* Europagate, 1995
*
* $Log: urp.c,v $
- * Revision 1.47 1996/01/18 13:54:48 adam
+ * Revision 1.51 2001/02/26 14:32:36 adam
+ * Updated for YAZ 1.7. HTML output tidy up. Added LOC target.
+ *
+ * Revision 1.50 1996/03/01 16:09:30 adam
+ * New setting: gw.msg.replyto that sets Reply-To in user response.
+ *
+ * Revision 1.49 1996/03/01 14:25:28 adam
+ * Email gateway obeys 'Reply-To:' in header.
+ *
+ * Revision 1.48 1996/02/12 10:04:57 adam
+ * The gateway doesn't try to reconnect if it is already known that
+ * it will fail (connect_fail flag introduced).
+ *
+ * Revision 1.47 1996/01/18 13:54:48 adam
* Help <command> gives help information about individual commands.
* Status without arguments gives list of available predefined targets.
*
gw_res_get (info.kernel_res, "gw.err.connect",
"Cannot connect to target"),
info.hostname, info.port);
+ info.connect_failed = 1;
return -1;
}
v = gw_res_get (info.kernel_res, "gw.description", NULL);
return 0;
if (memcmp (line_buf, "From ", 5) == 0)
sscanf (line_buf+4, "%s", from_str);
+ if (memcmp (line_buf, "Reply-To: ", 10) == 0)
+ sscanf (line_buf+10, "%s", from_str);
if (memcmp (line_buf, "Subject: ", 9) == 0 &&
sscanf (line_buf+9, "%s", subject_str+1) == 1)
strcpy (subject_str, line_buf+9);
*info.account = '\0';
info.account_in_session = 0;
read_kernel_res ();
+ info.connect_failed = 0;
return reopen_target ();
}
continue;
}
}
- if (record_log_fd != -1)
- write (record_log_fd, pp->record, strlen(pp->record));
- rec = iso2709_cvt (pp->record);
- if (rec)
- {
+ if (pp->record)
+ {
+ if (record_log_fd != -1)
+ write (record_log_fd, pp->record, strlen(pp->record));
+ rec = iso2709_cvt (pp->record);
+ if (rec)
+ {
#if USE_FML
- strcpy (format_str,
- gw_res_get (info.kernel_res,
- "gw.display.format", ""));
- if (format_token)
- {
- len = format_token->len;
- if (len >= sizeof(format_str))
- len = sizeof(format_str)-1;
- memcpy (format_str, format_token->name, len);
- format_str[len] = '\0';
- }
- if (info.fml && *format_str &&
- (!strcmp (format_str, "0") || !strcmp (format_str, "1")
- || !strcmp(format_str, "2")))
- {
- arg_ar[0] = "\\f";
- arg_ar[1] = format_str;
- arg_ar[2] = " \\list";
- arg_ar[3] = marc_to_str (info.fml, rec);
- arg_ar[4] = NULL;
- fml_exec_call_argv (info.fml, arg_ar);
- }
- else
- iso2709_display (rec, reply_fd);
+ strcpy (format_str,
+ gw_res_get (info.kernel_res,
+ "gw.display.format", ""));
+ if (format_token)
+ {
+ len = format_token->len;
+ if (len >= sizeof(format_str))
+ len = sizeof(format_str)-1;
+ memcpy (format_str, format_token->name, len);
+ format_str[len] = '\0';
+ }
+ if (info.fml && *format_str &&
+ (!strcmp (format_str, "0") || !strcmp (format_str, "1")
+ || !strcmp(format_str, "2")))
+ {
+ arg_ar[0] = "\\f";
+ arg_ar[1] = format_str;
+ arg_ar[2] = " \\list";
+ arg_ar[3] = marc_to_str (info.fml, rec);
+ arg_ar[4] = NULL;
+ fml_exec_call_argv (info.fml, arg_ar);
+ }
+ else
+ iso2709_display (rec, reply_fd);
#else
- iso2709_display (rec, reply_fd);
+ iso2709_display (rec, reply_fd);
#endif
- iso2709_rm (rec);
+ iso2709_rm (rec);
+ }
+ else
+ fprintf (reply_fd, "Record type not supported\n");
}
else
fprintf (reply_fd, "Not a MARC record\n");
{
if (no == 1 || no == 2 || no == 3) /* find/show/base? */
{
- if (!info.zass) /* open if not already opened */
+ if (!info.connect_failed && !info.zass)
+ /* open if not already opened */
reopen_target ();
fprintf (reply_fd, "\n> %s\n", str);
- if (!info.zass) /* fail? */
+ if (!info.zass) /* fail? */
{
fprintf (reply_fd, "\n%s\n",
gw_res_get (info.kernel_res, "gw.err.no.target",
int urp_start (int continuation, struct str_queue *queue)
{
char subject_str[128];
+ const char *cp;
info.command_no = 0;
info.reply_fname = NULL;
}
tty_init (reply_fd, 0, 0);
fprintf (reply_fd, "From: %s\n",
- gw_res_get (info.kernel_res, "gw.msg.from","Email-gateway"));
+ gw_res_get (info.kernel_res, "gw.msg.from",
+ "Email-Z39.50 gateway"));
+ cp = gw_res_get (info.kernel_res, "gw.msg.replyto", NULL);
+ if (cp)
+ fprintf (reply_fd, "Reply-To: %s\n", cp);
fprintf (reply_fd, "Subject: ");
if (*subject_str)
fprintf (reply_fd, "Z39.50 Re: %s", subject_str);