2016-09-15 00:57:38 +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 FileMapper extends Mapper {
|
|
|
|
private $utils;
|
2016-10-05 20:09:15 +08:00
|
|
|
|
2016-09-15 00:57:38 +08:00
|
|
|
public function __construct(IDBConnection $db, Utils $utils) {
|
|
|
|
parent::__construct($db, 'passman_files');
|
|
|
|
$this->utils = $utils;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2016-10-05 20:09:15 +08:00
|
|
|
* @param $file_id
|
|
|
|
* @param null $user_id
|
|
|
|
* @return File
|
2016-09-15 00:57:38 +08:00
|
|
|
* @throws \OCP\AppFramework\Db\DoesNotExistException if not found
|
|
|
|
* @throws \OCP\AppFramework\Db\MultipleObjectsReturnedException if more than one result
|
|
|
|
*/
|
2016-10-05 20:09:15 +08:00
|
|
|
public function getFile($file_id, $user_id = null) {
|
2016-09-15 00:57:38 +08:00
|
|
|
$sql = 'SELECT * FROM `*PREFIX*passman_files` ' .
|
2016-10-05 20:09:15 +08:00
|
|
|
'WHERE `id` = ?';
|
|
|
|
$params = [$file_id];
|
|
|
|
if ($user_id !== null) {
|
|
|
|
$sql .= ' and `user_id` = ? ';
|
|
|
|
array_push($params, $user_id);
|
|
|
|
}
|
|
|
|
return $this->findEntities($sql, $params);
|
2016-09-15 00:57:38 +08:00
|
|
|
}
|
|
|
|
|
2016-10-05 20:09:15 +08:00
|
|
|
public function create($file_raw, $userId) {
|
2016-09-15 00:57:38 +08:00
|
|
|
$file = new File();
|
|
|
|
$file->setGuid($this->utils->GUID());
|
|
|
|
$file->setUserId($userId);
|
|
|
|
$file->setFilename($file_raw['filename']);
|
|
|
|
$file->setSize($file_raw['size']);
|
|
|
|
$file->setCreated($this->utils->getTime());
|
|
|
|
$file->setFileData($file_raw['file_data']);
|
|
|
|
$file->setMimetype($file_raw['mimetype']);
|
|
|
|
|
|
|
|
|
|
|
|
return $this->insert($file);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function deleteFile($file_id, $userId) {
|
|
|
|
$file = new File();
|
|
|
|
$file->setId($file_id);
|
|
|
|
$file->setUserId($userId);
|
2016-09-15 05:04:38 +08:00
|
|
|
$this->delete($file);
|
2016-09-15 00:57:38 +08:00
|
|
|
}
|
2016-10-05 20:09:15 +08:00
|
|
|
|
|
|
|
public function updateFile(File $file) {
|
|
|
|
return $this->update($file);
|
|
|
|
}
|
2016-09-15 00:57:38 +08:00
|
|
|
}
|