Closed Bug 1912340 Opened 5 months ago Closed 5 months ago

In extensions, dataTransfer.getData returns empty String instead of data when dragging across windows

Categories

(Core :: DOM: Copy & Paste and Drag & Drop, defect)

Firefox 129
Desktop
All
defect

Tracking

()

RESOLVED FIXED
131 Branch
Tracking Status
firefox-esr115 --- unaffected
firefox-esr128 --- fixed
firefox129 --- wontfix
firefox130 + fixed
firefox131 + fixed

People

(Reporter: bobo1239, Assigned: handyman)

References

(Blocks 1 open bug, Regression)

Details

(Keywords: regression)

Attachments

(9 files)

2.71 KB, patch
Details | Diff | Splinter Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review
48 bytes, text/x-phabricator-request
Details | Review

User Agent: Mozilla/5.0 (X11; Linux x86_64; rv:130.0) Gecko/20100101 Firefox/130.0

Steps to reproduce:

Actual results:

The tab is cloned to the 2nd window.

Expected results:

The tab should be moved to the 2nd window. (removed from the original window)

Comment:

Note that this is a different bug than Bug 1911486. Firefox 128 behaves correctly but neither Firefox 129 nor a freshly built Firefox with https://phabricator.services.mozilla.com/D218667 applied (which fixes Bug 1911486) do. The relevant line in Sidebery is this one. The returned string from .getData('application/x-sidebery-dnd') is an empty string instead of something like {"type":1,"items":[{"id":2,"url":"about:newtab","title":"New Tab","parentId":-1,"container":"firefox-default"}],"windowId":36,"incognito":false,"panelId":"9tquD7XMOskZ","pinnedTabs":false,"x":58,"y":19} as when using Firefox 128. (The data is set here for completeness sake.)

The strange thing is that the correct string is returned in onDrop() and onDragEnd(). Just in onDragEnter() it is the empty string. I'm attaching a patch for Sidebery which adds some relevant logging in case that's helpful. (See here for dev instructions.) Remember to apply the fix for Bug 1911486 first.

Summary: dataTransfer.getData returns empty String instead of set data in `onDragEnter()` → `dataTransfer.getData()` returns empty String instead of set data in `onDragEnter()` when dragging across windows
Keywords: regression
Regressed by: 1893119

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

For more information, please visit BugBot documentation.

Flags: needinfo?(davidp99)

I can reproduce this as well, thanks. It looks like the it is in part a dual to the other issue, but there seems to be more to this than just that.

Assignee: nobody → davidp99
Flags: needinfo?(davidp99)

This comment assumes dom.events.datatransfer.protected.enabled=true. when
dom.events.datatransfer.protected.enabled=false (which matches the spec and is
not the default), the behavior is fine as-is.

Since bug 1871222 (by one perspective) moved drag sessions from PContents to
PBrowsers, we need to update permission handling for in-process "remote"
sessions (ones that started on one PBrowser and currently target another). When
the target and source are in the same process, they don't properly handle
privileged DataTransfer access. We are currently denying privileged access to
some in-process principals because we incorrectly use the system principal. The
system principal always happens to give the right result for out-of-process
remote sessions, which were the only kind that existed before bug 1871222.

This solution creates the "remote" DataTransfer with the correct (not system)
principal. However, this misses the case where two different browsers are at
the same location (same principal) -- each would incorrectly get privileged
access to the other's DataTransfer in a drag. We avoid that case by tracking
if the DataTransfer came from a drag that started outside of the target browser
and forbidding access to content (but not e.g. extended) principals, regardless
of subsumption.

Verify that DataTransfer is properly granted/restricted during DND operations
between different browsers.

This patch is separated from the previous to ease reading -- the code changes in
this patch are minor so the file split is mostly transparent. We also run the
test for dom.events.dataTransfer.protected.enabled = true. The test is split
into two to avoid timeouts.

Thank you for your work so far already. Just some quick comments:

  • In your first patch you mention that dom.events.datatransfer.protected.enabled=false is not the default but it actually seems to be? (both nightly and stable) Unless I'm missing something which is quite possible...
  • Are the current patches already supposed to fix the sidebery issue? Afaict I'm still observing it with a fresh Firefox build. (the issue from Bug 1911486 is resolved though)

(In reply to bobo1239 from comment #6)

Thank you for your work so far already. Just some quick comments:

  • In your first patch you mention that dom.events.datatransfer.protected.enabled=false is not the default but it actually seems to be? (both nightly and stable) Unless I'm missing something which is quite possible...

Thanks for catching that -- it was a typo.

  • Are the current patches already supposed to fix the sidebery issue? Afaict I'm still observing it with a fresh Firefox build. (the issue from Bug 1911486 is resolved though)

Yeah, I posted this prematurely. It seems the extension is requesting the data under a content principal instead of an extended one.

Summary: `dataTransfer.getData()` returns empty String instead of set data in `onDragEnter()` when dragging across windows → In extensions, dataTransfer.getData returns empty String instead of data when dragging across windows
Severity: -- → S2

No substantive changes. This avoids timeouts in automation.

Status: UNCONFIRMED → ASSIGNED
Ever confirmed: true
Blocks: 1882607
Pushed by daparks@mozilla.com: https://hg.mozilla.org/integration/autoland/rev/a6f49e7d3bbf Use correct principal for remotely dragged data-transfer contents r=m_kato https://hg.mozilla.org/integration/autoland/rev/17fa2e5dccdb Test DataTransfer access in synthesizeMockDragAndDrop r=m_kato https://hg.mozilla.org/integration/autoland/rev/238109e9e436 Run drag-drop test with dom.events.dataTransfer.protected.enabled true and false r=m_kato https://hg.mozilla.org/integration/autoland/rev/aa243ae27748 Further split up browser_dragdrop_[un]protected tests r=m_kato

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

  • If yes, please nominate the patch for beta approval.
  • If no, please set status-firefox130 to wontfix.

For more information, please visit BugBot documentation.

Flags: needinfo?(davidp99)

Comment on attachment 9418895 [details]
Bug 1912340: Use correct principal for remotely dragged data-transfer contents r=m_kato!

Beta/Release Uplift Approval Request

  • User impact if declined: Some broken drag-drop behavior in extensions. The bug was that extensions could not access some data that they previously could, when dragging from one window to another.
  • Is this code covered by automated tests?: Yes
  • Has the fix been verified in Nightly?: Yes
  • Needs manual test from QE?: No
  • If yes, steps to reproduce:
  • List of other uplifts needed: None
  • Risk to taking this patch: Low
  • Why is the change risky/not risky? (and alternatives if risky): This change should only affect the extension process. It's also contained -- all but one of the patches are test-only.
  • String changes made/needed: N/A
  • Is Android affected?: No
Flags: needinfo?(davidp99)
Attachment #9418895 - Flags: approval-mozilla-beta?
Flags: in-testsuite+

Comment on attachment 9418895 [details]
Bug 1912340: Use correct principal for remotely dragged data-transfer contents r=m_kato!

Approved for 130.0rc1. Thanks for all the added test coverage.

Attachment #9418895 - Flags: approval-mozilla-beta? → approval-mozilla-beta+

This comment assumes dom.events.datatransfer.protected.enabled=false. when
dom.events.datatransfer.protected.enabled=true (which matches the spec and is
not the default), the behavior is fine as-is.

Since bug 1871222 (by one perspective) moved drag sessions from PContents to
PBrowsers, we need to update permission handling for in-process "remote"
sessions (ones that started on one PBrowser and currently target another). When
the target and source are in the same process, they don't properly handle
privileged DataTransfer access. We are currently denying privileged access to
some in-process principals because we incorrectly use the system principal. The
system principal always happens to give the right result for out-of-process
remote sessions, which were the only kind that existed before bug 1871222.

This solution creates the "remote" DataTransfer with the "correct" (not system)
principal of its source content. However, this misses the case where two
different browsers are at the same location (same principal) -- each would
incorrectly get privileged access to the other's DataTransfer in a drag. We
avoid that case by limiting the change to extension processes. This means that
remote DataTransfers created in the extension process will check for protected
access using a principal check against the drag-source-element's principal but,
otherwise, DataTransfers will continue to use the system principal for the
check.

Original Revision: https://phabricator.services.mozilla.com/D219074

Attachment #9422893 - Flags: approval-mozilla-esr128?

Verify that DataTransfer is properly granted/restricted during DND operations
between different browsers.

Original Revision: https://phabricator.services.mozilla.com/D219075

Attachment #9422894 - Flags: approval-mozilla-esr128?

This patch is separated from the previous to ease reading -- the code changes in
this patch are minor so the file split is mostly transparent. We also run the
test for dom.events.dataTransfer.protected.enabled = true. The test is split
into two to avoid timeouts.

Original Revision: https://phabricator.services.mozilla.com/D219076

Attachment #9422895 - Flags: approval-mozilla-esr128?

No substantive changes. This avoids timeouts in automation.

Original Revision: https://phabricator.services.mozilla.com/D219548

Attachment #9422896 - Flags: approval-mozilla-esr128?

esr128 Uplift Approval Request

  • User impact if declined: breaks drag and drop in some extensions
  • Code covered by automated testing: yes
  • Fix verified in Nightly: yes
  • Needs manual QE test: no
  • Steps to reproduce for manual QE testing: n/a
  • Risk associated with taking this patch: low
  • Explanation of risk level: small change to principal passed for drag and drop
  • String changes made/needed: no
  • Is Android affected?: no
Attachment #9422896 - Flags: approval-mozilla-esr128? → approval-mozilla-esr128+
Attachment #9422895 - Flags: approval-mozilla-esr128? → approval-mozilla-esr128+
Attachment #9422894 - Flags: approval-mozilla-esr128? → approval-mozilla-esr128+
Attachment #9422893 - Flags: approval-mozilla-esr128? → approval-mozilla-esr128+
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Creator:
Created:
Updated:
Size: