electron/atom/browser/atom_permission_manager.cc

155 lines
4.9 KiB
C++
Raw Normal View History

// Copyright (c) 2016 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/browser/atom_permission_manager.h"
2016-03-08 14:32:59 +00:00
#include <vector>
#include "atom/browser/web_contents_preferences.h"
2016-01-30 13:31:10 +00:00
#include "content/public/browser/child_process_security_policy.h"
#include "content/public/browser/permission_type.h"
#include "content/public/browser/render_frame_host.h"
#include "content/public/browser/render_process_host.h"
2016-02-01 09:43:49 +00:00
#include "content/public/browser/render_view_host.h"
#include "content/public/browser/web_contents.h"
namespace atom {
2016-02-01 09:43:49 +00:00
namespace {
bool WebContentsDestroyed(int process_id) {
auto contents =
WebContentsPreferences::GetWebContentsFromProcessID(process_id);
if (!contents)
return true;
return contents->IsBeingDestroyed();
2016-02-01 09:43:49 +00:00
}
} // namespace
AtomPermissionManager::AtomPermissionManager()
: request_id_(0) {
}
AtomPermissionManager::~AtomPermissionManager() {
}
void AtomPermissionManager::SetPermissionRequestHandler(
const RequestHandler& handler) {
if (handler.is_null() && !pending_requests_.empty()) {
2016-02-01 09:43:49 +00:00
for (const auto& request : pending_requests_) {
if (!WebContentsDestroyed(request.second.render_process_id))
2016-05-23 01:59:39 +00:00
request.second.callback.Run(blink::mojom::PermissionStatus::DENIED);
2016-02-01 09:43:49 +00:00
}
pending_requests_.clear();
}
request_handler_ = handler;
}
int AtomPermissionManager::RequestPermission(
content::PermissionType permission,
content::RenderFrameHost* render_frame_host,
const GURL& requesting_origin,
2016-11-30 07:30:03 +00:00
bool user_gesture,
const ResponseCallback& response_callback) {
2016-02-01 09:43:49 +00:00
int process_id = render_frame_host->GetProcess()->GetID();
2016-01-30 13:31:10 +00:00
if (permission == content::PermissionType::MIDI_SYSEX) {
content::ChildProcessSecurityPolicy::GetInstance()->
2016-02-01 09:43:49 +00:00
GrantSendMidiSysExMessage(process_id);
2016-01-30 13:31:10 +00:00
}
if (!request_handler_.is_null()) {
auto web_contents =
content::WebContents::FromRenderFrameHost(render_frame_host);
++request_id_;
auto callback = base::Bind(&AtomPermissionManager::OnPermissionResponse,
base::Unretained(this),
request_id_,
requesting_origin,
response_callback);
2016-02-01 09:43:49 +00:00
pending_requests_[request_id_] = { process_id, callback };
request_handler_.Run(web_contents, permission, callback);
return request_id_;
}
2016-05-23 01:59:39 +00:00
response_callback.Run(blink::mojom::PermissionStatus::GRANTED);
return kNoPendingOperation;
}
2016-03-08 14:28:53 +00:00
int AtomPermissionManager::RequestPermissions(
const std::vector<content::PermissionType>& permissions,
content::RenderFrameHost* render_frame_host,
const GURL& requesting_origin,
2016-11-30 07:30:03 +00:00
bool user_gesture,
2016-03-08 14:28:53 +00:00
const base::Callback<void(
2016-11-30 07:30:03 +00:00
const std::vector<blink::mojom::PermissionStatus>&)>& callback) {
2016-03-08 14:28:53 +00:00
// FIXME(zcbenz): Just ignore multiple permissions request for now.
2016-05-23 01:59:39 +00:00
std::vector<blink::mojom::PermissionStatus> permissionStatuses;
2016-03-08 14:28:53 +00:00
for (auto permission : permissions) {
if (permission == content::PermissionType::MIDI_SYSEX) {
content::ChildProcessSecurityPolicy::GetInstance()->
GrantSendMidiSysExMessage(render_frame_host->GetProcess()->GetID());
}
2016-05-23 01:59:39 +00:00
permissionStatuses.push_back(blink::mojom::PermissionStatus::GRANTED);
2016-03-08 14:28:53 +00:00
}
callback.Run(permissionStatuses);
return kNoPendingOperation;
}
void AtomPermissionManager::OnPermissionResponse(
int request_id,
const GURL& origin,
const ResponseCallback& callback,
2016-05-23 01:59:39 +00:00
blink::mojom::PermissionStatus status) {
2016-02-01 09:43:49 +00:00
auto request = pending_requests_.find(request_id);
if (request != pending_requests_.end()) {
if (!WebContentsDestroyed(request->second.render_process_id))
callback.Run(status);
pending_requests_.erase(request);
}
}
void AtomPermissionManager::CancelPermissionRequest(int request_id) {
auto request = pending_requests_.find(request_id);
if (request != pending_requests_.end()) {
2016-02-01 09:43:49 +00:00
if (!WebContentsDestroyed(request->second.render_process_id))
2016-05-23 01:59:39 +00:00
request->second.callback.Run(blink::mojom::PermissionStatus::DENIED);
pending_requests_.erase(request);
}
}
void AtomPermissionManager::ResetPermission(
content::PermissionType permission,
const GURL& requesting_origin,
const GURL& embedding_origin) {
}
2016-05-23 01:59:39 +00:00
blink::mojom::PermissionStatus AtomPermissionManager::GetPermissionStatus(
content::PermissionType permission,
const GURL& requesting_origin,
const GURL& embedding_origin) {
2016-05-23 01:59:39 +00:00
return blink::mojom::PermissionStatus::GRANTED;
}
void AtomPermissionManager::RegisterPermissionUsage(
content::PermissionType permission,
const GURL& requesting_origin,
const GURL& embedding_origin) {
}
int AtomPermissionManager::SubscribePermissionStatusChange(
content::PermissionType permission,
const GURL& requesting_origin,
const GURL& embedding_origin,
const ResponseCallback& callback) {
return -1;
}
void AtomPermissionManager::UnsubscribePermissionStatusChange(
int subscription_id) {
}
} // namespace atom