Skip to content

Commit

Permalink
Merge pull request #1007 from bcgov/bcgov/chore/rpc
Browse files Browse the repository at this point in the history
chore: RPC plugin integration
  • Loading branch information
swcurran authored Feb 15, 2024
2 parents 035a20f + 5be8b94 commit fcc696f
Show file tree
Hide file tree
Showing 13 changed files with 62 additions and 56 deletions.
69 changes: 34 additions & 35 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
# Traction
# Traction

![Traction Logo](./docs/assets/readme-logo.png)

[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](LICENSE) [![Lifecycle:Maturing](https://img.shields.io/badge/Lifecycle-Maturing-007EC6)](<Redirect-URL>) [![Maintainability](https://api.codeclimate.com/v1/badges/e6df50041dd4373c7e15/maintainability)](https://codeclimate.com/github/bcgov/traction/maintainability)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](LICENSE) [![Lifecycle:Maturing](https://img.shields.io/badge/Lifecycle-Maturing-007EC6)](<Redirect-URL>) [![Maintainability](https://api.codeclimate.com/v1/badges/e6df50041dd4373c7e15/maintainability)](https://codeclimate.com/github/bcgov/traction/maintainability)


## Table of Contents
## Table of Contents

- [What is Traction?](#what-is-traction)
- [Start using Traction](#start-using-traction)
Expand All @@ -17,54 +17,54 @@
- [Engage with the community](#engage-with-the-community)


## What is Traction?

## What is Traction?
Traction is a digital wallet solution comprised of plugins layered on top of Hyperledger Aries Cloud Agent Python (ACA-Py) and streamlines the process of sending and receiving digital credentials for governments and organizations.

Traction is a digital wallet solution comprised of plugins layered on top of Hyperledger Aries Cloud Agent Python (ACA-Py) and streamlines the process of sending and receiving digital credentials for governments and organizations.

Its open-source foundation makes it easy to integrate digital trust technology into existing lines of business applications, without having to stand up, maintain and manage an instance of ACA-Py themselves. Future functionality could include machine-readable governance and more.
Its open-source foundation makes it easy to integrate digital trust technology into existing lines of business applications, without having to stand up, maintain and manage an instance of ACA-Py themselves. Future functionality could include machine-readable governance and more.

![Arch Diagram](./docs/assets/traction-flow-chart-1600x900-12162022-01.jpg)

## Play in the Traction Sandbox

Establish your own Traction tenant in a B.C. Government sandbox to issue, hold, present, and verify digital credentials using these [setup instructions](./docs/traction-anoncreds-workshop.md).
Establish your own Traction tenant in a B.C. Government sandbox to issue, hold, present, and verify digital credentials using these [setup instructions](./docs/traction-anoncreds-workshop.md).

**Disclaimer**: On the 1st and 15th of each month, the entire sandbox gets reset and all your work will be gone.

**Disclaimer**: On the 1st and 15th of each month, the entire sandbox gets reset and all your work will be gone.
## Start using Traction

## Start using Traction
**Running Traction**: to run a local instance of traction, see the documentation in [scripts](./scripts/README.md).

**Running Traction**: to run a local instance of traction, see the documentation in [scripts](./scripts/README.md).
**Deploying Traction**: Helm charts for deploying Traction to Kubernetes: [charts](./charts/README.md).

**Deploying Traction**: Helm charts for deploying Traction to Kubernetes: [charts](./charts/README.md).

## What are the benefits of using Traction?

## What are the benefits of using Traction?
Traction makes it easier to integrate digital trust technology into existing line of business applications.

Traction makes it easier to integrate digital trust technology into existing line of business applications.
- **API-first Architecture**: Traction is designed with an API-first architecture, this RESTful API allows for integration into existing line-of-business applications already being used by organizations, the Tenant user interface is built on this API to enable adoption prior to integration and for low-use functions.
- **Enhanced Interoperability**: Hyperledger Aries makes Traction more broadly compatible with existing technologies used by governments and organizations around the world.
- **Multi-tenancy**: Rather than having multiple digital tools to integrate with organizations, one scalable instance of Traction can be used to participate in the digital trust ecosystem, control all connections, and more easily share data.
- **Higher Scalability**: Traction is open-source technology, encouraging collaborative refinement, faster release, and higher scalability.

- **API-first Architecture**: Traction is designed with an API-first architecture, this RESTful API allows for integration into existing line-of-business applications already being used by organizations, the Tenant user interface is built on this API to enable adoption prior to integration and for low-use functions.
- **Enhanced Interoperability**: Hyperledger Aries makes Traction more broadly compatible with existing technologies used by governments and organizations around the world.
- **Multi-tenancy**: Rather than having multiple digital tools to integrate with organizations, one scalable instance of Traction can be used to participate in the digital trust ecosystem, control all connections, and more easily share data.
- **Higher Scalability**: Traction is open-source technology, encouraging collaborative refinement, faster release, and higher scalability.

## What is Traction comprised of?

## What is Traction comprised of?
- [ACA-Py + plugins](./plugins/README.md)
- [Tenant UI](./services/tenant-ui/README.md)
- [Endorser Services](./services/endorser/README.md)

- [ACA-Py + plugins](./plugins/README.md)
- [Tenant UI](./services/tenant-ui/README.md)
- [Endorser Services](./services/endorser/README.md)

## Start contributing to Traction

## Start contributing to Traction
Traction is an open-source technology project that welcomes collaboration.

Traction is an open-source technology project that welcomes collaboration.
If you would like to contribute to Traction, please review the following:

If you would like to contribute to Traction, please review the following:
- [Contributing](./CONTRIBUTING.md)
- [Code of Conduct](./CODE_OF_CONDUCT.md)
- [Compliance](./COMPLIANCE.yaml)

- [Contributing](./CONTRIBUTING.md)
- [Code of Conduct](./CODE_OF_CONDUCT.md)
- [Compliance](./COMPLIANCE.yaml)

## Developers: devcontainers
To aid in developers, there are 2 `devcontainers`: [plugins](./plugins/.devcontainer/devcontainer.json) and [tenant-ui](./services/tenant-ui/.devcontainer/devcontainer.json).
Expand Down Expand Up @@ -95,7 +95,6 @@ Note that Tenant Proxy and Traction DB are started via docker compose when start
### Repository workflow
Currently authorized users can create a branch and run a pull request to merge in changes. Unauthorized can always create a fork.


#### Rebasing of a branch
```bash
git fetch --all
Expand All @@ -105,22 +104,22 @@ git rebase origin/main
git push --force
```

## Who is maintaining Traction?
## Who is maintaining Traction?
[The Province of British Columbia](https://github.com/bcgov/) is maintaining Traction as an open-source project.

Maintainer(s):
Maintainer(s):
- Jason Sherman
- Jason Syrotuck
- Lucas O'Neil
- Jamie Popkin

## How is Traction licensed?
## How is Traction licensed?

Traction is licensed under Apache License 2.0 which can be reviewed [here](./LICENSE).
Traction is licensed under Apache License 2.0 which can be reviewed [here](./LICENSE).


## Engage with the community
## Engage with the community

Connect with others
- on Discord: [EMDT Public Discord Channel](https://discord.com/channels/766403442599657522/854432442382680104)
- on Discord: [EMDT Public Discord Channel](https://discord.com/channels/766403442599657522/854432442382680104)
- for Aries discussion see the Hyperlerger Aries Github [participation section](https://github.com/hyperledger/aries#project-participation)
1 change: 1 addition & 0 deletions charts/traction/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,7 @@ kubectl delete secret,pvc --selector "app.kubernetes.io/instance"=my-release
| `acapy.plugins.connectionUpdate` | Enable the connection update plugin. | `true` |
| `acapy.plugins.multitenantProvider` | Enable the multitenant provider plugin. | `true` |
| `acapy.plugins.tractionInnkeeper` | Enable the traction innkeeper plugin. | `true` |
| `acapy.plugins.rpc` | Enable the RPC plugin. | `true` |

### Acapy Plugin Configuration

Expand Down
3 changes: 3 additions & 0 deletions charts/traction/templates/acapy/deployment.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,9 @@ spec:
{{- end }}
{{- if .Values.acapy.plugins.multitenantProvider }}
--plugin multitenant_provider.v1_0 \
{{- end }}
{{- if .Values.acapy.plugins.rpc }}
--plugin rpc.v1_0 \
{{- end }}
"
]
Expand Down
2 changes: 2 additions & 0 deletions charts/traction/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -198,12 +198,14 @@ acapy:
## @param acapy.plugins.connectionUpdate Enable the connection update plugin.
## @param acapy.plugins.multitenantProvider Enable the multitenant provider plugin.
## @param acapy.plugins.tractionInnkeeper Enable the traction innkeeper plugin.
## @param acapy.plugins.rpc Enable the RPC plugin.
##
plugins:
basicmessageStorage: true
connectionUpdate: true
multitenantProvider: true
tractionInnkeeper: true
rpc: true

## @section Acapy Plugin Configuration
## Specify configuration values for each plugin.
Expand Down
1 change: 1 addition & 0 deletions plugins/demo/configs/default.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ plugin:
- basicmessage_storage.v1_0
- connection_update.v1_0
- multitenant_provider.v1_0
- rpc.v1_0

# block-plugin:

Expand Down
1 change: 1 addition & 0 deletions plugins/demo/configs/devcontainer.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ plugin:
- basicmessage_storage.v1_0
- connection_update.v1_0
- multitenant_provider.v1_0
- rpc.v1_0

# block-plugin:

Expand Down
3 changes: 2 additions & 1 deletion plugins/docker/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ COPY --chown=aries:aries traction_innkeeper/traction_innkeeper traction_plugins/
RUN pip install git+https://github.com/hyperledger/aries-acapy-plugins@main#subdirectory=basicmessage_storage
RUN pip install git+https://github.com/hyperledger/aries-acapy-plugins@main#subdirectory=connection_update
RUN pip install git+https://github.com/hyperledger/aries-acapy-plugins@main#subdirectory=multitenant_provider
RUN pip install git+https://github.com/hyperledger/aries-acapy-plugins@main#subdirectory=rpc

ENTRYPOINT ["/bin/bash", "-c", "aca-py \"$@\"", "--"]
CMD ["start", "--arg-file", "default.yml"]
CMD ["start", "--arg-file", "default.yml"]
4 changes: 0 additions & 4 deletions plugins/docker/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,18 +3,14 @@ This will contain the dockerfile that we will build our acapy + plugins image
Lots to do here to clean up where the plugin code comes from etc...
This uses the plugins/pyproject.toml to specify a new project that includes the (local) plugins as dependencies, should probably pull in versioned ones.


The dockerfile is copying over the local plugins code, but should it? Probably should be pulling in versioned code.


### developer notes

- install python 3.6.13
- install poetry version 1.1.15
- the base docker image is python 3.6.13, so best to develop using that version



### build and run
```
cd docker
Expand Down
1 change: 1 addition & 0 deletions plugins/docker/default.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ plugin:
- connection_update.v1_0
- multitenant_provider.v1_0
- traction_plugins.traction_innkeeper.v1_0
- rpc.v1_0


plugin-config-value:
Expand Down
1 change: 1 addition & 0 deletions scripts/.env-example
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ ACAPY_GENESIS_TRANSACTIONS_LIST=ledgers.yml
ACAPY_READ_ONLY_LEDGER=false

ACAPY_ADMIN_API_KEY=change-me
ACAPY_ADMIN_INSECURE_MODE=false

ACAPY_AUTO_ACCEPT_INVITES=true
ACAPY_AUTO_ACCEPT_REQUESTS=true
Expand Down
Loading

0 comments on commit fcc696f

Please sign in to comment.