3 namespace Wallabag\UserBundle\Mailer
;
5 use Scheb\TwoFactorBundle\Mailer\AuthCodeMailerInterface
;
6 use Scheb\TwoFactorBundle\Model\Email\TwoFactorInterface
;
10 * Custom mailer for TwoFactorBundle email.
11 * It adds a custom template to the email so user won't get a lonely authentication code but a complete email.
13 class AuthCodeMailer
implements AuthCodeMailerInterface
23 * Twig to render the html's email.
30 * Sender email address.
44 * Support URL to report any bugs.
51 * Url for the wallabag instance (only used for image in the HTML email template).
58 * Initialize the auth code mailer with the SwiftMailer object.
60 * @param string $senderEmail
61 * @param string $senderName
62 * @param string $supportUrl wallabag support url
63 * @param string $wallabagUrl wallabag instance url
65 public function __construct(\Swift_Mailer
$mailer, Environment
$twig, $senderEmail, $senderName, $supportUrl, $wallabagUrl)
67 $this->mailer
= $mailer;
69 $this->senderEmail
= $senderEmail;
70 $this->senderName
= $senderName;
71 $this->supportUrl
= $supportUrl;
72 $this->wallabagUrl
= $wallabagUrl;
76 * Send the auth code to the user via email.
78 public function sendAuthCode(TwoFactorInterface
$user): void
80 $template = $this->twig
->loadTemplate('WallabagUserBundle:TwoFactor:email_auth_code.html.twig');
82 $subject = $template->renderBlock('subject', []);
83 $bodyHtml = $template->renderBlock('body_html', [
84 'user' => $user->getName(),
85 'code' => $user->getEmailAuthCode(),
86 'support_url' => $this->supportUrl
,
87 'wallabag_url' => $this->wallabagUrl
,
89 $bodyText = $template->renderBlock('body_text', [
90 'user' => $user->getName(),
91 'code' => $user->getEmailAuthCode(),
92 'support_url' => $this->supportUrl
,
95 $message = new \
Swift_Message();
97 ->setTo($user->getEmailAuthRecipient())
98 ->setFrom($this->senderEmail
, $this->senderName
)
99 ->setSubject($subject)
100 ->setBody($bodyText, 'text/plain')
101 ->addPart($bodyHtml, 'text/html')
104 $this->mailer
->send($message);