Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 #ifndef CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ | 5 #ifndef CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ |
| 6 #define CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ | 6 #define CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/callback_forward.h" | 10 #include "base/callback_forward.h" |
| (...skipping 25 matching lines...) Expand all Loading... | |
| 36 explicit PermissionDispatcher(ServiceRegistry* service_registry); | 36 explicit PermissionDispatcher(ServiceRegistry* service_registry); |
| 37 virtual ~PermissionDispatcher(); | 37 virtual ~PermissionDispatcher(); |
| 38 | 38 |
| 39 // blink::WebPermissionClient implementation. | 39 // blink::WebPermissionClient implementation. |
| 40 virtual void queryPermission(blink::WebPermissionType type, | 40 virtual void queryPermission(blink::WebPermissionType type, |
| 41 const blink::WebURL& origin, | 41 const blink::WebURL& origin, |
| 42 blink::WebPermissionCallback* callback); | 42 blink::WebPermissionCallback* callback); |
| 43 virtual void requestPermission(blink::WebPermissionType, | 43 virtual void requestPermission(blink::WebPermissionType, |
| 44 const blink::WebURL& origin, | 44 const blink::WebURL& origin, |
| 45 blink::WebPermissionCallback* callback); | 45 blink::WebPermissionCallback* callback); |
| 46 virtual void requestPermissions( | |
| 47 const blink::WebVector<blink::WebPermissionType>& types, | |
| 48 const blink::WebURL& origin, | |
| 49 blink::WebPermissionsCallback* callback); | |
| 46 virtual void revokePermission(blink::WebPermissionType, | 50 virtual void revokePermission(blink::WebPermissionType, |
| 47 const blink::WebURL& origin, | 51 const blink::WebURL& origin, |
| 48 blink::WebPermissionCallback* callback); | 52 blink::WebPermissionCallback* callback); |
| 49 virtual void startListening(blink::WebPermissionType type, | 53 virtual void startListening(blink::WebPermissionType type, |
| 50 const blink::WebURL& origin, | 54 const blink::WebURL& origin, |
| 51 blink::WebPermissionObserver* observer); | 55 blink::WebPermissionObserver* observer); |
| 52 virtual void stopListening(blink::WebPermissionObserver* observer); | 56 virtual void stopListening(blink::WebPermissionObserver* observer); |
| 53 | 57 |
| 54 // The following methods must be called by workers on the main thread. | 58 // The following methods must be called by workers on the main thread. |
| 55 void QueryPermissionForWorker(blink::WebPermissionType type, | 59 void QueryPermissionForWorker(blink::WebPermissionType type, |
| 56 const std::string& origin, | 60 const std::string& origin, |
| 57 blink::WebPermissionCallback* callback, | 61 blink::WebPermissionCallback* callback, |
| 58 int worker_thread_id); | 62 int worker_thread_id); |
| 59 void RequestPermissionForWorker(blink::WebPermissionType type, | 63 void RequestPermissionForWorker(blink::WebPermissionType type, |
| 60 const std::string& origin, | 64 const std::string& origin, |
| 61 blink::WebPermissionCallback* callback, | 65 blink::WebPermissionCallback* callback, |
| 62 int worker_thread_id); | 66 int worker_thread_id); |
| 67 void RequestPermissionsForWorker( | |
| 68 const blink::WebVector<blink::WebPermissionType>& types, | |
| 69 const std::string& origin, | |
| 70 blink::WebPermissionsCallback* callback, | |
| 71 int worker_thread_id); | |
| 63 void RevokePermissionForWorker(blink::WebPermissionType type, | 72 void RevokePermissionForWorker(blink::WebPermissionType type, |
| 64 const std::string& origin, | 73 const std::string& origin, |
| 65 blink::WebPermissionCallback* callback, | 74 blink::WebPermissionCallback* callback, |
| 66 int worker_thread_id); | 75 int worker_thread_id); |
| 67 void StartListeningForWorker( | 76 void StartListeningForWorker( |
| 68 blink::WebPermissionType type, | 77 blink::WebPermissionType type, |
| 69 const std::string& origin, | 78 const std::string& origin, |
| 70 int worker_thread_id, | 79 int worker_thread_id, |
| 71 const base::Callback<void(blink::WebPermissionStatus)>& callback); | 80 const base::Callback<void(blink::WebPermissionStatus)>& callback); |
| 72 void GetNextPermissionChangeForWorker( | 81 void GetNextPermissionChangeForWorker( |
| 73 blink::WebPermissionType type, | 82 blink::WebPermissionType type, |
| 74 const std::string& origin, | 83 const std::string& origin, |
| 75 blink::WebPermissionStatus status, | 84 blink::WebPermissionStatus status, |
| 76 int worker_thread_id, | 85 int worker_thread_id, |
| 77 const base::Callback<void(blink::WebPermissionStatus)>& callback); | 86 const base::Callback<void(blink::WebPermissionStatus)>& callback); |
| 78 | 87 |
| 79 private: | 88 private: |
| 80 // Runs the given |callback| with |status| as a parameter. It has to be run | 89 // Runs the given |callback| with |status| as a parameter. It has to be run |
| 81 // on a worker thread. | 90 // on a worker thread. |
| 82 static void RunCallbackOnWorkerThread( | 91 static void RunCallbackOnWorkerThread( |
| 83 blink::WebPermissionCallback* callback, | 92 blink::WebPermissionCallback* callback, |
| 84 scoped_ptr<blink::WebPermissionStatus> status); | 93 scoped_ptr<blink::WebPermissionStatus> status); |
| 94 static void RunMultiCallbackOnWorkerThread( | |
|
mlamouri (slow - plz ping)
2015/08/18 13:37:15
I think it's find to overload RunCallbackOnWorkerT
Lalit Maganti
2015/08/20 14:23:30
Can't actually do this because I use it in a callb
| |
| 95 blink::WebPermissionsCallback* callback, | |
| 96 scoped_ptr<blink::WebVector<blink::WebPermissionStatus>> statuses); | |
| 85 | 97 |
| 86 // Helper method that returns an initialized PermissionServicePtr. | 98 // Helper method that returns an initialized PermissionServicePtr. |
| 87 PermissionServicePtr& GetPermissionServicePtr(); | 99 PermissionServicePtr& GetPermissionServicePtr(); |
| 88 | 100 |
| 89 void QueryPermissionInternal(blink::WebPermissionType type, | 101 void QueryPermissionInternal(blink::WebPermissionType type, |
| 90 const std::string& origin, | 102 const std::string& origin, |
| 91 blink::WebPermissionCallback* callback, | 103 blink::WebPermissionCallback* callback, |
| 92 int worker_thread_id); | 104 int worker_thread_id); |
| 93 void RequestPermissionInternal(blink::WebPermissionType type, | 105 void RequestPermissionInternal(blink::WebPermissionType type, |
| 94 const std::string& origin, | 106 const std::string& origin, |
| 95 blink::WebPermissionCallback* callback, | 107 blink::WebPermissionCallback* callback, |
| 96 int worker_thread_id); | 108 int worker_thread_id); |
| 109 void RequestPermissionsInternal( | |
| 110 const blink::WebVector<blink::WebPermissionType>& types, | |
| 111 const std::string& origin, | |
| 112 blink::WebPermissionsCallback* callback, | |
| 113 int worker_thread_id); | |
| 97 void RevokePermissionInternal(blink::WebPermissionType type, | 114 void RevokePermissionInternal(blink::WebPermissionType type, |
| 98 const std::string& origin, | 115 const std::string& origin, |
| 99 blink::WebPermissionCallback* callback, | 116 blink::WebPermissionCallback* callback, |
| 100 int worker_thread_id); | 117 int worker_thread_id); |
| 101 | 118 |
| 102 // This is the callback function used for query and revoke | 119 // This is the callback function used for query and revoke |
| 103 void OnPermissionResponse(int request_id, | 120 void OnPermissionResponse(int request_id, |
| 104 PermissionStatus status); | 121 PermissionStatus status); |
| 122 void OnPermissionsResponse(int request_id, | |
| 123 const mojo::Array<PermissionStatus>& status); | |
| 105 void OnPermissionChanged(blink::WebPermissionType type, | 124 void OnPermissionChanged(blink::WebPermissionType type, |
| 106 const std::string& origin, | 125 const std::string& origin, |
| 107 blink::WebPermissionObserver* observer, | 126 blink::WebPermissionObserver* observer, |
| 108 PermissionStatus status); | 127 PermissionStatus status); |
| 109 void OnPermissionChangedForWorker( | 128 void OnPermissionChangedForWorker( |
| 110 int worker_thread_id, | 129 int worker_thread_id, |
| 111 const base::Callback<void(blink::WebPermissionStatus)>& callback, | 130 const base::Callback<void(blink::WebPermissionStatus)>& callback, |
| 112 PermissionStatus status); | 131 PermissionStatus status); |
| 113 | 132 |
| 114 void GetNextPermissionChange(blink::WebPermissionType type, | 133 void GetNextPermissionChange(blink::WebPermissionType type, |
| 115 const std::string& origin, | 134 const std::string& origin, |
| 116 blink::WebPermissionObserver* observer, | 135 blink::WebPermissionObserver* observer, |
| 117 PermissionStatus current_status); | 136 PermissionStatus current_status); |
| 118 | 137 |
| 119 // Saves some basic information about the callback in order to be able to run | 138 // Saves some basic information about the callback in order to be able to run |
| 120 // it in the right thread. | 139 // it in the right thread. |
| 140 template<typename T> | |
| 121 class CallbackInformation { | 141 class CallbackInformation { |
| 122 public: | 142 public: |
| 123 CallbackInformation(blink::WebPermissionCallback* callback, | 143 CallbackInformation(T* callback, |
| 124 int worker_thread_id); | 144 int worker_thread_id) |
| 125 ~CallbackInformation(); | 145 : callback_(callback), |
| 146 worker_thread_id_(worker_thread_id) { | |
| 147 } | |
| 126 | 148 |
| 127 blink::WebPermissionCallback* callback() const; | 149 ~CallbackInformation() {} |
|
mlamouri (slow - plz ping)
2015/08/18 13:37:15
nit: = default.
Lalit Maganti
2015/08/20 14:23:30
Removed class.
| |
| 128 int worker_thread_id() const; | |
| 129 | 150 |
| 130 blink::WebPermissionCallback* ReleaseCallback(); | 151 T* callback() const { |
| 152 return callback_.get(); | |
| 153 } | |
| 154 | |
| 155 int worker_thread_id() const { | |
| 156 return worker_thread_id_; | |
| 157 } | |
| 158 | |
| 159 T* ReleaseCallback() { | |
| 160 return callback_.release(); | |
| 161 } | |
| 131 | 162 |
| 132 private: | 163 private: |
| 133 scoped_ptr<blink::WebPermissionCallback> callback_; | 164 scoped_ptr<T> callback_; |
| 134 int worker_thread_id_; | 165 int worker_thread_id_; |
| 135 | 166 |
| 136 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); | 167 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); |
| 137 }; | 168 }; |
| 138 using CallbackMap = IDMap<CallbackInformation, IDMapOwnPointer>; | 169 |
| 170 using SingleCallbackInfo = CallbackInformation<blink::WebPermissionCallback>; | |
|
mlamouri (slow - plz ping)
2015/08/18 13:37:15
I dislike the name to be honest. Maybe you could c
Lalit Maganti
2015/08/20 14:23:30
The reason I put the using is because the lines be
| |
| 171 using CallbackMap = IDMap<SingleCallbackInfo, IDMapOwnPointer>; | |
| 139 CallbackMap pending_callbacks_; | 172 CallbackMap pending_callbacks_; |
| 140 | 173 |
| 174 using MultiCallbackInfo = CallbackInformation<blink::WebPermissionsCallback>; | |
|
mlamouri (slow - plz ping)
2015/08/18 13:37:15
ditto.
Lalit Maganti
2015/08/20 14:23:30
Acknowledged.
| |
| 175 using MultipleCallbackMap = IDMap<MultiCallbackInfo, IDMapOwnPointer>; | |
|
mlamouri (slow - plz ping)
2015/08/18 13:37:15
Again, the name isn't clear. At least, add a comme
Lalit Maganti
2015/08/20 14:23:30
Acknowledged.
| |
| 176 MultipleCallbackMap multiple_pending_callbacks_; | |
| 177 | |
| 141 ServiceRegistry* service_registry_; | 178 ServiceRegistry* service_registry_; |
| 142 PermissionServicePtr permission_service_; | 179 PermissionServicePtr permission_service_; |
| 143 | 180 |
| 144 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); | 181 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); |
| 145 }; | 182 }; |
| 146 | 183 |
| 147 } // namespace content | 184 } // namespace content |
| 148 | 185 |
| 149 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ | 186 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ |
| OLD | NEW |