2008-11-24 10:40:45 +01:00
|
|
|
<?php
|
|
|
|
/***************************************************************************\
|
|
|
|
* eGroupWare - FeLaMiMail *
|
|
|
|
* http://www.linux-at-work.de *
|
|
|
|
* http://www.phpgw.de *
|
|
|
|
* http://www.egroupware.org *
|
|
|
|
* Written by : Lars Kneschke [lkneschke@linux-at-work.de] *
|
|
|
|
* ------------------------------------------------- *
|
|
|
|
* This program is free software; you can redistribute it and/or modify it *
|
|
|
|
* under the terms of the GNU General Public License as published by the *
|
|
|
|
* Free Software Foundation; either version 2 of the License, or (at your *
|
|
|
|
* option) any later version. *
|
|
|
|
\***************************************************************************/
|
|
|
|
/* $Id$ */
|
|
|
|
|
|
|
|
require_once(EGW_INCLUDE_ROOT.'/felamimail/inc/class.sopreferences.inc.php');
|
|
|
|
|
|
|
|
class bopreferences extends sopreferences
|
|
|
|
{
|
|
|
|
var $public_functions = array
|
|
|
|
(
|
|
|
|
'getPreferences' => 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()
|
|
|
|
{
|
|
|
|
$this->sessionData = (array) unserialize($GLOBALS['egw']->session->appsession('fm_preferences','felamimail'));
|
|
|
|
}
|
|
|
|
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 "<p>backtrace: ".function_backtrace()."</p>\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;
|
|
|
|
}
|
making the standard substitutes for signatures useable even for the user:
supported substitutes are:
$$fullname$$ => name of the user,
$$firstname$$ => first name of the user,
$$lastname$$ => last name of the user,
$$domain$$ => domain name for mail-address,
$$email$$ => email-address of the user,
$$date$$ => todays date,
Note: substitutions are performed, as the signature is added to the email, in EDIT Mode of
the signature in question the above listed placeholders are shown, if used.
Note: this is the discussed feature for signature placeholder substitution of 1.4.
It was never dropped, (as assumed earlier, but not useable, as substitution was performed for almost
every edit of the signature (and the placeholders where lost that way))
2008-12-09 15:22:31 +01:00
|
|
|
if($profileData->userDefinedAccounts && $GLOBALS['egw_info']['user']['apps']['felamimail']) {
|
2008-11-24 10:40:45 +01:00
|
|
|
// 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 "<p>backtrace: ".function_backtrace()."</p>\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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|