eclp增加仓库查询接口,增加银豹api
This commit is contained in:
114
platformapi/yinbaoapi/yinbaoapi.go
Normal file
114
platformapi/yinbaoapi/yinbaoapi.go
Normal file
@@ -0,0 +1,114 @@
|
||||
package yinbaoapi
|
||||
|
||||
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 (
|
||||
sigKey = "sign"
|
||||
url = "https://area27-win.pospal.cn:443/pospal-api2/openapi/v1"
|
||||
)
|
||||
|
||||
type API struct {
|
||||
appKey string
|
||||
appID string
|
||||
client *http.Client
|
||||
config *platformapi.APIConfig
|
||||
}
|
||||
|
||||
func New(appKey, appID string, config ...*platformapi.APIConfig) *API {
|
||||
curConfig := platformapi.DefAPIConfig
|
||||
if len(config) > 0 {
|
||||
curConfig = *config[0]
|
||||
}
|
||||
return &API{
|
||||
appKey: appKey,
|
||||
appID: appID,
|
||||
client: &http.Client{Timeout: curConfig.ClientTimeout},
|
||||
config: &curConfig,
|
||||
}
|
||||
}
|
||||
|
||||
func (a *API) signParam(params map[string]interface{}) (sig string) {
|
||||
var valueList []string
|
||||
for k, v := range params {
|
||||
if k != sigKey {
|
||||
if str := fmt.Sprint(v); str != "" {
|
||||
valueList = append(valueList, fmt.Sprintf("%s=%s", k, str))
|
||||
}
|
||||
}
|
||||
}
|
||||
sort.Sort(sort.StringSlice(valueList))
|
||||
valueList = append(valueList, fmt.Sprintf("key=%s", a.appKey))
|
||||
sig = strings.Join(valueList, "&")
|
||||
binSig := md5.Sum([]byte(sig))
|
||||
sig = fmt.Sprintf("%X", binSig)
|
||||
return sig
|
||||
}
|
||||
|
||||
func (a *API) AccessAPI(action string, bizParams map[string]interface{}) (retVal map[string]interface{}, err error) {
|
||||
params := make(map[string]interface{})
|
||||
params["appId"] = a.appID
|
||||
fullURL := utils.GenerateGetURL(url, action, nil)
|
||||
err = platformapi.AccessPlatformAPIWithRetry(a.client,
|
||||
func() *http.Request {
|
||||
request, _ := http.NewRequest(http.MethodPost, fullURL, strings.NewReader(utils.Map2URLValues(params).Encode()))
|
||||
signStr := a.signParam(params)
|
||||
request.Header.Set("User-Agent", "openApi")
|
||||
request.Header.Set("accept-encoding", "gzip,deflate")
|
||||
request.Header.Set("data-signature", signStr)
|
||||
request.Header.Set("time-stamp", utils.Int64ToStr(time.Now().Unix()))
|
||||
request.Header.Set("Content-Type", "application/json; charset=utf-8")
|
||||
return request
|
||||
},
|
||||
a.config,
|
||||
func(response *http.Response, bodyStr string, jsonResult1 map[string]interface{}) (errLevel string, err error) {
|
||||
if jsonResult1 == nil {
|
||||
return platformapi.ErrLevelRecoverableErr, fmt.Errorf("mapData is nil")
|
||||
}
|
||||
if err == nil {
|
||||
if jsonResult1["error_response"] != nil {
|
||||
errLevel = platformapi.ErrLevelGeneralFail
|
||||
err = utils.NewErrorCode(jsonResult1["error_response"].(map[string]interface{})["zh_desc"].(string), jsonResult1["error_response"].(map[string]interface{})["code"].(string))
|
||||
baseapi.SugarLogger.Debugf("jdeclp AccessAPI failed, jsonResult1:%s", utils.Format4Output(jsonResult1, true))
|
||||
}
|
||||
retVal = jsonResult1
|
||||
}
|
||||
return errLevel, err
|
||||
})
|
||||
return retVal, err
|
||||
}
|
||||
|
||||
type AddProductInfoParam struct{
|
||||
ProductInfo struct {
|
||||
CategoryUID int `json:"categoryUid"`
|
||||
Name string `json:"name"`
|
||||
Barcode string `json:"barcode"`
|
||||
BuyPrice int `json:"buyPrice"`
|
||||
SellPrice int `json:"sellPrice"`
|
||||
Stock int `json:"stock"`
|
||||
Pinyin string `json:"pinyin"`
|
||||
Description string `json:"description"`
|
||||
IsCustomerDiscount int `json:"isCustomerDiscount"`
|
||||
SupplierUID int `json:"supplierUid"`
|
||||
Enable int `json:"enable"`
|
||||
} `json:"productInfo"`
|
||||
AppID string `json:"appId"`
|
||||
}
|
||||
|
||||
//新增商品
|
||||
//http://pospal.cn/openplatform/productapi.html#addProductInfo
|
||||
func (a *API) AddProductInfo(addProductInfoParam *AddProductInfoParam) (err error) {
|
||||
result, err := a.AccessAPI("productOpenApi/addProductInfo", utils.Struct2FlatMap(addProductInfoParam))
|
||||
|
||||
return err
|
||||
}
|
||||
Reference in New Issue
Block a user