Database restore #123
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Database restore | |
on: | |
workflow_dispatch: | |
inputs: | |
database_file_override: | |
description: "Path on S3 bucket to a specific database file to restore." | |
required: false | |
jobs: | |
restore-database: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Set env.BRANCH | |
run: | | |
echo "BRANCH=$(echo $GITHUB_REF | cut -d'/' -f 3)" >> $GITHUB_ENV | |
- name: Install basic dependancies | |
run: ./scripts/pipeline/deb-basic-deps.sh | |
- name: Install AWSCLI | |
run: ./scripts/pipeline/awscli-install.sh | |
- name: Install MySQL Client | |
run: ./scripts/pipeline/deb-mysql-client-install.sh | |
- name: Install Cloudfoundry CLI | |
run: ./scripts/pipeline/deb-cf-install.sh | |
- name: Cloud.gov login | |
env: | |
CF_USER: "${{ secrets.CF_USER }}" | |
CF_PASSWORD: "${{ secrets.CF_PASSWORD }}" | |
CF_ORG: "${{ secrets.CF_ORG }}" | |
PROJECT: "${{ secrets.PROJECT }}" | |
run: | | |
source ./scripts/pipeline/cloud-gov-login.sh | |
- name: Start Bastion | |
env: | |
DATABASE_BACKUP_BASTION_NAME: "${{ secrets.DATABASE_BACKUP_BASTION_NAME }}" | |
PROJECT: "${{ secrets.PROJECT }}" | |
run: | | |
echo "BRANCH=$(echo $GITHUB_REF | cut -d'/' -f 3)" >> $GITHUB_ENV | |
cf start "${PROJECT}-${DATABASE_BACKUP_BASTION_NAME}-${BRANCH}" #>/dev/null 2>&1 | |
./scripts/pipeline/cloud-gov-wait-for-app-start.sh "${PROJECT}-${DATABASE_BACKUP_BASTION_NAME}-${BRANCH}" | |
- name: Restore database | |
shell: bash | |
env: | |
CF_USER: "${{ secrets.CF_USER }}" | |
CF_PASSWORD: "${{ secrets.CF_PASSWORD }}" | |
CF_ORG: "${{ secrets.CF_ORG }}" | |
PROJECT: "${{ secrets.PROJECT }}" | |
DATABASE_BACKUP_BASTION_NAME: "${{ secrets.DATABASE_BACKUP_BASTION_NAME }}" | |
TEST_USER_PASS: "${{ secrets.TEST_USER_PASS }}" | |
TEST_USER_NAMES: "${{ secrets.TEST_USER_NAMES }}" | |
run: | | |
export S3_FILE_PATH=${{ github.event.inputs.database_file_override }} | |
source ./scripts/pipeline/s3-backup-download.sh | |
source ./scripts/pipeline/database-restore.sh | |
# Split the USERS_LIST into an array | |
IFS=',' read -ra users <<< "${TEST_USER_NAMES}" | |
# Generate the password reset commands | |
password_reset_commands="" | |
for user in "${users[@]}"; do | |
password_reset_commands+="drush user:password $user \"TU_PASS\"\n" | |
done | |
# Make replacement in the drush post deploy with user change password commands | |
sed -i "s|### USER_PASSWORD_RESET_PLACEHOLDER ###|$password_reset_commands|" ./scripts/drush-post-deploy.sh | |
# Set the test user's passwords to the value of the github secret value for TEST_USER_PASS. | |
sed -i "s#TU_PASS#${TEST_USER_PASS}#g" ./scripts/drush-post-deploy.sh | |
# Execute the drush command script | |
source ./scripts/pipeline/cloud-gov-post-deploy.sh | |
source ./scripts/pipeline/cloud-gov-post-deploy.sh | |
source ./scripts/pipeline/s3-backup-post-restore.sh | |
stopBastion: | |
name: Stop Bastion | |
runs-on: ubuntu-latest | |
needs: restore-database | |
if: ${{ always() }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Set env.BRANCH | |
run: echo "BRANCH=$(echo $GITHUB_REF | cut -d'/' -f 3)" >> $GITHUB_ENV | |
- name: Install basic dependancies | |
run: ./scripts/pipeline/deb-basic-deps.sh | |
- name: Install Cloudfoundry CLI | |
run: ./scripts/pipeline/deb-cf-install.sh | |
- name: Cloud.gov login | |
env: | |
CF_USER: "${{ secrets.CF_USER }}" | |
CF_PASSWORD: "${{ secrets.CF_PASSWORD }}" | |
CF_ORG: "${{ secrets.CF_ORG }}" | |
PROJECT: "${{ secrets.PROJECT }}" | |
run: | | |
source ./scripts/pipeline/cloud-gov-login.sh | |
- name: Stop Bastion | |
env: | |
DATABASE_BACKUP_BASTION_NAME: "${{ secrets.DATABASE_BACKUP_BASTION_NAME }}" | |
PROJECT: "${{ secrets.PROJECT }}" | |
run: | | |
echo "BRANCH=$(echo $GITHUB_REF | cut -d'/' -f 3)" >> $GITHUB_ENV | |
cf stop "${PROJECT}-${DATABASE_BACKUP_BASTION_NAME}-${BRANCH}" >/dev/null 2>&1 |