@digitalcredentials/vpqr
v2.2.1
Published
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.
Downloads
366
Readme
Verifiable Presentations to QR Code JS Lib (@digitalcredentials/vpqr)
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.
Table of Contents
Background
(Forked from digitalbazaar/vpqr
v2.1
to provide TypeScript and ReactNative compatibility.)
Security
TBD
Install
- Node.js 12+ is required.
To install locally (for development):
git clone https://github.com/digitalcredentials/vpqr.git
cd vpqr
npm install
Usage
Encoding Verifiable Presentations as QR Code Images
import vpqr from '@digitalcredentials/vpqr';
const vp = {
"@context": "https://www.w3.org/2018/credentials/v1",
"type": "VerifiablePresentation",
"verifiableCredential": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://w3id.org/cit/v1",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"id": "urn:uuid:188e8450-269e-11eb-b545-d3692cf35398",
"type": [
"VerifiableCredential",
"ConcealedIdTokenCredential"
],
"issuer": "did:key:z6Mku2yHBpMvm13KqtupN7MNEj7Y7AREUWsFfGBRhyP9YZf7",
"issuanceDate": "2021-03-24T20:03:03Z",
"expirationDate": "2021-06-24T20:03:03Z",
"credentialSubject": {
"concealedIdToken": "zo58FV8vqzY2ZqLT4fSaVhe7CsdBKsUikBMbKridqSyc7LceLmgWcNTeHm2gfvgjuNjrVif1G2A5EKx2eyNkSu5ZBc6gNnjF8ZkV3P8dPrX8o46SF"
},
"proof": {
"type": "Ed25519Signature2020",
"created": "2021-03-24T20:03:03Z",
"verificationMethod": "did:key:z6Mku2yHBpMvm13KqtupN7MNEj7Y7AREUWsFfGBRhyP9YZf7#z6Mku2yHBpMvm13KqtupN7MNEj7Y7AREUWsFfGBRhyP9YZf7",
"proofPurpose": "assertionMethod",
"proofValue": "z5Z33Pi9zWUWMHdxhG1Ko7ssgeHsuT3ocyg46pJTTjbwk1YjjtSCa4CQ5UyjnkQ6ar5ohY5Kv2mncWbfgEqWcVrTQ"
}
}
};
// Set up your documentLoader
const documentLoader = {/*...*/};
const {imageDataUrl} = await vpqr.toQrCode({vp, documentLoader});
// ...
When these QR Codes are scanned, they are read as Alphanumeric mode text,
VP1-B3ECQDIYBCEMDGEAYG2UADAYRCV4DA2DUORYHGOR...
in the format:
<format and version, 'VP1-'><multibase prefix, 'B'><base32 RFC4648 (no padding) encoded CBORLD>
Decoding QR Code Text to Verifiable Presentation
// Alphanumeric text from a QR Code Reader lib
const qrCodeText = 'VP1-B3ECQDIYBCEMDGEAYG2UADAYRCV4DA2DUORYHGOR...';
// Set up your documentLoader
const documentLoader = {/*...*/};
const {vp} = await vqpr.fromQrCode({text: qrCodeText, documentLoader});
// { "@context": "https://www.w3.org/2018/credentials/v1", ... }
// becomes a JSON object with the VP in the example above.
Contribute
See the contribute file!
PRs accepted.
If editing the Readme, please conform to the standard-readme specification.
License
- MIT License - DCC - TypeScript compatibility.
- New BSD License (3-clause) © 2021 Digital Bazaar - Initial implementation.