Skip to content

Commit

Permalink
Make emails translatable
Browse files Browse the repository at this point in the history
closes #267
  • Loading branch information
tobyzerner committed Oct 19, 2015
1 parent 7e763ec commit 43c44ef
Show file tree
Hide file tree
Showing 6 changed files with 39 additions and 45 deletions.
22 changes: 16 additions & 6 deletions src/Core/Command/RequestPasswordResetHandler.php
Expand Up @@ -18,6 +18,7 @@
use Illuminate\Database\Eloquent\ModelNotFoundException;
use Flarum\Core;
use Flarum\Forum\UrlGenerator;
use Symfony\Component\Translation\TranslatorInterface;

class RequestPasswordResetHandler
{
Expand All @@ -41,18 +42,25 @@ class RequestPasswordResetHandler
*/
protected $url;

/**
* @var TranslatorInterface
*/
protected $translator;

/**
* @param UserRepository $users
* @param SettingsRepository $settings
* @param Mailer $mailer
* @param UrlGenerator $url
* @param TranslatorInterface $translator
*/
public function __construct(UserRepository $users, SettingsRepository $settings, Mailer $mailer, UrlGenerator $url)
public function __construct(UserRepository $users, SettingsRepository $settings, Mailer $mailer, UrlGenerator $url, TranslatorInterface $translator)
{
$this->users = $users;
$this->settings = $settings;
$this->mailer = $mailer;
$this->url = $url;
$this->translator = $translator;
}

/**
Expand All @@ -72,14 +80,16 @@ public function handle(RequestPasswordReset $command)
$token->save();

$data = [
'username' => $user->username,
'url' => $this->url->toRoute('resetPassword', ['token' => $token->id]),
'forumTitle' => $this->settings->get('forum_title'),
'{username}' => $user->username,
'{url}' => $this->url->toRoute('resetPassword', ['token' => $token->id]),
'{forum}' => $this->settings->get('forum_title'),
];

$this->mailer->send(['text' => 'flarum::emails.resetPassword'], $data, function (Message $message) use ($user) {
$body = $this->translator->trans('core.email.reset_password.body', $data);

$this->mailer->raw($body, function (Message $message) use ($user, $data) {
$message->to($user->email);
$message->subject('Reset Your Password');
$message->subject('['.$data['{forum}'].'] '.$this->translator->trans('core.email.reset_password.subject'));
});

return $user;
Expand Down
36 changes: 22 additions & 14 deletions src/Core/Listener/EmailConfirmationMailer.php
Expand Up @@ -20,6 +20,7 @@
use Illuminate\Contracts\Events\Dispatcher;
use Illuminate\Contracts\Mail\Mailer;
use Illuminate\Mail\Message;
use Symfony\Component\Translation\TranslatorInterface;

class EmailConfirmationMailer
{
Expand All @@ -32,21 +33,29 @@ class EmailConfirmationMailer
* @var Mailer
*/
protected $mailer;

/**
* @var UrlGenerator
*/
private $url;
protected $url;

/**
* @var TranslatorInterface
*/
protected $translator;

/**
* @param \Flarum\Settings\SettingsRepository $settings
* @param Mailer $mailer
* @param UrlGenerator $url
* @param TranslatorInterface $translator
*/
public function __construct(SettingsRepository $settings, Mailer $mailer, UrlGenerator $url)
public function __construct(SettingsRepository $settings, Mailer $mailer, UrlGenerator $url, TranslatorInterface $translator)
{
$this->settings = $settings;
$this->mailer = $mailer;
$this->url = $url;
$this->translator = $translator;
}

/**
Expand All @@ -71,9 +80,11 @@ public function whenUserWasRegistered(UserWasRegistered $event)

$data = $this->getEmailData($user, $user->email);

$this->mailer->send(['text' => 'flarum::emails.activateAccount'], $data, function (Message $message) use ($user) {
$body = $this->translator->trans('core.email.activate_account.body', $data);

$this->mailer->raw($body, function (Message $message) use ($user, $data) {
$message->to($user->email);
$message->subject('Activate Your New Account');
$message->subject('['.$data['{forum}'].'] '.$this->translator->trans('core.email.activate_account.subject'));
});
}

Expand All @@ -85,16 +96,17 @@ public function whenUserEmailChangeWasRequested(UserEmailChangeWasRequested $eve
$email = $event->email;
$data = $this->getEmailData($event->user, $email);

$this->mailer->send(['text' => 'flarum::emails.confirmEmail'], $data, function (Message $message) use ($email) {
$body = $this->translator->trans('core.email.confirm_email.body', $data);

$this->mailer->raw($body, function (Message $message) use ($email, $data) {
$message->to($email);
$message->subject('Confirm Your New Email Address');
$message->subject('['.$data['{forum}'].'] '.$this->translator->trans('core.email.confirm_email.subject'));
});
}

/**
* @param User $user
* @param string $email
*
* @return EmailToken
*/
protected function generateToken(User $user, $email)
Expand All @@ -110,20 +122,16 @@ protected function generateToken(User $user, $email)
*
* @param User $user
* @param string $email
*
* @return array
*/
protected function getEmailData(User $user, $email)
{
$token = $this->generateToken($user, $email);

// TODO: Need to use AbstractUrlGenerator, but since this is part of core we
// don't know that the forum routes will be loaded. Should the confirm
// email route be part of core??
return [
'username' => $user->username,
'url' => $this->url->toRoute('confirmEmail', ['token' => $token->id]),
'forumTitle' => $this->settings->get('forum_title')
'{username}' => $user->username,
'{url}' => $this->url->toRoute('confirmEmail', ['token' => $token->id]),
'{forum}' => $this->settings->get('forum_title')
];
}
}
2 changes: 1 addition & 1 deletion src/Forum/Controller/ResetPasswordController.php
Expand Up @@ -34,8 +34,8 @@ public function __construct(Factory $view)

/**
* @param Request $request
* @param array $routeParams
* @return \Illuminate\Contracts\View\View
* @throws InvalidConfirmationTokenException
*/
public function render(Request $request)
{
Expand Down
8 changes: 0 additions & 8 deletions views/emails/activateAccount.blade.php

This file was deleted.

8 changes: 0 additions & 8 deletions views/emails/confirmEmail.blade.php

This file was deleted.

8 changes: 0 additions & 8 deletions views/emails/resetPassword.blade.php

This file was deleted.

0 comments on commit 43c44ef

Please sign in to comment.