tony2001                Sun Jan  9 12:42:03 2005 EDT

  Modified files:              
    /php-src/ext/session        session.c 
  Log:
  fix bug #31454 (session_set_save_handler crashes PHP when supplied 
non-existent object ref)
  
  
http://cvs.php.net/diff.php/php-src/ext/session/session.c?r1=1.403&r2=1.404&ty=u
Index: php-src/ext/session/session.c
diff -u php-src/ext/session/session.c:1.403 php-src/ext/session/session.c:1.404
--- php-src/ext/session/session.c:1.403 Thu Dec  9 12:15:52 2004
+++ php-src/ext/session/session.c       Sun Jan  9 12:42:02 2005
@@ -17,7 +17,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: session.c,v 1.403 2004/12/09 17:15:52 tony2001 Exp $ */
+/* $Id: session.c,v 1.404 2005/01/09 17:42:02 tony2001 Exp $ */
 
 #ifdef HAVE_CONFIG_H
 #include "config.h"
@@ -1361,6 +1361,7 @@
        zval **args[6];
        int i;
        ps_user *mdata;
+       char *name;
 
        if (ZEND_NUM_ARGS() != 6 || zend_get_parameters_array_ex(6, args) == 
FAILURE)
                WRONG_PARAM_COUNT;
@@ -1368,6 +1369,14 @@
        if (PS(session_status) != php_session_none) 
                RETURN_FALSE;
        
+       for (i = 0; i < 6; i++) {
+               if (!zend_is_callable(*args[i], 0, &name)) {
+                       php_error_docref(NULL TSRMLS_CC, E_WARNING, "Argument 
%d is not a valid callback", i+1);
+                       efree(name);
+                       RETURN_FALSE;
+               }               
+       }
+       
        zend_alter_ini_entry("session.save_handler", 
sizeof("session.save_handler"), "user", sizeof("user")-1, PHP_INI_USER, 
PHP_INI_STAGE_RUNTIME);
 
        mdata = emalloc(sizeof(*mdata));

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to