Skip to content

Commit

Permalink
chore: integration from Funke branch
Browse files Browse the repository at this point in the history
  • Loading branch information
sanderPostma committed Sep 16, 2024
1 parent 4a29446 commit db25837
Show file tree
Hide file tree
Showing 114 changed files with 3,661 additions and 1,284 deletions.
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { DataStoreContactEntities } from '@sphereon/ssi-sdk.data-store'
import { SqliteConnectionOptions } from 'typeorm/driver/sqlite/SqliteConnectionOptions'
import { DataStoreContactMigrations } from '@sphereon/ssi-sdk.data-store/dist/migrations/generic'
import { DataStoreContactMigrations } from '@sphereon/ssi-sdk.data-store'
import { Entities as VeramoDataStoreEntities } from '@veramo/data-store'
import { migrations as VeramoDataStoreMigrations } from '@veramo/data-store/build/migrations'

Expand Down
4 changes: 2 additions & 2 deletions packages/contact-manager-rest-api/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@
},
"dependencies": {
"@sphereon/ssi-express-support": "workspace:*",
"@sphereon/ssi-sdk-ext.key-manager": "0.24.1-next.112",
"@sphereon/ssi-sdk-ext.key-utils": "0.24.1-next.112",
"@sphereon/ssi-sdk-ext.key-manager": "0.24.1-unstable.112",
"@sphereon/ssi-sdk-ext.key-utils": "0.24.1-unstable.112",
"@sphereon/ssi-sdk.contact-manager": "workspace:*",
"@sphereon/ssi-sdk.core": "workspace:*",
"@sphereon/ssi-sdk.data-store": "workspace:*",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ export default (testContext: { getAgent: () => ConfiguredAgent; setup: () => Pro
const digitalCredential: AddDigitalCredential = {
credentialRole: CredentialRole.HOLDER,
tenantId: 'test-tenant',
kmsKeyRef: 'testKeyRef',
identifierMethod: 'did',
issuerCorrelationId: 'did:example:the-issuer',
issuerCorrelationType: CredentialCorrelationType.DID,
rawDocument: JSON.stringify(exampleVC),
Expand All @@ -46,8 +48,10 @@ export default (testContext: { getAgent: () => ConfiguredAgent; setup: () => Pro
const sdJwtAdd: AddDigitalCredential = {
credentialRole: CredentialRole.HOLDER,
tenantId: 'test-tenant',
kmsKeyRef: 'testKeyRef',
identifierMethod: 'did',
issuerCorrelationId: 'CN="test"',
issuerCorrelationType: CredentialCorrelationType.X509_CN,
issuerCorrelationType: CredentialCorrelationType.X509_SAN,
rawDocument: examplePid,
}
pidSdJwtCredential = await agent.crsAddCredential({ credential: sdJwtAdd })
Expand Down Expand Up @@ -205,6 +209,8 @@ export default (testContext: { getAgent: () => ConfiguredAgent; setup: () => Pro
const digitalCredential1: AddDigitalCredential = {
credentialRole: CredentialRole.VERIFIER,
tenantId: 'test-tenant',
kmsKeyRef: 'testKeyRef',
identifierMethod: 'did',
issuerCorrelationId: 'did:example:item1',
issuerCorrelationType: CredentialCorrelationType.DID,
rawDocument: JSON.stringify(exampleVC),
Expand All @@ -216,6 +222,8 @@ export default (testContext: { getAgent: () => ConfiguredAgent; setup: () => Pro
const digitalCredential2: AddDigitalCredential = {
credentialRole: CredentialRole.VERIFIER,
tenantId: 'test-tenant',
kmsKeyRef: 'testKeyRef',
identifierMethod: 'did',
issuerCorrelationId: 'did:example:item2',
issuerCorrelationType: CredentialCorrelationType.DID,
rawDocument: JSON.stringify(exampleVC2),
Expand Down
19 changes: 6 additions & 13 deletions packages/credential-store/src/agent/CredentialStore.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import { IAgentPlugin } from '@veramo/core'
import crypto from 'crypto'
import {
AddCredentialArgs,
credentialIdOrHashFilter,
Expand All @@ -17,8 +16,10 @@ import {
TClaimsColumns,
UniqueDigitalCredential,
} from '../index'
import { AbstractDigitalCredentialStore, DigitalCredential, UpdateCredentialStateArgs } from '@sphereon/ssi-sdk.data-store'
import { AbstractDigitalCredentialStore, DigitalCredential, parseRawDocument, UpdateCredentialStateArgs } from '@sphereon/ssi-sdk.data-store'
import { IVerifiableCredential } from '@sphereon/ssi-types'
import { defaultHasher } from '@sphereon/ssi-sdk.data-store'

// Exposing the methods here for any REST implementation
export const credentialStoreMethods: Array<string> = [
'crsAddCredential',
Expand Down Expand Up @@ -59,7 +60,7 @@ export class CredentialStore implements IAgentPlugin {

/** {@inheritDoc ICRManager.crmAddCredential} */
private async crsAddCredential(args: AddCredentialArgs): Promise<DigitalCredential> {
return await this.store.addCredential({ ...args.credential, opts: { ...args.opts, hasher: args.opts?.hasher ?? this.generateDigest } })
return await this.store.addCredential({ ...args.credential, opts: { ...args.opts, hasher: args.opts?.hasher ?? defaultHasher } })
}

/** {@inheritDoc ICRManager.updateCredentialState} */
Expand All @@ -70,8 +71,7 @@ export class CredentialStore implements IAgentPlugin {
/** {@inheritDoc ICRManager.crmGetCredential} */
private async crsGetCredential(args: GetCredentialArgs): Promise<DigitalCredential> {
const { id } = args
const credential = await this.store.getCredential({ id })
return credential
return await this.store.getCredential({ id })
}

/** {@inheritDoc ICRManager.crmGetCredentials} */
Expand Down Expand Up @@ -219,10 +219,7 @@ export class CredentialStore implements IAgentPlugin {
}

private secureParse<Type>(original: string): Type {
if (original.includes('~')) {
return original as Type
}
return JSON.parse(original)
return parseRawDocument(original) as Type
}

private toUniqueCredentials(credentials: Array<DigitalCredential>): Array<UniqueDigitalCredential> {
Expand Down Expand Up @@ -261,8 +258,4 @@ export class CredentialStore implements IAgentPlugin {
),
)
}

private generateDigest = (data: string, algorithm: string): Uint8Array => {
return new Uint8Array(crypto.createHash(algorithm).update(data).digest())
}
}
3 changes: 2 additions & 1 deletion packages/credential-store/src/types/ICredentialStore.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import {
ICredential,
IPresentation,
IVerifiableCredential,
IVerifiablePresentation,
OriginalVerifiableCredential,
OriginalVerifiablePresentation,
} from '@sphereon/ssi-types'
Expand Down Expand Up @@ -133,7 +134,7 @@ export interface UniqueDigitalCredential {
originalCredential?: ICredential
originalPresentation?: IPresentation
uniformVerifiableCredential?: IVerifiableCredential
uniformVerifiablePresentation?: IVerifiableCredential
uniformVerifiablePresentation?: IVerifiablePresentation
}

export type OptionalUniqueDigitalCredential = UniqueDigitalCredential | undefined
Expand Down
4 changes: 2 additions & 2 deletions packages/data-store/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@
},
"dependencies": {
"@sphereon/pex": "4.1.1-unstable.1",
"@sphereon/ssi-sdk-ext.did-utils": " 0.24.1-next.112",
"@sphereon/ssi-sdk-ext.identifier-resolution": " 0.24.1-next.112",
"@sphereon/ssi-sdk-ext.did-utils": "0.24.1-unstable.112",
"@sphereon/ssi-sdk-ext.identifier-resolution": "0.24.1-unstable.112",
"@sphereon/ssi-sdk.agent-config": "workspace:*",
"@sphereon/kmp-mdl-mdoc": "0.2.0-SNAPSHOT.22",
"@sphereon/ssi-sdk.core": "workspace:*",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ describe('Database entities tests', (): void => {
'eyJraWQiOiJkaWQ6a2V5Ono2TWtyaGt5M3B1c20yNk1laUZhWFUzbjJuZWtyYW13RlVtZ0dyZUdHa0RWNnpRaiN6Nk1rcmhreTNwdXNtMjZNZWlGYVhVM24ybmVrcmFtd0ZVbWdHcmVHR2tEVjZ6UWoiLCJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJ2YyI6eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvMjAxOC9jcmVkZW50aWFscy92MSIsImh0dHBzOi8vc3BoZXJlb24tb3BlbnNvdXJjZS5naXRodWIuaW8vc3NpLW1vYmlsZS13YWxsZXQvY29udGV4dC9zcGhlcmVvbi13YWxsZXQtaWRlbnRpdHktdjEuanNvbmxkIl0sInR5cGUiOlsiVmVyaWZpYWJsZUNyZWRlbnRpYWwiLCJTcGhlcmVvbldhbGxldElkZW50aXR5Q3JlZGVudGlhbCJdLCJjcmVkZW50aWFsU3ViamVjdCI6eyJmaXJzdE5hbWUiOiJTIiwibGFzdE5hbWUiOiJLIiwiZW1haWxBZGRyZXNzIjoic0BrIn19LCJzdWIiOiJ1cm46dXVpZDpkZGE3YmYyNC04ZTdhLTQxZjgtYjY2Yy1hNDhkYmM1YjEwZmEiLCJqdGkiOiJ1cm46dXVpZDpkZGE3YmYyNC04ZTdhLTQxZjgtYjY2Yy1hNDhkYmM1YjEwZmEiLCJuYmYiOjE3MDg0NDA4MDgsImlzcyI6ImRpZDprZXk6ejZNa3Joa3kzcHVzbTI2TWVpRmFYVTNuMm5la3JhbXdGVW1nR3JlR0drRFY2elFqIn0.G0M84XVAxSmzGY-NQuB9NBofNrINSn6lvxW6761Vlq6ypvYgtc2xNdpiRmw8ryVNfnpzrr4Z5cB1RlrC05rJAw'
const digitalCredential: AddCredentialArgs = {
rawDocument: rawCredential,
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand Down Expand Up @@ -68,6 +70,8 @@ describe('Database entities tests', (): void => {
const digitalCredential: NonPersistedDigitalCredential = nonPersistedDigitalCredentialEntityFromAddArgs({
rawDocument:
'eyJraWQiOiJkaWQ6a2V5Ono2TWtyaGt5M3B1c20yNk1laUZhWFUzbjJuZWtyYW13RlVtZ0dyZUdHa0RWNnpRaiN6Nk1rcmhreTNwdXNtMjZNZWlGYVhVM24ybmVrcmFtd0ZVbWdHcmVHR2tEVjZ6UWoiLCJhbGciOiJFZERTQSIsInR5cCI6IkpXVCJ9.eyJ2YyI6eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvMjAxOC9jcmVkZW50aWFscy92MSIsImh0dHBzOi8vc3BoZXJlb24tb3BlbnNvdXJjZS5naXRodWIuaW8vc3NpLW1vYmlsZS13YWxsZXQvY29udGV4dC9zcGhlcmVvbi13YWxsZXQtaWRlbnRpdHktdjEuanNvbmxkIl0sInR5cGUiOlsiVmVyaWZpYWJsZUNyZWRlbnRpYWwiLCJTcGhlcmVvbldhbGxldElkZW50aXR5Q3JlZGVudGlhbCJdLCJjcmVkZW50aWFsU3ViamVjdCI6eyJmaXJzdE5hbWUiOiJTIiwibGFzdE5hbWUiOiJLIiwiZW1haWxBZGRyZXNzIjoic0BrIn19LCJzdWIiOiJ1cm46dXVpZDpkZGE3YmYyNC04ZTdhLTQxZjgtYjY2Yy1hNDhkYmM1YjEwZmEiLCJqdGkiOiJ1cm46dXVpZDpkZGE3YmYyNC04ZTdhLTQxZjgtYjY2Yy1hNDhkYmM1YjEwZmEiLCJuYmYiOjE3MDg0NDA4MDgsImlzcyI6ImRpZDprZXk6ejZNa3Joa3kzcHVzbTI2TWVpRmFYVTNuMm5la3JhbXdGVW1nR3JlR0drRFY2elFqIn0.G0M84XVAxSmzGY-NQuB9NBofNrINSn6lvxW6761Vlq6ypvYgtc2xNdpiRmw8ryVNfnpzrr4Z5cB1RlrC05rJAw',
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand All @@ -85,6 +89,8 @@ describe('Database entities tests', (): void => {
const digitalCredential: NonPersistedDigitalCredential = nonPersistedDigitalCredentialEntityFromAddArgs({
rawDocument:
'eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCIsImtpZCI6ImRpZDpleGFtcGxlOmFiZmUxM2Y3MTIxMjA0MzFjMjc2ZTEyZWNhYiNrZXlzLTEifQ.eyJzdWIiOiJkaWQ6ZXhhbXBsZTplYmZlYjFmNzEyZWJjNmYxYzI3NmUxMmVjMjEiLCJqdGkiOiJodHRwOi8vZXhhbXBsZS5lZHUvY3JlZGVudGlhbHMvMzczMiIsImlzcyI6Imh0dHBzOi8vZXhhbXBsZS5jb20va2V5cy9mb28uandrIiwibmJmIjoxNTQxNDkzNzI0LCJpYXQiOjE1NDE0OTM3MjQsImV4cCI6MTU3MzAyOTcyMywibm9uY2UiOiI2NjAhNjM0NUZTZXIiLCJ2YyI6eyJAY29udGV4dCI6WyJodHRwczovL3d3dy53My5vcmcvMjAxOC9jcmVkZW50aWFscy92MSIsImh0dHBzOi8vd3d3LnczLm9yZy8yMDE4L2NyZWRlbnRpYWxzL2V4YW1wbGVzL3YxIl0sInR5cGUiOlsiVmVyaWZpYWJsZUNyZWRlbnRpYWwiLCJVbml2ZXJzaXR5RGVncmVlQ3JlZGVudGlhbCJdLCJjcmVkZW50aWFsU3ViamVjdCI6eyJkZWdyZWUiOnsidHlwZSI6IkJhY2hlbG9yRGVncmVlIiwibmFtZSI6IjxzcGFuIGxhbmc9J2ZyLUNBJz5CYWNjYWxhdXLDqWF0IGVuIG11c2lxdWVzIG51bcOpcmlxdWVzPC9zcGFuPiJ9fX19.KLJo5GAyBND3LDTn9H7FQokEsUEi8jKwXhGvoN3JtRa51xrNDgXDb0cq1UTYB-rK4Ft9YVmR1NI_ZOF8oGc_7wAp8PHbF2HaWodQIoOBxxT-4WNqAxft7ET6lkH-4S6Ux3rSGAmczMohEEf8eCeN-jC8WekdPl6zKZQj0YPB1rx6X0-xlFBs7cl6Wt8rfBP_tZ9YgVWrQmUWypSioc0MUyiphmyEbLZagTyPlUyflGlEdqrZAv6eSe6RtxJy6M1-lD7a5HTzanYTWBPAUHDZGyGKXdJw-W_x0IWChBzI8t3kpG253fg6V3tPgHeKXE94fz_QpYfg--7kLsyBAfQGbg',
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand Down Expand Up @@ -128,6 +134,8 @@ describe('Database entities tests', (): void => {
},
],
}),
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand Down Expand Up @@ -227,6 +235,8 @@ describe('Database entities tests', (): void => {
jws: '...',
},
}),
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand All @@ -244,6 +254,8 @@ describe('Database entities tests', (): void => {
const digitalCredential: NonPersistedDigitalCredential = nonPersistedDigitalCredentialEntityFromAddArgs({
rawDocument:
'eyJhbGciOiJFZERTQSIsInR5cCI6InZjK3NkLWp3dCIsImtpZCI6IiN6Nk1rdHF0WE5HOENEVVk5UHJydG9TdEZ6ZUNuaHBNbWd4WUwxZ2lrY1czQnp2TlcifQ.eyJ2Y3QiOiJJZGVudGl0eUNyZWRlbnRpYWwiLCJmYW1pbHlfbmFtZSI6IkRvZSIsInBob25lX251bWJlciI6IisxLTIwMi01NTUtMDEwMSIsImFkZHJlc3MiOnsic3RyZWV0X2FkZHJlc3MiOiIxMjMgTWFpbiBTdCIsImxvY2FsaXR5IjoiQW55dG93biIsIl9zZCI6WyJOSm5tY3QwQnFCTUUxSmZCbEM2alJRVlJ1ZXZwRU9OaVl3N0E3TUh1SnlRIiwib201Wnp0WkhCLUdkMDBMRzIxQ1ZfeE00RmFFTlNvaWFPWG5UQUpOY3pCNCJdfSwiY25mIjp7Imp3ayI6eyJrdHkiOiJPS1AiLCJjcnYiOiJFZDI1NTE5IiwieCI6Im9FTlZzeE9VaUg1NFg4d0pMYVZraWNDUmswMHdCSVE0c1JnYms1NE44TW8ifX0sImlzcyI6ImRpZDprZXk6ejZNa3RxdFhORzhDRFVZOVBycnRvU3RGemVDbmhwTW1neFlMMWdpa2NXM0J6dk5XIiwiaWF0IjoxNjk4MTUxNTMyLCJfc2RfYWxnIjoic2hhLTI1NiIsIl9zZCI6WyIxQ3VyMmsyQTJvSUI1Q3NoU0lmX0FfS2ctbDI2dV9xS3VXUTc5UDBWZGFzIiwiUjF6VFV2T1lIZ2NlcGowakh5cEdIejlFSHR0VktmdDB5c3diYzlFVFBiVSIsImVEcVFwZFRYSlhiV2hmLUVzSTd6dzVYNk92WW1GTi1VWlFRTWVzWHdLUHciLCJwZERrMl9YQUtIbzdnT0Fmd0YxYjdPZENVVlRpdDJrSkhheFNFQ1E5eGZjIiwicHNhdUtVTldFaTA5bnUzQ2w4OXhLWGdtcFdFTlpsNXV5MU4xbnluX2pNayIsInNOX2dlMHBIWEY2cW1zWW5YMUE5U2R3SjhjaDhhRU5reGJPRHNUNzRZd0kiXX0.coOK8NzJmEWz4qx-qRhjo-RK7aejrSkQM9La9Cw3eWmzcja9DXrkBoQZKbIJtNoSzSPLjwK2V71W78z0miZsDQ~WyJzYWx0IiwiaXNfb3Zlcl82NSIsdHJ1ZV0~WyJzYWx0IiwiaXNfb3Zlcl8yMSIsdHJ1ZV0~WyJzYWx0IiwiZW1haWwiLCJqb2huZG9lQGV4YW1wbGUuY29tIl0~WyJzYWx0IiwiY291bnRyeSIsIlVTIl0~WyJzYWx0IiwiZ2l2ZW5fbmFtZSIsIkpvaG4iXQ~eyJhbGciOiJFZERTQSIsInR5cCI6ImtiK2p3dCJ9.eyJpYXQiOjE2OTgxNTE1MzIsIm5vbmNlIjoic2FsdCIsImF1ZCI6ImRpZDprZXk6elVDNzRWRXFxaEVIUWNndjR6YWdTUGtxRkp4dU5XdW9CUEtqSnVIRVRFVWVITG9TcVd0OTJ2aVNzbWFXank4MnkiLCJfc2RfaGFzaCI6Ii1kTUd4OGZhUnpOQm91a2EwU0R6V2JkS3JYckw1TFVmUlNQTHN2Q2xPMFkifQ.TQQLqc4ZzoKjQfAghAzC_4aaU3KCS8YqzxAJtzT124guzkv9XSHtPN8d3z181_v-ca2ATXjTRoRciozitE6wBA',
kmsKeyRef: 'testRef',
identifierMethod: 'did',
issuerCorrelationType: CredentialCorrelationType.DID,
subjectCorrelationType: CredentialCorrelationType.DID,
issuerCorrelationId: 'did:key:z6Mkrhky3pusm26MeiFaXU3n2nekramwFUmgGreGGkDV6zQj',
Expand Down
Loading

0 comments on commit db25837

Please sign in to comment.