Skip to content

Commit

Permalink
sql
Browse files Browse the repository at this point in the history
Signed-off-by: Maxence Lange <[email protected]>
  • Loading branch information
ArtificialOwl committed Oct 3, 2023
1 parent ea22334 commit 3d272b9
Showing 1 changed file with 74 additions and 21 deletions.
95 changes: 74 additions & 21 deletions lib/private/FilesMetadata/FilesMetadataManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,17 +6,25 @@

use OC\FilesMetadata\Event\FilesMetadataEvent;
use OC\FilesMetadata\Model\FilesMetadata;
use OCP\DB\Exception;
use OCP\DB\QueryBuilder\IQueryBuilder;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\FilesMetadata\Exceptions\FilesMetadataNotFoundException;
use OCP\FilesMetadata\IFilesMetadata;
use OCP\FilesMetadata\IFilesMetadataManager;
use OCP\FilesMetadata\IFilesMetadataQueryHelper;
use OCP\IDBConnection;
use Psr\Log\LoggerInterface;

class FilesMetadataManager implements IFilesMetadataManager {
public const TABLE_METADATA = 'files_metadata';
public const TABLE_METADATA_INDEX = 'files_metadata_index';

public function __construct(
private IDBConnection $dbConnection,
private IEventDispatcher $eventDispatcher,
private FilesMetadataQueryHelper $filesMetadataQueryHelper,
private LoggerInterface $logger
) {
}

Expand All @@ -28,7 +36,7 @@ public function refreshMetadata(
$metadata = null;
if (!$fromScratch) {
try {
$metadata = $this->getMetadataFromDatabase($fileId);
$metadata = $this->selectMetadata($fileId);
} catch (FilesMetadataNotFoundException $e) {
}
}
Expand All @@ -53,7 +61,7 @@ public function refreshMetadata(
*/
public function getMetadata(int $fileId, bool $createIfNeeded = false): IFilesMetadata {
try {
return $this->getMetadataFromDatabase($fileId);
return $this->selectMetadata($fileId);
} catch (FilesMetadataNotFoundException $e) {
if ($createIfNeeded) {
return $this->refreshMetadata($fileId, true);
Expand All @@ -63,31 +71,21 @@ public function getMetadata(int $fileId, bool $createIfNeeded = false): IFilesMe
}
}

/**
* @param int $fileId
*
* @return IFilesMetadata
* @throws FilesMetadataNotFoundException
*/
public function getMetadataFromDatabase(int $fileId): IFilesMetadata {
$metadata = new FilesMetadata($fileId);
throw new FilesMetadataNotFoundException();

$json = '[]'; // get json from database;
// if entry exist in database.
$metadata->import($json);

return $metadata;
}


public function saveMetadata(IFilesMetadata $filesMetadata): void {
if ($filesMetadata->getFileId() === 0) {
return;
}

// database thing ...
// try to update first, if no update, insert as new
// update first, and insert if no row affected
try {
if (!$this->updateMetadata($filesMetadata)) {
$this->insertMetadata($filesMetadata);
}
} catch (Exception $e) {
$this->logger->warning('exception while saveMetadata()', ['exception' => $e]);
return;
}

// remove indexes from metadata_index that are not in the list of indexes anymore.
foreach ($filesMetadata->listIndexes() as $index) {
Expand All @@ -100,4 +98,59 @@ public function saveMetadata(IFilesMetadata $filesMetadata): void {
public function getQueryHelper(): IFilesMetadataQueryHelper {
return $this->filesMetadataQueryHelper;
}

public function insertMetadata(IFilesMetadata $filesMetadata): void {
$qb = $this->dbConnection->getQueryBuilder();
$qb->insert(self::TABLE_METADATA)
->setValue('file_id', $qb->createNamedParameter($filesMetadata->getFileId(), IQueryBuilder::PARAM_INT))
->setValue('json', $qb->createNamedParameter(json_encode($filesMetadata->jsonSerialize())))
->where($qb->expr()->eq('file_id', $qb->createNamedParameter($filesMetadata->getFileId(), IQueryBuilder::PARAM_INT)));
$qb->executeStatement();
}

/**
* @param IFilesMetadata $filesMetadata
*
* @return bool
* @throws Exception
*/
public function updateMetadata(IFilesMetadata $filesMetadata): bool {
// TODO check sync_token on update
$qb = $this->dbConnection->getQueryBuilder();
$qb->update(self::TABLE_METADATA)
->set('json', $qb->createNamedParameter(json_encode($filesMetadata->jsonSerialize())))
->where($qb->expr()->eq('file_id', $qb->createNamedParameter($filesMetadata->getFileId(), IQueryBuilder::PARAM_INT)));
return ($qb->executeStatement() > 0);
}


/**
* @param int $fileId
*
* @return IFilesMetadata
* @throws FilesMetadataNotFoundException
*/
private function selectMetadata(int $fileId): IFilesMetadata {
try {
$qb = $this->dbConnection->getQueryBuilder();
$qb->select('json')->from(self::TABLE_METADATA);
$qb->where($qb->expr()->eq('file_id', $qb->createNamedParameter($fileId, IQueryBuilder::PARAM_INT)));
$result = $qb->executeQuery();
$data = $result->fetch();
$result->closeCursor();
} catch (Exception $e) {
$this->logger->warning('exception while getMetadataFromDatabase()', ['exception' => $e, 'fileId' => $fileId]);
throw new FilesMetadataNotFoundException();
}

if ($data === false) {
throw new FilesMetadataNotFoundException();
}

$metadata = new FilesMetadata($fileId);
$metadata->import($data['json'] ?? '');

return $metadata;
}

}

0 comments on commit 3d272b9

Please sign in to comment.