Passed
Pull Request — master (#1587)
by René
04:20
created

WatchMapper::deleteOldEntries()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 7
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 5
dl 0
loc 7
rs 10
c 1
b 0
f 0
cc 1
nc 1
nop 1
1
<?php
2
/**
3
 * @copyright Copyright (c) 2021 René Gieling <[email protected]>
4
 *
5
 * @author René Gieling <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 *  This program is free software: you can redistribute it and/or modify
10
 *  it under the terms of the GNU Affero General Public License as
11
 *  published by the Free Software Foundation, either version 3 of the
12
 *  License, or (at your option) any later version.
13
 *
14
 *  This program is distributed in the hope that it will be useful,
15
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 *  GNU Affero General Public License for more details.
18
 *
19
 *  You should have received a copy of the GNU Affero General Public License
20
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
24
namespace OCA\Polls\Db;
25
26
use OCP\IDBConnection;
27
use OCP\AppFramework\Db\QBMapper;
28
29
/**
30
 * @template-extends QBMapper<Watch>
31
 */
32
class WatchMapper extends QBMapper {
33
	public function __construct(IDBConnection $db) {
34
		parent::__construct($db, 'polls_watch', '\OCA\Polls\Db\Watch');
35
	}
36
37
	/**
38
	 * @throws \OCP\AppFramework\Db\DoesNotExistException if not found
39
	 * @return Watch[]
40
	 */
41
	public function findUpdatesForPollId(int $pollId, int $offset): array {
42
		$qb = $this->db->getQueryBuilder();
43
44
		$qb->select('*')
45
		   ->from($this->getTableName())
46
		   ->where($qb->expr()->gt('updated', $qb->createNamedParameter($offset)))
47
		   ->andWhere($qb->expr()->orX(
48
			   $qb->expr()->eq('poll_id', $qb->createNamedParameter($pollId)),
49
			   $qb->expr()->eq('table', $qb->createNamedParameter('polls'))
50
		   ));
51
52
		return $this->findEntities($qb);
53
	}
54
55
	/**
56
	 * @throws \OCP\AppFramework\Db\DoesNotExistException if not found
57
	 * @return Watch
58
	 */
59
	public function findForPollIdAndTable(int $pollId, string $table): Watch {
60
		$qb = $this->db->getQueryBuilder();
61
62
		$qb->select('*')
63
		   ->from($this->getTableName())
64
		   ->where(
65
			   $qb->expr()->eq('poll_id', $qb->createNamedParameter($pollId))
66
		   )
67
		   ->andWhere(
68
			   $qb->expr()->eq('table', $qb->createNamedParameter($table))
69
		   );
70
71
		return $this->findEntity($qb);
72
	}
73
74
	/**
75
	 * Delete entries per timestamp
76
	 * @return void
77
	 */
78
	public function deleteOldEntries(int $offset): void {
79
		$query = $this->db->getQueryBuilder();
80
		$query->delete($this->getTableName())
81
			->where(
82
				$query->expr()->lt('updated', $query->createNamedParameter($offset))
83
			);
84
		$query->execute();
85
	}
86
}
87