base64-based sign/verify

This commit is contained in:
Pieter Wuille 2011-09-20 15:42:36 +02:00
parent b53d6284eb
commit d9867551fc

View File

@ -561,7 +561,8 @@ Value signmessage(const Array& params, bool fHelp)
sres << key.GetPubKey(); // public key sres << key.GetPubKey(); // public key
sres << vchSig; // signature; sres << vchSig; // signature;
return HexStr(sres.begin(), sres.end()); vector<unsigned char> vchRet(sres.begin(), sres.end());
return EncodeBase64(&vchRet[0], vchRet.size());
} }
Value verifymessage(const Array& params, bool fHelp) Value verifymessage(const Array& params, bool fHelp)
@ -579,7 +580,12 @@ Value verifymessage(const Array& params, bool fHelp)
if (!addr.IsValid()) if (!addr.IsValid())
throw JSONRPCError(-3, "Invalid address"); throw JSONRPCError(-3, "Invalid address");
vector<unsigned char> vchResult = ParseHex(strSign); bool fInvalid = false;
vector<unsigned char> vchResult = DecodeBase64(strSign.c_str(), &fInvalid);
if (fInvalid)
throw JSONRPCError(-5, "Malformed base64 encoding");
CDataStream sres(vchResult); CDataStream sres(vchResult);
std::vector<unsigned char> vchPubKey; std::vector<unsigned char> vchPubKey;