summaryrefslogtreecommitdiff
path: root/root-topology/mktopology.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'root-topology/mktopology.cpp')
-rw-r--r--root-topology/mktopology.cpp48
1 files changed, 48 insertions, 0 deletions
diff --git a/root-topology/mktopology.cpp b/root-topology/mktopology.cpp
new file mode 100644
index 00000000..516fd71b
--- /dev/null
+++ b/root-topology/mktopology.cpp
@@ -0,0 +1,48 @@
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include <string>
+#include <iostream>
+#include <map>
+
+#include "../node/Utils.hpp"
+#include "../node/Identity.hpp"
+#include "../node/Dictionary.hpp"
+
+using namespace ZeroTier;
+
+int main(int argc,char **argv)
+{
+ std::string buf;
+
+ if (!Utils::readFile("root-topology-authority.secret",buf)) {
+ std::cerr << "Cannot read root-topology-authority.secret" << std::endl;
+ return 1;
+ }
+ Identity topologyAuthority(buf);
+
+ Dictionary topology;
+
+ Dictionary supernodes;
+ std::map<std::string,bool> supernodeDictionaries(Utils::listDirectory("supernodes"));
+ for(std::map<std::string,bool>::iterator sn(supernodeDictionaries.begin());sn!=supernodeDictionaries.end();++sn) {
+ if ((sn->first.length() == 10)&&(!sn->second)) {
+ buf.clear();
+ if (!Utils::readFile((std::string("supernodes/")+sn->first).c_str(),buf)) {
+ std::cerr << "Cannot read supernodes/" << sn->first << std::endl;
+ return 1;
+ }
+ supernodes[sn->first] = buf;
+ }
+ }
+ topology["supernodes"] = supernodes.toString();
+
+ if (!topology.sign(topologyAuthority)) {
+ std::cerr << "Unable to sign!" << std::endl;
+ return 1;
+ }
+
+ std::cout << topology.toString();
+ return 0;
+}