merge demo pack update (#232) #748
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: 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 }} |