mirror of
https://github.com/kevinveenbirkenbach/infinito.git
synced 2025-01-09 14:07:25 +01:00
Refactored reciever
This commit is contained in:
parent
33b1151a00
commit
0aac336609
@ -26,9 +26,9 @@ final class RightChecker implements RightCheckerInterface
|
||||
*/
|
||||
private function getAllSourcesToWhichRightApplies(): Collection
|
||||
{
|
||||
$rightSourceMemberInformation = new SourceMemberInformation($this->right->getSource());
|
||||
$rightSourceMemberInformation = new SourceMemberInformation($this->right->getReciever());
|
||||
$allSourcesToWhichRightApplies = clone $rightSourceMemberInformation->getAllMembers();
|
||||
$allSourcesToWhichRightApplies->add($this->right->getSource());
|
||||
$allSourcesToWhichRightApplies->add($this->right->getReciever());
|
||||
|
||||
return $allSourcesToWhichRightApplies;
|
||||
}
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
namespace App\Entity\Attribut;
|
||||
|
||||
use App\Entity\Meta\RecieverInterface;
|
||||
use App\Entity\Source\SourceInterface;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
@ -10,16 +10,16 @@ use App\Entity\Meta\RecieverInterface;
|
||||
trait RecieverAttribut
|
||||
{
|
||||
/**
|
||||
* @var RecieverInterface
|
||||
* @var SourceInterface
|
||||
*/
|
||||
protected $reciever;
|
||||
|
||||
public function setReciever(RecieverInterface $reciever): void
|
||||
public function setReciever(SourceInterface $reciever): void
|
||||
{
|
||||
$this->reciever = $reciever;
|
||||
}
|
||||
|
||||
public function getReciever(): RecieverInterface
|
||||
public function getReciever(): SourceInterface
|
||||
{
|
||||
return $this->reciever;
|
||||
}
|
||||
|
@ -2,14 +2,14 @@
|
||||
|
||||
namespace App\Entity\Attribut;
|
||||
|
||||
use App\Entity\Meta\RecieverInterface;
|
||||
use App\Entity\Source\SourceInterface;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
*/
|
||||
interface RecieverAttributInterface
|
||||
{
|
||||
public function setReciever(RecieverInterface $reciever): void;
|
||||
public function setReciever(SourceInterface $reciever): void;
|
||||
|
||||
public function getReciever(): RecieverInterface;
|
||||
public function getReciever(): SourceInterface;
|
||||
}
|
||||
|
@ -1,46 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Entity\Meta;
|
||||
|
||||
use Doctrine\Common\Collections\ArrayCollection;
|
||||
use Doctrine\ORM\Mapping as ORM;
|
||||
use App\Entity\Source\SourceInterface;
|
||||
use App\Entity\Attribut\RightAttribut;
|
||||
use App\Entity\Attribut\CollectionAttribut;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
* @ORM\Table(name="meta_reciever")
|
||||
* @ORM\Entity()
|
||||
*/
|
||||
class Reciever extends AbstractMeta implements RecieverInterface
|
||||
{
|
||||
use RightAttribut, CollectionAttribut;
|
||||
|
||||
/**
|
||||
* The right which the reciever group belongs to.
|
||||
*
|
||||
* @ORM\OneToOne(targetEntity="Right",cascade={"persist", "remove"})
|
||||
* @ORM\JoinColumn(name="right_id", referencedColumnName="id",onDelete="CASCADE")
|
||||
*
|
||||
* @var RightInterface
|
||||
*/
|
||||
protected $right;
|
||||
|
||||
/**
|
||||
* @ORM\ManyToMany(targetEntity="App\Entity\Source\AbstractSource")
|
||||
* @ORM\JoinTable(name="meta_reciever_members",
|
||||
* joinColumns={@ORM\JoinColumn(name="reciever_id", referencedColumnName="id")},
|
||||
* inverseJoinColumns={@ORM\JoinColumn(name="source_id", referencedColumnName="id")}
|
||||
* )
|
||||
*
|
||||
* @var ArrayCollection | SourceInterface[]
|
||||
*/
|
||||
protected $collection;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
parent::__construct();
|
||||
$this->collection = new ArrayCollection();
|
||||
}
|
||||
}
|
@ -1,15 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Entity\Meta;
|
||||
|
||||
use App\Entity\Attribut\RightAttributInterface;
|
||||
use App\Entity\Attribut\CollectionAttributInterface;
|
||||
|
||||
/**
|
||||
* It's neccessary to have an own reciever class, because if you would use a GroupSource it would lead to an infinite loop.
|
||||
*
|
||||
* @author kevinfrantz
|
||||
*/
|
||||
interface RecieverInterface extends MetaInterface, RightAttributInterface, CollectionAttributInterface
|
||||
{
|
||||
}
|
@ -15,6 +15,7 @@ use App\Entity\Attribut\RecieverAttribut;
|
||||
use App\Entity\Attribut\LayerAttribut;
|
||||
use App\Entity\Attribut\RelationAttribut;
|
||||
use App\Entity\Attribut\PriorityAttribut;
|
||||
use App\Entity\Source\SourceInterface;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
@ -25,6 +26,14 @@ class Right extends AbstractMeta implements RightInterface
|
||||
{
|
||||
use TypeAttribut,LawAttribut, RelationAttribut, GrantAttribut,ConditionAttribut,RecieverAttribut,LayerAttribut,PriorityAttribut;
|
||||
|
||||
/**
|
||||
* @ORM\OneToOne(targetEntity="App\Entity\Source\AbstractSource",cascade={"persist", "remove"})
|
||||
* @ORM\JoinColumn(name="source_id", referencedColumnName="id",onDelete="CASCADE")
|
||||
*
|
||||
* @var SourceInterface The requested source to which the law applies
|
||||
*/
|
||||
protected $source;
|
||||
|
||||
/**
|
||||
* @ORM\Column(type="integer")
|
||||
*
|
||||
@ -49,10 +58,11 @@ class Right extends AbstractMeta implements RightInterface
|
||||
protected $layer;
|
||||
|
||||
/**
|
||||
* @ORM\OneToOne(targetEntity="Reciever",cascade={"persist", "remove"})
|
||||
* @todo Test and implement it on an correct way!
|
||||
* @ORM\OneToOne(targetEntity="App\Entity\Source\AbstractSource",cascade={"persist"})
|
||||
* @ORM\JoinColumn(name="reciever_id", referencedColumnName="id",onDelete="CASCADE")
|
||||
*
|
||||
* @var RecieverInterface
|
||||
* @var SourceInterface
|
||||
*/
|
||||
protected $reciever;
|
||||
|
||||
@ -84,7 +94,5 @@ class Right extends AbstractMeta implements RightInterface
|
||||
parent::__construct();
|
||||
$this->grant = true;
|
||||
$this->priority = 0;
|
||||
$this->reciever = new Reciever();
|
||||
$this->reciever->setRight($this);
|
||||
}
|
||||
}
|
||||
|
@ -15,6 +15,9 @@ use App\Entity\Meta\LawInterface;
|
||||
use App\Entity\Meta\RightInterface;
|
||||
use Doctrine\Common\Collections\ArrayCollection;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
*/
|
||||
class LawPermissionCheckerTest extends TestCase
|
||||
{
|
||||
/**
|
||||
@ -30,7 +33,12 @@ class LawPermissionCheckerTest extends TestCase
|
||||
/**
|
||||
* @var RightInterface
|
||||
*/
|
||||
protected $client;
|
||||
protected $clientRight;
|
||||
|
||||
/**
|
||||
* @var SourceInterface
|
||||
*/
|
||||
private $clientSource;
|
||||
|
||||
private function getSourceMock(): SourceInterface
|
||||
{
|
||||
@ -40,61 +48,60 @@ class LawPermissionCheckerTest extends TestCase
|
||||
|
||||
private function checkClientPermission(): bool
|
||||
{
|
||||
return $this->lawPermissionChecker->hasPermission($this->client);
|
||||
return $this->lawPermissionChecker->hasPermission($this->clientRight);
|
||||
}
|
||||
|
||||
public function setUp(): void
|
||||
{
|
||||
$this->client = new Right();
|
||||
$this->clientRight = new Right();
|
||||
$this->law = new Law();
|
||||
$this->lawPermissionChecker = new LawPermissionCheckerService($this->law);
|
||||
$source = $this->getSourceMock();
|
||||
$this->client->setSource($source);
|
||||
$this->client->setLayer(LayerType::SOURCE);
|
||||
$this->client->setType(RightType::READ);
|
||||
$this->clientSource = $this->getSourceMock();
|
||||
$this->clientRight->setSource($this->clientSource);
|
||||
$this->clientRight->setLayer(LayerType::SOURCE);
|
||||
$this->clientRight->setType(RightType::READ);
|
||||
}
|
||||
|
||||
public function testGeneralPermission(): void
|
||||
{
|
||||
$this->assertFalse($this->checkClientPermission());
|
||||
$lawRight = clone $this->client;
|
||||
$lawRight = clone $this->clientRight;
|
||||
$lawRight->setReciever($this->clientSource);
|
||||
$this->law->getRights()->add($lawRight);
|
||||
$this->assertTrue($this->checkClientPermission());
|
||||
$this->client->setType(RightType::WRITE);
|
||||
$this->clientRight->setType(RightType::WRITE);
|
||||
$this->assertFalse($this->checkClientPermission());
|
||||
}
|
||||
|
||||
public function testMemberPermission(): void
|
||||
{
|
||||
$parentSource = $this->getSourceMock();
|
||||
$this->client->getSource()->getMemberRelation()->getMemberships()->add($parentSource);
|
||||
$parentSource->getMemberRelation()->getMembers()->add($this->client->getSource());
|
||||
$lawRight = clone $this->client;
|
||||
$lawRight->setSource($parentSource);
|
||||
$this->clientRight->getSource()->getMemberRelation()->getMemberships()->add($parentSource);
|
||||
$parentSource->getMemberRelation()->getMembers()->add($this->clientRight->getSource());
|
||||
$lawRight = clone $this->clientRight;
|
||||
$lawRight->setReciever($parentSource);
|
||||
$this->law->getRights()->add($lawRight);
|
||||
$permission = $this->lawPermissionChecker->hasPermission($this->client);
|
||||
$permission = $this->lawPermissionChecker->hasPermission($this->clientRight);
|
||||
$this->assertTrue($permission);
|
||||
$this->law->setRights(new ArrayCollection());
|
||||
$permission = $this->lawPermissionChecker->hasPermission($this->client);
|
||||
$permission = $this->lawPermissionChecker->hasPermission($this->clientRight);
|
||||
$this->assertFalse($permission);
|
||||
}
|
||||
|
||||
public function testSort(): void
|
||||
{
|
||||
$right1 = clone $this->client;
|
||||
$right1 = clone $this->clientRight;
|
||||
$right1->setPriority(123);
|
||||
$right1->setGrant(false);
|
||||
$right2 = clone $this->client;
|
||||
$right1->setReciever($this->clientSource);
|
||||
$right2 = clone $this->clientRight;
|
||||
$right2->setPriority(456);
|
||||
$right2->setGrant(true);
|
||||
$right2->setReciever($this->clientSource);
|
||||
$this->law->setRights(new ArrayCollection([$right1, $right2]));
|
||||
$this->assertFalse($this->checkClientPermission());
|
||||
$right2->setPriority(789);
|
||||
$right1->setPriority(101112);
|
||||
$this->assertTrue($this->checkClientPermission());
|
||||
}
|
||||
|
||||
// public function test2Rights():void{
|
||||
|
||||
// }
|
||||
}
|
||||
|
@ -51,7 +51,7 @@ class RightCheckerTest extends TestCase
|
||||
$this->type = RightType::READ;
|
||||
$this->source = $this->getSourceMock();
|
||||
$this->right = new Right();
|
||||
$this->right->setSource($this->source);
|
||||
$this->right->setReciever($this->source);
|
||||
$this->right->setType($this->type);
|
||||
$this->right->setLayer($this->layer);
|
||||
$this->rightManager = new RightChecker($this->right);
|
||||
@ -68,6 +68,8 @@ class RightCheckerTest extends TestCase
|
||||
$this->right->setGrant(false);
|
||||
$notGranted3 = $this->rightManager->isGranted($this->layer, $this->type, $this->source);
|
||||
$this->assertFalse($notGranted3);
|
||||
$notGranted4 = $this->rightManager->isGranted($this->layer, $this->type, $this->getSourceMock());
|
||||
$this->assertFalse($notGranted4);
|
||||
}
|
||||
|
||||
public function testSecondDimension(): void
|
||||
|
@ -5,7 +5,7 @@ namespace Tests\Unit\Entity\Attribut;
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use App\Entity\Attribut\RecieverAttributInterface;
|
||||
use App\Entity\Attribut\RecieverAttribut;
|
||||
use App\Entity\Meta\RecieverInterface;
|
||||
use App\Entity\Source\AbstractSource;
|
||||
|
||||
class RecieverAttributTest extends TestCase
|
||||
{
|
||||
@ -29,7 +29,7 @@ class RecieverAttributTest extends TestCase
|
||||
|
||||
public function testAccessors(): void
|
||||
{
|
||||
$reciever = $this->createMock(RecieverInterface::class);
|
||||
$reciever = $this->createMock(AbstractSource::class);
|
||||
$this->assertNull($this->reciever->setReciever($reciever));
|
||||
$this->assertEquals($reciever, $this->reciever->getReciever());
|
||||
}
|
||||
|
@ -1,28 +0,0 @@
|
||||
<?php
|
||||
|
||||
namespace App\Tests\Unit\Entity\Meta;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use App\Entity\Meta\Reciever;
|
||||
use App\Entity\Meta\RecieverInterface;
|
||||
use Doctrine\Common\Collections\Collection;
|
||||
|
||||
class RecieverTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var RecieverInterface
|
||||
*/
|
||||
public $reciever;
|
||||
|
||||
public function setUp(): void
|
||||
{
|
||||
$this->reciever = new Reciever();
|
||||
}
|
||||
|
||||
public function testConstructor(): void
|
||||
{
|
||||
$this->assertInstanceOf(Collection::class, $this->reciever->getCollection());
|
||||
$this->expectException(\TypeError::class);
|
||||
$this->reciever->getRight();
|
||||
}
|
||||
}
|
@ -27,11 +27,16 @@ class RightTest extends TestCase
|
||||
|
||||
public function testConstructorGeneral(): void
|
||||
{
|
||||
$this->assertEquals($this->right, $this->right->getReciever()->getRight());
|
||||
$this->assertTrue($this->right->getGrant());
|
||||
$this->assertEquals(0, $this->right->getPriority());
|
||||
}
|
||||
|
||||
public function testConstructorReciever(): void
|
||||
{
|
||||
$this->expectException(\TypeError::class);
|
||||
$this->right->getReciever();
|
||||
}
|
||||
|
||||
public function testConstructorLayer(): void
|
||||
{
|
||||
$this->expectException(\TypeError::class);
|
||||
|
Loading…
Reference in New Issue
Block a user