Fix Acl
This commit is contained in:
@@ -30,22 +30,26 @@ class Acl extends Entity implements \JsonSerializable {
|
|||||||
const PERMISSION_SHARE = 2;
|
const PERMISSION_SHARE = 2;
|
||||||
const PERMISSION_MANAGE = 3;
|
const PERMISSION_MANAGE = 3;
|
||||||
|
|
||||||
|
const PERMISSION_TYPE_USER = 0;
|
||||||
|
const PERMISSION_TYPE_GROUP = 1;
|
||||||
|
|
||||||
public $id;
|
public $id;
|
||||||
protected $participant;
|
protected $participant;
|
||||||
protected $type;
|
protected $type;
|
||||||
protected $boardId;
|
protected $boardId;
|
||||||
protected $permissionEdit;
|
protected $permissionEdit = false;
|
||||||
protected $permissionShare;
|
protected $permissionShare = false;
|
||||||
protected $permissionManage;
|
protected $permissionManage = false;
|
||||||
protected $owner;
|
protected $owner = false;
|
||||||
|
|
||||||
public function __construct() {
|
public function __construct() {
|
||||||
$this->addType('id','integer');
|
$this->addType('id', 'integer');
|
||||||
$this->addType('boardId','integer');
|
$this->addType('boardId', 'integer');
|
||||||
$this->addType('permissionEdit', 'boolean');
|
$this->addType('permissionEdit', 'boolean');
|
||||||
$this->addType('permissionShare', 'boolean');
|
$this->addType('permissionShare', 'boolean');
|
||||||
$this->addType('permissionManage', 'boolean');
|
$this->addType('permissionManage', 'boolean');
|
||||||
$this->addType('owner', 'boolean');
|
$this->addType('owner', 'boolean');
|
||||||
|
$this->addType('type', 'integer');
|
||||||
$this->addRelation('owner');
|
$this->addRelation('owner');
|
||||||
$this->setPermissionEdit(false);
|
$this->setPermissionEdit(false);
|
||||||
$this->setPermissionShare(false);
|
$this->setPermissionShare(false);
|
||||||
@@ -70,12 +74,33 @@ class Acl extends Entity implements \JsonSerializable {
|
|||||||
return [
|
return [
|
||||||
'id' => $this->id,
|
'id' => $this->id,
|
||||||
'participant' => $this->participant,
|
'participant' => $this->participant,
|
||||||
'type' => $this->type,
|
'type' => $this->getType(),
|
||||||
'boardId' => $this->boardId,
|
'boardId' => $this->boardId,
|
||||||
'permissionEdit' => $this->permissionEdit,
|
'permissionEdit' => $this->getPermissionEdit(),
|
||||||
'permissionShare' => $this->permissionShare,
|
'permissionShare' => $this->getPermissionShare(),
|
||||||
'permissionManage' => $this->permissionManage,
|
'permissionManage' => $this->getPermissionManage(),
|
||||||
'owner' => $this->owner
|
'owner' => $this->getOwner()
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* FIXME: migrate other code to const PERMISSION_TYPE_ instead of strings
|
||||||
|
* iirc js uses those strings as well
|
||||||
|
*/
|
||||||
|
public function getType() {
|
||||||
|
if ($this->type === Acl::PERMISSION_TYPE_GROUP) {
|
||||||
|
return 'group';
|
||||||
|
}
|
||||||
|
return 'user';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setType($type) {
|
||||||
|
if ($type === 'group') {
|
||||||
|
$typeInt = Acl::PERMISSION_TYPE_GROUP;
|
||||||
|
} else {
|
||||||
|
$typeInt = Acl::PERMISSION_TYPE_USER;
|
||||||
|
}
|
||||||
|
$this->markFieldUpdated('type');
|
||||||
|
$this->type = $typeInt;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -30,9 +30,9 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
$acl->setParticipant("admin");
|
$acl->setParticipant("admin");
|
||||||
$acl->setType("user");
|
$acl->setType("user");
|
||||||
$acl->setBoardId(1);
|
$acl->setBoardId(1);
|
||||||
$acl->setPermissionEdit(1);
|
$acl->setPermissionEdit(true);
|
||||||
$acl->setPermissionShare(1);
|
$acl->setPermissionShare(true);
|
||||||
$acl->setPermissionManage(1);
|
$acl->setPermissionManage(true);
|
||||||
return $acl;
|
return $acl;
|
||||||
}
|
}
|
||||||
private function createAclGroup() {
|
private function createAclGroup() {
|
||||||
@@ -41,9 +41,9 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
$acl->setParticipant("administrators");
|
$acl->setParticipant("administrators");
|
||||||
$acl->setType("group");
|
$acl->setType("group");
|
||||||
$acl->setBoardId(1);
|
$acl->setBoardId(1);
|
||||||
$acl->setPermissionEdit(1);
|
$acl->setPermissionEdit(true);
|
||||||
$acl->setPermissionShare(1);
|
$acl->setPermissionShare(true);
|
||||||
$acl->setPermissionManage(1);
|
$acl->setPermissionManage(true);
|
||||||
return $acl;
|
return $acl;
|
||||||
}
|
}
|
||||||
public function testJsonSerialize() {
|
public function testJsonSerialize() {
|
||||||
@@ -53,10 +53,10 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
'participant' => 'admin',
|
'participant' => 'admin',
|
||||||
'type' => 'user',
|
'type' => 'user',
|
||||||
'boardId' => 1,
|
'boardId' => 1,
|
||||||
'permissionEdit' => 1,
|
'permissionEdit' => true,
|
||||||
'permissionShare' => 1,
|
'permissionShare' => true,
|
||||||
'permissionManage' => 1,
|
'permissionManage' => true,
|
||||||
'owner' => 0
|
'owner' => false
|
||||||
], $acl->jsonSerialize());
|
], $acl->jsonSerialize());
|
||||||
$acl = $this->createAclGroup();
|
$acl = $this->createAclGroup();
|
||||||
$this->assertEquals([
|
$this->assertEquals([
|
||||||
@@ -64,10 +64,10 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
'participant' => 'administrators',
|
'participant' => 'administrators',
|
||||||
'type' => 'group',
|
'type' => 'group',
|
||||||
'boardId' => 1,
|
'boardId' => 1,
|
||||||
'permissionEdit' => 1,
|
'permissionEdit' => true,
|
||||||
'permissionShare' => 1,
|
'permissionShare' => true,
|
||||||
'permissionManage' => 1,
|
'permissionManage' => true,
|
||||||
'owner' => 0
|
'owner' => false
|
||||||
], $acl->jsonSerialize());
|
], $acl->jsonSerialize());
|
||||||
}
|
}
|
||||||
public function testSetOwner() {
|
public function testSetOwner() {
|
||||||
@@ -78,10 +78,10 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
'participant' => 'admin',
|
'participant' => 'admin',
|
||||||
'type' => 'user',
|
'type' => 'user',
|
||||||
'boardId' => 1,
|
'boardId' => 1,
|
||||||
'permissionEdit' => 1,
|
'permissionEdit' => true,
|
||||||
'permissionShare' => 1,
|
'permissionShare' => true,
|
||||||
'permissionManage' => 1,
|
'permissionManage' => true,
|
||||||
'owner' => 1
|
'owner' => true
|
||||||
], $acl->jsonSerialize());
|
], $acl->jsonSerialize());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -92,9 +92,9 @@ class AclTest extends \PHPUnit_Framework_TestCase {
|
|||||||
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_EDIT));
|
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_EDIT));
|
||||||
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_MANAGE));
|
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_MANAGE));
|
||||||
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_SHARE));
|
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_SHARE));
|
||||||
$acl->setPermissionEdit(0);
|
$acl->setPermissionEdit(false);
|
||||||
$acl->setPermissionShare(0);
|
$acl->setPermissionShare(false);
|
||||||
$acl->setPermissionManage(0);
|
$acl->setPermissionManage(false);
|
||||||
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_READ));
|
$this->assertEquals(true, $acl->getPermission(Acl::PERMISSION_READ));
|
||||||
$this->assertEquals(false, $acl->getPermission(Acl::PERMISSION_EDIT));
|
$this->assertEquals(false, $acl->getPermission(Acl::PERMISSION_EDIT));
|
||||||
$this->assertEquals(false, $acl->getPermission(Acl::PERMISSION_MANAGE));
|
$this->assertEquals(false, $acl->getPermission(Acl::PERMISSION_MANAGE));
|
||||||
|
|||||||
Reference in New Issue
Block a user