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
,
105 // Last entry: Add new entries above and ensure to update the
106 // "ExtensionPermission2" enum in tools/metrics/histograms/histograms.xml.
109 static_assert(PermissionMessage::kNone
> PermissionMessage::kUnknown
,
110 "kNone should not greater than kUnknown");
112 // Creates the corresponding permission message.
113 PermissionMessage(ID id
, const base::string16
& message
);
114 PermissionMessage(ID id
,
115 const base::string16
& message
,
116 const base::string16
& details
);
117 ~PermissionMessage();
119 // Gets the id of the permission message, which can be used in UMA
121 ID
id() const { return id_
; }
123 // Gets a localized message describing this permission. Please note that
124 // the message will be empty for message types TYPE_NONE and TYPE_UNKNOWN.
125 const base::string16
& message() const { return message_
; }
127 // Gets a localized message describing the details for this permission. Please
128 // note that the message will be empty for message types TYPE_NONE and
130 const base::string16
& details() const { return details_
; }
132 // Comparator to work with std::set.
133 bool operator<(const PermissionMessage
& that
) const {
134 return id_
< that
.id_
;
136 // Comparator to work with base::STLSetDifference.
137 bool operator>(const PermissionMessage
& that
) const {
138 return id_
> that
.id_
;
143 base::string16 message_
;
144 base::string16 details_
;
147 typedef std::vector
<PermissionMessage
> PermissionMessages
;
149 } // namespace extensions
151 #endif // EXTENSIONS_COMMON_PERMISSIONS_PERMISSION_MESSAGE_H_