Add Minishell Write Up - THCon 2024 (#42) #11
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: Build and deploy HUGO website | |
on: | |
# Runs on pull requests to check that the website is building without errors | |
pull_request: | |
# Runs on push/merge to main to deploy the new website | |
# Only run if the push updates website sources | |
push: | |
paths: | |
- src/** | |
branches: | |
- main | |
# Allows you to run this workflow manually from the Actions tab | |
workflow_dispatch: | |
jobs: | |
# Build job | |
build: | |
runs-on: ubuntu-latest | |
steps: | |
# Checkout repo AND ITS SUBMODULES | |
- name: π Checkout | |
uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
# Build the static website with the provided docker-compose rules | |
- name: π οΈ Build with HUGO | |
run: | | |
docker compose up builder --exit-code-from builder | |
# Upload build artifacts for deployment or download | |
- name: π Upload Artifacts | |
uses: actions/upload-artifact@v3 | |
with: | |
name: build | |
path: ./build/blog | |
# Deployment job: heavily inspired from https://swharden.com/blog/2022-03-20-github-actions-hugo/ | |
# /!\ only triggers on push events and manually triggered | |
deploy: | |
needs: [build] | |
if: ${{ github.event_name == 'push' || github.event_name == 'workflow_dispatch' }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: π οΈ Setup build directory | |
run: | | |
mkdir -p build/blog | |
- name: π₯ Download build Artifacts | |
uses: actions/download-artifact@v3 | |
with: | |
name: build | |
path: build/blog | |
# Create the SSH key file and fill the known_hosts to avoid a prompt from ssh (1st time connecting to remote host) | |
- name: π Create Key File | |
run: | | |
mkdir ~/.ssh | |
touch ~/.ssh/id_rsa | |
chmod 600 ~/.ssh/id_rsa | |
- name: π Load Host Keys | |
run: | | |
echo "${{ secrets.SSH_KNOWN_HOSTS }}" > ~/.ssh/known_hosts | |
- name: π Populate Key | |
run: | | |
echo "${{ secrets.PRIVATE_SSH_KEY }}" > ~/.ssh/id_rsa | |
# Upload the build to the remote server location: the volume shared by the nginx container serving http requests | |
- name: π Upload | |
run: | | |
rsync --archive --stats --verbose --delete ./build/blog/* ${{ secrets.CI_USER_NAME }}@iscsc.fr:${{ secrets.STATIC_WEBSITE_PATH}} | |
# Finally notify of the new article (if any) on the iScsc discord server | |
# action jitterbit/get-changed-files@v1 doesn't support 'workflow_dispatch' events: https://github.com/jitterbit/get-changed-files/issues/38 | |
notify: | |
needs: [deploy] | |
if: ${{ github.event_name != 'workflow_dispatch' }} | |
runs-on: ubuntu-latest | |
steps: | |
# Checkout repo, no need to checkout submodule | |
- name: π Checkout | |
uses: actions/checkout@v3 | |
# Get the list of added, changed, removed, and renamed files | |
- name: π Get changed files | |
uses: jitterbit/get-changed-files@v1 | |
id: files | |
with: | |
format: space-delimited | |
- name: Print changed files... | |
run: | | |
echo "All:" | |
echo "${{ steps.files.outputs.all }}" | |
echo "Added:" | |
echo "${{ steps.files.outputs.added }}" | |
echo "Removed:" | |
echo "${{ steps.files.outputs.removed }}" | |
echo "Renamed:" | |
echo "${{ steps.files.outputs.renamed }}" | |
echo "Modified:" | |
echo "${{ steps.files.outputs.modified }}" | |
echo "Added+Modified:" | |
echo "${{ steps.files.outputs.added_modified }}" | |
- name: π¨ Notify on Discord | |
run: | | |
python3 -m pip install requests PyYAML | |
python3 ./scripts/new_article.py ${{ steps.files.outputs.added }} |