Feat: Donate to educator account #61
Workflow file for this run
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: Publish | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- master | |
pull_request: | |
concurrency: | |
cancel-in-progress: false | |
group: ${{ github.workflow }}-${{ github.ref }} | |
jobs: | |
publish: | |
permissions: | |
pull-requests: write | |
runs-on: ubuntu-latest | |
steps: | |
- name: GitHub Slug Action | |
uses: rlespinasse/github-slug-action@v4 | |
- name: Generate Domain Name | |
id: generate_domain_name | |
uses: actions/github-script@v6 | |
with: | |
result-encoding: string | |
script: | | |
if (context.payload.ref == 'refs/heads/master') { | |
return 'ai-horde.rikudou.dev'; | |
} | |
return process.env.GITHUB_REF_NAME_SLUG_URL + '.ai-horde.rikudou.dev'; | |
- name: Generate SLS Stage | |
id: generate_sls_stage | |
uses: actions/github-script@v6 | |
with: | |
result-encoding: string | |
script: | | |
if (context.payload.ref == 'refs/heads/master') { | |
return 'prod'; | |
} | |
return process.env.GITHUB_REF_NAME_SLUG_URL; | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Setup prod dependencies | |
run: yarn install | |
- name: Deploy infrastructure | |
uses: serverless/github-action@v3 | |
with: | |
args: deploy --stage ${{ steps.generate_sls_stage.outputs.result }} --verbose | |
env: | |
AWS_REGION: eu-central-1 | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
DOMAIN_ZONE: ${{ secrets.APP_DOMAIN_HOSTED_ZONE }} | |
DOMAIN_NAME: ${{ steps.generate_domain_name.outputs.result }} | |
- name: Create runtime version | |
run: echo "window['APP_VERSION'] = '$GITHUB_SHA';" >> src/assets/runtime-variables.js | |
- name: Build app | |
run: ./node_modules/.bin/ng build | |
- name: Disable robots | |
run: | | |
echo 'User-agent: *' >> dist/ai-horde-website/browser/robots.txt | |
echo 'Disallow: /' >> dist/ai-horde-website/browser/robots.txt | |
- name: Copy files to S3 | |
env: | |
STACK_NAME: AiHordeFrontend-${{ steps.generate_sls_stage.outputs.result }} | |
AWS_REGION: eu-central-1 | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
run: | | |
BUCKET=$(aws cloudformation describe-stacks --stack-name $STACK_NAME --query "Stacks[0].Outputs[?OutputKey=='Bucket'].OutputValue" --output=text) | |
aws s3 sync dist/ai-horde-website/browser s3://$BUCKET --delete | |
- name: Create invalidation | |
env: | |
STACK_NAME: AiHordeFrontend-${{ steps.generate_sls_stage.outputs.result }} | |
AWS_REGION: eu-central-1 | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
run: | | |
CDN_ID=$(aws cloudformation describe-stacks --stack-name $STACK_NAME --query "Stacks[0].Outputs[?OutputKey=='Cdn'].OutputValue" --output=text) | |
aws cloudfront create-invalidation --distribution-id $CDN_ID --paths "/*" 2>&1 > /dev/null | |
- name: Post Link | |
uses: thollander/actions-comment-pull-request@v2 | |
if: github.event_name == 'pull_request' | |
with: | |
message: This pull request has been deployed to https://${{ steps.generate_domain_name.outputs.result }} | |
comment_tag: post_link_comment |