‪TYPO3CMS  ‪main
ContentSecurityPolicyMutationsProvider.php
Go to the documentation of this file.
1 <?php
2 
3 declare(strict_types=1);
4 
5 /*
6  * This file is part of the TYPO3 CMS project.
7  *
8  * It is free software; you can redistribute it and/or modify it under
9  * the terms of the GNU General Public License, either version 2
10  * of the License, or any later version.
11  *
12  * For the full copyright and license information, please read the
13  * LICENSE.txt file that was distributed with this source code.
14  *
15  * The TYPO3 project - inspiring people to share!
16  */
17 
19 
31 
33 {
34  public function ‪__construct(
35  protected readonly ‪ModelService $modelService,
36  protected readonly ‪MutationRepository $mutationRepository
37  ) {}
38 
39  public function ‪getConfiguration(): array
40  {
41  $nonce = new ‪ConsumableNonce();
42  $data = [];
47  foreach ($this->mutationRepository->findAll() as $scope => $scopeDetails) {
48  $policy = new ‪Policy();
49  $scopeValue = (string)$scope;
50  $data[$scopeValue] = [];
55  foreach ($scopeDetails as $mutationOrigin => $mutationCollection) {
56  $policy->mutate($mutationCollection);
57  $mutationOriginValue = sprintf(
58  "%s '%s'",
59  $mutationOrigin->type->value,
60  $mutationOrigin->value
61  );
62  foreach ($mutationCollection->mutations as $mutation) {
63  $sourceValues = array_map(
64  // like `ModelService::compileSources()`, but for a single item & without a nonce
65  fn(‪SourceInterface $source) => $source instanceof ‪SourceValueInterface
66  ? $source->compile()
67  : $this->modelService->serializeSource($source),
68  $mutation->sources
69  );
70  $data[$scopeValue][$mutationOriginValue][] = sprintf(
71  '%s: %s %s',
72  $mutation->mode->value,
73  $mutation->directive->value,
74  implode(' ', $sourceValues)
75  );
76  }
77  }
78  $data[$scopeValue] = ['@policy' => $policy->compile($nonce), ...$data[$scopeValue]];
79  }
80  ArrayUtility::naturalKeySortRecursive($data);
81  return $data;
82  }
83 }
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\SourceValueInterface
Definition: SourceValueInterface.php:31
‪TYPO3\CMS\Lowlevel\ConfigurationModuleProvider\ContentSecurityPolicyMutationsProvider\__construct
‪__construct(protected readonly ModelService $modelService, protected readonly MutationRepository $mutationRepository)
Definition: ContentSecurityPolicyMutationsProvider.php:34
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\MutationOrigin
Definition: MutationOrigin.php:25
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\ModelService
Definition: ModelService.php:28
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\ConsumableNonce
Definition: ConsumableNonce.php:24
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\Policy
Definition: Policy.php:31
‪TYPO3\CMS\Lowlevel\ConfigurationModuleProvider\ContentSecurityPolicyMutationsProvider
Definition: ContentSecurityPolicyMutationsProvider.php:33
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\SourceInterface
Definition: SourceInterface.php:27
‪TYPO3\CMS\Lowlevel\ConfigurationModuleProvider\AbstractProvider
Definition: AbstractProvider.php:27
‪TYPO3\CMS\Lowlevel\ConfigurationModuleProvider\ProviderInterface\getConfiguration
‪getConfiguration()
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\MutationRepository
Definition: MutationRepository.php:29
‪TYPO3\CMS\Lowlevel\ConfigurationModuleProvider
Definition: AbstractProvider.php:18
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\Scope
Definition: Scope.php:30
‪TYPO3\CMS\Core\Utility\ArrayUtility
Definition: ArrayUtility.php:26
‪TYPO3\CMS\Core\Security\ContentSecurityPolicy\MutationCollection
Definition: MutationCollection.php:24
‪TYPO3\CMS\Core\Type\Map
Definition: Map.php:47