namespace Wallabag\CoreBundle\Helper;
use RulerZ\RulerZ;
-
use Wallabag\CoreBundle\Entity\Entry;
use Wallabag\CoreBundle\Entity\Tag;
use Wallabag\CoreBundle\Repository\EntryRepository;
public function __construct(RulerZ $rulerz, TagRepository $tagRepository, EntryRepository $entryRepository)
{
- $this->rulerz = $rulerz;
- $this->tagRepository = $tagRepository;
+ $this->rulerz = $rulerz;
+ $this->tagRepository = $tagRepository;
$this->entryRepository = $entryRepository;
}
}
foreach ($rule->getTags() as $label) {
- $tag = $this->getTag($entry->getUser(), $label);
+ $tag = $this->getTag($label);
$entry->addTag($tag);
}
*/
public function tagAllForUser(User $user)
{
- $rules = $this->getRulesForUser($user);
- $entries = array();
+ $rules = $this->getRulesForUser($user);
+ $entries = [];
foreach ($rules as $rule) {
- $qb = $this->entryRepository->getBuilderForAllByUser($user->getId());
+ $qb = $this->entryRepository->getBuilderForAllByUser($user->getId());
$entries = $this->rulerz->filter($qb, $rule->getRule());
foreach ($entries as $entry) {
foreach ($rule->getTags() as $label) {
- $tag = $this->getTag($user, $label);
+ $tag = $this->getTag($label);
$entry->addTag($tag);
- $entries[] = $entry;
}
}
}
}
/**
- * Fetch a tag for a user.
+ * Fetch a tag.
*
- * @param User $user
* @param string $label The tag's label.
*
* @return Tag
*/
- private function getTag(User $user, $label)
+ private function getTag($label)
{
- $tag = $this->tagRepository->findOneByLabelAndUserId($label, $user->getId());
+ $tag = $this->tagRepository->findOneByLabel($label);
if (!$tag) {
- $tag = new Tag($user);
+ $tag = new Tag();
$tag->setLabel($label);
}