订单rpc
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
1.1 KiB

  1. package orderrpc
  2. import (
  3. "encoding/json"
  4. "strconv"
  5. "time"
  6. "git.tetele.net/tgo/crypter"
  7. "github.com/golang/protobuf/proto"
  8. )
  9. type OrderCancelRes struct {
  10. Success bool
  11. }
  12. func Cancel(dbname, site_id string, order_id string, url ...string) (*OrderCancelRes, error) {
  13. conn, err := rpc_server_conn(url...)
  14. if err != nil {
  15. return nil, err
  16. }
  17. defer conn.Close()
  18. data := map[string]string{
  19. "dbname": dbname,
  20. "site_id": site_id,
  21. "order_id": order_id,
  22. }
  23. data_json, err := json.Marshal(data)
  24. if err != nil {
  25. return nil, err
  26. }
  27. encryData := crypter.DesEn(string(data_json), DES_KEY)
  28. now_int64 := time.Now().Unix()
  29. now := strconv.FormatInt(now_int64, 10)
  30. sign := Sign(encryData, now)
  31. req := &CreateRequest{
  32. proto.String(encryData),
  33. proto.String(now),
  34. proto.String(sign),
  35. nil}
  36. res := &CreateResponse{}
  37. err = conn.Cancel(req, res)
  38. if err != nil {
  39. return nil, err
  40. }
  41. res_data, err := HandleResponse(res)
  42. var res_arr OrderCancelRes
  43. err = json.Unmarshal([]byte(res_data), &res_arr)
  44. if err != nil {
  45. return nil, err
  46. }
  47. return &res_arr, nil
  48. }