yhdev/dat/nginx-confgen.md
Yorhel 6242b2ee9c Rewrite to static site
With a complete reorganisation of the directory structure and most of
the content converted to pandoc-flavoured markdown.

Some TODO's left before this can go live:
- Main page
- Atom feeds
- Bug tracker
2019-03-23 11:56:53 +01:00

1.5 KiB

% Nginx Configuration Generator

nginx-confgen is a simple preprocessor and macro system for nginx and nginx-like configuration files. It support variable substitution, macro expansion and using the output of arbitrary commands to generate config files.

Example

pre_set $certdir /etc/nginx-certificates/;

# Fetch the 'resolver' from /etc/resolv.conf
pre_exec $nameserver "grep nameserver /etc/resolv.conf \\
                      | head -n 1 | sed 's/^nameserver //'";
resolver $nameserver;

# Convenient macro to create a HTTPS virtual host
macro vhost $domain @aliases &block {
  server {
    listen [::]:443 ssl;
    server_name $domain @aliases;

    ssl_certificate     $certdir/$domain/fullchain.pem;
    ssl_certificate_key $certdir/$domain/privkey.pem;
    pre_if -f $certdir/$domain/ocsp.der {
      ssl_stapling_file $certdir/$domain/ocsp.der;
    }

    █
  }
}

vhost example.com www.example.com {
  root /var/www/example.com;
}

See the manual for more features.

Download

If you're on a x86_64 Linux system, you can simply use the binary:

curl -s https://dev.yorhel.nl/download/nginx-confgen-linux-amd64-1.2.tar.gz | tar -xzf-
./nginx-confgen <input.conf >output.conf

To compile from source, install Haskell Stack and run:

git clone https://code.blicky.net/yorhel/nginx-confgen.git
cd nginx-confgen
stack install

The git repository is also available for online browsing.