first commit
This commit is contained in:
		
							
								
								
									
										44
									
								
								common/result/jobResult.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								common/result/jobResult.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| package result | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"aedata-server/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 | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user