aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoryemkareems <yemkareems@gmail.com>2024-05-30 15:38:06 +0530
committerMarcel Klehr <mklehr@gmx.net>2024-06-19 12:52:46 +0200
commitd0883b5e85f757aafacfb6d67062f34299a25b34 (patch)
treec9021429acfe578ce652c9ff21abab207986b2b1
parent8782b8724aa01ea7dbce91817b352613726cd133 (diff)
downloadnextcloud-server-d0883b5e85f757aafacfb6d67062f34299a25b34.tar.gz
nextcloud-server-d0883b5e85f757aafacfb6d67062f34299a25b34.zip
fix: filtering tags based on existing tags and doing a transaction around the select and insert
Signed-off-by: yemkareems <yemkareems@gmail.com>
-rw-r--r--lib/private/SystemTag/SystemTagObjectMapper.php25
1 files changed, 14 insertions, 11 deletions
diff --git a/lib/private/SystemTag/SystemTagObjectMapper.php b/lib/private/SystemTag/SystemTagObjectMapper.php
index 78e21d0cb27..852c3a28135 100644
--- a/lib/private/SystemTag/SystemTagObjectMapper.php
+++ b/lib/private/SystemTag/SystemTagObjectMapper.php
@@ -115,6 +115,7 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
}
$this->assertTagsExist($tagIds);
+ $this->connection->beginTransaction();
$query = $this->connection->getQueryBuilder();
$query->select('systemtagid')
@@ -124,6 +125,12 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
->andWhere($query->expr()->eq('objectid', $query->createNamedParameter($objId)));
$result = $query->executeQuery();
$rows = $result->fetchAll();
+ $existingTags = [];
+ foreach ($rows as $k => $row) {
+ $existingTags[] = $row['systemtagid'];
+ }
+ //filter only tags that do not exist in db
+ $tagIds = array_diff($tagIds, $existingTags);
$query = $this->connection->getQueryBuilder();
$query->insert(self::RELATION_TABLE)
@@ -135,20 +142,16 @@ class SystemTagObjectMapper implements ISystemTagObjectMapper {
$tagsAssigned = [];
foreach ($tagIds as $tagId) {
- if(!in_array($tagId, array_column($rows, 'systemtagid'))) {
- // tag not in db so create new one
- try {
- $query->setParameter('tagid', $tagId);
- $query->execute();
- $tagsAssigned[] = $tagId;
- } catch (UniqueConstraintViolationException $e) {
- // ignore existing relations
- }
- } else {
- //tag exists already don't insert
+ try {
+ $query->setParameter('tagid', $tagId);
+ $query->execute();
+ $tagsAssigned[] = $tagId;
+ } catch (UniqueConstraintViolationException $e) {
+ // ignore existing relations
}
}
+ $this->connection->commit();
if (empty($tagsAssigned)) {
return;
}