2015-11-26 17:49:14 +03:00
|
|
|
<?php
|
2019-12-03 21:57:53 +03:00
|
|
|
|
2018-02-21 23:56:00 +03:00
|
|
|
declare(strict_types=1);
|
2019-12-03 21:57:53 +03:00
|
|
|
|
2015-11-26 17:49:14 +03:00
|
|
|
/**
|
2016-07-21 18:07:57 +03:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
2020-04-29 12:57:22 +03:00
|
|
|
* @author Christoph Wurst <christoph@winzerhof-wurst.at>
|
2016-07-21 18:07:57 +03:00
|
|
|
* @author Joas Schilling <coding@schilljs.com>
|
2017-11-06 17:56:42 +03:00
|
|
|
* @author Jörn Friedrich Dreyer <jfd@butonic.de>
|
|
|
|
* @author Roeland Jago Douma <roeland@famdouma.nl>
|
2015-11-26 17:49:14 +03:00
|
|
|
* @author Vincent Petry <pvince81@owncloud.com>
|
|
|
|
*
|
|
|
|
* @license AGPL-3.0
|
|
|
|
*
|
|
|
|
* This code is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* 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, version 3,
|
2019-12-03 21:57:53 +03:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
2015-11-26 17:49:14 +03:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OC\SystemTag;
|
|
|
|
|
2015-11-30 12:12:15 +03:00
|
|
|
use Doctrine\DBAL\Exception\UniqueConstraintViolationException;
|
2016-01-25 19:17:36 +03:00
|
|
|
use OCP\DB\QueryBuilder\IQueryBuilder;
|
2015-11-30 12:12:15 +03:00
|
|
|
use OCP\IDBConnection;
|
2019-11-22 22:52:10 +03:00
|
|
|
use OCP\IGroupManager;
|
|
|
|
use OCP\IUser;
|
|
|
|
use OCP\SystemTag\ISystemTag;
|
2015-11-30 12:12:15 +03:00
|
|
|
use OCP\SystemTag\ISystemTagManager;
|
2016-02-01 14:19:48 +03:00
|
|
|
use OCP\SystemTag\ManagerEvent;
|
2015-11-30 12:12:15 +03:00
|
|
|
use OCP\SystemTag\TagAlreadyExistsException;
|
|
|
|
use OCP\SystemTag\TagNotFoundException;
|
2016-02-01 14:19:48 +03:00
|
|
|
use Symfony\Component\EventDispatcher\EventDispatcherInterface;
|
2015-11-26 17:49:14 +03:00
|
|
|
|
2016-04-27 13:47:04 +03:00
|
|
|
/**
|
|
|
|
* Manager class for system tags
|
|
|
|
*/
|
2015-11-30 12:12:15 +03:00
|
|
|
class SystemTagManager implements ISystemTagManager {
|
2020-04-10 17:54:27 +03:00
|
|
|
public const TAG_TABLE = 'systemtag';
|
|
|
|
public const TAG_GROUP_TABLE = 'systemtag_group';
|
2015-11-26 17:49:14 +03:00
|
|
|
|
2016-02-01 14:19:48 +03:00
|
|
|
/** @var IDBConnection */
|
|
|
|
protected $connection;
|
|
|
|
|
|
|
|
/** @var EventDispatcherInterface */
|
|
|
|
protected $dispatcher;
|
2015-11-26 17:49:14 +03:00
|
|
|
|
2016-04-27 13:47:04 +03:00
|
|
|
/** @var IGroupManager */
|
|
|
|
protected $groupManager;
|
|
|
|
|
2015-11-26 17:49:14 +03:00
|
|
|
/**
|
|
|
|
* Prepared query for selecting tags directly
|
|
|
|
*
|
|
|
|
* @var \OCP\DB\QueryBuilder\IQueryBuilder
|
|
|
|
*/
|
|
|
|
private $selectTagQuery;
|
|
|
|
|
|
|
|
/**
|
2016-02-01 14:19:48 +03:00
|
|
|
* Constructor.
|
|
|
|
*
|
|
|
|
* @param IDBConnection $connection database connection
|
2018-02-21 23:56:00 +03:00
|
|
|
* @param IGroupManager $groupManager
|
2016-02-01 14:19:48 +03:00
|
|
|
* @param EventDispatcherInterface $dispatcher
|
|
|
|
*/
|
2016-04-27 13:47:04 +03:00
|
|
|
public function __construct(
|
|
|
|
IDBConnection $connection,
|
|
|
|
IGroupManager $groupManager,
|
|
|
|
EventDispatcherInterface $dispatcher
|
|
|
|
) {
|
2015-11-26 17:49:14 +03:00
|
|
|
$this->connection = $connection;
|
2016-04-27 13:47:04 +03:00
|
|
|
$this->groupManager = $groupManager;
|
2016-02-01 14:19:48 +03:00
|
|
|
$this->dispatcher = $dispatcher;
|
2015-11-26 17:49:14 +03:00
|
|
|
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$this->selectTagQuery = $query->select('*')
|
|
|
|
->from(self::TAG_TABLE)
|
|
|
|
->where($query->expr()->eq('name', $query->createParameter('name')))
|
|
|
|
->andWhere($query->expr()->eq('visibility', $query->createParameter('visibility')))
|
|
|
|
->andWhere($query->expr()->eq('editable', $query->createParameter('editable')));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function getTagsByIds($tagIds): array {
|
|
|
|
if (!\is_array($tagIds)) {
|
2015-11-26 17:49:14 +03:00
|
|
|
$tagIds = [$tagIds];
|
|
|
|
}
|
|
|
|
|
|
|
|
$tags = [];
|
|
|
|
|
|
|
|
// note: not all databases will fail if it's a string or starts with a number
|
|
|
|
foreach ($tagIds as $tagId) {
|
|
|
|
if (!is_numeric($tagId)) {
|
|
|
|
throw new \InvalidArgumentException('Tag id must be integer');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->select('*')
|
|
|
|
->from(self::TAG_TABLE)
|
|
|
|
->where($query->expr()->in('id', $query->createParameter('tagids')))
|
|
|
|
->addOrderBy('name', 'ASC')
|
|
|
|
->addOrderBy('visibility', 'ASC')
|
|
|
|
->addOrderBy('editable', 'ASC')
|
2016-01-25 19:17:36 +03:00
|
|
|
->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY);
|
2015-11-26 17:49:14 +03:00
|
|
|
|
|
|
|
$result = $query->execute();
|
|
|
|
while ($row = $result->fetch()) {
|
|
|
|
$tags[$row['id']] = $this->createSystemTagFromRow($row);
|
|
|
|
}
|
|
|
|
|
|
|
|
$result->closeCursor();
|
|
|
|
|
2018-02-21 23:56:00 +03:00
|
|
|
if (\count($tags) !== \count($tagIds)) {
|
2015-12-01 16:51:26 +03:00
|
|
|
throw new TagNotFoundException(
|
|
|
|
'Tag id(s) not found', 0, null, array_diff($tagIds, array_keys($tags))
|
|
|
|
);
|
2015-11-26 17:49:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return $tags;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function getAllTags($visibilityFilter = null, $nameSearchPattern = null): array {
|
2015-11-26 17:49:14 +03:00
|
|
|
$tags = [];
|
|
|
|
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->select('*')
|
|
|
|
->from(self::TAG_TABLE);
|
|
|
|
|
2018-02-21 23:56:00 +03:00
|
|
|
if (!\is_null($visibilityFilter)) {
|
2015-11-26 17:49:14 +03:00
|
|
|
$query->andWhere($query->expr()->eq('visibility', $query->createNamedParameter((int)$visibilityFilter)));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($nameSearchPattern)) {
|
|
|
|
$query->andWhere(
|
|
|
|
$query->expr()->like(
|
|
|
|
'name',
|
2016-07-06 23:39:34 +03:00
|
|
|
$query->createNamedParameter('%' . $this->connection->escapeLikeParameter($nameSearchPattern). '%')
|
2015-11-26 17:49:14 +03:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$query
|
|
|
|
->addOrderBy('name', 'ASC')
|
|
|
|
->addOrderBy('visibility', 'ASC')
|
|
|
|
->addOrderBy('editable', 'ASC');
|
|
|
|
|
|
|
|
$result = $query->execute();
|
|
|
|
while ($row = $result->fetch()) {
|
|
|
|
$tags[$row['id']] = $this->createSystemTagFromRow($row);
|
|
|
|
}
|
|
|
|
|
|
|
|
$result->closeCursor();
|
|
|
|
|
|
|
|
return $tags;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function getTag(string $tagName, bool $userVisible, bool $userAssignable): ISystemTag {
|
2015-11-26 17:49:14 +03:00
|
|
|
$result = $this->selectTagQuery
|
|
|
|
->setParameter('name', $tagName)
|
2018-02-21 23:56:00 +03:00
|
|
|
->setParameter('visibility', $userVisible ? 1 : 0)
|
|
|
|
->setParameter('editable', $userAssignable ? 1 : 0)
|
2015-11-26 17:49:14 +03:00
|
|
|
->execute();
|
|
|
|
|
|
|
|
$row = $result->fetch();
|
|
|
|
$result->closeCursor();
|
|
|
|
if (!$row) {
|
|
|
|
throw new TagNotFoundException(
|
|
|
|
'Tag ("' . $tagName . '", '. $userVisible . ', ' . $userAssignable . ') does not exist'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->createSystemTagFromRow($row);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function createTag(string $tagName, bool $userVisible, bool $userAssignable): ISystemTag {
|
2015-11-26 17:49:14 +03:00
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->insert(self::TAG_TABLE)
|
|
|
|
->values([
|
|
|
|
'name' => $query->createNamedParameter($tagName),
|
2018-02-21 23:56:00 +03:00
|
|
|
'visibility' => $query->createNamedParameter($userVisible ? 1 : 0),
|
|
|
|
'editable' => $query->createNamedParameter($userAssignable ? 1 : 0),
|
2015-11-26 17:49:14 +03:00
|
|
|
]);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$query->execute();
|
|
|
|
} catch (UniqueConstraintViolationException $e) {
|
|
|
|
throw new TagAlreadyExistsException(
|
|
|
|
'Tag ("' . $tagName . '", '. $userVisible . ', ' . $userAssignable . ') already exists',
|
|
|
|
0,
|
|
|
|
$e
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-02-01 14:19:48 +03:00
|
|
|
$tagId = $query->getLastInsertId();
|
2015-11-26 17:49:14 +03:00
|
|
|
|
2016-02-01 14:19:48 +03:00
|
|
|
$tag = new SystemTag(
|
2018-02-21 23:56:00 +03:00
|
|
|
(string)$tagId,
|
2015-11-26 17:49:14 +03:00
|
|
|
$tagName,
|
2018-02-21 23:56:00 +03:00
|
|
|
$userVisible,
|
|
|
|
$userAssignable
|
2015-11-26 17:49:14 +03:00
|
|
|
);
|
2016-02-01 14:19:48 +03:00
|
|
|
|
|
|
|
$this->dispatcher->dispatch(ManagerEvent::EVENT_CREATE, new ManagerEvent(
|
|
|
|
ManagerEvent::EVENT_CREATE, $tag
|
|
|
|
));
|
|
|
|
|
|
|
|
return $tag;
|
2015-11-26 17:49:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function updateTag(string $tagId, string $tagName, bool $userVisible, bool $userAssignable) {
|
2016-02-01 14:19:48 +03:00
|
|
|
try {
|
|
|
|
$tags = $this->getTagsByIds($tagId);
|
|
|
|
} catch (TagNotFoundException $e) {
|
|
|
|
throw new TagNotFoundException(
|
|
|
|
'Tag does not exist', 0, null, [$tagId]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$beforeUpdate = array_shift($tags);
|
|
|
|
$afterUpdate = new SystemTag(
|
2018-02-21 23:56:00 +03:00
|
|
|
$tagId,
|
2016-02-01 14:19:48 +03:00
|
|
|
$tagName,
|
2018-02-21 23:56:00 +03:00
|
|
|
$userVisible,
|
|
|
|
$userAssignable
|
2016-02-01 14:19:48 +03:00
|
|
|
);
|
|
|
|
|
2015-11-26 17:49:14 +03:00
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->update(self::TAG_TABLE)
|
|
|
|
->set('name', $query->createParameter('name'))
|
|
|
|
->set('visibility', $query->createParameter('visibility'))
|
|
|
|
->set('editable', $query->createParameter('editable'))
|
|
|
|
->where($query->expr()->eq('id', $query->createParameter('tagid')))
|
|
|
|
->setParameter('name', $tagName)
|
2018-02-21 23:56:00 +03:00
|
|
|
->setParameter('visibility', $userVisible ? 1 : 0)
|
|
|
|
->setParameter('editable', $userAssignable ? 1 : 0)
|
2015-11-26 17:49:14 +03:00
|
|
|
->setParameter('tagid', $tagId);
|
|
|
|
|
|
|
|
try {
|
|
|
|
if ($query->execute() === 0) {
|
|
|
|
throw new TagNotFoundException(
|
2015-12-01 16:51:26 +03:00
|
|
|
'Tag does not exist', 0, null, [$tagId]
|
2015-11-26 17:49:14 +03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
} catch (UniqueConstraintViolationException $e) {
|
|
|
|
throw new TagAlreadyExistsException(
|
|
|
|
'Tag ("' . $tagName . '", '. $userVisible . ', ' . $userAssignable . ') already exists',
|
|
|
|
0,
|
|
|
|
$e
|
|
|
|
);
|
|
|
|
}
|
2016-02-01 14:19:48 +03:00
|
|
|
|
|
|
|
$this->dispatcher->dispatch(ManagerEvent::EVENT_UPDATE, new ManagerEvent(
|
|
|
|
ManagerEvent::EVENT_UPDATE, $afterUpdate, $beforeUpdate
|
|
|
|
));
|
2015-11-26 17:49:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function deleteTags($tagIds) {
|
2018-02-21 23:56:00 +03:00
|
|
|
if (!\is_array($tagIds)) {
|
2015-11-26 17:49:14 +03:00
|
|
|
$tagIds = [$tagIds];
|
|
|
|
}
|
|
|
|
|
2015-12-01 16:51:26 +03:00
|
|
|
$tagNotFoundException = null;
|
2016-02-01 14:19:48 +03:00
|
|
|
$tags = [];
|
2015-12-01 16:51:26 +03:00
|
|
|
try {
|
2016-02-01 14:19:48 +03:00
|
|
|
$tags = $this->getTagsByIds($tagIds);
|
2015-12-01 16:51:26 +03:00
|
|
|
} catch (TagNotFoundException $e) {
|
|
|
|
$tagNotFoundException = $e;
|
2016-02-01 14:19:48 +03:00
|
|
|
|
|
|
|
// Get existing tag objects for the hooks later
|
|
|
|
$existingTags = array_diff($tagIds, $tagNotFoundException->getMissingTags());
|
|
|
|
if (!empty($existingTags)) {
|
|
|
|
try {
|
|
|
|
$tags = $this->getTagsByIds($existingTags);
|
|
|
|
} catch (TagNotFoundException $e) {
|
|
|
|
// Ignore further errors...
|
|
|
|
}
|
|
|
|
}
|
2015-12-01 16:51:26 +03:00
|
|
|
}
|
|
|
|
|
2015-11-26 17:49:14 +03:00
|
|
|
// delete relationships first
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->delete(SystemTagObjectMapper::RELATION_TABLE)
|
|
|
|
->where($query->expr()->in('systemtagid', $query->createParameter('tagids')))
|
2016-01-25 19:17:36 +03:00
|
|
|
->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
|
2015-11-26 17:49:14 +03:00
|
|
|
->execute();
|
|
|
|
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->delete(self::TAG_TABLE)
|
|
|
|
->where($query->expr()->in('id', $query->createParameter('tagids')))
|
2016-01-25 19:17:36 +03:00
|
|
|
->setParameter('tagids', $tagIds, IQueryBuilder::PARAM_INT_ARRAY)
|
2015-12-01 16:51:26 +03:00
|
|
|
->execute();
|
2015-11-26 17:49:14 +03:00
|
|
|
|
2016-02-01 14:19:48 +03:00
|
|
|
foreach ($tags as $tag) {
|
|
|
|
$this->dispatcher->dispatch(ManagerEvent::EVENT_DELETE, new ManagerEvent(
|
|
|
|
ManagerEvent::EVENT_DELETE, $tag
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2015-12-01 16:51:26 +03:00
|
|
|
if ($tagNotFoundException !== null) {
|
2015-11-26 17:49:14 +03:00
|
|
|
throw new TagNotFoundException(
|
2015-12-01 16:51:26 +03:00
|
|
|
'Tag id(s) not found', 0, $tagNotFoundException, $tagNotFoundException->getMissingTags()
|
2015-11-26 17:49:14 +03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-27 13:47:04 +03:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function canUserAssignTag(ISystemTag $tag, IUser $user): bool {
|
2016-05-11 13:39:22 +03:00
|
|
|
// early check to avoid unneeded group lookups
|
2016-04-27 16:24:28 +03:00
|
|
|
if ($tag->isUserAssignable() && $tag->isUserVisible()) {
|
2016-04-27 13:47:04 +03:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-04-27 16:24:28 +03:00
|
|
|
if ($this->groupManager->isAdmin($user->getUID())) {
|
2016-04-27 13:47:04 +03:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-05-11 13:39:22 +03:00
|
|
|
if (!$tag->isUserVisible()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-05-11 17:47:33 +03:00
|
|
|
$groupIds = $this->groupManager->getUserGroupIds($user);
|
2016-05-11 13:39:22 +03:00
|
|
|
if (!empty($groupIds)) {
|
|
|
|
$matchingGroups = array_intersect($groupIds, $this->getTagGroups($tag));
|
|
|
|
if (!empty($matchingGroups)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-27 13:47:04 +03:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function canUserSeeTag(ISystemTag $tag, IUser $user): bool {
|
2016-04-27 13:47:04 +03:00
|
|
|
if ($tag->isUserVisible()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-04-27 16:24:28 +03:00
|
|
|
if ($this->groupManager->isAdmin($user->getUID())) {
|
2016-04-27 13:47:04 +03:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2015-11-26 17:49:14 +03:00
|
|
|
private function createSystemTagFromRow($row) {
|
2018-02-21 23:56:00 +03:00
|
|
|
return new SystemTag((string)$row['id'], $row['name'], (bool)$row['visibility'], (bool)$row['editable']);
|
2015-11-26 17:49:14 +03:00
|
|
|
}
|
2016-05-11 13:25:09 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function setTagGroups(ISystemTag $tag, array $groupIds) {
|
2016-05-11 13:25:09 +03:00
|
|
|
// delete relationships first
|
|
|
|
$this->connection->beginTransaction();
|
|
|
|
try {
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->delete(self::TAG_GROUP_TABLE)
|
|
|
|
->where($query->expr()->eq('systemtagid', $query->createNamedParameter($tag->getId())))
|
|
|
|
->execute();
|
|
|
|
|
|
|
|
// add each group id
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
|
|
|
$query->insert(self::TAG_GROUP_TABLE)
|
|
|
|
->values([
|
|
|
|
'systemtagid' => $query->createNamedParameter($tag->getId()),
|
|
|
|
'gid' => $query->createParameter('gid'),
|
|
|
|
]);
|
|
|
|
foreach ($groupIds as $groupId) {
|
2017-03-02 13:36:20 +03:00
|
|
|
if ($groupId === '') {
|
|
|
|
continue;
|
|
|
|
}
|
2016-05-11 13:25:09 +03:00
|
|
|
$query->setParameter('gid', $groupId);
|
|
|
|
$query->execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->connection->commit();
|
|
|
|
} catch (\Exception $e) {
|
2017-07-23 22:03:26 +03:00
|
|
|
$this->connection->rollBack();
|
2016-05-11 13:25:09 +03:00
|
|
|
throw $e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2018-02-21 23:56:00 +03:00
|
|
|
public function getTagGroups(ISystemTag $tag): array {
|
2016-05-11 13:25:09 +03:00
|
|
|
$groupIds = [];
|
|
|
|
$query = $this->connection->getQueryBuilder();
|
2016-05-18 12:31:41 +03:00
|
|
|
$query->select('gid')
|
2016-05-11 13:25:09 +03:00
|
|
|
->from(self::TAG_GROUP_TABLE)
|
|
|
|
->where($query->expr()->eq('systemtagid', $query->createNamedParameter($tag->getId())))
|
|
|
|
->orderBy('gid');
|
|
|
|
|
|
|
|
$result = $query->execute();
|
|
|
|
while ($row = $result->fetch()) {
|
|
|
|
$groupIds[] = $row['gid'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$result->closeCursor();
|
|
|
|
|
|
|
|
return $groupIds;
|
|
|
|
}
|
2015-11-26 17:49:14 +03:00
|
|
|
}
|