namespace Wallabag\ImportBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
-use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
-use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
-use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\Routing\Annotation\Route;
+use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
class PocketController extends Controller
{
- /**
- * Return Pocket Import Service with or without RabbitMQ enabled.
- *
- * @return \Wallabag\ImportBundle\Import\PocketImport
- */
- private function getPocketImportService()
- {
- $pocket = $this->get('wallabag_import.pocket.import');
- $pocket->setUser($this->getUser());
-
- if ($this->get('craue_config')->get('import_with_rabbitmq')) {
- $pocket->setProducer($this->get('old_sound_rabbit_mq.import_pocket_producer'));
- } elseif ($this->get('craue_config')->get('import_with_redis')) {
- $pocket->setProducer($this->get('wallabag_import.producer.redis.pocket'));
- }
-
- return $pocket;
- }
-
/**
* @Route("/pocket", name="import_pocket")
*/
return $this->redirect($this->generateUrl('import_pocket'));
}
+ $form = $request->request->get('form');
+
$this->get('session')->set('import.pocket.code', $requestToken);
- $this->get('session')->set('mark_as_read', $request->request->get('form')['mark_as_read']);
+ if (null !== $form && \array_key_exists('mark_as_read', $form)) {
+ $this->get('session')->set('mark_as_read', $form['mark_as_read']);
+ }
return $this->redirect(
- 'https://getpocket.com/auth/authorize?request_token='.$requestToken.'&redirect_uri='.$this->generateUrl('import_pocket_callback', [], UrlGeneratorInterface::ABSOLUTE_URL),
+ 'https://getpocket.com/auth/authorize?request_token=' . $requestToken . '&redirect_uri=' . $this->generateUrl('import_pocket_callback', [], UrlGeneratorInterface::ABSOLUTE_URL),
301
);
}
if (true === $pocket->setMarkAsRead($markAsRead)->import()) {
$summary = $pocket->getSummary();
$message = $this->get('translator')->trans('flashes.import.notice.summary', [
- '%imported%' => $summary['imported'],
- '%skipped%' => $summary['skipped'],
+ '%imported%' => null !== $summary && \array_key_exists('imported', $summary) ? $summary['imported'] : 0,
+ '%skipped%' => null !== $summary && \array_key_exists('skipped', $summary) ? $summary['skipped'] : 0,
]);
- if (0 < $summary['queued']) {
+ if (null !== $summary && \array_key_exists('queued', $summary) && 0 < $summary['queued']) {
$message = $this->get('translator')->trans('flashes.import.notice.summary_with_queue', [
'%queued%' => $summary['queued'],
]);
return $this->redirect($this->generateUrl('homepage'));
}
+
+ /**
+ * Return Pocket Import Service with or without RabbitMQ enabled.
+ *
+ * @return \Wallabag\ImportBundle\Import\PocketImport
+ */
+ private function getPocketImportService()
+ {
+ $pocket = $this->get('wallabag_import.pocket.import');
+ $pocket->setUser($this->getUser());
+
+ if ($this->get('craue_config')->get('import_with_rabbitmq')) {
+ $pocket->setProducer($this->get('old_sound_rabbit_mq.import_pocket_producer'));
+ } elseif ($this->get('craue_config')->get('import_with_redis')) {
+ $pocket->setProducer($this->get('wallabag_import.producer.redis.pocket'));
+ }
+
+ return $pocket;
+ }
}