mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-13 13:54:23 +00:00
person: add validation to relationship to avoid duplicate
This commit is contained in:
parent
83dd8f810c
commit
07ea2b771c
@ -15,6 +15,7 @@ use Chill\MainBundle\Doctrine\Model\TrackCreationInterface;
|
|||||||
use Chill\MainBundle\Doctrine\Model\TrackUpdateInterface;
|
use Chill\MainBundle\Doctrine\Model\TrackUpdateInterface;
|
||||||
use Chill\MainBundle\Entity\User;
|
use Chill\MainBundle\Entity\User;
|
||||||
use Chill\PersonBundle\Entity\Person;
|
use Chill\PersonBundle\Entity\Person;
|
||||||
|
use Chill\PersonBundle\Validator\Constraints\Relationship\RelationshipNoDuplicate;
|
||||||
use DateTimeImmutable;
|
use DateTimeImmutable;
|
||||||
use DateTimeInterface;
|
use DateTimeInterface;
|
||||||
use Doctrine\ORM\Mapping as ORM;
|
use Doctrine\ORM\Mapping as ORM;
|
||||||
@ -31,6 +32,7 @@ use Symfony\Component\Validator\Constraints as Assert;
|
|||||||
* @DiscriminatorMap(typeProperty="type", mapping={
|
* @DiscriminatorMap(typeProperty="type", mapping={
|
||||||
* "relationship": Relationship::class
|
* "relationship": Relationship::class
|
||||||
* })
|
* })
|
||||||
|
* @RelationshipNoDuplicate
|
||||||
*/
|
*/
|
||||||
class Relationship implements TrackCreationInterface, TrackUpdateInterface
|
class Relationship implements TrackCreationInterface, TrackUpdateInterface
|
||||||
{
|
{
|
||||||
|
@ -0,0 +1,27 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Chill is a software for social workers
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view
|
||||||
|
* the LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Chill\PersonBundle\Validator\Constraints\Relationship;
|
||||||
|
|
||||||
|
use Symfony\Component\Validator\Constraint;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Annotation
|
||||||
|
*/
|
||||||
|
class RelationshipNoDuplicate extends Constraint
|
||||||
|
{
|
||||||
|
public $message = 'relationship.duplicate';
|
||||||
|
|
||||||
|
public function getTargets()
|
||||||
|
{
|
||||||
|
return self::CLASS_CONSTRAINT;
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,56 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Chill is a software for social workers
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view
|
||||||
|
* the LICENSE file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Chill\PersonBundle\Validator\Constraints\Relationship;
|
||||||
|
|
||||||
|
use Chill\PersonBundle\Repository\Relationships\RelationshipRepository;
|
||||||
|
use Symfony\Component\Form\Exception\UnexpectedTypeException;
|
||||||
|
use Symfony\Component\Validator\Constraint;
|
||||||
|
use Symfony\Component\Validator\ConstraintValidator;
|
||||||
|
|
||||||
|
class RelationshipNoDuplicateValidator extends ConstraintValidator
|
||||||
|
{
|
||||||
|
private RelationshipRepository $relationshipRepository;
|
||||||
|
|
||||||
|
public function __construct(RelationshipRepository $relationshipRepository)
|
||||||
|
{
|
||||||
|
$this->relationshipRepository = $relationshipRepository;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validate($relationship, Constraint $constraint)
|
||||||
|
{
|
||||||
|
if (!$constraint instanceof RelationshipNoDuplicate) {
|
||||||
|
throw new UnexpectedTypeException($constraint, RelationshipNoDuplicate::class);
|
||||||
|
}
|
||||||
|
|
||||||
|
$fromPerson = $relationship->getFromPerson();
|
||||||
|
$toPerson = $relationship->getToPerson();
|
||||||
|
|
||||||
|
$relationships = $this->relationshipRepository->findBy([
|
||||||
|
'fromPerson' => $fromPerson,
|
||||||
|
'fromPerson' => $toPerson,
|
||||||
|
'toPerson' => $fromPerson,
|
||||||
|
'toPerson' => $fromPerson,
|
||||||
|
]);
|
||||||
|
|
||||||
|
foreach ($relationships as $r) {
|
||||||
|
if (
|
||||||
|
$r->getFromPerson() === $fromPerson
|
||||||
|
|| $r->getFromPerson() === $toPerson
|
||||||
|
|| $r->getToPerson() === $fromPerson
|
||||||
|
|| $r->getToPerson() === $toPerson
|
||||||
|
) {
|
||||||
|
$this->context->buildViolation($constraint->message)
|
||||||
|
->addViolation();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -62,3 +62,7 @@ You cannot associate a resource with the same person: Vous ne pouvez pas ajouter
|
|||||||
#location
|
#location
|
||||||
The period must remain located: 'Un parcours doit être localisé'
|
The period must remain located: 'Un parcours doit être localisé'
|
||||||
The person where the course is located must be associated to the course. Change course's location before removing the person.: "Le parcours est localisé auprès cet usager. Veuillez changer la localisation du parcours avant de suprimer l'usager"
|
The person where the course is located must be associated to the course. Change course's location before removing the person.: "Le parcours est localisé auprès cet usager. Veuillez changer la localisation du parcours avant de suprimer l'usager"
|
||||||
|
|
||||||
|
#relationship
|
||||||
|
relationship:
|
||||||
|
duplicate: Une relation de filiation existe déjà entre ces 2 personnes
|
Loading…
x
Reference in New Issue
Block a user