Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2012 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_COMMON_EXTENSIONS_PERMISSIONS_BLUETOOTH_DEVICE_PERMISSION_H_ | |
| 6 #define CHROME_COMMON_EXTENSIONS_PERMISSIONS_BLUETOOTH_DEVICE_PERMISSION_H_ | |
| 7 | |
| 8 #include <set> | |
| 9 #include <string> | |
| 10 | |
| 11 #include "chrome/common/extensions/permissions/api_permission.h" | |
| 12 | |
| 13 namespace base { | |
| 14 class Value; | |
| 15 } | |
| 16 | |
| 17 namespace IPC { | |
| 18 class Message; | |
| 19 } | |
| 20 | |
| 21 namespace extensions { | |
| 22 | |
| 23 // There's room to share code with related classes, see http://crbug.com/147531 | |
| 24 class BluetoothDevicePermission : public APIPermission { | |
| 25 public: | |
| 26 struct CheckParam : APIPermission::CheckParam { | |
|
Matt Perry
2012/11/27 21:35:32
does this need to use public inheritance?
bryeung
2012/11/28 21:55:05
Yes: we do casts from APIPermission::CheckParam to
| |
| 27 CheckParam(const std::string& device_address) | |
| 28 : device_address(device_address) {} | |
| 29 const std::string device_address; | |
| 30 }; | |
| 31 | |
| 32 explicit BluetoothDevicePermission(const APIPermissionInfo* info); | |
| 33 | |
| 34 virtual ~BluetoothDevicePermission(); | |
| 35 | |
| 36 // Adds BluetoothDevices from |devices| to the set of allowed devices. | |
| 37 // |devices| should be a string of Bluetooth device addresses separated by |. | |
| 38 void AddDevicesFromString(const std::string &devices_string); | |
|
Matt Perry
2012/11/27 21:35:32
nit: & before space
bryeung
2012/11/28 21:55:05
Done.
| |
| 39 | |
| 40 // APIPermission overrides | |
| 41 virtual std::string ToString() const OVERRIDE; | |
| 42 virtual bool ManifestEntryRequired() const OVERRIDE; | |
| 43 virtual bool ManifestEntryForbidden() const OVERRIDE; | |
| 44 virtual bool HasMessages() const OVERRIDE; | |
| 45 virtual PermissionMessages GetMessages() const OVERRIDE; | |
| 46 virtual bool Check( | |
| 47 const APIPermission::CheckParam* param) const OVERRIDE; | |
| 48 virtual bool Contains(const APIPermission* rhs) const OVERRIDE; | |
| 49 virtual bool Equal(const APIPermission* rhs) const OVERRIDE; | |
| 50 virtual bool FromValue(const base::Value* value) OVERRIDE; | |
| 51 virtual void ToValue(base::Value** value) const OVERRIDE; | |
| 52 virtual APIPermission* Clone() const OVERRIDE; | |
| 53 virtual APIPermission* Diff(const APIPermission* rhs) const OVERRIDE; | |
| 54 virtual APIPermission* Union(const APIPermission* rhs) const OVERRIDE; | |
| 55 virtual APIPermission* Intersect(const APIPermission* rhs) const OVERRIDE; | |
| 56 virtual void Write(IPC::Message* m) const OVERRIDE; | |
| 57 virtual bool Read(const IPC::Message* m, PickleIterator* iter) OVERRIDE; | |
| 58 virtual void Log(std::string* log) const OVERRIDE; | |
| 59 | |
| 60 private: | |
| 61 std::set<std::string> allowed_devices_; | |
|
Matt Perry
2012/11/27 21:35:32
shouldn't this be requested_devices instead?
bryeung
2012/11/28 21:55:05
Depends. If it's a request, then yes. But if thi
Matt Perry
2012/11/28 21:59:00
Sounds good.
(though it seems the latest upload d
| |
| 62 }; | |
| 63 | |
| 64 } // namespace extensions | |
| 65 | |
| 66 #endif // CHROME_COMMON_EXTENSIONS_PERMISSIONS_BLUETOOTH_DEVICE_PERMISSION_H_ | |
| OLD | NEW |