mqtt_send.py 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. '''
  2. 处理mqtt发送的消息
  3. '''
  4. import queue
  5. import json
  6. from enum import Enum
  7. import numpy
  8. import common.sys_comm as sys_comm
  9. from common.sys_comm import LOGDBG, LOGINFO, LOGWARN, LOGERR
  10. from common.sys_comm import POSE_CLASS_E, POSE_E
  11. from mqtt.mqtt_topics import TOPICS
  12. import mqtt.mqtt_process as mp
  13. # 消息类型
  14. class MSG_TYPE(Enum):
  15. MSG_DEV_STATUS = 0 # 设备状态变更
  16. MSG_DEV_RAW_POINTS = 1 # 实时点云
  17. MSG_REALTIME_TARGET = 2 # 实时目标位置
  18. MSG_EVENT_FALL = 3 # 跌倒事件
  19. MSG_EVENT_EXIST = 4 # 存在事件
  20. # 准备将消息通过 MQTT 发送
  21. def send_msg(topic:str, format_json:dict, qos:int=0):
  22. try:
  23. parts = topic.split('/')
  24. model = parts[1]
  25. if model != "dev":
  26. with sys_comm.g_sys_conf_mtx:
  27. format_json["sp_id"] = sys_comm.g_sys_conf["sp_id"]
  28. content:str = json.dumps(format_json)
  29. mqtt_msg = {
  30. "topic": topic,
  31. "msg": content,
  32. "qos": qos
  33. }
  34. mp.g_mqtt_client.send_msg(mqtt_msg)
  35. LOGINFO(f"send_msg, {topic}")
  36. except Exception as e:
  37. LOGERR(f"send_msg error: {e}")
  38. # 告警事件
  39. def alarm_event(
  40. dev_id: str,
  41. dev_name: str,
  42. uuid: str,
  43. plan_uuid: str,
  44. event_type: str,
  45. info: dict,
  46. linkage_action: dict,
  47. table: str):
  48. format_json = dict()
  49. format_json["dev_id"] = dev_id
  50. format_json["dev_name"] = dev_name
  51. format_json["uuid"] = uuid
  52. format_json["plan_uuid"] =plan_uuid
  53. format_json["event_type"] = event_type
  54. format_json["info"] = info
  55. format_json["linkage_action"] = linkage_action
  56. format_json["table"] = table
  57. send_msg(TOPICS.las_alarm_event, format_json, 2)
  58. # 测试
  59. def las_test_resp():
  60. module_name = sys_comm.g_sys_conf["module_name"]
  61. platform = sys_comm.g_sys_conf["platform"]
  62. host_ip = sys_comm.g_sys_conf["host_ip"]
  63. max_log_files = sys_comm.g_sys_conf["max_log_files"]
  64. max_log_size = sys_comm.g_sys_conf["max_log_size"]
  65. log_lvl = sys_comm.g_sys_conf["log_lvl"]
  66. sp_id = sys_comm.g_sys_conf["sp_id"]
  67. format_json = dict()
  68. format_json["module_name"] = module_name
  69. format_json["platform"] = platform
  70. format_json["host_ip"] = host_ip
  71. format_json["max_log_files"] = max_log_files
  72. format_json["max_log_size"] = max_log_size
  73. format_json["log_lvl"] = log_lvl
  74. format_json["sp_id"] = sp_id
  75. send_msg(TOPICS.las_test_resp, format_json, 2)
  76. # 测试
  77. def las_debug_info(plans_info:list):
  78. sp_id = sys_comm.g_sys_conf["sp_id"]
  79. format_json = dict()
  80. format_json["plans_info"] = plans_info
  81. format_json["sp_id"] = sp_id
  82. send_msg(TOPICS.las_test_resp, format_json, 2)