Skip to content

Commit

Permalink
fix(credential-ld): let verifiers use all supported verification methods
Browse files Browse the repository at this point in the history
The `VeramoLdSignature.getSupportedVerificationType()` can now return `string[]` as well as `string`

fixes #1329
  • Loading branch information
mirceanis committed Jan 26, 2024
1 parent 7896cea commit cde68aa
Show file tree
Hide file tree
Showing 8 changed files with 36 additions and 28 deletions.
3 changes: 2 additions & 1 deletion __tests__/shared/verifiableDataLD.ts
Original file line number Diff line number Diff line change
Expand Up @@ -230,7 +230,8 @@ export default (testContext: {

// Check credential:
expect(verifiableCredential).toHaveProperty('proof')
expect(verifiableCredential).toHaveProperty('proof.jws')
const proofValue = verifiableCredential.proof.jws ?? verifiableCredential.proof.proofValue
expect(proofValue).toBeDefined()
expect(verifiableCredential.proof.verificationMethod).toEqual(
`${didKeyIdentifier.did}#${didKeyIdentifier.did.substring(
didKeyIdentifier.did.lastIndexOf(':') + 1,
Expand Down
16 changes: 9 additions & 7 deletions packages/credential-ld/src/ld-credential-module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,7 @@ export class LdCredentialModule {
this.ldSuiteLoader = options.ldSuiteLoader
}

getDocumentLoader(
context: IAgentContext<IResolver>,
attemptToFetchContexts: boolean = false,
) {
getDocumentLoader(context: IAgentContext<IResolver>, attemptToFetchContexts: boolean = false) {
return extendContextLoader(async (url: string) => {
// console.log(`resolving context for: ${url}`)

Expand All @@ -55,8 +52,11 @@ export class LdCredentialModule {
// currently, Veramo LD suites can modify the resolution response for DIDs from
// the document Loader. This allows us to fix incompatibilities between DID Documents
// and LD suites to be fixed specifically within the Veramo LD Suites definition
// TODO: every suite takes turns modifying the result, potentially leading to overwrites and incompatibilities
// between concurrent suites. Ideally, this should be performed by each suite only before it interacts with the
// document loader, to allow each suite to massage the verification methods into formats it knows about.
for (const x of this.ldSuiteLoader.getAllSignatureSuites()) {
result = (await x.preDidResolutionModification(url, result, context)) || result;
result = (await x.preDidResolutionModification(url, result, context)) || result
}

// console.log(`Returning from Documentloader: ${JSON.stringify(returnDocument)}`)
Expand Down Expand Up @@ -110,10 +110,11 @@ export class LdCredentialModule {
options: any,
context: IAgentContext<RequiredAgentMethods>,
): Promise<VerifiableCredential> {
// TODO: try multiple matching suites until one works or list is exhausted
const suite = this.ldSuiteLoader.getSignatureSuiteForKeyType(
key.type,
key.meta?.verificationMethod?.type ?? '',
)
)[0]
const documentLoader = this.getDocumentLoader(context, options.fetchRemoteContexts)

// some suites can modify the incoming credential (e.g. add required contexts)
Expand All @@ -138,10 +139,11 @@ export class LdCredentialModule {
options: any,
context: IAgentContext<RequiredAgentMethods>,
): Promise<VerifiablePresentation> {
// TODO: try multiple matching suites until one works or list is exhausted
const suite = this.ldSuiteLoader.getSignatureSuiteForKeyType(
key.type,
key.meta?.verificationMethod?.type ?? '',
)
)[0]
const documentLoader = this.getDocumentLoader(context, options.fetchRemoteContexts)

suite.preSigningPresModification(presentation)
Expand Down
20 changes: 10 additions & 10 deletions packages/credential-ld/src/ld-suite-loader.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
import { VeramoLdSignature } from './ld-suites.js'
import { TKeyType } from '@veramo/core-types'
import { asArray } from '@veramo/utils'

/**
* Initializes a list of Veramo-wrapped LD Signature suites and exposes those to the Agent Module
*/
export class LdSuiteLoader {
constructor(options: { veramoLdSignatures: VeramoLdSignature[] }) {
options.veramoLdSignatures.forEach((obj) => {
// FIXME: some suites would work for multiple key types, but this only returns a single value per suite.
// For example, EcdsaSecp256k1RecoverySignature2020 should work with both EcdsaSecp256k1VerificationKey2019
// as well as EcdsaSecp256k1RecoveryMethod2020 since the VerificationKey can also be expressed as the recovery
// method.
const keyType = obj.getSupportedVeramoKeyType()
const verificationType = obj.getSupportedVerificationType()
return (this.signatureMap[keyType] = { ...this.signatureMap[keyType], [verificationType]: obj })
options.veramoLdSignatures.forEach((ldSuite) => {
const keyType = ldSuite.getSupportedVeramoKeyType()
let verifierMapping = this.signatureMap[keyType] ?? {}
asArray(ldSuite.getSupportedVerificationType()).forEach((verificationType) => {
verifierMapping[verificationType] = [...(verifierMapping[verificationType] ?? []), ldSuite]
})
return (this.signatureMap[keyType] = { ...this.signatureMap[keyType], ...verifierMapping })
})
}

private signatureMap: Record<string, Record<string, VeramoLdSignature>> = {}
private signatureMap: Record<string, Record<string, VeramoLdSignature[]>> = {}

getSignatureSuiteForKeyType(type: TKeyType, verificationType: string) {
const suite = this.signatureMap[type]?.[verificationType]
Expand All @@ -29,7 +29,7 @@ export class LdSuiteLoader {
getAllSignatureSuites(): VeramoLdSignature[] {
return Object.values(this.signatureMap)
.map((x) => Object.values(x))
.flat()
.flat(2)
}

getAllSignatureSuiteTypes() {
Expand Down
2 changes: 1 addition & 1 deletion packages/credential-ld/src/ld-suites.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ export abstract class VeramoLdSignature {
// Add type definition as soon as https://github.com/digitalbazaar/jsonld-signatures
// supports those.

abstract getSupportedVerificationType(): string
abstract getSupportedVerificationType(): string | string[]

abstract getSupportedVeramoKeyType(): TKeyType

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ const { EcdsaSecp256k1RecoveryMethod2020, EcdsaSecp256k1RecoverySignature2020 }
export class VeramoEcdsaSecp256k1RecoverySignature2020 extends VeramoLdSignature {
getSupportedVerificationType(): string {
return 'EcdsaSecp256k1RecoveryMethod2020'
// TODO: add support for ['EcdsaSecp256k1VerificationKey2020', 'EcdsaSecp256k1VerificationKey2019',
// 'JsonWebKey2020', 'Multikey']
}

getSupportedVeramoKeyType(): TKeyType {
Expand Down Expand Up @@ -52,7 +54,7 @@ export class VeramoEcdsaSecp256k1RecoverySignature2020 extends VeramoLdSignature
key: new EcdsaSecp256k1RecoveryMethod2020({
publicKeyHex: key.publicKeyHex,
signer: () => signer,
type: this.getSupportedVerificationType(),
type: 'EcdsaSecp256k1RecoveryMethod2020',
controller,
id: verifiableMethodId,
}),
Expand Down
7 changes: 4 additions & 3 deletions packages/credential-ld/src/suites/Ed25519Signature2018.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,9 @@ import { Ed25519Signature2018, Ed25519VerificationKey2018 } from '@transmute/ed2
* @alpha This API is experimental and is very likely to change or disappear in future releases without notice.
*/
export class VeramoEd25519Signature2018 extends VeramoLdSignature {
getSupportedVerificationType(): string {
return 'Ed25519VerificationKey2018'
getSupportedVerificationType(): string[] {
return ['Ed25519VerificationKey2018', 'JsonWebKey2020']
// TODO: add support for ['Ed25519VerificationKey2020', 'Multikey']
}

getSupportedVeramoKeyType(): TKeyType {
Expand Down Expand Up @@ -54,7 +55,7 @@ export class VeramoEd25519Signature2018 extends VeramoLdSignature {
controller,
publicKey: hexToBytes(key.publicKeyHex),
signer: () => signer,
type: this.getSupportedVerificationType(),
type: 'Ed25519VerificationKey2018',
})
// overwrite the signer since we're not passing the private key and transmute doesn't support that behavior
verificationKey.signer = () => signer as any
Expand Down
7 changes: 4 additions & 3 deletions packages/credential-ld/src/suites/Ed25519Signature2020.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,9 @@ const debug = Debug('veramo:credential-ld:Ed25519Signature2020')
* @alpha This API is experimental and is very likely to change or disappear in future releases without notice.
*/
export class VeramoEd25519Signature2020 extends VeramoLdSignature {
getSupportedVerificationType(): string {
return 'Ed25519VerificationKey2020'
getSupportedVerificationType(): string[] {
return ['Ed25519VerificationKey2020', 'Ed25519VerificationKey2018']
// TODO: add support for ['JsonWebKey2020', 'Multikey']
}

getSupportedVeramoKeyType(): TKeyType {
Expand Down Expand Up @@ -72,7 +73,7 @@ export class VeramoEd25519Signature2020 extends VeramoLdSignature {
})
// overwrite the signer since we're not passing the private key
verificationKey.signer = () => signer as any
verificationKey.type = this.getSupportedVerificationType()
verificationKey.type = 'Ed25519VerificationKey2020'
return new Ed25519Signature2020({
key: verificationKey,
signer: signer,
Expand Down
5 changes: 3 additions & 2 deletions packages/credential-ld/src/suites/JsonWebSignature2020.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,9 @@ import {
* @alpha This API is experimental and is very likely to change or disappear in future releases without notice.
*/
export class VeramoJsonWebSignature2020 extends VeramoLdSignature {
getSupportedVerificationType(): 'JsonWebKey2020' {
getSupportedVerificationType(): string {
return 'JsonWebKey2020'
// TODO: add support for ['Ed25519VerificationKey2018', 'Ed25519VerificationKey2020', 'Multikey'] and others
}

getSupportedVeramoKeyType(): TKeyType {
Expand Down Expand Up @@ -59,7 +60,7 @@ export class VeramoJsonWebSignature2020 extends VeramoLdSignature {

const verificationKey = await JsonWebKey.from({
id: id,
type: this.getSupportedVerificationType(),
type: 'JsonWebKey2020',
controller: controller,
publicKeyJwk: {
kty: 'OKP',
Expand Down

0 comments on commit cde68aa

Please sign in to comment.