All checks were successful
Build and Deploy / build-and-deploy (push) Successful in 45s
revert replaced hashing function for caching
95 lines
2.9 KiB
YAML
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"
|