Edit report at https://bugs.php.net/bug.php?id=63379&edit=1
ID: 63379 Comment by: avatar2004-php at yahoo dot fr Reported by: avatar2004-php at yahoo dot fr Summary: Warning when using session_regenerate_id(TRUE) with a SessionHandler Status: Open Type: Bug Package: Session related Operating System: Gentoo PHP Version: 5.4.8 Block user comment: N Private report: N New Comment: If I understand correctly and "mod_user_is_open" is just a global state parameter used by the SessionHandler instance, I was wondering why the check wasn't being done on "session_status" instead to conform with the rest of the session_* API ? Previous Comments: ------------------------------------------------------------------------ [2012-10-29 01:04:34] avatar2004-php at yahoo dot fr Description: ------------ It seems there's an issue with the SessionHandler implementation and the way the destroy handler is invoked when using session_regenerate_id(TRUE) The problem seems to come from using the global "mod_user_is_open" in the PS_SANITY_CHECK_IS_OPEN macro (in ext/session/mod_user_class.c). The test script generates an undue warning: Test script: --------------- $handler = new SessionHandler(); session_set_save_handler($handler, TRUE); // or FALSE, doesn't matter session_start(); session_regenerate_id(TRUE); //session_write_close(); Expected result: ---------------- No warning Actual result: -------------- PHP Warning: Unknown: Parent session handler is not open in Unknown on line 0 ------------------------------------------------------------------------ -- Edit this bug report at https://bugs.php.net/bug.php?id=63379&edit=1