rabbitmq_communication.cpp 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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. // LOG(INFO) << "get message from " << p_msg->m_routing_key;
  20. return {};
  21. }
  22. //定时封装发送消息, 一般为心跳和状态信息, 需要子类重载
  23. Error_manager RabbitmqCommunicationTof3D::auto_encapsulate_status() {
  24. static int heart = 0;
  25. if (++heart > 999) {
  26. heart = 0;
  27. }
  28. measure_buffer rabbit_measure_info;
  29. DetectManager::DetectResult detect_measure_info;
  30. // 设备状态
  31. if (DeviceTof3D::iter()->getDeviceStatus() != SUCCESS) {
  32. rabbit_measure_info.mutable_measure_info_to_plc_forward()->set_ground_status(MeasureStatu::Lidar_Disconnect);
  33. }
  34. MeasureStatu measure_status = DetectManager::iter()->getMeasureResult(detect_measure_info);
  35. if (measure_status != MeasureStatu::Measure_OK) {
  36. rabbit_measure_info.mutable_measure_info_to_plc_forward()->set_ground_status(measure_status);
  37. }
  38. // 超界判断
  39. JetStream::MeasureInfo info;
  40. m_boundary.transMeasureInfo(detect_measure_info, info);
  41. m_boundary.limit(info);
  42. // 保存grpc数据中间块
  43. TransitData::MeasureInfo grpc_measure_info;
  44. m_boundary.transMeasureInfo(info, grpc_measure_info);
  45. grpc_measure_info.error.append("heart: " + std::to_string(heart));
  46. grpc_measure_info.error.append(detect_measure_info.info());
  47. TransitData::get_instance_pointer()->setMeasureInfo(grpc_measure_info);
  48. // 发送rabbitmq消息
  49. m_boundary.transMeasureInfo(info, rabbit_measure_info);
  50. encapsulate_status_msg(rabbit_measure_info.DebugString(), 0);
  51. return {};
  52. }
  53. Error_manager RabbitmqCommunicationTof3D::rabbitmq_init_from_protobuf(std::string prototxt_path) {
  54. m_boundary.init(ETC_PATH PROJECT_NAME "/limit.prototxt") ?
  55. printf("boundary init success.\n") :
  56. printf("boundary init failed form %s.\n", ETC_PATH PROJECT_NAME "/limit.prototxt");
  57. return Rabbitmq_base::rabbitmq_init_from_protobuf(prototxt_path);
  58. }