mirror of https://github.com/nostar/urfd.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
124 lines
3.6 KiB
124 lines
3.6 KiB
// Copyright © 2019 Marius Petrescu (YO2LOJ). All rights reserved.
|
|
|
|
// urfd -- The universal reflector
|
|
// Copyright © 2021 Thomas A. Early N7TAE
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
|
|
#include "Defines.h"
|
|
#include "Timer.h"
|
|
#include "SEProtocol.h"
|
|
#include "DVHeaderPacket.h"
|
|
#include "DVFramePacket.h"
|
|
#include "RawSocket.h"
|
|
#include "UDPMsgSocket.h"
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
// note on the G3 terminal/AP protocol:
|
|
//
|
|
// There are 3 steps in handling an incoming connection
|
|
//
|
|
// 1 - Notification of terminal call on port UDP 12346, Presence port, a CUdpSocket.
|
|
// - Call will be rejected if in blacklisted
|
|
//
|
|
// 2 - Destination request on port UDP 12345, Config port, a CUdpMsgSocket.
|
|
// - Calls to specific callsigns will be accepted for a default module
|
|
// - Repeater calls will be accepted for local modules
|
|
// - All other calls are rejected
|
|
//
|
|
// 3 - Actual D-star flow like in Dextra to/from port 40000
|
|
// 2 distinct sockets where used in the initial protocol
|
|
// later firmwares implement a single bidirectional socket
|
|
//
|
|
// Alive monitoring is done via a "PING" to remote port 40000. We will get an
|
|
// ICMP unreachable on terminal mode close or on station shut down if routing is done
|
|
// correctly. Otherwise a long timeout is used (e.g. 1h)
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////
|
|
// class
|
|
|
|
class CG3Protocol : public CSEProtocol
|
|
{
|
|
public:
|
|
// constructor
|
|
CG3Protocol() : m_GwAddress(0u), m_Modules("*"), m_LastModTime(0) {}
|
|
|
|
// initialization
|
|
bool Initialize(const char *type, const EProtocol ptype, const uint16_t port, const bool has_ipv4, const bool has_ipv6);
|
|
|
|
// close
|
|
void Close(void);
|
|
|
|
// task
|
|
void Task(void);
|
|
|
|
protected:
|
|
// threads
|
|
void PresenceThread(void);
|
|
void ConfigThread(void);
|
|
void IcmpThread(void);
|
|
|
|
// helper tasks
|
|
void PresenceTask(void);
|
|
void ConfigTask(void);
|
|
void IcmpTask(void);
|
|
|
|
// config
|
|
void ReadOptions(void);
|
|
|
|
// helper
|
|
char *TrimWhiteSpaces(char *);
|
|
void NeedReload(void);
|
|
|
|
// queue helper
|
|
void HandleQueue(void);
|
|
|
|
// keepalive helpers
|
|
void HandleKeepalives(void);
|
|
|
|
// stream helpers
|
|
void OnDvHeaderPacketIn(std::unique_ptr<CDvHeaderPacket> &, const CIp &);
|
|
|
|
// packet decoding helpers
|
|
bool IsValidDvHeaderPacket(const CBuffer &, std::unique_ptr<CDvHeaderPacket> &);
|
|
bool IsValidDvFramePacket(const CBuffer &, std::unique_ptr<CDvFramePacket> &);
|
|
|
|
// packet encoding helpers
|
|
bool EncodeDvHeaderPacket(const CDvHeaderPacket &, CBuffer &) const;
|
|
bool EncodeDvFramePacket(const CDvFramePacket &, CBuffer &) const;
|
|
|
|
protected:
|
|
std::future<void> m_PresenceFuture, m_ConfigFuture, m_IcmpFuture;
|
|
|
|
// time
|
|
CTimer m_LastKeepaliveTime;
|
|
|
|
// sockets
|
|
CUdpSocket m_PresenceSocket;
|
|
CUdpMsgSocket m_ConfigSocket;
|
|
CRawSocket m_IcmpRawSocket;
|
|
|
|
// optional params
|
|
uint32_t m_GwAddress;
|
|
std::string m_Modules;
|
|
time_t m_LastModTime;
|
|
std::string m_TerminalPath;
|
|
};
|