Failed Conditions
Pull Request — master (#682)
by
unknown
09:41
created

lib/Db/VaultMapper.php (1 issue)

Labels
Severity

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
/**
3
 * Nextcloud - passman
4
 *
5
 * @copyright Copyright (c) 2016, Sander Brand ([email protected])
6
 * @copyright Copyright (c) 2016, Marcos Zuriaga Miguel ([email protected])
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\Passman\Db;
25
26
use OCA\Passman\Utility\Utils;
27
use OCP\AppFramework\Db\DoesNotExistException;
28
use OCP\AppFramework\Db\Entity;
29
use OCP\AppFramework\Db\MultipleObjectsReturnedException;
30
use OCP\AppFramework\Db\QBMapper;
31
use OCP\DB\QueryBuilder\IQueryBuilder;
32
use OCP\IDBConnection;
33
34
class VaultMapper extends QBMapper {
35
	const TABLE_NAME = 'passman_vaults';
36
	private Utils $utils;
0 ignored issues
show
This code did not parse for me. Apparently, there is an error somewhere around this line:

Syntax error, unexpected T_STRING, expecting T_FUNCTION or T_CONST
Loading history...
37
38
	public function __construct(IDBConnection $db, Utils $utils) {
39
		parent::__construct($db, self::TABLE_NAME);
40
		$this->utils = $utils;
41
	}
42
43
44
	/**
45
	 * @param int $vault_id
46
	 * @param string $user_id
47
	 * @return Vault[]
48
	 */
49
	public function find(int $vault_id, string $user_id) {
50
		$qb = $this->db->getQueryBuilder();
51
		$qb->select('*')
52
			->from(self::TABLE_NAME)
53
			->where($qb->expr()->eq('id', $qb->createNamedParameter($vault_id, IQueryBuilder::PARAM_INT)))
54
			->andWhere($qb->expr()->eq('user_id', $qb->createNamedParameter($user_id, IQueryBuilder::PARAM_STR)));
55
56
		/** @var Vault[] $vaults */
57
		$vaults = $this->findEntities($qb);
58
		return $vaults;
59
	}
60
61
	/**
62
	 * @param string $vault_guid
63
	 * @param string $user_id
64
	 * @return Vault
65
	 * @throws DoesNotExistException
66
	 * @throws MultipleObjectsReturnedException
67
	 */
68
	public function findByGuid(string $vault_guid, string $user_id) {
69
		$qb = $this->db->getQueryBuilder();
70
		$qb->select('*')
71
			->from(self::TABLE_NAME)
72
			->where($qb->expr()->eq('guid', $qb->createNamedParameter($vault_guid, IQueryBuilder::PARAM_STR)))
73
			->andWhere($qb->expr()->eq('user_id', $qb->createNamedParameter($user_id, IQueryBuilder::PARAM_STR)));
74
75
		/** @var Vault $vault */
76
		$vault = $this->findEntity($qb);
77
		return $vault;
78
	}
79
80
81
	/**
82
	 * @param string $user_id
83
	 * @return Vault[]
84
	 */
85
	public function findVaultsFromUser(string $user_id) {
86
		$qb = $this->db->getQueryBuilder();
87
		$qb->select('*')
88
			->from(self::TABLE_NAME)
89
			->where($qb->expr()->eq('user_id', $qb->createNamedParameter($user_id, IQueryBuilder::PARAM_STR)));
90
91
		/** @var Vault[] $vaults */
92
		$vaults = $this->findEntities($qb);
93
		return $vaults;
94
	}
95
96
	/**
97
	 * Creates a vault
98
	 *
99
	 * @param string $vault_name
100
	 * @param string $user_id
101
	 * @return Vault|Entity
102
	 */
103
	public function create(string $vault_name, string $user_id) {
104
		$vault = new Vault();
105
		$vault->setName($vault_name);
106
		$vault->setUserId($user_id);
107
		$vault->setGuid($this->utils->GUID());
108
		$vault->setCreated($this->utils->getTime());
109
		$vault->setLastAccess(0);
110
		return parent::insert($vault);
111
	}
112
113
	/**
114
	 * Update last access time of a vault
115
	 *
116
	 * @param int $vault_id
117
	 * @param string $user_id
118
	 * @return Vault|Entity
119
	 */
120
	public function setLastAccess(int $vault_id, string $user_id) {
121
		$vault = new Vault();
122
		$vault->setId($vault_id);
123
		$vault->setUserId($user_id);
124
		$vault->setLastAccess(Utils::getTime());
125
		return $this->update($vault);
126
	}
127
128
	/**
129
	 * Update vault
130
	 *
131
	 * @param Vault $vault
132
	 * @return Vault|Entity
133
	 */
134
	public function updateVault(Vault $vault) {
135
		return $this->update($vault);
136
	}
137
138
	/**
139
	 * Update the sharing key's
140
	 *
141
	 * @param int $vault_id
142
	 * @param string $privateKey
143
	 * @param string $publicKey
144
	 * @return Vault|Entity
145
	 */
146
	public function updateSharingKeys(int $vault_id, string $privateKey, string $publicKey) {
147
		$vault = new Vault();
148
		$vault->setId($vault_id);
149
		$vault->setPrivateSharingKey($privateKey);
150
		$vault->setPublicSharingKey($publicKey);
151
		$vault->setSharingKeysGenerated($this->utils->getTime());
152
		return $this->update($vault);
153
	}
154
155
	/**
156
	 * Delete a vault
157
	 *
158
	 * @param Vault $vault
159
	 */
160
	public function deleteVault(Vault $vault) {
161
		$this->delete($vault);
162
	}
163
}
164