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 |