namespace Wallabag\CoreBundle\Helper;
+use Psr\Log\LoggerInterface;
use RulerZ\RulerZ;
use Wallabag\CoreBundle\Entity\Entry;
use Wallabag\CoreBundle\Entity\Tag;
+use Wallabag\CoreBundle\Entity\TaggingRule;
use Wallabag\CoreBundle\Repository\EntryRepository;
use Wallabag\CoreBundle\Repository\TagRepository;
use Wallabag\UserBundle\Entity\User;
private $rulerz;
private $tagRepository;
private $entryRepository;
+ private $logger;
- public function __construct(RulerZ $rulerz, TagRepository $tagRepository, EntryRepository $entryRepository)
+ public function __construct(RulerZ $rulerz, TagRepository $tagRepository, EntryRepository $entryRepository, LoggerInterface $logger)
{
$this->rulerz = $rulerz;
$this->tagRepository = $tagRepository;
$this->entryRepository = $entryRepository;
+ $this->logger = $logger;
}
/**
continue;
}
+ $this->logger->info('Matching rule.', [
+ 'rule' => $rule->getRule(),
+ 'tags' => $rule->getTags(),
+ ]);
+
foreach ($rule->getTags() as $label) {
$tag = $this->getTag($label);
{
$rules = $this->getRulesForUser($user);
$entries = [];
+ $tagsCache = [];
foreach ($rules as $rule) {
$qb = $this->entryRepository->getBuilderForAllByUser($user->getId());
foreach ($entries as $entry) {
foreach ($rule->getTags() as $label) {
- $tag = $this->getTag($label);
+ // avoid new tag duplicate by manually caching them
+ if (!isset($tagsCache[$label])) {
+ $tagsCache[$label] = $this->getTag($label);
+ }
+
+ $tag = $tagsCache[$label];
$entry->addTag($tag);
}