UNPKG

@animo-id/pex

Version:

A Typescript implementation of the v1 and v2 DIF Presentation Exchange specification

437 lines 49.7 kB
"use strict"; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.PEX = void 0; const ConstraintUtils_1 = require("./ConstraintUtils"); const evaluation_1 = require("./evaluation"); const signing_1 = require("./signing"); const types_1 = require("./types"); const PexCredentialMapper_1 = require("./types/PexCredentialMapper"); const utils_1 = require("./utils"); const validation_1 = require("./validation"); /** * This is the main interfacing class to be used by developers using the PEX library. */ class PEX { constructor(options) { // TODO: So we have state in the form of this property which is set in the constructor, but we are overwriting it elsewhere. We need to retrhink how to instantiate PEX this._evaluationClientWrapper = new evaluation_1.EvaluationClientWrapper(); this.options = options; } /*** * The evaluatePresentation compares what is expected from one or more presentations with a presentationDefinition. * presentationDefinition: It can be either v1 or v2 of presentationDefinition * * @param presentationDefinition the definition of what is expected in the presentation. * @param presentations the presentation(s) which have to be evaluated in comparison of the definition. * @param opts - limitDisclosureSignatureSuites the credential signature suites that support limit disclosure * * @return the evaluation results specify what was expected and was fulfilled and also specifies which requirements described in the input descriptors * were not fulfilled by the presentation(s). */ evaluatePresentation(presentationDefinition, presentations, opts) { var _a; // We map it to an array for now to make processing on the presentations easier, but before checking against the submission // we will transform it to the original structure (array vs single) so the references in the submission stay correct const presentationsArray = Array.isArray(presentations) ? presentations : [presentations]; if (presentationsArray.length === 0) { throw new Error('At least one presentation must be provided'); } let originalPresentationSubmission = opts === null || opts === void 0 ? void 0 : opts.presentationSubmission; const generatePresentationSubmission = (opts === null || opts === void 0 ? void 0 : opts.generatePresentationSubmission) !== undefined ? opts.generatePresentationSubmission : (opts === null || opts === void 0 ? void 0 : opts.presentationSubmission) === undefined; const pd = types_1.SSITypesBuilder.toInternalPresentationDefinition(presentationDefinition); const presentationsCopy = JSON.parse(JSON.stringify(presentationsArray)); const wrappedPresentations = presentationsCopy.map((p) => types_1.SSITypesBuilder.mapExternalVerifiablePresentationToWrappedVP(p)); let presentationSubmission = opts === null || opts === void 0 ? void 0 : opts.presentationSubmission; let presentationSubmissionLocation = (_a = opts === null || opts === void 0 ? void 0 : opts.presentationSubmissionLocation) !== null && _a !== void 0 ? _a : ((Array.isArray(presentations) && presentations.length > 1) || !PexCredentialMapper_1.PexCredentialMapper.isW3cPresentation(wrappedPresentations[0].presentation) ? signing_1.PresentationSubmissionLocation.EXTERNAL : signing_1.PresentationSubmissionLocation.PRESENTATION); // When only one presentation, we also allow it to be present in the VP if (!presentationSubmission && presentationsArray.length === 1 && PexCredentialMapper_1.PexCredentialMapper.isW3cPresentation(wrappedPresentations[0].presentation) && !(opts === null || opts === void 0 ? void 0 : opts.generatePresentationSubmission)) { const decoded = wrappedPresentations[0].decoded; if ('presentation_submission' in decoded) { presentationSubmission = JSON.parse(JSON.stringify(decoded.presentation_submission)); originalPresentationSubmission = decoded.presentation_submission; } if (!presentationSubmission) { throw Error(`Either a presentation submission as part of the VP or provided in options was expected`); } presentationSubmissionLocation = signing_1.PresentationSubmissionLocation.PRESENTATION; if ((opts === null || opts === void 0 ? void 0 : opts.presentationSubmissionLocation) && opts.presentationSubmissionLocation !== signing_1.PresentationSubmissionLocation.PRESENTATION) { throw new Error(`unexpected presentationSubmissionLocation ${opts.presentationSubmissionLocation} was provided. Expected ${signing_1.PresentationSubmissionLocation.PRESENTATION} when no presentationSubmission passed and first verifiable presentation contains a presentation_submission and generatePresentationSubmission is false`); } // We need to update the vp path as PEX decoded assumes it's an external submission // So we need to update the submission paths if (wrappedPresentations[0].format === 'jwt_vp') { for (const descriptor of presentationSubmission.descriptor_map) { if (!descriptor.path.startsWith('$.vp')) { descriptor.path = descriptor.path.replace('$.', '$.vp.'); } } } } else if (!presentationSubmission && !generatePresentationSubmission) { throw new Error('Presentation submission in options was expected.'); } // TODO: we should probably add support for holder dids in the kb-jwt of an SD-JWT. We can extract this from the // `wrappedPresentation.original.compactKbJwt`, but as HAIP doesn't use dids, we'll leave it for now. const holderDIDs = wrappedPresentations .map((p) => { return PexCredentialMapper_1.PexCredentialMapper.isW3cPresentation(p.presentation) && p.presentation.holder ? p.presentation.holder : undefined; }) .filter((d) => d !== undefined); const updatedOpts = Object.assign(Object.assign({}, opts), { holderDIDs, presentationSubmission, presentationSubmissionLocation, generatePresentationSubmission }); const allWvcs = wrappedPresentations.reduce((all, wvp) => [...all, ...wvp.vcs], []); const result = this._evaluationClientWrapper.evaluatePresentations(pd, Array.isArray(presentations) ? wrappedPresentations : wrappedPresentations[0], updatedOpts); if (result.areRequiredCredentialsPresent !== ConstraintUtils_1.Status.ERROR) { const selectFromClientWrapper = new evaluation_1.EvaluationClientWrapper(); const selectResults = selectFromClientWrapper.selectFrom(pd, allWvcs, updatedOpts); if (selectResults.areRequiredCredentialsPresent !== ConstraintUtils_1.Status.ERROR) { result.errors = []; } } return Object.assign(Object.assign({}, result), { value: originalPresentationSubmission !== null && originalPresentationSubmission !== void 0 ? originalPresentationSubmission : result.value }); } /*** * The evaluate compares what is expected from a verifiableCredentials with the presentationDefinition. * * @param presentationDefinition the v1 or v2 definition of what is expected in the presentation. * @param verifiableCredentials the verifiable credentials which are candidates to fulfill requirements defined in the presentationDefinition param. * @param opts - holderDIDs the list of the DIDs that the wallet holders controls. Optional, but needed by some input requirements that do a holderDID check. * @ - limitDisclosureSignatureSuites the credential signature suites that support limit disclosure * * @return the evaluation results specify what was expected and was fulfilled and also specifies which requirements described in the input descriptors * were not fulfilled by the verifiable credentials. */ evaluateCredentials(presentationDefinition, verifiableCredentials, opts) { const wrappedVerifiableCredentials = types_1.SSITypesBuilder.mapExternalVerifiableCredentialsToWrappedVcs(verifiableCredentials); // TODO: So we have state in the form of this property which is set in the constructor, but we are overwriting it here. We need to retrhink how to instantiate PEX this._evaluationClientWrapper = new evaluation_1.EvaluationClientWrapper(); const pd = types_1.SSITypesBuilder.toInternalPresentationDefinition(presentationDefinition); const result = this._evaluationClientWrapper.evaluate(pd, wrappedVerifiableCredentials, opts); if (result.value && result.value.descriptor_map.length) { const selectFromClientWrapper = new evaluation_1.EvaluationClientWrapper(); const selectResults = selectFromClientWrapper.selectFrom(pd, wrappedVerifiableCredentials, opts); result.areRequiredCredentialsPresent = selectResults.areRequiredCredentialsPresent; result.errors = selectResults.errors; } else { result.areRequiredCredentialsPresent = ConstraintUtils_1.Status.ERROR; } return result; } /** * The selectFrom method is a helper function that helps filter out the verifiable credentials which can not be selected and returns * the selectable credentials. * * @param presentationDefinition the v1 or v2 definition of what is expected in the presentation. * @param verifiableCredentials verifiable credentials are the credentials from wallet provided to the library to find selectable credentials. * @param opts - holderDIDs the decentralized identifier(s) of the wallet holderDID. This is used to identify the credentials issued to the holderDID of wallet in certain scenario's. * - limitDisclosureSignatureSuites the credential signature suites that support limit disclosure * * @return the selectable credentials. */ selectFrom(presentationDefinition, verifiableCredentials, opts) { const verifiableCredentialCopy = JSON.parse(JSON.stringify(verifiableCredentials)); const pd = types_1.SSITypesBuilder.toInternalPresentationDefinition(presentationDefinition); // TODO: So we have state in the form of this property which is set in the constructor, but we are overwriting it here. We need to retrhink how to instantiate PEX this._evaluationClientWrapper = new evaluation_1.EvaluationClientWrapper(); return this._evaluationClientWrapper.selectFrom(pd, types_1.SSITypesBuilder.mapExternalVerifiableCredentialsToWrappedVcs(verifiableCredentialCopy), opts); } presentationSubmissionFrom(presentationDefinition, selectedCredentials, opts) { const pd = types_1.SSITypesBuilder.toInternalPresentationDefinition(presentationDefinition); return this._evaluationClientWrapper.submissionFrom(pd, types_1.SSITypesBuilder.mapExternalVerifiableCredentialsToWrappedVcs(selectedCredentials), opts); } /** * This method helps create an Unsigned Presentation. An Unsigned Presentation after signing becomes a Presentation. And can be sent to * the verifier after signing it. * * @param presentationDefinition the v1 or v2 definition of what is expected in the presentation. * @param selectedCredentials the credentials which were declared selectable by getSelectableCredentials and then chosen by the intelligent-user * (e.g. human). * @param opts - holderDID optional; the decentralized identity of the wallet holderDID. This is used to identify the holderDID of the presentation. * * @return the presentation. */ presentationFrom(presentationDefinition, selectedCredentials, opts) { var _a; const presentationSubmission = this.presentationSubmissionFrom(presentationDefinition, selectedCredentials, opts); const hasSdJwtCredentials = selectedCredentials.some((c) => PexCredentialMapper_1.PexCredentialMapper.isSdJwtDecodedCredential(c) || PexCredentialMapper_1.PexCredentialMapper.isSdJwtEncoded(c)); // We could include it in the KB-JWT? Not sure if we want that if ((opts === null || opts === void 0 ? void 0 : opts.presentationSubmissionLocation) === signing_1.PresentationSubmissionLocation.PRESENTATION && hasSdJwtCredentials) { throw new Error('Presentation submission location cannot be set to presentation when creating a presentation with an SD-JWT VC'); } const presentationSubmissionLocation = (_a = opts === null || opts === void 0 ? void 0 : opts.presentationSubmissionLocation) !== null && _a !== void 0 ? _a : (hasSdJwtCredentials ? signing_1.PresentationSubmissionLocation.EXTERNAL : signing_1.PresentationSubmissionLocation.PRESENTATION); const presentations = this.constructPresentations(selectedCredentials, Object.assign(Object.assign({}, opts), { // We only pass in the submission in case it needs to be included in the presentation presentationSubmission: presentationSubmissionLocation === signing_1.PresentationSubmissionLocation.PRESENTATION ? presentationSubmission : undefined })); this.updateSdJwtCredentials(presentations); return { presentations, presentationSubmissionLocation, presentationSubmission, }; } constructPresentations(selectedCredentials, opts) { var _a, _b, _c; if (!selectedCredentials) { throw Error(`At least a verifiable credential needs to be passed in to create a presentation`); } const verifiableCredential = (Array.isArray(selectedCredentials) ? selectedCredentials : [selectedCredentials]); const wVCs = verifiableCredential.map((vc) => PexCredentialMapper_1.PexCredentialMapper.toWrappedVerifiableCredential(vc)); const holders = Array.from(new Set(wVCs.flatMap((wvc) => (0, utils_1.getSubjectIdsAsString)(wvc.credential)))); const holder = (_a = opts === null || opts === void 0 ? void 0 : opts.holderDID) !== null && _a !== void 0 ? _a : (holders.length === 1 ? holders[0] : undefined); const type = ((_b = opts === null || opts === void 0 ? void 0 : opts.basePresentationPayload) === null || _b === void 0 ? void 0 : _b.type) ? Array.isArray(opts.basePresentationPayload.type) ? opts.basePresentationPayload.type : [opts.basePresentationPayload.type] : []; if (!type.includes('VerifiablePresentation')) { type.push('VerifiablePresentation'); } const context = ((_c = opts === null || opts === void 0 ? void 0 : opts.basePresentationPayload) === null || _c === void 0 ? void 0 : _c['@context']) ? Array.isArray(opts.basePresentationPayload['@context']) ? opts.basePresentationPayload['@context'] : [opts.basePresentationPayload['@context']] : []; if (!context.includes('https://www.w3.org/2018/credentials/v1')) { context.push('https://www.w3.org/2018/credentials/v1'); } if (opts === null || opts === void 0 ? void 0 : opts.presentationSubmission) { if (!type.includes('PresentationSubmission')) { type.push('PresentationSubmission'); } if (!context.includes('https://identity.foundation/presentation-exchange/submission/v1')) { context.push('https://identity.foundation/presentation-exchange/submission/v1'); } } const result = []; if (PEX.allowMultipleVCsPerPresentation(verifiableCredential)) { result.push(Object.assign(Object.assign(Object.assign(Object.assign({}, opts === null || opts === void 0 ? void 0 : opts.basePresentationPayload), { '@context': context, type, holder }), (!!(opts === null || opts === void 0 ? void 0 : opts.presentationSubmission) && { presentation_submission: opts.presentationSubmission })), { verifiableCredential })); } else { verifiableCredential.forEach((vc) => { if (PexCredentialMapper_1.PexCredentialMapper.isSdJwtDecodedCredential(vc)) { result.push(vc); } else if (PexCredentialMapper_1.PexCredentialMapper.isSdJwtEncoded(vc)) { const decoded = PexCredentialMapper_1.PexCredentialMapper.decodeVerifiableCredential(vc); result.push(decoded); } else { // This should be jwt or json-ld result.push(Object.assign(Object.assign(Object.assign(Object.assign({}, opts === null || opts === void 0 ? void 0 : opts.basePresentationPayload), { '@context': context, type, holder }), (!!(opts === null || opts === void 0 ? void 0 : opts.presentationSubmission) && { presentation_submission: opts.presentationSubmission })), { verifiableCredential: [vc] })); } }); } return result; } /* TODO SDK-37 refinement needed */ static allowMultipleVCsPerPresentation(verifiableCredentials) { var _a; const jwtCredentials = verifiableCredentials.filter((c) => PexCredentialMapper_1.PexCredentialMapper.isJwtEncoded(c) || PexCredentialMapper_1.PexCredentialMapper.isJwtDecodedCredential(c)); if (jwtCredentials.length > 0) { const subjects = new Set(); const verificationMethods = new Set(); for (const credential of jwtCredentials) { const decodedCredential = PexCredentialMapper_1.PexCredentialMapper.isJwtEncoded(credential) ? PexCredentialMapper_1.PexCredentialMapper.decodeVerifiableCredential(credential) : credential; const subject = decodedCredential.sub || (decodedCredential.vc && 'id' in decodedCredential.vc.credentialSubject && decodedCredential.vc.credentialSubject.id); if (subject) { subjects.add(subject); } const vcProof = (_a = decodedCredential.proof) !== null && _a !== void 0 ? _a : decodedCredential.vc.proof; const proofs = Array.isArray(vcProof) ? vcProof : [vcProof]; proofs.filter((proof) => proof.verificationMethod).forEach((proof) => verificationMethods.add(proof.verificationMethod)); } // If there's more than one unique subject or verification method, we can't allow multiple VCs in a single presentation if (subjects.size > 1 || verificationMethods.size > 1) { return false; } } if (verifiableCredentials.some((c) => PexCredentialMapper_1.PexCredentialMapper.isSdJwtEncoded(c) || PexCredentialMapper_1.PexCredentialMapper.isSdJwtDecodedCredential(c))) { return false; } return true; } /** * This method validates whether an object is usable as a presentation definition or not. * * @param presentationDefinition presentationDefinition of V1 or v2 to be validated. * * @return the validation results to reveal what is acceptable/unacceptable about the passed object to be considered a valid presentation definition */ static validateDefinition(presentationDefinition) { const result = (0, utils_1.definitionVersionDiscovery)(presentationDefinition); if (result.error) { const errorParts = [result.error]; const v1ErrorString = (0, utils_1.formatValidationErrors)(result.v1Errors); if (v1ErrorString) { errorParts.push('\nVersion 1 validation errors:\n ' + v1ErrorString); } const v2ErrorString = (0, utils_1.formatValidationErrors)(result.v2Errors); if (v2ErrorString) { errorParts.push('\nVersion 2 validation errors:\n ' + v2ErrorString); } throw new Error(errorParts.join('')); } const validators = []; result.version === types_1.PEVersion.v1 ? validators.push({ bundler: new validation_1.PresentationDefinitionV1VB('root'), target: types_1.SSITypesBuilder.modelEntityToInternalPresentationDefinitionV1(presentationDefinition), }) : validators.push({ bundler: new validation_1.PresentationDefinitionV2VB('root'), target: types_1.SSITypesBuilder.modelEntityInternalPresentationDefinitionV2(presentationDefinition), }); return new validation_1.ValidationEngine().validate(validators); } /** * This method validates whether an object is usable as a presentation submission or not. * * @param presentationSubmission the object to be validated. * * @return the validation results to reveal what is acceptable/unacceptable about the passed object to be considered a valid presentation submission */ static validateSubmission(presentationSubmission) { return new validation_1.ValidationEngine().validate([ { bundler: new validation_1.PresentationSubmissionVB('root'), target: presentationSubmission, }, ]); } /** * This method can be used to combine a definition, selected Verifiable Credentials, together with * signing opts and a callback to sign a presentation, making it a Verifiable Presentation before sending. * * Please note that PEX has no signature support on purpose. We didn't want this library to depend on all kinds of signature suites. * The callback function next to the Signing Params also gets a Presentation which is evaluated against the definition. * It is up to you to decide whether you simply update the supplied partial proof and add it to the presentation in the callback, * or whether you will use the selected Credentials, Presentation definition, evaluation results and/or presentation submission together with the signature opts * * @param presentationDefinition the Presentation Definition V1 or V2 * @param selectedCredentials the PEX and/or User selected/filtered credentials that will become part of the Verifiable Presentation * @param signingCallBack the function which will be provided as a parameter. And this will be the method that will be able to perform actual * signing. One example of signing is available in the project named. pe-selective-disclosure. * @param opts Signing Params these are the signing params required to sign. * * @return the signed and thus Verifiable Presentation. */ verifiablePresentationFrom(presentationDefinition, selectedCredentials, signingCallBack, opts) { return __awaiter(this, void 0, void 0, function* () { const { holderDID, signatureOptions, proofOptions } = opts; function limitedDisclosureSuites() { let limitDisclosureSignatureSuites = []; if (proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.typeSupportsSelectiveDisclosure) { if (!(proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.type)) { throw Error('Please provide a proof type if you enable selective disclosure'); } limitDisclosureSignatureSuites = [proofOptions.type]; } return limitDisclosureSignatureSuites; } const holderDIDs = holderDID ? [holderDID] : []; const limitDisclosureSignatureSuites = limitedDisclosureSuites(); const evaluationResult = this.evaluateCredentials(presentationDefinition, selectedCredentials, { holderDIDs, limitDisclosureSignatureSuites, }); if (evaluationResult.areRequiredCredentialsPresent === ConstraintUtils_1.Status.ERROR) { throw new Error('Could not create presentation, selected credentials do not satisfy the presentation definition'); } const presentationResult = this.presentationFrom(presentationDefinition, evaluationResult.verifiableCredential, opts); const presentations = presentationResult.presentations; const evaluationResults = this.evaluatePresentation(presentationDefinition, presentations, Object.assign({ limitDisclosureSignatureSuites }, (presentationResult.presentationSubmissionLocation === signing_1.PresentationSubmissionLocation.EXTERNAL && { presentationSubmission: presentationResult.presentationSubmission, }))); if (!evaluationResults.value && selectedCredentials.length === 0) { evaluationResults.value = presentationResult.presentationSubmission; } if (!evaluationResults.value) { throw new Error('Could not get evaluation results from presentationResult'); } const proof = { type: proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.type, verificationMethod: signatureOptions === null || signatureOptions === void 0 ? void 0 : signatureOptions.verificationMethod, created: (proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.created) ? proofOptions.created : new Date().toISOString(), proofPurpose: proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.proofPurpose, proofValue: signatureOptions === null || signatureOptions === void 0 ? void 0 : signatureOptions.proofValue, jws: signatureOptions === null || signatureOptions === void 0 ? void 0 : signatureOptions.jws, challenge: proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.challenge, nonce: proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.nonce, domain: proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.domain, }; this.updateSdJwtCredentials(presentations, proofOptions === null || proofOptions === void 0 ? void 0 : proofOptions.nonce); const verifiablePresentations = []; for (const presentation of presentations) { const callBackParams = { options: Object.assign(Object.assign({}, opts), { presentationSubmissionLocation: presentationResult.presentationSubmissionLocation }), presentation, presentationDefinition, selectedCredentials, proof, presentationSubmission: evaluationResults.value, evaluationResults, }; verifiablePresentations.push(yield signingCallBack(callBackParams)); } return { verifiablePresentations, presentationSubmissionLocation: presentationResult.presentationSubmissionLocation, presentationSubmission: evaluationResults.value, }; }); } updateSdJwtCredentials(presentations, nonce) { presentations.forEach((presentation, index) => { var _a; // Select type without kbJwt as isSdJwtDecodedCredential and won't accept the partial sdvc type if (PexCredentialMapper_1.PexCredentialMapper.isSdJwtDecodedCredential(presentation)) { const sdJwtCredential = presentation; // extract sd_alg or default to sha-256 const hashAlg = (_a = sdJwtCredential.signedPayload._sd_alg) !== null && _a !== void 0 ? _a : 'sha-256'; const sdHash = (0, utils_1.calculateSdHash)(sdJwtCredential.compactSdJwtVc, hashAlg); const kbJwt = { // alg MUST be set by the signer header: { typ: 'kb+jwt', }, // aud MUST be set by the signer or provided by e.g. SIOP/OpenID4VP lib payload: { iat: Math.floor(new Date().getTime() / 1000), nonce: nonce, sd_hash: sdHash, }, }; presentations[index] = Object.assign(Object.assign({}, sdJwtCredential), { kbJwt }); } }); } static definitionVersionDiscovery(presentationDefinition) { return (0, utils_1.definitionVersionDiscovery)(presentationDefinition); } } exports.PEX = PEX; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PEX.js","sourceRoot":"","sources":["../../../lib/PEX.ts"],"names":[],"mappings":"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"}