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
3 // found in the LICENSE file.
5 #ifndef CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_
6 #define CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_
10 #include "base/callback_forward.h"
11 #include "base/id_map.h"
12 #include "base/macros.h"
13 #include "base/memory/scoped_ptr.h"
14 #include "content/child/permissions/permission_observers_registry.h"
15 #include "content/common/permission_service.mojom.h"
16 #include "third_party/WebKit/public/platform/modules/permissions/WebPermissionClient.h"
20 class ServiceRegistry
;
22 // The PermissionDispatcher is a layer between Blink and the Mojo
23 // PermissionService. It implements blink::WebPermissionClient. It is being used
24 // from workers and frames independently. When called outside of the main
25 // thread, QueryPermissionForWorker is meant to be called. It will handle the
27 class PermissionDispatcher
: public blink::WebPermissionClient
,
28 public PermissionObserversRegistry
{
30 // Returns whether the given WebPermissionType is observable. Some types have
31 // static values that never changes.
32 static bool IsObservable(blink::WebPermissionType type
);
34 // The caller must guarantee that |service_registry| will have a lifetime
35 // larger than this instance of PermissionDispatcher.
36 explicit PermissionDispatcher(ServiceRegistry
* service_registry
);
37 virtual ~PermissionDispatcher();
39 // blink::WebPermissionClient implementation.
40 virtual void queryPermission(blink::WebPermissionType type
,
41 const blink::WebURL
& origin
,
42 blink::WebPermissionCallback
* callback
);
43 virtual void requestPermission(blink::WebPermissionType
,
44 const blink::WebURL
& origin
,
45 blink::WebPermissionCallback
* callback
);
46 virtual void revokePermission(blink::WebPermissionType
,
47 const blink::WebURL
& origin
,
48 blink::WebPermissionCallback
* callback
);
49 virtual void startListening(blink::WebPermissionType type
,
50 const blink::WebURL
& origin
,
51 blink::WebPermissionObserver
* observer
);
52 virtual void stopListening(blink::WebPermissionObserver
* observer
);
54 // The following methods must be called by workers on the main thread.
55 void QueryPermissionForWorker(blink::WebPermissionType type
,
56 const std::string
& origin
,
57 blink::WebPermissionCallback
* callback
,
58 int worker_thread_id
);
59 void RequestPermissionForWorker(blink::WebPermissionType type
,
60 const std::string
& origin
,
61 blink::WebPermissionCallback
* callback
,
62 int worker_thread_id
);
63 void RevokePermissionForWorker(blink::WebPermissionType type
,
64 const std::string
& origin
,
65 blink::WebPermissionCallback
* callback
,
66 int worker_thread_id
);
67 void StartListeningForWorker(
68 blink::WebPermissionType type
,
69 const std::string
& origin
,
71 const base::Callback
<void(blink::WebPermissionStatus
)>& callback
);
72 void GetNextPermissionChangeForWorker(
73 blink::WebPermissionType type
,
74 const std::string
& origin
,
75 blink::WebPermissionStatus status
,
77 const base::Callback
<void(blink::WebPermissionStatus
)>& callback
);
80 // Runs the given |callback| with |status| as a parameter. It has to be run
81 // on a worker thread.
82 static void RunCallbackOnWorkerThread(
83 blink::WebPermissionCallback
* callback
,
84 scoped_ptr
<blink::WebPermissionStatus
> status
);
86 // Helper method that returns an initialized PermissionServicePtr.
87 PermissionServicePtr
& GetPermissionServicePtr();
89 void QueryPermissionInternal(blink::WebPermissionType type
,
90 const std::string
& origin
,
91 blink::WebPermissionCallback
* callback
,
92 int worker_thread_id
);
93 void RequestPermissionInternal(blink::WebPermissionType type
,
94 const std::string
& origin
,
95 blink::WebPermissionCallback
* callback
,
96 int worker_thread_id
);
97 void RevokePermissionInternal(blink::WebPermissionType type
,
98 const std::string
& origin
,
99 blink::WebPermissionCallback
* callback
,
100 int worker_thread_id
);
102 // This is the callback function used for query and revoke
103 void OnPermissionResponse(int request_id
,
104 PermissionStatus status
);
105 void OnPermissionChanged(blink::WebPermissionType type
,
106 const std::string
& origin
,
107 blink::WebPermissionObserver
* observer
,
108 PermissionStatus status
);
109 void OnPermissionChangedForWorker(
110 int worker_thread_id
,
111 const base::Callback
<void(blink::WebPermissionStatus
)>& callback
,
112 PermissionStatus status
);
114 void GetNextPermissionChange(blink::WebPermissionType type
,
115 const std::string
& origin
,
116 blink::WebPermissionObserver
* observer
,
117 PermissionStatus current_status
);
119 // Saves some basic information about the callback in order to be able to run
120 // it in the right thread.
121 class CallbackInformation
{
123 CallbackInformation(blink::WebPermissionCallback
* callback
,
124 int worker_thread_id
);
125 ~CallbackInformation();
127 blink::WebPermissionCallback
* callback() const;
128 int worker_thread_id() const;
130 blink::WebPermissionCallback
* ReleaseCallback();
133 scoped_ptr
<blink::WebPermissionCallback
> callback_
;
134 int worker_thread_id_
;
136 DISALLOW_COPY_AND_ASSIGN(CallbackInformation
);
138 using CallbackMap
= IDMap
<CallbackInformation
, IDMapOwnPointer
>;
139 CallbackMap pending_callbacks_
;
141 ServiceRegistry
* service_registry_
;
142 PermissionServicePtr permission_service_
;
144 DISALLOW_COPY_AND_ASSIGN(PermissionDispatcher
);
147 } // namespace content
149 #endif // CONTENT_CHILD_PERMISSIONS_PERMISSION_DISPATCHER_H_