nextcloud-swarm-plugin/lib/Db/SwarmFileMapper.php
Karim Vergnes 04deba7cfa
fix(files_scan): Fixed disappearing files issue (#65)
The missing getDirectoryContent() method was preventing the indexer from
discovering files within the root folder, so it didn't bother and marked
everything as nonexistent.

This commit also includes a fix for files disappearing when the parent
folder is renamed.

This fix supersedes #64
2024-09-18 12:44:31 +02:00

147 lines
4.5 KiB
PHP
Executable file

<?php
declare(strict_types=1);
/**
* @copyright Copyright (c) 2022, MetaProvide Holding EKF
*
* @author Ron Trevor <ecoron@proton.me>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCA\Files_External_Ethswarm\Db;
use OCP\AppFramework\Db\DoesNotExistException;
use OCP\AppFramework\Db\QBMapper;
use OCP\IDBConnection;
use OCP\Files\IMimeTypeLoader;
/**
* @template-extends QBMapper<SwarmFile>
*/
class SwarmFileMapper extends QBMapper {
public const TABLE_NAME = 'files_swarm';
public function __construct(IDBConnection $db) {
parent::__construct($db, self::TABLE_NAME);
}
/**
* @return SwarmFile[]
*/
public function findAll(string $fileid): array {
$qb = $this->db->getQueryBuilder();
$select = $qb
->select('*')
->from($this->getTableName())
->where($qb->expr()->eq('fileid', $qb->createNamedParameter($fileid)));
return $this->findEntities($select);
}
/**
* @param string $name
* @param int $storage
*
* @return SwarmFile
* @throws DoesNotExistException
*/
public function find(string $name, int $storage): SwarmFile {
$qb = $this->db->getQueryBuilder();
$select = $qb
->select('*')
->from($this->getTableName())
->where($qb->expr()->eq('name', $qb->createNamedParameter($name, $qb::PARAM_STR)))
->andWhere($qb->expr()->eq('storage', $qb->createNamedParameter($storage, $qb::PARAM_INT)));
return $this->findEntity($select);
}
/**
* @param string $name
* @param int $storage
*
* @return count of elements in array
*/
public function findExists(string $name, int $storage): int {
$qb = $this->db->getQueryBuilder();
$select = $qb
->select('id')
->from($this->getTableName())
->where($qb->expr()->eq('name', $qb->createNamedParameter($name, $qb::PARAM_STR)))
->andWhere($qb->expr()->eq('storage', $qb->createNamedParameter($storage, $qb::PARAM_INT)));
return count($this->findEntities($select));
}
public function createDirectory(string $path, int $storage): SwarmFile {
$swarm = new SwarmFile();
$swarm->setName($path);
$swarm->setMimetype(\OC::$server->get(IMimeTypeLoader::class)->getId("httpd/unix-directory"));
$swarm->setSize(1);
$swarm->setStorageMtime(time());
$swarm->setStorage($storage);
return $this->insert($swarm);
}
public function createFile(array $filearray): SwarmFile {
$swarm = new SwarmFile();
$swarm->setName($filearray["name"]);
$swarm->setSwarmReference($filearray["reference"]);
$swarm->setSwarmTag($filearray["etag"]);
$swarm->setMimetype($filearray["mimetype"]);
$swarm->setSize($filearray["size"]);
$swarm->setStorageMtime($filearray["storage_mtime"]);
$swarm->setStorage($filearray["storage"]);
return $this->insert($swarm);
}
public function getPathTree(string $path1, int $storage, bool $incSelf = true): array {
// Get files from directory tree based on path parameter
$dir = array();
if ($incSelf) {
try {
array_push($dir, $this->find($path1, $storage));
} catch (DoesNotExistException $e) {
}
}
if ($path1 !== '')
$path1 .= '/';
$qb = $this->db->getQueryBuilder();
$select = $qb
->select('*')
->from($this->getTableName())
->where($qb->expr()->like('name', $qb->createNamedParameter($this->db->escapeLikeParameter($path1) . '%', $qb::PARAM_STR)))
->andWhere($qb->expr()->eq('storage', $qb->createNamedParameter($storage, $qb::PARAM_INT)));
return array_merge($dir, $this->findEntities($select));
}
public function updatePath(string $path1, string $path2, int $storage): int {
$qb = $this->db->getQueryBuilder();
$qb
->update($this->getTableName())
->set('name', $qb->createNamedParameter($path2))
->where($qb->expr()->eq('name', $qb->createNamedParameter($path1, $qb::PARAM_STR)))
->andWhere($qb->expr()->eq('storage', $qb->createNamedParameter($storage, $qb::PARAM_INT)));
$sql = $qb->getSQL();
return $qb->executeStatement();
}
}