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

Should we allow multiple path segments or @key properties in a model definition? #160

Closed
markcowl opened this issue Jan 10, 2022 · 5 comments
Assignees
Labels
design:accepted Proposal for design has been discussed and accepted. triaged:core

Comments

@markcowl
Copy link
Contributor

markcowl commented Jan 10, 2022

This came up as part of #110

Currently, multiple path segments designated on a model is disallowed. Is there a need to allow multiple path segments for a key:

  • For composite keys (i.e. when there are multiple keys, but no parent resource)
    • possible example: Compute VM Gallery
    • How do we express ordering in the path segments without a route string (for autoroute)?
  • If there are alternate paths to accessing the resource
    • this is a common pattern for ODATA APIs

Additionally, should we separate '@key' from path segments, and should we allow multiple `@key' properties in a model

  • This comes up in arrays of complex types. The 'id' of a particular instance may be made up of multiple properties (e.g. firstName, lastName)
    • should we allow this
    • Is there any important ordering in keys (last name, first name, for example) that we want to preserve?
@markcowl markcowl added the design:needed A design request has been raised that needs a proposal label Jan 10, 2022
@markcowl markcowl added this to the Backlog milestone Jan 10, 2022
@markcowl markcowl changed the title Should we allow multiple @key properties in a model definition? Should we allow multiple path segments or @key properties in a model definition? Feb 23, 2022
@markcowl markcowl self-assigned this Mar 28, 2022
@markcowl markcowl modified the milestones: Backlog, [2022] May Apr 12, 2022
@markcowl markcowl modified the milestones: [2022] May, Backlog May 11, 2022
@markcowl markcowl modified the milestones: Backlog, [2023] June May 1, 2023
@markcowl markcowl modified the milestones: [2023] June, Backlog Jun 6, 2023
@markcowl markcowl removed their assignment Jun 6, 2023
@markcowl markcowl modified the milestones: Backlog, [2023] December Nov 6, 2023
@markcowl
Copy link
Contributor Author

markcowl commented Nov 7, 2023

potential solutions

  • empty parent resource

@markcowl
Copy link
Contributor Author

markcowl commented Nov 7, 2023

Thgis sprint:

    • links to specs with this issue

@markcowl markcowl modified the milestones: [2023] December, Backlog Nov 7, 2023
@markcowl markcowl self-assigned this Nov 7, 2023
@markcowl markcowl modified the milestones: Backlog, [2023] December Nov 7, 2023
@markcowl markcowl removed their assignment Jan 29, 2024
@markcowl
Copy link
Contributor Author

Need to collect data on how many specs would benefit from this

@timotheeguerin
Copy link
Member

@markcowl
Copy link
Contributor Author

@markcowl markcowl added design:accepted Proposal for design has been discussed and accepted. and removed design:needed A design request has been raised that needs a proposal labels Nov 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
design:accepted Proposal for design has been discussed and accepted. triaged:core
Projects
None yet
Development

No branches or pull requests

4 participants