|
@@ -132,7 +132,7 @@ RethinkDB::RethinkDB(EmbeddedNetworkController *const nc,const Address &myAddres
|
|
for(int t=0;t<ZT_CONTROLLER_RETHINKDB_COMMIT_THREADS;++t) {
|
|
for(int t=0;t<ZT_CONTROLLER_RETHINKDB_COMMIT_THREADS;++t) {
|
|
_commitThread[t] = std::thread([this]() {
|
|
_commitThread[t] = std::thread([this]() {
|
|
std::unique_ptr<R::Connection> rdb;
|
|
std::unique_ptr<R::Connection> rdb;
|
|
- std::unique_ptr<nlohmann::json> config;
|
|
|
|
|
|
+ nlohmann::json *config = (nlohmann::json *)0;
|
|
while ((this->_commitQueue.get(config))&&(_run == 1)) {
|
|
while ((this->_commitQueue.get(config))&&(_run == 1)) {
|
|
if (!config)
|
|
if (!config)
|
|
continue;
|
|
continue;
|
|
@@ -219,7 +219,7 @@ RethinkDB::~RethinkDB()
|
|
_networksDbWatcher.join();
|
|
_networksDbWatcher.join();
|
|
}
|
|
}
|
|
|
|
|
|
-inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network)
|
|
|
|
|
|
+bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
|
|
|
|
@@ -238,7 +238,7 @@ inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network)
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
-inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,const uint64_t memberId,nlohmann::json &member)
|
|
|
|
|
|
+bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,const uint64_t memberId,nlohmann::json &member)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
|
|
|
|
@@ -261,7 +261,7 @@ inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,cons
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
-inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,const uint64_t memberId,nlohmann::json &member,NetworkSummaryInfo &info)
|
|
|
|
|
|
+bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,const uint64_t memberId,nlohmann::json &member,NetworkSummaryInfo &info)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
|
|
|
|
@@ -285,7 +285,7 @@ inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,cons
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
-inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,std::vector<nlohmann::json> &members)
|
|
|
|
|
|
+bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,std::vector<nlohmann::json> &members)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
|
|
|
|
@@ -306,7 +306,7 @@ inline bool RethinkDB::get(const uint64_t networkId,nlohmann::json &network,std:
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
-inline bool RethinkDB::summary(const uint64_t networkId,NetworkSummaryInfo &info)
|
|
|
|
|
|
+bool RethinkDB::summary(const uint64_t networkId,NetworkSummaryInfo &info)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
|
|
|
|
@@ -337,7 +337,7 @@ void RethinkDB::networks(std::vector<uint64_t> &networks)
|
|
void RethinkDB::save(const nlohmann::json &record)
|
|
void RethinkDB::save(const nlohmann::json &record)
|
|
{
|
|
{
|
|
waitForReady();
|
|
waitForReady();
|
|
- _commitQueue.post(std::unique_ptr<nlohmann::json>(new nlohmann::json(record)));
|
|
|
|
|
|
+ _commitQueue.post(new nlohmann::json(record));
|
|
}
|
|
}
|
|
|
|
|
|
void RethinkDB::eraseNetwork(const uint64_t networkId)
|
|
void RethinkDB::eraseNetwork(const uint64_t networkId)
|
|
@@ -345,23 +345,23 @@ void RethinkDB::eraseNetwork(const uint64_t networkId)
|
|
char tmp2[24];
|
|
char tmp2[24];
|
|
waitForReady();
|
|
waitForReady();
|
|
Utils::hex(networkId,tmp2);
|
|
Utils::hex(networkId,tmp2);
|
|
- json tmp;
|
|
|
|
- tmp["id"] = tmp2;
|
|
|
|
- tmp["objtype"] = "delete_network"; // pseudo-type, tells thread to delete network
|
|
|
|
- _commitQueue.post(std::unique_ptr<nlohmann::json>(new nlohmann::json(tmp)));
|
|
|
|
|
|
+ json *tmp = new json();
|
|
|
|
+ (*tmp)["id"] = tmp2;
|
|
|
|
+ (*tmp)["objtype"] = "delete_network"; // pseudo-type, tells thread to delete network
|
|
|
|
+ _commitQueue.post(tmp);
|
|
}
|
|
}
|
|
|
|
|
|
void RethinkDB::eraseMember(const uint64_t networkId,const uint64_t memberId)
|
|
void RethinkDB::eraseMember(const uint64_t networkId,const uint64_t memberId)
|
|
{
|
|
{
|
|
char tmp2[24];
|
|
char tmp2[24];
|
|
- json tmp;
|
|
|
|
|
|
+ json *tmp = new json();
|
|
waitForReady();
|
|
waitForReady();
|
|
Utils::hex(networkId,tmp2);
|
|
Utils::hex(networkId,tmp2);
|
|
- tmp["nwid"] = tmp2;
|
|
|
|
|
|
+ (*tmp)["nwid"] = tmp2;
|
|
Utils::hex10(memberId,tmp2);
|
|
Utils::hex10(memberId,tmp2);
|
|
- tmp["id"] = tmp2;
|
|
|
|
- tmp["objtype"] = "delete_member"; // pseudo-type, tells thread to delete network
|
|
|
|
- _commitQueue.post(std::unique_ptr<nlohmann::json>(new nlohmann::json(tmp)));
|
|
|
|
|
|
+ (*tmp)["id"] = tmp2;
|
|
|
|
+ (*tmp)["objtype"] = "delete_member"; // pseudo-type, tells thread to delete network
|
|
|
|
+ _commitQueue.post(tmp);
|
|
}
|
|
}
|
|
|
|
|
|
void RethinkDB::_memberChanged(nlohmann::json &old,nlohmann::json &member)
|
|
void RethinkDB::_memberChanged(nlohmann::json &old,nlohmann::json &member)
|
|
@@ -511,14 +511,4 @@ void RethinkDB::_networkChanged(nlohmann::json &old,nlohmann::json &network)
|
|
|
|
|
|
} // namespace ZeroTier
|
|
} // namespace ZeroTier
|
|
|
|
|
|
-/*
|
|
|
|
-int main(int argc,char **argv)
|
|
|
|
-{
|
|
|
|
- ZeroTier::RethinkDB db(ZeroTier::Address(0x8056c2e21cULL),"10.6.6.188",28015,"ztc","");
|
|
|
|
- db.waitForReady();
|
|
|
|
- printf("ready.\n");
|
|
|
|
- pause();
|
|
|
|
-}
|
|
|
|
-*/
|
|
|
|
-
|
|
|
|
#endif // ZT_CONTROLLER_USE_RETHINKDB
|
|
#endif // ZT_CONTROLLER_USE_RETHINKDB
|