/*
- * Copyright (c) 1998-2001, Index Data.
+ * Copyright (c) 1998-2004, Index Data.
* See the file LICENSE for details.
*
- * $Id: yaz-my-client.cpp,v 1.11 2002-10-09 12:50:26 adam Exp $
+ * $Id: yaz-my-client.cpp,v 1.20 2005-06-08 13:28:06 adam Exp $
*/
+#include <stdlib.h>
#include <yaz/log.h>
#include <yaz/options.h>
#include <yaz/diagbib1.h>
#include <yaz++/pdu-assoc.h>
#include <yaz++/socket-manager.h>
-#if HAVE_YAZ_URSULA_H
-#include <yaz/zes-ursula.h>
-#endif
-
extern "C" {
#if HAVE_READLINE_READLINE_H
#include <readline/readline.h>
#endif
}
-class YAZ_EXPORT MyClient : public Yaz_IR_Assoc {
+using namespace yazpp_1;
+
+class YAZ_EXPORT MyClient : public IR_Assoc {
private:
int m_interactive_flag;
char m_thisCommand[1024];
char m_lastCommand[1024];
int m_setOffset;
- Yaz_SocketManager *m_socketManager;
+ SocketManager *m_socketManager;
public:
- MyClient(IYaz_PDU_Observable *the_PDU_Observable,
- Yaz_SocketManager *the_SocketManager);
- IYaz_PDU_Observer *sessionNotify(
- IYaz_PDU_Observable *the_PDU_Observable, int fd);
- int args(Yaz_SocketManager *socketManager, int argc, char **argv);
- int interactive(Yaz_SocketManager *socketManager);
+ MyClient(IPDU_Observable *the_PDU_Observable,
+ SocketManager *the_SocketManager);
+ IPDU_Observer *sessionNotify(
+ IPDU_Observable *the_PDU_Observable, int fd);
+ int args(SocketManager *socketManager, int argc, char **argv);
+ int interactive(SocketManager *socketManager);
int wait();
void recv_initResponse(Z_InitResponse *initResponse);
void recv_searchResponse(Z_SearchResponse *searchResponse);
const char *databaseName);
void recv_textRecord(int type, const char *buf, size_t len);
void recv_genericRecord(Z_GenericRecord *r);
-#if HAVE_YAZ_URSULA_H
- void recv_extendedServicesResponse(Z_ExtendedServicesResponse *extendedServicesResponse);
-#endif
void display_genericRecord(Z_GenericRecord *r, int level);
void display_variant(Z_Variant *v, int level);
void connectNotify();
int cmd_init(char *args);
int cmd_format(char *args);
int cmd_proxy(char *args);
-#if HAVE_YAZ_URSULA_H
- int cmd_ursula(char *args);
- int cmd_ursula_renew(char *args);
-#endif
};
set_lastReceived(-1);
}
-IYaz_PDU_Observer *MyClient::sessionNotify(
- IYaz_PDU_Observable *the_PDU_Observable, int fd)
+IPDU_Observer *MyClient::sessionNotify(IPDU_Observable *the_PDU_Observable,
+ int fd)
{
return new MyClient(the_PDU_Observable, m_socketManager);
}
-MyClient::MyClient(IYaz_PDU_Observable *the_PDU_Observable,
- Yaz_SocketManager *the_socketManager) :
- Yaz_IR_Assoc (the_PDU_Observable)
+MyClient::MyClient(IPDU_Observable *the_PDU_Observable,
+ SocketManager *the_socketManager) :
+ IR_Assoc (the_PDU_Observable)
{
m_setOffset = 1;
m_interactive_flag = 1;
recv_records (presentResponse->records);
}
-#if HAVE_YAZ_URSULA_H
-void MyClient::recv_extendedServicesResponse(Z_ExtendedServicesResponse *extendedServicesResponse)
-{
- printf("Got ESresponse\n");
- printf(" OperationStatus=%d with %d diagnostics:\n",
- *extendedServicesResponse->operationStatus,
- extendedServicesResponse->num_diagnostics);
- recv_diagrecs(extendedServicesResponse->diagnostics,
- extendedServicesResponse->num_diagnostics);
- //TODO: Add more info !
-}
-#endif
-
int MyClient::wait()
{
set_lastReceived(0);
client (host);
timeout (10);
wait ();
- timeout (0);
+ timeout (-1);
return 1;
}
client (host);
timeout (10);
wait ();
- timeout (0);
+ timeout (-1);
send_initRequest();
wait ();
return 1;
return 1;
}
-#if HAVE_YAZ_URSULA_H
-int MyClient::cmd_ursula(char *args)
-{
- Z_APDU *apdu = create_Z_PDU(Z_APDU_extendedServicesRequest);
- Z_ExtendedServicesRequest *req = apdu->u.extendedServicesRequest;
-
- req->packageType = odr_getoidbystr(odr_encode(), "1.2.840.10003");
-// req->packageType = odr_getoidbystr(odr_encode(), "1.2.840.10003.9.1000.105.3");
-
- Z_External *ext = (Z_External *) odr_malloc(odr_encode(), sizeof(*ext));
- req->taskSpecificParameters = ext;
- ext->direct_reference = req->packageType;
- ext->descriptor = 0;
- ext->indirect_reference = 0;
-
- ext->which = Z_External_octet;
- ext->u.single_ASN1_type = (Odr_oct *)
- odr_malloc (odr_encode(), sizeof(Odr_oct));
-
- Z_UrsPDU *pdu = (Z_UrsPDU *) odr_malloc (odr_encode(), sizeof(*pdu));
- pdu->which = Z_UrsPDU_request;
- pdu->u.request = (Z_UrsRequest *)
- odr_malloc (odr_encode(), sizeof(*pdu->u.request));
- pdu->u.request->libraryNo = odr_strdup(odr_encode(), "000200");
- pdu->u.request->borrowerTickerNo = odr_strdup(odr_encode(),"1234567973");
- pdu->u.request->disposalType = 0;
- pdu->u.request->lastUseDate = odr_strdup(odr_encode(),"20011224");
-#ifdef SKIPTHIS
- pdu->u.request->num_items = 0;
- pdu->u.request->items = (Z_UrsRequestItem **) odr_nullval();
-#else
- pdu->u.request->num_items = 1;
- pdu->u.request->items = (Z_UrsRequestItem **)
- odr_malloc(odr_encode(), 1 * sizeof(Z_UrsRequestItem*) );
- pdu->u.request->items[0] = (Z_UrsRequestItem*)
- odr_malloc(odr_encode(), sizeof(Z_UrsRequestItem) );
- pdu->u.request->items[0]->id = odr_strdup(odr_encode(),"002231336x");
- pdu->u.request->items[0]->titlePartNo=odr_strdup(odr_encode(),"31");
-#endif
-
- pdu->u.request->counter = odr_strdup(odr_encode(),"HB");
- pdu->u.request->priority = 0;
- pdu->u.request->disposalNote = 0;
- pdu->u.request->overrule=(bool_t*)odr_malloc(odr_encode(),sizeof(bool_t));
- *pdu->u.request->overrule = false;
-
- if (!z_UrsPDU (odr_encode(), &pdu, 0, ""))
- {
- yaz_log (LOG_LOG, "ursula encoding failed");
- return 1;
- }
- char *buf =
- odr_getbuf (odr_encode(), &ext->u.single_ASN1_type->len, 0);
-
- ext->u.single_ASN1_type->buf = (unsigned char*)
- odr_malloc (odr_encode(), ext->u.single_ASN1_type->len);
- memcpy (ext->u.single_ASN1_type->buf, buf, ext->u.single_ASN1_type->len);
- ext->u.single_ASN1_type->size = ext->u.single_ASN1_type->len;
-
- if (send_Z_PDU(apdu) >= 0)
- wait();
- return 1;
-}
-
-int MyClient::cmd_ursula_renew(char *args)
-{
- Z_APDU *apdu = create_Z_PDU(Z_APDU_extendedServicesRequest);
- Z_ExtendedServicesRequest *req = apdu->u.extendedServicesRequest;
-
- req->packageType = odr_getoidbystr(odr_encode(), "1.2.840.10003");
-
- Z_External *ext = (Z_External *) odr_malloc(odr_encode(), sizeof(*ext));
- req->taskSpecificParameters = ext;
- ext->direct_reference = req->packageType;
- ext->descriptor = 0;
- ext->indirect_reference = 0;
-
- ext->which = Z_External_octet;
- ext->u.single_ASN1_type = (Odr_oct *)
- odr_malloc (odr_encode(), sizeof(Odr_oct));
-
- Z_UrsPDU *pdu = (Z_UrsPDU *) odr_malloc (odr_encode(), sizeof(*pdu));
- pdu->which = Z_UrsPDU_renewal;
- pdu->u.renewal = (Z_UrsRenewal *)
- odr_malloc (odr_encode(), sizeof(*pdu->u.renewal));
- pdu->u.renewal->libraryNo = odr_strdup(odr_encode(), "000200");
- pdu->u.renewal->borrowerTicketNo = odr_strdup(odr_encode(),"1234567973");
- pdu->u.renewal->num_copies=1;
- pdu->u.renewal->copies = (Z_InternationalString **)
- odr_malloc(odr_encode(),1* sizeof(Z_InternationalString *) );
- pdu->u.renewal->copies[0]= odr_strdup(odr_encode(), "000035238");
- pdu->u.renewal->newReturnDate=odr_strdup(odr_encode(), "20011224");
- pdu->u.renewal->overrule=(bool_t*)odr_malloc(odr_encode(),sizeof(bool_t));
- *pdu->u.renewal->overrule=false;
-
- if (!z_UrsPDU (odr_encode(), &pdu, 0, ""))
- {
- yaz_log (LOG_LOG, "ursula encoding failed");
- return 1;
- }
- char *buf =
- odr_getbuf (odr_encode(), &ext->u.single_ASN1_type->len, 0);
-
- ext->u.single_ASN1_type->buf = (unsigned char*)
- odr_malloc (odr_encode(), ext->u.single_ASN1_type->len);
- memcpy (ext->u.single_ASN1_type->buf, buf, ext->u.single_ASN1_type->len);
- ext->u.single_ASN1_type->size = ext->u.single_ASN1_type->len;
-
- if (send_Z_PDU(apdu) >= 0)
- wait();
- return 1;
-}
-
-
-#endif
-
int MyClient::processCommand(const char *commandLine)
{
char cmdStr[1024], cmdArgs[1024];
cmdArgs[0] = '\0';
cmdStr[0] = '\0';
static struct {
- char *cmd;
+ const char *cmd;
int (MyClient::*fun)(char *arg);
- char *ad;
+ const char *ad;
} cmd[] = {
{"open", &MyClient::cmd_open, "<host>[':'<port>][/<database>]"},
{"connect", &MyClient::cmd_connect, "<host>[':'<port>][/<database>]"},
{"init", &MyClient::cmd_init, ""},
{"format", &MyClient::cmd_format, "<record-syntax>"},
{"proxy", &MyClient::cmd_proxy, "<host>:[':'<port>]"},
-#if HAVE_YAZ_URSULA_H
- {"ursula", &MyClient::cmd_ursula, ""},
- {"ursula_request", &MyClient::cmd_ursula, ""},
- {"ursreq", &MyClient::cmd_ursula, ""},
- {"ursnew", &MyClient::cmd_ursula_renew, ""},
- {"ursula_renew", &MyClient::cmd_ursula_renew, ""},
-#endif
{0,0,0}
};
return m_lastCommand;
}
-int MyClient::interactive(Yaz_SocketManager *socketManager)
+int MyClient::interactive(SocketManager *socketManager)
{
const char *cmd;
if (!m_interactive_flag)
return 0;
}
-int MyClient::args(Yaz_SocketManager *socketManager, int argc, char **argv)
+int MyClient::args(SocketManager *socketManager, int argc, char **argv)
{
char *host = 0;
char *proxy = 0;
client (host);
timeout (10);
wait ();
- timeout (0);
+ timeout (-1);
send_initRequest();
wait ();
}
int main(int argc, char **argv)
{
- Yaz_SocketManager mySocketManager;
- Yaz_PDU_Assoc *some = new Yaz_PDU_Assoc(&mySocketManager);
+ SocketManager mySocketManager;
+ PDU_Assoc *some = new PDU_Assoc(&mySocketManager);
MyClient z(some, &mySocketManager);