feat: 초기 프로젝트 설정 및 룰.md 파일 추가
This commit is contained in:
37
api.hyungi.net/node_modules/@simplewebauthn/server/script/helpers/validateExtFIDOGenCEAAGUID.js
generated
vendored
Normal file
37
api.hyungi.net/node_modules/@simplewebauthn/server/script/helpers/validateExtFIDOGenCEAAGUID.js
generated
vendored
Normal file
@@ -0,0 +1,37 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.validateExtFIDOGenCEAAGUID = validateExtFIDOGenCEAAGUID;
|
||||
const asn1_schema_1 = require("@peculiar/asn1-schema");
|
||||
const index_js_1 = require("./iso/index.js");
|
||||
/**
|
||||
* Attestation Certificate Extension OID: `id-fido-gen-ce-aaguid`
|
||||
*
|
||||
* Sourced from https://fidoalliance.org/specs/fido-v2.0-ps-20150904/fido-key-attestation-v2.0-ps-20150904.html#verifying-an-attestation-statement
|
||||
*/
|
||||
const id_fido_gen_ce_aaguid = '1.3.6.1.4.1.45724.1.1.4';
|
||||
/**
|
||||
* Look for the id-fido-gen-ce-aaguid certificate extension. If it's present then check it against
|
||||
* the attestation statement AAGUID.
|
||||
*/
|
||||
function validateExtFIDOGenCEAAGUID(certExtensions, aaguid) {
|
||||
// The certificate had no extensions so there's nothing to validate
|
||||
if (!certExtensions) {
|
||||
return true;
|
||||
}
|
||||
const extFIDOGenCEAAGUID = certExtensions.find((ext) => ext.extnID === id_fido_gen_ce_aaguid);
|
||||
// The extension isn't present so there's nothing to validate
|
||||
if (!extFIDOGenCEAAGUID) {
|
||||
return true;
|
||||
}
|
||||
// Parse the extension value
|
||||
const parsedExtFIDOGenCEAAGUID = asn1_schema_1.AsnParser.parse(extFIDOGenCEAAGUID.extnValue, asn1_schema_1.OctetString);
|
||||
const extValue = new Uint8Array(parsedExtFIDOGenCEAAGUID.buffer);
|
||||
// Compare the two values
|
||||
const aaguidAndExtAreEqual = index_js_1.isoUint8Array.areEqual(aaguid, extValue);
|
||||
if (!aaguidAndExtAreEqual) {
|
||||
const _debugExtHex = index_js_1.isoUint8Array.toHex(extValue);
|
||||
const _debugAAGUIDHex = index_js_1.isoUint8Array.toHex(aaguid);
|
||||
throw new Error(`Certificate extension id-fido-gen-ce-aaguid (${id_fido_gen_ce_aaguid}) value of "${_debugExtHex}" was present but not equal to attestation statement AAGUID value of "${_debugAAGUIDHex}"`);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
Reference in New Issue
Block a user