diff options
Diffstat (limited to 'apps/settings/lib/Activity')
-rw-r--r-- | apps/settings/lib/Activity/GroupProvider.php | 132 | ||||
-rw-r--r-- | apps/settings/lib/Activity/GroupSetting.php | 79 | ||||
-rw-r--r-- | apps/settings/lib/Activity/Provider.php | 165 | ||||
-rw-r--r-- | apps/settings/lib/Activity/SecurityFilter.php | 44 | ||||
-rw-r--r-- | apps/settings/lib/Activity/SecurityProvider.php | 84 | ||||
-rw-r--r-- | apps/settings/lib/Activity/SecuritySetting.php | 46 | ||||
-rw-r--r-- | apps/settings/lib/Activity/Setting.php | 79 |
7 files changed, 629 insertions, 0 deletions
diff --git a/apps/settings/lib/Activity/GroupProvider.php b/apps/settings/lib/Activity/GroupProvider.php new file mode 100644 index 00000000000..2d492265cf4 --- /dev/null +++ b/apps/settings/lib/Activity/GroupProvider.php @@ -0,0 +1,132 @@ +<?php + +/** + * 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\IGroup; +use OCP\IGroupManager; +use OCP\IURLGenerator; +use OCP\IUserManager; +use OCP\L10N\IFactory as L10nFactory; + +class GroupProvider implements IProvider { + public const ADDED_TO_GROUP = 'group_added'; + public const REMOVED_FROM_GROUP = 'group_removed'; + + /** @var string[] */ + protected $groupDisplayNames = []; + + + public function __construct( + private L10nFactory $l10n, + private IURLGenerator $urlGenerator, + private IManager $activityManager, + protected IUserManager $userManager, + protected IGroupManager $groupManager, + ) { + } + + public function parse($language, IEvent $event, ?IEvent $previousEvent = null) { + if ($event->getType() !== 'group_settings') { + throw new UnknownActivityException(); + } + + $l = $this->l10n->get('settings', $language); + + $params = $event->getSubjectParameters(); + $parsedParameters = [ + 'user' => $this->generateUserParameter($params['user']), + 'group' => $this->generateGroupParameter($params['group']), + ]; + + if (isset($params['actor'])) { + $parsedParameters['actor'] = $this->generateUserParameter($params['actor']); + } + + switch ($event->getSubject()) { + case self::ADDED_TO_GROUP: + if (isset($parsedParameters['actor'])) { + if ($this->activityManager->getCurrentUserId() === $params['user']) { + $subject = $l->t('{actor} added you to group {group}'); + } elseif (isset($params['actor']) && $this->activityManager->getCurrentUserId() === $params['actor']) { + $subject = $l->t('You added {user} to group {group}'); + } else { + $subject = $l->t('{actor} added {user} to group {group}'); + } + } elseif ($this->activityManager->getCurrentUserId() === $params['user']) { + $subject = $l->t('An administrator added you to group {group}'); + } else { + $subject = $l->t('An administrator added {user} to group {group}'); + } + break; + case self::REMOVED_FROM_GROUP: + if (isset($parsedParameters['actor'])) { + if ($this->activityManager->getCurrentUserId() === $params['user']) { + $subject = $l->t('{actor} removed you from group {group}'); + } elseif (isset($params['actor']) && $this->activityManager->getCurrentUserId() === $params['actor']) { + $subject = $l->t('You removed {user} from group {group}'); + } else { + $subject = $l->t('{actor} removed {user} from group {group}'); + } + } elseif ($this->activityManager->getCurrentUserId() === $params['user']) { + $subject = $l->t('An administrator removed you from group {group}'); + } else { + $subject = $l->t('An administrator removed {user} from group {group}'); + } + break; + default: + throw new UnknownActivityException(); + } + + $this->setSubjects($event, $subject, $parsedParameters); + + return $event; + } + + protected function setSubjects(IEvent $event, string $subject, array $parameters): void { + $event->setRichSubject($subject, $parameters); + } + + /** + * @param string $gid + * @return array + */ + protected function generateGroupParameter(string $gid): array { + if (!isset($this->groupDisplayNames[$gid])) { + $this->groupDisplayNames[$gid] = $this->getGroupDisplayName($gid); + } + + return [ + 'type' => 'user-group', + 'id' => $gid, + 'name' => $this->groupDisplayNames[$gid], + ]; + } + + /** + * @param string $gid + * @return string + */ + protected function getGroupDisplayName(string $gid): string { + $group = $this->groupManager->get($gid); + if ($group instanceof IGroup) { + return $group->getDisplayName(); + } + return $gid; + } + + protected function generateUserParameter(string $uid): array { + return [ + 'type' => 'user', + 'id' => $uid, + 'name' => $this->userManager->getDisplayName($uid) ?? $uid, + ]; + } +} diff --git a/apps/settings/lib/Activity/GroupSetting.php b/apps/settings/lib/Activity/GroupSetting.php new file mode 100644 index 00000000000..917f4a7ef26 --- /dev/null +++ b/apps/settings/lib/Activity/GroupSetting.php @@ -0,0 +1,79 @@ +<?php + +/** + * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +namespace OCA\Settings\Activity; + +use OCP\Activity\ISetting; +use OCP\IL10N; + +class GroupSetting implements ISetting { + + /** + * @param IL10N $l + */ + public function __construct( + protected IL10N $l, + ) { + } + + /** + * @return string Lowercase a-z and underscore only identifier + * @since 11.0.0 + */ + public function getIdentifier(): string { + return 'group_settings'; + } + + /** + * @return string A translated string + * @since 11.0.0 + */ + public function getName(): string { + return $this->l->t('Your <strong>group memberships</strong> were modified'); + } + + /** + * @return int whether the filter should be rather on the top or bottom of + * the admin section. The filters are arranged in ascending order of the + * priority values. It is required to return a value between 0 and 100. + * @since 11.0.0 + */ + public function getPriority(): int { + return 0; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function canChangeStream(): bool { + return false; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function isDefaultEnabledStream(): bool { + return true; + } + + /** + * @return bool True when the option can be changed for the mail + * @since 11.0.0 + */ + public function canChangeMail(): bool { + return true; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function isDefaultEnabledMail(): bool { + return true; + } +} diff --git a/apps/settings/lib/Activity/Provider.php b/apps/settings/lib/Activity/Provider.php new file mode 100644 index 00000000000..c31a900abd5 --- /dev/null +++ b/apps/settings/lib/Activity/Provider.php @@ -0,0 +1,165 @@ +<?php + +declare(strict_types=1); + +/** + * SPDX-FileCopyrightText: 2017 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\IL10N; +use OCP\IURLGenerator; +use OCP\IUserManager; +use OCP\L10N\IFactory; + +class Provider implements IProvider { + public const PASSWORD_CHANGED_BY = 'password_changed_by'; + public const PASSWORD_CHANGED_SELF = 'password_changed_self'; + public const PASSWORD_RESET = 'password_changed'; + public const PASSWORD_RESET_SELF = 'password_reset_self'; + public const EMAIL_CHANGED_BY = 'email_changed_by'; + public const EMAIL_CHANGED_SELF = 'email_changed_self'; + public const EMAIL_CHANGED = 'email_changed'; + public const APP_TOKEN_CREATED = 'app_token_created'; + public const APP_TOKEN_DELETED = 'app_token_deleted'; + public const APP_TOKEN_RENAMED = 'app_token_renamed'; + public const APP_TOKEN_FILESYSTEM_GRANTED = 'app_token_filesystem_granted'; + public const APP_TOKEN_FILESYSTEM_REVOKED = 'app_token_filesystem_revoked'; + + /** @var IL10N */ + protected $l; + + public function __construct( + protected IFactory $languageFactory, + protected IURLGenerator $url, + protected IUserManager $userManager, + private IManager $activityManager, + ) { + } + + /** + * @param string $language + * @param IEvent $event + * @param IEvent|null $previousEvent + * @return IEvent + * @throws UnknownActivityException + * @since 11.0.0 + */ + public function parse($language, IEvent $event, ?IEvent $previousEvent = null): IEvent { + if ($event->getApp() !== 'settings') { + throw new UnknownActivityException('Unknown app'); + } + + $this->l = $this->languageFactory->get('settings', $language); + + if ($this->activityManager->getRequirePNG()) { + $event->setIcon($this->url->getAbsoluteURL($this->url->imagePath('settings', 'personal.png'))); + } else { + $event->setIcon($this->url->getAbsoluteURL($this->url->imagePath('settings', 'personal.svg'))); + } + + if ($event->getSubject() === self::PASSWORD_CHANGED_BY) { + $subject = $this->l->t('{actor} changed your password'); + } elseif ($event->getSubject() === self::PASSWORD_CHANGED_SELF) { + $subject = $this->l->t('You changed your password'); + } elseif ($event->getSubject() === self::PASSWORD_RESET) { + $subject = $this->l->t('Your password was reset by an administrator'); + } elseif ($event->getSubject() === self::PASSWORD_RESET_SELF) { + $subject = $this->l->t('Your password was reset'); + } elseif ($event->getSubject() === self::EMAIL_CHANGED_BY) { + $subject = $this->l->t('{actor} changed your email address'); + } elseif ($event->getSubject() === self::EMAIL_CHANGED_SELF) { + $subject = $this->l->t('You changed your email address'); + } elseif ($event->getSubject() === self::EMAIL_CHANGED) { + $subject = $this->l->t('Your email address was changed by an administrator'); + } elseif ($event->getSubject() === self::APP_TOKEN_CREATED) { + if ($event->getAffectedUser() === $event->getAuthor()) { + $subject = $this->l->t('You created an app password for a session named "{token}"'); + } else { + $subject = $this->l->t('An administrator created an app password for a session named "{token}"'); + } + } elseif ($event->getSubject() === self::APP_TOKEN_DELETED) { + $subject = $this->l->t('You deleted app password "{token}"'); + } elseif ($event->getSubject() === self::APP_TOKEN_RENAMED) { + $subject = $this->l->t('You renamed app password "{token}" to "{newToken}"'); + } elseif ($event->getSubject() === self::APP_TOKEN_FILESYSTEM_GRANTED) { + $subject = $this->l->t('You granted filesystem access to app password "{token}"'); + } elseif ($event->getSubject() === self::APP_TOKEN_FILESYSTEM_REVOKED) { + $subject = $this->l->t('You revoked filesystem access from app password "{token}"'); + } else { + throw new UnknownActivityException('Unknown subject'); + } + + $parsedParameters = $this->getParameters($event); + $this->setSubjects($event, $subject, $parsedParameters); + + return $event; + } + + /** + * @param IEvent $event + * @return array + * @throws UnknownActivityException + */ + protected function getParameters(IEvent $event): array { + $subject = $event->getSubject(); + $parameters = $event->getSubjectParameters(); + + switch ($subject) { + case self::PASSWORD_CHANGED_SELF: + case self::PASSWORD_RESET: + case self::PASSWORD_RESET_SELF: + case self::EMAIL_CHANGED_SELF: + case self::EMAIL_CHANGED: + return []; + case self::PASSWORD_CHANGED_BY: + case self::EMAIL_CHANGED_BY: + return [ + 'actor' => $this->generateUserParameter($parameters[0]), + ]; + case self::APP_TOKEN_CREATED: + case self::APP_TOKEN_DELETED: + case self::APP_TOKEN_FILESYSTEM_GRANTED: + case self::APP_TOKEN_FILESYSTEM_REVOKED: + return [ + 'token' => [ + 'type' => 'highlight', + 'id' => (string)$event->getObjectId(), + 'name' => $parameters['name'], + ] + ]; + case self::APP_TOKEN_RENAMED: + return [ + 'token' => [ + 'type' => 'highlight', + 'id' => (string)$event->getObjectId(), + 'name' => $parameters['name'], + ], + 'newToken' => [ + 'type' => 'highlight', + 'id' => (string)$event->getObjectId(), + 'name' => $parameters['newName'], + ] + ]; + } + + throw new UnknownActivityException('Unknown subject'); + } + + protected function setSubjects(IEvent $event, string $subject, array $parameters): void { + $event->setRichSubject($subject, $parameters); + } + + protected function generateUserParameter(string $uid): array { + return [ + 'type' => 'user', + 'id' => $uid, + 'name' => $this->userManager->getDisplayName($uid) ?? $uid, + ]; + } +} diff --git a/apps/settings/lib/Activity/SecurityFilter.php b/apps/settings/lib/Activity/SecurityFilter.php new file mode 100644 index 00000000000..9a32e82a984 --- /dev/null +++ b/apps/settings/lib/Activity/SecurityFilter.php @@ -0,0 +1,44 @@ +<?php + +/** + * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +namespace OCA\Settings\Activity; + +use OCP\Activity\IFilter; +use OCP\IL10N; +use OCP\IURLGenerator; + +class SecurityFilter implements IFilter { + + public function __construct( + private IURLGenerator $urlGenerator, + private IL10N $l10n, + ) { + } + + public function allowedApps() { + return []; + } + + public function filterTypes(array $types) { + return array_intersect(['security'], $types); + } + + public function getIcon() { + return $this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/password.svg')); + } + + public function getIdentifier() { + return 'security'; + } + + public function getName() { + return $this->l10n->t('Security'); + } + + public function getPriority() { + return 30; + } +} 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; + } +} diff --git a/apps/settings/lib/Activity/SecuritySetting.php b/apps/settings/lib/Activity/SecuritySetting.php new file mode 100644 index 00000000000..9226b5aea5b --- /dev/null +++ b/apps/settings/lib/Activity/SecuritySetting.php @@ -0,0 +1,46 @@ +<?php + +/** + * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +namespace OCA\Settings\Activity; + +use OCP\Activity\ISetting; +use OCP\IL10N; + +class SecuritySetting implements ISetting { + + public function __construct( + private IL10N $l10n, + ) { + } + + public function canChangeMail() { + return false; + } + + public function canChangeStream() { + return false; + } + + public function getIdentifier() { + return 'security'; + } + + public function getName() { + return $this->l10n->t('Security'); + } + + public function getPriority() { + return 30; + } + + public function isDefaultEnabledMail() { + return true; + } + + public function isDefaultEnabledStream() { + return true; + } +} diff --git a/apps/settings/lib/Activity/Setting.php b/apps/settings/lib/Activity/Setting.php new file mode 100644 index 00000000000..f9c659594d6 --- /dev/null +++ b/apps/settings/lib/Activity/Setting.php @@ -0,0 +1,79 @@ +<?php + +/** + * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors + * SPDX-License-Identifier: AGPL-3.0-or-later + */ +namespace OCA\Settings\Activity; + +use OCP\Activity\ISetting; +use OCP\IL10N; + +class Setting implements ISetting { + + /** + * @param IL10N $l + */ + public function __construct( + protected IL10N $l, + ) { + } + + /** + * @return string Lowercase a-z and underscore only identifier + * @since 11.0.0 + */ + public function getIdentifier() { + return 'personal_settings'; + } + + /** + * @return string A translated string + * @since 11.0.0 + */ + public function getName() { + return $this->l->t('Your <strong>password</strong> or <strong>email</strong> was modified'); + } + + /** + * @return int whether the filter should be rather on the top or bottom of + * the admin section. The filters are arranged in ascending order of the + * priority values. It is required to return a value between 0 and 100. + * @since 11.0.0 + */ + public function getPriority() { + return 0; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function canChangeStream() { + return false; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function isDefaultEnabledStream() { + return true; + } + + /** + * @return bool True when the option can be changed for the mail + * @since 11.0.0 + */ + public function canChangeMail() { + return false; + } + + /** + * @return bool True when the option can be changed for the stream + * @since 11.0.0 + */ + public function isDefaultEnabledMail() { + return false; + } +} |