fune/toolkit/components/windowwatcher/nsOpenWindowInfo.h
Anny Gakhokidze 28243d5736 Bug 1630323 - Do not override user preferences when clicking on a service worker notification to open a new document, r=Gijs,nika,geckoview-reviewers,snorp
In Bug 1622749 a user preference for where to open new documents (from a
service worker notification) was temporarily overriden in order to quickly fix
a crash that was happening in mozilla::dom::ClientOpenWindow. The crash was
ocurring when the pref "browser.link.open_newwindow" was set to 2, meaning new
documents are opened in a new window, instead of a new tab. The reason the
browser crashed is because the path for opening a new document is different
depending on the current user setting, and in NEWWINDOW case we did not get a
browsing context returned when calling mozilla::dom::OpenWindow which resulted
in a failed assertion.

The solution is to pass in a callback to mozilla::dom::OpenWindow as part of
nsOpenWindowInfo object, and invoke that callback with a corresponding
BrowsingContext in nsFrameLoader when that browsing context is ready.

After we call mozilla::dom::OpenWindow, we wait on a promise, that will be
resolved when the callback is invoked, before executing the rest of the code
that depends on the browsing context for a newly opened document being
available.

Differential Revision: https://phabricator.services.mozilla.com/D72745
2020-05-27 18:15:36 +00:00

48 lines
1.4 KiB
C++

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef nsOpenWindowInfo_h
#define nsOpenWindowInfo_h
#include "nsIOpenWindowInfo.h"
#include "nsISupportsImpl.h"
#include "mozilla/OriginAttributes.h"
#include "mozilla/RefPtr.h"
#include "mozilla/dom/ClientOpenWindowUtils.h"
class nsOpenWindowInfo : public nsIOpenWindowInfo {
public:
NS_DECL_ISUPPORTS
NS_DECL_NSIOPENWINDOWINFO
bool mForceNoOpener = false;
bool mIsRemote = false;
RefPtr<mozilla::dom::BrowserParent> mNextRemoteBrowser;
mozilla::OriginAttributes mOriginAttributes;
RefPtr<mozilla::dom::BrowsingContext> mParent;
RefPtr<nsIBrowsingContextReadyCallback> mBrowsingContextReadyCallback;
private:
virtual ~nsOpenWindowInfo() = default;
};
class nsBrowsingContextReadyCallback : public nsIBrowsingContextReadyCallback {
public:
NS_DECL_ISUPPORTS
NS_DECL_NSIBROWSINGCONTEXTREADYCALLBACK
explicit nsBrowsingContextReadyCallback(
RefPtr<mozilla::dom::BrowsingContextCallbackReceivedPromise::Private>
aPromise);
private:
virtual ~nsBrowsingContextReadyCallback();
RefPtr<mozilla::dom::BrowsingContextCallbackReceivedPromise::Private>
mPromise;
};
#endif // nsOpenWindowInfo_h