Skip to content

Merge pull request #757 from podverse/develop #531

Merge pull request #757 from podverse/develop

Merge pull request #757 from podverse/develop #531

Workflow file for this run

name: master-branch
on:
push:
branches: [ master ]
jobs:
build:
runs-on: ubuntu-latest
steps:
-
name: Checkout
uses: actions/checkout@v4
-
name: Read node from package.json
uses: culshaw/read-package-node-version-actions@v1
id: package-node-version
-
name: send deploying message to Matrix Alerts room
uses: s3krit/[email protected]
with:
room_id: ${{ secrets.MATRIX_ALERTS_ROOM_ID }}
access_token: ${{ secrets.MATRIX_ACCESS_TOKEN }}
message: "Deploying podverse-api ${{ steps.package-node-version.outputs.version }} to prod..."
server: ${{ secrets.MATRIX_SERVER }}
-
name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
-
name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
-
name: Build and push
uses: docker/build-push-action@v5
with:
context: .
file: ./Dockerfile
push: true
tags: podverse/podverse_api:latest,podverse/podverse_api:${{ steps.package-node-version.outputs.version }}
-
name: Tailscale
uses: tailscale/github-action@main
with:
authkey: ${{ secrets.TAILSCALE_AUTHKEY }}
-
name: log into prod, then deploy latest prod image
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.PROD_SSH_HOST }}
username: ${{ secrets.PROD_SSH_USERNAME }}
key: ${{ secrets.PROD_SSH_PRIVATE_KEY }}
command_timeout: 60m
script: |
docker stop podverse_api_prod
docker rm podverse_api_prod
docker image rm podverse/podverse_api:latest
docker compose -f /opt/podverse-ops/docker-compose/prod/srv/docker-compose.yml up --quiet-pull -d podverse_api
-
name: send deploy finished message to Matrix Alerts room
uses: s3krit/[email protected]
with:
room_id: ${{ secrets.MATRIX_ALERTS_ROOM_ID }}
access_token: ${{ secrets.MATRIX_ACCESS_TOKEN }}
message: "podverse-api ${{ steps.package-node-version.outputs.version }} has finished deploying to prod 🎉"
server: ${{ secrets.MATRIX_SERVER }}