]> Raphaël G. Git Repositories - airbundle/blobdiff - Entity/User.php
Add calendar2 command
[airbundle] / Entity / User.php
index bd9f802333f9fb11db38c0598e38f51da4371d07..807fecececcbae08ceaf8626904a327c31cbf7f4 100644 (file)
-<?php
+<?php declare(strict_types=1);
+
+/*
+ * this file is part of the rapsys packbundle package.
+ *
+ * (c) raphaël gertz <symfony@rapsys.eu>
+ *
+ * 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 Rapsys\AirBundle\Entity\Application;
-use Rapsys\AirBundle\Entity\Group;
-use Rapsys\AirBundle\Entity\Vote;
+use Doctrine\Common\Collections\Collection;
+use Doctrine\Common\Collections\ArrayCollection;
+
 use Rapsys\UserBundle\Entity\User as BaseUser;
 
 class User extends BaseUser {
        /**
-        * @var string
+        * @var ?string
+        */
+       private ?string $city;
+
+       /**
+        * @var ?string
+        */
+       private ?string $phone;
+
+       /**
+        * @var Country
+        */
+       private ?Country $country;
+
+       /**
+        * @var ?string
+        */
+       private ?string $pseudonym;
+
+       /**
+        * @var ?string
+        */
+       private ?string $zipcode;
+
+       /**
+        * @var \Doctrine\Common\Collections\Collection
+        */
+       private Collection $applications;
+
+       /**
+        * @var \Doctrine\Common\Collections\Collection
+        */
+       private Collection $dances;
+
+       /**
+        * @var \Doctrine\Common\Collections\Collection
         */
-       protected $phone;
+       private Collection $locations;
 
        /**
         * @var \Doctrine\Common\Collections\Collection
         */
-       private $votes;
+       private Collection $snippets;
 
        /**
         * @var \Doctrine\Common\Collections\Collection
         */
-       private $applications;
+       private Collection $subscribers;
+
+       /**
+        * @var \Doctrine\Common\Collections\Collection
+        */
+       private Collection $subscriptions;
+
+       /**
+        * @var \Doctrine\Common\Collections\Collection
+        */
+       private Collection $googleTokens;
 
        /**
         * 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->city = null;
+               $this->country = null;
+               $this->phone = null;
+               $this->pseudonym = null;
+               $this->zipcode = 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();
+               $this->googleTokens = new ArrayCollection();
+       }
+
+       /**
+        * Set city
+        *
+        * @param string $city
+        *
+        * @return User
+        */
+       public function setCity(?string $city): User {
+               $this->city = $city;
+
+               return $this;
+       }
+
+       /**
+        * Get city
+        *
+        * @return string
+        */
+       public function getCity(): ?string {
+               return $this->city;
+       }
+
+       /**
+        * Set country
+        *
+        * @param Country $country
+        *
+        * @return User
+        */
+       public function setCountry(?Country $country): User {
+               $this->country = $country;
+
+               return $this;
+       }
+
+       /**
+        * Get country
+        *
+        * @return Country
+        */
+       public function getCountry(): ?Country {
+               return $this->country;
        }
 
        /**
@@ -38,7 +154,7 @@ class User extends BaseUser {
         *
         * @return User
         */
-       public function setPhone($phone) {
+       public function setPhone(?string $phone): User {
                $this->phone = $phone;
 
                return $this;
@@ -49,49 +165,62 @@ class User extends BaseUser {
         *
         * @return string
         */
-       public function getPhone() {
+       public function getPhone(): ?string {
                return $this->phone;
        }
 
        /**
-        * Add vote
+        * Set pseudonym
         *
-        * @param \Rapsys\AirBundle\Entity\Vote $vote
+        * @param string $pseudonym
         *
         * @return User
         */
-       public function addVote(Vote $vote) {
-               $this->votes[] = $vote;
+       public function setPseudonym(?string $pseudonym): User {
+               $this->pseudonym = $pseudonym;
 
                return $this;
        }
 
        /**
-        * Remove vote
+        * Get pseudonym
         *
-        * @param \Rapsys\AirBundle\Entity\Vote $vote
+        * @return string
         */
-       public function removeVote(Vote $vote) {
-               $this->votes->removeElement($vote);
+       public function getPseudonym(): ?string {
+               return $this->pseudonym;
        }
 
        /**
-        * Get votes
+        * Set zipcode
         *
-        * @return \Doctrine\Common\Collections\Collection
+        * @param string $zipcode
+        *
+        * @return User
         */
-       public function getVotes() {
-               return $this->votes;
+       public function setZipcode(?string $zipcode): User {
+               $this->zipcode = $zipcode;
+
+               return $this;
+       }
+
+       /**
+        * Get zipcode
+        *
+        * @return string
+        */
+       public function getZipcode(): ?string {
+               return $this->zipcode;
        }
 
        /**
         * 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,10 +229,10 @@ 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);
        }
 
        /**
@@ -111,18 +240,205 @@ class User extends BaseUser {
         *
         * @return \Doctrine\Common\Collections\Collection
         */
-       public function getApplications() {
+       public function getApplications(): Collection {
                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 \Doctrine\Common\Collections\Collection
+        */
+       public function getDances(): Collection {
+               return $this->dances;
+       }
+
+       /**
+        * Add location
         *
-        * @return array
+        * @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 \Doctrine\Common\Collections\Collection
+        */
+       public function getLocations(): Collection {
+               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 \Doctrine\Common\Collections\Collection
+        */
+       public function getSnippets(): Collection {
+               return $this->snippets;
+       }
+
+       /**
+        * Add subscriber
+        *
+        * @param User $subscriber
+        *
+        * @return User
+        */
+       public function addSubscriber(User $subscriber): User {
+               //Add from owning side
+               $subscriber->addSubscription($this);
+
+               $this->subscribers[] = $subscriber;
+
+               return $this;
+       }
+
+       /**
+        * Remove subscriber
+        *
+        * @param User $subscriber
+        */
+       public function removeSubscriber(User $subscriber): bool {
+               if (!$this->subscriptions->contains($subscriber)) {
+                       return true;
+               }
+
+               //Remove from owning side
+               $subscriber->removeSubscription($this);
+
+               return $this->subscribers->removeElement($subscriber);
+       }
+
+       /**
+        * Get subscribers
+        *
+        * @return \Doctrine\Common\Collections\Collection
+        */
+       public function getSubscribers(): Collection {
+               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 \Doctrine\Common\Collections\Collection
+        */
+       public function getSubscriptions(): Collection {
+               return $this->subscriptions;
+       }
+
+       /**
+        * Add google token
+        *
+        * @param GoogleToken $googleToken
+        *
+        * @return User
+        */
+       public function addGoogleToken(GoogleToken $googleToken): User {
+               $this->googleTokens[] = $googleToken;
+
+               return $this;
+       }
+
+       /**
+        * Remove google token
+        *
+        * @param GoogleToken $googleToken
+        */
+       public function removeGoogleToken(GoogleToken $googleToken): bool {
+               return $this->googleTokens->removeElement($googleToken);
+       }
+
+       /**
+        * Get googleTokens
+        *
+        * @return \Doctrine\Common\Collections\Collection
         */
-       public function getRoles() {
-               //Return roles array
-               //XXX: [ ROLE_USER, ROLE_XXX, ... ]
-               return parent::getRoles();
+       public function getGoogleTokens(): Collection {
+               return $this->googleTokens;
        }
 }