Upstream version 7.36.149.0
[platform/framework/web/crosswalk.git] / src / chrome / browser / ui / website_settings / permission_bubble_request.h
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
3 // found in the LICENSE file.
4
5 #ifndef CHROME_BROWSER_UI_WEBSITE_SETTINGS_PERMISSION_BUBBLE_REQUEST_H_
6 #define CHROME_BROWSER_UI_WEBSITE_SETTINGS_PERMISSION_BUBBLE_REQUEST_H_
7
8 #include "base/strings/string16.h"
9 #include "url/gurl.h"
10
11 // Describes the interface a feature utilizing permission bubbles should
12 // implement. A class of this type is registered with the permission bubble
13 // manager to receive updates about the result of the permissions request
14 // from the bubble. It should live until it is unregistered or until
15 // RequestFinished is called.
16 // Note that no particular guarantees are made about what exact UI surface
17 // is presented to the user. The delegate may be coalesced with other bubble
18 // requests, or depending on the situation, not shown at all.
19 class PermissionBubbleRequest {
20  public:
21   virtual ~PermissionBubbleRequest() {}
22
23   // The icon to use next to the message text fragment in the permission bubble.
24   // Must be a valid icon of size 16x16. (TODO(gbillock): tbd size)
25   virtual int GetIconID() const = 0;
26
27   // Returns the full prompt text for this permission. This is the only text
28   // that will be shown in the single-permission case and should be phrased
29   // positively as a complete sentence.
30   virtual base::string16 GetMessageText() const = 0;
31
32   // Returns the shortened prompt text for this permission.  Must be phrased
33   // as a heading, e.g. "Location", or "Camera". The permission bubble may
34   // coalesce different requests, and if it does, this text will be displayed
35   // next to an image and indicate the user grants the permission.
36   virtual base::string16 GetMessageTextFragment() const = 0;
37
38   // Get whether this request was accompanied by a user gesture. User gestured
39   // permissions requests will not be suppressed.
40   virtual bool HasUserGesture() const = 0;
41
42   // Get the hostname on whose behalf this permission request is being made.
43   virtual GURL GetRequestingHostname() const = 0;
44
45   // Called when the user has granted the requested permission.
46   virtual void PermissionGranted() = 0;
47
48   // Called when the user has denied the requested permission.
49   virtual void PermissionDenied() = 0;
50
51   // Called when the user has cancelled the permission request. This
52   // corresponds to a denial, but is segregated in case the context needs to
53   // be able to distinguish between an active refusal or an implicit refusal.
54   virtual void Cancelled() = 0;
55
56   // The bubble this request was associated with was answered by the user.
57   // It is safe for the request to be deleted at this point -- it will receive
58   // no further message from the permission bubble system. This method will
59   // eventually be called on every request which is not unregistered.
60   virtual void RequestFinished() = 0;
61 };
62
63 #endif  // CHROME_BROWSER_UI_WEBSITE_SETTINGS_PERMISSION_BUBBLE_REQUEST_H_