[0001]
[0002]
[0003]
[0004]
[0005]
[0006]
[0007]
[0008]
[0009]
[0010]
[0011]
[0012]
[0013]
[0014]
[0015]
[0016]
[0017]
[0018]
[0019]
[0020]
[0021]
[0022]
[0023]
[0024]
[0025]
[0026]
[0027]
[0028]
[0029]
[0030]
[0031]
[0032]
[0033]
[0034]
[0035]
[0036]
[0037]
[0038]
[0039]
[0040]
[0041]
[0042]
[0043]
[0044]
[0045]
[0046]
[0047]
[0048]
[0049]
[0050]
[0051]
[0052]
[0053]
[0054]
[0055]
[0056]
[0057]
[0058]
[0059]
[0060]
[0061]
[0062]
[0063]
[0064]
[0065]
[0066]
[0067]
[0068]
[0069]
[0070]
[0071]
[0072]
[0073]
[0074]
[0075]
[0076]
[0077]
[0078]
[0079]
[0080]
[0081]
[0082]
[0083]
[0084]
[0085]
[0086]
[0087]
[0088]
[0089]
[0090]
[0091]
[0092]
[0093]
[0094]
[0095]
[0096]
[0097]
[0098]
[0099]
[0100]
[0101]
[0102]
[0103]
[0104]
[0105]
[0106]
[0107]
[0108]
[0109]
[0110]
[0111]
[0112]
[0113]
[0114]
[0115]
[0116]
[0117]
[0118]
[0119]
[0120]
[0121]
[0122]
[0123]
[0124]
[0125]
[0126]
[0127]
[0128]
[0129]
[0130]
[0131]
[0132]
[0133]
[0134]
[0135]
[0136]
[0137]
[0138]
[0139]
[0140]
[0141]
[0142]
[0143]
[0144]
[0145]
[0146]
[0147]
[0148]
[0149]
[0150]
[0151]
[0152]
[0153]
[0154]
[0155]
[0156]
[0157]
[0158]
[0159]
[0160]
[0161]
[0162]
[0163]
[0164]
[0165]
[0166]
[0167]
[0168]
[0169]
[0170]
[0171]
[0172]
[0173]
[0174]
[0175]
[0176]
[0177]
[0178]
[0179]
[0180]
[0181]
[0182]
[0183]
[0184]
[0185]
[0186]
[0187]
[0188]
[0189]
[0190]
[0191]
[0192]
[0193]
[0194]
[0195]
[0196]
[0197]
[0198]
[0199]
[0200]
[0201]
[0202]
[0203]
[0204]
[0205]
[0206]
[0207]
[0208]
/*****************************************************************************/
/*
                            CGIplusCallout.c


Example CGIplus script illustrating the use of callouts.

Uses the CGILIB routines.

Also see CGIPLUSCALLOUTPROC.COM which directly manipulates the required
environment variables, etc., and so could be used as an example for creating
non-C-language scripts and agents.


BUILD DETAILS
-------------
See BUILD_ONE.COM procedure.

  $ @BUILD_ONE BUILD CGIPLUSCALLOUT
  $ @BUILD_ONE LINK CGIPLUSCALLOUT


COPYRIGHT
---------
Copyright (C) 1999-2021 Mark G.Daniel

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://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.


VERSION HISTORY
---------------
06-OCT-2004  MGD  v1.2.0, CGILIB object library
06-SEP-1999  MGD  v1.0.0, initial development
*/

/*****************************************************************************/

/* standard C header files */
#include <ctype.h>
#include <errno.h>
#include <stdarg.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <ssdef.h>

#include <cgilib.h>

/*****************************************************************************/
/*
*/

main ()
       
{
   int  status;

   /*********/
   /* begin */
   /*********/

   CgiLibEnvironmentInit (0, NULL, 0);

   /* MUST only be executed in a CGIplus environment! */
   if (!CgiLibEnvironmentIsCgiPlus ()) exit (SS$_ABORT);

   for (;;)
   {
      /* block waiting for the next request */
      CgiLibVar ("");
      ProcessRequest ();
      CgiLibCgiPlusEOF ();
   }
}

/*****************************************************************************/
/*
Main authentication request processing function.
*/

ProcessRequest ()
       
{
   static int  UsageCount = 0;

   char  ExampleFile [] = "WASD_ROOT:[SRC.HTTPD]", 
         ExamplePath [] = "/wasd_root/src/httpd/";

   char  Response [256];

  /*********/
   /* begin */
   /*********/

   UsageCount++;

   CgiLibResponseHeader (200, "text/html");

   fprintf (stdout,
"<B><U>CGIPLUSCALLOUT.C</U></B>\n\
<P>Usage count: %d\n\
\
<P>This script provides a simple demonstration of the CGIplus <I>callout</I>\n\
facility, used to suspend normal script output and communicate directly with\n\
the server.  This allows the script to request information from the server,\n\
or set certain script operating parameters, etc.\n\
\
<P>To begin an <I>callout</I> the CGIPLUSESC environment variable (logical\n\
name) is output as a record.  For this script it has a value of:\n\
<PRE>  %s</PRE>\n\
<P>(but of course is not static, and varies each time the script is first\n\
executed).\n\
\
<P>A single-record script request followed by a single-record server response\n\
dialog may then be engaged in.\n\
\
<P>To end an <I>callout</I> the CGIPLUSEOT environment variable (logical\n\
name) is output as a record.  For this script it has a value of:\n\
<PRE>  %s</PRE>\n\
<P>(and also will vary each time the script is first executed).\n\
\
<P>Normal script output (to the browser) is then resumed.  When in\n\
<I>callout</I> mode one or more request/responses may be made.  Normal and\n\
callout output may be interleaved during a script response, as this script\n\
illustrates.\n\
\
<P><B><U>Example Behaviour</U></B>\n\
\
<UL>\n\
\
<LI>Translating a URL-style path to a VMS file specification:\n\
<PRE>  %s</PRE>\n\
<P>The request sent to the server was:\n\
<PRE>  MAP-PATH: %s</PRE>\n",
      UsageCount, getenv("CGIPLUSESC"), getenv("CGIPLUSEOT"),
      ExamplePath, ExamplePath);

   /* provide the server attention "escape" sequence record */
   CgiLibCgiPlusESC ();
   /* remember, this dialog is record-oriented, so fflush() as necessary */
   fprintf (stdout, "MAP-PATH: %s", ExamplePath);
   fflush (stdout);
   CgiLibCgiPlusInGets (Response, sizeof(Response));
   /* provide the "escape" end-of-text sequence record */
   CgiLibCgiPlusEOT ();

   fprintf (stdout,
"<P>The full server response was:\n\
<PRE>  %s</PRE>\n\
<P> Yielding a file specification of:\n\
<PRE>  %s</PRE>\n\
\
<LI>Now a translation of a VMS file specification into a URL-style path:\n\
<PRE>  %s</PRE>\n\
<P>The request sent to the server was:\n\
<PRE>  MAP-FILE: %s</PRE>\n",
      Response, Response+4,
      ExampleFile, ExampleFile);

   CgiLibCgiPlusESC ();
   fprintf (stdout, "MAP-FILE: %s", ExampleFile);
   fflush (stdout);
   CgiLibCgiPlusInGets (Response, sizeof(Response));
   CgiLibCgiPlusEOT ();

   fprintf (stdout,
"<P>The full server response was:\n\
<PRE>  %s</PRE>\n\
<P> Yielding a path of:\n\
<PRE>  %s</PRE>\n\
\
<LI>Finally an error response to an unknown callout request:\n\
<P>The request sent to the server was:\n\
<PRE>  UNKNOWN?: %s</PRE>\n",
      Response, Response+4,
      ExampleFile);

   CgiLibCgiPlusESC ();
   fprintf (stdout, "UNKNOWN: %s", ExampleFile);
   fflush (stdout);
   CgiLibCgiPlusInGets (Response, sizeof(Response));
   CgiLibCgiPlusEOT ();

   fprintf (stdout,
"<P>The full server response was:\n\
<PRE>  %s</PRE>\n\
\
</UL>\n\
\
<B><U>Comments</U></B>\n\
<P>Success responses begin with an HTTP-like &quot;200&quot;,\n\
other responses with appropriate status codes.\n",
      Response);
}

/*****************************************************************************/