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

Side by Side Diff: Source/modules/permissions/Permissions.cpp

Issue 1234023002: blink: permissions: add plumbing to revoke permissions (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Add Runtime flag for permissions Created 5 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "config.h" 5 #include "config.h"
6 #include "modules/permissions/Permissions.h" 6 #include "modules/permissions/Permissions.h"
7 7
8 #include "bindings/core/v8/ScriptPromise.h" 8 #include "bindings/core/v8/ScriptPromise.h"
9 #include "bindings/core/v8/ScriptPromiseResolver.h" 9 #include "bindings/core/v8/ScriptPromiseResolver.h"
10 #include "bindings/modules/v8/V8MidiPermissionDescriptor.h" 10 #include "bindings/modules/v8/V8MidiPermissionDescriptor.h"
11 #include "bindings/modules/v8/V8PermissionDescriptor.h" 11 #include "bindings/modules/v8/V8PermissionDescriptor.h"
12 #include "bindings/modules/v8/V8PushPermissionDescriptor.h" 12 #include "bindings/modules/v8/V8PushPermissionDescriptor.h"
13 #include "core/dom/DOMException.h" 13 #include "core/dom/DOMException.h"
14 #include "core/dom/Document.h" 14 #include "core/dom/Document.h"
15 #include "core/dom/ExceptionCode.h" 15 #include "core/dom/ExceptionCode.h"
16 #include "modules/permissions/PermissionCallback.h"
16 #include "modules/permissions/PermissionController.h" 17 #include "modules/permissions/PermissionController.h"
17 #include "modules/permissions/PermissionDescriptor.h" 18 #include "modules/permissions/PermissionDescriptor.h"
18 #include "modules/permissions/PermissionQueryCallback.h"
19 #include "modules/permissions/PermissionStatus.h" 19 #include "modules/permissions/PermissionStatus.h"
20 #include "public/platform/Platform.h" 20 #include "public/platform/Platform.h"
21 #include "public/platform/modules/permissions/WebPermissionClient.h" 21 #include "public/platform/modules/permissions/WebPermissionClient.h"
22 22
23 namespace blink { 23 namespace blink {
24 24
25 namespace { 25 namespace {
26 26
27 WebPermissionClient* permissionClient(ExecutionContext* executionContext) 27 WebPermissionClient* permissionClient(ExecutionContext* executionContext)
28 { 28 {
29 if (executionContext->isDocument()) { 29 if (executionContext->isDocument()) {
30 Document* document = toDocument(executionContext); 30 Document* document = toDocument(executionContext);
31 if (!document->frame()) 31 if (!document->frame())
32 return nullptr; 32 return nullptr;
33 PermissionController* controller = PermissionController::from(*document- >frame()); 33 PermissionController* controller = PermissionController::from(*document- >frame());
34 return controller ? controller->client() : nullptr; 34 return controller ? controller->client() : nullptr;
35 } 35 }
36 return Platform::current()->permissionClient(); 36 return Platform::current()->permissionClient();
37 } 37 }
38 38
39 bool quickHandlePermissions(
mlamouri (slow - plz ping) 2015/07/17 13:16:18 Could you call that "handleDefaultBehaviour()" and
Lalit Maganti 2015/07/17 13:47:35 Done. The name you suggest is nice - I couldn't re
40 ScriptState* scriptState, const ScriptValue& rawPermission, PassRefPtr<Scrip tPromiseResolver> resolver, WebPermissionType type, TrackExceptionState& excepti onState)
41 {
42 if (type == WebPermissionTypePushNotifications) {
43 PushPermissionDescriptor pushPermission = NativeValueTraits<PushPermissi onDescriptor>::nativeValue(scriptState->isolate(), rawPermission.v8Value(), exce ptionState);
44 // Only "userVisibleOnly" push is supported for now.
45 if (!pushPermission.userVisibleOnly()) {
46 resolver->reject(DOMException::create(NotSupportedError, "Push Permi ssion without userVisibleOnly:true isn't supported yet."));
47 return true;
48 }
49 } else if (type == WebPermissionTypeMidiSysEx) {
50 MidiPermissionDescriptor midiPermission = NativeValueTraits<MidiPermissi onDescriptor>::nativeValue(scriptState->isolate(), rawPermission.v8Value(), exce ptionState);
51 // Only sysex usage requires a permission, otherwise it is granted.
52 if (!midiPermission.sysex()) {
53 resolver->resolve(PermissionStatus::create(scriptState->executionCon text(), WebPermissionStatusGranted, WebPermissionTypeMidi));
54 return true;
55 }
56 }
57 return false;
58 }
59
39 } // anonymous namespace 60 } // anonymous namespace
40 61
41 ScriptPromise Permissions::query(ScriptState* scriptState, const ScriptValue& ra wPermission) 62 ScriptPromise Permissions::query(ScriptState* scriptState, const ScriptValue& ra wPermission)
42 { 63 {
43 WebPermissionClient* client = permissionClient(scriptState->executionContext ()); 64 WebPermissionClient* client = permissionClient(scriptState->executionContext ());
44 if (!client) 65 if (!client)
45 return ScriptPromise::rejectWithDOMException(scriptState, DOMException:: create(InvalidStateError, "In its current state, the global scope can't query pe rmissions.")); 66 return ScriptPromise::rejectWithDOMException(scriptState, DOMException:: create(InvalidStateError, "In its current state, the global scope can't query pe rmissions."));
46 67
47 TrackExceptionState exceptionState; 68 TrackExceptionState exceptionState;
48 PermissionDescriptor permission = NativeValueTraits<PermissionDescriptor>::n ativeValue(scriptState->isolate(), rawPermission.v8Value(), exceptionState); 69 PermissionDescriptor permission = NativeValueTraits<PermissionDescriptor>::n ativeValue(scriptState->isolate(), rawPermission.v8Value(), exceptionState);
49 70
50 71
51 if (exceptionState.hadException()) 72 if (exceptionState.hadException())
52 return ScriptPromise::reject(scriptState, v8::Exception::TypeError(v8Str ing(scriptState->isolate(), exceptionState.message()))); 73 return ScriptPromise::reject(scriptState, v8::Exception::TypeError(v8Str ing(scriptState->isolate(), exceptionState.message())));
53 74
54 RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scrip tState); 75 RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scrip tState);
55 ScriptPromise promise = resolver->promise(); 76 ScriptPromise promise = resolver->promise();
56 77
57 String name = permission.name(); 78 String name = permission.name();
58 WebPermissionType type; 79 WebPermissionType type = convertPermissionStringToType(name);
59 if (name == "geolocation") { 80 bool handled = quickHandlePermissions(scriptState, rawPermission, resolver, type, exceptionState);
60 type = WebPermissionTypeGeolocation; 81
61 } else if (name == "notifications") { 82 if (handled)
62 type = WebPermissionTypeNotifications; 83 return promise;
mlamouri (slow - plz ping) 2015/07/17 13:16:18 if (handleDefaultBehaviour(...)) return promis
Lalit Maganti 2015/07/17 13:47:35 Done. This is a pattern I've got to get used to.
63 } else if (name == "push") {
64 PushPermissionDescriptor pushPermission = NativeValueTraits<PushPermissi onDescriptor>::nativeValue(scriptState->isolate(), rawPermission.v8Value(), exce ptionState);
65 // Only "userVisibleOnly" push is supported for now.
66 if (!pushPermission.userVisibleOnly()) {
67 resolver->reject(DOMException::create(NotSupportedError, "Push Permi ssion without userVisibleOnly:true isn't supported yet."));
68 return promise;
69 }
70 type = WebPermissionTypePushNotifications;
71 } else if (name == "midi") {
72 MidiPermissionDescriptor midiPermission = NativeValueTraits<MidiPermissi onDescriptor>::nativeValue(scriptState->isolate(), rawPermission.v8Value(), exce ptionState);
73 // Only sysex usage requires a permission, otherwise it is granted.
74 if (!midiPermission.sysex()) {
75 resolver->resolve(PermissionStatus::create(scriptState->executionCon text(), WebPermissionStatusGranted, WebPermissionTypeMidi));
76 return promise;
77 }
78 type = WebPermissionTypeMidiSysEx;
79 } else {
80 ASSERT_NOT_REACHED();
81 type = WebPermissionTypeGeolocation;
82 }
83 84
84 // If the current origin is a file scheme, it will unlikely return a 85 // If the current origin is a file scheme, it will unlikely return a
85 // meaningful value because most APIs are broken on file scheme and no 86 // meaningful value because most APIs are broken on file scheme and no
86 // permission prompt will be shown even if the returned permission will most 87 // permission prompt will be shown even if the returned permission will most
87 // likely be "prompt". 88 // likely be "prompt".
88 client->queryPermission(type, KURL(KURL(), scriptState->executionContext()-> securityOrigin()->toString()), new PermissionQueryCallback(resolver, type)); 89 client->queryPermission(type, KURL(KURL(), scriptState->executionContext()-> securityOrigin()->toString()), new PermissionCallback(resolver, type));
89 return promise; 90 return promise;
90 } 91 }
91 92
93 ScriptPromise Permissions::revoke(ScriptState* scriptState, const ScriptValue& r awPermission)
94 {
95 WebPermissionClient* client = permissionClient(scriptState->executionContext ());
96 if (!client)
97 return ScriptPromise::rejectWithDOMException(scriptState, DOMException:: create(InvalidStateError, "In its current state, the global scope can't revoke p ermissions."));
98
99 TrackExceptionState exceptionState;
100 PermissionDescriptor permission = NativeValueTraits<PermissionDescriptor>::n ativeValue(scriptState->isolate(), rawPermission.v8Value(), exceptionState);
101
102 if (exceptionState.hadException())
103 return ScriptPromise::reject(scriptState, v8::Exception::TypeError(v8Str ing(scriptState->isolate(), exceptionState.message())));
104
105 RefPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::create(scrip tState);
106 ScriptPromise promise = resolver->promise();
107
108 String name = permission.name();
109 WebPermissionType type = convertPermissionStringToType(name);
110 bool handled = quickHandlePermissions(scriptState, rawPermission, resolver, type, exceptionState);
111
112 if (handled)
113 return promise;
mlamouri (slow - plz ping) 2015/07/17 13:16:18 ditto
Lalit Maganti 2015/07/17 13:47:35 Done.
114
115 client->revokePermission(type, KURL(KURL(), scriptState->executionContext()- >securityOrigin()->toString()), new PermissionCallback(resolver, type));
116 return promise;
117 }
118
119 WebPermissionType Permissions::convertPermissionStringToType(const String& name)
120 {
121 if (name == "geolocation")
122 return WebPermissionTypeGeolocation;
123 if (name == "notifications")
124 return WebPermissionTypeNotifications;
125 if (name == "push")
126 return WebPermissionTypePushNotifications;
127 if (name == "midi")
128 return WebPermissionTypeMidiSysEx;
129
130 ASSERT_NOT_REACHED();
131 return WebPermissionTypeGeolocation;
132 }
133
92 } // namespace blink 134 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698