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:
parent
a0842f3b7c
commit
010f07230d
@ -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 );
|
||||||
|
@ -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 ] );
|
||||||
|
|
||||||
|
@ -33,145 +33,90 @@ 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() );
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function getId(): ?int {
|
public function getId(): ?int {
|
||||||
return $this->id;
|
return $this->id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName(): ?string {
|
public function getName(): ?string {
|
||||||
return $this->name;
|
return $this->name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setName( $name ): self {
|
public function setName( $name ): self {
|
||||||
if ( is_a( $name, 'DateTime' ) ) {
|
if ( is_a( $name, 'DateTime' ) ) {
|
||||||
$this->setDateTime( $name );
|
$this->setDateTime( $name );
|
||||||
$name = $name->format( 'D Y-m-d' );
|
$name = $name->format( 'D Y-m-d' );
|
||||||
}
|
}
|
||||||
$this->name = $name;
|
$this->name = $name;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDateTime(): ?DateTimeInterface {
|
public function getDateTime(): ?DateTimeInterface {
|
||||||
return $this->dateTime;
|
return $this->dateTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setDateTime( ?DateTimeInterface $dateTime ): self {
|
public function setDateTime( ?DateTimeInterface $dateTime ): self {
|
||||||
$this->dateTime = $dateTime;
|
$this->dateTime = $dateTime;
|
||||||
|
|
||||||
|
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[]
|
|
||||||
*/
|
|
||||||
public function getStackOfVotes(): Collection {
|
|
||||||
return $this->stackOfVotes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function addVote( Choice $vote ): self {
|
|
||||||
if ( ! $this->stackOfVotes->contains( $vote ) ) {
|
|
||||||
$this->stackOfVotes[] = $vote;
|
|
||||||
$vote->setChoice( $this );
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function removeVote( Choice $vote ): self {
|
|
||||||
if ( $this->stackOfVotes->contains( $vote ) ) {
|
|
||||||
$this->stackOfVotes->removeElement( $vote );
|
|
||||||
// set the owning side to null (unless already changed)
|
|
||||||
if ( $vote->getChoice() === $this ) {
|
|
||||||
$vote->setChoice( null );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function addStackOfVote( StackOfVotes $stackOfVote ): self {
|
|
||||||
if ( ! $this->stackOfVotes->contains( $stackOfVote ) ) {
|
|
||||||
$this->stackOfVotes[] = $stackOfVote;
|
|
||||||
$stackOfVote->setChoice( $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[]
|
* @return Collection|Vote[]
|
||||||
*/
|
*/
|
||||||
public function getVotes(): Collection {
|
public function getVotes(): Collection {
|
||||||
return $this->votes;
|
return $this->votes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function addVote( Vote $vote ): self {
|
||||||
|
if ( ! $this->votes->contains( $vote ) ) {
|
||||||
|
$this->votes[] = $vote;
|
||||||
|
$vote->setChoice( $this );
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function removeVote( Vote $vote ): self {
|
||||||
|
if ( $this->votes->contains( $vote ) ) {
|
||||||
|
$this->votes->removeElement( $vote );
|
||||||
|
// set the owning side to null (unless already changed)
|
||||||
|
if ( $vote->getChoice() === $this ) {
|
||||||
|
$vote->setChoice( null );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPoll(): ?Poll
|
||||||
|
{
|
||||||
|
return $this->poll;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setPoll(?Poll $poll): self
|
||||||
|
{
|
||||||
|
$this->poll = $poll;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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")
|
||||||
@ -142,314 +142,349 @@ class Poll {
|
|||||||
|
|
||||||
|
|
||||||
public function __construct() {
|
public function __construct() {
|
||||||
$this->adminKey = uniqid();
|
$this->adminKey = uniqid();
|
||||||
$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(),
|
||||||
$this->defaultExpiracyDaysFromNow
|
$this->defaultExpiracyDaysFromNow
|
||||||
) );
|
) );
|
||||||
$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 ) {
|
||||||
$st = strtotime( $date->getTimestamp() . ' + ' . $days . ' days' );
|
$st = strtotime( $date->getTimestamp() . ' + ' . $days . ' days' );
|
||||||
|
|
||||||
return new \DateTime( $st );
|
return new \DateTime( $st );
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getId(): ?int {
|
public function getId(): ?int {
|
||||||
return $this->id;
|
return $this->id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getTitle(): ?string {
|
public function getTitle(): ?string {
|
||||||
return $this->title;
|
return $this->title;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setTitle( string $title ): self {
|
public function setTitle( string $title ): self {
|
||||||
$this->title = $title;
|
$this->title = $title;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getCreationDate(): ?DateTimeInterface {
|
public function getCreationDate(): ?DateTimeInterface {
|
||||||
return $this->creationDate;
|
return $this->creationDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setCreationDate( DateTimeInterface $creationDate ): self {
|
public function setCreationDate( DateTimeInterface $creationDate ): self {
|
||||||
$this->creationDate = $creationDate;
|
$this->creationDate = $creationDate;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setExpiracyDate( DateTimeInterface $expiracyDate ): self {
|
public function setExpiracyDate( DateTimeInterface $expiracyDate ): self {
|
||||||
$this->expiracyDate = $expiracyDate;
|
$this->expiracyDate = $expiracyDate;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getOwner(): ?Owner {
|
public function getOwner(): ?Owner {
|
||||||
return $this->owner;
|
return $this->owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setOwner( ?Owner $owner ): self {
|
public function setOwner( ?Owner $owner ): self {
|
||||||
$this->owner = $owner;
|
$this->owner = $owner;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Collection|Vote[]
|
* @return Collection|Vote[]
|
||||||
*/
|
*/
|
||||||
public function getVotes(): Collection {
|
public function getVotes(): Collection {
|
||||||
return $this->votes;
|
return $this->votes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getAdminKey(): ?string {
|
public function getAdminKey(): ?string {
|
||||||
return $this->adminKey;
|
return $this->adminKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setAdminKey( string $adminKey ): self {
|
public function setAdminKey( string $adminKey ): self {
|
||||||
$this->adminKey = $adminKey;
|
$this->adminKey = $adminKey;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDescription(): ?string {
|
public function getDescription(): ?string {
|
||||||
return $this->description;
|
return $this->description;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setDescription( string $description ): self {
|
public function setDescription( string $description ): self {
|
||||||
$this->description = $description;
|
$this->description = $description;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getKind(): ?string {
|
public function getKind(): ?string {
|
||||||
return $this->kind;
|
return $this->kind;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setKind( string $kind ): self {
|
public function setKind( string $kind ): self {
|
||||||
$this->kind = $kind;
|
$this->kind = $kind;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getCustomUrl(): ?string {
|
public function getCustomUrl(): ?string {
|
||||||
return $this->customUrl;
|
return $this->customUrl;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setCustomUrl( string $customUrl ): self {
|
public function setCustomUrl( string $customUrl ): self {
|
||||||
$this->customUrl = $customUrl;
|
$this->customUrl = $customUrl;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getPassword(): ?string {
|
public function getPassword(): ?string {
|
||||||
return $this->password;
|
return $this->password;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setPassword( string $password ): self {
|
public function setPassword( string $password ): self {
|
||||||
$this->password = $password;
|
$this->password = $password;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getModificationPolicy(): ?string {
|
public function getModificationPolicy(): ?string {
|
||||||
return $this->modificationPolicy;
|
return $this->modificationPolicy;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setModificationPolicy( string $modificationPolicy ): self {
|
public function setModificationPolicy( string $modificationPolicy ): self {
|
||||||
$this->modificationPolicy = $modificationPolicy;
|
$this->modificationPolicy = $modificationPolicy;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getMailOnComment(): ?bool {
|
public function getMailOnComment(): ?bool {
|
||||||
return $this->mailOnComment;
|
return $this->mailOnComment;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setMailOnComment( bool $mailOnComment ): self {
|
public function setMailOnComment( bool $mailOnComment ): self {
|
||||||
$this->mailOnComment = $mailOnComment;
|
$this->mailOnComment = $mailOnComment;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getMailOnVote(): ?bool {
|
public function getMailOnVote(): ?bool {
|
||||||
return $this->mailOnVote;
|
return $this->mailOnVote;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setMailOnVote( bool $mailOnVote ): self {
|
public function setMailOnVote( bool $mailOnVote ): self {
|
||||||
$this->mailOnVote = $mailOnVote;
|
$this->mailOnVote = $mailOnVote;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getHideResults(): ?bool {
|
public function getHideResults(): ?bool {
|
||||||
return $this->hideResults;
|
return $this->hideResults;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setHideResults( bool $hideResults ): self {
|
public function setHideResults( bool $hideResults ): self {
|
||||||
$this->hideResults = $hideResults;
|
$this->hideResults = $hideResults;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getShowResultEvenIfPasswords(): ?bool {
|
public function getShowResultEvenIfPasswords(): ?bool {
|
||||||
return $this->showResultEvenIfPasswords;
|
return $this->showResultEvenIfPasswords;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setShowResultEvenIfPasswords( bool $showResultEvenIfPasswords ): self {
|
public function setShowResultEvenIfPasswords( bool $showResultEvenIfPasswords ): self {
|
||||||
$this->showResultEvenIfPasswords = $showResultEvenIfPasswords;
|
$this->showResultEvenIfPasswords = $showResultEvenIfPasswords;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Collection|Comment[]
|
* @return Collection|Comment[]
|
||||||
*/
|
*/
|
||||||
public function getComments(): Collection {
|
public function getComments(): Collection {
|
||||||
return $this->comments;
|
return $this->comments;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addComment( Comment $comment ): self {
|
public function addComment( Comment $comment ): self {
|
||||||
if ( ! $this->comments->contains( $comment ) ) {
|
if ( ! $this->comments->contains( $comment ) ) {
|
||||||
$this->comments[] = $comment;
|
$this->comments[] = $comment;
|
||||||
$comment->setPoll( $this );
|
$comment->setPoll( $this );
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function removeComment( Comment $comment ): self {
|
public function removeComment( Comment $comment ): self {
|
||||||
if ( $this->comments->contains( $comment ) ) {
|
if ( $this->comments->contains( $comment ) ) {
|
||||||
$this->comments->removeElement( $comment );
|
$this->comments->removeElement( $comment );
|
||||||
// set the owning side to null (unless already changed)
|
// set the owning side to null (unless already changed)
|
||||||
if ( $comment->getPoll() === $this ) {
|
if ( $comment->getPoll() === $this ) {
|
||||||
$comment->setPoll( null );
|
$comment->setPoll( null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
return $this;
|
public function getStacksOfVotes() {
|
||||||
}
|
return $this->stacksOfVotes;
|
||||||
|
}
|
||||||
public function getStacksOfVotes(): ?StackOfVotes {
|
|
||||||
return $this->stacksOfVotes;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function setStacksOfVotes( ?StackOfVotes $stacksOfVotes ): self {
|
public function setStacksOfVotes( ?StackOfVotes $stacksOfVotes ): self {
|
||||||
$this->stacksOfVotes = $stacksOfVotes;
|
$this->stacksOfVotes = $stacksOfVotes;
|
||||||
|
|
||||||
|
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 );
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
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 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getExpiracyDate(): ?\DateTimeInterface {
|
public function getExpiracyDate(): ?\DateTimeInterface {
|
||||||
return $this->expiracyDate;
|
return $this->expiracyDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addVote( Vote $vote ): self {
|
public function addVote( Vote $vote ): self {
|
||||||
if ( ! $this->votes->contains( $vote ) ) {
|
if ( ! $this->votes->contains( $vote ) ) {
|
||||||
$this->votes[] = $vote;
|
$this->votes[] = $vote;
|
||||||
$vote->setPoll( $this );
|
$vote->setPoll( $this );
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function removeVote( Vote $vote ): self {
|
public function removeVote( Vote $vote ): self {
|
||||||
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->getPoll() === $this ) {
|
if ( $vote->getPoll() === $this ) {
|
||||||
$vote->setPoll( null );
|
$vote->setPoll( null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Collection|Choice[]
|
* @return Collection|Choice[]
|
||||||
*/
|
*/
|
||||||
public function getChoices(): Collection {
|
public function getChoices(): Collection {
|
||||||
return $this->choices;
|
return $this->choices;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addTextChoiceArray( Array $choiceTextArray ): self {
|
public function addTextChoiceArray( Array $choiceTextArray ): self {
|
||||||
foreach ( $choiceTextArray as $text ) {
|
foreach ( $choiceTextArray as $text ) {
|
||||||
$newChoice = new Choice();
|
$newChoice = new Choice();
|
||||||
$newChoice->setName( $text );
|
$newChoice->setName( $text );
|
||||||
$this->addChoice( $newChoice );
|
$this->addChoice( $newChoice );
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addChoice( Choice $choice ): self {
|
public function addChoice( Choice $choice ): self {
|
||||||
if ( ! $this->choices->contains( $choice ) ) {
|
if ( ! $this->choices->contains( $choice ) ) {
|
||||||
$this->choices[] = $choice;
|
$this->choices[] = $choice;
|
||||||
$choice->setPoll( $this );
|
$choice->setPoll( $this );
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function removeChoice( Choice $choice ): self {
|
public function removeChoice( Choice $choice ): self {
|
||||||
if ( $this->choices->contains( $choice ) ) {
|
if ( $this->choices->contains( $choice ) ) {
|
||||||
$this->choices->removeElement( $choice );
|
$this->choices->removeElement( $choice );
|
||||||
// set the owning side to null (unless already changed)
|
// set the owning side to null (unless already changed)
|
||||||
if ( $choice->getPoll() === $this ) {
|
if ( $choice->getPoll() === $this ) {
|
||||||
$choice->setPoll( null );
|
$choice->setPoll( null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getAllowedAnswers(): ?array {
|
public function getAllowedAnswers(): ?array {
|
||||||
return $this->allowedAnswers;
|
return $this->allowedAnswers;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setAllowedAnswers( array $allowedAnswers ): self {
|
public function setAllowedAnswers( array $allowedAnswers ): self {
|
||||||
$this->allowedAnswers = $allowedAnswers;
|
$this->allowedAnswers = $allowedAnswers;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user