diff options
author | Lukas Reschke <lukas@statuscode.ch> | 2017-06-09 11:34:08 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-09 11:34:08 +0200 |
commit | 0433c4e4cf92b80fbfabcf0847e6e7c55a854499 (patch) | |
tree | 90a21a46452e58027e056d0094bbf1aa91a1205c /settings | |
parent | e99bcc496d535e7dc7a4b909deebcc91bf0b96b6 (diff) | |
parent | cec6ceba9c7f33033db2098584268b1c8f0753a4 (diff) | |
download | nextcloud-server-0433c4e4cf92b80fbfabcf0847e6e7c55a854499.tar.gz nextcloud-server-0433c4e4cf92b80fbfabcf0847e6e7c55a854499.zip |
Merge pull request #5118 from nextcloud/use-language-of-recipient-not-admin
Use the language of the recipient not the actor
Diffstat (limited to 'settings')
-rw-r--r-- | settings/Hooks.php | 33 |
1 files changed, 32 insertions, 1 deletions
diff --git a/settings/Hooks.php b/settings/Hooks.php index 9addaea5a91..daf3a40cf1b 100644 --- a/settings/Hooks.php +++ b/settings/Hooks.php @@ -23,11 +23,13 @@ namespace OC\Settings; use OC\Settings\Activity\Provider; use OCP\Activity\IManager as IActivityManager; +use OCP\IConfig; use OCP\IL10N; use OCP\IURLGenerator; use OCP\IUser; use OCP\IUserManager; use OCP\IUserSession; +use OCP\L10N\IFactory; use OCP\Mail\IMailer; class Hooks { @@ -42,15 +44,28 @@ class Hooks { protected $urlGenerator; /** @var IMailer */ protected $mailer; + /** @var IConfig */ + protected $config; + /** @var IFactory */ + protected $languageFactory; /** @var IL10N */ protected $l; - public function __construct(IActivityManager $activityManager, IUserManager $userManager, IUserSession $userSession, IURLGenerator $urlGenerator, IMailer $mailer, IL10N $l) { + public function __construct(IActivityManager $activityManager, + IUserManager $userManager, + IUserSession $userSession, + IURLGenerator $urlGenerator, + IMailer $mailer, + IConfig $config, + IFactory $languageFactory, + IL10N $l) { $this->activityManager = $activityManager; $this->userManager = $userManager; $this->userSession = $userSession; $this->urlGenerator = $urlGenerator; $this->mailer = $mailer; + $this->config = $config; + $this->languageFactory = $languageFactory; $this->l = $l; } @@ -77,6 +92,14 @@ class Hooks { $actor = $this->userSession->getUser(); if ($actor instanceof IUser) { if ($actor->getUID() !== $user->getUID()) { + $this->l = $this->languageFactory->get( + 'settings', + $this->config->getUserValue( + $user->getUID(), 'core', 'lang', + $this->config->getSystemValue('default_language', 'en') + ) + ); + $text = $this->l->t('%1$s changed your password on %2$s.', [$actor->getDisplayName(), $instanceUrl]); $event->setAuthor($actor->getUID()) ->setSubject(Provider::PASSWORD_CHANGED_BY, [$actor->getUID()]); @@ -133,6 +156,14 @@ class Hooks { $actor = $this->userSession->getUser(); if ($actor instanceof IUser) { if ($actor->getUID() !== $user->getUID()) { + $this->l = $this->languageFactory->get( + 'settings', + $this->config->getUserValue( + $user->getUID(), 'core', 'lang', + $this->config->getSystemValue('default_language', 'en') + ) + ); + $text = $this->l->t('%1$s changed your email address on %2$s.', [$actor->getDisplayName(), $instanceUrl]); $event->setAuthor($actor->getUID()) ->setSubject(Provider::EMAIL_CHANGED_BY, [$actor->getUID()]); |