PetFeedValidator.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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 PetFeedValidator 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. $petFoodValidator = new PetFoodValidator($this->validation);
  40. if (!$petFoodValidator->validate($itemId, [])) {
  41. $this->throwMessage(['itemId' => $itemId], '物品({itemId})不是宠物口粮');
  42. return false;
  43. }
  44. return true;
  45. } catch (\Exception $e) {
  46. $this->throwMessage(['error' => $e->getMessage()], '验证过程发生错误: {error}');
  47. return false;
  48. }
  49. }
  50. }