@sphereon/did-resolver-key
Version:
Sphereon did:key resolver with BBS+/BLS and EBSI support.
100 lines • 4 kB
JavaScript
;
// Brent Shambaugh <brent.shambaugh@gmail.com>. 2021.
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.pubKeyBytesToXY = exports.keyToDidDoc = void 0;
const u8a = __importStar(require("uint8arrays"));
const nist_weierstrauss = __importStar(require("nist-weierstrauss"));
/**
* Constructs the document based on the method key
*/
function keyToDidDoc(pubKeyBytes, fingerprint) {
const did = `did:key:${fingerprint}`;
const keyId = `${did}#${fingerprint}`;
const key = pubKeyBytesToXY(pubKeyBytes);
return {
id: did,
verificationMethod: [
{
id: keyId,
type: 'JsonWebKey2020',
controller: did,
publicKeyJwk: {
kty: 'EC',
crv: 'P-256',
x: key.xm,
y: key.ym,
},
},
],
authentication: [keyId],
assertionMethod: [keyId],
capabilityDelegation: [keyId],
capabilityInvocation: [keyId],
};
}
exports.keyToDidDoc = keyToDidDoc;
/**
*
* @param pubKeyBytes - public key as uncompressed byte array with no prefix (raw key),
* uncompressed with 0x04 prefix, or compressed with 0x02 prefix if even and 0x03 prefix if odd.
* @returns point x,y with coordinates as multibase encoded base64urls
*
* See the the did:key specification: https://w3c-ccg.github.io/did-method-key/#p-256.
* At present only raw p-256 keys are covered in the specification.
* @throws TypeError: input cannot be null or undefined.
* @throws Error: Unexpected pubKeyBytes
* @internal
*/
function pubKeyBytesToXY(pubKeyBytes) {
if (!nist_weierstrauss.nist_weierstrauss_common.testUint8Array(pubKeyBytes)) {
throw new TypeError('input must be a Uint8Array');
}
const publicKeyHex = nist_weierstrauss.nist_weierstrauss_common.pubKeyBytesToHex(pubKeyBytes);
const bytesCount = publicKeyHex.length / 2;
// raw p-256 key
if (bytesCount == 64) {
return nist_weierstrauss.nist_weierstrauss_common.publicKeyToXY(publicKeyHex);
}
// uncompressed p-256 key, SEC format
if (bytesCount == 65) {
if (publicKeyHex.slice(0, 2) == '04') {
const publicKey = publicKeyHex.slice(2);
return nist_weierstrauss.nist_weierstrauss_common.publicKeyToXY(publicKey);
}
}
// compressed p-256 key, SEC format
if (bytesCount == 33) {
if (publicKeyHex.slice(0, 2) == '03' || publicKeyHex.slice(0, 2) == '02') {
const publicKey = u8a.fromString(publicKeyHex, 'base16');
const point = nist_weierstrauss.secp256r1.ECPointDecompress(publicKey);
return nist_weierstrauss.nist_weierstrauss_common.publicKeyIntToXY(point);
}
}
throw new Error('Unexpected pubKeyBytes');
}
exports.pubKeyBytesToXY = pubKeyBytesToXY;
exports.default = { keyToDidDoc };
//# sourceMappingURL=secp256r1.js.map