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, ]; } }