94 lines
2.9 KiB
Go
94 lines
2.9 KiB
Go
|
|
package haiyuapi
|
|||
|
|
|
|||
|
|
import (
|
|||
|
|
"errors"
|
|||
|
|
"fmt"
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// 海宇API平台返回码
|
|||
|
|
const (
|
|||
|
|
CodeSuccess = 0 // 业务成功
|
|||
|
|
CodeQueryEmpty = 1000 // 查询为空
|
|||
|
|
CodeSystem = 1001 // 接口异常
|
|||
|
|
CodeDecryptFail = 1002 // 参数解密失败
|
|||
|
|
CodeRequestParam = 1003 // 基础参数校验不正确
|
|||
|
|
CodeInvalidIP = 1004 // 未经授权的IP
|
|||
|
|
CodeMissingAccessID = 1005 // 缺少Access-Id
|
|||
|
|
CodeInvalidAccessID = 1006 // 未经授权的AccessId
|
|||
|
|
CodeInsufficientBalance = 1007 // 账户余额不足,无法请求
|
|||
|
|
CodeProductNotSubscribed = 1008 // 未开通此产品
|
|||
|
|
CodeBusiness = 2001 // 业务失败
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
var (
|
|||
|
|
ErrDatasource = errors.New("数据源异常")
|
|||
|
|
ErrSystem = errors.New("系统异常")
|
|||
|
|
ErrNotFound = errors.New("查询为空")
|
|||
|
|
)
|
|||
|
|
|
|||
|
|
// haiyuapiAPIError 海宇API平台错误
|
|||
|
|
type haiyuapiAPIError struct {
|
|||
|
|
Code int
|
|||
|
|
Message string
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
func (e *haiyuapiAPIError) Error() string {
|
|||
|
|
return fmt.Sprintf("海宇API返回错误,code: %d,message: %s", e.Code, e.Message)
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// NewHaiyuapiAPIError 创建平台错误
|
|||
|
|
func NewHaiyuapiAPIError(code int, message string) *haiyuapiAPIError {
|
|||
|
|
if message == "" {
|
|||
|
|
if desc := GetPlatformCodeDesc(code); desc != "" {
|
|||
|
|
message = desc
|
|||
|
|
} else {
|
|||
|
|
message = "海宇API返回未知错误"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return &haiyuapiAPIError{Code: code, Message: message}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// platformCodeDesc 平台 code -> 官方 message
|
|||
|
|
var platformCodeDesc = map[int]string{
|
|||
|
|
CodeSuccess: "业务成功",
|
|||
|
|
CodeQueryEmpty: "查询为空",
|
|||
|
|
CodeSystem: "接口异常",
|
|||
|
|
CodeDecryptFail: "参数解密失败",
|
|||
|
|
CodeRequestParam: "基础参数校验不正确",
|
|||
|
|
CodeInvalidIP: "未经授权的IP",
|
|||
|
|
CodeMissingAccessID: "缺少Access-Id",
|
|||
|
|
CodeInvalidAccessID: "未经授权的AccessId",
|
|||
|
|
CodeInsufficientBalance: "账户余额不足,无法请求",
|
|||
|
|
CodeProductNotSubscribed: "未开通此产品",
|
|||
|
|
CodeBusiness: "业务失败",
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// GetPlatformCodeDesc 根据平台 code 获取描述
|
|||
|
|
func GetPlatformCodeDesc(code int) string {
|
|||
|
|
if desc, ok := platformCodeDesc[code]; ok {
|
|||
|
|
return desc
|
|||
|
|
}
|
|||
|
|
return ""
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// GetErrByCode 将海宇API code 映射为内部哨兵错误,供处理器 errors.Is 判断
|
|||
|
|
//
|
|||
|
|
// 1000 -> ErrNotFound(查询为空,可按产品约定当成功处理)
|
|||
|
|
// 1001, 1002, 1003 -> ErrSystem(接口/解密/参数校验异常)
|
|||
|
|
// 1004~1008, 2001 -> ErrDatasource(鉴权、余额、产品、业务类上游错误)
|
|||
|
|
func GetErrByCode(code int) error {
|
|||
|
|
switch code {
|
|||
|
|
case CodeSuccess:
|
|||
|
|
return nil
|
|||
|
|
case CodeQueryEmpty:
|
|||
|
|
return ErrNotFound
|
|||
|
|
case CodeSystem, CodeDecryptFail, CodeRequestParam:
|
|||
|
|
return ErrSystem
|
|||
|
|
case CodeInvalidIP, CodeMissingAccessID, CodeInvalidAccessID,
|
|||
|
|
CodeInsufficientBalance, CodeProductNotSubscribed, CodeBusiness:
|
|||
|
|
return ErrDatasource
|
|||
|
|
default:
|
|||
|
|
return ErrDatasource
|
|||
|
|
}
|
|||
|
|
}
|