*/
public function getName()
{
- return 'Wallabag v1';
+ return 'wallabag v1';
+ }
+
+ /**
+ * {@inheritdoc}
+ */
+ public function getUrl()
+ {
+ return 'import_wallabag_v1';
}
/**
*/
public function getDescription()
{
- return 'This importer will import all your wallabag v1 articles.';
+ return 'This importer will import all your wallabag v1 articles. On your config page, click on "JSON export" in the "Export your wallabag data" section. You will have a "wallabag-export-1-xxxx-xx-xx.json" file.';
}
/**
return false;
}
- $this->parseEntries(json_decode(file_get_contents($this->filepath), true));
+ $data = json_decode(file_get_contents($this->filepath), true);
+
+ if (empty($data)) {
+ return false;
+ }
+
+ $this->parseEntries($data);
return true;
}
*/
private function parseEntries($entries)
{
+ $i = 1;
+
foreach ($entries as $importedEntry) {
$existingEntry = $this->em
->getRepository('WallabagCoreBundle:Entry')
- ->existByUrlAndUserId($importedEntry['url'], $this->user->getId());
+ ->findByUrlAndUserId($importedEntry['url'], $this->user->getId());
if (false !== $existingEntry) {
++$this->skippedEntries;
$this->em->persist($entry);
++$this->importedEntries;
+
+ // flush every 20 entries
+ if (($i % 20) === 0) {
+ $this->em->flush();
+ }
+ ++$i;
}
$this->em->flush();