#
# Nginx server configuration for the Monitoring Plugins.
#
# See:
# /usr/share/doc/nginx-doc/examples
#
# http://wiki.nginx.org/Pitfalls
# http://wiki.nginx.org/QuickStart
# http://wiki.nginx.org/Configuration
#
#
# TLS configuration.
#
ssl_ciphers HIGH:!aNULL:!MD5:!3DES:!SSLv2:@STRENGTH;
ssl_dhparam /home/plugins/etc/ssl/dh-parameters.pem;
#
# Server definition for .
#
server {
listen 130.133.8.40:443 ssl http2;
listen 130.133.8.40:444 ssl http2;
server_name monitoring-plugins.org www.monitoring-plugins.org;
root /home/plugins/web/port-$server_port;
ssl_certificate /home/plugins/etc/ssl/monitoring-plugins.crt;
ssl_certificate_key /home/plugins/etc/ssl/monitoring-plugins.key;
#
# Downloads and attachments.
#
location ^~ /download/ {
if ($args = $is_args) {
# Fancy Index: Sort by modification time (descending).
rewrite ^(.*/)$ $1?C=M&O=D last;
}
root /home/plugins/web;
fancyindex on;
fancyindex_default_sort date_desc;
fancyindex_name_length 40;
fancyindex_exact_size off;
fancyindex_time_format "%F";
fancyindex_css_href /resources/plugins.css;
fancyindex_ignore ^timestamp$;
}
location ^~ /attachments/ {
root /home/plugins/web;
}
#
# Make Mailman archives available for Gmane TEMPORARILY.
#
location ^~ /mbox/ {
root /home/plugins/tmp/;
fancyindex on;
fancyindex_exact_size off;
fancyindex_css_href /resources/plugins.css;
}
#
# Mailman and cgit.
#
location ^~ /cgit {
root /home/git/opt/cgit/web;
}
location ^~ /archive/ {
alias /home/mailman/server/archives/public/;
}
location ^~ /list/icons/ {
alias /home/mailman/server/icons/;
}
location ~ ^/list(?:/listinfo)?/?$ {
return 301 /support.html;
}
location ~ ^/(?:list/|repositories) {
root /home/plugins/web/cgi-bin;
fastcgi_split_path_info ^(/list/[^/]+|/repositories)(.*)$;
fastcgi_pass unix:/var/run/fcgiwrap.socket;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
include /etc/nginx/fastcgi_params;
gzip off; # Scripts have to complete before getting gzipped.
}
#
# Rspamd.
#
location /rspamd/ {
proxy_pass http://127.0.0.1:11334/;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
#
# Redirects etc.
#
location = /favicon.ico {
root /home/plugins/web/site/resources;
}
location = /doc/release-notes/1-5.html {
return 301 /news/release-1-5.html;
}
location = /download/snapshot/monitoring-plugins-HEAD.tar.gz {
return 301 /download/snapshot/monitoring-plugins-master.tar.gz;
}
location = /rfc/new_threshold_syntax {
return 301 /doc/new-threshold-syntax.html;
}
location = /taxonomy/term/2 {
return 301 /doc/writing-perl-plugins.html;
}
location ^~ /snapshot {
return 301 /download$request_uri;
}
location ~ ^/(?:man.*|guidelines|extra-opts)$ {
return 301 /doc$request_uri.html;
}
}
#
# Our plugins/t/check_http.t checks .
#
server {
listen 130.133.8.40:80;
server_name test.monitoring-plugins.org;
root /home/plugins/web/site;
location ~ ^/(?:index.html)?$ {
# Serve index.html.
}
location / {
return 301 https://www.monitoring-plugins.org$request_uri;
}
}
#
# Redirect HTTP to . Ditto for the test
# instance.
#
server {
listen 130.133.8.40:80;
server_name monitoring-plugins.org www.monitoring-plugins.org;
return 301 https://www.monitoring-plugins.org$request_uri;
}
server {
listen 130.133.8.40:81;
server_name monitoring-plugins.org www.monitoring-plugins.org;
return 301 https://www.monitoring-plugins.org:444$request_uri;
}
#
# Outdated domains. Can be deleted in 2026.
#
server {
listen 130.133.8.40:80 default_server;
listen 130.133.8.40:443 default_server ssl http2;
root /home/plugins/web-redirect;
ssl_certificate /home/plugins/etc/ssl/monitoring-plugins.crt;
ssl_certificate_key /home/plugins/etc/ssl/monitoring-plugins.key;
}
server {
listen 130.133.8.40:81 default_server;
listen 130.133.8.40:444 default_server ssl http2;
root /home/plugins/web-redirect;
ssl_certificate /home/plugins/etc/ssl/monitoring-plugins.crt;
ssl_certificate_key /home/plugins/etc/ssl/monitoring-plugins.key;
}