Merge pull request #12766 from stalker314314/streaming-options
Expose Swift Mailer streaming options in config, fixes #12702
This commit is contained in:
commit
6f994be665
3 changed files with 33 additions and 0 deletions
|
@ -421,6 +421,13 @@ $CONFIG = array(
|
|||
*/
|
||||
'mail_send_plaintext_only' => false,
|
||||
|
||||
/**
|
||||
* This depends on ``mail_smtpmode``. Array of additional streams options that
|
||||
* will be passed to underlying Swift mailer implementation.
|
||||
* Defaults to an empty array.
|
||||
*/
|
||||
'mail_smtpstreamoptions' => array(),
|
||||
|
||||
/**
|
||||
* Which mode is used for sendmail/qmail: ``smtp`` or ``pipe``.
|
||||
*
|
||||
|
|
|
@ -259,6 +259,10 @@ class Mailer implements IMailer {
|
|||
if (!empty($smtpSecurity)) {
|
||||
$transport->setEncryption($smtpSecurity);
|
||||
}
|
||||
$streamingOptions = $this->config->getSystemValue('mail_smtpstreamoptions', []);
|
||||
if (is_array($streamingOptions) && !empty($streamingOptions)) {
|
||||
$transport->setStreamOptions($streamingOptions);
|
||||
}
|
||||
|
||||
return $transport;
|
||||
}
|
||||
|
|
|
@ -167,4 +167,26 @@ class MailerTest extends TestCase {
|
|||
|
||||
$this->assertSame(EMailTemplate::class, get_class($this->mailer->createEMailTemplate('tests.MailerTest')));
|
||||
}
|
||||
|
||||
public function testStreamingOptions() {
|
||||
$this->config->method('getSystemValue')
|
||||
->will($this->returnValueMap([
|
||||
['mail_smtpmode', 'smtp', 'smtp'],
|
||||
['mail_smtpstreamoptions', [], ['foo' => 1]]
|
||||
]));
|
||||
$mailer = self::invokePrivate($this->mailer, 'getInstance');
|
||||
$this->assertEquals(1, count($mailer->getTransport()->getStreamOptions()));
|
||||
$this->assertTrue(isset($mailer->getTransport()->getStreamOptions()['foo']));
|
||||
|
||||
}
|
||||
|
||||
public function testStreamingOptionsWrongType() {
|
||||
$this->config->method('getSystemValue')
|
||||
->will($this->returnValueMap([
|
||||
['mail_smtpmode', 'smtp', 'smtp'],
|
||||
['mail_smtpstreamoptions', [], 'bar']
|
||||
]));
|
||||
$mailer = self::invokePrivate($this->mailer, 'getInstance');
|
||||
$this->assertEquals(0, count($mailer->getTransport()->getStreamOptions()));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue