00001 <?php
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043 include_once( 'kernel/classes/datatypes/ezuser/ezuser.php' );
00044 include_once( "lib/ezdb/classes/ezdb.php" );
00045
00046 define( 'EZ_PREFERENCES_SESSION_NAME', 'eZPreferences' );
00047
00048 class eZPreferences
00049 {
00050 function eZPreferences()
00051 {
00052 }
00053
00054
00055
00056
00057
00058
00059
00060
00061
00062
00063
00064
00065
00066
00067 function setValue( $name, $value, $storeUserID = false )
00068 {
00069 $db =& eZDB::instance();
00070 $name = $db->escapeString( $name );
00071 $value = $db->escapeString( $value );
00072
00073 $isCurrentUser = true;
00074 if ( $storeUserID === false )
00075 {
00076 $user =& eZUser::currentUser();
00077 }
00078 else
00079 {
00080 $currentID = eZUser::currentUserID();
00081 if ( $currentID != $storeUserID )
00082 $isCurrentUser = false;
00083
00084 $user = eZUser::fetch( $storeUserID );
00085 if ( !is_object( $user ) )
00086 {
00087 eZDebug::writeError( "Cannot set preference for user $storeUserID, the user does not exist" );
00088 return false;
00089 }
00090 }
00091
00092
00093
00094
00095
00096 if ( $storeUserID !== false or $user->isLoggedIn() )
00097 {
00098
00099
00100 $userID = $user->attribute( 'contentobject_id' );
00101 $existingRes = $db->arrayQuery( "SELECT * FROM ezpreferences WHERE user_id = $userID AND name='$name'" );
00102
00103 if ( count( $existingRes ) > 0 )
00104 {
00105 $prefID = $existingRes[0]['id'];
00106 $query = "UPDATE ezpreferences SET value='$value' WHERE id = $prefID AND name='$name'";
00107 $db->query( $query );
00108 }
00109 else
00110 {
00111 $query = "INSERT INTO ezpreferences ( user_id, name, value ) VALUES ( $userID, '$name', '$value' )";
00112 $db->query( $query );
00113 }
00114 }
00115
00116
00117 if ( $isCurrentUser )
00118 {
00119 eZPreferences::storeInSession( $name, $value );
00120 }
00121
00122 return true;
00123 }
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133 function value( $name, $user = false )
00134 {
00135 if ( get_class( $user ) != 'ezuser' )
00136 $user =& eZUser::currentUser();
00137
00138 $value = false;
00139
00140 $http =& eZHTTPTool::instance();
00141 $useCache = ( $user->ContentObjectID == $http->sessionVariable( 'eZUserLoggedInID' ) );
00142 if ( $useCache and eZPreferences::isStoredInSession( $name ) )
00143 return eZPreferences::storedSessionValue( $name );
00144
00145
00146 if ( $user->isAnonymous() )
00147 return false;
00148
00149 $db =& eZDB::instance();
00150 $name = $db->escapeString( $name );
00151 $userID = $user->attribute( 'contentobject_id' );
00152 $existingRes = $db->arrayQuery( "SELECT value FROM ezpreferences WHERE user_id = $userID AND name = '$name'" );
00153
00154 if ( count( $existingRes ) == 1 )
00155 {
00156 $value = $existingRes[0]['value'];
00157 if ( $useCache )
00158 eZPreferences::storeInSession( $name, $value );
00159 }
00160 else
00161 {
00162 if ( $useCache )
00163 eZPreferences::storeInSession( $name, false );
00164 }
00165 return $value;
00166 }
00167
00168
00169
00170
00171
00172
00173
00174 function values( $user = false )
00175 {
00176 if ( get_class( $user ) != 'ezuser' )
00177 $user =& eZUser::currentUser();
00178
00179 if ( !$user->isAnonymous() )
00180 {
00181
00182 $http =& eZHTTPTool::instance();
00183 $useCache = ( $user->ContentObjectID == $http->sessionVariable( 'eZUserLoggedInID' ) );
00184
00185 $returnArray = array();
00186 $userID = $user->attribute( 'contentobject_id' );
00187 $db =& eZDB::instance();
00188 $values = $db->arrayQuery( "SELECT name,value FROM ezpreferences WHERE user_id=$userID ORDER BY id" );
00189 foreach ( $values as $item )
00190 {
00191 if ( $useCache )
00192 eZPreferences::storeInSession( $item['name'], $item['value'] );
00193 $returnArray[$item['name']] = $item['value'];
00194 }
00195 return $returnArray;
00196 }
00197 else
00198 {
00199
00200 $http =& eZHTTPTool::instance();
00201 if ( $http->hasSessionVariable( EZ_PREFERENCES_SESSION_NAME ) )
00202 return $http->sessionVariable( EZ_PREFERENCES_SESSION_NAME );
00203 return array();
00204 }
00205 }
00206
00207
00208
00209
00210
00211 function sessionCleanup()
00212 {
00213 $http =& eZHTTPTool::instance();
00214 $http->removeSessionVariable( EZ_PREFERENCES_SESSION_NAME );
00215 }
00216
00217
00218
00219
00220
00221 function storeInSession( $name, $value )
00222 {
00223 $http =& eZHTTPTool::instance();
00224 $preferencesInSession = array();
00225 if ( $http->hasSessionVariable( EZ_PREFERENCES_SESSION_NAME ) )
00226 $preferencesInSession =& $http->sessionVariable( EZ_PREFERENCES_SESSION_NAME );
00227 $preferencesInSession[$name] = $value;
00228 $http->setSessionVariable( EZ_PREFERENCES_SESSION_NAME, $preferencesInSession );
00229 }
00230
00231
00232
00233
00234
00235 function isStoredInSession( $name )
00236 {
00237 $http =& eZHTTPTool::instance();
00238 if ( !$http->hasSessionVariable( EZ_PREFERENCES_SESSION_NAME ) )
00239 return false;
00240 $preferencesInSession =& $http->sessionVariable( EZ_PREFERENCES_SESSION_NAME );
00241 return array_key_exists( $name, $preferencesInSession );
00242 }
00243
00244
00245
00246
00247
00248 function storedSessionValue( $name )
00249 {
00250 $http =& eZHTTPTool::instance();
00251 if ( !$http->hasSessionVariable( EZ_PREFERENCES_SESSION_NAME ) )
00252 return null;
00253 $preferencesInSession =& $http->sessionVariable( EZ_PREFERENCES_SESSION_NAME );
00254 if ( !array_key_exists( $name, $preferencesInSession ) )
00255 return null;
00256 return $preferencesInSession[$name];
00257 }
00258
00259
00260
00261
00262
00263
00264
00265 function cleanup()
00266 {
00267 $db =& eZDB::instance();
00268 $db->query( "DELETE FROM ezpreferences" );
00269 }
00270 }
00271
00272
00273 ?>