-
Notifications
You must be signed in to change notification settings - Fork 683
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
[css-mediaqueries] Should prefers-color-scheme in SVG images be context-dependent? #7213
Comments
cc #6988 which is somewhat related. |
Yeah, so basically you're asking if the used color scheme should automatically inherit into nested documents. That's a communication bit, which we try to avoid adding for cross-origin stuff, at least. (#6988 would allow passing the color-scheme in purposely, if both the outer and inner page successfully handshaked.) |
Right. My reasoning for doing this for SVG images is that they cannot run script, etc, so it's a much more limited environment. But I guess you're right that they could trigger different image loads to exfiltrate that bit, potentially. For the record, Gecko does inherit the color scheme into some frames (so that e.g., extension setting popups behave correctly if you have a dark Firefox theme but a light content theme). This is not exposed to regular |
The comment: #7213 (comment) confused me a bit since @emilio's example affects the preferred color-scheme, not the used color-scheme or color-scheme property directly. This is about changing the preferred color-scheme in the SVG and the SVG root color-scheme would not be affected in another way than through the preferred color-scheme, right? |
Yeah, that's right. |
The CSS Working Group just discussed
The full IRC log of that discussion<fantasai> topic: [css-mediaqueries] Should prefers-color-scheme in SVG images be context-dependent?<fantasai> github: https://github.com//issues/7213 <fantasai> emilio: We got an interesting bug report in Firefox <fantasai> emilio: When you have a Firefox theme that's dark, but OS theme is light <fantasai> emilio: sites can't choose a reasonable favicon for dark mode <fantasai> emilio: Suggestion is to make preferred-color-scheme for SVG images reflect the used color scheme <fantasai> emilio: Then could have light+dark icons anywhere in your page, and then as long as your parent has the correct color-scheme will display correctly <fantasai> emilio: Maybe worth making this more general <fantasai> emilio: Tab seemed to have some reservations <fantasai> TabAtkins: This makes a cross-origin communication bit, and we try to restrict those <fantasai> TabAtkins: use case makes sense <fantasai> TabAtkins: Just one more bit that you can use to talk to an iframe, and every bit counts <fantasai> TabAtkins: but if that's considered not too much of a problem, then I'm fine with it <fantasai> emilio: It's a communication channel in the sense that the SVG could request a different image or something <fantasai> emilio: but SVG images don't run script <fantasai> emilio: I think Chrome did something like this for iframes, don't know the details of that <futhark> q+ <fantasai> emilio: If your iframe is in color-scheme: ? then you force a light background <fantasai> futhark: Behavior for ?? is specified in the spec, that you set the background of the iframe if 'color-scheme' doesn't match parent <fantasai> futhark: so you don't wind up with black on black or white on white <TabAtkins> s/??/iframes with different color scheme than parent document/ <fantasai> futhark: Wanted to ask, has anyone asked for similar functionality for iframe? <emilio> q+ <fantasai> futhark: or will there be other cases? <Rossen_> ack futhark <fantasai> futhark: other than SVG <Rossen_> ack fantasai <Zakim> fantasai, you wanted to ask why not restrict cross-origin <fantasai> fantasai: If the concern is cross-origin, why not restrict to same-origin <fantasai> emilio: Possible, but maybe awkward <fantasai> emilio: wrt Rune's question, we actually do that for some frames <fantasai> emilio: e.g. for extension popups in Firefox, they're just iframes inside a popup <fantasai> emilio: we make those inherit the color scheme of Firefox in a similar fashion <fantasai> emilio: so we already have this code to make it work for iframes <fantasai> futhark: We do something similar for <select> popups in Chrome <fantasai> futhark: If you have <select> with a color scheme, that affects the drop-down render <fantasai> emilio: This seems generally a useful thing then <fantasai> emilio: Main question is whether it's reasonable, given the issue Tab mentioned <fantasai> emilio: I'm not sure I'm the right person to make that assessment <fantasai> emilio: What about we ask people in privacy/security what they think about this? <fantasai> emilio: If we accept it, then we can consider doing iframes as well <fantasai> Rossen_: seems like a reasonable path forward <fantasai> Rossen_: I think general consensus of the group leans towards the proposal <fantasai> Rossen_: pending feedback from Security folks <fantasai> Rossen_: So my proposal is to end the discussion here, and then get back to it as we gather more information <TabAtkins> Always useful to resolve, if for no other reason than to have a neat conclusion easy to read at the end <fantasai> fantasai: Could resolve that we want to do this, if reasonable from security standpoint <fantasai> Rossen_: Any objection to record this as consensus of group? <fantasai> PROPOSAL: Have prefered-color-scheme reflect 'color-scheme' on the element in the embedding document, to the extent acceptable from security standpoint <fantasai> RESOLVED: Have prefered-color-scheme reflect 'color-scheme' on the embedding element in the embedding document, to the extent acceptable from security standpoint (pending security review) |
I just realized that in non-Gecko browsers, this bit of information is already passed down to the right process due to #4772. |
…lor schemes. r=jwatt In the future we might want to (also?) propagate the prefers-color-scheme on the iframe like we do for the content/chrome boundary / top browsing contexts, see: * w3c/csswg-drafts#4772 * w3c/csswg-drafts#7213 Differential Revision: https://phabricator.services.mozilla.com/D146162
…lor schemes. r=jwatt In the future we might want to (also?) propagate the prefers-color-scheme on the iframe like we do for the content/chrome boundary / top browsing contexts, see: * w3c/csswg-drafts#4772 * w3c/csswg-drafts#7213 Differential Revision: https://phabricator.services.mozilla.com/D146162
Bringing this up again because I was working on this in https://bugzilla.mozilla.org/show_bug.cgi?id=1738380, and I realized that there's no way to guarantee a transparent background of an iframe without hard-coding the color-scheme. That is: an iframe with That's a bit unfortunate, there's a variety of regressions from my work that would ideally be fixed by just having @smfr / @lilles / @tabatkins, is there any chance you could ping some of the WebKit / Blink security folks about this (since that's the major concern here)? I'll do the same for Mozilla's security folks, but my guess is that since the relevant information is already in the target process, it's not really a big leak... |
Would this affect SVG images used as CSS |
Probably? |
It looks like no browser allows an SVG image to load subresources, so maybe this isn't a problem? |
Maciej pointed out that the HTML spec doesn't actually say that SVG images use "Secure Animated Mode", and that HTML probably needs a central place to define valid image resources as "a non-interactive, optionally animated, image resource that is neither paged nor scripted." https://html.spec.whatwg.org/#image-button-state-(type=image) says "User agents must only display the first page of a multipage resource. User agents must not allow the resource to act in an interactive fashion, but should honor any animation in the resource." but this text should be generalized and shared with things like video poster images in the spec. If it's clear that SVG images are in "Secure Animated Mode", then I think WebKit is ok allow color-scheme to propagate in. |
The CSS Working Group just discussed
The full IRC log of that discussion<fantasai> Topic: [css-mediaqueries] Should prefers-color-scheme in SVG images be context-dependent?<fantasai> github: https://github.com//issues/7213 <fantasai> emilio: I did check with the security folks at MOzilla, and they weren't concerned about making this apply even more generally to iframes <fantasai> emilio: Only attack is if a page is in an iframe and a top-level frame, can determine ??? <fantasai> emilio: But no problem for SVG images <fantasai> emilio: I think it'd be nice to do it for iframes as well <fantasai> emilio: My discussion with them was that it's not a big concern, idk if other folks have an opinion <fantasai> smfr: On the WebKit side would be much more reluctant to do on iframes, but OK for SVG images <fantasai> smfr: Was having trouble finding text in HTML spec that SVG couldn't run script or load external images <fantasai> smfr: so part of this issue needs to clarify when SVG can load external resources or run script <chris> q+ <fantasai> emilio: Why reluctant to make it work on iframes? <fantasai> emilio: We already communicate info about backgrounds <fantasai> smfr: I'd have to go back and ask the security ppl <astearns> ack chris <fantasai> chris: SVG images in <img> tag don't run scripts or fetch resources <dholbert> smfr: RE where it's defined that SVG Images don't run scripts, that's defined in https://svgwg.org/specs/integration/ <fantasai> chris: if they are in <object> they can fetch and run script <fantasai> chris: It's not a function of SVG, but function of SVG's integration in external environment and what it allows them to do <dholbert> see https://svgwg.org/specs/integration/#secure-animated-mode <fantasai> astearns: When in <object> ... <dholbert> "Secure animated mode" <fantasai> chris: They can do everything <fantasai> astearns: Are they SVG images? <fantasai> chris: Yes, just not using an <img> tags <smfr> dholbert: but HTML doesn’t reference that everywhere it needs to <fantasai> emilio: From implementation point of view, they are iframes <TabAtkins> (as far as I recall) Chrome is fine with passing into any SVG that can't fetch or run script (aka <img> tags), and same-origin iframes. <fantasai> chris: Also if displayed standalone, same thing <fantasai> chris: they can run scripts, fetch resources, etc. <TabAtkins> We just don't want to open up new cross-origin communication bits. <fantasai> emilio: Seems there would be no objection to doing on SVG images <fantasai> emilio: and maybe file an issue about iframes <fantasai> smfr: Sounds good <astearns> ack TabAtkins <fantasai> TabAtkins: from what I recall, Chrome is fine with this so long as it doesn't open up new cross-origin communication bits <fantasai> TabAtkins: So SVG as img should be fine <fantasai> TabAtkins: and same-origin iframe should be fine <fantasai> smfr: That matches WebKit's preference, too <fantasai> emilio: OK, then we can discuss iframes separately <fantasai> emilio: I'm more interested in this SVG case <fantasai> emilio: It's not easy for the iframe to tell where the preference comes from <fantasai> emilio: we can discuss another time <astearns> ack fantasai <Zakim> fantasai, you wanted to propose resolution <fantasai> fantasai: Seems we have consensus on SVG as <img> and also same-origin iframe <fantasai> ???: what about SVG's that are rendered through CSS? <fantasai> fantasai: There's an embedding mode for SVG that does this, so anything in that embedding mode <fantasai> astearns: Maybe let's take a resolution on SVG first <fantasai> emilio: draw background in iframes, that doesn't care about same vs cross-origin, so unsure how to do that <fantasai> astearns: proposed that prefers-color-scheme in SVG-images is context-dependent <fantasai> smfr: "SVG rendered in secure animated mode" <smfr> https://svgwg.org/specs/integration/#secure-animated-mode <fantasai> astearns: objections? <fantasai> RESOLVED: prefers-color-scheme in SVG rendered in secure animated mode is context-dependent <fantasai> Meeting closed. <astearns> zakim, end meeting <Zakim> As of this point the attendees have been flackr, bramus, emilio, dholbert, rachelandrew, argyle, dbaron, alisonmaher, TabAtkins, plinss, jfkthame, chrishtr, jensimmons, GameMaker, <Zakim> ... oriol, faceless, fantasai, bkardell_, dandclark, lea, bradk, tantek, hober <Zakim> RRSAgent, please draft minutes v2 <RRSAgent> I have made the request to generate https://www.w3.org/2022/07/13-css-minutes.html Zakim <Zakim> I am happy to have been of service, astearns; please remember to excuse RRSAgent. Goodbye |
As per discussion in w3c/csswg-drafts#7213. Differential Revision: https://phabricator.services.mozilla.com/D151751 bugzilla-url: https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 gecko-commit: 33fbecca098c163ff086113225f580d67a53c611 gecko-reviewers: aosmond
…on content too. r=aosmond As per discussion in w3c/csswg-drafts#7213. Differential Revision: https://phabricator.services.mozilla.com/D151751
As per discussion in w3c/csswg-drafts#7213. Differential Revision: https://phabricator.services.mozilla.com/D151751 bugzilla-url: https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 gecko-commit: 33fbecca098c163ff086113225f580d67a53c611 gecko-reviewers: aosmond
…on content too. r=aosmond As per discussion in w3c/csswg-drafts#7213. Differential Revision: https://phabricator.services.mozilla.com/D151751
…scheme of the embedding node for prefers-color-scheme. #7213
All right, embedded SVG text added to MQ5. Left a note about us still discussing this for iframes. |
We resolved for iframes in #7493 didn't we? |
Ah, we did! Thanks, I'll fix it up then. |
Closing this issue as the necessary edits have made it in. Added the necessary labels to #7493, which is concerned with the behavior for iframes. |
Note that due to https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 / w3c/csswg-drafts#7213, prefers-color-scheme works fine even if the user has an explicitly light theme or so.
Note that due to https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 / w3c/csswg-drafts#7213, prefers-color-scheme works fine even if the user has an explicitly light theme or so. This fixes mozilla#2583 too.
Note that due to https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 / w3c/csswg-drafts#7213, prefers-color-scheme works fine even if the user has an explicitly light theme or so. This fixes mozilla#2583 too.
Note that due to https://bugzilla.mozilla.org/show_bug.cgi?id=1779457 / w3c/csswg-drafts#7213, prefers-color-scheme works fine even if the user has an explicitly light theme or so. This fixes mozilla#2583 entirely.
WebKit, and thus Safari, does not inherit context like media query state from the site to an SVG image embedded in said site [0] even though the CSS Working Group decided that this should be done in secure context [1]. While I'd prefer the cleaner solution we will have a hard time arguing that WebKit, i.e., Apple is at fault here (because huge enterprisy companies certainly cannot be that...), so rework what we did in commits 2a81bf3 ("ui: use vectorized and natively color-scheme aware Proxmox logo") and 51ddc29 ("ui: make cpu and memory icons dark-mode aware") to a more legacy method by using CSS filter for icons and two versions of our logo. [0]: https://bugs.webkit.org/show_bug.cgi?id=199134 [1]: w3c/csswg-drafts#7213 (comment) Signed-off-by: Thomas Lamprecht <[email protected]>
Consider this test-case:
Right now the rendering of those images match in all browsers, but one could argue that perhaps they should render differently (top blue, bottom purple)?
See also https://bugzilla.mozilla.org/show_bug.cgi?id=1764354, which is what prompted this discussion.
cc @lilles @smfr
The text was updated successfully, but these errors were encountered: