In this post we will see how to setup Hugo and leverage GitHub webhooks to auto-run Hugo whenever a commit is pushed to the GitHub repository. The basic process goes like this
SSH into the server and then install Hugo on the server. Obtain the link to the latest release build from https://github.com/gohugoio/hugo/releases
wget https://github.com/gohugoio/hugo/releases/download/v0.62.0/hugo_extended_0.62.0_Linux-64bit.deb
sudo dpkg -i hugo_extended_0.62.0_Linux-64bit.deb
You can find the Hugo config.toml file from my website in this gist. Notice the parameters that is configured for staticman, we will discuss that in depth in the later posts.
I also modified the awesome Ezhil theme to support staticman commenting , error page customization and a custom dark theme. You can find my repository for the modified theme here
For build and deploy automation to work. We make use of GitHub’s webhooks facility. First we need to set up an endpoint that GitHub can hit every time it receives a commit. After a bit of researching I decided to go with Adnan’s awesome Webhook project https://github.com/adnanh/webhook. It seemed perfect for my use case.
Installing Webhook
sudo apt install webhook
Create the hooks.json file containing all the exposed endpoints and commands that needs to be executed. This is the hook file that I wrote to handle GitHub triggered events. Webhook also matches the signature so that the endpoint only works when triggered by GitHub.
[
{
"id": "web_hook_endpoint_name",
"execute-command": "/home/ubuntu/deploy.sh",
"command-working-directory": "specify-the-working-directory",
"trigger-rule": {
"and": [
{
"match": {
"type": "payload-hash-sha1",
"secret": "SECRET-KEY-THATS-SPECIFIED-AT-GITHUB-WEBHOOK-CONFIG",
"parameter": {
"source": "header",
"name": "X-Hub-Signature"
}
}
}
]
}
}
]
The deploy.sh file looks like this and it resides in my blog’s local git repository folder
!/bin/sh
git push
git pull origin master
hugo
git add .
git commit -m "Hugo: Auto generated public file changes"
git push origin master
Run webhooks with the hooks.json file that we created above. Keep in mind that if you installed webhooks from apt then it might be already running as a service. I suggest that you kill it before starting again.
sudo killall webhook
webhook -hooks hooks.json -verbose
Once that is setup we need to choose an endpoint URL. I created a subdomain from my domain registrar’s control panel and setup the Nginx reverse proxy configuration for it. Also used Certbot to generate the certificate for this subdomain. This is the basic reverse proxy configuration that I used to point all traffic incoming to the webhook process running at port 9000
server {
server_name deploy.patali.in;
index index.html;
location / {
proxy_pass http://localhost:9000/hooks/web_hook_endpoint_name;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
client_max_body_size 0;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload";
add_header Referrer-Policy "same-origin";
access_log /var/log/nginx/webhook-deploy-patali.access.log;
error_log /var/log/nginx/webhook-deploy-patali.error.log;
}
}
That’s all. Now every time a commit is pushed to the repository the deploy.sh script get triggered automatically and the new site changes becomes live instantly. In the next part of this blog series we will learn about integrating Staticman commenting system into a Hugo generated static website.
Quick links to other parts in this series
Part 1 | Part 2 | Part 3 | Part 4