aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/lib/Activity
diff options
context:
space:
mode:
Diffstat (limited to 'apps/settings/lib/Activity')
-rw-r--r--apps/settings/lib/Activity/GroupProvider.php132
-rw-r--r--apps/settings/lib/Activity/GroupSetting.php79
-rw-r--r--apps/settings/lib/Activity/Provider.php165
-rw-r--r--apps/settings/lib/Activity/SecurityFilter.php44
-rw-r--r--apps/settings/lib/Activity/SecurityProvider.php84
-rw-r--r--apps/settings/lib/Activity/SecuritySetting.php46
-rw-r--r--apps/settings/lib/Activity/Setting.php79
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;
+ }
+}