diff options
author | Jeremy Benoist <jeremy.benoist@gmail.com> | 2015-12-30 13:26:30 +0100 |
---|---|---|
committer | Jeremy Benoist <jeremy.benoist@gmail.com> | 2016-01-02 23:27:41 +0100 |
commit | b1d05721cf37ab94ec1a6837fe79cf19474dd0ff (patch) | |
tree | 95cb2413a6044af6603a40339a1ceb2961206ae3 /src/Wallabag/ImportBundle/Controller | |
parent | 252ebd60719d32ec954d0519c9edf2b52b03310c (diff) | |
download | wallabag-b1d05721cf37ab94ec1a6837fe79cf19474dd0ff.tar.gz wallabag-b1d05721cf37ab94ec1a6837fe79cf19474dd0ff.tar.zst wallabag-b1d05721cf37ab94ec1a6837fe79cf19474dd0ff.zip |
Rewrote Wallabag v1 import
Diffstat (limited to 'src/Wallabag/ImportBundle/Controller')
-rw-r--r-- | src/Wallabag/ImportBundle/Controller/PocketController.php | 2 | ||||
-rw-r--r-- | src/Wallabag/ImportBundle/Controller/WallabagV1Controller.php | 58 |
2 files changed, 59 insertions, 1 deletions
diff --git a/src/Wallabag/ImportBundle/Controller/PocketController.php b/src/Wallabag/ImportBundle/Controller/PocketController.php index 61eeba43..ebcee099 100644 --- a/src/Wallabag/ImportBundle/Controller/PocketController.php +++ b/src/Wallabag/ImportBundle/Controller/PocketController.php | |||
@@ -51,7 +51,7 @@ class PocketController extends Controller | |||
51 | 51 | ||
52 | if (true === $pocket->import()) { | 52 | if (true === $pocket->import()) { |
53 | $summary = $pocket->getSummary(); | 53 | $summary = $pocket->getSummary(); |
54 | $message = $summary['imported'].' entrie(s) imported, '.$summary['skipped'].' already saved.'; | 54 | $message = 'Import summary: '.$summary['imported'].' imported, '.$summary['skipped'].' already saved.'; |
55 | } | 55 | } |
56 | 56 | ||
57 | $this->get('session')->getFlashBag()->add( | 57 | $this->get('session')->getFlashBag()->add( |
diff --git a/src/Wallabag/ImportBundle/Controller/WallabagV1Controller.php b/src/Wallabag/ImportBundle/Controller/WallabagV1Controller.php new file mode 100644 index 00000000..de200184 --- /dev/null +++ b/src/Wallabag/ImportBundle/Controller/WallabagV1Controller.php | |||
@@ -0,0 +1,58 @@ | |||
1 | <?php | ||
2 | |||
3 | namespace Wallabag\ImportBundle\Controller; | ||
4 | |||
5 | use Symfony\Bundle\FrameworkBundle\Controller\Controller; | ||
6 | use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; | ||
7 | use Symfony\Component\HttpFoundation\Request; | ||
8 | use Wallabag\ImportBundle\Form\Type\UploadImportType; | ||
9 | |||
10 | class WallabagV1Controller extends Controller | ||
11 | { | ||
12 | /** | ||
13 | * @Route("/import/wallabag-v1", name="import_wallabag_v1") | ||
14 | */ | ||
15 | public function indexAction(Request $request) | ||
16 | { | ||
17 | $importForm = $this->createForm(new UploadImportType()); | ||
18 | $importForm->handleRequest($request); | ||
19 | $user = $this->getUser(); | ||
20 | |||
21 | if ($importForm->isValid()) { | ||
22 | $file = $importForm->get('file')->getData(); | ||
23 | $name = $user->getId().'.json'; | ||
24 | |||
25 | if (in_array($file->getClientMimeType(), $this->getParameter('wallabag_import.allow_mimetypes')) && $file->move($this->getParameter('wallabag_import.resource_dir'), $name)) { | ||
26 | $wallabag = $this->get('wallabag_import.wallabag_v1.import'); | ||
27 | $res = $wallabag | ||
28 | ->setUser($this->getUser()) | ||
29 | ->setFilepath($this->getParameter('wallabag_import.resource_dir').'/'.$name) | ||
30 | ->import(); | ||
31 | |||
32 | $message = 'Import failed, please try again.'; | ||
33 | if (true === $res) { | ||
34 | $summary = $wallabag->getSummary(); | ||
35 | $message = 'Import summary: '.$summary['imported'].' imported, '.$summary['skipped'].' already saved.'; | ||
36 | |||
37 | @unlink($this->getParameter('wallabag_import.resource_dir').'/'.$name); | ||
38 | } | ||
39 | |||
40 | $this->get('session')->getFlashBag()->add( | ||
41 | 'notice', | ||
42 | $message | ||
43 | ); | ||
44 | |||
45 | return $this->redirect($this->generateUrl('homepage')); | ||
46 | } else { | ||
47 | $this->get('session')->getFlashBag()->add( | ||
48 | 'notice', | ||
49 | 'Error while processing import. Please verify your import file.' | ||
50 | ); | ||
51 | } | ||
52 | } | ||
53 | |||
54 | return $this->render('WallabagImportBundle:WallabagV1:index.html.twig', [ | ||
55 | 'form' => $importForm->createView(), | ||
56 | ]); | ||
57 | } | ||
58 | } | ||