Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2408)

Unified Diff: chrome/browser/android/dev_tools_server.cc

Issue 382143005: Supports DevTools socket access authentication based on Android permissions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Packing parameters to a stucture Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/android/dev_tools_server.cc
diff --git a/chrome/browser/android/dev_tools_server.cc b/chrome/browser/android/dev_tools_server.cc
index acdb6b589d5bd7225c51eeb82d05122367aeb6f8..8e71af4b80c7a2c9aecf0a58baac9155282b5c63 100644
--- a/chrome/browser/android/dev_tools_server.cc
+++ b/chrome/browser/android/dev_tools_server.cc
@@ -77,6 +77,14 @@ static GURL GetFaviconURLForContents(WebContents* web_contents) {
return GURL();
}
+bool AuthenticateSocketAccess(
+ const net::UnixDomainServerSocket::Credentials& credentials) {
+ JNIEnv* env = base::android::AttachCurrentThread();
+ return Java_DevToolsServer_checkPermission(env,
+ credentials.process_id, credentials.user_id) ||
byungchul 2014/08/04 22:18:02 wrong indentation. Should be aligned to '(', or li
SeRya 2014/08/05 10:32:27 Done.
+ content::CanUserConnectToDevTools(credentials);
+}
+
class TargetBase : public content::DevToolsTarget {
public:
// content::DevToolsTarget implementation:
@@ -371,7 +379,7 @@ class DevToolsServerDelegate : public content::DevToolsHttpHandlerDelegate {
*name,
"",
delegate,
- base::Bind(&content::CanUserConnectToDevTools))
+ base::Bind(&AuthenticateSocketAccess))
.PassAs<net::StreamListenSocket>();
}
@@ -427,7 +435,7 @@ void DevToolsServer::Start() {
new net::deprecated::UnixDomainListenSocketWithAbstractNamespaceFactory(
socket_name_,
base::StringPrintf("%s_%d", socket_name_.c_str(), getpid()),
- base::Bind(&content::CanUserConnectToDevTools)),
+ base::Bind(&AuthenticateSocketAccess)),
base::StringPrintf(kFrontEndURL, content::GetWebKitRevision().c_str()),
new DevToolsServerDelegate(),
base::FilePath());

Powered by Google App Engine
This is Rietveld 408576698