rabbitmq_communication.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #include "rabbitmq_communication.h"
  2. RabbitmqCommunicationTof3D::RabbitmqCommunicationTof3D() = default;
  3. RabbitmqCommunicationTof3D::~RabbitmqCommunicationTof3D() = default;
  4. //检查消息是否有效, 主要检查消息类型和接受者, 判断这条消息是不是给我的.
  5. Error_manager RabbitmqCommunicationTof3D::check_msg(Rabbitmq_message *p_msg) {
  6. return {SUCCESS, NORMAL, "Don't check any message."};
  7. }
  8. //检查执行者的状态, 判断能否处理这条消息, 需要子类重载
  9. Error_manager RabbitmqCommunicationTof3D::check_executer(Rabbitmq_message *p_msg) {
  10. return {SUCCESS, NORMAL, "Don't check any message."};
  11. }
  12. //处理消息, 需要子类重载
  13. Error_manager RabbitmqCommunicationTof3D::execute_msg(Rabbitmq_message *p_msg) {
  14. Error_manager ret;
  15. return ret;
  16. }
  17. //处理消息, 需要子类重载
  18. Error_manager RabbitmqCommunicationTof3D::execute_time_consume_msg(Rabbitmq_message *p_msg) {
  19. if (p_msg->m_routing_key.find("dispatch_") != std::string::npos &&
  20. p_msg->m_routing_key.find("_statu_port") != std::string::npos) {
  21. dispatch_node_statu t_dispatch_node_statu;
  22. if(google::protobuf::TextFormat::ParseFromString(p_msg->m_message_buf, &t_dispatch_node_statu))
  23. {
  24. // TODO:开关门控制算法流程
  25. // usleep(5 * 1000 * 1000);
  26. // DetectManager::iter()->Stop();
  27. // DeviceTof3D::iter()->Stop();
  28. //
  29. // usleep(5 * 1000 * 1000);
  30. // DeviceTof3D::iter()->Continue();
  31. // DetectManager::iter()->Continue();
  32. }
  33. }
  34. //终端点击存车时, 发送存车表单给检查节点, 这里顺便发送给感测节点.
  35. if (p_msg->m_routing_key == "user_park_command_request_port") {
  36. park_table t_park_table_msg; //存车表单
  37. if(google::protobuf::TextFormat::ParseFromString(p_msg->m_message_buf, &t_park_table_msg))
  38. {
  39. // TODO:从算法取数据保存
  40. }
  41. }
  42. return {};
  43. }
  44. //定时封装发送消息, 一般为心跳和状态信息, 需要子类重载
  45. Error_manager RabbitmqCommunicationTof3D::auto_encapsulate_status() {
  46. static int heart = 0;
  47. if (++heart > 999) {
  48. heart = 0;
  49. }
  50. measure_buffer rabbit_measure_info;
  51. DetectManager::DetectResult detect_measure_info;
  52. // 设备状态
  53. if (DeviceTof3D::iter()->getDeviceStatus() != SUCCESS) {
  54. rabbit_measure_info.mutable_measure_info_to_plc_forward()->set_ground_status(MeasureStatu::Lidar_Disconnect);
  55. }
  56. MeasureStatu measure_status = DetectManager::iter()->getMeasureResult(detect_measure_info);
  57. if (measure_status != MeasureStatu::Measure_OK) {
  58. rabbit_measure_info.mutable_measure_info_to_plc_forward()->set_ground_status(measure_status);
  59. }
  60. // 超界判断
  61. JetStream::MeasureInfo info;
  62. m_boundary.transMeasureInfo(detect_measure_info, info);
  63. m_boundary.limit(info);
  64. // 保存grpc数据中间块
  65. TransitData::MeasureInfo grpc_measure_info;
  66. m_boundary.transMeasureInfo(info, grpc_measure_info);
  67. grpc_measure_info.error.append("heart: " + std::to_string(heart));
  68. grpc_measure_info.error.append(detect_measure_info.info());
  69. TransitData::get_instance_pointer()->setMeasureInfo(grpc_measure_info);
  70. // 发送rabbitmq消息
  71. m_boundary.transMeasureInfo(info, rabbit_measure_info);
  72. encapsulate_status_msg(rabbit_measure_info.DebugString(), 0);
  73. return {};
  74. }
  75. Error_manager RabbitmqCommunicationTof3D::rabbitmq_init_from_protobuf(std::string prototxt_path) {
  76. m_boundary.init(ETC_PATH PROJECT_NAME "/limit.prototxt") ?
  77. printf("boundary init success.\n") :
  78. printf("boundary init failed form %s.\n", ETC_PATH PROJECT_NAME "/limit.prototxt");
  79. return Rabbitmq_base::rabbitmq_init_from_protobuf(prototxt_path);
  80. }