2018-07-11 16:11:19 +00:00
|
|
|
#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();
|
2018-07-11 16:11:19 +00:00
|
|
|
auto itr = m_Endpoints.begin();
|
|
|
|
while(itr != m_Endpoints.end())
|
|
|
|
{
|
2018-07-18 22:50:05 +00:00
|
|
|
itr->second->Tick(now);
|
2018-07-11 16:11:19 +00:00
|
|
|
++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))
|
|
|
|
{
|
2018-07-12 13:43:37 +00:00
|
|
|
llarp::LogError("failed to set ", k, "=", v,
|
|
|
|
" for hidden service endpoint ", conf.first);
|
2018-07-11 16:11:19 +00:00
|
|
|
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));
|
2018-07-11 16:11:19 +00:00
|
|
|
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
|