Annotation of embedaddon/thttpd/cgi-src/ssi.8, revision 1.1
1.1 ! misho 1: .TH ssi 8 "18 October 1995"
! 2: .SH NAME
! 3: ssi - server-side-includes CGI program
! 4: .SH SYNOPSIS
! 5: .B ssi
! 6: .SH DESCRIPTION
! 7: .PP
! 8: This is an external CGI program that gives you the same functionality
! 9: as the built-in server-side-includes feature in some HTTP daemons.
! 10: It is written for use with thttpd(8), but should be easy to adapt
! 11: to other systems.
! 12: .PP
! 13: To use this program, first make sure it is installed in your server's
! 14: CGI area, and that CGI is enabled.
! 15: Then set up your URLs with the path to the document you want parsed
! 16: as the "pathinfo".
! 17: That's the part of the URL that comes after the CGI program name.
! 18: For example, if the URL to this program is:
! 19: .nf
! 20: http://www.acme.com/cgi-bin/ssi
! 21: .fi
! 22: and the url for your document is:
! 23: .nf
! 24: http://www.acme.com/users/wecoyote/doc.html
! 25: .fi
! 26: then the compound URL that gives you the document filtered through the
! 27: program would be:
! 28: .nf
! 29: http://www.acme.com/cgi-bin/ssi/users/wecoyote/doc.html
! 30: .fi
! 31: .PP
! 32: The format description below is adapted from
! 33: http://hoohoo.ncsa.uiuc.edu/docs/tutorials/includes.html
! 34: .SH "INCLUDE FORMAT"
! 35: .PP
! 36: All directives are formatted as SGML comments within the document.
! 37: This is in case the document should ever find itself in the client's
! 38: hands unparsed.
! 39: Each directive has the following format:
! 40: .nf
! 41: <!--#command tag1="value1" tag2="value2" -->
! 42: .fi
! 43: Each command takes different arguments, most only accept one tag at a time.
! 44: Here is a breakdown of the commands and their associated tags:
! 45: .IP * 4
! 46: .BR config :
! 47: The config directive controls various aspects of the file parsing.
! 48: There are two valid tags:
! 49: .IP o 8
! 50: .BR timefmt :
! 51: gives the server a new format to use when providing dates.
! 52: This is a string compatible with the strftime library call.
! 53: .IP o 8
! 54: .BR sizefmt :
! 55: determines the formatting to be used when displaying the
! 56: size of a file.
! 57: Valid choices are bytes, for a formatted byte count
! 58: (formatted as 1,234,567), or abbrev for an abbreviated version
! 59: displaying the number of kilobytes or megabytes the file occupies.
! 60: .IP * 4
! 61: .BR include :
! 62: Inserts the text of another document into the parsed document.
! 63: The inserted file is parsed recursively, so it can contain
! 64: server-side-include directives too.
! 65: This command accepts two tags:
! 66: .IP o 8
! 67: .BR virtual :
! 68: Gives a virtual path to a document on the server.
! 69: .IP o 8
! 70: .BR file :
! 71: Gives a pathname relative to the current directory. ../ cannot
! 72: be used in this pathname, nor can absolute paths be used.
! 73: .IP * 4
! 74: .BR echo :
! 75: Prints the value of one of the include variables (defined below).
! 76: Any dates are printed subject to the currently configured timefmt.
! 77: The only valid tag to this command is var, whose value is the name of the
! 78: variable you wish to echo.
! 79: .IP * 4
! 80: .BR fsize :
! 81: prints the size of the specified file,
! 82: subject to the sizefmt parameter to the config command.
! 83: Valid tags are the same as with the include command.
! 84: .IP * 4
! 85: .BR flastmod :
! 86: prints the last modification date of the specified file, subject
! 87: to the formatting preference given by the timefmt parameter to config.
! 88: Valid tags are the same as with the include command.
! 89: .SH VARIABLES
! 90: .PP
! 91: A number of variables are made available to parsed documents.
! 92: In addition to
! 93: the CGI variable set, the following variables are made available:
! 94: .IP * 4
! 95: .BR DOCUMENT_NAME :
! 96: The current filename.
! 97: .IP * 4
! 98: .BR DOCUMENT_URI :
! 99: The virtual path to this document (such as /~robm/foo.shtml).
! 100: .IP * 4
! 101: .BR QUERY_STRING_UNESCAPED :
! 102: The unescaped version of any search query the client sent.
! 103: .IP * 4
! 104: .BR DATE_LOCAL :
! 105: The current date, local time zone.
! 106: Subject to the timefmt parameter to the config command.
! 107: .IP * 4
! 108: .BR DATE_GMT :
! 109: Same as DATE_LOCAL but in Greenwich mean time.
! 110: .IP * 4
! 111: .BR LAST_MODIFIED :
! 112: The last modification date of the current document.
! 113: Subject to timefmt like the others.
! 114: .SH "BUGS / DEFICIENCIES"
! 115: .PP
! 116: Does not implement the "exec" directive.
! 117: Actually, I consider this neither a bug nor a deficiency, but some may.
! 118: .SH "SEE ALSO"
! 119: thttpd(8), strftime(3)
! 120: .SH AUTHOR
! 121: Copyright © 1995 by Jef Poskanzer <jef@mail.acme.com>.
! 122: All rights reserved.
! 123: .\" Redistribution and use in source and binary forms, with or without
! 124: .\" modification, are permitted provided that the following conditions
! 125: .\" are met:
! 126: .\" 1. Redistributions of source code must retain the above copyright
! 127: .\" notice, this list of conditions and the following disclaimer.
! 128: .\" 2. Redistributions in binary form must reproduce the above copyright
! 129: .\" notice, this list of conditions and the following disclaimer in the
! 130: .\" documentation and/or other materials provided with the distribution.
! 131: .\"
! 132: .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
! 133: .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! 134: .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! 135: .\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
! 136: .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! 137: .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
! 138: .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
! 139: .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
! 140: .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
! 141: .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
! 142: .\" SUCH DAMAGE.
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>