|
|
|
@ -19,7 +19,7 @@
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Foobar. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// along with Foobar. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
#include "main.h"
|
|
|
|
#include "main.h"
|
|
|
|
@ -87,28 +87,28 @@ CReflector::~CReflector()
|
|
|
|
bool CReflector::Start(void)
|
|
|
|
bool CReflector::Start(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
bool ok = true;
|
|
|
|
bool ok = true;
|
|
|
|
|
|
|
|
|
|
|
|
// reset stop flag
|
|
|
|
// reset stop flag
|
|
|
|
m_bStopThreads = false;
|
|
|
|
m_bStopThreads = false;
|
|
|
|
|
|
|
|
|
|
|
|
// init gate keeper
|
|
|
|
// init gate keeper
|
|
|
|
ok &= g_GateKeeper.Init();
|
|
|
|
ok &= g_GateKeeper.Init();
|
|
|
|
|
|
|
|
|
|
|
|
// create protocols
|
|
|
|
// create protocols
|
|
|
|
ok &= m_Protocols.Init();
|
|
|
|
ok &= m_Protocols.Init();
|
|
|
|
|
|
|
|
|
|
|
|
// start one thread per reflector module
|
|
|
|
// start one thread per reflector module
|
|
|
|
for ( int i = 0; i < NB_OF_MODULES; i++ )
|
|
|
|
for ( int i = 0; i < NB_OF_MODULES; i++ )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
m_RouterThreads[i] = new std::thread(CReflector::RouterThread, this, &(m_Streams[i]));
|
|
|
|
m_RouterThreads[i] = new std::thread(CReflector::RouterThread, this, &(m_Streams[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// start the reporting threads
|
|
|
|
// start the reporting threads
|
|
|
|
m_XmlReportThread = new std::thread(CReflector::XmlReportThread, this);
|
|
|
|
m_XmlReportThread = new std::thread(CReflector::XmlReportThread, this);
|
|
|
|
#ifdef JSON_MONITOR
|
|
|
|
#ifdef JSON_MONITOR
|
|
|
|
m_JsonReportThread = new std::thread(CReflector::JsonReportThread, this);
|
|
|
|
m_JsonReportThread = new std::thread(CReflector::JsonReportThread, this);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
// done
|
|
|
|
// done
|
|
|
|
return ok;
|
|
|
|
return ok;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -117,7 +117,7 @@ void CReflector::Stop(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// stop & delete all threads
|
|
|
|
// stop & delete all threads
|
|
|
|
m_bStopThreads = true;
|
|
|
|
m_bStopThreads = true;
|
|
|
|
|
|
|
|
|
|
|
|
// stop & delete report threads
|
|
|
|
// stop & delete report threads
|
|
|
|
if ( m_XmlReportThread != NULL )
|
|
|
|
if ( m_XmlReportThread != NULL )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
@ -131,7 +131,7 @@ void CReflector::Stop(void)
|
|
|
|
delete m_JsonReportThread;
|
|
|
|
delete m_JsonReportThread;
|
|
|
|
m_JsonReportThread = NULL;
|
|
|
|
m_JsonReportThread = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// stop & delete all router thread
|
|
|
|
// stop & delete all router thread
|
|
|
|
for ( int i = 0; i < NB_OF_MODULES; i++ )
|
|
|
|
for ( int i = 0; i < NB_OF_MODULES; i++ )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
@ -142,10 +142,10 @@ void CReflector::Stop(void)
|
|
|
|
m_RouterThreads[i] = NULL;
|
|
|
|
m_RouterThreads[i] = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// close protocols
|
|
|
|
// close protocols
|
|
|
|
m_Protocols.Close();
|
|
|
|
m_Protocols.Close();
|
|
|
|
|
|
|
|
|
|
|
|
// close gatekeeper
|
|
|
|
// close gatekeeper
|
|
|
|
g_GateKeeper.Close();
|
|
|
|
g_GateKeeper.Close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -161,10 +161,10 @@ bool CReflector::IsStreaming(char module)
|
|
|
|
CPacketStream *CReflector::OpenStream(CDvHeaderPacket *DvHeader, CClient *client)
|
|
|
|
CPacketStream *CReflector::OpenStream(CDvHeaderPacket *DvHeader, CClient *client)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CPacketStream *retStream = NULL;
|
|
|
|
CPacketStream *retStream = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
// clients MUST have bee locked by the caller
|
|
|
|
// clients MUST have bee locked by the caller
|
|
|
|
// so we can freely access it within the fuction
|
|
|
|
// so we can freely access it within the fuction
|
|
|
|
|
|
|
|
|
|
|
|
// check if client is valid candidate
|
|
|
|
// check if client is valid candidate
|
|
|
|
if ( m_Clients.IsClient(client) && !client->IsAMaster() )
|
|
|
|
if ( m_Clients.IsClient(client) && !client->IsAMaster() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
@ -181,14 +181,14 @@ CPacketStream *CReflector::OpenStream(CDvHeaderPacket *DvHeader, CClient *client
|
|
|
|
// stream open, mark client as master
|
|
|
|
// stream open, mark client as master
|
|
|
|
// so that it can't be deleted
|
|
|
|
// so that it can't be deleted
|
|
|
|
client->SetMasterOfModule(module);
|
|
|
|
client->SetMasterOfModule(module);
|
|
|
|
|
|
|
|
|
|
|
|
// update last heard time
|
|
|
|
// update last heard time
|
|
|
|
client->Heard();
|
|
|
|
client->Heard();
|
|
|
|
retStream = stream;
|
|
|
|
retStream = stream;
|
|
|
|
|
|
|
|
|
|
|
|
// and push header packet
|
|
|
|
// and push header packet
|
|
|
|
stream->Push(DvHeader);
|
|
|
|
stream->Push(DvHeader);
|
|
|
|
|
|
|
|
|
|
|
|
// report
|
|
|
|
// report
|
|
|
|
std::cout << "Opening stream on module " << module << " for client " << client->GetCallsign()
|
|
|
|
std::cout << "Opening stream on module " << module << " for client " << client->GetCallsign()
|
|
|
|
<< " with sid " << DvHeader->GetStreamId() << std::endl;
|
|
|
|
<< " with sid " << DvHeader->GetStreamId() << std::endl;
|
|
|
|
@ -225,33 +225,33 @@ void CReflector::CloseStream(CPacketStream *stream)
|
|
|
|
CTimePoint::TaskSleepFor(10);
|
|
|
|
CTimePoint::TaskSleepFor(10);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} while (!bEmpty);
|
|
|
|
} while (!bEmpty);
|
|
|
|
|
|
|
|
|
|
|
|
// lock it
|
|
|
|
// lock it
|
|
|
|
stream->Lock();
|
|
|
|
stream->Lock();
|
|
|
|
|
|
|
|
|
|
|
|
// lock clients
|
|
|
|
// lock clients
|
|
|
|
GetClients();
|
|
|
|
GetClients();
|
|
|
|
|
|
|
|
|
|
|
|
// get and check the master
|
|
|
|
// get and check the master
|
|
|
|
CClient *client = stream->GetOwnerClient();
|
|
|
|
CClient *client = stream->GetOwnerClient();
|
|
|
|
if ( client != NULL )
|
|
|
|
if ( client != NULL )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// client no longer a master
|
|
|
|
// client no longer a master
|
|
|
|
client->NotAMaster();
|
|
|
|
client->NotAMaster();
|
|
|
|
|
|
|
|
|
|
|
|
// notify
|
|
|
|
// notify
|
|
|
|
g_Reflector.OnStreamClose(stream->GetUserCallsign());
|
|
|
|
g_Reflector.OnStreamClose(stream->GetUserCallsign());
|
|
|
|
|
|
|
|
|
|
|
|
std::cout << "Closing stream of module " << GetStreamModule(stream) << std::endl;
|
|
|
|
std::cout << "Closing stream of module " << GetStreamModule(stream) << std::endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// stop the queue
|
|
|
|
// stop the queue
|
|
|
|
stream->Close();
|
|
|
|
stream->Close();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// release clients
|
|
|
|
// release clients
|
|
|
|
ReleaseClients();
|
|
|
|
ReleaseClients();
|
|
|
|
|
|
|
|
|
|
|
|
// and unlock
|
|
|
|
// and unlock
|
|
|
|
stream->Unlock();
|
|
|
|
stream->Unlock();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -264,10 +264,10 @@ void CReflector::RouterThread(CReflector *This, CPacketStream *streamIn)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// get our module
|
|
|
|
// get our module
|
|
|
|
uint8 uiModuleId = This->GetStreamModule(streamIn);
|
|
|
|
uint8 uiModuleId = This->GetStreamModule(streamIn);
|
|
|
|
|
|
|
|
|
|
|
|
// get on input queue
|
|
|
|
// get on input queue
|
|
|
|
CPacket *packet;
|
|
|
|
CPacket *packet;
|
|
|
|
|
|
|
|
|
|
|
|
while ( !This->m_bStopThreads )
|
|
|
|
while ( !This->m_bStopThreads )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// any packet in our input queue ?
|
|
|
|
// any packet in our input queue ?
|
|
|
|
@ -283,31 +283,31 @@ void CReflector::RouterThread(CReflector *This, CPacketStream *streamIn)
|
|
|
|
packet = NULL;
|
|
|
|
packet = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
streamIn->Unlock();
|
|
|
|
streamIn->Unlock();
|
|
|
|
|
|
|
|
|
|
|
|
// route it
|
|
|
|
// route it
|
|
|
|
if ( packet != NULL )
|
|
|
|
if ( packet != NULL )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// set origin
|
|
|
|
// set origin
|
|
|
|
packet->SetModuleId(uiModuleId);
|
|
|
|
packet->SetModuleId(uiModuleId);
|
|
|
|
|
|
|
|
|
|
|
|
// iterate on all protocols
|
|
|
|
// iterate on all protocols
|
|
|
|
for ( int i = 0; i < This->m_Protocols.Size(); i++ )
|
|
|
|
for ( int i = 0; i < This->m_Protocols.Size(); i++ )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// duplicate packet
|
|
|
|
// duplicate packet
|
|
|
|
CPacket *packetClone = packet->Duplicate();
|
|
|
|
CPacket *packetClone = packet->Duplicate();
|
|
|
|
|
|
|
|
|
|
|
|
// get protocol
|
|
|
|
// get protocol
|
|
|
|
CProtocol *protocol = This->m_Protocols.GetProtocol(i);
|
|
|
|
CProtocol *protocol = This->m_Protocols.GetProtocol(i);
|
|
|
|
|
|
|
|
|
|
|
|
// if packet is header, update RPT2 according to protocol
|
|
|
|
// if packet is header, update RPT2 according to protocol
|
|
|
|
if ( packetClone->IsDvHeader() )
|
|
|
|
if ( packetClone->IsDvHeader() )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// get our callsign
|
|
|
|
// get our callsign
|
|
|
|
CCallsign csRPT = protocol->GetReflectorCallsign();
|
|
|
|
CCallsign csRPT = protocol->GetReflectorCallsign();
|
|
|
|
csRPT.SetModule(This->GetStreamModule(streamIn));
|
|
|
|
csRPT.SetModule(This->GetStreamModule(streamIn));
|
|
|
|
((CDvHeaderPacket *)packetClone)->SetRpt2Callsign(csRPT);
|
|
|
|
((CDvHeaderPacket *)packetClone)->SetRpt2Callsign(csRPT);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// and push it
|
|
|
|
// and push it
|
|
|
|
CPacketQueue *queue = protocol->GetQueue();
|
|
|
|
CPacketQueue *queue = protocol->GetQueue();
|
|
|
|
queue->push(packetClone);
|
|
|
|
queue->push(packetClone);
|
|
|
|
@ -317,7 +317,7 @@ void CReflector::RouterThread(CReflector *This, CPacketStream *streamIn)
|
|
|
|
delete packet;
|
|
|
|
delete packet;
|
|
|
|
packet = NULL;
|
|
|
|
packet = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// wait a bit
|
|
|
|
// wait a bit
|
|
|
|
CTimePoint::TaskSleepFor(10);
|
|
|
|
CTimePoint::TaskSleepFor(10);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -341,7 +341,11 @@ void CReflector::XmlReportThread(CReflector *This)
|
|
|
|
// and close file
|
|
|
|
// and close file
|
|
|
|
xmlFile.close();
|
|
|
|
xmlFile.close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::cout << "Failed to open " << XML_PATH << std::endl;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// and wait a bit
|
|
|
|
// and wait a bit
|
|
|
|
CTimePoint::TaskSleepFor(XML_UPDATE_PERIOD * 1000);
|
|
|
|
CTimePoint::TaskSleepFor(XML_UPDATE_PERIOD * 1000);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -353,10 +357,10 @@ void CReflector::JsonReportThread(CReflector *This)
|
|
|
|
CBuffer Buffer;
|
|
|
|
CBuffer Buffer;
|
|
|
|
CIp Ip;
|
|
|
|
CIp Ip;
|
|
|
|
bool bOn;
|
|
|
|
bool bOn;
|
|
|
|
|
|
|
|
|
|
|
|
// init variable
|
|
|
|
// init variable
|
|
|
|
bOn = false;
|
|
|
|
bOn = false;
|
|
|
|
|
|
|
|
|
|
|
|
// create listening socket
|
|
|
|
// create listening socket
|
|
|
|
if ( Socket.Open(JSON_PORT) )
|
|
|
|
if ( Socket.Open(JSON_PORT) )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
@ -370,26 +374,26 @@ void CReflector::JsonReportThread(CReflector *This)
|
|
|
|
if ( Buffer.Compare((uint8 *)"hello", 5) == 0 )
|
|
|
|
if ( Buffer.Compare((uint8 *)"hello", 5) == 0 )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::cout << "Monitor socket connected with " << Ip << std::endl;
|
|
|
|
std::cout << "Monitor socket connected with " << Ip << std::endl;
|
|
|
|
|
|
|
|
|
|
|
|
// connected
|
|
|
|
// connected
|
|
|
|
bOn = true;
|
|
|
|
bOn = true;
|
|
|
|
|
|
|
|
|
|
|
|
// announce ourselves
|
|
|
|
// announce ourselves
|
|
|
|
This->SendJsonReflectorObject(Socket, Ip);
|
|
|
|
This->SendJsonReflectorObject(Socket, Ip);
|
|
|
|
|
|
|
|
|
|
|
|
// dump tables
|
|
|
|
// dump tables
|
|
|
|
This->SendJsonNodesObject(Socket, Ip);
|
|
|
|
This->SendJsonNodesObject(Socket, Ip);
|
|
|
|
This->SendJsonStationsObject(Socket, Ip);
|
|
|
|
This->SendJsonStationsObject(Socket, Ip);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if ( Buffer.Compare((uint8 *)"bye", 3) == 0 )
|
|
|
|
else if ( Buffer.Compare((uint8 *)"bye", 3) == 0 )
|
|
|
|
{
|
|
|
|
{
|
|
|
|
std::cout << "Monitor socket disconnected" << std::endl;
|
|
|
|
std::cout << "Monitor socket disconnected" << std::endl;
|
|
|
|
|
|
|
|
|
|
|
|
// diconnected
|
|
|
|
// diconnected
|
|
|
|
bOn = false;
|
|
|
|
bOn = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// any notifications ?
|
|
|
|
// any notifications ?
|
|
|
|
CNotification notification;
|
|
|
|
CNotification notification;
|
|
|
|
This->m_Notifications.Lock();
|
|
|
|
This->m_Notifications.Lock();
|
|
|
|
@ -444,7 +448,7 @@ void CReflector::JsonReportThread(CReflector *This)
|
|
|
|
void CReflector::OnClientsChanged(void)
|
|
|
|
void CReflector::OnClientsChanged(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CNotification notification(NOTIFICATION_CLIENTS);
|
|
|
|
CNotification notification(NOTIFICATION_CLIENTS);
|
|
|
|
|
|
|
|
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
@ -453,7 +457,7 @@ void CReflector::OnClientsChanged(void)
|
|
|
|
void CReflector::OnUsersChanged(void)
|
|
|
|
void CReflector::OnUsersChanged(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CNotification notification(NOTIFICATION_USERS);
|
|
|
|
CNotification notification(NOTIFICATION_USERS);
|
|
|
|
|
|
|
|
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
@ -462,7 +466,7 @@ void CReflector::OnUsersChanged(void)
|
|
|
|
void CReflector::OnStreamOpen(const CCallsign &callsign)
|
|
|
|
void CReflector::OnStreamOpen(const CCallsign &callsign)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CNotification notification(NOTIFICATION_STREAM_OPEN, callsign);
|
|
|
|
CNotification notification(NOTIFICATION_STREAM_OPEN, callsign);
|
|
|
|
|
|
|
|
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
@ -471,7 +475,7 @@ void CReflector::OnStreamOpen(const CCallsign &callsign)
|
|
|
|
void CReflector::OnStreamClose(const CCallsign &callsign)
|
|
|
|
void CReflector::OnStreamClose(const CCallsign &callsign)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
CNotification notification(NOTIFICATION_STREAM_CLOSE, callsign);
|
|
|
|
CNotification notification(NOTIFICATION_STREAM_CLOSE, callsign);
|
|
|
|
|
|
|
|
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.Lock();
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.push(notification);
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
m_Notifications.Unlock();
|
|
|
|
@ -521,12 +525,12 @@ void CReflector::WriteXmlFile(std::ofstream &xmlFile)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// write header
|
|
|
|
// write header
|
|
|
|
xmlFile << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" << std::endl;
|
|
|
|
xmlFile << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" << std::endl;
|
|
|
|
|
|
|
|
|
|
|
|
// software version
|
|
|
|
// software version
|
|
|
|
char sz[64];
|
|
|
|
char sz[64];
|
|
|
|
::sprintf(sz, "%d.%d.%d", VERSION_MAJOR, VERSION_MINOR, VERSION_REVISION);
|
|
|
|
::sprintf(sz, "%d.%d.%d", VERSION_MAJOR, VERSION_MINOR, VERSION_REVISION);
|
|
|
|
xmlFile << "<Version>" << sz << "</Version>" << std::endl;
|
|
|
|
xmlFile << "<Version>" << sz << "</Version>" << std::endl;
|
|
|
|
|
|
|
|
|
|
|
|
// linked nodes
|
|
|
|
// linked nodes
|
|
|
|
xmlFile << "<" << m_Callsign << "linked nodes>" << std::endl;
|
|
|
|
xmlFile << "<" << m_Callsign << "linked nodes>" << std::endl;
|
|
|
|
// lock
|
|
|
|
// lock
|
|
|
|
@ -539,7 +543,7 @@ void CReflector::WriteXmlFile(std::ofstream &xmlFile)
|
|
|
|
// unlock
|
|
|
|
// unlock
|
|
|
|
ReleaseClients();
|
|
|
|
ReleaseClients();
|
|
|
|
xmlFile << "</" << m_Callsign << "linked nodes>" << std::endl;
|
|
|
|
xmlFile << "</" << m_Callsign << "linked nodes>" << std::endl;
|
|
|
|
|
|
|
|
|
|
|
|
// last heard users
|
|
|
|
// last heard users
|
|
|
|
xmlFile << "<" << m_Callsign << "heard users>" << std::endl;
|
|
|
|
xmlFile << "<" << m_Callsign << "heard users>" << std::endl;
|
|
|
|
// lock
|
|
|
|
// lock
|
|
|
|
@ -562,7 +566,7 @@ void CReflector::SendJsonReflectorObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
char Buffer[1024];
|
|
|
|
char Buffer[1024];
|
|
|
|
char cs[CALLSIGN_LEN+1];
|
|
|
|
char cs[CALLSIGN_LEN+1];
|
|
|
|
char mod[8] = "\"A\"";
|
|
|
|
char mod[8] = "\"A\"";
|
|
|
|
|
|
|
|
|
|
|
|
// get reflector callsign
|
|
|
|
// get reflector callsign
|
|
|
|
m_Callsign.GetCallsign((uint8 *)cs);
|
|
|
|
m_Callsign.GetCallsign((uint8 *)cs);
|
|
|
|
cs[CALLSIGN_LEN] = 0;
|
|
|
|
cs[CALLSIGN_LEN] = 0;
|
|
|
|
@ -579,7 +583,7 @@ void CReflector::SendJsonReflectorObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
|
|
|
|
|
|
|
|
// and send
|
|
|
|
// and send
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -591,7 +595,7 @@ void CReflector::SendJsonNodesObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
char Buffer[12+(JSON_NBMAX_NODES*94)];
|
|
|
|
char Buffer[12+(JSON_NBMAX_NODES*94)];
|
|
|
|
|
|
|
|
|
|
|
|
// nodes object table
|
|
|
|
// nodes object table
|
|
|
|
::sprintf(Buffer, "{\"nodes\":[");
|
|
|
|
::sprintf(Buffer, "{\"nodes\":[");
|
|
|
|
// lock
|
|
|
|
// lock
|
|
|
|
CClients *clients = GetClients();
|
|
|
|
CClients *clients = GetClients();
|
|
|
|
// iterate on clients
|
|
|
|
// iterate on clients
|
|
|
|
@ -604,21 +608,21 @@ void CReflector::SendJsonNodesObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// unlock
|
|
|
|
// unlock
|
|
|
|
ReleaseClients();
|
|
|
|
ReleaseClients();
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
|
|
|
|
|
|
|
|
// and send
|
|
|
|
// and send
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CReflector::SendJsonStationsObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
void CReflector::SendJsonStationsObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
char Buffer[15+(LASTHEARD_USERS_MAX_SIZE*94)];
|
|
|
|
char Buffer[15+(LASTHEARD_USERS_MAX_SIZE*94)];
|
|
|
|
|
|
|
|
|
|
|
|
// stations object table
|
|
|
|
// stations object table
|
|
|
|
::sprintf(Buffer, "{\"stations\":[");
|
|
|
|
::sprintf(Buffer, "{\"stations\":[");
|
|
|
|
|
|
|
|
|
|
|
|
// lock
|
|
|
|
// lock
|
|
|
|
CUsers *users = GetUsers();
|
|
|
|
CUsers *users = GetUsers();
|
|
|
|
// iterate on users
|
|
|
|
// iterate on users
|
|
|
|
@ -629,12 +633,12 @@ void CReflector::SendJsonStationsObject(CUdpSocket &Socket, CIp &Ip)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
::strcat(Buffer, ",");
|
|
|
|
::strcat(Buffer, ",");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// unlock
|
|
|
|
// unlock
|
|
|
|
ReleaseUsers();
|
|
|
|
ReleaseUsers();
|
|
|
|
|
|
|
|
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
::strcat(Buffer, "]}");
|
|
|
|
|
|
|
|
|
|
|
|
// and send
|
|
|
|
// and send
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
@ -644,11 +648,11 @@ void CReflector::SendJsonOnairObject(CUdpSocket &Socket, CIp &Ip, const CCallsig
|
|
|
|
{
|
|
|
|
{
|
|
|
|
char Buffer[128];
|
|
|
|
char Buffer[128];
|
|
|
|
char sz[CALLSIGN_LEN+1];
|
|
|
|
char sz[CALLSIGN_LEN+1];
|
|
|
|
|
|
|
|
|
|
|
|
// onair object
|
|
|
|
// onair object
|
|
|
|
Callsign.GetCallsignString(sz);
|
|
|
|
Callsign.GetCallsignString(sz);
|
|
|
|
::sprintf(Buffer, "{\"onair\":\"%s\"}", sz);
|
|
|
|
::sprintf(Buffer, "{\"onair\":\"%s\"}", sz);
|
|
|
|
|
|
|
|
|
|
|
|
// and send
|
|
|
|
// and send
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
@ -658,11 +662,11 @@ void CReflector::SendJsonOffairObject(CUdpSocket &Socket, CIp &Ip, const CCallsi
|
|
|
|
{
|
|
|
|
{
|
|
|
|
char Buffer[128];
|
|
|
|
char Buffer[128];
|
|
|
|
char sz[CALLSIGN_LEN+1];
|
|
|
|
char sz[CALLSIGN_LEN+1];
|
|
|
|
|
|
|
|
|
|
|
|
// offair object
|
|
|
|
// offair object
|
|
|
|
Callsign.GetCallsignString(sz);
|
|
|
|
Callsign.GetCallsignString(sz);
|
|
|
|
::sprintf(Buffer, "{\"offair\":\"%s\"}", sz);
|
|
|
|
::sprintf(Buffer, "{\"offair\":\"%s\"}", sz);
|
|
|
|
|
|
|
|
|
|
|
|
// and send
|
|
|
|
// and send
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
//std::cout << Buffer << std::endl;
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
Socket.Send(Buffer, Ip);
|
|
|
|
|