mirror of
https://github.com/kevinveenbirkenbach/infinito.git
synced 2025-09-13 13:57:10 +02:00
Renamed domain SecureManagement to Secure
This commit is contained in:
@@ -0,0 +1,105 @@
|
||||
<?php
|
||||
|
||||
namespace tests\Unit\Domain\Secure;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Infinito\Entity\Source\AbstractSource;
|
||||
use Infinito\DBAL\Types\Meta\Right\LayerType;
|
||||
use Infinito\DBAL\Types\Meta\Right\CRUDType;
|
||||
use Infinito\Entity\Meta\Right;
|
||||
use Infinito\Domain\Request\Right\RequestedRight;
|
||||
use Infinito\Domain\Request\Entity\RequestedEntityInterface;
|
||||
use Infinito\Domain\Secure\SecureRequestedRightCheckerService;
|
||||
use Infinito\Domain\Right\RightTransformerService;
|
||||
use Infinito\Domain\Request\Right\RequestedRightInterface;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
*/
|
||||
class SecureRequestedRightCheckerServiceTest extends TestCase
|
||||
{
|
||||
public function testGranted(): void
|
||||
{
|
||||
$reciever = new class() extends AbstractSource {
|
||||
};
|
||||
$layer = LayerType::SOURCE;
|
||||
$crud = CRUDType::READ;
|
||||
$source = new class() extends AbstractSource {
|
||||
};
|
||||
$right = new Right();
|
||||
$right->setSource($source);
|
||||
$right->setLayer($layer);
|
||||
$right->setActionType($crud);
|
||||
$right->setReciever($reciever);
|
||||
$source->getLaw()->getRights()->add($right);
|
||||
$requestedRight = new RequestedRight();
|
||||
$requestedRight->setActionType($crud);
|
||||
$requestedRight->setLayer($layer);
|
||||
$requestedRight->setReciever($reciever);
|
||||
$requestedEntity = $this->createMock(RequestedEntityInterface::class);
|
||||
$requestedEntity->method('hasId')->willReturn(true);
|
||||
$requestedEntity->method('getEntity')->willReturn($source);
|
||||
$requestedEntity->method('hasIdentity')->willReturn(true);
|
||||
$requestedRight->setRequestedEntity($requestedEntity);
|
||||
$rightTransformerService = new RightTransformerService();
|
||||
$secureEntityChecker = new SecureRequestedRightCheckerService($rightTransformerService);
|
||||
$result = $secureEntityChecker->check($requestedRight);
|
||||
$this->assertTrue($result);
|
||||
}
|
||||
|
||||
public function testNotGranted(): void
|
||||
{
|
||||
$reciever = new class() extends AbstractSource {
|
||||
};
|
||||
$layer = LayerType::SOURCE;
|
||||
$crud = CRUDType::READ;
|
||||
$source = new class() extends AbstractSource {
|
||||
};
|
||||
$right = new Right();
|
||||
$right->setSource($source);
|
||||
$right->setLayer($layer);
|
||||
$right->setActionType(CRUDType::CREATE);
|
||||
$right->setReciever($reciever);
|
||||
$source->getLaw()->getRights()->add($right);
|
||||
$requestedRight = new RequestedRight();
|
||||
$requestedRight->setActionType($crud);
|
||||
$requestedRight->setLayer($layer);
|
||||
$requestedRight->setReciever($reciever);
|
||||
$requestedEntity = $this->createMock(RequestedEntityInterface::class);
|
||||
$requestedEntity->method('hasId')->willReturn(true);
|
||||
$requestedEntity->method('getEntity')->willReturn($source);
|
||||
$requestedEntity->method('hasIdentity')->willReturn(true);
|
||||
$requestedRight->setRequestedEntity($requestedEntity);
|
||||
$rightTransformerService = new RightTransformerService();
|
||||
$secureEntityChecker = new SecureRequestedRightCheckerService($rightTransformerService);
|
||||
$result = $secureEntityChecker->check($requestedRight);
|
||||
$this->assertFalse($result);
|
||||
}
|
||||
|
||||
public function testRightAppliesToAll(): void
|
||||
{
|
||||
$reciever = new class() extends AbstractSource {
|
||||
};
|
||||
$layer = LayerType::SOURCE;
|
||||
$crud = CRUDType::READ;
|
||||
$source = new class() extends AbstractSource {
|
||||
};
|
||||
$requestedRight = $this->createMock(RequestedRightInterface::class);
|
||||
$requestedRight->method('getActionType')->willReturn($crud);
|
||||
$requestedRight->method('getLayer')->willReturn($layer);
|
||||
$requestedRight->method('getReciever')->willReturn($reciever);
|
||||
$requestedRight->method('getSource')->willReturn($source);
|
||||
$rightTransformerService = new RightTransformerService();
|
||||
$secureEntityChecker = new SecureRequestedRightCheckerService($rightTransformerService);
|
||||
$this->assertFalse($secureEntityChecker->check($requestedRight));
|
||||
$right = new Right();
|
||||
$right->setActionType($crud);
|
||||
$right->setLayer($layer);
|
||||
$right->setSource($source);
|
||||
$source->getLaw()->getRights()->add($right);
|
||||
$this->assertTrue($secureEntityChecker->check($requestedRight));
|
||||
$right->setReciever(new class() extends AbstractSource {
|
||||
});
|
||||
$this->assertFalse($secureEntityChecker->check($requestedRight));
|
||||
}
|
||||
}
|
@@ -0,0 +1,126 @@
|
||||
<?php
|
||||
|
||||
namespace Tests\Unit\Domain\Secure;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Infinito\Entity\Source\SourceInterface;
|
||||
use Infinito\Domain\Secure\SecureSourceCheckerInterface;
|
||||
use Infinito\Entity\Source\AbstractSource;
|
||||
use Infinito\Domain\Secure\SecureSourceChecker;
|
||||
use Infinito\Entity\Meta\Right;
|
||||
use Infinito\DBAL\Types\Meta\Right\LayerType;
|
||||
use Infinito\DBAL\Types\Meta\Right\CRUDType;
|
||||
use Infinito\Attribut\SourceAttribut;
|
||||
use Infinito\Attribut\SourceAttributInterface;
|
||||
use Infinito\Exception\Permission\NoSourcePermissionException;
|
||||
|
||||
/**
|
||||
* @author kevinfrantz
|
||||
*/
|
||||
class SecureSourceCheckerTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var SourceInterface|SourceAttributInterface
|
||||
*/
|
||||
private $source;
|
||||
|
||||
/**
|
||||
* @var SourceInterface
|
||||
*/
|
||||
private $recieverSource;
|
||||
|
||||
/**
|
||||
* @var SecureSourceCheckerInterface
|
||||
*/
|
||||
private $securerSourceChecker;
|
||||
|
||||
/**
|
||||
* @return SourceInterface
|
||||
*/
|
||||
private function createSourceMock(): SourceInterface
|
||||
{
|
||||
return new class() extends AbstractSource implements SourceAttributInterface {
|
||||
use SourceAttribut;
|
||||
};
|
||||
}
|
||||
|
||||
public function setUp(): void
|
||||
{
|
||||
$this->source = $this->createSourceMock();
|
||||
$this->recieverSource = $this->createSourceMock();
|
||||
$this->securerSourceChecker = new SecureSourceChecker($this->source);
|
||||
}
|
||||
|
||||
public function testFirstLevel(): void
|
||||
{
|
||||
$right = new Right();
|
||||
$right->setLayer(LayerType::SOURCE);
|
||||
$right->setActionType(CRUDType::UPDATE);
|
||||
$right->setReciever($this->recieverSource);
|
||||
$right->setSource($this->source);
|
||||
$this->source->getLaw()->getRights()->add($right);
|
||||
$requestedRight = clone $right;
|
||||
$this->assertTrue($this->securerSourceChecker->hasPermission($requestedRight));
|
||||
$requestedRight->setActionType(CRUDType::READ);
|
||||
$this->assertFalse($this->securerSourceChecker->hasPermission($requestedRight));
|
||||
}
|
||||
|
||||
public function testSecondLevel(): void
|
||||
{
|
||||
$right = new Right();
|
||||
$right->setLayer(LayerType::SOURCE);
|
||||
$right->setActionType(CRUDType::UPDATE);
|
||||
$right->setReciever($this->recieverSource);
|
||||
$right->setSource($this->source);
|
||||
$this->source->getLaw()->getRights()->add($right);
|
||||
$attributSource = $this->createSourceMock();
|
||||
$childRight = clone $right;
|
||||
$attributSource->getLaw()->getRights()->add($childRight);
|
||||
$this->source->setSource($attributSource);
|
||||
$requestedRight = clone $right;
|
||||
$this->assertTrue($this->securerSourceChecker->hasPermission($requestedRight));
|
||||
$childRight->setActionType(CRUDType::READ);
|
||||
$this->expectException(NoSourcePermissionException::class);
|
||||
$this->securerSourceChecker->hasPermission($requestedRight);
|
||||
}
|
||||
|
||||
public function testThirdLevel(): void
|
||||
{
|
||||
$right = new Right();
|
||||
$right->setLayer(LayerType::SOURCE);
|
||||
$right->setActionType(CRUDType::UPDATE);
|
||||
$right->setReciever($this->recieverSource);
|
||||
$right->setSource($this->source);
|
||||
$this->source->getLaw()->getRights()->add($right);
|
||||
$attribut1Source = $this->createSourceMock();
|
||||
$attribut1Source->getLaw()->getRights()->add($right);
|
||||
$this->source->setSource($attribut1Source);
|
||||
$childRight = clone $right;
|
||||
$attribut2Source = $this->createSourceMock();
|
||||
$attribut2Source->getLaw()->getRights()->add($childRight);
|
||||
$attribut1Source->setSource($attribut2Source);
|
||||
$requestedRight = clone $right;
|
||||
$this->assertTrue($this->securerSourceChecker->hasPermission($requestedRight));
|
||||
$childRight->setActionType(CRUDType::READ);
|
||||
$this->expectException(NoSourcePermissionException::class);
|
||||
$this->securerSourceChecker->hasPermission($requestedRight);
|
||||
}
|
||||
|
||||
public function testRightAppliesToAll(): void
|
||||
{
|
||||
$right = new Right();
|
||||
$right->setLayer(LayerType::SOURCE);
|
||||
$right->setActionType(CRUDType::READ);
|
||||
$right->setReciever($this->recieverSource);
|
||||
$right->setSource($this->source);
|
||||
$this->assertFalse($this->securerSourceChecker->hasPermission($right));
|
||||
$requestedRight = new Right();
|
||||
$requestedRight->setLayer(LayerType::SOURCE);
|
||||
$requestedRight->setActionType(CRUDType::READ);
|
||||
$requestedRight->setSource($this->source);
|
||||
$this->source->getLaw()->getRights()->add($requestedRight);
|
||||
$this->assertTrue($this->securerSourceChecker->hasPermission($right));
|
||||
$requestedRight->setReciever($this->createSourceMock());
|
||||
$this->assertFalse($this->securerSourceChecker->hasPermission($right));
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user