User.php 5.8 KB

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