| Total Complexity | 7 |
| Total Lines | 33 |
| Duplicated Lines | 0 % |
| Coverage | 100% |
| Changes | 1 | ||
| Bugs | 1 | Features | 0 |
| 1 | <?php |
||
| 13 | final class FidoAaguidExtension |
||
| 14 | { |
||
| 15 | private const OID_FIDO_GEN_CE_AAGUID = '1.3.6.1.4.1.45724.1.1.4'; |
||
| 16 | |||
| 17 | 7 | public static function checkAaguidExtension(CertificateDetailsInterface $cert, Aaguid $validAaguid): void |
|
| 18 | { |
||
| 19 | 7 | $aaguid = self::getFidoAaguidExtensionValue($cert); |
|
| 20 | |||
| 21 | 5 | if ($aaguid === null) { |
|
| 22 | 2 | return; |
|
| 23 | } |
||
| 24 | |||
| 25 | 3 | if (!$validAaguid->equals($aaguid)) { |
|
| 26 | 1 | throw new VerificationException('AAGUID in certificate extension does not match the AAGUID in the authenticator data.'); |
|
| 27 | } |
||
| 28 | 2 | } |
|
| 29 | |||
| 30 | 7 | private static function getFidoAaguidExtensionValue(CertificateDetailsInterface $cert): ?Aaguid |
|
| 46 | } |
||
| 47 | } |
||
| 49 |