Trivial change to trigger CI #25
Workflow file for this run
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: NameGuard API - Lambda Deploy | |
on: | |
push: | |
branches: | |
- main | |
- ci | |
paths: | |
- 'api/**' | |
- '.github/workflows/nameguard_api_lambda_deploy.yml' | |
permissions: | |
id-token: write | |
contents: write | |
concurrency: | |
group: ${{ github.workflow }} | |
cancel-in-progress: false | |
jobs: | |
build-image-deploy-serverless: | |
runs-on: ubuntu-latest | |
env: | |
SERVICE_NAME: nameguard | |
steps: | |
- name: Checkout NameKit repo | |
uses: actions/checkout@v4 | |
- name: Setup pnpm | |
uses: pnpm/action-setup@v4 | |
- name: Install Node.js | |
uses: actions/setup-node@v4 | |
with: | |
node-version-file: .nvmrc | |
cache: "pnpm" | |
- name: Install npm dependencies | |
run: pnpm install --frozen-lockfile | |
- name: Setup git | |
run: | | |
git config --global user.name 'GitHub Actions' | |
git config --global user.email '' | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
role-to-assume: ${{ secrets.AWS_ROLE}} | |
aws-region: us-east-1 | |
- name: Set up QEMU | |
uses: docker/setup-qemu-action@v3 | |
with: | |
platforms: arm64 | |
- name: Copy LICENSE to api directory | |
run: cp LICENSE api/ | |
- name: Build and deploy lambda | |
env: | |
PROVIDER_URI_MAINNET: ${{ secrets.PROVIDER_URI_MAINNET }} | |
PROVIDER_URI_SEPOLIA: ${{ secrets.PROVIDER_URI_SEPOLIA }} | |
ALCHEMY_URI_MAINNET: ${{ secrets.ALCHEMY_URI_MAINNET }} | |
ALCHEMY_URI_SEPOLIA: ${{ secrets.ALCHEMY_URI_SEPOLIA }} | |
ENS_SUBGRAPH_URL_MAINNET: ${{ secrets.ENS_SUBGRAPH_URL_MAINNET }} | |
ENS_SUBGRAPH_URL_SEPOLIA: ${{ secrets.ENS_SUBGRAPH_URL_SEPOLIA }} | |
run: pnpm run deploy:prod | |
working-directory: api | |
- name: Delete old images from ECR | |
env: | |
ECR_REPO: serverless-oss-nameguard-prod | |
run: | | |
ALL_IMAGES_TO_DELETE=$(aws ecr describe-images --repository-name $ECR_REPO --query 'sort_by(imageDetails,& imagePushedAt)[*].imageDigest' --filter "tagStatus=UNTAGGED" --output json ) | |
len=`echo $ALL_IMAGES_TO_DELETE | jq length` | |
IMAGES_TO_DELETE=$(aws ecr describe-images --repository-name $ECR_REPO --query 'sort_by(imageDetails,& imagePushedAt)[*].imageDigest' --filter "tagStatus=UNTAGGED" --output json | jq '.[0]') | |
if [[ $len > 5 ]]; then aws ecr batch-delete-image --repository-name $ECR_REPO --image-ids imageDigest=$IMAGES_TO_DELETE; fi | |
working-directory: api | |
notify: | |
name: Send Slack deployment event notification | |
if: ${{ needs.build-image-deploy-serverless.result != 'skipped' && always() }} | |
needs: [build-image-deploy-serverless] | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Output status on deployment success | |
if: ${{ needs.build-image-deploy-serverless.result == 'success'}} | |
run: | | |
echo "STATUS=Success :rocket:" >> $GITHUB_ENV | |
echo "TEXT=Lambda NameGuard deployed successfully! :white_check_mark:" >> $GITHUB_ENV | |
- name: Output status on deployment failed | |
if: ${{ needs.build-image-deploy-serverless.result == 'failure' }} | |
run: | | |
echo "STATUS=Failure :x:" >> $GITHUB_ENV | |
echo "TEXT=Lambda NameGuard deployment failed! :rotating_light:" >> $GITHUB_ENV | |
- name: Send deployment status Slack notification | |
uses: 8398a7/action-slack@v3 | |
with: | |
status: custom | |
fields: commit,workflow,repo | |
custom_payload: | | |
{ | |
attachments: [{ | |
color: '${{ needs.build-image-deploy-serverless.result }}' === 'success' ? 'good' : '${{ needs.build-image-deploy-serverless.result }}' === 'failure' ? 'danger' : 'warning', | |
title: 'Lambda NameGuard deployment.', | |
text: '${{ env.TEXT }}', | |
fields: [ | |
{ | |
title: 'Repository', | |
value: `${process.env.AS_REPO}`, | |
short: true | |
}, | |
{ | |
title: 'Status', | |
value: '${{ env.STATUS }}', | |
short: true | |
}, | |
{ | |
title: 'Workflow', | |
value: `${process.env.AS_WORKFLOW}`, | |
short: true | |
} | |
] | |
}] | |
} | |
env: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL}} |