Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
74 changes: 65 additions & 9 deletions .github/workflows/deploy-lambda.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,74 @@ on:
push:
branches: [ "develop", "main" ]

workflow_dispatch:
inputs:
target_env:
description: "Manual deployment target"
required: true
type: choice
options:
- staging

# OIDC ์ธ์ฆ์„ ์œ„ํ•œ ๊ถŒํ•œ ์„ค์ •
permissions:
id-token: write
id-token: write
contents: read

jobs:
resolve:
name: Resolve deployment target
runs-on: ubuntu-latest

outputs:
env_type: ${{ steps.resolve.outputs.env_type }}
github_environment: ${{ steps.resolve.outputs.github_environment }}

steps:
- name: Resolve target environment
id: resolve
shell: bash
run: |
if [[ "${GITHUB_EVENT_NAME}" == "workflow_dispatch" ]]; then
ENV_TYPE="${{ github.event.inputs.target_env }}"

if [[ "$ENV_TYPE" != "staging" ]]; then
echo "Only staging manual deployment is allowed."
exit 1
fi

GITHUB_ENVIRONMENT="STAGING"
else
case "${GITHUB_REF_NAME}" in
develop)
ENV_TYPE="dev"
GITHUB_ENVIRONMENT="DEV"
;;
main)
ENV_TYPE="prod"
GITHUB_ENVIRONMENT="PROD"
;;
*)
echo "Unsupported branch for push deployment: ${GITHUB_REF_NAME}"
exit 1
;;
esac
fi

echo "env_type=$ENV_TYPE" >> "$GITHUB_OUTPUT"
echo "github_environment=$GITHUB_ENVIRONMENT" >> "$GITHUB_OUTPUT"

echo "--- Event: ${GITHUB_EVENT_NAME}"
echo "--- Branch: ${GITHUB_REF_NAME}"
echo "--- Env type: $ENV_TYPE"
echo "--- GitHub environment: $GITHUB_ENVIRONMENT"

deploy:
name: Build, Push to ECR, and Deploy to Lambda
needs: resolve
runs-on: ubuntu-latest

# ๋ธŒ๋žœ์น˜์— ๋”ฐ๋ผ ์‚ฌ์šฉํ•  ํ™˜๊ฒฝ ์„ ํƒ
environment: ${{ github.ref == 'refs/heads/main' && 'PROD' || 'DEV' }}
# resolve job์—์„œ ๊ฒฐ์ •ํ•œ GitHub Environment ์‚ฌ์šฉ
environment: ${{ needs.resolve.outputs.github_environment }}

steps:
- name: Checkout code
Expand All @@ -25,7 +81,7 @@ jobs:
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ vars.AWS_ROLE_ARN }}
role-to-assume: ${{ vars.AWS_ROLE_ARN }}
aws-region: ${{ vars.AWS_REGION }}

# Amazon ECR ๋กœ๊ทธ์ธ
Expand All @@ -46,14 +102,14 @@ jobs:
docker push $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG
docker push $ECR_REGISTRY/$ECR_REPOSITORY:latest

echo "image_uri=$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG" >> $GITHUB_OUTPUT
echo "image_uri=$ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG" >> "$GITHUB_OUTPUT"

# Lambda ํ•จ์ˆ˜ ์—…๋ฐ์ดํŠธ
- name: Deploy new image to AWS Lambda
run: |
aws lambda update-function-code \
--function-name ${{ vars.LAMBDA_FUNCTION_NAME }} \
--image-uri ${{ steps.build-image.outputs.image_uri }}
--function-name "${{ vars.LAMBDA_FUNCTION_NAME }}" \
--image-uri "${{ steps.build-image.outputs.image_uri }}"

# ์ฝ”๋“œ ์—…๋ฐ์ดํŠธ๊ฐ€ ์™„๋ฃŒ๋  ๋•Œ๊นŒ์ง€ ๋Œ€๊ธฐ
- name: Wait for Lambda function update to complete
Expand All @@ -65,7 +121,7 @@ jobs:
- name: Update Lambda Environment Variables
run: |
aws lambda update-function-configuration \
--function-name ${{ vars.LAMBDA_FUNCTION_NAME }} \
--function-name "${{ vars.LAMBDA_FUNCTION_NAME }}" \
--environment "Variables={ \
REGION_NAME=${{ vars.AWS_REGION }}, \
LAMBDA_FUNCTION_NAME=${{ vars.LAMBDA_FUNCTION_NAME }}, \
Expand Down
Loading