|
@@ -3,31 +3,15 @@ package wechat
|
|
|
import (
|
|
|
"bytes"
|
|
|
"encoding/json"
|
|
|
+ "encoding/xml"
|
|
|
"errors"
|
|
|
|
|
|
"git.chuangxin1.com/cx/myth"
|
|
|
)
|
|
|
|
|
|
-func checkErrorWithBody(msg myth.HTTPMessage) (body []byte, err error) {
|
|
|
+func checkJSONError(msg myth.HTTPMessage) (jq *myth.JSONQuery, err error) {
|
|
|
if msg.StatusCode == 200 {
|
|
|
- var res ResponseMsg
|
|
|
- err = json.Unmarshal(msg.Body, &res)
|
|
|
- if err == nil {
|
|
|
- if res.ErrCode != ErrReqOk {
|
|
|
- err = errors.New(res.ErrMsg)
|
|
|
- } else {
|
|
|
- body = msg.Body
|
|
|
- }
|
|
|
- }
|
|
|
- } else {
|
|
|
- err = errors.New(`HTTP StatusCode not 200`)
|
|
|
- }
|
|
|
- return
|
|
|
-}
|
|
|
-
|
|
|
-func checkError(msg myth.HTTPMessage) (jq *myth.JSONQuery, err error) {
|
|
|
- if msg.StatusCode == 200 {
|
|
|
- jq, err = myth.NewJSONQuery(msg.Body)
|
|
|
+ jq, err = msg.JSONQuery()
|
|
|
if err != nil {
|
|
|
return
|
|
|
}
|
|
@@ -44,86 +28,63 @@ func checkError(msg myth.HTTPMessage) (jq *myth.JSONQuery, err error) {
|
|
|
}
|
|
|
err = errors.New(msg)
|
|
|
}
|
|
|
-
|
|
|
- err = json.Unmarshal(msg.Body, &res)
|
|
|
- if err == nil {
|
|
|
- if res.ErrCode != ErrReqOk {
|
|
|
- err = errors.New(res.ErrMsg)
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
} else {
|
|
|
err = errors.New(`HTTP StatusCode not 200`)
|
|
|
}
|
|
|
return
|
|
|
}
|
|
|
|
|
|
+
|
|
|
func getJSON(uri string) (jq *myth.JSONQuery, err error) {
|
|
|
var msg myth.HTTPMessage
|
|
|
- if msg, err = myth.Get(uri, "", "", map[string]string{}); err != nil {
|
|
|
- return
|
|
|
- }
|
|
|
- jq, err = checkError(msg)
|
|
|
- return
|
|
|
-}
|
|
|
|
|
|
-func getBody(uri string) (body []byte, err error) {
|
|
|
- var msg myth.HTTPMessage
|
|
|
- if msg, err = myth.Get(uri, "", "", map[string]string{}); err != nil {
|
|
|
+ headers := make(map[string]string)
|
|
|
+ headers["Accept-Encoding"] = "gzip, deflate, br"
|
|
|
+ headers["Accept"] = "application/json"
|
|
|
+ if msg, err = myth.Get(uri, "", "", headers); err != nil {
|
|
|
return
|
|
|
}
|
|
|
- body, err = checkErrorWithBody(msg)
|
|
|
+ jq, err = checkJSONError(msg)
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-func postXML(url string, data []byte) (jq *myth.JSONQuery, err error) {
|
|
|
- var (
|
|
|
- msg myth.HTTPMessage
|
|
|
- headers = make(map[string]string)
|
|
|
- )
|
|
|
-
|
|
|
+
|
|
|
+func getBody(uri string) (msg myth.HTTPMessage, err error) {
|
|
|
+ headers := make(map[string]string)
|
|
|
headers["Accept-Encoding"] = "gzip, deflate, br"
|
|
|
- headers["Accept"] = "application/json"
|
|
|
- headers["Content-Type"] = "application/xml; charset=utf-8"
|
|
|
- msg, err = myth.Post(url, "", "", headers, bytes.NewReader(data))
|
|
|
- if err != nil {
|
|
|
- return
|
|
|
- }
|
|
|
- jq, err = checkError(msg)
|
|
|
+
|
|
|
+ msg, err = myth.Get(uri, "", "", headers)
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-func postJSON(url string, data []byte) (jq *myth.JSONQuery, err error) {
|
|
|
- var (
|
|
|
- msg myth.HTTPMessage
|
|
|
- headers = make(map[string]string)
|
|
|
- )
|
|
|
+func postJSON(url string, args interface{}) (msg myth.HTTPMessage, err error) {
|
|
|
+ headers := make(map[string]string)
|
|
|
|
|
|
headers["Accept-Encoding"] = "gzip, deflate, br"
|
|
|
- headers["Accept"] = "application/json"
|
|
|
headers["Content-Type"] = "application/json; charset=utf-8"
|
|
|
- msg, err = myth.Post(url, "", "", headers, bytes.NewReader(data))
|
|
|
+
|
|
|
+ var data []byte
|
|
|
+ data, err = json.Marshal(args)
|
|
|
if err != nil {
|
|
|
return
|
|
|
}
|
|
|
- jq, err = checkError(msg)
|
|
|
+ msg, err = myth.Post(url, "", "", headers, bytes.NewReader(data))
|
|
|
+
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-func postJSONBody(uri string, data []byte) (body []byte, err error) {
|
|
|
- var (
|
|
|
- msg myth.HTTPMessage
|
|
|
- headers = make(map[string]string)
|
|
|
- )
|
|
|
+func postXML(url string, args interface{}) (msg myth.HTTPMessage, err error) {
|
|
|
+ headers := make(map[string]string)
|
|
|
|
|
|
headers["Accept-Encoding"] = "gzip, deflate, br"
|
|
|
- headers["Accept"] = "application/json"
|
|
|
- headers["Content-Type"] = "application/json; charset=utf-8"
|
|
|
- msg, err = myth.Post(uri, "", "", headers, bytes.NewReader(data))
|
|
|
+ headers["Content-Type"] = "application/xml; charset=utf-8"
|
|
|
+
|
|
|
+ var data []byte
|
|
|
+ data, err = xml.Marshal(args)
|
|
|
if err != nil {
|
|
|
return
|
|
|
}
|
|
|
- body, err = checkErrorWithBody(msg)
|
|
|
+ msg, err = myth.Post(url, "", "", headers, bytes.NewReader(data))
|
|
|
|
|
|
return
|
|
|
}
|