True, ); // stores the users profile var $profileData; var $sessionData; function bopreferences() { parent::sopreferences(); $this->boemailadmin = new emailadmin_bo(); if ( !(is_array($this->sessionData) && (count($this->sessionData)>0)) ) $this->restoreSessionData(); if (isset($this->sessionData['profileData']) && is_a($this->sessionData['profileData'],'ea_preferences')) { $this->profileData = $this->sessionData['profileData']; } } function restoreSessionData() { // set an own autoload function, search emailadmin for missing classes $GLOBALS['egw_info']['flags']['autoload'] = array(__CLASS__,'autoload'); $this->sessionData = (array) unserialize($GLOBALS['egw']->session->appsession('fm_preferences','felamimail')); } /** * Autoload classes from emailadmin, 'til they get autoloading conform names * * @param string $class */ static function autoload($class) { if (file_exists($file=EGW_INCLUDE_ROOT.'/emailadmin/inc/class.'.$class.'.inc.php')) { include_once($file); //error_log(__METHOD__."($class) included $file"); } elseif (file_exists($file=EGW_INCLUDE_ROOT.'/felamimail/inc/class.'.$class.'.inc.php')) { include_once($file); } else { error_log(__METHOD__."($class) failed!"); } } function saveSessionData() { $GLOBALS['egw']->session->appsession('fm_preferences','felamimail',serialize($this->sessionData)); } // get the first active user defined account function getAccountData(&$_profileData, $_accountID=NULL) { #echo "
backtrace: ".function_backtrace()."
\n"; if(!is_a($_profileData, 'ea_preferences')) die(__FILE__.': '.__LINE__); $accountData = parent::getAccountData($GLOBALS['egw_info']['user']['account_id'],$_accountID); // currently we use only the first profile available $accountData = array_shift($accountData); #_debug_array($accountData); $icServer =& CreateObject('emailadmin.defaultimap'); $icServer->encryption = isset($accountData['ic_encryption']) ? $accountData['ic_encryption'] : 1; $icServer->host = $accountData['ic_hostname']; $icServer->port = isset($accountData['ic_port']) ? $accountData['ic_port'] : 143; $icServer->validatecert = isset($accountData['ic_validatecertificate']) ? (bool)$accountData['ic_validatecertificate'] : 1; $icServer->username = $accountData['ic_username']; $icServer->loginName = $accountData['ic_username']; $icServer->password = $accountData['ic_password']; $icServer->enableSieve = isset($accountData['ic_enable_sieve']) ? (bool)$accountData['ic_enable_sieve'] : 1; $icServer->sieveHost = $accountData['ic_sieve_server']; $icServer->sievePort = isset($accountData['ic_sieve_port']) ? $accountData['ic_sieve_port'] : 2000; if ($accountData['ic_folderstoshowinhome']) $icServer->folderstoshowinhome = $accountData['ic_folderstoshowinhome']; if ($accountData['ic_trashfolder']) $icServer->trashfolder = $accountData['ic_trashfolder']; if ($accountData['ic_sentfolder']) $icServer->sentfolder = $accountData['ic_sentfolder']; if ($accountData['ic_draftfolder']) $icServer->draftfolder = $accountData['ic_draftfolder']; if ($accountData['ic_templatefolder']) $icServer->templatefolder = $accountData['ic_templatefolder']; $ogServer =& CreateObject('emailadmin.defaultsmtp'); $ogServer->host = $accountData['og_hostname']; $ogServer->port = isset($accountData['og_port']) ? $accountData['og_port'] : 25; $ogServer->smtpAuth = (bool)$accountData['og_smtpauth']; if($ogServer->smtpAuth) { $ogServer->username = $accountData['og_username']; $ogServer->password = $accountData['og_password']; } $identity =& CreateObject('emailadmin.ea_identity'); $identity->emailAddress = $accountData['emailaddress']; $identity->realName = $accountData['realname']; //$identity->default = true; $identity->default = (bool)$accountData['active']; $identity->organization = $accountData['organization']; $identity->signature = $accountData['signatureid']; $identity->id = $accountData['id']; $isActive = (bool)$accountData['active']; return array('icServer' => $icServer, 'ogServer' => $ogServer, 'identity' => $identity, 'active' => $isActive); } function getAllAccountData(&$_profileData) { if(!is_a($_profileData, 'ea_preferences')) die(__FILE__.': '.__LINE__); $AllAccountData = parent::getAccountData($GLOBALS['egw_info']['user']['account_id'],'all'); #_debug_array($accountData); foreach ($AllAccountData as $key => $accountData) { $icServer =& CreateObject('emailadmin.defaultimap'); $icServer->encryption = isset($accountData['ic_encryption']) ? $accountData['ic_encryption'] : 1; $icServer->host = $accountData['ic_hostname']; $icServer->port = isset($accountData['ic_port']) ? $accountData['ic_port'] : 143; $icServer->validatecert = isset($accountData['ic_validatecertificate']) ? (bool)$accountData['ic_validatecertificate'] : 1; $icServer->username = $accountData['ic_username']; $icServer->loginName = $accountData['ic_username']; $icServer->password = $accountData['ic_password']; $icServer->enableSieve = isset($accountData['ic_enable_sieve']) ? (bool)$accountData['ic_enable_sieve'] : 1; $icServer->sieveHost = $accountData['ic_sieve_server']; $icServer->sievePort = isset($accountData['ic_sieve_port']) ? $accountData['ic_sieve_port'] : 2000; if ($accountData['ic_folderstoshowinhome']) $icServer->folderstoshowinhome = $accountData['ic_folderstoshowinhome']; if ($accountData['ic_trashfolder']) $icServer->trashfolder = $accountData['ic_trashfolder']; if ($accountData['ic_sentfolder']) $icServer->sentfolder = $accountData['ic_sentfolder']; if ($accountData['ic_draftfolder']) $icServer->draftfolder = $accountData['ic_draftfolder']; if ($accountData['ic_templatefolder']) $icServer->templatefolder = $accountData['ic_templatefolder']; $ogServer =& CreateObject('emailadmin.defaultsmtp'); $ogServer->host = $accountData['og_hostname']; $ogServer->port = isset($accountData['og_port']) ? $accountData['og_port'] : 25; $ogServer->smtpAuth = (bool)$accountData['og_smtpauth']; if($ogServer->smtpAuth) { $ogServer->username = $accountData['og_username']; $ogServer->password = $accountData['og_password']; } $identity =& CreateObject('emailadmin.ea_identity'); $identity->emailAddress = $accountData['emailaddress']; $identity->realName = $accountData['realname']; //$identity->default = true; $identity->default = (bool)$accountData['active']; $identity->organization = $accountData['organization']; $identity->signature = $accountData['signatureid']; $identity->id = $accountData['id']; $isActive = (bool)$accountData['active']; $out[] = array('icServer' => $icServer, 'ogServer' => $ogServer, 'identity' => $identity, 'active' => $isActive); } return $out; } function getUserDefinedIdentities() { $profileData = $this->boemailadmin->getUserProfile('felamimail'); if(!is_a($profileData, 'ea_preferences') || !is_a($profileData->ic_server[0], 'defaultimap')) { return false; } if($profileData->userDefinedAccounts) { // get user defined accounts $allAccountData = $this->getAllAccountData($profileData); if ($allAccountData) { foreach ($allAccountData as $tmpkey => $accountData) { $accountArray[] = $accountData['identity']; } return $accountArray; } } return array(); } function getPreferences() { if (isset($this->sessionData['profileData']) && is_a($this->sessionData['profileData'],'ea_preferences')) { $this->profileData = $this->sessionData['profileData']; } if(!is_a($this->profileData,'ea_preferences')) { $imapServerTypes = $this->boemailadmin->getIMAPServerTypes(); $profileData = $this->boemailadmin->getUserProfile('felamimail'); if(!is_a($profileData, 'ea_preferences') || !is_a($profileData->ic_server[0], 'defaultimap')) { return false; } if($profileData->userDefinedAccounts && $GLOBALS['egw_info']['user']['apps']['felamimail']) { // get user defined accounts $accountData = $this->getAccountData($profileData); if($accountData['active']) { // replace the global defined IMAP Server if(is_a($accountData['icServer'],'defaultimap')) $profileData->setIncomingServer($accountData['icServer'],0); // replace the global defined SMTP Server if(is_a($accountData['ogServer'],'defaultsmtp')) $profileData->setOutgoingServer($accountData['ogServer'],0); // replace the global defined identity if(is_a($accountData['identity'],'ea_identity')) { $profileData->setIdentity($accountData['identity'],0); $rememberID = $accountData['identity']->id; } } $allUserIdentities = $this->getUserDefinedIdentities(); if (is_array($allUserIdentities)) { $i=count($allUserIdentities); foreach ($allUserIdentities as $tmpkey => $id) { if ($id->id != $rememberID) { $profileData->setIdentity($id,$i); $i++; } } } } $GLOBALS['egw']->preferences->read_repository(); $userPrefs = $GLOBALS['egw_info']['user']['preferences']['felamimail']; # echo "backtrace: ".function_backtrace()."
\n"; if (is_array($profileData->ic_server[0]->folderstoshowinhome) && !empty($profileData->ic_server[0]->folderstoshowinhome[0])) { $userPrefs['mainscreen_showfolders'] = implode(',',$profileData->ic_server[0]->folderstoshowinhome); } if (!empty($profileData->ic_server[0]->sentfolder)) $userPrefs['sentFolder'] = $profileData->ic_server[0]->sentfolder; if (!empty($profileData->ic_server[0]->trashfolder)) $userPrefs['trashFolder'] = $profileData->ic_server[0]->trashfolder; if (!empty($profileData->ic_server[0]->draftfolder)) $userPrefs['draftFolder'] = $profileData->ic_server[0]->draftfolder; if (!empty($profileData->ic_server[0]->templatefolder)) $userPrefs['templateFolder'] = $profileData->ic_server[0]->templatefolder; if(empty($userPrefs['deleteOptions'])) $userPrefs['deleteOptions'] = 'mark_as_deleted'; if (!empty($userPrefs['trash_folder'])) $userPrefs['move_to_trash'] = True; if (!empty($userPrefs['sent_folder'])) $userPrefs['move_to_sent'] = True; $userPrefs['signature'] = $userPrefs['email_sig']; unset($userPrefs['email_sig']); $profileData->setPreferences($userPrefs); #_debug_array($profileData);#exit; $this->sessionData['profileData'] = $this->profileData = $profileData; $this->saveSessionData(); #_debug_array($this->profileData); } return $this->profileData; } function ggetSignature($_signatureID, $_unparsed = false) { if($_signatureID == -1) { $profileData = $this->boemailadmin->getUserProfile('felamimail'); $systemSignatureIsDefaultSignature = !parent::getDefaultSignature($GLOBALS['egw_info']['user']['account_id']); $systemSignature = array( 'signatureid' => -1, 'description' => 'eGroupWare '. lang('default signature'), 'signature' => ($_unparsed === true ? $profileData->ea_default_signature : $GLOBALS['egw']->preferences->parse_notify($profileData->ea_default_signature)), 'defaultsignature' => $systemSignatureIsDefaultSignature, ); return $systemSignature; } else { require_once('class.felamimail_signatures.inc.php'); $signature = new felamimail_signatures($_signatureID); if($_unparsed === false) { $signature->fm_signature = $GLOBALS['egw']->preferences->parse_notify($signature->fm_signature); } return $signature; } } function ggetDefaultSignature() { return parent::getDefaultSignature($GLOBALS['egw_info']['user']['account_id']); } function ddeleteSignatures($_signatureID) { if(!is_array($_signatureID)) { return false; } return parent::deleteSignatures($GLOBALS['egw_info']['user']['account_id'], $_signatureID); } function saveAccountData($_icServer, $_ogServer, $_identity) { if(is_object($_icServer) && !isset($_icServer->validatecert)) { $_icServer->validatecert = true; } if(isset($_icServer->host)) { $_icServer->sieveHost = $_icServer->host; } $this->sessionData = array(); $this->saveSessionData(); return parent::saveAccountData($GLOBALS['egw_info']['user']['account_id'], $_icServer, $_ogServer, $_identity); } function deleteAccountData($_identity) { if (is_array($_identity)) { foreach ($_identity as $tmpkey => $id) { if ($id->id) { $identity[] = $id->id; } else { $identity[] = $id; } } } else { $identity = $_identity; } $this->sessionData = array(); $this->saveSessionData(); parent::deleteAccountData($GLOBALS['egw_info']['user']['account_id'], $identity); } function ssaveSignature($_signatureID, $_description, $_signature, $_isDefaultSignature) { return parent::saveSignature($GLOBALS['egw_info']['user']['account_id'], $_signatureID, $_description, $_signature, (bool)$_isDefaultSignature); } function setProfileActive($_status, $_identity=NULL) { $this->sessionData = array(); $this->saveSessionData(); parent::setProfileActive($GLOBALS['egw_info']['user']['account_id'], $_status, $_identity); } } ?>