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
171 changes: 114 additions & 57 deletions .github/workflows/deploy-lambda.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,72 +4,129 @@ 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' }}
environment: ${{ needs.resolve.outputs.github_environment }}

steps:
- name: Checkout code
uses: actions/checkout@v4

# AWS ์ž๊ฒฉ ์ฆ๋ช… ์„ค์ •
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ vars.AWS_ROLE_ARN }}
aws-region: ${{ vars.AWS_REGION }}

# Amazon ECR ๋กœ๊ทธ์ธ
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v2

# Docker ์ด๋ฏธ์ง€ ๋นŒ๋“œ ๋ฐ ํ‘ธ์‹œ
- name: Build, tag, and push image to Amazon ECR
id: build-image
env:
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }}
ECR_REPOSITORY: ${{ vars.ECR_REPOSITORY_NAME }}
IMAGE_TAG: ${{ github.sha }}
run: |
docker build --provenance=false -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG -t $ECR_REGISTRY/$ECR_REPOSITORY:latest -f Dockerfile .

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

# 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 }}

# ์ฝ”๋“œ ์—…๋ฐ์ดํŠธ๊ฐ€ ์™„๋ฃŒ๋  ๋•Œ๊นŒ์ง€ ๋Œ€๊ธฐ
- name: Wait for Lambda function update to complete
run: |
aws lambda wait function-updated \
--function-name ${{ vars.LAMBDA_FUNCTION_NAME }}

# Lambda ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ์„ค์ •
- name: Update Lambda Environment Variables
run: |
aws lambda update-function-configuration \
--function-name ${{ vars.LAMBDA_FUNCTION_NAME }} \
--environment "Variables={ \
REGION_NAME=${{ vars.AWS_REGION }}, \
LAMBDA_FUNCTION_NAME=${{ vars.LAMBDA_FUNCTION_NAME }}, \
ECR_REPOSITORY_NAME=${{ vars.ECR_REPOSITORY_NAME }}, \
BUCKET_NAME=${{ vars.BUCKET_NAME }}, \
THUMBNAIL_BUCKET=${{ vars.THUMBNAIL_BUCKET }} \
}"
- name: Checkout code
uses: actions/checkout@v4

# AWS ์ž๊ฒฉ ์ฆ๋ช… ์„ค์ •
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ vars.AWS_ROLE_ARN }}
aws-region: ${{ vars.AWS_REGION }}

# Amazon ECR ๋กœ๊ทธ์ธ
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v2

# Docker ์ด๋ฏธ์ง€ ๋นŒ๋“œ ๋ฐ ํ‘ธ์‹œ
- name: Build, tag, and push image to Amazon ECR
id: build-image
env:
ECR_REGISTRY: ${{ steps.login-ecr.outputs.registry }}
ECR_REPOSITORY: ${{ vars.ECR_REPOSITORY_NAME }}
IMAGE_TAG: ${{ github.sha }}
run: |
docker build --provenance=false -t $ECR_REGISTRY/$ECR_REPOSITORY:$IMAGE_TAG -t $ECR_REGISTRY/$ECR_REPOSITORY:latest -f Dockerfile .
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"

# 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 }}"

# ์ฝ”๋“œ ์—…๋ฐ์ดํŠธ๊ฐ€ ์™„๋ฃŒ๋  ๋•Œ๊นŒ์ง€ ๋Œ€๊ธฐ
- name: Wait for Lambda function update to complete
run: |
aws lambda wait function-updated \
--function-name ${{ vars.LAMBDA_FUNCTION_NAME }}

# Lambda ํ™˜๊ฒฝ ๋ณ€์ˆ˜ ์„ค์ •
- name: Update Lambda Environment Variables
run: |
aws lambda update-function-configuration \
--function-name "${{ vars.LAMBDA_FUNCTION_NAME }}" \
--environment "Variables={ \
REGION_NAME=${{ vars.AWS_REGION }}, \
LAMBDA_FUNCTION_NAME=${{ vars.LAMBDA_FUNCTION_NAME }}, \
ECR_REPOSITORY_NAME=${{ vars.ECR_REPOSITORY_NAME }}, \
BUCKET_NAME=${{ vars.BUCKET_NAME }}, \
THUMBNAIL_BUCKET=${{ vars.THUMBNAIL_BUCKET }} \
}"
Loading