]> granicus.if.org Git - php/commitdiff
Allow filters to work on INPUT_SERVER in CLI (bug #44779)
authorArnaud Le Blanc <lbarnaud@php.net>
Thu, 24 Jul 2008 09:11:48 +0000 (09:11 +0000)
committerArnaud Le Blanc <lbarnaud@php.net>
Thu, 24 Jul 2008 09:11:48 +0000 (09:11 +0000)
ext/filter/tests/bug44779.phpt [new file with mode: 0644]
sapi/cli/php_cli.c

diff --git a/ext/filter/tests/bug44779.phpt b/ext/filter/tests/bug44779.phpt
new file mode 100644 (file)
index 0000000..33a4fe4
--- /dev/null
@@ -0,0 +1,8 @@
+--TEST--
+Bug #44779 (filter returns NULL in CLI when it shouldn't)
+--FILE--
+<?php
+var_dump(filter_input(INPUT_SERVER, "PHP_SELF"));
+?>
+--EXPECTF--
+%unicode|string%(%d) "%s"
index 969d7adcc7bcfddb5c61533a0fe7435eb9373c06..d24b81afd3c831b156aa173e7a2ed48fdd249a1e 100644 (file)
@@ -296,19 +296,35 @@ static char *script_filename = "";
 
 static void sapi_cli_register_variables(zval *track_vars_array TSRMLS_DC) /* {{{ */
 {
+       size_t len;
+       char   *docroot = "";
+
        /* In CGI mode, we consider the environment to be a part of the server
         * variables
         */
        php_import_environment_variables(track_vars_array TSRMLS_CC);
 
        /* Build the special-case PHP_SELF variable for the CLI version */
-       php_register_variable("PHP_SELF", php_self, track_vars_array TSRMLS_CC);
-       php_register_variable("SCRIPT_NAME", php_self, track_vars_array TSRMLS_CC);
+       len = strlen(php_self);
+       if (sapi_module.input_filter(PARSE_SERVER, "PHP_SELF", &php_self, len, &len TSRMLS_CC)) {
+               php_register_variable("PHP_SELF", php_self, track_vars_array TSRMLS_CC);
+       }
+       if (sapi_module.input_filter(PARSE_SERVER, "SCRIPT_NAME", &php_self, len, &len TSRMLS_CC)) {
+               php_register_variable("SCRIPT_NAME", php_self, track_vars_array TSRMLS_CC);
+       }
        /* filenames are empty for stdin */
-       php_register_variable("SCRIPT_FILENAME", script_filename, track_vars_array TSRMLS_CC);
-       php_register_variable("PATH_TRANSLATED", script_filename, track_vars_array TSRMLS_CC);
+       len = strlen(script_filename);
+       if (sapi_module.input_filter(PARSE_SERVER, "SCRIPT_FILENAME", &script_filename, len, &len TSRMLS_CC)) {
+               php_register_variable("SCRIPT_FILENAME", script_filename, track_vars_array TSRMLS_CC);
+       }
+       if (sapi_module.input_filter(PARSE_SERVER, "PATH_TRANSLATED", &script_filename, len, &len TSRMLS_CC)) {
+               php_register_variable("PATH_TRANSLATED", script_filename, track_vars_array TSRMLS_CC);
+       }
        /* just make it available */
-       php_register_variable("DOCUMENT_ROOT", "", track_vars_array TSRMLS_CC);
+       len = 0U;
+       if (sapi_module.input_filter(PARSE_SERVER, "DOCUMENT_ROOT", &docroot, len, &len TSRMLS_CC)) {
+               php_register_variable("DOCUMENT_ROOT", docroot, track_vars_array TSRMLS_CC);
+       }
 }
 /* }}} */