This commit is contained in:
Julius Haertl
2017-01-19 13:09:16 +01:00
parent 40f179fe48
commit 581ca05554
2 changed files with 92 additions and 67 deletions

View File

@@ -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;
}
} }

View File

@@ -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));