Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tetraveda/abydos-tutorial
The ACDC schemas, configuration files, scripts, webhook, and documentation for the Abydos Treasure Hunting Expedition Navigators Assembly (ATHENA) tutorial
https://github.com/tetraveda/abydos-tutorial
Last synced: 2 months ago
JSON representation
The ACDC schemas, configuration files, scripts, webhook, and documentation for the Abydos Treasure Hunting Expedition Navigators Assembly (ATHENA) tutorial
- Host: GitHub
- URL: https://github.com/tetraveda/abydos-tutorial
- Owner: TetraVeda
- Created: 2023-03-09T12:39:13.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-10-27T03:26:02.000Z (3 months ago)
- Last Synced: 2024-10-27T04:27:26.245Z (3 months ago)
- Language: Shell
- Size: 12.3 MB
- Stars: 4
- Watchers: 1
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# [Abydos](https://en.wikipedia.org/wiki/Abydos,_Egypt) Tutorial
This is the companion repository for the *KERI Tutorial Series: Treasure Hunting in Abydos! Issuing and Verifying a Credential (ACDC)* blog article.
## Modes
1. KLI: Use the KERI Command Line to create witnesses, controllers, and issue credentials
```bash
./workflow.sh
```
2. Agents: Use KERI Agents to create controllers and issue credentials. Uses the KLI for witness creation.
```bash
./workflow.sh -a
```## Dependencies
- [kaslcred](https://pypi.org/project/kaslcred/) for generation of schemas
- [vLEI server (vLEI-server)](https://github.com/WebOfTrust/vLEI)
- [sally](https://github.com/kentbull/sally)See the [installation](#installation) section for a detailed dependency set up walkthrough.
## Installation
### Dependencies
- vLEI-server: https://github.com/WebOfTrust/vLEI
- sally (my fork): https://github.com/kentbull/sally### KASLCred
Install Kaslcred from PyPi like so:
```bash
python3 -m pip install kaslcred==0.1.6
```KASLCred depends on the following libraries being installed:
- KERIpy
- Rust: `curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y`
- Libsodium: `brew install libsodium`#### [KERIpy](https://github.com/WebOfTrust/keripy)
Install version 1.1.20 of KERIpy from PyPi:
you have to install from source like so:
```bash
python3 -m pip install keri==1.1.20
```KERIpy further depends on the following set of dependencies being installed:
- [Rust](#rust)
- [Libsodium](#libsodium)#### [Rust](https://www.rust-lang.org/tools/install)
Install with the typical script.
```bash
# the "-s -- -y" options are for a silent, unattended install. Omit them if you want to configure the install.
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y
# Remember to set the PATH variable to include the Cargo binary directory like so: PATH="$HOME/.cargo/bin:$PATH
```#### [Libsodium](https://libsodium.gitbook.io/doc/installation)
The Homebrew installation of Libsodium is not sufficient, or did not work for me. I had to do the following instructions like stated in Libsodium's Gitbook [Installation documentation](https://libsodium.gitbook.io/doc/installation) \
You need Libsodium on your PATH.\
Download a tarball of libsodium, preferably the latest stable version, then follow the ritual:
```bash
./configure
make && make check
sudo make install
```### vLEI-server
[//]: # (TODO: Add instructions for using Vessel to host ACDC schemas instead of vLEI-server.)
The vLEI-server binary is created from the [WebOfTrust/vLEI](https://github.com/WebOfTrust/vLEI) repository.\
Install it like so:
```bash
git clone https://github.com/WebOfTrust/vLEI.git
cd vLEI
python -m pip install -e ./
# installs the vLEI-server binary to your Python bin directory.
```### My fork of Sally
The [sally](https://github.com/kentbull/sally) component is a small credential handler wrapper on top of KERIpy.\
You could think of it as a custom controller.\
Make sure to download my fork at https://github.com/kentbull/sally.Sally depends on [KERIpy](#keripy) so all of KERIpy's dependencies must be installed including Rust and Libsodium.
Do not use the [GLEIF-IT/sally](https://github.com/GLEIF-IT/sally) upstream repository unless you want to write your own customizations.
If you end up writing a lot of customizations you may as well write your own custom controller from scratch using my fork and the GLEIF-IT sally as inspiration.
## References
- [wait-for](https://github.com/eficode/wait-for)## Troubleshooting
### Seeing the keri/cf/main directory created
This means you don't have the configuration directory properly set, or you may not be running the script from the root of this repository.
Make sure you are running the script from the root of the repository.
## Code Style
### Double quoting to prevent word splitting
Use `"${VARNAME}"` instead of `${VARNAME}`. See [SC2086](https://github.com/koalaman/shellcheck/wiki/SC2086)