| | |
| | | | program/include/rcube_user.inc | |
| | | | | |
| | | | This file is part of the RoundCube Webmail client | |
| | | | Copyright (C) 2005-2007, RoundCube Dev. - Switzerland | |
| | | | Copyright (C) 2005-2008, RoundCube Dev. - Switzerland | |
| | | | Licensed under the GNU GPL | |
| | | | | |
| | | | PURPOSE: | |
| | |
| | | /** |
| | | * Write the given user prefs to the user's record |
| | | * |
| | | * @param mixed User prefs to save |
| | | * @param array User prefs to save |
| | | * @return boolean True on success, False on failure |
| | | */ |
| | | function save_prefs($a_user_prefs) |
| | | { |
| | | if (!$this->ID) |
| | | return false; |
| | | |
| | | $config = rcmail::get_instance()->config; |
| | | $old_prefs = (array)$this->get_prefs(); |
| | | |
| | | // merge (partial) prefs array with existing settings |
| | | $a_user_prefs += (array)$this->get_prefs(); |
| | | unset($a_user_prefs['language']); |
| | | |
| | | $save_prefs = $a_user_prefs + $old_prefs; |
| | | unset($save_prefs['language']); |
| | | |
| | | // don't save prefs with default values if they haven't been changed yet |
| | | foreach ($a_user_prefs as $key => $value) { |
| | | if (!isset($old_prefs[$key]) && ($value == $config->get($key))) |
| | | unset($save_prefs[$key]); |
| | | } |
| | | |
| | | $this->db->query( |
| | | "UPDATE ".get_table_name('users')." |
| | | SET preferences=?, |
| | | language=? |
| | | WHERE user_id=?", |
| | | serialize($a_user_prefs), |
| | | serialize($save_prefs), |
| | | $_SESSION['language'], |
| | | $this->ID); |
| | | |
| | | $this->language = $_SESSION['language']; |
| | | if ($this->db->affected_rows()) |
| | | { |
| | | rcmail::get_instance()->config->merge($a_user_prefs); |
| | | if ($this->db->affected_rows()) { |
| | | $config->merge($a_user_prefs); |
| | | return true; |
| | | } |
| | | |
| | |
| | | { |
| | | $dbh = rcmail::get_instance()->get_dbh(); |
| | | |
| | | // query if user already registered |
| | | $sql_result = $dbh->query( |
| | | "SELECT * FROM ".get_table_name('users')." |
| | | WHERE mail_host=? AND (username=? OR alias=?)", |
| | | $host, |
| | | $user, |
| | | $user); |
| | | |
| | | // query for matching user name |
| | | $query = "SELECT * FROM ".get_table_name('users')." WHERE mail_host=? AND %s=?"; |
| | | $sql_result = $dbh->query(sprintf($query, 'username'), $host, $user); |
| | | |
| | | // query for matching alias |
| | | if (!($sql_arr = $dbh->fetch_assoc($sql_result))) { |
| | | $sql_result = $dbh->query(sprintf($query, 'alias'), $host, $user); |
| | | $sql_arr = $dbh->fetch_assoc($sql_result); |
| | | } |
| | | |
| | | // user already registered -> overwrite username |
| | | if ($sql_arr = $dbh->fetch_assoc($sql_result)) |
| | | if ($sql_arr) |
| | | return new rcube_user($sql_arr['user_id'], $sql_arr); |
| | | else |
| | | return false; |
| | |
| | | static function email2user($email) |
| | | { |
| | | $user = $email; |
| | | $r = self::findinvirtual("^$email\s"); |
| | | $r = self::findinvirtual('^' . quotemeta($email) . '[[:space:]]'); |
| | | |
| | | for ($i=0; $i<count($r); $i++) |
| | | { |
| | |
| | | */ |
| | | static function user2email($user) |
| | | { |
| | | $email = ""; |
| | | $r = self::findinvirtual("\s$user\s*$"); |
| | | $email = ''; |
| | | $r = self::findinvirtual('[[:space:]]' . quotemeta($user) . '[[:space:]]*$'); |
| | | |
| | | for ($i=0; $i<count($r); $i++) |
| | | { |