Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Distinguish expandability for a collection vs expandability for an item within a collection #399

Open
ralfhandl opened this issue Mar 20, 2024 · 2 comments
Assignees

Comments

@ralfhandl
Copy link
Contributor

Gareth Jones opened [https://github.com/oasis-tcs/odata/issues/12:]

It's very useful to be able to distinguish capabilities of a single entity in a collection vs the capabilities of a collection.

This is embodied in ReadRestrictions vs ReadByKeyRestrictions for support for GET foos vs GET foos/{fooId}

In practice we've found that implementing $expand on a single entity is frequently cost-effective, whereas implementing it across a whole collection is not. Consequently we'd like to be able to qualify ExpandRestrictions with something akin to an ExpandByKeyRestrictions.

A cheap and cheerful variant of this would be a boolean control flag in ExpandRestrictions, but it misses the possibility that the expandable set of nav properties varies between single/collection.

For clarity, we need a vocabulary annotation that allows us to express

  1. NOT Supported: GET /foos?$expand=bars
  2. Supported: {{GET /foos/{fooId}?$expand=bars}}

Another issue of ExpandRestrictions is ODATA-1502.

Imported from ODATA-1639

@garethj-msft
Copy link

@ralfhandl @mikepizzo we'd really like to see this in 4.02 for Microsoft Graph

@mikepizzo
Copy link
Contributor

Proposal:
Define a ExpandByKeyRestrictions on the existing ExpandRestrictionsType; anything not specified in the ExpandByKeyRestrictions would be inherited from the parent ExpandRestrictions.

@ralfhandl ralfhandl moved this from Open to Resolved in OData TC Nov 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Resolved
Development

No branches or pull requests

3 participants