diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 0000000..118c5d2 --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,85 @@ +name: CI/CD + +on: + push: + pull_request: + +env: + PROJECT_NAME: sfscon-backend + DOCKER_IMAGE: ghcr.io/${{ github.repository }}/sfscon-backend + +jobs: + deploy-test: + runs-on: ubuntu-22.04 + if: github.ref == 'refs/heads/main' + concurrency: deploy-test + env: + SERVER_PORT: 1005 + DOCKER_TAG: ${{ github.sha }}-test + steps: + - name: Checkout source code + uses: actions/checkout@v4 + + - name: Create .env file + uses: noi-techpark/github-actions/env-file@v2 + with: + working-directory: ${{ env.WORKING_DIRECTORY }} + env: + X_SERVER_PORT: ${{ env.SERVER_PORT }} + X_DOCKER_IMAGE: ${{ env.DOCKER_IMAGE }} + X_DOCKER_TAG: ${{ env.DOCKER_TAG }} + + - name: Build and push images + uses: noi-techpark/github-actions/docker-build-and-push@v2 + with: + working-directory: infrastructure + docker-username: ${{ github.actor }} + docker-password: ${{ secrets.GITHUB_TOKEN }} + + - name: Deploy application + uses: noi-techpark/github-actions/docker-deploy@v2 + with: + working-directory: infrastructure/ansible + hosts: "test" + ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }} + docker-username: "noi-techpark-bot" + docker-password: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }} + project-name: ${{ env.PROJECT_NAME }} + + deploy-prod: + runs-on: ubuntu-22.04 + if: github.ref == 'refs/heads/prod' + # needs: test + concurrency: deploy-prod + env: + SERVER_PORT: 1006 + DOCKER_TAG: ${{ github.sha }} + steps: + - name: Checkout source code + uses: actions/checkout@v4 + + - name: Create .env file + uses: noi-techpark/github-actions/env-file@v2 + with: + working-directory: ${{ env.WORKING_DIRECTORY }} + env: + X_SERVER_PORT: ${{ env.SERVER_PORT }} + X_DOCKER_IMAGE: ${{ env.DOCKER_IMAGE }} + X_DOCKER_TAG: ${{ env.DOCKER_TAG }} + + - name: Build and push images + uses: noi-techpark/github-actions/docker-build-and-push@v2 + with: + working-directory: infrastructure + docker-username: ${{ github.actor }} + docker-password: ${{ secrets.GITHUB_TOKEN }} + + - name: Deploy application + uses: noi-techpark/github-actions/docker-deploy@v2 + with: + working-directory: infrastructure/ansible + hosts: "test" + ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }} + docker-username: "noi-techpark-bot" + docker-password: ${{ secrets.GH_PERSONAL_ACCESS_TOKEN }} + project-name: ${{ env.PROJECT_NAME }} \ No newline at end of file