Provided by: djvuserve_3.5.28-2build4_amd64 bug

NAME

       djvuserve - Generate indirect DjVu documents on the fly.

DESCRIPTION

       Program  djvuserve is a CGI program that can be executed by a HTTP server for serving DjVu
       documents.  This program is able to convert a bundled multi-page document into an indirect
       document on the fly.

USING DJVUSERVE

       Program djvuserve must first be installed as a CGI program for your web server.  There are
       several ways to achieve this.   The Apache web  server,  for  instance,  often  defines  a
       specific directory for CGI programs using the ScriptAlias directive.  Assume that the file
       httpd.conf contains the following line:

          ScriptAlias /cgi–bin/ "/var/www/cgi–bin"

       It is then sufficient to create a small executable shell script /var/www/cgi–bin/djvuserve
       containing the following lines:

          #!/bin/sh
          exec /full/path/to/djvuserve

       Suppose that a large bundled multi-page DjVu document is available at the following URL.

          http://server/dir/doc.djvu

       The  CGI  program  djvuserve  lets you access this same document as an indirect multi-page
       DjVu document using the following URL.

          http://server/cgi–bin/djvuserve/dir/doc.djvu/index.djvu

       Serving indirect  multi-page  DjVu  documents  provides  for  efficiently  browsing  large
       document  without  transferring  unnecessary pages over the network.  See djvu(1) for more
       information.

       Furthermore djvuserve searches certain keywords among the CGI arguments of the  URL.   The
       keyword bundled forces serving a bundled document using

          http://server/cgi–bin/djvuserve/dir/doc.djvu?bundled

       The  keyword download inserts a content disposition HTTP header that suggests to display a
       save dialog instead of displaying the document.

          http://server/cgi–bin/djvuserve/dir/doc.djvu?download

USING DJVUSERVE AS A HANDLER

       The Apache web server provides a way to  automatically  execute  djvuserve  for  all  DjVu
       documents.   This  can  be  achieved  using  the following directives in either the Apache
       configuration file or the .htaccess files.

          Action djvu-server /cgi–bin/djvuserve/
          AddHandler djvu-server .djvu

       Apache then executes program djvuserve for serving all DjVu files.  Providing the  URL  of
       DjVu  file  serves  this  DjVu  file as usual, except that bundled multipage documents are
       converted to indirect documents on the fly.  This convenience comes at the expense of  the
       computational cost of executing djvuserve whenever a DjVu file is requested.

TECHNICAL DETAILS

       Program djvuserve provides a mean to directly access any component of a bundled multi-page
       DjVu document can be accessed using an extended URL.   Suppose  that  the  component  file
       representing  page  1  is named p0001.djvu.  The following URL provides a direct access to
       this page:

          http://server/cgi–bin/djvuserve/dir/doc.djvu/p0001.djvu

       It is preferred however to access individual pages using the CGI style arguments described
       in nsdejavu(1), as in the following URL.

          http://server/cgi–bin/djvuserve/dir/doc.djvu?djvuopts&page=12

       The special component file name index.djvu is recognized as a request for the index of the
       corresponding indirect multi-page document.  In fact, when you access a  bundled  document
       using djvuserve, the browser gets redirected to the following URL:

          http://server/cgi–bin/djvuserve/dir/doc.djvu/index.djvu

       and  then  behaves as if the bundled file was a directory containing the various component
       files of an equivalent indirect document.

ACCESS CONTROL

       Program djvuserve, like many  CGI  programs,  bypasses  a  number  of  access  protections
       established  in  a web server.  Assume for instance that your web site contains DjVu files
       protected by a password.  Program djvuserve knows nothing about this protection  and  will
       happily serve any DjVu file associated with a valid URL.

       Access  control with djvuserve can be implemented by first remembering that the web server
       always executes program djvuserve via shell script /var/www/cgi–bin/djvuserve.

       This script can decide to execute the real program djvuserve on the basis  of  the  target
       filename available in the environment variable PATH_TRANSLATED.

       There  can  be several such scripts providing access to various collections of DjVu files.
       Each of these scripts can be password protected using the usual methods supported by  your
       web server.

KNOWN BUGS

       Hyperlinks  specified  using  a  relative URL may not work with djvuserve.  These URLs are
       relative to the URL of the DjVu document. Yet djvuserve changes the apparent document  URL
       http://server/dir/doc.djvu        into        the        more        complicated       URL
       http://server/cgi–bin/djvuserve/dir/doc.djvu/index.djvu.  The extra components change  the
       interpretation of relative URLs.

CREDITS

       This program was written by Leon Bottou <leonb@users.sourceforge.com>.

SEE ALSO

       djvu(1), djvmcvt(1), nsdejavu(1)