setName('wallabag:import') ->setDescription('Import entries from a JSON export from a wallabag v1 instance') ->addArgument('userId', InputArgument::REQUIRED, 'User ID to populate') ->addArgument('filepath', InputArgument::REQUIRED, 'Path to the JSON file') ->addOption('importer', null, InputArgument::OPTIONAL, 'The importer to use: v1 or v2', 'v1') ->addOption('markAsRead', null, InputArgument::OPTIONAL, 'Mark all entries as read: true/false', false) ; } protected function execute(InputInterface $input, OutputInterface $output) { $output->writeln('Start : '.(new \DateTime())->format('d-m-Y G:i:s').' ---'); $em = $this->getContainer()->get('doctrine')->getManager(); // Turning off doctrine default logs queries for saving memory $em->getConnection()->getConfiguration()->setSQLLogger(null); $user = $em->getRepository('WallabagUserBundle:User')->findOneById($input->getArgument('userId')); if (!is_object($user)) { throw new Exception(sprintf('User with id "%s" not found', $input->getArgument('userId'))); } $wallabag = $this->getContainer()->get('wallabag_import.wallabag_v1.import'); if ('v2' === $input->getOption('importer')) { $wallabag = $this->getContainer()->get('wallabag_import.wallabag_v2.import'); } if ('yes' === $input->getOption('markAsRead')) { $wallabag->setMarkAsRead(true); } $res = $wallabag ->setUser($user) ->setFilepath($input->getArgument('filepath')) ->import(); if (true === $res) { $summary = $wallabag->getSummary(); $output->writeln(''.$summary['imported'].' imported'); $output->writeln(''.$summary['skipped'].' already saved'); } $em->clear(); $output->writeln('End : '.(new \DateTime())->format('d-m-Y G:i:s').' ---'); } }