forked from wallabag/wallabag
Fix tags count in menu
Move enable cache for Tag in the Entity because function `find*` should return result and not a Query
This commit is contained in:
@ -7,17 +7,45 @@ use Doctrine\ORM\EntityRepository;
|
||||
class TagRepository extends EntityRepository
|
||||
{
|
||||
/**
|
||||
* Find Tags.
|
||||
* Find all tags per user.
|
||||
*
|
||||
* @param int $userId
|
||||
* @param int $cacheLifeTime Duration of the cache for this query
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function findAllTags($userId, $cacheLifeTime = null)
|
||||
{
|
||||
$query = $this->createQueryBuilder('t')
|
||||
->select('t')
|
||||
->leftJoin('t.entries', 'e')
|
||||
->where('e.user = :userId')->setParameter('userId', $userId)
|
||||
->groupBy('t.slug')
|
||||
->getQuery();
|
||||
|
||||
if (null !== $cacheLifeTime) {
|
||||
$query->useQueryCache(true);
|
||||
$query->useResultCache(true);
|
||||
$query->setResultCacheLifetime($cacheLifeTime);
|
||||
}
|
||||
|
||||
return $query->getArrayResult();
|
||||
}
|
||||
|
||||
/**
|
||||
* Find all tags with associated entries per user.
|
||||
*
|
||||
* @param int $userId
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function findAllTags($userId)
|
||||
public function findAllTagsWithEntries($userId)
|
||||
{
|
||||
return $this->createQueryBuilder('t')
|
||||
->leftJoin('t.entries', 'e')
|
||||
->where('e.user = :userId')->setParameter('userId', $userId);
|
||||
->where('e.user = :userId')->setParameter('userId', $userId)
|
||||
->getQuery()
|
||||
->getResult();
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user