mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-24 14:22:14 -05:00
b79f7d0c8c
* image: support OpenStack image build / upload * cli: add OpenStack terraform template * config: add OpenStack as CSP * versionsapi: add OpenStack as CSP * cli: add OpenStack as provider for `config generate` and `create` * disk-mapper: add basic support for boot on OpenStack * debugd: add placeholder for OpenStack * image: fix config file sourcing for image upload
42 lines
1.5 KiB
Bash
Executable File
42 lines
1.5 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Copyright (c) Edgeless Systems GmbH
|
|
#
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
set -euo pipefail
|
|
shopt -s inherit_errexit
|
|
|
|
if [[ -f ${CONFIG_FILE-} ]]; then
|
|
# shellcheck source=/dev/null
|
|
. "${CONFIG_FILE}"
|
|
fi
|
|
|
|
PK_FILE=${PKI}/PK.cer
|
|
KEK_FILES=${PKI}/KEK.cer,${PKI}/MicCorKEKCA2011_2011-06-24.crt
|
|
DB_FILES=${PKI}/db.cer,${PKI}/MicWinProPCA2011_2011-10-19.crt,${PKI}/MicCorUEFCA2011_2011-06-27.crt
|
|
|
|
gsutil mb -l "${GCP_REGION}" "gs://${GCP_BUCKET}" || true
|
|
gsutil pap set enforced "gs://${GCP_BUCKET}" || true
|
|
gsutil cp "${GCP_IMAGE_PATH}" "gs://${GCP_BUCKET}/${GCP_IMAGE_FILENAME}"
|
|
gcloud compute images create "${GCP_IMAGE_NAME}" \
|
|
"--family=${GCP_IMAGE_FAMILY}" \
|
|
"--source-uri=gs://${GCP_BUCKET}/${GCP_IMAGE_FILENAME}" \
|
|
"--guest-os-features=GVNIC,SEV_CAPABLE,VIRTIO_SCSI_MULTIQUEUE,UEFI_COMPATIBLE" \
|
|
"--platform-key-file=${PK_FILE}" \
|
|
"--key-exchange-key-file=${KEK_FILES}" \
|
|
"--signature-database-file=${DB_FILES}" \
|
|
"--project=${GCP_PROJECT}"
|
|
gcloud compute images add-iam-policy-binding "${GCP_IMAGE_NAME}" \
|
|
"--project=${GCP_PROJECT}" \
|
|
--member='allAuthenticatedUsers' \
|
|
--role='roles/compute.imageUser'
|
|
gsutil rm "gs://${GCP_BUCKET}/${GCP_IMAGE_FILENAME}"
|
|
|
|
image_reference=$(gcloud compute images describe "${GCP_IMAGE_NAME}" \
|
|
--project "${GCP_PROJECT}" \
|
|
'--format=value(selfLink.scope(v1))')
|
|
json=$(jq -ncS \
|
|
--arg image_reference "${image_reference}" \
|
|
'{"gcp": {"sev-es": $image_reference}}')
|
|
echo -n "${json}" > "${GCP_JSON_OUTPUT}"
|