订单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.

75 lines
1.1 KiB

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