2016-02-26 12:59:08 +00:00
|
|
|
<?php
|
|
|
|
|
2024-02-19 00:30:12 +00:00
|
|
|
namespace Wallabag\Repository;
|
2016-02-26 12:59:08 +00:00
|
|
|
|
2022-08-27 21:01:09 +00:00
|
|
|
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
|
2017-07-29 20:51:50 +00:00
|
|
|
use Doctrine\ORM\QueryBuilder;
|
2022-08-27 21:01:09 +00:00
|
|
|
use Doctrine\Persistence\ManagerRegistry;
|
2024-02-19 00:30:12 +00:00
|
|
|
use Wallabag\Entity\Annotation;
|
2016-02-26 12:59:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* AnnotationRepository.
|
2022-11-23 14:51:33 +00:00
|
|
|
*
|
|
|
|
* @method Annotation|null findOneById(int $id)
|
2016-02-26 12:59:08 +00:00
|
|
|
*/
|
2022-08-27 21:01:09 +00:00
|
|
|
class AnnotationRepository extends ServiceEntityRepository
|
2016-02-26 12:59:08 +00:00
|
|
|
{
|
2022-08-27 21:01:09 +00:00
|
|
|
public function __construct(ManagerRegistry $registry)
|
|
|
|
{
|
|
|
|
parent::__construct($registry, Annotation::class);
|
|
|
|
}
|
|
|
|
|
2016-02-26 12:59:08 +00:00
|
|
|
/**
|
|
|
|
* Retrieves all annotations for a user.
|
|
|
|
*
|
|
|
|
* @param int $userId
|
|
|
|
*
|
|
|
|
* @return QueryBuilder
|
|
|
|
*/
|
|
|
|
public function getBuilderForAllByUser($userId)
|
|
|
|
{
|
|
|
|
return $this
|
2018-09-02 15:32:32 +00:00
|
|
|
->getSortedQueryBuilderByUser($userId)
|
2016-02-26 12:59:08 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get annotation for this id.
|
|
|
|
*
|
|
|
|
* @param int $annotationId
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function findAnnotationById($annotationId)
|
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->andWhere('a.id = :annotationId')->setParameter('annotationId', $annotationId)
|
2016-10-22 10:09:20 +00:00
|
|
|
->getQuery()
|
|
|
|
->getSingleResult()
|
2016-02-26 12:59:08 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
2023-01-23 11:16:09 +00:00
|
|
|
/**
|
|
|
|
* Find annotation by id and user.
|
|
|
|
*
|
|
|
|
* @param int $annotationId
|
|
|
|
* @param int $userId
|
|
|
|
*
|
|
|
|
* @return Annotation
|
|
|
|
*/
|
|
|
|
public function findOneByIdAndUserId($annotationId, $userId)
|
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
2023-04-24 12:45:28 +00:00
|
|
|
->where('a.id = :annotationId')->setParameter('annotationId', $annotationId)
|
|
|
|
->andWhere('a.user = :userId')->setParameter('userId', $userId)
|
|
|
|
->setMaxResults(1)
|
|
|
|
->getQuery()
|
|
|
|
->getOneOrNullResult();
|
2023-01-23 11:16:09 +00:00
|
|
|
}
|
|
|
|
|
2016-02-26 12:59:08 +00:00
|
|
|
/**
|
|
|
|
* Find annotations for entry id.
|
|
|
|
*
|
|
|
|
* @param int $entryId
|
|
|
|
* @param int $userId
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2023-01-23 11:16:09 +00:00
|
|
|
public function findByEntryIdAndUserId($entryId, $userId)
|
2016-02-26 12:59:08 +00:00
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->where('a.entry = :entryId')->setParameter('entryId', $entryId)
|
|
|
|
->andwhere('a.user = :userId')->setParameter('userId', $userId)
|
2016-10-22 10:09:20 +00:00
|
|
|
->getQuery()
|
|
|
|
->getResult()
|
2016-02-26 12:59:08 +00:00
|
|
|
;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Find last annotation for a given entry id. Used only for tests.
|
|
|
|
*
|
|
|
|
* @param int $entryId
|
|
|
|
*
|
2023-04-24 12:45:28 +00:00
|
|
|
* @return Annotation|null
|
2016-02-26 12:59:08 +00:00
|
|
|
*/
|
2023-01-23 11:16:09 +00:00
|
|
|
public function findLastAnnotationByUserId($entryId, $userId)
|
2016-02-26 12:59:08 +00:00
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->where('a.entry = :entryId')->setParameter('entryId', $entryId)
|
|
|
|
->andwhere('a.user = :userId')->setParameter('userId', $userId)
|
|
|
|
->orderBy('a.id', 'DESC')
|
|
|
|
->setMaxResults(1)
|
|
|
|
->getQuery()
|
|
|
|
->getOneOrNullResult();
|
|
|
|
}
|
2016-03-11 16:56:41 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Used only in test case to get the right annotation associated to the right user.
|
|
|
|
*
|
|
|
|
* @param string $username
|
|
|
|
*
|
|
|
|
* @return Annotation
|
|
|
|
*/
|
|
|
|
public function findOneByUsername($username)
|
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->leftJoin('a.user', 'u')
|
|
|
|
->where('u.username = :username')->setParameter('username', $username)
|
2016-03-12 09:45:14 +00:00
|
|
|
->orderBy('a.id', 'DESC')
|
2016-03-11 16:56:41 +00:00
|
|
|
->setMaxResults(1)
|
|
|
|
->getQuery()
|
|
|
|
->getSingleResult();
|
|
|
|
}
|
2016-10-01 12:01:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all annotations for a user id.
|
2023-09-17 20:54:49 +00:00
|
|
|
* Used when a user wants to reset all information.
|
2016-10-01 12:01:13 +00:00
|
|
|
*
|
2016-10-08 09:14:09 +00:00
|
|
|
* @param int $userId
|
2016-10-01 12:01:13 +00:00
|
|
|
*/
|
|
|
|
public function removeAllByUserId($userId)
|
|
|
|
{
|
|
|
|
$this->getEntityManager()
|
2024-02-19 00:30:12 +00:00
|
|
|
->createQuery('DELETE FROM Wallabag\Entity\Annotation a WHERE a.user = :userId')
|
2016-10-11 19:45:43 +00:00
|
|
|
->setParameter('userId', $userId)
|
2016-10-01 12:01:13 +00:00
|
|
|
->execute();
|
|
|
|
}
|
2017-03-30 14:24:59 +00:00
|
|
|
|
|
|
|
/**
|
2017-03-31 08:53:23 +00:00
|
|
|
* Find all annotations related to archived entries.
|
2017-03-30 14:24:59 +00:00
|
|
|
*/
|
2017-03-31 15:03:08 +00:00
|
|
|
public function findAllArchivedEntriesByUser($userId)
|
2017-03-30 14:24:59 +00:00
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->leftJoin('a.entry', 'e')
|
|
|
|
->where('a.user = :userid')->setParameter(':userid', $userId)
|
|
|
|
->andWhere('e.isArchived = true')
|
|
|
|
->getQuery()
|
|
|
|
->getResult();
|
|
|
|
}
|
2017-07-01 07:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a query builder to used by other getBuilderFor* method.
|
|
|
|
*
|
|
|
|
* @param int $userId
|
|
|
|
*
|
|
|
|
* @return QueryBuilder
|
|
|
|
*/
|
2018-09-02 15:32:32 +00:00
|
|
|
private function getSortedQueryBuilderByUser($userId)
|
2017-07-01 07:52:38 +00:00
|
|
|
{
|
|
|
|
return $this->createQueryBuilder('a')
|
|
|
|
->leftJoin('a.user', 'u')
|
|
|
|
->andWhere('u.id = :userId')->setParameter('userId', $userId)
|
|
|
|
->orderBy('a.id', 'desc')
|
|
|
|
;
|
|
|
|
}
|
2016-02-26 12:59:08 +00:00
|
|
|
}
|