mirror of
https://github.com/e107inc/e107.git
synced 2025-03-14 17:39:46 +01:00
This commit is contained in:
parent
9387a43d9d
commit
c4211ee52b
@ -243,6 +243,7 @@ class mailout_admin extends e_admin_dispatcher
|
|||||||
'sent/list' => array('caption'=> LAN_MAILOUT_192, 'perm' => 'W'),
|
'sent/list' => array('caption'=> LAN_MAILOUT_192, 'perm' => 'W'),
|
||||||
'other2' => array('divider'=> true),
|
'other2' => array('divider'=> true),
|
||||||
'prefs/prefs' => array('caption'=> LAN_PREFS, 'perm' => '0'),
|
'prefs/prefs' => array('caption'=> LAN_PREFS, 'perm' => '0'),
|
||||||
|
|
||||||
'maint/maint' => array('caption'=> ADLAN_40, 'perm' => '0'),
|
'maint/maint' => array('caption'=> ADLAN_40, 'perm' => '0'),
|
||||||
'main/templates' => array('caption'=> LAN_MAILOUT_262, 'perm' => '0'),
|
'main/templates' => array('caption'=> LAN_MAILOUT_262, 'perm' => '0'),
|
||||||
);
|
);
|
||||||
@ -256,6 +257,19 @@ class mailout_admin extends e_admin_dispatcher
|
|||||||
protected $adminMenuIcon = 'e-mail-24';
|
protected $adminMenuIcon = 'e-mail-24';
|
||||||
|
|
||||||
protected $menuTitle = LAN_MAILOUT_15;
|
protected $menuTitle = LAN_MAILOUT_15;
|
||||||
|
|
||||||
|
|
||||||
|
function init()
|
||||||
|
{
|
||||||
|
$mailer = e107::getPref('bulkmailer');
|
||||||
|
|
||||||
|
if($mailer === 'smtp' )
|
||||||
|
{
|
||||||
|
$this->adminMenu['other3'] = array('divider'=> true);
|
||||||
|
$this->adminMenu['prefs/test'] =array('caption'=> LAN_MAILOUT_270, 'perm' => '0'); //TODO LAN
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class mailout_main_ui extends e_admin_ui
|
class mailout_main_ui extends e_admin_ui
|
||||||
@ -603,7 +617,7 @@ class mailout_main_ui extends e_admin_ui
|
|||||||
$options = array('mailer'=>$pref['bulkmailer']);
|
$options = array('mailer'=>$pref['bulkmailer']);
|
||||||
|
|
||||||
|
|
||||||
if (!e107::getEmail($options)->sendEmail($sendto, LAN_MAILOUT_189, $eml))
|
if (e107::getEmail($options)->sendEmail($sendto, LAN_MAILOUT_189, $eml) !== true)
|
||||||
{
|
{
|
||||||
$mes->addError(($pref['bulkmailer'] == 'smtp') ? LAN_MAILOUT_67 : LAN_MAILOUT_106);
|
$mes->addError(($pref['bulkmailer'] == 'smtp') ? LAN_MAILOUT_67 : LAN_MAILOUT_106);
|
||||||
}
|
}
|
||||||
@ -961,8 +975,102 @@ class mailout_main_ui extends e_admin_ui
|
|||||||
}
|
}
|
||||||
|
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @TODO Do NOT translate, this is for debugging ONLY.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
function testPage()
|
||||||
|
{
|
||||||
|
|
||||||
|
require_once(e_HANDLER. 'phpmailer/PHPMailerAutoload.php');
|
||||||
|
|
||||||
|
$smtp = new SMTP;
|
||||||
|
$smtp->do_debug = SMTP::DEBUG_CONNECTION;
|
||||||
|
|
||||||
|
$mes = e107::getMessage();
|
||||||
|
$pref = e107::getPref();
|
||||||
|
|
||||||
|
$username = $pref['smtp_username'];
|
||||||
|
$pwd = $pref['smtp_password'];
|
||||||
|
$port = ($pref['smtp_port'] != 465) ? $pref['smtp_port'] : 25;
|
||||||
|
|
||||||
|
// var_dump($pref['smtp_password']);
|
||||||
|
// print_a($pref['smtp_password']);
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
//Connect to an SMTP server
|
||||||
|
if(!$smtp->connect($pref['smtp_server'], $port))
|
||||||
|
{
|
||||||
|
$mes->addError('Connect failed');
|
||||||
|
}
|
||||||
|
//Say hello
|
||||||
|
if(!$smtp->hello(gethostname()))
|
||||||
|
{
|
||||||
|
$mes->addError('EHLO failed: ' . $smtp->getError()['error']);
|
||||||
|
}
|
||||||
|
//Get the list of ESMTP services the server offers
|
||||||
|
$e = $smtp->getServerExtList();
|
||||||
|
//If server can do TLS encryption, use it
|
||||||
|
if(is_array($e) && array_key_exists('STARTTLS', $e))
|
||||||
|
{
|
||||||
|
$mes->addSuccess("TLS is supported. ");
|
||||||
|
$tlsok = $smtp->startTLS();
|
||||||
|
if(!$tlsok)
|
||||||
|
{
|
||||||
|
$mes->addError('Failed to start encryption: ' . $smtp->getError()['error']);
|
||||||
|
}
|
||||||
|
//Repeat EHLO after STARTTLS
|
||||||
|
if(!$smtp->hello(gethostname()))
|
||||||
|
{
|
||||||
|
$mes->addError('EHLO (2) failed: ' . $smtp->getError()['error']);
|
||||||
|
}
|
||||||
|
//Get new capabilities list, which will usually now include AUTH if it didn't before
|
||||||
|
$e = $smtp->getServerExtList();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$mes->addWarning("TLS is not supported. ");
|
||||||
|
|
||||||
|
}
|
||||||
|
//If server supports authentication, do it (even if no encryption)
|
||||||
|
if(is_array($e) && array_key_exists('AUTH', $e))
|
||||||
|
{
|
||||||
|
if($smtp->authenticate($username, $pwd))
|
||||||
|
{
|
||||||
|
$mes->addSuccess("Connected ok!");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$msg = e107::getParser()->lanVars(LAN_MAILOUT_271,array('x'=>$username, 'y'=>$pwd), true);
|
||||||
|
$mes->addError($msg . $smtp->getError()['error']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception $e)
|
||||||
|
{
|
||||||
|
$mes->addError('SMTP error: ' . $e->getMessage());
|
||||||
|
}
|
||||||
|
//Whatever happened, close the connection.
|
||||||
|
$smtp->quit(true);
|
||||||
|
|
||||||
|
$content = ob_get_contents();
|
||||||
|
|
||||||
|
ob_end_clean();
|
||||||
|
|
||||||
|
print_a($content);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function sendPage()
|
function sendPage()
|
||||||
{
|
{
|
||||||
|
@ -297,11 +297,11 @@ class e107Email extends PHPMailer
|
|||||||
{
|
{
|
||||||
case 'TLS' :
|
case 'TLS' :
|
||||||
$this->SMTPSecure = 'tls';
|
$this->SMTPSecure = 'tls';
|
||||||
$this->Port = $smtpPort; // Can also use port 587, and maybe even 25
|
$this->Port = ($smtpPort != 465) ? $smtpPort : 25; // Can also use port 587, and maybe even 25
|
||||||
break;
|
break;
|
||||||
case 'SSL' :
|
case 'SSL' :
|
||||||
$this->SMTPSecure = 'ssl';
|
$this->SMTPSecure = 'ssl';
|
||||||
$this->Port = $smtpPort;
|
$this->Port = ($smtpPort != 587) ? $smtpPort : 465;
|
||||||
break;
|
break;
|
||||||
default :
|
default :
|
||||||
if ($this->debug) echo "Invalid option: {$smtp_options['secure']}<br />";
|
if ($this->debug) echo "Invalid option: {$smtp_options['secure']}<br />";
|
||||||
@ -1071,10 +1071,13 @@ class e107Email extends PHPMailer
|
|||||||
if(!empty($eml['SMTPDebug']))
|
if(!empty($eml['SMTPDebug']))
|
||||||
{
|
{
|
||||||
e107::getMessage()->addError($this->ErrorInfo);
|
e107::getMessage()->addError($this->ErrorInfo);
|
||||||
|
$tmp = $this;
|
||||||
|
$tmp->pref = array();
|
||||||
|
e107::getMessage()->addDebug(print_a($tmp,true));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$this->clearAddresses(); // In case we send another email
|
$this->clearAddresses(); // In case we send another email
|
||||||
$this->clearCustomHeaders();
|
$this->clearCustomHeaders();
|
||||||
|
|
||||||
|
@ -231,7 +231,7 @@ class e107MailManager
|
|||||||
|
|
||||||
$this->mailOverrides = $overrides;
|
$this->mailOverrides = $overrides;
|
||||||
|
|
||||||
if(deftrue('e_DEBUG'))
|
if(deftrue('e_DEBUG_BULKMAIL'))
|
||||||
{
|
{
|
||||||
$this->debugMode = true;
|
$this->debugMode = true;
|
||||||
}
|
}
|
||||||
|
@ -291,4 +291,10 @@ define("LAN_MAILOUT_267", "Generate Public/Private keys");
|
|||||||
define("LAN_MAILOUT_268", "Developer Mode Only");
|
define("LAN_MAILOUT_268", "Developer Mode Only");
|
||||||
define("LAN_MAILOUT_269", "Send Later");
|
define("LAN_MAILOUT_269", "Send Later");
|
||||||
|
|
||||||
?>
|
define("LAN_MAILOUT_270", "Test SMTP Connection");
|
||||||
|
define("LAN_MAILOUT_271", "Authentication failed with username ([x]) and password ([y]):");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
?>
|
Loading…
x
Reference in New Issue
Block a user