diff options
Diffstat (limited to 'root-topology/mktopology.cpp')
-rw-r--r-- | root-topology/mktopology.cpp | 48 |
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; +} |