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 21 matching lines...) Expand all Loading... | |
| 32 static bool IsObservable(blink::WebPermissionType type); | 32 static bool IsObservable(blink::WebPermissionType type); |
| 33 | 33 |
| 34 // The caller must guarantee that |service_registry| will have a lifetime | 34 // The caller must guarantee that |service_registry| will have a lifetime |
| 35 // larger than this instance of PermissionDispatcher. | 35 // larger than this instance of PermissionDispatcher. |
| 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::WebPermissionQueryCallback* callback); | 42 blink::WebPermissionCallback* callback); |
| 43 virtual void revokePermission(blink::WebPermissionType, | |
| 44 const blink::WebURL&, | |
| 45 blink::WebPermissionCallback*); | |
|
mlamouri (slow - plz ping)
2015/07/20 17:02:10
Please keep the argument names. Blink and Chromium
Lalit Maganti
2015/07/21 09:13:35
Done.
| |
| 43 virtual void startListening(blink::WebPermissionType type, | 46 virtual void startListening(blink::WebPermissionType type, |
| 44 const blink::WebURL& origin, | 47 const blink::WebURL& origin, |
| 45 blink::WebPermissionObserver* observer); | 48 blink::WebPermissionObserver* observer); |
| 46 virtual void stopListening(blink::WebPermissionObserver* observer); | 49 virtual void stopListening(blink::WebPermissionObserver* observer); |
| 47 | 50 |
| 48 // The following methods must be called by workers on the main thread. | 51 // The following methods must be called by workers on the main thread. |
| 49 void QueryPermissionForWorker(blink::WebPermissionType type, | 52 void QueryPermissionForWorker(blink::WebPermissionType type, |
| 50 const std::string& origin, | 53 const std::string& origin, |
| 51 blink::WebPermissionQueryCallback* callback, | 54 blink::WebPermissionCallback* callback, |
| 52 int worker_thread_id); | 55 int worker_thread_id); |
| 56 void RevokePermissionForWorker(blink::WebPermissionType type, | |
| 57 const std::string& origin, | |
| 58 blink::WebPermissionCallback* callback, | |
| 59 int worker_thread_id); | |
|
mlamouri (slow - plz ping)
2015/07/20 17:02:10
ditto
Lalit Maganti
2015/07/21 09:13:35
Done.
| |
| 53 void StartListeningForWorker( | 60 void StartListeningForWorker( |
| 54 blink::WebPermissionType type, | 61 blink::WebPermissionType type, |
| 55 const std::string& origin, | 62 const std::string& origin, |
| 56 int worker_thread_id, | 63 int worker_thread_id, |
| 57 const base::Callback<void(blink::WebPermissionStatus)>& callback); | 64 const base::Callback<void(blink::WebPermissionStatus)>& callback); |
| 58 void GetNextPermissionChangeForWorker( | 65 void GetNextPermissionChangeForWorker( |
| 59 blink::WebPermissionType type, | 66 blink::WebPermissionType type, |
| 60 const std::string& origin, | 67 const std::string& origin, |
| 61 blink::WebPermissionStatus status, | 68 blink::WebPermissionStatus status, |
| 62 int worker_thread_id, | 69 int worker_thread_id, |
| 63 const base::Callback<void(blink::WebPermissionStatus)>& callback); | 70 const base::Callback<void(blink::WebPermissionStatus)>& callback); |
| 64 | 71 |
| 65 private: | 72 private: |
| 66 // Runs the given |callback| with |status| as a parameter. It has to be run | 73 // Runs the given |callback| with |status| as a parameter. It has to be run |
| 67 // on a worker thread. | 74 // on a worker thread. |
| 68 static void RunCallbackOnWorkerThread( | 75 static void RunCallbackOnWorkerThread( |
| 69 blink::WebPermissionQueryCallback* callback, | 76 blink::WebPermissionCallback* callback, |
| 70 scoped_ptr<blink::WebPermissionStatus> status); | 77 scoped_ptr<blink::WebPermissionStatus> status); |
| 71 | 78 |
| 72 // Helper method that returns an initialized PermissionServicePtr. | 79 // Helper method that returns an initialized PermissionServicePtr. |
| 73 PermissionServicePtr& GetPermissionServicePtr(); | 80 PermissionServicePtr& GetPermissionServicePtr(); |
| 74 | 81 |
| 75 void QueryPermissionInternal(blink::WebPermissionType type, | 82 void QueryPermissionInternal(blink::WebPermissionType type, |
| 76 const std::string& origin, | 83 const std::string& origin, |
| 77 blink::WebPermissionQueryCallback* callback, | 84 blink::WebPermissionCallback* callback, |
| 78 int worker_thread_id); | 85 int worker_thread_id); |
| 86 void RevokePermissionInternal(blink::WebPermissionType type, | |
| 87 const std::string& origin, | |
| 88 blink::WebPermissionCallback* callback, | |
| 89 int worker_thread_id); | |
| 79 | 90 |
| 80 void OnQueryPermission(int request_id, PermissionStatus status); | 91 // This is the callback function used for request and revoke |
|
mlamouri (slow - plz ping)
2015/07/20 17:02:10
s/request and revoke/query and revoke/
Lalit Maganti
2015/07/21 09:13:35
Done.
| |
| 92 void OnPermissionResponse(int request_id, | |
| 93 PermissionStatus status); | |
| 81 void OnPermissionChanged(blink::WebPermissionType type, | 94 void OnPermissionChanged(blink::WebPermissionType type, |
| 82 const std::string& origin, | 95 const std::string& origin, |
| 83 blink::WebPermissionObserver* observer, | 96 blink::WebPermissionObserver* observer, |
| 84 PermissionStatus status); | 97 PermissionStatus status); |
| 85 void OnPermissionChangedForWorker( | 98 void OnPermissionChangedForWorker( |
| 86 int worker_thread_id, | 99 int worker_thread_id, |
| 87 const base::Callback<void(blink::WebPermissionStatus)>& callback, | 100 const base::Callback<void(blink::WebPermissionStatus)>& callback, |
| 88 PermissionStatus status); | 101 PermissionStatus status); |
| 89 | 102 |
| 90 void GetNextPermissionChange(blink::WebPermissionType type, | 103 void GetNextPermissionChange(blink::WebPermissionType type, |
| 91 const std::string& origin, | 104 const std::string& origin, |
| 92 blink::WebPermissionObserver* observer, | 105 blink::WebPermissionObserver* observer, |
| 93 PermissionStatus current_status); | 106 PermissionStatus current_status); |
| 94 | 107 |
| 95 // Saves some basic information about the callback in order to be able to run | 108 // Saves some basic information about the callback in order to be able to run |
| 96 // it in the right thread. | 109 // it in the right thread. |
| 97 class CallbackInformation { | 110 class CallbackInformation { |
| 98 public: | 111 public: |
| 99 CallbackInformation(blink::WebPermissionQueryCallback* callback, | 112 CallbackInformation(blink::WebPermissionCallback* callback, |
| 100 int worker_thread_id); | 113 int worker_thread_id); |
| 101 ~CallbackInformation(); | 114 ~CallbackInformation(); |
| 102 | 115 |
| 103 blink::WebPermissionQueryCallback* callback() const; | 116 blink::WebPermissionCallback* callback() const; |
| 104 int worker_thread_id() const; | 117 int worker_thread_id() const; |
| 105 | 118 |
| 106 blink::WebPermissionQueryCallback* ReleaseCallback(); | 119 blink::WebPermissionCallback* ReleaseCallback(); |
| 107 | 120 |
| 108 private: | 121 private: |
| 109 scoped_ptr<blink::WebPermissionQueryCallback> callback_; | 122 scoped_ptr<blink::WebPermissionCallback> callback_; |
| 110 int worker_thread_id_; | 123 int worker_thread_id_; |
| 111 | 124 |
| 112 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); | 125 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); |
| 113 }; | 126 }; |
| 114 using CallbackMap = IDMap<CallbackInformation, IDMapOwnPointer>; | 127 using CallbackMap = IDMap<CallbackInformation, IDMapOwnPointer>; |
| 115 CallbackMap pending_callbacks_; | 128 CallbackMap pending_callbacks_; |
| 116 | 129 |
| 117 ServiceRegistry* service_registry_; | 130 ServiceRegistry* service_registry_; |
| 118 PermissionServicePtr permission_service_; | 131 PermissionServicePtr permission_service_; |
| 119 | 132 |
| 120 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); | 133 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); |
| 121 }; | 134 }; |
| 122 | 135 |
| 123 } // namespace content | 136 } // namespace content |
| 124 | 137 |
| 125 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ | 138 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ |
| OLD | NEW |