RC-HTTPD(8) RC-HTTPD(8) NAME rc-httpd - HTTP server SYNOPSIS rc-httpd/rc-httpd DESCRIPTION Rc-httpd serves the requested file or an index of files found under a website's root directory, or, in the case of CGI, executes a specified CGI program. CONFIGURATION As all pieces of rc-httpd are shell scripts, configuration is achieved by setting variables and adding, removing or modifying commands in various files. rc-httpd rc_httpd_dir must be set to the root of the rc-httpd instal- lation, the directory containing the rc-httpd script. path must include rc_httpd_dir/handlers ahead of the base system's path elements. cgi_path is substituted for path when cgi scripts are run. (Be sure to set path back in rc-based cgi scripts.) extra_headers is an optional list of strings to emit when sending http headers. SERVER_PORT is the port HTTP is to be served on. select-handler PATH_INFO is the location relative to the website's root directory of the file to be displayed. Typically, the location from the incoming request is honored. FS_ROOT sets the root directory of the website. NOINDEXFILE instructs the dir-index module not to look for index.html files, otherwise if an index.html file is found dir-index will exec serve-static to serve the file. At pre- sent there is no module to serve an index file but not a directory. If you do not want directory indexing at all, replace static-or-index with serve-static, which will report 503 forbidden for directories. Page 1 Plan 9 (printed 1/15/25) RC-HTTPD(8) RC-HTTPD(8) Multiple virtual hosts may be configured by creating condi- tional statements that act upon the SERVER_NAME variable. Fine-grained control of specific request strings may be con- figured via a similar method acting upon the location and/or other variables. The REMOTE_USER variable provides a user identification string supplied by the client as part of user authentica- tion. EXAMPLES The following examples demonstrate possible ways to config- ure select-handler. Serve static files: if(~ $SERVER_NAME 9front.org){ PATH_INFO=$location FS_ROOT=/usr/sl/www/$SERVER_NAME exec static-or-index } HTTP basic authentication: if(~ $SERVER_NAME *restricted.org){ PATH_INFO=$location FS_ROOT=/usr/kgb/www/$SERVER_NAME authorize if(~ $REMOTE_USER (glenda kgb)) exec static-or-index error 401 } CGI: if(~ $SERVER_NAME *cat-v.org){ PATH_INFO=$location FS_ROOT=/usr/sl/www/werc/sites/$SERVER_NAME exec static-or-cgi /usr/sl/www/werc/bin/werc.rc } Custom error message for a denied URL: fn do_error{ do_log $1 echo 'HTTP/1.1 '^$1^$cr emit_extra_headers echo 'Content-type: text/html'^$cr echo $cr echo '<html> <head> <title>'^$1^'</title> </head> <body> <h1>'^$1^'</h1>' echo $2 Page 2 Plan 9 (printed 1/15/25) RC-HTTPD(8) RC-HTTPD(8) echo '<p><i>rc-httpd at' $SERVER_NAME '</i>' echo ' </body> </html> ' } if(~ $location /v8.tar.bz2){ do_error '27b/6' exit } STARTUP Rc-httpd is run from a file in the directory scanned by listen(8), or called as an argument to aux/listen1. The program's standard error may be captured to a log file: exec /rc/bin/rc-httpd/rc-httpd >>[2]/sys/log/www FILES /rc/bin/rc-httpd/rc-httpd /rc/bin/rc-httpd/select-handler /rc/bin/rc-httpd/handlers/authorize /rc/bin/rc-httpd/handlers/cgi /rc/bin/rc-httpd/handlers/dir-index /rc/bin/rc-httpd/handlers/error /rc/bin/rc-httpd/handlers/redirect /rc/bin/rc-httpd/handlers/serve-static /rc/bin/rc-httpd/handlers/static-or-cgi /rc/bin/rc-httpd/handlers/static-or-index /rc/bin/service/tcp80 /sys/log/www SOURCE /rc/bin/rc-httpd SEE ALSO rc(1), listen(8) HISTORY Rc-httpd first appeared in 9front (February, 2013). Page 3 Plan 9 (printed 1/15/25)