2 * Copyright (c) 1995, the EUROPAGATE consortium (see below).
4 * The EUROPAGATE consortium members are:
6 * University College Dublin
7 * Danmarks Teknologiske Videnscenter
8 * An Chomhairle Leabharlanna
9 * Consejo Superior de Investigaciones Cientificas
11 * Permission to use, copy, modify, distribute, and sell this software and
12 * its documentation, in whole or in part, for any purpose, is hereby granted,
15 * 1. This copyright and permission notice appear in all copies of the
16 * software and its documentation. Notices of copyright or attribution
17 * which appear at the beginning of any file must remain unchanged.
19 * 2. The names of EUROPAGATE or the project partners may not be used to
20 * endorse or promote products derived from this software without specific
21 * prior written permission.
23 * 3. Users of this software (implementors and gateway operators) agree to
24 * inform the EUROPAGATE consortium of their use of the software. This
25 * information will be used to evaluate the EUROPAGATE project and the
26 * software, and to plan further developments. The consortium may use
27 * the information in later publications.
29 * 4. Users of this software agree to make their best efforts, when
30 * documenting their use of the software, to acknowledge the EUROPAGATE
31 * consortium, and the role played by the software in their work.
33 * THIS SOFTWARE IS PROVIDED "AS IS" AND WITHOUT WARRANTY OF ANY KIND,
34 * EXPRESS, IMPLIED, OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
35 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
36 * IN NO EVENT SHALL THE EUROPAGATE CONSORTIUM OR ITS MEMBERS BE LIABLE
37 * FOR ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF
38 * ANY KIND, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA
39 * OR PROFITS, WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND
40 * ON ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
41 * USE OR PERFORMANCE OF THIS SOFTWARE.
44 * Revision 1.7 1995/11/06 17:44:23 adam
45 * State reestablised when shell restarts. History of previous
48 * Revision 1.6 1995/11/06 10:51:19 adam
49 * End of response marker in response from wsh/wproto to wcgi.
50 * Shells are respawned when necessary.
52 * Revision 1.5 1995/11/01 16:15:48 adam
53 * Better presentation of records. Query/set number persistent.
55 * Revision 1.4 1995/10/27 15:12:12 adam
56 * IrTcl incorporated in the gateway.
57 * Better separation of script types.
58 * Z39.50 gateway scripts entered.
60 * Revision 1.3 1995/10/23 16:55:41 adam
61 * A lot of changes - really.
63 * Revision 1.2 1995/10/20 14:02:42 adam
64 * First version of WWW gateway with embedded Tcl.
66 * Revision 1.1 1995/10/20 11:49:28 adam
67 * First version of www gateway.
82 #define TIMEOUT_SHORT 60
83 #define TIMEOUT_MEDIUM 1800
84 #define TIMEOUT_LONG 7200
87 static char *mod = "wsh";
89 int main (int argc, char **argv)
91 char *script, *parms, parms_buf[512];
92 int timeout = TIMEOUT_SHORT;
95 chdir("/usr/local/etc/httpd/cgi-bin");
97 gw_log_file (GW_LOG_ALL, "/usr/local/etc/httpd/logs/egwsh_log");
98 gw_log_level (GW_LOG_ALL);
99 gw_log (GW_LOG_STAT, mod, "Europagate www shell: %s", *argv);
101 if (!(wcl = wproto_init()))
103 gw_log (GW_LOG_FATAL, mod, "init");
106 gw_log_session (wcl->id);
107 if (!strcmp (*argv, "egwtcl"))
108 w_interp = w_interp_create (w_interp_tcl, wcl, NULL);
109 else if (!strcmp (*argv, "egwirtcl"))
110 w_interp = w_interp_create (w_interp_irtcl, wcl, NULL);
111 else if (!strcmp (*argv, "egwhtml"))
112 w_interp = w_interp_create (w_interp_html, wcl, NULL);
115 gw_log (GW_LOG_FATAL, mod, "Cannot determine shell type. prog=%s",
119 w_interp_load_state (w_interp, NULL);
120 while (wproto_process(wcl, timeout) > 0)
124 wo_clear (wcl, "text/html");
125 strcpy (parms_buf, wcl->wf_parms);
126 script = parms = parms_buf;
127 while (*parms && *parms != '/')
133 p = script + strlen(script) - 1;
134 while (*p && p != script)
138 wproto_cache (wcl, wcl->cache_level+1);
143 wproto_cache (wcl, wcl->cache_level-atoi(p+1));
145 wproto_cache (wcl, wcl->cache_level-1);
150 wproto_cache (wcl, atoi(p+1));
157 for (p = parms; *p; p++)
160 gw_log (GW_LOG_DEBUG, mod, "script: %s", script);
161 gw_log (GW_LOG_DEBUG, mod, "parms: %s", parms);
162 if (w_interp_exec (w_interp, script, parms))
164 wo_printf (wcl, "<html><head><title>wsh error</title></head>\n");
165 wo_printf (wcl, "<body>Couldn't execute script %s</body></html>",
170 w_interp_save_state (w_interp, NULL);
171 wproto_terminate(wcl);