ProcessActiveSkillsJob.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <?php
  2. namespace App\Module\Pet\Jobs;
  3. use App\Module\Pet\Models\PetActiveSkill;
  4. use App\Module\Pet\Logic\PetAutoSkillLogic;
  5. use Illuminate\Bus\Queueable;
  6. use Illuminate\Contracts\Queue\ShouldQueue;
  7. use Illuminate\Foundation\Bus\Dispatchable;
  8. use Illuminate\Queue\InteractsWithQueue;
  9. use Illuminate\Queue\SerializesModels;
  10. use Illuminate\Support\Facades\Log;
  11. use UCore\Queue\QueueJob;
  12. /**
  13. * 处理宠物激活技能的定时任务
  14. *
  15. * 每分钟执行一次,检查所有激活中的宠物技能并执行相应操作
  16. */
  17. class ProcessActiveSkillsJob extends QueueJob
  18. {
  19. /**
  20. * 任务超时时间(秒)
  21. *
  22. * @var int
  23. */
  24. public $timeout = 300; // 5分钟
  25. /**
  26. * 最大重试次数
  27. *
  28. * @var int
  29. */
  30. public $tries = 3;
  31. /**
  32. * 处理技能效果
  33. *
  34. * @param PetActiveSkill $activeSkill 激活的技能
  35. * @return void
  36. */
  37. protected function processSkillEffect(PetActiveSkill $activeSkill): void
  38. {
  39. $autoSkillLogic = new PetAutoSkillLogic();
  40. switch ($activeSkill->skill_name) {
  41. case \App\Module\Pet\Enums\PET_SKILL_NAME::AUTO_HARVESTING->value:
  42. $autoSkillLogic->processAutoHarvest($activeSkill);
  43. break;
  44. case \App\Module\Pet\Enums\PET_SKILL_NAME::AUTO_PLANTING->value:
  45. $autoSkillLogic->processAutoPlant($activeSkill);
  46. break;
  47. case \App\Module\Pet\Enums\PET_SKILL_NAME::AUTO_WEEDING->value:
  48. $autoSkillLogic->processAutoWeeding($activeSkill);
  49. break;
  50. case \App\Module\Pet\Enums\PET_SKILL_NAME::AUTO_WATERING->value:
  51. $autoSkillLogic->processAutoWatering($activeSkill);
  52. break;
  53. case \App\Module\Pet\Enums\PET_SKILL_NAME::AUTO_PEST_CONTROL->value:
  54. $autoSkillLogic->processAutoPestControl($activeSkill);
  55. break;
  56. default:
  57. Log::warning('未知的技能类型', [
  58. 'active_skill_id' => $activeSkill->id,
  59. 'skill_name' => $activeSkill->skill_name
  60. ]);
  61. break;
  62. }
  63. // 更新最后检查时间
  64. $activeSkill->updateLastCheckTime();
  65. }
  66. public function run(): bool
  67. {
  68. Log::info('开始处理宠物激活技能定时任务');
  69. try {
  70. // 获取所有生效中的技能
  71. $activeSkills = PetActiveSkill::active()->get();
  72. Log::info('找到激活技能数量', [ 'count' => $activeSkills->count() ]);
  73. $processedCount = 0;
  74. $expiredCount = 0;
  75. /**
  76. * @var PetActiveSkill $activeSkill
  77. */
  78. foreach ($activeSkills as $activeSkill) {
  79. try {
  80. // 检查技能是否已过期
  81. if ($activeSkill->isExpired()) {
  82. $activeSkill->markAsExpired();
  83. $expiredCount++;
  84. Log::info('技能已过期', [
  85. 'active_skill_id' => $activeSkill->id,
  86. 'pet_id' => $activeSkill->pet_id,
  87. 'skill_name' => $activeSkill->skill_name
  88. ]);
  89. continue;
  90. }
  91. // 检查是否需要执行检查
  92. if (!$activeSkill->shouldCheck()) {
  93. Log::debug('shouldCheck false', [
  94. 'active_skill_id' => $activeSkill->id,
  95. 'pet_id' => $activeSkill->pet_id,
  96. 'skill_name' => $activeSkill->skill_name
  97. ]);
  98. continue;
  99. }
  100. Log::debug('shouldCheck false', [
  101. 'active_skill_id' => $activeSkill->id,
  102. 'pet_id' => $activeSkill->pet_id,
  103. 'skill_name' => $activeSkill->skill_name
  104. ]);
  105. // 处理技能效果
  106. $this->processSkillEffect($activeSkill);
  107. $processedCount++;
  108. } catch (\Exception $e) {
  109. Log::error('处理单个激活技能失败', [
  110. 'active_skill_id' => $activeSkill->id,
  111. 'pet_id' => $activeSkill->pet_id,
  112. 'skill_name' => $activeSkill->skill_name,
  113. 'error' => $e->getMessage(),
  114. 'trace' => $e->getTraceAsString()
  115. ]);
  116. }
  117. }
  118. Log::info('宠物激活技能定时任务完成', [
  119. 'total_skills' => $activeSkills->count(),
  120. 'processed_count' => $processedCount,
  121. 'expired_count' => $expiredCount
  122. ]);
  123. } catch (\Exception $e) {
  124. Log::error('处理宠物激活技能定时任务失败', [
  125. 'error' => $e->getMessage(),
  126. 'trace' => $e->getTraceAsString()
  127. ]);
  128. throw $e;
  129. }
  130. return true;
  131. }
  132. public function payload()
  133. {
  134. return [];
  135. }
  136. }