-PHP_RINIT_FUNCTION(http_env)
-{
- /* populate form data on non-POST requests */
- if (SG(request_info).request_method && strcasecmp(SG(request_info).request_method, "POST") && SG(request_info).content_type && *SG(request_info).content_type) {
- uint ct_len = strlen(SG(request_info).content_type);
- char *ct_str = estrndup(SG(request_info).content_type, ct_len);
- php_http_params_opts_t opts;
- HashTable params;
-
- php_http_params_opts_default_get(&opts);
- opts.input.str = ct_str;
- opts.input.len = ct_len;
-
- SG(request_info).content_type_dup = ct_str;
-
- ZEND_INIT_SYMTABLE(¶ms);
- if (php_http_params_parse(¶ms, &opts)) {
- zend_string *key_str;
- zend_ulong key_num;
-
- if (HASH_KEY_IS_STRING == zend_hash_get_current_key(¶ms, &key_str, &key_num)) {
- sapi_post_entry *post_entry = NULL;
-
- if ((post_entry = zend_hash_find_ptr(&SG(known_post_content_types), key_str))) {
- SG(request_info).post_entry = post_entry;
-
- if (post_entry->post_reader) {
- post_entry->post_reader();
- }
-
- if (sapi_module.default_post_reader) {
- sapi_module.default_post_reader();
- }
-
- sapi_handle_post(&PG(http_globals)[TRACK_VARS_POST]);
-
- /*
- * the rfc1867 handler is an awkward buddy
- * FIXME: this leaks because php_auto_globals_create_files()
- * as well as the rfc1867_handler call
- * array_init(&PG(http_globals)[TRACK_VARS_FILES])
- */
- Z_TRY_ADDREF(PG(http_globals)[TRACK_VARS_FILES]);
- zend_hash_str_update(&EG(symbol_table), "_FILES", lenof("_FILES"), &PG(http_globals)[TRACK_VARS_FILES]);
- }
- }
- zend_hash_destroy(¶ms);
- }
- }
-
- PTR_SET(SG(request_info).content_type_dup, NULL);
-
- return SUCCESS;
-}