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*); | |
| 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); | |
| 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); | |
| 90 void OnQueryOrRevokePermission(int request_id, PermissionStatus status); | |
|
mlamouri (slow - plz ping)
2015/07/17 13:21:27
Could you keep that in the same block as OnPermiss
| |
| 79 | 91 |
| 80 void OnQueryPermission(int request_id, PermissionStatus status); | |
| 81 void OnPermissionChanged(blink::WebPermissionType type, | 92 void OnPermissionChanged(blink::WebPermissionType type, |
| 82 const std::string& origin, | 93 const std::string& origin, |
| 83 blink::WebPermissionObserver* observer, | 94 blink::WebPermissionObserver* observer, |
| 84 PermissionStatus status); | 95 PermissionStatus status); |
| 85 void OnPermissionChangedForWorker( | 96 void OnPermissionChangedForWorker( |
| 86 int worker_thread_id, | 97 int worker_thread_id, |
| 87 const base::Callback<void(blink::WebPermissionStatus)>& callback, | 98 const base::Callback<void(blink::WebPermissionStatus)>& callback, |
| 88 PermissionStatus status); | 99 PermissionStatus status); |
| 89 | 100 |
| 90 void GetNextPermissionChange(blink::WebPermissionType type, | 101 void GetNextPermissionChange(blink::WebPermissionType type, |
| 91 const std::string& origin, | 102 const std::string& origin, |
| 92 blink::WebPermissionObserver* observer, | 103 blink::WebPermissionObserver* observer, |
| 93 PermissionStatus current_status); | 104 PermissionStatus current_status); |
| 94 | 105 |
| 95 // Saves some basic information about the callback in order to be able to run | 106 // Saves some basic information about the callback in order to be able to run |
| 96 // it in the right thread. | 107 // it in the right thread. |
| 97 class CallbackInformation { | 108 class CallbackInformation { |
| 98 public: | 109 public: |
| 99 CallbackInformation(blink::WebPermissionQueryCallback* callback, | 110 CallbackInformation(blink::WebPermissionCallback* callback, |
| 100 int worker_thread_id); | 111 int worker_thread_id); |
| 101 ~CallbackInformation(); | 112 ~CallbackInformation(); |
| 102 | 113 |
| 103 blink::WebPermissionQueryCallback* callback() const; | 114 blink::WebPermissionCallback* callback() const; |
| 104 int worker_thread_id() const; | 115 int worker_thread_id() const; |
| 105 | 116 |
| 106 blink::WebPermissionQueryCallback* ReleaseCallback(); | 117 blink::WebPermissionCallback* ReleaseCallback(); |
| 107 | 118 |
| 108 private: | 119 private: |
| 109 scoped_ptr<blink::WebPermissionQueryCallback> callback_; | 120 scoped_ptr<blink::WebPermissionCallback> callback_; |
| 110 int worker_thread_id_; | 121 int worker_thread_id_; |
| 111 | 122 |
| 112 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); | 123 DISALLOW_COPY_AND_ASSIGN(CallbackInformation); |
| 113 }; | 124 }; |
| 114 using CallbackMap = IDMap<CallbackInformation, IDMapOwnPointer>; | 125 using CallbackMap = IDMap<CallbackInformation, IDMapOwnPointer>; |
| 115 CallbackMap pending_callbacks_; | 126 CallbackMap pending_callbacks_; |
| 116 | 127 |
| 117 ServiceRegistry* service_registry_; | 128 ServiceRegistry* service_registry_; |
| 118 PermissionServicePtr permission_service_; | 129 PermissionServicePtr permission_service_; |
| 119 | 130 |
| 120 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); | 131 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher); |
| 121 }; | 132 }; |
| 122 | 133 |
| 123 } // namespace content | 134 } // namespace content |
| 124 | 135 |
| 125 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ | 136 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_ |
| OLD | NEW |