mirror of
https://github.com/oxen-io/lokinet.git
synced 2024-11-15 12:13:24 +00:00
46ad8d4058
- includes are now sorted in consistent, logical order; first step in an attempt to fix the tomfoolery (no relation to Tom) brought in by include-what-you-use - shuffled around some cmake linking to simplify dependency graph - superfluous files removed
51 lines
1.5 KiB
C++
51 lines
1.5 KiB
C++
#pragma once
|
|
#include <llarp/endpoint_base.hpp>
|
|
#include <llarp/net/ip_packet.hpp>
|
|
#include <llarp/net/net_int.hpp>
|
|
|
|
#include <functional>
|
|
#include <unordered_map>
|
|
|
|
namespace llarp::vpn
|
|
{
|
|
using AddressVariant_t = llarp::EndpointBase::AddressVariant_t;
|
|
using EgresPacketHandlerFunc = std::function<void(AddressVariant_t, net::IPPacket)>;
|
|
|
|
struct EgresLayer4Handler
|
|
{
|
|
virtual ~EgresLayer4Handler() = default;
|
|
|
|
virtual void
|
|
HandleIPPacketFrom(AddressVariant_t from, net::IPPacket pkt) = 0;
|
|
|
|
virtual void AddSubHandler(nuint16_t, EgresPacketHandlerFunc){};
|
|
virtual void RemoveSubHandler(nuint16_t){};
|
|
};
|
|
|
|
class EgresPacketRouter
|
|
{
|
|
EgresPacketHandlerFunc m_BaseHandler;
|
|
std::unordered_map<uint8_t, std::unique_ptr<EgresLayer4Handler>> m_IPProtoHandler;
|
|
|
|
public:
|
|
/// baseHandler will be called if no other handlers matches a packet
|
|
explicit EgresPacketRouter(EgresPacketHandlerFunc baseHandler);
|
|
|
|
/// feed in an ip packet for handling
|
|
void
|
|
HandleIPPacketFrom(AddressVariant_t, net::IPPacket pkt);
|
|
|
|
/// add a non udp packet handler using ip protocol proto
|
|
void
|
|
AddIProtoHandler(uint8_t proto, EgresPacketHandlerFunc func);
|
|
|
|
/// helper that adds a udp packet handler for UDP destinted for localport
|
|
void
|
|
AddUDPHandler(huint16_t localport, EgresPacketHandlerFunc func);
|
|
|
|
/// remove a udp handler that is already set up by bound port
|
|
void
|
|
RemoveUDPHandler(huint16_t localport);
|
|
};
|
|
} // namespace llarp::vpn
|