mirror of
https://github.com/SuiteCRM/SuiteCRM-Core.git
synced 2025-08-29 08:17:18 +08:00
81ce7933fd SuiteCRM 7.13.0 Release 595d2bd92b Fix saveDropDown getting called statically a70c5d1b99 Fix message deletion after auto import f57b5ede02 Fix Inbound Email allow_outbound_group_usage filtering 9d38016f59 Remove external_oauth_providers config d5b4f0025c Remove provider field from ExternalOAuthConnection d457827c7d Change ExternalOAuthProvider to use open visibility by default for group records 3a51437d3a Add null check b49d6b79a0 Fix Inbound email tests 277f2c91cb Set default on inbound emails 261dae81c1 Add group to OutboundEmailAccounts menu 3e9dbdd5de Fix ExternalOAuthConnection list view pagination and checkboxes 36cbb6a90c Fix ExternalOAuthProvider list view pagination and checkboxes fe5f0a10d6 Fix OutboundEmailAccounts list view pagination and checkboxes b9217a36e2 Fix InboundEmail list view pagination and checkboxes 83bd0024a6 Allow selecting group InboundEmails in folder management f6a9111b25 Fix inbound email relationship definition 07b3110f8a Filter listview email displayed accounts according to preferences 6c49df527a Remove code that auto-selects a group email none is selected 243a0276af Fix preferences mail folder management dropdown e7838f0bd4 Fix owner field definition in OutboundEmailAccounts db9a52a27d Fix bounce mailbox type not being properly set 14d43e1efa Fix compose emails not sending f9e3677db8 Add optional connection string to InboundEmail module cef8b2bdb6 Allow setting placeholder for varchar on editview b2d669a022 Fix group_id not being saved properly on InboundEmail 8d25cc19d8 Fix: From not populating fae3d7b629 Fix folders not clearing subscription a8e9eba917 Fix signatures not being editable after being created 1762704a28 Fix menu label in ExternalOAuthConnections module e97ddb6af0 Fix inbound_emails_external_oauth_connections relationship 2cbebdd5a9 Replace External Oauth Provider sugar_config with module 89f2cee005 Add admin menu entry for ExternalOAuthProviders dbe91ffe26 Add External providers to ExternalOAuthConnector menu 63b944e033 Add ExternalOAuthProvider module 214f0d9008 Rename ExternalOAuthProvider to ExternalOAuthProviderConnector 972356fa90 Add stringmap field c701e4c6d5 Add json_decode smarty modifier 49024376be Update Travis build to remove php 7.3 test runs c23f0e57ac Update Minimum php version to php 7.4 b5914d782e Fix #9670 - Disabling the user profile option about notification of assignments does not work c2f260e477 Clear caches used by Inline Edition 89de5b620f Fix #99568: Ignore int length when comparing vardefs in newer MySQL versions fb50e2250e ElasticSearch Indexing batch error handling 32af678e4f Fix #9473 - Missing item "Survey" in campainglog_activity_type_dom a12f4f37be Fix #9638 - Elasticsearch issue with accented characters d85d72996d Fix #9499 - Add View Survey Responses Menu item dcd3ea1091 Fix #9574 - Update method to static for module renaming c56a5b2188 Fix #9646 - Display TinyMCE in step 4 of the campaigns form wizard d99439aca1 Fix #9717 - Security Suite Record Group selector doesn't appear when duplicating records ea0b42469a Add new ACL access logic hooks be0dec47dc Refactor module access query for extendability 8361cceb60 fix #9802 - Diagnostic checkboxes 44e4f47cca SuiteCRM 7.13.0-beta Release 0d6fef782e Fix #9839 - Make Inbound Email not auditable c0b93a5d2a Fix #9839 - Align Inbound and Outbound email menu labels 3883c2cb7e Fix #9839 - Inbound email assignment fields save and detail display 0a4fbfa2a9 Fix #9839 - Inbound email filters not displaying 6fefdd79a0 Fix #9839 - OutboundEmailAccounts list filtering 3dcab78053 Fix #9839 - Hide sort fields in search modal if none is sortable 95d099d3b4 Fix #9839 - Always sort emails by date received aff7965abd Fix #9839 - Add showing sort direction when field is not manually sortable e3f7d02a65 Fix #9839 - Use previously selected email mailbox when using the navigation links 01c96bf15c Fix #9839 - Add Imap2Handler to use imap2 lib d8dee51d94 Fix #9839 - Move email list retrieval from InboundEmail to ImapHandler f798b9af4a Fix #9839 - Update InboundEmail calls to mailparser to send 2nd argument 68a8fa97dd Fix #9839 - Move stream validity check to ImapHandlers fb4f1c81ec Fix #9839 - Fix InboundEmail pagination totals dc26951a35 Fix #9839 - Use previously selected email mailbox when using the navigation links cca80e945b Fix #9839 - Move case macro input to Case module settings admin menu 0fb1075aa2 Fix #9839 - Fix undefined error in listview displayEmptyDataMessages 990e98e4bc Fix #9839 - Add support to test oauth connection in InboundEmail 7259c9ce79 Fix #9839 - Allow refreshing ExternalOAuthConnection tokens 49c5c0ee09 Fix #9839 - Make ExternalOAuthConnection sensitive fields db_encrypted 17bbeb3683 Fix #9839 - Allow admins to list Group and personal ExternalOAuthConnection 0f559a6223 Fix #9839 - Allow encrypting fields on db by setting db_encrypted 471792d75f Fix #9839 - Apply acl and group check filtering to OutboundEmailAccounts 093f08f27b Fix #9839 - Apply acl and group check filtering to InboundEmail decdd27b23 Fix #9839 - Apply acl and group check filtering to ExternalOAuthConnection 584e40cfb3 Fix #9839 - Add user acl group action check 07c5b9f021 Fix #9839 - Show no-data message on empty OutboundEmailAccounts listview b857e4feab Fix #9839 - Show no-data message on empty ExternalOAuthConnection listview 9b6a7c4fcf Fix #9839 - Validate required fields on InboundEmail folder selection 0755e4bc7e Fix #9839 - Mark fields required when changing authType in InboundEmail 55123f4d70 Fix #9839 - Show no-data message on empty InboundEmail listview 059d112349 Fix #9839 - Fix InboundEmail save a656abd069 Fix #9839 - Make getUserRoleNames a static method ae49f130a9 Fix #9839 - Add is-value-set data to password field 2964fcbebc Fix #9839 - Add option to disable listview empty data messages a5794343cb Fix #9839 - Add ExternalOAuthConnection link to admin menu 215413931c Fix #9839 - Align mail related menu entries ee9e98741d Fix #9839 - Always keep write-only fields in OutboundEmailAccounts 4e0551e9f0 Fix #9839 - Disable massupdate and export in OutboundEmailAccounts bulk actions bbf351ee5e Fix #9839 - Disable massupdate and export in InboundEmail bulkactions 6871295c66 Fix #9839 - Allow selecting auth type in InboundEmail module 9befcd0ae6 Fix #9839 - Add ExternalOAuthConnection entrypoints 2cee6f1d67 Fix #9839 - Add ExternalOAuthConnection module 70025d5b66 Fix #9839 - Add write-only display option to text fields 25e2443850 Fix #9839 - Add write-only display option to varchar fields 6be8a334b1 Fix #9839 - Allow creating personal outbound email accounts 8bff1fb237 Fix #9839 - Align Outbound email accounts views with Inbound e396b7373c Fix #9839 - Allow admin to create personal inbound accounts for users 284d0eca76 Fix #9839 - Align inbound email and outbound email list views 186d8e41e4 Fix #9839 - Add Security Groups subpanel to Outbound email accounts c07f43decb Fix #9839 - Add Security Groups subpanel to Inbound email accounts 87c9eee413 Fix #9839 - Add access checks to personal outbound email accounts 2f76e6a5f5 Fix #9839 - Add access checks to personal inbound email accounts 88adc8135b Fix #9839 - Remove email account configuration from User Settings 33feb0b1c2 Fix #9839 - Allow setting personal InboundEmail signatures 4cb0fd99aa Fix #9839 - Allow setting personal InboundEmail as default b8cc31d8dd Fix #9839 - Add security groups to OutboundEmailAccounts 70a0daba51 Fix #9839 - Tidy OutboundEmailAccounts view definitions ca171a4460 Fix #9839 - Remove email_provider_chooser from OutboundEmailAccounts f8a6105618 Fix #9839 - Add menu definition to OutboundEmailAccounts 7d6cfd6c6c Fix #9839 - Load InboundEmail stored_options into fields on load f18ec84b47 Fix #9839 - Adjust InboundEmail save to use new fields 54bfb4f72c Fix #9839 - Remove InboundEmail legacy custom views 69d008671e Fix #9839 - Add new menu entries to InboundEmail d01a196f3b Fix #9839 - Add js code for inboundEmail 701498d007 Fix #9839 - Add standard view definitions to InboundEmail b5870531ba Fix #9839 - Add fields for stored_options in InboundEmail 8c57b07591 Fix #9839 - Add inbound and outbound email menu links to Users module a8bc647662 Fix #9839 - Add combinescripts smarty plugin e4db0fbfd4 Fix #9839 - Add writeonly display mode for password fields 1cc85c2dbf Fix #9839 - Add readonly display mode for enum fields git-subtree-dir: public/legacy git-subtree-split: 81ce7933fd9cecc378154ed4eac7eaab5ec1f139
817 lines
25 KiB
PHP
817 lines
25 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* SugarCRM Community Edition is a customer relationship management program developed by
|
|
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
|
|
*
|
|
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
|
|
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it under
|
|
* the terms of the GNU Affero General Public License version 3 as published by the
|
|
* Free Software Foundation with the addition of the following permission added
|
|
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
|
|
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
|
|
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
* details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License along with
|
|
* this program; if not, see http://www.gnu.org/licenses or write to the Free
|
|
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA.
|
|
*
|
|
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
|
|
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
|
|
*
|
|
* The interactive user interfaces in modified source and object code versions
|
|
* of this program must display Appropriate Legal Notices, as required under
|
|
* Section 5 of the GNU Affero General Public License version 3.
|
|
*
|
|
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
|
|
* these Appropriate Legal Notices must retain the display of the "Powered by
|
|
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
|
|
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
|
|
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
|
|
*/
|
|
if (!defined('sugarEntry') || !sugarEntry) {
|
|
die('Not A Valid Entry Point');
|
|
}
|
|
|
|
/**
|
|
* EmailsDataAddressCollector
|
|
*
|
|
* @author gyula
|
|
*/
|
|
class EmailsDataAddressCollector
|
|
{
|
|
const ERR_INVALID_INBOUND_EMAIL_TYPE = 201;
|
|
const ERR_STORED_OUTBOUND_EMAIL_NOT_SET = 202;
|
|
const ERR_STORED_OUTBOUND_EMAIL_ID_IS_INVALID = 203;
|
|
const ERR_REPLY_TO_ADDR_NOT_FOUND = 204;
|
|
const ERR_REPLY_TO_FORMAT_INVALID_SPLITS = 205;
|
|
const ERR_STORED_OUTBOUND_EMAIL_NOT_FOUND = 206;
|
|
const ERR_REPLY_TO_FORMAT_INVALID_NO_NAME = 207;
|
|
const ERR_REPLY_TO_FORMAT_INVALID_NO_ADDR = 208;
|
|
const ERR_REPLY_TO_FORMAT_INVALID_AS_FROM = 209;
|
|
|
|
/**
|
|
*
|
|
* @var User
|
|
*/
|
|
protected $currentUser;
|
|
|
|
/**
|
|
*
|
|
* @var array
|
|
*/
|
|
protected $sugarConfig;
|
|
|
|
/**
|
|
*
|
|
* @var int
|
|
*/
|
|
protected $err;
|
|
|
|
/**
|
|
*
|
|
* @var OutboundEmail
|
|
*/
|
|
protected $oe;
|
|
|
|
// ------------------ FROM DATA STRUCT -------------------
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $replyTo;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $fromAddr;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $fromName;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $oeId;
|
|
|
|
/**
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $oeName;
|
|
|
|
// -------------------------------------------------------
|
|
|
|
/**
|
|
*
|
|
* @param User $currentUser
|
|
* @param array $sugarConfig
|
|
*/
|
|
public function __construct(User $currentUser, $sugarConfig)
|
|
{
|
|
$this->currentUser = $currentUser;
|
|
$this->sugarConfig = $sugarConfig;
|
|
}
|
|
|
|
/**
|
|
* @param $ieAccounts
|
|
* @param $showFolders
|
|
* @param $prependSignature
|
|
* @param $emailSignatures
|
|
* @param $defaultEmailSignature
|
|
* @return array
|
|
* @throws EmailValidatorException
|
|
*/
|
|
public function collectDataAddressesFromIEAccounts(
|
|
$ieAccounts,
|
|
$showFolders,
|
|
$prependSignature,
|
|
$emailSignatures,
|
|
$defaultEmailSignature
|
|
) {
|
|
$dataAddresses = array();
|
|
foreach ($ieAccounts as $inboundEmail) {
|
|
$this->validateInboundEmail($inboundEmail);
|
|
|
|
if (in_array($inboundEmail->id, $showFolders)) {
|
|
$storedOptions = sugar_unserialize(base64_decode($inboundEmail->stored_options));
|
|
$isGroupEmailAccount = $inboundEmail->isGroupEmailAccount();
|
|
$isPersonalEmailAccount = $inboundEmail->isPersonalEmailAccount();
|
|
|
|
// if group email account, check that user is allowed to use group email account
|
|
$inboundEmailStoredOptions = $inboundEmail->getStoredOptions();
|
|
if ($isGroupEmailAccount && !isTrue($inboundEmailStoredOptions['allow_outbound_group_usage'] ?? false)) {
|
|
continue;
|
|
}
|
|
|
|
$this->getOutboundEmailOrError($storedOptions, $inboundEmail);
|
|
$this->retrieveFromDataStruct($storedOptions);
|
|
|
|
$emailFromValidator = new EmailFromValidator();
|
|
|
|
$this->logReplyToError($emailFromValidator);
|
|
|
|
|
|
$dataAddress = $this->getDataAddressFromIEAccounts(
|
|
$inboundEmail,
|
|
$storedOptions,
|
|
$prependSignature,
|
|
$isPersonalEmailAccount,
|
|
$isGroupEmailAccount,
|
|
$emailSignatures,
|
|
$defaultEmailSignature
|
|
);
|
|
|
|
$dataAddresses[] = $dataAddress;
|
|
}
|
|
}
|
|
|
|
return $this->fillDataAddress($dataAddresses, $defaultEmailSignature, $prependSignature);
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
* @param InboundEmail $inboundEmail
|
|
* @throws InvalidArgumentException
|
|
*/
|
|
protected function validateInboundEmail($inboundEmail = null)
|
|
{
|
|
if (!$inboundEmail instanceof InboundEmail) {
|
|
throw new InvalidArgumentException(
|
|
'Inbound Email Account should be a valid Inbound Email. ' . gettype($inboundEmail) . ' given.',
|
|
self::ERR_INVALID_INBOUND_EMAIL_TYPE
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
* @param InboundEmail $inboundEmail
|
|
*/
|
|
protected function getOutboundEmailOrError($storedOptions, InboundEmail $inboundEmail)
|
|
{
|
|
$this->err = null;
|
|
$this->setOe(null);
|
|
if (!isset($storedOptions['outbound_email'])) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() expects an outbound email id as stored option of inbound email (' . $inboundEmail->id . ') but it isn\'t set.');
|
|
$this->err = self::ERR_STORED_OUTBOUND_EMAIL_NOT_SET;
|
|
} else {
|
|
$validator = new SuiteCRM\Utility\SuiteValidator();
|
|
if ($validator->isValidId($storedOptions['outbound_email'])) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() expects an outbound email id as stored option of inbound email (' . $inboundEmail->id . ') but it isn\'t valid.');
|
|
$this->err = self::ERR_STORED_OUTBOUND_EMAIL_ID_IS_INVALID;
|
|
} else {
|
|
$this->setOe($this->getOutboundEmailOrErrorByStoredOptions($storedOptions));
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param OutboundEmail|null $oe
|
|
*/
|
|
protected function setOe($oe)
|
|
{
|
|
$this->oe = $oe;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
*/
|
|
protected function retrieveFromDataStruct($storedOptions)
|
|
{
|
|
if ($this->err) {
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() panic: An error occurred! (' . $this->err . ')');
|
|
|
|
$this->replyTo = $this->getReplyToOnError($storedOptions);
|
|
$this->fromName = $this->getFromNameOnError($storedOptions);
|
|
$this->fromAddr = $this->getFromAddrOnError($storedOptions);
|
|
$this->oeId = null;
|
|
$this->oeName = null;
|
|
} else {
|
|
$this->replyTo = utf8_encode($storedOptions['reply_to_addr']);
|
|
$this->fromName = utf8_encode($storedOptions['from_name']);
|
|
$this->fromAddr = utf8_encode($storedOptions['from_addr']);
|
|
$this->oeId = $this->oe->id;
|
|
$this->oeName = $this->oe->name;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param EmailFromValidator $emailFromValidator
|
|
* @throws EmailValidatorException
|
|
*/
|
|
protected function logReplyToError(EmailFromValidator $emailFromValidator)
|
|
{
|
|
if (!$this->replyTo) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() panic: An Outbound Email Reply-to Address is not found.');
|
|
$replyToErr = self::ERR_REPLY_TO_ADDR_NOT_FOUND;
|
|
} else {
|
|
$splits = explode(' ', $this->replyTo);
|
|
if (count($splits) !== 2) {
|
|
LoggerManager::getLogger()->error('Incorrect "replay to" format found: ' . $this->replyTo);
|
|
$replyToErr = self::ERR_REPLY_TO_FORMAT_INVALID_SPLITS;
|
|
} else {
|
|
$replyToErr = null;
|
|
$tmpName = $this->getTmpNameForLogReplyToError($splits, $replyToErr);
|
|
$tmpAddr = $this->getTmpAddrForLogReplyToError($splits, $replyToErr);
|
|
|
|
$this->validateForLogReplyToError($tmpName, $tmpAddr, $emailFromValidator, $replyToErr);
|
|
}
|
|
}
|
|
|
|
if (isset($replyToErr) && $replyToErr) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() error: ' . $replyToErr);
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $splits
|
|
* @param int $replyToErr
|
|
* @return string
|
|
*/
|
|
protected function getTmpNameForLogReplyToError($splits, &$replyToErr)
|
|
{
|
|
if (!isset($splits[0])) {
|
|
LoggerManager::getLogger()->error('Reply-to name part not found: ' . $this->getReplyTo());
|
|
$replyToErr = self::ERR_REPLY_TO_FORMAT_INVALID_NO_NAME;
|
|
}
|
|
|
|
return isset($splits[0]) ? $splits[0] : null;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $splits
|
|
* @param int $replyToErr
|
|
* @return string
|
|
*/
|
|
protected function getTmpAddrForLogReplyToError($splits, &$replyToErr)
|
|
{
|
|
if (!isset($splits[1])) {
|
|
LoggerManager::getLogger()->error('Reply-to email address part not found: ' . $this->getReplyTo());
|
|
$replyToErr = self::ERR_REPLY_TO_FORMAT_INVALID_NO_ADDR;
|
|
}
|
|
|
|
return isset($splits[1]) ? $splits[1] : null;
|
|
}
|
|
|
|
/**
|
|
* @param $tmpName
|
|
* @param $tmpAddr
|
|
* @param EmailFromValidator $emailFromValidator
|
|
* @param $replyToErr
|
|
* @throws EmailValidatorException
|
|
*/
|
|
protected function validateForLogReplyToError(
|
|
$tmpName,
|
|
$tmpAddr,
|
|
EmailFromValidator $emailFromValidator,
|
|
&$replyToErr
|
|
) {
|
|
$tmpEmail = BeanFactory::newBean('Emails');
|
|
$tmpEmail->FromName = $tmpEmail->from_name = $tmpName;
|
|
$tmpEmail->From = $tmpEmail->from_addr = $tmpAddr;
|
|
$tmpEmail->from_addr_name = $this->getReplyTo();
|
|
|
|
if (!$emailFromValidator->isValid($tmpEmail)) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() panic: An Outbound Email Reply-to Address is invalid.');
|
|
$replyToErr = self::ERR_REPLY_TO_FORMAT_INVALID_AS_FROM;
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function getReplyTo()
|
|
{
|
|
return $this->replyTo;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param InboundEmail $inboundEmail
|
|
* @param array $storedOptions
|
|
* @param string $prependSignature
|
|
* @param bool $isPersonalEmailAccount
|
|
* @param bool $isGroupEmailAccount
|
|
* @param array $emailSignatures
|
|
* @param array $defaultEmailSignature
|
|
* @return array
|
|
*/
|
|
protected function getDataAddressFromIEAccounts(
|
|
InboundEmail $inboundEmail,
|
|
$storedOptions,
|
|
$prependSignature,
|
|
$isPersonalEmailAccount,
|
|
$isGroupEmailAccount,
|
|
$emailSignatures,
|
|
$defaultEmailSignature
|
|
) {
|
|
$dataAddress = $this->getDataAddressArrayFromIEAccounts(
|
|
$inboundEmail,
|
|
$storedOptions,
|
|
$prependSignature,
|
|
$isPersonalEmailAccount,
|
|
$isGroupEmailAccount
|
|
);
|
|
|
|
$emailSignatureId = $this->getEmailSignatureId($emailSignatures, $inboundEmail);
|
|
|
|
$signature = $this->currentUser->getSignature($emailSignatureId);
|
|
if (!$signature) {
|
|
if ($defaultEmailSignature['no_default_available'] === true) {
|
|
$dataAddress['emailSignatures'] = $defaultEmailSignature;
|
|
} else {
|
|
$dataAddress['emailSignatures'] = array(
|
|
'html' => utf8_encode(html_entity_decode($defaultEmailSignature['signature_html'])),
|
|
'plain' => $defaultEmailSignature['signature'],
|
|
);
|
|
}
|
|
} else {
|
|
$dataAddress['emailSignatures'] = array(
|
|
'html' => utf8_encode(html_entity_decode($signature['signature_html'])),
|
|
'plain' => $signature['signature'],
|
|
);
|
|
}
|
|
|
|
return $dataAddress;
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
* @param InboundEmail $inboundEmail
|
|
* @param array $storedOptions
|
|
* @param string $prependSignature
|
|
* @param bool $isPersonalEmailAccount
|
|
* @param bool $isGroupEmailAccount
|
|
* @return array
|
|
*/
|
|
protected function getDataAddressArrayFromIEAccounts(
|
|
InboundEmail $inboundEmail,
|
|
$storedOptions,
|
|
$prependSignature,
|
|
$isPersonalEmailAccount,
|
|
$isGroupEmailAccount
|
|
) {
|
|
$dataAddress = new EmailsDataAddress();
|
|
|
|
return $dataAddress->getDataArray(
|
|
$inboundEmail->module_name,
|
|
$inboundEmail->id,
|
|
$storedOptions['reply_to_addr'],
|
|
$storedOptions['from_addr'],
|
|
$storedOptions['from_name'],
|
|
null,
|
|
$prependSignature,
|
|
$isPersonalEmailAccount,
|
|
$isGroupEmailAccount,
|
|
$this->getOeId(),
|
|
$this->getOeName(),
|
|
[]
|
|
);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function getOeId()
|
|
{
|
|
return $this->oeId;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function getOeName()
|
|
{
|
|
return $this->oeName;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $emailSignatures
|
|
* @param InboundEmail $inboundEmail
|
|
* @return string
|
|
*/
|
|
protected function getEmailSignatureId($emailSignatures, InboundEmail $inboundEmail)
|
|
{
|
|
|
|
// Include signature
|
|
if (isset($emailSignatures[$inboundEmail->id]) && !empty($emailSignatures[$inboundEmail->id])) {
|
|
$emailSignatureId = $emailSignatures[$inboundEmail->id];
|
|
} else {
|
|
$emailSignatureId = '';
|
|
}
|
|
|
|
return $emailSignatureId;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $dataAddresses
|
|
* @param array $defaultEmailSignature
|
|
* @param string $prependSignature
|
|
* @return array
|
|
*/
|
|
protected function fillDataAddress($dataAddresses, $defaultEmailSignature, $prependSignature)
|
|
{
|
|
$dataAddressesWithUserAddresses = $this->fillDataAddressFromUserAddresses(
|
|
$dataAddresses,
|
|
$defaultEmailSignature,
|
|
$prependSignature
|
|
);
|
|
$dataAddressesWithUserAddressesAndSystem = $this->fillDataAddressWithSystemMailerSettings(
|
|
$dataAddressesWithUserAddresses,
|
|
$defaultEmailSignature
|
|
);
|
|
|
|
return
|
|
$this->fillDataAddressFromPersonal(
|
|
$dataAddressesWithUserAddressesAndSystem
|
|
);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $dataAddresses
|
|
* @param array $defaultEmailSignature
|
|
* @param string $prependSignature
|
|
* @return array
|
|
*/
|
|
protected function fillDataAddressFromUserAddresses($dataAddresses, $defaultEmailSignature, $prependSignature)
|
|
{
|
|
if (isset($this->sugarConfig['email_allow_send_as_user']) && $this->sugarConfig['email_allow_send_as_user']) {
|
|
$sugarEmailAddress = new SugarEmailAddress();
|
|
$userAddressesArr = $sugarEmailAddress->getAddressesByGUID($this->currentUser->id, 'Users');
|
|
$dataAddresses = $this->collectDataAddressesFromUserAddresses(
|
|
$dataAddresses,
|
|
$userAddressesArr,
|
|
$defaultEmailSignature,
|
|
$prependSignature
|
|
);
|
|
}
|
|
|
|
return $dataAddresses;
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
* @param array $dataAddresses
|
|
* @param array $userAddressesArr
|
|
* @param array $defaultEmailSignature
|
|
* @param string $prependSignature
|
|
* @return array
|
|
*/
|
|
protected function collectDataAddressesFromUserAddresses(
|
|
$dataAddresses,
|
|
$userAddressesArr,
|
|
$defaultEmailSignature,
|
|
$prependSignature
|
|
) {
|
|
foreach ($userAddressesArr as $userAddress) {
|
|
if (!isset($userAddress['reply_to_addr']) || !$userAddress['reply_to_addr']) {
|
|
LoggerManager::getLogger()->error('EmailController::action_getFromFields() is Panicking: Reply-To address is not filled.');
|
|
}
|
|
$fromString = $this->getFromString($userAddress);
|
|
$signatureHtml = $this->getSignatureHtml($defaultEmailSignature);
|
|
$signatureTxt = $this->getSignatureTxt($defaultEmailSignature);
|
|
|
|
$dataAddresses[] = $this->getCollectDataAddressArrayFromUserAddresses(
|
|
$userAddress,
|
|
$fromString,
|
|
$prependSignature,
|
|
$signatureHtml,
|
|
$signatureTxt
|
|
);
|
|
}
|
|
|
|
return $dataAddresses;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $userAddress
|
|
* @return string
|
|
*/
|
|
protected function getFromString($userAddress)
|
|
{
|
|
if (isset($userAddress['reply_to_addr']) && $userAddress['reply_to_addr'] === '1') {
|
|
$fromString = $this->currentUser->full_name . ' <' . $userAddress['email_address'] . '>';
|
|
} else {
|
|
$fromString = $this->currentUser->full_name . ' <' . $this->currentUser->email1 . '>';
|
|
}
|
|
|
|
return $fromString;
|
|
}
|
|
|
|
/**
|
|
* @param $email
|
|
* @return string
|
|
*/
|
|
protected function addCurrentUserToEmailString($email)
|
|
{
|
|
return $this->currentUser->full_name . ' <' . $email . '>';
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $defaultEmailSignature
|
|
* @return string
|
|
*/
|
|
protected function getSignatureHtml($defaultEmailSignature)
|
|
{
|
|
if (!isset($defaultEmailSignature['signature_html'])) {
|
|
LoggerManager::getLogger()->warn('EmailController::action_getFromFields() is Panicking: Default email signature array does not have index as signature_html');
|
|
$signatureHtml = null;
|
|
} else {
|
|
$signatureHtml = $defaultEmailSignature['signature_html'];
|
|
}
|
|
|
|
return $signatureHtml;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $defaultEmailSignature
|
|
* @return string
|
|
*/
|
|
protected function getSignatureTxt($defaultEmailSignature)
|
|
{
|
|
if (!isset($defaultEmailSignature['signature'])) {
|
|
LoggerManager::getLogger()->warn('EmailController::action_getFromFields() is Panicking: Default email signature array does not have index as signature');
|
|
$signatureTxt = null;
|
|
} else {
|
|
$signatureTxt = $defaultEmailSignature['signature'];
|
|
}
|
|
|
|
return $signatureTxt;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $userAddress
|
|
* @param string $fromString
|
|
* @param string $prependSignature
|
|
* @param string $signatureHtml
|
|
* @param string $signatureTxt
|
|
* @return array
|
|
*/
|
|
protected function getCollectDataAddressArrayFromUserAddresses(
|
|
$userAddress,
|
|
$fromString,
|
|
$prependSignature,
|
|
$signatureHtml,
|
|
$signatureTxt
|
|
) {
|
|
$dataAddress = new EmailsDataAddress();
|
|
|
|
return $dataAddress->getDataArray(
|
|
'personal',
|
|
$userAddress['email_address_id'],
|
|
$this->currentUser->full_name . ' <' . $userAddress['email_address'] . '>',
|
|
$fromString,
|
|
$this->currentUser->full_name,
|
|
null,
|
|
$prependSignature,
|
|
true,
|
|
false,
|
|
null,
|
|
null,
|
|
[
|
|
'html' => utf8_encode(html_entity_decode($signatureHtml)),
|
|
'plain' => $signatureTxt,
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $dataAddresses
|
|
* @param array $defaultEmailSignature
|
|
* @return array
|
|
*/
|
|
protected function fillDataAddressWithSystemMailerSettings($dataAddresses, $defaultEmailSignature)
|
|
{
|
|
$this->setOe(new OutboundEmail());
|
|
if ($this->getOe()->isAllowUserAccessToSystemDefaultOutbound()) {
|
|
$system = $this->getOe()->getSystemMailerSettings();
|
|
$dataAddresses[] = $this->getFillDataAddressArray(
|
|
$system->id,
|
|
$system->name,
|
|
$system->smtp_from_name,
|
|
$system->smtp_from_addr,
|
|
$system->mail_smtpuser,
|
|
$defaultEmailSignature
|
|
);
|
|
}
|
|
|
|
return $dataAddresses;
|
|
}
|
|
|
|
/**
|
|
* @param $dataAddresses
|
|
* @return mixed
|
|
*/
|
|
protected function fillDataAddressFromPersonal($dataAddresses)
|
|
{
|
|
foreach ($dataAddresses as $address => $userAddress) {
|
|
if ($userAddress['type'] !== 'system') {
|
|
$emailInfo = $userAddress['attributes'];
|
|
$fromString = $emailInfo['from'];
|
|
$replyString = $emailInfo['reply_to'];
|
|
|
|
$dataAddresses[$address]['attributes'] = [
|
|
'from' => $fromString,
|
|
'name' => $userAddress['attributes']['name'],
|
|
'oe' => $userAddress['attributes']['oe'],
|
|
'reply_to' => $replyString
|
|
];
|
|
}
|
|
}
|
|
|
|
return $dataAddresses;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return OutboundEmail
|
|
*/
|
|
protected function getOe()
|
|
{
|
|
return $this->oe;
|
|
}
|
|
|
|
|
|
/**
|
|
*
|
|
* @param string $id
|
|
* @param string $name
|
|
* @param string $fromName
|
|
* @param string $fromAddr
|
|
* @param string $mailUser
|
|
* @param array $defaultEmailSignature
|
|
* @return array
|
|
*/
|
|
protected function getFillDataAddressArray(
|
|
$id,
|
|
$name,
|
|
$fromName,
|
|
$fromAddr,
|
|
$mailUser,
|
|
$defaultEmailSignature
|
|
) {
|
|
$dataAddress = new EmailsDataAddress();
|
|
|
|
return $dataAddress->getDataArray(
|
|
'system',
|
|
$id,
|
|
"$fromName <$fromAddr>",
|
|
"$fromName <$fromAddr>",
|
|
$fromName,
|
|
false,
|
|
false,
|
|
true,
|
|
$id,
|
|
$name,
|
|
$mailUser,
|
|
$defaultEmailSignature
|
|
);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
* @return OutboundEmail
|
|
*/
|
|
protected function getOutboundEmailOrErrorByStoredOptions($storedOptions)
|
|
{
|
|
$this->oe = new OutboundEmail();
|
|
if (!$this->oe->retrieve($storedOptions['outbound_email'])) {
|
|
// exception
|
|
LoggerManager::getLogger()->error('Trying to retrieve an OutboundEmail by ID: ' . $storedOptions['outbound_email'] . ' but it is not found.');
|
|
$this->err = self::ERR_STORED_OUTBOUND_EMAIL_NOT_FOUND;
|
|
}
|
|
|
|
return $this->oe;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
* @return string
|
|
*/
|
|
protected function getReplyToOnError($storedOptions)
|
|
{
|
|
if (!isset($storedOptions['reply_to_addr'])) {
|
|
LoggerManager::getLogger()->warn('Stored reply to address is not set.');
|
|
} elseif (!$storedOptions['reply_to_addr']) {
|
|
LoggerManager::getLogger()->warn('Stored reply to address is not filled.');
|
|
}
|
|
$this->replyTo = isset($storedOptions['reply_to_addr']) ? $storedOptions['reply_to_addr'] : null;
|
|
|
|
return $this->replyTo;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
* @return string
|
|
*/
|
|
protected function getFromNameOnError($storedOptions)
|
|
{
|
|
if (!isset($storedOptions['from_name'])) {
|
|
LoggerManager::getLogger()->warn('Stored from name is not set.');
|
|
} elseif (!$storedOptions['from_name']) {
|
|
LoggerManager::getLogger()->warn('Stored from name is not filled.');
|
|
}
|
|
$this->fromName = isset($storedOptions['from_name']) ? $storedOptions['from_name'] : null;
|
|
|
|
return $this->fromName;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $storedOptions
|
|
* @return string
|
|
*/
|
|
protected function getFromAddrOnError($storedOptions)
|
|
{
|
|
if (!isset($storedOptions['from_addr'])) {
|
|
LoggerManager::getLogger()->warn('Stored from address is not set.');
|
|
} elseif (!$storedOptions['from_addr']) {
|
|
LoggerManager::getLogger()->warn('Stored from address is not filled.');
|
|
}
|
|
$this->fromAddr = isset($storedOptions['from_addr']) ? $storedOptions['from_addr'] : null;
|
|
|
|
return $this->fromAddr;
|
|
}
|
|
}
|