From 9b399850898c0ea172f2c07d9625145f60994cf9 Mon Sep 17 00:00:00 2001 From: Spomky Date: Thu, 2 Jan 2020 23:52:22 +0100 Subject: [PATCH] Several corrections and bugs fixed before first v3.0 live tests --- composer.json | 36 ++--- phpstan.neon | 4 +- psalm.xml | 55 ------- .../src/DistantSingleMetadataFactory.php | 43 ----- .../src/MetadataServiceFactory.php | 43 ----- .../src/MetadataStatementRepository.php | 5 + ...etadataStatementStatusReportRepository.php | 22 --- .../src/MetadataTOCPayloadEntry.php | 2 +- src/metadata-service/src/RgbPaletteEntry.php | 6 +- .../src/SimpleMetadataStatementRepository.php | 129 --------------- .../tests/functional/MetadataServiceTest.php | 2 +- .../src/DataCollector/WebauthnCollector.php | 9 -- .../src/DependencyInjection/Configuration.php | 104 +----------- .../DependencyInjection/WebauthnExtension.php | 68 +------- .../Resources/config/android_safetynet.php | 2 +- src/symfony/src/Resources/config/cose.php | 2 +- .../src/Resources/config/dev_services.php | 2 +- .../src/Resources/config/metadata_service.php | 46 ------ .../config/metadata_statement_supports.php | 2 +- src/symfony/src/Resources/config/security.php | 2 +- src/symfony/src/Resources/config/services.php | 2 +- .../config/transport_binding_profile.php | 2 +- src/symfony/src/Routing/Loader.php | 13 +- .../Security/Firewall/WebauthnListener.php | 2 +- .../src/Security/Storage/SessionStorage.php | 5 - ...henticatorAttestationResponseValidator.php | 4 +- ...licKeyCredentialCreationOptionsFactory.php | 2 +- src/symfony/tests/config/config.yml | 152 ++++++++++-------- src/symfony/tests/config/routing.php | 2 +- .../MetadataService/MetadataServiceTest.php | 9 +- .../MetadataStatementRepository.php | 120 ++++++++++++++ .../AndroidKeyAttestationStatementSupport.php | 1 + .../AttestationObjectLoader.php | 38 +++-- .../FidoU2FAttestationStatementSupport.php | 1 + src/webauthn/src/Server.php | 5 +- .../tests/functional/AbstractTestCase.php | 30 ++-- ...droidSafetyNetAttestationStatementTest.php | 4 +- .../tests/functional/AssertionTest.php | 12 +- .../MetadataStatementRepository.php | 83 ++++++++++ src/webauthn/tests/functional/W10Test.php | 4 +- .../tests/unit/TrustPath/TrustPathTest.php | 14 +- 41 files changed, 405 insertions(+), 684 deletions(-) delete mode 100644 psalm.xml delete mode 100644 src/metadata-service/src/DistantSingleMetadataFactory.php delete mode 100644 src/metadata-service/src/MetadataServiceFactory.php delete mode 100644 src/metadata-service/src/MetadataStatementStatusReportRepository.php delete mode 100644 src/metadata-service/src/SimpleMetadataStatementRepository.php delete mode 100644 src/symfony/src/Resources/config/metadata_service.php create mode 100644 src/symfony/tests/functional/MetadataStatementRepository.php create mode 100644 src/webauthn/tests/functional/MetadataStatementRepository.php diff --git a/composer.json b/composer.json index dd51f06ab..463c4028e 100644 --- a/composer.json +++ b/composer.json @@ -29,7 +29,8 @@ "Webauthn\\Tests\\Functional\\": "src/webauthn/tests/functional/", "Webauthn\\Tests\\Unit\\": "src/webauthn/tests/unit/", "Webauthn\\Bundle\\Tests\\Functional\\": "src/symfony/tests/functional/", - "Webauthn\\MetadataService\\Tests\\Functional\\": "src/metadata-service/tests/functional/" + "Webauthn\\MetadataService\\Tests\\Functional\\": "src/metadata-service/tests/functional/", + "Webauthn\\MetadataService\\Tests\\Unit\\": "src/metadata-service/tests/unit/" } }, "require": { @@ -41,19 +42,18 @@ "fgrosse/phpasn1": "^2.1", "league/uri": "^6.0", "league/uri-components": "^2.1", - "nyholm/psr7": "^1.1", "psr/http-client": "^1.0", "psr/http-factory": "^1.0", "psr/http-message": "^1.0", "spomky-labs/base64url": "^2.0", "spomky-labs/cbor-bundle": "^2.0", - "symfony/config": "^4.3|^5.0", - "symfony/dependency-injection": "^4.3|^5.0", - "symfony/framework-bundle": "^4.3|^5.0", - "symfony/process": "^4.3|^5.0", + "symfony/config": "^5.0", + "symfony/dependency-injection": "^5.0", + "symfony/framework-bundle": "^5.0", + "symfony/process": "^5.0", "symfony/psr-http-message-bridge": "^2.0", - "symfony/security-bundle": "^4.3|^5.0", - "symfony/twig-bundle": "^4.3|^5.0", + "symfony/security-bundle": "^5.0", + "symfony/twig-bundle": "^5.0", "web-token/jwt-key-mgmt": "^2.0.9", "web-token/jwt-signature": "^2.0.9", "web-token/signature-pack": "^2.0.9" @@ -86,9 +86,10 @@ }, "require-dev": { "doctrine/dbal": "^2.9", - "doctrine/doctrine-bundle": "^1.10|^2.0", + "doctrine/doctrine-bundle": "^2.0", "doctrine/orm": "^2.6", "fzaninotto/faker": "^1.8", + "nyholm/psr7": "^1.1", "php-http/curl-client": "^2.0", "php-http/mock-client": "^1.0", "phpstan/phpstan": "^0.12", @@ -98,14 +99,13 @@ "phpstan/phpstan-strict-rules": "^0.12", "phpunit/phpunit": "^8.2.5", "ramsey/uuid": "^3.8", - "symfony/browser-kit": "^4.3|^5.0", - "symfony/http-client": "^4.3|^5.0", - "symfony/phpunit-bridge": "^4.3|^5.0", - "symfony/serializer": "^4.3|^5.0", - "symfony/translation": "^4.3|^5.0", - "symfony/validator": "^4.3|^5.0", - "symfony/var-dumper": "^4.3|^5.0", - "symfony/yaml": "^4.3|^5.0", - "vimeo/psalm": "^3.8" + "symfony/browser-kit": "^5.0", + "symfony/http-client": "^5.0", + "symfony/phpunit-bridge": "^5.0", + "symfony/serializer": "^5.0", + "symfony/translation": "^5.0", + "symfony/validator": "^5.0", + "symfony/var-dumper": "^5.0", + "symfony/yaml": "^5.0" } } diff --git a/phpstan.neon b/phpstan.neon index a0abab8d3..e34fee22e 100644 --- a/phpstan.neon +++ b/phpstan.neon @@ -6,14 +6,12 @@ parameters: - %currentWorkingDirectory%/src/*/tests/* - %currentWorkingDirectory%/src/*/var/* ignoreErrors: + - '#Call to an undefined method Symfony\\Component\\Config\\Definition\\Builder\\NodeParentInterface::scalarNode\(\)\.#' - '#Call to function is_array\(\) with array\ will always evaluate to true\.#' - '#Call to an undefined method Symfony\\Component\\Config\\Definition\\Builder\\NodeDefinition::(.*)\(\)#' - - '#Cannot call method scalarNode\(\) on Symfony\\Component\\Config\\Definition\\Builder\\NodeParentInterface|null\.#' - '#Parameter (.*) of class FG\\ASN1\\Universal\\Integer constructor expects int, string given\.#' - '#Parameter (.*) of class Webauthn\\PublicKeyCredentialSource constructor expects string, string|null given\.#' - '#Instanceof between Symfony\\Component\\HttpFoundation\\Response and Symfony\\Component\\HttpFoundation\\Response will always evaluate to true\.#' - - '#Parameter (.*) of class Webauthn\\Bundle\\Security\\Authentication\\Token\\WebauthnToken constructor expects array(.*) given#' - - '#Call to deprecated method checkAttestationMedata\(\) of class Webauthn\\CertificateToolbox.*#' checkMissingIterableValueType: false checkGenericClassInNonGenericObjectType: false includes: diff --git a/psalm.xml b/psalm.xml deleted file mode 100644 index 42f355b2c..000000000 --- a/psalm.xml +++ /dev/null @@ -1,55 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/metadata-service/src/DistantSingleMetadataFactory.php b/src/metadata-service/src/DistantSingleMetadataFactory.php deleted file mode 100644 index 0120ce85f..000000000 --- a/src/metadata-service/src/DistantSingleMetadataFactory.php +++ /dev/null @@ -1,43 +0,0 @@ -httpClient = $httpClient; - $this->requestFactory = $requestFactory; - } - - public function create(string $uri, bool $isBare64Encoded, array $additionalHeaders = [], ?ClientInterface $client = null): DistantSingleMetadata - { - $client = $client ?? $this->httpClient; - - return new DistantSingleMetadata($uri, $isBare64Encoded, $client, $this->requestFactory, $additionalHeaders); - } -} diff --git a/src/metadata-service/src/MetadataServiceFactory.php b/src/metadata-service/src/MetadataServiceFactory.php deleted file mode 100644 index aa6efa0b5..000000000 --- a/src/metadata-service/src/MetadataServiceFactory.php +++ /dev/null @@ -1,43 +0,0 @@ -httpClient = $httpClient; - $this->requestFactory = $requestFactory; - } - - public function create(string $serviceUri, array $additionalQueryStringValues = [], array $additionalHeaders = [], ?ClientInterface $client = null): MetadataService - { - $client = $client ?? $this->httpClient; - - return new MetadataService($serviceUri, $client, $this->requestFactory, $additionalQueryStringValues, $additionalHeaders); - } -} diff --git a/src/metadata-service/src/MetadataStatementRepository.php b/src/metadata-service/src/MetadataStatementRepository.php index 2743e184e..014de4f77 100644 --- a/src/metadata-service/src/MetadataStatementRepository.php +++ b/src/metadata-service/src/MetadataStatementRepository.php @@ -16,4 +16,9 @@ interface MetadataStatementRepository { public function findOneByAAGUID(string $aaguid): ?MetadataStatement; + + /** + * @return StatusReport[] + */ + public function findStatusReportsByAAGUID(string $aaguid): array; } diff --git a/src/metadata-service/src/MetadataStatementStatusReportRepository.php b/src/metadata-service/src/MetadataStatementStatusReportRepository.php deleted file mode 100644 index 35533e9ed..000000000 --- a/src/metadata-service/src/MetadataStatementStatusReportRepository.php +++ /dev/null @@ -1,22 +0,0 @@ - $this->aaid, 'aaguid' => $this->aaguid, 'attestationCertificateKeyIdentifiers' => $this->attestationCertificateKeyIdentifiers, - 'hash' => $this->hash, + 'hash' => Base64Url::encode($this->hash), 'url' => $this->url, 'statusReports' => $this->statusReports, 'timeOfLastStatusChange' => $this->timeOfLastStatusChange, diff --git a/src/metadata-service/src/RgbPaletteEntry.php b/src/metadata-service/src/RgbPaletteEntry.php index 3bc5e91e6..21d320798 100644 --- a/src/metadata-service/src/RgbPaletteEntry.php +++ b/src/metadata-service/src/RgbPaletteEntry.php @@ -35,9 +35,9 @@ class RgbPaletteEntry implements JsonSerializable public function __construct(int $r, int $g, int $b) { - Assertion::range($r, 0, 254, Utils::logicException('The key "r" is invalid')); - Assertion::range($g, 0, 254, Utils::logicException('The key "g" is invalid')); - Assertion::range($b, 0, 254, Utils::logicException('The key "b" is invalid')); + Assertion::range($r, 0, 255, Utils::logicException('The key "r" is invalid')); + Assertion::range($g, 0, 255, Utils::logicException('The key "g" is invalid')); + Assertion::range($b, 0, 255, Utils::logicException('The key "b" is invalid')); $this->r = $r; $this->g = $g; $this->b = $b; diff --git a/src/metadata-service/src/SimpleMetadataStatementRepository.php b/src/metadata-service/src/SimpleMetadataStatementRepository.php deleted file mode 100644 index c3e4d518e..000000000 --- a/src/metadata-service/src/SimpleMetadataStatementRepository.php +++ /dev/null @@ -1,129 +0,0 @@ -cacheItemPool = $cacheItemPool; - } - - public function addService(string $name, MetadataService $service): self - { - $this->services[$name] = $service; - - return $this; - } - - public function addSingleStatement(string $name, SingleMetadata $singleStatements): self - { - $this->singleStatements[$name] = $singleStatements; - - return $this; - } - - public function findOneByAAGUID(string $aaguid): ?MetadataStatement - { - $metadataStatement = $this->findOneByAAGUIDFromServices($aaguid); - if (null !== $metadataStatement) { - return $metadataStatement; - } - - return $this->findOneByAAGUIDFromSingleStatements($aaguid); - } - - public function findStatusReportsByAAGUID(string $aaguid): array - { - $entry = $this->findEntryForAAGUID($aaguid); - - return null === $entry ? [] : $entry->getStatusReports(); - } - - private function findOneByAAGUIDFromSingleStatements(string $aaguid): ?MetadataStatement - { - foreach ($this->singleStatements as $name => $singleStatement) { - try { - $singleCacheItem = $this->cacheItemPool->getItem(sprintf('MDS-%s', $name)); - if (!$singleCacheItem->isHit()) { - $metadataStatement = $singleStatement->getMetadataStatement(); - $singleCacheItem->set($metadataStatement); - $this->cacheItemPool->save($singleCacheItem); - } else { - $metadataStatement = $singleCacheItem->get(); - } - - if ($metadataStatement->getAaguid() === $aaguid) { - return $metadataStatement; - } - } catch (Throwable $throwable) { - continue; - } - } - - return null; - } - - private function findOneByAAGUIDFromServices(string $aaguid): ?MetadataStatement - { - $entry = $this->findEntryForAAGUID($aaguid, $service); - try { - return $service->getMetadataStatementFor($entry); - } catch (Throwable $throwable) { - return null; - } - } - - private function findEntryForAAGUID(string $aaguid, ?MetadataService &$service = null): ?MetadataTOCPayloadEntry - { - foreach ($this->services as $name => $s) { - try { - $tableOfContent = $s->getMetadataTOCPayload(); - foreach ($tableOfContent->getEntries() as $entry) { - if ($aaguid !== $entry->getAaguid()) { //Does not correspond - continue; - } - if (null === $entry->getUrl() || null === $entry->getHash()) { //Not published - continue; - } - $service = $s; - - return $entry; - } - } catch (Throwable $throwable) { - continue; - } - } - - return null; - } -} diff --git a/src/metadata-service/tests/functional/MetadataServiceTest.php b/src/metadata-service/tests/functional/MetadataServiceTest.php index a667db237..0855cefa4 100644 --- a/src/metadata-service/tests/functional/MetadataServiceTest.php +++ b/src/metadata-service/tests/functional/MetadataServiceTest.php @@ -66,7 +66,7 @@ public function theTocCanBeRetrieved(): void private function callObjectMethods($object): void { $availableMethods = get_class_methods($object); - $availableMethods = array_filter($availableMethods, static function ($method) use ($object) { + $availableMethods = array_filter($availableMethods, static function ($method) use ($object): bool { $classMethod = new ReflectionMethod($object, $method); return !\in_array($method, ['createFromArray', 'create', '__construct', 'jsonSerialize'], true) && 0 === \count($classMethod->getParameters()); diff --git a/src/symfony/src/DataCollector/WebauthnCollector.php b/src/symfony/src/DataCollector/WebauthnCollector.php index bf94afac3..1a9217acc 100644 --- a/src/symfony/src/DataCollector/WebauthnCollector.php +++ b/src/symfony/src/DataCollector/WebauthnCollector.php @@ -13,7 +13,6 @@ namespace Webauthn\Bundle\DataCollector; -use Exception; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; @@ -124,14 +123,6 @@ public function reset(): void $this->data = []; } - /** - * {@inheritdoc} - */ - public function getData(): array - { - return $this->data; - } - public static function getSubscribedEvents(): array { return [ diff --git a/src/symfony/src/DependencyInjection/Configuration.php b/src/symfony/src/DependencyInjection/Configuration.php index 37e7a4e55..38f0d710d 100644 --- a/src/symfony/src/DependencyInjection/Configuration.php +++ b/src/symfony/src/DependencyInjection/Configuration.php @@ -92,110 +92,8 @@ public function getConfigTreeBuilder() ->canBeEnabled() ->children() ->scalarNode('repository') - ->defaultValue('webauthn.metadata_service.default_repository') - ->info('Metadata Statement repository') - ->end() - ->scalarNode('http_client') - ->defaultValue('webauthn.metadata_service.default_http_client') - ->info('PSR18 HTTP Client') - ->end() - ->scalarNode('request_factory') ->isRequired() - ->info('PSR-7 Request factory service') - ->end() - ->arrayNode('services') - ->treatFalseLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->arrayPrototype() - ->addDefaultsIfNotSet() - ->children() - ->booleanNode('is_public') - ->defaultFalse() - ->info('If true, the service will be public') - ->end() - ->scalarNode('uri') - ->isRequired() - ->info('Metadata service URI (e.g. https://mds2.fidoalliance.org)') - ->end() - ->arrayNode('additional_query_string_values') - ->info('Additional query string key/value pairs (e.g. access token)') - ->treatFalseLike([]) - ->treatTrueLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->variablePrototype()->end() - ->end() - ->arrayNode('additional_headers') - ->info('Additional header parameters (e.g. authorization)') - ->treatFalseLike([]) - ->treatTrueLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->variablePrototype()->end() - ->end() - ->scalarNode('http_client') - ->defaultNull() - ->info('If set, this client will override the one defined in the "metadata_service" section') - ->end() - ->end() - ->end() - ->end() - ->arrayNode('distant_single_statements') - ->treatFalseLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->arrayPrototype() - ->addDefaultsIfNotSet() - ->children() - ->booleanNode('is_public') - ->defaultFalse() - ->info('If true, the service will be public') - ->end() - ->booleanNode('is_base_64') - ->defaultFalse() - ->info('If the metadata statement is encoded in base 64, set true') - ->end() - ->scalarNode('uri') - ->isRequired() - ->info('Metadata URI (e.g. https://raw.githubusercontent.com/solokeys/solo/2.1.0/metadata/Solo-FIDO2-CTAP2-Authenticator.json)') - ->end() - ->scalarNode('http_client') - ->defaultNull() - ->info('If set, this client will override the one defined in the "metadata_service" section') - ->end() - ->arrayNode('additional_headers') - ->info('Additional header parameters (e.g. authorization)') - ->treatFalseLike([]) - ->treatTrueLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->variablePrototype()->end() - ->end() - ->end() - ->end() - ->end() - ->arrayNode('from_data') - ->treatFalseLike([]) - ->treatNullLike([]) - ->useAttributeAsKey('name') - ->arrayPrototype() - ->addDefaultsIfNotSet() - ->children() - ->booleanNode('is_public') - ->defaultFalse() - ->info('If true, the service will be public') - ->end() - ->booleanNode('is_base_64') - ->defaultFalse() - ->info('If the metadata statement is encoded in base 64, set true') - ->end() - ->scalarNode('data') - ->isRequired() - ->info('Metadata data') - ->end() - ->end() - ->end() + ->info('Metadata Statement repository') ->end() ->end() ->end() diff --git a/src/symfony/src/DependencyInjection/WebauthnExtension.php b/src/symfony/src/DependencyInjection/WebauthnExtension.php index 751737e7c..a7bc14b23 100644 --- a/src/symfony/src/DependencyInjection/WebauthnExtension.php +++ b/src/symfony/src/DependencyInjection/WebauthnExtension.php @@ -42,12 +42,8 @@ use Webauthn\ConformanceToolset\Controller\AttestationResponseControllerFactory; use Webauthn\Counter\CounterChecker; use Webauthn\MetadataService\DistantSingleMetadata; -use Webauthn\MetadataService\DistantSingleMetadataFactory; use Webauthn\MetadataService\MetadataService; -use Webauthn\MetadataService\MetadataServiceFactory; use Webauthn\MetadataService\MetadataStatementRepository; -use Webauthn\MetadataService\MetadataStatementStatusReportRepository; -use Webauthn\MetadataService\SingleMetadata; use Webauthn\PublicKeyCredentialSourceRepository; use Webauthn\TokenBinding\TokenBindingHandler; @@ -98,6 +94,9 @@ public function load(array $configs, ContainerBuilder $container): void $this->loadTransportBindingProfile($container, $loader, $config); $this->loadMetadataServices($container, $loader, $config); + if (true === $config['metadata_service']['enabled']) { + $this->loadMetadataStatementSupports($container, $loader, $config); + } if (null !== $config['user_repository']) { $container->setAlias(PublicKeyCredentialUserEntityRepository::class, $config['user_repository']); @@ -169,8 +168,11 @@ public function loadTransportBindingProfile(ContainerBuilder $container, LoaderI } } - private function loadAndroidSafetyNet(ContainerBuilder $container, LoaderInterface $loader, array $config): void + private function loadMetadataStatementSupports(ContainerBuilder $container, LoaderInterface $loader, array $config): void { + $loader->load('metadata_statement_supports.php'); + + //Android SafetyNet $container->setAlias('webauthn.android_safetynet.http_client', $config['android_safetynet']['http_client']); $container->setParameter('webauthn.android_safetynet.api_key', $config['android_safetynet']['api_key']); $container->setParameter('webauthn.android_safetynet.leeway', $config['android_safetynet']['leeway']); @@ -180,64 +182,10 @@ private function loadAndroidSafetyNet(ContainerBuilder $container, LoaderInterfa private function loadMetadataServices(ContainerBuilder $container, LoaderInterface $loader, array $config): void { - //INFO: in v2.1, all metadata statement supports are loaded. - // Starting at v3.0, if the metadata service is not enabled, only "none" will be available as this service will become mandatory for: - // - FIDO2 U2F - // - Packed - // - Android Key - // - Android SafetyNet - // - TPM - $loader->load('metadata_statement_supports.php'); - $this->loadAndroidSafetyNet($container, $loader, $config); - - if (false === $config['metadata_service']['enabled'] || !class_exists(MetadataServiceFactory::class)) { + if (false === $config['metadata_service']['enabled']) { return; } $container->setAlias(MetadataStatementRepository::class, $config['metadata_service']['repository']); - $container->setAlias(MetadataStatementStatusReportRepository::class, $config['metadata_service']['repository']); - $container->setAlias('webauthn.metadata_service.http_client', $config['metadata_service']['http_client']); - $container->setAlias('webauthn.metadata_service.request_factory', $config['metadata_service']['request_factory']); - $loader->load('metadata_service.php'); - - foreach ($config['metadata_service']['services'] as $name => $statementConfig) { - $metadataServiceId = sprintf('webauthn.metadata_service.service.%s', $name); - $metadataService = new Definition(MetadataService::class); - $metadataService->setFactory([new Reference(MetadataServiceFactory::class), 'create']); - $metadataService->setArguments([ - $statementConfig['uri'], - $statementConfig['additional_query_string_values'], - $statementConfig['additional_headers'], - $statementConfig['http_client'], - ]); - $metadataService->setPublic($statementConfig['is_public']); - $metadataService->addTag(MetadataServiceCompilerPass::TAG); - $container->setDefinition($metadataServiceId, $metadataService); - } - foreach ($config['metadata_service']['distant_single_statements'] as $name => $statementConfig) { - $metadataServiceId = sprintf('webauthn.metadata_service.distant_single_statement.%s', $name); - $metadataService = new Definition(DistantSingleMetadata::class); - $metadataService->setFactory([new Reference(DistantSingleMetadataFactory::class), 'create']); - $metadataService->setArguments([ - $statementConfig['uri'], - $statementConfig['is_base_64'], - $statementConfig['additional_headers'], - $statementConfig['http_client'], - ]); - $metadataService->setPublic($statementConfig['is_public']); - $metadataService->addTag(SingleMetadataCompilerPass::TAG); - $container->setDefinition($metadataServiceId, $metadataService); - } - foreach ($config['metadata_service']['from_data'] as $name => $statementConfig) { - $metadataServiceId = sprintf('webauthn.metadata_service.from_data.%s', $name); - $metadataService = new Definition(SingleMetadata::class); - $metadataService->setArguments([ - $statementConfig['data'], - $statementConfig['is_base_64'], - ]); - $metadataService->setPublic($statementConfig['is_public']); - $metadataService->addTag(SingleMetadataCompilerPass::TAG); - $container->setDefinition($metadataServiceId, $metadataService); - } } /** diff --git a/src/symfony/src/Resources/config/android_safetynet.php b/src/symfony/src/Resources/config/android_safetynet.php index 9bf030fba..e3b2d2b2d 100644 --- a/src/symfony/src/Resources/config/android_safetynet.php +++ b/src/symfony/src/Resources/config/android_safetynet.php @@ -17,7 +17,7 @@ use Symfony\Component\HttpClient\Psr18Client; use Webauthn\AttestationStatement; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Resources/config/cose.php b/src/symfony/src/Resources/config/cose.php index 1a41ed37a..5a814b22f 100644 --- a/src/symfony/src/Resources/config/cose.php +++ b/src/symfony/src/Resources/config/cose.php @@ -15,7 +15,7 @@ use Cose\Algorithm\Signature; use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Resources/config/dev_services.php b/src/symfony/src/Resources/config/dev_services.php index 8de8d7d5c..331b8b815 100644 --- a/src/symfony/src/Resources/config/dev_services.php +++ b/src/symfony/src/Resources/config/dev_services.php @@ -15,7 +15,7 @@ use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Resources/config/metadata_service.php b/src/symfony/src/Resources/config/metadata_service.php deleted file mode 100644 index d116e341b..000000000 --- a/src/symfony/src/Resources/config/metadata_service.php +++ /dev/null @@ -1,46 +0,0 @@ -services()->defaults() - ->private() - ->autoconfigure() - ->autowire(); - - $container->set('webauthn.metadata_service.default_http_client') - ->class(Psr18Client::class); - - $container->set('webauthn.metadata_service.default_repository') - ->class(SimpleMetadataStatementRepository::class) - ->public(); - - $container->set(MetadataServiceFactory::class) - ->public() - ->args([ - ref('webauthn.metadata_service.http_client'), - ref('webauthn.metadata_service.request_factory'), - ]); - $container->set(DistantSingleMetadataFactory::class) - ->public() - ->args([ - ref('webauthn.metadata_service.http_client'), - ref('webauthn.metadata_service.request_factory'), - ]); -}; diff --git a/src/symfony/src/Resources/config/metadata_statement_supports.php b/src/symfony/src/Resources/config/metadata_statement_supports.php index 26b3824ec..06cbe5925 100644 --- a/src/symfony/src/Resources/config/metadata_statement_supports.php +++ b/src/symfony/src/Resources/config/metadata_statement_supports.php @@ -15,7 +15,7 @@ use function Symfony\Component\DependencyInjection\Loader\Configurator\ref; use Webauthn\AttestationStatement; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Resources/config/security.php b/src/symfony/src/Resources/config/security.php index e484456d2..1ca74e106 100644 --- a/src/symfony/src/Resources/config/security.php +++ b/src/symfony/src/Resources/config/security.php @@ -38,7 +38,7 @@ use Webauthn\PublicKeyCredentialLoader; use Webauthn\PublicKeyCredentialSourceRepository; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container->services()->set(WebauthnProvider::class) ->private() ->arg(0, ref(UserCheckerInterface::class)) diff --git a/src/symfony/src/Resources/config/services.php b/src/symfony/src/Resources/config/services.php index 1b6fb0f7e..d48961193 100644 --- a/src/symfony/src/Resources/config/services.php +++ b/src/symfony/src/Resources/config/services.php @@ -32,7 +32,7 @@ use Webauthn\TokenBinding; use Webauthn\TokenBinding\TokenBindingHandler; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Resources/config/transport_binding_profile.php b/src/symfony/src/Resources/config/transport_binding_profile.php index 9e7614d43..ec2d967d4 100644 --- a/src/symfony/src/Resources/config/transport_binding_profile.php +++ b/src/symfony/src/Resources/config/transport_binding_profile.php @@ -16,7 +16,7 @@ use Webauthn\ConformanceToolset\Controller\AssertionResponseControllerFactory; use Webauthn\ConformanceToolset\Controller\AttestationResponseControllerFactory; -return function (ContainerConfigurator $container) { +return static function (ContainerConfigurator $container): void { $container = $container->services()->defaults() ->private() ->autoconfigure() diff --git a/src/symfony/src/Routing/Loader.php b/src/symfony/src/Routing/Loader.php index 3eba60577..ad57b75ed 100644 --- a/src/symfony/src/Routing/Loader.php +++ b/src/symfony/src/Routing/Loader.php @@ -13,13 +13,12 @@ namespace Webauthn\Bundle\Routing; -use Symfony\Component\Config\Loader\LoaderInterface; -use Symfony\Component\Config\Loader\LoaderResolverInterface; +use Symfony\Component\Config\Loader\Loader as SymfonyLoader; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\Routing\Route; use Symfony\Component\Routing\RouteCollection; -class Loader implements LoaderInterface +class Loader extends SymfonyLoader { /** * @var RouteCollection @@ -48,12 +47,4 @@ public function supports($resource, string $type = null): bool { return 'webauthn' === $type; } - - public function getResolver(): void - { - } - - public function setResolver(LoaderResolverInterface $resolver): void - { - } } diff --git a/src/symfony/src/Security/Firewall/WebauthnListener.php b/src/symfony/src/Security/Firewall/WebauthnListener.php index 4a36bd2bc..178931b6d 100644 --- a/src/symfony/src/Security/Firewall/WebauthnListener.php +++ b/src/symfony/src/Security/Firewall/WebauthnListener.php @@ -382,7 +382,7 @@ private function getCredentials(PublicKeyCredentialUserEntity $userEntity): arra { $credentialSources = $this->publicKeyCredentialSourceRepository->findAllForUserEntity($userEntity); - return array_map(function (PublicKeyCredentialSource $credential) { + return array_map(static function (PublicKeyCredentialSource $credential): PublicKeyCredentialDescriptor { return $credential->getPublicKeyCredentialDescriptor(); }, $credentialSources); } diff --git a/src/symfony/src/Security/Storage/SessionStorage.php b/src/symfony/src/Security/Storage/SessionStorage.php index 1c647c2c3..5cd76a864 100644 --- a/src/symfony/src/Security/Storage/SessionStorage.php +++ b/src/symfony/src/Security/Storage/SessionStorage.php @@ -13,7 +13,6 @@ namespace Webauthn\Bundle\Security\Storage; -use Assert\Assertion; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; use Webauthn\PublicKeyCredentialOptions; @@ -29,16 +28,12 @@ final class SessionStorage implements OptionsStorage public function store(Request $request, StoredData $data): void { $session = $request->getSession(); - Assertion::notNull($session, 'This authentication method requires a session.'); - $session->set(self::SESSION_PARAMETER, ['options' => $data->getPublicKeyCredentialOptions(), 'userEntity' => $data->getPublicKeyCredentialUserEntity()]); } public function get(Request $request): StoredData { $session = $request->getSession(); - Assertion::notNull($session, 'This authentication method requires a session.'); - $sessionValue = $session->remove(self::SESSION_PARAMETER); if (!\is_array($sessionValue) || !\array_key_exists('options', $sessionValue) || !\array_key_exists('userEntity', $sessionValue)) { throw new BadRequestHttpException('No public key credential options available for this session.'); diff --git a/src/symfony/src/Service/AuthenticatorAttestationResponseValidator.php b/src/symfony/src/Service/AuthenticatorAttestationResponseValidator.php index 028147921..d42e41442 100644 --- a/src/symfony/src/Service/AuthenticatorAttestationResponseValidator.php +++ b/src/symfony/src/Service/AuthenticatorAttestationResponseValidator.php @@ -34,9 +34,9 @@ final class AuthenticatorAttestationResponseValidator extends BaseAuthenticatorA */ private $eventDispatcher; - public function __construct(AttestationStatementSupportManager $attestationStatementSupportManager, PublicKeyCredentialSourceRepository $publicKeyCredentialSource, TokenBindingHandler $tokenBindingHandler, ExtensionOutputCheckerHandler $extensionOutputCheckerHandler, EventDispatcherInterface $eventDispatcher, bool $enforceMetadataStatementVerification = false) + public function __construct(AttestationStatementSupportManager $attestationStatementSupportManager, PublicKeyCredentialSourceRepository $publicKeyCredentialSource, TokenBindingHandler $tokenBindingHandler, ExtensionOutputCheckerHandler $extensionOutputCheckerHandler, EventDispatcherInterface $eventDispatcher) { - parent::__construct($attestationStatementSupportManager, $publicKeyCredentialSource, $tokenBindingHandler, $extensionOutputCheckerHandler, $enforceMetadataStatementVerification); + parent::__construct($attestationStatementSupportManager, $publicKeyCredentialSource, $tokenBindingHandler, $extensionOutputCheckerHandler); $this->eventDispatcher = $eventDispatcher; } diff --git a/src/symfony/src/Service/PublicKeyCredentialCreationOptionsFactory.php b/src/symfony/src/Service/PublicKeyCredentialCreationOptionsFactory.php index d4095b170..a0d7ee4bf 100644 --- a/src/symfony/src/Service/PublicKeyCredentialCreationOptionsFactory.php +++ b/src/symfony/src/Service/PublicKeyCredentialCreationOptionsFactory.php @@ -93,7 +93,7 @@ private function createRpEntity(array $profile): PublicKeyCredentialRpEntity */ private function createCredentialParameters(array $profile): array { - $callback = function ($alg) { + $callback = static function ($alg): PublicKeyCredentialParameters { return new PublicKeyCredentialParameters( PublicKeyCredentialDescriptor::CREDENTIAL_TYPE_PUBLIC_KEY, $alg diff --git a/src/symfony/tests/config/config.yml b/src/symfony/tests/config/config.yml index cacac91b7..a185ad6e4 100644 --- a/src/symfony/tests/config/config.yml +++ b/src/symfony/tests/config/config.yml @@ -53,6 +53,92 @@ services: Webauthn\Bundle\Tests\Functional\FailureHandler: ~ Webauthn\Bundle\Tests\Functional\SuccessHandler: ~ Webauthn\Bundle\Tests\Functional\CustomSessionStorage: ~ + Webauthn\Bundle\Tests\Functional\MetadataStatementRepository: + arguments: + - '@httplug.client.mock' + - '@Nyholm\Psr7\Factory\Psr17Factory' + calls: + - method: addDistantSingleStatement + arguments: + - 'https://raw.githubusercontent.com/solokeys/solo/2.1.0/metadata/Solo-FIDO2-CTAP2-Authenticator.json' + - method: addSingleStatement + arguments: + - '{"description": "Yubico U2F Root CA Serial 457200631","aaguid": "f8a011f3-8c0a-4d15-8006-17111f9edc7d","protocolFamily": "fido2","attestationRootCertificates": ["MIIDHjCCAgagAwIBAgIEG0BT9zANBgkqhkiG9w0BAQsFADAuMSwwKgYDVQQDEyNZdWJpY28gVTJGIFJvb3QgQ0EgU2VyaWFsIDQ1NzIwMDYzMTAgFw0xNDA4MDEwMDAwMDBaGA8yMDUwMDkwNDAwMDAwMFowLjEsMCoGA1UEAxMjWXViaWNvIFUyRiBSb290IENBIFNlcmlhbCA0NTcyMDA2MzEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC/jwYuhBVlqaiYWEMsrWFisgJ+PtM91eSrpI4TK7U53mwCIawSDHy8vUmk5N2KAj9abvT9NP5SMS1hQi3usxoYGonXQgfO6ZXyUA9a+KAkqdFnBnlyugSeCOep8EdZFfsaRFtMjkwz5Gcz2Py4vIYvCdMHPtwaz0bVuzneueIEz6TnQjE63Rdt2zbwnebwTG5ZybeWSwbzy+BJ34ZHcUhPAY89yJQXuE0IzMZFcEBbPNRbWECRKgjq//qT9nmDOFVlSRCt2wiqPSzluwn+v+suQEBsUjTGMEd25tKXXTkNW21wIWbxeSyUoTXwLvGS6xlwQSgNpk2qXYwf8iXg7VWZAgMBAAGjQjBAMB0GA1UdDgQWBBQgIvz0bNGJhjgpToksyKpP9xv9oDAPBgNVHRMECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAQEAjvjuOMDSa+JXFCLyBKsycXtBVZsJ4Ue3LbaEsPY4MYN/hIQ5ZM5p7EjfcnMG4CtYkNsfNHc0AhBLdq45rnT87q/6O3vUEtNMafbhU6kthX7Y+9XFN9NpmYxr+ekVY5xOxi8h9JDIgoMP4VB1uS0aunL1IGqrNooL9mmFnL2kLVVee6/VR6C5+KSTCMCWppMuJIZII2v9o4dkoZ8Y7QRjQlLfYzd3qGtKbw7xaF1UsG/5xUb/Btwb2X2g4InpiB/yt/3CpQXpiWX/K4mBvUKiGn05ZsqeY1gx4g0xLBqcU9psmyPzK+Vsgw2jeRQ5JlKDyqE0hebfC1tvFu0CCrJFcw=="]}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual FIDO2 EdDSA25519 SHA512 Conformance Testing CTAP2 Authenticator", "aaguid": "91dfead7-959e-4475-ad26-9b0d482be089", "alternativeDescriptions": {"ru-RU": "Виртуальный CTAP2 EdDSA25519 SHA512 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 18, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PCKS1.5 SHA1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "a8d59924-63b7-49ea-b9de-34a753de1e01", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 15, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PCKS1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "9debdbfd-14dd-4e8d-877b-4a6e35ddb375", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA256 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PCKS1.5 SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "59c118ea-188c-4dcf-9881-b8b058abf2f1", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA384 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 13, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PCKS1.5 SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "1e4fcea1-3681-48d3-9deb-9cbf5d2f79b5", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA512 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 14, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PKCS 1.5 SHA1 FIDO2 Conformance Testing CTAP2 Authenticator with TPM Attestation", "aaguid": "f244b67e-5364-4fd5-9f90-c396227317db", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA1 CTAP2 аутентификатор с TPM аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 15, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15882], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PKCS 1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator with SafetyNet attestation", "aaguid": "c87cdd97-56c1-49b8-9e24-cb363654f350", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA256 CTAP2 аутентификатор с SafetyNet аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSA PKCS 1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator with TPM Attestation", "aaguid": "a7d6d93a-8a0d-11e8-9a94-a6cf71072f73", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA256 CTAP2 аутентификатор с TPM аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15882], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSAPSS SHA256 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "a96c4970-7d5f-4d6a-81f7-7632b7ae0240", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA256 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 3, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSAPSS SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "06ecba69-665c-4299-bd7f-43546324d1cd", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA384 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 10, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual RSAPSS SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "5fb69bde-6076-4c75-a2af-75102cabe2de", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA512 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 11, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256K1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "79d699df-0191-4b10-b903-5467e7ce8231", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256K1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 5, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256K1 FIDO2 Conformance Testing U2F Authenticator", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256K1 U2F аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "attestationCertificateKeyIdentifiers": ["564df7c0f8c655b6a11f6c4d19f3bf41e2fd0179"], "protocolFamily": "u2f", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "U2FV1BIN", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 256, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 26, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": true, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "326adcf0-0cef-46d0-9392-98d6c4a84a72", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with Android Key Attestation", "aaguid": "550e4b54-aa47-409f-9a95-1ab76c130131", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор с Android Key аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIDFTCCArygAwIBAgIJAPYG0nMp5fspMAoGCCqGSM49BAMCMIHcMT0wOwYDVQQDDDRGQUtFIEFuZHJvaWQgS2V5c3RvcmUgU29mdHdhcmUgQXR0ZXN0YXRpb24gUm9vdCBGQUtFMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDAgFw0xOTA0MjUwNTQ5MzJaGA8yMDc0MDEyNjA1NDkzMlowgdwxPTA7BgNVBAMMNEZBS0UgQW5kcm9pZCBLZXlzdG9yZSBTb2Z0d2FyZSBBdHRlc3RhdGlvbiBSb290IEZBS0UxMTAvBgkqhkiG9w0BCQEWImNvbmZvcm1hbmNlLXRvb2xzQGZpZG9hbGxpYW5jZS5vcmcxFjAUBgNVBAoMDUZJRE8gQWxsaWFuY2UxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEaH+BmKuo1XRtjS3UJVLrjh0bNl/lLhU7VX89N8+kuI8rnZCfXVD5k3qpOFSY6oTtrcZ1aQRSyR4sZ8EC6Hoi7aNjMGEwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAoQwHQYDVR0OBBYEFFKaGzLgVqrNUQ/vX4A3BovykSMdMB8GA1UdIwQYMBaAFFKaGzLgVqrNUQ/vX4A3BovykSMdMAoGCCqGSM49BAMCA0cAMEQCIAfWMAOOjxO6noErB+wtRBmrDruNIApw70G7kBhliXLkAiBM8sYUVClPsJkCUHI5Wix3ybY31L5J51VS+f1gACNn+Q=="], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with Self(surrogate) attestation", "aaguid": "2b2ecbb4-59b4-44fa-868d-a072485d8ae0", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор с самоаттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": [], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with supported extensions", "aaguid": "69700f79-d1fb-472e-bd9b-a3a3b9a9eda0", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2 с дополнениями"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 3, "tcDisplayContentType": "image/png", "tcDisplayPNGCharacteristics": [{"bitDepth": 16, "colorType": 2, "compression": 0, "filter": 0, "height": 240, "interlace": 0, "width": 320}], "supportedExtensions": [{"id": "example.extension", "fail_if_unknown": false}, {"id": "txAuthGeneric", "fail_if_unknown": false}, {"id": "txAuthSimple", "fail_if_unknown": false}], "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp256R1 Multiple Root Certificates FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "80f53d1e-852e-43ed-bb3f-d02f1322e5af", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2 содержащий множество корневых сертификатов"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp384r1 SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "0c71d839-41d7-43ed-928f-381023196e35", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp384r1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 16, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addSingleStatement + arguments: + - '{"description": "Virtual Secp521r1 SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "2388ab8d-8915-4146-93ba-d43e671d2538", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp521r1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 17, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + - method: addService + arguments: + - 'https://fidoalliance.co.nz/mds/execute/0ab57df429bd2a277c1e87ce705099d134219af5e2e2577ff287afa073c963ad' + - method: addService + arguments: + - 'https://fidoalliance.co.nz/mds/execute/39fa5b56ba6d5186e1f384d3fd880499ef9647086b2e7419cc01e12211ca16dd' + - method: addService + arguments: + - 'https://fidoalliance.co.nz/mds/execute/3d559152a328ae5c934de1005f53a376a03f5ef6f61ec4c318ca5552a9c4ebf7' + - method: addService + arguments: + - 'https://fidoalliance.co.nz/mds/execute/d7eac3e12c24a05edbb3eef1cd757c3fa670a348e29e35285046f1173b77d7c0' + - method: addService + arguments: + - 'https://fidoalliance.co.nz/mds/execute/d7f47b1a5d510bd440874b7d89e3b42347413cdd5a311059ee53cf5dc688526b' doctrine: dbal: @@ -122,71 +208,7 @@ webauthn: session_parameter_name: '__WEBAUTHN_ASSERTION_REQUEST__1' metadata_service: enabled: true - http_client: 'httplug.client.mock' - request_factory: 'Nyholm\Psr7\Factory\Psr17Factory' - services: - fido_alliance_test1: - uri: 'https://fidoalliance.co.nz/mds/execute/0ab57df429bd2a277c1e87ce705099d134219af5e2e2577ff287afa073c963ad' - fido_alliance_test2: - uri: 'https://fidoalliance.co.nz/mds/execute/39fa5b56ba6d5186e1f384d3fd880499ef9647086b2e7419cc01e12211ca16dd' - fido_alliance_test3: - uri: 'https://fidoalliance.co.nz/mds/execute/3d559152a328ae5c934de1005f53a376a03f5ef6f61ec4c318ca5552a9c4ebf7' - fido_alliance_test4: - uri: 'https://fidoalliance.co.nz/mds/execute/d7eac3e12c24a05edbb3eef1cd757c3fa670a348e29e35285046f1173b77d7c0' - fido_alliance_test5: - uri: 'https://fidoalliance.co.nz/mds/execute/d7f47b1a5d510bd440874b7d89e3b42347413cdd5a311059ee53cf5dc688526b' - fido_alliance: - is_public: true - uri: 'https://foo.com' - additional_query_string_values: - token: '--TOKEN--' - distant_single_statements: - solo: - uri: 'https://raw.githubusercontent.com/solokeys/solo/2.1.0/metadata/Solo-FIDO2-CTAP2-Authenticator.json' - additional_headers: ~ - from_data: - yubico: - data: '{"description": "Yubico U2F Root CA Serial 457200631","aaguid": "f8a011f3-8c0a-4d15-8006-17111f9edc7d","protocolFamily": "fido2","attestationRootCertificates": ["MIIDHjCCAgagAwIBAgIEG0BT9zANBgkqhkiG9w0BAQsFADAuMSwwKgYDVQQDEyNZdWJpY28gVTJGIFJvb3QgQ0EgU2VyaWFsIDQ1NzIwMDYzMTAgFw0xNDA4MDEwMDAwMDBaGA8yMDUwMDkwNDAwMDAwMFowLjEsMCoGA1UEAxMjWXViaWNvIFUyRiBSb290IENBIFNlcmlhbCA0NTcyMDA2MzEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC/jwYuhBVlqaiYWEMsrWFisgJ+PtM91eSrpI4TK7U53mwCIawSDHy8vUmk5N2KAj9abvT9NP5SMS1hQi3usxoYGonXQgfO6ZXyUA9a+KAkqdFnBnlyugSeCOep8EdZFfsaRFtMjkwz5Gcz2Py4vIYvCdMHPtwaz0bVuzneueIEz6TnQjE63Rdt2zbwnebwTG5ZybeWSwbzy+BJ34ZHcUhPAY89yJQXuE0IzMZFcEBbPNRbWECRKgjq//qT9nmDOFVlSRCt2wiqPSzluwn+v+suQEBsUjTGMEd25tKXXTkNW21wIWbxeSyUoTXwLvGS6xlwQSgNpk2qXYwf8iXg7VWZAgMBAAGjQjBAMB0GA1UdDgQWBBQgIvz0bNGJhjgpToksyKpP9xv9oDAPBgNVHRMECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAQEAjvjuOMDSa+JXFCLyBKsycXtBVZsJ4Ue3LbaEsPY4MYN/hIQ5ZM5p7EjfcnMG4CtYkNsfNHc0AhBLdq45rnT87q/6O3vUEtNMafbhU6kthX7Y+9XFN9NpmYxr+ekVY5xOxi8h9JDIgoMP4VB1uS0aunL1IGqrNooL9mmFnL2kLVVee6/VR6C5+KSTCMCWppMuJIZII2v9o4dkoZ8Y7QRjQlLfYzd3qGtKbw7xaF1UsG/5xUb/Btwb2X2g4InpiB/yt/3CpQXpiWX/K4mBvUKiGn05ZsqeY1gx4g0xLBqcU9psmyPzK+Vsgw2jeRQ5JlKDyqE0hebfC1tvFu0CCrJFcw=="]}' - virtual1: - data: '{"description": "Virtual FIDO2 EdDSA25519 SHA512 Conformance Testing CTAP2 Authenticator", "aaguid": "91dfead7-959e-4475-ad26-9b0d482be089", "alternativeDescriptions": {"ru-RU": "Виртуальный CTAP2 EdDSA25519 SHA512 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 18, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual2: - data: '{"description": "Virtual RSA PCKS1.5 SHA1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "a8d59924-63b7-49ea-b9de-34a753de1e01", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 15, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual3: - data: '{"description": "Virtual RSA PCKS1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "9debdbfd-14dd-4e8d-877b-4a6e35ddb375", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA256 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual4: - data: '{"description": "Virtual RSA PCKS1.5 SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "59c118ea-188c-4dcf-9881-b8b058abf2f1", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA384 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 13, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual5: - data: '{"description": "Virtual RSA PCKS1.5 SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "1e4fcea1-3681-48d3-9deb-9cbf5d2f79b5", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PCKS1.5 SHA512 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 14, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual6: - data: '{"description": "Virtual RSA PKCS 1.5 SHA1 FIDO2 Conformance Testing CTAP2 Authenticator with TPM Attestation", "aaguid": "f244b67e-5364-4fd5-9f90-c396227317db", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA1 CTAP2 аутентификатор с TPM аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 15, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15882], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' - virtual7: - data: '{"description": "Virtual RSA PKCS 1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator with SafetyNet attestation", "aaguid": "c87cdd97-56c1-49b8-9e24-cb363654f350", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA256 CTAP2 аутентификатор с SafetyNet аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFOTCCBCGgAwIBAgIQzOijZqaG5pqU9/bIQUhq1zANBgkqhkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxCzAJBgNVBAgMAk1ZMRIwEAYDVQQHDAlXYWtlZmllbGQxFjAUBgNVBAoMDUZJRE8gQWxsaWFuY2UxDDAKBgNVBAsMA0NXRzEyMDAGA1UEAwwpRklETyBGYWtlIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTgwHhcNMTcwMjAxMDAwMDAwWhcNMzUwMTMxMjM1OTU5WjBuMQswCQYDVQQGEwJVUzErMCkGA1UECgwiRklETyBBbGxpYW5jZXMgRkFLRSBUcnVzdCBTZXJ2aWNlczEyMDAGA1UEAwwpRklETyBBbGxpYW5jZXMgRkFLRSBJbnRlcm5ldCBBdXRob3JpdHkgRjMwggEiMA0GCSqGSIb3DQEBCwUAA4IBDwAwggEKAgMBAAECggEBALUTcsaOBiR6WeP1KONyPzYa/9VpPLIi50tMYg95bg+pAPZUvav17DhuqQtyQNJIR48gVwJ+GagQ1ZJuqXAi4HzDEC3FD3jD3ZLw3/6BYFzSk4OqneUAtcd1BB+MiZbSahdlGApiMOL5AbGxVA+Q9lK/OF7DNR2/XRJbH2APQOQbakzYl/0sWqmNBYul29TnI4Uo8gIX7ArcsJ7K0QpoTlaGeQbLgbTft+EgFUWTVwGhhrs+IlT/wx32Qg4yVHgSUjb3RMfRt9pqupqLXFTcrQsP23usbPXh8myjGOEMgBqW0N44OprSC25Zg/QO7UHTYWavv4IuqRlk4NOblj6LkoOjggG2MIIBsjALBgNVHQ8EBAMCAYYwSwYDVR0gBEQwQjBABgZngQwBAgIwNjA0BggrBgEFBQcCARYoaHR0cHM6Ly9maWRvYWxsaWFuY2UuY28ubnovc2FmZXR5bmV0cGtpLzAdBgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwEgYDVR0TAQH/BAgwBgEB/wIBADAfBgNVHQ4EGAQWwhThQ9/glRuwcWqdAyRd/ggvPsPIGjAfBgNVHSMEGAQWoBSqNv9BadKdijvYHGXTW95rcC2UkDBqBgNVHR8EYzBhMF+gXaBbhllodHRwczovL2ZpZG9hbGxpYW5jZS5jby5uei9zYWZldHluZXRwa2kvY3JsL0ZJRE8gRmFrZSBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAyMDE4LmNybDB1BggrBgEFBQcBAQRpMGcwZQYIKwYBBQUHMAGGWWh0dHBzOi8vZmlkb2FsbGlhbmNlLmNvLm56L3NhZmV0eW5ldHBraS9GSURPIEZha2UgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgMjAxOC5jcmwuY3J0MA0GCSqGSIb3DQEBCwUAA4IBAQA1auRqossPgWcw/ALzMwkYMWLadKJmq8tJNaeLLQjxvltrS3EG8yoiAnCC/dUIjyTACS6lBspH6TGpNDGmEwt+iBpFT5BGkQniLhOmknEE8XKlJ600Mg9PCJIawjfeJxivIGnkfXkEr8MCi3E9/dL9NmR7FK7nY3zVZtSVjQEhB7g5bpQtp3mq625Edp0jxXYQACz4WW6vXatC3MgdGHWBAltVQTgqvLG2zEdUM54pu46VjiMZo4WXUwEVw5xhbcRPH7lfY4F3P8Ozyqs8tOs8pDmfetIIji72CSUWItl7ELe3kJZHfv6kfAFFDB4J640CYvOPCKGCXo1NYkS6StGZ", "MIIFOTCCBCGgAwIBAgIQHHwrrcKFWcRmaZ61Ug/AGDANBgkqhkiG9w0BAQsFADCBiDELMAkGA1UEBhMCVVMxCzAJBgNVBAgMAk1ZMRIwEAYDVQQHDAlXYWtlZmllbGQxFjAUBgNVBAoMDUZJRE8gQWxsaWFuY2UxDDAKBgNVBAsMA0NXRzEyMDAGA1UEAwwpRklETyBGYWtlIFJvb3QgQ2VydGlmaWNhdGUgQXV0aG9yaXR5IDIwMTgwHhcNMTcwMjAxMDAwMDAwWhcNMzUwMTMxMjM1OTU5WjBuMQswCQYDVQQGEwJVUzErMCkGA1UECgwiRklETyBBbGxpYW5jZXMgRkFLRSBUcnVzdCBTZXJ2aWNlczEyMDAGA1UEAwwpRklETyBBbGxpYW5jZXMgRkFLRSBJbnRlcm5ldCBBdXRob3JpdHkgRjIwggEiMA0GCSqGSIb3DQEBCwUAA4IBDwAwggEKAgMBAAECggEBAMJJRL5h8Eq34mFwDBnq0UUCHCk91lX96oYmZv/evpxLDOeabuBSPuX/0EmJUKzTz8m9rn8LjI+zSwES3vb7VbH5tUORudlwJwKLY6mNxtnysZ0C08zIGBQhJKwjqs6euT/WUnrd+ZZcw+LLZlBjsjRNWu3T0KeG7iHoT9tMAr7/TMyXYfSUo+uYwCWU+boM0Xa/XhsfhRb0TdPV6UKBxw+oHjIN1hYZlpsSh5vkleBMLtr8Smi9QAWN0kAHsv5SUXvra4gDcOlDqoggNHCyep1SC5YyyI19EutVR5WkUL1a8sGSy0NYRirEbwKn33YBONW1QqpZjkkOwvrC0aUXZ6ejggG2MIIBsjALBgNVHQ8EBAMCAYYwSwYDVR0gBEQwQjBABgZngQwBAgIwNjA0BggrBgEFBQcCARYoaHR0cHM6Ly9maWRvYWxsaWFuY2UuY28ubnovc2FmZXR5bmV0cGtpLzAdBgNVHSUEFjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwEgYDVR0TAQH/BAgwBgEB/wIBADAfBgNVHQ4EGAQWwhRvX3OedT+mxCsP6QjBjSVn7XflJDAfBgNVHSMEGAQWoBSqNv9BadKdijvYHGXTW95rcC2UkDBqBgNVHR8EYzBhMF+gXaBbhllodHRwczovL2ZpZG9hbGxpYW5jZS5jby5uei9zYWZldHluZXRwa2kvY3JsL0ZJRE8gRmFrZSBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAyMDE4LmNybDB1BggrBgEFBQcBAQRpMGcwZQYIKwYBBQUHMAGGWWh0dHBzOi8vZmlkb2FsbGlhbmNlLmNvLm56L3NhZmV0eW5ldHBraS9GSURPIEZha2UgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgMjAxOC5jcmwuY3J0MA0GCSqGSIb3DQEBCwUAA4IBAQCTbQRFbIDNnsHl9X3yQ0K2dIXEPdKjWaJDxNUSqX1mV/9gUswGJNtLK92ZbR8flrRemrK80BtWpoaAzHTo5kBIHUvbjJ3KMPdGB+n279xyv9ra9oof1obmcG7HPmUkksWPskcyE+LMyoBwVpmpyi59mjWhtBsy0o6XXq1HOKD2rHs/QTxrosP8sOAS5kyLbhyYuMB3r1YB3zI6bH4utKUwmELWYkYsJKFCNwUiJVAuMBvJMt7Wznl46epCvsr9tb4PKwamm/lkA3qYQhzVGbwzt+OEwfPggJOPPuy4a6DXUXZMYsFT2UCokQs4NL9tFxzWpsRxbv3TKYimfEdIQw0L", "MIID1zCCAr+gAwIBAgIPBHHuTg2or5b9P/YXma/CMA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSkwJwYDVQQDDCBGSURPIEFsbGlhbmNlcyBGQUtFIFJvb3QgQ0EgLSBTMTAeFw0xNzAyMDEwMDAwMDBaFw0zNTAxMzEyMzU5NTlaMFAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSkwJwYDVQQDDCBGSURPIEFsbGlhbmNlcyBGQUtFIFJvb3QgQ0EgLSBTMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALmjPyFJ5QJSz9Fhdi4eF5u70nP1Bgdw/XD/f8JXDor81Q9kzEmJu/hBHWZ8cNJlIqDUBrO4rgMq0987hNuctm0wqMA98f5inD2f2TZ3aqnAvIRvDggKpkxZSPF9Mb6243cYu3ZvERvwpwx+3KMBHaWiGCKZSiebR553UYcVOlfKfmVcLoc4Tg7SyAlkRaHRbe1k/qqhiQ+KiYMo6BLTs9OTXa02FHD9zfHEcniYIeT1CH3dUX5FfzYzXc17zaJ1Kp0ylFzauz67IiRWi4KjB6xHFhkwEX4p1fGQEvNQrF8FQdo3lnRwbag9MiM4xugx9UikgFenDopvwWBwGfvDBHECAwEAAaOBrTCBqjALBgNVHQ8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHQ4EGAQWwhSqNv9BadKdijvYHGXTW95rcC2UkDAfBgNVHSMEGDAWgBSqNv9BadKdijvYHGXTW95rcC2UkDBIBgNVHR8EQTA/MD2gO6A5hjdodHRwczovL2ZpZG9hbGxpYW5jZS5jby5uei9zYWZldHluZXRwa2kvY3JsL3Jvb3QtczEuY3JsMA0GCSqGSIb3DQEBCwUAA4IBAQAtT1x/AGZrSL+N42YTcMGzrQX+0gytCvbwdjUtarjtFMCl6U3ZnS2It/DBpwf1V3uIGZAvfUHflOcz/Mn+SiBWCj887y5W852Dxq3MFpuhWSMsFzeHElwaDhivUlrhK/+zyfUM2ze5fjsBmaF2Z2CstjnGTZtjvTW8mh3uYu3S39W6Dc1cS1Xvbcn6NwSdFp2zvtwEUUy5Bt2aMS+wLVSVxryqj6hwpcZsg5euUM8qL+MNBVX/p3vlN0VSqviRRauPlbb7QgKG4k/GYPVDjfG026LQ77MeVL7LBWtw/QOIbEe6i5xGGXFkvy/BFyeJg2VeZUb4TsCsfyAhvLnQKDS6", "MIID1TCCAr2gAwIBAgIPBIQMnDY4Zs+TwM1SW60PMA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSkwJwYDVQQDDCBGSURPIEFsbGlhbmNlcyBGQUtFIFJvb3QgQ0EgLSBTMTAeFw0xNzAyMDEwMDAwMDBaFw0zNTAxMzEyMzU5NTlaMFAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSkwJwYDVQQDDCBGSURPIEFsbGlhbmNlcyBGQUtFIFJvb3QgQ0EgLSBTMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALmjPyFJ5QJSz9Fhdi4eF5u70nP1Bgdw/XD/f8JXDor81Q9kzEmJu/hBHWZ8cNJlIqDUBrO4rgMq0987hNuctm0wqMA98f5inD2f2TZ3aqnAvIRvDggKpkxZSPF9Mb6243cYu3ZvERvwpwx+3KMBHaWiGCKZSiebR553UYcVOlfKfmVcLoc4Tg7SyAlkRaHRbe1k/qqhiQ+KiYMo6BLTs9OTXa02FHD9zfHEcniYIeT1CH3dUX5FfzYzXc17zaJ1Kp0ylFzauz67IiRWi4KjB6xHFhkwEX4p1fGQEvNQrF8FQdo3lnRwbag9MiM4xugx9UikgFenDopvwWBwGfvDBHECAwEAAaOBqzCBqDALBgNVHQ8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUXFuQuA5+geet451Npwk6k2KbnygwHwYDVR0jBBgwFoAUXFuQuA5+geet451Npwk6k2KbnygwSAYDVR0fBEEwPzA9oDugOYY3aHR0cHM6Ly9maWRvYWxsaWFuY2UuY28ubnovc2FmZXR5bmV0cGtpL2NybC9yb290LXMxLmNybDANBgkqhkiG9w0BAQsFAAOCAQEAFyYRP7B+LED306YB578ccZA03jw1GKq79xqsZXeuoBMARaj6/jzgjjGrsVz3RtOM/zw4TXjDGnjaJddVfEHqfOPp9eNsNoFdqCL3Z0q1eaSerekC0U5wkxmfIWgCI3lfdSpjgljRSFToVNthsu4HmEMEFwoiLkLv4S7p1Azn+MNlu9Wk4RhtToWoAdj7AFXSr7cvNyY4xIAwQ5Fv7i1qTmaOhlfTtjt9+kTon5my5W+uXZ6P0IiSvUJVYWqC8Ld5fTsF6ofUQGRRccJ03pGbKaMd682y1G/dDMVVC/8HTZSoOoCl3fgk5ue2hpEhdkaWxWyrDG2U/q/2Gpxl4ylzHQ=="], "icon": ""}' - virtual8: - data: '{"description": "Virtual RSA PKCS 1.5 SHA256 FIDO2 Conformance Testing CTAP2 Authenticator with TPM Attestation", "aaguid": "a7d6d93a-8a0d-11e8-9a94-a6cf71072f73", "alternativeDescriptions": {"ru-RU": "Виртуальный RSA PKCS 1.5 SHA256 CTAP2 аутентификатор с TPM аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 12, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15882], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' - virtual9: - data: '{"description": "Virtual RSAPSS SHA256 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "a96c4970-7d5f-4d6a-81f7-7632b7ae0240", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA256 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 3, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual10: - data: '{"description": "Virtual RSAPSS SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "06ecba69-665c-4299-bd7f-43546324d1cd", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA384 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 10, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual11: - data: '{"description": "Virtual RSAPSS SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "5fb69bde-6076-4c75-a2af-75102cabe2de", "alternativeDescriptions": {"ru-RU": "Виртуальный RSAPSS SHA512 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 11, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual12: - data: '{"description": "Virtual Secp256K1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "79d699df-0191-4b10-b903-5467e7ce8231", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256K1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 5, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual13: - data: '{"description": "Virtual Secp256K1 FIDO2 Conformance Testing U2F Authenticator", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256K1 U2F аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "attestationCertificateKeyIdentifiers": ["564df7c0f8c655b6a11f6c4d19f3bf41e2fd0179"], "protocolFamily": "u2f", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "U2FV1BIN", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 256, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 26, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": true, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual14: - data: '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "326adcf0-0cef-46d0-9392-98d6c4a84a72", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual15: - data: '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with Android Key Attestation", "aaguid": "550e4b54-aa47-409f-9a95-1ab76c130131", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор с Android Key аттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIDFTCCArygAwIBAgIJAPYG0nMp5fspMAoGCCqGSM49BAMCMIHcMT0wOwYDVQQDDDRGQUtFIEFuZHJvaWQgS2V5c3RvcmUgU29mdHdhcmUgQXR0ZXN0YXRpb24gUm9vdCBGQUtFMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMSIwIAYDVQQLDBlBdXRoZW50aWNhdG9yIEF0dGVzdGF0aW9uMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDAgFw0xOTA0MjUwNTQ5MzJaGA8yMDc0MDEyNjA1NDkzMlowgdwxPTA7BgNVBAMMNEZBS0UgQW5kcm9pZCBLZXlzdG9yZSBTb2Z0d2FyZSBBdHRlc3RhdGlvbiBSb290IEZBS0UxMTAvBgkqhkiG9w0BCQEWImNvbmZvcm1hbmNlLXRvb2xzQGZpZG9hbGxpYW5jZS5vcmcxFjAUBgNVBAoMDUZJRE8gQWxsaWFuY2UxIjAgBgNVBAsMGUF1dGhlbnRpY2F0b3IgQXR0ZXN0YXRpb24xCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEaH+BmKuo1XRtjS3UJVLrjh0bNl/lLhU7VX89N8+kuI8rnZCfXVD5k3qpOFSY6oTtrcZ1aQRSyR4sZ8EC6Hoi7aNjMGEwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAoQwHQYDVR0OBBYEFFKaGzLgVqrNUQ/vX4A3BovykSMdMB8GA1UdIwQYMBaAFFKaGzLgVqrNUQ/vX4A3BovykSMdMAoGCCqGSM49BAMCA0cAMEQCIAfWMAOOjxO6noErB+wtRBmrDruNIApw70G7kBhliXLkAiBM8sYUVClPsJkCUHI5Wix3ybY31L5J51VS+f1gACNn+Q=="], "icon": ""}' - virtual16: - data: '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with Self(surrogate) attestation", "aaguid": "2b2ecbb4-59b4-44fa-868d-a072485d8ae0", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор с самоаттестацией для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": [], "icon": ""}' - virtual17: - data: '{"description": "Virtual Secp256R1 FIDO2 Conformance Testing CTAP2 Authenticator with supported extensions", "aaguid": "69700f79-d1fb-472e-bd9b-a3a3b9a9eda0", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2 с дополнениями"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 3, "tcDisplayContentType": "image/png", "tcDisplayPNGCharacteristics": [{"bitDepth": 16, "colorType": 2, "compression": 0, "filter": 0, "height": 240, "interlace": 0, "width": 320}], "supportedExtensions": [{"id": "example.extension", "fail_if_unknown": false}, {"id": "txAuthGeneric", "fail_if_unknown": false}, {"id": "txAuthSimple", "fail_if_unknown": false}], "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual18: - data: '{"description": "Virtual Secp256R1 Multiple Root Certificates FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "80f53d1e-852e-43ed-bb3f-d02f1322e5af", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp256R1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2 содержащий множество корневых сертификатов"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 1, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["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"], "icon": ""}' - virtual19: - data: '{"description": "Virtual Secp384r1 SHA384 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "0c71d839-41d7-43ed-928f-381023196e35", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp384r1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 16, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' - virtual20: - data: '{"description": "Virtual Secp521r1 SHA512 FIDO2 Conformance Testing CTAP2 Authenticator", "aaguid": "2388ab8d-8915-4146-93ba-d43e671d2538", "alternativeDescriptions": {"ru-RU": "Виртуальный Secp521r1 CTAP2 аутентификатор для тестирование серверов на соответсвие спецификации FIDO2"}, "protocolFamily": "fido2", "authenticatorVersion": 2, "upv": [{"major": 1, "minor": 0}], "assertionScheme": "FIDOV2", "authenticationAlgorithm": 17, "publicKeyAlgAndEncoding": 260, "attestationTypes": [15879, 15880], "userVerificationDetails": [[{"userVerification": 1}]], "keyProtection": 10, "matcherProtection": 4, "cryptoStrength": 128, "operatingEnv": "Secure Element (SE)", "attachmentHint": 2, "isSecondFactorOnly": false, "tcDisplay": 0, "attestationRootCertificates": ["MIIFwDCCA6gCCQCNm1u56oRwXTANBgkqhkiG9w0BAQsFADCBoTEYMBYGA1UEAwwPRklETzIgVEVTVCBST09UMTEwLwYJKoZIhvcNAQkBFiJjb25mb3JtYW5jZS10b29sc0BmaWRvYWxsaWFuY2Uub3JnMRYwFAYDVQQKDA1GSURPIEFsbGlhbmNlMQwwCgYDVQQLDANDV0cxCzAJBgNVBAYTAlVTMQswCQYDVQQIDAJNWTESMBAGA1UEBwwJV2FrZWZpZWxkMB4XDTE4MDMxNjE0MzUyN1oXDTQ1MDgwMTE0MzUyN1owgaExGDAWBgNVBAMMD0ZJRE8yIFRFU1QgUk9PVDExMC8GCSqGSIb3DQEJARYiY29uZm9ybWFuY2UtdG9vbHNAZmlkb2FsbGlhbmNlLm9yZzEWMBQGA1UECgwNRklETyBBbGxpYW5jZTEMMAoGA1UECwwDQ1dHMQswCQYDVQQGEwJVUzELMAkGA1UECAwCTVkxEjAQBgNVBAcMCVdha2VmaWVsZDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL11U5yAIVLMrL3xS8u8ysMSdOkDeoTO+RcAy+uXXp6k4SC+jOy37gICEtYI+MKQV1EMeMMf3rM1ueZAO3iPFa0NEdi/oQ7npnGjBNI8wMzD8FfNe6rWtzkDaHpsZW///MwWDpGyJR+Xyjcq6U4vS9bS6zZ7jslw0Oczx4UsYgOsIUXSSBaGOrRbxJ/JC5gnDYEYvtNM+PDPczLNKAyhdvBZWNWHr7MZ0P5TeJQcXsAoShRX2Y8U8fRNJm7SeiFKDP0Nn/QKxOSt7zGP4xt9nMasE1q2ZTdar2+W13CRz37RI0ZWpq/+YquoEbZ7Uj7NmBTcqhb260nmDER2FpwwYwPSark92IZbamozB8d7OEI1jJgsrjJhKan0EmRaWVBpHT4xYKdEu7r09S0JhKyU+52WDmmVQTMpYLrm4Xl7hRxyPyBYkalrozsGmPs8vlhNq3VsVbyBSMSpEmUaeAa7LLE9/Vh0agJLVFHh1ehYKJpzHnmmBXUqx0Fz3afmDm1NX0sr3O/6xIx1VSTViT3KNxBYpVH1qjHATLzuxcWmm+75fcJMiPYPSMXVmRb3Q1l91AM4BBeWhlP3Fbc7gDy0r+s7m0sGS6PT2J2rGog2rUxnJ+zCM11M7DeO0XM2nny4uRYPPk9w2EXzfvtdvieYU/5RB4RDm5TGxHhGXVZUgac5AgMBAAEwDQYJKoZIhvcNAQELBQADggIBAFt2XGd3k5GpbO1EUm3u60zT1fE6u6pOscp156k5VnsHgaHRHdIAPNLeLNmR7y5OnrXbh13CrGwU1q84jjJXpv+v14xUCc5i01yopFTQFLr4A7NHp2nNYfNhhIVSFAgW43EflJflbLEelCJzxLlWb5BoDsZeeNmEQsXIM1mJ26R3r0dzsHBb0uy+8LNR1gdVqdjhC8BLy3gh4+BWuidyZNt07LveDsSFW5rcj5wRrSx9hXPIyVpjQSljNvY7MVTouqJzNAAQMsTKkXPkTXldCop9Qo9UPkHRRm0l7LLtdaOoXrct0Ymocf8zxf9bFNiw9f4WRYQM6sMhzt8+s/oDilo4QhcUgeJEiEPESi6ynYTV62SHA4eMunUJ5dlCaRnFiR9DTImFa5IRzie326/nW/SPCaKc/yrFIihMMjJoSAPhpTb/K6yHOUG8r+KiQut7NzqGV301pQ9u62dGL5Oi1VXmCFlE2ramZs15BNOUyAo2CBbRJg3jKcdu/8QC6ojjDvQ863+7LPtn74wJC5RpUJsS0GhQWgq5pAXO3wA61Uobxi6MkOpCC0zBWx/d4CqpS4j4hFgxWBTXX48ihPu+hIxIF/AxbqtPvqLMExW/xZITn6ArpWyQ9e4SUVr3n3F33ap1XdDyZ0vwFcm18JQAtsvXT6qCLrWOXnHUgfn/+Viu"], "icon": ""}' + repository: 'Webauthn\Bundle\Tests\Functional\MetadataStatementRepository' security: providers: diff --git a/src/symfony/tests/config/routing.php b/src/symfony/tests/config/routing.php index fcdeb7aa8..2dbc953d2 100644 --- a/src/symfony/tests/config/routing.php +++ b/src/symfony/tests/config/routing.php @@ -16,7 +16,7 @@ use Webauthn\Bundle\Tests\Functional\HomeController; use Webauthn\Bundle\Tests\Functional\SecurityController; -return function (RoutingConfigurator $routes) { +return static function (RoutingConfigurator $routes): void { $routes->import('.', 'webauthn'); // Security diff --git a/src/symfony/tests/functional/MetadataService/MetadataServiceTest.php b/src/symfony/tests/functional/MetadataService/MetadataServiceTest.php index 783025b0c..48ed7a18a 100644 --- a/src/symfony/tests/functional/MetadataService/MetadataServiceTest.php +++ b/src/symfony/tests/functional/MetadataService/MetadataServiceTest.php @@ -41,8 +41,11 @@ public function theMetadataTOCPayloadCanBeRetrieved(): void $client = self::$container->get('httplug.client.mock'); $this->prepareResponsesMap($client); - /** @var MetadataService $service */ - $service = self::$container->get('webauthn.metadata_service.service.fido_alliance'); + $service = new MetadataService( + 'https://foo.com', + $client, + new Psr17Factory() + ); $data = $service->getMetadataTOCPayload(); $entries = $data->getEntries(); static::assertCount(42, $entries); @@ -114,7 +117,7 @@ public function aMetadataStatementCanBeFoundByTheRepository(): void private function callObjectMethods($object): void { $availableMethods = get_class_methods($object); - $availableMethods = array_filter($availableMethods, static function ($method) use ($object) { + $availableMethods = array_filter($availableMethods, static function ($method) use ($object): bool { $classMethod = new ReflectionMethod($object, $method); return !\in_array($method, ['createFromArray', 'create', '__construct', 'jsonSerialize'], true) && 0 === \count($classMethod->getParameters()); diff --git a/src/symfony/tests/functional/MetadataStatementRepository.php b/src/symfony/tests/functional/MetadataStatementRepository.php new file mode 100644 index 000000000..b9177ae4a --- /dev/null +++ b/src/symfony/tests/functional/MetadataStatementRepository.php @@ -0,0 +1,120 @@ +httpClient = $httpClient; + $this->requestFactory = $requestFactory; + } + + public function addSingleStatement(string $data, bool $isBare64Encoded = false): void + { + $this->metadataStatements[] = new SingleMetadata($data, $isBare64Encoded); + } + + public function addDistantSingleStatement(string $uri, bool $isBare64Encoded = false, array $additionalHeaders = []): void + { + $this->metadataStatements[] = new DistantSingleMetadata($uri, $isBare64Encoded, $this->httpClient, $this->requestFactory, $additionalHeaders); + } + + public function addService(string $url, array $additionalQueryStringParameters = [], array $additionalHeaders = []): void + { + $this->metadataServices[] = new MetadataService($url, $this->httpClient, $this->requestFactory, $additionalQueryStringParameters, $additionalHeaders); + } + + public function addStatusReport(string $aaguid, StatusReport $statusReport): void + { + if (!isset($this->statusReports[$aaguid])) { + $this->statusReports[$aaguid] = []; + } + $this->statusReports[$aaguid][] = $statusReport; + } + + public function findOneByAAGUID(string $aaguid): ?MetadataStatement + { + foreach ($this->metadataStatements as $metadataStatement) { + try { + $mds = $metadataStatement->getMetadataStatement(); + if ($mds->getAaguid() === $aaguid) { + return $mds; + } + } catch (\Throwable $throwable) { + continue; + } + } + foreach ($this->metadataServices as $metadataService) { + try { + $toc = $metadataService->getMetadataTOCPayload(); + foreach ($toc->getEntries() as $entry) { + if ($entry->getAaguid() === $aaguid) { + try { + return $metadataService->getMetadataStatementFor($entry); + } catch (\Throwable $throwable) { + continue; + } + } + } + } catch (\Throwable $throwable) { + continue; + } + } + + return null; + } + + /** + * {@inheritdoc} + */ + public function findStatusReportsByAAGUID(string $aaguid): array + { + return $this->statusReports[$aaguid] ?? []; + } +} diff --git a/src/webauthn/src/AttestationStatement/AndroidKeyAttestationStatementSupport.php b/src/webauthn/src/AttestationStatement/AndroidKeyAttestationStatementSupport.php index a66dc44f5..c736ed0ea 100644 --- a/src/webauthn/src/AttestationStatement/AndroidKeyAttestationStatementSupport.php +++ b/src/webauthn/src/AttestationStatement/AndroidKeyAttestationStatementSupport.php @@ -104,6 +104,7 @@ private function checkCertificateAndGetPublicKey(string $certificate, string $cl $certDetails = openssl_x509_parse($certificate); //Find Android KeyStore Extension with OID “1.3.6.1.4.1.11129.2.1.17” in certificate extensions + Assertion::isArray($certDetails, 'The certificate is not valid'); Assertion::keyExists($certDetails, 'extensions', 'The certificate has no extension'); Assertion::isArray($certDetails['extensions'], 'The certificate has no extension'); Assertion::keyExists($certDetails['extensions'], '1.3.6.1.4.1.11129.2.1.17', 'The certificate extension "1.3.6.1.4.1.11129.2.1.17" is missing'); diff --git a/src/webauthn/src/AttestationStatement/AttestationObjectLoader.php b/src/webauthn/src/AttestationStatement/AttestationObjectLoader.php index 0dbf8e7dc..359ec993d 100644 --- a/src/webauthn/src/AttestationStatement/AttestationObjectLoader.php +++ b/src/webauthn/src/AttestationStatement/AttestationObjectLoader.php @@ -26,7 +26,7 @@ use Webauthn\AuthenticationExtensions\AuthenticationExtensionsClientOutputsLoader; use Webauthn\AuthenticatorData; use Webauthn\MetadataService\MetadataStatement; -use Webauthn\MetadataService\MetadataStatementStatusReportRepository; +use Webauthn\MetadataService\MetadataStatementRepository; use Webauthn\StringStream; class AttestationObjectLoader @@ -45,11 +45,11 @@ class AttestationObjectLoader private $attestationStatementSupportManager; /** - * @var MetadataStatementStatusReportRepository + * @var MetadataStatementRepository|null */ private $metadataStatementRepository; - public function __construct(AttestationStatementSupportManager $attestationStatementSupportManager, MetadataStatementStatusReportRepository $metadataStatementRepository) + public function __construct(AttestationStatementSupportManager $attestationStatementSupportManager, ?MetadataStatementRepository $metadataStatementRepository = null) { $this->decoder = new Decoder(new TagObjectManager(), new OtherObjectManager()); $this->attestationStatementSupportManager = $attestationStatementSupportManager; @@ -99,32 +99,40 @@ public function load(string $data): AttestationObject $authDataStream->close(); $authenticatorData = new AuthenticatorData($authData, $rp_id_hash, $flags, $signCount, $attestedCredentialData, $extension); - $metadataStatement = $this->getMetadataStatement($attestedCredentialData); + $metadataStatement = $this->getMetadataStatement($attestationStatement, $attestedCredentialData); return new AttestationObject($data, $attestationStatement, $authenticatorData, $metadataStatement); } - private function getMetadataStatement(?AttestedCredentialData $attestedCredentialData): ?MetadataStatement + private function getMetadataStatement(AttestationStatement $attestationStatement, ?AttestedCredentialData $attestedCredentialData): ?MetadataStatement { + // If no attested credential data is present, no MDS can be found if (null === $attestedCredentialData) { return null; } + + // If the AAGUID is a zero-based UUID, no MDS can be found $aaguid = $attestedCredentialData->getAaguid()->toString(); - $metadataStatement = null; - if (null !== $this->metadataStatementRepository) { - $metadataStatement = $this->metadataStatementRepository->findOneByAAGUID($aaguid); - $this->checkStatusReport($aaguid); + if ('00000000-0000-0000-0000-000000000000' === $aaguid) { + return null; } - $this->checkMetadataExist($aaguid, $metadataStatement); - return $metadataStatement; - } + // If the attestation statement type is "none", no MDS is required + if (AttestationStatement::TYPE_NONE === $attestationStatement->getType()) { + return null; + } - private function checkMetadataExist(string $aaguid, ?MetadataStatement $metadataStatement): void - { - if ('00000000-0000-0000-0000-000000000000' !== $aaguid && null === $metadataStatement) { + if (null === $this->metadataStatementRepository) { + throw new RuntimeException(sprintf('Unable to find the Metadata Statement for the AAGUID "%s"', $aaguid)); + } + + $metadataStatement = $this->metadataStatementRepository->findOneByAAGUID($aaguid); + if (null === $metadataStatement) { throw new RuntimeException(sprintf('Unable to find the Metadata Statement for the AAGUID "%s"', $aaguid)); } + $this->checkStatusReport($aaguid); + + return $metadataStatement; } private function checkStatusReport(string $aaguid): void diff --git a/src/webauthn/src/AttestationStatement/FidoU2FAttestationStatementSupport.php b/src/webauthn/src/AttestationStatement/FidoU2FAttestationStatementSupport.php index 3f4d66120..2095daf25 100644 --- a/src/webauthn/src/AttestationStatement/FidoU2FAttestationStatementSupport.php +++ b/src/webauthn/src/AttestationStatement/FidoU2FAttestationStatementSupport.php @@ -104,6 +104,7 @@ private function checkCertificate(string $publicKey): void throw new InvalidArgumentException('Invalid certificate or certificate chain', 0, $throwable); } $details = openssl_pkey_get_details($resource); + Assertion::isArray($details, 'Invalid certificate or certificate chain'); Assertion::keyExists($details, 'ec', 'Invalid certificate or certificate chain'); Assertion::keyExists($details['ec'], 'curve_name', 'Invalid certificate or certificate chain'); Assertion::eq($details['ec']['curve_name'], 'prime256v1', 'Invalid certificate or certificate chain'); diff --git a/src/webauthn/src/Server.php b/src/webauthn/src/Server.php index ba5f44794..155a98986 100644 --- a/src/webauthn/src/Server.php +++ b/src/webauthn/src/Server.php @@ -195,7 +195,7 @@ public function generatePublicKeyCredentialRequestOptions(?string $userVerificat public function loadAndCheckAttestationResponse(string $data, PublicKeyCredentialCreationOptions $publicKeyCredentialCreationOptions, ServerRequestInterface $serverRequest): PublicKeyCredentialSource { $attestationStatementSupportManager = $this->getAttestationStatementSupportManager(); - $attestationObjectLoader = new AttestationObjectLoader($attestationStatementSupportManager, null, $this->metadataStatementRepository); + $attestationObjectLoader = new AttestationObjectLoader($attestationStatementSupportManager, $this->metadataStatementRepository); $publicKeyCredentialLoader = new PublicKeyCredentialLoader($attestationObjectLoader); $publicKeyCredential = $publicKeyCredentialLoader->load($data); @@ -224,7 +224,6 @@ public function loadAndCheckAssertionResponse(string $data, PublicKeyCredentialR $authenticatorAssertionResponseValidator = new AuthenticatorAssertionResponseValidator( $this->publicKeyCredentialSourceRepository, - null, $this->tokenBindingHandler, $this->extensionOutputCheckerHandler, $this->coseAlgorithmManagerFactory->create($this->selectedAlgorithms) @@ -256,7 +255,7 @@ private function getAttestationStatementSupportManager(): AttestationStatementSu $attestationStatementSupportManager->add(new AndroidSafetyNetAttestationStatementSupport($this->httpClient, $this->googleApiKey, $this->requestFactory, 2000, 60000)); $attestationStatementSupportManager->add(new AndroidKeyAttestationStatementSupport()); $attestationStatementSupportManager->add(new TPMAttestationStatementSupport()); - $attestationStatementSupportManager->add(new PackedAttestationStatementSupport(null, $coseAlgorithmManager)); + $attestationStatementSupportManager->add(new PackedAttestationStatementSupport($coseAlgorithmManager)); } return $attestationStatementSupportManager; diff --git a/src/webauthn/tests/functional/AbstractTestCase.php b/src/webauthn/tests/functional/AbstractTestCase.php index 61113765e..8cc869f8a 100644 --- a/src/webauthn/tests/functional/AbstractTestCase.php +++ b/src/webauthn/tests/functional/AbstractTestCase.php @@ -30,7 +30,6 @@ use Psr\Http\Message\RequestInterface; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\StreamInterface; -use Symfony\Component\Cache\Adapter\FilesystemAdapter; use Webauthn\AttestationStatement\AndroidKeyAttestationStatementSupport; use Webauthn\AttestationStatement\AndroidSafetyNetAttestationStatementSupport; use Webauthn\AttestationStatement\AttestationObjectLoader; @@ -44,7 +43,7 @@ use Webauthn\AuthenticatorAttestationResponseValidator; use Webauthn\MetadataService\DistantSingleMetadata; use Webauthn\MetadataService\MetadataService; -use Webauthn\MetadataService\SimpleMetadataStatementRepository; +use Webauthn\MetadataService\MetadataStatementRepository as MetadataStatementRepositoryInterface; use Webauthn\MetadataService\SingleMetadata; use Webauthn\PublicKeyCredentialLoader; use Webauthn\PublicKeyCredentialSourceRepository; @@ -164,7 +163,7 @@ private function getAttestationObjectLoader(): AttestationObjectLoader if (!$this->attestationObjectLoader) { $this->attestationObjectLoader = new AttestationObjectLoader( $this->getAttestationStatementSupportManager(), - $this->getSimpleMetadataStatementRepository() + $this->getMetadataStatementRepository() ); } @@ -172,40 +171,37 @@ private function getAttestationObjectLoader(): AttestationObjectLoader } /** - * @var SimpleMetadataStatementRepository|null + * @var MetadataStatementRepositoryInterface|null */ - private $simpleMetadataStatementRepository; + private $metadataStatementRepository; - private function getSimpleMetadataStatementRepository(): SimpleMetadataStatementRepository + private function getMetadataStatementRepository(): MetadataStatementRepositoryInterface { - if (!$this->simpleMetadataStatementRepository) { - $this->simpleMetadataStatementRepository = new SimpleMetadataStatementRepository( - new FilesystemAdapter('webauthn') - ); + if (!$this->metadataStatementRepository) { + $this->metadataStatementRepository = new MetadataStatementRepository(); foreach ($this->getSingleStatements() as $name => $statement) { - $this->simpleMetadataStatementRepository->addSingleStatement($name, new SingleMetadata( - $statement, - false - )); + $this->metadataStatementRepository->addSingleStatement( + new SingleMetadata($statement, false) + ); } $client = new Client(); $this->prepareResponsesMap($client); - $this->simpleMetadataStatementRepository->addSingleStatement('solo', new DistantSingleMetadata( + $this->metadataStatementRepository->addSingleStatement(new DistantSingleMetadata( 'https://bar.foo/solokeys/solo/2.1.0/metadata/Solo-FIDO2-CTAP2-Authenticator.json', false, $client, new Psr17Factory() )); - $this->simpleMetadataStatementRepository->addService('fido-alliance', new MetadataService( + $this->metadataStatementRepository->addService(new MetadataService( 'https://foo.bar', $client, new Psr17Factory() )); } - return $this->simpleMetadataStatementRepository; + return $this->metadataStatementRepository; } private function getSingleStatements(): array diff --git a/src/webauthn/tests/functional/AndroidSafetyNetAttestationStatementTest.php b/src/webauthn/tests/functional/AndroidSafetyNetAttestationStatementTest.php index 3cbb29138..0a6e79b6b 100644 --- a/src/webauthn/tests/functional/AndroidSafetyNetAttestationStatementTest.php +++ b/src/webauthn/tests/functional/AndroidSafetyNetAttestationStatementTest.php @@ -15,10 +15,10 @@ use Cose\Algorithms; use Http\Mock\Client; -use InvalidArgumentException; use Nyholm\Psr7\Response; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Message\UriInterface; +use RuntimeException; use Webauthn\AuthenticationExtensions\AuthenticationExtensionsClientInputs; use Webauthn\AuthenticatorAttestationResponse; use Webauthn\AuthenticatorSelectionCriteria; @@ -39,7 +39,7 @@ class AndroidSafetyNetAttestationStatementTest extends AbstractTestCase */ public function anAndroidSafetyNetAttestationCanBeVerified(): void { - $this->expectException(InvalidArgumentException::class); + $this->expectException(RuntimeException::class); $this->expectExceptionMessage('The certificate expired'); $publicKeyCredentialCreationOptions = new PublicKeyCredentialCreationOptions( new PublicKeyCredentialRpEntity('My Application'), diff --git a/src/webauthn/tests/functional/AssertionTest.php b/src/webauthn/tests/functional/AssertionTest.php index 297452f6f..a83f177ee 100644 --- a/src/webauthn/tests/functional/AssertionTest.php +++ b/src/webauthn/tests/functional/AssertionTest.php @@ -58,7 +58,7 @@ public function anAssertionCanBeVerified(): void $publicKeyCredentialSource = $this->prophesize(PublicKeyCredentialSource::class); $publicKeyCredentialSource->getUserHandle()->willReturn('foo'); $publicKeyCredentialSource->getCounter()->willReturn(100); - $publicKeyCredentialSource->setCounter(Argument::is(123))->will(function () {}); + $publicKeyCredentialSource->setCounter(Argument::is(123))->will(function (): void {}); $publicKeyCredentialSource->getAttestedCredentialData()->willReturn(new AttestedCredentialData( Uuid::fromString('00000000-0000-0000-0000-000000000000'), base64_decode('eHouz/Zi7+BmByHjJ/tx9h4a1WZsK4IzUmgGjkhyOodPGAyUqUp/B9yUkflXY3yHWsNtsrgCXQ3HjAIFUeZB+w==', true), @@ -67,7 +67,7 @@ public function anAssertionCanBeVerified(): void $credentialRepository = $this->prophesize(PublicKeyCredentialSourceRepository::class); $credentialRepository->findOneByCredentialId(base64_decode('eHouz/Zi7+BmByHjJ/tx9h4a1WZsK4IzUmgGjkhyOodPGAyUqUp/B9yUkflXY3yHWsNtsrgCXQ3HjAIFUeZB+w==', true))->willReturn($publicKeyCredentialSource->reveal()); - $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function () {}); + $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function (): void {}); $request = $this->prophesize(ServerRequestInterface::class); @@ -106,7 +106,7 @@ public function anAssertionWithTokenBindingCanBeVerified(): void $publicKeyCredentialSource = $this->prophesize(PublicKeyCredentialSource::class); $publicKeyCredentialSource->getUserHandle()->willReturn('foo'); $publicKeyCredentialSource->getCounter()->willReturn(100); - $publicKeyCredentialSource->setCounter(Argument::is(148))->will(function () {}); + $publicKeyCredentialSource->setCounter(Argument::is(148))->will(function (): void {}); $publicKeyCredentialSource->getAttestedCredentialData()->willReturn(new AttestedCredentialData( Uuid::fromBytes(base64_decode('+KAR84wKTRWABhcRH57cfQ==', true)), base64_decode('+uZVS9+4JgjAYI49YhdzTgHmbn638+ZNSvC0UtHkWTVS+CtTjnaSbqtzdzijByOAvEAsh+TaQJAr43FRj+dYag==', true), @@ -115,7 +115,7 @@ public function anAssertionWithTokenBindingCanBeVerified(): void $credentialRepository = $this->prophesize(PublicKeyCredentialSourceRepository::class); $credentialRepository->findOneByCredentialId(base64_decode('+uZVS9+4JgjAYI49YhdzTgHmbn638+ZNSvC0UtHkWTVS+CtTjnaSbqtzdzijByOAvEAsh+TaQJAr43FRj+dYag==', true))->willReturn($publicKeyCredentialSource->reveal()); - $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function () {}); + $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function (): void {}); $uri = $this->prophesize(UriInterface::class); $uri->getHost()->willReturn('localhost'); @@ -157,7 +157,7 @@ public function anAssertionWithUserHandleCanBeVerified(): void $publicKeyCredentialSource = $this->prophesize(PublicKeyCredentialSource::class); $publicKeyCredentialSource->getUserHandle()->willReturn('abfc8fdf-07f6-45a9-abec-fa192275b276'); $publicKeyCredentialSource->getCounter()->willReturn(100); - $publicKeyCredentialSource->setCounter(Argument::is(1548765641))->will(function () {}); + $publicKeyCredentialSource->setCounter(Argument::is(1548765641))->will(function (): void {}); $publicKeyCredentialSource->getAttestedCredentialData()->willReturn(new AttestedCredentialData( Uuid::fromString('00000000-0000-0000-0000-000000000000'), base64_decode('ADqYfFWXiscOCOPCd9OLiBtSGhletNPKlSOELS0Nuwj/uCzf9s3trLUK9ockO8xa8jBAYdKixLZYOAezy0FJiV1bnTCty/LiInWWJlov', true), @@ -166,7 +166,7 @@ public function anAssertionWithUserHandleCanBeVerified(): void $credentialRepository = $this->prophesize(PublicKeyCredentialSourceRepository::class); $credentialRepository->findOneByCredentialId(base64_decode('ADqYfFWXiscOCOPCd9OLiBtSGhletNPKlSOELS0Nuwj/uCzf9s3trLUK9ockO8xa8jBAYdKixLZYOAezy0FJiV1bnTCty/LiInWWJlov', true))->willReturn($publicKeyCredentialSource->reveal()); - $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function () {}); + $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function (): void {}); $uri = $this->prophesize(UriInterface::class); $uri->getHost()->willReturn('spomky-webauthn.herokuapp.com'); diff --git a/src/webauthn/tests/functional/MetadataStatementRepository.php b/src/webauthn/tests/functional/MetadataStatementRepository.php new file mode 100644 index 000000000..9763816ff --- /dev/null +++ b/src/webauthn/tests/functional/MetadataStatementRepository.php @@ -0,0 +1,83 @@ +metadataStatements[] = $metadataStatement; + } + + public function addService(MetadataService $metadataService): void + { + $this->metadataServices[] = $metadataService; + } + + public function addStatusReport(string $aaguid, StatusReport $statusReport): void + { + if (!isset($this->statusReports[$aaguid])) { + $this->statusReports[$aaguid] = []; + } + $this->statusReports[$aaguid][] = $statusReport; + } + + public function findOneByAAGUID(string $aaguid): ?MetadataStatement + { + foreach ($this->metadataStatements as $metadataStatement) { + if ($metadataStatement->getMetadataStatement()->getAaguid() === $aaguid) { + return $metadataStatement->getMetadataStatement(); + } + } + foreach ($this->metadataServices as $metadataService) { + $toc = $metadataService->getMetadataTOCPayload(); + foreach ($toc->getEntries() as $entry) { + if ($entry->getAaguid() === $aaguid) { + return $metadataService->getMetadataStatementFor($entry); + } + } + } + + return null; + } + + /** + * {@inheritdoc} + */ + public function findStatusReportsByAAGUID(string $aaguid): array + { + return $this->statusReports[$aaguid] ?? []; + } +} diff --git a/src/webauthn/tests/functional/W10Test.php b/src/webauthn/tests/functional/W10Test.php index bae189841..c02a61937 100644 --- a/src/webauthn/tests/functional/W10Test.php +++ b/src/webauthn/tests/functional/W10Test.php @@ -89,7 +89,7 @@ public function anAssertionCanBeVerified(): void $publicKeyCredentialSource = $this->prophesize(PublicKeyCredentialSource::class); $publicKeyCredentialSource->getUserHandle()->willReturn('ee13d4f1-4863-47dd-a407-097cb49ac822'); $publicKeyCredentialSource->getCounter()->willReturn(0); - $publicKeyCredentialSource->setCounter(Argument::is(4))->will(function () {}); + $publicKeyCredentialSource->setCounter(Argument::is(4))->will(function (): void {}); $publicKeyCredentialSource->getAttestedCredentialData()->willReturn(new AttestedCredentialData( Uuid::fromBytes(base64_decode('YCiwF7HUTAK0s6/Nr8lrsg==', true)), base64_decode('6oRgydKXdC3LtZBDoAXxKnWte68elEQejDrYOV9x+18=', true), @@ -98,7 +98,7 @@ public function anAssertionCanBeVerified(): void $credentialRepository = $this->prophesize(PublicKeyCredentialSourceRepository::class); $credentialRepository->findOneByCredentialId(base64_decode('6oRgydKXdC3LtZBDoAXxKnWte68elEQejDrYOV9x+18=', true))->willReturn($publicKeyCredentialSource->reveal()); - $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function () {}); + $credentialRepository->saveCredentialSource(Argument::type(PublicKeyCredentialSource::class))->will(function (): void {}); $uri = $this->prophesize(UriInterface::class); $uri->getHost()->willReturn('webauthn.spomky-labs.com'); diff --git a/src/webauthn/tests/unit/TrustPath/TrustPathTest.php b/src/webauthn/tests/unit/TrustPath/TrustPathTest.php index bd7cba660..bf8cc94b0 100644 --- a/src/webauthn/tests/unit/TrustPath/TrustPathTest.php +++ b/src/webauthn/tests/unit/TrustPath/TrustPathTest.php @@ -28,7 +28,7 @@ class TrustPathTest extends TestCase /** * @test * - * @use \Webauthn\TrustPath\TrustPath\CertificateTrustPath + * @use CertificateTrustPath */ public function aCertificateTrustPathCanBeCreated(): void { @@ -40,7 +40,7 @@ public function aCertificateTrustPathCanBeCreated(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\EcdaaKeyIdTrustPath + * @use EcdaaKeyIdTrustPath */ public function anEcdaaKeyIdTrustPathCanBeCreated(): void { @@ -52,7 +52,7 @@ public function anEcdaaKeyIdTrustPathCanBeCreated(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\TrustPathLoader + * @use TrustPathLoader */ public function theLoaderCanLoadCustomTrustPath(): void { @@ -66,7 +66,7 @@ public function theLoaderCanLoadCustomTrustPath(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\TrustPathLoader + * @use TrustPathLoader */ public function theLoaderCannotLoadUnsupportedTypeName(): void { @@ -80,7 +80,7 @@ public function theLoaderCannotLoadUnsupportedTypeName(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\TrustPathLoader + * @use TrustPathLoader */ public function theLoaderCannotLoadUnsupportedTypeNameBasedOnClass(): void { @@ -94,7 +94,7 @@ public function theLoaderCannotLoadUnsupportedTypeNameBasedOnClass(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\TrustPathLoader + * @use TrustPathLoader */ public function theLoaderCanLoadOldTrustPathType(): void { @@ -110,7 +110,7 @@ public function theLoaderCanLoadOldTrustPathType(): void /** * @test * - * @use \Webauthn\TrustPath\TrustPath\TrustPathLoader + * @use TrustPathLoader */ public function theLoaderCanLoadNewTrustPathType(): void {