X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=server%2Fsession.h;h=aefe3da441da0a9f3ecfd38f5a6cab2926895018;hb=62e356bd92b3ab4c97d82dfdce290ca84f0759ca;hp=abb3c6055a91999a5851ec264002ffaaf1a93e84;hpb=99268f722648e84bf5c54eb685a1434e100f38a1;p=yaz-moved-to-github.git diff --git a/server/session.h b/server/session.h index abb3c60..aefe3da 100644 --- a/server/session.h +++ b/server/session.h @@ -4,7 +4,24 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: session.h,v $ - * Revision 1.7 1995-05-16 08:51:08 quinn + * 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 * License, documentation, and memory fixes * * Revision 1.6 1995/05/15 11:56:41 quinn @@ -36,7 +53,8 @@ #include #include #include -#include +#include +#include "eventl.h" typedef struct request { @@ -49,19 +67,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; @@ -84,10 +104,17 @@ typedef struct association void *backend; /* backend handle */ request_q incoming; /* Q of incoming PDUs */ request_q outgoing; /* Q of outgoing data buffers (enc. PDUs) */ + 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) */ } association; association *create_association(IOCHAN channel, COMSTACK link); @@ -98,7 +125,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