| @ -1,109 +1,106 @@ | |||||
| package site | package site | ||||
| import ( | |||||
| "crypto/md5" | |||||
| "encoding/hex" | |||||
| "encoding/json" | |||||
| "errors" | |||||
| "strconv" | |||||
| "strings" | |||||
| "time" | |||||
| // import ( | |||||
| // "encoding/json" | |||||
| // "errors" | |||||
| // "strconv" | |||||
| // "time" | |||||
| "git.tetele.net/tgo/crypter" | |||||
| // "git.tetele.net/tgo/crypter" | |||||
| "github.com/golang/protobuf/proto" | |||||
| ) | |||||
| // "github.com/golang/protobuf/proto" | |||||
| // ) | |||||
| type SiteBalanceTypeReqArg struct { | |||||
| SiteId string `json:"site_id"` | |||||
| Dbname string `json:"dbname"` | |||||
| } | |||||
| // type SiteBalanceTypeReqArg struct { | |||||
| // SiteId string `json:"site_id"` | |||||
| // Dbname string `json:"dbname"` | |||||
| // } | |||||
| type SiteBalanceType struct { | |||||
| Id string | |||||
| Name string | |||||
| UseLimit string | |||||
| Unit string | |||||
| Type string | |||||
| CleanRate string | |||||
| CleanTime string | |||||
| } | |||||
| // type SiteBalanceType struct { | |||||
| // Id string | |||||
| // Name string | |||||
| // UseLimit string | |||||
| // Unit string | |||||
| // Type string | |||||
| // CleanRate string | |||||
| // CleanTime string | |||||
| // } | |||||
| /** | |||||
| * 由配置key取对应value | |||||
| * 请求及回均加密验签 | |||||
| * 2021/01/20 | |||||
| * GZ | |||||
| */ | |||||
| func GetBalanceType(site_id, dbname string, url ...string) (*[]SiteBalanceType, error) { | |||||
| // /** | |||||
| // * 由配置key取对应value | |||||
| // * 请求及回均加密验签 | |||||
| // * 2021/01/20 | |||||
| // * GZ | |||||
| // */ | |||||
| // func GetBalanceType(site_id, dbname string, url ...string) (*[]SiteBalanceType, error) { | |||||
| var site_rpc_url string = "127.0.0.1:7971" | |||||
| if len(url) > 0 && url[0] != "" { | |||||
| site_rpc_url = url[0] | |||||
| } | |||||
| conn, _, err := DialSiteService("tcp", site_rpc_url) | |||||
| if err != nil { | |||||
| return nil, err | |||||
| } | |||||
| defer conn.Close() | |||||
| // var site_rpc_url string = "127.0.0.1:7971" | |||||
| // if len(url) > 0 && url[0] != "" { | |||||
| // site_rpc_url = url[0] | |||||
| // } | |||||
| // conn, _, err := DialSiteService("tcp", site_rpc_url) | |||||
| // if err != nil { | |||||
| // return nil, err | |||||
| // } | |||||
| // defer conn.Close() | |||||
| arg := SiteConfigItemReqArg{site_id, dbname, key} | |||||
| // arg := SiteConfigItemReqArg{site_id, dbname, key} | |||||
| data_json, err := json.Marshal(arg) | |||||
| if err != nil { | |||||
| return nil, err | |||||
| } | |||||
| now_int64 := time.Now().Unix() | |||||
| // data_json, err := json.Marshal(arg) | |||||
| // if err != nil { | |||||
| // return nil, err | |||||
| // } | |||||
| // now_int64 := time.Now().Unix() | |||||
| encryData := crypter.DesEn(string(data_json), "confdata") | |||||
| // encryData := crypter.DesEn(string(data_json), "confdata") | |||||
| now := strconv.FormatInt(now_int64, 10) | |||||
| // now := strconv.FormatInt(now_int64, 10) | |||||
| sign := Sign(encryData, now) | |||||
| // sign := Sign(encryData, now) | |||||
| req := &ConfigRequest{proto.String(encryData), proto.String(now), proto.String(sign), nil} | |||||
| // req := &ConfigRequest{proto.String(encryData), proto.String(now), proto.String(sign), nil} | |||||
| res := &ConfigResponse{} | |||||
| // res := &ConfigResponse{} | |||||
| err = conn.GetConfig(req, res) | |||||
| // err = conn.GetConfig(req, res) | |||||
| if err != nil { | |||||
| return nil, err | |||||
| } | |||||
| // if err != nil { | |||||
| // return nil, err | |||||
| // } | |||||
| res_data := res.GetData() | |||||
| // res_data := res.GetData() | |||||
| if res_data != "" { | |||||
| // if res_data != "" { | |||||
| time_int64, err := strconv.ParseInt(res.GetTime(), 10, 64) | |||||
| if err != nil { | |||||
| return nil, err | |||||
| } | |||||
| // time_int64, err := strconv.ParseInt(res.GetTime(), 10, 64) | |||||
| // if err != nil { | |||||
| // return nil, err | |||||
| // } | |||||
| now_int64 = time.Now().Unix() | |||||
| // now_int64 = time.Now().Unix() | |||||
| if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||||
| //时间误差前后10秒,返回 | |||||
| return nil, errors.New("返回时间错误") | |||||
| } | |||||
| // if now_int64-time_int64 > 10 || time_int64-now_int64 > 10 { | |||||
| // //时间误差前后10秒,返回 | |||||
| // return nil, errors.New("返回时间错误") | |||||
| // } | |||||
| check_sign := CheckSign(res.GetSign(), res_data, res.GetTime()) | |||||
| if !check_sign { | |||||
| return nil, errors.New("返回数据签名错误") | |||||
| } | |||||
| // check_sign := CheckSign(res.GetSign(), res_data, res.GetTime()) | |||||
| // if !check_sign { | |||||
| // return nil, errors.New("返回数据签名错误") | |||||
| // } | |||||
| //解密 | |||||
| res_data_de := crypter.DesDe(res_data, "confdata") | |||||
| // //解密 | |||||
| // res_data_de := crypter.DesDe(res_data, "confdata") | |||||
| var res_arr []SiteBalanceType | |||||
| // var res_arr []SiteBalanceType | |||||
| err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
| // err = json.Unmarshal([]byte(res_data_de), &res_arr) | |||||
| if err != nil { | |||||
| return nil, err | |||||
| } | |||||
| return &res_arr, nil | |||||
| } | |||||
| // if err != nil { | |||||
| // return nil, err | |||||
| // } | |||||
| // return &res_arr, nil | |||||
| // } | |||||
| return nil, nil | |||||
| } | |||||
| // return nil, nil | |||||
| // } | |||||