mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
3ea5015f8b
* API Replace existing Email and Mailer classes with SwiftMailer powered email system * DOCS New Email docs * Initial feedback from Damian * Making Mailer an interface * Templates relocated * Round of feedback * More robust approach to plain parts * Revert changes to TestMailer
126 lines
3.4 KiB
PHP
126 lines
3.4 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\Dev;
|
|
|
|
use SilverStripe\Control\Email\Mailer;
|
|
use Swift_Attachment;
|
|
|
|
class TestMailer implements Mailer
|
|
{
|
|
/**
|
|
* @var array
|
|
*/
|
|
protected $emailsSent = [];
|
|
|
|
public function send($email)
|
|
{
|
|
// Detect body type
|
|
$htmlContent = null;
|
|
$plainContent = null;
|
|
if ($email->getSwiftMessage()->getContentType() === 'text/plain') {
|
|
$type = 'plain';
|
|
$plainContent = $email->getBody();
|
|
} else {
|
|
$type = 'html';
|
|
$htmlContent = $email->getBody();
|
|
$plainPart = $email->findPlainPart();
|
|
if ($plainPart) {
|
|
$plainContent = $plainPart->getBody();
|
|
}
|
|
}
|
|
|
|
// Get attachments
|
|
$attachedFiles = [];
|
|
foreach ($email->getSwiftMessage()->getChildren() as $child) {
|
|
if ($child instanceof Swift_Attachment) {
|
|
$attachedFiles[] = [
|
|
'contents' => $child->getBody(),
|
|
'filename' => $child->getFilename(),
|
|
'mimetype' => $child->getContentType(),
|
|
];
|
|
}
|
|
}
|
|
|
|
// Serialise email
|
|
$serialised = [
|
|
'Type' => $type,
|
|
'To' => implode(';', array_keys($email->getTo() ?: [])),
|
|
'From' => implode(';', array_keys($email->getFrom() ?: [])),
|
|
'Subject' => $email->getSubject(),
|
|
'Content' => $email->getBody(),
|
|
'AttachedFiles' => $attachedFiles
|
|
];
|
|
if ($plainContent) {
|
|
$serialised['PlainContent'] = $plainContent;
|
|
}
|
|
if ($htmlContent) {
|
|
$serialised['HtmlContent'] = $htmlContent;
|
|
}
|
|
|
|
$this->saveEmail($serialised);
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Save a single email to the log
|
|
*
|
|
* @param array $data A map of information about the email
|
|
*/
|
|
protected function saveEmail($data)
|
|
{
|
|
$this->emailsSent[] = $data;
|
|
}
|
|
|
|
/**
|
|
* Clear the log of emails sent
|
|
*/
|
|
public function clearEmails()
|
|
{
|
|
$this->emailsSent = array();
|
|
}
|
|
|
|
/**
|
|
* Search for an email that was sent.
|
|
* All of the parameters can either be a string, or, if they start with "/", a PREG-compatible regular expression.
|
|
*
|
|
* @param string $to
|
|
* @param string $from
|
|
* @param string $subject
|
|
* @param string $content
|
|
* @return array Contains the keys: 'type', 'to', 'from', 'subject', 'content', 'plainContent', 'attachedFiles',
|
|
* 'customHeaders', 'htmlContent', 'inlineImages'
|
|
*/
|
|
public function findEmail($to, $from = null, $subject = null, $content = null)
|
|
{
|
|
$compare = [
|
|
'To' => $to,
|
|
'From' => $from,
|
|
'Subject' => $subject,
|
|
'Content' => $content,
|
|
];
|
|
|
|
foreach ($this->emailsSent as $email) {
|
|
$matched = true;
|
|
|
|
foreach (array('To','From','Subject','Content') as $field) {
|
|
if ($value = $compare[$field]) {
|
|
if ($value[0] == '/') {
|
|
$matched = preg_match($value, $email[$field]);
|
|
} else {
|
|
$matched = ($value == $email[$field]);
|
|
}
|
|
if (!$matched) {
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($matched) {
|
|
return $email;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
}
|