[#3] ci: 액션 테스트 브랜치 삭제 #9
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
name: Deploy Swagger UI | |
on: | |
push: | |
branches: | |
- main | |
env: | |
NCP_ACCESS_KEY: ${{ secrets.NCP_ACCESS_KEY }} | |
NCP_SECRET_KEY: ${{ secrets.NCP_SECRET_KEY }} | |
NCP_VPC_ID: ${{ secrets.NCP_VPC_ID }} | |
NCP_AGC_ID: ${{ secrets.NCP_AGC_ID }} | |
NCP_API_URL: https://ncloud.apigw.ntruss.com | |
API_DOC_SERVER_HOST: ${{ secrets.API_DOC_SERVER_HOST }} | |
API_DOC_SERVER_SSH_PORT: ${{ secrets.API_DOC_SERVER_SSH_PORT }} | |
API_DOC_SERVER_USERNAME: ${{ secrets.API_DOC_SERVER_USERNAME }} | |
API_DOC_SERVER_PASSWORD: ${{ secrets.API_DOC_SERVER_PASSWORD }} | |
SSH_PORT: 22 | |
jobs: | |
build-and-deploy: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
- name: Get Github Actions IP | |
id: ip | |
run: | | |
PUBLIC_IP=$(curl -s https://ifconfig.me) | |
echo "::set-output name=public_ip::$PUBLIC_IP" | |
- name: Setup JDK 21 | |
uses: actions/setup-java@v4 | |
with: | |
java-version: '21' | |
distribution: 'temurin' | |
- name: Setup Gradle | |
uses: gradle/actions/setup-gradle@v3 | |
- name: Build with Gradle | |
run: ./gradlew clean build | |
- name: Setting NCP CLI & Credentials | |
run: | | |
cd ~ | |
wget https://www.ncloud.com/api/support/download/5/65 | |
unzip 65 | |
mkdir ~/.ncloud | |
echo -e "[DEFAULT]\nncloud_access_key_id = ${{ env.NCP_ACCESS_KEY }}\nncloud_secret_access_key = ${{ env.NCP_SECRET_KEY }}\nncloud_api_url = ${{ env.NCP_API_URL }}" >> ~/.ncloud/configure | |
- name: Add Github Action Ip to Security group | |
run: | | |
chmod -R 777 ~/cli_linux | |
cd ~/cli_linux | |
./ncloud vserver addAccessControlGroupInboundRule \ | |
--regionCode KR --vpcNo ${{ env.NCP_VPC_ID }} \ | |
--accessControlGroupNo ${{ secrets.NCP_AGC_ID }} \ | |
--accessControlGroupRuleList "protocolTypeCode='TCP', ipBlock='${{ steps.ip.outputs.public_ip }}/32', portRange='22'" | |
- name: Copy OAS to API-doc Server | |
uses: appleboy/scp-action@master | |
with: | |
host: ${{ env.API_DOC_SERVER_HOST }} | |
port: ${{ env.API_DOC_SERVER_SSH_PORT }} | |
username: ${{ env.API_DOC_SERVER_USERNAME }} | |
password: ${{ env.API_DOC_SERVER_PASSWORD }} | |
source: build/api-spec/openapi3.yaml | |
target: ~/app/docs | |
strip_components: 2 | |
overwrite: true | |
- name: Deploy Swagger UI | |
uses: appleboy/ssh-action@master | |
with: | |
host: ${{ env.API_DOC_SERVER_HOST }} | |
port: ${{ env.API_DOC_SERVER_SSH_PORT }} | |
username: ${{ env.API_DOC_SERVER_USERNAME }} | |
password: ${{ env.API_DOC_SERVER_PASSWORD }} | |
script: | | |
CONTAINER_NAME="api-doc" | |
CONTAINER_ID=$(sudo docker ps --filter name=$CONTAINER_NAME -q) | |
if [ -z "$CONTAINER_ID" ]; then | |
sudo docker run -d -p 80:8080 \ | |
-v ~/app/docs:/usr/share/nginx/html/docs \ | |
-e URL="/docs/openapi3.yaml" \ | |
--name $CONTAINER_NAME swaggerapi/swagger-ui:latest | |
fi | |
- name: Remove Github Action Ip from Security group | |
if: always() | |
run: | | |
chmod -R 777 ~/cli_linux | |
cd ~/cli_linux | |
./ncloud vserver removeAccessControlGroupInboundRule \ | |
--regionCode KR --vpcNo ${{ env.NCP_VPC_ID }} \ | |
--accessControlGroupNo ${{ env.NCP_AGC_ID }} \ | |
--accessControlGroupRuleList "protocolTypeCode='TCP', ipBlock='${{ steps.ip.outputs.public_ip }}/32', portRange='${{ env.SSH_PORT }}'" |