diff options
author | redmatrix <git@macgirvin.com> | 2016-03-12 19:53:07 -0800 |
---|---|---|
committer | redmatrix <git@macgirvin.com> | 2016-03-12 19:53:07 -0800 |
commit | cc29e27acc04511b943c5dcab85b1ce215ac2e49 (patch) | |
tree | 4861ff715cec11a22e1c8e8b207b3a2460c714e0 /include/session.php | |
parent | 70ad69d38c53f78d04d912495f63c6fb781f0550 (diff) | |
download | volse-hubzilla-cc29e27acc04511b943c5dcab85b1ce215ac2e49.tar.gz volse-hubzilla-cc29e27acc04511b943c5dcab85b1ce215ac2e49.tar.bz2 volse-hubzilla-cc29e27acc04511b943c5dcab85b1ce215ac2e49.zip |
issue #320 - regression, after removing channel attached to an authenticated session the session was not completely cleared.
Diffstat (limited to 'include/session.php')
-rw-r--r-- | include/session.php | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/include/session.php b/include/session.php index 43bba528b..6060e4712 100644 --- a/include/session.php +++ b/include/session.php @@ -12,6 +12,38 @@ $session_exists = 0; $session_expire = 180000; + +/** + * @brief Resets the current session. + * + * @return void + */ + +function nuke_session() { + new_cookie(0); // 0 means delete on browser exit + + unset($_SESSION['authenticated']); + unset($_SESSION['account_id']); + unset($_SESSION['uid']); + unset($_SESSION['visitor_id']); + unset($_SESSION['administrator']); + unset($_SESSION['cid']); + unset($_SESSION['theme']); + unset($_SESSION['mobile_theme']); + unset($_SESSION['show_mobile']); + unset($_SESSION['page_flags']); + unset($_SESSION['delegate']); + unset($_SESSION['delegate_channel']); + unset($_SESSION['my_url']); + unset($_SESSION['my_address']); + unset($_SESSION['addr']); + unset($_SESSION['return_url']); + unset($_SESSION['remote_service_class']); + unset($_SESSION['remote_hub']); +} + + + function new_cookie($time) { $old_sid = session_id(); |