0
0
Fork 0
mirror of https://github.com/verdigado/groupfolder_tags.git synced 2024-12-06 11:42:42 +01:00

finished table schema; added tag service; added first occ command

This commit is contained in:
Jonathan Treffler 2024-08-20 14:43:02 +02:00 committed by Jonathan Treffler
parent afa35503d8
commit 3156833ff0
4 changed files with 134 additions and 14 deletions

View file

@ -10,8 +10,12 @@ use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
use OCA\GroupfolderTags\Service\TagService;
class Tag extends Base {
public function __construct() {
public function __construct(
private TagService $service,
) {
parent::__construct();
}
@ -26,13 +30,13 @@ class Tag extends Base {
'Add or update tag of the given groupfolder id'
)
->addOption(
'tag_key',
'key',
null,
InputOption::VALUE_REQUIRED,
'Set tag key to given value'
)
->addOption(
'tag_value',
'value',
null,
InputOption::VALUE_OPTIONAL,
'Set tag value to given value'
@ -40,11 +44,28 @@ class Tag extends Base {
}
protected function execute(InputInterface $input, OutputInterface $output): int {
$errors = [];
$groupFolderId = $input->getOption('groupfolder_id');
$tagKey = $input->getOption('tag_key');
$tagValue = $input->getOption('tag_value');
$tagKey = $input->getOption('key');
$tagValue = $input->getOption('value');
$output->writeln($groupFolderId . " " . $tagKey . " " . $tagValue);
return 0;
if(!is_numeric($groupFolderId)) {
$errors[] = "no group folder id provided";
}
if(is_null($tagKey) || $tagKey === "") {
$errors[] = "no tag key provided";
}
if(empty($errors)) {
$output->writeln($groupFolderId . " " . $tagKey . " " . $tagValue);
$output->writeln(json_encode($this->service->update((int)$groupFolderId, $tagKey, $tagValue)));
return 0;
} else {
$output->writeln("Error: \n" . implode("\n", $errors));
return 1;
}
}
}

View file

@ -10,6 +10,7 @@ use OCP\IDBConnection;
class TagMapper extends QBMapper {
public const TABLENAME = 'groupfolder_tags';
public const GROUP_FOLDERS_TABLENAME = "group_folders";
public function __construct(IDBConnection $db) {
parent::__construct($db, self::TABLENAME, Tag::class);
@ -34,8 +35,29 @@ class TagMapper extends QBMapper {
}
/**
* @param int $groupFolderId
* @param string $tagKey
* @param string|null $tagValue
* @return Entity|Tag
* @throws \OCP\AppFramework\Db\MultipleObjectsReturnedException
* @throws DoesNotExistException
*/
public function findIncludingGroupfolder(int $groupFolderId, string $tagKey): Tag {
/* @var $qb IQueryBuilder */
$qb = $this->db->getQueryBuilder();
$qb->select('*')
->from(self::TABLENAME, "t")
->where($qb->expr()->eq('group_folder_id', $qb->createNamedParameter($groupFolderId, IQueryBuilder::PARAM_INT)))
->andWhere($qb->expr()->eq('tag_key', $qb->createNamedParameter($tagKey)))
->leftJoin('t', self::GROUP_FOLDERS_TABLENAME, 'g', $qb->expr()->andX(
$qb->expr()->eq('t.group_folder_id', 'g.id'),
));
return $this->findOneQuery($qb);
}
/**
* @param string $tagKey
* @param string|null $tagValue
* @return array
*/
public function findAll(string $tagKey, ?string $tagValue): array {
@ -45,9 +67,9 @@ class TagMapper extends QBMapper {
->from(self::TABLENAME)
->where($qb->expr()->eq('tag_key', $qb->createNamedParameter($tagKey)));
if(isset($tagValue)) {
$qb->andWhere($qb->expr()->eq('tag_value', $qb->createNamedParameter($tagValue)));
}
if(isset($tagValue)) {
$qb->andWhere($qb->expr()->eq('tag_value', $qb->createNamedParameter($tagValue)));
}
return $this->findEntities($qb);
}

View file

@ -26,6 +26,10 @@ class Version000000Date20240731110600 extends SimpleMigrationStep {
if (!$schema->hasTable(self::GROUP_FOLDER_TAGS_TABLE)) {
$table = $schema->createTable(self::GROUP_FOLDER_TAGS_TABLE);
$table->addColumn('id', Types::INTEGER, [
'autoincrement' => true,
'notnull' => true,
]);
$table->addColumn('group_folder_id', Types::BIGINT, [
'notnull' => true,
'length' => 20,
@ -35,14 +39,14 @@ class Version000000Date20240731110600 extends SimpleMigrationStep {
'length' => 50,
]);
$table->addColumn('tag_value', Types::STRING, [
'notnull' => true,
'notnull' => false,
'length' => 200,
]);
$table->addColumn('last_updated_timestamp', Types::BIGINT, [
'notnull' => true,
]);
$table->setPrimaryKey(['group_folder_id', 'tag_key']);
$table->setPrimaryKey(['id']);
$table->addUniqueIndex(['group_folder_id', 'tag_key'], "groupfolder_tags_group_folder_id_tag_key_index");
$table->addIndex(['group_folder_id'], 'groupfolder_tags_group_folder_id_index');
$table->addForeignKeyConstraint(
$schema->getTable(self::GROUP_FOLDERS_TABLE),

View file

@ -0,0 +1,73 @@
<?php
namespace OCA\GroupfolderTags\Service;
use Exception;
use OCP\AppFramework\Db\DoesNotExistException;
use OCP\AppFramework\Db\MultipleObjectsReturnedException;
use OCA\GroupfolderTags\Errors\TagNotFound;
use OCA\GroupfolderTags\Db\Tag;
use OCA\GroupfolderTags\Db\TagMapper;
class TagService {
public function __construct(
private TagMapper $mapper
) {
}
public function findAllWithTagKey(string $tagKey, ?string $tagValue): array {
return $this->mapper->findAll($tagKey, $tagValue);
}
private function handleException(Exception $e): void {
if ($e instanceof DoesNotExistException ||
$e instanceof MultipleObjectsReturnedException) {
throw new TagNotFound($e->getMessage());
} else {
throw $e;
}
}
public function find(int $groupFolderId, string $tagKey): Tag {
try {
return $this->mapper->find($groupFolderId, $tagKey);
} catch (Exception $e) {
$this->handleException($e);
}
}
public function update(int $groupFolderId, string $key, ?string $value): Tag {
try {
$tag = $this->find($groupFolderId, $key);
$tagExists = True;
} catch(TagNotFound $error) {
$tag = new Tag();
$tag->setGroupFolderId($groupFolderId);
$tag->setTagKey($key);
$tagExists = False;
}
$tag->setTagValue($value);
$tag->setLastUpdatedTimestamp(time());
if($tagExists) {
return $this->mapper->update($tag);
} else {
return $this->mapper->insert($tag);
}
}
public function delete(int $groupFolderId, string $key): Tag {
try {
$tag = $this->mapper->find($groupFolderId, $key);
$this->mapper->delete($tag);
return $tag;
} catch (Exception $e) {
$this->handleException($e);
}
}
}