#include "router_mac.h" #include "helper_route_mac.h" #include #include #include RouterMac &RouterMac::Instance() { static RouterMac s; return s; } bool RouterMac::routeAdd(const QString &ipWithSubnet, const QString &gw) { QString ip = Utils::ipAddressFromIpWithSubnet(ipWithSubnet); QString mask = Utils::netMaskFromIpWithSubnet(ipWithSubnet); QString cmd; if (mask == "255.255.255.255") { cmd = QString("route add -host %1 %2").arg(ip).arg(gw); } else { cmd = QString("route add -net %1 %2 %3").arg(ip).arg(gw).arg(mask); } QStringList parts = cmd.split(" "); int argc = parts.size(); char **argv = new char*[argc]; for (int i = 0; i < argc; i++) { argv[i] = new char[parts.at(i).toStdString().length() + 1]; strcpy(argv[i], parts.at(i).toStdString().c_str()); } mainRouteIface(argc, argv); for (int i = 0; i < argc; i++) { delete [] argv[i]; } delete[] argv; return true; } int RouterMac::routeAddList(const QString &gw, const QStringList &ips) { int cnt = 0; for (const QString &ip: ips) { if (routeAdd(ip, gw)) cnt++; //QThread::msleep(10); } return cnt; } bool RouterMac::clearSavedRoutes() { // No need to delete routes after iface down return true; // int cnt = 0; // for (const QString &ip: m_addedRoutes) { // if (routeDelete(ip)) cnt++; // } // return (cnt == m_addedRoutes.count()); } bool RouterMac::routeDelete(const QString &ip, const QString &gw) { if (ip == "0.0.0.0") { qDebug().noquote() << "Warning, trying to remove default route, skipping: " << ip << gw; return true; } // route delete ip gw QProcess p; p.setProcessChannelMode(QProcess::MergedChannels); p.start("route", QStringList() << "delete" << ip); p.waitForFinished(); // skipping gw qDebug().noquote() << "routeDelete, skipping gw`: " << ip; qDebug().noquote() << "OUTPUT routeDelete: " << p.readAll(); return p.exitCode() == 0; } void RouterMac::flushDns() { // sudo killall -HUP mDNSResponder QProcess p; p.setProcessChannelMode(QProcess::MergedChannels); p.start("killall", QStringList() << "-HUP" << "mDNSResponder"); p.waitForFinished(); qDebug().noquote() << "OUTPUT killall -HUP mDNSResponder: " + p.readAll(); }