prepare_project.bash (91 lines of code) (raw):

#!/bin/bash # Copyright 2019 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. GREEN="\e[32m" RED="\e[31m" RESET="\e[0m" PROJECT=${PROJECT} print_usage() { echo -e ${RED?}'Usage: prepare_project [-h] [-p project_id]'${RESET?} echo -e ${RED?}' -h \t show this help usage'${RESET?} echo -e ${RED?}' -p \t GCP project_id to deploy to'${RESET?} } while getopts ':hp:' flag; do case "${flag}" in h) print_usage exit 1 ;; p) PROJECT="${OPTARG}" ;; *) echo -e ${RED?}'Unknown flag: -'${flag}${RESET?} print_usage exit 1 ;; esac done if [[ "${PROJECT}" == "" ]]; then echo -e ${RED?}'Must provide a project via $PROJECT or -p project'${RESET?} print_usage exit 1 fi PROJECT_NUMBER=$(gcloud projects list --filter="${PROJECT?}" --format="value(PROJECT_NUMBER)") if [[ "$?" != 0 ]]; then exit 1 fi echo -e ${GREEN?}'Preparing the GCP project '${PROJECT?}' for deployment.'${RESET?} # Enbable the required APIs. echo -e ${GREEN?}'Enabling the required APIs.'${RESET?} gcloud services enable --project=${PROJECT?}\ appengine.googleapis.com \ appengineflex.googleapis.com \ appenginestandard.googleapis.com \ sql-component.googleapis.com \ sqladmin.googleapis.com \ datastore.googleapis.com \ iam.googleapis.com \ cloudbuild.googleapis.com \ bigquery.googleapis.com \ storage-component.googleapis.com \ cloudkms.googleapis.com # Create a GAE app. gcloud app create --project=${PROJECT?} --region=us-central # Grant the required permissions. echo -e ${GREEN?}'Granting the required permissions.'${RESET?} gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:${PROJECT?}@appspot.gserviceaccount.com --role roles/cloudkms.cryptoKeyEncrypterDecrypter gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:${PROJECT?}@appspot.gserviceaccount.com --role roles/cloudkms.signerVerifier gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:${PROJECT?}@appspot.gserviceaccount.com --role roles/iam.serviceAccountTokenCreator gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:${PROJECT?}@appspot.gserviceaccount.com --role roles/logging.viewer gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:${PROJECT?}@appspot.gserviceaccount.com --role roles/logging.logWriter gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:service-${PROJECT_NUMBER?}@gae-api-prod.google.com.iam.gserviceaccount.com --role roles/cloudsql.client gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:service-${PROJECT_NUMBER?}@gae-api-prod.google.com.iam.gserviceaccount.com --role roles/editor gcloud projects add-iam-policy-binding -q ${PROJECT?} \ --member serviceAccount:service-${PROJECT_NUMBER?}@gae-api-prod.google.com.iam.gserviceaccount.com --role roles/resourcemanager.projectIamAdmin # TODO: make region configurable. # Create a datastore index to power related queries. gcloud datastore indexes create deploy/index.yaml --project=${PROJECT?} --quiet # Setup Cloud SQL # Create a CloudSQL db-f1-micro (memory=128M, disk=250G) postgres 11 instance in us-central-1. echo -e ${GREEN?}'Creating Cloud SQL database for Hydra.'${RESET?} gcloud sql instances create hydra --project=${PROJECT?} --database-version=POSTGRES_11 \ --tier=db-f1-micro --region=us-central1 --require-ssl # Create user: name="${NAME}", password="${PASSWORD}" gcloud sql users create hydra --project=${PROJECT?} --instance=hydra --password=hydra # Create database ic gcloud sql databases create ic --project=${PROJECT?} --instance=hydra # Create database dam gcloud sql databases create dam --project=${PROJECT?} --instance=hydra echo -e ${GREEN?}'Creating a GCS bucket with an example file.'${RESET?} gsutil mb -p ${PROJECT?} gs://${PROJECT?}-test-dataset tempdir=`mktemp -d` pushd $tempdir echo "This is an example" > example.txt gsutil cp -p=${PROJECT?} example.txt gs://${PROJECT?}-test-dataset gsutil uniformbucketlevelaccess set on gs://${PROJECT?}-test-dataset popd rm -rf $tempdir # Deploy a simple defaut app to GAE default service. echo -e ${GREEN?}'Deploy a helloworld to GAE default service.'${RESET?} tempdir=`mktemp -d` pushd $tempdir git clone https://github.com/GoogleCloudPlatform/golang-samples.git pushd golang-samples/appengine/go11x/helloworld gcloud app deploy --project=${PROJECT?} --version=master -q . popd popd rm -rf $tempdir echo -e ${GREEN?}'Building Base Hydra Docker Image.'${RESET?} mkdir -p ./deploy/build/hydra cp -R ./deploy/build-templates/hydra/* ./deploy/build/hydra/ sed -i 's/${YOUR_PROJECT_ID}/'${PROJECT?}'/g' ./deploy/build/hydra/Dockerfile gcloud builds submit --project=${PROJECT?} --config=deploy/build/hydra/cloudbuild.yaml . echo -e ${GREEN?}'Project preparation complete.'${RESET?}