-
Notifications
You must be signed in to change notification settings - Fork 25
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
Support for subschemas and references #5
Comments
Thanks for the report! I think there may be some fundamental issues here with using JSON Schema as a schema definition language. We chose it because it was convenient to use an existing standard with tooling, but I'm not sure the needs always align with what we need in Cambria. I think your proposed fix seems reasonable, especially since it's similar to how we handle anyOf. But what about a case where multiple subschemas match because they contain overlapping parts? Might it make sense to update more than one? I'm not sure there's really an obvious answer. As a short term thing, I'm open to adding more functionality that handles these cases better, and hopefully we can also do a better job documenting too. One tool that seems potentially very helpful is this library from cloudflare, which handles 1) dereferencing refs, 2) collapsing allOf into a single schema. That seems like it might take care of your immediate issues -- would you have any interest in trying out that tooling? It seems like potentially you could just preprocess the schema through that, and then use cambria as-is. Bigger picture, I think it could be reasonable to designate a subset of JSON Schema supported by Cambria. I think the core data definition parts are good, and features like refs probably make sense, but not sure that allOf is really a feature that makes sense for this use case. |
Ah, good to know. So I take it you're much more interested in deriving type declarations for TypeScript? For us, JSON Schema is a core requirement, because it's how we determine the schemas supported by the server, and we need that in some serialized format that can be determined at runtime. Although I'd be open to exploring alternatives to JSON Schema.
Exactly, there's a lot of complexity I haven't even begun to touch. Which is why I'm not sure I want to pursue this "naive" approach much further than I have so far.
Oh great, that looks like a promising library. And yea, I think it could make most sense to preprocess the schemas like you say. I think we can safely make some assumptions that should keep it simple enough, since like I said, there's really just one schema in that As for bigger picture, that all sounds good to me. Good to know it's probably not in scope for Cambria to provide full support for the entire JSON Schema spec, and I think we can work around that. |
I ran into some errors trying to update a schema that had subschemas using the
allOf
keyword. The schema I was trying to update can be seen here.I've implemented a naive fix that strictly addresses this problem for my use case, but then I run into the problem that
$ref
's are not yet supported. I dug around a bit and found a mention of this issue in #1 (comment), and I assume this is still the status, as @geoffreylitt mentioned there:So I guess I'm wondering if there have been any further decisions or discussion about how this will move forward, and whether contributions would be considered. If so, I'd be happy to lend a hand.
For my own use case, it's fairly trivial to just pull out the only
allOf
schema that's really significant (frankly, it's annoying it's there at all), and then "dereference" my schema definitions as normal properties. I'm already doing so in my demo repo. So I have a workaround. But I figured it could be useful to document here, and I appreciate any updates if and when there is progress on these features.The text was updated successfully, but these errors were encountered: