Documentation ¶
Overview ¶
Package errcode is used for http and grpc error codes, include system-level error codes and business-level error codes
Index ¶
- Constants
- Variables
- func GetErrorCode(err error) int
- func GetStatusCode(err error) codes.Code
- func HCode(num int) int
- func ListGRPCErrCodes(w http.ResponseWriter, _ *http.Request)
- func RCode(num int) codes.Code
- func ShowConfig(jsonData []byte) func(w http.ResponseWriter, r *http.Request)
- type Detail
- type ErrInfo
- type Error
- func (e *Error) Code() int
- func (e *Error) Details() []string
- func (e *Error) Err(msg ...string) error
- func (e *Error) ErrToHTTP(msg ...string) error
- func (e *Error) Msg() string
- func (e *Error) NeedHTTPCode() bool
- func (e *Error) RewriteMsg(msg string) *Error
- func (e *Error) ToHTTPCode() int
- func (e *Error) WithDetails(details ...string) *Error
- func (e *Error) WithOutMsg(msg string) *Error
- func (e *Error) WithOutMsgI18n(langMsg map[int]map[string]string, lang string) *Error
- type RPCStatus
- type Responser
Constants ¶
const ToHTTPCodeLabel = "[standard http code]"
ToHTTPCodeLabel need to convert to standard http code label
Variables ¶
var ( Success = NewError(0, "ok") InvalidParams = NewError(100001, "Invalid Parameter") InternalServerError = NewError(100003, "Internal Server Error") NotFound = NewError(100004, "Not Found") Timeout = NewError(100006, "Request Timeout") TooManyRequests = NewError(100007, "Too Many Requests") Forbidden = NewError(100008, "Forbidden") LimitExceed = NewError(100009, "Limit Exceed") DeadlineExceeded = NewError(100010, "Deadline Exceeded") AccessDenied = NewError(100011, "Access Denied") MethodNotAllowed = NewError(100012, "Method Not Allowed") Canceled = NewError(100014, "Canceled") Unknown = NewError(100015, "Unknown") PermissionDenied = NewError(100016, "Permission Denied") ResourceExhausted = NewError(100017, "Resource Exhausted") FailedPrecondition = NewError(100018, "Failed Precondition") Aborted = NewError(100019, "Aborted") OutOfRange = NewError(100020, "Out Of Range") Unimplemented = NewError(100021, "Unimplemented") DataLoss = NewError(100022, "Data Loss") StatusBadGateway = NewError(100023, "Bad Gateway") // Deprecated: use Conflict instead AlreadyExists = NewError(100005, "Already Exists") Conflict = NewError(100409, "Conflict") TooEarly = NewError(100425, "Too Early") )
http system level error code, error code range 10000~20000
var ( StatusSuccess = NewRPCStatus(0, "ok") StatusCanceled = NewRPCStatus(300001, "Canceled") StatusUnknown = NewRPCStatus(300002, "Unknown") StatusInvalidParams = NewRPCStatus(300003, "Invalid Parameter") StatusDeadlineExceeded = NewRPCStatus(300004, "Deadline Exceeded") StatusNotFound = NewRPCStatus(300005, "Not Found") StatusAlreadyExists = NewRPCStatus(300006, "Already Exists") StatusPermissionDenied = NewRPCStatus(300007, "Permission Denied") StatusResourceExhausted = NewRPCStatus(300008, "Resource Exhausted") StatusFailedPrecondition = NewRPCStatus(300009, "Failed Precondition") StatusAborted = NewRPCStatus(300010, "Aborted") StatusOutOfRange = NewRPCStatus(300011, "Out Of Range") StatusUnimplemented = NewRPCStatus(300012, "Unimplemented") StatusInternalServerError = NewRPCStatus(300013, "Internal Server Error") StatusDataLoss = NewRPCStatus(300015, "Data Loss") StatusTimeout = NewRPCStatus(300017, "Request Timeout") StatusTooManyRequests = NewRPCStatus(300018, "Too Many Requests") StatusForbidden = NewRPCStatus(300019, "Forbidden") StatusLimitExceed = NewRPCStatus(300020, "Limit Exceed") StatusMethodNotAllowed = NewRPCStatus(300021, "Method Not Allowed") StatusAccessDenied = NewRPCStatus(300022, "Access Denied") StatusConflict = NewRPCStatus(300023, "Conflict") )
rpc system level error code with status prefix, error code range 30000~40000
var SkipResponse = errors.New("skip response") //nolint
SkipResponse skip response
Functions ¶
func GetErrorCode ¶
GetErrorCode get Error code from error returned by http invoke
func GetStatusCode ¶
GetStatusCode get status code from error returned by RPC invoke
func HCode ¶
HCode Generate an error code between 200000 and 300000 according to the number
http service level error code, Err prefix, example.
var ( ErrUserCreate = NewError(HCode(1)+1, "failed to create user") // 200101 ErrUserDelete = NewError(HCode(1)+2, "failed to delete user") // 200102 ErrUserUpdate = NewError(HCode(1)+3, "failed to update user") // 200103 ErrUserGet = NewError(HCode(1)+4, "failed to get user details") // 200104 )
func ListGRPCErrCodes ¶
func ListGRPCErrCodes(w http.ResponseWriter, _ *http.Request)
ListGRPCErrCodes list grpc error codes, http handle func
func RCode ¶
RCode Generate an error code between 400000 and 500000 according to the number
rpc service level error code, status prefix, example.
var ( StatusUserCreate = NewRPCStatus(RCode(1)+1, "failed to create user") // 400101 StatusUserDelete = NewRPCStatus(RCode(1)+2, "failed to delete user") // 400102 StatusUserUpdate = NewRPCStatus(RCode(1)+3, "failed to update user") // 400103 StatusUserGet = NewRPCStatus(RCode(1)+4, "failed to get user details") // 400104 )
func ShowConfig ¶
func ShowConfig(jsonData []byte) func(w http.ResponseWriter, r *http.Request)
ShowConfig show config info @Summary show config info @Description show config info @Tags system @Accept json @Produce json @Router /config [get]
Types ¶
type Error ¶
type Error struct {
// contains filtered or unexported fields
}
Error error
func ParseError ¶
ParseError parsing out error codes from error messages
func (*Error) Err ¶
Err convert to standard error, if there is a parameter 'msg', it will replace the original message.
func (*Error) ErrToHTTP ¶
ErrToHTTP convert to standard error add ToHTTPCodeLabel to error message, use it if you need to convert to standard HTTP status code, if there is a parameter 'msg', it will replace the original message. Tips: you can call the GetErrorCode function to get the standard HTTP status code.
func (*Error) NeedHTTPCode ¶
NeedHTTPCode need to convert to standard http code
func (*Error) RewriteMsg ¶
RewriteMsg rewrite error message
func (*Error) WithDetails ¶
WithDetails add error details
func (*Error) WithOutMsg ¶
WithOutMsg out error message Deprecated: use RewriteMsg instead
func (*Error) WithOutMsgI18n ¶
WithOutMsgI18n out error message i18n langMsg example:
map[int]map[string]string{ 20010: { "en-US": "login failed", "zh-CN": "登录失败", }, }
lang BCP 47 code https://learn.microsoft.com/en-us/openspecs/office_standards/ms-oe376/6c085406-a698-4e12-9d4d-c3b0ee3dbc4a
type RPCStatus ¶
type RPCStatus struct {
// contains filtered or unexported fields
}
RPCStatus rpc status
func NewRPCStatus ¶
NewRPCStatus create a new rpc status
func (*RPCStatus) Err ¶
Err return error if there is a parameter 'desc', it will replace the original message
func (*RPCStatus) ErrToHTTP ¶
ErrToHTTP convert to standard error add ToHTTPCodeLabel to error message, usually used when HTTP calls the GRPC API, if there is a parameter 'desc', it will replace the original message.