When interacting with Verifiable Presentations, it is often useful to use QR codes.
For converting VPs to QRs, and vice versa, LearnCard leverages an open-source library from Digital Bazaar, :
An isomorphic JS (for Node.js and browser) library that takes a Verifiable Presentation, compresses it via CBOR-LD, and turns it into a QR Code.
There are several advantages to the VPQR approach:
Base-64 Image: for locally generated, transient QR codes.
CBOR-LD Compression: because VPs are JSON-LD, they can often be bloated with context files; VPQR handles compressing/expanding JSON-LD files for minimal QR data footprint.
Installation
pnpm i @learncard/vpqr-plugin
Use Cases
There are many use cases for converting between VPs & QR codes.
Issuing a Verifiable Credential to a subject: for example, check out the LearnCard Discord Bot, which sends a QR code as an attachment to an issued credential in a Discord message, allowing receivers to scan and claim the credential from any interoperable wallet.
//TODO: more examples
How to Convert a Verifiable Presentation into a QR code:
/**
* Returns a QR-embeddable data string from a VP
*/
VPtoQrCode: (vp: VP) => Promise<string>;
Then, the qrImage can be embedded in HTML like so:
<img src=""
alt="Test VP Embedded in QR Code" />
If you scan the QR code, you will get the following text:
How to Retrieve a Verifiable Presentation from a QR code:
/**
* Returns a VP from a QR code string.
*/
VPfromQrCode: (text: string) => Promise<VP>;
If you followed the steps in the previous section, to generate a QR code from a Verifiable Presentation, you should be able to scan a QR code and read a string like this: