NOTE: SOME FUNCTIONALITY EMPLOYS JAVASCRIPT

WASD Web Environment

For version 12.0 release of WASD VMS Web Services.

Published November 2021

Document generated using wasDOC version 2.0.0

Abstract

This document is a guide to supporting Web documents within the WASD Web Services environment. It is not a tutorial on writing HTML documents.

For installation and update details see WASD Web Services - Installation

For detailed configuration information see WASD Web Services - Configuration

For the more significant features and facilities available see WASD Web Services - Features

For information on CGI, CGIplus, ISAPI, OSU, etc., scripting, see WASD Web Services - Scripting

Online Search

   

WASD VMS Web Services – Copyright © 1996-2021 Mark G. Daniel

Apache License, Version 2.0
License

Licensed under the Apache License, Version 2.0 (the "License");

you may not use this software except in compliance with the License. You may obtain a copy of the License at

https://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Mark.Daniel@wasd.vsm.com.au
A pox on the houses of all spamers. Make that two poxes.

All copyright and trademarks within this document belong to their rightful owners. See 10. Attribution and Acknowledgement.

This is a static (file), single document.
Alternative multi-part static and dynamic documents.
Links followed by ⤤ open in a new page.

Table of Content

1.…………………Introduction
2.…………………Document Access and Specification
2.1…………………Document Content Type
2.2…………………Explicitly Specifying Content-Type
2.3…………………Document Specification
2.3.1…………………Absolute File Path
2.3.2…………………Partial (or Relative) File Path
2.4…………………Extended File Specifications (ODS-5)
2.4.1…………………Characters In Request Paths
2.4.2…………………Characters In Server-Generated Paths
2.4.3…………………Document Cache
3.…………………Directory Listing
3.1…………………Controlling Access To A Directory
3.2…………………"Hidden" Files
3.3…………………Server Directives
3.3.1………………….WWW_WASD
3.3.2…………………Layout
3.3.3…………………Directory Style
3.3.4…………………Selective Listing
3.3.5…………………Listing Title
3.3.6…………………Listing Font
3.3.7…………………File Versions
3.3.8…………………Readme Files
3.3.9…………………Listing Delimiters
3.3.10…………………Suppressing Directories
3.3.11…………………Listing Refresh and Expiry
3.3.12…………………Scripting From Directory Listings
3.3.13…………………Auto-Scripting
3.3.14…………………Target Window
3.3.15…………………Specifying Content-Type
3.3.16…………………Icon Plain Text Link
3.3.17…………………Query String
3.3.18…………………Allowing Override
3.4…………………Directory Tree
4.…………………Server Side Includes (SSI)
4.1…………………Virtual Documents
4.2…………………Last-Modified Information
4.3…………………Pre-Expiring Documents
4.4…………………Directive Syntax
4.5…………………Directives
4.5.1…………………#ACCESSES
4.5.2…………………#CONFIG
4.5.3…………………#DIR
4.5.4…………………#DCL
4.5.5…………………#ECHO
4.5.6…………………#ELIF
4.5.7…………………#ELSE
4.5.8…………………#ENDIF
4.5.9…………………#EXEC
4.5.10…………………#EXIT
4.5.11…………………#FCREATED
4.5.12…………………#FLASTMOD
4.5.13…………………#FSIZE
4.5.14…………………#IF
4.5.15…………………#INCLUDE
4.5.16…………………#MODIFIED
4.5.17…………………#ORIF
4.5.18…………………#PRINTENV
4.5.19…………………#SET
4.5.20…………………#SSI
4.5.21…………………#STOP
4.6…………………Variables
4.7…………………Flow Control
4.8…………………Query Strings
4.9…………………File and Virtual Specifications
4.9.1…………………THE_FILE_NAME
4.10…………………Time Format
4.11…………………OSU Compatibility
4.12…………………Script-Generated SSI Documents
5.…………………Document Searching
5.1…………………Plain-Text Search
5.2…………………HTML Search
5.3…………………Search Syntax
5.3.1…………………Standard Search Form
5.3.2…………………Forms-Based Search
5.3.3…………………Search Options
5.3.4…………………Example Search Form
6.…………………VMS Help and Text Libraries
7.…………………Bookreader Books and Libraries
8.…………………Web Document Update
9.…………………Index
10.…………………Attribution and Acknowledgement

1.Introduction

This document provides an overview of non-administration aspects of the WASD package. Intended more for the end-user authoring documents or wishing to use some particular behaviour, most of the aspects descibed here can be used without recourse to the site administrator. Originally intended for an audience inside the organisation where WASD originated, at a time when the Web and web technologies were in their infancy (i.e. last century :-) the document is focused on WASD specifics and admittedly is a little dated in the some of the aspects covered but not in the detail. The descriptions in this document are kept current.

The document assumes a basic understanding of web technologies and uses some terms without explaining them (e.g. HTTP, HTML, URL, CGI, etc.) It is not a tutorial on writing HTML or any other documents.


2.Document Access and Specification

2.1Document Content Type
2.2Explicitly Specifying Content-Type
2.3Document Specification
2.3.1Absolute File Path
2.3.2Partial (or Relative) File Path
2.4Extended File Specifications (ODS-5)
2.4.1Characters In Request Paths
2.4.2Characters In Server-Generated Paths
2.4.3Document Cache

Arbitrary documents may not be accessed.

The server can only access files where the path is allowed according to a specified set of rules specified within the web environment.

Documents must be read-accessible.

The server can only access files that are world readable, or that have an ACL specifically controlling access for "HTTP$SERVER", the server account.

2.1Document Content Type

Document (file) retrieval is initiated by providing the server with the file specification as a URL path. Server configuration determines the format in which the file is returned to the client. It may contain text or images immediately diplayable by the browser, or by a viewer external to the browser may be spawned. The server may automatically activate a script to provide a gateway to non-native information (see description of [AddType] configuration directive in the Technical Overview). The file type (extension) determines the content type by which the server returns (and/or interprets) the file.

The following table lists some of the current file types (as examples) and their associated MIME-style content type. HTML documents are presented layed-up according to the full HTML-capabilities of the browser. Plain-text documents are presented in a fixed-font format. Other types require an external viewer to be activated. Here are a few examples.

.BKB Bookreader document (BNU) text/html, gateway script activated .BKS Bookreader shelf (BNU) text/html, gateway script activated .C C source text/plain .COM DCL procedure text/plain .CONF configuration file text/plain .CPP C++ source text/plain .DECW$BOOK Bookreader document text/html, gateway script activated .FOR Fortran source text/plain .GIF GIF image image/gif .H C header text/plain .HLB VMS Help library text/html, gateway script activated .HTML HyperText Markup Language text/html .HTM HyperText Markup Language text/html .JPG JPEG image image/jpeg .LIS Listing text/plain .MAR Macro source text/plain .PAS Pascal source text/plain .PRO IDL source text/plain .PS PostScript application/PostScript .TEXT Text text/plain .TLB VMS text library text/html, gateway script activated .TXT Text text/plain .SHTML HyperText Markup Language pre-processed text/html .ZIP zipped file application/binary

If other file types are required to be defined contact the Web administrator.

2.2Explicitly Specifying Content-Type

When accessing files it is possible to explicitly specify the identifying content-type to be returned to the browser in the HTTP response header. Of course this does not change the actual content of the file, just the header content-type! This is primarily provided to allow access to plain-text documents that have obscure, non-"standard" or non-configured file extensions.

It could also be used for other purposes, "forcing" the browser to accept a particular file as a particular content-type. This can be useful if the extension is not configured (as mentioned above) or in the case where the file contains data of a known content-type but with an extension conflicting with an already configured extension specifying data of a different content-type.

Enter the file path into the browser's URL specification field ("Location:", "Address:"). Then, for plain-text, append the following query string:

?httpd=content&type=text/plain
/wasd_root/wasdoc/env/file.unknown

For another content-type substitute it appropriately. For example, to retrieve a text file in binary (why I can't imagine :^) use

?httpd=content&type=application/octet-stream
/wasd_root/wasdoc/env/file.unknown?httpd=content&type=text/plain

It is also posssible to "force" the content-type for all files in a particular directory. See 3.3.15 Specifying Content-Type.

Ignored Content-Type

Even then some browsers and/or some operating systems and/or some version combinations insist on ignoring the response header specified content-type and instead seem to second-guess (often incorrectly) based on the file name extension. A common example is the content of DCL procedures on Windows and up-until-fairly-recent versions of Internet Explorer.

Faux Extension

Notwithstanding, if a '$' and then a second extension is appended to the URI this is often sufficient to coerce the browser into displaying the content associated with the bogus extension. In the case of DCL procedure access on a Windows platform try using "$.txt", or for other purposes whatever extension fits the requirement, as in the following examples.

/wasd_root/src/build_all.com$.txt /wasd_root/src/build_all.com$.anythingatall
WASD specially handles a URI in this format when the requested resource is not found by internally stripping the "$." extension and attempting to access the resultant file name again. This technique works for file based resources and not for scripts, etc.

2.3Document Specification

For the "http:" protocol, file and directory locations are specified using URL path syntax where slash-separated ("/") elements delineate a hierarchy leading to a data item. Anyone familiar with the syntax of the Unix file system, or the MS-DOS file system (where back-slashes are hierarchy delimiters), will feel at home with URL syntax. Specifications under VMS are not case-sensitive.

A VMS directory specification

WEB:[TECHNICAL.HTML-PRIMER]
would be represented in URL syntax as
/web/technical/html-primer/
and a VMS file specification
WEB:[TECHNICAL.HTML-PRIMER]HTML-PRIMER.HTML
represented as
/web/technical/html-primer/html-primer.html
Master file directory [000000]
[000000]

It is not required (although not forbidden) to supply a VMS master file directory component ("[000000]", "[000000.", etc.) in a URL specification. Hence the file specification
WEB:[000000]HOME.HTML
should be represented as
/web/home.html

2.3.1Absolute File Path

A file may be specified using an absolute, or full path. This must specify the location of the file exactly. Absolute paths always begin with a forward-slash ("/"). For example:

/web/committee/minutes/1994/1994-09-27.txt /web/committee/constitution.txt /web/committee/membership/fred-bloggs.txt

2.3.2Partial (or Relative) File Path

(Strictly speaking, it is a function of the client to construct a full URL from such a relative URL before sending the request to the server.)

A file may be specified relative to its current location. That is, a current document (or menu) may specify another document file relative to itself. This may be at the current level, a subdirectory, or in another part of the directory tree related to the current. Relative paths never begin with forward-slash ("/").

For example, documents at the same level as the current may be specified without any hierachy being indicated:

1994-07-22.txt 1994-08-24.txt 1994-09-27.txt

Documents at an inferior point in the hierarchy may be specified as in the following example:

1993/1993-02-17.txt 1993/reports/membership.txt other/etc.txt

Documents in a related part of the hierarchy may be referenced using the "./" construct. As with MS-DOS and Unix this syntax indicates the immediately superior directory.

../other_committee/1993/1993-02-17.txt ../other_committee/1993/reports/balance-sheet.txt ../../other_section/committee/constitution.txt

2.4Extended File Specifications (ODS-5)

OpenVMS Alpha V7.2 introduced a new on-disk file system structure, ODS-5. This brings to VMS in general, and WASD and other Web servers in particular, a number of issues regarding the handling of characters previously not encountered during (ODS-2) file system activities.

2.4.1Characters In Request Paths

There is a standard for characters used in HTTP requests paths and query strings (URLs). This includes conventions for the handling of reserved characters, for example "?", "+", "&", "=" that have specific meanings in a request, characters that are completely forbidden, for example white-space, control characters (0x00 to 0x1f), and others that have usages by convention, for example the "~", commonly used to indicate a username mapping. The request can otherwise contain these characters provided they are URL-encoded (i.e. a percentage symbol followed by two hexadecimal digits representing the hexadecimal-encoded character value).

There is also an RMS standard for handling characters in extended file specifications, some of which are forbidden in the ODS-2 file naming conventions, and others which have a reserved meaning to either the command-line interpreter (e.g. the space) or the file system structure (e.g. the ":", "[", "]" and "."). Generally the allowed but reserved characters can be used in ODS-5 file names if escaped using the "^" character. For example, the ODS-2 file name "THIS_AND_THAT.TXT" could be named "This^_^&^_That.txt" on an ODS-5 volume. More complex rules control the use of character combinations with significance to RMS, for instance multiple periods. The following file name is allowed on an ODS-5 volume, "A-GNU-zipped-TAR-archive^.tar.gz", where the non-significant period has been escaped making it acceptable to RMS.

The WASD server will accept request paths for file specifications in both formats, URL-encoded and RMS-escaped. Of course characters absolutely forbidden in request paths must still be URL-encoded, the most obvious example is the space. RMS will accept the file name "This^ and^ that.txt" (i.e. containing escaped spaces) but the request path would need to be specified as "This%20and%20that.txt", or possibly "This^%20and^%20that.txt" although the RMS escape character is basically redundant.

Unlike for ODS-2 volumes, ODS-5 volumes do not have "invalid" characters, so unlike with ODS-2 no processing is performed by the server to ensure RMS compliance.

2.4.2Characters In Server-Generated Paths

When the server generates a path to be returned to the browser, either in a viewable page such as a directory listing or error message, or as a part of the HTTP transaction such as a redirection, the path will contain the URL-encoded equivalent of the canonical form of an extended file specification escaped character. For example, the file name "This^_and^_that.txt" will be represented by "This%20and%20that.txt".

When presenting a file name in a viewable page the general rule is to also provide this URL-equivalent of the unescaped file name, with a small number of exceptions. The first is a directory listing where VMS format has been requested by including a version component in the request file specification. The second is in similar fashion, but with the tree facility, displaying a directory tree. The third is in the navigation page of the UPDate menu. In all of the instances the canonical form of the extended file specification is presented (although any actual reference to the file is URL-encoded as described above).

2.4.3Document Cache

The Web server is most commonly set up to cache static documents (files). A cache is higher speed storage, in-memory, in the server itself. Cached documents are checked periodically for changes when being requested. Changes to a file are determined by the comparing the modification date/time and file length. A common check period is one minute, though it can set longer or even disabled. If a document has changed the old one is discarded from cache (called invalidation) and the new one loaded into cache while being transfered to the client.

After making changes to a document it is possible the server will continue to serve the old one for a short period. This can be overridden by using the browser's Reload facility. This directs the server to go and check the on-disk file regardless, invalidating it if necessary.


3.Directory Listing

3.1Controlling Access To A Directory
3.2"Hidden" Files
3.3Server Directives
3.3.1.WWW_WASD
3.3.2Layout
3.3.3Directory Style
3.3.4Selective Listing
3.3.5Listing Title
3.3.6Listing Font
3.3.7File Versions
3.3.8Readme Files
3.3.9Listing Delimiters
3.3.10Suppressing Directories
3.3.11Listing Refresh and Expiry
3.3.12Scripting From Directory Listings
3.3.13Auto-Scripting
3.3.14Target Window
3.3.15Specifying Content-Type
3.3.16Icon Plain Text Link
3.3.17Query String
3.3.18Allowing Override
3.4Directory Tree

A directory listing is sometimes refered to as a document Index, and is generally titled "Index of …".

Unless disabled by the server's configuration, a directory listing is recognised by the server whenever a wildcard is present in a specification and there is no query string directing another activity (e.g. a document search). Compliant with other web implementations, a directory listing is also generated if a URL specifies a directory only and that directory contains no home page.

All specifications must be made using URL-style paths. See 2.3 Document Specification.

The directory listing is designed to look very much like the basic layout of other servers, except that all directories are grouped at the top. In the opinion of the author, this looks and functions better than when interspersed with the files, as is otherwise common. The default listing provides:

The description can be either just that, a description of the role of that type of file under VMS, or if presented within quotes, an HTML document's own internal description taken from the "<title></title>" element.

Note that directory listings only processes the physical file system. This may or may not correspond to the web environment's virtual mappings.

The following link illustrates the directory listing format: /wasd_root/wasdoc/*.*

VMS-ish Format

The default listing has a generic WWW look about it, however it can be made to look a little more like the format of the VMS "DIRECTORY" command. In this mode the directories are presented as VMS subdirectories, the version number is shown, if a version wildcard was included in the specification then all matching versions are shown, the size is presented in used and allocated blocks, and automatic script activation is disabled. The VMS-style format is enabled by providing an explicit or wildcard version number with the specification, as in the following example: /wasd_root/wasdoc/*.*;

Listing Icons

By default (and generally) WASD installations are configured to return a binary file for unknown content-types (usually triggering a browser "save-as" dialog). For such files, and in fact all files in general, a directory listing icon is usually a link to a plain-text version of the file (regardless of the actual content). This becomes convenient way to access the content for files with "interesting" file name extensions and the actual markup of HTML source files, etc. Of course some files containing non-textual data will be variously displayed as gibberish depending on the browser.

YMMV

Some browsers and operating systems insist they know better than the server and ignore the response-specified content-type, inferring presentation of the content from magic bytes in that content or the trailing dot-separated file name extension.

3.1Controlling Access To A Directory

The following files (empty, or not), when within a specific directory regulate access to that directory, and the listing of any parent directory or subdirectories.

3.2"Hidden" Files

Any file name beginning with a period is hidden from the directory listing mechanism (i.e. in VMS parlance it has only a type/suffix/extension). If specifically accessed they will be retrieved however. Hence the following files would not appear in a directory listing:

.WWW_NOPS .CANT_BE_SEEN .HIDDEN_FROM_VIEW .;1 .WWW_WASD

3.3Server Directives

The WASD server behaviour can be modified using server directives. For directory listings this involves the inclusion of a query string beginning with "?httpd=index". The server detects this URI query string and processes it internally, changing the default action of directory listings.

Multiple directives can be combined by concatenating them with intervening ampersands, as per normal URI syntax.

?httpd=index&autoscript=no ?httpd=index&readme=no ?httpd=index&type=text/plain ?httpd=index&layout=format ?httpd=index&script=script-name ?httpd=index&script=script-name&readme=no ?httpd=index&delimit=none&readme=no&nos=yes

Server directives specified in the URI propagate when moving between directories unless the query string also contains

&local=yes

3.3.1.WWW_WASD

The control file .WWW_WASD can be used to contain server directives. Directives are generally included one per line with "#" prefixed comment lines allowed.

When a .WWW_WASD file is present in a directory it takes precedence over any SSI or URI (query string) directives also being applied, unless it includes an override=yes directive. When this is present any SSI and/or URI directive string is also applied to the request.

# an example .WWW_WASD file autoscript=no readme=no style=sort2 sort=s- override=yes

3.3.2Layout

Allows specification of the directory listing layout from the URL, overriding the server default. The layout directive is a short, case-insensitive string that specifies the included fields, relative placement and optionally the width of the fields in a directory listing. Each field is controlled by a single letter (one with colon-separated parameter) and optional leading decimal number specifying the width. When a width is not specified an appropriate default applies. An underscore is used to indicate a single space and is used to separate the fields (two consecutive works well).

The default layout is:

I__L__R__S__D

The following provide other examples:

?httpd=index&layout=UI__L__R__S__D ?httpd=index&layout=I__L__R__S:b__D ?httpd=index&layout=I__L__R__S__D ?httpd=index&layout=I__15L__S__D ?httpd=index&layout=15L__9R__S ?httpd=index&layout=15N_9C_9R_S

By default the size of files is calculated as 1024 byte kilos.

When using the "S:D", the size is displayed as per "F" with 1000 byte kilos. If it is prefered to have the default display in 1000 byte kilos then set the directory listing layout using:

?httpd=index&layout=I__L__R__S:d__D
or explicitly direct the "kilo" quantity to 1000 with
?httpd=index&layout=I__L__R__S:0__D
to 1024 (as per VMS /UNIT=BYTES) with
?httpd=index&layout=I__L__R__S:2__D
with or without an explicit size directive
?httpd=index&layout=I__L__R__S:2:K__D
The following links illustrate the difference between the "kilo" values:
/wasd_root/wasdoc/*.*?httpd=index&layout=I__L__R__S:0__D (1000)
/wasd_root/wasdoc/*.*?httpd=index&layout=I__L__R__S:2__D (1024)

If unsure of the kilo value being used check the "<meta>" information in the directory listing.

The following links illustrate this functionality by listing this document's directory in various formats.

/wasd_root/wasdoc/*.* Default
/wasd_root/wasdoc/*.*?httpd=index&layout=I__L Only an icon and link.
/wasd_root/wasdoc/*.*;?httpd=index&layout=I__L__S Icon, link and size (in VMS-style format).
/wasd_root/wasdoc/*.*?httpd=index&layout=N__9C__9R Name, day created and day revised.
/wasd_root/wasdoc/*.*?httpd=index&layout=UN__9C__9R Name (in upper-case), day created and day revised.
/wasd_root/wasdoc/*.*?httpd=index&layout=30D:l__S:b__R Description (fixed width) as a link, size in bytes, and day revised.

3.3.3Directory Style

WASD has a default directory listing style where the page title is a series of links to the various directories in the path, then column labels are separated from directory links by a horizontal line, the after the listed directories a blank line, and the listed files, followed by another horizontal line, all in monospace font. There have been a small number of variations on this over the years. The current default (post-v10.4) style is implemented using an HTML table and differs from the historical preformatted text approach.

For each style there is a second variant where the horizontal lines partitioning the listing are not present.

The various directory listing styles are illustrated below.

/wasd_root/wasdoc/*.*
/wasd_root/wasdoc/*.*?httpd=index&style=default2
/wasd_root/wasdoc/*.*?httpd=index&style=sort
/wasd_root/wasdoc/*.*?httpd=index&style=sort2
/wasd_root/wasdoc/*.*?httpd=index&style=anchor
/wasd_root/wasdoc/*.*?httpd=index&style=anchor2
/wasd_root/wasdoc/*.*?httpd=index&style=htdir
/wasd_root/wasdoc/*.*?httpd=index&style=htdir2
/wasd_root/wasdoc/*.*?httpd=index&style=original
/wasd_root/wasdoc/*.*?httpd=index&style=original2
Sortable Listing

There is also a useful alternate style that allows manual, automatic and programmatic sorting of the listing content. The sort is performed by JavaScript and does not require a re-request of the server. A sortable listing is indicated by ▼▲  in the header icon column (if present). When a column has been sorted ascending/descending symbols are present adjacent to the column label. The taper of the symbol shape   indicating larger/later to smaller/earlier top to bottom (descending), and   smaller/earlier to larger/later top to bottom (ascending). Manual sorting is accomplished by clicking on the column label. This reverses the current sort order.

The examples above include the basic sortable listing.

The sortable listing by default generates the standard WASD ascending by name listing. It is also possible to automatically sort a listing on a particular column when it is generated. This is done with an additional parameter specifying the layout column character as used in . The default is to list top-to-bottom ascending order. An optional "-" lists top-to-bottom in descending order (the redundant "+") is also accepted.

Examples of automatic sort on size, descending size, revision data and descending revision date are below.

/wasd_root/wasdoc/*.*?httpd=index&style=sort&sort=s
/wasd_root/wasdoc/*.*?httpd=index&style=sort2&sort=s-
/wasd_root/wasdoc/*.*?httpd=index&style=sort&sort=r+
/wasd_root/wasdoc/*.*?httpd=index&style=sort2&sort=r-

Programmatic listing from JavaScript embedded in a README.HTML or enclosing SSI document can be performed by calling the wasdDirSort() function with a string parameter containing the column character and optional order character. The following example sorts descending by size.

<script language="JavaScript">wasdDirSort('S-')</script>

To make all directory listings for a server or site sortable, place the following mapping rule appropriately close to the top of relevant mapping rules.

SET * dir=style=sort

3.3.4Selective Listing

The WASD directory listing permits the use of VMS wildcards in the file specification. This directly allows selected listings of files. For example, all files, all the SDML files in this document's directory, all the HTML files, and finally all the files containing 01 in the name.

/wasd_root/wasdoc/*.*
/wasd_root/wasdoc/*.wasdoc
/wasd_root/wasdoc/*.html
/wasd_root/wasdoc/*0*.*

In addition, it is possible to selectively include and/or exclude selected files using the server directive httpd=index&these=. The parameter is one or more, comma-separated file name specifications which may contain wildcards. The directory listing usually would have file name and type wildcard (though can be a selector in itself) and then files are selected using using the above directive. If a selector is preceded by an exclamation point ("!") this excludes matching files. Matching is first to last and the first match hit is applied.

The following examples provide the equivalent listings to the examples above.

/wasd_root/wasdoc/*.*?httpd=index&these=*
/wasd_root/wasdoc/*.*?httpd=index&these=*.wasdoc
/wasd_root/wasdoc/*.*?httpd=index&these=*.html
/wasd_root/wasdoc/*.*?httpd=index&these=*0*.*

This example lists all of the files above in the one listing.

/wasd_root/wasdoc/*.*?httpd=index&these=*.wasdoc,*.html,*01*.*

This example lists all files except those with an .HTML type.

/wasd_root/wasdoc/*.*?httpd=index&these=!*.html

3.3.5Listing Title

The listing (page) title may be explicitly supplied using the httpd=index&title=.. directive.

The keywords parallel those provided for path mapping SET dir=title=...

3.3.6Listing Font

Historically and by default, directory listings are provided in a monospace font. The parent document or browser (proprtional) font may be used instead with the httpd=index&font=inherit directive. This can only be used with the sortable and tabular (post-v10.4) listings. Historical listing styles are only suitable for monospace fonts.

/wasd_root/wasdoc/*.*?httpd=index&font=inherit

There is the per-path SET dir=font=inherit mapping rule equivalent.

3.3.7File Versions

As described above, a directory listing can be requested in a VMSish style by appending a version delimter to the URL file specification, with multiple versions of the file, where they exist, displayed with version number.

Multiple versions may also be selectively listed using the httpd=index&versions= directive. The parameter can be an integer representing the maximum number of versions to be listed, or an asterisk wildcard indicating all versions should be listed.

?httpd=index&versions=0 ?httpd=index&versions=3
/wasd_root/wasdoc/*.*?httpd=index&versions=*

There is the per-path SET dir=versions= mapping rule equivalent.

3.3.8Readme Files

When a directory listing is generated any "README.", "README.TXT" or "README.HTML" file (or others as configured for the particular server) in the directory will have the contents displayed immediately below the title of the page. This allows additional information on the directory's contents, function, etc., to be presented. This can be suppressed by appending the following query-string to the directory specification, as in the accompanying example:

/wasd_root/wasdoc/*.*?httpd=index&readme=no

Read-me files can be SSI documents if configured by the server administrator. General SSI guidelines apply to these, see 4. Server Side Includes (SSI)

3.3.9Listing Delimiters

A directory listing is normally delimited by a header, comprising an "Index of", column headings and horizontal line, and a footer, comprising a horizintal line. This default behaviour may be modified using the "delimit=" directive.

?httpd=index&delimit=none ?httpd=index&delimit=top

3.3.10Suppressing Directories

Parent and subdirectories may be suppressed in a listing using the "nop", "nops" and "nos" directives. These parallel the purpose of the directory listing control files described in 3.1 Controlling Access To A Directory, and if set to true suppress the listing of the corresponding directories.

?httpd=index&nop=yes ?httpd=index&nops=yes ?httpd=index&nos=yes

3.3.11Listing Refresh and Expiry

Directory listings and trees may be pre-expired. That is, the listing is reloaded each time the page is referenced. This is convenient in some environments where directory contents change frequently, but adds considerable over-head and so is often disabled by default. Individual directory listings may have either default behaviour over-ridden using syntax similar to the following examples:

/dir1/dir2/*.*?httpd=index?expired=yes /dir1/dir2/*.*?httpd=index?expired=no /tree/dir1/dir2/?httpd=index?expired=yes /tree/dir1/dir2/?httpd=index?expired=no

3.3.12Scripting From Directory Listings

When a directory listing is requested a script name can be specified to be used as a prefix to all of the file links in the listing. When the client selects a file link the script specified is implicitly activated.

?httpd=index&script=script_name

The following link illustrates this facility by specifying the liner script. When a link is selected the liner script presents the file with preprended line numbers:

/wasd_root/wasdoc/*.*?httpd=index&script=/cgi-bin/liner

3.3.13Auto-Scripting

The server's auto-scripting facility (see description of [AddType] configuration directive in the Technical Overview) can be suppressed by appending the following query-string to the directory specification, as in the accompanying example:

?httpd=index&autoscript=no
/wasd_root/wasdoc/*.*?httpd=index&autoscript=no

This implies that any file accessed from the listing will be transfered without any data conversion possible due to script activation. The browser must then process the document in some fashion (often by activating a save as dialog).

3.3.14Target Window

Files generally open in the current browser window. It is possible to open a file in another window using the target= directive.

?httpd=index&target=_blank
/wasd_root/wasdoc/*.*?httpd=index&target=_blank

Browser (HTML) Supported Targets
Browser (HTML) Supported Targets
Target Description
_blank opens the file in a new window or tab
_self in the same frame
_parent in the parent frame
_top in the full body of the window
framename in a named frame
There is a per-path mapping "SET dir=target=" equivalent.

3.3.15Specifying Content-Type

When accessing files it is possible to explicitly specify the identifying content-type to be returned to the browser in the HTTP response header. Of course this does not change the actual content of the file, just the header content-type! This is primarily provided to allow access to plain-text documents that have obscure, non"-standard" or non-configured file extensions. See 2.2 Explicitly Specifying Content-Type.

It could also be used for other purposes, "forcing" the browser to accept a particular file as a particular content-type. This can be useful if the extension is not configured (as mentioned above) or in the case where the file contains data of a known content-type but with an extension conflicting with an already configured extension specifying data of a different content-type.

It is posssible to "force" the content-type for all files in a particular directory. Enter the path to the directory and then add

?httpd=index&type=text/plain

(or what-ever type is desired). Links to files in the listing will contain the appropriate "?httpd=content&type=..." appended as a query string.

This is an example:

/wasd_root/wasdoc/*.*
/wasd_root/wasdoc/*.*?httpd=index&type=text/plain
YMMV

Some browsers and operating systems insist they know better than the server and ignore the response-specified content-type, inferring presentation of the content from magic bytes in that content or the trailing dot-separated file name extension.

3.3.16Icon Plain Text Link

Directory listing icons are generally links to the content of the file displayed as plain-text (‘Listing Icons’ in 3. Directory Listing). This can be disabled using the ilink directive.

?httpd=index&ilink=no
/wasd_root/wasdoc/*.*&ilink=no
There is a per-path mapping "SET dir=noilink" equivalent.

3.3.17Query String

The query=<string> directive can be used to propagate an explicit query string to subsequent directory requests. This is intended to be applied from a .WWW_WASD control file because actual URI query strings are propagated by default.

# an example .WWW_WASD file query=httpd=index&style=sort2&sort=s-

3.3.18Allowing Override

When a .WWW_WASD file is present in a directory it takes precedence over any SSI or URI (query string) directives also available, unless it includes an override=yes directive. When this is present any SSI and/or URI directive string is also applied to the request.

# an example .WWW_WASD file override=yes

3.4Directory Tree

The "Tree" internal script allows a directory tree to be generated. This script is supplied with a directory name from which it displays all subdirectories in a hierarchical layout, showing subordinancies. Selecting any one of the subdirectories displayed generates a directory listing (see 3. Directory Listing).

Appending a file specification (with or without wildcards) to the directory name results in the any directory listing displaying only files matching the specification. To display all files a "*.*" should always be appended.

Note that this script only processes the physical file system. This may or may not correspond to the web environment's virtual mappings.

To enable the VMS-style directory listing format, or to use any of the directory server directives, append one, or a combination of, the following query strings to the directory specification:

?httpd=index&autoscript=no ?httpd=index&readme=no ?httpd=index&script=script-name ?httpd=index&script=script-name&readme=no

The following links provide online demonstrations:

/tree/wasd_root/wasdoc/*.*
/tree/wasd_root/wasdoc/*.*; VMS-ish

Note that this activity is I/O intensive, and can take a considerable period if the tree is extensive.


4.Server Side Includes (SSI)

4.1Virtual Documents
4.2Last-Modified Information
4.3Pre-Expiring Documents
4.4Directive Syntax
4.5Directives
4.5.1#ACCESSES
4.5.2#CONFIG
4.5.3#DIR
4.5.4#DCL
4.5.5#ECHO
4.5.6#ELIF
4.5.7#ELSE
4.5.8#ENDIF
4.5.9#EXEC
4.5.10#EXIT
4.5.11#FCREATED
4.5.12#FLASTMOD
4.5.13#FSIZE
4.5.14#IF
4.5.15#INCLUDE
4.5.16#MODIFIED
4.5.17#ORIF
4.5.18#PRINTENV
4.5.19#SET
4.5.20#SSI
4.5.21#STOP
4.6Variables
4.7Flow Control
4.8Query Strings
4.9File and Virtual Specifications
4.9.1THE_FILE_NAME
4.10Time Format
4.11OSU Compatibility
4.12Script-Generated SSI Documents

The HTML pre-processor is used to provide dynamic information inside of an otherwise static, HTML (HyperText Markup Language) document. The HTTPd server provides this as internal functionality, scanning the input document for special pre-processor directives, which are replaced by dynamic information based upon the particular directive.

As of version 5.1 WASD SSI has been enhanced to provide flow-control statements, allowing blocks of the document to be conditionally processed, see 4.7 Flow Control. These extensions allow quite versatile documents to be created without resorting to script processing.

Two documents are provided as examples of SSI processing.

By default the HTML pre-processor is invoked when the document file's extension is ".SHTML". As there is a significant overhead with pre-processed HTML compared to normal HTML, it should only be used when it serves a useful documentary purpose, and not just for the novelty.

Essential compatibility with OSU Server Side Includes is provided. This may ease any transition between the two. See 4.11 OSU Compatibility for further information.

4.1Virtual Documents

One effective use for pre-processed HTML is the creation of single virtual documents from two or more physical documents. That is, the pre-processed document is used to include multiple physical documents, that may even be independently administered, to return a composite document to the client. This is a relatively low-overhead activity as SSI goes, but because it is a dynamic document, without some extra considerations (see 4.2 Last-Modified Information).

Example 1

This provides an example of the efficient use of SSI processing to create virtual documents. Each page will comprise a header (containing the body tag and page header, etc), the document proper and a footer (containg the end-of-page information, modification date, and end-body tag, etc).

<HTML> <HEAD> <TITLE>Just an example!</TITLE> </HEAD> <!--#include virtual="header.shtml" --> <P> This is the document information. <P> Blah, blah, blah. <!--#include virtual="/web/common/footer.shtml" --> </HTML>

A more efficient variant places the document proper in its own, plain HTML file which is then #included (it is much, much, much more efficient for the server to throw a file at the network, than parse every character in one ;^)

<HTML> <HEAD> <TITLE>Just an example!</TITLE> </HEAD> <!--#include virtual="header.shtml" --> <!--#include virtual="example.html" --> <!--#include virtual="footer.shtml" --> </HTML>
Example 2

This example provides a seemingly more convoluted, but very much more powerful configuration, that uses recursion to greatly simplify maintenance of common-layout documents for the end-user.

File 1; the document accessed via the browser URL, doesn't matter what its name is, this configuration is completely naming independent.

<!--#ssi #if var={PARENT_FILE_NAME} eqs="" #set var=TITLE value="Just an Example" #include virtual="/web/common/template.shtml" #else #include virtual="document.html" #endif -->

File 2; the TEMPLATE.SHTML refered to by the first include above.

<!--#ssi #include virtual="/web/common/header.shtml" #include virtual="{DOCUMENT_ROOT}header.html" fmt="?" #include virtual="{DOCUMENT_URI}" #include virtual="{DOCUMENT_ROOT}footer.html" fmt="?" #include virtual="/web/common/footer.shtml" -->

File 3; the DOCUMENT.HTML refered to by the second include in file 1.

This is just a bunch of HTML!

This is an explanation of how it works …

  1. the browser accesses file 1 via a URL
  2. processing begins with file 1
  3. file 1 checks if it has a parent (is the first file processed),
    it doesn't and so …
  4. file 1 set a variable named TITLE
  5. file 1 #includes file 2, a site-common template
  6. file 2 substitutes the TITLE variable contents as the document title
  7. file 2 #includes a site-common header
  8. file 2 #includes an optional document-local header
  9. here's the interesting bit …
    file 2 now re-#includes the original document, file 1 (!!)
  10. file 1 checks if it has a parent (is the first file processed),
    it does and so …
  11. file 1 #includes file 3 (the actual contents of the document)
  12. file 3 is a plain HTML document, just added to the output
  13. file 1 is now exhausted and processing returns to file 2
  14. file 2 #includes an optional document-local footer
  15. file 2 #includes a site-common footer
  16. file 2 is exhausted and processing returns to file 1
  17. file 1 is exhausted and processing stops

The following link provides an example of a such a virtual document.

4.2Last-Modified Information

SSI documents generally contain dynamic elements, that is those that may change with each access to the document (e.g. current date/time). This makes evaluation of any document modification date difficult and so by default no "Last-Modified: timestamp" information is supplied against an SSI document. The potential efficiencies of having document timestamps, so that requests can be made for a document to be returned only if modified after a certain date/time ("If-Modified-Since: timestamp"), are significant against the CPU overheads of processing SSI documents.

WASD allows the document author to determine whether or not a last-modified header field should be generated for a particular document and which contributing file(s) should be used to determine it. This is done using the #modified directive. If a virtual document is made up of multiple source documents (files) each can be assessed using multiple virtual= or file= tags, the most recently modified will be used to determine if the virtual document has been modified, and also to generate the last-modified timestamp.

The if-modified-since tag compares the determined revision date/time of the document file(s) with any "If-Modified-Since:" timestamp supplied with the request. If the virtual document's revision date/time is the same or older than the request's then a not-modified (304 status) header is generated and sent to the client and document processing ceases. If more recent an appropriate "Last-Modified:" header field is added to the document and it continues to be processed.

If a request has a "Pragma: no-cache" field (as with Navigator's reload function) the document is always generated (this is consistent with general WASD behaviour). The following example illustrates the essential features.

<!--#ssi #modified #modified virtual="/web/common/header.shtml" #modified virtual="header.html" fmt="?" #modified virtual="index.html" fmt="?" #modified virtual="footer.html" fmt="?" #modified virtual="/web/common/footer.shtml" #modified if-modified-since -->

This construct should be placed at the very beginning of the SSI document, and certainly before there is any chance of output being sent to the browser. Once output to the client has occured there can be no change to the response header information (not unreasonably).

4.3Pre-Expiring Documents

SSI preprocessed documents are dynamic in the sense that the information presented can be different every time the document is generated (e.g. if time directives are included). If it is important that each time the document is accessed it is regenerated then an HTML META tag can be included in the HTML header to cause the document to expire. This will result in the document being reloaded with each access. This can be accomplished two ways.

4.4Directive Syntax

The syntax follows closely that used by the other implementations, but some directives are tailored to the WASD and VMS environment. The directive is enclosed within an HTML comment and takes the form:

<!--#directive [[tag1="value"] [tag2="value"] ...] -->

A tag provides parameter information to the directive. A directive may have zero, one or more parameters. Values supplied with any tag may be literal or via variable substitution (see 4.6 Variables). A value must be encolosed by quotation marks if it contains white-space.

A directive can be split over multiple lines provided the new line begins naturally on white-space within the directive. For example, this is correctly split

<!--#echo created[="<EMPHASIS>(time-format)"] -->
while the following is not (and would produce an error)
<!--#echo creat ed[="<EMPHASIS>(time-format)"] -->

Directive and tag keywords are case insensitive. The tag value may or may not be case sensitive, depending upon the command/tag. Generally the effect of a command is to produce additional text to be inserted in the document, although it is possible to control the flow of processing in a document with decision structures.

4.5Directives

SSI Directives
Directive Description Section
#accesses document access count 4.5.1 #ACCESSES
#config document processing options 4.5.2 #CONFIG
#dir directory listing 4.5.3 #DIR
#dcl DCL command processing 4.5.4 #DCL
#echo output information 4.5.5 #ECHO
#elif flow control 4.5.6 #ELIF
#else flow control 4.5.7 #ELSE
#endif flow control 4.5.8 #ENDIF
#exec same as "#dcl" 4.5.9 #EXEC
#exit flow control, stop current document processing 4.5.10 #EXIT
#fcreated output file creation date/time 4.5.11 #FCREATED
#flastmod output file last modification date/time 4.5.12 #FLASTMOD
#fsize output file size 4.5.13 #FSIZE
#if flow control 4.5.14 #IF
#include include a text file or another SSI document 4.5.15 #INCLUDE
#modified HTTP response control 4.5.16 #MODIFIED
#orif flow control 4.5.17 #ORIF
#printenv list document variables 4.5.18 #PRINTENV
#set assign value to a document variable 4.5.19 #SET
#ssi block of SSI statements 4.5.20 #SSI
#stop stop SSI processing completely 4.5.21 #STOP

4.5.1#ACCESSES

The #accesses directive allows the number of times the document has been accessed to be included. It does this by creating a counter file in the same location and using the same name with a dollar symbol appended to the type (extension). The count may be reset by deleting the file. This is an expensive function (in terms of file system activity) and so should be used appropriately. It can be disabled by server configuration. Three tags provide additional functionality:

4.5.2#CONFIG

The #config directive allows time and file size formats to be specified for all subsequent directives providing these values. Optional specifications for individual directives may still be made, and override, do not supercede, any specification made using a config directive. A config directive may be made once, or any number of times in a document, and applies until another is made, or until the end of the document.

4.5.3#DIR

The #dir directive generates an Index of … directory listing inside an HTML document. Apart from not generating a title (it is up to the pre-processed document to title, or otherwise caption, the listing) it provides all the functionality of the WASD HTTPd directory listing (see 3. Directory Listing), including query string format control via the "par=" parameter (note that from the "?httpd=index" introducer used with directory listings is not necessary from SSI). It is an WASD HTTPd extension to pre-processed HTML.

For example:

<!--#dir file="/wasd_root/src/httpd/" --> <!--#dir file="/wasd_root/src/httpd/*.c" par="layout=UL__S&nops=yes" -->

4.5.4#DCL

The #dcl directive executes a DCL command and incorporates the output into the processed document. It is an WASD HTTPd extension to the more common exec directive, which is also included.

By default, output from the DCL command has all HTML-forbidden characters (e.g. "<", "&") escaped before inclusion in the processed document. Thus command output cannot interfere with document markup, but nor can the DCL command provide HTML markup. This behaviour may be changed by appending the following tag to the directive:

type="text/html"

Some #dcl directives are for privileged documents only, documents defined as those being owned by the SYSTEM account, and not being world-writeable. The reason for this should be obvious. There are implicit security concerns about any document being able to execute any DCL command(s), even if it is being executed in a completely unprivileged process. Hence only innocuous commands are allowed in standard documents.

4.5.5#ECHO

The #echo directive incorporates the specified information into the processed document. Multiple tags may be used within the one directive.

4.5.6#ELIF

The #elif directive (else-if) allows blocks of HTML markup and SSI directives to be conditionally processed, see 4.7 Flow Control and 4.5.14 #IF. This directive effectively allows a case statement to be constructed.

<!--#elif var="[variable}|literal" -->

4.5.7#ELSE

The #else directive allows blocks of HTML markup and SSI directives to be conditionally processed, see 4.7 Flow Control. It is the default block after an "#if", "#orif" or "#elif".

<!--#else -->

4.5.8#ENDIF

The #endif directive marks the end of a block of document text being conditionally processed, see 4.7 Flow Control.

<!--#endif -->

4.5.9#EXEC

The #exec directive executes a DCL command and incorporates the output into the processed document. It is the VMS equivalent of the exec shell directive of some Unix implementations. It is implemented in the same way as the #DCL directive, and so the general detail of that directive applies. It supports both the cmd tag and the cgi tag, allowing execution of CGI scripts (the response header is absorbed).

<!--#exec cmd="show device/full tape1:" --> <!--#exec cgi="/cgi-bin/calendar?2004" -->

The #exec directive is for privileged documents only, documents defined as those being owned by the SYSTEM account, and not being world-writeable. The reason for this should be obvious. There are implicit security concerns about any document being able to execute any DCL command(s), even if it is being executed in a completely unprivileged process.

4.5.10#EXIT

The #exit directive causes the server to stop processing the current SSI file. If the current file was an #included SSI file, processing continues back with the parent file. Note that the #stop directive also is available, it stops processing of the entire virtual document.

<!--#exit -->

4.5.11#FCREATED

The #fcreated directive incorporates the creation date/time of a specified file/document into the processed document.

4.5.12#FLASTMOD

The #flastmod directive incorporates the last modification date/time of a specified file/document into the processed document.

4.5.13#FSIZE

The #fsize directive incorporates the size, in bytes, kbytes or Mbytes, of a specified file/document into the processed document.

4.5.14#IF

The #if directive allows blocks of HTML markup and SSI directives to be conditionally processed, see 4.7 Flow Control.

As in the following examples:

<!--#if value={DOCUMENT_URI} eqs="/wasd_root/doc/env/xssi.shtml" --> <!--#if value={COUNT} lt=10 --> <!--#if value="This is a test!" eqs={STRING} --> <!--#if value={PATH_INFO} srch="*/env/*" -->

4.5.15#INCLUDE

The #include directive incorporates the contents of a specified file/document into the processed document.

The contents of the specified file are included differently depending on the MIME content-type of the file. Files of text/html content-type (HTML documents) are included directly, and any HTML tags within them contribute to the markup of the document. Files of text/plain content-type (plain-text documents) are encapsulated in "<pre></pre>" tags and have all HTML-forbidden characters (e.g. "<", "&") escaped before inclusion in the processed document. An HTML file can be forced to be included as plain-text by using the following syntax:

<!--#include virtual="example.html" type="text/plain" -->

To "force" a file to be considered as text regardless of the actual content (as determined by the server from the file type), use on of the following depending on whether it should be rendered as plain or HTML text.

<!--#include virtual="example.html" content="text/plain" --> <!--#include virtual="example.html" content="text/html" -->

Other SSI files may be included and their content dynamically included in the resulting document. To prevent a recursive inclusion of documents the nesting level of SSI documents is limited to five.

4.5.16#MODIFIED

The #modified directive allows a document author to control the "Last-Modified:"/"If-Modified-Since:"/"304 Not modified" behaviour of an SSI document. See 4.1 Virtual Documents.

4.5.17#ORIF

The #orif directive (or-if) allows blocks of HTML markup and SSI directives to be conditionally processed, see 4.7 Flow Control and 4.5.14 #IF. In the absence of any real expression parser this directive allows a block to be processed if one of multiple conditions are met.

<!--#orif var="[variable}|literal" -->

4.5.18#PRINTENV

The #printenv directive prints a plain-text list of all SSI-specific, then CGI, then document-assigned variables (see 4.6 Variables). This directive is intended for use when debugging flow-controlled SSI documents.

<!--#printenv -->

The following link uses the example SSI document WASD_ROOT:[WASDOC.ENV]XSSI.SHTML to demonstrate this.

4.5.19#SET

The #set directive allows a user variable to be assigned or modified, see 4.6 Variables.

<!--#set var="variable-name" value="whatever" -->

Variables are always stored as strings and have a finite but generally usable length. Some comparison tags provided in the flow-control directives treat the contents of variables as numbers. A numeric conversion is done at evaluation time.

4.5.20#SSI

The #ssi directive allows multiple SSI directives to be used without the requirement to enclose them in the normal HTML comment tags (i.e. <!-- -->). This helps reduce the clutter in an SSI document that uses the extended capabilities of variable assignment and flow control. Document HTML cannot be included between the opening and closing comment elements of the "#ssi" tag, although of course document output can be generated using the "#echo" tag.

<!--#ssi #set var=HOUR value={DATE_LOCAL,12,2} #if var={HOUR} lt=12 #set var=GREETING value="Good morning" #elif var={HOUR} lt=19 #set var=GREETING value="Good afternoon" #else #set var=GREETING value="Good evening" #endif -->

The example SSI document WASD_ROOT:[WASDOC.ENV]XSSI.SHTML will demonstrate this concept.

4.5.21#STOP

The #stop directive causes the server to stop processing the virtual document. It can be used with flow control structures to conditionally process only part of a virtual document. Note that the #exit directive also is available, it stops processing of the current file (for nested #includes, etc.).

<!--#stop -->

4.6Variables

The SSI processor maintains information about the server, date and time, request path, request parameters, etc., accessible via variable name. Although these server variables cannot be modified by the document the processor also allows the author to create and assign new document variables by name. SSI variables have global scope, with a small number of exceptions listed below. That is, the same set of variables are shared with the parent document by any other SSI documents #included, and any included by those, etc.

Local variables:

One other special-purpose variable, THE_FILE_NAME, see 4.9.1 THE_FILE_NAME.

Server assigned variables comprise some SSI-specific as well as the same CGI variables available to CGI scripts. These may be found listed in the CGI Variables in WASD Scripting document. <P> The following link provides a list of the SSI and CGI variables available to SSI documents.

Whenever a directive uses information from a tag (see 4.4 Directive Syntax) values from variables may be substituted as as a whole or partial value. This is done using curly braces to delimit the variable name. For example

<!--#include virtual={FILENAME} -->
would include the file named by the contents of a variable named "FILENAME". When using a variable in a tag it is not necessary to enclose the tag parameter in quotation marks unless there is additional literal text. Variables may also be used within literal strings, producing a compound, resultant string, as in the following example
<!--#echo var="Hello {REMOTE_HOST}, time here is {LOCAL_TIME}" -->

Variables are considered numeric when they begin with a digit. Those beginning with an alphabetic are considered to have a numeric value of zero.

Variables are considered to be boolean false if empty and true when not empty.

Substrings

It is also possible to extract substrings from variables using the following syntax,

{variable-name,start-index,count}

where the start-index begins with the zeroth character and numbers up to the last character in the string, and count may be zero or any positive number. If only one number is supplied it is regarded as a count and the string is extracted from the zeroth character.

To illustrate,

<!--#set var=EXAMPLE value="This is an example!" --> <!--#echo "{EXAMPLE,2}at was {EXAMPLE,8,999}" -->

would output

That was an example!
Other "Functions"

The example SSI document WASD_ROOT:[WASDOC.ENV]XSSI.SHTML can demonstrate these concepts.

4.7Flow Control

WASD SSI allows blocks of document to be conditionally processed. This uses constructs in a similar way to any programming language. The emphasis has been on simplicity and speed of processing. No complex expression parser is provided. Despite this, complex document constructs can be implemented. Flow control structures may be nested up to eight levels.

The "#if", "#orif" and "#elif" directives must provide an evaluation. This can be single variable, which if numeric and non-zero is considered true, if zero if false, or can be a string, which if empty is false, and if not empty is true. Tests can be made against the variable which when evaluated return a true or false. Multiple tests may be made against the one variable, or against more than one variable. Multiple tests act as a logical AND of the results and terminate when the first fails.

Any evaluation can have the result negated by prefixing it with an exclamation point. For instance, the first of these examples would produce a false result, the second true.

<!--#if value="test" !eqs="test" --> <!--#if value=20 !lt=10 -->

The following is a simple example illustration of variable setting, use of variable substrings, and conditional processing of document blocks.

<!--##config trace=1 --> <HTML> <!--#set var=HOUR value={DATE_LOCAL,12,5} --> <!--#if var={HOUR} lt=12 --> <!--#set var=GREETING value="Good morning" --> <!--#elif var={HOUR} lt=19 --> <!--#set var=GREETING value="Good afternoon" --> <!--#else --> <!--#set var=GREETING value="Good evening" --> <!--#endif --> <HEAD> <TITLE><!--#echo var={GREETING} --> <!--#echo var="{REMOTE_HOST}!" --></TITLE> </HEAD> <BODY> <H1>Simple XSSI Demonstration</H1> <!--#echo var={GREETING} --> <!--#echo var={REMOTE_HOST} -->, the time here is <!--#echo var={DATE_LOCAL,12,5} -->. <!--#if var={REMOTE_HOST} eqs={REMOTE_ADDR} --> (Sorry, I do not know your name, DNS lookup must be disabled!) <!--#endif --> </BODY> </HTML>

The example SSI document WASD_ROOT:[WASDOC.ENV]XSSI.SHTML further illustrates these concepts.

4.8Query Strings

A query string may be passed to an SSI document in much the same way as to a CGI script. In this way the behaviour of the document can be varied in accordance to information explicitly passed to it when accessed. To prevent the server's default query engine being given the request precede any query string with "?httpd=ssi". The server detects this and passes the request instead to the SSI processor. Just append the desired query string components to this as if they were form elements. For example:

?httpd=ssi&printenv=no ?httpd=ssi&printenv=yes ?httpd=ssi&trace=yes&test2=one&test2=two&test3=three

The following link uses the example SSI document WASD_ROOT:[WASDOC.ENV]XSSI.SHTML to demonstrate this. Look for the <QUOTE>(FORM_TEST1=one), etc.

4.9File and Virtual Specifications

Documents may be specified using either the "FILE" or "VIRTUAL" tags.

The "FILE" tag expects an absolute VMS file specification.

The "VIRTUAL" tag expects an URL-style path to a document. This can be an absolute or relative path. See 2.3 Document Specification for further details.

4.9.1THE_FILE_NAME

Generally, when an error are encountered document processing halts and and an error report is generated. For some common circumstances, in particular the existance or not of a particular file, may require an alternative action. For file activities (e.g. #include, #flastmod, #created, #fsize) the optional fmt="" tag provides some measure of control on error behaviour. If the format string begins with a "?" files not found are not reported as errors and processing continues. Other file systems errors, such as directory not found, syntax errors, etc., are always reported.

Every time a file is accessed (e.g. #include, #flastmod) the server variable THE_FILE_NAME gets set to that name if successful, or reset to empty if unsuccessful. This variable can be checked to determine success or otherwise.

4.10Time Format

Whenever a time directive is used an optional tag can be included to specify the format of the output. The default looks a little VMS-ish. If a format specification is made it must confirm to the C programming language function strftime().

The format specifier follows a similar syntax to the C standard library printf() family of functions, where conversion specifiers are introduced by percentage symbols. Here are some example uses:

The date is <!--#echo date_local fmt="%d/%m/%y" -->. The time is <!--#echo date_local fmt="%r" -->. The day-of-the-week is <!--#echo date_local fmt="%A" -->.

A problem with any supplied time formatting specification will be reported.

The following table provides the general conversion specifiers. For further information on the formatting process refer to a C programming library document on the strftime() function.

strftime() Format Directives
Specifier Replaced by
a The locale's abbreviated weekday name
A The locale's full weekday name
b The locale's abbreviated month name
B The locale's full month name
c The locale's appropriate date and time representation
C The century number (the year divided by 100 and truncated to an integer) as a decimal number (00 - 99)
d The day of the month as a decimal number (01 - 31)
D Same as %m/%d/%y
e The day of the month as a decimal number (1 - 31) in a 2 digit field with the leading space character fill
Ec The locale's alternative date and time representation
EC The name of the base year (period) in the locale's alternative representation
Ex The locale's alternative date representation
EX The locale's alternative time representation
Ey The offset from the base year (%EC) in the locale's alternative representation
EY The locale's full alternative year representation
h Same as %b
H The hour (24-hour clock) as a decimal number (00 - 23)
I The hour (12-hour clock) as a decimal number (01 - 12)
j The day of the year as a decimal number (001 - 366)
m The month as a decimal number (01 - 12)
M The minute as a decimal number (00 - 59)
n The newline character
Od The day of the month using the locale's alternative numeric symbols
Oe The date of the month using the locale's alternative numeric symbols
OH The hour (24-hour clock) using the locale's alternative numeric symbols
OI The hour (12-hour clock) using the locale's alternative numeric symbols
Om The month using the locale's alternative numeric symbols
OM The minutes using the locale's alternative numeric symbols
OS The seconds using the locale's alternative numeric symbols
Ou The weekday as a number in the locale's alternative representation (Monday=1)
OU The week number of the year (Sunday as the first day of the week) using the locale's alternative numeric symbols
OV The week number of the year (Monday as the first day of the week) as a decimal number (01 -53) using the locale's alternative numeric symbols. If the week containing January 1 has four or more days in the new year, it is considered as week 1. Otherwise, it is considered as week 53 of the previous year, and the next week is week 1.
Ow The weekday as a number (Sunday=0) using the locale's alternative numeric symbols
OW The week number of the year (Monday as the first day of the week) using the locale's alternative numeric symbols
Oy The year without the century using the locale's alternative numeric symbols
p The locale's equivalent of the AM/PM designations associated with a 12-hour clock
r The time in AM/PM notation
R The time in 24-hour notation (%H:%M)
S The second as a decimal number (00 - 61)
t The tab character
T The time (%H:%M:%S)
u The weekday as a decimal number between 1 and 7 (Monday=1)
U The week number of the year (the first Sunday as the first day of week 1) as a decimal number (00 - 53)
V The week number of the year (Monday as the first day of the week) as a decimal number (00 - 53). If the week containing January 1 has four or more days in the new year, it is considered as week 1. Otherwise, it is considered as week 53 of the previous year, and the next week is week 1.
w The weekday as a decimal number (0 [Sunday] - 6)
W The week number of the year (the first Monday as the first day of week 1) as a decimal number (00 - 53)
x The locale's appropriate date representation
X The locale's appropriate time representation
y The year without century as a decimal number (00 - 99)
Y The year with century as a decimal number
Z Timezone name or abbreviation. If timezone information is not available, no character is output.
% %

4.11OSU Compatibility

Essential compatibility with OSU Server Side Includes directives is provided. This is intended to ease any transition to WASD, as existing SSI documents will not need to be changed unless any of the WASD capabilities are required. To provide transparent processing of OSU .HTMLX files ensure the following WASD configuration is in place.

In HTTPD$CONFIG file:

[AddType] .HTMLX text/x-shtml - OSU SSI HTML

Note that the content description must contain the string "OSU" to activate some compliancy behaviours.

In HTTPD$MAP file:

redirect /*.*.htmlx /*.htmlx?httpd=ssi&__part=*

This provides a mechanism for the OSU part-document facility. (Yes, the "__part" has two leading underscores!)

OSU Directives

The following OSU directives are provided specifically for OSU compatibility, although there is no reason why most of these may not also be deployed in general WASD SSI documents if there is a requirement. Note that these are OSU-specifics, other OSU directives are provided by the standard WASD SSI engine.

OSU Compatible Directives
Directive Description
#begin label [label] delimit a part-document (see ‘OSU "Part"s’ in 4.11 OSU Compatibility)
#config verify=1 enable commented-tag trace output
#echo accesses document access count
#echo accesses_ordinal document access count
#echo getenv="" output logical or symbol
#echo hw_name system hardware name
#echo server_name HTTPd server host name
#echo server_version HTTPd software version
#echo vms_version HTTPd system version of VMS
#end label [label] delimit a part-document (see ‘OSU "Part"s’ in 4.11 OSU Compatibility)
#include [file|virtual]="" part="label" include only part of a virtual document

If WASD is configured for OSU SSI compatibility the following link provides an online demonstration as well as further explanation of the OSU SSI engine using an OSU preprocessor document from the distribution (included within copyright compliance).

/wasd_root/src/osu/preproc.htmlx

How do we know WASD is processing it? Look for the #echo var="GETENV=SYS$REM_ID" towards the end of the document. It should indicate "[VARIABLE_DOES_NOT_EXIST!]" because it's attempting to output a DECnet-related logical name!

OSU "Part"s

The OSU processor allows for delimited subsections of an #included document, or a URL referenced document for that matter, to be included in the output. This is supported, but only for compatibility. It is only enabled for ".HTMLX" documents and if otherwise used may interact unexpectedly with WASD SSI flow-control.

4.12Script-Generated SSI Documents

It is possible to have script output passed back through the SSI engine for markup. This approach might allow script output to automatically be wrapped in standard site headers and footers for example. Essentially the script must output an SSI-markup response body and include in the otherwise standard CGI response header a field containing "Script-Control: X-content-handler=SSI". The following example in DCL show the essential elements of such a script.

$ say = "write sys$output" $ say "Status: 200" $ say "Script-Control: X-content-handler=SSI"" $ say "" $ say "<HTML>" $ say "<HEAD>" $ say "<TITLE>Example of X-content-handler=SSI</TITLE>" $ say "</HEAD>" $ say "<BODY>" $ say "<!--#include virtual=""/site/header.html"" -->" $ say "<H1>Example of X-content-handler:SSI</H1>" $ say "Hi there <!--#echo var=""WWW_REMOTE_HOST"" -->" $ say "<!--#include virtual=""/site/footer.html"" -->" $ say "</BODY>" $ say "</HTML>"

5.Document Searching

5.1Plain-Text Search
5.2HTML Search
5.3Search Syntax
5.3.1Standard Search Form
5.3.2Forms-Based Search
5.3.3Search Options
5.3.4Example Search Form

The query and extract scripts provide real-time searching of plain-text and HTML documents, and document retrieval. The search is a simple-string search, not a GREP-style search. It is designed to provide a useful mechanism for locating documents containing a keyword, not for document analysis. It has the useful feature for plain-text documents of allowing the selective extraction of only the portion near the hit.

Only files with a plain-text or HTML MIME data type (see 2. Document Access and Specification) will be searched. Others may be specified, or be selected from wildcard file specification, but they will not actually have their contents searched.

Directory specifications may include a wildcard elipsis (allowing a directory tree to be traversed) and/or file name wildcards. In other words, anything acceptable as VMS file system syntax (except in URL-format of course). See examples in 5.3.1 Standard Search Form.

5.1Plain-Text Search

A search of a plain-text file is straight-forward. Each line in the file is searched for the required string. The first time it is encountered is considered a hit. The line is not searched for any further occurances.

Searches of plain text files allow the subsequent selection of partial documents (i.e. the retrieval of only a number of lines around any actual hit). This allows the user to selectively extract a portion of a document, avoiding the need to explcitly scan through to the section of interest.

5.2HTML Search

A search of an HTML file is a little more complex. As might be expected, only text presented in the document text is searched, markup text is ignored. That is, all text not part of an HTML tag construct is extracted and searched. For example, out of the following HTML fragment

<!-- an example HTML document --> <p> The document entitled <a target="_blank" href="example.html">"Example Document"</a> provides only an <i>overview</i> of the full capabilities of HTML.
only the following text would actually be searched
The document entitled "Example Document" provides only an overview of the full capabilities of HTML.

The mechanism for partial document retrieval available with plain-text files is not present with HTML documents. HTML files generally must be treated as a whole, with the formatting of current sections often very dependent on the formatting of previous sections. This makes extracting a subsection perilous without extensive syntactical analyis. On the positive side, HTML documents tend to be already divided into meaningful subdocuments (files), making retrieval of a hit naturally more-or-less within context.

Instead of partial document retrieval, the document is processed to place anchors for each hit, making it possible to jump directly to a particular section of interest. Generally this works well but may occasionally distort the presentation of a document.

5.3Search Syntax

A search may be initiated in basic three ways:

  1. Appending a question-mark and search string to a file specification (the simple syntax of "ISINDEX"-style searching). This is standard HTTP, and of course must conform to HTTP syntax.
  2. Providing the name of the query script followed by the directory path to be searched. The script then returns a standard search form.
  3. Forms-based search, which allows the format and mechanism of the search to be controlled.
<isindex> tag obsolete (as of HTML4)

Placing the HTML tag "<isindex>" within a document's text is sufficient to inform the browser that searching is available for that document. The browser will inform the user of this and allow a search of that document to be initiated at any time. Note that it is limited to the one document.

Using the keyword search syntax explicitly is another method of initiating a search, and additionally can use a wildcard in the document specification. For example:

/wasd_root/doc/env/*.*?formatted

The following link provides an online demonstration search using the above syntax. Note the difference in the way plain-text file hits are presented compared with those of HTML files.

/wasd_root/wasdoc/env/*.*?formatted


5.3.1Standard Search Form

Using the "QUERY" script name followed by a URL-format path specifying the directory to be searched returns a standard, script-generated search form.

The following link provides an online demonstration of the standard search form.

/cgi-bin/query/wasd_root/wasdoc/env/

As with all search specifications, the directory specification may include wildcard a elipsis (allowing a directory tree to be traversed) and/or file name wildcards. In other words, anything acceptable as VMS file system syntax (except in URL-format of course). See the following examples.

/cgi-bin/query/wasd_root/wasdoc/env/*.html
/cgi-bin/query/wasd_root/wasdoc/.../
/cgi-bin/query/wasd_root/wasdoc/.../*.html

5.3.2Forms-Based Search

A "forms-based" search is initiated by the server receiving a file specification, which of course may contain wildcards, followed by a search parameter. This is a typical HTML forms format URL. For example:

*.txt?search=SIMPLE /web/.../*.*?search=THIS sub_directory/*.*?search=THAT ../sibling_directory/*.HTML?search=OTHER

The following link provides an online demonstration search using the form-based syntax.

/wasd_root/wasdoc/env/*.*?search=formatted

5.3.3Search Options

Additional URI components may be appended after the initial "search=" parameter. These are appended with intervening "&") characters.

5.3.4Example Search Form

To allow the client to enter a search string and submit a search to the server a HTML level 2 form construct can be used. Here is an example:

<form action="/web/html/.../*.html"> Search HTML documents for:&nbsp; <input type="text" name="search"> <input type="submit" value="execute"> </form>

The following provides an online demonstration of the form used above:

Search HTML documents for: 
Bells and Whistles

A form providing all the options refered to in 5.3.3 Search Options is shown below (some additional white-space introduced for clarity):

<form action="/web/html/.../*.html"> Search HTML documents for: <input type="text" name="search"> <input type="submit" value="execute"> <br><a target="_blank" href="/query/-/aboutquery.html">About</a> this search. <br>Output By: line <input type="radio" name="hits" value="line" checked> document <input type="radio" name="hits" value="document"> <br>Case sensitive: no <input type="radio" name="case" value="no" checked> yes <input type="radio" name="case" value="yes"> </form>

The following provides an online demonstration of the form used above:

Search HTML documents for:
About this search.
Output By: line document
Case sensitive: no yes

6.VMS Help and Text Libraries

Affectionately known as Conan the Librarian – and with all due acknowlegement to Wierd Al.Yankovic – this script makes VMS Help and Text libraries accessible in the web environment.

The librarian script will be automatically activated if the file specified has an extension of ".HLB" or ".TLB". Alternatively it may be explicitly activated by specifying as a prefix to the file specification (but the ability to provide a relative specification is lost). The following examples illustrate the syntax:

/sys$common/syshlp/helplib.hlb VMS Help
/conan/sys$common/syshlp/helplib.hlb via /Conan
Other Librarian Functionality

To obtain an index of matching libraries explicitly activate the Conan script providing a wildcard file specification.

/conan/sys$common/syshlp/*.hlb All Help libraries

To obtain the library header information add a query string to the library file specification, as shown in the following example:

/conan/sys$common/syshlp/helplib.hlb?do=header VMS help library header

7.Bookreader Books and Libraries

While largely of historical interest these days, access to Bookreader format documentation (and any generated internally) is provided in the WASD web environment via two integrated scripts, HyperReader, which reads the books, and HyperShelf, which reads the Library and Shelf structures.

The HyperReader and HyperShelf scripts are automatically activated when the document file's extension is ".DECW$BOOK" and ".DECW$BOOKSHELF" respectively. Alternatively, the respective scripts may be explicitly specified (but the ability to provide a relative specification is lost).

If the server system supports Bookreader documentation collection one ot both the following links will provide an online demonstration:

/HyperShelf/
/cgi-bin/HyperShelf/

8.Web Document Update

The Update facility allows Web documents and file environments to be administered from a standard browser. This facility is available to Web administrator and user alike. Availability and capability depends on the authorization environment within the server.

It should be stressed that this is not designed as a full web administration or authoring tool, and for document preparation relies on the editing capabilities of the "<textarea>" widget of the user's browser. It does however, allow ad-hoc changes to be made to documents fairly easily, as well as allowing documents to be deleted, and directories to be created and deleted.

Consult the current Update documentation for usage detail.

And depending on site configuration /upd/wasd_root/ an example of the interface.

Update Access Permission

Of course, the user must have write (POST/PUT) access to the document or area on the server (i.e. the path) and the server account have file system permission to write into the parent directory.

Contact the Web Administrator for further information on the availablility of authentication and authorization permissions to do online updates of Web paths.

The server will report "Insufficient privilege or object protection violation ... /path/" if it does not have file system permission to write into a directory.

Write access by the server into VMS directories (using the POST or PUT HTTP methods) is controlled using VMS ACLs. This is in addition to the path authorization of the server itself of course! The requirement to have an ACL on the directory prevents inadvertant mapping/authorization of a path resulting in the ability to write somewhere not intended.

Two different ACLs implement two grades of access.

  1. If the ACL grants CONTROL access to the server account then only VMS-authenticated usernames with security profiles can potentially write to the directory. Only potentially, because a further check is made to assess whether that VMS account in particular has write access.

    This example shows a suitable ACL that applies only to the original directory:

    $ SET SECURITY directory.DIR - /ACL=(IDENT=HTTP$SERVER,ACCESS=READ+CONTROL)
    This example shows setting an ACL that will propagate to created files and importantly, subdirectories:
    $ SET SECURITY directory.DIR - /ACL=((IDENT=HTTP$SERVER,OPTIONS=DEFAULT,ACCESS=READ+WRITE+DELETE+CONTROL), - (IDENT=HTTP$SERVER,ACCESS=READ+WRITE+DELETE+CONTROL))
  2. If the ACL grants WRITE access then the directory can be written into by any authenticated username for the authorized path.

    This example shows a suitable ACL that applies only to the original directory:

    $ SET SECURITY directory.DIR - /ACL=(IDENT=HTTP$SERVER,ACCESS=READ+WRITE)
    This example shows setting an ACL that will propagate to created files and importantly, subdirectories:
    $ SET SECURITY directory.DIR - /ACL=((IDENT=HTTP$SERVER,OPTIONS=DEFAULT,ACCESS=READ+WRITE+DELETE), - (IDENT=HTTP$SERVER,ACCESS=READ+WRITE+DELETE))

9.Index

A2.3.1 Absolute File Path
 ‘Abstract’ in WASD Web Environment
 3.3.18 Allowing Override
 ‘Apache License, Version 2.0’ in WASD Web Environment
 10. Attribution and Acknowledgement
 3.3.13 Auto-Scripting
B‘Bells and Whistles’ in 5.3.4 Example Search Form
 ‘Bjöern Höehrmann’ in 10. Attribution and Acknowledgement
 7. Bookreader Books and Libraries
 ‘Browser (HTML) Supported Targets’ in 3.3.14 Target Window
C2.4.1 Characters In Request Paths
 2.4.2 Characters In Server-Generated Paths
 ‘Clark Cooper, et.al.’ in 10. Attribution and Acknowledgement
 3.1 Controlling Access To A Directory
D4.4 Directive Syntax
 4.5 Directives
 3. Directory Listing
 3.3.3 Directory Style
 3.4 Directory Tree
 2. Document Access and Specification
 2.4.3 Document Cache
 2.1 Document Content Type
 5. Document Searching
 2.3 Document Specification
E‘Example 1’ in 4.1 Virtual Documents
 ‘Example 2’ in 4.1 Virtual Documents
 5.3.4 Example Search Form
 2.2 Explicitly Specifying Content-Type
 2.4 Extended File Specifications (ODS-5)
F‘Faux Extension’ in 2.2 Explicitly Specifying Content-Type
 4.9 File and Virtual Specifications
 3.3.7 File Versions
 4.7 Flow Control
 5.3.2 Forms-Based Search
 ‘Free Software Foundation’ in 10. Attribution and Acknowledgement
H3.2 "Hidden" Files
 5.2 HTML Search
I‘<isindex> tag obsolete (as of HTML4)’ in 5.3 Search Syntax
 3.3.16 Icon Plain Text Link
 ‘Ignored Content-Type’ in 2.2 Explicitly Specifying Content-Type
 9. Index
 1. Introduction
L4.2 Last-Modified Information
 3.3.2 Layout
 ‘License’ in WASD Web Environment
 ‘Licensed under the Apache License, Version 2.0’ in 10. Attribution and Acknowledgement
 3.3.9 Listing Delimiters
 3.3.6 Listing Font
 ‘Listing Icons’ in 3. Directory Listing
 3.3.11 Listing Refresh and Expiry
 3.3.5 Listing Title
M‘Master file directory [000000]’ in 2.3 Document Specification
N‘None of the following licensing appears incompatible with the Apache License’ in 10. Attribution and Acknowledgement
O‘Ohio State University’ in 10. Attribution and Acknowledgement
 ‘Online Search’ in WASD Web Environment
 ‘OpenSSL Project’ in 10. Attribution and Acknowledgement
 ‘OSU "Part"s’ in 4.11 OSU Compatibility
 4.11 OSU Compatibility
 ‘OSU Compatible Directives’ in 4.11 OSU Compatibility
 ‘OSU Directives’ in 4.11 OSU Compatibility
 ‘Other "Functions"’ in 4.6 Variables
 ‘Other Librarian Functionality’ in 6. VMS Help and Text Libraries
P2.3.2 Partial (or Relative) File Path
 ‘Paul E. Jones’ in 10. Attribution and Acknowledgement
 5.1 Plain-Text Search
 4.3 Pre-Expiring Documents
Q3.3.17 Query String
 4.8 Query Strings
R3.3.8 Readme Files
 ‘RSA Data Security’ in 10. Attribution and Acknowledgement
S4.12 Script-Generated SSI Documents
 3.3.12 Scripting From Directory Listings
 5.3.3 Search Options
 5.3 Search Syntax
 3.3.4 Selective Listing
 3.3 Server Directives
 4. Server Side Includes (SSI)
 ‘Sortable Listing’ in 3.3.3 Directory Style
 3.3.15 Specifying Content-Type
 ‘SSI Directives’ in 4.5 Directives
 5.3.1 Standard Search Form
 ‘strftime() Format Directives’ in 4.10 Time Format
 ‘Stuart Langridge’ in 10. Attribution and Acknowledgement
 ‘Substrings’ in 4.6 Variables
 3.3.10 Suppressing Directories
T‘Table of Content’ in WASD Web Environment
 3.3.14 Target Window
 ‘Tatsuhiro Tsujikawa’ in 10. Attribution and Acknowledgement
 4.9.1 THE_FILE_NAME
 4.10 Time Format
U‘Update Access Permission’ in 8. Web Document Update
V4.6 Variables
 4.1 Virtual Documents
 6. VMS Help and Text Libraries
 ‘VMS-ish Format’ in 3. Directory Listing
W‘WASD VMS Web Services – Copyright © 1996-2021 Mark G. Daniel’ in 10. Attribution and Acknowledgement
 ‘WASD Web Environment’ in WASD Web Environment
 8. Web Document Update
Y‘YMMV’ in 3. Directory Listing
 ‘YMMV’ in 3.3.15 Specifying Content-Type

10.Attribution and Acknowledgement

WASD VMS Web Services – Copyright © 1996-2021 Mark G. Daniel
Licensed under the Apache License, Version 2.0

You may not use this software except in compliance with the License. You may obtain a copy of the License at https://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
None of the following licensing appears incompatible with the Apache License
Clark Cooper, et.al.

This package uses the Expat XML parsing toolkit.

Copyright (c) 1998, 1999, 2000 Thai Open Source Software Center Ltd and Clark Cooper Copyright (c) 2001, 2002, 2003, 2004, 2005, 2006 Expat maintainers. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
Bjöern Höehrmann

This package uses essential algorithm and code from Flexible and Economical UTF-8 Decoder.

Copyright (c) 2008-2009 Bjöern Höehrmann (<bjoern@hoehrmann.de>) Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
Free Software Foundation

This package contains software made available by the Free Software Foundation under the GNU General Public License.

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version.
Ohio State University

This package contains software provided with the OSU (DECthreads) HTTP server package, authored by David Jones:

Copyright 1994,1997 The Ohio State University. The Ohio State University will not assert copyright with respect to reproduction, distribution, performance and/or modification of this program by any person or entity that ensures that all copies made, controlled or distributed by or for him or it bear appropriate acknowlegement of the developers of this program.
OpenSSL Project

This product can include software developed by the OpenSSL Project for use in the OpenSSL Toolkit (https://www.openssl.org/).

Redistribution and use in source and binary forms, with or without modification, are permitted ...
Paul E. Jones

This package uses SHA-1 hash code.

Copyright (C) 1998, 2009 Paul E. Jones <paulej@packetizer.com> Freeware Public License (FPL) This software is licensed as "freeware." Permission to distribute this software in source and binary forms, including incorporation into other products, is hereby granted without a fee.
RSA Data Security

This software contains code derived in part from RSA Data Security, Inc:

permission granted to make and use derivative works provided that such works are identified as "derived from the RSA Data Security, Inc. MD5 Message-Digest Algorithm" in all material mentioning or referencing the derived work.
Stuart Langridge

SortTable version 2
Stuart Langridge, http://www.kryogenix.org/code/browser/sorttable/

Thanks to many, many people for contributions and suggestions. Licenced as X11: http://www.kryogenix.org/code/browser/licence.html This basically means: do what you want with it.
Tatsuhiro Tsujikawa

nghttp2 - HTTP/2 C Library
Tatsuhiro Tsujikawa, https://github.com/tatsuhiro-t

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

VSI OpenVMS, VSI TCP/IP Services for OpenVMS, VSI C
are registered trademarks of VMS Software Inc.

OpenVMS, HP TCP/IP Services for OpenVMS, HP C, Alpha, Itanium and VAX
are registered trademarks of Hewlett Packard Enterprise

MultiNet and TCPware are registered trademarks of Process Software Corporation

WASD Web Environment