2023-08-23 10:39:49 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
# Try to upload a file to S3 and then delete it using the configapi cli.
|
|
|
|
# Check the file exists after uploading it.
|
|
|
|
# Check the file does not exist after deleting it.
|
|
|
|
|
|
|
|
###### script header ######
|
|
|
|
|
|
|
|
lib=$(realpath @@BASE_LIB@@) || exit 1
|
|
|
|
stat "${lib}" >> /dev/null || exit 1
|
|
|
|
|
2023-08-31 04:46:50 -04:00
|
|
|
# shellcheck source=../../../../../bazel/sh/lib.bash
|
2023-08-23 10:39:49 -04:00
|
|
|
if ! source "${lib}"; then
|
|
|
|
echo "Error: could not find import"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
configapi_cli=$(realpath @@CONFIGAPI_CLI@@)
|
|
|
|
stat "${configapi_cli}" >> /dev/null
|
2023-09-25 05:53:02 -04:00
|
|
|
configapi_cli="${configapi_cli} --testing"
|
2023-08-23 10:39:49 -04:00
|
|
|
###### script body ######
|
|
|
|
|
|
|
|
readonly region="eu-west-1"
|
|
|
|
readonly bucket="resource-api-testing"
|
|
|
|
|
|
|
|
tmpdir=$(mktemp -d)
|
|
|
|
readonly tmpdir
|
|
|
|
registerExitHandler "rm -rf $tmpdir"
|
|
|
|
|
2023-09-25 05:53:02 -04:00
|
|
|
# empty the bucket version state
|
|
|
|
${configapi_cli} delete recursive --region "$region" --bucket "$bucket"
|
|
|
|
|
|
|
|
# the high version numbers ensure that it's newer than the current latest value
|
2023-10-17 11:36:50 -04:00
|
|
|
readonly current_report_path="$tmpdir/currentSnpReport.json"
|
|
|
|
cat << EOF > "$current_report_path"
|
2023-09-25 05:53:02 -04:00
|
|
|
{
|
2023-10-17 11:36:50 -04:00
|
|
|
"snp_report": {
|
|
|
|
"reported_tcb": {
|
|
|
|
"bootloader": 1,
|
|
|
|
"tee": 1,
|
|
|
|
"snp": 1,
|
|
|
|
"microcode": 1
|
|
|
|
},
|
|
|
|
"committed_tcb": {
|
|
|
|
"bootloader": 1,
|
|
|
|
"tee": 1,
|
|
|
|
"snp": 1,
|
|
|
|
"microcode": 1
|
|
|
|
},
|
|
|
|
"launch_tcb": {
|
|
|
|
"bootloader": 1,
|
|
|
|
"tee": 1,
|
|
|
|
"snp": 1,
|
|
|
|
"microcode": 1
|
|
|
|
}
|
2023-09-25 05:53:02 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
# upload a fake latest version for the fetcher
|
2023-10-17 11:36:50 -04:00
|
|
|
${configapi_cli} --force --snp-report-path "$current_report_path" --upload-date "2000-01-01-01-01" --region "$region" --bucket "$bucket"
|
2023-09-25 05:53:02 -04:00
|
|
|
|
|
|
|
# the high version numbers ensure that it's newer than the current latest value
|
2023-10-17 11:36:50 -04:00
|
|
|
readonly report_path="$tmpdir/snpReport.json"
|
|
|
|
cat << EOF > "$report_path"
|
2023-08-23 10:39:49 -04:00
|
|
|
{
|
2023-10-17 11:36:50 -04:00
|
|
|
"snp_report": {
|
|
|
|
"reported_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 255
|
|
|
|
},
|
|
|
|
"committed_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 255
|
|
|
|
},
|
|
|
|
"launch_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 255
|
|
|
|
}
|
2023-08-23 10:39:49 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
2023-09-25 05:53:02 -04:00
|
|
|
# has an older version
|
2023-10-17 11:36:50 -04:00
|
|
|
readonly older_report_path="$tmpdir/snpReportOld.json"
|
|
|
|
cat << EOF > "$older_report_path"
|
2023-09-25 05:53:02 -04:00
|
|
|
{
|
2023-10-17 11:36:50 -04:00
|
|
|
"snp_report": {
|
|
|
|
"reported_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 254
|
|
|
|
},
|
|
|
|
"committed_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 254
|
|
|
|
},
|
|
|
|
"launch_tcb": {
|
|
|
|
"bootloader": 255,
|
|
|
|
"tee": 255,
|
|
|
|
"snp": 255,
|
|
|
|
"microcode": 254
|
|
|
|
}
|
2023-09-25 05:53:02 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
# report 3 versions with different dates to fill the reporter cache
|
|
|
|
readonly date_oldest="2023-02-01-03-04"
|
2023-10-17 11:36:50 -04:00
|
|
|
${configapi_cli} --snp-report-path "$older_report_path" --upload-date "$date_oldest" --region "$region" --bucket "$bucket" --cache-window-size 3
|
2023-09-25 05:53:02 -04:00
|
|
|
readonly date_older="2023-02-02-03-04"
|
2023-10-17 11:36:50 -04:00
|
|
|
${configapi_cli} --snp-report-path "$older_report_path" --upload-date "$date_older" --region "$region" --bucket "$bucket" --cache-window-size 3
|
2023-09-25 05:53:02 -04:00
|
|
|
readonly date="2023-02-03-03-04"
|
2023-10-17 11:36:50 -04:00
|
|
|
${configapi_cli} --snp-report-path "$report_path" --upload-date "$date" --region "$region" --bucket "$bucket" --cache-window-size 3
|
2023-08-23 10:39:49 -04:00
|
|
|
|
2023-09-25 05:53:02 -04:00
|
|
|
# expect that $date_oldest is served as latest version
|
2023-08-23 10:39:49 -04:00
|
|
|
baseurl="https://d33dzgxuwsgbpw.cloudfront.net/constellation/v1/attestation/azure-sev-snp"
|
2023-09-25 05:53:02 -04:00
|
|
|
if ! curl -fsSL ${baseurl}/${date_oldest}.json > version.json; then
|
|
|
|
echo "Checking for uploaded version file constellation/v1/attestation/azure-sev-snp/${date_oldest}.json: request returned ${?}"
|
2023-08-23 10:39:49 -04:00
|
|
|
exit 1
|
|
|
|
fi
|
2023-09-25 05:53:02 -04:00
|
|
|
# check that version values are equal to expected
|
|
|
|
if ! cmp -s <(echo -n '{"bootloader":255,"tee":255,"snp":255,"microcode":254}') version.json; then
|
|
|
|
echo "The version content:"
|
|
|
|
cat version.json
|
|
|
|
echo " is not equal to the expected version content:"
|
|
|
|
echo '{"bootloader":255,"tee":255,"snp":255,"microcode":254}'
|
2023-08-23 10:39:49 -04:00
|
|
|
exit 1
|
|
|
|
fi
|
2023-09-25 05:53:02 -04:00
|
|
|
if ! curl -fsSL ${baseurl}/${date_oldest}.json.sig > /dev/null; then
|
|
|
|
echo "Checking for uploaded version signature file constellation/v1/attestation/azure-sev-snp/${date_oldest}.json.sig: request returned ${?}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
# check list endpoint
|
|
|
|
if ! curl -fsSL ${baseurl}/list > list.json; then
|
2023-08-23 10:39:49 -04:00
|
|
|
echo "Checking for uploaded list file constellation/v1/attestation/azure-sev-snp/list: request returned ${?}"
|
|
|
|
exit 1
|
|
|
|
fi
|
2023-09-25 05:53:02 -04:00
|
|
|
# check that version values are equal to expected
|
|
|
|
if ! cmp -s <(echo -n '["2023-02-01-03-04.json","2000-01-01-01-01.json"]') list.json; then
|
|
|
|
echo "The list content:"
|
|
|
|
cat list.json
|
|
|
|
echo " is not equal to the expected version content:"
|
|
|
|
echo '["2023-02-01-03-04.json","2000-01-01-01-01.json"]'
|
|
|
|
exit 1
|
|
|
|
fi
|
2023-08-23 10:39:49 -04:00
|
|
|
|
2023-09-25 05:53:02 -04:00
|
|
|
# check that the other versions are not uploaded
|
|
|
|
http_code=$(curl -sSL -w '%{http_code}\n' -o /dev/null ${baseurl}/${date_older}.json)
|
2023-08-23 10:39:49 -04:00
|
|
|
if [[ $http_code -ne 404 ]]; then
|
2023-09-25 05:53:02 -04:00
|
|
|
echo "Expected HTTP code 404 for: constellation/v1/attestation/azure-sev-snp/${date_older}.json, but got ${http_code}"
|
2023-08-23 10:39:49 -04:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
http_code=$(curl -sSL -w '%{http_code}\n' -o /dev/null ${baseurl}/${date}.json.sig)
|
|
|
|
if [[ $http_code -ne 404 ]]; then
|
|
|
|
echo "Expected HTTP code 404 for: constellation/v1/attestation/azure-sev-snp/${date}.json, but got ${http_code}"
|
|
|
|
exit 1
|
|
|
|
fi
|
2023-09-25 05:53:02 -04:00
|
|
|
|
|
|
|
${configapi_cli} delete --version "$date_oldest" --region "$region" --bucket "$bucket"
|
|
|
|
|
|
|
|
# Omit -f to check for 404. We want to check that a file was deleted, therefore we expect the query to fail.
|
|
|
|
http_code=$(curl -sSL -w '%{http_code}\n' -o /dev/null ${baseurl}/${date_oldest}.json)
|
|
|
|
if [[ $http_code -ne 404 ]]; then
|
|
|
|
echo "Expected HTTP code 404 for: constellation/v1/attestation/azure-sev-snp/${date_oldest}.json, but got ${http_code}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
# Omit -f to check for 404. We want to check that a file was deleted, therefore we expect the query to fail.
|
|
|
|
http_code=$(curl -sSL -w '%{http_code}\n' -o /dev/null ${baseurl}/${date_oldest}.json.sig)
|
|
|
|
if [[ $http_code -ne 404 ]]; then
|
|
|
|
echo "Expected HTTP code 404 for: constellation/v1/attestation/azure-sev-snp/${date_oldest}.json, but got ${http_code}"
|
|
|
|
exit 1
|
|
|
|
fi
|