Completed
Push — master ( ec3803...963c88 )
by Maxence
02:31
created

EventWrapperRequest   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 79
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Importance

Changes 0
Metric Value
wmc 5
lcom 1
cbo 3
dl 0
loc 79
rs 10
c 0
b 0
f 0

5 Methods

Rating   Name   Duplication   Size   Complexity  
A save() 0 17 1
A update() 0 10 1
A updateAll() 0 8 1
A getFailedEvents() 0 6 1
A getByToken() 0 6 1
1
<?php
2
3
declare(strict_types=1);
4
5
6
/**
7
 * Circles - Bring cloud-users closer together.
8
 *
9
 * This file is licensed under the Affero General Public License version 3 or
10
 * later. See the COPYING file.
11
 *
12
 * @author Maxence Lange <[email protected]>
13
 * @copyright 2017
14
 * @license GNU AGPL version 3 or any later version
15
 *
16
 * This program is free software: you can redistribute it and/or modify
17
 * it under the terms of the GNU Affero General Public License as
18
 * published by the Free Software Foundation, either version 3 of the
19
 * License, or (at your option) any later version.
20
 *
21
 * This program is distributed in the hope that it will be useful,
22
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 * GNU Affero General Public License for more details.
25
 *
26
 * You should have received a copy of the GNU Affero General Public License
27
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
28
 *
29
 */
30
31
32
namespace OCA\Circles\Db;
33
34
35
use OCA\Circles\Model\Federated\EventWrapper;
36
37
38
/**
39
 * Class EventWrapperRequest
40
 *
41
 * @package OCA\Circles\Db
42
 */
43
class EventWrapperRequest extends EventWrapperRequestBuilder {
44
45
46
	/**
47
	 * @param EventWrapper $wrapper
48
	 */
49
	public function save(EventWrapper $wrapper): void {
50
		$qb = $this->getEventWrapperInsertSql();
51
		$qb->setValue('token', $qb->createNamedParameter($wrapper->getToken()))
52
		   ->setValue(
53
			   'event', $qb->createNamedParameter(json_encode($wrapper->getEvent(), JSON_UNESCAPED_SLASHES))
54
		   )
55
		   ->setValue(
56
			   'result', $qb->createNamedParameter(json_encode($wrapper->getResult(), JSON_UNESCAPED_SLASHES))
57
		   )
58
		   ->setValue('instance', $qb->createNamedParameter($wrapper->getInstance()))
59
		   ->setValue('interface', $qb->createNamedParameter($wrapper->getInterface()))
60
		   ->setValue('severity', $qb->createNamedParameter($wrapper->getSeverity()))
61
		   ->setValue('status', $qb->createNamedParameter($wrapper->getStatus()))
62
		   ->setValue('creation', $qb->createNamedParameter($wrapper->getCreation()));
63
64
		$qb->execute();
65
	}
66
67
	/**
68
	 * @param EventWrapper $wrapper
69
	 */
70
	public function update(EventWrapper $wrapper): void {
71
		$qb = $this->getEventWrapperUpdateSql();
72
		$qb->set('result', $qb->createNamedParameter(json_encode($wrapper->getResult())))
73
		   ->set('status', $qb->createNamedParameter($wrapper->getStatus()));
74
75
		$qb->limitToInstance($wrapper->getInstance());
76
		$qb->limitToToken($wrapper->getToken());
77
78
		$qb->execute();
79
	}
80
81
82
	/**
83
	 * @param string $token
84
	 * @param int $status
85
	 */
86
	public function updateAll(string $token, int $status): void {
87
		$qb = $this->getEventWrapperUpdateSql();
88
		$qb->set('status', $qb->createNamedParameter($status));
89
90
		$qb->limitToToken($token);
91
92
		$qb->execute();
93
	}
94
95
96
	/**
97
	 * returns unique token not set as FAILED
98
	 *
99
	 * @return EventWrapper[]
100
	 */
101
	public function getFailedEvents(): array {
102
		$qb = $this->getEventWrapperSelectSql();
103
		$qb->limitInt('status', EventWrapper::STATUS_FAILED);
104
105
		return $this->getItemsFromRequest($qb);
106
	}
107
108
109
	/**
110
	 * @param string $token
111
	 *
112
	 * @return EventWrapper[]
113
	 */
114
	public function getByToken(string $token): array {
115
		$qb = $this->getEventWrapperSelectSql();
116
		$qb->limitToToken($token);
117
118
		return $this->getItemsFromRequest($qb);
119
	}
120
121
}
122
123