diff options
author | Sean Molenaar <sean@seanmolenaar.eu> | 2021-02-16 21:16:18 +0100 |
---|---|---|
committer | Sean Molenaar <SMillerDev@users.noreply.github.com> | 2021-02-20 13:57:09 +0100 |
commit | 01e1db329ced43323654990828744d577cac4ba8 (patch) | |
tree | 76c1c710667abddcdc1390b81a0d35a7d34600f1 /lib/Command/Debug | |
parent | 78bf8242b38607c114ba1982fde357adbbfc56f5 (diff) |
Command: Add debug item list commands
Signed-off-by: Sean Molenaar <sean@seanmolenaar.eu>
Diffstat (limited to 'lib/Command/Debug')
-rw-r--r-- | lib/Command/Debug/FeedItemList.php | 99 | ||||
-rw-r--r-- | lib/Command/Debug/FolderItemList.php | 100 | ||||
-rw-r--r-- | lib/Command/Debug/ItemList.php | 94 |
3 files changed, 293 insertions, 0 deletions
diff --git a/lib/Command/Debug/FeedItemList.php b/lib/Command/Debug/FeedItemList.php new file mode 100644 index 000000000..49820993c --- /dev/null +++ b/lib/Command/Debug/FeedItemList.php @@ -0,0 +1,99 @@ +<?php +declare(strict_types=1); + +namespace OCA\News\Command\Debug; + +use OCA\News\Controller\ApiPayloadTrait; +use OCA\News\Service\ItemServiceV2; +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 ItemList + * + * @package OCA\News\Command + */ +class FeedItemList extends Command +{ + use ApiPayloadTrait; + + /** + * @var ItemServiceV2 service for the items. + */ + protected $itemService; + + public function __construct(ItemServiceV2 $itemService) + { + parent::__construct(null); + + $this->itemService = $itemService; + } + + /** + * Configure command + * + * @return void + */ + protected function configure() + { + $this->setName('news:item:list-feed') + ->setDescription('List all items in a feed') + ->addArgument('user-id', InputArgument::REQUIRED, 'User to list the items for') + ->addArgument('feed', InputArgument::REQUIRED, 'Feed to list the items for') + ->addOption('limit', 'l', InputOption::VALUE_REQUIRED, 'Limit for item amount', 40) + ->addOption('offset', 'o', InputOption::VALUE_REQUIRED, 'Item list offset', 0) + ->addOption('reverse-sort', null, InputOption::VALUE_NONE, 'Item list sorting') + ->addOption('hide-read', null, InputOption::VALUE_NONE, 'Hide read items'); + } + + /** + * Execute command + * + * @param InputInterface $input + * @param OutputInterface $output + * + * @return int|void + */ + protected function execute(InputInterface $input, OutputInterface $output) + { + $user = $input->getArgument('user-id'); + + $feed = $input->getArgument('feed'); + if (!is_numeric($feed)) { + $output->writeln('Invalid Type!'); + return 255; + } + + $limit = $input->getOption('limit'); + if (!is_numeric($limit)) { + $output->writeln('Invalid limit!'); + return 255; + } + + $offset = $input->getOption('offset'); + if (!is_numeric($offset)) { + $output->writeln('Invalid offset!'); + return 255; + } + + $reverseSort = $input->getOption('reverse-sort'); + $hideRead = $input->getOption('hide-read'); + + $items = $this->itemService->findAllInFeedWithFilters( + $user, + intval($feed), + intval($limit), + intval($offset), + $hideRead, + $reverseSort, + [] + ); + + $output->writeln(json_encode($this->serialize($items), JSON_PRETTY_PRINT)); + + return 0; + } +} diff --git a/lib/Command/Debug/FolderItemList.php b/lib/Command/Debug/FolderItemList.php new file mode 100644 index 000000000..4e6f07dae --- /dev/null +++ b/lib/Command/Debug/FolderItemList.php @@ -0,0 +1,100 @@ +<?php +declare(strict_types=1); + +namespace OCA\News\Command\Debug; + +use OCA\News\Controller\ApiPayloadTrait; +use OCA\News\Service\ItemServiceV2; +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 ItemList + * + * @package OCA\News\Command + */ +class FolderItemList extends Command +{ + use ApiPayloadTrait; + + /** + * @var ItemServiceV2 service for the items. + */ + protected $itemService; + + public function __construct(ItemServiceV2 $itemService) + { + parent::__construct(null); + + $this->itemService = $itemService; + } + + /** + * Configure command + * + * @return void + */ + protected function configure() + { + $this->setName('news:item:list-folder') + ->setDescription('List all items in a folder') + ->addArgument('user-id', InputArgument::REQUIRED, 'User to list the items for') + ->addArgument('folder', InputArgument::OPTIONAL, 'Folder to list the items for') + ->addOption('limit', 'l', InputOption::VALUE_REQUIRED, 'Limit for item amount', 40) + ->addOption('offset', 'o', InputOption::VALUE_REQUIRED, 'Item list offset', 0) + ->addOption('reverse-sort', null, InputOption::VALUE_NONE, 'Item list sorting') + ->addOption('hide-read', null, InputOption::VALUE_NONE, 'Hide read items'); + } + + /** + * Execute command + * + * @param InputInterface $input + * @param OutputInterface $output + * + * @return int|void + */ + protected function execute(InputInterface $input, OutputInterface $output) + { + $user = $input->getArgument('user-id'); + + $folder = $input->getArgument('folder'); + if (!is_null($folder) && !is_numeric($folder)) { + $output->writeln('Invalid folder ID!'); + return 255; + } + + $limit = $input->getOption('limit'); + if (!is_numeric($limit)) { + $output->writeln('Invalid limit!'); + return 255; + } + + $offset = $input->getOption('offset'); + if (!is_numeric($offset)) { + $output->writeln('Invalid offset!'); + return 255; + } + + $folder = is_null($folder) ? $folder : intval($folder); + $reverseSort = $input->getOption('reverse-sort'); + $hideRead = $input->getOption('hide-read'); + + $items = $this->itemService->findAllInFolderWithFilters( + $user, + $folder, + intval($limit), + intval($offset), + $hideRead, + $reverseSort, + [] + ); + + $output->writeln(json_encode($this->serialize($items), JSON_PRETTY_PRINT)); + + return 0; + } +} diff --git a/lib/Command/Debug/ItemList.php b/lib/Command/Debug/ItemList.php new file mode 100644 index 000000000..06f8b1c1b --- /dev/null +++ b/lib/Command/Debug/ItemList.php @@ -0,0 +1,94 @@ +<?php +declare(strict_types=1); + +namespace OCA\News\Command\Debug; + +use OCA\News\Controller\ApiPayloadTrait; +use OCA\News\Db\ListType; +use OCA\News\Service\ItemServiceV2; +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 ItemList + * + * @package OCA\News\Command + */ +class ItemList extends Command +{ + use ApiPayloadTrait; + + /** + * @var ItemServiceV2 service for the items. + */ + protected $itemService; + + public function __construct(ItemServiceV2 $itemService) + { + parent::__construct(null); + + $this->itemService = $itemService; + } + + /** + * Configure command + * + * @return void + */ + protected function configure() + { + $this->setName('news:item:list') + ->setDescription('List all items') + ->addArgument('user-id', InputArgument::REQUIRED, 'User to list the items for') + ->addOption('type', 't', InputOption::VALUE_REQUIRED, 'Item type', ListType::ALL_ITEMS) + ->addOption('limit', 'l', InputOption::VALUE_REQUIRED, 'Limit for item amount', 40) + ->addOption('offset', 'o', InputOption::VALUE_REQUIRED, 'Item list offset', 0) + ->addOption('reverse-sort', 'r', InputOption::VALUE_NONE, 'Item list sorting'); + } + + /** + * Execute command + * + * @param InputInterface $input + * @param OutputInterface $output + * + * @return int|void + */ + protected function execute(InputInterface $input, OutputInterface $output) + { + $user = $input->getArgument('user-id'); + + $type = $input->getOption('type'); + if (!is_numeric($type)) { + $output->writeln('Invalid Type!'); + return 255; + } + $limit = $input->getOption('limit'); + if (!is_numeric($limit)) { + $output->writeln('Invalid limit!'); + return 255; + } + $offset = $input->getOption('offset'); + if (!is_numeric($offset)) { + $output->writeln('Invalid offset!'); + return 255; + } + $reverseSort = $input->getOption('reverse-sort'); + + $items = $this->itemService->findAllWithFilters( + $user, + intval($type), + intval($limit), + intval($offset), + $reverseSort, + [] + ); + + $output->writeln(json_encode($this->serialize($items), JSON_PRETTY_PRINT)); + + return 0; + } +} |