Skip to content

Commit

Permalink
- Adding a callback mechanism to the unserializer. (patch by Bernd
Browse files Browse the repository at this point in the history
  Roemer <berndr@bonn.edu>)
#- An explainatory e-mail will be send to php-dev
  • Loading branch information
Derick Rethans committed Nov 26, 2001
1 parent b91a666 commit 06cdf29
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 5 deletions.
39 changes: 34 additions & 5 deletions ext/standard/var_unserializer.c
Expand Up @@ -371,6 +371,13 @@ yy19: yych = *++YYCURSOR;
zend_class_entry *ce;
int incomplete_class = 0;

char *rval_temp;

zval *user_func;
zval *retval_ptr;
zval **args[1];
zval *arg_func_name;

INIT_PZVAL(*rval);
len2 = len = parse_iv(start + 2);
if (len == 0)
Expand All @@ -385,12 +392,34 @@ yy19: yych = *++YYCURSOR;
}
}

if (zend_hash_find(EG(class_table), class_name, len2 + 1, (void **) &ce) != SUCCESS) {
incomplete_class = 1;
ce = PHP_IC_ENTRY;
} else
if (zend_hash_find(CG(class_table), class_name, len2 + 1, (void **) &ce) != SUCCESS) {
if (PG(unserialize_callback_func) == NULL) {
incomplete_class = 1;
ce = PHP_IC_ENTRY;
} else {
MAKE_STD_ZVAL(user_func);
ZVAL_STRING(user_func, PG(unserialize_callback_func), 1);

args[0] = &arg_func_name;
MAKE_STD_ZVAL(arg_func_name);
ZVAL_STRING(arg_func_name, class_name, 1);

if (call_user_function_ex(CG(function_table), NULL, user_func, &retval_ptr, 1, args, 0, NULL TSRMLS_CC) != SUCCESS) {
zend_error(E_WARNING, "'unserialize_callback_func' defined (%s) but not found", user_func->value.str.val);
incomplete_class = 1;
ce = PHP_IC_ENTRY;
} else {
if (zend_hash_find(CG(class_table), class_name, len2 + 1, (void **) &ce) != SUCCESS) {
zend_error(E_WARNING, "'unserialize_callback_func' (%s) hasn't defined the class it was called for", user_func->value.str.val);
incomplete_class = 1;
ce = PHP_IC_ENTRY;
} else
efree(class_name);
}
}
} else
efree(class_name);

*p = YYCURSOR;
elements = object_common1(UNSERIALIZE_PASSTHRU, ce);

Expand Down
1 change: 1 addition & 0 deletions main/main.c
Expand Up @@ -239,6 +239,7 @@ PHP_INI_BEGIN()
STD_PHP_INI_BOOLEAN("track_errors", "0", PHP_INI_ALL, OnUpdateBool, track_errors, php_core_globals, core_globals)
STD_PHP_INI_BOOLEAN("y2k_compliance", "0", PHP_INI_ALL, OnUpdateBool, y2k_compliance, php_core_globals, core_globals)

STD_PHP_INI_ENTRY("unserialize_callback_func", NULL, PHP_INI_ALL, OnUpdateStringUnempty, unserialize_callback_func, php_core_globals, core_globals)
STD_PHP_INI_ENTRY("arg_separator.output", "&", PHP_INI_ALL, OnUpdateStringUnempty, arg_separator.output, php_core_globals, core_globals)
STD_PHP_INI_ENTRY("arg_separator.input", "&", PHP_INI_SYSTEM|PHP_INI_PERDIR, OnUpdateStringUnempty, arg_separator.input, php_core_globals, core_globals)

Expand Down
2 changes: 2 additions & 0 deletions main/php_globals.h
Expand Up @@ -66,6 +66,8 @@ struct _php_core_globals {

char *output_handler;

char *unserialize_callback_func;

char *safe_mode_exec_dir;

long memory_limit;
Expand Down
9 changes: 9 additions & 0 deletions php.ini-dist
Expand Up @@ -94,6 +94,15 @@ output_buffering = Off
; Setting an output handler automatically turns on output buffering.
output_handler =

; The unserialize callback function will called (with the undefind class'
; name as parameter), if the unserializer finds an undefined class
; which should be instanciated.
; A warning appears if the specified function is not defined, or if the
; function doesn't include/implement the missing class.
; So only set this entry, if you really want to implement such a
; callback-function.
unserialize_callback_func=

; Transparent output compression using the zlib library
; Valid values for this option are 'off', 'on', or a specific buffer size
; to be used for compression (default is 4KB)
Expand Down

0 comments on commit 06cdf29

Please sign in to comment.