WLG/utility/search_dev.cpp

93 lines
3.5 KiB
C++
Raw Normal View History

2024-10-23 09:22:06 +08:00
#include "search_dev.hpp"
2024-10-22 19:04:25 +08:00
#include <unistd.h>
#include <fstream>
#include <iostream>
2024-10-23 20:33:05 +08:00
#include <zlog.h>
2024-10-22 19:04:25 +08:00
#include <boost/bind.hpp>
#include <boost/thread/thread.hpp>
2024-10-23 09:22:06 +08:00
2024-10-23 20:33:05 +08:00
extern zlog_category_t *zct;
2024-10-22 19:04:25 +08:00
static const char* MULTICAST_HOST_NAME1 = "224.0.0.1"; //组播接收平台搜索信号地址
static const int MULTICAST_PORT_RECV1 = 7301; //组播接收端口
static const int MULTICAST_PORT_SEND = 7302; //根据接收组播udp发送端口
SearchDev::SearchDev(boost::asio::io_service& ioservice) : mSockRecv_1(ioservice), mListenEP1(ip::udp::v4(), MULTICAST_PORT_RECV1), mSendEndpoint1(ip::address::from_string(MULTICAST_HOST_NAME1), MULTICAST_PORT_SEND) { Init(); }
SearchDev::~SearchDev() { Stop(); }
void SearchDev::Init() {
try {
mSockRecv_1.open(mListenEP1.protocol());
mSockRecv_1.set_option(ip::udp::socket::reuse_address(true));
mSockRecv_1.bind(mListenEP1);
mSockRecv_1.set_option(ip::multicast::join_group(ip::address_v4::from_string(MULTICAST_HOST_NAME1)));
mSockRecv_1.set_option(boost::asio::ip::multicast::enable_loopback(false));
} catch (boost::system::system_error& e) {
std::cout << e.what() << std::endl;
}
}
2024-10-23 20:33:05 +08:00
void SearchDev::GwRouteInit() {}
2024-10-22 19:04:25 +08:00
void SearchDev::HandleSend_1(const char* pMsg, const boost::system::error_code& pEc) {
if (pEc) {
2024-10-23 20:33:05 +08:00
zlog_info(zct, "send udp error 7302");
2024-10-22 19:04:25 +08:00
} else {
2024-10-23 20:33:05 +08:00
zlog_info(zct, "send udp ok 7302");
2024-10-22 19:04:25 +08:00
}
}
void SearchDev::MultiCastRecv() { MultiCastRecv_1(); }
void SearchDev::MultiCastRecv_1() {
memset(mRecvBuf1, 0, BUF_LENGTH);
mSockRecv_1.async_receive_from(boost::asio::buffer(mRecvBuf1, BUF_LENGTH), mRecvEP1, boost::bind(&SearchDev::HandleRecv_1, this, boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred));
}
void SearchDev::HandleRecv_1(const boost::system::error_code& pEc, size_t pBytesRecv) {
if (!pEc) {
2024-10-23 20:33:05 +08:00
zlog_info(zct, "mRecvBuf1 : %s", mRecvBuf1);
2024-10-22 19:04:25 +08:00
std::string data = std::string(mRecvBuf1);
Json::Value jsData;
Json::Reader recvReader;
Json::Value JsonVal;
Json::FastWriter fw;
if (recvReader.parse(data, jsData)) {
int cmdType = atoi(jsData["cmd"].asString().c_str());
switch (cmdType) {
case 4: {
std::string status = jsData["status"].asString();
if (status.compare("REQ") == 0) {
jsData["dataWatchNo"] = GlobalConfig::MacAddr_G.c_str();
jsData["localServerIpAddress"] = GlobalConfig::IpAddr_G;
jsData["status"] = "ACK";
jsData["DeviceType"] = "WirelessGateWay";
std::string strData = fw.write(jsData);
2024-10-23 20:33:05 +08:00
zlog_info(zct, "send info %s ip: %s\n", strData.c_str(), mRecvEP1.address().to_string().c_str());
2024-10-22 19:04:25 +08:00
ip::udp::endpoint remoteEP(ip::address::from_string(mRecvEP1.address().to_string()), MULTICAST_PORT_SEND);
mSockRecv_1.async_send_to(boost::asio::buffer(strData), remoteEP, boost::bind(&SearchDev::HandleSend_1, this, "SockRecv_1_1", boost::asio::placeholders::error));
}
} break;
default: break;
}
} else {
2024-10-23 20:33:05 +08:00
zlog_error(zct, "parse error\n");
2024-10-22 19:04:25 +08:00
}
MultiCastRecv_1();
} else {
}
}
void SearchDev::Run() {
// mIoSev.run();
}
void SearchDev::Stop() {
// if (!mIoSev.stopped())
// mIoSev.stop();
}
void SearchDev::Restart() { Init(); }