e86d1cba75
* chore: bump chromium in DEPS to 104.0.5096.0 * 3651284: Use the entry settings object for window.open navigation https://chromium-review.googlesource.com/c/chromium/src/+/3651284 * 3644598: Make RenderFrameHost used for notification permission decision https://chromium-review.googlesource.com/c/chromium/src/+/3644598 * 3642842: Window Placement: Prototype Fullscreen Capability Delegation - Part 2 https://chromium-review.googlesource.com/c/chromium/src/+/3642842 * 3652785: [sandbox] Enable sandboxed pointers on sanitizer builds https://chromium-review.googlesource.com/c/v8/v8/+/3652785 * 3611967: webhid: Migrate HidDelegate to use BrowserContext and Origin https://chromium-review.googlesource.com/c/chromium/src/+/3611967 * 3665762: Remove RenderFrameHost::IsRenderFrameCreated from //content/. https://chromium-review.googlesource.com/c/chromium/src/+/3665762 * 3659375: Fold x509_util_ios and most of x509_util_mac into x509_util_apple https://chromium-review.googlesource.com/c/chromium/src/+/3659375 * 3656234: [CodeHealth] Remove uses of base::ListValue::Append() (Final, take 2) https://chromium-review.googlesource.com/c/chromium/src/+/3656234 * chore: update patch indices * chore: fix lint * 3644598: Make RenderFrameHost used for notification permission decision https://chromium-review.googlesource.com/c/chromium/src/+/3644598 * webhid: Migrate HidDelegate to use BrowserContext and Origin This is a temporary fix for https://chromium-review.googlesource.com/c/chromium/src/+/3611967 to get the build compiling, but we need to either patch around https://chromium-review.googlesource.com/c/chromium/src/+/3611967 or move our device permissioning to BrowserContext * chore: fix lint * build: run electron/script/gen-libc++-filenames.js fixes gn check * chore: bump chromium in DEPS to 104.0.5098.0 * chore: disable flaking tests * 3682394: Change pipes surrounding code references in comments to backticks https://chromium-review.googlesource.com/c/chromium/src/+/3682394 * 3652749: Delete GLRenderer and related classes https://chromium-review.googlesource.com/c/chromium/src/+/3652749 * chore: fixup patch indices * 3671199: Remove ContentMainDelegate::PostFieldTrialInitialization https://chromium-review.googlesource.com/c/chromium/src/+/3671199 * 3607963: hid: Do not exclude HID device with no collections https://chromium-review.googlesource.com/c/chromium/src/+/3607963 * refactor: use ElectronBrowserContext instead of WebContents to persist devices due to changes like https://chromium-review.googlesource.com/c/chromium/src/+/3611967, we can no longer use WebContents to store device permissions so this commit moves device permission storage to live in memory in ElectronBrowserContext instead. * 3557253: Deprecate some signature checks https://chromium-review.googlesource.com/c/v8/v8/+/3557253 * chore: bump chromium in DEPS to 104.0.5100.0 * 3680781: Add policy for Renderer App Container. https://chromium-review.googlesource.com/c/chromium/src/+/3680781 * chore: update patch indices * 3675465: Update NetLog network service API to use mojom::DictionaryValue. https://chromium-review.googlesource.com/c/chromium/src/+/3675465 * chore: bump chromium in DEPS to 104.0.5102.0 * chore: update patches * chore: bump chromium in DEPS to 104.0.5103.0 * chore: update patches * chore: bump chromium in DEPS to 104.0.5104.0 * chore: update patches * fix: add patch for DCHECK in fullscreen test * build: fix nan build * build: make the nan spec runner work on macOS * chore: bump chromium in DEPS to 104.0.5106.0 * chore: update patches * chore: bump chromium in DEPS to 104.0.5108.0 * chore: update patches * chore: bump chromium in DEPS to 104.0.5110.0 * chore: update patches * chore: bump chromium in DEPS to 104.0.5112.0 * chore: bump chromium in DEPS to 105.0.5113.0 * chore: bump chromium in DEPS to 105.0.5115.0 * chore: bump chromium in DEPS to 105.0.5117.0 * chore: update patches * chore: update libcpp patch * 3693745: Delete base::LowerCaseEqualsASCII() Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3693745 * 3669226: Remove printing PostTask usage of IO thread Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3669226 * 3687395: Remove DictionaryValue::HasKey(). Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3687395 * 3691014: Prevent unsafe narrowing: ui/accessibility, part 2 Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3691014 * 3560567: [MSC] Porting GenerateStreams clients to handle stream vectors. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3560567 * 3684873: [Bluetooth][Win/Linux] Add bluetooth pair confirmation prompt https://chromium-review.googlesource.com/c/chromium/src/+/3684873 * chore: bump chromium in DEPS to 105.0.5119.0 * chore: missing includes in desktop_notification_controller * chore: update patches * 3685951: Reland "Make sure screen object is created once in tests." https://chromium-review.googlesource.com/c/chromium/src/+/3685951 * fixup: Reland "Make sure screen object is created once in tests." * 3646014: [API] Deprecate LegacyOOMErrorCallback Ref: https://chromium-review.googlesource.com/c/v8/v8/+/3646014 * chore: bump chromium in DEPS to 105.0.5121.0 * chore: update patches * 3699085: [cleanup] update PrintBackend::EnumeratePrinters to use reference Ref: https://chromium-review.googlesource.com/c/chromium/src/+/3699085 * chore: bump chromium in DEPS to 105.0.5123.0 * chore: update patches * chore: bump chromium in DEPS to 105.0.5125.0 * chore: update patches * 3630082: [sandbox] Also enable the sandbox outside of Chromium builds Ref: https://chromium-review.googlesource.com/c/v8/v8/+/3630082 * chore: bump chromium in DEPS to 105.0.5127.0 * chore: update patches * chore: bump chromium in DEPS to 105.0.5129.0 * chore: update patches * 3703741: Remove WebContents::GetMainFrame. https://chromium-review.googlesource.com/c/chromium/src/+/3703741 * chore: update patches * fixup! 3703741: Remove WebContents::GetMainFrame. * fix lint * more lint * chore: document breaking change * 3687671: [v8] Freeze flags after initialization https://chromium-review.googlesource.com/c/chromium/src/+/3687671 * fixup! 3560567: [MSC] Porting GenerateStreams clients to handle stream vectors. * use the v8 allocator for node serdes * chore: update patches * remove faulty non-v8-sandbox-compatible code * make NodeArrayBufferAllocator use the v8 allocator under the hood * fixup! 3560567: [MSC] Porting GenerateStreams clients to handle stream vectors. * fix build on windows * 3691954: [Reland][Extensions Bindings] Validate arguments sent to API events https://chromium-review.googlesource.com/c/chromium/src/+/3691954 * chore: remove deprecated AccessorSignatures https://github.com/nodejs/nan/pull/941 * Update patches/chromium/notification_provenance.patch Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * remove chore_expose_v8_initialization_isolate_callbacks.patch * add link to nodejs/nan#941 * 52026: Do not allow md4 or md5 based signatures in X.509 certificates. https://boringssl-review.googlesource.com/c/boringssl/+/52026 * chore: update patches * disable nan buffer-test * disable sandboxed pointers for now * force sandboxed pointers off * improve node allocation patch * restore accidentally dropped node crypto test patch Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <sattard@salesforce.com> Co-authored-by: Keeley Hammond <khammond@slack-corp.com> Co-authored-by: VerteDinde <keeleymhammond@gmail.com> Co-authored-by: VerteDinde <vertedinde@electronjs.org> Co-authored-by: Jeremy Rose <jeremya@chromium.org> Co-authored-by: Jeremy Rose <japthorp@slack-corp.com>
228 lines
8.2 KiB
C++
228 lines
8.2 KiB
C++
// Copyright (c) 2013 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef ELECTRON_SHELL_BROWSER_ELECTRON_BROWSER_CONTEXT_H_
|
|
#define ELECTRON_SHELL_BROWSER_ELECTRON_BROWSER_CONTEXT_H_
|
|
|
|
#include <map>
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "chrome/browser/predictors/preconnect_manager.h"
|
|
#include "content/public/browser/browser_context.h"
|
|
#include "content/public/browser/resource_context.h"
|
|
#include "electron/buildflags/buildflags.h"
|
|
#include "mojo/public/cpp/bindings/remote.h"
|
|
#include "services/network/public/mojom/network_context.mojom.h"
|
|
#include "services/network/public/mojom/url_loader_factory.mojom.h"
|
|
#include "shell/browser/media/media_device_id_salt.h"
|
|
#include "third_party/blink/public/common/permissions/permission_utils.h"
|
|
|
|
class PrefService;
|
|
class ValueMapPrefStore;
|
|
|
|
namespace network {
|
|
class SharedURLLoaderFactory;
|
|
}
|
|
|
|
namespace storage {
|
|
class SpecialStoragePolicy;
|
|
}
|
|
|
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
|
namespace extensions {
|
|
class ElectronExtensionSystem;
|
|
}
|
|
#endif
|
|
|
|
namespace electron {
|
|
|
|
using DevicePermissionMap =
|
|
std::map<blink::PermissionType,
|
|
std::map<url::Origin, std::vector<std::unique_ptr<base::Value>>>>;
|
|
|
|
class ElectronBrowserContext;
|
|
class ElectronDownloadManagerDelegate;
|
|
class ElectronPermissionManager;
|
|
class CookieChangeNotifier;
|
|
class ResolveProxyHelper;
|
|
class WebViewManager;
|
|
class ProtocolRegistry;
|
|
|
|
class ElectronBrowserContext : public content::BrowserContext {
|
|
public:
|
|
// disable copy
|
|
ElectronBrowserContext(const ElectronBrowserContext&) = delete;
|
|
ElectronBrowserContext& operator=(const ElectronBrowserContext&) = delete;
|
|
|
|
// partition_id => browser_context
|
|
struct PartitionKey {
|
|
std::string partition;
|
|
bool in_memory;
|
|
|
|
PartitionKey(const std::string& partition, bool in_memory)
|
|
: partition(partition), in_memory(in_memory) {}
|
|
|
|
bool operator<(const PartitionKey& other) const {
|
|
if (partition == other.partition)
|
|
return in_memory < other.in_memory;
|
|
return partition < other.partition;
|
|
}
|
|
|
|
bool operator==(const PartitionKey& other) const {
|
|
return (partition == other.partition) && (in_memory == other.in_memory);
|
|
}
|
|
};
|
|
using BrowserContextMap =
|
|
std::map<PartitionKey, std::unique_ptr<ElectronBrowserContext>>;
|
|
|
|
// Get or create the BrowserContext according to its |partition| and
|
|
// |in_memory|. The |options| will be passed to constructor when there is no
|
|
// existing BrowserContext.
|
|
static ElectronBrowserContext* From(
|
|
const std::string& partition,
|
|
bool in_memory,
|
|
base::DictionaryValue options = base::DictionaryValue());
|
|
|
|
static BrowserContextMap& browser_context_map();
|
|
|
|
void SetUserAgent(const std::string& user_agent);
|
|
std::string GetUserAgent() const;
|
|
absl::optional<std::string> GetUserAgentOverride() const;
|
|
bool CanUseHttpCache() const;
|
|
int GetMaxCacheSize() const;
|
|
ResolveProxyHelper* GetResolveProxyHelper();
|
|
predictors::PreconnectManager* GetPreconnectManager();
|
|
scoped_refptr<network::SharedURLLoaderFactory> GetURLLoaderFactory();
|
|
|
|
// content::BrowserContext:
|
|
base::FilePath GetPath() override;
|
|
bool IsOffTheRecord() override;
|
|
content::ResourceContext* GetResourceContext() override;
|
|
std::unique_ptr<content::ZoomLevelDelegate> CreateZoomLevelDelegate(
|
|
const base::FilePath& partition_path) override;
|
|
content::PushMessagingService* GetPushMessagingService() override;
|
|
content::SSLHostStateDelegate* GetSSLHostStateDelegate() override;
|
|
content::BackgroundFetchDelegate* GetBackgroundFetchDelegate() override;
|
|
content::BackgroundSyncController* GetBackgroundSyncController() override;
|
|
content::BrowsingDataRemoverDelegate* GetBrowsingDataRemoverDelegate()
|
|
override;
|
|
std::string GetMediaDeviceIDSalt() override;
|
|
content::DownloadManagerDelegate* GetDownloadManagerDelegate() override;
|
|
content::BrowserPluginGuestManager* GetGuestManager() override;
|
|
content::PlatformNotificationService* GetPlatformNotificationService()
|
|
override;
|
|
content::PermissionControllerDelegate* GetPermissionControllerDelegate()
|
|
override;
|
|
storage::SpecialStoragePolicy* GetSpecialStoragePolicy() override;
|
|
content::ClientHintsControllerDelegate* GetClientHintsControllerDelegate()
|
|
override;
|
|
content::StorageNotificationService* GetStorageNotificationService() override;
|
|
|
|
CookieChangeNotifier* cookie_change_notifier() const {
|
|
return cookie_change_notifier_.get();
|
|
}
|
|
PrefService* prefs() const { return prefs_.get(); }
|
|
void set_in_memory_pref_store(ValueMapPrefStore* pref_store) {
|
|
in_memory_pref_store_ = pref_store;
|
|
}
|
|
ValueMapPrefStore* in_memory_pref_store() const {
|
|
return in_memory_pref_store_;
|
|
}
|
|
base::WeakPtr<ElectronBrowserContext> GetWeakPtr() {
|
|
return weak_factory_.GetWeakPtr();
|
|
}
|
|
|
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
|
extensions::ElectronExtensionSystem* extension_system() {
|
|
// Guard usages of extension_system() with !IsOffTheRecord()
|
|
// There is no extension system for in-memory sessions
|
|
DCHECK(!IsOffTheRecord());
|
|
return extension_system_;
|
|
}
|
|
#endif
|
|
|
|
ProtocolRegistry* protocol_registry() const {
|
|
return protocol_registry_.get();
|
|
}
|
|
|
|
void SetSSLConfig(network::mojom::SSLConfigPtr config);
|
|
network::mojom::SSLConfigPtr GetSSLConfig();
|
|
void SetSSLConfigClient(mojo::Remote<network::mojom::SSLConfigClient> client);
|
|
|
|
~ElectronBrowserContext() override;
|
|
|
|
// Grants |origin| access to |device|.
|
|
// To be used in place of ObjectPermissionContextBase::GrantObjectPermission.
|
|
void GrantDevicePermission(const url::Origin& origin,
|
|
const base::Value& device,
|
|
blink::PermissionType permissionType);
|
|
|
|
// Revokes |origin| access to |device|.
|
|
// To be used in place of ObjectPermissionContextBase::RevokeObjectPermission.
|
|
void RevokeDevicePermission(const url::Origin& origin,
|
|
const base::Value& device,
|
|
blink::PermissionType permission_type);
|
|
|
|
// Returns the list of devices that |origin| has been granted permission to
|
|
// access. To be used in place of
|
|
// ObjectPermissionContextBase::GetGrantedObjects.
|
|
bool CheckDevicePermission(const url::Origin& origin,
|
|
const base::Value& device,
|
|
blink::PermissionType permissionType);
|
|
|
|
private:
|
|
ElectronBrowserContext(const std::string& partition,
|
|
bool in_memory,
|
|
base::DictionaryValue options);
|
|
|
|
// Initialize pref registry.
|
|
void InitPrefs();
|
|
|
|
bool DoesDeviceMatch(const base::Value& device,
|
|
const base::Value* device_to_compare,
|
|
blink::PermissionType permission_type);
|
|
|
|
ValueMapPrefStore* in_memory_pref_store_ = nullptr;
|
|
|
|
std::unique_ptr<content::ResourceContext> resource_context_;
|
|
std::unique_ptr<CookieChangeNotifier> cookie_change_notifier_;
|
|
std::unique_ptr<PrefService> prefs_;
|
|
std::unique_ptr<ElectronDownloadManagerDelegate> download_manager_delegate_;
|
|
std::unique_ptr<WebViewManager> guest_manager_;
|
|
std::unique_ptr<ElectronPermissionManager> permission_manager_;
|
|
std::unique_ptr<MediaDeviceIDSalt> media_device_id_salt_;
|
|
scoped_refptr<ResolveProxyHelper> resolve_proxy_helper_;
|
|
scoped_refptr<storage::SpecialStoragePolicy> storage_policy_;
|
|
std::unique_ptr<predictors::PreconnectManager> preconnect_manager_;
|
|
std::unique_ptr<ProtocolRegistry> protocol_registry_;
|
|
|
|
absl::optional<std::string> user_agent_;
|
|
base::FilePath path_;
|
|
bool in_memory_ = false;
|
|
bool use_cache_ = true;
|
|
int max_cache_size_ = 0;
|
|
|
|
#if BUILDFLAG(ENABLE_ELECTRON_EXTENSIONS)
|
|
// Owned by the KeyedService system.
|
|
extensions::ElectronExtensionSystem* extension_system_;
|
|
#endif
|
|
|
|
// Shared URLLoaderFactory.
|
|
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory_;
|
|
|
|
network::mojom::SSLConfigPtr ssl_config_;
|
|
mojo::Remote<network::mojom::SSLConfigClient> ssl_config_client_;
|
|
|
|
// In-memory cache that holds objects that have been granted permissions.
|
|
DevicePermissionMap granted_devices_;
|
|
|
|
base::WeakPtrFactory<ElectronBrowserContext> weak_factory_{this};
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // ELECTRON_SHELL_BROWSER_ELECTRON_BROWSER_CONTEXT_H_
|