-
-
Notifications
You must be signed in to change notification settings - Fork 285
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
[FEATURE REQUEST] allow $schema #377
Comments
Hi @ripienaar , thanks for bringing this up! This is excactly the problem I'm currently facing as well. I've prepared this commit as an example how this could be solved at the JSON Schema document level: https://github.com/I522722/asyncapi/commit/dede4318a3425e5541a47832bf2cd87147508f1f Probably we can make the following distinctions for solving this problem:
|
For others interested in this topic. There is a lot of clarification here https://asyncapi.slack.com/archives/C34F2JV0U/p1588926494498200 |
For the simplest intermediary solution, we could just add "$schema": {
"type": "string",
"format": "uri",
"description": "The $schema keyword is used to declare that this JSON document is validated against the JSON Schema of the AsyncAPI 2.0.0 Specification. Adding this allows for automated tool support and code intelligence. See https://json-schema.org/understanding-json-schema/reference/schema.html"
} This would be a very quick fix to enable the use case. There could be a follow-up issue whether this should be taken up to be more explicitly supported and e.g. the Schema officially published at a schema registry. @derberg What's your oppinion on it? I could create a PR for just this change. Or do you want to discuss it further / go for a more complete solution right from the start? |
@I522722 Hi Simon. It is a spec we are talking here about so quick fix is not something that will be quick :) I mean that quick fix will land quickly in the There is one thing I started to think about. And I was thinking that So basically have a @ripienaar @I522722 what do you think about it? Or maybe there is some service like this for schemas that is giving what we need 🤔 |
Hi @derberg , yes, quick was definately the wrong word for it. I wasn't expecting a quick release of this in any way :) Let me rephrase it to: uncomplicated to add and without the introduction of breaking changes. This is an interesting point you make here. You could definitely get at least some analytics - but it's probably very hard to guess how big the percentage of tools is that would actually resolve this URI. It's good that you are transparent about the implications 👍 There is already a service for this, but I'm not sure whether it provides analytics that are available. If it uses a CDN for static file hosting this is most likely not the case. See https://github.com/SchemaStore/schemastore The question then is whether this property should be mandatory then. If you make it mandatory AND add a If you keep it optional, my guess is that most people would not understand it or the usefulness of it. But those who do can easily add it and enjoy the benefits and there is no need to introduce a breaking change to the spec. |
Hey @I522722, IntelliJ and VSCode support Even though the possible analytics info we could get from |
Hi @derberg , thanks for the update! Sounds reasonable :) Regarding the editor support of Schemastore: It would be interesting to know if this support is automatic or is used on a case-by-case basis. If the $schema is not explicitly stated in a .json file, there would need to be some clear mapping between the schemastore schema and the file is actually validated against. Most likely, each editor or editor extension will have a certain ruleset for this? But if AsyncAPI is added in schemastore, it will have the public visibility so it is more likely to be considered for such rules. Btw. a nice extension to bring Schema support for YAML is this one: https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml Since you can have a per-project config for this extension, you can define those rules (which file matches a schema) there via configuration yourself. E.g. "yaml.schemas": {
"http://json.schemastore.org/composer": ["/*"],
"file:///home/johnd/some-schema.json": ["some.yaml"],
"../relative/path/schema.json": ["/config*.yaml"],
"/Users/johnd/some-schema.json": ["some.yaml"],
} This is an interesting discussion 👍 If I may come back to my original suggestion and the motivation behind it: The "minimal" solution that would enable those use cases for me is that |
I asked a few questions to the schemastore community -> SchemaStore/schemastore#1048. This looks very awesome. We can store schema on our servers and do our analytics if we want, and at the same time we can register schema at the schemastore and point to our servers and it will work like a charm. Once we enable above, I don't see really why would one need Don't you think it is actually enough to have schemastore setup in place? |
I am confused. How you did not find any? Even JSON Schema lets you add it to tell editors and tools what the authored document comply to. It’s a common case and the reasons JSON Schema allows it is the same as why it would be allowed here. |
ok, JSON Schema of course allows, this is the only one that was pretty obvious for me and I didn't mention it, for me it is an exception that just confirms what I wrote. Json Schema for OpenAPI also doesn't support it and also disallows additional properties |
Does AsyncAPI dictate the file name for a api description so it would be compatible with file match? Documentation says it’s by convention. |
No, it doesn't, we would probably have to do something like openapi
|
On the other hand, if we allow |
Yes, I'd be highly in favor of this. Currently, it's not really possible to define $schema explicitly. But I'm rather sure that Schemstore support doesn't come automatically active the moment you add your schema there. Having this explicit My PR proposal would have added $schema at least as a known property so it may be explicitly added without it immediately marking itself as invalid. Whitelisting all It's also from JSON Schema side a best practice if I interpret it correctly? At least JSON Schema always states its |
This issue has been automatically marked as stale because it has not had recent activity 😴 |
I'm in progress with AsyncAPI schema store, hope to have something working this year |
Is your feature request related to a problem? Please describe.
When editing AsyncAPI documents it would be useful to allow $schema since modern IDEs will do code completion etc based on whats valid in the schema.
Can't it be tackled using specification extensions?
nope
Describe the solution you'd like
Allow $schema key in the top level.
Describe alternatives you've considered
Manual editing of IDEs, not nice.
Additional context
Publishing the schemas on well known URLs would be good if not already.
The text was updated successfully, but these errors were encountered: