User.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  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 App\Models\Unit;
  12. use Carbon\Carbon;
  13. /**
  14. * @property int $id
  15. * @property string $name
  16. * @property string $email
  17. * @property string $password
  18. * @property string $status
  19. * @property UserTypeEnum $user_type
  20. * @property \Illuminate\Support\Carbon|null $created_at
  21. * @property \Illuminate\Support\Carbon|null $updated_at
  22. * @property string|null $deleted_at
  23. * @property \Illuminate\Support\Carbon|null $last_login_at
  24. * @property string|null $cpf
  25. * @property string|null $avatar_url
  26. * @property int|null $state_id
  27. * @property LanguageEnum $language
  28. * @property-read \Illuminate\Notifications\DatabaseNotificationCollection<int, \Illuminate\Notifications\DatabaseNotification> $notifications
  29. * @property-read int|null $notifications_count
  30. * @property-read \Kalnoy\Nestedset\Collection<int, \App\Models\Permission> $permissions
  31. * @property-read int|null $permissions_count
  32. * @property-read \App\Models\State|null $state
  33. * @property-read \Illuminate\Database\Eloquent\Collection<int, \Laravel\Sanctum\PersonalAccessToken> $tokens
  34. * @property-read int|null $tokens_count
  35. * @property-read \Illuminate\Database\Eloquent\Collection<int, Unit> $units
  36. * @property-read int|null $units_count
  37. * @method static \Database\Factories\UserFactory factory($count = null, $state = [])
  38. * @method static \Illuminate\Database\Eloquent\Builder<static>|User newModelQuery()
  39. * @method static \Illuminate\Database\Eloquent\Builder<static>|User newQuery()
  40. * @method static \Illuminate\Database\Eloquent\Builder<static>|User query()
  41. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereAvatarUrl($value)
  42. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereCpf($value)
  43. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereCreatedAt($value)
  44. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereDeletedAt($value)
  45. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereEmail($value)
  46. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereId($value)
  47. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereLastLoginAt($value)
  48. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereName($value)
  49. * @method static \Illuminate\Database\Eloquent\Builder<static>|User wherePassword($value)
  50. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereStateId($value)
  51. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereStatus($value)
  52. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereUpdatedAt($value)
  53. * @method static \Illuminate\Database\Eloquent\Builder<static>|User whereUserType($value)
  54. * @mixin \Eloquent
  55. */
  56. class User extends Authenticatable
  57. {
  58. use HasFactory, Notifiable, HasApiTokens, HasPermissions;
  59. protected $guarded = ["id"];
  60. /**
  61. * The attributes that should be hidden for serialization.
  62. *
  63. * @var array<int, string>
  64. */
  65. protected $hidden = ["password", "remember_token"];
  66. /**
  67. * Get the attributes that should be cast.
  68. *
  69. * @return array<string, string>
  70. */
  71. protected function casts(): array
  72. {
  73. return [
  74. "email_verified_at" => "datetime",
  75. "last_login_at" => "datetime",
  76. "password" => "hashed",
  77. "language" => LanguageEnum::class,
  78. ];
  79. }
  80. public function isAdmin(): bool
  81. {
  82. return $this->user_type === 'ADMIN';
  83. }
  84. public function userType(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  85. {
  86. return $this->belongsTo(\App\Models\UserType::class, 'user_type', 'slug');
  87. }
  88. public function state(): \Illuminate\Database\Eloquent\Relations\BelongsTo
  89. {
  90. return $this->belongsTo(\App\Models\State::class, 'state_id');
  91. }
  92. public function units(): BelongsToMany
  93. {
  94. return $this->belongsToMany(Unit::class, 'unit_users', 'user_id', 'unit_id')
  95. ->withTimestamps();
  96. }
  97. /**
  98. * Create a new access token for the user.
  99. */
  100. public function createAccessToken(string $deviceId): string
  101. {
  102. return $this->createToken(
  103. name: "access_token_{$deviceId}",
  104. abilities: ["access"],
  105. expiresAt: Carbon::now()->addMinutes(15),
  106. )->plainTextToken;
  107. }
  108. /**
  109. * Create a new refresh token for the user.
  110. */
  111. public function createRefreshToken(string $deviceId): string
  112. {
  113. return $this->createToken(
  114. name: "refresh_token_{$deviceId}",
  115. abilities: ["refresh"],
  116. expiresAt: Carbon::now()->addDays(30),
  117. )->plainTextToken;
  118. }
  119. /**
  120. * Delete all tokens (access and refresh) for a specific device.
  121. */
  122. public function deleteTokensByDevice(string $deviceId): void
  123. {
  124. $this->tokens()
  125. ->where("name", "like", "%_{$deviceId}")
  126. ->delete();
  127. }
  128. /**
  129. * @return BelongsToMany
  130. */
  131. public function permissions(): BelongsToMany
  132. {
  133. return $this->belongsToMany(
  134. Permission::class,
  135. "user_type_permissions",
  136. "user_type",
  137. "permission_id",
  138. );
  139. }
  140. }