X-Git-Url: http://git.indexdata.com/?p=yazpp-moved-to-github.git;a=blobdiff_plain;f=src%2Fyaz-z-server-update.cpp;h=be554f766370187da1cdae22b2979d5e2073dfce;hp=68de621b1b30caa80729e878c3a35d035c99e14c;hb=5e3f7e1a720a08d30c407049c94c6ca825a5ed27;hpb=27f5d35959ef9720a628bb35aa58065ce1cbb85b diff --git a/src/yaz-z-server-update.cpp b/src/yaz-z-server-update.cpp index 68de621..be554f7 100644 --- a/src/yaz-z-server-update.cpp +++ b/src/yaz-z-server-update.cpp @@ -1,15 +1,12 @@ /* - * 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.8 2005-05-17 12:59:50 adam Exp $ */ #include -#include +#include int Yaz_Facility_Update::init(Yaz_Z_Server *s, Z_InitRequest *initRequest, Z_InitResponse *initResponse) @@ -29,14 +26,25 @@ int Yaz_Facility_Update::recv(Yaz_Z_Server *s, Z_APDU *apdu_request) if (apdu_request->which != Z_APDU_extendedServicesRequest) 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; }