2013-07-04 20:56:19 +00:00
|
|
|
/*
|
|
|
|
* ZeroTier One - Global Peer to Peer Ethernet
|
|
|
|
* Copyright (C) 2012-2013 ZeroTier Networks LLC
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* --
|
|
|
|
*
|
|
|
|
* ZeroTier may be used and distributed under the terms of the GPLv3, which
|
|
|
|
* are available at: http://www.gnu.org/licenses/gpl-3.0.html
|
|
|
|
*
|
|
|
|
* If you would like to embed ZeroTier into a commercial application or
|
|
|
|
* redistribute it in a modified binary form, please contact ZeroTier Networks
|
|
|
|
* LLC. Start here: http://www.zerotier.com/
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ZT_RUNTIMEENVIRONMENT_HPP
|
|
|
|
#define _ZT_RUNTIMEENVIRONMENT_HPP
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
#include "Identity.hpp"
|
2013-07-13 02:07:48 +00:00
|
|
|
#include "Condition.hpp"
|
2013-07-04 20:56:19 +00:00
|
|
|
|
|
|
|
namespace ZeroTier {
|
|
|
|
|
|
|
|
class NodeConfig;
|
|
|
|
class Logger;
|
|
|
|
class Demarc;
|
|
|
|
class Switch;
|
|
|
|
class Topology;
|
|
|
|
class SysEnv;
|
2013-07-12 02:06:25 +00:00
|
|
|
class Multicaster;
|
2013-07-13 18:28:26 +00:00
|
|
|
class CMWC4096;
|
2013-07-25 21:53:57 +00:00
|
|
|
class RPC;
|
2013-07-04 20:56:19 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Holds global state for an instance of ZeroTier::Node
|
|
|
|
*
|
|
|
|
* I do not believe in mutable static variables, period, or in global static
|
|
|
|
* instances of objects that don't basically represent constants. It makes
|
|
|
|
* unit testing, embedding, threading, and other things hard and is poor
|
|
|
|
* practice.
|
|
|
|
*
|
|
|
|
* So we put everything that we would want to be global, like Logger, here
|
|
|
|
* and we give everybody this as _r. The Node creates and initializes this
|
|
|
|
* on startup and deletes things on shutdown.
|
|
|
|
*/
|
|
|
|
class RuntimeEnvironment
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
RuntimeEnvironment() :
|
|
|
|
log((Logger *)0),
|
2013-07-13 18:28:26 +00:00
|
|
|
prng((CMWC4096 *)0),
|
2013-07-04 20:56:19 +00:00
|
|
|
nc((NodeConfig *)0),
|
|
|
|
demarc((Demarc *)0),
|
2013-07-12 02:06:25 +00:00
|
|
|
multicaster((Multicaster *)0),
|
2013-07-04 20:56:19 +00:00
|
|
|
sw((Switch *)0),
|
2013-07-25 21:53:57 +00:00
|
|
|
topology((Topology *)0),
|
|
|
|
sysEnv((SysEnv *)0),
|
|
|
|
rpc((RPC *)0)
|
2013-07-04 20:56:19 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string homePath;
|
|
|
|
|
2013-07-13 02:07:48 +00:00
|
|
|
// signal() to prematurely interrupt main loop wait
|
|
|
|
Condition mainLoopWaitCondition;
|
|
|
|
|
2013-07-04 20:56:19 +00:00
|
|
|
Identity identity;
|
|
|
|
|
2013-07-25 21:53:57 +00:00
|
|
|
// Order matters a bit here. These are constructed in this order
|
|
|
|
// and then deleted in the opposite order on Node exit.
|
|
|
|
|
2013-07-04 20:56:19 +00:00
|
|
|
Logger *log; // may be null
|
2013-07-13 18:28:26 +00:00
|
|
|
CMWC4096 *prng;
|
2013-07-04 20:56:19 +00:00
|
|
|
NodeConfig *nc;
|
|
|
|
Demarc *demarc;
|
2013-07-12 02:06:25 +00:00
|
|
|
Multicaster *multicaster;
|
2013-07-04 20:56:19 +00:00
|
|
|
Switch *sw;
|
|
|
|
Topology *topology;
|
|
|
|
SysEnv *sysEnv;
|
2013-07-25 21:53:57 +00:00
|
|
|
RPC *rpc;
|
2013-07-04 20:56:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace ZeroTier
|
|
|
|
|
|
|
|
#endif
|