Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(474)

Side by Side Diff: content/browser/permissions/permission_service_impl.h

Issue 2080083002: Revert of Deletes mojo::Callback (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_ 5 #ifndef CONTENT_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_
6 #define CONTENT_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_ 6 #define CONTENT_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_
7 7
8 #include "base/callback.h"
9 #include "base/id_map.h" 8 #include "base/id_map.h"
10 #include "base/macros.h" 9 #include "base/macros.h"
11 #include "base/memory/weak_ptr.h" 10 #include "base/memory/weak_ptr.h"
12 #include "content/browser/permissions/permission_service_context.h" 11 #include "content/browser/permissions/permission_service_context.h"
13 #include "mojo/public/cpp/bindings/binding.h" 12 #include "mojo/public/cpp/bindings/binding.h"
14 #include "third_party/WebKit/public/platform/modules/permissions/permission.mojo m.h" 13 #include "third_party/WebKit/public/platform/modules/permissions/permission.mojo m.h"
15 14
16 namespace content { 15 namespace content {
17 16
18 enum class PermissionType; 17 enum class PermissionType;
(...skipping 16 matching lines...) Expand all
35 34
36 protected: 35 protected:
37 friend PermissionServiceContext; 36 friend PermissionServiceContext;
38 37
39 PermissionServiceImpl( 38 PermissionServiceImpl(
40 PermissionServiceContext* context, 39 PermissionServiceContext* context,
41 mojo::InterfaceRequest<blink::mojom::PermissionService> request); 40 mojo::InterfaceRequest<blink::mojom::PermissionService> request);
42 41
43 private: 42 private:
44 using PermissionStatusCallback = 43 using PermissionStatusCallback =
45 base::Callback<void(blink::mojom::PermissionStatus)>; 44 mojo::Callback<void(blink::mojom::PermissionStatus)>;
45 using PermissionsStatusCallback =
46 mojo::Callback<void(mojo::Array<blink::mojom::PermissionStatus>)>;
46 47
47 struct PendingRequest { 48 struct PendingRequest {
48 PendingRequest(const RequestPermissionsCallback& callback, 49 PendingRequest(const PermissionsStatusCallback& callback,
49 int request_count); 50 int request_count);
50 ~PendingRequest(); 51 ~PendingRequest();
51 52
52 // Request ID received from the PermissionManager. 53 // Request ID received from the PermissionManager.
53 int id; 54 int id;
54 RequestPermissionsCallback callback; 55 PermissionsStatusCallback callback;
55 int request_count; 56 int request_count;
56 }; 57 };
57 using RequestsMap = IDMap<PendingRequest, IDMapOwnPointer>; 58 using RequestsMap = IDMap<PendingRequest, IDMapOwnPointer>;
58 59
59 struct PendingSubscription { 60 struct PendingSubscription {
60 PendingSubscription(PermissionType permission, const GURL& origin, 61 PendingSubscription(PermissionType permission, const GURL& origin,
61 const PermissionStatusCallback& callback); 62 const PermissionStatusCallback& callback);
62 ~PendingSubscription(); 63 ~PendingSubscription();
63 64
64 // Subscription ID received from the PermissionManager. 65 // Subscription ID received from the PermissionManager.
65 int id; 66 int id;
66 PermissionType permission; 67 PermissionType permission;
67 GURL origin; 68 GURL origin;
68 PermissionStatusCallback callback; 69 PermissionStatusCallback callback;
69 }; 70 };
70 using SubscriptionsMap = IDMap<PendingSubscription, IDMapOwnPointer>; 71 using SubscriptionsMap = IDMap<PendingSubscription, IDMapOwnPointer>;
71 72
72 // blink::mojom::PermissionService. 73 // blink::mojom::PermissionService.
73 void HasPermission(blink::mojom::PermissionName permission, 74 void HasPermission(blink::mojom::PermissionName permission,
74 const mojo::String& origin, 75 const mojo::String& origin,
75 const PermissionStatusCallback& callback) override; 76 const PermissionStatusCallback& callback) override;
76 void RequestPermission(blink::mojom::PermissionName permission, 77 void RequestPermission(blink::mojom::PermissionName permission,
77 const mojo::String& origin, 78 const mojo::String& origin,
78 bool user_gesture, 79 bool user_gesture,
79 const PermissionStatusCallback& callback) override; 80 const PermissionStatusCallback& callback) override;
80 void RequestPermissions(mojo::Array<blink::mojom::PermissionName> permissions, 81 void RequestPermissions(mojo::Array<blink::mojom::PermissionName> permissions,
81 const mojo::String& origin, 82 const mojo::String& origin,
82 bool user_gesture, 83 bool user_gesture,
83 const RequestPermissionsCallback& callback) override; 84 const PermissionsStatusCallback& callback) override;
84 void RevokePermission(blink::mojom::PermissionName permission, 85 void RevokePermission(blink::mojom::PermissionName permission,
85 const mojo::String& origin, 86 const mojo::String& origin,
86 const PermissionStatusCallback& callback) override; 87 const PermissionStatusCallback& callback) override;
87 void GetNextPermissionChange( 88 void GetNextPermissionChange(
88 blink::mojom::PermissionName permission, 89 blink::mojom::PermissionName permission,
89 const mojo::String& origin, 90 const mojo::String& origin,
90 blink::mojom::PermissionStatus last_known_status, 91 blink::mojom::PermissionStatus last_known_status,
91 const PermissionStatusCallback& callback) override; 92 const PermissionStatusCallback& callback) override;
92 93
93 void OnConnectionError(); 94 void OnConnectionError();
(...skipping 21 matching lines...) Expand all
115 PermissionServiceContext* context_; 116 PermissionServiceContext* context_;
116 mojo::Binding<blink::mojom::PermissionService> binding_; 117 mojo::Binding<blink::mojom::PermissionService> binding_;
117 base::WeakPtrFactory<PermissionServiceImpl> weak_factory_; 118 base::WeakPtrFactory<PermissionServiceImpl> weak_factory_;
118 119
119 DISALLOW_COPY_AND_ASSIGN(PermissionServiceImpl); 120 DISALLOW_COPY_AND_ASSIGN(PermissionServiceImpl);
120 }; 121 };
121 122
122 } // namespace content 123 } // namespace content
123 124
124 #endif // CONTENT_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_ 125 #endif // CONTENT_BROWSER_PERMISSIONS_PERMISSION_SERVICE_IMPL_H_
OLDNEW
« no previous file with comments | « content/browser/media/capture/image_capture_impl.cc ('k') | content/browser/permissions/permission_service_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698