This source file includes following definitions.
- m_sourceList
- allows
- allowInline
- allowEval
- allowNonce
- allowHash
- isHashOrNoncePresent
- hashAlgorithmsUsed
#include "config.h"
#include "core/frame/csp/SourceListDirective.h"
#include "core/frame/csp/CSPSourceList.h"
#include "core/frame/csp/ContentSecurityPolicy.h"
#include "platform/network/ContentSecurityPolicyParsers.h"
#include "platform/weborigin/KURL.h"
#include "wtf/text/WTFString.h"
namespace WebCore {
SourceListDirective::SourceListDirective(const String& name, const String& value, ContentSecurityPolicy* policy)
: CSPDirective(name, value, policy)
, m_sourceList(policy, name)
{
Vector<UChar> characters;
value.appendTo(characters);
m_sourceList.parse(characters.data(), characters.data() + characters.size());
}
bool SourceListDirective::allows(const KURL& url) const
{
return m_sourceList.matches(url.isEmpty() ? policy()->url() : url);
}
bool SourceListDirective::allowInline() const
{
return m_sourceList.allowInline();
}
bool SourceListDirective::allowEval() const
{
return m_sourceList.allowEval();
}
bool SourceListDirective::allowNonce(const String& nonce) const
{
return m_sourceList.allowNonce(nonce.stripWhiteSpace());
}
bool SourceListDirective::allowHash(const CSPHashValue& hashValue) const
{
return m_sourceList.allowHash(hashValue);
}
bool SourceListDirective::isHashOrNoncePresent() const
{
return m_sourceList.isHashOrNoncePresent();
}
uint8_t SourceListDirective::hashAlgorithmsUsed() const
{
return m_sourceList.hashAlgorithmsUsed();
}
}