* Sebastian Hammer, Adam Dickmeiss
*
* $Log: client.c,v $
- * Revision 1.1 1995-05-22 11:30:31 quinn
+ * Revision 1.10 1995-06-06 14:56:58 quinn
+ * Better diagnostics.
+ *
+ * Revision 1.9 1995/06/06 08:15:19 quinn
+ * Cosmetic.
+ *
+ * Revision 1.8 1995/06/05 10:52:22 quinn
+ * Added SCAN.
+ *
+ * Revision 1.7 1995/06/02 09:50:09 quinn
+ * Smallish.
+ *
+ * Revision 1.6 1995/05/31 08:29:21 quinn
+ * Nothing significant.
+ *
+ * Revision 1.5 1995/05/29 08:10:47 quinn
+ * Moved oid.c to util.
+ *
+ * Revision 1.4 1995/05/22 15:30:13 adam
+ * Client uses prefix query notation.
+ *
+ * Revision 1.3 1995/05/22 15:06:53 quinn
+ * *** empty log message ***
+ *
+ * Revision 1.2 1995/05/22 14:56:40 quinn
+ * *** empty log message ***
+ *
+ * Revision 1.1 1995/05/22 11:30:31 quinn
* Added prettier client.
*
*
#include <stdlib.h>
#include <sys/time.h>
#include <assert.h>
+#ifdef _AIX
+#include <sys/select.h>
+#endif
#include <comstack.h>
#include <tcpip.h>
#endif
#include <proto.h>
-#include <oid.h>
#include <marcdisp.h>
+
+#ifdef RPN_QUERY
+#ifdef PREFIX_QUERY
+#include <pquery.h>
+#else
#include <yaz-ccl.h>
+#endif
+#endif
+
#include "../version.h"
#define C_PROMPT "Z> "
static int mediumSetPresentNumber = 0;
static int setno = 1; /* current set offset */
static int protocol = PROTO_Z3950; /* current app protocol */
+static ODR_MEM session_mem; /* memory handle for init-response */
+static Z_InitResponse *session = 0; /* session parameters */
+static char last_scan[512] = "0";
+static char last_cmd[100] = "?";
+#ifdef RPN_QUERY
+#ifndef PREFIX_QUERY
static CCL_bibset bibset; /* CCL bibset handle */
+#endif
+#endif
static void send_apdu(Z_APDU *a)
{
ODR_MASK_SET(req->options, Z_Options_search);
ODR_MASK_SET(req->options, Z_Options_present);
+ ODR_MASK_SET(req->options, Z_Options_namedResultSets);
+ ODR_MASK_SET(req->options, Z_Options_triggerResourceCtrl);
+ ODR_MASK_SET(req->options, Z_Options_scan);
- ODR_MASK_SET(req->protocolVersion, 0);
- ODR_MASK_SET(req->protocolVersion, 1);
- ODR_MASK_SET(req->protocolVersion, 2);
+ ODR_MASK_SET(req->protocolVersion, Z_ProtocolVersion_1);
+ ODR_MASK_SET(req->protocolVersion, Z_ProtocolVersion_2);
req->idAuthentication = auth;
static int process_initResponse(Z_InitResponse *res)
{
+ /* save session parameters for later use */
+ session_mem = odr_extract_mem(in);
+ session = res;
+
if (!*res->result)
printf("Connection rejected by target.\n");
else
fprintf(stderr, "Bad type: %s\n", type);
return 0;
}
- if (!(conn = cs_create(t, 1, CS_Z3950)))
+ if (!(conn = cs_create(t, 1, protocol)))
{
perror("cs_create");
return 0;
conn = 0;
return 0;
}
- printf("Ok!\n");
+ printf("Ok.\n");
send_initRequest();
return 2;
}
Z_SearchRequest *req = apdu->u.searchRequest;
char *databaseNames = database;
Z_Query query;
+#ifdef RPN_QUERY
+#ifndef PREFIX_QUERY
+ struct ccl_rpn_node *rpn;
int error, pos;
+#endif
+#endif
char setstring[100];
+#ifdef RPN_QUERY
Z_RPNQuery *RPNquery;
oident bib1;
- struct ccl_rpn_node *rpn;
-#ifndef RPN_QUERY
+#else
Odr_oct ccl_query;
#endif
#ifdef RPN_QUERY
+#ifndef PREFIX_QUERY
rpn = ccl_find_str(bibset, arg, &error, &pos);
if (error)
{
return 0;
}
#endif
+#endif
if (!strcmp(arg, "@big")) /* strictly for troublemaking */
{
#ifdef RPN_QUERY
query.which = Z_Query_type_1;
+
+#ifndef PREFIX_QUERY
assert((RPNquery = ccl_rpn_query(rpn)));
+#else
+ RPNquery = p_query_rpn (out, arg);
+ if (!RPNquery)
+ {
+ printf("Prefix query error\n");
+ return 0;
+ }
+#endif
bib1.proto = protocol;
bib1.class = CLASS_ATTSET;
bib1.value = VAL_BIB1;
static int process_searchResponse(Z_SearchResponse *res)
{
- if (res->searchStatus)
+ if (*res->searchStatus)
printf("Search was a success.\n");
else
printf("Search was a bloomin' failure.\n");
printf("Set numbering disabled.\n");
setnumber = -1;
}
- return 2;
+ return 1;
}
/* PRESENT SERVICE ----------------------------- */
exit(0);
}
+int cmd_cancel(char *arg)
+{
+ Z_APDU *apdu = zget_APDU(out, Z_APDU_triggerResourceControlRequest);
+ Z_TriggerResourceControlRequest *req =
+ apdu->u.triggerResourceControlRequest;
+ bool_t false = 0;
+
+ if (!session)
+ {
+ printf("Session not initialized yet\n");
+ return 0;
+ }
+ if (!ODR_MASK_GET(session->options, Z_Options_triggerResourceCtrl))
+ {
+ printf("Target doesn't support cancel (trigger resource ctrl)\n");
+ return 0;
+ }
+ *req->requestedAction = Z_TriggerResourceCtrl_cancel;
+ req->resultSetWanted = &false;
+
+ send_apdu(apdu);
+ printf("Sent cancel request\n");
+ return 2;
+}
+
+int send_scanrequest(char *string, int pp, int num)
+{
+ Z_APDU *apdu = zget_APDU(out, Z_APDU_scanRequest);
+ Z_ScanRequest *req = apdu->u.scanRequest;
+ char *db = database;
+ oident attset;
+
+ req->num_databaseNames = 1;
+ req->databaseNames = &db;
+ attset.proto = protocol;
+ attset.class = CLASS_ATTSET;
+ attset.value = VAL_BIB1;
+ req->attributeSet = oid_getoidbyent(&attset);
+ req->termListAndStartPoint = p_query_scan(out, string);
+ req->numberOfTermsRequested = #
+ req->preferredPositionInResponse = &pp;
+ send_apdu(apdu);
+ return 2;
+}
+
+void display_term(Z_TermInfo *t)
+{
+ if (t->term->which == Z_Term_general)
+ {
+ printf("%.*s (%d)\n", t->term->u.general->len, t->term->u.general->buf,
+ t->globalOccurrences ? *t->globalOccurrences : -1);
+ sprintf(last_scan, "%.*s", t->term->u.general->len,
+ t->term->u.general->buf);
+ }
+ else
+ printf("Term type not general.\n");
+}
+
+void process_scanResponse(Z_ScanResponse *res)
+{
+ int i;
+
+ printf("SCAN: %d entries, position=%d\n", *res->numberOfEntriesReturned,
+ *res->positionOfTerm);
+ if (*res->scanStatus != Z_Scan_success)
+ printf("Scan returned code %d\n", *res->scanStatus);
+ if (!res->entries)
+ return;
+ if (res->entries->which == Z_ListEntries_entries)
+ {
+ Z_Entries *ent = res->entries->u.entries;
+
+ for (i = 0; i < ent->num_entries; i++)
+ if (ent->entries[i]->which == Z_Entry_termInfo)
+ {
+ printf("%c ", i + 1 == *res->positionOfTerm ? '*' : ' ');
+ display_term(ent->entries[i]->u.termInfo);
+ }
+ else
+ display_diagrec(ent->entries[i]->u.surrogateDiagnostic);
+ }
+ else
+ display_diagrec(res->entries->u.nonSurrogateDiagnostics->diagRecs[0]);
+}
+
+int cmd_scan(char *arg)
+{
+ if (!session)
+ {
+ printf("Session not initialized yet\n");
+ return 0;
+ }
+ if (!ODR_MASK_GET(session->options, Z_Options_scan))
+ {
+ printf("Target doesn't support scan\n");
+ return 0;
+ }
+ if (*arg)
+ {
+ if (send_scanrequest(arg, 5, 19) < 0)
+ return 0;
+ }
+ else
+ if (send_scanrequest(last_scan, 1, 19) < 0)
+ return 0;
+ return 2;
+}
+
static void initialize(void)
{
+#ifdef RPN_QUERY
+#ifndef PREFIX_QUERY
FILE *inf;
+#endif
+#endif
if (!(out = odr_createmem(ODR_ENCODE)) ||
!(in = odr_createmem(ODR_DECODE)) ||
}
setvbuf(stdout, 0, _IONBF, 0);
+#ifdef RPN_QUERY
+#ifndef PREFIX_QUERY
bibset = ccl_qual_mk ();
inf = fopen ("default.bib", "r");
if (inf)
ccl_qual_file (bibset, inf);
fclose (inf);
}
+#endif
+#endif
}
static int client(void)
{"find", cmd_find, "<CCL-QUERY>"},
{"base", cmd_base, "<BASE-NAME>"},
{"show", cmd_show, "<REC#>['+'<#RECS>]"},
+ {"scan", cmd_scan, "<TERM>"},
{"authentication", cmd_authentication, "<ACCTSTRING>"},
{"lslb", cmd_lslb, "<largeSetLowerBound>"},
{"ssub", cmd_ssub, "<smallSetUpperBound>"},
{"mspn", cmd_mspn, "<mediumSetPresentNumber>"},
{"status", cmd_status, ""},
{"setnames", cmd_setnames, ""},
+ {"cancel", cmd_cancel, ""},
{0,0}
};
char *netbuffer= 0;
int i;
Z_APDU *apdu;
- printf(C_PROMPT);
while (1)
{
int res;
break;
if ((res = sscanf(line, "%s %[^;]", word, arg)) <= 0)
{
- printf(C_PROMPT);
- continue;
+ strcpy(word, last_cmd);
+ *arg = '\0';
}
- if (res == 1)
+ else if (res == 1)
*arg = 0;
+ strcpy(last_cmd, word);
for (i = 0; cmd[i].cmd; i++)
if (!strncmp(cmd[i].cmd, word, strlen(word)))
{
case Z_APDU_searchResponse:
process_searchResponse(apdu->u.searchResponse);
break;
+ case Z_APDU_scanResponse:
+ process_scanResponse(apdu->u.scanResponse);
+ break;
case Z_APDU_presentResponse:
printf("Received presentResponse.\n");
setno +=
initialize();
if (argc > 1)
cmd_open(argv[1]);
+ else
+ printf(C_PROMPT);
return client();
}