Completed
Pull Request — master (#93)
by Janis
14:24
created

OcrJobMapper   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 64
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 6
lcom 0
cbo 0
dl 0
loc 64
rs 10
c 1
b 0
f 0

6 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 3 1
A find() 0 4 1
A findAll() 0 4 1
A findAllProcessed() 0 4 1
A findAllPending() 0 4 1
A findAllFailed() 0 4 1
1
<?php
2
/**
3
 * Nextcloud - OCR
4
 *
5
 * This file is licensed under the Affero General Public License version 3 or
6
 * later. See the COPYING file.
7
 *
8
 * @author Janis Koehr <[email protected]>
9
 * @copyright Janis Koehr 2017
10
 */
11
12
namespace OCA\Ocr\Db;
13
14
use OCP\AppFramework\Db\Mapper;
15
use OCP\IDBConnection;
16
17
/**
18
 * Class OcrJobMapper
19
 *
20
 * @package OCA\Ocr\Db
21
 */
22
class OcrJobMapper extends Mapper {
23
24
	/**
25
	 * OcrJobMapper constructor.
26
	 *
27
	 * @param IDBConnection $db
28
	 */
29
	public function __construct(IDBConnection $db) {
30
		parent::__construct($db, 'ocr_jobs', 'OCA\Ocr\Db\OcrJob');
31
	}
32
33
	/**
34
	 * Find a specific job entity
35
	 *
36
	 * @param $id
37
	 * @return OcrJob
38
	 */
39
	public function find($id) {
40
		$sql = 'SELECT * FROM *PREFIX*ocr_jobs WHERE id = ?';
41
		return $this->findEntity($sql, [$id]);
42
	}
43
44
	/**
45
	 * Finds all user specific jobs entities
46
	 *
47
	 * @param $userId
48
	 * @return OcrJob[]
49
	 */
50
	public function findAll($userId) {
51
		$sql = 'SELECT * FROM *PREFIX*ocr_jobs WHERE user_id = ?';
52
		return $this->findEntities($sql, [$userId]);
53
	}
54
55
	/**
56
	 * Finds all jobs PROCESSED entities for a given userid
57
	 * @param $userId
58
	 * @return OcrJob[]
59
	 */
60
	public function findAllProcessed($userId) {
61
		$sql = 'SELECT * FROM *PREFIX*ocr_jobs WHERE user_id = ? AND status = ?';
62
		return $this->findEntities($sql, [$userId, 'PROCESSED']);
63
	}
64
65
	/**
66
	 * Finds all jobs PENDING entities for a given userid
67
	 * @param $userId
68
	 * @return OcrJob[]
69
	 */
70
	public function findAllPending($userId) {
71
		$sql = 'SELECT * FROM *PREFIX*ocr_jobs WHERE user_id = ? AND status = ?';
72
		return $this->findEntities($sql, [$userId, 'PENDING']);
73
	}
74
75
	/**
76
	 * Finds all jobs FAILED entities for a given userid
77
	 * @param $userId
78
	 * @return OcrJob[]
79
	 */
80
	public function findAllFailed($userId) {
81
		$sql = 'SELECT * FROM *PREFIX*ocr_jobs WHERE user_id = ? AND status = ? AND error_displayed = ?';
82
		return $this->findEntities($sql, [$userId, 'FAILED', false]);
83
	}
84
85
}