http_client
—
threaded client for HTTP and HTTPS
PDEL Library (libpdel, -lpdel)
#include
<sys/types.h>
#include <stdio.h>
#include <netinet/in.h>
#include <openssl/ssl.h>
#include
<pdel/http/http_defs.h>
#include
<pdel/http/http_server.h>
struct http_client *
http_client_create
(struct
pevent_ctx *ctx, const
char *user_agent, u_int
max_conn, u_int
max_cache, u_int
max_cache_idle,
http_logger_t
*logger);
int
http_client_destroy
(struct
http_client **clientp);
struct http_client_connection *
http_client_connect
(struct
http_client *client,
struct in_addr ip,
u_int16_t port,
int https);
struct in_addr
http_client_get_local_ip
(struct
http_client_connection *cc);
u_int16_t
http_client_get_local_port
(struct
http_client_connection *cc);
struct http_request *
http_client_get_request
(struct
http_client_connection *client);
struct http_response *
http_client_get_response
(struct
http_client_connection *client);
void
http_client_close
(struct
http_client_connection **cconp);
const char *
http_client_get_reason
(struct
http_client_connection *ccon);
These functions implement threaded HTTP clients, supporting SSL
and HTTP keep-alive.
An HTTP client (represented by a struct
http_client
) can be used to make multiple simultaneous individual
HTTP connections (each corresponding to a single HTTP request/reply pair and
represented by a struct http_client_connection
). To
reduce overhead, a client will cache TCP connections to each remote server
and reuse TCP connections for subsequent requests, using the HTTP keep-alive
mechanism.
http_client_create
()
creates a new HTTP client. ctx is a
pevent(3)
event context. The user_agent string is used for the
"User-Agent:" HTTP header. max_conn limits
the number of active connections that may exist simultaneously.
max_cache is the maximum number of server TCP sessions
that the client may cache (or zero to disable caching), and
max_cache_idle is the maximum idle time for cached TCP
sessions, after which they are closed. max_cache must
be strictly less than max_conn. The
logger, if not NULL,
specifies
a callback for logging:
typedef void http_logger_t(int sev, const char *fmt, ...);
Here sev is a
syslog(3)
severity level.
http_client_destroy
()
attempts to destroy an HTTP client. If there are still active connections
(i.e., connections for which http_client_close
() has
yet to be called), then http_client_destroy
() will
fail and return -1 with errno set to
EBUSY.
Otherwise, upon return
*clientp is set to NULL.
If
*clientp is already NULL
when
http_client_destroy
() is invoked, nothing
happens.
http_client_connect
()
creates a new HTTP connection associated with client.
If there are already max_conn active connections, then
http_client_connect
() will block until a connection
becomes free. The new connection is initiated to the HTTP (or HTTPS if
https is non-zero) server at IP address
ip and port port.
http_client_get_local_ip
()
and
http_client_get_local_port
()
return the local IP address and port used for the connection,
respectively.
http_client_get_request
()
and http_client_get_response
() return the HTTP
request and response objects associated with the connection (see
http_request(3)
and
http_response(3)).
http_client_close
()
closes and frees a connection. If caching is enabled and the remote server
supports keep-alive, the connection will cached for up to
max_cache_idle seconds. Upon return,
*cconp is set to NULL.
If
*cconp is already NULL
when
http_client_close
() is invoked, nothing happens.
If
http_client_get_response
()
returns NULL
(for example, the server sent back a
malformed response), then
http_client_get_reason
()
may be used to retrieve an explanatory error string. The string is only
valid until http_client_close
() is invoked.
Upon error, http_client_create
(),
http_client_connect
(), and
http_client_get_response
() return
NULL
and set errno to an
appropriate value.
http_mime(3),
http_request(3),
http_response(3),
http_server(3),
http_xml(3),
libpdel(3),
pevent(3),
syslog(3)
R. Fielding,
J. Gettys, J. Mogul,
H. Frystyk, L. Masinter,
P. Leach, and T.
Berners-Lee, Hypertext Transfer Protocol --
HTTP/1.1, RFC 2616.
The PDEL library was developed at Packet Design, LLC.
http://www.packetdesign.com/
Archie Cobbs
⟨archie@freebsd.org⟩
Support for validating a server's SSL certificates against a list
of known, trusted certificate authorities should be added.