From 3d7030b43f84c061c891fdda80f63400da67c339 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 8 Dec 2014 16:23:23 +0000 Subject: [PATCH] fix fatal error in mass password-reset in admin when changing mail account parameters --- .../inc/class.emailadmin_account.inc.php | 41 ++++++++++++------- 1 file changed, 27 insertions(+), 14 deletions(-) diff --git a/emailadmin/inc/class.emailadmin_account.inc.php b/emailadmin/inc/class.emailadmin_account.inc.php index 348d18d229..cac4fdf904 100644 --- a/emailadmin/inc/class.emailadmin_account.inc.php +++ b/emailadmin/inc/class.emailadmin_account.inc.php @@ -295,6 +295,28 @@ class emailadmin_account implements ArrayAccess return (array)$data + (array)$smtp_data; } + /** + * Query quota, aliases, forwards, ... from imap and smtp backends and sets them as parameters on current object + * + * @param array with values for keys in self::$user_data + */ + public function saveUserData($user, array $data) + { + // store account-information of managed mail server + if ($user > 0 && $data['acc_smtp_type'] && $data['acc_smtp_type'] != 'emailadmin_smtp') + { + $smtp = self::_smtp($data); + $smtp->setUserData($user, (array)$data['mailAlternateAddress'], (array)$data['mailForwardingAddress'], + $data['deliveryMode'], $data['accountStatus'], $data['mailLocalAddress'], $data['quotaLimit']); + } + if ($user > 0 && $data['acc_imap_type'] && $data['acc_imap_type'] != 'emailadmin_imap') + { + $class = self::getIcClass($data['acc_imap_type']); + $imap = new $class($data, true); + $imap->setUserData($GLOBALS['egw']->accounts->id2name($user), $data['quotaLimit']); + } + } + /** * Get new Horde_Imap_Client imap server object * @@ -1168,26 +1190,17 @@ class emailadmin_account implements ArrayAccess ($data['called_for'] ? $data['called_for'] : $GLOBALS['egw_info']['user']['account_id']), (array)$data['notify_folders']); - // store account-information of managed mail server - if ($user > 0 && $data['acc_smtp_type'] && $data['acc_smtp_type'] != 'emailadmin_smtp') - { - $smtp = self::_smtp($data); - $smtp->setUserData($user, (array)$data['mailAlternateAddress'], (array)$data['mailForwardingAddress'], - $data['deliveryMode'], $data['accountStatus'], $data['mailLocalAddress'], $data['quotaLimit']); - } - if ($user > 0 && $data['acc_imap_type'] && $data['acc_imap_type'] != 'emailadmin_imap') - { - $class = self::getIcClass($data['acc_imap_type']); - $imap = new $class($data, true); - $imap->setUserData($GLOBALS['egw']->accounts->id2name($user), $data['quotaLimit']); - } - // store domain of an account for all user like before as "mail_suffix" config if ($data['acc_domain'] && (!$data['account_id'] || $data['account_id'] == array(0))) { config::save_value('mail_suffix', $data['acc_domain'], 'phpgwapi', true); } + if ($user > 0) + { + $emailadmin = new emailadmin_account($data, $user); + $emailadmin->saveUserData($user, $data); + } self::cache_invalidate($data['acc_id']); //error_log(__METHOD__."() returning ".array2string($data)); return $data;