Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 1 | package swservice |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 2 | |
| 3 | import ( |
| 4 | "bytes" |
| 5 | "crypto/hmac" |
| 6 | "crypto/sha1" |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 7 | "crypto/tls" |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 8 | "encoding/hex" |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 9 | "encoding/json" |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 10 | "errors" |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 11 | "fmt" |
| 12 | log "github.com/Sirupsen/logrus" |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 13 | "io/ioutil" |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 14 | "net" |
| 15 | "net/http" |
| 16 | "net/url" |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 17 | "strconv" |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 18 | "strings" |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 19 | "time" |
| 20 | ) |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 21 | |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 22 | type WebSession struct { |
| 23 | AppId string |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 24 | TermId string |
| 25 | Appsecret string |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 26 | BaseUrl string |
| 27 | DefaultTimeout int |
| 28 | session_key string |
Tang Cheng | 0b9abf1 | 2015-08-20 09:55:32 +0800 | [diff] [blame] | 29 | ssl_verify bool |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 30 | } |
| 31 | |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 32 | func safe_get_json_int(value interface{}) int { |
| 33 | if value == nil { |
| 34 | return 0 |
| 35 | } |
| 36 | s := fmt.Sprintf("%v", value) |
| 37 | if i, err := strconv.Atoi(s); err != nil { |
| 38 | return 0 |
| 39 | } else { |
| 40 | return i |
| 41 | } |
| 42 | } |
| 43 | |
| 44 | type ServiceResponse struct { |
| 45 | RetCode int |
| 46 | RetMsg string |
| 47 | Result map[string]interface{} |
| 48 | } |
| 49 | |
| 50 | func NewServiceResponseFromJson(json_data interface{}) *ServiceResponse { |
| 51 | if json_data == nil { |
| 52 | return nil |
| 53 | } |
| 54 | res := &ServiceResponse{} |
| 55 | res.Result = json_data.(map[string]interface{}) |
| 56 | res.RetCode = safe_get_json_int(res.Result["retcode"]) |
| 57 | res.RetMsg = res.GetStrValue("retmsg") |
| 58 | return res |
| 59 | } |
| 60 | func (r *ServiceResponse) GetIntValue(name string) int { |
| 61 | return safe_get_json_int(r.Result[name]) |
| 62 | } |
| 63 | |
| 64 | func (r *ServiceResponse) GetStrValue(name string) string { |
| 65 | if s, ok := r.Result[name]; ok { |
| 66 | return fmt.Sprintf("%v", s) |
| 67 | } else { |
| 68 | return "" |
| 69 | } |
| 70 | } |
| 71 | |
| 72 | func (r *ServiceResponse) GetFloatValue(name string) float64 { |
| 73 | if s, ok := r.Result[name]; ok { |
| 74 | t := fmt.Sprintf("%v", s) |
| 75 | if f, err := strconv.ParseFloat(t, 64); err != nil { |
| 76 | return 0.0 |
| 77 | } else { |
| 78 | return f |
| 79 | } |
| 80 | } else { |
| 81 | return 0.0 |
| 82 | } |
| 83 | } |
| 84 | |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 85 | func (w *WebSession) DoGet(uri string, params map[string]string) (*http.Response, error) { |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 86 | client := w.NewClient(3) |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 87 | |
| 88 | full_url := w.BaseUrl + uri |
| 89 | |
| 90 | vl := url.Values{} |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 91 | |
| 92 | if params != nil { |
| 93 | for k, v := range params { |
| 94 | vl.Add(k, v) |
| 95 | } |
| 96 | } |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 97 | full_url = full_url + "?" + vl.Encode() |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 98 | // fmt.Printf("%v\n", full_url) |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 99 | return client.Get(full_url) |
| 100 | } |
| 101 | |
| 102 | func (w *WebSession) GetTimestamp() string { |
| 103 | t := time.Now() |
| 104 | return fmt.Sprintf("%04d%02d%02d%02d%02d%02d", t.Year(), t.Month(), t.Day(), |
| 105 | t.Hour(), t.Minute(), t.Second()) |
| 106 | } |
| 107 | |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 108 | func (w *WebSession) SignWithKey(key, message string) string { |
| 109 | mac := hmac.New(sha1.New, []byte(key)) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 110 | mac.Write([]byte(message)) |
| 111 | res := mac.Sum(nil) |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 112 | return hex.EncodeToString(res) |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 113 | } |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 114 | func (w *WebSession) Sign(message string) string { |
| 115 | return w.SignWithKey(w.Appsecret, message) |
| 116 | } |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 117 | |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 118 | func (w *WebSession) NewClient(timeout int) *http.Client { |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 119 | var transport http.Transport |
| 120 | if strings.HasPrefix(w.BaseUrl, "https://") { |
Tang Cheng | 0b9abf1 | 2015-08-20 09:55:32 +0800 | [diff] [blame] | 121 | var b bool |
| 122 | if w.ssl_verify { |
| 123 | b = false |
| 124 | } else { |
| 125 | b = true |
| 126 | } |
Tang Cheng | 9166585 | 2015-08-29 22:17:20 +0800 | [diff] [blame] | 127 | transport = http.Transport{MaxIdleConnsPerHost: 0, DisableKeepAlives: true, |
| 128 | TLSClientConfig: &tls.Config{InsecureSkipVerify: b}, |
| 129 | TLSHandshakeTimeout: time.Duration(timeout) * time.Second, |
| 130 | Dial: func(network, addr string) (net.Conn, error) { |
| 131 | default_timeout := time.Duration(1) * time.Second |
| 132 | return net.DialTimeout(network, addr, default_timeout) |
| 133 | }} |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 134 | } else if strings.HasPrefix(w.BaseUrl, "http://") { |
Tang Cheng | 9166585 | 2015-08-29 22:17:20 +0800 | [diff] [blame] | 135 | transport = http.Transport{MaxIdleConnsPerHost: 0, DisableKeepAlives: true, |
| 136 | Dial: func(network, addr string) (net.Conn, error) { |
| 137 | default_timeout := time.Duration(1) * time.Second |
| 138 | return net.DialTimeout(network, addr, default_timeout) |
| 139 | }} |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 140 | } |
Tang Cheng | 9166585 | 2015-08-29 22:17:20 +0800 | [diff] [blame] | 141 | return &http.Client{Transport: &transport, Timeout: time.Duration(timeout) * time.Second} |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 142 | } |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 143 | |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 144 | func (w *WebSession) DoPost(uri string, param map[string]string) (*http.Response, error) { |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 145 | client := w.NewClient(3) |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 146 | param["app_id"] = w.AppId |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 147 | param["term_id"] = w.TermId |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 148 | param["sign_method"] = "HMAC" |
| 149 | param["session_key"] = w.session_key |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 150 | ts := w.GetTimestamp() |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 151 | param["timestamp"] = ts |
| 152 | param["sign"] = w.Sign(w.AppId + w.TermId + w.session_key + ts) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 153 | |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 154 | full_url := w.BaseUrl + uri |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 155 | data, err := json.Marshal(param) |
| 156 | if err != nil { |
| 157 | return nil, err |
| 158 | } |
| 159 | var r *http.Response |
| 160 | r, err = client.Post(full_url, "application/json", bytes.NewReader(data)) |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 161 | if err != nil || r.StatusCode != 200 { |
| 162 | log.Errorf("Status=%v, err=%v", r, err) |
| 163 | } |
| 164 | return r, err |
| 165 | } |
| 166 | |
| 167 | func (w *WebSession) Auth() error { |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 168 | token, err := w.getAuthToken() |
| 169 | if err != nil { |
| 170 | return err |
| 171 | } |
| 172 | err = w.getAppAccessKey(token) |
| 173 | if err != nil { |
| 174 | return err |
| 175 | } |
Tang Cheng | 32e3256 | 2015-07-08 17:08:03 +0800 | [diff] [blame] | 176 | return nil |
| 177 | } |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 178 | |
Tang Cheng | 0b9abf1 | 2015-08-20 09:55:32 +0800 | [diff] [blame] | 179 | func NewSession(appid, appsecret, termid, baseurl string, timeout int, sslVerify bool) *WebSession { |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 180 | return &WebSession{ |
| 181 | AppId: appid, |
| 182 | Appsecret: appsecret, |
| 183 | TermId: termid, |
| 184 | BaseUrl: baseurl, |
| 185 | DefaultTimeout: timeout, |
Tang Cheng | 0b9abf1 | 2015-08-20 09:55:32 +0800 | [diff] [blame] | 186 | ssl_verify: sslVerify} |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 187 | } |
| 188 | |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 189 | func (w *WebSession) getAuthToken() (string, error) { |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 190 | type FormJson struct { |
| 191 | AppId string `json:"app_id"` |
| 192 | TermId string `json:"term_id"` |
| 193 | AccessToken string `json:"access_token"` |
| 194 | } |
| 195 | |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 196 | uri := fmt.Sprintf("/authservice/getauth/%v/getaccesstoken", w.AppId) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 197 | |
| 198 | params := make(map[string]string) |
| 199 | params["term_id"] = w.TermId |
| 200 | r, err := w.DoGet(uri, params) |
| 201 | |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 202 | if err != nil { |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 203 | // log.Errorf("Status = %v, err = %v\n", r.StatusCode, err) |
Tang Cheng | f8716aa | 2015-08-19 10:20:40 +0800 | [diff] [blame] | 204 | return "", err |
| 205 | } |
| 206 | if r.StatusCode != 200 { |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 207 | return "", errors.New("请求失败") |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 208 | } |
| 209 | |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 210 | body, err := ioutil.ReadAll(r.Body) |
Tang Cheng | 9166585 | 2015-08-29 22:17:20 +0800 | [diff] [blame] | 211 | defer r.Body.Close() |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 212 | |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 213 | s := &FormJson{} |
| 214 | err = json.Unmarshal(body, &s) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 215 | if err != nil { |
| 216 | log.Errorf("json unmarshal err %v", err) |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 217 | return "", errors.New("解析失败") |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 218 | } |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 219 | return s.AccessToken, nil |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 220 | } |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 221 | func (w *WebSession) getAppAccessKey(token string) error { |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 222 | type FormJson struct { |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 223 | AppId string `json:"app_id"` |
| 224 | TermId string `json:"term_id"` |
| 225 | SessionKey string `json:"session_key"` |
| 226 | CardKey string `json:"card_key"` |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 227 | } |
| 228 | |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 229 | uri := fmt.Sprintf("/authservice/getauth/%v", w.AppId) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 230 | |
| 231 | params := make(map[string]string) |
| 232 | params["term_id"] = w.TermId |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 233 | params["access_token"] = token |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 234 | params["timestamp"] = w.GetTimestamp() |
| 235 | params["v"] = "1" |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 236 | params["sign"] = w.Sign(token + params["timestamp"]) |
| 237 | params["sign_method"] = "HMAC" |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 238 | |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 239 | r, err := w.DoGet(uri, params) |
Tang Cheng | 5581474 | 2015-09-08 17:24:05 +0800 | [diff] [blame^] | 240 | if r != nil { |
| 241 | defer r.Body.Close() |
| 242 | } |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 243 | if err != nil || r.StatusCode != 200 { |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 244 | log.Errorf(" err = %v\n", err) |
| 245 | return err |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 246 | } |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 247 | |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 248 | body, err := ioutil.ReadAll(r.Body) |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 249 | |
| 250 | s := &FormJson{} |
| 251 | err = json.Unmarshal(body, &s) |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 252 | if err != nil { |
| 253 | log.Errorf("json unmarshal err %v", err) |
| 254 | } |
qiaowei | ca037fa | 2015-07-10 18:31:53 +0800 | [diff] [blame] | 255 | w.session_key = s.SessionKey |
| 256 | return nil |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 257 | } |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 258 | |
| 259 | func (w *WebSession) CallYKTApi(request *MessageWriter) (*MessageReader, error) { |
| 260 | call_data := request.Serialize() |
| 261 | params := make(map[string]string) |
| 262 | params["funcdata"] = call_data |
| 263 | r, err := w.DoPost("/ecardservice/ecardapi", params) |
| 264 | |
Tang Cheng | 5581474 | 2015-09-08 17:24:05 +0800 | [diff] [blame^] | 265 | if r != nil { |
| 266 | defer r.Body.Close() |
| 267 | } |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 268 | if err != nil { |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 269 | log.Errorf(" err = %v\n", err) |
| 270 | return nil, err |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 271 | } |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 272 | |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 273 | if r.StatusCode != 200 { |
| 274 | return nil, errors.New(fmt.Sprintf("Request StatusCode:%v", r.StatusCode)) |
| 275 | } |
| 276 | |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 277 | body, err := ioutil.ReadAll(r.Body) |
Tang Cheng | 26b9115 | 2015-07-22 12:26:52 +0800 | [diff] [blame] | 278 | return NewMessageReader(body), nil |
zongqiang.zhang | b8ab9b4 | 2015-07-10 17:45:20 +0800 | [diff] [blame] | 279 | } |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 280 | |
| 281 | func (w *WebSession) CallService(path string, params map[string]interface{}, |
| 282 | sign_field []string, timeout int) (response *ServiceResponse, err error) { |
| 283 | |
| 284 | return w.CallService2(path, params, timeout, sign_field...) |
| 285 | } |
| 286 | |
| 287 | func (w *WebSession) CallService2(path string, params map[string]interface{}, timeout int, |
| 288 | sign_field ...string) (response *ServiceResponse, err error) { |
| 289 | client := w.NewClient(timeout) |
| 290 | err = nil |
| 291 | params["app_id"] = w.AppId |
| 292 | params["term_id"] = w.TermId |
| 293 | ts := w.GetTimestamp() |
| 294 | params["timestamp"] = ts |
| 295 | |
| 296 | vl := &url.Values{} |
| 297 | for k, v := range params { |
| 298 | vl.Set(k, fmt.Sprintf("%v", v)) |
| 299 | } |
| 300 | |
| 301 | sign_data := "" |
| 302 | for _, k := range sign_field { |
| 303 | if v, ok := params[k]; ok { |
| 304 | sign_data += fmt.Sprintf("%v", v) |
| 305 | } |
| 306 | } |
| 307 | sign_data += ts + w.session_key |
| 308 | vl.Set("sign_method", "HMAC") |
| 309 | log.Debugf("Sign: key[%v] data[%v]\n", w.session_key, sign_data) |
| 310 | vl.Set("sign", w.SignWithKey(w.Appsecret, sign_data)) |
| 311 | |
| 312 | full_url := w.BaseUrl + path |
| 313 | log.Debugf("CallService: %v\n", full_url) |
| 314 | var r *http.Response |
| 315 | r, err = client.Post(full_url, "application/x-www-form-urlencoded", |
| 316 | bytes.NewReader([]byte(vl.Encode()))) |
Tang Cheng | 5581474 | 2015-09-08 17:24:05 +0800 | [diff] [blame^] | 317 | if r != nil { |
| 318 | defer r.Body.Close() |
| 319 | } |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 320 | if err != nil { |
| 321 | log.Errorf("Status=%v, err=%v", r, err) |
| 322 | return |
| 323 | } |
| 324 | if r.StatusCode != 200 { |
| 325 | log.Errorf("Request Error %v\n", r.StatusCode) |
| 326 | err = errors.New(fmt.Sprintf("Request Error, StatusCode : %v", r.StatusCode)) |
| 327 | return |
| 328 | } |
| 329 | body, err := ioutil.ReadAll(r.Body) |
Tang Cheng | f16121a | 2015-07-27 13:46:14 +0800 | [diff] [blame] | 330 | var s interface{} |
| 331 | err = json.Unmarshal(body, &s) |
| 332 | if err != nil { |
| 333 | log.Errorf("json unmarshal err %v", err) |
| 334 | return |
| 335 | } |
| 336 | response = NewServiceResponseFromJson(s) |
| 337 | return |
| 338 | } |