Bump year
[yazpp-moved-to-github.git] / src / yaz-z-server-update.cpp
index 68de621..a6f2d1a 100644 (file)
@@ -1,42 +1,62 @@
-/*
- * Copyright (c) 2000-2001, Index Data.
+/* This file is part of the yazpp toolkit.
+ * Copyright (C) 1998-2013 Index Data and Mike Taylor
  * 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.
- *
  */
 
+#if HAVE_CONFIG_H
+#include <config.h>
+#endif
 #include <yaz/log.h>
-#include <yaz++/yaz-z-server.h>
+#include <yazpp/z-server.h>
+
+using namespace yazpp_1;
 
-int Yaz_Facility_Update::init(Yaz_Z_Server *s, Z_InitRequest *initRequest,
-                          Z_InitResponse *initResponse)
+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
+ * c-file-style: "Stroustrup"
+ * indent-tabs-mode: nil
+ * End:
+ * vim: shiftwidth=4 tabstop=8 expandtab
+ */
+