Publish Website #1360
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: "Publish Website" | |
on: | |
schedule: | |
- cron: '0 2,14 * * *' | |
workflow_dispatch: | |
jobs: | |
publish-code: | |
runs-on: ubuntu-latest | |
steps: | |
# See documentation for the action | |
- name: Install SSH key | |
uses: shimataro/ssh-key-action@v2 | |
with: | |
key: ${{ secrets.GIT_SSH_KEY }} | |
known_hosts: ${{ secrets.KNOWN_HOSTS }} | |
if_key_exists: fail | |
- name: Clone repository | |
uses: actions/checkout@v3 | |
with: | |
repository: ictunion/main-website | |
fetch-depth: 0 | |
ref: main | |
ssh-key: ${{ secrets.GIT_SSH_KEY }} | |
ssh-known-hosts: ${{ secrets.KNOWN_HOSTS }} | |
# Nix | |
- uses: DeterminateSystems/nix-installer-action@main | |
- uses: DeterminateSystems/magic-nix-cache-action@main | |
- name: Create anonymized repo | |
run: nix run github:ictunion/git-anonymize -- . -o /tmp/anonymized -n 'ICT Guerrilla' -e '[email protected]' -r HEAD production | |
- name: Publish anonymized repository | |
working-directory: /tmp/anonymized | |
run: | | |
git checkout main | |
git remote add origin [email protected]:ictunion/main-website-public.git | |
git push --force origin main | |
git push origin production:production --force | |
deploy-testing: | |
needs: publish-code | |
runs-on: ubuntu-latest | |
steps: | |
# See documentation for the action | |
- name: Install SSH key | |
uses: shimataro/ssh-key-action@v2 | |
with: | |
key: ${{ secrets.GIT_SSH_KEY }} | |
known_hosts: ${{ secrets.KNOWN_HOSTS }} | |
if_key_exists: fail | |
- name: Clone repository | |
uses: actions/checkout@v3 | |
with: | |
repository: ictunion/main-website-public | |
ref: main | |
ssh-key: ${{ secrets.GIT_SSH_KEY }} | |
ssh-known-hosts: ${{ secrets.KNOWN_HOSTS }} | |
# Nix | |
- uses: DeterminateSystems/nix-installer-action@main | |
- uses: DeterminateSystems/magic-nix-cache-action@main | |
- name: Current time | |
run: date +%c | |
- name: Build website | |
run: nix run . -- --baseURL=https://testing.ictunion.cz | |
- name: Deploy main to testing | |
run: | | |
nix-shell -p rsync --run 'rsync -rtc -I public/ [email protected]:/home/website/testing/var/www' | |
deploy-production: | |
needs: publish-code | |
runs-on: ubuntu-latest | |
steps: | |
# See documentation for the action | |
- name: Install SSH key | |
uses: shimataro/ssh-key-action@v2 | |
with: | |
key: ${{ secrets.GIT_SSH_KEY }} | |
known_hosts: ${{ secrets.KNOWN_HOSTS }} | |
if_key_exists: fail | |
- name: Clone repository | |
uses: actions/checkout@v3 | |
with: | |
repository: ictunion/main-website-public | |
ref: production | |
ssh-key: ${{ secrets.GIT_SSH_KEY }} | |
ssh-known-hosts: ${{ secrets.KNOWN_HOSTS }} | |
# Nix | |
- uses: DeterminateSystems/nix-installer-action@main | |
- uses: DeterminateSystems/magic-nix-cache-action@main | |
- name: Current time | |
run: date +%c | |
- name: Build website | |
run: nix run . -- --baseURL=https://ictunion.cz | |
- name: Deploy main to production | |
run: | | |
nix-shell -p rsync --run 'rsync -rtc public/ [email protected]:/home/website/production/var/www' |