User.php 5.5 KB

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