Skip to content

Commit 043df2b

Browse files
laanwjjonasschnelli
authored andcommitted
Simplify RPCclient, adapt json_parse_error test
# Conflicts: # src/test/rpc_tests.cpp
1 parent 519eede commit 043df2b

File tree

3 files changed

+30
-33
lines changed

3 files changed

+30
-33
lines changed

src/rpcclient.cpp

Lines changed: 16 additions & 20 deletions
Original file line numberDiff line numberDiff line change
@@ -121,6 +121,18 @@ CRPCConvertTable::CRPCConvertTable()
121121

122122
static CRPCConvertTable rpcCvtTable;
123123

124+
/** Non-RFC4627 JSON parser, accepts internal values (such as numbers, true, false, null)
125+
* as well as objects and arrays.
126+
*/
127+
UniValue ParseNonRFCJSONValue(const std::string& strVal)
128+
{
129+
UniValue jVal;
130+
if (!jVal.read(std::string("[")+strVal+std::string("]")) ||
131+
!jVal.isArray() || jVal.size()!=1)
132+
throw runtime_error(string("Error parsing JSON:")+strVal);
133+
return jVal[0];
134+
}
135+
124136
/** Convert strings to command-specific RPC representation */
125137
UniValue RPCConvertValues(const std::string &strMethod, const std::vector<std::string> &strParams)
126138
{
@@ -129,28 +141,12 @@ UniValue RPCConvertValues(const std::string &strMethod, const std::vector<std::s
129141
for (unsigned int idx = 0; idx < strParams.size(); idx++) {
130142
const std::string& strVal = strParams[idx];
131143

132-
// insert string value directly
133144
if (!rpcCvtTable.convert(strMethod, idx)) {
145+
// insert string value directly
134146
params.push_back(strVal);
135-
}
136-
137-
// parse string as JSON, insert bool/number/object/etc. value
138-
else {
139-
//according to rfc4627 null, true, false are not valid json strings
140-
UniValue jVal;
141-
if(strVal == "null")
142-
jVal.setNull();
143-
else if(strVal == "true")
144-
jVal.setBool(true);
145-
else if(strVal == "false")
146-
jVal.setBool(false);
147-
else
148-
{
149-
if (!jVal.read(strVal) || (jVal.isNull() && strVal.size() > 0))
150-
if(!jVal.setNumStr(strVal) || jVal.isNull())
151-
throw runtime_error(string("Error parsing JSON:")+strVal);
152-
}
153-
params.push_back(jVal);
147+
} else {
148+
// parse string as JSON, insert bool/number/object/etc. value
149+
params.push_back(ParseNonRFCJSONValue(strVal));
154150
}
155151
}
156152

src/rpcclient.h

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,5 +9,9 @@
99
#include "univalue/univalue.h"
1010

1111
UniValue RPCConvertValues(const std::string& strMethod, const std::vector<std::string>& strParams);
12+
/** Non-RFC4627 JSON parser, accepts internal values (such as numbers, true, false, null)
13+
* as well as objects and arrays.
14+
*/
15+
UniValue ParseNonRFCJSONValue(const std::string& strVal);
1216

1317
#endif // BITCOIN_RPCCLIENT_H

src/test/rpc_tests.cpp

Lines changed: 10 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -143,23 +143,20 @@ BOOST_AUTO_TEST_CASE(rpc_parse_monetary_values)
143143

144144
BOOST_AUTO_TEST_CASE(json_parse_errors)
145145
{
146-
UniValue value;
147146
// Valid
148-
BOOST_CHECK_EQUAL(value.read(std::string("1.0")), false);
149-
BOOST_CHECK_EQUAL(value.read(std::string("[1.0]")), true);
150-
// Valid, with trailing whitespace
151-
BOOST_CHECK_EQUAL(value.read(std::string("1.0 ")), false);
152-
BOOST_CHECK_EQUAL(value.read(std::string("[1.0 ] ")), true);
147+
BOOST_CHECK_EQUAL(ParseNonRFCJSONValue("1.0").get_real(), 1.0);
148+
// Valid, with leading or trailing whitespace
149+
BOOST_CHECK_EQUAL(ParseNonRFCJSONValue(" 1.0").get_real(), 1.0);
150+
BOOST_CHECK_EQUAL(ParseNonRFCJSONValue("1.0 ").get_real(), 1.0);
153151
// Invalid, initial garbage
154-
BOOST_CHECK_EQUAL(value.read(std::string("[1.0")), false);
155-
BOOST_CHECK_EQUAL(value.read(std::string("[a1.0]")), false);
156-
BOOST_CHECK_EQUAL(value.read(std::string("[\"a1.0\"]")), true);
152+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("[1.0"), std::runtime_error);
153+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("a1.0"), std::runtime_error);
157154
// Invalid, trailing garbage
158-
BOOST_CHECK_EQUAL(value.read(std::string("1.0sds")), false);
159-
BOOST_CHECK_EQUAL(value.read(std::string("1.0]")), false);
155+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("1.0sds"), std::runtime_error);
156+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("1.0]"), std::runtime_error);
160157
// BTC addresses should fail parsing
161-
BOOST_CHECK_EQUAL(value.read(std::string("175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W")), false);
162-
BOOST_CHECK_EQUAL(value.read(std::string("3J98t1WpEZ73CNmQviecrnyiWrnqRhWNL")), false);
158+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("175tWpb8K1S7NmH4Zx6rewF9WQrcZv245W"), std::runtime_error);
159+
BOOST_CHECK_THROW(ParseNonRFCJSONValue("3J98t1WpEZ73CNmQviecrnyiWrnqRhWNL"), std::runtime_error);
163160
}
164161

165162
BOOST_AUTO_TEST_CASE(rpc_boostasiotocnetaddr)

0 commit comments

Comments
 (0)