2024-02-29 13:57:26 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
set -eo pipefail
|
|
|
|
|
|
|
|
usage() {
|
2024-02-29 15:40:58 +00:00
|
|
|
echo "Usage: $0 <REQUEST> <REQUEST_MSG>"
|
2024-02-29 13:57:26 +00:00
|
|
|
echo " <REQUEST>: Instantiate | SessionCreate | SessionSetPubKey"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
IAS_API_KEY="669244b3e6364b5888289a11d2a1726d"
|
|
|
|
RA_CLIENT_SPID="51CAF5A48B450D624AEFE3286D314894"
|
2024-05-13 13:50:29 +00:00
|
|
|
QUOTE_FILE="/tmp/${USER}_test.quote"
|
|
|
|
REPORT_FILE="/tmp/${USER}_datareport"
|
|
|
|
REPORT_SIG_FILE="/tmp/${USER}_datareportsig"
|
2024-02-29 13:57:26 +00:00
|
|
|
|
|
|
|
REQUEST="$1"
|
2024-02-29 15:40:58 +00:00
|
|
|
REQUEST_MSG=${2:-"{}"}
|
2024-02-29 13:57:26 +00:00
|
|
|
|
|
|
|
# clear tmp files from previous runs
|
|
|
|
rm -f "$QUOTE_FILE" "$REPORT_FILE" "$REPORT_SIG_FILE"
|
|
|
|
|
|
|
|
# query the gRPC quartz enclave service
|
2024-02-29 15:40:58 +00:00
|
|
|
ATTESTED_MSG=$(grpcurl -plaintext -import-path ../../utils/quartz-proto/proto/ -proto quartz.proto -d "$REQUEST_MSG" '127.0.0.1:11090' quartz.Core/"$REQUEST" | jq -c '.message | fromjson')
|
2024-02-29 13:57:26 +00:00
|
|
|
|
|
|
|
# parse out the quote and the message
|
|
|
|
QUOTE=$(echo "$ATTESTED_MSG" | jq -c '.quote')
|
|
|
|
MSG=$(echo "$ATTESTED_MSG" | jq 'del(.quote)')
|
|
|
|
|
|
|
|
# request the IAS report for EPID attestations
|
|
|
|
echo -n "$QUOTE" | xxd -r -p - > "$QUOTE_FILE"
|
|
|
|
gramine-sgx-ias-request report -g "$RA_CLIENT_SPID" -k "$IAS_API_KEY" -q "$QUOTE_FILE" -r "$REPORT_FILE" -s "$REPORT_SIG_FILE" > /dev/null 2>&1
|
|
|
|
REPORT=$(cat "$REPORT_FILE")
|
|
|
|
REPORTSIG=$(cat "$REPORT_SIG_FILE" | tr -d '\r')
|
|
|
|
|
|
|
|
#echo "$QUOTE"
|
|
|
|
#echo "$REPORT"
|
|
|
|
#echo "$REPORTSIG"
|
|
|
|
|
|
|
|
case "$REQUEST" in
|
|
|
|
"Instantiate")
|
|
|
|
jq -nc --argjson msg "$MSG" --argjson "attestation" \
|
|
|
|
"$(jq -nc --argjson report "$(jq -nc --argjson report "$REPORT" --arg reportsig "$REPORTSIG" '$ARGS.named')" '$ARGS.named')" \
|
|
|
|
'$ARGS.named' ;;
|
|
|
|
|
|
|
|
"SessionCreate" | "SessionSetPubKey")
|
|
|
|
REQUEST_KEY=$(echo "$REQUEST" | sed 's/\([A-Z]\)/_\L\1/g;s/^_//')
|
|
|
|
jq -nc --argjson quartz "$(jq -nc --argjson "$REQUEST_KEY" "$(jq -nc --argjson msg "$MSG" --argjson attestation \
|
|
|
|
"$(jq -nc --argjson report "$(jq -nc --argjson report "$REPORT" --arg reportsig "$REPORTSIG" '$ARGS.named')" '$ARGS.named')" \
|
|
|
|
'$ARGS.named')" '$ARGS.named')" '$ARGS.named' ;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
usage ;;
|
|
|
|
esac
|