Add backend for assigning groups to cards
Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
@@ -30,10 +30,16 @@ class AssignedUsers extends RelationalEntity implements JsonSerializable {
|
||||
public $id;
|
||||
protected $participant;
|
||||
protected $cardId;
|
||||
protected $type;
|
||||
|
||||
public const TYPE_USER = Acl::PERMISSION_TYPE_USER;
|
||||
public const TYPE_GROUP = Acl::PERMISSION_TYPE_GROUP;
|
||||
public const TYPE_CIRCLE = Acl::PERMISSION_TYPE_CIRCLE;
|
||||
|
||||
public function __construct() {
|
||||
$this->addType('id', 'integer');
|
||||
$this->addType('cardId', 'integer');
|
||||
$this->addType('type', 'integer');
|
||||
$this->addResolvable('participant');
|
||||
}
|
||||
|
||||
|
||||
@@ -26,6 +26,7 @@ namespace OCA\Deck\Db;
|
||||
|
||||
use OCP\AppFramework\Db\Entity;
|
||||
use OCP\IDBConnection;
|
||||
use OCP\IGroupManager;
|
||||
use OCP\IUserManager;
|
||||
|
||||
|
||||
@@ -33,11 +34,16 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
|
||||
|
||||
private $cardMapper;
|
||||
private $userManager;
|
||||
/**
|
||||
* @var IGroupManager
|
||||
*/
|
||||
private $groupManager;
|
||||
|
||||
public function __construct(IDBConnection $db, CardMapper $cardMapper, IUserManager $userManager) {
|
||||
public function __construct(IDBConnection $db, CardMapper $cardMapper, IUserManager $userManager, IGroupManager $groupManager) {
|
||||
parent::__construct($db, 'deck_assigned_users', AssignedUsers::class);
|
||||
$this->cardMapper = $cardMapper;
|
||||
$this->userManager = $userManager;
|
||||
$this->groupManager = $groupManager;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -78,8 +84,8 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
|
||||
* @return null|Entity
|
||||
*/
|
||||
public function insert(Entity $entity) {
|
||||
$user = $this->userManager->get($entity->getParticipant());
|
||||
if ($user !== null) {
|
||||
$origin = $this->getOrigin($entity);
|
||||
if ($origin !== null) {
|
||||
/** @var AssignedUsers $assignment */
|
||||
$assignment = parent::insert($entity);
|
||||
$this->mapParticipant($assignment);
|
||||
@@ -89,15 +95,26 @@ class AssignedUsersMapper extends DeckMapper implements IPermissionMapper {
|
||||
}
|
||||
|
||||
public function mapParticipant(AssignedUsers &$assignment) {
|
||||
$userManager = $this->userManager;
|
||||
$assignment->resolveRelation('participant', function() use (&$userManager, &$assignment) {
|
||||
$user = $userManager->get($assignment->getParticipant());
|
||||
if ($user !== null) {
|
||||
return new User($user);
|
||||
}
|
||||
return null;
|
||||
$self = $this;
|
||||
$assignment->resolveRelation('participant', function() use (&$self, &$assignment) {
|
||||
return $self->getOrigin($assignment);
|
||||
});
|
||||
}
|
||||
|
||||
private function getOrigin(AssignedUsers $assignment) {
|
||||
if ($assignment->getType() === AssignedUsers::TYPE_USER) {
|
||||
$origin = $this->userManager->get($assignment->getParticipant());
|
||||
return $origin ? new User($origin) : null;
|
||||
}
|
||||
if ($assignment->getType() === AssignedUsers::TYPE_GROUP) {
|
||||
$origin = $this->groupManager->get($assignment->getParticipant());
|
||||
return $origin ? new Group($origin) : null;
|
||||
}
|
||||
if ($assignment->getType() === AssignedUsers::TYPE_CIRCLE) {
|
||||
$origin = $this->groupManager->get($assignment->getParticipant());
|
||||
return $origin ? new Circle($origin) : null;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -232,7 +232,10 @@ class BoardMapper extends DeckMapper implements IPermissionMapper {
|
||||
\OC::$server->getLogger()->debug('Group ' . $acl->getId() . ' not found when mapping acl ' . $acl->getParticipant());
|
||||
return null;
|
||||
}
|
||||
if ($acl->getType() === Acl::PERMISSION_TYPE_CIRCLE && $this->circlesEnabled) {
|
||||
if ($acl->getType() === Acl::PERMISSION_TYPE_CIRCLE) {
|
||||
if (!$this->circlesEnabled) {
|
||||
return null;
|
||||
}
|
||||
try {
|
||||
$circle = \OCA\Circles\Api\v1\Circles::detailsCircle($acl->getParticipant(), true);
|
||||
if ($circle) {
|
||||
|
||||
Reference in New Issue
Block a user