User.php 6.3 KB

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