types #111
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: deploy-aws-dev | |
on: | |
push: | |
branches: | |
- develop | |
# # run every 6 hours | |
# only runs on the base branch, weird, github???? | |
# schedule: | |
# - cron: "0 */6 * * *" | |
# Allows you to run this workflow manually from the Actions tab | |
workflow_dispatch: | |
concurrency: | |
group: develop | |
cancel-in-progress: false | |
jobs: | |
aws_deploy_dev: | |
runs-on: ubuntu-latest | |
environment: | |
name: develop | |
url: https://develop.lemmyverse.net | |
steps: | |
# https://github.com/actions/toolkit/issues/946#issuecomment-1590016041 | |
- name: root suid tar | |
run: sudo chown root:root /bin/tar && sudo chmod u+s /bin/tar | |
- uses: actions/checkout@v3 | |
- name: Use Node.js 22.12.0 | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 22.12.0 | |
# download latest redis database | |
- name: get current hour for cache busting | |
id: cache-hour | |
run: echo "hour=$(date +'%Y-%m-%d-%H')" >>$GITHUB_OUTPUT | |
- name: Cache Redis Dump | |
id: cache-redis | |
uses: actions/cache@v3 | |
env: | |
cache-name: cache-redis | |
with: | |
path: ./.redis/dump.rdb | |
key: cache-redis-${{ steps.cache-hour.outputs.hour }} | |
# download redis db dump from s3 | |
- name: Download the Redis Dump | |
if: steps.cache-redis.outputs.cache-hit != 'true' | |
uses: keithweaver/[email protected] | |
with: | |
command: cp | |
source: s3://${{ vars.BUILD_S3_BUCKET }}/checkpoint/dump.rdb | |
destination: ./.redis/dump.rdb | |
aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws_region: ap-southeast-2 | |
# log the sha 256 hash of the redis dump | |
- name: Log Redis Dump Hash | |
run: sha256sum ./.redis/dump.rdb | |
# start redis & check if it is running | |
- name: Start Redis | |
working-directory: ./crawler | |
run: docker compose -f "docker-compose.github.yaml" up -d redis | |
- working-directory: ./crawler | |
run: docker ps -a | |
- working-directory: ./crawler | |
run: docker compose -f "docker-compose.github.yaml" logs redis | |
# Install + Cache Crawler Dependencies | |
- name: Cache Node Modules | Crawler | |
id: cache-crawler-npm | |
uses: actions/cache@v3 | |
env: | |
cache-name: cache-crawler-npm | |
with: | |
path: ./crawler/node_modules/ | |
key: cache-crawler-yarn-${{ hashFiles('crawler/yarn.lock') }} | |
- name: Install Node Modules | Crawler | |
if: steps.cache-crawler-npm.outputs.cache-hit != 'true' | |
run: yarn --frozen-lockfile | |
working-directory: ./crawler | |
# Run Crawler Output Script | |
- name: Run Health Script | |
run: yarn health | |
working-directory: ./crawler | |
- name: Run Output Script | |
run: yarn output | |
working-directory: ./crawler | |
# Install + Cache Frontend Dependencies | |
- name: Cache Node Modules | Frontend | |
id: cache-frontend-npm | |
uses: actions/cache@v3 | |
env: | |
cache-name: cache-frontend-npm | |
with: | |
path: ./frontend/node_modules/ | |
key: cache-frontend-npm-${{ hashFiles('frontend/package-lock.json') }} | |
- name: Install Node Modules | Frontend | |
if: steps.cache-frontend-npm.outputs.cache-hit != 'true' | |
run: npm ci | |
working-directory: ./frontend | |
- name: Build the Frontend | |
run: npm run build | |
working-directory: ./frontend | |
- name: Create CDK Config JSON | |
id: create-json | |
uses: jsdaniell/[email protected] | |
with: | |
dir: ./cdk | |
name: "config.json" | |
json: ${{ vars.CONFIG_JSON }} | |
# Install + Cache CDK Dependencies | |
- name: Cache Node Modules | CDK | |
id: cache-cdk-npm | |
uses: actions/cache@v3 | |
env: | |
cache-name: cache-cdk-npm | |
with: | |
path: ./cdk/node_modules/ | |
key: cache-cdk-npm-${{ hashFiles('frontend/package-lock.json') }} | |
- name: Install Node Modules | CDK | |
if: steps.cache-cdk-npm.outputs.cache-hit != 'true' | |
run: npm ci | |
working-directory: ./cdk | |
- name: CDK Bootstrap | |
run: ./node_modules/.bin/cdk bootstrap | |
working-directory: ./cdk | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
- name: CDK Synth | |
run: ./node_modules/.bin/cdk synthesize --all | |
working-directory: ./cdk | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
- name: CDK Diff | |
run: ./node_modules/.bin/cdk diff --all | |
working-directory: ./cdk | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
- name: CDK Deploy | |
run: ./node_modules/.bin/cdk deploy --all --require-approval never | |
working-directory: ./cdk | |
env: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |