X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/b2215f349d8b99db8fb4f28f7c17f0c6984d43bb..c6bbcfd55938e1dac9eab54a00f5880e1f712785:/Entity/User.php?ds=sidebyside diff --git a/Entity/User.php b/Entity/User.php index bd9f802..189e0ea 100644 --- a/Entity/User.php +++ b/Entity/User.php @@ -1,97 +1,167 @@ - + * + * for the full copyright and license information, please view the license + * file that was distributed with this source code. + */ -// src/Rapsys/AirBundle/Entity/User.php namespace Rapsys\AirBundle\Entity; +use Doctrine\Common\Collections\ArrayCollection; + use Rapsys\AirBundle\Entity\Application; use Rapsys\AirBundle\Entity\Group; -use Rapsys\AirBundle\Entity\Vote; +use Rapsys\AirBundle\Entity\Link; +use Rapsys\AirBundle\Entity\Snippet; use Rapsys\UserBundle\Entity\User as BaseUser; class User extends BaseUser { + /** + * @var string + */ + protected $pseudonym; + /** * @var string */ protected $phone; /** - * @var \Doctrine\Common\Collections\Collection + * @var string */ - private $votes; + protected $slug; /** - * @var \Doctrine\Common\Collections\Collection + * @var ArrayCollection */ private $applications; + /** + * @var ArrayCollection + */ + private $dances; + + /** + * @var ArrayCollection + */ + private $locations; + + /** + * @var ArrayCollection + */ + private $snippets; + + /** + * @var ArrayCollection + */ + private $subscribers; + + /** + * @var ArrayCollection + */ + private $subscriptions; + /** * Constructor + * + * @param string $mail The user mail */ - public function __construct() { - parent::__construct(); + public function __construct(string $mail) { + //Call parent constructor + parent::__construct($mail); + + //Set defaults + $this->pseudonym = null; + $this->phone = null; + $this->slug = null; + + //Set collections + $this->applications = new ArrayCollection(); + $this->dances = new ArrayCollection(); + $this->locations = new ArrayCollection(); + $this->snippets = new ArrayCollection(); + $this->subscribers = new ArrayCollection(); + $this->subscriptions = new ArrayCollection(); } /** - * Set phone + * Set pseudonym * - * @param string $phone + * @param string $pseudonym * * @return User */ - public function setPhone($phone) { - $this->phone = $phone; + public function setPseudonym(?string $pseudonym): User { + $this->pseudonym = $pseudonym; return $this; } /** - * Get phone + * Get pseudonym * * @return string */ - public function getPhone() { - return $this->phone; + public function getPseudonym(): ?string { + return $this->pseudonym; } /** - * Add vote + * Set phone * - * @param \Rapsys\AirBundle\Entity\Vote $vote + * @param string $phone * * @return User */ - public function addVote(Vote $vote) { - $this->votes[] = $vote; + public function setPhone(?string $phone): User { + $this->phone = $phone; return $this; } /** - * Remove vote + * Get phone * - * @param \Rapsys\AirBundle\Entity\Vote $vote + * @return string */ - public function removeVote(Vote $vote) { - $this->votes->removeElement($vote); + public function getPhone(): ?string { + return $this->phone; } /** - * Get votes + * Set slug + * + * @param string $slug * - * @return \Doctrine\Common\Collections\Collection + * @return User */ - public function getVotes() { - return $this->votes; + public function setSlug(?string $slug): User { + $this->slug = $slug; + + return $this; + } + + /** + * Get slug + * + * @return string + */ + public function getSlug(): ?string { + return $this->slug; } /** * Add application * - * @param \Rapsys\AirBundle\Entity\Application $application + * @param Application $application * * @return User */ - public function addApplication(Application $application) { + public function addApplication(Application $application): User { $this->applications[] = $application; return $this; @@ -100,29 +170,175 @@ class User extends BaseUser { /** * Remove application * - * @param \Rapsys\AirBundle\Entity\Application $application + * @param Application $application */ - public function removeApplication(Application $application) { - $this->applications->removeElement($application); + public function removeApplication(Application $application): bool { + return $this->applications->removeElement($application); } /** * Get applications * - * @return \Doctrine\Common\Collections\Collection + * @return ArrayCollection */ - public function getApplications() { + public function getApplications(): ArrayCollection { return $this->applications; } /** - * Get roles + * Add dance + * + * @param Dance $dance + * + * @return User + */ + public function addDance(Dance $dance): User { + $this->dances[] = $dance; + + return $this; + } + + /** + * Remove dance + * + * @param Dance $dance + * + * @return bool + */ + public function removeDance(Dance $dance): bool { + return $this->dances->removeElement($dance); + } + + /** + * Get dances + * + * @return ArrayCollection + */ + public function getDances(): ArrayCollection { + return $this->dances; + } + + /** + * Add location + * + * @param Location $location + * + * @return User + */ + public function addLocation(Location $location): User { + $this->locations[] = $location; + + return $this; + } + + /** + * Remove location + * + * @param Location $location + */ + public function removeLocation(Location $location): bool { + return $this->locations->removeElement($location); + } + + /** + * Get locations + * + * @return ArrayCollection + */ + public function getLocations(): ArrayCollection { + return $this->locations; + } + + /** + * Add snippet + * + * @param Snippet $snippet + * + * @return User + */ + public function addSnippet(Snippet $snippet): User { + $this->snippets[] = $snippet; + + return $this; + } + + /** + * Remove snippet + * + * @param Snippet $snippet + */ + public function removeSnippet(Snippet $snippet): bool { + return $this->snippets->removeElement($snippet); + } + + /** + * Get snippets + * + * @return ArrayCollection + */ + public function getSnippets(): ArrayCollection { + return $this->snippets; + } + + /** + * Add subscriber + * + * @param User $subscriber + * + * @return User + */ + public function addSubscriber(User $subscriber): User { + $this->subscribers[] = $subscriber; + + return $this; + } + + /** + * Remove subscriber + * + * @param User $subscriber + */ + public function removeSubscriber(User $subscriber): bool { + return $this->subscribers->removeElement($subscriber); + } + + /** + * Get subscribers + * + * @return ArrayCollection + */ + public function getSubscribers(): ArrayCollection { + return $this->subscribers; + } + + /** + * Add subscription + * + * @param User $subscription + * + * @return User + */ + public function addSubscription(User $subscription): User { + $this->subscriptions[] = $subscription; + + return $this; + } + + /** + * Remove subscription + * + * @param User $subscription + */ + public function removeSubscription(User $subscription): bool { + return $this->subscriptions->removeElement($subscription); + } + + /** + * Get subscriptions * - * @return array + * @return ArrayCollection */ - public function getRoles() { - //Return roles array - //XXX: [ ROLE_USER, ROLE_XXX, ... ] - return parent::getRoles(); + public function getSubscriptions(): ArrayCollection { + return $this->subscriptions; } }