You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

53 lines
1.4 KiB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * This file is part of Hyperf.
  5. *
  6. * @link https://www.hyperf.io
  7. * @document https://doc.hyperf.io
  8. * @contact group@hyperf.io
  9. * @license https://github.com/hyperf/hyperf/blob/master/LICENSE
  10. */
  11. namespace App\Exception;
  12. use App\Commons\Log;
  13. use App\Constants\v3\ErrorCode;
  14. use App\Constants\v3\LogLabel;
  15. use Hyperf\HttpServer\Contract\RequestInterface;
  16. use Hyperf\Server\Exception\ServerException;
  17. use Throwable;
  18. use Hyperf\Di\Annotation\Inject;
  19. class ErrorCodeException extends ServerException
  20. {
  21. /**
  22. * @Inject
  23. * @var Log
  24. */
  25. protected $log;
  26. /**
  27. * @Inject
  28. * @var RequestInterface
  29. */
  30. protected $request;
  31. public function __construct(int $code = 0, string $message = null, $logData=[], Throwable $previous = null)
  32. {
  33. if (is_null($message)) {
  34. $message = ErrorCode::getMessage($code);
  35. } else {
  36. $message = ErrorCode::getMessage($code) . ' ' . $message;
  37. }
  38. if (!empty($logData)) {
  39. $this->log->event(LogLabel::ERROR_CODE_EXCEPTION_LOG_DATA, ['message' => $message, 'logData' => json_encode($logData), 'request' => json_encode($this->request->all())]);
  40. } else {
  41. $this->log->event(LogLabel::ERROR_CODE_EXCEPTION, ['message' => $message]);
  42. }
  43. parent::__construct($message, $code, $previous);
  44. }
  45. }