Merge pull request #71 from oodd-team/dev #10
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
# This workflow will do a clean install of node dependencies, cache/restore them, build the source code and run tests across different versions of node | |
# For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions | |
name: prod-deploy | |
on: | |
push: | |
branches: ['main'] | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
node-version: [20.16.0] | |
# See supported Node.js release schedule at https://nodejs.org/en/about/releases/ | |
steps: | |
- name: Checkout source code. | |
uses: actions/checkout@v2 | |
- name: Use Node.js ${{ matrix.node-version }} | |
uses: actions/setup-node@v2 | |
with: | |
node-version: ${{ matrix.node-version }} | |
- name: Check Npm -v | |
run: npm -v | |
- name: create env file | |
working-directory: ./ | |
run: | | |
echo "DB_HOST=${{ secrets.DB_HOST }}" >> .env | |
echo "DB_USER=${{ secrets.DB_USER }}" >> .env | |
echo "DB_PASSWORD=${{ secrets.DB_PASSWORD }}" >> .env | |
echo "DB_DATABASE=${{ secrets.PROD_DB_DATABASE }}" >> .env | |
echo "JWT_SECRET=${{ secrets.JWT_SECRET }}" >> .env | |
echo "JWT_EXPIRATION=${{ secrets.JWT_EXPIRATION }}" >> .env | |
echo "KAKAO_ID=${{ secrets.KAKAO_ID }}" >> .env | |
echo "KAKAO_SECRET=${{ secrets.KAKAO_SECRET }}" >> .env | |
echo "KAKAO_REDIRECT=${{ secrets.PROD_KAKAO_REDIRECT }}" >> .env | |
echo "NAVER_ID=${{ secrets.NAVER_ID }}" >> .env | |
echo "NAVER_SECRET=${{ secrets.NAVER_SECRET }}" >> .env | |
echo "NAVER_REDIRECT=${{ secrets.PROD_NAVER_REDIRECT }}" >> .env | |
echo "PORT"=${{ secrets.PROD_PORT }} >> .env | |
- name: copy appspec.yml | |
run: cp appspec/appspec-prod.yml appspec.yml | |
- name: copy scripts | |
run: mkdir -p scripts && cp prod-scripts/after-deploy.sh scripts/after-deploy.sh | |
- name: build server files | |
working-directory: ./ | |
run: | | |
yarn install | |
yarn run build | |
- name: zip file | |
run: zip -r build.zip ./dist ./scripts ./appspec.yml ./.env ./package.json ./node_modules ./yarn.lock | |
- name: AWS configure credentials | |
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: ap-northeast-2 | |
- name: upload to S3 | |
run: aws s3 cp --region ap-northeast-2 ./build.zip s3://oodd-api-bucket/prod/ | |
- name: deploy with AWS codeDeploy | |
run: aws deploy create-deployment | |
--application-name nestjs-app-prod | |
--deployment-config-name CodeDeployDefault.OneAtATime | |
--deployment-group-name nestjs-app-prod-group | |
--s3-location bucket=oodd-api-bucket,bundleType=zip,key=prod/build.zip |