This commit is contained in:
suyl
2021-07-16 16:52:46 +08:00
parent ddea5f5228
commit 4f68cf371c
2 changed files with 32 additions and 18 deletions

View File

@@ -12,7 +12,7 @@ import (
) )
const ( const (
prodURL = "https://api.tibiot.cn/api" prodURL = "https://api.tibiot.cn/api/v1"
signKey = "password" signKey = "password"
) )
@@ -30,41 +30,39 @@ var (
type API struct { type API struct {
platformapi.APICookie platformapi.APICookie
appID string username string
appKey string password string
client *http.Client client *http.Client
config *platformapi.APIConfig config *platformapi.APIConfig
} }
func New(appID, appKey string, config ...*platformapi.APIConfig) *API { func New(username, password string, config ...*platformapi.APIConfig) *API {
curConfig := platformapi.DefAPIConfig curConfig := platformapi.DefAPIConfig
if len(config) > 0 { if len(config) > 0 {
curConfig = *config[0] curConfig = *config[0]
} }
return &API{ return &API{
appID: appID, username: username,
appKey: appKey, password: password,
client: &http.Client{Timeout: curConfig.ClientTimeout}, client: &http.Client{Timeout: curConfig.ClientTimeout},
config: &curConfig, config: &curConfig,
} }
} }
func (a *API) signParams(apiParams map[string]interface{}) string { func (a *API) signParams(apiParams map[string]interface{}) string {
return fmt.Sprintf("%x", md5.Sum([]byte(a.appID+a.appKey+apiParams["timestamp"].(string)))) return fmt.Sprintf("%x", md5.Sum([]byte(fmt.Sprintf("%x", md5.Sum([]byte(a.username+apiParams["tkey"].(string)))))))
} }
func (a *API) AccessAPI(apiName string, apiParams map[string]interface{}) (retVal interface{}, err error) { func (a *API) AccessAPI(url string, apiParams map[string]interface{}) (retVal interface{}, err error) {
params := utils.MergeMaps(map[string]interface{}{ params := utils.MergeMaps(map[string]interface{}{
"app_id": a.appID, "username": a.username,
"method": apiName,
}, apiParams) }, apiParams)
fullURL := utils.GenerateGetURL(prodURL, url, nil)
err = platformapi.AccessPlatformAPIWithRetry(a.client, err = platformapi.AccessPlatformAPIWithRetry(a.client,
func() *http.Request { func() *http.Request {
params["timestamp"] = utils.Int64ToStr(time.Now().Unix()) params["tkey"] = time.Now().Format("20060102150405")
sign := a.signParams(params) sign := a.signParams(params)
params[signKey] = sign params[signKey] = sign
fullURL := prodURL
request, _ := http.NewRequest(http.MethodPost, fullURL, strings.NewReader(utils.Map2URLValues(params).Encode())) request, _ := http.NewRequest(http.MethodPost, fullURL, strings.NewReader(utils.Map2URLValues(params).Encode()))
request.Header.Set("Content-Type", "application/x-www-form-urlencoded") request.Header.Set("Content-Type", "application/x-www-form-urlencoded")
return request return request
@@ -91,3 +89,10 @@ func (a *API) AccessAPI(apiName string, apiParams map[string]interface{}) (retVa
}) })
return retVal, err return retVal, err
} }
func (a *API) GetCardInfo(iccid string) (err error) {
a.AccessAPI("card/getCardInfo", map[string]interface{}{
"iccid": iccid,
})
return err
}

View File

@@ -3,6 +3,7 @@ package tibiotapi
import ( import (
"git.rosy.net.cn/baseapi" "git.rosy.net.cn/baseapi"
"go.uber.org/zap" "go.uber.org/zap"
"testing"
) )
var ( var (
@@ -15,5 +16,13 @@ func init() {
sugarLogger = logger.Sugar() sugarLogger = logger.Sugar()
baseapi.Init(sugarLogger) baseapi.Init(sugarLogger)
api = New("1000", "rfBd56ti2SMtYvSg") api = New("ruoxikeji", "Ruoxi@369")
}
func TestGetCardInfo(t *testing.T) {
err := api.GetCardInfo("")
if err != nil {
t.Fatalf("PrintMsg return error:%v", err)
}
//baseapi.SugarLogger.Debug(result)
} }