2005-01-12 07:03:29 +00:00
/*
Unix SMB / CIFS implementation .
2005-09-26 11:47:55 +00:00
composite request interfaces
2005-01-12 07:03:29 +00:00
Copyright ( C ) Andrew Tridgell 2005
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
/*
this defines the structures associated with " composite "
requests . Composite requests are libcli requests that are internally
2005-09-26 11:47:55 +00:00
implemented as multiple async calls , but can be treated as a
2005-01-12 07:03:29 +00:00
single call via these composite calls . The composite calls are
2005-09-26 11:47:55 +00:00
particularly designed to be used in async applications .
you can also stack multiple level of composite call
2005-01-12 07:03:29 +00:00
*/
2005-09-26 11:47:55 +00:00
/*
a composite call moves between the following 3 states .
*/
2005-09-29 22:36:41 +00:00
enum composite_state { COMPOSITE_STATE_INIT , /* we are creating the request */
COMPOSITE_STATE_IN_PROGRESS , /* the request is in the outgoing socket Q */
COMPOSITE_STATE_DONE , /* the request is received by the caller finished */
COMPOSITE_STATE_ERROR } ; /* a packet or transport level error has occurred */
2005-01-12 07:03:29 +00:00
2005-09-26 11:47:55 +00:00
/* the context of one "composite" call */
2005-01-31 08:30:44 +00:00
struct composite_context {
2005-01-12 07:03:29 +00:00
/* the external state - will be queried by the caller */
2005-09-26 11:47:55 +00:00
enum composite_state state ;
2005-01-12 07:03:29 +00:00
2005-01-16 22:22:13 +00:00
/* a private pointer for use by the composite function
implementation */
2005-09-26 11:47:55 +00:00
void * private_data ;
2005-01-12 11:43:18 +00:00
2005-01-12 07:03:29 +00:00
/* status code when finished */
NTSTATUS status ;
2005-01-15 10:29:43 +00:00
/* the event context we are using */
struct event_context * event_ctx ;
2005-01-12 07:03:29 +00:00
/* information on what to do on completion */
struct {
2005-01-31 08:30:44 +00:00
void ( * fn ) ( struct composite_context * ) ;
2005-09-26 11:47:55 +00:00
void * private_data ;
2005-01-12 07:03:29 +00:00
} async ;
2005-12-08 01:13:45 +00:00
BOOL used_wait ;
2005-04-15 14:45:00 +00:00
} ;
2006-03-07 11:07:23 +00:00
2006-03-14 15:03:25 +00:00
struct irpc_request ;
struct smbcli_request ;
2006-03-18 15:42:57 +00:00
struct rpc_request ;
struct nbt_name_request ;
2006-03-14 15:03:25 +00:00
2006-03-07 11:07:23 +00:00
# include "libcli/composite/proto.h"