blob: 51e2954cd100b7a69595bdd546e2697428a8c166 [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef EXTENSIONS_COMMON_PERMISSIONS_API_PERMISSION_SET_H_
#define EXTENSIONS_COMMON_PERMISSIONS_API_PERMISSION_SET_H_
#include <stddef.h>
#include <set>
#include <string>
#include <vector>
#include "base/strings/string16.h"
#include "extensions/common/permissions/api_permission.h"
#include "extensions/common/permissions/base_set_operators.h"
namespace base {
class ListValue;
} // namespace base
namespace extensions {
class APIPermissionSet;
template<>
struct BaseSetOperatorsTraits<APIPermissionSet> {
typedef APIPermission ElementType;
typedef APIPermission::ID ElementIDType;
};
class APIPermissionSet : public BaseSetOperators<APIPermissionSet> {
public:
enum ParseSource {
// Don't allow internal permissions to be parsed (e.g. entries in the
// "permissions" list in a manifest).
kDisallowInternalPermissions,
// Allow internal permissions to be parsed (e.g. from the "api" field of a
// permissions list in the prefs).
kAllowInternalPermissions,
};
void insert(APIPermission::ID id);
// Insert |permission| into the APIPermissionSet. The APIPermissionSet will
// take the ownership of |permission|,
void insert(APIPermission* permission);
// Parses permissions from |permissions| and adds the parsed permissions to
// |api_permissions|. If |source| is kDisallowInternalPermissions, treat
// permissions with kFlagInternal as errors. If |unhandled_permissions| is
// not NULL, the names of all permissions that couldn't be parsed will be
// added to this vector. If |error| is NULL, parsing will continue with the
// next permission if invalid data is detected. If |error| is not NULL, it
// will be set to an error message and false is returned when an invalid
// permission is found.
static bool ParseFromJSON(
const base::ListValue* permissions,
ParseSource source,
APIPermissionSet* api_permissions,
base::string16* error,
std::vector<std::string>* unhandled_permissions);
};
// An ID representing a single permission that belongs to an app or extension.
//
// Each PermissionID has a required ID to identify the permission. For most
// permissions, this is all they have.
//
// Some more complex permissions have a parameter, which acts like an argument
// for the permission. For example, host permissions might have the ID
// kReadOnlyHost and the argument 'www.google.com' (the host which is
// read-only). Parameters are passed to the permission message rules for this
// permission, so they can affect the displayed message.
//
// Note: Inheriting from std::pair automatically gives us an operator<
// (required for putting these into an std::set).
//
// TODO(sashab): Move this to the same file as PermissionIDSet once that moves
// to its own file.
class PermissionID : public std::pair<APIPermission::ID, base::string16> {
public:
explicit PermissionID(APIPermission::ID id);
PermissionID(APIPermission::ID id, const base::string16& parameter);
virtual ~PermissionID();
const APIPermission::ID& id() const { return this->first; }
const base::string16& parameter() const { return this->second; }
};
// A set of permissions for an app or extension. Used for passing around groups
// of permissions, such as required or optional permissions.
//
// Each permission can also store a string, such as a hostname or device number,
// as a parameter that helps identify the permission. This parameter can then
// be used when the permission message is generated. For example, the permission
// kHostReadOnly might have the parameter "google.com", which means that the app
// or extension has the permission to read the host google.com. This parameter
// may then be included in the permission message when it is generated later.
//
// Example:
// // Create an empty PermissionIDSet.
// PermissionIDSet p;
// // Add a permission to the set.
// p.insert(APIPermission::kNetworkState);
// // Add a permission with a parameter to the set.
// p.insert(APIPermission::kHostReadOnly,
// base::ASCIIToUTF16("http://www.google.com"));
//
// TODO(sashab): Move this to its own file and rename it to PermissionSet after
// APIPermission is removed, the current PermissionSet is no longer used, and
// APIPermission::ID is the only type of Permission ID.
class PermissionIDSet {
public:
using const_iterator = std::set<PermissionID>::const_iterator;
PermissionIDSet();
PermissionIDSet(std::initializer_list<APIPermission::ID> permissions);
PermissionIDSet(const PermissionIDSet& other);
virtual ~PermissionIDSet();
// Adds the given permission, and an optional parameter, to the set.
void insert(APIPermission::ID permission_id);
void insert(APIPermission::ID permission_id,
const base::string16& permission_parameter);
void InsertAll(const PermissionIDSet& permission_set);
// Erases all permissions with the given id.
void erase(APIPermission::ID permission_id);
// Returns the parameters for all PermissionIDs in this set.
std::vector<base::string16> GetAllPermissionParameters() const;
// Check if the set contains a permission with the given ID.
bool ContainsID(PermissionID permission_id) const;
bool ContainsID(APIPermission::ID permission_id) const;
// Check if the set contains permissions with all the given IDs.
bool ContainsAllIDs(const std::set<APIPermission::ID>& permission_ids) const;
// Check if the set contains any permission with one of the given IDs.
bool ContainsAnyID(const std::set<APIPermission::ID>& permission_ids) const;
bool ContainsAnyID(const PermissionIDSet& other) const;
// Returns all the permissions in this set with the given ID.
PermissionIDSet GetAllPermissionsWithID(
APIPermission::ID permission_id) const;
// Returns all the permissions in this set with one of the given IDs.
PermissionIDSet GetAllPermissionsWithIDs(
const std::set<APIPermission::ID>& permission_ids) const;
// Convenience functions for common set operations.
bool Includes(const PermissionIDSet& subset) const;
bool Equals(const PermissionIDSet& set) const;
static PermissionIDSet Difference(const PermissionIDSet& set_1,
const PermissionIDSet& set_2);
size_t size() const;
bool empty() const;
const_iterator begin() const { return permissions_.begin(); }
const_iterator end() const { return permissions_.end(); }
private:
explicit PermissionIDSet(const std::set<PermissionID>& permissions);
std::set<PermissionID> permissions_;
};
} // namespace extensions
#endif // EXTENSIONS_COMMON_PERMISSIONS_API_PERMISSION_SET_H_