Skip to content

merge education demo apck update (#210) #728

merge education demo apck update (#210)

merge education demo apck update (#210) #728

Workflow file for this run

name: Sync To S3
on:
# Run on push on master
push:
branches: [ master ]
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
jobs:
build:
runs-on: ubuntu-latest
# https://github.com/marketplace/actions/s3-sync
steps:
- name: checkout repo
uses: actions/checkout@master
with:
# need at least 2 here so we can get a proper log in getting updated filed before invalidate step
fetch-depth: 2
- name: sync with S3
uses: jakejarvis/s3-sync-action@master
with:
args: --follow-symlinks --delete --exclude '.git/*' --exclude '.github/*' --size-only
env:
AWS_S3_BUCKET: ${{ secrets.AWS_S3_BUCKET }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
AWS_REGION: ${{ secrets.AWS_REGION }}
SOURCE_DIR: './'
- name: Sleep Action
uses: juliangruber/[email protected]
with:
# giving some time for things to settle down between s3 and cloudfront
# may not need this time since there usaually no sync up needed between s3 and cloudfront
time: 10s
- name: get updated files
run: |
# allow grep to fail
set +e
FILES=$(git diff --name-only HEAD~1 | awk '{print "/"$1}')
set -e
[ -z "$FILES" ] && touch .updated_files && exit 0
for file in $FILES; do
echo $file
# add bare directory to list of updated paths when we see index.html
[[ "$file" == *"/index.html" ]] && echo $file | sed -e 's/\/index.html$/\//'
done | sort | uniq | tr '\n' ' ' > .updated_files
- name: invalidate Cloudfront
uses: chetan/invalidate-cloudfront-action@v2
env:
PATHS_FROM: .updated_files
AWS_REGION: 'us-east-2'
DISTRIBUTION: ${{ secrets.DISTRIBUTION }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
DEBUG: ${{ secrets.CLOUDFRONT_DEBUG }}