From d1885a58743f150fd1ec6979bbb4dfd05ec4900f Mon Sep 17 00:00:00 2001 From: Tatsuhiro Tsujikawa Date: Wed, 15 Jun 2011 00:42:50 +0900 Subject: [PATCH] Allowed missing params in system.multicall RPC method. --- src/RpcMethodImpl.cc | 16 ++++++++++------ test/RpcMethodTest.cc | 5 +---- 2 files changed, 11 insertions(+), 10 deletions(-) diff --git a/src/RpcMethodImpl.cc b/src/RpcMethodImpl.cc index 216c4ce0..3012c218 100644 --- a/src/RpcMethodImpl.cc +++ b/src/RpcMethodImpl.cc @@ -1380,11 +1380,9 @@ SharedHandle SystemMulticallRpcMethod::process continue; } const String* methodName = asString(methodDict->get(KEY_METHOD_NAME)); - const List* paramsList = asList(methodDict->get(KEY_PARAMS)); - - if(!methodName || !paramsList) { + if(!methodName) { list->append(createErrorResponse - (DL_ABORT_EX("Missing methodName or params."), req)); + (DL_ABORT_EX("Missing methodName."), req)); continue; } if(methodName->s() == getMethodName()) { @@ -1392,9 +1390,15 @@ SharedHandle SystemMulticallRpcMethod::process (DL_ABORT_EX("Recursive system.multicall forbidden."), req)); continue; } + const SharedHandle& tempParamsList = methodDict->get(KEY_PARAMS); + SharedHandle paramsList; + if(asList(tempParamsList)) { + paramsList = static_pointer_cast(tempParamsList); + } else { + paramsList = List::g(); + } SharedHandle method = RpcMethodFactory::create(methodName->s()); - RpcRequest innerReq - (methodName->s(), static_pointer_cast(methodDict->get(KEY_PARAMS))); + RpcRequest innerReq(methodName->s(), paramsList); innerReq.jsonRpc = req.jsonRpc; RpcResponse res = method->execute(innerReq, e); if(res.code == 0) { diff --git a/test/RpcMethodTest.cc b/test/RpcMethodTest.cc index 72d03d1d..8d9c5d7a 100644 --- a/test/RpcMethodTest.cc +++ b/test/RpcMethodTest.cc @@ -1129,10 +1129,7 @@ void RpcMethodTest::testSystemMulticall() asInteger (asDict(resParams->get(4))->get("faultCode")) ->i()); - CPPUNIT_ASSERT_EQUAL((int64_t)1, - asInteger - (asDict(resParams->get(5))->get("faultCode")) - ->i()); + CPPUNIT_ASSERT(asList(resParams->get(5))); CPPUNIT_ASSERT(asList(resParams->get(6))); }