From 03bca94981b46d3b7e1251d11a91f7aeaef2143e Mon Sep 17 00:00:00 2001
From: tbrehm <t.brehm@ispconfig.org>
Date: Wed, 12 Jan 2011 09:43:14 -0500
Subject: [PATCH] Merged revisions 2173-2174 from stable branch.

---
 interface/lib/classes/session.inc.php |   10 +++++++++-
 1 files changed, 9 insertions(+), 1 deletions(-)

diff --git a/interface/lib/classes/session.inc.php b/interface/lib/classes/session.inc.php
index 7ec2955..34dfaa5 100644
--- a/interface/lib/classes/session.inc.php
+++ b/interface/lib/classes/session.inc.php
@@ -56,7 +56,7 @@
 
         if (is_array($rec)) {
 			$this->session_array = $rec;
-			return $rec['session_data'];
+			return $this->session_array['session_data'];
 		} else {
 			return '';
 		}
@@ -68,6 +68,14 @@
             $this->session_array = array();
         }
 		
+		// Dont write session_data to DB if session data has not been changed after reading it.
+		if(isset($this->session_array['session_data']) && $this->session_array['session_data'] != '' && $this->session_array['session_data'] == $session_data) {
+			$session_id   = $this->db->quote($session_id);
+			$last_updated = date('Y-m-d H:i:s');
+            $this->db->query("UPDATE sys_session SET last_updated = '$last_updated' WHERE session_id = '$session_id'");
+			return true;
+		}
+		
 
         if ($this->session_array['session_id'] == '') {
 			$session_id   = $this->db->quote($session_id);

--
Gitblit v1.9.1