sas Tue Feb 18 14:14:15 2003 EDT
Modified files: (Branch: PHP_4)
/php4/ext/session php_session.h session.c
Log:
MFH regen improvements
Index: php4/ext/session/php_session.h
diff -u php4/ext/session/php_session.h:1.84.2.1.2.3
php4/ext/session/php_session.h:1.84.2.1.2.4
--- php4/ext/session/php_session.h:1.84.2.1.2.3 Tue Feb 18 13:51:34 2003
+++ php4/ext/session/php_session.h Tue Feb 18 14:14:14 2003
@@ -121,6 +121,7 @@
long hash_func;
long hash_bits_per_character;
+ int send_cookie;
} php_ps_globals;
typedef php_ps_globals zend_ps_globals;
Index: php4/ext/session/session.c
diff -u php4/ext/session/session.c:1.336.2.5.2.3
php4/ext/session/session.c:1.336.2.5.2.4
--- php4/ext/session/session.c:1.336.2.5.2.3 Tue Feb 18 13:51:34 2003
+++ php4/ext/session/session.c Tue Feb 18 14:14:14 2003
@@ -17,7 +17,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: session.c,v 1.336.2.5.2.3 2003/02/18 18:51:34 sas Exp $ */
+/* $Id: session.c,v 1.336.2.5.2.4 2003/02/18 19:14:14 sas Exp $ */
#ifdef HAVE_CONFIG_H
#include "config.h"
@@ -1023,7 +1023,6 @@
zval **ppid;
zval **data;
char *p;
- int send_cookie = 1;
int define_sid = 1;
int module_number = PS(module_number);
int nrand;
@@ -1031,6 +1030,7 @@
PS(apply_trans_sid) = PS(use_trans_sid);
+ PS(send_cookie) = 1;
if (PS(session_status) != php_session_none)
return;
@@ -1050,7 +1050,7 @@
lensess + 1, (void **) &ppid) == SUCCESS) {
PPID2SID;
PS(apply_trans_sid) = 0;
- send_cookie = 0;
+ PS(send_cookie) = 0;
define_sid = 0;
}
@@ -1061,7 +1061,7 @@
zend_hash_find(Z_ARRVAL_PP(data), PS(session_name),
lensess + 1, (void **) &ppid) == SUCCESS) {
PPID2SID;
- send_cookie = 0;
+ PS(send_cookie) = 0;
}
if (!PS(use_only_cookies) && !PS(id) &&
@@ -1071,7 +1071,7 @@
zend_hash_find(Z_ARRVAL_PP(data), PS(session_name),
lensess + 1, (void **) &ppid) == SUCCESS) {
PPID2SID;
- send_cookie = 0;
+ PS(send_cookie) = 0;
}
}
@@ -1104,20 +1104,20 @@
strstr(Z_STRVAL_PP(data), PS(extern_referer_chk)) == NULL) {
efree(PS(id));
PS(id) = NULL;
- send_cookie = 1;
+ PS(send_cookie) = 1;
if (PS(use_trans_sid))
PS(apply_trans_sid) = 1;
}
php_session_initialize(TSRMLS_C);
- if (!PS(use_cookies) && send_cookie) {
+ if (!PS(use_cookies) && PS(send_cookie)) {
if (PS(use_trans_sid))
PS(apply_trans_sid) = 1;
- send_cookie = 0;
+ PS(send_cookie) = 0;
}
- if (send_cookie) {
+ if (PS(send_cookie)) {
php_session_send_cookie(TSRMLS_C);
}
@@ -1363,10 +1363,15 @@
Update the current session id with a newly generated one. */
PHP_FUNCTION(session_regenerate_id)
{
- if (PS(mod)) {
+ if (PS(session_status) == php_session_active) {
if (PS(id)) efree(PS(id));
PS(id) = PS(mod)->s_create_sid(&PS(mod_data), NULL TSRMLS_CC);
+
+ if (PS(send_cookie)) {
+ php_session_send_cookie(TSRMLS_C);
+ }
+
RETURN_TRUE;
}
RETURN_FALSE;
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php