Files
hugoblog/.gitea/workflows/deploy.yml
bennolor 9bb267d464
All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 45s
revert 83639ac94d
revert replaced hashing function for caching
2025-06-17 23:46:38 +02:00

95 lines
2.9 KiB
YAML

name: Build and Deploy
on:
push:
branches: [master]
jobs:
build-and-deploy:
runs-on: ubuntu-latest
env:
RUNNER_TOOL_CACHE: /toolcache
steps:
- name: Checkout
uses: actions/checkout@v3
with:
submodules: false # Don't fetch submodules yet
fetch-depth: 0
# Cache the submodule content
- name: Cache submodules
id: cache-submodules
uses: actions/cache@v3
with:
path: |
.git/modules
themes/blowfish
key: ${{ runner.os }}-submodules-${{ hashFiles('.gitmodules') }}
restore-keys: |
${{ runner.os }}-submodules-
# Initialize submodules if cache miss
- name: Initialize submodules
if: steps.cache-submodules.outputs.cache-hit != 'true'
run: git submodule update --init --recursive
# Cache Hugo dependencies and modules
- name: Cache Hugo dependencies
uses: actions/cache@v3
with:
path: /tmp/hugo_cache
key: ${{ runner.os }}-hugo-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-hugo-
- name: Setup Hugo
uses: peaceiris/actions-hugo@v2
with:
hugo-version: "latest"
extended: true
# Cache resources but not public to prevent infinite loops
- name: Cache Hugo resources
uses: actions/cache@v3
with:
path: resources/_gen
key: ${{ runner.os }}-hugo-resources-${{ hashFiles('content/**', 'layouts/**', 'static/**', 'themes/**', 'config/**') }}
restore-keys: |
${{ runner.os }}-hugo-resources-
- name: Build
run: hugo --minify --buildFuture
# Cache apt packages
- name: Cache apt packages
uses: actions/cache@v3
with:
path: /var/cache/apt/archives
key: ${{ runner.os }}-apt-${{ hashFiles('**/deploy.yml') }}
restore-keys: |
${{ runner.os }}-apt-
- name: Install rsync
run: sudo apt-get update && sudo apt-get install -y rsync
- name: Install SSH Key
uses: shimataro/ssh-key-action@v2
with:
key: ${{ secrets.SSH_PRIVATE_KEY }}
known_hosts: unnecessary
if_key_exists: replace
- name: Adding Known Hosts
run: ssh-keyscan -p ${{ secrets.SERVER_PORT }} -H ${{ secrets.SERVER_HOST }} >> ~/.ssh/known_hosts
- name: Deploy with rsync
run: |
rsync -avz --delete -e "ssh -p ${{ secrets.SERVER_PORT }}" \
./public ./botPolicy.yaml ./nginx.conf ./docker-compose.prod.yml \
${{ secrets.SERVER_USER }}@${{ secrets.SERVER_HOST }}:${{ secrets.DEPLOY_PATH }}
- name: Restart Docker container
run: |
ssh -p ${{ secrets.SERVER_PORT }} ${{ secrets.SERVER_USER }}@${{ secrets.SERVER_HOST }} \
"cd ${{ secrets.DEPLOY_PATH }} && sudo docker compose -f docker-compose.prod.yml up -d --build"