Skip to content

Deploy Lambda assertion #42

Deploy Lambda assertion

Deploy Lambda assertion #42

name: Deploy Lambda assertion
on:
push:
branches:
- "main"
paths:
- "**/src/oneid/oneid-lambda-assertion/**"
workflow_dispatch:
inputs:
environment:
description: 'Choose environment'
type: choice
required: true
default: dev
options:
- dev
- uat
jobs:
build:
runs-on: ubuntu-22.04
steps:
- name: Checkout code
uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
- name: Install dependencies
working-directory: src/oneid/oneid-lambda-assertion
run: |
pip install -r ./requirements.txt -t ./
- name: Zip Lambda
working-directory: src/oneid/oneid-lambda-assertion
run: |
mkdir -p ./target && zip -r target/assertion-lambda.zip . -x "*.dist-info/*" -x "target/*"
- name: Archive build artifacts
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808
with:
name: assertion-lambda
path: ./src/oneid/oneid-lambda-assertion/target/assertion-lambda.zip
deploy:
runs-on: ubuntu-22.04
needs: build
environment: ${{ github.event.inputs.environment }}
env:
ENV_SHORT: ${{ fromJSON('{"dev":"d","uat":"u","prod":"p"}')[github.event.inputs.environment] }}
permissions:
id-token: write
contents: read
steps:
- name: Download build artifacts
uses: actions/download-artifact@65a9edc5881444af0b9093a5e628f2fe47ea3b2e
with:
name: assertion-lambda
path: ./src/oneid/oneid-lambda-assertion/target
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@e3dd6a429d7300a6a4c196c26e071d42e0343502
with:
role-to-assume: ${{ vars.IAM_ROLE_DEPLOY_LAMBDA }}
aws-region: ${{ vars.AWS_REGION }}
- name: Deploy Lambda function (${{ github.event.inputs.environment }})
run: |
aws lambda update-function-code \
--function-name oneid-es-1-${{ env.ENV_SHORT }}-assertion \
--zip-file fileb://src/oneid/oneid-lambda-assertion/target/assertion-lambda.zip