jobResult.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. package result
  2. import (
  3. "context"
  4. "GtDataStore/common/xerr"
  5. "github.com/pkg/errors"
  6. "github.com/zeromicro/go-zero/core/logx"
  7. "google.golang.org/grpc/status"
  8. )
  9. // job返回
  10. func JobResult(ctx context.Context, resp interface{}, err error) {
  11. if err == nil {
  12. // 成功返回 ,只有dev环境下才会打印info,线上不显示
  13. if resp != nil {
  14. logx.Infof("resp: %+v", resp)
  15. }
  16. return
  17. } else {
  18. errCode := xerr.SERVER_COMMON_ERROR
  19. errMsg := "服务器开小差啦,稍后再来试一试"
  20. // 错误返回
  21. causeErr := errors.Cause(err) // err类型
  22. if e, ok := causeErr.(*xerr.CodeError); ok { // 自定义错误类型
  23. // 自定义CodeError
  24. errCode = e.GetErrCode()
  25. errMsg = e.GetErrMsg()
  26. } else {
  27. if gstatus, ok := status.FromError(causeErr); ok { // grpc err错误
  28. grpcCode := uint32(gstatus.Code())
  29. if xerr.IsCodeErr(grpcCode) { // 区分自定义错误跟系统底层、db等错误,底层、db错误不能返回给前端
  30. errCode = grpcCode
  31. errMsg = gstatus.Message()
  32. }
  33. }
  34. }
  35. logx.WithContext(ctx).Errorf("【JOB-ERR】 : %+v ,errCode:%d , errMsg:%s ", err, errCode, errMsg)
  36. return
  37. }
  38. }