1 // Copyright 2013 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 CHROME_BROWSER_CONTENT_SETTINGS_PERMISSION_QUEUE_CONTROLLER_H_
6 #define CHROME_BROWSER_CONTENT_SETTINGS_PERMISSION_QUEUE_CONTROLLER_H_
9 #include "components/content_settings/core/common/content_settings_types.h"
10 #include "content/public/browser/notification_observer.h"
11 #include "content/public/browser/notification_registrar.h"
14 class PermissionRequestID
;
18 // This class controls an infobar queue per profile, and it's used by
19 // GeolocationPermissionContext, and so on.
20 // An alternate approach would be to have this queue per tab, and use
21 // notifications to broadcast when permission is set / listen to notification to
22 // cancel pending requests. This may be specially useful if there are other
23 // things listening for such notifications.
24 // For the time being this class is self-contained and it doesn't seem pulling
25 // the notification infrastructure would simplify.
26 class PermissionQueueController
: public content::NotificationObserver
{
28 typedef base::Callback
<void(bool /* allowed */)> PermissionDecidedCallback
;
30 PermissionQueueController(Profile
* profile
, ContentSettingsType type
);
31 ~PermissionQueueController() override
;
33 // The InfoBar will be displayed immediately if the tab is not already
34 // displaying one, otherwise it'll be queued.
35 void CreateInfoBarRequest(const PermissionRequestID
& id
,
36 const GURL
& requesting_frame
,
38 PermissionDecidedCallback callback
);
40 // Cancels a specific infobar request.
41 void CancelInfoBarRequest(const PermissionRequestID
& id
);
43 // Called by the InfoBarDelegate to notify permission has been set.
44 // It'll notify and dismiss any other pending InfoBar request for the same
45 // |requesting_frame| and embedder.
46 void OnPermissionSet(const PermissionRequestID
& id
,
47 const GURL
& requesting_frame
,
49 bool update_content_setting
,
52 // Performs the update to content settings for a particular request frame
54 void UpdateContentSetting(
55 const GURL
& requesting_frame
, const GURL
& embedder
, bool allowed
);
58 // content::NotificationObserver:
59 void Observe(int type
,
60 const content::NotificationSource
& source
,
61 const content::NotificationDetails
& details
) override
;
64 class PendingInfobarRequest
;
67 typedef std::vector
<PendingInfobarRequest
> PendingInfobarRequests
;
69 // Returns true if a geolocation infobar is already visible for the tab
70 // corresponding to |id|.
71 bool AlreadyShowingInfoBarForTab(const PermissionRequestID
& id
) const;
73 // Shows the next pending infobar for the tab corresponding to |id|, if any.
74 // Note that this may not be the pending request whose ID is |id| if other
75 // requests are higher in the queue. If we can't show infobars because there
76 // is no InfoBarService for this tab, removes all queued requests for this
78 void ShowQueuedInfoBarForTab(const PermissionRequestID
& id
);
80 void ClearPendingInfobarRequestsForTab(const PermissionRequestID
& id
);
82 void RegisterForInfoBarNotifications(InfoBarService
* infobar_service
);
83 void UnregisterForInfoBarNotifications(InfoBarService
* infobar_service
);
85 content::NotificationRegistrar registrar_
;
87 Profile
* const profile_
;
88 ContentSettingsType type_
;
89 PendingInfobarRequests pending_infobar_requests_
;
92 DISALLOW_COPY_AND_ASSIGN(PermissionQueueController
);
95 #endif // CHROME_BROWSER_CONTENT_SETTINGS_PERMISSION_QUEUE_CONTROLLER_H_