simoncor.net/.gitea/workflows/build.yaml

72 lines
1.8 KiB
YAML
Raw Normal View History

---
# generic
name: 'Build and Publish'
on:
push:
branches:
2024-07-25 09:33:32 +02:00
- 'main'
# jobs
jobs:
# build container
2024-07-04 16:08:35 +02:00
Build:
runs-on: 'ubuntu-latest'
steps:
2024-09-06 16:36:36 +02:00
# setup build action
- name: 'setup docker buildx'
uses: 'docker/setup-buildx-action@v3'
# checkout code
- name: 'Clone repo'
uses: 'actions/checkout@v2'
# login to cr.simoncor.net
- name: 'Login to cr.simoncor.net'
uses: 'docker/login-action@v2'
with:
registry: 'cr.simoncor.net'
username: ${{ vars.REGISTER_USERNAME }}
password: ${{ vars.REGISTER_PASSWORD }}
# build and publish container
- name: 'Build and Publish'
2024-09-06 16:36:36 +02:00
uses: 'docker/buildx-push-action@v6'
with:
context: '.'
file: 'Dockerfile.linux.amd64'
push: true
2024-09-06 12:13:57 +02:00
tags: 'cr.simoncor.net/siempie/simoncor-net:latest,cr.simoncor.net/siempie/simoncor-net:${{ gitea.sha }}'
2024-09-06 16:36:36 +02:00
cache-from: '/tmp/cache-folder'
2024-09-06 13:45:38 +02:00
# kubernetes deployment
2024-07-04 16:08:35 +02:00
Deployment:
runs-on: 'ubuntu-latest'
needs: "Build"
steps:
# name: Build
2024-09-06 13:45:38 +02:00
- name: 'Kubernetes deployment'
uses: 'appleboy/ssh-action@v1.0.3'
with:
# bastion
2024-09-06 12:12:50 +02:00
proxy_host: 'wireguard.do.siempie.com'
proxy_port: '22'
proxy_username: ${{ secrets.USERNAME }}
proxy_key: ${{ secrets.SSHKEY }}
2024-09-06 13:45:38 +02:00
# kubernetes management
2024-09-06 12:12:50 +02:00
host: 'mgmt01.infra.vpn.mirahsimon.us'
port: '22'
username: ${{ secrets.USERNAME }}
key: ${{ secrets.SSHKEY }}
# command
script: |
2024-09-06 12:51:30 +02:00
sudo -u simon kubectl apply -f /home/simon/Documents/kaas-simoncor-net/manifests
2024-09-06 13:51:33 +02:00
sudo -u simon kubectl rollout restart --namespace=simoncor-net deployment simoncor-net