Fetch membership for assignments

Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
Julius Härtl
2020-10-12 16:06:31 +02:00
parent f188213cb7
commit 886d2b4d02
2 changed files with 59 additions and 23 deletions

View File

@@ -21,27 +21,34 @@
* *
*/ */
declare(strict_types=1);
namespace OCA\Deck\Db; namespace OCA\Deck\Db;
use OCA\Deck\Service\CirclesService;
use OCP\AppFramework\Db\Entity; use OCP\AppFramework\Db\Entity;
use OCP\AppFramework\Db\QBMapper;
use OCP\IDBConnection; use OCP\IDBConnection;
use OCP\IGroupManager; use OCP\IGroupManager;
use OCP\IUserManager; use OCP\IUserManager;
class AssignedUsersMapper extends DeckMapper implements IPermissionMapper { class AssignedUsersMapper extends QBMapper implements IPermissionMapper {
private $cardMapper;
private $userManager;
/**
* @var IGroupManager
*/
private $groupManager;
public function __construct(IDBConnection $db, CardMapper $cardMapper, IUserManager $userManager, IGroupManager $groupManager) { /** @var CardMapper */
private $cardMapper;
/** @var IUserManager */
private $userManager;
/** @var IGroupManager */
private $groupManager;
/** @var CirclesService */
private $circleService;
public function __construct(IDBConnection $db, CardMapper $cardMapper, IUserManager $userManager, IGroupManager $groupManager, CirclesService $circleService) {
parent::__construct($db, 'deck_assigned_users', AssignedUsers::class); parent::__construct($db, 'deck_assigned_users', AssignedUsers::class);
$this->cardMapper = $cardMapper; $this->cardMapper = $cardMapper;
$this->userManager = $userManager; $this->userManager = $userManager;
$this->groupManager = $groupManager; $this->groupManager = $groupManager;
$this->circleService = $circleService;
} }
/** /**
@@ -51,9 +58,12 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
* @return array|Entity * @return array|Entity
*/ */
public function find($cardId) { public function find($cardId) {
$sql = 'SELECT * FROM `*PREFIX*deck_assigned_users` ' . $qb = $this->db->getQueryBuilder();
'WHERE `card_id` = ?'; $qb->select('*')
$users = $this->findEntities($sql, [$cardId]); ->from('deck_assigned_users')
->where($qb->expr()->eq('card_id', $qb->createNamedParameter($cardId)));
/** @var AssignedUsers[] $users */
$users = $this->findEntities($qb);
foreach ($users as &$user) { foreach ($users as &$user) {
$this->mapParticipant($user); $this->mapParticipant($user);
} }
@@ -61,9 +71,12 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
} }
public function findByUserId($uid) { public function findByUserId($uid) {
$sql = 'SELECT * FROM `*PREFIX*deck_assigned_users` ' . $qb = $this->db->getQueryBuilder();
'WHERE `participant` = ?'; $qb->select('*')
return $this->findEntities($sql, [$uid]); ->from('deck_assigned_users')
->where($qb->expr()->eq('participant', $qb->createNamedParameter($uid)));
/** @var AssignedUsers[] $users */
return $this->findEntities($qb);
} }
@@ -81,24 +94,43 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
* @param Entity $entity * @param Entity $entity
* @return null|Entity * @return null|Entity
*/ */
public function insert(Entity $entity) { public function insert(Entity $entity): Entity {
$origin = $this->getOrigin($entity); $origin = $this->getOrigin($entity);
if ($origin !== null) { if ($origin === null) {
/** @var AssignedUsers $assignment */ throw new \Exception('No origin found for assignment');
$assignment = parent::insert($entity);
$this->mapParticipant($assignment);
return $assignment;
} }
return null; /** @var AssignedUsers $assignment */
$assignment = parent::insert($entity);
$this->mapParticipant($assignment);
return $assignment;
} }
public function mapParticipant(AssignedUsers &$assignment) { public function mapParticipant(AssignedUsers $assignment): void {
$self = $this; $self = $this;
$assignment->resolveRelation('participant', function () use (&$self, &$assignment) { $assignment->resolveRelation('participant', function () use (&$self, &$assignment) {
return $self->getOrigin($assignment); return $self->getOrigin($assignment);
}); });
} }
public function isUserAssigned($cardId, $userId): bool {
$assignments = $this->find($cardId);
/** @var AssignedUsers $assignment */
foreach ($assignments as $assignment) {
$origin = $this->getOrigin($assignment);
if ($origin instanceof User && $assignment->getParticipant() === $userId) {
return true;
}
if ($origin instanceof Group && $this->groupManager->isInGroup($userId, $assignment->getParticipant())) {
return true;
}
if ($origin instanceof Circle && $this->circleService->isUserInCircle($assignment->getParticipant(), $userId)) {
return true;
}
}
return false;
}
private function getOrigin(AssignedUsers $assignment) { private function getOrigin(AssignedUsers $assignment) {
if ($assignment->getType() === AssignedUsers::TYPE_USER) { if ($assignment->getType() === AssignedUsers::TYPE_USER) {
$origin = $this->userManager->get($assignment->getParticipant()); $origin = $this->userManager->get($assignment->getParticipant());
@@ -109,7 +141,7 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
return $origin ? new Group($origin) : null; return $origin ? new Group($origin) : null;
} }
if ($assignment->getType() === AssignedUsers::TYPE_CIRCLE) { if ($assignment->getType() === AssignedUsers::TYPE_CIRCLE) {
$origin = $this->groupManager->get($assignment->getParticipant()); $origin = $this->circleService->getCircle($assignment->getParticipant());
return $origin ? new Circle($origin) : null; return $origin ? new Circle($origin) : null;
} }
return null; return null;

View File

@@ -57,4 +57,8 @@ class RelationalObject implements \JsonSerializable {
throw new \Exception('jsonSerialize is not implemented on ' . get_class($this)); throw new \Exception('jsonSerialize is not implemented on ' . get_class($this));
} }
} }
public function getPrimaryKey(): string {
return $this->primaryKey;
}
} }