makestatic-parse-csp v1.0.9
Parse Content Security Policy
Parse csp.txt files to an AST
Parses content security policy text files to an abstract syntax tree.
Designed so that plugins can safely modify content security policy definitions.
Install
yarn add makestatic-parse-cspAPI
ParseCsp
Parses content security policy text files to abstract syntax trees.
See Also
.sources
ParseCsp.prototype.sources(file, context)Parses content security policy files to an abstract syntax tree.
Use this plugin during the parse phase.
This plugin configures a default test pattern that matches any file
ending with csp.txt.
The parsed AST is assigned to file.ast.csp.
Parsed files are marked as transient so they are not written to disc.
fileObject the current file.contextObject the processing context.
CspAst
Represents a parsed content security policy abstract syntax tree.
map
readonly Object mapThe declaration map.
.getDeclaration
CspAst.prototype.getDeclaration(directive, policy)Get a content security policy declaration.
Returns a content security policy declaration.
directiveString the directive name.policyArray list of policies for the directive.
.parse
CspAst.prototype.parse()Parse a string value to a content security policy declaration.
Returns a content security policy declaration.
.get
CspAst.prototype.get(directive)Get a declaration by directive name.
Returns the declaration if it exists.
directiveString the directive name.
.set
CspAst.prototype.set(declaration)Update a content security policy declaration in the map.
declarationCspDeclaration the policy declaration.
.add
CspAst.prototype.add(declaration)Add a content security policy declaration to the map.
declarationCspDeclaration the policy declaration.
Throws
Erroron duplicate directive.
.remove
CspAst.prototype.remove(declaration)Remove a content security policy declaration from the map.
Returns the existing declaration if it exists.
declarationCspDeclaration the policy declaration.
CspParser
Parse and serialize a content security policy text files.
.parse
CspParser.prototype.parse(content)Parse a content security policy file.
Declarations are delimited by a semicolon and may span multiple lines.
This implementation removes comments starting with a '#', comments are not preserved in the AST.
Returns parsed abstract syntax tree.
contentString the file content.
Throws
Erroron unknown directive.Erroron deprecated directive.Erroron duplicate directive.
.serialize
CspParser.prototype.serialize(ast)Serialize a content security policy AST.
Keywords are automatically quoted when necessary.
Returns string content security policy.
astObject the parsed abstract syntax tree.
License
MIT
Created by mkdoc on March 12, 2017