-
Notifications
You must be signed in to change notification settings - Fork 56
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 $schema in manifest.json #507
Comments
This is likely a Chrome only issue, since Safari allows it and I think Firefox is lax about unknown manifest keys as well. |
I think this key is straight out rejected by the store actually. For the first time I tried it last week and the store rejected my first zip upload. I removed the key and it worked. |
@fregante, which store are you referring to? |
Chrome Web Store |
@fregante Just tested in Chrome. Loading an extension with a |
I'm still getting the warning here. Which Chrome version are you using? I'm
using Chrome Version 120.0.6099.199 (Official Build) (64-bit) on Ubuntu:
"*
…On Thu, Jan 4, 2024 at 1:53 PM carlosjeurissen ***@***.***> wrote:
@fregante <https://github.com/fregante> Just tested in Chrome. Loading an
extension with a $schema property seems to work fine. So it seems a
Chrome Web Store only issue.
—
Reply to this email directly, view it on GitHub
<#507 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ABKED7MKMT73ACAFF4COUFLYM3NBXAVCNFSM6AAAAABAVL77TCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTQNZXGQ2DAMZXGM>
.
You are receiving this because you authored the thread.Message ID:
***@***.***>
|
A warning is not a fatal error. |
I think we're discussing two different issues here, this thread is originally about removing the warning about this manifest key that appears when clicking on the "Errors" button in chrome://extensions page. @fregante mentioned another issue about Chrome Web Store rejection, maybe we could create a new thread for that to avoid confusion? |
I think the issue is the same: officially recognizing and allowing the $schema property. Having the browser not warn but then the store reject the extension is worse. The store must accept the property before the browser removes the warning. |
That makes sense @fregante. However, it seems like the meeting attendees didn't understand it that way. Quoting the meeting notes:
That isn't the main request. It's treating it as a recognized/supported key instead (both in the browser by removing the warning and in the Chrome Web Store by not letting it be rejected) |
@lucasrmendonca thanks for checking the notes! We are saying the same thing, though. As this is the WECG, there is nothing to do with the Chrome Web Store. So the relevant request here is for it to be recognized in Chrome. This means removing the hard error. |
@patrickkettner I see, maybe the confusion is related to calling it a hard error instead of a non-fatal warning? Judging by @carlosjeurissen and @Rob--W replies, it seems like they were expecting the extension to not work properly in Chrome when using the $schema key, which was never a problem |
Apologies. There is confusion on verbiage. I was under the impression that when If not, then we can close this and I will open a bug with the Chrome Web Store team internally to allow it. |
It would be great for the WECG to standardize it since having manifest.json type-checking:
If the WECG decides it's still not useful enough it to become a standard, I'm happy with at least not discouraging it by removing the warning in Chrome... |
What is the specific request? What is the thing you want produced by the WECG as a result of this bug |
Removing the warning for this key in Chrome and opening a bug with the Chrome Web Store team internally to allow it |
WECG could formally recognize and allow the field, so that Chrome and other implementor don't risk rejecting it. If WECG rejects that, then it's just a "bug" that should be reported to Chrome. |
@lucasrmendonca the only member of the WECG that shows a warning is Chrome. The WECG doesn't have a specification for the manifest file at the moment, so beyond the agreement to what browsers are already doing, there doesn't seem to be a conversation to be had. As for the Chrome Web Store bug, it is outside of the scope of the WECG, so it wouldn't be related to wether or not it remains open @fregante what do you mean by formally recognize? What does that actually, concretely, mean? To be clear, I am a representative of Chrome, as is Oliver. We aren't rejecting it. The WECG isn't rejecting this issue as of now, but it isn't clear what is being requested. |
@patrickkettner I thought the specification for the manifest file and its allowed keys was part of the WECG scope. It seems like something that should be agreed across all browsers instead of dealt on a per-browser basis (let me know if I'm wrong here). Are you suggesting we move this discussion to somewhere else that involves only Chrome since it's the only browser that displays the warning for |
I'm not sure how detailed you want my request to be. Do "Web Extensions" have a specification? Is it this one? If so, WECG should mention and define Whether other browsers already allow it is irrelevant here; they could, at any time, stop allowing it, because nobody cared to include it in the specification. And if Chrome doesn't allow it, why should they? |
The correct URL is https://w3c.github.io/webextensions/specification/ ("browserext" is not relevant and obsolete).
You have expressed a request to specify a new key in the manifest.json file, seemingly primarily motivated by the presence of an error message in Chrome. What other browsers do IS relevant, because as of now it looks like a Chrome-only issue. There is consensus among browser vendors to make sure that unrecognized keys should not prevent extensions from loading. A key being unrecognized should not be a problem. If it was, we'd like to understand why, in order to work towards a resolution. After all, we recognize that unsupported keys exist, and that their presence in a manifest should not cause serious issues. It would be helpful if you state more clearly why the presence of a non-fatal warning is an issue to you. There is already a request on Chrome's issue tracker about removing the warning for some unsupported keys, but with little progress and the why-question being unanswered, at https://crbug.com/1246358 |
In the meeting, I definitely thought the report was that this was a hard error. With that not being the case, I think the importance of this fix is a little diminished, but I still appreciate @lucasrmendonca's perspective that it would be nice to avoid warnings for some keys that developers may wish to use despite there being no special handling in the browser for them. I've left a comment on the bug to that effect which is likely the best place to continue this part of the discussion. I tried reproducing the issue in the web store but wasn't able to. Can anyone still reproduce that? As @patrickkettner said one of us would be happy to raise that with the team if we can find any issues. Finally, for standardisation, I think having a "these keys are not used but browsers should ignore them" section in the spec we would like to eventually write would be nice. The specification is so bare bones right now though that I'm not sure there is any action item to take today unless someone wants to try drafting that (and we would need to discuss as a group if we actually want to merge something like that). |
I tried uploading the extension I had issues with and I wasn't able to see the issue either. It's strange because my upload last month failed and it resolved after I dropped $schema. Might have been a coincidence. Sorry for the noise. Just for reference, here's the successful upload with $schema: https://github.com/w3c/webextensions/assets/1402241/bd216da2-dc40-49d2-b8c4-fa48c112fb46
💙 👍 That sounds perfect. Maybe they could be a list of "reserved" or "private" list of keys. |
We discussed this in an in-person meeting at TPAC 2024 (#659). Since Related, I also raised the same issue about Oliver is starting a patch for |
These keys are widely adopted and are understood to not have special behavior in Chrome. Therefore, don’t generate manifest warnings if these keys are specified. This was agreed on in the WebExtensions Community Group: w3c/webextensions#507 Bug: 40196501 Change-Id: Ia6d14031e6f4af6b8c7672a6f368685a2a9cdcbd Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5889684 Reviewed-by: Devlin Cronin <rdevlin.cronin@chromium.org> Commit-Queue: Oliver Dunk <oliverdunk@chromium.org> Cr-Commit-Position: refs/heads/main@{#1361955}
Starting in Chrome 131, the You can see the schedule for rollout here. |
Is it possible to allow the $schema key in manifest.json as a valid optional key?
Currently, some editors such as VSCode allow for type-checking json files by using the $schema key. This is particularly useful for beginners and for folks migrating their manifests from version 2.0 to 3.0 since it gives out squiggly lines if you mistype something in your json file. Tools such as Cspell and Knip even provide the $schema key by default in their docs.
When I tried using
"$schema": "http://json.schemastore.org/chrome-manifest"
in manifest.json, although type-checking worked fine, when loading the extension to the browser, an Error appears: Unrecognized manifest key '$schema'.This message doesn't stop type-checking from working, but it creates a persistent "Errors" button at chrome://extensions page for our users, which isn't desirable. If possible, allowing it to be a valid optional key would be great.
The text was updated successfully, but these errors were encountered: