rabbitmq.go 39 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202
  1. package initialize
  2. import (
  3. "encoding/base64"
  4. "fmt"
  5. "mtp20access/client"
  6. "mtp20access/global"
  7. rsp "mtp20access/model/mq/response"
  8. "mtp20access/packet"
  9. "mtp20access/publish"
  10. "mtp20access/rabbitmq"
  11. "mtp20access/res/pb"
  12. accountSrv "mtp20access/service/account"
  13. "mtp20access/utils"
  14. "strconv"
  15. // "github.com/golang/protobuf/proto"
  16. "github.com/streadway/amqp"
  17. "go.uber.org/zap"
  18. "google.golang.org/protobuf/encoding/protojson"
  19. "google.golang.org/protobuf/proto"
  20. )
  21. func RabbitMQ() *global.RabbitMQ {
  22. url := global.M2A_CONFIG.Rabbitmq.Url
  23. connection, err := amqp.Dial(url)
  24. if err != nil {
  25. global.M2A_LOG.Error("rabbitmq connect failed, err:", zap.Error(err))
  26. return nil
  27. }
  28. channel, err := connection.Channel()
  29. if err != nil {
  30. global.M2A_LOG.Error("rabbitmq open channel failed, err:", zap.Error(err))
  31. return nil
  32. }
  33. global.M2A_LOG.Info("rabbitmq connect successed.")
  34. return &global.RabbitMQ{
  35. Connection: connection,
  36. Channel: channel,
  37. }
  38. }
  39. // MQProc 消息处理对象
  40. type MQProc struct{}
  41. // process 消息处理接口
  42. func (t *MQProc) Process(topic, queuename string, msg *[]byte) {
  43. info := fmt.Sprintf("rabbitmq receive message from: topic[%s] queue[%s] contentLen[%d]",
  44. topic,
  45. queuename,
  46. len(string(*msg)))
  47. global.M2A_LOG.Info(info)
  48. if funcode, sessionId, bytes, serialNumber, err := t.getRspProtobuf(msg); err == nil && bytes != nil {
  49. if sessionId == 0 || funcode == uint32(global.LogoutRsp) || funcode == uint32(global.LoginRsp) {
  50. // 通知类 或 特殊处理
  51. t.onNtf(funcode, sessionId, bytes)
  52. } else {
  53. // 请求回复
  54. // 尝试获取对应异步任务
  55. if c, exists := client.Clients[int(sessionId)]; exists {
  56. key := fmt.Sprintf("%v_%v_%v", sessionId, funcode, serialNumber)
  57. // 银行服务相关的回复流水号是错误的,所以需要特殊处理
  58. if int(funcode) == global.T2bBankSignRsp ||
  59. int(funcode) == global.T2bSMSVerificationCodeRsp ||
  60. int(funcode) == global.T2bBankCancelSignRsp ||
  61. int(funcode) == global.T2bBankWithdrawRsp ||
  62. int(funcode) == global.T2bBankDepositRsp {
  63. key = fmt.Sprintf("%v_%v", sessionId, funcode)
  64. }
  65. asyncTask := c.GetAsyncTask(key)
  66. if asyncTask != nil {
  67. rspData := string(*bytes)
  68. // 判断是否要加密
  69. if asyncTask.IsEncrypted {
  70. if b, err := packet.Encrypt(*bytes, packet.AESKey, true); err != nil {
  71. global.M2A_LOG.Error("总线回复数据加密失败", zap.Error(err))
  72. return
  73. } else {
  74. rspData = base64.StdEncoding.EncodeToString(b)
  75. }
  76. }
  77. // 给客户端回调
  78. global.M2A_LOG.Info("[S->C]", zap.Any("rsp", funcode), zap.Any("sessionId", sessionId), zap.Any("data", string(rspData)))
  79. r := rsp.MQBodyRsp{
  80. FunCode: funcode,
  81. IsEncrypted: asyncTask.IsEncrypted,
  82. Data: rspData,
  83. }
  84. asyncTask.Rsp <- r
  85. } else {
  86. global.M2A_LOG.Info("找不到对应KEY的异步任务", zap.Any("key", key), zap.Any("AsyncMap", c.GetAllAsyncTask()))
  87. global.M2A_LOG.Info("++++++++++++++ 当前的 Clients", zap.Any("client.Clients", client.Clients))
  88. global.M2A_LOG.Info("-------------- 当前的 AsyncTask", zap.Any("SessionId", c.SessionID), zap.Any("AsyncTask", c.GetAllAsyncTask()))
  89. }
  90. } else {
  91. global.M2A_LOG.Info("找不到对应的client", zap.Any("sessionId", sessionId))
  92. }
  93. }
  94. }
  95. }
  96. func (t *MQProc) onNtf(funcode uint32, sessionId uint32, bytes *[]byte) {
  97. var clients []*client.Client
  98. var err error
  99. var sendBytes *[]byte
  100. switch int(funcode) {
  101. case global.LoginRsp: // 用户登录应答 - 主要记录旧Token
  102. var p pb.LoginRsp
  103. if err = proto.Unmarshal(*bytes, &p); err != nil {
  104. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  105. return
  106. }
  107. // if bs, e := protojson.Marshal(&p); e != nil {
  108. // global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  109. // return
  110. // } else {
  111. // sendBytes = &bs
  112. // }
  113. // 获取目标客户
  114. for i := range client.Clients {
  115. c := client.Clients[i]
  116. if strconv.Itoa(int(p.GetUserID())) == c.UserID &&
  117. strconv.Itoa(int(sessionId)) == c.SessionID {
  118. // 主要记录旧Token
  119. c.OldToken = p.GetToken()
  120. }
  121. }
  122. case global.LogoutRsp: // 用户登出应答 - 主要用于接收管理端踢上线
  123. var p pb.LogoutRsp
  124. if err = proto.Unmarshal(*bytes, &p); err != nil {
  125. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  126. return
  127. }
  128. if bs, e := protojson.Marshal(&p); e != nil {
  129. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  130. return
  131. } else {
  132. sendBytes = &bs
  133. }
  134. // 获取目标客户
  135. clients = make([]*client.Client, 0)
  136. for i := range client.Clients {
  137. c := client.Clients[i]
  138. if strconv.Itoa(int(p.GetHeader().GetUserID())) == c.UserID {
  139. clients = append(clients, c)
  140. }
  141. }
  142. case global.MoneyChangedNtf: // 资金变化通知
  143. var p pb.MoneyChangedNtf
  144. if err = proto.Unmarshal(*bytes, &p); err != nil {
  145. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  146. return
  147. }
  148. if bs, e := protojson.Marshal(&p); e != nil {
  149. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  150. return
  151. } else {
  152. sendBytes = &bs
  153. }
  154. // 获取目标客户
  155. clients, err = accountSrv.GetClientsByAccountID(*p.AccountID)
  156. if err != nil {
  157. return
  158. }
  159. case global.PosChangedNtf: // 头寸变化通知
  160. var p pb.PosChangedNtf
  161. if err = proto.Unmarshal(*bytes, &p); err != nil {
  162. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  163. return
  164. }
  165. if bs, e := protojson.Marshal(&p); e != nil {
  166. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  167. return
  168. } else {
  169. sendBytes = &bs
  170. }
  171. // global.M2A_LOG.Info("接收 PosChangedNtf", zap.Any("ntf", funcode), zap.Any("AccountID", *p.AccountID))
  172. // global.M2A_LOG.Info("当前的 Clients", zap.Any("ntf", funcode), zap.Any("client.Clients", client.Clients))
  173. // 获取目标客户
  174. clients, err = accountSrv.GetClientsByAccountID(*p.AccountID)
  175. global.M2A_LOG.Info("找到对应的clients", zap.Any("ntf", funcode), zap.Any("clients", clients))
  176. if err != nil {
  177. global.M2A_LOG.Info(fmt.Sprintf("接收头寸变化通知时获取不到对应Client,AccountID:%v", *p.AccountID))
  178. return
  179. }
  180. case global.OrderDealedNtf: // 委托单成交通知
  181. var p pb.OrderDealedNtf
  182. if err = proto.Unmarshal(*bytes, &p); err != nil {
  183. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  184. return
  185. }
  186. if bs, e := protojson.Marshal(&p); e != nil {
  187. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  188. return
  189. } else {
  190. sendBytes = &bs
  191. }
  192. // 获取目标客户
  193. clients, err = accountSrv.GetClientsByAccountID(*p.AccountID)
  194. if err != nil {
  195. return
  196. }
  197. case global.MarketStatusChangeNtf: // 市场状态变更通知
  198. var p pb.MarketStatusChangeNtf
  199. if err = proto.Unmarshal(*bytes, &p); err != nil {
  200. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  201. return
  202. }
  203. if bs, e := protojson.Marshal(&p); e != nil {
  204. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  205. return
  206. } else {
  207. sendBytes = &bs
  208. }
  209. // 获取目标客户
  210. clients = make([]*client.Client, 0)
  211. for i := range client.Clients {
  212. c := client.Clients[i]
  213. clients = append(clients, c)
  214. }
  215. case global.OrderCanceledNtf: // 委托单撤消通知
  216. var p pb.OrderCanceledNtf
  217. if err = proto.Unmarshal(*bytes, &p); err != nil {
  218. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  219. return
  220. }
  221. if bs, e := protojson.Marshal(&p); e != nil {
  222. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  223. return
  224. } else {
  225. sendBytes = &bs
  226. }
  227. // 获取目标客户
  228. clients = make([]*client.Client, 0)
  229. for i := range client.Clients {
  230. c := client.Clients[i]
  231. if strconv.Itoa(int(p.GetHeader().GetUserID())) == c.UserID {
  232. clients = append(clients, c)
  233. }
  234. }
  235. case global.RiskCutNtf: // 斩仓通知
  236. var p pb.RiskCutNtf
  237. if err = proto.Unmarshal(*bytes, &p); err != nil {
  238. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  239. return
  240. }
  241. if bs, e := protojson.Marshal(&p); e != nil {
  242. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  243. return
  244. } else {
  245. sendBytes = &bs
  246. }
  247. // 获取目标客户
  248. clients, err = accountSrv.GetClientsByAccountID(*p.AccountId)
  249. if err != nil {
  250. return
  251. }
  252. case global.RiskControlNtf: // 风控通知
  253. var p pb.RiskControlNtf
  254. if err = proto.Unmarshal(*bytes, &p); err != nil {
  255. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  256. return
  257. }
  258. if bs, e := protojson.Marshal(&p); e != nil {
  259. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  260. return
  261. } else {
  262. sendBytes = &bs
  263. }
  264. // 获取目标客户
  265. clients, err = accountSrv.GetClientsByAccountID(*p.AccountId)
  266. if err != nil {
  267. return
  268. }
  269. case global.ListingOrderChangeNtf: // 挂牌委托变更广播通知
  270. var p pb.ListingOrderChangeNtf
  271. if err = proto.Unmarshal(*bytes, &p); err != nil {
  272. global.M2A_LOG.Error("总线数据反序列化失败", zap.Error(err))
  273. return
  274. }
  275. if bs, e := protojson.Marshal(&p); e != nil {
  276. global.M2A_LOG.Error("总线数据序列化JSON失败", zap.Error(err))
  277. return
  278. } else {
  279. sendBytes = &bs
  280. }
  281. // 获取目标客户
  282. clients = make([]*client.Client, 0)
  283. for i := range client.Clients {
  284. c := client.Clients[i]
  285. clients = append(clients, c)
  286. }
  287. }
  288. if err == nil && len(clients) > 0 {
  289. // 组装待发送给客户端的5.0报文包
  290. b, err := packet.BuildPacket(funcode, 0, 0, *sendBytes, true)
  291. if err != nil {
  292. global.M2A_LOG.Error("组装5.0报文失败", zap.Error(err))
  293. return
  294. }
  295. // 发送信息
  296. for _, item := range clients {
  297. // c := clients[i]
  298. sessionId, _ := strconv.Atoi(item.SessionID)
  299. c := client.Clients[sessionId]
  300. // c.WriteTradeWsBuf(b)
  301. // 给客户端通知
  302. global.M2A_LOG.Info("[S->C]给客户端通知", zap.Any("ntf", funcode), zap.Any("clients", c.LoginID), zap.Any("SessionID", c.SessionID), zap.Any("len", len(b)))
  303. // 分发给订阅者
  304. m := make(map[string][]byte)
  305. m[item.SessionID] = b
  306. global.M2A_Publish.Publish(publish.Topic_Trading, m)
  307. }
  308. }
  309. }
  310. // getRspProtobuf 将总线回复的数据反序列化为Protobuf
  311. func (t *MQProc) getRspProtobuf(msg *[]byte) (funcode uint32, sessionId uint32, bytes *[]byte, serialNumber uint32, err error) {
  312. // 分解总线包信息
  313. funcode = utils.BytesToUint32((*msg)[0:4])
  314. sessionId = utils.BytesToUint32((*msg)[4:8])
  315. b := (*msg)[8:]
  316. global.M2A_LOG.Info("收到总线消息", zap.Any("funcode", funcode), zap.Any("sessionId", sessionId), zap.Any("len", len(b)))
  317. switch int(funcode) {
  318. case global.PosChangedNtf,
  319. global.MoneyChangedNtf,
  320. global.OrderDealedNtf,
  321. global.MarketStatusChangeNtf,
  322. global.OrderCanceledNtf,
  323. global.RiskCutNtf,
  324. global.RiskControlNtf,
  325. global.LoginRsp,
  326. global.LogoutRsp,
  327. global.ListingOrderChangeNtf: // 资金变化通知等
  328. // global.M2A_LOG.Info("进入通知逻辑----------", zap.Any("funcode", funcode), zap.Any("sessionId", sessionId))
  329. bytes = &b
  330. case global.ModifyPwdRsp: // 修改账户密码应答
  331. var p pb.ModifyPwdRsp
  332. if err = proto.Unmarshal(b, &p); err != nil {
  333. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  334. return
  335. }
  336. if bs, e := protojson.Marshal(&p); e != nil {
  337. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  338. return
  339. } else {
  340. bytes = &bs
  341. serialNumber = p.GetHeader().GetRequestID()
  342. }
  343. case global.UserReceiveInfoRsp: // 新增修改收货地址请求响应
  344. var p pb.UserReceiveInfoRsp
  345. if err = proto.Unmarshal(b, &p); err != nil {
  346. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  347. return
  348. }
  349. if bs, e := protojson.Marshal(&p); e != nil {
  350. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  351. return
  352. } else {
  353. bytes = &bs
  354. serialNumber = p.GetHeader().GetRequestID()
  355. }
  356. case global.DelUserReceiveInfoRsp: // 删除收货地址请求响应
  357. var p pb.DelUserReceiveInfoRsp
  358. if err = proto.Unmarshal(b, &p); err != nil {
  359. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  360. return
  361. }
  362. if bs, e := protojson.Marshal(&p); e != nil {
  363. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  364. return
  365. } else {
  366. bytes = &bs
  367. serialNumber = p.GetHeader().GetRequestID()
  368. }
  369. case global.UserReceiveIsDefaultRsp:
  370. var p pb.UserReceiveIsDefaultRsp
  371. if err = proto.Unmarshal(b, &p); err != nil {
  372. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  373. return
  374. }
  375. if bs, e := protojson.Marshal(&p); e != nil {
  376. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  377. return
  378. } else {
  379. bytes = &bs
  380. serialNumber = p.GetHeader().GetRequestID()
  381. }
  382. case global.UserReceiptInfoRsp: // 新增修改用户发票信息请求响应
  383. var p pb.UserReceiptInfoRsp
  384. if err = proto.Unmarshal(b, &p); err != nil {
  385. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  386. return
  387. }
  388. if bs, e := protojson.Marshal(&p); e != nil {
  389. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  390. return
  391. } else {
  392. bytes = &bs
  393. serialNumber = p.GetHeader().GetRequestID()
  394. }
  395. case global.DelUserReceiptInfoRsp: // 删除用户发票信息请求响应
  396. var p pb.DelUserReceiptInfoRsp
  397. if err = proto.Unmarshal(b, &p); err != nil {
  398. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  399. return
  400. }
  401. if bs, e := protojson.Marshal(&p); e != nil {
  402. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  403. return
  404. } else {
  405. bytes = &bs
  406. serialNumber = p.GetHeader().GetRequestID()
  407. }
  408. case global.T2bBankSignRsp: // 签约应答
  409. var p pb.T2BBankSignRsp
  410. if err = proto.Unmarshal(b, &p); err != nil {
  411. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  412. return
  413. }
  414. if bs, e := protojson.Marshal(&p); e != nil {
  415. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  416. return
  417. } else {
  418. bytes = &bs
  419. serialNumber = p.GetHeader().GetRequestID()
  420. }
  421. case global.T2bSMSVerificationCodeRsp:
  422. var p pb.T2BSMSVerificationCodeRsp
  423. if err = proto.Unmarshal(b, &p); err != nil {
  424. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  425. return
  426. }
  427. if bs, e := protojson.Marshal(&p); e != nil {
  428. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  429. return
  430. } else {
  431. bytes = &bs
  432. serialNumber = p.GetHeader().GetRequestID()
  433. }
  434. case global.T2bBankCancelSignRsp: // 解约应答
  435. var p pb.T2BBankCancelSignRsp
  436. if err = proto.Unmarshal(b, &p); err != nil {
  437. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  438. return
  439. }
  440. if bs, e := protojson.Marshal(&p); e != nil {
  441. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  442. return
  443. } else {
  444. bytes = &bs
  445. serialNumber = p.GetHeader().GetRequestID()
  446. }
  447. case global.T2bBankWithdrawRsp: // 出金应答
  448. var p pb.T2BBankWithdrawRsp
  449. if err = proto.Unmarshal(b, &p); err != nil {
  450. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  451. return
  452. }
  453. if bs, e := protojson.Marshal(&p); e != nil {
  454. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  455. return
  456. } else {
  457. bytes = &bs
  458. serialNumber = p.GetHeader().GetRequestID()
  459. }
  460. case global.T2bBankDepositRsp: // 入金应答
  461. var p pb.T2BBankDepositRsp
  462. if err = proto.Unmarshal(b, &p); err != nil {
  463. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  464. return
  465. }
  466. if bs, e := protojson.Marshal(&p); e != nil {
  467. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  468. return
  469. } else {
  470. bytes = &bs
  471. serialNumber = p.GetHeader().GetRequestID()
  472. }
  473. case global.WarehouseApplyRsp: // 仓库申请应答
  474. var p pb.WarehouseApplyRsp
  475. if err = proto.Unmarshal(b, &p); err != nil {
  476. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  477. return
  478. }
  479. if bs, e := protojson.Marshal(&p); e != nil {
  480. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  481. return
  482. } else {
  483. bytes = &bs
  484. serialNumber = p.GetHeader().GetRequestID()
  485. }
  486. case global.PerformanceContractedApplyRsp: // 违约申请应答
  487. var p pb.PerformanceContractedApplyRsp
  488. if err = proto.Unmarshal(b, &p); err != nil {
  489. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  490. return
  491. }
  492. if bs, e := protojson.Marshal(&p); e != nil {
  493. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  494. return
  495. } else {
  496. bytes = &bs
  497. serialNumber = p.GetHeader().GetRequestID()
  498. }
  499. case global.PerformanceDelayApplyRsp: // 延期申请应答
  500. var p pb.PerformanceDelayApplyRsp
  501. if err = proto.Unmarshal(b, &p); err != nil {
  502. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  503. return
  504. }
  505. if bs, e := protojson.Marshal(&p); e != nil {
  506. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  507. return
  508. } else {
  509. bytes = &bs
  510. serialNumber = p.GetHeader().GetRequestID()
  511. }
  512. case global.PerformanceManualConfirmRsp: // 履约手动确认应答
  513. var p pb.PerformanceManualConfirmRsp
  514. if err = proto.Unmarshal(b, &p); err != nil {
  515. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  516. return
  517. }
  518. if bs, e := protojson.Marshal(&p); e != nil {
  519. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  520. return
  521. } else {
  522. bytes = &bs
  523. serialNumber = p.GetHeader().GetRequestID()
  524. }
  525. case global.PerformanceModifyContactRsp: // 履约修改联络信息回应
  526. var p pb.PerformanceModifyContactRsp
  527. if err = proto.Unmarshal(b, &p); err != nil {
  528. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  529. return
  530. }
  531. if bs, e := protojson.Marshal(&p); e != nil {
  532. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  533. return
  534. } else {
  535. bytes = &bs
  536. serialNumber = p.GetHeader().GetRequestID()
  537. }
  538. case global.GoodsFavoriteOperateRsp: // 商品收藏操作接口应答
  539. var p pb.GoodsFavoriteOperateRsp
  540. if err = proto.Unmarshal(b, &p); err != nil {
  541. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  542. return
  543. }
  544. if bs, e := protojson.Marshal(&p); e != nil {
  545. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  546. return
  547. } else {
  548. bytes = &bs
  549. serialNumber = p.GetHeader().GetRequestID()
  550. }
  551. case global.ZSBuyOrderListingRsp: // 钻石买挂牌接口应答
  552. var p pb.ZSBuyOrderListingRsp
  553. if err = proto.Unmarshal(b, &p); err != nil {
  554. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  555. return
  556. }
  557. if bs, e := protojson.Marshal(&p); e != nil {
  558. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  559. return
  560. } else {
  561. bytes = &bs
  562. serialNumber = p.GetHeader().GetRequestID()
  563. }
  564. case global.ZSSellOrderListingRsp: // 钻石卖挂牌接口响应
  565. var p pb.ZSSellOrderListingRsp
  566. if err = proto.Unmarshal(b, &p); err != nil {
  567. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  568. return
  569. }
  570. if bs, e := protojson.Marshal(&p); e != nil {
  571. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  572. return
  573. } else {
  574. bytes = &bs
  575. serialNumber = p.GetHeader().GetRequestID()
  576. }
  577. case global.ZSBuyOrderDestingRsp: // 钻石卖摘牌申请接口响应
  578. var p pb.ZSBuyOrderDestingRsp
  579. if err = proto.Unmarshal(b, &p); err != nil {
  580. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  581. return
  582. }
  583. if bs, e := protojson.Marshal(&p); e != nil {
  584. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  585. return
  586. } else {
  587. bytes = &bs
  588. serialNumber = p.GetHeader().GetRequestID()
  589. }
  590. case global.ZSSellOrderDestingApplyOperateRsp: // 钻石卖摘牌申请操作接口应答
  591. var p pb.ZSSellOrderDestingApplyOperateRsp
  592. if err = proto.Unmarshal(b, &p); err != nil {
  593. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  594. return
  595. }
  596. if bs, e := protojson.Marshal(&p); e != nil {
  597. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  598. return
  599. } else {
  600. bytes = &bs
  601. serialNumber = p.GetHeader().GetRequestID()
  602. }
  603. case global.ZSBuyOrderDestingNegPriceRsp: // 买摘牌询价接口应答
  604. var p pb.ZSBuyOrderDestingNegPriceRsp
  605. if err = proto.Unmarshal(b, &p); err != nil {
  606. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  607. return
  608. }
  609. if bs, e := protojson.Marshal(&p); e != nil {
  610. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  611. return
  612. } else {
  613. bytes = &bs
  614. serialNumber = p.GetHeader().GetRequestID()
  615. }
  616. case global.ZSBuyOrderDestingNegPriceOperateRsp: // 买摘牌询价操作接口应答
  617. var p pb.ZSBuyOrderDestingNegPriceOperateRsp
  618. if err = proto.Unmarshal(b, &p); err != nil {
  619. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  620. return
  621. }
  622. if bs, e := protojson.Marshal(&p); e != nil {
  623. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  624. return
  625. } else {
  626. bytes = &bs
  627. serialNumber = p.GetHeader().GetRequestID()
  628. }
  629. case global.WRListingCancelOrderRsp: // 挂牌撤单应答
  630. var p pb.WRListingCancelOrderRsp
  631. if err = proto.Unmarshal(b, &p); err != nil {
  632. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  633. return
  634. }
  635. if bs, e := protojson.Marshal(&p); e != nil {
  636. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  637. return
  638. } else {
  639. bytes = &bs
  640. serialNumber = p.GetHeader().GetRequestID()
  641. }
  642. case global.HdWROrderRsp:
  643. var p pb.HdWROrderRsp
  644. if err = proto.Unmarshal(b, &p); err != nil {
  645. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  646. return
  647. }
  648. if bs, e := protojson.Marshal(&p); e != nil {
  649. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  650. return
  651. } else {
  652. bytes = &bs
  653. serialNumber = p.GetHeader().GetRequestID()
  654. }
  655. case global.WROutApplyRsp:
  656. var p pb.WROutApplyRsp
  657. if err = proto.Unmarshal(b, &p); err != nil {
  658. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  659. return
  660. }
  661. if bs, e := protojson.Marshal(&p); e != nil {
  662. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  663. return
  664. } else {
  665. bytes = &bs
  666. serialNumber = p.GetHeader().GetRequestID()
  667. }
  668. case global.ReceiptZSOutApplyRsp: // 钻石出库申请接口响应
  669. var p pb.ReceiptZSOutApplyRsp
  670. if err = proto.Unmarshal(b, &p); err != nil {
  671. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  672. return
  673. }
  674. if bs, e := protojson.Marshal(&p); e != nil {
  675. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  676. return
  677. } else {
  678. bytes = &bs
  679. serialNumber = p.GetHeader().GetRequestID()
  680. }
  681. case global.SpotPresaleListingOrderRsp: // 铁合金现货预售挂牌接口应答
  682. var p pb.SpotPresaleListingOrderRsp
  683. if err = proto.Unmarshal(b, &p); err != nil {
  684. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  685. return
  686. }
  687. if bs, e := protojson.Marshal(&p); e != nil {
  688. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  689. return
  690. } else {
  691. bytes = &bs
  692. serialNumber = p.GetHeader().GetRequestID()
  693. }
  694. case global.CJJCMemberOperateRsp: // 出境检测会员操作响应
  695. var p pb.CJJCMemberOperateRsp
  696. if err = proto.Unmarshal(b, &p); err != nil {
  697. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  698. return
  699. }
  700. if bs, e := protojson.Marshal(&p); e != nil {
  701. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  702. return
  703. } else {
  704. bytes = &bs
  705. serialNumber = p.GetHeader().GetRequestID()
  706. }
  707. case global.BSFWMemberOperateRsp: // 保税服务会员操作响应
  708. var p pb.BSFWMemberOperateRsp
  709. if err = proto.Unmarshal(b, &p); err != nil {
  710. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  711. return
  712. }
  713. if bs, e := protojson.Marshal(&p); e != nil {
  714. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  715. return
  716. } else {
  717. bytes = &bs
  718. serialNumber = p.GetHeader().GetRequestID()
  719. }
  720. case global.AccountFundInfoRsp: // 账户资金信息响应
  721. var p pb.AccountFundInfoRsp
  722. if err = proto.Unmarshal(b, &p); err != nil {
  723. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  724. return
  725. }
  726. if bs, e := protojson.Marshal(&p); e != nil {
  727. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  728. return
  729. } else {
  730. bytes = &bs
  731. serialNumber = p.GetHeader().GetRequestID()
  732. }
  733. case global.GZPresaleApplyRsp: // 广钻预售申请响应
  734. var p pb.GZPresaleApplyRsp
  735. if err = proto.Unmarshal(b, &p); err != nil {
  736. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  737. return
  738. }
  739. if bs, e := protojson.Marshal(&p); e != nil {
  740. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  741. return
  742. } else {
  743. bytes = &bs
  744. serialNumber = p.GetHeader().GetRequestID()
  745. }
  746. case global.GZPresaleOrderRsp: // 广钻预售认购下单响应
  747. var p pb.GZPresaleOrderRsp
  748. if err = proto.Unmarshal(b, &p); err != nil {
  749. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  750. return
  751. }
  752. if bs, e := protojson.Marshal(&p); e != nil {
  753. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  754. return
  755. } else {
  756. bytes = &bs
  757. serialNumber = p.GetHeader().GetRequestID()
  758. }
  759. case global.GZCenterPurchaseApplyRsp: // 广钻集采申请响应
  760. var p pb.GZCenterPurchaseApplyRsp
  761. if err = proto.Unmarshal(b, &p); err != nil {
  762. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  763. return
  764. }
  765. if bs, e := protojson.Marshal(&p); e != nil {
  766. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  767. return
  768. } else {
  769. bytes = &bs
  770. serialNumber = p.GetHeader().GetRequestID()
  771. }
  772. case global.GZCenterPurchaseOrderRsp: // 广钻集采认购下单响应
  773. var p pb.GZCenterPurchaseOrderRsp
  774. if err = proto.Unmarshal(b, &p); err != nil {
  775. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  776. return
  777. }
  778. if bs, e := protojson.Marshal(&p); e != nil {
  779. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  780. return
  781. } else {
  782. bytes = &bs
  783. serialNumber = p.GetHeader().GetRequestID()
  784. }
  785. case global.BSWMSReckonPayRsp: // WMS结算单支付接口响应
  786. var p pb.BSWMSReckonPayRsp
  787. if err = proto.Unmarshal(b, &p); err != nil {
  788. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  789. return
  790. }
  791. if bs, e := protojson.Marshal(&p); e != nil {
  792. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  793. return
  794. } else {
  795. bytes = &bs
  796. serialNumber = p.GetHeader().GetRequestID()
  797. }
  798. case global.OrderRsp:
  799. var p pb.OrderRsp
  800. if err = proto.Unmarshal(b, &p); err != nil {
  801. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  802. return
  803. }
  804. if bs, e := protojson.Marshal(&p); e != nil {
  805. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  806. return
  807. } else {
  808. bytes = &bs
  809. serialNumber = p.GetHeader().GetRequestID()
  810. }
  811. case global.OfflineDeliveryApplyCancelOrderRsp:
  812. var p pb.OfflineDeliveryApplyCancelOrderRsp
  813. if err = proto.Unmarshal(b, &p); err != nil {
  814. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  815. return
  816. }
  817. if bs, e := protojson.Marshal(&p); e != nil {
  818. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  819. return
  820. } else {
  821. bytes = &bs
  822. serialNumber = p.GetHeader().GetRequestID()
  823. }
  824. case global.CancelOrderRsp:
  825. var p pb.CancelOrderRsp
  826. if err = proto.Unmarshal(b, &p); err != nil {
  827. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  828. return
  829. }
  830. if bs, e := protojson.Marshal(&p); e != nil {
  831. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  832. return
  833. } else {
  834. bytes = &bs
  835. serialNumber = p.GetHeader().GetRequestID()
  836. }
  837. case global.HolderCloseRsp:
  838. var p pb.HolderCloseRsp
  839. if err = proto.Unmarshal(b, &p); err != nil {
  840. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  841. return
  842. }
  843. if bs, e := protojson.Marshal(&p); e != nil {
  844. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  845. return
  846. } else {
  847. bytes = &bs
  848. serialNumber = p.GetHeader().GetRequestID()
  849. }
  850. case global.DeliveryOrderRsp:
  851. var p pb.DeliveryOrderRsp
  852. if err = proto.Unmarshal(b, &p); err != nil {
  853. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  854. return
  855. }
  856. if bs, e := protojson.Marshal(&p); e != nil {
  857. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  858. return
  859. } else {
  860. bytes = &bs
  861. serialNumber = p.GetHeader().GetRequestID()
  862. }
  863. case global.MakeUpDepositRsp:
  864. var p pb.MakeUpDepositRsp
  865. if err = proto.Unmarshal(b, &p); err != nil {
  866. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  867. return
  868. }
  869. if bs, e := protojson.Marshal(&p); e != nil {
  870. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  871. return
  872. } else {
  873. bytes = &bs
  874. serialNumber = p.GetHeader().GetRequestID()
  875. }
  876. case global.HoldAppendDepositRsp:
  877. var p pb.HoldAppendDepositRsp
  878. if err = proto.Unmarshal(b, &p); err != nil {
  879. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  880. return
  881. }
  882. if bs, e := protojson.Marshal(&p); e != nil {
  883. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  884. return
  885. } else {
  886. bytes = &bs
  887. serialNumber = p.GetHeader().GetRequestID()
  888. }
  889. case global.OfflineDeliveryRsp:
  890. var p pb.OfflineDeliveryRsp
  891. if err = proto.Unmarshal(b, &p); err != nil {
  892. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  893. return
  894. }
  895. if bs, e := protojson.Marshal(&p); e != nil {
  896. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  897. return
  898. } else {
  899. bytes = &bs
  900. serialNumber = p.GetHeader().GetRequestID()
  901. }
  902. case global.HdWRDealOrderRsp:
  903. var p pb.HdWRDealOrderRsp
  904. if err = proto.Unmarshal(b, &p); err != nil {
  905. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  906. return
  907. }
  908. if bs, e := protojson.Marshal(&p); e != nil {
  909. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  910. return
  911. } else {
  912. bytes = &bs
  913. serialNumber = p.GetHeader().GetRequestID()
  914. }
  915. case global.SupplementDepositRsp:
  916. var p pb.SupplementDepositRsp
  917. if err = proto.Unmarshal(b, &p); err != nil {
  918. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  919. return
  920. }
  921. if bs, e := protojson.Marshal(&p); e != nil {
  922. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  923. return
  924. } else {
  925. bytes = &bs
  926. serialNumber = p.GetHeader().GetRequestID()
  927. }
  928. case global.RefundedDepositRsp:
  929. var p pb.RefundedDepositRsp
  930. if err = proto.Unmarshal(b, &p); err != nil {
  931. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  932. return
  933. }
  934. if bs, e := protojson.Marshal(&p); e != nil {
  935. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  936. return
  937. } else {
  938. bytes = &bs
  939. serialNumber = p.GetHeader().GetRequestID()
  940. }
  941. case global.MarketOrderDeliveryApplyRsp:
  942. var p pb.MarketOrderDeliveryApplyRsp
  943. if err = proto.Unmarshal(b, &p); err != nil {
  944. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  945. return
  946. }
  947. if bs, e := protojson.Marshal(&p); e != nil {
  948. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  949. return
  950. } else {
  951. bytes = &bs
  952. serialNumber = p.GetHeader().GetRequestID()
  953. }
  954. case global.DeliveryClientOperatorRsp:
  955. var p pb.DeliveryClientOperatorRsp
  956. if err = proto.Unmarshal(b, &p); err != nil {
  957. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  958. return
  959. }
  960. if bs, e := protojson.Marshal(&p); e != nil {
  961. global.M2A_LOG.Error("总线回复数据反序列化失败", zap.Error(err))
  962. return
  963. } else {
  964. bytes = &bs
  965. serialNumber = p.GetHeader().GetRequestID()
  966. }
  967. }
  968. return
  969. }
  970. // RabbitMQSubscribeTopic 订阅主题
  971. func RabbitMQSubscribeTopic() (err error) {
  972. // 订阅需要的总线响应主题
  973. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_USER); err != nil {
  974. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  975. return
  976. }
  977. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_NTF); err != nil {
  978. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  979. return
  980. }
  981. if err = rabbitmq.SubscribeTopic(global.TOPIC_NOTIFY); err != nil {
  982. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  983. return
  984. }
  985. if err = rabbitmq.SubscribeTopic(global.TOPIC_NTF_CONTROL); err != nil {
  986. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  987. return
  988. }
  989. if err = rabbitmq.SubscribeTopic(global.TOPIC_RISK_NOTIFY); err != nil {
  990. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  991. return
  992. }
  993. if err = rabbitmq.SubscribeTopic(global.TOPIC_CLIENT_NTF); err != nil {
  994. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  995. return
  996. }
  997. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_QKERNEL); err != nil {
  998. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  999. return
  1000. }
  1001. if err = rabbitmq.SubscribeTopic(global.TOPIC_MANAGE_RSP); err != nil {
  1002. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1003. return
  1004. }
  1005. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_BANK); err != nil {
  1006. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1007. return
  1008. }
  1009. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_MONEY); err != nil {
  1010. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1011. return
  1012. }
  1013. if err = rabbitmq.SubscribeTopic(global.TOPIC_PERFORMANCE_RSP); err != nil {
  1014. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1015. return
  1016. }
  1017. if err = rabbitmq.SubscribeTopic(global.TOPIC_WAREHOUSE_RECIEPT_RSP); err != nil {
  1018. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1019. return
  1020. }
  1021. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_WAREHOUSE_TRADE); err != nil {
  1022. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1023. return
  1024. }
  1025. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_WAREHOUSE_TRADE_GZ); err != nil {
  1026. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1027. return
  1028. }
  1029. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_CJBS_TRADE_GZ); err != nil {
  1030. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1031. return
  1032. }
  1033. // 铁合金
  1034. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_WAREHOUSE_PRESALE_THJ); err != nil {
  1035. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1036. return
  1037. }
  1038. if err = rabbitmq.SubscribeTopic(global.TOPIC_MANAGER_THJ_NTF); err != nil {
  1039. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1040. return
  1041. }
  1042. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_WAREHOUSE_PRESALE_GZ); err != nil {
  1043. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1044. return
  1045. }
  1046. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_WAREHOUSE_CENTERPURCHASE_GZ); err != nil {
  1047. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1048. return
  1049. }
  1050. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_ORDER); err != nil {
  1051. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1052. return
  1053. }
  1054. if err = rabbitmq.SubscribeTopic(global.TOPIC_RSP_DELIVERY_TRADE); err != nil {
  1055. global.M2A_LOG.Error("rabbitmq subscribe topic failed, err:", zap.Error(err))
  1056. return
  1057. }
  1058. global.M2A_LOG.Info("rabbitmq subscribe topic successed.")
  1059. return
  1060. }
  1061. // StartRabbitMQReceive 开始接收总线消息
  1062. func StartRabbitMQReceive() {
  1063. t := &MQProc{}
  1064. go func() {
  1065. for _, subinfo := range rabbitmq.SubInfos {
  1066. rabbitmq.Receive(subinfo.Topic, subinfo.QueueName, t)
  1067. }
  1068. }()
  1069. }
  1070. // InitFuncodeTopic 初始化功能码主题MAP
  1071. func InitFuncodeTopic() {
  1072. if global.M2A_FuncodeTopic == nil {
  1073. global.M2A_FuncodeTopic = make(map[string][]int)
  1074. }
  1075. global.M2A_FuncodeTopic[global.TOPIC_REQ_QKERNEL] = []int{
  1076. global.ModifyPwdReq,
  1077. }
  1078. global.M2A_FuncodeTopic[global.TOPIC_MANAGE_REQ] = []int{
  1079. global.UserReceiveInfoReq,
  1080. global.DelUserReceiveInfoReq,
  1081. global.UserReceiveIsDefaultReq,
  1082. global.UserReceiptInfoReq,
  1083. global.DelUserReceiptInfoReq,
  1084. global.WarehouseApplyReq,
  1085. global.WROutApplyReq,
  1086. }
  1087. global.M2A_FuncodeTopic[global.TOPIC_REQ_BANK] = []int{
  1088. global.T2bBankSignReq,
  1089. global.T2bBankCancelSignReq,
  1090. global.T2bBankWithdrawReq,
  1091. global.T2bBankDepositReq,
  1092. global.T2bSMSVerificationCodeReq,
  1093. }
  1094. global.M2A_FuncodeTopic[global.TOPIC_REQ_MONEY] = []int{
  1095. global.AccountFundInfoReq,
  1096. }
  1097. global.M2A_FuncodeTopic[global.TOPIC_PERFORMANCE_REQ] = []int{
  1098. global.PerformanceContractedApplyReq,
  1099. global.PerformanceDelayApplyReq,
  1100. global.PerformanceManualConfirmReq,
  1101. global.PerformanceModifyContactReq,
  1102. }
  1103. global.M2A_FuncodeTopic[global.TOPIC_WAREHOUSE_RECIEPT] = []int{
  1104. global.ReceiptZSOutApplyReq,
  1105. }
  1106. global.M2A_FuncodeTopic[global.TOPIC_REQ_WAREHOUSE_TRADE] = []int{
  1107. global.WRListingCancelOrderReq,
  1108. global.HdWROrderReq,
  1109. global.HdWRDealOrderReq,
  1110. }
  1111. global.M2A_FuncodeTopic[global.TOPIC_REQ_WAREHOUSE_TRADE_GZ] = []int{
  1112. global.GoodsFavoriteOperateReq,
  1113. global.ZSBuyOrderListingReq,
  1114. global.ZSSellOrderListingReq,
  1115. global.ZSBuyOrderDestingReq,
  1116. global.ZSSellOrderDestingApplyReq,
  1117. global.ZSSellOrderDestingApplyOperateReq,
  1118. global.ZSBuyOrderDestingNegPriceReq,
  1119. global.ZSBuyOrderDestingNegPriceOperateReq,
  1120. }
  1121. global.M2A_FuncodeTopic[global.TOPIC_REQ_CJBS_TRADE_GZ] = []int{
  1122. global.CJJCMemberOperateReq,
  1123. global.BSFWMemberOperateReq,
  1124. global.BSWMSReckonPayReq,
  1125. }
  1126. // 铁合金
  1127. global.M2A_FuncodeTopic[global.TOPIC_REQ_WAREHOUSE_PRESALE_THJ] = []int{
  1128. global.SpotPresaleListingOrderReq,
  1129. }
  1130. global.M2A_FuncodeTopic[global.TOPIC_REQ_WAREHOUSE_PRESALE_GZ] = []int{
  1131. global.GZPresaleApplyReq,
  1132. global.GZPresaleOrderReq,
  1133. }
  1134. global.M2A_FuncodeTopic[global.TOPIC_REQ_WAREHOUSE_CENTERPURCHASE_GZ] = []int{
  1135. global.GZCenterPurchaseApplyReq,
  1136. global.GZCenterPurchaseOrderReq,
  1137. }
  1138. global.M2A_FuncodeTopic[global.TOPIC_REQ_ORDER] = []int{
  1139. global.OrderReq,
  1140. global.CancelOrderReq,
  1141. global.HolderCloseReq,
  1142. global.MakeUpDepositReq,
  1143. global.HoldAppendDepositReq,
  1144. global.OfflineDeliveryReq,
  1145. global.SupplementDepositReq,
  1146. global.RefundedDepositReq,
  1147. global.MarketOrderDeliveryApplyReq,
  1148. global.DeliveryClientOperatorReq,
  1149. global.OfflineDeliveryApplyCancelOrderReq,
  1150. }
  1151. global.M2A_FuncodeTopic[global.TOPIC_REQ_DELIVERY_TRADE] = []int{
  1152. global.DeliveryOrderReq,
  1153. }
  1154. global.M2A_FuncodeTopic[global.TOPIC_REQ_USER] = []int{
  1155. global.LoginReq,
  1156. }
  1157. }