⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ztest.c

📁 harvest是一个下载html网页得机器人
💻 C
📖 第 1 页 / 共 2 页
字号:
/* * Copyright (c) 1995-2003, Index Data. * See the file LICENSE for details. * * $Id: ztest.c,v 1.58 2003/09/02 12:12:13 adam Exp $ *//* * Demonstration of simple server */#include <stdio.h>#include <stdlib.h>#include <ctype.h>#include <yaz/yaz-util.h>#include <yaz/backend.h>#include <yaz/ill.h>Z_GenericRecord *dummy_grs_record (int num, ODR o);char *dummy_marc_record (int num, ODR odr);char *dummy_xml_record (int num, ODR odr);int ztest_search (void *handle, bend_search_rr *rr);int ztest_sort (void *handle, bend_sort_rr *rr);int ztest_present (void *handle, bend_present_rr *rr);int ztest_esrequest (void *handle, bend_esrequest_rr *rr);int ztest_delete (void *handle, bend_delete_rr *rr);int ztest_search (void *handle, bend_search_rr *rr){    if (rr->num_bases != 1)    {        rr->errcode = 23;        return 0;    }    if (yaz_matchstr (rr->basenames[0], "Default"))    {        rr->errcode = 109;        rr->errstring = rr->basenames[0];        return 0;    }    rr->hits = rand() % 24;    return 0;}/* this huge function handles extended services */int ztest_esrequest (void *handle, bend_esrequest_rr *rr){    /* user-defined handle - created in bend_init */    int *counter = (int*) handle;      yaz_log(LOG_LOG, "ESRequest no %d", *counter);    (*counter)++;    if (rr->esr->packageName)    	yaz_log(LOG_LOG, "packagename: %s", rr->esr->packageName);    yaz_log(LOG_LOG, "Waitaction: %d", *rr->esr->waitAction);    yaz_log(LOG_LOG, "function: %d", *rr->esr->function);    if (!rr->esr->taskSpecificParameters)    {        yaz_log (LOG_WARN, "No task specific parameters");    }    else if (rr->esr->taskSpecificParameters->which == Z_External_itemOrder)    {    	Z_ItemOrder *it = rr->esr->taskSpecificParameters->u.itemOrder;	yaz_log (LOG_LOG, "Received ItemOrder");        if (it->which == Z_IOItemOrder_esRequest)	{	    Z_IORequest *ir = it->u.esRequest;	    Z_IOOriginPartToKeep *k = ir->toKeep;	    Z_IOOriginPartNotToKeep *n = ir->notToKeep;	    	    if (k && k->contact)	    {	        if (k->contact->name)		    yaz_log(LOG_LOG, "contact name %s", k->contact->name);		if (k->contact->phone)		    yaz_log(LOG_LOG, "contact phone %s", k->contact->phone);		if (k->contact->email)		    yaz_log(LOG_LOG, "contact email %s", k->contact->email);	    }	    if (k->addlBilling)	    {	        yaz_log(LOG_LOG, "Billing info (not shown)");	    }	    	    if (n->resultSetItem)	    {	        yaz_log(LOG_LOG, "resultsetItem");		yaz_log(LOG_LOG, "setId: %s", n->resultSetItem->resultSetId);		yaz_log(LOG_LOG, "item: %d", *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)		{		    oident *ent = oid_getentbyoid(r->direct_reference);		    if (ent)			yaz_log(LOG_LOG, "OID %s", ent->desc);                    if (ent && ent->value == VAL_TEXT_XML)                    {			yaz_log (LOG_LOG, "ILL XML request");                        if (r->which == Z_External_octet)                            yaz_log (LOG_LOG, "%.*s", r->u.octet_aligned->len,                                     r->u.octet_aligned->buf);                     }		    if (ent && ent->value == VAL_ISO_ILL_1)		    {			yaz_log (LOG_LOG, "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_LOG,                                    "Couldn't decode ItemRequest %s near %d",                                       odr_errmsg(odr_geterror(rr->decode)),                                       odr_offset(rr->decode));                            }			    else			        yaz_log(LOG_LOG, "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_LOG, "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_LOG,                                    "Couldn't decode ILL APDU %s near %d",                                       odr_errmsg(odr_geterror(rr->decode)),                                       odr_offset(rr->decode));                                yaz_log(LOG_LOG, "PDU dump:");                                odr_dumpBER(yaz_log_file(),                                     (char *) r->u.single_ASN1_type->buf,                                     r->u.single_ASN1_type->len);                            }			    else			        yaz_log(LOG_LOG, "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_LOG, "ILL protocol version = %d",			     *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;                targetPart->itemRequest = 0;                targetPart->statusOrErrorReport = 0;                targetPart->auxiliaryStatus = 0;            }	}    }    else if (rr->esr->taskSpecificParameters->which == Z_External_update)    {    	Z_IUUpdate *up = rr->esr->taskSpecificParameters->u.update;	yaz_log (LOG_LOG, "Received DB Update");	if (up->which == Z_IUUpdate_esRequest)	{	    Z_IUUpdateEsRequest *esRequest = up->u.esRequest;	    Z_IUOriginPartToKeep *toKeep = esRequest->toKeep;	    Z_IUSuppliedRecords *notToKeep = esRequest->notToKeep;	    	    yaz_log (LOG_LOG, "action");	    if (toKeep->action)	    {		switch (*toKeep->action)		{		case Z_IUOriginPartToKeep_recordInsert:		    yaz_log (LOG_LOG, " recordInsert");		    break;		case Z_IUOriginPartToKeep_recordReplace:		    yaz_log (LOG_LOG, " recordReplace");		    break;		case Z_IUOriginPartToKeep_recordDelete:		    yaz_log (LOG_LOG, " recordDelete");		    break;		case Z_IUOriginPartToKeep_elementUpdate:		    yaz_log (LOG_LOG, " elementUpdate");		    break;		case Z_IUOriginPartToKeep_specialUpdate:		    yaz_log (LOG_LOG, " specialUpdate");		    break;		default:		    yaz_log (LOG_LOG, " unknown (%d)", *toKeep->action);		}	    }	    if (toKeep->databaseName)	    {		yaz_log (LOG_LOG, "database: %s", toKeep->databaseName);		if (!strcmp(toKeep->databaseName, "fault"))		{		    rr->errcode = 109;		    rr->errstring = toKeep->databaseName;		}		if (!strcmp(toKeep->databaseName, "accept"))		    rr->errcode = -1;	    }	    if (toKeep)	    {		Z_External *ext = (Z_External *)                    odr_malloc (rr->stream, sizeof(*ext));		Z_IUOriginPartToKeep *keep = (Z_IUOriginPartToKeep *)                    odr_malloc (rr->stream, sizeof(*keep));		Z_IUTargetPart *targetPart = (Z_IUTargetPart *)		    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, "123");		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_update;		ext->u.update = (Z_IUUpdate *)		    odr_malloc (rr->stream, sizeof(*ext->u.update));		ext->u.update->which = Z_IUUpdate_taskPackage;		ext->u.update->u.taskPackage =  (Z_IUUpdateTaskPackage *)		    odr_malloc (rr->stream, sizeof(Z_IUUpdateTaskPackage));		ext->u.update->u.taskPackage->originPart = keep;		ext->u.update->u.taskPackage->targetPart = targetPart;		keep->action = (int *) odr_malloc (rr->stream, sizeof(int));		*keep->action = *toKeep->action;		keep->databaseName =		    odr_strdup (rr->stream, toKeep->databaseName);		keep->schema = 0;		keep->elementSetName = 0;		keep->actionQualifier = 0;		targetPart->updateStatus = odr_intdup (rr->stream, 1);		targetPart->num_globalDiagnostics = 0;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -