| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267 |
- <?php
- namespace App\Module\Pet\Models;
- use UCore\ModelCore;
- use Illuminate\Database\Eloquent\Relations\BelongsTo;
- /**
- * 宠物技能处理日志模型
- *
- * 记录宠物技能每次被计划任务处理的详细信息
- *
- * @property int $id 主键ID
- * @property int $active_skill_id 激活技能ID
- * @property int $pet_id 宠物ID
- * @property int $user_id 用户ID
- * @property string $skill_name 技能名称
- * @property string $process_status 处理状态:success-成功,failed-失败,skipped-跳过
- * @property string $process_reason 处理原因/结果描述
- * @property array $process_data 处理数据详情
- * @property float $execution_time 执行耗时(秒)
- * @property \Carbon\Carbon $processed_at 处理时间
- * @property \Carbon\Carbon $created_at 创建时间
- * @property \Carbon\Carbon $updated_at 更新时间
- */
- class PetSkillProcessLog extends ModelCore
- {
- /**
- * 数据表名
- *
- * @var string
- */
- protected $table = 'pet_skill_process_logs';
- /**
- * 可批量赋值的属性
- *
- * @var array<int, string>
- */
- protected $fillable = [
- 'active_skill_id',
- 'pet_id',
- 'user_id',
- 'skill_name',
- 'process_status',
- 'process_reason',
- 'process_data',
- 'execution_time',
- 'processed_at',
- ];
- /**
- * 属性类型转换
- *
- * @var array<string, string>
- */
- protected $casts = [
- 'process_data' => 'array',
- 'execution_time' => 'float',
- 'processed_at' => 'datetime',
- 'created_at' => 'datetime',
- 'updated_at' => 'datetime',
- ];
- /**
- * 处理状态常量
- */
- const STATUS_SUCCESS = 'success'; // 成功
- const STATUS_FAILED = 'failed'; // 失败
- const STATUS_SKIPPED = 'skipped'; // 跳过
- const STATUS_EXPIRED = 'expired'; // 过期
- /**
- * 关联激活技能
- *
- * @return BelongsTo
- */
- public function activeSkill(): BelongsTo
- {
- return $this->belongsTo(PetActiveSkill::class, 'active_skill_id');
- }
- /**
- * 关联宠物
- *
- * @return BelongsTo
- */
- public function pet(): BelongsTo
- {
- return $this->belongsTo(PetUser::class, 'pet_id');
- }
- /**
- * 创建成功处理日志
- *
- * @param PetActiveSkill $activeSkill 激活技能
- * @param array $processData 处理数据
- * @param float $executionTime 执行时间
- * @param string $reason 处理原因
- * @return static
- */
- public static function createSuccessLog(
- PetActiveSkill $activeSkill,
- array $processData = [],
- float $executionTime = 0.0,
- string $reason = '技能处理成功'
- ): static {
- return static::create([
- 'active_skill_id' => $activeSkill->id,
- 'pet_id' => $activeSkill->pet_id,
- 'user_id' => $activeSkill->pet->user_id,
- 'skill_name' => $activeSkill->skill_name,
- 'process_status' => static::STATUS_SUCCESS,
- 'process_reason' => $reason,
- 'process_data' => $processData,
- 'execution_time' => $executionTime,
- 'processed_at' => now(),
- ]);
- }
- /**
- * 创建失败处理日志
- *
- * @param PetActiveSkill $activeSkill 激活技能
- * @param string $reason 失败原因
- * @param array $processData 处理数据
- * @param float $executionTime 执行时间
- * @return static
- */
- public static function createFailedLog(
- PetActiveSkill $activeSkill,
- string $reason,
- array $processData = [],
- float $executionTime = 0.0
- ): static {
- return static::create([
- 'active_skill_id' => $activeSkill->id,
- 'pet_id' => $activeSkill->pet_id,
- 'user_id' => $activeSkill->pet->user_id,
- 'skill_name' => $activeSkill->skill_name,
- 'process_status' => static::STATUS_FAILED,
- 'process_reason' => $reason,
- 'process_data' => $processData,
- 'execution_time' => $executionTime,
- 'processed_at' => now(),
- ]);
- }
- /**
- * 创建跳过处理日志
- *
- * @param PetActiveSkill $activeSkill 激活技能
- * @param string $reason 跳过原因
- * @param array $processData 处理数据
- * @return static
- */
- public static function createSkippedLog(
- PetActiveSkill $activeSkill,
- string $reason,
- array $processData = []
- ): static {
- return static::create([
- 'active_skill_id' => $activeSkill->id,
- 'pet_id' => $activeSkill->pet_id,
- 'user_id' => $activeSkill->pet->user_id,
- 'skill_name' => $activeSkill->skill_name,
- 'process_status' => static::STATUS_SKIPPED,
- 'process_reason' => $reason,
- 'process_data' => $processData,
- 'execution_time' => 0.0,
- 'processed_at' => now(),
- ]);
- }
- /**
- * 创建过期处理日志
- *
- * @param PetActiveSkill $activeSkill 激活技能
- * @param string $reason 过期原因
- * @return static
- */
- public static function createExpiredLog(
- PetActiveSkill $activeSkill,
- string $reason = '技能已过期'
- ): static {
- return static::create([
- 'active_skill_id' => $activeSkill->id,
- 'pet_id' => $activeSkill->pet_id,
- 'user_id' => $activeSkill->pet->user_id,
- 'skill_name' => $activeSkill->skill_name,
- 'process_status' => static::STATUS_EXPIRED,
- 'process_reason' => $reason,
- 'process_data' => [],
- 'execution_time' => 0.0,
- 'processed_at' => now(),
- ]);
- }
- /**
- * 查询成功的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeSuccess($query)
- {
- return $query->where('process_status', static::STATUS_SUCCESS);
- }
- /**
- * 查询失败的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeFailed($query)
- {
- return $query->where('process_status', static::STATUS_FAILED);
- }
- /**
- * 查询跳过的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeSkipped($query)
- {
- return $query->where('process_status', static::STATUS_SKIPPED);
- }
- /**
- * 查询特定技能的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @param string $skillName 技能名称
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeBySkillName($query, string $skillName)
- {
- return $query->where('skill_name', $skillName);
- }
- /**
- * 查询特定宠物的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @param int $petId 宠物ID
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeByPet($query, int $petId)
- {
- return $query->where('pet_id', $petId);
- }
- /**
- * 查询特定用户的处理日志
- *
- * @param \Illuminate\Database\Eloquent\Builder $query
- * @param int $userId 用户ID
- * @return \Illuminate\Database\Eloquent\Builder
- */
- public function scopeByUser($query, int $userId)
- {
- return $query->where('user_id', $userId);
- }
- }
|