X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=server%2Fsession.h;h=084da36fb9226a2a7e4f4c1acaf41d812f22b2ac;hb=7574c044d6c2dc8ede5c7c406f9939215a220260;hp=5e44a74611d78cc3be219c72bedb8303c6efd360;hpb=dd509bd7c24e5c9f93f0c0072bfb91227142705b;p=yaz-moved-to-github.git diff --git a/server/session.h b/server/session.h index 5e44a74..084da36 100644 --- a/server/session.h +++ b/server/session.h @@ -1,10 +1,27 @@ /* - * Copyright (C) 1995, Index Data I/S + * Copyright (C) 1995-1998, Index Data I/S * See the file LICENSE for details. * Sebastian Hammer, Adam Dickmeiss * * $Log: session.h,v $ - * Revision 1.8 1995-05-17 08:42:28 quinn + * Revision 1.13 1998-01-29 13:30:23 adam + * Better event handle system for NT/Unix. + * + * Revision 1.12 1997/09/01 08:53:01 adam + * New windows NT/95 port using MSV5.0. The test server 'ztest' was + * moved a separate directory. MSV5.0 project server.dsp created. + * As an option, the server can now operate as an NT service. + * + * Revision 1.11 1995/11/08 17:41:40 quinn + * Smallish. + * + * Revision 1.10 1995/08/29 11:18:01 quinn + * Added code to receive close + * + * Revision 1.9 1995/06/16 10:31:38 quinn + * Added session timeout. + * + * Revision 1.8 1995/05/17 08:42:28 quinn * Transfer auth info to backend. Allow backend to reject init gracefully. * * Revision 1.7 1995/05/16 08:51:08 quinn @@ -39,7 +56,8 @@ #include #include #include -#include +#include +#include "eventl.h" typedef struct request { @@ -52,19 +70,21 @@ typedef struct request } state; Z_APDU *request; /* Current request */ - ODR_MEM request_mem; /* ODR memory handle for request */ + NMEM request_mem; /* memory handle for request */ int size_response; /* size of buffer */ int len_response; /* length of encoded data */ char *response; /* encoded data waiting for transmission */ struct request *next; + struct request_q *q; } request; typedef struct request_q { request *head; request *tail; + request *list; int num; } request_q; @@ -87,11 +107,19 @@ typedef struct association void *backend; /* backend handle */ request_q incoming; /* Q of incoming PDUs */ request_q outgoing; /* Q of outgoing data buffers (enc. PDUs) */ - int rejected; /* session rejected */ + enum + { + ASSOC_NEW, /* not initialized yet */ + ASSOC_UP, /* normal operation */ + ASSOC_DEAD /* dead. Close if input arrives */ + } state; /* session parameters */ int preferredMessageSize; int maximumRecordSize; + int version; /* highest version-bit set (2 or 3) */ + + int (*bend_sort) (); } association; association *create_association(IOCHAN channel, COMSTACK link); @@ -102,7 +130,8 @@ void request_enq(request_q *q, request *r); request *request_head(request_q *q); request *request_deq(request_q *q); void request_initq(request_q *q); -request *request_get(void); +void request_delq(request_q *q); +request *request_get(request_q *q); void request_release(request *r); #endif