X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Fhttp.h;h=1067e85080adc80490c7b3d3cb1ef37b9d85fd0a;hb=64dccf5757a22cedd3c21ca834e3e02f39dd0504;hp=dcaa3a8961e95546ce98363f18088409ce73f8f0;hpb=7d0d04af0ae9a019adf0ee16248b5e9c8ea21922;p=pazpar2-moved-to-github.git diff --git a/src/http.h b/src/http.h index dcaa3a8..1067e85 100644 --- a/src/http.h +++ b/src/http.h @@ -1,5 +1,5 @@ /* This file is part of Pazpar2. - Copyright (C) 2006-2009 Index Data + Copyright (C) Index Data Pazpar2 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 @@ -20,18 +20,17 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #ifndef HTTP_H #define HTTP_H -// Generic I/O buffer -struct http_buf -{ -#define HTTP_BUF_SIZE 4096 - char buf[4096]; - int offset; - int len; - struct http_buf *next; -}; +#include +#include +#include "eventl.h" +// Generic I/O buffer +struct http_buf; typedef struct http_channel_observer_s *http_channel_observer_t; +typedef struct http_server *http_server_t; +typedef struct http_sessions *http_sessions_t; + struct http_channel { IOCHAN iochan; @@ -47,12 +46,15 @@ struct http_channel int keep_alive; NMEM nmem; WRBUF wrbuf; + yaz_timing_t yt; struct http_request *request; struct http_response *response; struct http_channel *next; // for freelist - char addr[20]; // forwarded address + char addr[256]; // forwarded address http_channel_observer_t observers; struct conf_server *server; + http_server_t http_server; + http_sessions_t http_sessions; }; struct http_proxy // attached to iochan for proxy connection @@ -100,17 +102,22 @@ struct http_response char *content_type; }; +void http_mutex_init(struct conf_server *server); +void http_server_destroy(http_server_t hs); + void http_set_proxyaddr(const char *url, struct conf_server *ser); -int http_init(const char *addr, struct conf_server *ser); +int http_init(struct conf_server *ser, const char *record_fname); void http_close_server(struct conf_server *ser); -void http_addheader(struct http_response *r, +void http_addheader(struct http_response *r, const char *name, const char *value); -struct http_header * http_header_append(struct http_channel *ch, - struct http_header * hp, - const char *name, +const char *http_lookup_header(struct http_header *header, + const char *name); +struct http_header * http_header_append(struct http_channel *ch, + struct http_header * hp, + const char *name, const char *value); -char *http_argbyname(struct http_request *r, char *name); -char *http_headerbyname(struct http_header *r, char *name); +const char *http_argbyname(struct http_request *r, const char *name); +const char *http_headerbyname(struct http_header *r, const char *name); struct http_response *http_create_response(struct http_channel *c); void http_send_response(struct http_channel *c); void urlencode(const char *i, char *o); @@ -124,6 +131,12 @@ void http_observer_set_data2(http_channel_observer_t obs, void *data2); void http_remove_observer(http_channel_observer_t obs); struct http_channel *http_channel_observer_chan(http_channel_observer_t obs); + +void http_command(struct http_channel *c); + +http_sessions_t http_sessions_create(void); +void http_sessions_destroy(http_sessions_t hs); + #endif /*