-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy path3-client-demo.sh
executable file
·56 lines (42 loc) · 1.81 KB
/
3-client-demo.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#!/bin/bash
# Copyright (c) Microsoft Corporation.
# Licensed under the MIT License.
### Client script to submit a claim to the SCITT ledger and verify the receipt
set -e
# Variables
: "${COSE_CLAIMS_PATH:?"variable not set. Please define the path to the COSE claim to register into the ledger"}"
: "${OUTPUT_FOLDER:?"variable not set. Please define the output folder to use to store script artifacts"}"
SCITT_URL=${SCITT_URL:-"https://127.0.0.1:8000"}
# Create output folder
mkdir -p "$OUTPUT_FOLDER"
echo -e "\nSetting up environment"
if [ ! -f "venv/bin/activate" ]; then
python3.8 -m venv "venv"
fi
# Activate environment and install pyscitt local library
source venv/bin/activate
pip install --disable-pip-version-check -q -e ./pyscitt
# Get service parameters
echo -e "\nGetting service parameters"
SERVICE_PARAMS_FOLDER="$OUTPUT_FOLDER"/service_params
mkdir -p "$SERVICE_PARAMS_FOLDER"
# Get historic parameters to populate the trust store with all the previous service identities
# This is useful to verify entries that have been committed with a previous service identity (e.g., prior to a CCF disaster recovery)
curl -k -f "$SCITT_URL"/parameters/historic > "$SERVICE_PARAMS_FOLDER"/scitt.json
echo -e "\nSubmitting claim to the ledger and getting receipt for the committed transaction"
RECEIPT_FOLDER="$OUTPUT_FOLDER"/receipts
mkdir -p "$RECEIPT_FOLDER"
RECEIPT_PATH="$RECEIPT_FOLDER"/embedded.receipt.cose
# Submit signed claim
scitt submit "$COSE_CLAIMS_PATH" \
--transparent-statement "$RECEIPT_PATH" \
--url "$SCITT_URL" \
--development
# Preview receipt
echo -e "\nViewing embedded receipt content"
scitt pretty-receipt "$RECEIPT_PATH"
# Verify receipt
echo -e "\nVerifying receipt"
scitt validate "$RECEIPT_PATH" \
--service-trust-store "$SERVICE_PARAMS_FOLDER"
echo -e "\nScript completed successfully"