#!/usr/bin/env python3 #coding:utf-8 import paho.mqtt.client as mqtt import os import sys import time import utils import proto.flight_information_pb2 as flight_information_pb2 import proto.flyformatioln_pb2 as flyformatioln_pb2 import rospy from std_msgs.msg import String import logging def init_dataFormat(cfg:utils.Read_SUB_Config): if cfg.msg_format == "Proto": utils.Proto_msg_to_ros.rate = rospy.Rate(10) utils.Proto_msg_to_ros.publisher_Flight_Information = rospy.Publisher(cfg.ROStopicName_Flight_Information,String,queue_size=10) utils.Proto_msg_to_ros.publisher_Fly_Formation = rospy.Publisher(cfg.ROStopicName_Fly_Formation,String,queue_size=10) utils.Proto_msg_to_ros.flight_information_msg = flight_information_pb2.flight_information_message() utils.Proto_msg_to_ros.flyformatioln_msg = flyformatioln_pb2.fly_formation_message() client.message_callback_add(cfg.Flight_Information_topicToMqtt, utils.Proto_msg_to_ros.on_message_Flight_Information) client.message_callback_add(cfg.Fly_Formation_topicToMqtt, utils.Proto_msg_to_ros.on_message_Fly_Formation) utils.Proto_msg_to_ros.Flight_Information_topicToMqtt = cfg.Flight_Information_topicToMqtt utils.Proto_msg_to_ros.Fly_Formation_topicToMqtt = cfg.Fly_Formation_topicToMqtt elif cfg.msg_format == "Json": # set ros publisher utils.Json_msg_to_ros.rate = rospy.Rate(10) utils.Json_msg_to_ros.publisher_Fly_Formation = rospy.Publisher(cfg.ROStopicName_Fly_Formation,String,queue_size=10) utils.Json_msg_to_ros.Drone550_publisher_Flight_Information = rospy.Publisher(cfg.Dron550_ROStopicName_Flight_Information,String,queue_size=10) utils.Json_msg_to_ros.Drone380_publisher_Flight_Information = rospy.Publisher(cfg.Dron380_ROStopicName_Flight_Information,String,queue_size=10) utils.Json_msg_to_ros.Drone650_publisher_Flight_Information = rospy.Publisher(cfg.Dron650_ROStopicName_Flight_Information,String,queue_size=10) # set callback to each topic client.message_callback_add(cfg.Fly_Formation_topicToMqtt, utils.Json_msg_to_ros.on_message_Fly_Formation) client.message_callback_add(cfg.Drone550_Flight_Information_topicToMqtt, utils.Json_msg_to_ros.Drone550_on_message_Flight_Information) client.message_callback_add(cfg.Drone380_Flight_Information_topicToMqtt, utils.Json_msg_to_ros.Drone380_on_message_Flight_Information) client.message_callback_add(cfg.Drone650_Flight_Information_topicToMqtt, utils.Json_msg_to_ros.Drone650_on_message_Flight_Information) utils.Json_msg_to_ros.Flight_Information_topicToMqtt = cfg.Flight_Information_topicToMqtt utils.Json_msg_to_ros.Fly_Formation_topicToMqtt = cfg.Fly_Formation_topicToMqtt else: logger.debug("msg_format not found") def on_connect(self, userdata, flags, rc): logger.info("Connected with result code " + str(rc)) client.subscribe(cfg.Fly_Formation_topicToMqtt) client.subscribe(cfg.Drone550_Flight_Information_topicToMqtt) client.subscribe(cfg.Drone380_Flight_Information_topicToMqtt) client.subscribe(cfg.Drone650_Flight_Information_topicToMqtt) def on_disconnect(client, userdata, rc): logger.info("disconnecting reason " +str(rc)) client.connected_flag=False client.disconnect_flag=True def on_publish(self, userdata, mid): pass if __name__ == '__main__': # Read Config FilePath = os.path.join(os.path.dirname(__file__),"utils","mqttConfig_SUB.yml") cfg = utils.Read_SUB_Config(FilePath) client = utils.MQTTClient(cfg.MQTTClientNameSub) # set log log_format = "%(asctime)s - %(levelname)s - %(message)s" formatter = logging.Formatter(log_format) stream_handler = logging.StreamHandler() stream_handler.setFormatter(formatter) stream_handler.setLevel(logging.DEBUG) file_handler = logging.FileHandler(cfg.logFileName) file_handler.setFormatter(formatter) file_handler.setLevel(logging.INFO) logger = logging.getLogger(__name__) logger.setLevel(logging.DEBUG) logger.addHandler(file_handler) logger.addHandler(stream_handler) logger.info(cfg) # Mqtt client = utils.MQTTClient(cfg.MQTTClientNameSub) client.on_connect = on_connect client.on_publish = on_publish client.on_disconnect = on_disconnect client.connect(host=cfg.host, port=cfg.port, keepalive=cfg.keepalive) # Ros rospy.init_node(cfg.ROSClientNameSub) # initialize init_dataFormat(cfg) try: client.loop_start() rospy.spin() except BaseException as error: client.loop_stop() client.disconnect() logger.info("End of program") sys.exit(0)