2004-12-30 22:43:55 +00:00
|
|
|
/*
|
2009-02-13 10:39:20 +00:00
|
|
|
* $Id: component.c,v 1.4 2009/02/13 10:39:22 schmirl Exp $
|
2004-12-30 22:43:55 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "server/component.h"
|
|
|
|
#include "server/connection.h"
|
|
|
|
|
|
|
|
cServerComponent::cServerComponent(const char *Protocol, const char *ListenIp,
|
2009-02-13 10:39:20 +00:00
|
|
|
uint ListenPort, int Type, int IpProto):
|
2005-05-09 20:22:29 +00:00
|
|
|
m_Protocol(Protocol),
|
2009-02-13 10:39:20 +00:00
|
|
|
m_Listen(Type, IpProto),
|
2005-05-09 20:22:29 +00:00
|
|
|
m_ListenIp(ListenIp),
|
|
|
|
m_ListenPort(ListenPort)
|
|
|
|
{
|
2004-12-30 22:43:55 +00:00
|
|
|
}
|
|
|
|
|
2005-05-09 20:22:29 +00:00
|
|
|
cServerComponent::~cServerComponent()
|
|
|
|
{
|
2004-12-30 22:43:55 +00:00
|
|
|
}
|
|
|
|
|
2005-05-09 20:22:29 +00:00
|
|
|
bool cServerComponent::Initialize(void)
|
|
|
|
{
|
2004-12-30 22:43:55 +00:00
|
|
|
if (!m_Listen.Listen(m_ListenIp, m_ListenPort, 5)) {
|
2005-05-09 20:22:29 +00:00
|
|
|
esyslog("Streamdev: Couldn't listen (%s) %s:%d: %m",
|
|
|
|
m_Protocol, m_ListenIp, m_ListenPort);
|
2004-12-30 22:43:55 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
isyslog("Streamdev: Listening (%s) on port %d", m_Protocol, m_ListenPort);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2005-05-09 20:22:29 +00:00
|
|
|
void cServerComponent::Destruct(void)
|
|
|
|
{
|
2004-12-30 22:43:55 +00:00
|
|
|
m_Listen.Close();
|
|
|
|
}
|
|
|
|
|
2005-05-09 20:22:29 +00:00
|
|
|
cServerConnection *cServerComponent::Accept(void)
|
|
|
|
{
|
|
|
|
cServerConnection *client = NewClient();
|
|
|
|
if (client->Accept(m_Listen)) {
|
|
|
|
isyslog("Streamdev: Accepted new client (%s) %s:%d", m_Protocol,
|
|
|
|
client->RemoteIp().c_str(), client->RemotePort());
|
|
|
|
return client;
|
|
|
|
} else {
|
|
|
|
esyslog("Streamdev: Couldn't accept (%s): %m", m_Protocol);
|
|
|
|
delete client;
|
2004-12-30 22:43:55 +00:00
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|