| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 | /* * ZeroTier One - Network Virtualization Everywhere * Copyright (C) 2011-2015  ZeroTier, Inc. * * 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_SQLITENETWORKCONTROLLER_HPP#define ZT_SQLITENETWORKCONTROLLER_HPP#include <stdint.h>#include <sqlite3.h>#include <string>#include <map>#include <vector>#include "../node/Constants.hpp"#include "../node/NetworkController.hpp"#include "../node/Mutex.hpp"#include "../osdep/Thread.hpp"// Number of in-memory last log entries to maintain per user#define ZT_SQLITENETWORKCONTROLLER_IN_MEMORY_LOG_SIZE 32// How long do circuit tests last before they're forgotten?#define ZT_SQLITENETWORKCONTROLLER_CIRCUIT_TEST_TIMEOUT 60000namespace ZeroTier {class Node;class SqliteNetworkController : public NetworkController{public:	SqliteNetworkController(Node *node,const char *dbPath,const char *circuitTestPath);	virtual ~SqliteNetworkController();	virtual NetworkController::ResultCode doNetworkConfigRequest(		const InetAddress &fromAddr,		const Identity &signingId,		const Identity &identity,		uint64_t nwid,		const Dictionary &metaData,		Dictionary &netconf);	unsigned int handleControlPlaneHttpGET(		const std::vector<std::string> &path,		const std::map<std::string,std::string> &urlArgs,		const std::map<std::string,std::string> &headers,		const std::string &body,		std::string &responseBody,		std::string &responseContentType);	unsigned int handleControlPlaneHttpPOST(		const std::vector<std::string> &path,		const std::map<std::string,std::string> &urlArgs,		const std::map<std::string,std::string> &headers,		const std::string &body,		std::string &responseBody,		std::string &responseContentType);	unsigned int handleControlPlaneHttpDELETE(		const std::vector<std::string> &path,		const std::map<std::string,std::string> &urlArgs,		const std::map<std::string,std::string> &headers,		const std::string &body,		std::string &responseBody,		std::string &responseContentType);	// threadMain() for backup thread -- do not call directly	void threadMain()		throw();private:	enum IpAssignmentType {		// IP assignment is a static IP address		ZT_IP_ASSIGNMENT_TYPE_ADDRESS = 0,		// IP assignment is a network -- a route via this interface, not an address		ZT_IP_ASSIGNMENT_TYPE_NETWORK = 1	};	unsigned int _doCPGet(		const std::vector<std::string> &path,		const std::map<std::string,std::string> &urlArgs,		const std::map<std::string,std::string> &headers,		const std::string &body,		std::string &responseBody,		std::string &responseContentType);	NetworkController::ResultCode _doNetworkConfigRequest(		const InetAddress &fromAddr,		const Identity &signingId,		const Identity &identity,		uint64_t nwid,		const Dictionary &metaData,		Dictionary &netconf);	static void _circuitTestCallback(ZT_Node *node,ZT_CircuitTest *test,const ZT_CircuitTestReport *report);	Node *_node;	Thread _backupThread;	volatile bool _backupThreadRun;	std::string _dbPath;	std::string _circuitTestPath;	std::string _instanceId;	// Circuit tests outstanding	struct _CircuitTestEntry	{		ZT_CircuitTest *test;		std::string jsonResults;	};	std::map< uint64_t,_CircuitTestEntry > _circuitTests;	// Last request time by address, for rate limitation	std::map< std::pair<uint64_t,uint64_t>,uint64_t > _lastRequestTime;	sqlite3 *_db;	sqlite3_stmt *_sGetNetworkById;	sqlite3_stmt *_sGetMember;	sqlite3_stmt *_sCreateMember;	sqlite3_stmt *_sGetNodeIdentity;	sqlite3_stmt *_sCreateOrReplaceNode;	sqlite3_stmt *_sGetMaxNodeHistoryNetworkVisitCounter;	sqlite3_stmt *_sAddNodeHistoryEntry;	sqlite3_stmt *_sDeleteOldNodeHistoryEntries;	sqlite3_stmt *_sGetActiveNodesOnNetwork;	sqlite3_stmt *_sGetNodeHistory;	sqlite3_stmt *_sGetEtherTypesFromRuleTable;	sqlite3_stmt *_sGetActiveBridges;	sqlite3_stmt *_sGetIpAssignmentsForNode;	sqlite3_stmt *_sGetIpAssignmentPools;	sqlite3_stmt *_sGetLocalRoutes;	sqlite3_stmt *_sCheckIfIpIsAllocated;	sqlite3_stmt *_sAllocateIp;	sqlite3_stmt *_sDeleteIpAllocations;	sqlite3_stmt *_sDeleteLocalRoutes;	sqlite3_stmt *_sGetRelays;	sqlite3_stmt *_sListNetworks;	sqlite3_stmt *_sListNetworkMembers;	sqlite3_stmt *_sGetMember2;	sqlite3_stmt *_sGetIpAssignmentPools2;	sqlite3_stmt *_sListRules;	sqlite3_stmt *_sCreateRule;	sqlite3_stmt *_sCreateNetwork;	sqlite3_stmt *_sGetNetworkRevision;	sqlite3_stmt *_sSetNetworkRevision;	sqlite3_stmt *_sGetIpAssignmentsForNode2;	sqlite3_stmt *_sDeleteRelaysForNetwork;	sqlite3_stmt *_sCreateRelay;	sqlite3_stmt *_sDeleteIpAssignmentPoolsForNetwork;	sqlite3_stmt *_sDeleteRulesForNetwork;	sqlite3_stmt *_sCreateIpAssignmentPool;	sqlite3_stmt *_sUpdateMemberAuthorized;	sqlite3_stmt *_sUpdateMemberActiveBridge;	sqlite3_stmt *_sDeleteMember;	sqlite3_stmt *_sDeleteAllNetworkMembers;	sqlite3_stmt *_sDeleteNetwork;	sqlite3_stmt *_sGetGateways;	sqlite3_stmt *_sDeleteGateways;	sqlite3_stmt *_sCreateGateway;	sqlite3_stmt *_sIncrementMemberRevisionCounter;	sqlite3_stmt *_sGetConfig;	sqlite3_stmt *_sSetConfig;	Mutex _lock;};} // namespace ZeroTier#endif
 |