www/.github/workflows/cd.yml

108 lines
3.3 KiB
YAML
Raw Normal View History

2022-03-25 16:52:12 +03:00
on:
push:
branches:
- main
paths-ignore:
2022-07-07 23:18:49 +03:00
- '*.md'
2022-03-14 17:54:16 +03:00
concurrency:
group: deploy
cancel-in-progress: true
2022-07-07 23:18:49 +03:00
env:
TEA_SECRET: ${{ secrets.TEA_SECRET }}
2022-03-14 17:54:16 +03:00
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Create Deployment
2022-05-04 22:08:51 +03:00
uses: bobheadxi/deployments@v1
2022-03-14 17:54:16 +03:00
id: deployment
with:
step: start
env: aws
2022-05-04 22:08:51 +03:00
- uses: actions/checkout@v3
2022-03-14 17:54:16 +03:00
- name: Copy packages.json summary from dist.tea.xyz
uses: prewk/s3-cp-action@v2
with:
aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
2022-10-14 17:00:32 +03:00
source: 's3://dist.tea.xyz/packages.json'
dest: './src/data/packages.json'
2022-10-13 10:29:27 +03:00
- name: Create Package Detail Pages from packages.json
uses: getneil/jq-action@v1
id: version
with:
cmd: '.github/build-package-pages.sh src/data/packages.json src/content/packages'
2022-10-29 05:51:28 +03:00
- name: Download package thumbnails from Airtable
uses: getneil/jq-action@v1
with:
cmd: '.github/prepare-thumb-images.sh src/data/packages.json'
- name: Upload package thumbnails to AWS S3
uses: jakejarvis/s3-sync-action@master
env:
AWS_S3_BUCKET: www.tea.xyz
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: 'us-east-1'
SOURCE_DIR: 'packages_thumbs_images'
DEST_DIR: 'Images/packages'
2022-07-07 23:18:49 +03:00
- run: .github/mk-pantry-accessible.sh ${{ secrets.TEMP_JACOBS_GITHUB_PAT }}
- uses: teaxyz/setup@v0
with:
2022-07-07 23:18:49 +03:00
target: build
2022-08-22 23:12:58 +03:00
- name: Check for broken links
uses: lycheeverse/lychee-action@v1
with:
fail: true
args: --verbose --no-progress './public/**/*.md' './public/**/*.html'
env:
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
2022-03-14 17:54:16 +03:00
## means s3 sync will only sync things we need syncd
- uses: chetan/git-restore-mtime-action@v1
- uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1
# cache-control of 10 mins because we *need* to be able to update
# this and have people see the results can be fixed well with a static site builder
- run: |
aws s3 sync public s3://www.tea.xyz \
2022-03-14 17:54:16 +03:00
--metadata-directive REPLACE \
--cache-control max-age=600 \
--exclude '.git/*' --exclude '.github/*' \
--exclude 'pour.sh' \
--exclude 'tea.white-paper*.pdf' \
2022-03-25 16:39:06 +03:00
--exclude '*.md' \
2022-10-29 05:43:03 +03:00
--exclude 'public/Images/packages/*' \
2022-03-14 17:54:16 +03:00
--delete
#TODO create a github-action that can be used to parse the
# output from `s3 sync` into invalidation commands. NOTE
# I have already looked for something to do this and failed.
- run: |
aws cloudfront create-invalidation \
--distribution-id ${{ secrets.AWS_CF_DISTRIBUTION_ID }} \
--paths '/*'
- name: Seal Deployment
2022-05-04 22:08:51 +03:00
uses: bobheadxi/deployments@v1
2022-03-14 17:54:16 +03:00
if: always()
with:
step: finish
status: ${{ job.status }}
deployment_id: ${{ steps.deployment.outputs.deployment_id }}
2022-05-04 22:08:51 +03:00
env: ${{ steps.deployment.outputs.env }}