diff options
author | Thies C. Arntzen <thies@php.net> | 2002-05-03 08:00:41 +0000 |
---|---|---|
committer | Thies C. Arntzen <thies@php.net> | 2002-05-03 08:00:41 +0000 |
commit | 9712a4b3c87f47146783a48f567c89253a720922 (patch) | |
tree | cb887ec83072c15250b68f8b4507eb908352a3bc /ext/standard/url_scanner_ex.re | |
parent | 9679267b88c7eb99277282222721b490c65a7f2f (diff) | |
download | php-git-9712a4b3c87f47146783a48f567c89253a720922.tar.gz |
@ - Added output_add_rewrite_var() and output_remove_rewrite_var() to inject
@ and remove variables from the URL-Rewriter. (thies)
i have also modified the session module to use this - so it doesn't
need to fiddle with the output-system any more
Diffstat (limited to 'ext/standard/url_scanner_ex.re')
-rw-r--r-- | ext/standard/url_scanner_ex.re | 152 |
1 files changed, 113 insertions, 39 deletions
diff --git a/ext/standard/url_scanner_ex.re b/ext/standard/url_scanner_ex.re index 4d7c507894..ffbca6f261 100644 --- a/ext/standard/url_scanner_ex.re +++ b/ext/standard/url_scanner_ex.re @@ -32,7 +32,6 @@ #include "basic_functions.h" #undef STATE_TAG -#define url_adapt_ext url_adapt_ext_ex #define url_scanner url_scanner_ex #include "php_smart_str.h" @@ -96,11 +95,15 @@ alpha = [a-zA-Z]; #define YYLIMIT q #define YYMARKER r -static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *name, smart_str *val, const char *separator) +static inline void append_modified_url(smart_str *url, smart_str *dest, HashTable *rewrite_vars, const char *separator) { register const char *p, *q; const char *bash = NULL; const char *sep = "?"; + char *string_key; + url_adapt_var_t *value; + int num_key; + q = (p = url->c) + url->len; @@ -124,10 +127,16 @@ done: else smart_str_append(dest, url); - smart_str_appends(dest, sep); - smart_str_append(dest, name); - smart_str_appendc(dest, '='); - smart_str_append(dest, val); + zend_hash_internal_pointer_reset(rewrite_vars); + while (zend_hash_get_current_key(rewrite_vars, &string_key, &num_key, 0) != HASH_KEY_NON_EXISTANT) { + zend_hash_get_current_data(rewrite_vars, &value); + smart_str_appends(dest, sep); + smart_str_append(dest, &(value->var)); + smart_str_appendc(dest, '='); + smart_str_append(dest, &(value->val)); + zend_hash_move_forward(rewrite_vars); + sep = separator; /* switch from ? to now! */ + } if (bash) smart_str_appendl(dest, bash, q - bash); @@ -150,7 +159,7 @@ static inline void tag_arg(url_adapt_state_ex_t *ctx, char quotes, char type TSR if (quotes) smart_str_appendc(&ctx->result, type); if (f) { - append_modified_url(&ctx->val, &ctx->result, &ctx->q_name, &ctx->q_value, PG(arg_separator).output); + append_modified_url(&ctx->val, &ctx->result, ctx->rewrite_vars, PG(arg_separator).output); } else { smart_str_append(&ctx->result, &ctx->val); } @@ -185,11 +194,20 @@ static inline void passthru(STD_PARA) static inline void handle_form(STD_PARA) { if (ctx->tag.len == 4 && strncasecmp(ctx->tag.c, "form", 4) == 0) { - smart_str_appends(&ctx->result, "<input type=\"hidden\" name=\""); - smart_str_append(&ctx->result, &ctx->q_name); - smart_str_appends(&ctx->result, "\" value=\""); - smart_str_append(&ctx->result, &ctx->q_value); - smart_str_appends(&ctx->result, "\" />"); + char *string_key; + url_adapt_var_t *value; + int num_key; + + zend_hash_internal_pointer_reset(ctx->rewrite_vars); + while (zend_hash_get_current_key(ctx->rewrite_vars, &string_key, &num_key, 0) != HASH_KEY_NON_EXISTANT) { + zend_hash_get_current_data(ctx->rewrite_vars, &value); + smart_str_appends(&ctx->result, "<input type=\"hidden\" name=\""); + smart_str_append(&ctx->result, &(value->var)); + smart_str_appends(&ctx->result, "\" value=\""); + smart_str_append(&ctx->result, &(value->val)); + smart_str_appends(&ctx->result, "\" />"); + zend_hash_move_forward(ctx->rewrite_vars); + } } } @@ -318,34 +336,13 @@ stop: } -char *url_adapt_single_url(const char *url, size_t urllen, const char *name, const char *value, size_t *newlen TSRMLS_DC) -{ - smart_str surl = {0}; - smart_str buf = {0}; - smart_str sname = {0}; - smart_str sval = {0}; - - smart_str_setl(&surl, url, urllen); - smart_str_sets(&sname, name); - smart_str_sets(&sval, value); - - append_modified_url(&surl, &buf, &sname, &sval, PG(arg_separator).output); - - smart_str_0(&buf); - if (newlen) *newlen = buf.len; - - return buf.c; -} - -char *url_adapt_ext(const char *src, size_t srclen, const char *name, const char *value, size_t *newlen, zend_bool do_flush TSRMLS_DC) +static char *url_adapt_ext(const char *src, size_t srclen, size_t *newlen, zend_bool do_flush TSRMLS_DC) { url_adapt_state_ex_t *ctx; char *retval; ctx = &BG(url_adapt_state_ex); - smart_str_sets(&ctx->q_name, name); - smart_str_sets(&ctx->q_value, value); xx_mainloop(ctx, src, srclen TSRMLS_CC); *newlen = ctx->result.len; @@ -389,14 +386,66 @@ int php_url_scanner_ex_deactivate(TSRMLS_D) return SUCCESS; } +static void php_url_scanner_output_handler(char *output, uint output_len, char **handled_output, uint *handled_output_len, int mode TSRMLS_DC) +{ + if (BG(url_adapt_state_ex).rewrite_vars && zend_hash_num_elements(BG(url_adapt_state_ex).rewrite_vars)) { + *handled_output = url_adapt_ext(output, output_len, handled_output_len, (zend_bool) (mode&PHP_OUTPUT_HANDLER_END ? 1 : 0) TSRMLS_CC); + } else { + *handled_output = NULL; + } +} + +static void php_url_scanner_var_dtor(url_adapt_var_t *var) +{ + smart_str_free(&(var->var)); + smart_str_free(&(var->val)); +} + +int php_url_scanner_add_var(char *name, int name_len, char *value, int value_len, int urlencode TSRMLS_DC) +{ + url_adapt_var_t var; + char *encoded; + int encoded_len; + + if (! BG(url_adapt_state_ex).active) { + int chunk_size = 4096; /* XXX where should we get chunk_size from? */ + + php_url_scanner_ex_activate(TSRMLS_C); + php_start_ob_buffer(NULL, chunk_size, 1 TSRMLS_CC); + php_ob_set_internal_handler(php_url_scanner_output_handler, chunk_size, "URL-Rewriter", 1 TSRMLS_CC); + BG(url_adapt_state_ex).active = 1; + } + + if (! BG(url_adapt_state_ex).rewrite_vars) { + BG(url_adapt_state_ex).rewrite_vars = emalloc(sizeof(HashTable)); + zend_hash_init(BG(url_adapt_state_ex).rewrite_vars, 0, NULL, (void (*)(void *)) php_url_scanner_var_dtor, 0); + } + + smart_str_setl(&(var.var), estrndup(name, name_len), name_len); + + if (urlencode) { + encoded = php_url_encode(value, value_len, &encoded_len); + smart_str_setl(&(var.val), encoded, encoded_len); + } else { + smart_str_setl(&(var.val), estrndup(value, value_len), value_len); + } + + return zend_hash_add(BG(url_adapt_state_ex).rewrite_vars, name, name_len, &var, sizeof(url_adapt_var_t), NULL); +} + +int php_url_scanner_remove_var(char *name, int name_len TSRMLS_DC) +{ + if (BG(url_adapt_state_ex).rewrite_vars) { + return zend_hash_del(BG(url_adapt_state_ex).rewrite_vars, name, name_len); + } + + return FAILURE; +} + PHP_MINIT_FUNCTION(url_scanner) { - url_adapt_state_ex_t *ctx; - - ctx = &BG(url_adapt_state_ex); + BG(url_adapt_state_ex).tags = NULL; - ctx->tags = NULL; - REGISTER_INI_ENTRIES(); return SUCCESS; } @@ -406,5 +455,30 @@ PHP_MSHUTDOWN_FUNCTION(url_scanner) UNREGISTER_INI_ENTRIES(); zend_hash_destroy(BG(url_adapt_state_ex).tags); free(BG(url_adapt_state_ex).tags); + + return SUCCESS; +} + +PHP_RINIT_FUNCTION(url_scanner) +{ + BG(url_adapt_state_ex).active = 0; + BG(url_adapt_state_ex).rewrite_vars = NULL; + + return SUCCESS; +} + +PHP_RSHUTDOWN_FUNCTION(url_scanner) +{ + if (BG(url_adapt_state_ex).active) { + php_url_scanner_ex_deactivate(TSRMLS_C); + BG(url_adapt_state_ex).active = 0; + } + + if (BG(url_adapt_state_ex).rewrite_vars) { + zend_hash_destroy(BG(url_adapt_state_ex).rewrite_vars); + efree(BG(url_adapt_state_ex).rewrite_vars); + BG(url_adapt_state_ex).rewrite_vars = NULL; + } + return SUCCESS; } |