2019-07-24 23:01:08 +00:00
|
|
|
// Copyright 2014 The Chromium Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
|
|
|
|
2021-11-22 07:34:31 +00:00
|
|
|
#ifndef ELECTRON_SHELL_BROWSER_EXTENSIONS_ELECTRON_EXTENSIONS_BROWSER_CLIENT_H_
|
|
|
|
#define ELECTRON_SHELL_BROWSER_EXTENSIONS_ELECTRON_EXTENSIONS_BROWSER_CLIENT_H_
|
2019-07-24 23:01:08 +00:00
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "extensions/browser/extensions_browser_client.h"
|
2020-04-24 01:55:17 +00:00
|
|
|
#include "extensions/browser/kiosk/kiosk_delegate.h"
|
2019-12-11 00:22:35 +00:00
|
|
|
#include "mojo/public/cpp/bindings/pending_remote.h"
|
2021-08-11 21:04:56 +00:00
|
|
|
#include "services/network/public/cpp/resource_request.h"
|
2020-12-22 22:14:44 +00:00
|
|
|
#include "services/network/public/mojom/fetch_api.mojom.h"
|
2024-06-07 21:18:35 +00:00
|
|
|
#include "url/origin.h"
|
2019-07-24 23:01:08 +00:00
|
|
|
|
|
|
|
class PrefService;
|
|
|
|
|
|
|
|
namespace extensions {
|
|
|
|
class ExtensionsAPIClient;
|
|
|
|
class KioskDelegate;
|
|
|
|
class ProcessManagerDelegate;
|
2020-01-13 22:55:58 +00:00
|
|
|
class ElectronProcessManagerDelegate;
|
2019-07-24 23:01:08 +00:00
|
|
|
class ProcessMap;
|
2020-02-13 00:39:12 +00:00
|
|
|
class ElectronComponentExtensionResourceManager;
|
2019-07-24 23:01:08 +00:00
|
|
|
} // namespace extensions
|
|
|
|
|
|
|
|
namespace electron {
|
|
|
|
|
|
|
|
// An ExtensionsBrowserClient that supports a single content::BrowserContext
|
|
|
|
// with no related incognito context.
|
2020-02-03 22:01:10 +00:00
|
|
|
class ElectronExtensionsBrowserClient
|
|
|
|
: public extensions::ExtensionsBrowserClient {
|
2019-07-24 23:01:08 +00:00
|
|
|
public:
|
2020-02-03 22:01:10 +00:00
|
|
|
ElectronExtensionsBrowserClient();
|
|
|
|
~ElectronExtensionsBrowserClient() override;
|
2019-07-24 23:01:08 +00:00
|
|
|
|
2021-11-03 11:41:45 +00:00
|
|
|
// disable copy
|
|
|
|
ElectronExtensionsBrowserClient(const ElectronExtensionsBrowserClient&) =
|
|
|
|
delete;
|
|
|
|
ElectronExtensionsBrowserClient& operator=(
|
|
|
|
const ElectronExtensionsBrowserClient&) = delete;
|
|
|
|
|
2019-07-24 23:01:08 +00:00
|
|
|
// ExtensionsBrowserClient overrides:
|
|
|
|
bool IsShuttingDown() override;
|
|
|
|
bool AreExtensionsDisabled(const base::CommandLine& command_line,
|
|
|
|
content::BrowserContext* context) override;
|
chore: bump chromium to 118.0.5975.0 (main) (#39531)
* chore: bump chromium in DEPS to 118.0.5951.0
* chore: update printing.patch
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4727894
No logic changes, but patch needed to be manually re-applied due to upstream code shear
* chore: update port_autofill_colors_to_the_color_pipeline.patch
No manual changes; patch applied with fuzz
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5953.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5955.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5957.0
* chore: update patches
* chore: include path of native_web_keyboard_event.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
* chore: remove reference to eextensions/browser/notification-types.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4771627
* chore: update references to renamed upstream field NativeWebKeyboardEvent.skip_if_unhandled (formerly known as skip_in_browser
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
Need a second pair of eyes on this commit. In particular the reference in content_converter.cc, skipInBrowser, seems to not be set or documented anywhere? Is this unused/vestigal code?
* chore: sync signature of ElectronExtensionsBrowserClient::IsValidContext() to upstream change
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4784198
* chore: add auto_pip_setting_helper.[cc,h] to chromium_src build
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4688277
Exiting upstream code used by chromium_src now depends on this new upstream class
* chore: bump chromium in DEPS to 118.0.5959.0
* chore: update add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
Xref: add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
manually adjust patch to minor upstream chagnes
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5961.0
* chore: bump chromium in DEPS to 118.0.5963.0
* chore: update patches
* 4780994: Rename various base files to "apple" since iOS uses them too
https://chromium-review.googlesource.com/c/chromium/src/+/4780994
* Many files moved from `mac` -> `apple`
This commit follows a handful of CLs that simply rename files/symbols to change `mac`
to `apple`
to signify their use across both macOS and iOS:
- 4784010: Move scoped_nsautorelease_pool to base/apple, leave a forwarding header
- 4790744: Move foundation_util to base/apple, leave a forwarding header
- 4790741: Move scoped_cftypreref to base/apple, leave a forwarding header
- 4787627: Move and rename macOS+iOS base/ files in PA to "apple"
- 4780399: Move OSStatus logging to base/apple
- 4787387: Remove forwarding headers
- 4781113: Rename message_pump_mac to "apple" because iOS uses it too
* fixup minor patch update error
A function param got dropped from this patch somewhere earlier
* chore: bump chromium in DEPS to 118.0.5965.2
* chore: update patches
* 4799213: Move ScopedTypeRef and ScopedCFTypeRef into base::apple::
https://chromium-review.googlesource.com/c/chromium/src/+/4799213
* Fix removed include to BrowserContext
In crrev.com/c/4767962 an include to BrowserContext was removed,
which was necessary for compilation. This broke only for us because
"chrome/browser/profiles/profile.h" includes that class, but we remove
all references to profiles.
* chore: bump chromium in DEPS to 118.0.5967.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5969.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5971.0
* chore: bump chromium in DEPS to 118.0.5973.0
* chore: update patches
* 4772121: [OOPIF PDF] Replace PDFWebContentsHelper with PDFDocumentHelper
https://chromium-review.googlesource.com/c/chromium/src/+/4772121
* 4811164: [Extensions] Do some cleanup in ChromeManagementAPIDelegate.
https://chromium-review.googlesource.com/c/chromium/src/+/4811164
* 4809488: Remove duplicate dnd functionality between Web and Renderer prefs
https://chromium-review.googlesource.com/c/chromium/src/+/4809488
Given that this is no longer an option of web preferences, we should
consider deprecating this option and then removing it.
* chore: bump chromium in DEPS to 118.0.5975.0
* chore: update patches
* fixup! chore: add auto_pip_settings_helper.{cc|h} to chromium_src build
* Reland "[windows] Remove RegKey::DeleteEmptyKey"
Refs https://chromium-review.googlesource.com/c/chromium/src/+/4813255
* Ensure StrCat means StrCat
Refs https://chromium-review.googlesource.com/c/chromium/src/+/1117180
* fixup! Remove RegKey::DeleteEmptyKey
* Consistently reject large p and large q in DH
Refs https://boringssl-review.googlesource.com/c/boringssl/+/62226
---------
Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
Co-authored-by: Charles Kerr <charles@charleskerr.com>
Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
Co-authored-by: clavin <clavin@electronjs.org>
Co-authored-by: deepak1556 <hop2deep@gmail.com>
2023-09-01 06:54:59 +00:00
|
|
|
bool IsValidContext(void* context) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
bool IsSameContext(content::BrowserContext* first,
|
|
|
|
content::BrowserContext* second) override;
|
|
|
|
bool HasOffTheRecordContext(content::BrowserContext* context) override;
|
|
|
|
content::BrowserContext* GetOffTheRecordContext(
|
|
|
|
content::BrowserContext* context) override;
|
|
|
|
content::BrowserContext* GetOriginalContext(
|
|
|
|
content::BrowserContext* context) override;
|
2023-07-16 14:14:43 +00:00
|
|
|
content::BrowserContext* GetContextRedirectedToOriginal(
|
2022-10-03 20:21:00 +00:00
|
|
|
content::BrowserContext* context,
|
2023-07-16 14:14:43 +00:00
|
|
|
bool force_guest_profile) override;
|
|
|
|
content::BrowserContext* GetContextOwnInstance(
|
2022-10-03 20:21:00 +00:00
|
|
|
content::BrowserContext* context,
|
2023-07-16 14:14:43 +00:00
|
|
|
bool force_guest_profile) override;
|
|
|
|
content::BrowserContext* GetContextForOriginalOnly(
|
2022-10-03 20:21:00 +00:00
|
|
|
content::BrowserContext* context,
|
2023-07-16 14:14:43 +00:00
|
|
|
bool force_guest_profile) override;
|
2023-07-20 07:36:59 +00:00
|
|
|
bool AreExtensionsDisabledForContext(
|
|
|
|
content::BrowserContext* context) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
bool IsGuestSession(content::BrowserContext* context) const override;
|
|
|
|
bool IsExtensionIncognitoEnabled(
|
|
|
|
const std::string& extension_id,
|
|
|
|
content::BrowserContext* context) const override;
|
|
|
|
bool CanExtensionCrossIncognito(
|
|
|
|
const extensions::Extension* extension,
|
|
|
|
content::BrowserContext* context) const override;
|
|
|
|
base::FilePath GetBundleResourcePath(
|
|
|
|
const network::ResourceRequest& request,
|
|
|
|
const base::FilePath& extension_resources_path,
|
|
|
|
int* resource_id) const override;
|
|
|
|
void LoadResourceFromResourceBundle(
|
|
|
|
const network::ResourceRequest& request,
|
2019-12-11 00:22:35 +00:00
|
|
|
mojo::PendingReceiver<network::mojom::URLLoader> loader,
|
2019-07-24 23:01:08 +00:00
|
|
|
const base::FilePath& resource_relative_path,
|
|
|
|
int resource_id,
|
2021-06-03 08:05:04 +00:00
|
|
|
scoped_refptr<net::HttpResponseHeaders> headers,
|
|
|
|
mojo::PendingRemote<network::mojom::URLLoaderClient> client) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
bool AllowCrossRendererResourceLoad(
|
2020-12-14 18:57:36 +00:00
|
|
|
const network::ResourceRequest& request,
|
2020-12-22 22:14:44 +00:00
|
|
|
network::mojom::RequestDestination destination,
|
2019-07-24 23:01:08 +00:00
|
|
|
ui::PageTransition page_transition,
|
|
|
|
int child_id,
|
|
|
|
bool is_incognito,
|
|
|
|
const extensions::Extension* extension,
|
|
|
|
const extensions::ExtensionSet& extensions,
|
chore: bump chromium to 128.0.6611.0 (main) (#42779)
* chore: bump chromium in DEPS to 128.0.6577.0
* chore: bump chromium in DEPS to 128.0.6579.0
* 5675706: Reland "Reland "Reland "Reland "Add toolchains without PartitionAlloc-Everywhere for dump_syms et al""""
https://chromium-review.googlesource.com/c/chromium/src/+/5675706
* 5668597: [PDF Ink Signatures] Prompt download menu on save when there are edits
https://chromium-review.googlesource.com/c/chromium/src/+/5668597
* 5677014: Reland "Pull data_sharing_sdk from CIPD"
https://chromium-review.googlesource.com/c/chromium/src/+/5677014
* chore: fixup patch indices
* chore: bump chromium in DEPS to 128.0.6581.0
* chore: bump chromium in DEPS to 128.0.6583.0
* update patches
* 5455480: [Extensions] Allow service worker requests to continue without a cert
https://chromium-review.googlesource.com/c/chromium/src/+/5455480
* try to get some debugging output from script/push-patch.js
* chore: bump chromium in DEPS to 128.0.6585.0
* chore: bump chromium in DEPS to 128.0.6587.0
* update patches
* chore: bump chromium in DEPS to 128.0.6589.0
* more patch work
* maybe over here?
* chore: update patches
* 5673207: [HTTPS Upgrades] Disable in captive portal login webview
https://chromium-review.googlesource.com/c/chromium/src/+/5673207
* 5636785: Extensions: WAR: manifest.json's use_dynamic_url requires a dynamic url
https://chromium-review.googlesource.com/c/chromium/src/+/5636785
* chore: bump chromium in DEPS to 128.0.6591.0
* 5665458: Trigger WN2 page when feature is enabled
https://chromium-review.googlesource.com/c/chromium/src/+/5665458
* update patches
* chore: bump chromium in DEPS to 128.0.6593.0
* chore: bump chromium in DEPS to 128.0.6595.0
* chore: bump chromium in DEPS to 128.0.6597.0
* (patch update) 5694586: [compile hints] Remove the usage of v8::Isolate::SetJavaScriptCompileHintsMagicEnabledCallback API
https://chromium-review.googlesource.com/c/chromium/src/+/5694586
* update patches
* 5691287: Reland "Change blink::WebKeyboardEvent to use std::array in is members"
https://chromium-review.googlesource.com/c/chromium/src/+/5691287
The code changed here is modeled after code in `content/renderer/pepper/event_conversion.cc` that was also modified in this CL, so I took the same approach.
* 5529018: Cleanup EnableWebHidOnExtensionServiceWorker flag
https://chromium-review.googlesource.com/c/chromium/src/+/5529018
* 5526324: [Code Health] Add deprecation comment for base::SupportsWeakPtr.
https://chromium-review.googlesource.com/c/chromium/src/+/5526324
Note that this CL actually does make `SupportsWeakPtr` strictly restricted to existing implementations, no new ones. We could add a patch to add ourselves to this list, but it looks like we'll have to refactor this anyways in the near future. Since the refactor seems straightforward, let's try that first.
* chore: bump chromium in DEPS to 128.0.6598.0
* chore: update patches
* 5704737: Rename ExclusiveAccessContext::GetActiveWebContents to avoid conflict
https://chromium-review.googlesource.com/c/chromium/src/+/5704737
* chore: bump chromium in DEPS to 128.0.6601.0
* chore: update patches
* Add `base::StringPiece` header includes
Chromium is working on replacing `base::StringPiece` with `std::string_view`. (See the Chromium Bug below.) They're currently running mass codemods (across many multiple changes) to replace uses of `StringPiece` with `string_view`, including removing the header include for `StringPiece` in those files. This cascades down to our files that were implicitly depending on those includes through some other include.
They're on track to eventually deprecate and remove `StringPiece` so our code should be converted, but that can be done as an upgrade follow-up task. For now, adding the header back to files that need it should suffice for minimal upgrade changes.
Chromium Bug: https://issues.chromium.org/issues/40506050
* 5702737: GlobalRequestID: Avoid unwanted inlining and narrowing int conversions
https://chromium-review.googlesource.com/c/chromium/src/+/5702737
contender for smallest commit 2024
* 5706534: Rename GlobalFeatures to GlobalDesktopFeatures.
https://chromium-review.googlesource.com/c/chromium/src/+/5706534
* 5691321: ui: remove params variants of SelectFile listener functions
https://chromium-review.googlesource.com/c/chromium/src/+/5691321
* 5714949: [Extensions] Display re-enable dialog for MV2 disabled stage
https://chromium-review.googlesource.com/c/chromium/src/+/5714949
* chore: update libc++ filenames
* patch: disable scope reuse & associated dchecks in v8 (hopefully temp, upgrade follow-up)
* fixup! Add `base::StringPiece` header includes
* update MAS patch
5710330: Add crash keys to debug NativeWidgetMacNSWindowBorderlessFrame exception
https://chromium-review.googlesource.com/c/chromium/src/+/5710330
* chore: bump chromium in DEPS to 128.0.6603.0
* chore: update patches
* 5713258: Reland "Preparation for decoupling creation/initialization of context"
https://chromium-review.googlesource.com/c/chromium/src/+/5713258
When destroying a context, it must already be shutdown, and this change enforces it with a new CHECK.
We were overriding `BrowserContextKeyedServiceFactory::BrowserContextShutdown` with an empty implementation, which differed from the default implementation that notifies the `KeyedServiceFactory` that the context has shutdown. Since we were missing this notification, the CHECK would later trip when the service was being destoryed because it was not registered as shutdown when it was shutdown.
* chore: bump chromium in DEPS to 128.0.6605.2
* chore: update patches
* refactor: linux open/save dialog patch
Our existing implementation was relying on an opaque `void* params` parameter that was passed through `ui::SelectFileDialog`.
Recently, that parameter has been getting removed:
- 5691321: ui: remove params variants of SelectFile listener functions | https://chromium-review.googlesource.com/c/chromium/src/+/5691321
- 5709097: ui: remove SelectFileDialog impl params | https://chromium-review.googlesource.com/c/chromium/src/+/5709097
- https://issues.chromium.org/issues/340178601 "reconsider SelectFileDialog"
This restructures the patch to work with mostly the same mechanics, but directly on the `ui::SelectFileDialog` object. This nets us some wins in terms of a smaller patch.
* 5713262: DevTools UI binding AIDA client event returns response
https://chromium-review.googlesource.com/c/chromium/src/+/5713262
* fixup! refactor: linux open/save dialog patch
* chore: bump chromium in DEPS to 128.0.6606.0
* chore: update patches
* fixup! refactor: linux open/save dialog patch
* chore: bump chromium in DEPS to 128.0.6607.0
* chore: update printing.patch
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/5722937
* fix: pwd error in electron-test, nan-test
fix: unshallow depot_tools before 3-way apply
* chore: e patches all
* fixup! fix: pwd error in electron-test, nan-test
* chore: bump chromium in DEPS to 128.0.6609.0
* chore: bump chromium in DEPS to 128.0.6611.0
* chore: update patches
* chore: update libcxx filenames
---------
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: Jeremy Rose <nornagon@nornagon.net>
Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
Co-authored-by: clavin <clavin@electronjs.org>
Co-authored-by: Charles Kerr <charles@charleskerr.com>
Co-authored-by: Alice Zhao <alice@makenotion.com>
2024-07-23 15:59:44 +00:00
|
|
|
const extensions::ProcessMap& process_map,
|
|
|
|
const GURL& upstream_url) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
PrefService* GetPrefServiceForContext(
|
|
|
|
content::BrowserContext* context) override;
|
|
|
|
void GetEarlyExtensionPrefsObservers(
|
|
|
|
content::BrowserContext* context,
|
|
|
|
std::vector<extensions::EarlyExtensionPrefsObserver*>* observers)
|
|
|
|
const override;
|
|
|
|
extensions::ProcessManagerDelegate* GetProcessManagerDelegate()
|
|
|
|
const override;
|
2024-01-25 17:46:30 +00:00
|
|
|
mojo::PendingRemote<network::mojom::URLLoaderFactory>
|
|
|
|
GetControlledFrameEmbedderURLLoader(
|
2024-06-07 21:18:35 +00:00
|
|
|
const url::Origin& app_origin,
|
2024-01-25 17:46:30 +00:00
|
|
|
int frame_tree_node_id,
|
|
|
|
content::BrowserContext* browser_context) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
std::unique_ptr<extensions::ExtensionHostDelegate>
|
|
|
|
CreateExtensionHostDelegate() override;
|
|
|
|
bool DidVersionUpdate(content::BrowserContext* context) override;
|
|
|
|
void PermitExternalProtocolHandler() override;
|
|
|
|
bool IsInDemoMode() override;
|
|
|
|
bool IsScreensaverInDemoMode(const std::string& app_id) override;
|
|
|
|
bool IsRunningInForcedAppMode() override;
|
|
|
|
bool IsAppModeForcedForApp(
|
|
|
|
const extensions::ExtensionId& extension_id) override;
|
|
|
|
bool IsLoggedInAsPublicAccount() override;
|
|
|
|
extensions::ExtensionSystemProvider* GetExtensionSystemFactory() override;
|
|
|
|
std::unique_ptr<extensions::RuntimeAPIDelegate> CreateRuntimeAPIDelegate(
|
|
|
|
content::BrowserContext* context) const override;
|
|
|
|
const extensions::ComponentExtensionResourceManager*
|
|
|
|
GetComponentExtensionResourceManager() override;
|
|
|
|
void BroadcastEventToRenderers(
|
|
|
|
extensions::events::HistogramValue histogram_value,
|
|
|
|
const std::string& event_name,
|
2022-06-01 06:12:47 +00:00
|
|
|
base::Value::List args,
|
2019-11-04 23:59:31 +00:00
|
|
|
bool dispatch_to_off_the_record_profiles) override;
|
2019-07-24 23:01:08 +00:00
|
|
|
extensions::ExtensionCache* GetExtensionCache() override;
|
|
|
|
bool IsBackgroundUpdateAllowed() override;
|
|
|
|
bool IsMinBrowserVersionSupported(const std::string& min_version) override;
|
|
|
|
extensions::ExtensionWebContentsObserver* GetExtensionWebContentsObserver(
|
|
|
|
content::WebContents* web_contents) override;
|
|
|
|
extensions::KioskDelegate* GetKioskDelegate() override;
|
|
|
|
bool IsLockScreenContext(content::BrowserContext* context) override;
|
|
|
|
std::string GetApplicationLocale() override;
|
|
|
|
std::string GetUserAgent() const override;
|
2019-12-11 00:22:35 +00:00
|
|
|
void RegisterBrowserInterfaceBindersForFrame(
|
2020-05-26 20:06:26 +00:00
|
|
|
mojo::BinderMapWithContext<content::RenderFrameHost*>* map,
|
2019-12-11 00:22:35 +00:00
|
|
|
content::RenderFrameHost* render_frame_host,
|
|
|
|
const extensions::Extension* extension) const override;
|
2019-07-24 23:01:08 +00:00
|
|
|
|
|
|
|
// Sets the API client.
|
|
|
|
void SetAPIClientForTest(extensions::ExtensionsAPIClient* api_client);
|
|
|
|
|
|
|
|
private:
|
|
|
|
// Support for extension APIs.
|
|
|
|
std::unique_ptr<extensions::ExtensionsAPIClient> api_client_;
|
|
|
|
|
2020-01-13 22:55:58 +00:00
|
|
|
// Support for ProcessManager.
|
|
|
|
std::unique_ptr<extensions::ElectronProcessManagerDelegate>
|
|
|
|
process_manager_delegate_;
|
|
|
|
|
2019-07-24 23:01:08 +00:00
|
|
|
// The extension cache used for download and installation.
|
|
|
|
std::unique_ptr<extensions::ExtensionCache> extension_cache_;
|
|
|
|
|
2020-04-24 01:55:17 +00:00
|
|
|
std::unique_ptr<extensions::KioskDelegate> kiosk_delegate_;
|
|
|
|
|
2020-02-13 00:39:12 +00:00
|
|
|
std::unique_ptr<extensions::ElectronComponentExtensionResourceManager>
|
|
|
|
resource_manager_;
|
2019-07-24 23:01:08 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace electron
|
|
|
|
|
2021-11-22 07:34:31 +00:00
|
|
|
#endif // ELECTRON_SHELL_BROWSER_EXTENSIONS_ELECTRON_EXTENSIONS_BROWSER_CLIENT_H_
|