Skip to content

Web SDK to embed SSI credential verification capabilities in existing applications.

License

Notifications You must be signed in to change notification settings

kiva/protocol-sdk-verifier

Repository files navigation

Protocol Verifier

Web SDK to embed SSI credential verification capabilities in existing applications.

Build Status

Before You Start

This SDK is designed to be flexible enough to accommodate either an Aries agent running locally on your machine, or a cloud agent. If you already have one of these set up, you can skip this section, but if you don't and would still like to try out the platform, keep reading.

An easy option for making the SDK work out of the box is to set up the Kiva Aries backend locally. You'll need to install Docker, but otherwise you should be able to follow the steps in our protocol-demo repo to get an agent running quickly.

Setting up your config file

This SDK relies on a configuration file (you can read more about why that's the case, and how the file is used, here), and for convenience's sake we've created a sample config that you can use to get started right away.

There's plenty of stuff you can do to customize your UI using the config, which you can read about here, but here are the important points for getting started.

  1. Modify controllerUrlBase to use the base URL for whatever endpoint you're using for a Cloud agent. By default, we are using http://localhost:3014, because that's the default port that the Kiva cloud agent uses when you're using the backend locally.
  2. If you are running a local agent on your machine, you can instead modify the agent_port config to point to the localhost port where your agent is running.

Getting Started

Ok, at last: How do you actually run this?

First step is to install the NPM dependencies, which you can do from the root directory of this repo by running:

npm install

If you plan on contributing to this repo, we ask that you set up the Git hook scripts included in the ./hooks directory in your local environment. This can be done by running:

npm run initHooks

Once that's done, you can build and serve a development version of the application using the get_started config file by running:

npm run start

If you've ever used the create-react-apps NPM package, this should feel pretty familiar.

Please note that, while the run start command uses get_started.json by default, you can easily change the configuration file you're using by running the following.

export CONF_FILE=path/to/your/config.json

To create an optimized build package, we recommend you run the following command.

npm run build

To serve the package locally, you can run

npm run serve-build

Creating a Production Bundle for Deployment

This SDK is designed to support multiple deployments using just one codebase, with environment-specific variables provided by a configuration file.

To run a deployment for a specific configuration file, you can run this command from the root directory of this repo.

sh ./tools/bundle/create_bundle.sh <YOUR CONFIG>

This will create a production bundle using react-scripts and will populate variables using the file specified by <YOUR CONFIG>.

Configuration files also support custom environments, though at the moment we only support environments with the following names: dev, qa, sandbox and prod. (We are currently working on making this support less restrictive.)

In order to build a bundle for a specific environment, you can run this command.

sh ./tools/bundle/create_bundle.sh <YOUR CONFIG> --<dev/sandbox/prod>

If no environment is specified, the default is qa.

Tests

This SDK has some pre-written functional tests that you should feel free to use once you have your cloud/local agent spun up and the application running in development mode (as outlined in the previous section).

You can get a more in-depth review of the testing framework here, but the TL;DR version is that we use Cypress for testing. The platform is free to use and can be run without creating an account.

To run these tests, simply run:

npm run cy:open

and then click which test you'd like to run. The Cypress platform should take care of the rest.

About

Web SDK to embed SSI credential verification capabilities in existing applications.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •