mirror of
https://codeberg.org/anoncontributorxmr/monero.git
synced 2024-11-26 01:12:39 +00:00
Merge pull request #6603
4e2377995
Change ZMQ-JSON txextra to hex and remove unnecessary base fields (Lee Clagett)
This commit is contained in:
commit
a08df6eb1b
5 changed files with 48 additions and 6 deletions
|
@ -35,7 +35,7 @@ namespace rpc
|
||||||
{
|
{
|
||||||
|
|
||||||
static const uint32_t DAEMON_RPC_VERSION_ZMQ_MINOR = 0;
|
static const uint32_t DAEMON_RPC_VERSION_ZMQ_MINOR = 0;
|
||||||
static const uint32_t DAEMON_RPC_VERSION_ZMQ_MAJOR = 1;
|
static const uint32_t DAEMON_RPC_VERSION_ZMQ_MAJOR = 2;
|
||||||
|
|
||||||
static const uint32_t DAEMON_RPC_VERSION_ZMQ = DAEMON_RPC_VERSION_ZMQ_MINOR + (DAEMON_RPC_VERSION_ZMQ_MAJOR << 16);
|
static const uint32_t DAEMON_RPC_VERSION_ZMQ = DAEMON_RPC_VERSION_ZMQ_MINOR + (DAEMON_RPC_VERSION_ZMQ_MAJOR << 16);
|
||||||
|
|
||||||
|
|
|
@ -65,8 +65,6 @@ const rapidjson::Value& get_method_field(const rapidjson::Value& src)
|
||||||
void Message::toJson(rapidjson::Writer<epee::byte_stream>& dest) const
|
void Message::toJson(rapidjson::Writer<epee::byte_stream>& dest) const
|
||||||
{
|
{
|
||||||
dest.StartObject();
|
dest.StartObject();
|
||||||
INSERT_INTO_JSON_OBJECT(dest, status, status);
|
|
||||||
INSERT_INTO_JSON_OBJECT(dest, error_details, error_details);
|
|
||||||
INSERT_INTO_JSON_OBJECT(dest, rpc_version, DAEMON_RPC_VERSION_ZMQ);
|
INSERT_INTO_JSON_OBJECT(dest, rpc_version, DAEMON_RPC_VERSION_ZMQ);
|
||||||
doToJson(dest);
|
doToJson(dest);
|
||||||
dest.EndObject();
|
dest.EndObject();
|
||||||
|
@ -74,8 +72,6 @@ void Message::toJson(rapidjson::Writer<epee::byte_stream>& dest) const
|
||||||
|
|
||||||
void Message::fromJson(const rapidjson::Value& val)
|
void Message::fromJson(const rapidjson::Value& val)
|
||||||
{
|
{
|
||||||
GET_FROM_JSON_OBJECT(val, status, status);
|
|
||||||
GET_FROM_JSON_OBJECT(val, error_details, error_details);
|
|
||||||
GET_FROM_JSON_OBJECT(val, rpc_version, rpc_version);
|
GET_FROM_JSON_OBJECT(val, rpc_version, rpc_version);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -148,6 +148,26 @@ void fromJsonValue(const rapidjson::Value& val, std::string& str)
|
||||||
str = val.GetString();
|
str = val.GetString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, const std::vector<std::uint8_t>& src)
|
||||||
|
{
|
||||||
|
const std::string hex = epee::to_hex::string(epee::to_span(src));
|
||||||
|
dest.String(hex.data(), hex.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
void fromJsonValue(const rapidjson::Value& val, std::vector<std::uint8_t>& dest)
|
||||||
|
{
|
||||||
|
if (!val.IsString())
|
||||||
|
{
|
||||||
|
throw WRONG_TYPE("string");
|
||||||
|
}
|
||||||
|
|
||||||
|
dest.resize(val.GetStringLength() / 2);
|
||||||
|
if ((val.GetStringLength() % 2) != 0 || !epee::from_hex::to_buffer(epee::to_mut_span(dest), {val.GetString(), val.GetStringLength()}))
|
||||||
|
{
|
||||||
|
throw BAD_INPUT();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, bool i)
|
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, bool i)
|
||||||
{
|
{
|
||||||
dest.Bool(i);
|
dest.Bool(i);
|
||||||
|
|
|
@ -154,6 +154,9 @@ inline void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, const std::s
|
||||||
}
|
}
|
||||||
void fromJsonValue(const rapidjson::Value& val, std::string& str);
|
void fromJsonValue(const rapidjson::Value& val, std::string& str);
|
||||||
|
|
||||||
|
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, const std::vector<std::uint8_t>&);
|
||||||
|
void fromJsonValue(const rapidjson::Value& src, std::vector<std::uint8_t>& i);
|
||||||
|
|
||||||
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, bool i);
|
void toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, bool i);
|
||||||
void fromJsonValue(const rapidjson::Value& val, bool& b);
|
void fromJsonValue(const rapidjson::Value& val, bool& b);
|
||||||
|
|
||||||
|
@ -357,6 +360,10 @@ inline typename std::enable_if<sfinae::is_map_like<Map>::value, void>::type from
|
||||||
template <typename Vec>
|
template <typename Vec>
|
||||||
inline typename std::enable_if<sfinae::is_vector_like<Vec>::value, void>::type toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, const Vec &vec)
|
inline typename std::enable_if<sfinae::is_vector_like<Vec>::value, void>::type toJsonValue(rapidjson::Writer<epee::byte_stream>& dest, const Vec &vec)
|
||||||
{
|
{
|
||||||
|
using value_type = typename Vec::value_type;
|
||||||
|
static_assert(!std::is_same<value_type, char>::value, "encoding an array of chars is faster as hex");
|
||||||
|
static_assert(!std::is_same<value_type, unsigned char>::value, "encoding an array of unsigned char is faster as hex");
|
||||||
|
|
||||||
dest.StartArray();
|
dest.StartArray();
|
||||||
for (const auto& t : vec)
|
for (const auto& t : vec)
|
||||||
toJsonValue(dest, t);
|
toJsonValue(dest, t);
|
||||||
|
@ -379,6 +386,10 @@ namespace traits
|
||||||
template <typename Vec>
|
template <typename Vec>
|
||||||
inline typename std::enable_if<sfinae::is_vector_like<Vec>::value, void>::type fromJsonValue(const rapidjson::Value& val, Vec& vec)
|
inline typename std::enable_if<sfinae::is_vector_like<Vec>::value, void>::type fromJsonValue(const rapidjson::Value& val, Vec& vec)
|
||||||
{
|
{
|
||||||
|
using value_type = typename Vec::value_type;
|
||||||
|
static_assert(!std::is_same<value_type, char>::value, "encoding a vector of chars is faster as hex");
|
||||||
|
static_assert(!std::is_same<value_type, unsigned char>::value, "encoding a vector of unsigned char is faster as hex");
|
||||||
|
|
||||||
if (!val.IsArray())
|
if (!val.IsArray())
|
||||||
{
|
{
|
||||||
throw WRONG_TYPE("json array");
|
throw WRONG_TYPE("json array");
|
||||||
|
|
|
@ -97,7 +97,7 @@ namespace
|
||||||
|
|
||||||
rapidjson::Document doc;
|
rapidjson::Document doc;
|
||||||
doc.Parse(reinterpret_cast<const char*>(buffer.data()), buffer.size());
|
doc.Parse(reinterpret_cast<const char*>(buffer.data()), buffer.size());
|
||||||
if (doc.HasParseError() || !doc.IsObject())
|
if (doc.HasParseError())
|
||||||
{
|
{
|
||||||
throw cryptonote::json::PARSE_FAIL();
|
throw cryptonote::json::PARSE_FAIL();
|
||||||
}
|
}
|
||||||
|
@ -108,6 +108,21 @@ namespace
|
||||||
}
|
}
|
||||||
} // anonymous
|
} // anonymous
|
||||||
|
|
||||||
|
TEST(JsonSerialization, VectorBytes)
|
||||||
|
{
|
||||||
|
EXPECT_EQ(std::vector<std::uint8_t>{}, test_json(std::vector<std::uint8_t>{}));
|
||||||
|
EXPECT_EQ(std::vector<std::uint8_t>{0x00}, test_json(std::vector<std::uint8_t>{0x00}));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(JsonSerialization, InvalidVectorBytes)
|
||||||
|
{
|
||||||
|
rapidjson::Document doc;
|
||||||
|
doc.SetString("1");
|
||||||
|
|
||||||
|
std::vector<std::uint8_t> out;
|
||||||
|
EXPECT_THROW(cryptonote::json::fromJsonValue(doc, out), cryptonote::json::BAD_INPUT);
|
||||||
|
}
|
||||||
|
|
||||||
TEST(JsonSerialization, MinerTransaction)
|
TEST(JsonSerialization, MinerTransaction)
|
||||||
{
|
{
|
||||||
cryptonote::account_base acct;
|
cryptonote::account_base acct;
|
||||||
|
|
Loading…
Reference in a new issue