blob: 2844d2ae8754f1233ad3e5b7ae475b7d528b1407 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
// Copyright 2014 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_MANIFEST_HANDLERS_PERMISSIONS_PARSER_H_
#define EXTENSIONS_COMMON_MANIFEST_HANDLERS_PERMISSIONS_PARSER_H_
#include "base/memory/scoped_ptr.h"
#include "base/strings/string16.h"
#include "extensions/common/permissions/api_permission.h"
#include "extensions/common/permissions/permission_set.h"
namespace extensions {
class Extension;
class URLPatternSet;
// The class for parsing the kPermissions and kOptionalPermissions keys in the
// manifest. Because permissions are slightly different than other keys (they
// are used in many different handlers and need to be the first and last key
// touched), this is not an actual ManifestHandler (hence the difference in
// name).
class PermissionsParser {
public:
PermissionsParser();
~PermissionsParser();
// Parse the manifest-specified permissions.
bool Parse(Extension* extension, base::string16* error);
// Finalize the permissions, setting the related manifest data on the
// extension.
void Finalize(Extension* extension);
// Modify the manifest permissions. These methods should only be used
// during initialization and will DCHECK() for safety.
static void AddAPIPermission(Extension* extension,
APIPermission::ID permission);
static void AddAPIPermission(Extension* extension, APIPermission* permission);
static bool HasAPIPermission(const Extension* extension,
APIPermission::ID permission);
static void SetScriptableHosts(Extension* extension,
const URLPatternSet& scriptable_hosts);
// Return the extension's manifest-specified permissions. In no cases should
// these permissions be used to determine if an action is allowed. Instead,
// use PermissionsData.
static const PermissionSet& GetRequiredPermissions(
const Extension* extension);
static const PermissionSet& GetOptionalPermissions(
const Extension* extension);
private:
struct InitialPermissions;
// The initial permissions for the extension, which can still be modified.
scoped_ptr<InitialPermissions> initial_required_permissions_;
scoped_ptr<InitialPermissions> initial_optional_permissions_;
};
} // namespace extensions
#endif // EXTENSIONS_COMMON_MANIFEST_HANDLERS_PERMISSIONS_PARSER_H_
|