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