2016-09-12 01:45:20 +08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Nextcloud - passman
|
|
|
|
*
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later. See the COPYING file.
|
|
|
|
*
|
|
|
|
* @author Sander Brand <brantje@gmail.com>
|
|
|
|
* @copyright Sander Brand 2016
|
|
|
|
*/
|
|
|
|
namespace OCA\Passman\Db;
|
|
|
|
|
|
|
|
use OCA\Passman\Utility\Utils;
|
|
|
|
use OCP\IDBConnection;
|
|
|
|
use OCP\AppFramework\Db\Mapper;
|
|
|
|
|
|
|
|
class CredentialMapper extends Mapper {
|
|
|
|
private $utils;
|
|
|
|
public function __construct(IDBConnection $db, Utils $utils) {
|
|
|
|
parent::__construct($db, 'passman_credentials');
|
|
|
|
$this->utils = $utils;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @throws \OCP\AppFramework\Db\DoesNotExistException if not found
|
|
|
|
* @throws \OCP\AppFramework\Db\MultipleObjectsReturnedException if more than one result
|
|
|
|
*/
|
2016-09-12 02:47:29 +08:00
|
|
|
public function getCredentialsByVaultId($vault_id, $user_id) {
|
|
|
|
$sql = 'SELECT * FROM `*PREFIX*passman_credentials` ' .
|
2016-09-12 04:14:11 +08:00
|
|
|
'WHERE `user_id` = ? and vault_id = ?';
|
2016-09-12 02:47:29 +08:00
|
|
|
return $this->findEntities($sql, [$user_id, $vault_id]);
|
2016-09-12 01:45:20 +08:00
|
|
|
}
|
|
|
|
|
2016-10-16 03:03:50 +08:00
|
|
|
/**
|
|
|
|
* @param $vault_id
|
|
|
|
* @param $user_id
|
|
|
|
* @return Credential[]
|
|
|
|
*/
|
2016-10-01 02:43:20 +08:00
|
|
|
public function getRandomCredentialByVaultId($vault_id, $user_id) {
|
|
|
|
$sql = 'SELECT * FROM `*PREFIX*passman_credentials` ' .
|
2016-10-16 04:35:29 +08:00
|
|
|
'WHERE `user_id` = ? and vault_id = ? AND shared_key is NULL LIMIT 20';
|
2016-10-16 04:34:45 +08:00
|
|
|
$entities = $this->findEntities($sql, [$user_id, $vault_id]);
|
2016-10-16 04:37:23 +08:00
|
|
|
$count = count($entities)-1;
|
2016-10-16 04:34:45 +08:00
|
|
|
$entities = array_splice($entities, rand(0, $count), 1);
|
|
|
|
return $entities;
|
2016-10-01 02:43:20 +08:00
|
|
|
}
|
|
|
|
|
2016-10-16 03:03:50 +08:00
|
|
|
/**
|
|
|
|
* @param $timestamp
|
|
|
|
* @return Credential[]
|
|
|
|
*/
|
2016-09-23 21:05:27 +08:00
|
|
|
public function getExpiredCredentials($timestamp){
|
|
|
|
$sql = 'SELECT * FROM `*PREFIX*passman_credentials` ' .
|
|
|
|
'WHERE `expire_time` > 0 AND `expire_time` < ?';
|
|
|
|
return $this->findEntities($sql, [$timestamp]);
|
|
|
|
}
|
|
|
|
|
2016-10-04 02:38:40 +08:00
|
|
|
/**
|
|
|
|
* @param $credential_id
|
|
|
|
* @param null $user_id
|
|
|
|
* @return Credential
|
|
|
|
*/
|
2016-10-02 23:32:22 +08:00
|
|
|
public function getCredentialById($credential_id, $user_id = null){
|
2016-09-23 22:52:41 +08:00
|
|
|
$sql = 'SELECT * FROM `*PREFIX*passman_credentials` ' .
|
2016-10-02 23:32:22 +08:00
|
|
|
'WHERE `id` = ?';
|
|
|
|
// If we want to check the owner, add it to the query
|
2016-10-03 01:29:06 +08:00
|
|
|
$params = [$credential_id];
|
|
|
|
if ($user_id !== null){
|
|
|
|
$sql .= ' and `user_id` = ? ';
|
|
|
|
array_push($params, $user_id);
|
|
|
|
}
|
|
|
|
return $this->findEntity($sql,$params);
|
2016-09-23 22:52:41 +08:00
|
|
|
}
|
|
|
|
|
2016-10-02 21:39:52 +08:00
|
|
|
public function getCredentialLabelById($credential_id){
|
|
|
|
$sql = 'SELECT id, label FROM `*PREFIX*passman_credentials` ' .
|
|
|
|
'WHERE `id` = ? ';
|
|
|
|
return $this->findEntity($sql,[$credential_id]);
|
|
|
|
}
|
|
|
|
|
2016-09-12 01:45:20 +08:00
|
|
|
public function create($raw_credential){
|
|
|
|
$credential = new Credential();
|
|
|
|
|
|
|
|
$credential->setGuid($this->utils->GUID());
|
|
|
|
$credential->setVaultId($raw_credential['vault_id']);
|
|
|
|
$credential->setUserId($raw_credential['user_id']);
|
|
|
|
$credential->setLabel($raw_credential['label']);
|
|
|
|
$credential->setDescription($raw_credential['description']);
|
|
|
|
$credential->setCreated($this->utils->getTime());
|
|
|
|
$credential->setChanged($this->utils->getTime());
|
|
|
|
$credential->setTags($raw_credential['tags']);
|
|
|
|
$credential->setEmail($raw_credential['email']);
|
|
|
|
$credential->setUsername($raw_credential['username']);
|
|
|
|
$credential->setPassword($raw_credential['password']);
|
|
|
|
$credential->setUrl($raw_credential['url']);
|
|
|
|
$credential->setFavicon($raw_credential['favicon']);
|
|
|
|
$credential->setRenewInterval($raw_credential['renew_interval']);
|
|
|
|
$credential->setExpireTime($raw_credential['expire_time']);
|
|
|
|
$credential->setDeleteTime($raw_credential['delete_time']);
|
|
|
|
$credential->setFiles($raw_credential['files']);
|
|
|
|
$credential->setCustomFields($raw_credential['custom_fields']);
|
|
|
|
$credential->setOtp($raw_credential['otp']);
|
|
|
|
$credential->setHidden($raw_credential['hidden']);
|
2016-10-03 23:38:45 +08:00
|
|
|
$credential->setSharedKey($raw_credential['shared_key']);
|
2016-09-12 01:45:20 +08:00
|
|
|
return parent::insert($credential);
|
|
|
|
}
|
|
|
|
|
2016-09-24 00:17:47 +08:00
|
|
|
public function updateCredential($raw_credential){
|
2016-09-16 20:01:25 +08:00
|
|
|
if(!$raw_credential['guid']){
|
|
|
|
$raw_credential['guid'] = $this->utils->GUID();
|
|
|
|
}
|
|
|
|
if(!$raw_credential['created']){
|
|
|
|
$raw_credential['created'] = $this->utils->getTime();
|
|
|
|
}
|
2016-09-15 03:12:10 +08:00
|
|
|
$credential = new Credential();
|
|
|
|
$credential->setId($raw_credential['credential_id']);
|
2016-09-16 20:01:25 +08:00
|
|
|
$credential->setGuid($raw_credential['guid']);
|
|
|
|
$credential->setVaultId($raw_credential['vault_id']);
|
2016-09-15 03:12:10 +08:00
|
|
|
$credential->setUserId($raw_credential['user_id']);
|
|
|
|
$credential->setLabel($raw_credential['label']);
|
|
|
|
$credential->setDescription($raw_credential['description']);
|
2016-09-16 20:01:25 +08:00
|
|
|
$credential->setCreated($raw_credential['created']);
|
2016-09-15 03:12:10 +08:00
|
|
|
$credential->setChanged($this->utils->getTime());
|
|
|
|
$credential->setTags($raw_credential['tags']);
|
|
|
|
$credential->setEmail($raw_credential['email']);
|
|
|
|
$credential->setUsername($raw_credential['username']);
|
|
|
|
$credential->setPassword($raw_credential['password']);
|
|
|
|
$credential->setUrl($raw_credential['url']);
|
|
|
|
$credential->setFavicon($raw_credential['favicon']);
|
|
|
|
$credential->setRenewInterval($raw_credential['renew_interval']);
|
|
|
|
$credential->setExpireTime($raw_credential['expire_time']);
|
|
|
|
$credential->setFiles($raw_credential['files']);
|
|
|
|
$credential->setCustomFields($raw_credential['custom_fields']);
|
|
|
|
$credential->setOtp($raw_credential['otp']);
|
|
|
|
$credential->setHidden($raw_credential['hidden']);
|
2016-09-16 20:01:25 +08:00
|
|
|
$credential->setDeleteTime($raw_credential['delete_time']);
|
2016-10-03 02:18:51 +08:00
|
|
|
$credential->setSharedKey($raw_credential['shared_key']);
|
2016-09-15 03:12:10 +08:00
|
|
|
return parent::update($credential);
|
|
|
|
}
|
|
|
|
|
2016-09-24 03:30:07 +08:00
|
|
|
public function deleteCredential(Credential $credential){
|
2016-10-08 20:49:59 +08:00
|
|
|
return $this->delete($credential);
|
2016-09-24 03:30:07 +08:00
|
|
|
}
|
|
|
|
|
2016-09-24 00:17:47 +08:00
|
|
|
public function upd(Credential $credential){
|
|
|
|
$this->update($credential);
|
|
|
|
}
|
2016-10-04 20:40:48 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Finds a credential by the given guid
|
|
|
|
* @param $credential_guid
|
|
|
|
* @return Credential
|
|
|
|
*/
|
2016-10-07 18:43:54 +08:00
|
|
|
public function getCredentialByGUID($credential_guid, $user_id = null){
|
2016-10-04 20:40:48 +08:00
|
|
|
$q = 'SELECT * FROM `*PREFIX*passman_credentials` WHERE guid = ? ';
|
2016-10-07 18:43:54 +08:00
|
|
|
$params = [$credential_guid];
|
|
|
|
if ($user_id !== null){
|
|
|
|
$q .= ' and `user_id` = ? ';
|
|
|
|
array_push($params, $user_id);
|
|
|
|
}
|
|
|
|
return $this->findEntity($q, $params);
|
2016-10-04 20:40:48 +08:00
|
|
|
}
|
2016-09-12 01:45:20 +08:00
|
|
|
}
|