X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_message_api.h;h=9ba60817e9161d1ad2acd0b70f6daaa4b0f331c6;hp=b82f0a7bade7b2a18a9e452c57b43a49acc7a0fa;hb=60d91c35d7c2b4ce86ed67813f2f5a19266a30cc;hpb=0ac32c9b8590e88a5f110cc8b3154001d5c0c089 diff --git a/php_http_message_api.h b/php_http_message_api.h index b82f0a7..9ba6081 100644 --- a/php_http_message_api.h +++ b/php_http_message_api.h @@ -15,23 +15,16 @@ /* $Id$ */ -/* -DUMP: -HttpMessage - ->toResponseString(); - ->toRequestString(); - ->__toString(); ->__sleep(); ->serialize(); - ->fromString(); __wakeup($message); ->unserialize(); - ->setStatusCode(); - ->setHeader(); ->addHeader()... -*/ +#ifndef PHP_HTTP_MESSAGE_API_H +#define PHP_HTTP_MESSAGE_API_H +#include "php_http_info_api.h" #include "phpstr/phpstr.h" typedef enum { - HTTP_MSG_NONE, - HTTP_MSG_REQUEST, - HTTP_MSG_RESPONSE + HTTP_MSG_NONE = 0, + HTTP_MSG_REQUEST = IS_HTTP_REQUEST, + HTTP_MSG_RESPONSE = IS_HTTP_RESPONSE, } http_message_type; typedef struct _http_message http_message; @@ -40,50 +33,68 @@ struct _http_message { phpstr body; HashTable hdrs; http_message_type type; + struct http_info http; + http_message *parent; +}; - union { - struct { - float http_version; - char *method; - char *URI; - } request; +/* required minimum length of an HTTP message "HTTP/1.1" */ +#define HTTP_MSG_MIN_SIZE 8 - struct { - float http_version; - int status; - } response; +/* shorthand for type checks */ +#define HTTP_MSG_TYPE(TYPE, msg) ((msg) && ((msg)->type == HTTP_MSG_ ##TYPE)) - } info; +#define http_message_new() _http_message_init_ex(NULL, 0) +#define http_message_init(m) _http_message_init_ex((m), 0) +#define http_message_init_ex(m, t) _http_message_init_ex((m), (t)) +PHP_HTTP_API http_message *_http_message_init_ex(http_message *m, http_message_type t); + +#define http_message_set_type(m, t) _http_message_set_type((m), (t)) +PHP_HTTP_API void _http_message_set_type(http_message *m, http_message_type t); + +#define http_message_header(m, h) _http_message_header_ex((m), (h), sizeof(h)) +#define http_message_header_ex _http_message_header_ex +static inline zval *_http_message_header_ex(http_message *msg, char *key_str, size_t key_len) +{ + zval **header; + if (SUCCESS == zend_hash_find(&msg->hdrs, key_str, key_len, (void **) &header)) { + return *header; + } + return NULL; +} + +#define http_message_parse(m, l) http_message_parse_ex(NULL, (m), (l)) +#define http_message_parse_ex(h, m, l) _http_message_parse_ex((h), (m), (l) TSRMLS_CC) +PHP_HTTP_API http_message *_http_message_parse_ex(http_message *msg, const char *message, size_t length TSRMLS_DC); - size_t len; - zend_bool dup; +#define http_message_tostring(m, s, l) _http_message_tostring((m), (s), (l)) +PHP_HTTP_API void _http_message_tostring(http_message *msg, char **string, size_t *length); - union { - char *dup; - const char *ptr; - } raw; +#define http_message_serialize(m, s, l) _http_message_serialize((m), (s), (l)) +PHP_HTTP_API void _http_message_serialize(http_message *message, char **string, size_t *length); - http_message *nested; -}; +#define http_message_tostruct_recursive(m, s) _http_message_tostruct_recursive((m), (s) TSRMLS_CC) +PHP_HTTP_API void _http_message_tostruct_recursive(http_message *msg, zval *strct TSRMLS_DC); -/* required minimum length of an HTTP message "HTTP/1.1 200\r\n" */ -#define HTTP_MSG_MIN_SIZE 15 +#define http_message_send(m) _http_message_send((m) TSRMLS_CC) +PHP_HTTP_API STATUS _http_message_send(http_message *message TSRMLS_DC); -#define HTTP_MSG_RAW(msg) ( (msg)->dup ? msg->raw.dup : msg->raw.ptr ) +#define http_message_dup(m) _http_message_dup((m) TSRMLS_CC) +PHP_HTTP_API http_message *_http_message_dup(http_message *msg TSRMLS_DC); -#define http_message_init() _http_message_init_ex(NULL, 0) -#define http_message_init_ex(m, t) _http_message_init_ex((m), (t)) -#define http_message_free(m) _http_message_free((m)) #define http_message_dtor(m) _http_message_dtor((m)) - PHP_HTTP_API void _http_message_dtor(http_message *message); -PHP_HTTP_API void _http_message_free(http_message *message); -#define http_message_parse(m, l) http_message_parse_ex((m), (l), 1) -#define http_message_parse_ex(m, l, d) _http_message_parse_ex((m), (l), (d) TSRMLS_CC) -PHP_HTTP_API http_message *_http_message_parse_ex(const char *message, size_t length, zend_bool duplicate TSRMLS_DC); +#define http_message_free(m) _http_message_free((m)) +PHP_HTTP_API void _http_message_free(http_message **message); -#define http_message_tostring(m, s, l) _http_message_tostring((m), (s), (l)) -PHP_HTTP_API void _http_message_tostring(http_message *msg, char **string, size_t *length); +#endif +/* + * Local variables: + * tab-width: 4 + * c-basic-offset: 4 + * End: + * vim600: noet sw=4 ts=4 fdm=marker + * vim<600: noet sw=4 ts=4 + */