Deploy Layers #481
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 Layers | |
on: | |
push: | |
branches: | |
- master | |
schedule: | |
- cron: '0 0 * * *' # This will run the workflow daily at midnight | |
env: | |
AWS_REGIONS: "us-east-1 us-east-2 us-west-1 us-west-2 ca-central-1 eu-central-1 eu-west-1 eu-west-2 eu-west-3 eu-north-1 ap-northeast-1 ap-northeast-2 ap-southeast-1 ap-southeast-2 ap-south-1 sa-east-1" | |
S3_BUCKET_NAME: "shelf-lambda-layers" | |
jobs: | |
check_release: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v2 | |
- name: Setup AWS CLI | |
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 | |
- name: Get Previous Tag Version | |
id: prev_tag_version | |
run: echo "::set-output name=tag::$(cat .tag_version || echo '')" | |
- name: Get Latest Release URL and Tag Version | |
id: latest_release | |
run: | | |
JSON_RESPONSE=$(curl -s https://api.github.com/repos/Sparticuz/chromium/releases/latest) | |
LATEST_RELEASE_URL=$(echo $JSON_RESPONSE | grep -Po '"browser_download_url": "\K[^"]+' | awk 'NR==1') | |
TAG_VERSION=$(echo $JSON_RESPONSE | grep -Po '"tag_name": "\K[^"]+') | |
if [[ "$TAG_VERSION" == "${{ steps.prev_tag_version.outputs.tag }}" ]]; then | |
echo "Skipping as the tag version is the same as the previous run." | |
exit 78 | |
fi | |
echo "LATEST_RELEASE_URL=$LATEST_RELEASE_URL" >> $GITHUB_ENV | |
echo "TAG_VERSION=$TAG_VERSION" >> $GITHUB_ENV | |
echo "FILENAME=chromium-$TAG_VERSION.zip" >> $GITHUB_ENV | |
- name: Update Tag Version | |
run: echo ${{ env.TAG_VERSION }} > .tag_version | |
- name: Download Latest Release | |
run: | | |
curl -LO ${{ env.LATEST_RELEASE_URL }} | |
FILEPATH=$(basename ${{ env.LATEST_RELEASE_URL }}) | |
echo "FILEPATH=$FILEPATH" >> $GITHUB_ENV | |
- name: Upload to S3 | |
run: | | |
for REGION in ${{ env.AWS_REGIONS }}; do | |
BUCKET_NAME="${{ env.S3_BUCKET_NAME }}-$REGION" | |
aws configure set region $REGION | |
aws s3 cp ${{ env.FILEPATH }} s3://$BUCKET_NAME/${{ env.FILENAME }} & | |
done | |
wait | |
- name: Publish to AWS Regions with Permissions | |
run: | | |
for REGION in ${{ env.AWS_REGIONS }}; do | |
BUCKET_NAME="${{ env.S3_BUCKET_NAME }}-$REGION" | |
aws configure set region $REGION | |
{ | |
NEW_VERSION_NUMBER=$(aws lambda publish-layer-version \ | |
--layer-name chrome-aws-lambda \ | |
--content S3Bucket=$BUCKET_NAME,S3Key=${{ env.FILENAME }} \ | |
--region $REGION \ | |
--compatible-architecture x86_64 \ | |
--description "@sparticuz/chromium v${{ env.TAG_VERSION }} & Chromium v${{ env.TAG_VERSION }}" \ | |
--query Version \ | |
--output text) | |
aws lambda add-layer-version-permission \ | |
--region "$REGION" \ | |
--layer-name chrome-aws-lambda \ | |
--statement-id sid1 \ | |
--action lambda:GetLayerVersion \ | |
--principal '*' \ | |
--version-number $NEW_VERSION_NUMBER | |
echo "Published and permissions added for ${{ env.FILENAME }} in $REGION" | |
} & | |
done | |
wait | |
- name: Commit Tag Version | |
run: | | |
git config --local user.email "[email protected]" | |
git config --local user.name "GitHub Action" | |
git add .tag_version | |
git commit -m "Update tag version to ${{ env.TAG_VERSION }}" | |
git push |