* * @author Roeland Jago Douma * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * */ namespace OCA\Files\Notification; use OCP\IURLGenerator; use OCP\L10N\IFactory; use OCP\Notification\IAction; use OCP\Notification\INotification; use OCP\Notification\INotifier; class Notifier implements INotifier { /** @var IFactory */ protected $l10nFactory; /** @var IURLGenerator */ protected $urlGenerator; /** * @param IFactory $l10nFactory * @param IURLGenerator $urlGenerator */ public function __construct(IFactory $l10nFactory, IURLGenerator $urlGenerator) { $this->l10nFactory = $l10nFactory; $this->urlGenerator = $urlGenerator; } public function getID(): string { return 'files'; } public function getName(): string { return $this->l10nFactory->get('files')->t('Files'); } /** * @param INotification $notification * @param string $languageCode The code of the language that should be used to prepare the notification * @return INotification * @throws \InvalidArgumentException When the notification was not prepared by a notifier */ public function prepare(INotification $notification, string $languageCode): INotification { if ($notification->getApp() !== 'files') { throw new \InvalidArgumentException('Unhandled app'); } if ($notification->getSubject() === 'transferownershipRequest') { return $this->handleTransferownershipRequest($notification, $languageCode); } if ($notification->getSubject() === 'transferOwnershipFailedSource') { return $this->handleTransferOwnershipFailedSource($notification, $languageCode); } if ($notification->getSubject() === 'transferOwnershipFailedTarget') { return $this->handleTransferOwnershipFailedTarget($notification, $languageCode); } if ($notification->getSubject() === 'transferOwnershipDoneSource') { return $this->handleTransferOwnershipDoneSource($notification, $languageCode); } if ($notification->getSubject() === 'transferOwnershipDoneTarget') { return $this->handleTransferOwnershipDoneTarget($notification, $languageCode); } throw new \InvalidArgumentException('Unhandled subject'); } public function handleTransferownershipRequest(INotification $notification, string $languageCode): INotification { $l = $this->l10nFactory->get('files', $languageCode); $id = $notification->getObjectId(); $param = $notification->getSubjectParameters(); $approveAction = $notification->createAction() ->setParsedLabel($l->t('Accept')) ->setPrimary(true) ->setLink( $this->urlGenerator->getAbsoluteURL( $this->urlGenerator->linkTo( '', 'ocs/v2.php/apps/files/api/v1/transferownership/' . $id ) ), IAction::TYPE_POST ); $disapproveAction = $notification->createAction() ->setParsedLabel($l->t('Decline')) ->setPrimary(false) ->setLink( $this->urlGenerator->getAbsoluteURL( $this->urlGenerator->linkTo( '', 'ocs/v2.php/apps/files/api/v1/transferownership/' . $id ) ), IAction::TYPE_DELETE ); $notification->addParsedAction($approveAction) ->addParsedAction($disapproveAction) ->setRichSubject( $l->t('Incomming file transfer from {user}'), [ 'user' => [ 'type' => 'user', 'id' => $param['sourceUser'], 'name' => $param['sourceUser'], ], ]) ->setParsedSubject(str_replace('{user}', $param['sourceUser'], $l->t('Incomming file transfer from {user}'))) ->setRichMessage( $l->t('Do you want to accept {path}?'), [ 'path' => [ 'type' => 'highlight', 'id' => $param['targetUser'] . '::' . $param['nodeName'], 'name' => $param['nodeName'], ] ]) ->setParsedMessage(str_replace('{path}', $param['nodeName'], $l->t('Do you want to accept {path}?'))); return $notification; } public function handleTransferOwnershipFailedSource(INotification $notification, string $languageCode): INotification { $l = $this->l10nFactory->get('files', $languageCode); $param = $notification->getSubjectParameters(); $notification->setRichSubject($l->t('File transfer failed')) ->setParsedSubject(str_replace(['{path}', '{user}'], [$param['nodeName'], $param['targetUser']], $l->t('Your transfer of {path} to {user} failed.'))) ->setRichMessage( $l->t('Your transfer of {path} to {user} failed.'), [ 'path' => [ 'type' => 'highlight', 'id' => $param['targetUser'] . '::' . $param['nodeName'], 'name' => $param['nodeName'], ], 'user' => [ 'type' => 'user', 'id' => $param['targetUser'], 'name' => $param['targetUser'], ], ]) ->setParsedMessage($l->t('File transfer failed')); return $notification; } public function handleTransferOwnershipFailedTarget(INotification $notification, string $languageCode): INotification { $l = $this->l10nFactory->get('files', $languageCode); $param = $notification->getSubjectParameters(); $notification->setRichSubject($l->t('File transfer failed')) ->setParsedSubject(str_replace(['{path}', '{user}'], [$param['nodeName'], $param['sourceUser']], $l->t('The transfer of {path} from {user} failed.'))) ->setRichMessage( $l->t('The transfer of {path} from {user} failed.'), [ 'path' => [ 'type' => 'highlight', 'id' => $param['sourceUser'] . '::' . $param['nodeName'], 'name' => $param['nodeName'], ], 'user' => [ 'type' => 'user', 'id' => $param['sourceUser'], 'name' => $param['sourceUser'], ], ]) ->setParsedMessage($l->t('File transfer failed')); return $notification; } public function handleTransferOwnershipDoneSource(INotification $notification, string $languageCode): INotification { $l = $this->l10nFactory->get('files', $languageCode); $param = $notification->getSubjectParameters(); $notification->setRichSubject($l->t('File transfer done')) ->setParsedSubject(str_replace(['{path}', '{user}'], [$param['nodeName'], $param['targetUser']], $l->t('Your transfer of {path} to {user} has completed.'))) ->setRichMessage( $l->t('Your transfer of {path} to {user} has completed.'), [ 'path' => [ 'type' => 'highlight', 'id' => $param['targetUser'] . '::' . $param['nodeName'], 'name' => $param['nodeName'], ], 'user' => [ 'type' => 'user', 'id' => $param['targetUser'], 'name' => $param['targetUser'], ], ]) ->setParsedMessage($l->t('File transfer done')); return $notification; } public function handleTransferOwnershipDoneTarget(INotification $notification, string $languageCode): INotification { $l = $this->l10nFactory->get('files', $languageCode); $param = $notification->getSubjectParameters(); $notification->setRichSubject($l->t('File transfer done')) ->setParsedSubject(str_replace(['{path}', '{user}'], [$param['nodeName'], $param['sourceUser']], $l->t('The transfer of {path} from {user} has completed.'))) ->setRichMessage( $l->t('The transfer of {path} from {user} has completed.'), [ 'path' => [ 'type' => 'highlight', 'id' => $param['sourceUser'] . '::' . $param['nodeName'], 'name' => $param['nodeName'], ], 'user' => [ 'type' => 'user', 'id' => $param['sourceUser'], 'name' => $param['sourceUser'], ], ]) ->setParsedMessage($l->t('File transfer done')); return $notification; } }