Removed rm -rf .env command in deploy workflow
#7
This file contains hidden or 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: "Build and Push to GHCR" | |
| on: | |
| push: | |
| branches: | |
| - main | |
| - dev | |
| workflow_dispatch: # 👈 Added manual trigger support | |
| jobs: | |
| Deploy: | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout | |
| uses: actions/checkout@v3 | |
| - name: Login to GitHub Container Registry | |
| uses: docker/login-action@v2 | |
| with: | |
| registry: ghcr.io | |
| username: ${{ secrets.GHCR_USERNAME }} | |
| password: ${{ secrets.GHCR_TOKEN }} | |
| - name: Build and Push Docker Image | |
| run: | | |
| export CURRENT_BRANCH=${GITHUB_REF#refs/heads/} | |
| export REPO_NAME=$(echo $GITHUB_REPOSITORY | tr '[:upper:]' '[:lower:]') | |
| export TAG=$([[ $CURRENT_BRANCH == $(basename ${{ github.ref }}) ]] && echo $CURRENT_BRANCH || echo "latest") | |
| export GITHUB_REF_IMAGE=ghcr.io/$REPO_NAME:$GITHUB_SHA | |
| export GITHUB_BRANCH_IMAGE=ghcr.io/$REPO_NAME:$TAG | |
| docker build -t $GITHUB_REF_IMAGE -t $GITHUB_BRANCH_IMAGE . | |
| echo "Pushing Image to GitHub Container Registry" | |
| docker push $GITHUB_REF_IMAGE | |
| docker push $GITHUB_BRANCH_IMAGE | |
| - name: Deploy on PROD server | |
| if: github.ref == 'refs/heads/main' | |
| uses: appleboy/ssh-action@v0.1.7 | |
| with: | |
| host: ${{ secrets.PROD_REMOTE_SERVER_ADDRESS }} | |
| username: ${{ secrets.PROD_SERVER_USERNAME }} | |
| key: ${{ secrets.PROD_REMOTE_SERVER_KEY }} | |
| port: ${{ secrets.PROD_SSH_PORT }} | |
| script: | | |
| pwd | |
| cd myriadflow_gateway | |
| sudo docker stop myriadflow_gateway && sudo docker rm myriadflow_gateway && sudo docker rmi ghcr.io/myriadflow/gateway_v2:main | |
| echo ${{ secrets.GHCR_TOKEN }} | sudo docker login ghcr.io -u secrets.GHCR_USERNAME --password-stdin | |
| sudo docker pull ghcr.io/myriadflow/gateway_v2:main | |
| echo "Loading environment variables from secrets..." | |
| echo "${{ secrets.PROD_ENV_FILE }}" > .env | |
| sudo docker run --name="myriadflow_gateway" --env-file=.env -p 9090:8080 --network=myriadflow_network -d ghcr.io/myriadflow/gateway_v2:main | |
| # rm -rf .env | |
| - name: Deploy on Development server | |
| if: github.ref == 'refs/heads/dev' | |
| uses: appleboy/ssh-action@v0.1.7 | |
| with: | |
| host: ${{ secrets.PROD_REMOTE_SERVER_ADDRESS }} | |
| username: ${{ secrets.PROD_SERVER_USERNAME }} | |
| key: ${{ secrets.PROD_REMOTE_SERVER_KEY }} | |
| port: ${{ secrets.PROD_SSH_PORT }} | |
| script: | | |
| pwd | |
| # cd app.gateway | |
| sudo docker stop myriadflow_gateway_dev && sudo docker rm myriadflow_gateway_dev && sudo docker rmi ghcr.io/myriadflow/gateway_v2:dev | |
| echo ${{ secrets.GHCR_TOKEN }} | sudo docker login ghcr.io -u secrets.GHCR_USERNAME --password-stdin | |
| sudo docker pull ghcr.io/myriadflow/gateway_v2:dev | |
| echo "Loading environment variables from secrets..." | |
| echo "${{ secrets.DEV_ENV_FILE }}" > .env | |
| sudo docker run --name="myriadflow_gateway_dev" --env-file=.env -p 9091:8080 --network=myriadflow_network -d ghcr.io/myriadflow/gateway_v2:dev | |
| rm -rf .env |