-<?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/UserBundle/Entity/Group.php
namespace Rapsys\UserBundle\Entity;
-class Group extends \Symfony\Component\Security\Core\Role\Role {
+use Doctrine\Common\Collections\ArrayCollection;
+
+use Rapsys\UserBundle\Entity\User;
+
+/**
+ * Group
+ */
+class Group {
/**
* @var integer
*/
/**
* @var string
*/
- protected $role;
+ protected $title;
/**
* @var \DateTime
protected $updated;
/**
- * @var \Doctrine\Common\Collections\Collection
+ * @var ArrayCollection
*/
protected $users;
/**
* Constructor
- * @param string $role The role name
+ *
+ * @param string $title The group name
*/
- public function __construct($role) {
- $this->role = (string) $role;
- $this->users = new \Doctrine\Common\Collections\ArrayCollection();
+ public function __construct(string $title) {
+ $this->title = $title;
+ $this->users = new ArrayCollection();
}
/**
- * Set role
+ * Get id
*
- * @param string $role
+ * @return integer
+ */
+ public function getId(): int {
+ return $this->id;
+ }
+
+ /**
+ * Set title
+ *
+ * @param string $title The group name
*
- * @return User
+ * @return Group
*/
- public function setRole($role) {
- $this->role = $role;
+ public function setTitle(string $title): Group {
+ $this->title = $title;
return $this;
}
/**
- * Get role
+ * Get title
*
* @return string
*/
- public function getRole() {
- return $this->role;
+ public function getTitle(): ?string {
+ return $this->title;
}
/**
*
* @param \DateTime $created
*
- * @return User
+ * @return Group
*/
- public function setCreated($created) {
+ public function setCreated(\DateTime $created): Group {
$this->created = $created;
return $this;
*
* @return \DateTime
*/
- public function getCreated() {
+ public function getCreated(): \DateTime {
return $this->created;
}
*
* @param \DateTime $updated
*
- * @return User
+ * @return Group
*/
- public function setUpdated($updated) {
+ public function setUpdated(\DateTime $updated): Group {
$this->updated = $updated;
return $this;
*
* @return \DateTime
*/
- public function getUpdated() {
+ public function getUpdated(): \DateTime {
return $this->updated;
}
/**
* Add user
*
- * @param \Rapsys\UserBundle\Entity\User $user
+ * @param User $user
*
* @return Group
*/
- public function addUser(\Rapsys\UserBundle\Entity\User $user) {
+ public function addUser(User $user) {
$this->users[] = $user;
return $this;
/**
* Remove user
*
- * @param \Rapsys\UserBundle\Entity\User $user
+ * @param User $user
*/
- public function removeUser(\Rapsys\UserBundle\Entity\User $user) {
+ public function removeUser(User $user) {
$this->users->removeElement($user);
}
/**
* Get users
*
- * @return \Doctrine\Common\Collections\Collection
+ * @return ArrayCollection
*/
- public function getUsers() {
+ public function getUsers(): ArrayCollection {
return $this->users;
}
+
+ /**
+ * Returns a string representation of the group
+ *
+ * @return string
+ */
+ public function __toString(): string {
+ return $this->title;
+ }
+
+ /**
+ * Get role
+ *
+ * @return string
+ */
+ public function getRole(): string {
+ return 'ROLE_'.strtoupper($this->title);
+ }
}