aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/lib/Activity/SecurityProvider.php
diff options
context:
space:
mode:
Diffstat (limited to 'apps/settings/lib/Activity/SecurityProvider.php')
-rw-r--r--apps/settings/lib/Activity/SecurityProvider.php84
1 files changed, 84 insertions, 0 deletions
diff --git a/apps/settings/lib/Activity/SecurityProvider.php b/apps/settings/lib/Activity/SecurityProvider.php
new file mode 100644
index 00000000000..658e2e7b949
--- /dev/null
+++ b/apps/settings/lib/Activity/SecurityProvider.php
@@ -0,0 +1,84 @@
+<?php
+
+declare(strict_types=1);
+
+/**
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
+ */
+namespace OCA\Settings\Activity;
+
+use OCP\Activity\Exceptions\UnknownActivityException;
+use OCP\Activity\IEvent;
+use OCP\Activity\IManager;
+use OCP\Activity\IProvider;
+use OCP\IURLGenerator;
+use OCP\L10N\IFactory as L10nFactory;
+
+class SecurityProvider implements IProvider {
+
+ public function __construct(
+ private L10nFactory $l10n,
+ private IURLGenerator $urlGenerator,
+ private IManager $activityManager,
+ ) {
+ }
+
+ public function parse($language, IEvent $event, ?IEvent $previousEvent = null) {
+ if ($event->getType() !== 'security') {
+ throw new UnknownActivityException();
+ }
+
+ $l = $this->l10n->get('settings', $language);
+
+ switch ($event->getSubject()) {
+ case 'twofactor_success':
+ $params = $event->getSubjectParameters();
+ $event->setParsedSubject($l->t('You successfully logged in using two-factor authentication (%1$s)', [
+ $params['provider'],
+ ]));
+ if ($this->activityManager->getRequirePNG()) {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/password.png')));
+ } else {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/password.svg')));
+ }
+ break;
+ case 'twofactor_failed':
+ $params = $event->getSubjectParameters();
+ $event->setParsedSubject($l->t('A login attempt using two-factor authentication failed (%1$s)', [
+ $params['provider'],
+ ]));
+ if ($this->activityManager->getRequirePNG()) {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/password.png')));
+ } else {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/password.svg')));
+ }
+ break;
+ case 'remote_wipe_start':
+ $params = $event->getSubjectParameters();
+ $event->setParsedSubject($l->t('Remote wipe was started on %1$s', [
+ $params['name'],
+ ]));
+ if ($this->activityManager->getRequirePNG()) {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/delete.png')));
+ } else {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/delete.svg')));
+ }
+ break;
+ case 'remote_wipe_finish':
+ $params = $event->getSubjectParameters();
+ $event->setParsedSubject($l->t('Remote wipe has finished on %1$s', [
+ $params['name'],
+ ]));
+ if ($this->activityManager->getRequirePNG()) {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/delete.png')));
+ } else {
+ $event->setIcon($this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/delete.svg')));
+ }
+ break;
+ default:
+ throw new UnknownActivityException();
+ }
+ return $event;
+ }
+}