PetStatusValidator.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  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 PetStatusValidator 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 = (int)$value;
  25. $expectedStatus = $this->args[0] ?? PetStatus::NORMAL;
  26. try {
  27. // 获取宠物信息
  28. $pet = PetUser::find($petId);
  29. if (!$pet) {
  30. // 宠物不存在的验证应该由 PetExistsValidator 处理
  31. // 这里只关注状态验证
  32. return true;
  33. }
  34. // 检查宠物状态
  35. if ($pet->status !== $expectedStatus) {
  36. $statusName = $pet->status->name;
  37. $expectedStatusName = $expectedStatus->name;
  38. $this->addError("宠物当前状态({$statusName})不允许执行此操作,需要状态为({$expectedStatusName})");
  39. return false;
  40. }
  41. return true;
  42. } catch (\Exception $e) {
  43. $this->addError('验证过程发生错误: ' . $e->getMessage());
  44. return false;
  45. }
  46. }
  47. }