Skip to content

Commit

Permalink
feat: add fake did method usable in tests
Browse files Browse the repository at this point in the history
  • Loading branch information
mirceanis committed Jul 5, 2021
1 parent 6f01df3 commit 4fc587c
Show file tree
Hide file tree
Showing 8 changed files with 233 additions and 4 deletions.
3 changes: 3 additions & 0 deletions __tests__/localAgent.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ import didManager from './shared/didManager'
import didComm from './shared/didcomm'
import messageHandler from './shared/messageHandler'
import didDiscovery from './shared/didDiscovery'
import { FakeDidProvider, FakeDidResolver } from './utils/fake-did'

const databaseFile = 'local-database.sqlite'
const infuraProjectId = '5ffc47f65c4042ce847ef66a3fa70d4c'
Expand Down Expand Up @@ -130,13 +131,15 @@ const setup = async (options?: IAgentOptions): Promise<boolean> => {
'did:key': new KeyDIDProvider({
defaultKms: 'local',
}),
'did:fake': new FakeDidProvider(),
},
}),
new DIDResolverPlugin({
resolver: new Resolver({
...ethrDidResolver({ infuraProjectId }),
...webDidResolver(),
...getDidKeyResolver(),
...new FakeDidResolver(() => agent).getDidFakeResolver(),
}),
}),
new DataStore(dbConnection),
Expand Down
3 changes: 3 additions & 0 deletions __tests__/localMemoryStoreAgent.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ import keyManager from './shared/keyManager'
import didManager from './shared/didManager'
import didComm from './shared/didcomm'
import messageHandler from './shared/messageHandler'
import { FakeDidProvider, FakeDidResolver } from './utils/fake-did'

const databaseFile = 'local-database2.sqlite'
const infuraProjectId = '5ffc47f65c4042ce847ef66a3fa70d4c'
Expand Down Expand Up @@ -118,13 +119,15 @@ const setup = async (options?: IAgentOptions): Promise<boolean> => {
'did:key': new KeyDIDProvider({
defaultKms: 'local',
}),
'did:fake': new FakeDidProvider(),
},
}),
new DIDResolverPlugin({
resolver: new Resolver({
...ethrDidResolver({ infuraProjectId }),
...webDidResolver(),
...getDidKeyResolver(),
...new FakeDidResolver(() => agent).getDidFakeResolver(),
}),
}),
new DataStore(dbConnection),
Expand Down
6 changes: 5 additions & 1 deletion __tests__/restAgent.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
IDataStore,
IMessageHandler,
IAgentOptions,
TAgent,
} from '../packages/core/src'
import { MessageHandler } from '../packages/message-handler/src'
import { KeyManager } from '../packages/key-manager/src'
Expand Down Expand Up @@ -45,6 +46,7 @@ import { getResolver as ethrDidResolver } from 'ethr-did-resolver'
import { getResolver as webDidResolver } from 'web-did-resolver'
import { IDIDDiscovery, DIDDiscovery } from '../packages/did-discovery'
import { getUniversalResolver } from '../packages/did-resolver/src/universal-resolver'
import { FakeDidProvider, FakeDidResolver } from './utils/fake-did'

import fs from 'fs'

Expand Down Expand Up @@ -137,13 +139,15 @@ const setup = async (options?: IAgentOptions): Promise<boolean> => {
'did:key': new KeyDIDProvider({
defaultKms: 'local',
}),
'did:fake': new FakeDidProvider(),
},
}),
new DIDResolverPlugin({
resolver: new Resolver({
...ethrDidResolver({ infuraProjectId }),
...webDidResolver(),
key: getUniversalResolver(), // resolve using remote resolver
key: getUniversalResolver(), // resolve using remote resolver,
...new FakeDidResolver(() => serverAgent as TAgent<IDIDManager>).getDidFakeResolver(),
}),
}),
new DataStore(dbConnection),
Expand Down
2 changes: 1 addition & 1 deletion __tests__/shared/didManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ export default (testContext: {

it('should get providers', async () => {
const providers = await agent.didManagerGetProviders()
expect(providers).toEqual(['did:ethr', 'did:ethr:rinkeby', 'did:web', 'did:key'])
expect(providers).toEqual(['did:ethr', 'did:ethr:rinkeby', 'did:web', 'did:key', 'did:fake'])
})

let identifier: IIdentifier
Expand Down
66 changes: 65 additions & 1 deletion __tests__/shared/resolveDid.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { IDIDManager } from '@veramo/core'
import { TAgent, IResolver, IAgentOptions } from '../../packages/core/src'

type ConfiguredAgent = TAgent<IResolver>
type ConfiguredAgent = TAgent<IResolver & IDIDManager>

export default (testContext: {
getAgent: (options?: IAgentOptions) => ConfiguredAgent
Expand Down Expand Up @@ -30,6 +31,69 @@ export default (testContext: {
expect(didDoc?.id).toEqual(didUrl)
})

it('should resolve imported fake did', async () => {
const did = 'did:fake:myfakedid'
const importedFakeDID = await agent.didManagerImport({
did,
keys: [
{
type: 'Ed25519',
kid: 'fake-key-1',
publicKeyHex: '1fe9b397c196ab33549041b29cf93be29b9f2bdd27322f05844112fad97ff92a',
privateKeyHex:
'b57103882f7c66512dc96777cbafbeb2d48eca1e7a867f5a17a84e9a6740f7dc1fe9b397c196ab33549041b29cf93be29b9f2bdd27322f05844112fad97ff92a',
kms: 'local',
},
],
services: [
{
id: 'fake-service-1',
type: 'fakeService',
serviceEndpoint: 'http://it.is.fake.all.the.way.down',
},
],
provider: 'did:fake',
alias: 'faker',
})
const resolved = await agent.resolveDid({ didUrl: did })
expect(resolved.didDocument).toEqual({
id: 'did:fake:myfakedid',
service: [
{
id: 'did:fake:myfakedid#fake-service-1',
type: 'fakeService',
serviceEndpoint: 'http://it.is.fake.all.the.way.down',
},
],
verificationMethod: [
{
type: 'Ed25519VerificationKey2018',
publicKeyHex: '1fe9b397c196ab33549041b29cf93be29b9f2bdd27322f05844112fad97ff92a',
kms: 'local',
controller: 'did:fake:myfakedid',
id: 'did:fake:myfakedid#fake-key-1',
},
],
keyAgreement: ['did:fake:myfakedid#fake-key-1'],
authentication: ['did:fake:myfakedid#fake-key-1'],
assertionMethod: ['did:fake:myfakedid#fake-key-1'],
})
})

it('should resolve created fake did', async () => {
const alias = 'allfake'
const did = `did:fake:${alias}`
const createdDID = await agent.didManagerCreate({ alias, provider: 'did:fake' })
const modified = await agent.didManagerAddService({
did,
service: { id: 'fake-service-x', type: 'FakeService', serviceEndpoint: 'none' },
})
const resolved = await agent.resolveDid({ didUrl: did })
expect(resolved?.didDocument?.service).toEqual([
{ id: `${did}#fake-service-x`, type: 'FakeService', serviceEndpoint: 'none' },
])
})

it('should return an error for unsupported did methods', async () => {
expect.assertions(1)
await expect(agent.resolveDid({ didUrl: 'did:foo:bar' })).resolves.toEqual({
Expand Down
146 changes: 146 additions & 0 deletions __tests__/utils/fake-did.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
import { IAgentContext, IKeyManager, IIdentifier, IKey, IService, IDIDManager } from '@veramo/core'
import { AbstractIdentifierProvider } from '../../packages/did-manager/src/index'
import {
DIDResolutionOptions,
DIDResolutionResult,
DIDResolver,
Resolvable,
ParsedDID,
VerificationMethod,
} from 'did-resolver'
import { TAgent } from '@veramo/core/src'
import { _NormalizedVerificationMethod } from '../../packages/did-comm/src'

/**
* A DID method that uses the information stored by the DID manager to resolve
*/
export class FakeDidProvider extends AbstractIdentifierProvider {
private defaultKms: string

constructor({ defaultKms }: { defaultKms: string } = { defaultKms: 'local' }) {
super()
this.defaultKms = defaultKms
}

async createIdentifier(
{ kms, alias, options }: { kms?: string; alias?: string; options?: any },
context: IAgentContext<IKeyManager>,
): Promise<Omit<IIdentifier, 'provider'>> {
const key = await context.agent.keyManagerCreate({
kms: kms || this.defaultKms,
type: options?.type || 'Secp256k1',
})

const identifier: Omit<IIdentifier, 'provider'> = {
did: 'did:fake:' + alias,
controllerKeyId: key.kid,
keys: [key],
services: [],
}
return identifier
}

async deleteIdentifier(identifier: IIdentifier, context: IAgentContext<IKeyManager>): Promise<boolean> {
for (const { kid } of identifier.keys) {
await context.agent.keyManagerDelete({ kid })
}
return true
}

async addKey(
{ identifier, key, options }: { identifier: IIdentifier; key: IKey; options?: any },
context: IAgentContext<IKeyManager>,
): Promise<any> {
return { success: true }
}

async addService(
{ identifier, service, options }: { identifier: IIdentifier; service: IService; options?: any },
context: IAgentContext<IKeyManager>,
): Promise<any> {
return { success: true }
}

async removeKey(
args: { identifier: IIdentifier; kid: string; options?: any },
context: IAgentContext<IKeyManager>,
): Promise<any> {
return { success: true }
}

async removeService(
args: { identifier: IIdentifier; id: string; options?: any },
context: IAgentContext<IKeyManager>,
): Promise<any> {
return { success: true }
}
}

export class FakeDidResolver {
getAgent: () => TAgent<IDIDManager>

constructor(getAgent: () => TAgent<IDIDManager>) {
this.getAgent = getAgent
}

resolveFakeDid: DIDResolver = async (
didUrl: string,
_parsed: ParsedDID,
_resolver: Resolvable,
options: DIDResolutionOptions,
): Promise<DIDResolutionResult> => {
try {
const agent = this.getAgent()
const identifier = await agent.didManagerGet({ did: _parsed.did })
const did = _parsed.did
const verificationMethod: VerificationMethod[] = identifier.keys.map((key) => {
const vm: _NormalizedVerificationMethod = { ...key, controller: did, id: `${did}#${key.kid}` }
switch (key.type) {
case 'Secp256k1':
vm.type = 'EcdsaSecp256k1VerificationKey2019'
break
case 'Ed25519':
vm.type = 'Ed25519VerificationKey2018'
break
case 'X25519':
vm.type = 'X25519KeyAgreementKey2019'
break
default:
break
}
const { meta, description, kid, ...result } = vm as any
return result
})
const vmIds = verificationMethod.map((vm) => vm.id)
const service = identifier.services.map(service => {
service.id = `${did}#${service.id}`
delete service.description
return service
})

const didResolution: DIDResolutionResult = {
didResolutionMetadata: {},
didDocument: {
id: did,
service,
verificationMethod,
keyAgreement: vmIds,
authentication: vmIds,
assertionMethod: vmIds,
},
didDocumentMetadata: {},
}
return didResolution
} catch (err) {
return {
didDocumentMetadata: {},
didResolutionMetadata: { error: 'invalidDid', message: err.toString() },
didDocument: null,
}
}
}

getDidFakeResolver() {
return { fake: this.resolveFakeDid.bind(this) }
}
}
1 change: 0 additions & 1 deletion packages/did-provider-key/src/resolver.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import { resolver } from '@transmute/did-key.js'
import { DIDDocument } from '@veramo/core'
import { DIDResolutionOptions, DIDResolutionResult, DIDResolver, ParsedDID, Resolvable } from 'did-resolver'

const resolve: DIDResolver = async (
Expand Down
10 changes: 10 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2926,6 +2926,11 @@
"@types/keygrip" "*"
"@types/node" "*"

"@types/debug@4.1.5":
version "4.1.5"
resolved "https://registry.yarnpkg.com/@types/debug/-/debug-4.1.5.tgz#b14efa8852b7768d898906613c23f688713e02cd"
integrity sha512-Q1y515GcOdTHgagaVFhHnIFQ38ygs/kmxdNpvpou+raI9UO3YZcHDngBSYKQklcKlvA7iuQlmIKbzvmxcOE9CQ==

"@types/debug@4.1.6":
version "4.1.6"
resolved "https://registry.yarnpkg.com/@types/debug/-/debug-4.1.6.tgz#0b7018723084918a865eff99249c490505df2163"
Expand Down Expand Up @@ -11983,6 +11988,11 @@ typeorm@0.2.34:
yargs "^16.2.0"
zen-observable-ts "^1.0.0"

typescript@4.3.4:
version "4.3.4"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.3.4.tgz#3f85b986945bcf31071decdd96cf8bfa65f9dcbc"
integrity sha512-uauPG7XZn9F/mo+7MrsRjyvbxFpzemRjKEZXS4AK83oP2KKOJPvb+9cO/gmnv8arWZvhnjVOXz7B49m1l0e9Ew==

typescript@4.3.5, typescript@~4.3.4:
version "4.3.5"
resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.3.5.tgz#4d1c37cc16e893973c45a06886b7113234f119f4"
Expand Down

0 comments on commit 4fc587c

Please sign in to comment.