infra-template/cloudbuild.yaml (123 lines of code) (raw):
# Copyright 2022 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
steps:
- id: 'branch name'
name: 'alpine'
entrypoint: 'sh'
args:
- '-c'
- |
echo "***********************"
echo "$BRANCH_NAME"
echo "***********************"
- id: 'tf init'
name: 'hashicorp/terraform:1.0.0'
entrypoint: 'sh'
args:
- '-c'
- |
git config --global url."https://$$GITHUB_USER:$$GITHUB_TOKEN@github.com".insteadOf "https://github.com"
if [ -d "env/$BRANCH_NAME/" ]; then
cd env/$BRANCH_NAME
terraform init
else
for dir in env/*/
do
cd ${dir}
env=${dir%*/}
env=${env#*/}
echo ""
echo "*************** TERRAFORM INIT ******************"
echo "******* At environment: ${env} ********"
echo "*************************************************"
terraform init -no-color || exit 1
cd ../../
done
fi
secretEnv:
- GITHUB_TOKEN
- GITHUB_USER
- id: 'tf plan'
name: 'hashicorp/terraform:1.0.0'
entrypoint: 'sh'
args:
- '-c'
- |
export TF_VAR_github_user=$$GITHUB_USER
export TF_VAR_github_email=$$GITHUB_EMAIL
export TF_VAR_github_org=$$GITHUB_ORG
export TF_VAR_project_id=$PROJECT_ID
export TF_VAR_org_id=$$GCP_ORG
export TF_VAR_folder_id=$$GCP_FOLDER
export TF_VAR_billing_account=$$GCP_BILLINGAC
git config --global url."https://$$GITHUB_USER:$$GITHUB_TOKEN@github.com".insteadOf "https://github.com"
if [ -d "env/$BRANCH_NAME/" ]; then
cd env/$BRANCH_NAME
terraform plan
else
for dir in env/*/
do
cd ${dir}
env=${dir%*/}
env=${env#*/}
echo ""
echo "*************** TERRAFOM PLAN ******************"
echo "******* At environment: ${env} ********"
echo "*************************************************"
terraform plan -no-color || exit 1
cd ../../
done
fi
secretEnv:
- GITHUB_USER
- GITHUB_EMAIL
- GITHUB_ORG
- GCP_ORG
- GCP_FOLDER
- GCP_BILLINGAC
- id: 'tf apply'
name: 'hashicorp/terraform:1.0.0'
entrypoint: 'sh'
args:
- '-c'
- |
export TF_VAR_github_user=$$GITHUB_USER
export TF_VAR_github_email=$$GITHUB_EMAIL
export TF_VAR_github_org=$$GITHUB_ORG
export TF_VAR_project_id=$PROJECT_ID
export TF_VAR_org_id=$$GCP_ORG
export TF_VAR_folder_id=$$GCP_FOLDER
export TF_VAR_billing_account=$$GCP_BILLINGAC
git config --global url."https://$$GITHUB_USER:$$GITHUB_TOKEN@github.com".insteadOf "https://github.com"
if [ -d "env/$BRANCH_NAME/" ]; then
cd env/$BRANCH_NAME
terraform apply -auto-approve -no-color
else
echo "***************************** SKIPPING APPLYING *******************************"
echo "Branch '$BRANCH_NAME' does not represent an oficial environment."
echo "*******************************************************************************"
fi
secretEnv:
- GITHUB_USER
- GITHUB_EMAIL
- GITHUB_ORG
- GCP_ORG
- GCP_FOLDER
- GCP_BILLINGAC
timeout: 1200s
availableSecrets:
secretManager:
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/github-token/versions/latest
env: GITHUB_TOKEN
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/github-user/versions/latest
env: GITHUB_USER
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/github-email/versions/latest
env: GITHUB_EMAIL
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/github-org/versions/latest
env: GITHUB_ORG
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/gcp-org/versions/latest
env: GCP_ORG
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/gcp-folder/versions/latest
env: GCP_FOLDER
- versionName: projects/YOUR_SECRET_PROJECT_ID/secrets/gcp-billingac/versions/latest
env: GCP_BILLINGAC
options:
logging: CLOUD_LOGGING_ONLY