1*663afb9bSAndroid Build Coastguard Worker /* 2*663afb9bSAndroid Build Coastguard Worker * Copyright (c) 2006-2007 Niels Provos <[email protected]> 3*663afb9bSAndroid Build Coastguard Worker * Copyright (c) 2007-2012 Niels Provos and Nick Mathewson 4*663afb9bSAndroid Build Coastguard Worker * 5*663afb9bSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without 6*663afb9bSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions 7*663afb9bSAndroid Build Coastguard Worker * are met: 8*663afb9bSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright 9*663afb9bSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer. 10*663afb9bSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright 11*663afb9bSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the 12*663afb9bSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution. 13*663afb9bSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products 14*663afb9bSAndroid Build Coastguard Worker * derived from this software without specific prior written permission. 15*663afb9bSAndroid Build Coastguard Worker * 16*663afb9bSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 17*663afb9bSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18*663afb9bSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19*663afb9bSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, 20*663afb9bSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 21*663afb9bSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 22*663afb9bSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 23*663afb9bSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 24*663afb9bSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 25*663afb9bSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26*663afb9bSAndroid Build Coastguard Worker */ 27*663afb9bSAndroid Build Coastguard Worker #ifndef EVENT2_RPC_STRUCT_H_INCLUDED_ 28*663afb9bSAndroid Build Coastguard Worker #define EVENT2_RPC_STRUCT_H_INCLUDED_ 29*663afb9bSAndroid Build Coastguard Worker 30*663afb9bSAndroid Build Coastguard Worker #ifdef __cplusplus 31*663afb9bSAndroid Build Coastguard Worker extern "C" { 32*663afb9bSAndroid Build Coastguard Worker #endif 33*663afb9bSAndroid Build Coastguard Worker 34*663afb9bSAndroid Build Coastguard Worker /** @file event2/rpc_struct.h 35*663afb9bSAndroid Build Coastguard Worker 36*663afb9bSAndroid Build Coastguard Worker Structures used by rpc.h. Using these structures directly may harm 37*663afb9bSAndroid Build Coastguard Worker forward compatibility: be careful! 38*663afb9bSAndroid Build Coastguard Worker 39*663afb9bSAndroid Build Coastguard Worker */ 40*663afb9bSAndroid Build Coastguard Worker 41*663afb9bSAndroid Build Coastguard Worker /* Fix so that people don't have to run with <sys/queue.h> */ 42*663afb9bSAndroid Build Coastguard Worker #ifndef TAILQ_ENTRY 43*663afb9bSAndroid Build Coastguard Worker #define EVENT_DEFINED_TQENTRY_ 44*663afb9bSAndroid Build Coastguard Worker #define TAILQ_ENTRY(type) \ 45*663afb9bSAndroid Build Coastguard Worker struct { \ 46*663afb9bSAndroid Build Coastguard Worker struct type *tqe_next; /* next element */ \ 47*663afb9bSAndroid Build Coastguard Worker struct type **tqe_prev; /* address of previous next element */ \ 48*663afb9bSAndroid Build Coastguard Worker } 49*663afb9bSAndroid Build Coastguard Worker #endif /* !TAILQ_ENTRY */ 50*663afb9bSAndroid Build Coastguard Worker 51*663afb9bSAndroid Build Coastguard Worker /** 52*663afb9bSAndroid Build Coastguard Worker * provides information about the completed RPC request. 53*663afb9bSAndroid Build Coastguard Worker */ 54*663afb9bSAndroid Build Coastguard Worker struct evrpc_status { 55*663afb9bSAndroid Build Coastguard Worker #define EVRPC_STATUS_ERR_NONE 0 56*663afb9bSAndroid Build Coastguard Worker #define EVRPC_STATUS_ERR_TIMEOUT 1 57*663afb9bSAndroid Build Coastguard Worker #define EVRPC_STATUS_ERR_BADPAYLOAD 2 58*663afb9bSAndroid Build Coastguard Worker #define EVRPC_STATUS_ERR_UNSTARTED 3 59*663afb9bSAndroid Build Coastguard Worker #define EVRPC_STATUS_ERR_HOOKABORTED 4 60*663afb9bSAndroid Build Coastguard Worker int error; 61*663afb9bSAndroid Build Coastguard Worker 62*663afb9bSAndroid Build Coastguard Worker /* for looking at headers or other information */ 63*663afb9bSAndroid Build Coastguard Worker struct evhttp_request *http_req; 64*663afb9bSAndroid Build Coastguard Worker }; 65*663afb9bSAndroid Build Coastguard Worker 66*663afb9bSAndroid Build Coastguard Worker /* the structure below needs to be synchronized with evrpc_req_generic */ 67*663afb9bSAndroid Build Coastguard Worker 68*663afb9bSAndroid Build Coastguard Worker /* Encapsulates a request */ 69*663afb9bSAndroid Build Coastguard Worker struct evrpc { 70*663afb9bSAndroid Build Coastguard Worker TAILQ_ENTRY(evrpc) next; 71*663afb9bSAndroid Build Coastguard Worker 72*663afb9bSAndroid Build Coastguard Worker /* the URI at which the request handler lives */ 73*663afb9bSAndroid Build Coastguard Worker const char* uri; 74*663afb9bSAndroid Build Coastguard Worker 75*663afb9bSAndroid Build Coastguard Worker /* creates a new request structure */ 76*663afb9bSAndroid Build Coastguard Worker void *(*request_new)(void *); 77*663afb9bSAndroid Build Coastguard Worker void *request_new_arg; 78*663afb9bSAndroid Build Coastguard Worker 79*663afb9bSAndroid Build Coastguard Worker /* frees the request structure */ 80*663afb9bSAndroid Build Coastguard Worker void (*request_free)(void *); 81*663afb9bSAndroid Build Coastguard Worker 82*663afb9bSAndroid Build Coastguard Worker /* unmarshals the buffer into the proper request structure */ 83*663afb9bSAndroid Build Coastguard Worker int (*request_unmarshal)(void *, struct evbuffer *); 84*663afb9bSAndroid Build Coastguard Worker 85*663afb9bSAndroid Build Coastguard Worker /* creates a new reply structure */ 86*663afb9bSAndroid Build Coastguard Worker void *(*reply_new)(void *); 87*663afb9bSAndroid Build Coastguard Worker void *reply_new_arg; 88*663afb9bSAndroid Build Coastguard Worker 89*663afb9bSAndroid Build Coastguard Worker /* frees the reply structure */ 90*663afb9bSAndroid Build Coastguard Worker void (*reply_free)(void *); 91*663afb9bSAndroid Build Coastguard Worker 92*663afb9bSAndroid Build Coastguard Worker /* verifies that the reply is valid */ 93*663afb9bSAndroid Build Coastguard Worker int (*reply_complete)(void *); 94*663afb9bSAndroid Build Coastguard Worker 95*663afb9bSAndroid Build Coastguard Worker /* marshals the reply into a buffer */ 96*663afb9bSAndroid Build Coastguard Worker void (*reply_marshal)(struct evbuffer*, void *); 97*663afb9bSAndroid Build Coastguard Worker 98*663afb9bSAndroid Build Coastguard Worker /* the callback invoked for each received rpc */ 99*663afb9bSAndroid Build Coastguard Worker void (*cb)(struct evrpc_req_generic *, void *); 100*663afb9bSAndroid Build Coastguard Worker void *cb_arg; 101*663afb9bSAndroid Build Coastguard Worker 102*663afb9bSAndroid Build Coastguard Worker /* reference for further configuration */ 103*663afb9bSAndroid Build Coastguard Worker struct evrpc_base *base; 104*663afb9bSAndroid Build Coastguard Worker }; 105*663afb9bSAndroid Build Coastguard Worker 106*663afb9bSAndroid Build Coastguard Worker #ifdef EVENT_DEFINED_TQENTRY_ 107*663afb9bSAndroid Build Coastguard Worker #undef TAILQ_ENTRY 108*663afb9bSAndroid Build Coastguard Worker #endif 109*663afb9bSAndroid Build Coastguard Worker 110*663afb9bSAndroid Build Coastguard Worker #ifdef __cplusplus 111*663afb9bSAndroid Build Coastguard Worker } 112*663afb9bSAndroid Build Coastguard Worker #endif 113*663afb9bSAndroid Build Coastguard Worker 114*663afb9bSAndroid Build Coastguard Worker #endif /* EVENT2_RPC_STRUCT_H_INCLUDED_ */ 115