parent
cbc1ee5775
commit
672539187c
3 changed files with 19 additions and 6 deletions
|
@ -56,10 +56,7 @@ bool ElectronSerialDelegate::HasPortPermission(
|
||||||
content::RenderFrameHost* frame,
|
content::RenderFrameHost* frame,
|
||||||
const device::mojom::SerialPortInfo& port) {
|
const device::mojom::SerialPortInfo& port) {
|
||||||
auto* web_contents = content::WebContents::FromRenderFrameHost(frame);
|
auto* web_contents = content::WebContents::FromRenderFrameHost(frame);
|
||||||
auto* browser_context = web_contents->GetBrowserContext();
|
return GetChooserContext(frame)->HasPortPermission(
|
||||||
auto* chooser_context =
|
|
||||||
SerialChooserContextFactory::GetForBrowserContext(browser_context);
|
|
||||||
return chooser_context->HasPortPermission(
|
|
||||||
web_contents->GetPrimaryMainFrame()->GetLastCommittedOrigin(), port,
|
web_contents->GetPrimaryMainFrame()->GetLastCommittedOrigin(), port,
|
||||||
frame);
|
frame);
|
||||||
}
|
}
|
||||||
|
@ -91,8 +88,7 @@ void ElectronSerialDelegate::RevokePortPermissionWebInitiated(
|
||||||
const device::mojom::SerialPortInfo* ElectronSerialDelegate::GetPortInfo(
|
const device::mojom::SerialPortInfo* ElectronSerialDelegate::GetPortInfo(
|
||||||
content::RenderFrameHost* frame,
|
content::RenderFrameHost* frame,
|
||||||
const base::UnguessableToken& token) {
|
const base::UnguessableToken& token) {
|
||||||
// TODO(nornagon/jkleinsc): pass this on to the chooser context
|
return GetChooserContext(frame)->GetPortInfo(token);
|
||||||
return nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SerialChooserController* ElectronSerialDelegate::ControllerForFrame(
|
SerialChooserController* ElectronSerialDelegate::ControllerForFrame(
|
||||||
|
|
|
@ -103,6 +103,8 @@ void SerialChooserContext::GrantPortPermission(
|
||||||
const url::Origin& origin,
|
const url::Origin& origin,
|
||||||
const device::mojom::SerialPortInfo& port,
|
const device::mojom::SerialPortInfo& port,
|
||||||
content::RenderFrameHost* render_frame_host) {
|
content::RenderFrameHost* render_frame_host) {
|
||||||
|
port_info_.insert({port.token, port.Clone()});
|
||||||
|
|
||||||
auto* permission_manager = static_cast<ElectronPermissionManager*>(
|
auto* permission_manager = static_cast<ElectronPermissionManager*>(
|
||||||
browser_context_->GetPermissionControllerDelegate());
|
browser_context_->GetPermissionControllerDelegate());
|
||||||
return permission_manager->GrantDevicePermission(
|
return permission_manager->GrantDevicePermission(
|
||||||
|
@ -190,6 +192,9 @@ base::WeakPtr<SerialChooserContext> SerialChooserContext::AsWeakPtr() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void SerialChooserContext::OnPortAdded(device::mojom::SerialPortInfoPtr port) {
|
void SerialChooserContext::OnPortAdded(device::mojom::SerialPortInfoPtr port) {
|
||||||
|
if (!base::Contains(port_info_, port->token))
|
||||||
|
port_info_.insert({port->token, port->Clone()});
|
||||||
|
|
||||||
for (auto& observer : port_observer_list_)
|
for (auto& observer : port_observer_list_)
|
||||||
observer.OnPortAdded(*port);
|
observer.OnPortAdded(*port);
|
||||||
}
|
}
|
||||||
|
@ -198,6 +203,8 @@ void SerialChooserContext::OnPortRemoved(
|
||||||
device::mojom::SerialPortInfoPtr port) {
|
device::mojom::SerialPortInfoPtr port) {
|
||||||
for (auto& observer : port_observer_list_)
|
for (auto& observer : port_observer_list_)
|
||||||
observer.OnPortRemoved(*port);
|
observer.OnPortRemoved(*port);
|
||||||
|
|
||||||
|
port_info_.erase(port->token);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SerialChooserContext::EnsurePortManagerConnection() {
|
void SerialChooserContext::EnsurePortManagerConnection() {
|
||||||
|
@ -218,6 +225,15 @@ void SerialChooserContext::SetUpPortManagerConnection(
|
||||||
base::Unretained(this)));
|
base::Unretained(this)));
|
||||||
|
|
||||||
port_manager_->SetClient(client_receiver_.BindNewPipeAndPassRemote());
|
port_manager_->SetClient(client_receiver_.BindNewPipeAndPassRemote());
|
||||||
|
port_manager_->GetDevices(base::BindOnce(&SerialChooserContext::OnGetDevices,
|
||||||
|
weak_factory_.GetWeakPtr()));
|
||||||
|
}
|
||||||
|
|
||||||
|
void SerialChooserContext::OnGetDevices(
|
||||||
|
std::vector<device::mojom::SerialPortInfoPtr> ports) {
|
||||||
|
for (auto& port : ports)
|
||||||
|
port_info_.insert({port->token, std::move(port)});
|
||||||
|
is_initialized_ = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SerialChooserContext::OnPortManagerConnectionError() {
|
void SerialChooserContext::OnPortManagerConnectionError() {
|
||||||
|
|
|
@ -97,6 +97,7 @@ class SerialChooserContext : public KeyedService,
|
||||||
void EnsurePortManagerConnection();
|
void EnsurePortManagerConnection();
|
||||||
void SetUpPortManagerConnection(
|
void SetUpPortManagerConnection(
|
||||||
mojo::PendingRemote<device::mojom::SerialPortManager> manager);
|
mojo::PendingRemote<device::mojom::SerialPortManager> manager);
|
||||||
|
void OnGetDevices(std::vector<device::mojom::SerialPortInfoPtr> ports);
|
||||||
void OnPortManagerConnectionError();
|
void OnPortManagerConnectionError();
|
||||||
void RevokeObjectPermissionInternal(const url::Origin& origin,
|
void RevokeObjectPermissionInternal(const url::Origin& origin,
|
||||||
const base::Value& object,
|
const base::Value& object,
|
||||||
|
|
Loading…
Reference in a new issue