Skip to main content

Resolve DIDs

Going forward, the hard part of getting started on with Veramo on react-native(expo) is already behind us. From now, guides should be much simpler: install plugins, use plugins.

In our previous step we saw how to configure a Veramo instance to generate DIDs for us. It's very likely that this Veramo instance will not live in an isolated box, but will rather have to work with other (de)centralized systems, which use their own DIDs. Let's see how to configure our Veramo instance to resolve these remote DIDs and obtain their corresponding DID documents. These documents will be used to get more information about those DIDs, like what keys they use for signing and/or encryption, what service endpoints can be used with them, etc.

How this works

DID resolution depends on the DID method being used. This means that the ability to resolve various DID types, we have to find implementations of these DID method drivers and use them. There are lots of DID methods out there, and the choice of DID method to use is out of scope for this guide. But, since we already saw how to create did:peer identifiers, let's see how to also resolve them to get the DID documents.

Installation

The veramo list of "core" packages contains a DID resolver plugin. This plugin is an aggregator of multiple DID method drivers. Let's install that plugin as well as a DID resolver for did:ethr. And to see how multiple DID methods can be supported, let's also add support for resolving did:web.

npm install @veramo/did-resolver web-did-resolver cross-fetch

Setup

Next, let's install these in our Veramo setup. First, we'll add these imports:

// filename: setup.ts

// imports:
// Core interfaces
import { IResolver } from '@veramo/core'

// Core DID resolver plugin. This plugin orchestrates different DID resolver drivers to resolve the corresponding DID Documents for the given DIDs.
// This plugin implements `IResolver`
import { DIDResolverPlugin } from '@veramo/did-resolver'

// the did:peer resolver package
import { getResolver as peerDidResolver } from '@veramo/did-provider-peer'
// the did:web resolver package
import { getResolver as webDidResolver } from 'web-did-resolver'

Then, let's add this plugin to the list of plugins given to createAgent:

// filename: setup.ts

// ... imports & CONSTANTS & DB setup

// Veramo agent setup
export const agent = createAgent<IDIDManager & IKeyManager & IDataStore & IDataStoreORM & IResolver>({
// we also add the IResolver plugin interface
plugins: [
//
// ... previously added plugins
//
new DIDResolverPlugin({
...peerDidResolver(), // and set it up to support `did:peer`
...webDidResolver(), // and `did:web`
}),
],
})

Usage

First we need to add a polyfill that enables fetch() in our app:

// filename: App.tsx
// shims
import 'cross-fetch/polyfill'

Let's add a method that will call the agent to resolve a DID.

// filename: App.tsx

// ... imports
import { DIDResolutionResult } from '@veramo/core'

const App = () => {
const [resolutionResult, setResolutionResult] = useState<DIDResolutionResult | undefined>()

// Resolve a DID
const resolveDID = async (did: string) => {
const result = await agent.resolveDid({ didUrl: did })
console.log(JSON.stringify(result, null, 2))
setResolutionResult(result)
}

// ... the rest of the App code

// Modify the return value of the `App` function to include space for the DID document like so:
return (
<SafeAreaView>
<ScrollView>
<View style={{ padding: 20 }}>
<Text style={{ fontSize: 30, fontWeight: 'bold' }}>Identifiers</Text>
<Button onPress={() => createIdentifier()} title={'Create Identifier'} />
<View style={{ marginBottom: 50, marginTop: 20 }}>
{identifiers && identifiers.length > 0 ? (
identifiers.map((id: IIdentifier) => (
<Button key={id.did} onPress={() => resolveDID(id.did)} title={id.did} />
))
) : (
<Text>No identifiers created yet</Text>
)}
</View>
<Text style={{ fontSize: 30, fontWeight: 'bold' }}>Resolved DID document:</Text>
<View style={{ marginBottom: 50, marginTop: 20 }}>
{resolutionResult ? (
<Text>{JSON.stringify(resolutionResult.didDocument, null, 2)}</Text>
) : (
<Text>tap on a DID to resolve it</Text>
)}
</View>
</View>
</ScrollView>
</SafeAreaView>
)
}

Recap

In this guide we:

  • installed a new Veramo plugin that can resolve DIDs,
  • installed drivers for 2 DID methods
  • used the new plugin to resolve some DIDs
  • displayed the resolved DID documents

Notes

It's unlikely that DID documents will need to be displayed like this in real-world apps, but it's worth getting an idea about how they look like.

Check out the next section to see how to create and verify Verifiable Credentials using Veramo.