38 lines
936 B
PHP
38 lines
936 B
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Controller\Api\Frontend\Account\WebAuthn;
|
|
|
|
use App\Controller\Traits\UsesWebAuthnTrait;
|
|
use App\Http\Response;
|
|
use App\Http\ServerRequest;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
|
|
final class GetRegistrationAction
|
|
{
|
|
use UsesWebAuthnTrait;
|
|
|
|
public function __invoke(
|
|
ServerRequest $request,
|
|
Response $response,
|
|
array $params
|
|
): ResponseInterface {
|
|
$user = $request->getUser();
|
|
$webAuthn = $this->getWebAuthn($request);
|
|
|
|
$createArgs = $webAuthn->getCreateArgs(
|
|
(string)$user->getId(),
|
|
$user->getEmail(),
|
|
$user->getDisplayName(),
|
|
self::WEBAUTHN_TIMEOUT,
|
|
requireResidentKey: 'required',
|
|
requireUserVerification: 'preferred',
|
|
);
|
|
|
|
$this->setChallenge($request, $webAuthn->getChallenge());
|
|
|
|
return $response->withJson($createArgs);
|
|
}
|
|
}
|