Chromium Code Reviews| Index: android_webview/java/src/org/chromium/android_webview/permission/AwPermissionRequest.java |
| diff --git a/android_webview/java/src/org/chromium/android_webview/permission/AwPermissionRequest.java b/android_webview/java/src/org/chromium/android_webview/permission/AwPermissionRequest.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..98acde44adfdffe5966711d1818389e6ebe2203a |
| --- /dev/null |
| +++ b/android_webview/java/src/org/chromium/android_webview/permission/AwPermissionRequest.java |
| @@ -0,0 +1,64 @@ |
| +// 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. |
| + |
| +package org.chromium.android_webview.permission; |
| + |
| +import android.net.Uri; |
| + |
| +import org.chromium.base.CalledByNative; |
| +import org.chromium.base.JNINamespace; |
| + |
| +/** |
| + * This class wraps permission request in Chromium side, and can only be created |
| + * by native side. |
| + */ |
| +@JNINamespace("android_webview") |
| +public class AwPermissionRequest { |
| + private Uri mOrigin; |
| + private long mResources; |
| + |
| + // AwPermissionRequest native instance. |
| + private long mNativeAwPermissionRequest; |
| + |
| + @CalledByNative |
| + public static AwPermissionRequest create(long nativeAwPermissionRequest) { |
| + if (nativeAwPermissionRequest == 0) return null; |
| + return new AwPermissionRequest(nativeAwPermissionRequest); |
| + } |
| + |
| + private AwPermissionRequest(long nativeAwPermissionRequest) { |
| + mNativeAwPermissionRequest = nativeAwPermissionRequest; |
| + mOrigin = Uri.parse(nativeGetOrigin(mNativeAwPermissionRequest)); |
|
benm (inactive)
2014/04/16 14:51:10
Is it better to pass these values from native into
michaelbai
2014/04/22 20:53:51
Thanks
|
| + mResources = nativeGetResources(mNativeAwPermissionRequest); |
| + } |
| + |
| + public Uri getOrigin() { |
| + return mOrigin; |
| + } |
| + |
| + public long getResources() { |
| + return mResources; |
| + } |
| + |
| + public void grant() { |
| + if (mNativeAwPermissionRequest != 0) |
| + nativeOnAccept(mNativeAwPermissionRequest, true); |
| + destory(); |
| + } |
| + |
| + public void deny() { |
| + if (mNativeAwPermissionRequest != 0) |
| + nativeOnAccept(mNativeAwPermissionRequest, false); |
| + destory(); |
| + } |
| + |
| + @CalledByNative |
| + private void destory() { |
|
mkosiba (inactive)
2014/04/17 10:34:06
probably a good idea to have a finalizer for this.
michaelbai
2014/04/22 20:53:51
Right, thanks
On 2014/04/17 10:34:06, mkosiba wro
|
| + mNativeAwPermissionRequest = 0; |
| + } |
| + |
| + private native void nativeOnAccept(long nativeAwPermissionRequest, boolean allowed); |
| + private native String nativeGetOrigin(long nativeAwPermissionRequest); |
| + private native long nativeGetResources(long nativeAwPermissionRequest); |
| +} |