| Current Path : /var/www/surf/TYPO3/vendor/typo3/cms-frontend/Configuration/ |
| Current File : /var/www/surf/TYPO3/vendor/typo3/cms-frontend/Configuration/ContentSecurityPolicies.php |
<?php
declare(strict_types=1);
namespace TYPO3\CMS\Backend;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\Directive;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\Mutation;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\MutationCollection;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\MutationMode;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\Scope;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\SourceKeyword;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\SourceScheme;
use TYPO3\CMS\Core\Security\ContentSecurityPolicy\UriValue;
use TYPO3\CMS\Core\Type\Map;
/**
* Provides a simple basic Content-Security-Policy for the generic frontend scope.
*/
return Map::fromEntries([
Scope::frontend(),
new MutationCollection(
new Mutation(MutationMode::Extend, Directive::DefaultSrc, SourceKeyword::self),
new Mutation(MutationMode::Extend, Directive::ScriptSrc, SourceKeyword::nonceProxy),
// `style-src-attr 'unsafe-inline'` required for remaining inline styles, which is okay for color & dimension
// (e.g. `<div style="color: #000">` - but NOT having the possibility to use any other assets/files/URIs)
new Mutation(MutationMode::Set, Directive::StyleSrcAttr, SourceKeyword::unsafeInline),
// allow `data:` images
new Mutation(MutationMode::Extend, Directive::ImgSrc, SourceScheme::data),
// limits `<base>` element to be use just for same-origin URIs
new Mutation(MutationMode::Set, Directive::BaseUri, SourceKeyword::self),
// Allows to fetch media assets from YouTube and Vimeo and their associated CDNs,
// to be embedded in an `<iframe>` of the corresponding info modal in the file list
// backend module.
new Mutation(
MutationMode::Extend,
Directive::FrameSrc,
new UriValue('*.youtube-nocookie.com'),
new UriValue('*.youtube.com'),
new UriValue('*.vimeo.com')
),
new Mutation(
MutationMode::Extend,
Directive::ImgSrc,
new UriValue('*.ytimg.com'),
new UriValue('*.vimeocdn.com')
),
),
]);