aboutsummaryrefslogtreecommitdiff
path: root/src/rpc/server.cpp
diff options
context:
space:
mode:
authorWladimir J. van der Laan <[email protected]>2016-04-15 16:23:16 +0200
committerWladimir J. van der Laan <[email protected]>2016-04-15 16:24:02 +0200
commitbe14ca5e8c0f0e8cd8ef511ccb9c41f245d62fbf (patch)
treedc4ecb77376030b326930abc247133766aee5e9b /src/rpc/server.cpp
parentMerge #7870: [contrib] Add MarcoFalke key and move all keys to contrib/gitian... (diff)
parentAdd lockUnspents option to fundrawtransaction (diff)
downloaddiscoin-be14ca5e8c0f0e8cd8ef511ccb9c41f245d62fbf.tar.xz
discoin-be14ca5e8c0f0e8cd8ef511ccb9c41f245d62fbf.zip
Merge #7518: Add multiple options to fundrawtransaction
f2d0944 Add lockUnspents option to fundrawtransaction (João Barbosa) af4fe7f Add change options to fundrawtransaction (João Barbosa) 41e835d Add strict flag to RPCTypeCheckObj (João Barbosa)
Diffstat (limited to 'src/rpc/server.cpp')
-rw-r--r--src/rpc/server.cpp15
1 files changed, 14 insertions, 1 deletions
diff --git a/src/rpc/server.cpp b/src/rpc/server.cpp
index 8326fe14d..d06a9142b 100644
--- a/src/rpc/server.cpp
+++ b/src/rpc/server.cpp
@@ -89,7 +89,8 @@ void RPCTypeCheck(const UniValue& params,
void RPCTypeCheckObj(const UniValue& o,
const map<string, UniValue::VType>& typesExpected,
- bool fAllowNull)
+ bool fAllowNull,
+ bool fStrict)
{
BOOST_FOREACH(const PAIRTYPE(string, UniValue::VType)& t, typesExpected)
{
@@ -104,6 +105,18 @@ void RPCTypeCheckObj(const UniValue& o,
throw JSONRPCError(RPC_TYPE_ERROR, err);
}
}
+
+ if (fStrict)
+ {
+ BOOST_FOREACH(const string& k, o.getKeys())
+ {
+ if (typesExpected.count(k) == 0)
+ {
+ string err = strprintf("Unexpected key %s", k);
+ throw JSONRPCError(RPC_TYPE_ERROR, err);
+ }
+ }
+ }
}
CAmount AmountFromValue(const UniValue& value)