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