lokinet/llarp/service/context.cpp

64 lines
1.6 KiB
C++
Raw Normal View History

#include <llarp/service/context.hpp>
namespace llarp
{
namespace service
{
Context::Context(llarp_router *r) : m_Router(r)
{
}
Context::~Context()
{
auto itr = m_Endpoints.begin();
while(itr != m_Endpoints.end())
{
itr = m_Endpoints.erase(itr);
}
}
void
Context::Tick()
{
2018-07-18 22:50:05 +00:00
auto now = llarp_time_now_ms();
auto itr = m_Endpoints.begin();
while(itr != m_Endpoints.end())
{
2018-07-18 22:50:05 +00:00
itr->second->Tick(now);
++itr;
}
}
bool
Context::AddEndpoint(const Config::section_t &conf)
{
auto itr = m_Endpoints.find(conf.first);
if(itr != m_Endpoints.end())
{
llarp::LogError("cannot add hidden service with duplicate name: ",
conf.first);
return false;
}
auto service = new llarp::service::Endpoint(conf.first, m_Router);
for(const auto &option : conf.second)
{
auto &k = option.first;
auto &v = option.second;
if(!service->SetOption(k, v))
{
llarp::LogError("failed to set ", k, "=", v,
" for hidden service endpoint ", conf.first);
return false;
}
}
if(service->Start())
{
2018-07-29 23:29:36 +00:00
llarp::LogInfo("added hidden service endpoint ", service->Name());
2018-07-24 06:25:13 +00:00
m_Endpoints.insert(std::make_pair(conf.first, service));
return true;
}
llarp::LogError("failed to start hidden service endpoint ", conf.first);
return false;
}
2018-07-17 04:37:50 +00:00
} // namespace service
} // namespace llarp