Fetch membership for assignments
Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
@@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user