X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2FWallabag%2FCoreBundle%2FCommand%2FExportCommand.php;h=e3d3b399506ff4e3986a84b044f032c882732783;hb=ec8e7ffad48c9920b4b63b8e278c8bec1fc6f480;hp=9c3c3fefea4a575feb0796e84daf5156a83126bb;hpb=8303b037fb4e64b542f6f755828b999fdf6eebb0;p=github%2Fwallabag%2Fwallabag.git diff --git a/src/Wallabag/CoreBundle/Command/ExportCommand.php b/src/Wallabag/CoreBundle/Command/ExportCommand.php index 9c3c3fef..e3d3b399 100644 --- a/src/Wallabag/CoreBundle/Command/ExportCommand.php +++ b/src/Wallabag/CoreBundle/Command/ExportCommand.php @@ -7,7 +7,6 @@ use Symfony\Bundle\FrameworkBundle\Command\ContainerAwareCommand; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; -use Symfony\Component\Console\Output\StreamOutput; class ExportCommand extends ContainerAwareCommand { @@ -23,7 +22,7 @@ class ExportCommand extends ContainerAwareCommand 'User from which to export entries' ) ->addArgument( - 'filename', + 'filepath', InputArgument::OPTIONAL, 'Path of the exported file' ) @@ -33,11 +32,13 @@ class ExportCommand extends ContainerAwareCommand protected function execute(InputInterface $input, OutputInterface $output) { try { - $user = $this->getUser($input->getArgument('username')); + $user = $this->getDoctrine()->getRepository('WallabagUserBundle:User')->findOneByUserName($input->getArgument('username')); } catch (NoResultException $e) { $output->writeln(sprintf('User "%s" not found.', $input->getArgument('username'))); + return 1; } + $entries = $this->getDoctrine() ->getRepository('WallabagCoreBundle:Entry') ->getBuilderForAllByUser($user->getId()) @@ -46,10 +47,12 @@ class ExportCommand extends ContainerAwareCommand $output->write(sprintf('Exporting %d entrie(s) for user « %s »... ', count($entries), $user->getUserName())); - $filePath = $input->getArgument('filename'); + $filePath = $input->getArgument('filepath'); + if (!$filePath) { - $filePath = $this->getContainer()->getParameter('kernel.root_dir') . '/../' . sprintf('%s-export', $user->getUsername()); + $filePath = $this->getContainer()->getParameter('kernel.root_dir').'/../'.sprintf('%s-export.json', $user->getUsername()); } + try { $data = $this->getContainer()->get('wallabag_core.helper.entries_export') ->setEntries($entries) @@ -58,21 +61,13 @@ class ExportCommand extends ContainerAwareCommand file_put_contents($filePath, $data); } catch (\InvalidArgumentException $e) { $output->writeln(sprintf('Error: "%s"', $e->getMessage())); + + return 1; } $output->writeln('Done.'); - } - /** - * Fetches a user from its username. - * - * @param string $username - * - * @return \Wallabag\UserBundle\Entity\User - */ - private function getUser($username) - { - return $this->getDoctrine()->getRepository('WallabagUserBundle:User')->findOneByUserName($username); + return 0; } private function getDoctrine()