SysErrorStrategy.php 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <?php
  2. namespace App\Enums;
  3. /**
  4. * 错误策略枚举类
  5. */
  6. enum SysErrorStrategy: int
  7. {
  8. /**
  9. * 错误策略:继续执行
  10. */
  11. case CONTINUE = 1;
  12. /**
  13. * 错误策略:重试执行
  14. */
  15. case RETRY = 2;
  16. /**
  17. * 错误策略:跳过执行
  18. */
  19. case SKIP = 3;
  20. /**
  21. * 错误策略:停止执行
  22. */
  23. case STOP = 4;
  24. /**
  25. * 获取策略的显示文本
  26. *
  27. * @return string 策略的中文描述
  28. */
  29. public function label(): string
  30. {
  31. return match ($this) {
  32. self::CONTINUE => '继续执行',
  33. self::RETRY => '重试执行',
  34. self::SKIP => '跳过执行',
  35. self::STOP => '停止执行',
  36. };
  37. }
  38. /**
  39. * 获取策略的整数值
  40. *
  41. * @return int 策略值
  42. */
  43. public function value(): int
  44. {
  45. return $this->value;
  46. }
  47. /**
  48. * 检查当前策略是否与指定策略相同
  49. *
  50. * @param self $strategy 要比较的策略
  51. * @return bool 如果策略相同返回 true,否则返回 false
  52. */
  53. public function is(self $strategy): bool
  54. {
  55. return $this === $strategy;
  56. }
  57. /**
  58. * 根据整数值创建对应的策略枚举实例
  59. *
  60. * @param int $value 策略值
  61. * @return self|null 返回对应的策略枚举实例,如果值无效则返回 null
  62. */
  63. public static function fromValue(int $value): ?self
  64. {
  65. return match ($value) {
  66. self::CONTINUE->value => self::CONTINUE,
  67. self::RETRY->value => self::RETRY,
  68. self::SKIP->value => self::SKIP,
  69. self::STOP->value => self::STOP,
  70. default => null
  71. };
  72. }
  73. /**
  74. * 获取所有策略的值数组
  75. *
  76. * @return array 包含所有策略值的数组
  77. */
  78. public static function values(): array
  79. {
  80. return array_column(self::cases(), 'value');
  81. }
  82. /**
  83. * 获取所有策略的键值对数组
  84. *
  85. * @return array 策略值作为键,显示文本作为值的关联数组
  86. */
  87. public static function all(): array
  88. {
  89. return [
  90. self::CONTINUE->value => self::CONTINUE->label(),
  91. self::RETRY->value => self::RETRY->label(),
  92. self::SKIP->value => self::SKIP->label(),
  93. self::STOP->value => self::STOP->label(),
  94. ];
  95. }
  96. }