User.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace App\Models;
  3. use App\Enums\LanguageEnum;
  4. use App\Enums\UserTypeEnum;
  5. use App\Traits\HasPermissions;
  6. use Illuminate\Database\Eloquent\Factories\HasFactory;
  7. use Illuminate\Foundation\Auth\User as Authenticatable;
  8. use Illuminate\Notifications\Notifiable;
  9. use Laravel\Sanctum\HasApiTokens;
  10. use Illuminate\Database\Eloquent\Relations\BelongsToMany;
  11. use Carbon\Carbon;
  12. /**
  13. * @property int $id
  14. * @property string $name
  15. * @property string $email
  16. * @property \Illuminate\Support\Carbon|null $email_verified_at
  17. * @property string $password
  18. * @property UserTypeEnum $type
  19. * @property LanguageEnum $language
  20. * @property \Illuminate\Support\Carbon|null $created_at
  21. * @property \Illuminate\Support\Carbon|null $updated_at
  22. * @property-read \Illuminate\Notifications\DatabaseNotificationCollection<int, \Illuminate\Notifications\DatabaseNotification> $notifications
  23. * @property-read int|null $notifications_count
  24. * @property-read \Kalnoy\Nestedset\Collection<int, \App\Models\Permission> $permissions
  25. * @property-read int|null $permissions_count
  26. * @property-read \Illuminate\Database\Eloquent\Collection<int, \Laravel\Sanctum\PersonalAccessToken> $tokens
  27. * @property-read int|null $tokens_count
  28. * @method static \Database\Factories\UserFactory factory($count = null, $state = [])
  29. * @method static \Illuminate\Database\Eloquent\Builder<static>|User newModelQuery()
  30. * @method static \Illuminate\Database\Eloquent\Builder<static>|User newQuery()
  31. * @method static \Illuminate\Database\Eloquent\Builder<static>|User query()
  32. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereCreatedAt($value)
  33. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereEmail($value)
  34. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereEmailVerifiedAt($value)
  35. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereId($value)
  36. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereLanguage($value)
  37. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereName($value)
  38. * @method static \Illuminate\Database\Eloquent\Builder<static>|User wherePassword($value)
  39. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereType($value)
  40. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereUpdatedAt($value)
  41. * @mixin \Eloquent
  42. */
  43. class User extends Authenticatable
  44. {
  45. use HasFactory, Notifiable, HasApiTokens, HasPermissions;
  46. protected $guarded = ["id"];
  47. /**
  48. * The attributes that should be hidden for serialization.
  49. *
  50. * @var array<int, string>
  51. */
  52. protected $hidden = ["password", "remember_token"];
  53. /**
  54. * Get the attributes that should be cast.
  55. *
  56. * @return array<string, string>
  57. */
  58. protected function casts(): array
  59. {
  60. return [
  61. "email_verified_at" => "datetime",
  62. "password" => "hashed",
  63. "type" => UserTypeEnum::class,
  64. "language" => LanguageEnum::class,
  65. ];
  66. }
  67. public function isAdministrador(): bool
  68. {
  69. return $this->type === UserTypeEnum::ADMINISTRADOR;
  70. }
  71. public function isAssociado(): bool
  72. {
  73. return $this->type === UserTypeEnum::ASSOCIADO;
  74. }
  75. public function isParceiro(): bool
  76. {
  77. return $this->type === UserTypeEnum::PARCEIRO;
  78. }
  79. /**
  80. * Create a new access token for the user.
  81. */
  82. public function createAccessToken(string $deviceId): string
  83. {
  84. return $this->createToken(
  85. name: "access_token_{$deviceId}",
  86. abilities: ["access"],
  87. expiresAt: Carbon::now()->addMinutes(15),
  88. )->plainTextToken;
  89. }
  90. /**
  91. * Create a new refresh token for the user.
  92. */
  93. public function createRefreshToken(string $deviceId): string
  94. {
  95. return $this->createToken(
  96. name: "refresh_token_{$deviceId}",
  97. abilities: ["refresh"],
  98. expiresAt: Carbon::now()->addDays(30),
  99. )->plainTextToken;
  100. }
  101. /**
  102. * Delete all tokens (access and refresh) for a specific device.
  103. */
  104. public function deleteTokensByDevice(string $deviceId): void
  105. {
  106. $this->tokens()
  107. ->where("name", "like", "%_{$deviceId}")
  108. ->delete();
  109. }
  110. /**
  111. * @return BelongsToMany
  112. */
  113. public function permissions(): BelongsToMany
  114. {
  115. return $this->belongsToMany(
  116. Permission::class,
  117. "user_type_permissions",
  118. "user_type",
  119. "permission_id",
  120. );
  121. }
  122. }