PetRemouldValidator.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace App\Module\Pet\Validators;
  3. use App\Module\Pet\Enums\PetStatus;
  4. use App\Module\Pet\Models\PetUser;
  5. use UCore\Validator;
  6. use UCore\Validator\ValidationMessage;
  7. /**
  8. * 宠物洗髓验证器
  9. *
  10. * 用于验证宠物洗髓条件的合法性
  11. */
  12. class PetRemouldValidator extends Validator
  13. {
  14. use ValidationMessage;
  15. /**
  16. * 验证方法
  17. *
  18. * @param mixed $value 宠物ID
  19. * @param array $data 所有数据
  20. * @return bool 验证是否通过
  21. */
  22. public function validate(mixed $value, array $data): bool
  23. {
  24. $petId = $value;
  25. $itemId = $data['itemId'] ?? 0;
  26. try {
  27. // 获取宠物信息
  28. $pet = PetUser::find($petId);
  29. if (!$pet) {
  30. $this->throwMessage([], '宠物不存在');
  31. return false;
  32. }
  33. // 检查宠物状态
  34. if ($pet->status !== PetStatus::NORMAL) {
  35. $this->throwMessage(['status' => $pet->status->value], '宠物当前状态({status})不允许洗髓');
  36. return false;
  37. }
  38. // 如果使用道具
  39. if ($itemId > 0) {
  40. // 验证物品是否为洗髓道具
  41. $remouldItemId = config('pet.remould_cost.item_id');
  42. if ($itemId != $remouldItemId) {
  43. $this->throwMessage(['itemId' => $itemId], '物品({itemId})不是洗髓道具');
  44. return false;
  45. }
  46. }
  47. return true;
  48. } catch (\Exception $e) {
  49. $this->throwMessage(['error' => $e->getMessage()], '验证过程发生错误: {error}');
  50. return false;
  51. }
  52. }
  53. }