man.cgi with lighttpd
This post describes setting up OpenBSDs man.cgi(8) with lighttpd on Gentoo, with OpenRC.
Reasons for choosing lighttpd over nginx:
- Native CGI binary support
- Native chroot support
Both of these are going to turn out to be very important for man.cgi(8).
Installing man.cgi
First step would be to install a working man.cgi static binary. For this, we need to install to app-text/mandoc with the cgi USE flag:
$ USE="cgi" emerge --ask --verbose app-text/mandoc
This will install a static binary /var/www/cgi-bin/man.cgi.
Installing lighttpd
The default flags for lighttpd are enough to bring in CGI wrapper support.
$ emerge --ask --verbose www-servers/lighttpd
Set up /etc/lighttpd/lighttpd.conf
I am going to assume that this server is only for serving man pages and for nothing else, in which case the following /etc/lighttpd/lighttpd.conf
should suffice:
# chroot to directory (defaults to no chroot)
server.chroot = "/var/www"
server.username = "lighttpd"
server.groupname = "lighttpd"
var.basedir = "/"
var.logdir = "/var/log/lighttpd"
var.statedir = "/var/lib/lighttpd"
server.errorlog = var.logdir + "/error.log"
accesslog.filename = var.logdir + "/access.log"
server.document-root = "/"
server.pid-file = "/var/run/lighttpd.pid"
# NOTE: the order of modules is important.
server.modules = (
"mod_access",
"mod_cgi",
"mod_accesslog"
)
server.indexfiles = ("index.php", "index.html",
"index.htm", "default.htm")
server.follow-symlink = "enable"
server.use-ipv6 = "enable"
# (extensions that are usually handled by mod_cgi, mod_fastcgi, etc).
static-file.exclude-extensions = (".php", ".pl", ".cgi", ".fcgi")
$HTTP["url"] =~ "^/cgi-bin/" {
cgi.assign = (
".cgi" => "/cgi-bin/man.cgi"
)
}
include "mime-types.conf"
Don't start the server yet, it will fail
Set up the /var/www
chroot
From the above configuration, it is clear that we need some extra directories in /var/www
and with proper permissions.
I am going to be a bit lax about permissions, they can be hardened if need be.
$ mkdir -p /var/www/var/{{lib,log}/lighttpd,run,tmp} /var/www/man/system /var/www/dev
$ chown -R lighttpd:lighttpd /var/www/var
$ chmod 777 /var/www/var/{run,tmp}
Set up the /etc/init.d/lighttpd
service
Lighttpd currently needs a /dev/null
to be present inside the chroot at /var/www
which is not there by default.
We will modify the lighttpd init.d file to mount a devtmpfs on /var/www/dev
at each start.
You can of course do it a different way; make it into a separate init, modify existing devtmpfs mounts, etc. This is good enough for local servers.
#!/sbin/openrc-run
# Copyright 1999-2016 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
extra_started_commands="reload graceful"
LIGHTTPD_PID="$(grep pid ${LIGHTTPD_CONF} | cut -d '=' -f 2 | tr -d \\\" | tr -d [:space:])"
depend() {
need net
use mysql logger spawn-fcgi ldap slapd netmount dns
after famd
after sshd
}
checkconfig() {
if [ ! -f "${LIGHTTPD_CONF}" ] ; then
ewarn "${LIGHTTPD_CONF} does not exist."
return 1
fi
if [ -z "${LIGHTTPD_PID}" ] ; then
eerror "server.pid-file variable in ${LIGHTTPD_CONF}"
eerror "is not set. Please set this variable properly"
eerror "and try again"
return 1
fi
/usr/sbin/lighttpd -t -f ${LIGHTTPD_CONF}
}
start() {
checkconfig || return 1
# Glean lighttpd's credentials from the configuration file
# Fixes bug 454366
LIGHTTPD_USER="$(awk '/^server.username/{s=$3};{sub("\"","",s)};END{print s}' ${LIGHTTPD_CONF})"
LIGHTTPD_GROUP="$(awk '/^server.groupname/{s=$3};{sub("\"","",s)};END{print s}' ${LIGHTTPD_CONF})"
checkpath -d -q -m 0750 -o "${LIGHTTPD_USER}":"${LIGHTTPD_GROUP}" /run/lighttpd/
mount -t devtmpfs none /var/www/dev
ebegin "Starting lighttpd"
start-stop-daemon --start --exec /usr/sbin/lighttpd \
--pidfile "${LIGHTTPD_PID}" -- -f "${LIGHTTPD_CONF}"
eend $?
}
stop() {
local rv=0
ebegin "Stopping lighttpd"
start-stop-daemon --stop --pidfile "${LIGHTTPD_PID}"
umount -R /var/www/dev
}
reload() {
if ! service_started "${SVCNAME}" ; then
eerror "${SVCNAME} isn't running"
return 1
fi
checkconfig || return 1
ebegin "Re-opening lighttpd log files"
start-stop-daemon --pidfile "${LIGHTTPD_PID}" \
--signal HUP
eend $?
}
graceful() {
if ! service_started "${SVCNAME}" ; then
eerror "${SVCNAME} isn't running"
return 1
fi
checkconfig || return 1
ebegin "Gracefully stopping lighttpd"
start-stop-daemon --quiet --pidfile "${LIGHTTPD_PID}" \
--signal INT
if eend $? ; then
rm -f "${LIGHTTPD_PID}"
start
fi
}
Enable and start lighttpd.
$ mkdir -p /var/www/dev
$ rc-update add lighttpd default
$ rc-service lighttpd start
Set up the man pages
We will copy all the man pages into /var/www/man/system
and be done with the whole setup.
$ cp -r /usr/share/man/. /var/www/man/system
$ cd /var/www/man/system
$ makewhatis -T utf8 .
$ echo "system" > /var/www/man/manpath.conf
AND WE ARE DONE
Visit http://localhost/cgi-bin/man.cgi/ to check out them sexy man pages.