b713e34947
* chore: bump chromium to 124.0.6351.0 * chore: bump chromium in DEPS to 124.0.6339.0 * chore: update patches * chore: bump chromium in DEPS to 124.0.6341.0 * chore: update patches * chore: bump chromium in DEPS to 124.0.6343.0 * chore: bump chromium in DEPS to 124.0.6345.0 * chore: update patches * build: temporarily patch out usage of reclient inputs cfg * chore: implement missing OnPortConnectedStateChanged Ref: https://chromium-review.googlesource.com/c/chromium/src/+/5039155 * fix: move NativeHandlers in extensions to new RendererAPIProvider Ref: https://chromium-review.googlesource.com/c/chromium/src/+/5332839 Ref: https://chromium-review.googlesource.com/c/chromium/src/+/5334058 * chore: add missing websocket method * refactor: use std::erase instead of base::Erase Ref: https://issues.chromium.org/issues/40256229 * build: fix reclient inputs processor bug (workaround) * fix: delay extensions::Dispatcher construction * chore: bump chromium in DEPS to 124.0.6347.0 * chore: bump chromium in DEPS to 124.0.6349.0 * 5326217: [ViewsAX] Remove WebAXPlatformTreeManagerDelegate https://chromium-review.googlesource.com/c/chromium/src/+/5326217 * 5347916: Get origin from parent for process-isolated srcdoc. https://chromium-review.googlesource.com/c/chromium/src/+/5347916 * chore: patches fixup * 4866222: [api] Deprecate vector<v8::Local>, part 1 https://chromium-review.googlesource.com/c/v8/v8/+/4866222 * 5337304: Remove DXDiag telemetry code. https://chromium-review.googlesource.com/c/chromium/src/+/5337304 * 5328275: Implement watermark routing to the BrowserView https://chromium-review.googlesource.com/c/chromium/src/+/5328275 * [libc++] Rename __fwd/hash.h to __fwd/functional.h and add reference_wrapper * chore: bump chromium in DEPS to 124.0.6351.0 * chore: update patches * 5342763: [object] Fast path for adding props with existing transition https://chromium-review.googlesource.com/c/v8/v8/+/5342763 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <marshallofsound@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: bump chromium to 124.0.6353.0 * chore: bump chromium in DEPS to 124.0.6353.0 * chore: update patches * 5365462: Add missing perfetto::Flow and TRACE_EVENT includes https://chromium-review.googlesource.com/c/chromium/src/+/5365462 * 5356336: Ensure destruction of mojo channel when destructing KeySystemsImpl https://chromium-review.googlesource.com/c/chromium/src/+/5356336 * 5332839: [Extensions] Register NativeHandlers with the RendererAPIProvider https://chromium-review.googlesource.com/c/chromium/src/+/5332839 * 5148827: Add permission types for keyboard lock and pointer lock [1/N] https://chromium-review.googlesource.com/c/chromium/src/+/5148827 * 5358818: Revert "[object] Fast path for adding props with existing transition" https://chromium-review.googlesource.com/c/v8/v8/+/5358818 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <marshallofsound@electronjs.org> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com>
119 lines
4.3 KiB
C++
119 lines
4.3 KiB
C++
// Copyright 2019 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.
|
|
|
|
#ifndef ELECTRON_SHELL_BROWSER_SERIAL_SERIAL_CHOOSER_CONTEXT_H_
|
|
#define ELECTRON_SHELL_BROWSER_SERIAL_SERIAL_CHOOSER_CONTEXT_H_
|
|
|
|
#include <map>
|
|
#include <set>
|
|
#include <vector>
|
|
|
|
#include "base/memory/raw_ptr.h"
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "base/observer_list.h"
|
|
#include "base/unguessable_token.h"
|
|
#include "components/keyed_service/core/keyed_service.h"
|
|
#include "content/public/browser/serial_delegate.h"
|
|
#include "mojo/public/cpp/bindings/pending_remote.h"
|
|
#include "mojo/public/cpp/bindings/remote.h"
|
|
#include "services/device/public/mojom/serial.mojom-forward.h"
|
|
#include "shell/browser/electron_browser_context.h"
|
|
#include "third_party/blink/public/mojom/serial/serial.mojom.h"
|
|
#include "url/gurl.h"
|
|
#include "url/origin.h"
|
|
|
|
namespace base {
|
|
class Value;
|
|
}
|
|
|
|
namespace electron {
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
extern const char kDeviceInstanceIdKey[];
|
|
#else
|
|
extern const char kVendorIdKey[];
|
|
extern const char kProductIdKey[];
|
|
extern const char kSerialNumberKey[];
|
|
#if BUILDFLAG(IS_MAC)
|
|
extern const char kUsbDriverKey[];
|
|
#endif // BUILDFLAG(IS_MAC)
|
|
#endif // BUILDFLAG(IS_WIN)
|
|
|
|
class SerialChooserContext : public KeyedService,
|
|
public device::mojom::SerialPortManagerClient {
|
|
public:
|
|
class PortObserver : public content::SerialDelegate::Observer {
|
|
public:
|
|
// Called when the SerialChooserContext is shutting down. Observers must
|
|
// remove themselves before returning.
|
|
virtual void OnSerialChooserContextShutdown() = 0;
|
|
};
|
|
|
|
explicit SerialChooserContext(ElectronBrowserContext* context);
|
|
~SerialChooserContext() override;
|
|
|
|
// disable copy
|
|
SerialChooserContext(const SerialChooserContext&) = delete;
|
|
SerialChooserContext& operator=(const SerialChooserContext&) = delete;
|
|
|
|
// Serial-specific interface for granting and checking permissions.
|
|
void GrantPortPermission(const url::Origin& origin,
|
|
const device::mojom::SerialPortInfo& port,
|
|
content::RenderFrameHost* render_frame_host);
|
|
bool HasPortPermission(const url::Origin& origin,
|
|
const device::mojom::SerialPortInfo& port,
|
|
content::RenderFrameHost* render_frame_host);
|
|
void RevokePortPermissionWebInitiated(
|
|
const url::Origin& origin,
|
|
const base::UnguessableToken& token,
|
|
content::RenderFrameHost* render_frame_host);
|
|
static bool CanStorePersistentEntry(
|
|
const device::mojom::SerialPortInfo& port);
|
|
|
|
// Only call this if you're sure |port_info_| has been initialized
|
|
// before-hand. The returned raw pointer is owned by |port_info_| and will be
|
|
// destroyed when the port is removed.
|
|
const device::mojom::SerialPortInfo* GetPortInfo(
|
|
const base::UnguessableToken& token);
|
|
|
|
device::mojom::SerialPortManager* GetPortManager();
|
|
|
|
void AddPortObserver(PortObserver* observer);
|
|
void RemovePortObserver(PortObserver* observer);
|
|
|
|
base::WeakPtr<SerialChooserContext> AsWeakPtr();
|
|
|
|
// SerialPortManagerClient implementation.
|
|
void OnPortAdded(device::mojom::SerialPortInfoPtr port) override;
|
|
void OnPortRemoved(device::mojom::SerialPortInfoPtr port) override;
|
|
void OnPortConnectedStateChanged(
|
|
device::mojom::SerialPortInfoPtr port) override {}
|
|
|
|
private:
|
|
void EnsurePortManagerConnection();
|
|
void SetUpPortManagerConnection(
|
|
mojo::PendingRemote<device::mojom::SerialPortManager> manager);
|
|
void OnGetDevices(std::vector<device::mojom::SerialPortInfoPtr> ports);
|
|
void OnPortManagerConnectionError();
|
|
|
|
bool is_initialized_ = false;
|
|
|
|
// Tracks the set of ports to which an origin has access to.
|
|
std::map<url::Origin, std::set<base::UnguessableToken>> ephemeral_ports_;
|
|
|
|
// Map from port token to port info.
|
|
std::map<base::UnguessableToken, device::mojom::SerialPortInfoPtr> port_info_;
|
|
|
|
mojo::Remote<device::mojom::SerialPortManager> port_manager_;
|
|
mojo::Receiver<device::mojom::SerialPortManagerClient> client_receiver_{this};
|
|
base::ObserverList<PortObserver> port_observer_list_;
|
|
|
|
raw_ptr<ElectronBrowserContext> browser_context_;
|
|
|
|
base::WeakPtrFactory<SerialChooserContext> weak_factory_{this};
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // ELECTRON_SHELL_BROWSER_SERIAL_SERIAL_CHOOSER_CONTEXT_H_
|