2018-05-27 17:44:01 +00:00
|
|
|
#ifndef LLARP_HPP
|
|
|
|
#define LLARP_HPP
|
2019-10-04 18:10:58 +00:00
|
|
|
#include <llarp.h>
|
2019-04-14 17:12:11 +00:00
|
|
|
#include <util/fs.hpp>
|
2019-01-13 16:30:07 +00:00
|
|
|
#include <util/types.hpp>
|
2019-04-08 12:01:52 +00:00
|
|
|
#include <ev/ev.hpp>
|
2018-12-12 02:52:51 +00:00
|
|
|
|
|
|
|
#include <iostream>
|
2019-04-14 16:08:51 +00:00
|
|
|
#include <map>
|
2018-12-11 00:53:11 +00:00
|
|
|
#include <memory>
|
2018-05-27 17:44:01 +00:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
2019-01-11 00:12:43 +00:00
|
|
|
struct llarp_ev_loop;
|
|
|
|
struct llarp_nodedb;
|
|
|
|
struct llarp_nodedb_iter;
|
2019-07-24 15:25:40 +00:00
|
|
|
struct llarp_main;
|
2018-12-10 16:26:46 +00:00
|
|
|
|
2018-05-27 17:44:01 +00:00
|
|
|
namespace llarp
|
|
|
|
{
|
2019-07-02 21:28:28 +00:00
|
|
|
class Logic;
|
|
|
|
struct AbstractRouter;
|
2019-02-11 14:43:48 +00:00
|
|
|
struct Config;
|
2019-01-13 16:30:07 +00:00
|
|
|
struct Crypto;
|
2019-05-28 19:45:08 +00:00
|
|
|
struct CryptoManager;
|
2019-01-11 00:12:43 +00:00
|
|
|
struct RouterContact;
|
2019-07-09 13:47:24 +00:00
|
|
|
namespace thread
|
|
|
|
{
|
2019-07-15 09:15:51 +00:00
|
|
|
class ThreadPool;
|
2019-07-09 13:47:24 +00:00
|
|
|
}
|
2019-01-11 00:12:43 +00:00
|
|
|
|
2018-05-27 17:44:01 +00:00
|
|
|
struct Context
|
|
|
|
{
|
2019-10-04 18:10:58 +00:00
|
|
|
/// get context from main pointer
|
|
|
|
static Context *
|
|
|
|
Get(llarp_main *);
|
|
|
|
|
De-abseil, part 2: mutex, locks, (most) time
- util::Mutex is now a std::shared_timed_mutex, which is capable of
exclusive and shared locks.
- util::Lock is still present as a std::lock_guard<util::Mutex>.
- the locking annotations are preserved, but updated to the latest
supported by clang rather than using abseil's older/deprecated ones.
- ACQUIRE_LOCK macro is gone since we don't pass mutexes by pointer into
locks anymore (WTF abseil).
- ReleasableLock is gone. Instead there are now some llarp::util helper
methods to obtain unique and/or shared locks:
- `auto lock = util::unique_lock(mutex);` gets an RAII-but-also
unlockable object (std::unique_lock<T>, with T inferred from
`mutex`).
- `auto lock = util::shared_lock(mutex);` gets an RAII shared (i.e.
"reader") lock of the mutex.
- `auto lock = util::unique_locks(mutex1, mutex2, mutex3);` can be
used to atomically lock multiple mutexes at once (returning a
tuple of the locks).
This are templated on the mutex which makes them a bit more flexible
than using a concrete type: they can be used for any type of lockable
mutex, not only util::Mutex. (Some of the code here uses them for
getting locks around a std::mutex). Until C++17, using the RAII types
is painfully verbose:
```C++
// pre-C++17 - needing to figure out the mutex type here is annoying:
std::unique_lock<util::Mutex> lock(mutex);
// pre-C++17 and even more verbose (but at least the type isn't needed):
std::unique_lock<decltype(mutex)> lock(mutex);
// our compromise:
auto lock = util::unique_lock(mutex);
// C++17:
std::unique_lock lock(mutex);
```
All of these functions will also warn (under gcc or clang) if you
discard the return value. You can also do fancy things like
`auto l = util::unique_lock(mutex, std::adopt_lock)` (which lets a
lock take over an already-locked mutex).
- metrics code is gone, which also removes a big pile of code that was
only used by metrics:
- llarp::util::Scheduler
- llarp::thread::TimerQueue
- llarp::util::Stopwatch
2020-02-21 17:21:11 +00:00
|
|
|
Context() = default;
|
2019-04-05 09:20:48 +00:00
|
|
|
|
|
|
|
std::unique_ptr< Crypto > crypto;
|
2019-05-28 19:45:08 +00:00
|
|
|
std::unique_ptr< CryptoManager > cryptoManager;
|
2019-04-05 09:20:48 +00:00
|
|
|
std::unique_ptr< AbstractRouter > router;
|
2019-07-09 13:47:24 +00:00
|
|
|
std::shared_ptr< thread::ThreadPool > worker;
|
2019-05-22 16:20:03 +00:00
|
|
|
std::shared_ptr< Logic > logic;
|
2019-04-05 09:20:48 +00:00
|
|
|
std::unique_ptr< Config > config;
|
2019-02-11 14:43:48 +00:00
|
|
|
std::unique_ptr< llarp_nodedb > nodedb;
|
2019-04-08 12:01:52 +00:00
|
|
|
llarp_ev_loop_ptr mainloop;
|
2018-09-17 12:02:09 +00:00
|
|
|
std::string nodedb_dir;
|
2018-05-27 17:44:01 +00:00
|
|
|
|
|
|
|
bool
|
|
|
|
LoadConfig(const std::string &fname);
|
|
|
|
|
|
|
|
void
|
|
|
|
Close();
|
|
|
|
|
2018-06-19 09:45:29 +00:00
|
|
|
int
|
|
|
|
LoadDatabase();
|
|
|
|
|
|
|
|
int
|
2019-10-04 09:10:55 +00:00
|
|
|
Setup();
|
2018-06-23 14:56:59 +00:00
|
|
|
|
2018-05-27 17:44:01 +00:00
|
|
|
int
|
2019-10-04 18:10:58 +00:00
|
|
|
Run(llarp_main_runtime_opts opts);
|
2018-05-27 17:44:01 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
HandleSignal(int sig);
|
|
|
|
|
2019-10-04 18:10:58 +00:00
|
|
|
bool
|
|
|
|
Configure();
|
|
|
|
|
2019-12-07 19:58:19 +00:00
|
|
|
bool
|
|
|
|
IsUp() const;
|
|
|
|
|
|
|
|
bool
|
|
|
|
LooksAlive() const;
|
|
|
|
|
2019-10-09 13:08:38 +00:00
|
|
|
/// close async
|
|
|
|
void
|
2019-10-09 13:09:42 +00:00
|
|
|
CloseAsync();
|
2019-10-09 13:08:38 +00:00
|
|
|
|
|
|
|
/// wait until closed and done
|
|
|
|
void
|
|
|
|
Wait();
|
|
|
|
|
2019-10-04 18:10:58 +00:00
|
|
|
/// call a function in logic thread
|
|
|
|
/// return true if queued for calling
|
|
|
|
/// return false if not queued for calling
|
|
|
|
bool
|
|
|
|
CallSafe(std::function< void(void) > f);
|
|
|
|
|
2018-05-27 17:44:01 +00:00
|
|
|
private:
|
2019-01-21 15:45:18 +00:00
|
|
|
void
|
|
|
|
SetPIDFile(const std::string &fname);
|
2019-01-18 13:24:33 +00:00
|
|
|
|
|
|
|
bool
|
|
|
|
WritePIDFile() const;
|
|
|
|
|
|
|
|
void
|
|
|
|
RemovePIDFile() const;
|
|
|
|
|
2018-05-27 17:44:01 +00:00
|
|
|
void
|
|
|
|
SigINT();
|
|
|
|
|
|
|
|
bool
|
|
|
|
ReloadConfig();
|
|
|
|
|
|
|
|
std::string configfile;
|
2019-01-18 13:24:33 +00:00
|
|
|
std::string pidfile;
|
2019-10-09 13:08:38 +00:00
|
|
|
std::unique_ptr< std::promise< void > > closeWaiter;
|
2018-05-27 17:44:01 +00:00
|
|
|
};
|
2018-07-09 03:34:29 +00:00
|
|
|
} // namespace llarp
|
2018-05-27 17:44:01 +00:00
|
|
|
|
|
|
|
#endif
|