REDIRECT(8) System Manager's Manual (smm) REDIRECT(8)

redirect
Simple redirection CGI program

redirect

Three steps to set up a redirection:
  1. Make sure your web server is set up to allow CGI programs.
  2. Make a symbolic link from the file or directory you want to redirect, pointing at this program in the CGI bin directory.
  3. Add an entry to the file ".redirects" in the directory where your http server runs CGI programs. For most servers, this is the directory where the given CGI program lives.

The format of the .redirects file is a bunch of lines with a filename, whitespace, and the new URL. For example:

    /test/oldfile.html    http://www.acme.com/test/newfile.html 

The easiest way to figure out precisely what filename to put into .redirects is to set up the symlink and then click on it. You'll get back a "404 Not Found" page which includes the filename as received by the redirect program, and that's what you want to use.
You can also add a wildcard specification to redirect whole groups of files. For example:

    /wildtest/*          http://www.acme.com/test- 

will cause an access to the /wildtest/somefile.html to be redirected to http://www.acme.com/test-somefile.html. (Note that the asterisk need not be preceded by a slash.)
Note: redirect is designed for use with thttpd(8) and but the latter has its own built-in redirect support today which is probably what you want. Using redirect with other web servers may require some hacking. A possible gotcha is with the symbolic link from the old file pointing at this script - servers other than thttpd may not allow that link to be run as a CGI program, because they don't check the link to see that it points into the allowed CGI directory.

thttpd(8), merecat(8), merecat.conf(5)

Jef Poskanzer ⟨jef@mail.acme.com⟩

It would be really cool to have this program look for the .redirects file in the same directory as the file being redirected, instead of in the binaries directory. Unfortunately, this appears to be impossible with the information CGI gives, plus the non-standardized but widespread practice of running CGI programs in the directory where the binary lives. Perhaps CGI 1.2 will address this.
The wildcard mechanism is very primitive. In particular, any characters that follow the asterisk are blithely ignored.
August 3, 2019 merecat (2.32)