X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fyaz-z-server-update.cpp;h=2b1fe5144168cafb13ce81243281507a4eb5ae1a;hb=572f0d8babb3b5263f9848e094f80a3ea5926770;hp=68de621b1b30caa80729e878c3a35d035c99e14c;hpb=27f5d35959ef9720a628bb35aa58065ce1cbb85b;p=yazpp-moved-to-github.git diff --git a/src/yaz-z-server-update.cpp b/src/yaz-z-server-update.cpp index 68de621..2b1fe51 100644 --- a/src/yaz-z-server-update.cpp +++ b/src/yaz-z-server-update.cpp @@ -1,42 +1,60 @@ /* - * Copyright (c) 2000-2001, Index Data. + * Copyright (c) 2000-2004, Index Data. * See the file LICENSE for details. * - * $Log: yaz-z-server-update.cpp,v $ - * Revision 1.1 2001-05-03 12:42:57 adam - * Added update server service. - * + * $Id: yaz-z-server-update.cpp,v 1.12 2006-03-29 13:14:18 adam Exp $ */ #include -#include +#include -int Yaz_Facility_Update::init(Yaz_Z_Server *s, Z_InitRequest *initRequest, - Z_InitResponse *initResponse) +using namespace yazpp_1; + +int Yaz_Facility_Update::init(Z_Server *s, Z_InitRequest *initRequest, + Z_InitResponse *initResponse) { Z_Options *req = initRequest->options; Z_Options *res = initResponse->options; if (ODR_MASK_GET(req, Z_Options_extendedServices)) - ODR_MASK_SET(res, Z_Options_extendedServices); + ODR_MASK_SET(res, Z_Options_extendedServices); return 1; } -int Yaz_Facility_Update::recv(Yaz_Z_Server *s, Z_APDU *apdu_request) +int Yaz_Facility_Update::recv(Z_Server *s, Z_APDU *apdu_request) { Z_APDU *apdu_response; if (apdu_request->which != Z_APDU_extendedServicesRequest) - return 0; + return 0; Z_ExtendedServicesRequest *req = apdu_request->u.extendedServicesRequest; - if (!req->taskSpecificParameters || req->taskSpecificParameters->which != + if (req->taskSpecificParameters && req->taskSpecificParameters->which == Z_External_update) - return 0; - yaz_log (LOG_LOG, "got update p=%p", this); - apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); - update_service(req, req->taskSpecificParameters->u.update, - apdu_response->u.extendedServicesResponse); - s->transfer_referenceId(apdu_request, apdu_response); - s->send_Z_PDU(apdu_response); - return 1; + { + apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); + update_service(req, req->taskSpecificParameters->u.update, + apdu_response->u.extendedServicesResponse); + s->transfer_referenceId(apdu_request, apdu_response); + s->send_Z_PDU(apdu_response, 0); + return 1; + } + else if (req->taskSpecificParameters && + req->taskSpecificParameters->which == Z_External_update0) + { + apdu_response = s->create_Z_PDU(Z_APDU_extendedServicesResponse); + update_service0 (req, req->taskSpecificParameters->u.update0, + apdu_response->u.extendedServicesResponse); + s->transfer_referenceId(apdu_request, apdu_response); + s->send_Z_PDU(apdu_response, 0); + return 1; + } + return 0; } +/* + * Local variables: + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +