Skip to content
New issue

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

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

Already on GitHub? # to your account

feature idea: versioning #216

Open
jtmarmon opened this issue May 20, 2015 · 3 comments
Open

feature idea: versioning #216

jtmarmon opened this issue May 20, 2015 · 3 comments

Comments

@jtmarmon
Copy link

It would be cool to have schemas have optional versioning, so if I decide to make breaking changes to an API, the schema can still be coerced properly for clients requesting the old version. Not sure exactly what this would look like but I think it would be quite handy.

@w01fe
Copy link
Member

w01fe commented May 21, 2015

Thanks for the request. I'm not sure it makes sense for versioning to be built into schema, but potentially can be a layer built on top. For example, we've thought about (but not yet implemented) extensions to fnhouse that allow you to declare different coercions for different data versions, which could transparently manage the coercion to the latest version for you. Is this the sort of thing you're looking for?

@jtmarmon
Copy link
Author

Yep coercion is the main consideration here. Why would this be a feature in fnhouse, though? Isn't coercion a function of the schema library?

I definitely think some kind of integration with fnhouse would be useful - maybe if API versioning was added to fnhouse you could tie the coercion functions to the API versions

@w01fe
Copy link
Member

w01fe commented May 21, 2015

I suppose you're right that versioning could be useful outside of fnhouse, but I still think it's probably possible to do as a layer on top of the existing primitives. It seems like the tricky questions might revolve around nesting, and whether subschemas are versioned together or independently. If there are concrete proposals, we'd love to listen/look at them and consider for inclusion. Thanks!

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants