Lae/app/Models/User.php

166 lines
4.4 KiB
PHP

<?php
namespace App\Models;
// use Illuminate\Contracts\Auth\MustVerifyEmail;
use Carbon\Exceptions\InvalidFormatException;
use GeneaLabs\LaravelModelCaching\Traits\Cachable;
use Illuminate\Contracts\Encryption\DecryptException;
use Illuminate\Database\Eloquent\Casts\Attribute;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Illuminate\Support\Facades\Crypt;
use Laravel\Sanctum\HasApiTokens;
class User extends Authenticatable
{
use HasApiTokens, HasFactory, Notifiable, Cachable;
/**
* The attributes that are mass assignable.
*
* @var array<int, string>
*/
protected $fillable = [
'uuid',
'name',
'email',
'password',
];
/**
* The attributes that should be hidden for serialization.
*
* @var array<int, string>
*/
protected $hidden = [
'password',
'remember_token',
'id_card',
];
protected $casts = [
'email_verified_at' => 'datetime',
'real_name_verified_at' => 'datetime',
'balance' => 'decimal:2',
'banned_at' => 'datetime',
'birthday_at' => 'date:Y-m-d'
];
protected $dates = [
'email_verified_at',
'real_name_verified_at',
'banned_at',
'birthday_at',
];
// id card 必须加密
protected static function boot()
{
parent::boot();
static::creating(function (self $user) {
$user->email_md5 = md5($user->email);
});
static::updating(function (self $user) {
if ($user->isDirty('banned_at')) {
if ($user->banned_at) {
$user->tokens()->delete();
$user->hosts()->update(['status' => 'suspended', 'suspended_at' => now()]);
} else {
$user->hosts()->update(['status' => 'stopped']);
}
}
if ($user->isDirty('email')) {
$user->email_md5 = md5($user->email);
}
if ($user->isDirty('id_card')) {
$user->id_card = Crypt::encryptString($user->id_card);
}
if ($user->isDirty('id_card') || $user->isDirty('real_name')) if (empty($user->id_card) || empty($user->real_name)) {
$user->real_name_verified_at = null;
} else {
$user->real_name_verified_at = now();
// 更新生日
try {
$user->birthday_at = $user->getBirthdayFromIdCard();
} catch (InvalidFormatException) {
$user->birthday_at = null;
}
}
});
}
public function hosts(): HasMany
{
return $this->hasMany(Host::class);
}
private function getBirthdayFromIdCard(): string
{
$idCard = $this->id_card;
$year = substr($idCard, 6, 4);
$month = substr($idCard, 10, 2);
$day = substr($idCard, 12, 2);
return $year . '-' . $month . '-' . $day;
}
/**
* 获取用户的身份证号
*
* @return Attribute
*/
protected function idCard(): Attribute
{
return Attribute::make(
function ($value) {
try {
return Crypt::decryptString($value);
} catch (DecryptException) {
return $value;
}
}
);
}
public function isAdult(): bool
{
// 如果 birthday_at 为空,那么就返回 false
return $this->birthday_at?->diffInYears(now()) >= 18;
}
public function isRealNamed(): bool
{
return $this->real_name_verified_at !== null;
}
public function user_group(): BelongsTo
{
return $this->belongsTo(UserGroup::class);
}
public function scopeBirthday()
{
/** @noinspection PhpUndefinedMethodInspection */
return $this->select(['id', 'name', 'birthday_at', 'email_md5', 'created_at'])->whereMonth('birthday_at', now()->month)
->whereDay('birthday_at', now()->day)->whereNull('banned_at');
}
public function selectPublic(): User
{
// 过滤掉私有字段
return $this->select(['id', 'name', 'email_md5', 'created_at']);
}
}