1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- package result
- import (
- "context"
- "GtDataStore/common/xerr"
- "github.com/pkg/errors"
- "github.com/zeromicro/go-zero/core/logx"
- "google.golang.org/grpc/status"
- )
- // job返回
- func JobResult(ctx context.Context, resp interface{}, err error) {
- if err == nil {
- // 成功返回 ,只有dev环境下才会打印info,线上不显示
- if resp != nil {
- logx.Infof("resp: %+v", resp)
- }
- return
- } else {
- errCode := xerr.SERVER_COMMON_ERROR
- errMsg := "服务器开小差啦,稍后再来试一试"
- // 错误返回
- causeErr := errors.Cause(err) // err类型
- if e, ok := causeErr.(*xerr.CodeError); ok { // 自定义错误类型
- // 自定义CodeError
- errCode = e.GetErrCode()
- errMsg = e.GetErrMsg()
- } else {
- if gstatus, ok := status.FromError(causeErr); ok { // grpc err错误
- grpcCode := uint32(gstatus.Code())
- if xerr.IsCodeErr(grpcCode) { // 区分自定义错误跟系统底层、db等错误,底层、db错误不能返回给前端
- errCode = grpcCode
- errMsg = gstatus.Message()
- }
- }
- }
- logx.WithContext(ctx).Errorf("【JOB-ERR】 : %+v ,errCode:%d , errMsg:%s ", err, errCode, errMsg)
- return
- }
- }
|