feat: game that actually works! #67
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 on release | |
on: | |
push: | |
branches: | |
- master | |
- develop | |
release: | |
types: [published] | |
jobs: | |
docker-push-api: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Publish to Registry | |
uses: elgohr/Publish-Docker-Github-Action@v5 | |
env: | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
JWT_SECRET: ${{ secrets.JWT_SECRET }} | |
with: | |
name: arquisoft/wiq_en2b/api | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
workdir: api | |
buildargs: | | |
DATABASE_USER | |
DATABASE_PASSWORD | |
JWT_SECRET | |
docker-push-webapp: | |
runs-on: ubuntu-latest | |
permissions: | |
contents: read | |
packages: write | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Create .env file | |
run: echo "REACT_APP_API_ENDPOINT=http://${{ secrets.DEPLOY_HOST }}:8080" > webapp/.env | |
- name: Publish to Registry | |
uses: elgohr/Publish-Docker-Github-Action@v5 | |
env: | |
REACT_APP_API_ENDPOINT: http://${{ secrets.DEPLOY_HOST }}:8080 | |
teamname: wiq_en2b | |
with: | |
name: arquisoft/wiq_en2b/webapp | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
workdir: webapp | |
buildargs: | | |
REACT_APP_API_ENDPOINT | |
docker-push-question-generator: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Publish to Registry | |
uses: elgohr/Publish-Docker-Github-Action@v5 | |
env: | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
with: | |
name: arquisoft/wiq_en2b/question-generator | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
registry: ghcr.io | |
workdir: questiongenerator | |
buildargs: | | |
DATABASE_USER | |
DATABASE_PASSWORD | |
deploy: | |
name: Deploy over SSH | |
runs-on: ubuntu-latest | |
needs: [docker-push-api, docker-push-webapp, docker-push-question-generator] | |
steps: | |
- name: Deploy over SSH | |
uses: fifsky/ssh-action@master | |
env: | |
API_URI: ${{ secrets.DEPLOY_HOST }} | |
DATABASE_USER: ${{ secrets.DATABASE_USER }} | |
DATABASE_PASSWORD: ${{ secrets.DATABASE_PASSWORD }} | |
JWT_SECRET: ${{ secrets.JWT_SECRET }} | |
with: | |
host: ${{ secrets.DEPLOY_HOST }} | |
user: ${{ secrets.DEPLOY_USER }} | |
key: ${{ secrets.DEPLOY_KEY }} | |
command: | | |
wget https://raw.githubusercontent.com/arquisoft/wiq_en2b/master/docker-compose.yml -O docker-compose.yml | |
wget https://raw.githubusercontent.com/arquisoft/wiq_en2b/master/.env -O .env | |
echo "DATABASE_USER=${{ secrets.DATABASE_USER }}" >> .env | |
echo "DATABASE_PASSWORD=${{ secrets.DATABASE_PASSWORD }}" >> .env | |
echo "JWT_SECRET=${{ secrets.JWT_SECRET }}" >> .env | |
echo "API_URI=http://${{ secrets.DEPLOY_HOST }}:8080" >> .env | |
docker compose --profile prod down | |
docker compose --profile prod up -d --pull always |