node.py 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. import sys
  2. import json
  3. sys.path.append("..")
  4. import datetime
  5. import os
  6. import threading
  7. import time
  8. import async_communication as CM
  9. import message_pb2 as message
  10. import google.protobuf.text_format as tf
  11. import check_command_XmSgj as CHE_XmSgj
  12. import check_command_GyBhhy as CHE_GyBhhy
  13. import mytool.json_helper.parse_json as parse_json
  14. from http.server import HTTPServer, BaseHTTPRequestHandler
  15. from mytool.log_helper.logger import HandleLog
  16. def check_park_command(body):
  17. # print("接收停车指令 %s message:%s" % (datetime.datetime.now(), body))
  18. log.info("接收停车指令 %s message:%s" % (datetime.datetime.now(),body[0:250]))
  19. cmd = checker.entrance_isOK(body)
  20. park_cmd = message.park_table()
  21. park_cmd.CopyFrom(cmd)
  22. park_cmd.car_number_info.plate_full_image = ''
  23. park_cmd.car_number_info.plate_clip_image = ''
  24. response_port = "user_park_command_%d_response_port" % cmd.terminal_id
  25. dispatch_key = ""
  26. g_rabbitmq.publish(mq_config['mq_command_exchange_name'], response_port, tf.MessageToString(park_cmd, as_utf8=True))
  27. if cmd.statu.execute_statu == message.eNormal:
  28. # 指令检查正常
  29. log.info("停车指令 %s OK:%s 检查成功!\n" % (datetime.datetime.now(), tf.MessageToString(park_cmd, as_utf8=True)))
  30. dispatch_key = "dispatch_park_command_%d_request_port" % cmd.unit_id
  31. # if park_cmd.unit_id != 31 and park_cmd.unit_id != 32:
  32. request = checker.get_request_data(cmd, 'in')
  33. statu,response = checker.push_http_request(checker.get_in_url(), request)
  34. cmd.car_number_info.plate_full_image = ''
  35. cmd.car_number_info.plate_clip_image = ''
  36. if statu == message.eNormal:
  37. if ('Data' in response.keys()) and ('InPicUrl' in response['Data'].keys()):
  38. cmd.car_number_info.plate_full_image = response['Data']['InPicUrl']
  39. cmd.car_number_info.plate_clip_image = response['Data']['InPlateUrl']
  40. # else:
  41. # cmd.car_number_info.plate_full_image = ''
  42. # cmd.car_number_info.plate_clip_image = ''
  43. g_rabbitmq.publish(mq_config['mq_command_exchange_name'], dispatch_key, tf.MessageToString(cmd, as_utf8=True))
  44. else:
  45. cmd.car_number_info.plate_full_image = ''
  46. cmd.car_number_info.plate_clip_image = ''
  47. if cmd.statu.execute_statu == message.eWarning:
  48. log.warning("停车指令 %s 车牌号:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  49. datetime.datetime.now(), cmd.car_number,
  50. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  51. tf.MessageToString(cmd, as_utf8=True)))
  52. elif cmd.statu.execute_statu == message.eError:
  53. log.error("停车指令 %s 车牌号:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  54. datetime.datetime.now(), cmd.car_number,
  55. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  56. tf.MessageToString(cmd, as_utf8=True)))
  57. else:
  58. log.critical("停车指令 %s 车牌号:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  59. datetime.datetime.now(), cmd.car_number,
  60. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  61. tf.MessageToString(cmd, as_utf8=True)))
  62. def check_pick_command(body):
  63. log.info("接收取车指令 %s message:%s" % (datetime.datetime.now(), body))
  64. cmd = checker.exit_isOK(body)
  65. response_port = "user_pick_command_%d_response_port" % cmd.terminal_id
  66. dispatch_key = ""
  67. if cmd.statu.execute_statu == message.eNormal and cmd.statu.table_process_mod != message.PROCESS_ONLY_TO_PAY:
  68. # 指令检查正常
  69. log.info("取车指令 %s OK :%s 检查成功!\n" % (datetime.datetime.now(), tf.MessageToString(cmd, as_utf8=True)))
  70. dispatch_key = "dispatch_pick_command_%d_request_port" % cmd.unit_id
  71. g_rabbitmq.publish(mq_config['mq_command_exchange_name'], dispatch_key, tf.MessageToString(cmd, as_utf8=True))
  72. else:
  73. if cmd.statu.execute_statu == message.eWarning:
  74. log.warning("取车指令 %s 唯一码:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  75. datetime.datetime.now(), cmd.primary_key,
  76. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  77. tf.MessageToString(cmd, as_utf8=True)))
  78. elif cmd.statu.execute_statu == message.eError:
  79. log.error("取车指令 %s 唯一码:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  80. datetime.datetime.now(), cmd.primary_key,
  81. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  82. tf.MessageToString(cmd, as_utf8=True)))
  83. else:
  84. log.critical("取车指令 %s 唯一码:%s 检查失败!\n 发送反馈 交换机:%s 发送反馈端口:%s 反馈表单:%s" % (
  85. datetime.datetime.now(), cmd.primary_key,
  86. mq_config['mq_command_exchange_name'], response_port + "," + dispatch_key,
  87. tf.MessageToString(cmd, as_utf8=True)))
  88. if cmd.terminal_id != 0:
  89. g_rabbitmq.publish(mq_config['mq_command_exchange_name'], response_port, tf.MessageToString(cmd, as_utf8=True))
  90. else:
  91. return cmd
  92. class MyHttpRequestHandler(BaseHTTPRequestHandler):
  93. def _send_cors_headers(self):
  94. """ Sets headers required for CORS """
  95. self.send_header('Content-type', 'application/json')
  96. self.send_header("Access-Control-Allow-Origin", "*")
  97. self.send_header("Access-Control-Allow-Methods", "*")
  98. self.send_header("Access-Control-Allow-Headers", "Authorization, Content-Type")
  99. def do_POST(self):
  100. print('do_post:')
  101. datas = self.rfile.read(int(self.headers['content-length'])) # 固定格式,获取表单提交的数据
  102. self.send_response(200) # 返回状态码
  103. self.end_headers() # 返回响应头结束
  104. try:
  105. st = datas.decode('utf-8')
  106. res = json.loads(st)
  107. print(res)
  108. if ('data' in res.keys()) and ('InRecordId' in res['data'].keys()):
  109. primary_key = res['data']['InRecordId']
  110. table = message.pick_table()
  111. table.primary_key = primary_key
  112. # table.statu.table_process_mod = message.PROCESS_ONLY_TO_DISPATCH
  113. cmd = check_pick_command(tf.MessageToString(table, as_utf8=True))
  114. if cmd.statu.execute_statu == message.eNormal:
  115. buf = {"Message": "取车成功", "Tag": 1}
  116. else:
  117. buf = {"Message": cmd.statu.statu_description, "Tag": 0}
  118. else:
  119. buf = {"Message": "取车指令缺少关键字段Data或InRecordId!", "Tag": 0}
  120. # 以下是返回报文
  121. except Exception as e:
  122. buf = {"Message": "请求解析失败!", "Tag": 0}
  123. self.wfile.write(json.dumps(buf, ensure_ascii=False).encode('utf-8')) # 发送json格式的返回包体
  124. print(buf)
  125. def recv_post():
  126. ts = HTTPServer(('192.168.2.101', 8899), MyHttpRequestHandler)
  127. ts.serve_forever()
  128. if __name__ == '__main__':
  129. config = parse_json.parse_json_with_comments('./config.json')
  130. # 数据库配置
  131. db_config = config['db_config']
  132. # rabbitmq配置
  133. mq_config = config['mq_config']
  134. # 日志记录
  135. log = HandleLog.get_logger(os.getcwd()+'\\logs')
  136. # 消费指令消息
  137. cmd_callbacks = [["user_park_command_request_queue", check_park_command],
  138. ["user_pick_command_request_queue", check_pick_command]]
  139. if config['project_name'] == 'xm_sgj':
  140. checker = CHE_XmSgj.CommandChecker(db_config)
  141. elif config['project_name'] == 'gy_bhhy':
  142. checker = CHE_GyBhhy.CommandChecker(db_config)
  143. g_rabbitmq = CM.RabbitAsyncCommunicator(mq_config['mq_ip'], mq_config['mq_port'], mq_config['mq_user'], mq_config['mq_password'])
  144. g_rabbitmq.Init(cmd_callbacks, mq_config['mq_statu_exchange_keys'],"checker")
  145. for ex,key in mq_config['mq_statu_exchange_keys']:
  146. if key.find("dispatch") >= 0:
  147. g_rabbitmq.bind_statu_callback(ex,key,checker.receive_dispatch_statu)
  148. if key.find("measure") >= 0:
  149. g_rabbitmq.bind_statu_callback(ex,key,checker.receive_measure_info)
  150. t1 = threading.Thread(target=recv_post)
  151. g_rabbitmq.start()
  152. t1.start()
  153. g_rabbitmq.join()
  154. t1.join()