123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- <?php
- declare(strict_types=1);
- /**
- * @copyright 2020 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Georg Ehrke <oc.list@georgehrke.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- */
- namespace OCA\ContactsInteraction\Db;
- use OCP\AppFramework\Db\DoesNotExistException;
- use OCP\AppFramework\Db\QBMapper;
- use OCP\IDBConnection;
- use OCP\IUser;
- /**
- * @template-extends QBMapper<RecentContact>
- */
- class RecentContactMapper extends QBMapper {
- public const TABLE_NAME = 'recent_contact';
- public function __construct(IDBConnection $db) {
- parent::__construct($db, self::TABLE_NAME);
- }
- /**
- * @return RecentContact[]
- */
- public function findAll(string $uid): array {
- $qb = $this->db->getQueryBuilder();
- $select = $qb
- ->select('*')
- ->from($this->getTableName())
- ->where($qb->expr()->eq('actor_uid', $qb->createNamedParameter($uid)));
- return $this->findEntities($select);
- }
- /**
- * @throws DoesNotExistException
- */
- public function find(string $uid, int $id): RecentContact {
- $qb = $this->db->getQueryBuilder();
- $select = $qb
- ->select('*')
- ->from($this->getTableName())
- ->where($qb->expr()->eq('id', $qb->createNamedParameter($id, $qb::PARAM_INT)))
- ->andWhere($qb->expr()->eq('actor_uid', $qb->createNamedParameter($uid)));
- return $this->findEntity($select);
- }
- /**
- * @return RecentContact[]
- */
- public function findMatch(IUser $user,
- ?string $uid,
- ?string $email,
- ?string $cloudId): array {
- $qb = $this->db->getQueryBuilder();
- $or = $qb->expr()->orX();
- if ($uid !== null) {
- $or->add($qb->expr()->eq('uid', $qb->createNamedParameter($uid)));
- }
- if ($email !== null) {
- $or->add($qb->expr()->eq('email', $qb->createNamedParameter($email)));
- }
- if ($cloudId !== null) {
- $or->add($qb->expr()->eq('federated_cloud_id', $qb->createNamedParameter($cloudId)));
- }
- $select = $qb
- ->select('*')
- ->from($this->getTableName())
- ->where($or)
- ->andWhere($qb->expr()->eq('actor_uid', $qb->createNamedParameter($user->getUID())));
- return $this->findEntities($select);
- }
- public function findLastUpdatedForUserId(string $uid): ?int {
- $qb = $this->db->getQueryBuilder();
- $select = $qb
- ->select('last_contact')
- ->from($this->getTableName())
- ->where($qb->expr()->eq('actor_uid', $qb->createNamedParameter($uid)))
- ->orderBy('last_contact', 'DESC')
- ->setMaxResults(1);
- $cursor = $select->executeQuery();
- $row = $cursor->fetch();
- if ($row === false) {
- return null;
- }
- return (int)$row['last_contact'];
- }
- public function cleanUp(int $olderThan): void {
- $qb = $this->db->getQueryBuilder();
- $delete = $qb
- ->delete($this->getTableName())
- ->where($qb->expr()->lt('last_contact', $qb->createNamedParameter($olderThan)));
- $delete->executeStatement();
- }
- }
|