This project was developed to demonstrate how the Key Event Receipt Infrastructure (KERI) protocol can sign and verify an arbitrary electronic document by utilizing a browser extension.
The projects has two components a document signer web application and a verifier server.
This project is dependent on:
- Polaris browser extension: a light-weight KERI browser extensions. This extension will be published in Chrome Web Store and Firefox Browser Add-ons.
- Polaris web: a frontend companion library to the Polaris browser extension, which utilizes Signify-TS. Polaris web must be installed on a frontend application that utilizes the Polaris browser extension.
The document signer is a simple React application that allows users to upload any file, which will then be signed using the KERI protocol using the Polaris browser extension. Below is an overview of the key functionalities provided by the document signer:
- A user upload a file, e.g.,
filename.ext
, whereext
is the file extension. - A Blake3 digest of the file is computed, encoded as a Base64 CESR string, which is 44-character log starting with
E
for Blake3. - The digest is submitted to the Polaris browser extension.
- The user chooses an autonomic identifier (AID) to sign the document and click a confirm button.
- The digest of the document is anchored to the AID's key event log (KEL).
- The browser returns
filename.ext.cesr
the document signer, which contains the entire CESR stream for verifying the document with the KERI protocol. - The document signer create a zip file, called
filename-digest={DIGEST}.zip
, that containsfilename.ext
,filename.ext.cesr
, andREADME.txt
. The README only provides description of the zip file and is not involved in the signing and verification. - The user downloads the zip file.
- The user re-uploads the zip file, which is sent to the verifier server for verification.
Note that {DIGEST}
in the zip file must not be changed as it is required during verification below.
The document signer requires installation of the Polaris web in package.json
signify-polaris-web
.
"signify-polaris-web": "https://github.com/WebOfTrust/polaris-web.git"
A verifier server is a backend application using the Falcon framework. It is loosely based on the vLEI verifier GLEIF-IT/vlei-verifier. Below is an overview of the key functionalities provided by the verifier server:
- The verifier receives a
filename-digest={DIGEST}.zip
from the document signer application. - The verifier unzips the zip file to obtain
filename.ext
andfilename.ext.cesr
- The verifier compute the Base64-CESR-encoded Blake3 digest of
filename.ext
. - The digest is checked if it matches the zip's filename.
- The
filename.ext.cesr
is verified using KERIpy's parser. - The digest is checked if it matches the digest of the ACDC in the CESR file.
- The verification result is returned to the document signer.
Note: the verifier server currently does not support duplicity detection. Duplicitous but valid KELs in the CESR file will be verified and accepted.
Signing a document using the KERI protocol results in issuance of an authentic chained data container (ACDC). This project the data attestation credential scehma for signing documents. Its attribute contains the Base64-CESR-encoded digest of the document.
The data attestation credential could be optionally chained to another ACDC to provide a chain of trust of the signer to the document. For example, the credential could be chained to a Official Organization Role (OOR) or Engagement Context Role (ECR) vLEI credentials to provide a organizational chain of trust and assert that the document has been signed by an authorized organization representative.