* @copyright 2018, Maxence Lange * @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\Social\Command; use OC\Core\Command\Base; use OCA\Social\Exceptions\RequestException; use OCA\Social\Exceptions\SocialAppConfigException; use OCA\Social\Service\ActivityService; use OCA\Social\Service\ConfigService; use OCA\Social\Service\MiscService; use OCA\Social\Service\QueueService; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; class QueueProcess extends Base { /** @var ActivityService */ private $activityService; /** @var QueueService */ private $queueService; /** @var ConfigService */ private $configService; /** @var MiscService */ private $miscService; /** * NoteCreate constructor. * * @param ActivityService $activityService * @param QueueService $queueService * @param ConfigService $configService * @param MiscService $miscService */ public function __construct( ActivityService $activityService, QueueService $queueService, ConfigService $configService, MiscService $miscService ) { parent::__construct(); $this->activityService = $activityService; $this->queueService = $queueService; $this->configService = $configService; $this->miscService = $miscService; } /** * */ protected function configure() { parent::configure(); $this->setName('social:queue:process') ->setDescription('Process the request queue'); } /** * @param InputInterface $input * @param OutputInterface $output */ protected function execute(InputInterface $input, OutputInterface $output) { $requests = $this->queueService->getRequestStandby($total = 0); $output->writeLn('found a total of ' . $total . ' requests in the queue'); if ($total === 0) { return; } $output->writeLn(sizeof($requests) . ' are processable at this time'); if (sizeof($requests) === 0) { return; } $this->activityService->manageInit(); foreach ($requests as $request) { $request->setTimeout(ActivityService::TIMEOUT_SERVICE); $output->write('.'); try { $this->activityService->manageRequest($request); } catch (RequestException $e) { } catch (SocialAppConfigException $e) { } } $output->writeLn('done'); } }