Contentful Schema Migrate #119
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: Contentful Schema Migrate | |
on: | |
workflow_dispatch: | |
inputs: | |
target_environment: | |
required: true | |
default: 'dev' | |
type: choice | |
options: | |
- dev | |
- test | |
- prod | |
jobs: | |
setup: | |
runs-on: ubuntu-latest | |
environment: ${{inputs.target_environment}} | |
env: | |
MANAGEMENT_TOKEN: ${{ secrets.CONTENTFUL_MANAGEMENT_TOKEN }} | |
DELIVERY_KEY: ${{ secrets.TF_VAR_CPD_DELIVERY_KEY }} | |
ENVIRONMENT: ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} | |
SPACE_CAPACITY: ${{ vars.CONTENTFUL_SPACE_CAPACITY }} | |
SPACE_ID: ${{ secrets.TF_VAR_CPD_SPACE_ID }} | |
outputs: | |
staging-environment: ${{ steps.staging-env.outputs.staging-environment }} | |
required-migrations: ${{ steps.required-migrations.outputs.required-migrations }} | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- name: Install npm packages used by util scripts | |
working-directory: ./Contentful-Schema | |
run: npm ci | |
- name: Get target environment current migration version | |
id: current-migration-version | |
working-directory: ./Contentful-Schema/utils | |
run: node get-environment-version.js | |
- name: Verify contentful space has available environment capacity | |
working-directory: ./Contentful-Schema/utils | |
run: node verify-space-capacity.js | |
- name: Determine timestamp for new staging environment | |
run: echo "TIMESTAMP=$(date +%Y-%m-%d-%H-%M-%S)" >> $GITHUB_ENV | |
- name: Set var for name of new environment | |
id: staging-env | |
run: echo "staging-environment=$(echo ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }}-${{ env.TIMESTAMP }})" >> $GITHUB_OUTPUT | |
- name: Extract migration files from archive | |
working-directory: ./Contentful-Schema/migrations | |
run: rm *.cjs && rm manifest.txt && tar -zxf migrations.tar.gz && rm migrations.tar.gz | |
- name: Verify migration files against manifest | |
working-directory: ./Contentful-Schema/utils | |
run: node verify-migrations-against-manifest.js | |
- name: Determine required migrations for environment | |
id: required-migrations | |
working-directory: ./Contentful-Schema/utils | |
run: node get-required-migrations.js --currentVersion ${{ steps.current-migration-version.outputs.migration-version }} | |
clone: | |
if: ${{ join(needs.setup.outputs.required-migrations, '') != '[]' }} | |
needs: [setup] | |
runs-on: ubuntu-latest | |
env: | |
MANAGEMENT_TOKEN: ${{ secrets.CONTENTFUL_MANAGEMENT_TOKEN }} | |
SPACE_ID: ${{ secrets.TF_VAR_CPD_SPACE_ID }} | |
steps: | |
- name: Install Contentful CLI | |
run: npm install -g contentful-cli | |
- name: Login to Contentful with management token | |
run: contentful login --management-token "${{ env.MANAGEMENT_TOKEN }}" | |
- name: Set target space | |
run: contentful space use --space-id ${{ env.SPACE_ID }} --environment-id ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} | |
- name: Clone target environment ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} to staging environment ${{ needs.setup.outputs.staging-environment }} | |
run: contentful space environment create --name ${{ needs.setup.outputs.staging-environment }} --environment-id ${{ needs.setup.outputs.staging-environment }} --source ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} | |
migrate: | |
if: ${{ join(needs.setup.outputs.required-migrations, '') != '[]' }} | |
needs: [setup,clone] | |
runs-on: ubuntu-latest | |
strategy: | |
max-parallel: 1 | |
matrix: | |
value: ${{fromJSON(needs.setup.outputs.required-migrations)}} | |
env: | |
MANAGEMENT_TOKEN: ${{ secrets.CONTENTFUL_MANAGEMENT_TOKEN }} | |
SPACE_ID: ${{ secrets.TF_VAR_CPD_SPACE_ID }} | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- name: Install npm packages used by migration script | |
working-directory: ./Contentful-Schema | |
run: npm ci | |
- name: Install Contentful CLI | |
run: npm install -g contentful-cli | |
- name: Extract migration files from archive | |
working-directory: ./Contentful-Schema/migrations | |
run: rm *.cjs && rm manifest.txt && tar -zxf migrations.tar.gz && rm migrations.tar.gz | |
- name: Run migration script ${{ matrix.value }} | |
working-directory: ./Contentful-Schema/migrations | |
run: contentful space migration --space-id "${{ env.SPACE_ID }}" --environment-id ${{ needs.setup.outputs.staging-environment }} --management-token "${{ env.MANAGEMENT_TOKEN }}" ${{ matrix.value }} --yes | |
- name: Update environment's migration version | |
working-directory: ./Contentful-Schema/utils | |
env: | |
STAGING_ENVIRONMENT: ${{ needs.setup.outputs.staging-environment }} | |
MIGRATION_FILENAME: ${{ matrix.value }} | |
run: node set-environment-version.js | |
repoint-alias: | |
if: ${{ join(needs.setup.outputs.required-migrations, '') != '[]' }} | |
needs: [setup,migrate] | |
runs-on: ubuntu-latest | |
env: | |
STAGING_ENVIRONMENT: ${{ needs.setup.outputs.staging-environment }} | |
MANAGEMENT_TOKEN: ${{ secrets.CONTENTFUL_MANAGEMENT_TOKEN }} | |
ENVIRONMENT: ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} | |
SPACE_ID: ${{ secrets.TF_VAR_CPD_SPACE_ID }} | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- name: Install npm packages used by migration script | |
working-directory: ./Contentful-Schema | |
run: npm ci | |
- name: Run script to point alias ${{ inputs.target_environment == 'prod' && 'master' || inputs.target_environment }} at new environment ${{ env.STAGING_ENVIRONMENT }} | |
working-directory: ./Contentful-Schema/utils | |
run: node point-alias-at-environment.js |