2019-07-15 11:15:51 +02:00
|
|
|
#include <service/endpoint_state.hpp>
|
|
|
|
|
|
|
|
#include <exit/session.hpp>
|
|
|
|
#include <hook/shell.hpp>
|
2019-07-18 18:28:17 +02:00
|
|
|
#include <service/endpoint.hpp>
|
2019-07-15 11:15:51 +02:00
|
|
|
#include <service/outbound_context.hpp>
|
|
|
|
#include <util/str.hpp>
|
|
|
|
|
|
|
|
namespace llarp
|
|
|
|
{
|
|
|
|
namespace service
|
|
|
|
{
|
|
|
|
bool
|
|
|
|
EndpointState::SetOption(const std::string& k, const std::string& v,
|
2019-07-18 18:28:17 +02:00
|
|
|
Endpoint& ep)
|
2019-07-15 11:15:51 +02:00
|
|
|
{
|
2019-07-18 18:28:17 +02:00
|
|
|
const auto name = ep.Name();
|
2019-07-15 11:15:51 +02:00
|
|
|
if(k == "keyfile")
|
|
|
|
{
|
|
|
|
m_Keyfile = v;
|
|
|
|
}
|
|
|
|
if(k == "tag")
|
|
|
|
{
|
|
|
|
m_Tag = v;
|
|
|
|
LogInfo("Setting tag to ", v);
|
|
|
|
}
|
|
|
|
if(k == "prefetch-tag")
|
|
|
|
{
|
|
|
|
m_PrefetchTags.insert(v);
|
|
|
|
}
|
|
|
|
if(k == "prefetch-addr")
|
|
|
|
{
|
|
|
|
Address addr;
|
|
|
|
if(addr.FromString(v))
|
|
|
|
m_PrefetchAddrs.insert(addr);
|
|
|
|
}
|
|
|
|
if(k == "min-latency")
|
|
|
|
{
|
2019-07-18 18:28:17 +02:00
|
|
|
const auto val = atoi(v.c_str());
|
2019-07-15 11:15:51 +02:00
|
|
|
if(val > 0)
|
2020-02-25 18:05:13 +01:00
|
|
|
m_MinPathLatency = std::chrono::milliseconds(val);
|
2019-07-15 11:15:51 +02:00
|
|
|
}
|
2019-07-18 18:28:17 +02:00
|
|
|
if(k == "paths")
|
|
|
|
{
|
|
|
|
const auto val = atoi(v.c_str());
|
2019-08-02 11:27:27 +02:00
|
|
|
if(val >= 1 && val <= static_cast< int >(path::PathSet::max_paths))
|
2019-07-18 18:28:17 +02:00
|
|
|
{
|
|
|
|
ep.numPaths = val;
|
2019-07-18 18:32:26 +02:00
|
|
|
LogInfo(name, " set number of paths to ", ep.numHops);
|
2019-07-18 18:28:17 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-07-18 18:32:26 +02:00
|
|
|
LogWarn(name, " invalid number of paths: ", v);
|
2019-07-18 18:28:17 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if(k == "hops")
|
|
|
|
{
|
|
|
|
const auto val = atoi(v.c_str());
|
2019-08-02 11:27:27 +02:00
|
|
|
if(val >= 1 && val <= static_cast< int >(path::max_len))
|
2019-07-18 18:28:17 +02:00
|
|
|
{
|
|
|
|
ep.numHops = val;
|
|
|
|
LogInfo(name, " set number of hops to ", ep.numHops);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
LogWarn(name, " invalid number of hops: ", v);
|
|
|
|
}
|
|
|
|
}
|
2019-07-15 11:15:51 +02:00
|
|
|
if(k == "bundle-rc")
|
|
|
|
{
|
|
|
|
m_BundleRC = IsTrueValue(v.c_str());
|
|
|
|
}
|
|
|
|
if(k == "blacklist-snode")
|
|
|
|
{
|
|
|
|
RouterID snode;
|
|
|
|
if(!snode.FromString(v))
|
|
|
|
{
|
|
|
|
LogError(name, " invalid snode value: ", v);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
const auto result = m_SnodeBlacklist.insert(snode);
|
|
|
|
if(!result.second)
|
|
|
|
{
|
|
|
|
LogError(name, " duplicate blacklist-snode: ", snode.ToString());
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
LogInfo(name, " adding ", snode.ToString(), " to blacklist");
|
|
|
|
}
|
|
|
|
if(k == "on-up")
|
|
|
|
{
|
|
|
|
m_OnUp = hooks::ExecShellBackend(v);
|
|
|
|
if(m_OnUp)
|
|
|
|
LogInfo(name, " added on up script: ", v);
|
|
|
|
else
|
|
|
|
LogError(name, " failed to add on up script");
|
|
|
|
}
|
|
|
|
if(k == "on-down")
|
|
|
|
{
|
|
|
|
m_OnDown = hooks::ExecShellBackend(v);
|
|
|
|
if(m_OnDown)
|
|
|
|
LogInfo(name, " added on down script: ", v);
|
|
|
|
else
|
|
|
|
LogError(name, " failed to add on down script");
|
|
|
|
}
|
|
|
|
if(k == "on-ready")
|
|
|
|
{
|
|
|
|
m_OnReady = hooks::ExecShellBackend(v);
|
|
|
|
if(m_OnReady)
|
|
|
|
LogInfo(name, " added on ready script: ", v);
|
|
|
|
else
|
|
|
|
LogError(name, " failed to add on ready script");
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
util::StatusObject
|
|
|
|
EndpointState::ExtractStatus(util::StatusObject& obj) const
|
|
|
|
{
|
2020-02-25 18:05:13 +01:00
|
|
|
obj["lastPublished"] = to_json(m_LastPublish);
|
|
|
|
obj["lastPublishAttempt"] = to_json(m_LastPublishAttempt);
|
2019-08-19 11:33:26 +02:00
|
|
|
obj["introset"] = m_IntroSet.ExtractStatus();
|
2019-07-15 11:15:51 +02:00
|
|
|
|
|
|
|
if(!m_Tag.IsZero())
|
|
|
|
{
|
2019-08-19 11:33:26 +02:00
|
|
|
obj["tag"] = m_Tag.ToString();
|
|
|
|
}
|
|
|
|
|
|
|
|
static auto getSecond = [](const auto& item) -> auto
|
|
|
|
{
|
|
|
|
return item.second->ExtractStatus();
|
2019-07-15 11:15:51 +02:00
|
|
|
};
|
2019-08-19 11:33:26 +02:00
|
|
|
|
|
|
|
std::transform(m_DeadSessions.begin(), m_DeadSessions.end(),
|
|
|
|
std::back_inserter(obj["deadSessions"]), getSecond);
|
|
|
|
std::transform(m_RemoteSessions.begin(), m_RemoteSessions.end(),
|
|
|
|
std::back_inserter(obj["remoteSessions"]), getSecond);
|
|
|
|
std::transform(m_PendingLookups.begin(), m_PendingLookups.end(),
|
|
|
|
std::back_inserter(obj["lookups"]), getSecond);
|
|
|
|
std::transform(
|
|
|
|
m_SNodeSessions.begin(), m_SNodeSessions.end(),
|
|
|
|
std::back_inserter(obj["snodeSessions"]),
|
|
|
|
[](const auto& item) { return item.second.first->ExtractStatus(); });
|
2019-07-15 11:15:51 +02:00
|
|
|
|
|
|
|
util::StatusObject sessionObj{};
|
|
|
|
|
|
|
|
for(const auto& item : m_Sessions)
|
|
|
|
{
|
|
|
|
std::string k = item.first.ToHex();
|
2019-08-19 11:33:26 +02:00
|
|
|
sessionObj[k] = item.second.ExtractStatus();
|
2019-07-15 11:15:51 +02:00
|
|
|
}
|
|
|
|
|
2019-08-19 11:33:26 +02:00
|
|
|
obj["converstations"] = sessionObj;
|
2019-07-15 11:15:51 +02:00
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
} // namespace service
|
|
|
|
} // namespace llarp
|