pyvckit/README.md

155 lines
4.6 KiB
Markdown
Raw Permalink Normal View History

2024-05-28 15:38:27 +00:00
# PyVckit
PyVckit is a library for:
- sign verifiable credentials
- verify verifiable credentials
- generate verifiable presentations
- verify verifiable submissions
This library is strongly inspired by [SpruceId didkit](https://github.com/spruceid/didkit) and aims to maintain compatibility with it.
For now the supported cryptography is only EdDSA with a signature Ed25519Signature2018.
# Install
For now the installation is from the repository:
```sh
python -m venv env
source env/bin/activate
git clone https://gitea.pangea.org/ereuse/pyvckit.git
cd pyvckit
pip install -r requirements.txt
pip install -e .
```
2024-05-30 09:12:04 +00:00
# Cli
2024-05-28 15:38:27 +00:00
The mode of use under the command line would be the following:
## generate a key pair:
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/did.py -n keys > keypair.json
2024-05-28 15:38:27 +00:00
```
## generate a did identifier:
2024-05-30 09:12:04 +00:00
### did key
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/did.py -n did -k keypair.json
2024-05-30 09:12:04 +00:00
```
### did web
2024-05-28 15:38:27 +00:00
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/did.py -n did -k keypair.json -u https://localhost/user1/dids/
2024-05-28 15:38:27 +00:00
```
## generate an example signed credential:
An example of a credential is generated, which is the one that appears in the credential_tmpl template in the file [templates.py](templates.py)
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/sign_vc.py -k keypair.json > credential_signed.json
2024-05-28 15:38:27 +00:00
```
## verify a signed credential:
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/verify_vc.py credential_signed.json
2024-05-28 15:38:27 +00:00
```
## generate a verifiable presentation:
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/sign_vp.py -k keypair.json -c credential_signed.json > presentation_signed.json
2024-05-28 15:38:27 +00:00
```
## verify a verifiable presentation:
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/verify_vp.py presentation_signed.json
2024-05-28 15:38:27 +00:00
```
2024-05-30 09:18:22 +00:00
## creation of did document:
This command will create a json document and a url path where to place this document. The did must be a web did.
This document is an example and in production it must be adapted to contain the revoked verifiable credentials.
```sh
2024-06-03 15:53:58 +00:00
python pyvckit/did.py -k keypair.json -g did:web:localhost:did-registry:z6MkiNc8xqJLcG7QR1wzD9HPs5oPQEaWNcVf92QsbppNiB7C
2024-05-30 09:18:22 +00:00
```
2024-05-30 09:12:04 +00:00
# Use as a library
2024-05-28 15:38:27 +00:00
In the tests you can find examples of use. Now I will explain the usual cases
## generate a key pair:
```python
from pyvckit.did import generate_keys
key = generate_keys()
```
## generate a did identifier:
2024-05-30 09:12:04 +00:00
### did key
2024-05-28 15:38:27 +00:00
```python
from pyvckit.did import generate_keys, generate_did
key = generate_keys()
did = generate_did(key)
```
2024-05-30 09:12:04 +00:00
### did web
```python
from pyvckit.did import generate_keys, generate_did
key = generate_keys()
url = "https://localhost/user1/dids/"
did = generate_did(key, url)
```
2024-05-28 15:38:27 +00:00
## generate a signed credential:
Assuming **credential** is a valid credential.
**credential** is a string variable
```python
from pyvckit.did import generate_keys, generate_did, get_signing_key
from pyvckit.sign_vc import sign
key = generate_keys()
did = generate_did(key)
signing_key = get_signing_key(key)
vc = sign(credential, signing_key, did)
```
## verify a signed credential:
Assuming **vc** is a properly signed verifiable credential
```python
import json
from pyvckit.verify import verify_vc
verified = verify_vc(json.dumps(vc))
```
## generate a verifiable presentation:
```python
from pyvckit.did import generate_keys, generate_did, get_signing_key
from pyvckit.sign_vp import sign_vp
holder_key = generate_keys()
holder_did = generate_did(holder_key)
holder_signing_key = get_signing_key(holder_key)
vp = sign_vp(holder_signing_key, holder_did, vc_string)
```
## verify a verifiable presentation:
```python
from pyvckit.verify_vp import verify_vp
verified = verify_vp(json.dumps(vp))
```
2024-05-30 09:12:04 +00:00
## creation of did document:
This command will create a json document and a url path where to place this document. The did must be a web did.
This document is an example and in production it must be adapted to contain the revoked verifiable credentials.
```python
from pyvckit.did import generate_keys, generate_did, gen_did_document
key = generate_keys()
url = "https://localhost/did-registry"
did = generate_did(key, url)
definitive_url, document = gen_did_document(did, key)
```
2024-06-06 08:36:42 +00:00
# Differences with didkit from spruceId:
Although there is didkit support, there are some small differences in behavior.
## Namespaces:
In didkit it is necessary to define in the context every name, (key) used in the credential or else both the signature and the verification will fail.
In pyvckit if a name, (key) is used but is not defined in the context, then that signature or verification will filter out that part of the credential and ignore it as if it did not exist.
The signature will be made by deleting that undefined part.