namespace Wallabag\ImportBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
+use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
-use Wallabag\ImportBundle\Import\PocketImport;
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\Form\Extension\Core\Type\CheckboxType;
class PocketController extends Controller
{
/**
- * @Route("/import", name="import")
+ * @Route("/pocket", name="import_pocket")
*/
- public function importAction()
+ public function indexAction()
{
- return $this->render('WallabagImportBundle:Pocket:index.html.twig', array());
+ $pocket = $this->get('wallabag_import.pocket.import');
+ $form = $this->createFormBuilder($pocket)
+ ->add('read', CheckboxType::class, array(
+ 'label' => 'Mark all as read',
+ 'required' => false,
+ ))
+ ->getForm();
+
+ return $this->render('WallabagImportBundle:Pocket:index.html.twig', [
+ 'import' => $this->get('wallabag_import.pocket.import'),
+ 'has_consumer_key' => '' == trim($this->get('craue_config')->get('pocket_consumer_key')) ? false : true,
+ 'form' => $form->createView(),
+ ]);
}
/**
- * @Route("/auth-pocket", name="authpocket")
+ * @Route("/pocket/auth", name="import_pocket_auth")
*/
- public function authAction()
+ public function authAction(Request $request)
{
- $pocket = new PocketImport($this->get('security.token_storage'), $this->get('session'), $this->getDoctrine()->getManager(), $this->container->getParameter('pocket_consumer_key'));
- $authUrl = $pocket->oAuthRequest($this->generateUrl('import', array(), true), $this->generateUrl('callbackpocket', array(), true));
+ $requestToken = $this->get('wallabag_import.pocket.import')
+ ->getRequestToken($this->generateUrl('import', array(), UrlGeneratorInterface::ABSOLUTE_URL));
+
+ $this->get('session')->set('import.pocket.code', $requestToken);
+ $this->get('session')->set('read', $request->request->get('form')['read']);
- return $this->redirect($authUrl, 301);
+ return $this->redirect(
+ 'https://getpocket.com/auth/authorize?request_token='.$requestToken.'&redirect_uri='.$this->generateUrl('import_pocket_callback', array(), UrlGeneratorInterface::ABSOLUTE_URL),
+ 301
+ );
}
/**
- * @Route("/callback-pocket", name="callbackpocket")
+ * @Route("/pocket/callback", name="import_pocket_callback")
*/
public function callbackAction()
{
- $pocket = new PocketImport($this->get('security.token_storage'), $this->get('session'), $this->getDoctrine()->getManager(), $this->container->getParameter('pocket_consumer_key'));
- $accessToken = $pocket->oAuthAuthorize();
- $pocket->import($accessToken);
+ $message = 'Import failed, please try again.';
+ $pocket = $this->get('wallabag_import.pocket.import');
+ $markAsRead = $this->get('session')->get('read');
+ $this->get('session')->remove('read');
+
+ // something bad happend on pocket side
+ if (false === $pocket->authorize($this->get('session')->get('import.pocket.code'))) {
+ $this->get('session')->getFlashBag()->add(
+ 'notice',
+ $message
+ );
+
+ return $this->redirect($this->generateUrl('import_pocket'));
+ }
+
+ if (true === $pocket->setMarkAsRead($markAsRead)->import()) {
+ $summary = $pocket->getSummary();
+ $message = 'Import summary: '.$summary['imported'].' imported, '.$summary['skipped'].' already saved.';
+ }
+
+ $this->get('session')->getFlashBag()->add(
+ 'notice',
+ $message
+ );
return $this->redirect($this->generateUrl('homepage'));
}