X-Git-Url: http://git.indexdata.com/?p=yazpp-moved-to-github.git;a=blobdiff_plain;f=src%2Fyaz-ir-assoc.cpp;h=0978e060c521bd5f3f74f5e85ed53299b1e37d8d;hp=d5edf868901aa3586e10b41bf00b32c65b32c29d;hb=d62e0baee8ee3cccced41746ef09fc3e01f401d5;hpb=307a8638d6429b0f77ad762d52309c550e45648c diff --git a/src/yaz-ir-assoc.cpp b/src/yaz-ir-assoc.cpp index d5edf86..0978e06 100644 --- a/src/yaz-ir-assoc.cpp +++ b/src/yaz-ir-assoc.cpp @@ -1,66 +1,71 @@ -/* - * Copyright (c) 1998-2003, Index Data. +/* This file is part of the yazpp toolkit. + * Copyright (C) Index Data and Mike Taylor * See the file LICENSE for details. - * - * $Id: yaz-ir-assoc.cpp,v 1.20 2003-12-16 14:17:01 adam Exp $ */ +#if HAVE_CONFIG_H +#include +#endif #include #include -#include +#include +#include + +using namespace yazpp_1; -Yaz_IR_Assoc::Yaz_IR_Assoc(IYaz_PDU_Observable *the_PDU_Observable) - : Yaz_Z_Assoc(the_PDU_Observable) +IR_Assoc::IR_Assoc(IPDU_Observable *the_PDU_Observable) + : Z_Assoc(the_PDU_Observable) { m_num_databaseNames = 0; m_databaseNames = 0; - m_preferredRecordSyntax = VAL_NONE; + m_preferredRecordSyntax = 0; m_elementSetNames = 0; m_lastReceived = 0; m_host = 0; m_proxy = 0; m_cookie = 0; - m_log = LOG_DEBUG; + m_log = YLOG_DEBUG; const char *db = "Default"; set_databaseNames(1, &db); } -Yaz_IR_Assoc::~Yaz_IR_Assoc() +IR_Assoc::~IR_Assoc() { + xfree(m_preferredRecordSyntax); if (m_elementSetNames) - delete [] m_elementSetNames->u.generic; + delete [] m_elementSetNames->u.generic; delete [] m_elementSetNames; delete [] m_host; delete [] m_proxy; delete [] m_cookie; } -void Yaz_IR_Assoc::get_databaseNames (int *num, char ***list) +void IR_Assoc::get_databaseNames (int *num, char ***list) { *num = m_num_databaseNames; *list = m_databaseNames; } typedef char *charp; -void Yaz_IR_Assoc::set_databaseNames (int num, const char **list) +void IR_Assoc::set_databaseNames (int num, const char **list) { int i; - yaz_log (m_log, "Yaz_IR_Assoc::set_databaseNames num=%d", num); + yaz_log (m_log, "IR_Assoc::set_databaseNames num=%d", num); for (i = 0; idesc : ""; + if (m_preferredRecordSyntax) + *dst = m_preferredRecordSyntax; + else + *dst = ""; } -void Yaz_IR_Assoc::set_elementSetName (const char *elementSetName) +void IR_Assoc::set_elementSetName (const char *elementSetName) { if (m_elementSetNames) - delete [] m_elementSetNames->u.generic; + delete [] m_elementSetNames->u.generic; delete m_elementSetNames; m_elementSetNames = 0; if (elementSetName && *elementSetName) { - m_elementSetNames = new Z_ElementSetNames; - m_elementSetNames->which = Z_ElementSetNames_generic; - m_elementSetNames->u.generic = new char[strlen(elementSetName)+1]; - strcpy (m_elementSetNames->u.generic, elementSetName); + m_elementSetNames = new Z_ElementSetNames; + m_elementSetNames->which = Z_ElementSetNames_generic; + m_elementSetNames->u.generic = new char[strlen(elementSetName)+1]; + strcpy (m_elementSetNames->u.generic, elementSetName); } } -void Yaz_IR_Assoc::get_elementSetName (Z_ElementSetNames **elementSetNames) +void IR_Assoc::get_elementSetName (Z_ElementSetNames **elementSetNames) { *elementSetNames = m_elementSetNames; } -void Yaz_IR_Assoc::get_elementSetName (const char **elementSetName) +void IR_Assoc::get_elementSetName (const char **elementSetName) { if (!m_elementSetNames || - m_elementSetNames->which != Z_ElementSetNames_generic) + m_elementSetNames->which != Z_ElementSetNames_generic) { - *elementSetName = 0; - return; + *elementSetName = 0; + return; } *elementSetName = m_elementSetNames->u.generic; } -void Yaz_IR_Assoc::recv_GDU(Z_GDU *apdu, int len) +void IR_Assoc::recv_GDU(Z_GDU *apdu, int len) { if (apdu->which == Z_GDU_Z3950) - return recv_Z_PDU(apdu->u.z3950, len); + recv_Z_PDU(apdu->u.z3950, len); } -void Yaz_IR_Assoc::recv_Z_PDU(Z_APDU *apdu, int len) +void IR_Assoc::recv_Z_PDU(Z_APDU *apdu, int len) { yaz_log (m_log, "recv_Z_PDU %d bytes", len); m_lastReceived = apdu->which; switch (apdu->which) { case Z_APDU_initResponse: - yaz_log (m_log, "recv InitResponse"); - recv_initResponse(apdu->u.initResponse); - break; + yaz_log (m_log, "recv InitResponse"); + recv_initResponse(apdu->u.initResponse); + break; case Z_APDU_initRequest: yaz_log (m_log, "recv InitRequest"); - recv_initRequest(apdu->u.initRequest); + recv_initRequest(apdu->u.initRequest); break; case Z_APDU_searchRequest: yaz_log (m_log, "recv searchRequest"); - recv_searchRequest(apdu->u.searchRequest); + recv_searchRequest(apdu->u.searchRequest); break; case Z_APDU_searchResponse: - yaz_log (m_log, "recv searchResponse"); - recv_searchResponse(apdu->u.searchResponse); - break; + yaz_log (m_log, "recv searchResponse"); + recv_searchResponse(apdu->u.searchResponse); + break; case Z_APDU_presentRequest: yaz_log (m_log, "recv presentRequest"); - recv_presentRequest(apdu->u.presentRequest); + recv_presentRequest(apdu->u.presentRequest); break; case Z_APDU_presentResponse: yaz_log (m_log, "recv presentResponse"); - recv_presentResponse(apdu->u.presentResponse); + recv_presentResponse(apdu->u.presentResponse); break; case Z_APDU_extendedServicesResponse: yaz_log (m_log, "recv extendedServiceResponse"); @@ -193,35 +183,32 @@ void Yaz_IR_Assoc::recv_Z_PDU(Z_APDU *apdu, int len) } } -int Yaz_IR_Assoc::send_searchRequest(Yaz_Z_Query *query, +int IR_Assoc::send_searchRequest(Yaz_Z_Query *query, char* pResultSetId, char* pRefId) { Z_APDU *apdu = create_Z_PDU(Z_APDU_searchRequest); Z_SearchRequest *req = apdu->u.searchRequest; - int recordSyntax; req->query = query->get_Z_Query(); if (!req->query) - return -1; + return -1; get_databaseNames (&req->num_databaseNames, &req->databaseNames); - int oid_syntax[OID_SIZE]; - oident prefsyn; + const char *recordSyntax; get_preferredRecordSyntax(&recordSyntax); - if (recordSyntax != VAL_NONE) + if (recordSyntax && *recordSyntax) { - prefsyn.proto = PROTO_Z3950; - prefsyn.oclass = CLASS_RECSYN; - prefsyn.value = (enum oid_value) recordSyntax; - oid_ent_to_oid(&prefsyn, oid_syntax); - req->preferredRecordSyntax = oid_syntax; + req->preferredRecordSyntax + = yaz_string_to_oid_odr(yaz_oid_std(), CLASS_RECSYN, recordSyntax, + odr_encode()); } yaz_log (m_log, "send_searchRequest"); assert (req->otherInfo == 0); if (m_cookie) { - set_otherInformationString(&req->otherInfo, VAL_COOKIE, 1, m_cookie); - assert (req->otherInfo); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_cookie, + 1, m_cookie); + assert (req->otherInfo); } if ( pRefId ) @@ -237,10 +224,10 @@ int Yaz_IR_Assoc::send_searchRequest(Yaz_Z_Query *query, return send_Z_PDU(apdu, 0); } -int Yaz_IR_Assoc::send_presentRequest(int start, - int number, - char* pResultSetId, - char* pRefId) +int IR_Assoc::send_presentRequest(Odr_int start, + Odr_int number, + char* pResultSetId, + char* pRefId) { Z_APDU *apdu = create_Z_PDU(Z_APDU_presentRequest); Z_PresentRequest *req = apdu->u.presentRequest; @@ -248,30 +235,27 @@ int Yaz_IR_Assoc::send_presentRequest(int start, req->resultSetStartPoint = &start; req->numberOfRecordsRequested = &number; - int oid_syntax[OID_SIZE]; - oident prefsyn; - int recordSyntax; + const char *recordSyntax; get_preferredRecordSyntax (&recordSyntax); - if (recordSyntax != VAL_NONE) + if (recordSyntax && *recordSyntax) { - prefsyn.proto = PROTO_Z3950; - prefsyn.oclass = CLASS_RECSYN; - prefsyn.value = (enum oid_value) recordSyntax; - oid_ent_to_oid(&prefsyn, oid_syntax); - req->preferredRecordSyntax = oid_syntax; + req->preferredRecordSyntax = + yaz_string_to_oid_odr(yaz_oid_std(), CLASS_RECSYN, recordSyntax, + odr_encode()); } Z_RecordComposition compo; Z_ElementSetNames *elementSetNames; get_elementSetName (&elementSetNames); if (elementSetNames) { - req->recordComposition = &compo; + req->recordComposition = &compo; compo.which = Z_RecordComp_simple; compo.u.simple = elementSetNames; } if (m_cookie) - set_otherInformationString(&req->otherInfo, VAL_COOKIE, 1, m_cookie); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_cookie, + 1, m_cookie); if ( pRefId ) { @@ -286,103 +270,103 @@ int Yaz_IR_Assoc::send_presentRequest(int start, return send_Z_PDU(apdu, 0); } -void Yaz_IR_Assoc::set_proxy(const char *str) +void IR_Assoc::set_proxy(const char *str) { delete [] m_proxy; m_proxy = 0; if (str) { - m_proxy = new char[strlen(str)+1]; - strcpy (m_proxy, str); + m_proxy = new char[strlen(str)+1]; + strcpy (m_proxy, str); } } -void Yaz_IR_Assoc::set_cookie(const char *str) +void IR_Assoc::set_cookie(const char *str) { delete [] m_cookie; m_cookie = 0; if (str) { - m_cookie = new char[strlen(str)+1]; - strcpy(m_cookie, str); + m_cookie = new char[strlen(str)+1]; + strcpy(m_cookie, str); } } -const char *Yaz_IR_Assoc::get_cookie() +const char *IR_Assoc::get_cookie() { return m_cookie; } -void Yaz_IR_Assoc::client(const char *addr) +void IR_Assoc::client(const char *addr) { delete [] m_host; m_host = new char[strlen(addr)+1]; strcpy(m_host, addr); const char *dbpart = strchr(m_host, '/'); if (dbpart) - set_databaseNames (dbpart+1, "+ "); - Yaz_Z_Assoc::client(m_proxy ? m_proxy : m_host); + set_databaseNames (dbpart+1, "+ "); + Z_Assoc::client(m_proxy ? m_proxy : m_host); } -const char *Yaz_IR_Assoc::get_proxy() +const char *IR_Assoc::get_proxy() { return m_proxy; } -const char *Yaz_IR_Assoc::get_host() +const char *IR_Assoc::get_host() { return m_host; } -void Yaz_IR_Assoc::recv_searchRequest(Z_SearchRequest *searchRequest) +void IR_Assoc::recv_searchRequest(Z_SearchRequest *searchRequest) { Z_APDU *apdu = create_Z_PDU(Z_APDU_searchResponse); send_Z_PDU(apdu, 0); } -void Yaz_IR_Assoc::recv_presentRequest(Z_PresentRequest *presentRequest) +void IR_Assoc::recv_presentRequest(Z_PresentRequest *presentRequest) { Z_APDU *apdu = create_Z_PDU(Z_APDU_presentResponse); send_Z_PDU(apdu, 0); } -void Yaz_IR_Assoc::recv_initRequest(Z_InitRequest *initRequest) +void IR_Assoc::recv_initRequest(Z_InitRequest *initRequest) { Z_APDU *apdu = create_Z_PDU(Z_APDU_initResponse); send_Z_PDU(apdu, 0); } -void Yaz_IR_Assoc::recv_searchResponse (Z_SearchResponse *searchResponse) +void IR_Assoc::recv_searchResponse (Z_SearchResponse *searchResponse) { } -void Yaz_IR_Assoc::recv_presentResponse (Z_PresentResponse *presentResponse) +void IR_Assoc::recv_presentResponse (Z_PresentResponse *presentResponse) { } -void Yaz_IR_Assoc::recv_initResponse(Z_InitResponse *initResponse) +void IR_Assoc::recv_initResponse(Z_InitResponse *initResponse) { } -void Yaz_IR_Assoc::recv_extendedServicesResponse(Z_ExtendedServicesResponse *ExtendedServicesResponse) +void IR_Assoc::recv_extendedServicesResponse(Z_ExtendedServicesResponse *ExtendedServicesResponse) { } -int Yaz_IR_Assoc::get_lastReceived() +int IR_Assoc::get_lastReceived() { return m_lastReceived; } -void Yaz_IR_Assoc::set_lastReceived(int lastReceived) +void IR_Assoc::set_lastReceived(int lastReceived) { m_lastReceived = lastReceived; } -int Yaz_IR_Assoc::send_initRequest(char* pRefId) +int IR_Assoc::send_initRequest(char* pRefId) { Z_APDU *apdu = create_Z_PDU(Z_APDU_initRequest); Z_InitRequest *req = apdu->u.initRequest; - + ODR_MASK_SET(req->options, Z_Options_search); ODR_MASK_SET(req->options, Z_Options_present); ODR_MASK_SET(req->options, Z_Options_namedResultSets); @@ -402,13 +386,15 @@ int Yaz_IR_Assoc::send_initRequest(char* pRefId) } if (m_proxy && m_host) - set_otherInformationString(&req->otherInfo, VAL_PROXY, 1, m_host); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_proxy, + 1, m_host); if (m_cookie) - set_otherInformationString(&req->otherInfo, VAL_COOKIE, 1, m_cookie); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_cookie, + 1, m_cookie); return send_Z_PDU(apdu, 0); } -int Yaz_IR_Assoc::send_deleteResultSetRequest(char* pResultSetId, char* pRefId) +int IR_Assoc::send_deleteResultSetRequest(char* pResultSetId, char* pRefId) { char* ResultSetIds[1]; @@ -426,18 +412,29 @@ int Yaz_IR_Assoc::send_deleteResultSetRequest(char* pResultSetId, char* pRefId) { *req->deleteFunction = Z_DeleteResultSetRequest_all; } - + if ( pRefId ) { req->referenceId = getRefID(pRefId); } if (m_proxy && m_host) - set_otherInformationString(&req->otherInfo, VAL_PROXY, 1, m_host); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_proxy, + 1, m_host); if (m_cookie) - set_otherInformationString(&req->otherInfo, VAL_COOKIE, 1, m_cookie); + set_otherInformationString(&req->otherInfo, yaz_oid_userinfo_cookie, + 1, m_cookie); return send_Z_PDU(apdu, 0); } +/* + * Local variables: + * c-basic-offset: 4 + * c-file-style: "Stroustrup" + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +