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 EXTENSIONS_COMMON_PERMISSIONS_PERMISSION_MESSAGE_H_
6 #define EXTENSIONS_COMMON_PERMISSIONS_PERMISSION_MESSAGE_H_
11 #include "base/basictypes.h"
12 #include "base/strings/string16.h"
14 namespace extensions
{
16 // When prompting the user to install or approve permissions, we display
17 // messages describing the effects of the permissions rather than listing the
18 // permissions themselves. Each PermissionMessage represents one of the
19 // messages shown to the user.
20 class PermissionMessage
{
22 // Do not reorder this enumeration. If you need to add a new enum, add it just
23 // prior to kEnumBoundary.
24 // TODO(sashab): Deprecate these IDs - use whatever APIPermission::ID becomes
52 kDeleted_FileSystemWrite
,
53 kMediaGalleriesAllGalleriesRead
,
62 kMediaGalleriesAllGalleriesCopyTo
,
74 kDeclarativeWebRequest
,
76 kFileSystemWriteDirectory
,
83 kMediaGalleriesAllGalleriesDelete
,
87 kAccessibilityFeaturesModify
,
88 kAccessibilityFeaturesRead
,
91 kExperienceSamplingPrivate
,
100 kHosts4OrMoreReadOnly
,
103 // Last entry: Add new entries above and ensure to update the
104 // "ExtensionPermission2" enum in tools/metrics/histograms/histograms.xml.
107 static_assert(PermissionMessage::kNone
> PermissionMessage::kUnknown
,
108 "kNone should not greater than kUnknown");
110 // Creates the corresponding permission message.
111 PermissionMessage(ID id
, const base::string16
& message
);
112 PermissionMessage(ID id
,
113 const base::string16
& message
,
114 const base::string16
& details
);
115 ~PermissionMessage();
117 // Gets the id of the permission message, which can be used in UMA
119 ID
id() const { return id_
; }
121 // Gets a localized message describing this permission. Please note that
122 // the message will be empty for message types TYPE_NONE and TYPE_UNKNOWN.
123 const base::string16
& message() const { return message_
; }
125 // Gets a localized message describing the details for this permission. Please
126 // note that the message will be empty for message types TYPE_NONE and
128 const base::string16
& details() const { return details_
; }
130 // Comparator to work with std::set.
131 bool operator<(const PermissionMessage
& that
) const {
132 return id_
< that
.id_
;
134 // Comparator to work with base::STLSetDifference.
135 bool operator>(const PermissionMessage
& that
) const {
136 return id_
> that
.id_
;
141 base::string16 message_
;
142 base::string16 details_
;
145 typedef std::vector
<PermissionMessage
> PermissionMessages
;
147 } // namespace extensions
149 #endif // EXTENSIONS_COMMON_PERMISSIONS_PERMISSION_MESSAGE_H_