Closed Bug 1970075 Opened 5 months ago Closed 4 months ago

browser.notifications.create() no longer displays icons when using data: URLs (base64-encoded images)

Categories

(WebExtensions :: General, defect)

Firefox 139
defect

Tracking

(firefox-esr115 unaffected, firefox-esr128 unaffected, firefox-esr140 verified, firefox139 wontfix, firefox140 wontfix, firefox141 verified)

VERIFIED FIXED
141 Branch
Tracking Status
firefox-esr115 --- unaffected
firefox-esr128 --- unaffected
firefox-esr140 --- verified
firefox139 --- wontfix
firefox140 --- wontfix
firefox141 --- verified

People

(Reporter: firefoxbugs, Assigned: robwu)

References

(Regression)

Details

(Keywords: regression, Whiteboard: [addons-jira])

Attachments

(5 files, 1 obsolete file)

User Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:139.0) Gecko/20100101 Firefox/139.0

Steps to reproduce:

Run in webextension
browser.notifications.create({
type: "basic",
iconUrl: "",
title: "Test Notification",
message: "This notification should have an icon."
});

Load the extension temporarily (about:debugging → "This Firefox").

Trigger the background script.

Actual results:

The notification appears without any icon — the iconUrl is silently ignored.

No errors are thrown, but the image is never rendered.

Expected results:

The notification appears with the icon correctly rendered from the base64 data: URL.

This behavior previously worked with Firefox 138 as expected and is still documented as valid.

Hello,

I could not reproduce the issue on the latest Nightly (141.0a1/20250604183413), Beta (140.0b5/20250604091121) or Release (139.0.1/20250529122813) under Windows 11 and Ubuntu 24.04 LTS.

In Comment 0, you mentioned to load “the extension temporarily” but there is no extension attached. So I installed an extension which I know sends notifications from the OS - https://addons.mozilla.org/en-US/firefox/addon/s3download-statusbar/.

With the extension installed, I ran the code in the extension console and the notification that popped up had an icon. See attached screenshot.

I’ve also installed the same extension temporarily via about:debugging and ran the code in the extension console again. Same results as above i.e. the notification that pops up has an icon.

Did you use a specific extension when uncovering this? It would maybe help to link to it, or attach it here so I can test it out as well.

Attached image 2025-06-05_10h06_35.png

Sorry, forgot to mention that it's only with alerts.useSystemBackend = false
With alerts.useSystemBackend = true icon shows up.

Attached image Clipboard Image (1).jpg

Thank you for the additional info !

Rechecked with alerts.useSystemBackend = false and indeed, the notification does not have an icon in this case.

Status: UNCONFIRMED → NEW
Ever confirmed: true

This is because CSP for alerts.xhtml is too restrictive:
img-src chrome: resource: https:

https://searchfox.org/mozilla-central/rev/b6a437e0e51dbbfa65f07ee4e1db3864624ab5ea/toolkit/components/alerts/alert.xhtml#6

The documentation states:

https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/notifications/NotificationOptions#iconurl
The URL can be: a data URL, a blob URL, a http or https URL, or the relative URL of a file within the extension.

In practice the validation is nearly non-existent; The implementation accepts any string input, and if it is a relative URL, it converts it to a moz-extension:-URL. Otherwise (if the URL is absolute), it is accepted as is.

In any case, we should expand the img-src CSP directive in alerts.xhtml to also include http: data: blob:.

Component: Untriaged → General
Keywords: regression
Regressed by: 1958802

:simonf, since you are the author of the regressor, bug 1958802, could you take a look? Also, could you set the severity field?

For more information, please visit BugBot documentation.

Flags: needinfo?(sfriedberger)

I'll fix this (trivial) and add a unit test (bit more work).

Assignee: nobody → rob
Flags: needinfo?(sfriedberger)
Whiteboard: [addons-jira]
Attachment #9494537 - Attachment is obsolete: true
Status: NEW → RESOLVED
Closed: 4 months ago
Resolution: --- → FIXED
Target Milestone: --- → 141 Branch

The patch landed in nightly and beta is affected.
:robwu, is this bug important enough to require an uplift?

For more information, please visit BugBot documentation.

Flags: needinfo?(rob)

It's RC week for Beta, so I'm not going to uplift this bug to Beta.

It is a regression affecting users who have turned on a non-default feature. The impact is the icon not displaying in notifications.

I'll let it ride the train, and uplift this to ESR140 aligned with the 141 release, so that the regression does not persist for a long while on ESR140.

Flags: needinfo?(rob)

firefox-esr140 Uplift Approval Request

  • User impact if declined: Custom icons not displaying in desktop notifications created by extensions, when alerts.useSystemBackend = false (regression in version 139, fix landed in 141)
  • Code covered by automated testing: yes
  • Fix verified in Nightly: yes
  • Needs manual QE test: no
  • Steps to reproduce for manual QE testing: QA not needed; fully covered by automated tests.
  • Risk associated with taking this patch: Low
  • Explanation of risk level: Relaxes the overly strict CSP in desktop notification windows that was added in 139. This fixes an issue without causing new ones, and is verified by unit tests. This only changes the img-src CSP directive, the more security-relevant script-src directive is not touched
  • String changes made/needed: None
  • Is Android affected?: no
Attachment #9494919 - Flags: approval-mozilla-esr140?

Verified as Fixed. Tested on the latest Nightly (141.0a1/20250616214059) under Windows 11 and Ubuntu 24.04 LTS.

With alerts.useSystemBackend = false and using the STR from Comment 0 + the extension from Comment 2, the notification that pops up now has an icon. See attached screenshot.

Status: RESOLVED → VERIFIED
Attached image 2025-06-17_15h18_31.png
Attachment #9494919 - Flags: approval-mozilla-esr140? → approval-mozilla-esr140+

Verified as Fixed. Tested on the latest ESR (140.1.0esr/20250702122229 from https://treeherder.mozilla.org/jobs?repo=mozilla-esr140&revision=d18e8127f8f4d4fc4d9e4ee6f1a1a66965201154 – Build linked in Comment 20).

With alerts.useSystemBackend = false and using the STR from Comment 0 + the extension from Comment 2, the notification that pops up has an icon, confirming the fix.

You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: