]> git.gir.st - ttxd.git/blob - src/thttpd-2.27/cgi-src/ssi.8
initial code import
[ttxd.git] / src / thttpd-2.27 / cgi-src / ssi.8
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.
Imprint / Impressum