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

Side by Side Diff: extensions/common/permissions/extensions_api_permissions.cc

Issue 419713002: Support permission_broker for chrome.hid devices. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix hid in app_shell after its move to //extensions Created 6 years, 5 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 | Annotate | Revision Log
« no previous file with comments | « extensions/common/api/_permission_features.json ('k') | extensions/extensions_strings.grd » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 #include "extensions/common/permissions/extensions_api_permissions.h" 5 #include "extensions/common/permissions/extensions_api_permissions.h"
6 6
7 #include "extensions/common/permissions/api_permission.h" 7 #include "extensions/common/permissions/api_permission.h"
8 #include "extensions/common/permissions/permission_message.h" 8 #include "extensions/common/permissions/permission_message.h"
9 #include "extensions/common/permissions/socket_permission.h" 9 #include "extensions/common/permissions/socket_permission.h"
10 #include "extensions/common/permissions/usb_device_permission.h" 10 #include "extensions/common/permissions/usb_device_permission.h"
11 #include "grit/extensions_strings.h" 11 #include "grit/extensions_strings.h"
12 12
13 namespace extensions { 13 namespace extensions {
14 14
15 namespace { 15 namespace {
16 16
17 template <typename T> 17 template <typename T>
18 APIPermission* CreateAPIPermission(const APIPermissionInfo* permission) { 18 APIPermission* CreateAPIPermission(const APIPermissionInfo* permission) {
19 return new T(permission); 19 return new T(permission);
20 } 20 }
21 21
22 } // namespace 22 } // namespace
23 23
24 std::vector<APIPermissionInfo*> ExtensionsAPIPermissions::GetAllPermissions() 24 std::vector<APIPermissionInfo*> ExtensionsAPIPermissions::GetAllPermissions()
25 const { 25 const {
26 APIPermissionInfo::InitInfo permissions_to_register[] = { 26 APIPermissionInfo::InitInfo permissions_to_register[] = {
27 {APIPermission::kDns, "dns"}, 27 {APIPermission::kDns, "dns"},
28 {APIPermission::kHid, "hid", APIPermissionInfo::kFlagNone,
29 IDS_EXTENSION_PROMPT_WARNING_HID, PermissionMessage::kHid},
28 {APIPermission::kPower, "power"}, 30 {APIPermission::kPower, "power"},
29 // Because warning messages for the "socket" permission vary based 31 // Because warning messages for the "socket" permission vary based
30 // on the permissions parameters, no message ID or message text is 32 // on the permissions parameters, no message ID or message text is
31 // specified here. The message ID and text used will be 33 // specified here. The message ID and text used will be
32 // determined at run-time in the |SocketPermission| class. 34 // determined at run-time in the |SocketPermission| class.
33 {APIPermission::kSocket, "socket", 35 {APIPermission::kSocket, "socket",
34 APIPermissionInfo::kFlagCannotBeOptional, 0, PermissionMessage::kNone, 36 APIPermissionInfo::kFlagCannotBeOptional, 0, PermissionMessage::kNone,
35 &CreateAPIPermission<SocketPermission>}, 37 &CreateAPIPermission<SocketPermission>},
36 {APIPermission::kStorage, "storage"}, 38 {APIPermission::kStorage, "storage"},
37 {APIPermission::kUsb, "usb", APIPermissionInfo::kFlagNone, 39 {APIPermission::kUsb, "usb", APIPermissionInfo::kFlagNone,
38 IDS_EXTENSION_PROMPT_WARNING_USB, PermissionMessage::kUsb}, 40 IDS_EXTENSION_PROMPT_WARNING_USB, PermissionMessage::kUsb},
39 {APIPermission::kUsbDevice, "usbDevices", APIPermissionInfo::kFlagNone, 0, 41 {APIPermission::kUsbDevice, "usbDevices", APIPermissionInfo::kFlagNone, 0,
40 PermissionMessage::kNone, &CreateAPIPermission<UsbDevicePermission>}, 42 PermissionMessage::kNone, &CreateAPIPermission<UsbDevicePermission>},
41 }; 43 };
42 44
43 std::vector<APIPermissionInfo*> permissions; 45 std::vector<APIPermissionInfo*> permissions;
44 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(permissions_to_register); ++i) 46 for (size_t i = 0; i < ARRAYSIZE_UNSAFE(permissions_to_register); ++i)
45 permissions.push_back(new APIPermissionInfo(permissions_to_register[i])); 47 permissions.push_back(new APIPermissionInfo(permissions_to_register[i]));
46 return permissions; 48 return permissions;
47 } 49 }
48 50
49 std::vector<PermissionsProvider::AliasInfo> 51 std::vector<PermissionsProvider::AliasInfo>
50 ExtensionsAPIPermissions::GetAllAliases() const { 52 ExtensionsAPIPermissions::GetAllAliases() const {
51 return std::vector<PermissionsProvider::AliasInfo>(); 53 return std::vector<PermissionsProvider::AliasInfo>();
52 } 54 }
53 55
54 } // namespace extensions 56 } // namespace extensions
OLDNEW
« no previous file with comments | « extensions/common/api/_permission_features.json ('k') | extensions/extensions_strings.grd » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698