X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_url_api.h;h=70c1aae867093b587305e1524c32b347d3bace5f;hp=a4c5df0b3690997c9f7a00dfcab08c25b56176c4;hb=51669004bbd20bcb4cd9d509799ff65e3998ea47;hpb=669d2e6a8bdc642b6b52693f4593f199ddd7e8d2 diff --git a/php_http_url_api.h b/php_http_url_api.h index a4c5df0..70c1aae 100644 --- a/php_http_url_api.h +++ b/php_http_url_api.h @@ -6,7 +6,7 @@ | modification, are permitted provided that the conditions mentioned | | in the accompanying LICENSE file are met. | +--------------------------------------------------------------------+ - | Copyright (c) 2004-2006, Michael Wallner | + | Copyright (c) 2004-2007, Michael Wallner | +--------------------------------------------------------------------+ */ @@ -19,19 +19,28 @@ extern PHP_MINIT_FUNCTION(http_url); -#define http_absolute_url(u) _http_absolute_url((u) TSRMLS_CC) -PHP_HTTP_API char *_http_absolute_url(const char *url TSRMLS_DC); +#define http_absolute_url(u) _http_absolute_url_ex((u), HTTP_URL_REPLACE TSRMLS_CC) +#define http_absolute_url_ex(u, f) _http_absolute_url_ex((u), (f) TSRMLS_CC) +PHP_HTTP_API char *_http_absolute_url_ex(const char *url, int flags TSRMLS_DC); #define HTTP_URL_REPLACE 0x000 #define HTTP_URL_JOIN_PATH 0x001 #define HTTP_URL_JOIN_QUERY 0x002 #define HTTP_URL_STRIP_USER 0x004 #define HTTP_URL_STRIP_PASS 0x008 -#define HTTP_URL_STRIP_AUTH 0x010 +#define HTTP_URL_STRIP_AUTH (HTTP_URL_STRIP_USER|HTTP_URL_STRIP_PASS) #define HTTP_URL_STRIP_PORT 0x020 #define HTTP_URL_STRIP_PATH 0x040 #define HTTP_URL_STRIP_QUERY 0x080 #define HTTP_URL_STRIP_FRAGMENT 0x100 +#define HTTP_URL_STRIP_ALL ( \ + HTTP_URL_STRIP_AUTH | \ + HTTP_URL_STRIP_PORT | \ + HTTP_URL_STRIP_PATH | \ + HTTP_URL_STRIP_QUERY | \ + HTTP_URL_STRIP_FRAGMENT \ +) +#define HTTP_URL_FROM_ENV 0x1000 #define http_build_url(f, o, n, p, s, l) _http_build_url((f), (o), (n), (p), (s), (l) TSRMLS_CC) PHP_HTTP_API void _http_build_url(int flags, const php_url *old_url, const php_url *new_url, php_url **url_ptr, char **url_str, size_t *url_len TSRMLS_DC); @@ -43,11 +52,14 @@ PHP_HTTP_API STATUS _http_urlencode_hash_ex(HashTable *hash, zend_bool override_ #define http_urlencode_hash_recursive(ht, s, as, al, pr, pl) _http_urlencode_hash_recursive((ht), (s), (as), (al), (pr), (pl) TSRMLS_CC) PHP_HTTP_API STATUS _http_urlencode_hash_recursive(HashTable *ht, phpstr *str, const char *arg_sep, size_t arg_sep_len, const char *prefix, size_t prefix_len TSRMLS_DC); -#define array2url(ht) _array2url((ht) TSRMLS_CC) -static inline php_url *_array2url(HashTable *ht TSRMLS_DC) +#define http_url_from_struct(u, ht) _http_url_from_struct((u), (ht) TSRMLS_CC) +static inline php_url *_http_url_from_struct(php_url *url, HashTable *ht TSRMLS_DC) { zval **e; - php_url *url = ecalloc(1, sizeof(php_url)); + + if (!url) { + url = ecalloc(1, sizeof(php_url)); + } if ((SUCCESS == zend_hash_find(ht, "scheme", sizeof("scheme"), (void *) &e)) && (Z_TYPE_PP(e) == IS_STRING) && Z_STRLEN_PP(e)) { @@ -92,6 +104,55 @@ static inline php_url *_array2url(HashTable *ht TSRMLS_DC) return url; } +#define http_url_tostruct(u, strct) _http_url_tostruct((u), (strct) TSRMLS_CC) +static inline HashTable *_http_url_tostruct(php_url *url, zval *strct TSRMLS_DC) +{ + zval arr; + + if (strct) { + switch (Z_TYPE_P(strct)) { + default: + zval_dtor(strct); + array_init(strct); + case IS_ARRAY: + case IS_OBJECT: + INIT_ZARR(arr, HASH_OF(strct)); + } + } else { + INIT_PZVAL(&arr); + array_init(&arr); + } + + if (url) { + if (url->scheme) { + add_assoc_string(&arr, "scheme", url->scheme, 1); + } + if (url->user) { + add_assoc_string(&arr, "user", url->user, 1); + } + if (url->pass) { + add_assoc_string(&arr, "pass", url->pass, 1); + } + if (url->host) { + add_assoc_string(&arr, "host", url->host, 1); + } + if (url->port) { + add_assoc_long(&arr, "port", (long) url->port); + } + if (url->path) { + add_assoc_string(&arr, "path", url->path, 1); + } + if (url->query) { + add_assoc_string(&arr, "query", url->query, 1); + } + if (url->fragment) { + add_assoc_string(&arr, "fragment", url->fragment, 1); + } + } + + return Z_ARRVAL(arr); +} + #endif /*