Skip to content

🐛 [Fix]: 출석 response dto 응답 데이터 수정 #90

🐛 [Fix]: 출석 response dto 응답 데이터 수정

🐛 [Fix]: 출석 response dto 응답 데이터 수정 #90

Workflow file for this run

name: API Server Ci/Cd
on:
push:
branches:
- develop
- Fix/296
# paths:
# - 'apps/api/**'
jobs:
build-and-push:
runs-on: ubuntu-latest
env:
IMAGE_NAME: api-camon
DB_HOST: ${{ secrets.DB_HOST }}
DB_PORT: ${{ secrets.DB_PORT }}
DB_USERNAME: ${{ secrets.DB_USERNAME }}
DB_PASSWORD: ${{ secrets.DB_PASSWORD }}
DB_NAME: ${{ secrets.DB_NAME }}
GH_CLIENT_ID: ${{ secrets.GH_CLIENT_ID }}
GH_SECRET: ${{ secrets.GH_SECRET }}
GH_CALLBACK_URL: ${{ secrets.GH_CALLBACK_URL }}
JWT_SECRET: ${{ secrets.JWT_SECRET }}
GG_CLIENT_ID: ${{ secrets.GG_CLIENT_ID }}
GG_SECRET: ${{ secrets.GG_SECRET }}
GG_CALLBACK_URL: ${{ secrets.GG_CALLBACK_URL }}
CALLBACK_URI: ${{ secrets.CALLBACK_URI }}
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Log in to Ncloud Container Registry
env:
USERNAME: ${{ secrets.NCLOUD_ACCESS_KEY }}
PASSWORD: ${{ secrets.NCLOUD_SECRET_KEY }}
REGISTRY_URL: ${{ secrets.NCLOUD_REGISTRY_URL }}
run: |
echo "$PASSWORD" | docker login -u "$USERNAME" "$REGISTRY_URL" --password-stdin
- name: Build Docker image
run: |
docker build -f ./apps/api/Dockerfile -t ${{ secrets.NCLOUD_REGISTRY_URL }}/$IMAGE_NAME:latest \
--build-arg DB_HOST=$DB_HOST \
--build-arg DB_PORT=$DB_PORT \
--build-arg DB_USERNAME=$DB_USERNAME \
--build-arg DB_PASSWORD=$DB_PASSWORD \
--build-arg DB_NAME=$DB_NAME \
--build-arg GH_CLIENT_ID=$GH_CLIENT_ID \
--build-arg GH_SECRET=$GH_SECRET \
--build-arg GH_CALLBACK_URL=$GH_CALLBACK_URL \
--build-arg JWT_SECRET=$JWT_SECRET \
--build-arg GG_CLIENT_ID=$GG_CLIENT_ID \
--build-arg GG_SECRET=$GG_SECRET \
--build-arg GG_CALLBACK_URL=$GG_CALLBACK_URL \
--build-arg CALLBACK_URI=$CALLBACK_URI \
.
- name: Push to Ncloud Container Registry
run: |
docker push ${{ secrets.NCLOUD_REGISTRY_URL }}/$IMAGE_NAME:latest
deploy-and-run:
runs-on: ubuntu-latest
needs: build-and-push
steps:
- name: Checkout for docker-compose
uses: actions/checkout@v2
# - name: Copy docker-compose file
# uses: appleboy/scp-action@master
# with:
# host: ${{ secrets.SERVER_IP }}
# username: ${{ secrets.SERVER_USER }}
# key: ${{ secrets.SSH_SERVER_KEY }}
# source: "docker-compose.yml"
# target: "/home/${{ secrets.SERVER_USER }}/camon"
- name: Create .env.api file
uses: appleboy/[email protected]
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
script: |
cd /home/${{ secrets.SERVER_USER }}/camon
cat << EOF > .env.api
NCLOUD_ACCESS_KEY=${{ secrets.NCLOUD_ACCESS_KEY }}
NCLOUD_SECRET_KEY=${{ secrets.NCLOUD_SECRET_KEY }}
NCLOUD_BUCKET_NAME=${{ secrets.NCLOUD_BUCKET_NAME }}
RECORD_PORT=${{ secrets.RECORD_PORT }}
EOF
- name: SSH and deploy
uses: appleboy/[email protected]
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
port: 22
# envs: DB_HOST,DB_PORT,DB_USERNAME,DB_PASSWORD,DB_NAME,GH_CLIENT_ID,GH_SECRET,GH_CALLBACK_URL,JWT_SECRET,GG_CLIENT_ID,GG_SECRET,GG_CALLBACK_URL,CALLBACK_URI
script: |
cd /home/${{ secrets.SERVER_USER }}/camon
sudo docker login -u ${{secrets.NCLOUD_ACCESS_KEY}} -p ${{ secrets.NCLOUD_SECRET_KEY }} ${{ secrets.NCLOUD_REGISTRY_URL }}
sudo docker stop api-camon || true
sudo docker rm api-camon || true
sudo docker rmi ${{ secrets.NCLOUD_REGISTRY_URL }}/api-camon:latest || true
sudo docker pull ${{ secrets.NCLOUD_REGISTRY_URL }}/$IMAGE_NAME:latest
sudo docker-compose --env-file .env.api up -d api
sudo docker image prune -f
- name: Check container status
uses: appleboy/[email protected]
with:
host: ${{ secrets.SERVER_IP }}
username: ${{ secrets.SERVER_USER }}
key: ${{ secrets.SSH_SERVER_KEY }}
port: 22
script: |
sudo docker ps -f name=api-camon