* * @author Joas Schilling * * @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\Notifications\Command; use OCP\AppFramework\Utility\ITimeFactory; use OCP\IUser; use OCP\IUserManager; use OCP\Notification\IManager; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Input\InputOption; use Symfony\Component\Console\Output\OutputInterface; class Generate extends Command { /** @var ITimeFactory */ protected $timeFactory; /** @var IUserManager */ protected $userManager; /** @var IManager */ protected $notificationManager; /** * @param ITimeFactory $timeFactory * @param IUserManager $userManager * @param IManager $notificationManager */ public function __construct(ITimeFactory $timeFactory, IUserManager $userManager, IManager $notificationManager) { parent::__construct(); $this->timeFactory = $timeFactory; $this->userManager = $userManager; $this->notificationManager = $notificationManager; } protected function configure() { $this ->setName('notification:generate') ->setDescription('Generate a notification for the given user') ->addArgument( 'user-id', InputArgument::REQUIRED, 'User ID of the user to notify' ) ->addArgument( 'short-message', InputArgument::REQUIRED, 'Short message to be sent to the user (max. 255 characters)' ) ->addOption( 'long-message', 'l', InputOption::VALUE_REQUIRED, 'Long mesage to be sent to the user (max. 4000 characters)', '' ) ; } /** * @param InputInterface $input * @param OutputInterface $output * @return int */ protected function execute(InputInterface $input, OutputInterface $output): int { $userId = $input->getArgument('user-id'); $subject = $input->getArgument('short-message'); $message = $input->getOption('long-message'); $user = $this->userManager->get($userId); if (!$user instanceof IUser) { $output->writeln('Unknown user'); return 1; } if ($subject === '' || strlen($subject) > 255) { $output->writeln('Too long or empty short-message'); return 1; } if ($message !== '' && strlen($message) > 4000) { $output->writeln('Too long long-message'); return 1; } $notification = $this->notificationManager->createNotification(); $datetime = $this->timeFactory->getDateTime(); try { $notification->setApp('admin_notifications') ->setUser($user->getUID()) ->setDateTime($datetime) ->setObject('admin_notifications', dechex($datetime->getTimestamp())) ->setSubject('cli', [$subject]); if ($message !== '') { $notification->setMessage('cli', [$message]); } $this->notificationManager->notify($notification); } catch (\InvalidArgumentException $e) { $output->writeln('Error while sending the notification'); return 1; } return 0; } }