Django wrapper for a cloud-based Hyperledger Indy Agency for community applications.
This library provides a cloud-based framework for developing Hyperledger Indy Agent applications. This platform supports agents for both individuals and organizations in a single platform, as well as provides the ability to interact with stand-alone agents. This library currently supports the VCX agent protocol, however a future version will support the interoperable Indy Catalyst agent (https://github.com/bcgov/indy-catalyst/tree/master/agent).
Note that this library is in early development stage. It s suitable for developing a demonstration or POC but not (yet) for production applications.
- Easy-to-use wrapper/api around Indy libraries libindy and libvcx
- Supports multiple organizations/roles in a single deployment
- Easy registration process to create new users, organizations and agents
- Admin functions to load schemas, organizations and credential definitions
- Built-in UI, can be extended for business-specific functions (see demo)
The following features are planned:
- REST API (and demo application using vue.js)
- Integration of BC Government Indy Catalyst Python Agent
- "Hyperledger Composer"-like application for generating an application framework
- Additional business demos
- Video tutorials
This repository can be run as a stand-alone application to demonstrate Indy and Agent capabilities. This requires local Indy libraries, as well as a running set of Indy nodes.
There are two ways to accomplish this, to run the demo application:
- As a fully contained docker build
- By installing and running all dependencies locally
Both are described (along with docker scripts) here.
If you run the Docker-ized version, these steps are part of the application startup.
There are two Admin commands available to "seed" organizations, schemas and credential definitions:
python manage.py loads_orgs <orgs yml file>
python manage.py loads_schemas <schemas yml file> <org id>
An organization (with an identity on the network) is required to load schemas. Once schemas are loaded, credential definitions will automatically be created for organizations with matching roles (org role matches schema role). So, for example, the Docker-ised application runs the following on startup:
python manage.py loads_orgs ./trustee-org.yml
python manage.py loads_schemas ./test-schemas.yml 1
python manage.py loads_orgs ./test-orgs.yml
Once the organizations, schemas etc. are created, open 2 shells and run the following in each shell (note that this is done automatically within the Docker version):
python manage.py runserver
python manage.py process_tasks
You can login to the Django Admin application to inspect the data populated in the application database - https://localhost:8000/admin (admin@mail.com/pass1234)
You can also view the ledger browser (http://localhost:9000/) and inspect the Indy ledger objects created.
- Connect to the application http://localhost:8000/
2a. (Optional) Click on the "Create Organization Account" link at the bottom of the page
2b. (Optional) Enter user and organization information, enter a role matching one of the schema roles
2c. Login as your organization user (or use one of the pre-loaded organizations)
3a. In a separate browser, click on the "Create Individual Account" link at the bottom of the page
3b. Enter user information
3c. Login as your user
You should now have two sessions, one as an organization and one as a user.
-
Connect to the application http://localhost:8000/
-
As the Organization, click on the Connections tab and then click on "Send Connection Invite". Enter the user's email (from the previous step) and Submit
-
As the User, click on the Connections tab, there should be a Pending connection. Click on "Respond" and then "Submit"
-
Back to the Organization - click on "Check Status" and then "Submit"
At this point, both parties should have an Active connection to each other.
TBD include additional descriptions, and a link to a video tutorial