- zhongwuapi
This commit is contained in:
@@ -84,6 +84,15 @@ func (a *API) signParams(params url.Values) string {
|
||||
return fmt.Sprintf("%X", md5.Sum([]byte(finalStr)))
|
||||
}
|
||||
|
||||
func (a *API) getShopID(body map[string]interface{}) (shopID string) {
|
||||
if body[KeyShopID] != nil {
|
||||
return body[KeyShopID].(string)
|
||||
} else if body[KeyBaiduShopID] != nil {
|
||||
return fmt.Sprint(body[KeyBaiduShopID])
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
func (a *API) AccessAPI(cmd string, body map[string]interface{}) (retVal *ResponseResult, err error) {
|
||||
baseapi.SugarLogger.Debugf("ebai AccessAPI cmd:%s", cmd)
|
||||
// a.speedLimiter.AccessAPI(allAPI)
|
||||
|
||||
143
platformapi/zhongwuapi/zhongwuapi.go
Normal file
143
platformapi/zhongwuapi/zhongwuapi.go
Normal file
@@ -0,0 +1,143 @@
|
||||
package zhongwuapi
|
||||
|
||||
import (
|
||||
"crypto/md5"
|
||||
"fmt"
|
||||
"net/http"
|
||||
"sort"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"git.rosy.net.cn/baseapi"
|
||||
"git.rosy.net.cn/baseapi/platformapi"
|
||||
"git.rosy.net.cn/baseapi/utils"
|
||||
)
|
||||
|
||||
const (
|
||||
prodURL = "http://api.zhongwuyun.com"
|
||||
|
||||
signKey = "sign"
|
||||
timestampKey = "timestamp"
|
||||
)
|
||||
|
||||
const (
|
||||
ResponseCodeSuccess = 0 // 操作成功
|
||||
)
|
||||
|
||||
const (
|
||||
PrinterStatusOffline = 0
|
||||
PrinterStatusOnline = 1
|
||||
PrinterStatusLackPaper = 2
|
||||
)
|
||||
|
||||
var (
|
||||
exceedLimitCodes = map[int]int{}
|
||||
canRetryCodes = map[int]int{}
|
||||
)
|
||||
|
||||
type API struct {
|
||||
appID int
|
||||
appSecret string
|
||||
client *http.Client
|
||||
config *platformapi.APIConfig
|
||||
}
|
||||
|
||||
func New(appID int, appSecret string, config ...*platformapi.APIConfig) *API {
|
||||
curConfig := platformapi.DefAPIConfig
|
||||
if len(config) > 0 {
|
||||
curConfig = *config[0]
|
||||
}
|
||||
return &API{
|
||||
appID: appID,
|
||||
appSecret: appSecret,
|
||||
client: &http.Client{Timeout: curConfig.ClientTimeout},
|
||||
config: &curConfig,
|
||||
}
|
||||
}
|
||||
|
||||
func (a *API) signParams(apiParams map[string]interface{}) string {
|
||||
keys := utils.MapKeys(apiParams)
|
||||
sort.Sort(sort.StringSlice(keys))
|
||||
valueList := make([]string, len(keys)+1)
|
||||
for index, key := range keys {
|
||||
valueList[index] = fmt.Sprintf("%s%v", key, apiParams[key])
|
||||
}
|
||||
valueList[len(keys)] = a.appSecret
|
||||
return fmt.Sprintf("%x", md5.Sum([]byte(strings.Join(valueList, ""))))
|
||||
}
|
||||
|
||||
func (a *API) AccessAPI(apiName string, apiParams map[string]interface{}, isGet bool) (retVal map[string]interface{}, err error) {
|
||||
params := utils.MergeMaps(map[string]interface{}{
|
||||
"appid": a.appID,
|
||||
}, apiParams)
|
||||
|
||||
err = platformapi.AccessPlatformAPIWithRetry(a.client,
|
||||
func() (request *http.Request) {
|
||||
params[timestampKey] = time.Now().Unix()
|
||||
params[signKey] = a.signParams(params)
|
||||
if isGet {
|
||||
fullURL := utils.GenerateGetURL(prodURL, apiName, params)
|
||||
// baseapi.SugarLogger.Debug(fullURL)
|
||||
request, _ = http.NewRequest(http.MethodGet, fullURL, nil)
|
||||
} else {
|
||||
request, _ = http.NewRequest(http.MethodPost, utils.GenerateGetURL(prodURL, apiName, nil), strings.NewReader(utils.Map2URLValues(params).Encode()))
|
||||
request.Header.Set("charset", "UTF-8")
|
||||
request.Header.Set("Content-Type", "application/x-www-form-urlencoded")
|
||||
}
|
||||
// request.Close = true //todo 为了性能考虑还是不要关闭
|
||||
return request
|
||||
},
|
||||
a.config,
|
||||
func(jsonResult1 map[string]interface{}) (errLevel string, err error) {
|
||||
code := int(utils.MustInterface2Int64(jsonResult1["errNum"]))
|
||||
if code == ResponseCodeSuccess {
|
||||
retVal, _ = jsonResult1["retData"].(map[string]interface{})
|
||||
return platformapi.ErrLevelSuccess, nil
|
||||
}
|
||||
newErr := utils.NewErrorIntCode(jsonResult1["errMsg"].(string), code)
|
||||
if _, ok := exceedLimitCodes[code]; ok {
|
||||
return platformapi.ErrLevelExceedLimit, newErr
|
||||
} else if _, ok := canRetryCodes[code]; ok {
|
||||
return platformapi.ErrLevelRecoverableErr, newErr
|
||||
} else {
|
||||
baseapi.SugarLogger.Debugf("zhongwu AccessAPI failed, jsonResult1:%s", utils.Format4Output(jsonResult1, true))
|
||||
return platformapi.ErrLevelCodeIsNotOK, newErr
|
||||
}
|
||||
})
|
||||
return retVal, err
|
||||
}
|
||||
|
||||
func (a *API) PrintMsg(deviceID, deviceSecret, printData string) (dataID string, status int, err error) {
|
||||
retData, err := a.AccessAPI("", map[string]interface{}{
|
||||
"deviceid": deviceID,
|
||||
"devicesecret": deviceSecret,
|
||||
"printdata": printData,
|
||||
}, false)
|
||||
if err == nil {
|
||||
return utils.Interface2String(retData["id"]), int(utils.Str2Int64(utils.Interface2String(retData["status"]))), nil
|
||||
}
|
||||
return "", 0, err
|
||||
}
|
||||
|
||||
func (a *API) GetPrinterStatus(deviceID, deviceSecret string) (status int, err error) {
|
||||
retData, err := a.AccessAPI("status", map[string]interface{}{
|
||||
"deviceid": deviceID,
|
||||
"devicesecret": deviceSecret,
|
||||
}, true)
|
||||
if err == nil {
|
||||
return int(utils.Str2Int64(utils.Interface2String(retData["status"]))), nil
|
||||
}
|
||||
return 0, err
|
||||
}
|
||||
|
||||
func (a *API) GetPrintStatus(deviceID, deviceSecret, dataID string) (isPrinted bool, err error) {
|
||||
retData, err := a.AccessAPI("printstatus", map[string]interface{}{
|
||||
"deviceid": deviceID,
|
||||
"devicesecret": deviceSecret,
|
||||
"dataid": dataID,
|
||||
}, true)
|
||||
if err == nil {
|
||||
return int(utils.Str2Int64(utils.Interface2String(retData["status"]))) == 1, nil
|
||||
}
|
||||
return false, err
|
||||
}
|
||||
35
platformapi/zhongwuapi/zhongwuapi_test.go
Normal file
35
platformapi/zhongwuapi/zhongwuapi_test.go
Normal file
@@ -0,0 +1,35 @@
|
||||
package zhongwuapi
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"git.rosy.net.cn/baseapi"
|
||||
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
var (
|
||||
api *API
|
||||
sugarLogger *zap.SugaredLogger
|
||||
)
|
||||
|
||||
func init() {
|
||||
logger, _ := zap.NewDevelopment()
|
||||
sugarLogger = logger.Sugar()
|
||||
baseapi.Init(sugarLogger)
|
||||
|
||||
api = New(8000192, "29435497822f52f3cf659c65da548a79")
|
||||
}
|
||||
|
||||
func handleError(t *testing.T, err error) {
|
||||
if err != nil {
|
||||
sugarLogger.Debug(err)
|
||||
t.Fatal(err.Error())
|
||||
}
|
||||
}
|
||||
|
||||
func TestPrintMsg(t *testing.T) {
|
||||
id, status, err := api.PrintMsg("deviceid", "devicesecret", "printdata")
|
||||
handleError(t, err)
|
||||
baseapi.SugarLogger.Debug(id, status)
|
||||
}
|
||||
@@ -393,6 +393,13 @@ func MapKV2List(mapData map[string]interface{}) []map[string]interface{} {
|
||||
return retVal
|
||||
}
|
||||
|
||||
func MapKeys(mapData map[string]interface{}) (keys []string) {
|
||||
for k := range mapData {
|
||||
keys = append(keys, k)
|
||||
}
|
||||
return keys
|
||||
}
|
||||
|
||||
func Format4Output(obj interface{}, isSingleLine bool) (retVal string) {
|
||||
retVal, ok := obj.(string)
|
||||
if !ok {
|
||||
|
||||
Reference in New Issue
Block a user