Sources and automation for my personal webpage and blog built using Hugo, Woodpecker CI and MinIO
Go to file
Oliver Traber c11086ac68
All checks were successful
ci/woodpecker/push/deploy Pipeline was successful
ci/woodpecker/cron/deploy Pipeline was successful
Update hugo-profile
2024-01-28 02:14:28 +01:00
.woodpecker Allow manual and cron as pipeline triggers 2023-11-12 01:41:24 +01:00
archetypes Initial commit 2023-11-06 00:30:32 +01:00
content/blog Add post about the new blog 2024-01-28 01:00:24 +01:00
static Add post about the new blog 2024-01-28 01:00:24 +01:00
themes Update hugo-profile 2024-01-28 02:14:28 +01:00
.gitignore Initial commit 2023-11-06 00:30:32 +01:00
.gitmodules Initial commit 2023-11-06 00:30:32 +01:00
config.yaml Increase length of preview titles 2024-01-28 02:09:21 +01:00
LICENSE Add license and readme 2023-11-12 00:28:02 +01:00 Add status badge alt 2023-11-12 00:48:36 +01:00

My personal webpage and blog status-badge

This repo contains the sources for my personal webpage and blog. You can check out the live version at


The site uses the following components:

Content is written using markdown and some YAML configs.


The site is built using a Woodpecker CI pipeline for every change to main. After running hugo, the pipeline publishes the content of the public directory to a MinIO bucket using the mc command-line tool. is in turn just a Nginx server that proxies requests to the MinIO bucket and rewrites the upstream request to a corresponding /index.html file.

The (simplified) proxy config looks like this:

server {
    listen 443 ssl;
    listen [::]:443 ssl;
    http2 on;


    location / {
        rewrite ^(.*)/$ $1/index.html break;
        rewrite ^(.*/[^./]+)$ $1/index.html break;

        proxy_http_version 1.1;
        proxy_connect_timeout 300;
        chunked_transfer_encoding off;

        proxy_intercept_errors on;
        error_page 404 =404 /404.html;

        proxy_set_header Host "";
        proxy_set_header Connection "";