rabbitmq 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.

66 lines
1.1 KiB

  1. package rabbitmqrpc
  2. import (
  3. "encoding/json"
  4. "log"
  5. "strconv"
  6. "time"
  7. "git.tetele.net/tgo/crypter"
  8. "github.com/golang/protobuf/proto"
  9. )
  10. func SendDelay(exchange, key string, data interface{}, delay int64, url ...string) (*MsgSend, error) {
  11. conn, err := rpc_server_conn(url...)
  12. if err != nil {
  13. return nil, err
  14. }
  15. defer conn.Close()
  16. arg_data, err := json.Marshal(data)
  17. if err != nil {
  18. log.Println("json marshal error:", err)
  19. }
  20. arg := DelayMsgBody{}
  21. arg.Exchange = exchange
  22. arg.Key = key
  23. arg.Data = string(arg_data)
  24. arg.Delay = delay
  25. data_json, err := json.Marshal(arg)
  26. if err != nil {
  27. return nil, err
  28. }
  29. now_int64 := time.Now().Unix()
  30. encryData := crypter.DesEn(string(data_json), DES_KEY)
  31. now := strconv.FormatInt(now_int64, 10)
  32. sign := Sign(encryData, now)
  33. req := &Request{proto.String(encryData), proto.String(now), proto.String(sign), nil}
  34. res := &Response{}
  35. err = conn.SendDelay(req, res)
  36. if err != nil {
  37. return nil, err
  38. }
  39. res_data, err := GetOrgData(res)
  40. var res_arr MsgSend
  41. err = json.Unmarshal([]byte(res_data), &res_arr)
  42. if err != nil {
  43. return nil, err
  44. }
  45. return &res_arr, nil
  46. }