+ Z_ItemOrder *it = rr->esr->taskSpecificParameters->u.itemOrder;
+ yaz_log(log_level, "Received ItemOrder");
+ if (it->which == Z_IOItemOrder_esRequest)
+ {
+ Z_IORequest *ir = it->u.esRequest;
+ Z_IOOriginPartToKeep *k = ir->toKeep;
+ Z_IOOriginPartNotToKeep *n = ir->notToKeep;
+ const char *xml_in_response = 0;
+
+ if (k && k->contact)
+ {
+ if (k->contact->name)
+ yaz_log(log_level, "contact name %s", k->contact->name);
+ if (k->contact->phone)
+ yaz_log(log_level, "contact phone %s", k->contact->phone);
+ if (k->contact->email)
+ yaz_log(log_level, "contact email %s", k->contact->email);
+ }
+ if (k->addlBilling)
+ {
+ yaz_log(log_level, "Billing info (not shown)");
+ }
+
+ if (n->resultSetItem)
+ {
+ yaz_log(log_level, "resultsetItem");
+ yaz_log(log_level, "setId: %s", n->resultSetItem->resultSetId);
+ yaz_log(log_level, "item: " ODR_INT_PRINTF, *n->resultSetItem->item);
+ }
+ if (n->itemRequest)
+ {
+ Z_External *r = (Z_External*) n->itemRequest;
+ ILL_ItemRequest *item_req = 0;
+ ILL_APDU *ill_apdu = 0;
+ if (r->direct_reference)
+ {
+ char oid_name_str[OID_STR_MAX];
+ oid_class oclass;
+ const char *oid_name =
+ yaz_oid_to_string_buf(r->direct_reference,
+ &oclass, oid_name_str);
+ if (oid_name)
+ yaz_log(log_level, "OID %s", oid_name);
+ if (!oid_oidcmp(r->direct_reference, yaz_oid_recsyn_xml))
+ {
+ yaz_log(log_level, "ILL XML request");
+ if (r->which == Z_External_octet)
+ yaz_log(log_level, "%.*s",
+ r->u.octet_aligned->len,
+ r->u.octet_aligned->buf);
+ xml_in_response = "<dummy>x</dummy>";
+ }
+ if (!oid_oidcmp(r->direct_reference,
+ yaz_oid_general_isoill_1))
+ {
+ yaz_log(log_level, "Decode ItemRequest begin");
+ if (r->which == ODR_EXTERNAL_single)
+ {
+ odr_setbuf(rr->decode,
+ (char *) r->u.single_ASN1_type->buf,
+ r->u.single_ASN1_type->len, 0);
+
+ if (!ill_ItemRequest(rr->decode, &item_req, 0, 0))
+ {
+ yaz_log(log_level,
+ "Couldn't decode ItemRequest %s near %ld",
+ odr_errmsg(odr_geterror(rr->decode)),
+ (long) odr_offset(rr->decode));
+ }
+ else
+ yaz_log(log_level, "Decode ItemRequest OK");
+ if (rr->print)
+ {
+ ill_ItemRequest(rr->print, &item_req, 0,
+ "ItemRequest");
+ odr_reset(rr->print);
+ }
+ }
+ if (!item_req && r->which == ODR_EXTERNAL_single)
+ {
+ yaz_log(log_level, "Decode ILL APDU begin");
+ odr_setbuf(rr->decode,
+ (char*) r->u.single_ASN1_type->buf,
+ r->u.single_ASN1_type->len, 0);
+
+ if (!ill_APDU(rr->decode, &ill_apdu, 0, 0))
+ {
+ yaz_log(log_level,
+ "Couldn't decode ILL APDU %s near %ld",
+ odr_errmsg(odr_geterror(rr->decode)),
+ (long) odr_offset(rr->decode));
+ yaz_log(log_level, "PDU dump:");
+ odr_dumpBER(yaz_log_file(),
+ (char *) r->u.single_ASN1_type->buf,
+ r->u.single_ASN1_type->len);
+ }
+ else
+ yaz_log(log_level, "Decode ILL APDU OK");
+ if (rr->print)
+ {
+ ill_APDU(rr->print, &ill_apdu, 0,
+ "ILL APDU");
+ odr_reset(rr->print);
+ }
+ }
+ }
+ }
+ if (item_req)
+ {
+ yaz_log(log_level, "ILL protocol version = "
+ ODR_INT_PRINTF,
+ *item_req->protocol_version_num);
+ }
+ }
+ if (k)
+ {
+
+ Z_External *ext = (Z_External *)
+ odr_malloc(rr->stream, sizeof(*ext));
+ Z_IUOriginPartToKeep *keep = (Z_IUOriginPartToKeep *)
+ odr_malloc(rr->stream, sizeof(*keep));
+ Z_IOTargetPart *targetPart = (Z_IOTargetPart *)
+ odr_malloc(rr->stream, sizeof(*targetPart));
+
+ rr->taskPackage = (Z_TaskPackage *)
+ odr_malloc(rr->stream, sizeof(*rr->taskPackage));
+ rr->taskPackage->packageType =
+ odr_oiddup(rr->stream, rr->esr->packageType);
+ rr->taskPackage->packageName = 0;
+ rr->taskPackage->userId = 0;
+ rr->taskPackage->retentionTime = 0;
+ rr->taskPackage->permissions = 0;
+ rr->taskPackage->description = 0;
+ rr->taskPackage->targetReference = (Odr_oct *)
+ odr_malloc(rr->stream, sizeof(Odr_oct));
+ rr->taskPackage->targetReference->buf =
+ (unsigned char *) odr_strdup(rr->stream, "911");
+ rr->taskPackage->targetReference->len =
+ rr->taskPackage->targetReference->size =
+ strlen((char *) (rr->taskPackage->targetReference->buf));
+ rr->taskPackage->creationDateTime = 0;
+ rr->taskPackage->taskStatus = odr_intdup(rr->stream, 0);
+ rr->taskPackage->packageDiagnostics = 0;
+ rr->taskPackage->taskSpecificParameters = ext;
+
+ ext->direct_reference =
+ odr_oiddup(rr->stream, rr->esr->packageType);
+ ext->indirect_reference = 0;
+ ext->descriptor = 0;
+ ext->which = Z_External_itemOrder;
+ ext->u.itemOrder = (Z_ItemOrder *)
+ odr_malloc(rr->stream, sizeof(*ext->u.update));
+ ext->u.itemOrder->which = Z_IOItemOrder_taskPackage;
+ ext->u.itemOrder->u.taskPackage = (Z_IOTaskPackage *)
+ odr_malloc(rr->stream, sizeof(Z_IOTaskPackage));
+ ext->u.itemOrder->u.taskPackage->originPart = k;
+ ext->u.itemOrder->u.taskPackage->targetPart = targetPart;
+
+ if (xml_in_response)
+ targetPart->itemRequest =
+ z_ext_record_xml(rr->stream, xml_in_response,
+ strlen(xml_in_response));
+ else
+ targetPart->itemRequest = 0;
+
+ targetPart->statusOrErrorReport = 0;
+ targetPart->auxiliaryStatus = 0;
+ }
+ }