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_MANIFEST_HANDLERS_CSP_INFO_H_
6 #define EXTENSIONS_COMMON_MANIFEST_HANDLERS_CSP_INFO_H_
10 #include "extensions/common/extension.h"
11 #include "extensions/common/manifest_handler.h"
13 namespace extensions
{
15 // A structure to hold the Content-Security-Policy information.
16 struct CSPInfo
: public Extension::ManifestData
{
17 explicit CSPInfo(const std::string
& security_policy
);
20 // The Content-Security-Policy for an extension. Extensions can use
21 // Content-Security-Policies to mitigate cross-site scripting and other
23 std::string content_security_policy
;
25 static const std::string
& GetContentSecurityPolicy(
26 const Extension
* extension
);
28 // Returns the Content Security Policy that the specified resource should be
30 static const std::string
& GetResourceContentSecurityPolicy(
31 const Extension
* extension
,
32 const std::string
& relative_path
);
35 // Parses "content_security_policy" and "app.content_security_policy" keys.
36 class CSPHandler
: public ManifestHandler
{
38 explicit CSPHandler(bool is_platform_app
);
39 ~CSPHandler() override
;
41 bool Parse(Extension
* extension
, base::string16
* error
) override
;
42 bool AlwaysParseForType(Manifest::Type type
) const override
;
45 const std::vector
<std::string
> Keys() const override
;
47 bool is_platform_app_
;
49 DISALLOW_COPY_AND_ASSIGN(CSPHandler
);
52 } // namespace extensions
54 #endif // EXTENSIONS_COMMON_MANIFEST_HANDLERS_CSP_INFO_H_