mirror of
https://github.com/kevinveenbirkenbach/infinito.git
synced 2025-01-09 22:17:26 +01:00
Updated registration process
This commit is contained in:
parent
fcfe1ce9d7
commit
f919b0e02c
@ -7,6 +7,10 @@ use App\DBAL\Types\RightType;
|
|||||||
use App\Entity\NodeInterface;
|
use App\Entity\NodeInterface;
|
||||||
use App\Entity\Right;
|
use App\Entity\Right;
|
||||||
use App\Entity\LawInterface;
|
use App\Entity\LawInterface;
|
||||||
|
use App\DBAL\Types\RecieverType;
|
||||||
|
use App\Entity\RightInterface;
|
||||||
|
use App\Entity\RecieverGroupInterface;
|
||||||
|
use App\Entity\RecieverGroup;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author kevinfrantz
|
* @author kevinfrantz
|
||||||
@ -17,13 +21,30 @@ abstract class LawModificator
|
|||||||
{
|
{
|
||||||
foreach (LayerType::getChoices() as $layerKey => $layerValue) {
|
foreach (LayerType::getChoices() as $layerKey => $layerValue) {
|
||||||
foreach (RightType::getChoices() as $rightKey => $rightValue) {
|
foreach (RightType::getChoices() as $rightKey => $rightValue) {
|
||||||
$right = new Right();
|
$right = self::createRight($law, $node, $rightKey, $layerKey);
|
||||||
$right->setType($rightKey);
|
$right->setRecieverGroup(self::createRecieverGroup($node, RecieverType::NODE));
|
||||||
$right->setLaw($this);
|
|
||||||
$right->setLayer($layerKey);
|
|
||||||
$right->setNode($node);
|
|
||||||
$law->getRights()->add($right);
|
$law->getRights()->add($right);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function createRight(LawInterface $law, NodeInterface $node, string $type, string $layer): RightInterface
|
||||||
|
{
|
||||||
|
$right = new Right();
|
||||||
|
$right->setType($type);
|
||||||
|
$right->setLaw($law);
|
||||||
|
$right->setLayer($layer);
|
||||||
|
$right->setNode($node);
|
||||||
|
|
||||||
|
return $right;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function createRecieverGroup(NodeInterface $node, string $reciever): RecieverGroupInterface
|
||||||
|
{
|
||||||
|
$recieverGroup = new RecieverGroup();
|
||||||
|
$recieverGroup->setNode($node);
|
||||||
|
$recieverGroup->setReciever($reciever);
|
||||||
|
|
||||||
|
return $recieverGroup;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,8 +21,8 @@ class AbstractEntity
|
|||||||
*/
|
*/
|
||||||
protected $id;
|
protected $id;
|
||||||
|
|
||||||
protected function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
$this->id = 0;
|
//$this->id = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,10 +4,11 @@ namespace App\Entity;
|
|||||||
|
|
||||||
use App\Entity\Attribut\RightsAttributInterface;
|
use App\Entity\Attribut\RightsAttributInterface;
|
||||||
use App\Entity\Method\NodeGrantedInterface;
|
use App\Entity\Method\NodeGrantedInterface;
|
||||||
|
use App\Entity\Attribut\NodeAttributInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author kevinfrantz
|
* @author kevinfrantz
|
||||||
*/
|
*/
|
||||||
interface LawInterface extends RightsAttributInterface, NodeGrantedInterface
|
interface LawInterface extends RightsAttributInterface, NodeGrantedInterface, NodeAttributInterface
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@ use App\Entity\Attribut\SourceAttribut;
|
|||||||
use App\Entity\Attribut\ParentsAttribut;
|
use App\Entity\Attribut\ParentsAttribut;
|
||||||
use App\Entity\Attribut\ChildsAttribut;
|
use App\Entity\Attribut\ChildsAttribut;
|
||||||
use App\Entity\Attribut\LawAttribut;
|
use App\Entity\Attribut\LawAttribut;
|
||||||
|
use Doctrine\Common\Collections\ArrayCollection;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author kevinfrantz
|
* @author kevinfrantz
|
||||||
@ -41,20 +42,8 @@ class Node extends AbstractEntity implements NodeInterface
|
|||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
$this->law = new Law();
|
$this->law = new Law();
|
||||||
|
$this->parents = new ArrayCollection();
|
||||||
|
$this->childs = new ArrayCollection();
|
||||||
$this->law->setNode($this);
|
$this->law->setNode($this);
|
||||||
$this->initPermissions();
|
|
||||||
}
|
|
||||||
|
|
||||||
private function initPermissions(): void
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* @var RightInterface
|
|
||||||
*/
|
|
||||||
foreach ($this->law->getRights()->toArray() as $right) {
|
|
||||||
$permission = new Permission();
|
|
||||||
$permission->setNode($this);
|
|
||||||
$permission->setRight($right);
|
|
||||||
$right->addPermission($permission);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,9 +8,7 @@ use Fresh\DoctrineEnumBundle\Validator\Constraints as DoctrineAssert;
|
|||||||
use App\Entity\Attribut\LawAttribut;
|
use App\Entity\Attribut\LawAttribut;
|
||||||
use App\DBAL\Types\LayerType;
|
use App\DBAL\Types\LayerType;
|
||||||
use App\DBAL\Types\RightType;
|
use App\DBAL\Types\RightType;
|
||||||
use App\Entity\Attribut\PermissionsAttribut;
|
|
||||||
use App\Entity\Attribut\NodeAttribut;
|
use App\Entity\Attribut\NodeAttribut;
|
||||||
use App\Entity\Attribut\RecieverAttribut;
|
|
||||||
use App\Entity\Attribut\GrantAttribut;
|
use App\Entity\Attribut\GrantAttribut;
|
||||||
use App\Logic\Operation\OperationInterface;
|
use App\Logic\Operation\OperationInterface;
|
||||||
use App\Entity\Attribut\ConditionAttribut;
|
use App\Entity\Attribut\ConditionAttribut;
|
||||||
@ -24,7 +22,7 @@ use App\Entity\Attribut\LayerAttribut;
|
|||||||
*/
|
*/
|
||||||
class Right extends AbstractEntity implements RightInterface
|
class Right extends AbstractEntity implements RightInterface
|
||||||
{
|
{
|
||||||
use TypeAttribut,LawAttribut,PermissionsAttribut, NodeAttribut, RecieverAttribut,GrantAttribut,ConditionAttribut,RecieverGroupAttribut,LayerAttribut;
|
use TypeAttribut,LawAttribut, NodeAttribut, GrantAttribut,ConditionAttribut,RecieverGroupAttribut,LayerAttribut;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ORM\ManyToOne(targetEntity="Law", inversedBy="rights")
|
* @ORM\ManyToOne(targetEntity="Law", inversedBy="rights")
|
||||||
@ -75,7 +73,8 @@ class Right extends AbstractEntity implements RightInterface
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @ORM\OneToOne(targetEntity="AbstractOperation",cascade={"persist"})
|
* @ORM\OneToOne(targetEntity="AbstractOperation",cascade={"persist"})
|
||||||
* @ORM\Column(nullable=true)
|
* @ORM\JoinColumn(name="operation_id", referencedColumnName="id",nullable=true)
|
||||||
|
*
|
||||||
* @var OperationInterface
|
* @var OperationInterface
|
||||||
*/
|
*/
|
||||||
protected $condition;
|
protected $condition;
|
||||||
@ -84,7 +83,8 @@ class Right extends AbstractEntity implements RightInterface
|
|||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
$this->grant = true;
|
$this->grant = true;
|
||||||
$this->recieverGroup = new RecieverGroup();
|
//$this->node = new Node();
|
||||||
|
//$this->recieverGroup = new RecieverGroup();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function isGranted(NodeInterface $node, string $layer, string $right): bool
|
public function isGranted(NodeInterface $node, string $layer, string $right): bool
|
||||||
|
@ -43,5 +43,6 @@ class User extends BaseUser implements SourceAttributInterface
|
|||||||
$this->isActive = true;
|
$this->isActive = true;
|
||||||
$this->source = new UserSource();
|
$this->source = new UserSource();
|
||||||
LawModificator::grantAllRights($this->source->getNode()->getLaw(), $this->source->getNode());
|
LawModificator::grantAllRights($this->source->getNode()->getLaw(), $this->source->getNode());
|
||||||
|
//var_dump($this->source->getNode()->getLaw()->getRights()->get(0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
namespace App\Tests\Unit\Controller;
|
namespace App\Tests\Unit\Controller;
|
||||||
|
|
||||||
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;
|
||||||
use App\Controller\DefaultControllerInterface;
|
|
||||||
use App\Controller\DefaultController;
|
use App\Controller\DefaultController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
namespace tests\unit\Entity;
|
namespace tests\unit\Entity;
|
||||||
|
|
||||||
use PHPUnit\Framework\TestCase;
|
use PHPUnit\Framework\TestCase;
|
||||||
@ -8,18 +9,15 @@ use App\Entity\UserSource;
|
|||||||
use App\Entity\Node;
|
use App\Entity\Node;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @author kevinfrantz
|
* @author kevinfrantz
|
||||||
*/
|
*/
|
||||||
class UserTest extends TestCase
|
class UserTest extends TestCase
|
||||||
{
|
{
|
||||||
|
|
||||||
const PASSWORD = '12345678';
|
const PASSWORD = '12345678';
|
||||||
|
|
||||||
const USERNAME = 'tester';
|
const USERNAME = 'tester';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
|
||||||
* @var User
|
* @var User
|
||||||
*/
|
*/
|
||||||
protected $user;
|
protected $user;
|
||||||
|
Loading…
Reference in New Issue
Block a user