use Psr\Log\NullLogger;
use Doctrine\ORM\EntityManager;
use Wallabag\CoreBundle\Entity\Entry;
+use Wallabag\CoreBundle\Entity\Tag;
use Wallabag\UserBundle\Entity\User;
use Wallabag\CoreBundle\Tools\Utils;
+use Wallabag\CoreBundle\Helper\ContentProxy;
class WallabagV1Import implements ImportInterface
{
- private $user;
- private $em;
- private $logger;
- private $skippedEntries = 0;
- private $importedEntries = 0;
- private $filepath;
-
- public function __construct(EntityManager $em)
+ protected $user;
+ protected $em;
+ protected $logger;
+ protected $contentProxy;
+ protected $skippedEntries = 0;
+ protected $importedEntries = 0;
+ protected $filepath;
+
+ public function __construct(EntityManager $em, ContentProxy $contentProxy)
{
$this->em = $em;
$this->logger = new NullLogger();
+ $this->contentProxy = $contentProxy;
}
public function setLogger(LoggerInterface $logger)
*/
public function getName()
{
- return 'Wallabag v1';
+ return 'wallabag v1';
}
/**
public function import()
{
if (!$this->user) {
- $this->logger->error('WallabagV1Import: user is not defined');
+ $this->logger->error('WallabagImport: user is not defined');
return false;
}
if (!file_exists($this->filepath) || !is_readable($this->filepath)) {
- $this->logger->error('WallabagV1Import: unable to read file', array('filepath' => $this->filepath));
+ $this->logger->error('WallabagImport: unable to read file', array('filepath' => $this->filepath));
return false;
}
/**
* @param $entries
*/
- private function parseEntries($entries)
+ protected function parseEntries($entries)
{
$i = 1;
+ //Untitled in all languages from v1. This should never have been translated
+ $untitled = array('Untitled', 'Sans titre', 'podle nadpisu', 'Sin título', 'با عنوان', 'per titolo', 'Sem título', 'Без названия', 'po naslovu', 'Без назви', 'No title found', '');
+
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;
// @see ContentProxy->updateEntry
$entry = new Entry($this->user);
$entry->setUrl($importedEntry['url']);
- $entry->setTitle($importedEntry['title']);
+ if (in_array($importedEntry['title'], $untitled)) {
+ $entry = $this->contentProxy->updateEntry($entry, $importedEntry['url']);
+ } else {
+ $entry->setContent($importedEntry['content']);
+ $entry->setTitle($importedEntry['title']);
+ $entry->setReadingTime(Utils::getReadingTime($importedEntry['content']));
+ $entry->setDomainName(parse_url($importedEntry['url'], PHP_URL_HOST));
+ }
+ if (array_key_exists('tags', $importedEntry) && $importedEntry['tags'] != '') {
+ $tags = explode(',', $importedEntry['tags']);
+ $this->assignTagsToEntry($entry, $tags);
+ }
$entry->setArchived($importedEntry['is_read']);
$entry->setStarred($importedEntry['is_fav']);
- $entry->setContent($importedEntry['content']);
- $entry->setReadingTime(Utils::getReadingTime($importedEntry['content']));
- $entry->setDomainName(parse_url($importedEntry['url'], PHP_URL_HOST));
$this->em->persist($entry);
++$this->importedEntries;
// flush every 20 entries
if (($i % 20) === 0) {
- $em->flush();
+ $this->em->flush();
}
++$i;
}
$this->em->flush();
}
+
+ private function assignTagsToEntry(Entry $entry, $tags)
+ {
+ foreach ($tags as $tag) {
+ $label = trim($tag);
+ $tagEntity = $this->em
+ ->getRepository('WallabagCoreBundle:Tag')
+ ->findOneByLabel($label);
+ if (is_object($tagEntity)) {
+ $entry->addTag($tagEntity);
+ } else {
+ $newTag = new Tag();
+ $newTag->setLabel($label);
+ $entry->addTag($newTag);
+ }
+ $this->em->flush();
+ }
+ }
}