From 963fb88201af15ccfce189bb3ac7eedc846833d0 Mon Sep 17 00:00:00 2001 From: Timo Glastra Date: Mon, 11 Mar 2024 16:53:25 +0100 Subject: [PATCH] fix: await session state updates Signed-off-by: Timo Glastra --- .../lib/__tests__/issuerCallback.spec.ts | 2 +- packages/issuer/lib/VcIssuer.ts | 19 +++++++------------ .../lib/state-manager/LookupStateManager.ts | 8 ++++---- packages/issuer/lib/tokens/index.ts | 4 ++-- 4 files changed, 14 insertions(+), 19 deletions(-) diff --git a/packages/callback-example/lib/__tests__/issuerCallback.spec.ts b/packages/callback-example/lib/__tests__/issuerCallback.spec.ts index 9ec8f93a..be47ffa6 100644 --- a/packages/callback-example/lib/__tests__/issuerCallback.spec.ts +++ b/packages/callback-example/lib/__tests__/issuerCallback.spec.ts @@ -139,7 +139,7 @@ describe('issuerCallback', () => { }) const nonces = new MemoryStates() - nonces.set('test_value', { cNonce: 'test_value', createdAt: +new Date(), issuerState: 'existing-state' }) + await nonces.set('test_value', { cNonce: 'test_value', createdAt: +new Date(), issuerState: 'existing-state' }) vcIssuer = new VcIssuerBuilder() .withAuthorizationServer('https://authorization-server') .withCredentialEndpoint('https://credential-endpoint') diff --git a/packages/issuer/lib/VcIssuer.ts b/packages/issuer/lib/VcIssuer.ts index 676b0be6..66ffbf8b 100644 --- a/packages/issuer/lib/VcIssuer.ts +++ b/packages/issuer/lib/VcIssuer.ts @@ -32,19 +32,14 @@ import { toUniformCredentialOfferRequest, TYP_ERROR, UniformCredentialRequest, - URIState + URIState, } from '@sphereon/oid4vci-common' import { CompactSdJwtVc, CredentialMapper, W3CVerifiableCredential } from '@sphereon/ssi-types' import { v4 } from 'uuid' import { assertValidPinNumber, createCredentialOfferObject, createCredentialOfferURIFromObject } from './functions' import { LookupStateManager } from './state-manager' -import { - CredentialDataSupplier, - CredentialDataSupplierArgs, - CredentialIssuanceInput, - CredentialSignerCallback -} from './types' +import { CredentialDataSupplier, CredentialDataSupplierArgs, CredentialIssuanceInput, CredentialSignerCallback } from './types' const SECOND = 1000 @@ -350,17 +345,17 @@ export class VcIssuer { throw new Error(CREDENTIAL_MISSING_ERROR) } // remove the previous nonce - this.cNonces.delete(cNonceState.cNonce) + await this.cNonces.delete(cNonceState.cNonce) if (preAuthorizedCode && preAuthSession) { preAuthSession.lastUpdatedAt = +new Date() preAuthSession.status = IssueStatus.CREDENTIAL_ISSUED - this._credentialOfferSessions.set(preAuthorizedCode, preAuthSession) + await this._credentialOfferSessions.set(preAuthorizedCode, preAuthSession) } else if (issuerState && authSession) { // If both were set we used the pre auth flow above as well, hence the else if authSession.lastUpdatedAt = +new Date() authSession.status = IssueStatus.CREDENTIAL_ISSUED - this._credentialOfferSessions.set(issuerState, authSession) + await this._credentialOfferSessions.set(issuerState, authSession) } return { @@ -390,7 +385,7 @@ export class VcIssuer { preAuthSession.lastUpdatedAt = +new Date() preAuthSession.status = IssueStatus.ERROR preAuthSession.error = error instanceof Error ? error.message : error?.toString() - this._credentialOfferSessions.set(preAuthorizedCode, preAuthSession) + await this._credentialOfferSessions.set(preAuthorizedCode, preAuthSession) } } if (issuerState) { @@ -399,7 +394,7 @@ export class VcIssuer { authSession.lastUpdatedAt = +new Date() authSession.status = IssueStatus.ERROR authSession.error = error instanceof Error ? error.message : error?.toString() - this._credentialOfferSessions.set(issuerState, authSession) + await this._credentialOfferSessions.set(issuerState, authSession) } } } diff --git a/packages/issuer/lib/state-manager/LookupStateManager.ts b/packages/issuer/lib/state-manager/LookupStateManager.ts index 975caf97..b1d3adc5 100644 --- a/packages/issuer/lib/state-manager/LookupStateManager.ts +++ b/packages/issuer/lib/state-manager/LookupStateManager.ts @@ -48,8 +48,8 @@ export class LookupStateManager implem } async delete(id: string): Promise { - return await this.assertedValueId(id).then((value) => { - this.keyValueMapper.delete(id) + return await this.assertedValueId(id).then(async (value) => { + await this.keyValueMapper.delete(id) return this.valueStateManager.delete(value) }) } @@ -68,8 +68,8 @@ export class LookupStateManager implem } async setMapped(id: string, keyValue: K, stateValue: V): Promise { - this.keyValueMapper.set(id, keyValue) - this.valueStateManager.set(id, stateValue) + await this.keyValueMapper.set(id, keyValue) + await this.valueStateManager.set(id, stateValue) } async getAsserted(id: string): Promise { diff --git a/packages/issuer/lib/tokens/index.ts b/packages/issuer/lib/tokens/index.ts index 4d9c3cc6..06222703 100644 --- a/packages/issuer/lib/tokens/index.ts +++ b/packages/issuer/lib/tokens/index.ts @@ -88,7 +88,7 @@ export const assertValidAccessTokenRequest = async ( const credentialOfferSession = await credentialOfferSessions.getAsserted(request[PRE_AUTH_CODE_LITERAL]) credentialOfferSession.status = IssueStatus.ACCESS_TOKEN_REQUESTED credentialOfferSession.lastUpdatedAt = +new Date() - credentialOfferSessions.set(request[PRE_AUTH_CODE_LITERAL], credentialOfferSession) + await credentialOfferSessions.set(request[PRE_AUTH_CODE_LITERAL], credentialOfferSession) if (!isValidGrant(credentialOfferSession, request.grant_type)) { throw new TokenError(400, TokenErrorResponse.invalid_grant, UNSUPPORTED_GRANT_TYPE_ERROR) } @@ -165,6 +165,6 @@ export const createAccessTokenResponse = async ( const credentialOfferSession = await credentialOfferSessions.getAsserted(preAuthorizedCode) credentialOfferSession.status = IssueStatus.ACCESS_TOKEN_CREATED credentialOfferSession.lastUpdatedAt = +new Date() - credentialOfferSessions.set(preAuthorizedCode, credentialOfferSession) + await credentialOfferSessions.set(preAuthorizedCode, credentialOfferSession) return response }