From a368078243a08575ba0babc77faa1a8748badb68 Mon Sep 17 00:00:00 2001 From: R4SAS Date: Mon, 17 May 2021 20:37:30 +0300 Subject: [PATCH] add b33 support in keyinfo Signed-off-by: R4SAS --- keyinfo.cpp | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/keyinfo.cpp b/keyinfo.cpp index f587405..4a8d19e 100644 --- a/keyinfo.cpp +++ b/keyinfo.cpp @@ -1,5 +1,6 @@ #include "Identity.h" #include "I2PEndian.h" +#include "LeaseSet.h" #include #include #include @@ -11,7 +12,7 @@ static int printHelp(const char * exe, int exitcode) { - std::cout << "usage: " << exe << " [-v] [-d] privatekey.dat" << std::endl; + std::cout << "usage: " << exe << " [-v] [-d] [-b] privatekey.dat" << std::endl; return exitcode; } @@ -31,8 +32,9 @@ int main(int argc, char * argv[]) int opt; bool print_full = false; + bool print_blinded = false; bool verbose = false; - while((opt = getopt(argc, argv, "hvd")) != -1) { + while((opt = getopt(argc, argv, "hvdb")) != -1) { switch(opt){ case 'h': return printHelp(argv[0], 0); @@ -42,6 +44,9 @@ int main(int argc, char * argv[]) case 'd': print_full = true; break; + case 'b': + print_blinded = true; + break; default: return printHelp(argv[0], -1); } @@ -95,4 +100,16 @@ int main(int argc, char * argv[]) std::cout << ident.ToBase32() << ".b32.i2p" << std::endl; } } + + if (print_blinded) { + if (dest->GetSigningKeyType () == i2p::data::SIGNING_KEY_TYPE_REDDSA_SHA512_ED25519 || + dest->GetSigningKeyType () == i2p::data::SIGNING_KEY_TYPE_EDDSA_SHA512_ED25519 ) // 11 or 7 + { + i2p::data::BlindedPublicKey blindedKey (dest); + std::cout << "b33 address: " << blindedKey.ToB33 () << ".b32.i2p" << std::endl; + std::cout << "Today's store hash: " << blindedKey.GetStoreHash ().ToBase64 () << std::endl; + } + else + std::cout << "Invalid signature type " << SigTypeToName (dest->GetSigningKeyType ()) << std::endl; + } }