2022-07-13 08:04:46 -04:00
|
|
|
name: Constellation measure
|
|
|
|
description: |
|
|
|
|
Create measurements of a Constellation cluster and print to stdout.
|
|
|
|
Optionally sign and/or upload to S3, if corresponding inputs are provided.
|
|
|
|
inputs:
|
|
|
|
cloudProvider:
|
|
|
|
description: "Either 'gcp' or 'azure'."
|
|
|
|
required: true
|
|
|
|
cosignPublicKey:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "Cosign public key"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
cosignPrivateKey:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "Cosign private key"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
cosignPassword:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "Password for Cosign private key"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
awsAccessKeyID:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "AWS access key ID to upload measurements"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
awsSecretAccessKey:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "AWS secret access key to upload measurements"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
awsDefaultRegion:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "AWS region of S3 bucket to upload measurements"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
awsBucketName:
|
2022-09-02 06:44:20 -04:00
|
|
|
description: "S3 bucket name to upload measurements to"
|
2022-07-13 08:04:46 -04:00
|
|
|
required: false
|
2022-09-02 06:44:20 -04:00
|
|
|
default: ""
|
2022-07-13 08:04:46 -04:00
|
|
|
runs:
|
2022-09-02 06:44:20 -04:00
|
|
|
using: "composite"
|
2022-07-13 08:04:46 -04:00
|
|
|
steps:
|
2022-08-23 07:43:20 -04:00
|
|
|
- name: Build hack/pcr-reader
|
|
|
|
run: |
|
|
|
|
go build .
|
|
|
|
echo "$(pwd)" >> $GITHUB_PATH
|
|
|
|
working-directory: hack/pcr-reader
|
|
|
|
shell: bash
|
|
|
|
|
2022-07-13 08:04:46 -04:00
|
|
|
# Check /docs/secure_software_distribution.md#sign-measurements
|
|
|
|
# for why we ignore certain measurement values.
|
|
|
|
- name: Fetch PCRs
|
|
|
|
run: |
|
2022-07-25 05:07:21 -04:00
|
|
|
KUBECONFIG="$PWD/constellation-admin.conf" kubectl rollout status ds/verification-service -n kube-system --timeout=3m
|
2022-07-20 04:47:22 -04:00
|
|
|
CONSTELL_IP=$(jq -r ".bootstrapperhost" constellation-state.json)
|
|
|
|
pcr-reader --constell-ip ${CONSTELL_IP} -format yaml > measurements.yaml
|
2022-07-13 08:04:46 -04:00
|
|
|
case $CSP in
|
|
|
|
azure)
|
|
|
|
yq e 'del(.[0,6,10,11,12,13,14,15,16,17,18,19,20,21,22,23])' -i measurements.yaml
|
|
|
|
;;
|
|
|
|
gcp)
|
|
|
|
yq e 'del(.[11,12,13,14,15,16,17,18,19,20,21,22,23])' -i measurements.yaml
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
cat measurements.yaml
|
|
|
|
shell: bash
|
|
|
|
env:
|
|
|
|
CSP: ${{ inputs.cloudProvider }}
|
|
|
|
|
|
|
|
# TODO: Replace with https://github.com/sigstore/sigstore-installer/tree/initial
|
|
|
|
# once it has the functionality
|
|
|
|
- name: Install Cosign
|
2022-10-19 04:29:37 -04:00
|
|
|
uses: sigstore/cosign-installer@9becc617647dfa20ae7b1151972e9b3a2c338a2b # tag=v2.8.1
|
2022-07-13 08:04:46 -04:00
|
|
|
if: ${{ inputs.cosignPublicKey != '' && inputs.cosignPrivateKey != '' && inputs.cosignPassword != '' }}
|
|
|
|
- name: Install Rekor
|
|
|
|
run: |
|
2022-09-14 10:23:09 -04:00
|
|
|
curl -sLO https://github.com/sigstore/rekor/releases/download/v0.12.0/rekor-cli-linux-amd64
|
2022-07-13 08:04:46 -04:00
|
|
|
sudo install rekor-cli-linux-amd64 /usr/local/bin/rekor-cli
|
2022-09-13 05:28:00 -04:00
|
|
|
rm rekor-cli-linux-amd64
|
2022-07-13 08:04:46 -04:00
|
|
|
shell: bash
|
|
|
|
if: ${{ inputs.cosignPublicKey != '' && inputs.cosignPrivateKey != '' && inputs.cosignPassword != '' }}
|
|
|
|
- name: Sign measurements
|
|
|
|
run: |
|
|
|
|
echo "$COSIGN_PUBLIC_KEY" > cosign.pub
|
|
|
|
# Enabling experimental mode also publishes signature to Rekor
|
|
|
|
COSIGN_EXPERIMENTAL=1 cosign sign-blob --key env://COSIGN_PRIVATE_KEY measurements.yaml > measurements.yaml.sig
|
|
|
|
# Verify - As documentation & check
|
|
|
|
# Local Signature (input: artifact, key, signature)
|
|
|
|
cosign verify-blob --key cosign.pub --signature measurements.yaml.sig measurements.yaml
|
|
|
|
# Transparency Log Signature (input: artifact, key)
|
|
|
|
uuid=$(rekor-cli search --artifact measurements.yaml | tail -n 1)
|
|
|
|
sig=$(rekor-cli get --uuid=$uuid --format=json | jq -r .Body.HashedRekordObj.signature.content)
|
|
|
|
cosign verify-blob --key cosign.pub --signature <(echo $sig) measurements.yaml
|
|
|
|
shell: bash
|
|
|
|
env:
|
|
|
|
COSIGN_PUBLIC_KEY: ${{ inputs.cosignPublicKey }}
|
|
|
|
COSIGN_PRIVATE_KEY: ${{ inputs.cosignPrivateKey }}
|
|
|
|
COSIGN_PASSWORD: ${{ inputs.cosignPassword }}
|
|
|
|
if: ${{ inputs.cosignPublicKey != '' && inputs.cosignPrivateKey != '' && inputs.cosignPassword != '' }}
|
|
|
|
|
|
|
|
- name: Upload to S3
|
|
|
|
run: |
|
|
|
|
IMAGE=$(yq e ".provider.${CSP}.image" constellation-conf.yaml)
|
|
|
|
S3_PATH=s3://${PUBLIC_BUCKET_NAME}/${IMAGE}
|
|
|
|
aws s3 cp measurements.yaml ${S3_PATH}/measurements.yaml
|
|
|
|
if test -f measurements.yaml.sig; then
|
|
|
|
aws s3 cp measurements.yaml.sig ${S3_PATH}/measurements.yaml.sig
|
|
|
|
fi
|
|
|
|
shell: bash
|
|
|
|
env:
|
|
|
|
AWS_ACCESS_KEY_ID: ${{ inputs.awsAccessKeyID }}
|
|
|
|
AWS_SECRET_ACCESS_KEY: ${{ inputs.awsSecretAccessKey }}
|
|
|
|
AWS_DEFAULT_REGION: ${{ inputs.awsDefaultRegion }}
|
|
|
|
PUBLIC_BUCKET_NAME: ${{ inputs.awsBucketName }}
|
|
|
|
CSP: ${{ inputs.cloudProvider }}
|
|
|
|
if: ${{ inputs.awsAccessKeyID != '' && inputs.awsSecretAccessKey != '' && inputs.awsDefaultRegion != '' && inputs.awsBucketName != '' }}
|