diff --git a/phpgwapi/inc/class.preferences.inc.php b/phpgwapi/inc/class.preferences.inc.php index 572be4f25f..a2154a1cc6 100644 --- a/phpgwapi/inc/class.preferences.inc.php +++ b/phpgwapi/inc/class.preferences.inc.php @@ -26,7 +26,11 @@ /*! @class preferences @abstract preferences class used for setting application preferences - @discussion Author: none yet + @discussion the prefs are read into 4 arrays: \ + $data the effective prefs used everywhere in phpgw, they are merged from the other 3 arrays \ + $user the stored user prefs, only used for manipulating and storeing the user prefs \ + $default the default preferences, always used when the user has no own preference set \ + $forced forced preferences set by the admin, they take precedence over user or default prefs */ class preferences { @@ -34,8 +38,14 @@ var $account_id; /*! @var account_type */ var $account_type; - /*! @var data */ + /*! @var data effectiv user prefs, used by all apps */ var $data = array(); + /*! @var user set user prefs for saveing (no defaults/forced prefs merged) */ + var $user = array(); + /*! @var default default prefs */ + var $default = array(); + /*! @var forced forced prefs */ + var $forced = array(); /*! @var db */ var $db; /*! @var debug_init_prefs */ @@ -62,45 +72,120 @@ * These are the standard $this->account_id specific functions * \**************************************************************************/ + /*! + @function unquote + @abstract unquote (stripslashes) recursivly the whole array + @param $arr array to unquote (var-param!) + */ + function unquote(&$arr) + { + if (!is_array($arr)) + { + $arr = stripslashes($arr); + return; + } + foreach($arr as $key => $value) + { + if (is_array($value)) + { + $this->unquote($arr[$key]); + } + else + { + $arr[$key] = stripslashes($value); + } + } + } + /*! @function read_repository @abstract private - read preferences from the repository + @note the function ready all 3 prefs user/default/forced and merges them to the effective ones @discussion private function should only be called from within this class */ function read_repository() { - $this->db->query("SELECT * FROM phpgw_preferences WHERE " - . "preference_owner='" . $this->account_id . "' OR " - . "preference_owner='-1' ORDER BY preference_owner DESC",__LINE__,__FILE__); - $this->db->next_record(); + $this->db->query("SELECT * FROM phpgw_preferences". + " WHERE preference_owner IN (-1,-2,".intval($this->account_id).")",__LINE__,__FILE__); - $pref_info = $this->db->f('preference_value'); - $this->data = unserialize($pref_info); - - if ($this->db->next_record()) + $this->forced = $this->default = $this->user = array(); + while($this->db->next_record()) { - $global_defaults = unserialize($this->db->f('preference_value')); - - while (is_array($global_defaults) && list($appname,$values) = each($global_defaults)) + $app = $this->db->f('preference_app'); + $value = unserialize($this->db->f('preference_value')); + $this->unquote($value); + if (!is_array($value)) { - while (is_array($values) && list($var,$value) = each($values)) + $value = array(); + } + switch($this->db->f('preference_owner')) + { + case -1: // forced + if (empty($app)) // db not updated + { + $this->forced = $value; + } + else + { + $this->forced[$app] = $value; + } + break; + case -2: // default + if (empty($app)) // db not updated + { + $this->default = $value; + } + else + { + $this->default[$app] = $value; + } + break; + default: // user + if (empty($app)) // db not updated + { + $this->user = $value; + } + else + { + $this->user[$app] = $value; + } + break; + } + } + $this->data = $this->user; + + // now use defaults if needed (user-value unset or empty) + // + foreach($this->default as $app => $values) + { + foreach($values as $var => $value) + { + if (!isset($this->data[$app][$var]) || $this->data[$app][$var] === '') { - $this->data[$appname][$var] = $value; + $this->data[$app][$var] = $value; } } } - - /* This is to supress warnings during login */ - if (is_array($this->data)) + // now set/force forced values + // + foreach($this->forced as $app => $values) { - reset ($this->data); + foreach($values as $var => $value) + { + $this->data[$app][$var] = $value; + } } - // This is to supress warnings durring login if (is_array($this->data)) { reset($this->data); } + if ($this->debug && substr($GLOBALS['phpgw_info']['flags']['currentapp'],0,3) != 'log') { + echo "user
"; print_r($this->user); echo "\n"; + echo "forced
"; print_r($this->forced); echo "\n"; + echo "default
"; print_r($this->default); echo "\n"; + echo "effectiv
";print_r($this->data); echo "\n"; + } return $this->data; } @@ -128,16 +213,18 @@ @param $app_name name of the app @param $var name of preference to be stored @param $value value of the preference + @note the function works on user and data, to be able to save the pref and to have imediate effect */ function add($app_name,$var,$value = '') { + //echo "
add('$app_name','$var','$value')
\n"; if ($value == '') { global $$var; $value = $$var; } - $this->data[$app_name][$var] = $value; + $this->user[$app_name][$var] = $this->data[$app_name][$var] = $value; reset($this->data); return $this->data; } @@ -148,17 +235,21 @@ @discussion @param $app_name name of app @param $var variable to be deleted + @note the function works on user and data, to be able to save the pref and to have imediate effect */ function delete($app_name, $var = '') { + //echo "delete('$app_name','$var')
\n"; if (is_string($var) && $var == '') { // $this->data[$app_name] = array(); unset($this->data[$app_name]); + unset($this->user[$app_name]); } else { unset($this->data[$app_name][$var]); + unset($this->user[$app_name][$var]); } reset ($this->data); return $this->data; @@ -169,15 +260,27 @@ @abstract add complex array data preference to $app_name a particular app @discussion Use for sublevels of prefs, such as email app's extra accounts preferences @param $app_name name of the app - @param $var String to be evaled's as an ARRAY structure, name of preference to be stored + @param $var array keys separated by '/', eg. 'ex_accounts/1' @param $value value of the preference + @note the function works on user and data, to be able to save the pref and to have imediate effect */ function add_struct($app_name,$var,$value = '') { + /* eval is slow and dangerous $code = '$this->data[$app_name]'.$var.' = $value;'; //echo 'class.preferences: add_struct: $code: '.$code.'preferences::save_repository(,$type): account_id=$account_id, prefs="; print_r($prefs); echo "
\n"; + if (! $GLOBALS['phpgw']->acl->check('session_only_preferences',1,'preferences')) + { + $this->db->transaction_begin(); + $this->db->query("delete from phpgw_preferences where preference_owner=$account_id", + __LINE__,__FILE__); + + foreach($prefs as $app => $value) + { + if (!is_array($value)) continue; + $this->quote($value); + $value = $this->db->db_addslashes(serialize($value)); // this addslashes is for the database + $app = $this->db->db_addslashes($app); + + $this->db->query($sql = "INSERT INTO phpgw_preferences". + " (preference_owner,preference_app,preference_value)". + " VALUES ($account_id,'$app','$value')",__LINE__,__FILE__); + } $this->db->transaction_commit(); } else @@ -236,13 +396,13 @@ $GLOBALS['phpgw']->session->save_repositories(); } - if ($GLOBALS['phpgw_info']['server']['cache_phpgw_info'] && $this->account_id == $GLOBALS['phpgw_info']['user']['account_id']) + if (($type == 'user' || !$type) && $GLOBALS['phpgw_info']['server']['cache_phpgw_info'] && $this->account_id == $GLOBALS['phpgw_info']['user']['account_id']) { $GLOBALS['phpgw']->session->delete_cache($this->account_id); $GLOBALS['phpgw']->session->read_repositories(False); } - return $temp_data; + return $this->data; } /*! @@ -253,7 +413,8 @@ */ function create_defaults($account_id) { - $this->db->query("SELECT * FROM phpgw_preferences WHERE preference_owner='-2'",__LINE__,__FILE__); + return; // not longer needed, as the defaults are merged in on runtime + $this->db->query("select * from phpgw_preferences where preference_owner='-2'",__LINE__,__FILE__); $this->db->next_record(); if($this->db->f('preference_value')) diff --git a/phpgwapi/setup/setup.inc.php b/phpgwapi/setup/setup.inc.php index 6cf7921977..11ce49453d 100755 --- a/phpgwapi/setup/setup.inc.php +++ b/phpgwapi/setup/setup.inc.php @@ -13,7 +13,7 @@ /* Basic information about this app */ $setup_info['phpgwapi']['name'] = 'phpgwapi'; - $setup_info['phpgwapi']['version'] = '0.9.15.010'; + $setup_info['phpgwapi']['version'] = '0.9.15.011'; $setup_info['phpgwapi']['versions']['current_header'] = '1.23'; $setup_info['phpgwapi']['enable'] = 3; $setup_info['phpgwapi']['app_order'] = 1; diff --git a/phpgwapi/setup/tables_current.inc.php b/phpgwapi/setup/tables_current.inc.php index 379dc2eecd..766e9181df 100644 --- a/phpgwapi/setup/tables_current.inc.php +++ b/phpgwapi/setup/tables_current.inc.php @@ -72,10 +72,11 @@ ), 'phpgw_preferences' => array( 'fd' => array( - 'preference_owner' => array('type' => 'int', 'precision' => 4, 'nullable' => false), - 'preference_value' => array('type' => 'text') + 'preference_owner' => array('type' => 'int','precision' => '4','nullable' => False), + 'preference_app' => array('type' => 'varchar','precision' => '25','nullable' => False), + 'preference_value' => array('type' => 'text','nullable' => False) ), - 'pk' => array('preference_owner'), + 'pk' => array('preference_owner','preference_app'), 'fk' => array(), 'ix' => array(), 'uc' => array() diff --git a/phpgwapi/setup/tables_update.inc.php b/phpgwapi/setup/tables_update.inc.php index 835685463a..a208db3d12 100644 --- a/phpgwapi/setup/tables_update.inc.php +++ b/phpgwapi/setup/tables_update.inc.php @@ -105,12 +105,24 @@ // 0.9.14.5xx are the development-versions of the 0.9.16 release (based on the 0.9.14 api) // as 0.9.15.xxx are already used in HEAD - // 0.9.15.001-10 are already included in 0.9.14.502 + // 0.9.15.001-9 are already included in 0.9.14.502 $GLOBALS['setup_info']['phpgwapi']['currentver'] = '0.9.15.010'; return $GLOBALS['setup_info']['phpgwapi']['currentver']; } + $test[] = '0.9.14.503'; + function phpgwapi_upgrade0_9_14_503() + { + // 0.9.14.5xx are the development-versions of the 0.9.16 release (based on the 0.9.14 api) + // as 0.9.15.xxx are already used in HEAD + + // 0.9.15.001-11 are already included in 0.9.14.503 + + $GLOBALS['setup_info']['phpgwapi']['currentver'] = '0.9.15.011'; + return $GLOBALS['setup_info']['phpgwapi']['currentver']; + } + $test[] = '0.9.15.001'; function phpgwapi_upgrade0_9_15_001() { @@ -292,5 +304,48 @@ return $GLOBALS['setup_info']['phpgwapi']['currentver']; } + $test[] = '0.9.15.010'; + function phpgwapi_upgrade0_9_15_010() + { + $GLOBALS['phpgw_setup']->oProc->RenameTable('phpgw_preferences','old_preferences'); + + $GLOBALS['phpgw_setup']->oProc->CreateTable('phpgw_preferences',array( + 'fd' => array( + 'preference_owner' => array('type' => 'int','precision' => '4','nullable' => False), + 'preference_app' => array('type' => 'varchar','precision' => '25','nullable' => False), + 'preference_value' => array('type' => 'text','nullable' => False) + ), + 'pk' => array('preference_owner','preference_app'), + 'fk' => array(), + 'ix' => array(), + 'uc' => array() + )); + $db2 = $GLOBALS['phpgw_setup']->db; // we need a 2. result-set + $GLOBALS['phpgw_setup']->oProc->query("SELECT * FROM old_preferences"); + while ($GLOBALS['phpgw_setup']->oProc->next_record()) + { + $owner = intval($GLOBALS['phpgw_setup']->oProc->f('preference_owner')); + $prefs = unserialize($GLOBALS['phpgw_setup']->oProc->f('preference_value')); + + if (is_array($prefs)) + { + foreach ($prefs as $app => $pref) + { + if (!empty($app) && count($pref)) + { + $app = addslashes($app); + $pref = serialize($pref); + $db2->query("INSERT INTO phpgw_preferences". + " (preference_owner,preference_app,preference_value)". + " VALUES ($owner,'$app','$pref')"); + } + } + } + } + $GLOBALS['phpgw_setup']->oProc->DropTable('old_preferences'); + + $GLOBALS['setup_info']['phpgwapi']['currentver'] = '0.9.15.011'; + return $GLOBALS['setup_info']['phpgwapi']['currentver']; + } ?> diff --git a/preferences/inc/hook_settings.inc.php b/preferences/inc/hook_settings.inc.php index 7563455834..4dc6ca8442 100755 --- a/preferences/inc/hook_settings.inc.php +++ b/preferences/inc/hook_settings.inc.php @@ -24,9 +24,9 @@ } create_input_box('Max matches per page','maxmatchs', - 'Any listing in phpGW will show you this number or entries or lines per page."; print_r($array); echo "\n"; while (is_array($array) && list($var,$value) = each($array)) { if (isset($value) && $value != '' && $value != '**NULL**') @@ -251,23 +268,18 @@ continue; // dont write empty password-fields } } - $prefs[$var] = $value; + $prefs[$var] = stripslashes($value); } else { unset($prefs[$var]); } } - //echo "prefix='$prefix', prefs=
"; print_r($_p->data[$_appname]); + //echo "prefix='$prefix', prefs="; print_r($repository[$_appname]); echo "\n"; - $_p->save_repository(True); + $GLOBALS['phpgw']->preferences->save_repository(True,$GLOBALS['type']); } - /* So we can check if the admin is allowing users to make there own choices */ - /* in life. */ - $GLOBALS['gp'] = createobject('phpgwapi.preferences',-1); - $GLOBALS['gp']->read_repository(); - /* Only check this once */ if ($GLOBALS['phpgw']->acl->check('run',1,'admin')) { @@ -331,29 +343,22 @@ } $has_help = 0; - /* Only load if there working on the default preferences */ - if ($GLOBALS['type'] == 'default') - { - $GLOBALS['dp'] = createobject('phpgwapi.preferences',-2); - $GLOBALS['dp']->read_repository(); - } - if ($_POST['submit']) { /* Don't use a switch here, we need to check some permissions durring the ifs */ if ($GLOBALS['type'] == 'user' || !($GLOBALS['type'])) { - process_array($GLOBALS['phpgw']->preferences,$user,$prefix); + process_array($GLOBALS['phpgw']->preferences->user,$user,$prefix); } if ($GLOBALS['type'] == 'default' && is_admin()) { - process_array($GLOBALS['dp'], $default); + process_array($GLOBALS['phpgw']->preferences->default, $default); } if ($GLOBALS['type'] == 'forced' && is_admin()) { - process_array($GLOBALS['gp'], $forced); + process_array($GLOBALS['phpgw']->preferences->forced, $forced); } if (!is_admin()) @@ -386,13 +391,13 @@ switch ($GLOBALS['type']) // set up some globals to be used by the hooks { case 'forced': - $prefs = &$GLOBALS['gp']->data[check_app()]; + $prefs = &$GLOBALS['phpgw']->preferences->forced[check_app()]; break; case 'default': - $prefs = &$GLOBALS['dp']->data[check_app()]; + $prefs = &$GLOBALS['phpgw']->preferences->default[check_app()]; break; default: - $prefs = &$GLOBALS['phpgw']->preferences->data[check_app()]; + $prefs = &$GLOBALS['phpgw']->preferences->user[check_app()]; // use prefix if given in the url, used for email extra-accounts if ($prefix != '') { diff --git a/preferences/setup/phpgw_de.lang b/preferences/setup/phpgw_de.lang index 95b9b8f7a9..1314b1e37d 100644 --- a/preferences/setup/phpgw_de.lang +++ b/preferences/setup/phpgw_de.lang @@ -1,4 +1,5 @@ %1 - preferences preferences de %1 - Einstellungen +%1 hours preferences de %1 Stunden 12 hour preferences de 12 Stunden 24 hour preferences de 24 Stunden a template defines the layout of phpgroupware and it contains icons for each application. preferences de Die Benutzeroberfläche definert das Layout von phpGroupWare und enthält die Icons (Symbole) der Andwendungen. @@ -11,6 +12,7 @@ change your profile preferences de Profil change your settings preferences de Einstellungen ändern country preferences de Land date format preferences de Datumsformat +default preferences de Vorgabe default application preferences de Standard-Anwendung default preferences preferences de Voreinstellungen delete categories preferences de Kategorie Löschen @@ -31,6 +33,7 @@ interface/template selection preferences de Auswahl der Benutzeroberfl language preferences de Sprache max matches per page preferences de maximale Treffer pro Seite max matchs per page preferences de Maximale Treffer pro Seite +no default preferences de Keine Vorgabe note: this feature does *not* change your email password. this will need to be done manually. preferences de Hinweis: Diese Funktion ändert *nicht* Ihr Passwort auf dem E-Mail server. Dies müssen sie separat tun. please, select a new theme preferences de Bitte ein neues Schema wählen re-enter your password preferences de Neues Passwort wiederholen @@ -50,6 +53,7 @@ theme (colors/fonts) selection preferences de Auswahl des Themas (Farben/Schrift this is the application which will be started when you enter phpgroupware or click on the homepage icon.
you can also have more than one application showing up on the homepage, if you don't choose a specific application here (has to be configured in the preferences of each application). preferences de Diese Anwendung wird gestartet, wenn sie phpGroupWare neu starten oder auf das Symbol der Startseite klicken. Sie können auch mehrere Anwendungen auf ihrer Startseite anzeigen, dazu wählen sie keine Anwendung aus. Welche Anwendungen dann angezeigt werden, wird in den Einstellungen der jeweiligen Anwendungen konfiguriert. this server is located in the %1 timezone preferences de Der Server befindet sich in der Zeitzone %1 time format preferences de Zeitformat +use default preferences de Vorgabe benutzen users choice preferences de Benutzerauswahl which currency symbole or name should be used in phpgroupware. preferences de Welches Währungssymbol oder Name soll in phpGroupWare verwendet werden. you can show the applications as icons only, icons with app-name or both. preferences de Sie können die Anwendungen als Symbol (Icon), Text oder beides anzeigen. diff --git a/preferences/setup/phpgw_en.lang b/preferences/setup/phpgw_en.lang index 9e37a746c5..4993eea4d0 100644 --- a/preferences/setup/phpgw_en.lang +++ b/preferences/setup/phpgw_en.lang @@ -1,4 +1,5 @@ %1 - preferences preferences en %1 - Preferences +%1 hours preferences en %1 hours 12 hour preferences en 12 hour 24 hour preferences en 24 hour a template defines the layout of phpgroupware and it contains icons vor each application. preferences en A template defines the layout of phpGroupWare and it contains icons vor each application. @@ -11,6 +12,7 @@ change your profile preferences en Change your profile change your settings preferences en Change your Settings country preferences en Country date format preferences en Date format +default preferences en default default application preferences en Default application default preferences preferences en Default Preferences delete categories preferences en Delete Categories @@ -30,6 +32,7 @@ in which country are you. this is used to set certain defaults for you. preferen interface/template selection preferences en Interface/Template Selection language preferences en Language max matches per page preferences en Max matches per page +no default preferences en No default note: this feature does *not* change your email password. this will need to be done manually. preferences en Note: This feature does *not* change your email password. This will need to be done manually. please, select a new theme preferences en Please, select a new theme re-enter your password preferences en Re-Enter your password @@ -48,6 +51,7 @@ theme (colors/fonts) selection preferences en Theme (colors/fonts) Selection this is the application which will be started when you enter phpgroupware or click on the homepage icon.
you can also have more than one applications showing up on the homepage, if you don't choose a specific application here (has to be configured in the preferences of each applicaton). preferences en This is the application which will be started when you enter phpGroupWare or click on the homepage icon.
You can also have more than one applications showing up on the homepage, if you don't choose a specific application here (has to be configured in the preferences of each applicaton). this server is located in the %1 timezone preferences en This server is located in the %1 timezone time format preferences en Time format +use default preferences en Use default users choice preferences en Users choice which currency symbole or name should be used in phpgroupware. preferences en Which currency symbole or name should be used in phpGroupWare. you can show the applications as icons only, icons with app-name or both. preferences en You can show the applications as icons only, icons with app-name or both.