working commit
This commit is contained in:
+16
-23
@@ -13,6 +13,11 @@ extern "C" {
|
|||||||
#include <uxlogger.hpp>
|
#include <uxlogger.hpp>
|
||||||
#include <networkaux.hpp>
|
#include <networkaux.hpp>
|
||||||
|
|
||||||
|
TunNetwork::TunNetwork(std::string iladdr, std::string iraddr) {
|
||||||
|
laddr = iladdr;
|
||||||
|
raddr = iraddr;
|
||||||
|
used = false;
|
||||||
|
}
|
||||||
|
|
||||||
TunService::TunService(int svcport, std::string itunnelnet, std::vector<std::string> ilocalnets) {
|
TunService::TunService(int svcport, std::string itunnelnet, std::vector<std::string> ilocalnets) {
|
||||||
listenport = svcport;
|
listenport = svcport;
|
||||||
@@ -42,7 +47,9 @@ std::expected<void, std::string> TunService::Init(void) {
|
|||||||
auto raddrRes = nethost(netaddr, prefix, i + 2);
|
auto raddrRes = nethost(netaddr, prefix, i + 2);
|
||||||
auto laddr = laddrRes.value();
|
auto laddr = laddrRes.value();
|
||||||
auto raddr = raddrRes.value();
|
auto raddr = raddrRes.value();
|
||||||
uxlogger.Debug(std::format("Networks: {} {}", laddr, raddr));
|
TunNetwork tunnet(laddr, raddr);
|
||||||
|
tunnets.push_back(tunnet);
|
||||||
|
uxlogger.Debug(std::format("Aviliable address: {} -- {}", laddr, raddr));
|
||||||
}
|
}
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
@@ -102,31 +109,17 @@ std::expected<void, std::string> TunService::Listen(void) {
|
|||||||
|
|
||||||
|
|
||||||
void TunService::Handle(int sock) {
|
void TunService::Handle(int sock) {
|
||||||
auto networkRes = network(tunnelnet);
|
std::string laddr, raddr;
|
||||||
if (!networkRes) {
|
for (auto& net: tunnets) {
|
||||||
uxlogger.Error(networkRes.error());
|
if (!net.used) {
|
||||||
return;
|
laddr = net.laddr;
|
||||||
}
|
raddr = net.raddr;
|
||||||
auto prefixRes = netprefix(tunnelnet);
|
net.used = true;
|
||||||
if (!prefixRes) {
|
break;
|
||||||
uxlogger.Error(prefixRes.error());
|
}
|
||||||
return;
|
|
||||||
}
|
|
||||||
int num = (sock - 3);
|
|
||||||
auto localaddrRes = nethost(networkRes.value(), prefixRes.value(), num);
|
|
||||||
if (!networkRes) {
|
|
||||||
uxlogger.Error(networkRes.error());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
auto remoteaddrRes = nethost(networkRes.value(), prefixRes.value(), num + 1);
|
|
||||||
if (!remoteaddrRes) {
|
|
||||||
uxlogger.Error(remoteaddrRes.error());
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
uxlogger.Debug("Start socker handler");
|
uxlogger.Debug("Start socker handler");
|
||||||
SocketHandler handler;
|
SocketHandler handler;
|
||||||
std::string laddr = localaddrRes.value();
|
|
||||||
std::string raddr = remoteaddrRes.value();
|
|
||||||
handler.Handle(sock, laddr, raddr, localnets);
|
handler.Handle(sock, laddr, raddr, localnets);
|
||||||
uxlogger.Debug("Stop socket handler");
|
uxlogger.Debug("Stop socket handler");
|
||||||
close(sock);
|
close(sock);
|
||||||
|
|||||||
+8
-2
@@ -8,15 +8,21 @@
|
|||||||
|
|
||||||
#include <sockhand.hpp>
|
#include <sockhand.hpp>
|
||||||
|
|
||||||
class NetworkSlot {
|
class TunNetwork {
|
||||||
|
public:
|
||||||
|
TunNetwork(std::string iladdr, std::string iraddr);
|
||||||
|
std::string laddr;
|
||||||
|
std::string raddr;
|
||||||
|
bool used;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class TunService {
|
class TunService {
|
||||||
private:
|
private:
|
||||||
std::string tunnelnet;
|
std::string tunnelnet;
|
||||||
std::vector<std::string> localnets;
|
std::vector<std::string> localnets;
|
||||||
std::vector<NetworkSlot> netslots;
|
std::vector<TunNetwork> tunnets;
|
||||||
int listenport;
|
int listenport;
|
||||||
int sock;
|
int sock;
|
||||||
public:
|
public:
|
||||||
|
|||||||
Reference in New Issue
Block a user