Skip to content
This repository has been archived by the owner on Oct 2, 2024. It is now read-only.

Commit

Permalink
Merge pull request #77 from TimoGlastra/fix/no-async-in-filter
Browse files Browse the repository at this point in the history
fix: no async in filter
  • Loading branch information
nklomp authored Apr 24, 2024
2 parents 1d27bdf + 1ba09a5 commit 26c6d09
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 4 deletions.
17 changes: 13 additions & 4 deletions src/authorization-response/PresentationExchange.ts
Original file line number Diff line number Diff line change
Expand Up @@ -324,9 +324,9 @@ export class PresentationExchange {
) {
const pex = new PEX({ hasher: opts?.hasher });

function filterOutCorrectPresentation() {
async function filterOutCorrectPresentation() {
//TODO: add support for multiple VPs here
return vpPayloads.filter(async (vpw: WrappedVerifiablePresentation) => {
const matchingVps = vpPayloads.map(async (vpw: WrappedVerifiablePresentation): Promise<WrappedVerifiablePresentation | undefined> => {
const presentationSubmission =
opts?.presentationSubmission ??
(CredentialMapper.isWrappedW3CVerifiablePresentation(vpw) ? vpw.presentation.presentation_submission : undefined);
Expand Down Expand Up @@ -364,11 +364,20 @@ export class PresentationExchange {
if (!presentation || !submission) {
throw new Error(SIOPErrors.NO_PRESENTATION_SUBMISSION);
}
return submission && submission.definition_id === definition.id;

// No match
if (submission.definition_id !== definition.id) {
return undefined;
}

return vpw;
});

// Wait for all results to finish and filter out undefined (no match) values
return (await Promise.all(matchingVps)).filter((vp) => vp !== undefined);
}

const checkedPresentations: WrappedVerifiablePresentation[] = filterOutCorrectPresentation();
const checkedPresentations = await filterOutCorrectPresentation();

if (checkedPresentations.length !== 1) {
throw new Error(`${SIOPErrors.COULD_NOT_FIND_VCS_MATCHING_PD}`);
Expand Down
32 changes: 32 additions & 0 deletions test/PresentationExchange.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -422,4 +422,36 @@ describe('presentation exchange manager tests', () => {
console.log(e);
}
});

it("'validatePresentationsAgainstDefinitions' should fail if provided VP verification callback fails", async () => {
const payload: AuthorizationRequestPayload = await getPayloadVID1Val();
const pd: PresentationDefinitionWithLocation[] = await PresentationExchange.findValidPresentationDefinitions(payload);
const vcs = getVCs();
const pex = new PresentationExchange({ allDIDs: [HOLDER_DID], allVerifiableCredentials: vcs });
await pex.selectVerifiableCredentialsForSubmission(pd[0].definition);
const presentationSignCallback: PresentationSignCallback = async (_args) => ({
...(_args.presentation as IPresentation),
proof: {
type: 'RsaSignature2018',
created: '2018-09-14T21:19:10Z',
proofPurpose: 'authentication',
verificationMethod: 'did:example:ebfeb1f712ebc6f1c276e12ec21#keys-1',
challenge: '1f44d55f-f161-4938-a659-f8026467f126',
domain: '4jt78h47fh47',
jws: 'eyJhbGciOiJSUzI1NiIsImI2NCI6ZmFsc2UsImNyaXQiOlsiYjY0Il19..kTCYt5XsITJX1CxPCT8yAV-TVIw5WEuts01mq-pQy7UJiN5mgREEMGlv50aqzpqh4Qq_PbChOMqsLfRoPsnsgxD-WUcX16dUOqV0G_zS245-kronKb78cPktb3rk-BuQy72IFLN25DYuNzVBAh4vGHSrQyHUGlcTwLtjPAnKb78',
},
});
const verifiablePresentationResult = await pex.createVerifiablePresentation(pd[0].definition, vcs, presentationSignCallback, {});

await expect(
PresentationExchange.validatePresentationsAgainstDefinitions(
pd,
[CredentialMapper.toWrappedVerifiablePresentation(verifiablePresentationResult.verifiablePresentation)],
() => {
throw new Error('Verification failed');
},
{},
),
).rejects.toThrow(SIOPErrors.VERIFIABLE_PRESENTATION_SIGNATURE_NOT_VALID);
});
});

0 comments on commit 26c6d09

Please sign in to comment.