1
0
mirror of https://framagit.org/tykayn/date-poll-api synced 2023-08-25 08:23:11 +02:00

valid schema

This commit is contained in:
Baptiste Lemoine 2019-11-28 11:51:25 +01:00
parent a0842f3b7c
commit 010f07230d
6 changed files with 345 additions and 345 deletions

View File

@ -265,6 +265,8 @@ class DefaultController extends AbstractController {
if ( ! $poll ) { if ( ! $poll ) {
return $this->json( [ 'message' => 'poll not found' ], 404 ); return $this->json( [ 'message' => 'poll not found' ], 404 );
} }
$em = $this->getDoctrine()->getManager();
$data = $request->getContent(); $data = $request->getContent();
$data = json_decode( $data, true ); $data = json_decode( $data, true );
@ -273,13 +275,21 @@ class DefaultController extends AbstractController {
->setEmail( $data[ 'email' ] ) ->setEmail( $data[ 'email' ] )
->setPseudo( $data[ 'pseudo' ] ); ->setPseudo( $data[ 'pseudo' ] );
$stack = new StackOfVotes(); $stack = new StackOfVotes();
$stack
->setPseudo( $data[ 'pseudo' ] )
->setPoll( $poll );
foreach ( $data[ 'votes' ] as $voteInfo ) { foreach ( $data[ 'votes' ] as $voteInfo ) {
$vote = new Vote(); $vote = new Vote();
$foundChoice = $poll->findChoiceById( $voteInfo[ 'choice_id' ] ); $foundChoice = $poll->findChoiceById( $voteInfo[ 'choice_id' ] );
$vote->setPoll( $poll ) $vote->setPoll( $poll )
->setChoice( $foundChoice ) ->setChoice( $foundChoice )
->setValue( $voteInfo[ 'value' ] ); ->setValue( $voteInfo[ 'value' ] );
$vote->setPoll( $poll );
$stack->addVote( $vote ); $stack->addVote( $vote );
$poll->addVote( $vote );
$em->persist( $vote );
$em->persist( $foundChoice );
} }
// find poll from choices // find poll from choices
@ -299,13 +309,14 @@ class DefaultController extends AbstractController {
// ->setPoll( $poll ); // ->setPoll( $poll );
// $foundOwner->addComment( $comment ); // $foundOwner->addComment( $comment );
// //
$em = $this->getDoctrine()->getManager();
$em->persist( $stack ); $em->persist( $stack );
$em->persist( $poll );
// $em->persist( $comment ); // $em->persist( $comment );
$em->flush(); $em->flush();
return $this->json( [ return $this->json( [
'message' => 'you created a comment', 'message' => 'you created a vote',
'vote_stack' => $stack,
'json_you_sent' => $data, 'json_you_sent' => $data,
], ],
201 ); 201 );

View File

@ -15,7 +15,10 @@ use Doctrine\Common\Persistence\ObjectManager;
class AppPollFixtures extends Fixture { class AppPollFixtures extends Fixture {
public function load( ObjectManager $manager ) { public function load( ObjectManager $manager ) {
$owner = new Owner(); /**
* create a few demo people
*/
$owner = new Owner(); // someone who creates the polls
$owner->setEmail( 'tktest@tktest.com' ) $owner->setEmail( 'tktest@tktest.com' )
->setPseudo( 'tk_TEST' ); ->setPseudo( 'tk_TEST' );
$commenterMan = new Owner(); $commenterMan = new Owner();
@ -26,6 +29,11 @@ class AppPollFixtures extends Fixture {
$voter->setEmail( 'testing_vote_people@tktest.com' ) $voter->setEmail( 'testing_vote_people@tktest.com' )
->setPseudo( 'voting_people_TEST' ) ->setPseudo( 'voting_people_TEST' )
->setModifierToken( uniqid() ); ->setModifierToken( uniqid() );
$manager->persist( $owner );
$manager->persist( $commenterMan );
$manager->persist( $voter );
$manager->flush();
$poll = new Poll(); $poll = new Poll();
$poll->setTitle( 'citron ou orange' ) $poll->setTitle( 'citron ou orange' )
@ -45,9 +53,7 @@ class AppPollFixtures extends Fixture {
->addChoice( $choiceA ) ->addChoice( $choiceA )
->addChoice( $choiceB ); ->addChoice( $choiceB );
$manager->persist( $poll ); $manager->persist( $poll );
$manager->persist( $owner );
$manager->persist( $voter );
$manager->flush();
$stack1 = new StackOfVotes(); $stack1 = new StackOfVotes();
$stack1 $stack1
@ -57,13 +63,13 @@ class AppPollFixtures extends Fixture {
$voteA = new Vote(); $voteA = new Vote();
$voteA $voteA
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack1 ) ->setStacksOfVotes( $stack1 )
->setValue( "yes" ) ->setValue( "yes" )
->setChoice( $choiceA ); ->setChoice( $choiceA );
$voteB = new Vote(); $voteB = new Vote();
$voteB $voteB
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack1 ) ->setStacksOfVotes( $stack1 )
->setValue( "yes" ) ->setValue( "yes" )
->setChoice( $choiceB ); ->setChoice( $choiceB );
@ -83,7 +89,7 @@ class AppPollFixtures extends Fixture {
$voteA = new Vote(); $voteA = new Vote();
$voteA $voteA
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack2 ) ->setStacksOfVotes( $stack2 )
->setValue( "maybe" ) ->setValue( "maybe" )
->setChoice( $choiceA ); ->setChoice( $choiceA );
@ -210,13 +216,13 @@ class AppPollFixtures extends Fixture {
$vote = new Vote(); $vote = new Vote();
$vote $vote
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack ) ->setStacksOfVotes( $stack )
->setValue( "yes" ) ->setValue( "yes" )
->setChoice( $poll->getChoices()[ 2 ] ); ->setChoice( $poll->getChoices()[ 2 ] );
$vote = new Vote(); $vote = new Vote();
$vote $vote
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack ) ->setStacksOfVotes( $stack )
->setValue( "maybe" ) ->setValue( "maybe" )
->setChoice( $poll->getChoices()[ 1 ] ); ->setChoice( $poll->getChoices()[ 1 ] );
@ -230,19 +236,19 @@ class AppPollFixtures extends Fixture {
$vote = new Vote(); $vote = new Vote();
$vote $vote
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack ) ->setStacksOfVotes( $stack )
->setValue( "yes" ) ->setValue( "yes" )
->setChoice( $poll->getChoices()[ 1 ] ); ->setChoice( $poll->getChoices()[ 1 ] );
$vote = new Vote(); $vote = new Vote();
$vote $vote
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack ) ->setStacksOfVotes( $stack )
->setValue( "yes" ) ->setValue( "yes" )
->setChoice( $poll->getChoices()[ 2 ] ); ->setChoice( $poll->getChoices()[ 2 ] );
$vote = new Vote(); $vote = new Vote();
$vote $vote
->setPoll( $poll ) ->setPoll( $poll )
->setStackOfVotes( $stack ) ->setStacksOfVotes( $stack )
->setValue( "no" ) ->setValue( "no" )
->setChoice( $poll->getChoices()[ 2 ] ); ->setChoice( $poll->getChoices()[ 2 ] );

View File

@ -33,25 +33,19 @@ class Choice {
public $dateTime; public $dateTime;
/** /**
* @ORM\OneToMany(targetEntity="App\Entity\Poll", mappedBy="choices") * @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="choices", cascade={"persist"})
* @Serializer\Type("App\Entity\Poll") * @Serializer\Type("App\Entity\Poll")
*/ */
private $poll; private $poll;
/**
* @ORM\OneToMany(targetEntity="App\Entity\StackOfVotes", mappedBy="choice")
* @Serializer\Type("App\Entity\StackOfVotes")
*/
public $stackOfVotes;
/** /**
* @ORM\OneToMany(targetEntity="App\Entity\Vote", mappedBy="choice") * @ORM\OneToMany(targetEntity="App\Entity\Vote", mappedBy="choice", cascade={"persist"})
* @Serializer\Type("App\Entity\Vote") * @Serializer\Type("App\Entity\Vote")
*/ */
public $votes; public $votes;
public function __construct() { public function __construct() {
$this->poll = new ArrayCollection(); $this->poll = new ArrayCollection();
$this->stackOfVotes = new ArrayCollection();
$this->votes = new ArrayCollection(); $this->votes = new ArrayCollection();
$this->setDateTime( new \DateTime() ); $this->setDateTime( new \DateTime() );
} }
@ -85,59 +79,26 @@ class Choice {
return $this; return $this;
} }
/**
* @return Collection|Poll[]
*/
public function getPoll(): Collection {
return $this->poll;
}
public function setPoll( Poll $poll ): self {
$this->poll = [ $poll ];
return $this;
}
public function addPoll( Poll $poll ): self {
if ( ! $this->poll->contains( $poll ) ) {
$this->poll[] = $poll;
$poll->setChoices( $this );
}
return $this;
}
public function removePoll( Poll $poll ): self {
if ( $this->poll->contains( $poll ) ) {
$this->poll->removeElement( $poll );
// set the owning side to null (unless already changed)
if ( $poll->getChoices() === $this ) {
$poll->setChoices( null );
}
}
return $this;
}
/** /**
* @return Collection|Choice[] * @return Collection|Vote[]
*/ */
public function getStackOfVotes(): Collection { public function getVotes(): Collection {
return $this->stackOfVotes; return $this->votes;
} }
public function addVote( Choice $vote ): self { public function addVote( Vote $vote ): self {
if ( ! $this->stackOfVotes->contains( $vote ) ) { if ( ! $this->votes->contains( $vote ) ) {
$this->stackOfVotes[] = $vote; $this->votes[] = $vote;
$vote->setChoice( $this ); $vote->setChoice( $this );
} }
return $this; return $this;
} }
public function removeVote( Choice $vote ): self { public function removeVote( Vote $vote ): self {
if ( $this->stackOfVotes->contains( $vote ) ) { if ( $this->votes->contains( $vote ) ) {
$this->stackOfVotes->removeElement( $vote ); $this->votes->removeElement( $vote );
// set the owning side to null (unless already changed) // set the owning side to null (unless already changed)
if ( $vote->getChoice() === $this ) { if ( $vote->getChoice() === $this ) {
$vote->setChoice( null ); $vote->setChoice( null );
@ -147,31 +108,15 @@ class Choice {
return $this; return $this;
} }
public function addStackOfVote( StackOfVotes $stackOfVote ): self { public function getPoll(): ?Poll
if ( ! $this->stackOfVotes->contains( $stackOfVote ) ) { {
$this->stackOfVotes[] = $stackOfVote; return $this->poll;
$stackOfVote->setChoice( $this );
} }
public function setPoll(?Poll $poll): self
{
$this->poll = $poll;
return $this; return $this;
} }
public function removeStackOfVote( StackOfVotes $stackOfVote ): self {
if ( $this->stackOfVotes->contains( $stackOfVote ) ) {
$this->stackOfVotes->removeElement( $stackOfVote );
// set the owning side to null (unless already changed)
if ( $stackOfVote->getChoice() === $this ) {
$stackOfVote->setChoice( null );
}
}
return $this;
}
/**
* @return Collection|Vote[]
*/
public function getVotes(): Collection {
return $this->votes;
}
} }

View File

@ -111,7 +111,7 @@ class Poll {
* @ORM\OneToMany(targetEntity="App\Entity\StackOfVotes", mappedBy="poll", orphanRemoval=true,cascade={"persist", "remove"}) * @ORM\OneToMany(targetEntity="App\Entity\StackOfVotes", mappedBy="poll", orphanRemoval=true,cascade={"persist", "remove"})
* @Serializer\Type("App\Entity\StackOfVotes") * @Serializer\Type("App\Entity\StackOfVotes")
*/ */
public $stackOfVotes; public $stacksOfVotes;
/** /**
* @ORM\OneToMany(targetEntity="App\Entity\Choice", mappedBy="poll", orphanRemoval=true,cascade={"persist", "remove"}) * @ORM\OneToMany(targetEntity="App\Entity\Choice", mappedBy="poll", orphanRemoval=true,cascade={"persist", "remove"})
* @Serializer\Type("App\Entity\Choice") * @Serializer\Type("App\Entity\Choice")
@ -146,7 +146,7 @@ class Poll {
$this->votes = new ArrayCollection(); $this->votes = new ArrayCollection();
$this->choices = new ArrayCollection(); $this->choices = new ArrayCollection();
$this->comments = new ArrayCollection(); $this->comments = new ArrayCollection();
$this->stackOfVotes = new ArrayCollection(); $this->stacksOfVotes = new ArrayCollection();
$this->setCreationDate( new \DateTime() ); $this->setCreationDate( new \DateTime() );
$this->setExpiracyDate( $this->addDaysToDate( $this->setExpiracyDate( $this->addDaysToDate(
new \DateTime(), new \DateTime(),
@ -155,8 +155,26 @@ class Poll {
$this->setAllowedAnswers( [ 'yes' ] ); $this->setAllowedAnswers( [ 'yes' ] );
} }
public function findChoiceById( $id ) { public function findChoiceById( int $id ) {
return new Choice(); // TODO
error_reporting( E_ALL ^ E_NOTICE );
$choices = $this->getChoices();
var_dump( count( $choices ) );
foreach ( $choices as $choice ) {
if ( $choice && $choice->getId() == $id ) {
return $choice;
}
return null;
}
// if ( $choices && $choices->containsKey( $id ) ) {
// $foundChoice = $choices->get( $id );
// } else {
// $foundChoice = new Choice();
// $foundChoice->setPoll( $this );
// }
//
// return $foundChoice;
} }
public function addDaysToDate( \DateTime $date, int $days ) { public function addDaysToDate( \DateTime $date, int $days ) {
@ -342,7 +360,7 @@ class Poll {
return $this; return $this;
} }
public function getStacksOfVotes(): ?StackOfVotes { public function getStacksOfVotes() {
return $this->stacksOfVotes; return $this->stacksOfVotes;
} }
@ -352,16 +370,10 @@ class Poll {
return $this; return $this;
} }
/**
* @return Collection|StackOfVotes[]
*/
public function getStackOfVotes(): Collection {
return $this->stackOfVotes;
}
public function addStackOfVote( StackOfVotes $stackOfVote ): self { public function addStackOfVote( StackOfVotes $stackOfVote ): self {
if ( ! $this->stackOfVotes->contains( $stackOfVote ) ) { if ( ! $this->stacksOfVotes->contains( $stackOfVote ) ) {
$this->stackOfVotes[] = $stackOfVote; $this->stacksOfVotes[] = $stackOfVote;
$stackOfVote->setPoll( $this ); $stackOfVote->setPoll( $this );
} }
@ -369,8 +381,8 @@ class Poll {
} }
public function removeStackOfVote( StackOfVotes $stackOfVote ): self { public function removeStackOfVote( StackOfVotes $stackOfVote ): self {
if ( $this->stackOfVotes->contains( $stackOfVote ) ) { if ( $this->stacksOfVotes->contains( $stackOfVote ) ) {
$this->stackOfVotes->removeElement( $stackOfVote ); $this->stacksOfVotes->removeElement( $stackOfVote );
// set the owning side to null (unless already changed) // set the owning side to null (unless already changed)
if ( $stackOfVote->getPoll() === $this ) { if ( $stackOfVote->getPoll() === $this ) {
$stackOfVote->setPoll( null ); $stackOfVote->setPoll( null );
@ -450,6 +462,29 @@ class Poll {
public function setAllowedAnswers( array $allowedAnswers ): self { public function setAllowedAnswers( array $allowedAnswers ): self {
$this->allowedAnswers = $allowedAnswers; $this->allowedAnswers = $allowedAnswers;
return $this;
}
public function addStacksOfVote(StackOfVotes $stacksOfVote): self
{
if (!$this->stacksOfVotes->contains($stacksOfVote)) {
$this->stacksOfVotes[] = $stacksOfVote;
$stacksOfVote->setPoll($this);
}
return $this;
}
public function removeStacksOfVote(StackOfVotes $stacksOfVote): self
{
if ($this->stacksOfVotes->contains($stacksOfVote)) {
$this->stacksOfVotes->removeElement($stacksOfVote);
// set the owning side to null (unless already changed)
if ($stacksOfVote->getPoll() === $this) {
$stacksOfVote->setPoll(null);
}
}
return $this; return $this;
} }
} }

View File

@ -26,15 +26,18 @@ class StackOfVotes {
public $pseudo; public $pseudo;
/** /**
* @ORM\OneToMany(targetEntity="App\Entity\Vote", mappedBy="stacksOfVotes", cascade={"persist","remove"}) * @ORM\OneToMany(targetEntity="App\Entity\Vote", mappedBy="stacksOfVotes", cascade={"persist","remove"})
* @Serializer\Expose()
*/ */
private $votes; public $votes;
/** /**
* @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="stacksOfVotes", cascade={"persist"}) * @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="stacksOfVotes", cascade={"persist"})
* @Serializer\Expose()
*/ */
private $poll; private $poll;
/** /**
* @ORM\ManyToOne(targetEntity="App\Entity\Owner", inversedBy="stackOfVotes", cascade={"persist"}) * @ORM\ManyToOne(targetEntity="App\Entity\Owner", inversedBy="stackOfVotes", cascade={"persist"})
* @Serializer\Expose()
*/ */
private $owner; private $owner;
@ -58,7 +61,7 @@ class StackOfVotes {
$vote->setPoll( $this->getPoll() ); $vote->setPoll( $this->getPoll() );
$this->votes[] = $vote; $this->votes[] = $vote;
$vote->setStackOfVotes( $this ); $vote->setStacksOfVotes( $this );
} }
return $this; return $this;
@ -68,8 +71,8 @@ class StackOfVotes {
if ( $this->votes->contains( $vote ) ) { if ( $this->votes->contains( $vote ) ) {
$this->votes->removeElement( $vote ); $this->votes->removeElement( $vote );
// set the owning side to null (unless already changed) // set the owning side to null (unless already changed)
if ( $vote->getStackOfVotes() === $this ) { if ( $vote->getStacksOfVotes() === $this ) {
$vote->setStackOfVotes( null ); $vote->setStacksOfVotes( null );
} }
} }

View File

@ -23,7 +23,7 @@ class Vote {
*/ */
public $creationDate; public $creationDate;
/** /**
* @ORM\ManyToOne(targetEntity="App\Entity\Choice", inversedBy="votes") * @ORM\ManyToOne(targetEntity="App\Entity\Choice", inversedBy="votes", cascade={"persist"})
* @ORM\JoinColumn(nullable=false) * @ORM\JoinColumn(nullable=false)
* @Serializer\Type("App\Entity\choice") * @Serializer\Type("App\Entity\choice")
*/ */
@ -36,7 +36,7 @@ class Vote {
*/ */
private $id; private $id;
/** /**
* @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="votes") * @ORM\ManyToOne(targetEntity="App\Entity\Poll", inversedBy="votes", cascade={"persist"})
* @ORM\JoinColumn(nullable=false) * @ORM\JoinColumn(nullable=false)
* @Serializer\Type("App\Entity\Poll") * @Serializer\Type("App\Entity\Poll")
*/ */
@ -46,7 +46,7 @@ class Vote {
* @ORM\JoinColumn(nullable=false) * @ORM\JoinColumn(nullable=false)
* @Serializer\Type("App\Entity\StackOfVotes") * @Serializer\Type("App\Entity\StackOfVotes")
*/ */
private $stackOfVotes; private $stacksOfVotes;
public function __construct() { public function __construct() {
$this->setCreationDate( new \DateTime() ); $this->setCreationDate( new \DateTime() );
@ -99,12 +99,12 @@ class Vote {
return $this; return $this;
} }
public function getStackOfVotes(): ?StackOfVotes { public function getStacksOfVotes(): ?StackOfVotes {
return $this->stackOfVotes; return $this->stacksOfVotes;
} }
public function setStackOfVotes( ?StackOfVotes $stackOfVotes ): self { public function setStacksOfVotes( ?StackOfVotes $stacksOfVotes ): self {
$this->stackOfVotes = $stackOfVotes; $this->stacksOfVotes = $stacksOfVotes;
return $this; return $this;
} }