source: trunk/include/functions_session.inc.php @ 2757

Last change on this file since 2757 was 2757, checked in by rvelices, 16 years ago

merge 2755 and 2756 from branch 2.0 to trunk

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Author Date Id Revision
File size: 6.2 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | Piwigo - a PHP based picture gallery                                  |
4// +-----------------------------------------------------------------------+
5// | Copyright(C) 2008      Piwigo Team                  http://piwigo.org |
6// | Copyright(C) 2003-2008 PhpWebGallery Team    http://phpwebgallery.net |
7// | Copyright(C) 2002-2003 Pierrick LE GALL   http://le-gall.net/pierrick |
8// +-----------------------------------------------------------------------+
9// | This program is free software; you can redistribute it and/or modify  |
10// | it under the terms of the GNU General Public License as published by  |
11// | the Free Software Foundation                                          |
12// |                                                                       |
13// | This program is distributed in the hope that it will be useful, but   |
14// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
15// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
16// | General Public License for more details.                              |
17// |                                                                       |
18// | You should have received a copy of the GNU General Public License     |
19// | along with this program; if not, write to the Free Software           |
20// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
21// | USA.                                                                  |
22// +-----------------------------------------------------------------------+
23
24// The function generate_key creates a string with pseudo random characters.
25// the size of the string depends on the $conf['session_id_size'].
26// Characters used are a-z A-Z and numerical values. Examples :
27//                    "Er4Tgh6", "Rrp08P", "54gj"
28// input  : none (using global variable)
29// output : $key
30function generate_key($size)
31{
32  global $conf;
33
34  $md5 = md5(substr(microtime(), 2, 6));
35  $init = '';
36  for ( $i = 0; $i < strlen( $md5 ); $i++ )
37  {
38    if ( is_numeric( $md5[$i] ) ) $init.= $md5[$i];
39  }
40  $init = substr( $init, 0, 8 );
41  mt_srand( $init );
42  $key = '';
43  for ( $i = 0; $i < $size; $i++ )
44  {
45    $c = mt_rand( 0, 2 );
46    if ( $c == 0 )      $key .= chr( mt_rand( 65, 90 ) );
47    else if ( $c == 1 ) $key .= chr( mt_rand( 97, 122 ) );
48    else                $key .= mt_rand( 0, 9 );
49  }
50  return $key;
51}
52
53if (isset($conf['session_save_handler'])
54  and ($conf['session_save_handler'] == 'db')
55  and defined('PHPWG_INSTALLED'))
56{
57  session_set_save_handler('pwg_session_open',
58    'pwg_session_close',
59    'pwg_session_read',
60    'pwg_session_write',
61    'pwg_session_destroy',
62    'pwg_session_gc'
63  );
64  if ( function_exists('ini_set') )
65  {
66    ini_set('session.use_cookies', $conf['session_use_cookies']);
67    ini_set('session.use_only_cookies', $conf['session_use_only_cookies']);
68    ini_set('session.use_trans_sid', intval($conf['session_use_trans_sid']));
69    ini_set('session.cookie_httponly', 1);
70  }
71  session_name($conf['session_name']);
72  session_set_cookie_params(0, cookie_path());
73}
74
75/**
76 * returns true; used when the session_start() function is called
77 *
78 * @params not use but useful for php engine
79 */
80function pwg_session_open($path, $name)
81{
82  return true;
83}
84
85/**
86 * returns true; used when the session is closed (unset($_SESSION))
87 *
88 */
89function pwg_session_close()
90{
91  return true;
92}
93
94function get_remote_addr_session_hash()
95{
96        return vsprintf( "%02X%02X", explode('.',$_SERVER['REMOTE_ADDR']) );
97}
98
99/**
100 * this function returns
101 * a string corresponding to the value of the variable save in the session
102 * or an empty string when the variable doesn't exist
103 *
104 * @param string session id
105 */
106function pwg_session_read($session_id)
107{
108  $query = '
109SELECT data
110  FROM '.SESSIONS_TABLE.'
111  WHERE id = \''.get_remote_addr_session_hash().$session_id.'\'
112;';
113  $result = pwg_query($query);
114  if ($result)
115  {
116    $row = mysql_fetch_assoc($result);
117    return $row['data'];
118  }
119  else
120  {
121    return '';
122  }
123}
124
125/**
126 * returns true; writes set a variable in the active session
127 *
128 * @param string session id
129 * @data string value of date to be saved
130 */
131function pwg_session_write($session_id, $data)
132{
133  $query = '
134UPDATE '.SESSIONS_TABLE.'
135  SET expiration = now(),
136  data = \''.$data.'\'
137  WHERE id = \''.get_remote_addr_session_hash().$session_id.'\'
138;';
139  pwg_query($query);
140  if ( mysql_affected_rows()>0 )
141  {
142    return true;
143  }
144  $query = '
145INSERT INTO '.SESSIONS_TABLE.'
146  (id,data,expiration)
147  VALUES(\''.get_remote_addr_session_hash().$session_id.'\',\''.$data.'\',now())
148;';
149  mysql_query($query);
150  return true;
151}
152
153/**
154 * returns true; delete the active session
155 *
156 * @param string session id
157 */
158function pwg_session_destroy($session_id)
159{
160  $query = '
161DELETE
162  FROM '.SESSIONS_TABLE.'
163  WHERE id = \''.get_remote_addr_session_hash().$session_id.'\'
164;';
165  pwg_query($query);
166  return true;
167}
168
169/**
170 * returns true; delete expired sessions
171 * called each time a session is closed.
172 */
173function pwg_session_gc()
174{
175  global $conf;
176
177  $query = '
178DELETE
179  FROM '.SESSIONS_TABLE.'
180  WHERE UNIX_TIMESTAMP(NOW()) - UNIX_TIMESTAMP(expiration) > '
181  .$conf['session_length'].'
182;';
183  pwg_query($query);
184  return true;
185}
186
187
188/**
189 * persistently stores a variable for the current session
190 * currently we use standard php sessions but it might change
191 * @return boolean true on success
192 * @see pwg_get_session_var, pwg_unset_session_var
193 */
194function pwg_set_session_var($var, $value)
195{
196  if ( !isset($_SESSION) )
197    return false;
198  $_SESSION['pwg_'.$var] = $value;
199  return true;
200}
201
202/**
203 * retrieves the value of a persistent variable for the current session
204 * currently we use standard php sessions but it might change
205 * @return mixed
206 * @see pwg_set_session_var, pwg_unset_session_var
207 */
208function pwg_get_session_var($var, $default = null)
209{
210  if (isset( $_SESSION['pwg_'.$var] ) )
211  {
212    return $_SESSION['pwg_'.$var];
213  }
214  return $default;
215}
216
217/**
218 * deletes a persistent variable for the current session
219 * currently we use standard php sessions but it might change
220 * @return boolean true on success
221 * @see pwg_set_session_var, pwg_get_session_var
222 */
223function pwg_unset_session_var($var)
224{
225  if ( !isset($_SESSION) )
226    return false;
227  unset( $_SESSION['pwg_'.$var] );
228  return true;
229}
230
231?>
Note: See TracBrowser for help on using the repository browser.