vetKeys API demo
Advanced
Tutorial
This demo provides a canister (src/system_api
) that offers the proposed vetKD system API, implemented demonstration, testing, and initial development purposes. We stress that it does not offer security yet as no threshold cryptography is used yet to secure the key.
This demo uses files found in this repository.
Prerequisites
- Download and install the IC SDK package as described in the installing the IC SDK page.
- Download and install npm.
- Download and install git.
Step 1: Begin by cloning the Github repository containing this project:
- Motoko
- rust
git clone https://github.com/dfinity/examples/
cd examples/motoko/vetkd
git clone https://github.com/dfinity/examples/
cd examples/rust/vetkd
Step 2: Then, start a local instance of the Internet Computer:
dfx start --clean --background
Step 3: Ensure the dfx uses the canister IDs that are hard-coded in the source code:
dfx canister create system_api --specified-id s55qq-oqaaa-aaaaa-aaakq-cai
Without this, the dfx may use different canister IDs for the system_api
and app_backend
canisters.
Step 4: Ensure that the required node modules are available in your project directory:
npm install
Step 5: Register, build and deploy the project:
dfx deploy
This command should finish successfully with output similar to the following one:
Deployed canisters.
URLs:
Frontend canister via browser
app_frontend_js: http://127.0.0.1:4943/?canisterId=by6od-j4aaa-aaaaa-qaadq-cai
Backend canister via Candid interface:
app_backend: http://127.0.0.1:4943/?canisterId=avqkn-guaaa-aaaaa-qaaea-cai&id=tcvdh-niaaa-aaaaa-aaaoa-cai
app_frontend: http://127.0.0.1:4943/?canisterId=avqkn-guaaa-aaaaa-qaaea-cai&id=b77ix-eeaaa-aaaaa-qaada-cai
system_api: http://127.0.0.1:4943/?canisterId=avqkn-guaaa-aaaaa-qaaea-cai&id=s55qq-oqaaa-aaaaa-aaakq-cai