mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-01-22 04:04:16 +00:00
check for invalid params
This commit is contained in:
parent
92bebb7ecc
commit
158889b85c
@ -1,6 +1,4 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <vector>
|
|
||||||
#include <boost/algorithm/string.hpp>
|
|
||||||
#include "Log.h"
|
#include "Log.h"
|
||||||
#include "ClientContext.h"
|
#include "ClientContext.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
@ -435,15 +433,28 @@ namespace client
|
|||||||
|
|
||||||
void BOBCommandSession::NewkeysCommandHandler (const char * operand, size_t len)
|
void BOBCommandSession::NewkeysCommandHandler (const char * operand, size_t len)
|
||||||
{
|
{
|
||||||
LogPrint (eLogDebug, "BOB: newkeys");
|
LogPrint (eLogDebug, "BOB: newkeys");
|
||||||
std::vector<std::string> params;
|
|
||||||
boost::split (params, operand, boost::is_any_of(" "), boost::token_compress_on);
|
|
||||||
i2p::data::SigningKeyType signatureType = i2p::data::SIGNING_KEY_TYPE_DSA_SHA1;
|
i2p::data::SigningKeyType signatureType = i2p::data::SIGNING_KEY_TYPE_DSA_SHA1;
|
||||||
i2p::data::CryptoKeyType cryptoType = i2p::data::CRYPTO_KEY_TYPE_ELGAMAL;
|
i2p::data::CryptoKeyType cryptoType = i2p::data::CRYPTO_KEY_TYPE_ELGAMAL;
|
||||||
if (params.size () > 0)
|
if (*operand)
|
||||||
signatureType = std::stoi(params[0]);
|
{
|
||||||
if (params.size () > 1)
|
try
|
||||||
cryptoType = std::stoi(params[1]);
|
{
|
||||||
|
char * operand1 = (char *)strchr (operand, ' ');
|
||||||
|
if (operand1)
|
||||||
|
{
|
||||||
|
*operand1 = 0; operand1++;
|
||||||
|
cryptoType = std::stoi(operand1);
|
||||||
|
}
|
||||||
|
signatureType = std::stoi(operand);
|
||||||
|
}
|
||||||
|
catch (std::invalid_argument& ex)
|
||||||
|
{
|
||||||
|
LogPrint (eLogWarning, "BOB: newkeys ", ex.what ());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
m_Keys = i2p::data::PrivateKeys::CreateRandomKeys (signatureType, cryptoType);
|
m_Keys = i2p::data::PrivateKeys::CreateRandomKeys (signatureType, cryptoType);
|
||||||
SendReplyOK (m_Keys.GetPublic ()->ToBase64 ().c_str ());
|
SendReplyOK (m_Keys.GetPublic ()->ToBase64 ().c_str ());
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user