lokinet/llarp/router.cpp

106 lines
2.7 KiB
C++
Raw Normal View History

2017-11-28 15:05:31 +01:00
#include "link.hpp"
2018-01-26 15:17:51 +01:00
#include "mem.hpp"
2018-01-19 17:51:27 +01:00
#include "str.hpp"
2018-01-29 15:27:24 +01:00
#include <llarp/link.h>
#include <llarp/router.h>
2017-11-28 15:05:31 +01:00
2018-01-29 15:27:24 +01:00
namespace llarp {
void router_iter_config(llarp_config_iterator *iter, const char *section,
const char *key, const char *val);
struct router_links {
struct llarp_link *link = nullptr;
struct router_links *next = nullptr;
};
2018-01-08 14:49:05 +01:00
2018-01-29 15:27:24 +01:00
} // namespace llarp
2017-11-28 15:05:31 +01:00
2018-01-29 15:27:24 +01:00
struct llarp_router {
struct llarp_threadpool *tp;
2018-01-27 02:18:10 +01:00
llarp::router_links links;
llarp_crypto crypto;
2018-01-19 17:51:27 +01:00
2018-01-29 15:27:24 +01:00
static void *operator new(size_t sz) {
2018-01-27 02:18:10 +01:00
return llarp_g_mem.alloc(sz, llarp::alignment<llarp_router>());
}
2018-01-29 15:27:24 +01:00
static void operator delete(void *ptr) { llarp_g_mem.free(ptr); }
2018-01-27 02:18:10 +01:00
2018-01-29 15:27:24 +01:00
void AddLink(struct llarp_link *link) {
llarp::router_links *head = &links;
while (head->next && head->link)
2018-01-27 02:18:10 +01:00
head = head->next;
2018-01-29 15:27:24 +01:00
if (head->link)
2018-01-27 02:18:10 +01:00
head->next = new llarp::router_links{link, nullptr};
else
head->link = link;
}
2018-01-29 15:27:24 +01:00
void ForEachLink(std::function<void(llarp_link *)> visitor) {
llarp::router_links *cur = &links;
do {
if (cur->link)
2018-01-27 02:18:10 +01:00
visitor(cur->link);
cur = cur->next;
2018-01-29 15:27:24 +01:00
} while (cur);
2018-01-27 02:18:10 +01:00
}
2018-01-29 15:27:24 +01:00
void Close() { ForEachLink(llarp_link_stop); }
};
2018-01-27 02:18:10 +01:00
extern "C" {
2018-01-29 15:27:24 +01:00
struct llarp_router *llarp_init_router(struct llarp_threadpool *tp) {
llarp_router *router = new llarp_router;
router->tp = tp;
llarp_crypto_libsodium_init(&router->crypto);
return router;
}
2018-01-08 14:49:05 +01:00
2018-01-29 15:27:24 +01:00
int llarp_configure_router(struct llarp_router *router,
struct llarp_config *conf) {
llarp_config_iterator iter;
iter.user = router;
iter.visit = llarp::router_iter_config;
llarp_config_iter(conf, &iter);
return 0;
}
2018-01-08 14:49:05 +01:00
2018-01-29 15:27:24 +01:00
void llarp_run_router(struct llarp_router *router, struct llarp_ev_loop *loop) {
router->ForEachLink([loop](llarp_link *link) {
llarp_ev_add_udp_listener(loop, llarp_link_udp_listener(link));
});
}
2018-01-08 14:49:05 +01:00
2018-01-29 15:27:24 +01:00
void llarp_stop_router(struct llarp_router *router) { router->Close(); }
2018-01-29 15:19:00 +01:00
2018-01-29 15:27:24 +01:00
void llarp_free_router(struct llarp_router **router) {
if (*router) {
(*router)->ForEachLink([](llarp_link *link) { llarp_g_mem.free(link); });
delete *router;
2018-01-08 14:49:05 +01:00
}
2018-01-29 15:27:24 +01:00
*router = nullptr;
}
2018-01-08 14:49:05 +01:00
}
2018-01-19 17:51:27 +01:00
2018-01-29 15:27:24 +01:00
namespace llarp {
void router_iter_config(llarp_config_iterator *iter, const char *section,
const char *key, const char *val) {
llarp_router *self = static_cast<llarp_router *>(iter->user);
if (StrEq(section, "links")) {
if (StrEq(val, "ip")) {
struct llarp_link *link = llarp_link_alloc();
if (llarp_link_configure(link, key, AF_INET6))
self->AddLink(link);
else {
llarp_link_free(&link);
printf("failed to configure %s link for %s\n", val, key);
2018-01-19 17:51:27 +01:00
}
2018-01-29 15:27:24 +01:00
} else if (StrEq(val, "eth")) {
/** todo: ethernet link */
2018-01-19 17:51:27 +01:00
}
}
}
2018-01-29 15:27:24 +01:00
} // namespace llarp