2019-07-27 09:33:55 -04:00
|
|
|
<?php
|
2019-12-03 13:57:53 -05:00
|
|
|
|
2019-07-27 09:33:55 -04:00
|
|
|
declare(strict_types=1);
|
2019-12-03 13:57:53 -05:00
|
|
|
|
2019-07-27 09:33:55 -04:00
|
|
|
/**
|
2024-05-23 03:26:56 -04:00
|
|
|
* SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
2019-07-27 09:33:55 -04:00
|
|
|
*/
|
|
|
|
|
namespace OC\Security\FeaturePolicy;
|
|
|
|
|
|
|
|
|
|
use OCP\AppFramework\Http\EmptyFeaturePolicy;
|
|
|
|
|
use OCP\EventDispatcher\IEventDispatcher;
|
|
|
|
|
use OCP\Security\FeaturePolicy\AddFeaturePolicyEvent;
|
|
|
|
|
|
|
|
|
|
class FeaturePolicyManager {
|
|
|
|
|
/** @var EmptyFeaturePolicy[] */
|
2023-06-26 05:58:09 -04:00
|
|
|
private array $policies = [];
|
2019-07-27 09:33:55 -04:00
|
|
|
|
2023-06-26 05:58:09 -04:00
|
|
|
public function __construct(
|
|
|
|
|
private IEventDispatcher $dispatcher,
|
|
|
|
|
) {
|
2019-07-27 09:33:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function addDefaultPolicy(EmptyFeaturePolicy $policy): void {
|
|
|
|
|
$this->policies[] = $policy;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function getDefaultPolicy(): FeaturePolicy {
|
|
|
|
|
$event = new AddFeaturePolicyEvent($this);
|
2020-08-10 08:29:21 -04:00
|
|
|
$this->dispatcher->dispatchTyped($event);
|
2019-07-27 09:33:55 -04:00
|
|
|
|
|
|
|
|
$defaultPolicy = new FeaturePolicy();
|
|
|
|
|
foreach ($this->policies as $policy) {
|
|
|
|
|
$defaultPolicy = $this->mergePolicies($defaultPolicy, $policy);
|
|
|
|
|
}
|
|
|
|
|
return $defaultPolicy;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Merges the first given policy with the second one
|
|
|
|
|
*
|
|
|
|
|
*/
|
2023-06-26 05:58:09 -04:00
|
|
|
public function mergePolicies(
|
|
|
|
|
FeaturePolicy $defaultPolicy,
|
|
|
|
|
EmptyFeaturePolicy $originalPolicy,
|
|
|
|
|
): FeaturePolicy {
|
2019-07-27 09:33:55 -04:00
|
|
|
foreach ((object)(array)$originalPolicy as $name => $value) {
|
|
|
|
|
$setter = 'set' . ucfirst($name);
|
|
|
|
|
if (\is_array($value)) {
|
|
|
|
|
$getter = 'get' . ucfirst($name);
|
|
|
|
|
$currentValues = \is_array($defaultPolicy->$getter()) ? $defaultPolicy->$getter() : [];
|
|
|
|
|
$defaultPolicy->$setter(\array_values(\array_unique(\array_merge($currentValues, $value))));
|
|
|
|
|
} elseif (\is_bool($value)) {
|
|
|
|
|
$defaultPolicy->$setter($value);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $defaultPolicy;
|
|
|
|
|
}
|
|
|
|
|
}
|