diff --git a/.github/workflows/deploy-staging.yml b/.github/workflows/deploy-staging.yml index d1c8400..2b612fe 100644 --- a/.github/workflows/deploy-staging.yml +++ b/.github/workflows/deploy-staging.yml @@ -47,4 +47,5 @@ jobs: script: | sudo apt update && sudo apt install -y jq python3-pip cd infra-hideyoshi.com - ./deploy.sh --staging \ No newline at end of file + ./deploy.sh --staging + ./refresh.sh \ No newline at end of file diff --git a/.github/workflows/refresh-deployment.yml b/.github/workflows/refresh-deployment.yml new file mode 100644 index 0000000..3c1f566 --- /dev/null +++ b/.github/workflows/refresh-deployment.yml @@ -0,0 +1,47 @@ +name: workflow_02 + +on: + workflow_run: + workflows: ["build"] + branches: [main] + types: + - completed + repository_dispatch: + types: [refresh-deployments] + +jobs: + refresh-deployments: + name: Refresh deployments + environment: prod + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v3 + + - name: Executing Remote Commands - Refresh All Deployments + env: + deployments: ${{ github.event.client_payload.deployments }} + if: ${{ env.deployments == '' || github.event.workflow_run.conclusion == 'success' }} + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.SSH_HOST }} + username: ${{ secrets.SSH_USER }} + port: ${{ secrets.SSH_PORT }} + key: ${{ secrets.SSH_KEY }} + script: | + [[ -d infra-hideyoshi.com ]] && \ + ./infra-hideyoshi.com/refresh.sh + + - name: Executing Remote Commands - Refresh Specific Deployments + env: + deployments: ${{ github.event.client_payload.deployments }} + if: ${{ env.deployments != '' }} + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.SSH_HOST }} + username: ${{ secrets.SSH_USER }} + port: ${{ secrets.SSH_PORT }} + key: ${{ secrets.SSH_KEY }} + script: | + [[ -d infra-hideyoshi.com ]] && \ + ./infra-hideyoshi.com/refresh.sh ${{ env.deployments }} \ No newline at end of file diff --git a/deploy.sh b/deploy.sh index 152b02f..9c8eb9a 100755 --- a/deploy.sh +++ b/deploy.sh @@ -111,9 +111,6 @@ function main() { fi - # Refreshes all pods in case of a new image - bash ./refresh.sh - exit 0 } diff --git a/refresh.sh b/refresh.sh index 3d2a6ed..9f3e17d 100755 --- a/refresh.sh +++ b/refresh.sh @@ -4,12 +4,16 @@ NAMESPACES=( portfolio ) -DEPLOYMENTS=( - "frontend-deployment" - "backend-deployment" - "storage-deployment" - "storage-processor-deployment" -) +if [ $# -eq 0 ]; then + DEPLOYMENTS=( + "frontend-deployment" + "backend-deployment" + "storage-deployment" + "storage-processor-deployment" + ) +else + DEPLOYMENTS=("$@") +fi for i in "${NAMESPACES[@]}"; do for x in "${DEPLOYMENTS[@]}"; do