src/Entity/AccessToken.php line 12

Open in your IDE?
  1. <?php
  2. namespace App\Entity;
  3. use App\Repository\AccessTokenRepository;
  4. use Doctrine\ORM\Mapping as ORM;
  5. use Symfony\Component\HttpFoundation\Cookie;
  6. /**
  7.  * @ORM\Entity(repositoryClass=AccessTokenRepository::class)
  8.  */
  9. class AccessToken
  10. {
  11.     const TOKEN_EXPIRATION_MINUTES 5;
  12.     /**
  13.      * @ORM\Id
  14.      * @ORM\GeneratedValue
  15.      * @ORM\Column(type="integer")
  16.      */
  17.     private $id;
  18.     /**
  19.      * @ORM\Column(type="datetime")
  20.      */
  21.     private $createdAt;
  22.     /**
  23.      * @ORM\ManyToOne(targetEntity=Device::class, inversedBy="accessTokens")
  24.      */
  25.     private $device;
  26.     /**
  27.      * @ORM\Column(type="string", length=255, unique=true)
  28.      */
  29.     private $token;
  30.     /**
  31.      * @ORM\Column(type="boolean", nullable=true)
  32.      */
  33.     private $revoked;
  34.     /**
  35.      * @ORM\OneToOne(targetEntity=RefreshToken::class, cascade={"persist", "remove"})
  36.      */
  37.     private $refreshToken;
  38.     /**
  39.      * @ORM\ManyToOne(targetEntity=User::class)
  40.      * @ORM\JoinColumn(nullable=false)
  41.      */
  42.     private $user;
  43.     public function __construct()
  44.     {
  45.         $this->createdAt = new \DateTime();
  46.     }
  47.     public function getId(): ?int
  48.     {
  49.         return $this->id;
  50.     }
  51.     public function getCreatedAt(): ?\DateTimeInterface
  52.     {
  53.         return $this->createdAt;
  54.     }
  55.     public function setCreatedAt(\DateTimeInterface $createdAt): self
  56.     {
  57.         $this->createdAt $createdAt;
  58.         return $this;
  59.     }
  60.     public function getDevice(): ?Device
  61.     {
  62.         return $this->device;
  63.     }
  64.     public function setDevice(?Device $device): self
  65.     {
  66.         $this->device $device;
  67.         return $this;
  68.     }
  69.     public function getToken(): ?string
  70.     {
  71.         return $this->token;
  72.     }
  73.     public function setToken(string $token): self
  74.     {
  75.         $this->token $token;
  76.         return $this;
  77.     }
  78.     public function getExpiresAt(): ?\DateTimeInterface
  79.     {
  80.         if ($this->getCreatedAt()) {
  81.             $expiresAt = clone $this->getCreatedAt();
  82.             $expiresAt->modify('+' self::TOKEN_EXPIRATION_MINUTES ' minutes');
  83.             return $expiresAt;
  84.         }
  85.         return null;
  86.     }
  87.     public function isExpired(): bool
  88.     {
  89.         $expiresAt $this->getExpiresAt();
  90.         if ($expiresAt) {
  91.             return new \DateTime() > $expiresAt;
  92.         }
  93.         return false;
  94.     }
  95.     public function isRevoked(): ?bool
  96.     {
  97.         return $this->revoked;
  98.     }
  99.     public function setRevoked(?bool $revoked): self
  100.     {
  101.         $this->revoked $revoked;
  102.         return $this;
  103.     }
  104.     public function isAlive(): bool
  105.     {
  106.         return !$this->isExpired() && !$this->isRevoked();
  107.     }
  108.     public function getRefreshToken(): ?RefreshToken
  109.     {
  110.         return $this->refreshToken;
  111.     }
  112.     public function setRefreshToken(?RefreshToken $refreshToken): self
  113.     {
  114.         $this->refreshToken $refreshToken;
  115.         return $this;
  116.     }
  117.     public function getUser(): ?User
  118.     {
  119.         return $this->user;
  120.     }
  121.     public function setUser(?User $user): self
  122.     {
  123.         $this->user $user;
  124.         return $this;
  125.     }
  126.     public function isRefreshable(): bool
  127.     {
  128.         return $this->getRefreshToken() && $this->getRefreshToken()->isAlive();
  129.     }
  130.     public function createCookie()
  131.     {
  132.         return Cookie::create('access_token')
  133.             ->withValue($this->getToken())
  134.             ->withHttpOnly(true)
  135.             ->withSecure($_ENV["APP_ENV"] == "prod"// true in production with HTTPS //todo redo
  136.             ->withSameSite('Lax')
  137.             ->withPath('/1bc3f6fdaea8f6ae35')
  138.             ->withExpires((new \DateTime())->modify('+365 days'))
  139.         ;
  140.     }
  141. }