2026-05-05 10:29:45 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* SPDX-FileCopyrightText: 2026 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace OC\OCM;
|
|
|
|
|
|
|
|
|
|
use Firebase\JWT\Key;
|
|
|
|
|
use OC\Security\Signature\Rfc9421\IJwkResolvingSignatoryManager;
|
|
|
|
|
use OCP\Security\Signature\Exceptions\IdentityNotFoundException;
|
|
|
|
|
use OCP\Security\Signature\Model\Signatory;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Per-call wrapper around {@see OCMSignatoryManager} that swaps in the
|
2026-05-11 10:13:13 -04:00
|
|
|
* JWKS-published signatory and sets `rfc9421.format`. Wrapping (vs mutating)
|
|
|
|
|
* keeps the underlying DI-managed instance stateless across requests.
|
2026-05-05 10:29:45 -04:00
|
|
|
*/
|
|
|
|
|
final class Rfc9421SignatoryManager implements IJwkResolvingSignatoryManager {
|
|
|
|
|
public function __construct(
|
|
|
|
|
private readonly OCMSignatoryManager $delegate,
|
|
|
|
|
) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[\Override]
|
|
|
|
|
public function getProviderId(): string {
|
|
|
|
|
return $this->delegate->getProviderId();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[\Override]
|
|
|
|
|
public function getOptions(): array {
|
|
|
|
|
return array_merge($this->delegate->getOptions(), ['rfc9421.format' => true]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[\Override]
|
|
|
|
|
public function getLocalSignatory(): Signatory {
|
2026-05-11 10:13:13 -04:00
|
|
|
$signatory = $this->delegate->getLocalJwksSignatory();
|
2026-05-05 10:29:45 -04:00
|
|
|
if ($signatory === null) {
|
2026-05-11 10:13:13 -04:00
|
|
|
throw new IdentityNotFoundException('no JWKS-published signatory available');
|
2026-05-05 10:29:45 -04:00
|
|
|
}
|
|
|
|
|
return $signatory;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[\Override]
|
|
|
|
|
public function getRemoteSignatory(string $remote): ?Signatory {
|
|
|
|
|
return $this->delegate->getRemoteSignatory($remote);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[\Override]
|
|
|
|
|
public function getRemoteKey(string $origin, string $keyId): ?Key {
|
|
|
|
|
return $this->delegate->getRemoteKey($origin, $keyId);
|
|
|
|
|
}
|
|
|
|
|
}
|