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

Unified Diff: android_webview/native/permission/aw_permission_request.h

Issue 239793002: Handle media access permission request (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix error, landed it again Created 6 years, 8 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: android_webview/native/permission/aw_permission_request.h
diff --git a/android_webview/native/permission/aw_permission_request.h b/android_webview/native/permission/aw_permission_request.h
new file mode 100644
index 0000000000000000000000000000000000000000..e52e10d92408413edb75a38a8dd9a6da36d58174
--- /dev/null
+++ b/android_webview/native/permission/aw_permission_request.h
@@ -0,0 +1,70 @@
+// 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.
+
+#ifndef ANDROID_WEBVIEW_NATIVE_PERMISSION_AW_PERMISSION_REQUEST_H
+#define ANDROID_WEBVIEW_NATIVE_PERMISSION_AW_PERMISSION_REQUEST_H
+
+#include "base/android/jni_weak_ref.h"
+#include "base/android/scoped_java_ref.h"
+#include "base/memory/weak_ptr.h"
+#include "url/gurl.h"
+
+namespace android_webview {
+
+class AwPermissionRequestDelegate;
+
+// This class wraps a permission request, it works with PermissionRequestHandler
+// and its' Java peer to represent the request to AwContentsClient.
+// The specific permission request should implement the
+// AwPermissionRequestDelegate interface, See MediaPermissionRequest.
+class AwPermissionRequest {
+ public:
+ // The definition must synced with Android's
+ // android.webkit.PermissionRequest.
+ enum Resource {
+ Geolocation = 1 << 0,
+ VideoCapture = 1 << 1,
+ AudioCapture = 1 << 2
+ };
+
+ // Take the ownership of |delegate|.
+ AwPermissionRequest(scoped_ptr<AwPermissionRequestDelegate> delegate);
+ virtual ~AwPermissionRequest();
+
+ base::WeakPtr<AwPermissionRequest> GetWeakPtr() {
+ return weak_factory_.GetWeakPtr();
+ }
+
+ // Create and return Java peer.
+ base::android::ScopedJavaLocalRef<jobject> CreateJavaPeer();
+
+ // Return the Java peer.
+ base::android::ScopedJavaLocalRef<jobject> GetJavaObject();
+
+ // Invoked by Java peer when request is processed, |granted| indicates the
+ // request was granted or not.
+ void OnAccept(JNIEnv* env, jobject jcaller, jboolean granted);
+
+ // Return the origin which initiated the request.
+ const GURL& GetOrigin();
+
+ // Return the resources origin requested.
+ int64 GetResources();
+
+ private:
+ friend class TestAwPermissionRequest;
+
+ scoped_ptr<AwPermissionRequestDelegate> delegate_;
+ JavaObjectWeakGlobalRef java_ref_;
+
+ base::WeakPtrFactory<AwPermissionRequest> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(AwPermissionRequest);
+};
+
+bool RegisterAwPermissionRequest(JNIEnv* env);
+
+} // namespace android_webivew
+
+#endif // ANDROID_WEBVIEW_NATIVE_PERMISSION_AW_PERMISSION_REQUEST_H
« no previous file with comments | « android_webview/native/aw_web_contents_delegate.cc ('k') | android_webview/native/permission/aw_permission_request.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698