#ifdef VP_WITH_KAFKA #include "vp_json_kafka_broker_node.h" namespace vp_nodes { vp_json_kafka_broker_node::vp_json_kafka_broker_node(std::string node_name, std::string kafka_servers, std::string topic_name, vp_broke_for broke_for, int broking_cache_warn_threshold, int broking_cache_ignore_threshold): vp_msg_broker_node(node_name, broke_for, broking_cache_warn_threshold, broking_cache_ignore_threshold) { VP_INFO(vp_utils::string_format("[%s] kafka_servers:[%s] topic_name:[%s]", node_name.c_str(), kafka_servers.c_str(), topic_name.c_str())); kafka_producer = std::make_shared(kafka_servers, topic_name, 0); this->initialized(); } vp_json_kafka_broker_node::~vp_json_kafka_broker_node() { deinitialized(); stop_broking(); } void vp_json_kafka_broker_node::format_msg(const std::shared_ptr& meta, std::string& msg) { // serialize objects to json by cereal std::stringstream msg_stream; { cereal::JSONOutputArchive json_archive(msg_stream); // global values json_archive(cereal::make_nvp("channel_index", meta->channel_index), cereal::make_nvp("frame_index", meta->frame_index), cereal::make_nvp("width", meta->frame.cols), cereal::make_nvp("height", meta->frame.rows), cereal::make_nvp("fps", meta->fps), cereal::make_nvp("broke_for", broke_fors.at(broke_for))); // serialize values according to broke_for if (broke_for == vp_broke_for::NORMAL) { json_archive(cereal::make_nvp("target_size", meta->targets.size()), cereal::make_nvp("targets", meta->targets)); } else if (broke_for == vp_broke_for::FACE) { json_archive(cereal::make_nvp("face_target_size", meta->face_targets.size()), cereal::make_nvp("face_targets", meta->face_targets)); } else if (broke_for == vp_broke_for::TEXT) { json_archive(cereal::make_nvp("text_target_size", meta->text_targets.size()), cereal::make_nvp("text_targets", meta->text_targets)); } else { throw "invalid broke_for!"; } } // flush msg = msg_stream.str(); } void vp_json_kafka_broker_node::broke_msg(const std::string& msg) { // broke msg to kafka by kafka client api if (kafka_producer != nullptr) { kafka_producer->pushMessage(msg); } } } #endif