Renamed classes in abstract layer of RPC service from XmlRpc* to Rpc*.

Now JSON-RPC is available by default regardless of XML library.
XML-RPC becomes available when XML library is available.
pull/1/head
Tatsuhiro Tsujikawa 2011-03-14 16:38:54 +09:00
parent 5a1fb3875f
commit f0cfbb21c1
37 changed files with 715 additions and 711 deletions

View File

@ -72,9 +72,7 @@
#include "SelectEventPoll.h" #include "SelectEventPoll.h"
#include "DlAbortEx.h" #include "DlAbortEx.h"
#include "FileAllocationEntry.h" #include "FileAllocationEntry.h"
#ifdef ENABLE_XML_RPC #include "HttpListenCommand.h"
# include "HttpListenCommand.h"
#endif // ENABLE_XML_RPC
namespace aria2 { namespace aria2 {
@ -165,7 +163,6 @@ DownloadEngineFactory::newDownloadEngine
stopSec)); stopSec));
} }
} }
#ifdef ENABLE_XML_RPC
if(op->getAsBool(PREF_ENABLE_XML_RPC)) { if(op->getAsBool(PREF_ENABLE_XML_RPC)) {
static int families[] = { AF_INET, AF_INET6 }; static int families[] = { AF_INET, AF_INET6 };
size_t familiesLength = op->getAsBool(PREF_DISABLE_IPV6)?1:2; size_t familiesLength = op->getAsBool(PREF_DISABLE_IPV6)?1:2;
@ -179,7 +176,6 @@ DownloadEngineFactory::newDownloadEngine
} }
} }
} }
#endif // ENABLE_XML_RPC
return e; return e;
} }

View File

@ -45,7 +45,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace { namespace {
struct SessionData { struct SessionData {
@ -104,7 +104,7 @@ void mlCharacters(void* userData, const char* ch, int len)
} }
} // namespace } // namespace
XmlRpcRequest RpcRequest
XmlRpcRequestProcessor::parseMemory(const std::string& xml) XmlRpcRequestProcessor::parseMemory(const std::string& xml)
{ {
stm_.reset(new XmlRpcRequestParserStateMachine()); stm_.reset(new XmlRpcRequestParserStateMachine());
@ -125,10 +125,10 @@ XmlRpcRequestProcessor::parseMemory(const std::string& xml)
if(!asList(stm_->getCurrentFrameValue())) { if(!asList(stm_->getCurrentFrameValue())) {
throw DL_ABORT_EX("Bad XML-RPC parameter list"); throw DL_ABORT_EX("Bad XML-RPC parameter list");
} }
return XmlRpcRequest(stm_->getMethodName(), return RpcRequest(stm_->getMethodName(),
static_pointer_cast<List>(stm_->getCurrentFrameValue())); static_pointer_cast<List>(stm_->getCurrentFrameValue()));
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -40,11 +40,11 @@
#include <string> #include <string>
#include "SharedHandle.h" #include "SharedHandle.h"
#include "XmlRpcRequest.h" #include "RpcRequest.h"
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserStateMachine; class XmlRpcRequestParserStateMachine;
@ -52,10 +52,10 @@ class XmlRpcRequestProcessor {
private: private:
SharedHandle<XmlRpcRequestParserStateMachine> stm_; SharedHandle<XmlRpcRequestParserStateMachine> stm_;
public: public:
XmlRpcRequest parseMemory(const std::string& xml); RpcRequest parseMemory(const std::string& xml);
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -45,11 +45,6 @@
#include "HttpServerResponseCommand.h" #include "HttpServerResponseCommand.h"
#include "OptionParser.h" #include "OptionParser.h"
#include "OptionHandler.h" #include "OptionHandler.h"
#include "XmlRpcRequestProcessor.h"
#include "XmlRpcRequestParserStateMachine.h"
#include "XmlRpcMethod.h"
#include "XmlRpcMethodFactory.h"
#include "XmlRpcResponse.h"
#include "wallclock.h" #include "wallclock.h"
#include "util.h" #include "util.h"
#include "fmt.h" #include "fmt.h"
@ -57,6 +52,14 @@
#include "json.h" #include "json.h"
#include "DlAbortEx.h" #include "DlAbortEx.h"
#include "message.h" #include "message.h"
#include "RpcMethod.h"
#include "RpcMethodFactory.h"
#include "RpcRequest.h"
#include "RpcResponse.h"
#ifdef ENABLE_XML_RPC
# include "XmlRpcRequestProcessor.h"
# include "XmlRpcRequestParserStateMachine.h"
#endif // ENABLE_XML_RPC
namespace aria2 { namespace aria2 {
@ -84,7 +87,7 @@ HttpServerBodyCommand::~HttpServerBodyCommand()
} }
namespace { namespace {
xmlrpc::XmlRpcResponse rpc::RpcResponse
createJsonRpcErrorResponse createJsonRpcErrorResponse
(int code, (int code,
const std::string& msg, const std::string& msg,
@ -93,13 +96,13 @@ createJsonRpcErrorResponse
SharedHandle<Dict> params = Dict::g(); SharedHandle<Dict> params = Dict::g();
params->put("code", Integer::g(code)); params->put("code", Integer::g(code));
params->put("message", msg); params->put("message", msg);
xmlrpc::XmlRpcResponse res(code, params, id); rpc::RpcResponse res(code, params, id);
return res; return res;
} }
} // namespace } // namespace
void HttpServerBodyCommand::sendJsonRpcResponse void HttpServerBodyCommand::sendJsonRpcResponse
(const xmlrpc::XmlRpcResponse& res, (const rpc::RpcResponse& res,
const std::string& callback) const std::string& callback)
{ {
bool gzip = httpServer_->supportsGZip(); bool gzip = httpServer_->supportsGZip();
@ -126,11 +129,11 @@ void HttpServerBodyCommand::sendJsonRpcResponse
} }
void HttpServerBodyCommand::sendJsonRpcBatchResponse void HttpServerBodyCommand::sendJsonRpcBatchResponse
(const std::vector<xmlrpc::XmlRpcResponse>& results, (const std::vector<rpc::RpcResponse>& results,
const std::string& callback) const std::string& callback)
{ {
bool gzip = httpServer_->supportsGZip(); bool gzip = httpServer_->supportsGZip();
std::string responseData = xmlrpc::toJsonBatch(results, callback, gzip); std::string responseData = rpc::toJsonBatch(results, callback, gzip);
httpServer_->feedResponse(responseData, "application/json-rpc"); httpServer_->feedResponse(responseData, "application/json-rpc");
addHttpServerResponseCommand(); addHttpServerResponseCommand();
} }
@ -143,7 +146,7 @@ void HttpServerBodyCommand::addHttpServerResponseCommand()
e_->setNoWait(true); e_->setNoWait(true);
} }
xmlrpc::XmlRpcResponse rpc::RpcResponse
HttpServerBodyCommand::processJsonRpcRequest(const Dict* jsondict) HttpServerBodyCommand::processJsonRpcRequest(const Dict* jsondict)
{ {
@ -165,16 +168,16 @@ HttpServerBodyCommand::processJsonRpcRequest(const Dict* jsondict)
// TODO No support for Named params // TODO No support for Named params
return createJsonRpcErrorResponse(-32602, "Invalid params.", id); return createJsonRpcErrorResponse(-32602, "Invalid params.", id);
} }
xmlrpc::XmlRpcRequest req(methodName->s(), params, id); rpc::RpcRequest req(methodName->s(), params, id);
SharedHandle<xmlrpc::XmlRpcMethod> method; SharedHandle<rpc::RpcMethod> method;
try { try {
method = xmlrpc::XmlRpcMethodFactory::create(req.methodName); method = rpc::RpcMethodFactory::create(req.methodName);
} catch(RecoverableException& e) { } catch(RecoverableException& e) {
A2_LOG_INFO_EX(EX_EXCEPTION_CAUGHT, e); A2_LOG_INFO_EX(EX_EXCEPTION_CAUGHT, e);
return createJsonRpcErrorResponse(-32601, "Method not found.", id); return createJsonRpcErrorResponse(-32601, "Method not found.", id);
} }
method->setJsonRpc(true); method->setJsonRpc(true);
xmlrpc::XmlRpcResponse res = method->execute(req, e_); rpc::RpcResponse res = method->execute(req, e_);
return res; return res;
} }
@ -200,16 +203,17 @@ bool HttpServerBodyCommand::execute()
reqPath.erase(reqPath.size()-query.size(), query.size()); reqPath.erase(reqPath.size()-query.size(), query.size());
// Do something for requestpath and body // Do something for requestpath and body
if(reqPath == "/rpc") { if(reqPath == "/rpc") {
xmlrpc::XmlRpcRequest req = #ifdef ENABLE_XML_RPC
xmlrpc::XmlRpcRequestProcessor().parseMemory(httpServer_->getBody()); rpc::RpcRequest req =
rpc::XmlRpcRequestProcessor().parseMemory(httpServer_->getBody());
SharedHandle<xmlrpc::XmlRpcMethod> method = SharedHandle<rpc::RpcMethod> method =
xmlrpc::XmlRpcMethodFactory::create(req.methodName); rpc::RpcMethodFactory::create(req.methodName);
xmlrpc::XmlRpcResponse res = method->execute(req, e_); rpc::RpcResponse res = method->execute(req, e_);
bool gzip = httpServer_->supportsGZip(); bool gzip = httpServer_->supportsGZip();
std::string responseData = res.toXml(gzip); std::string responseData = res.toXml(gzip);
httpServer_->feedResponse(responseData, "text/xml"); httpServer_->feedResponse(responseData, "text/xml");
addHttpServerResponseCommand(); addHttpServerResponseCommand();
#endif // ENABLE_XML_RPC
return true; return true;
} else if(reqPath == "/jsonrpc") { } else if(reqPath == "/jsonrpc") {
std::string callback; std::string callback;
@ -227,7 +231,7 @@ bool HttpServerBodyCommand::execute()
(fmt("CUID#%lld - Failed to parse JSON-RPC request", (fmt("CUID#%lld - Failed to parse JSON-RPC request",
getCuid()), getCuid()),
e); e);
xmlrpc::XmlRpcResponse res rpc::RpcResponse res
(createJsonRpcErrorResponse (createJsonRpcErrorResponse
(-32700, "Parse error.", SharedHandle<ValueBase>())); (-32700, "Parse error.", SharedHandle<ValueBase>()));
sendJsonRpcResponse(res, callback); sendJsonRpcResponse(res, callback);
@ -235,24 +239,24 @@ bool HttpServerBodyCommand::execute()
} }
const Dict* jsondict = asDict(json); const Dict* jsondict = asDict(json);
if(jsondict) { if(jsondict) {
xmlrpc::XmlRpcResponse res = processJsonRpcRequest(jsondict); rpc::RpcResponse res = processJsonRpcRequest(jsondict);
sendJsonRpcResponse(res, callback); sendJsonRpcResponse(res, callback);
} else { } else {
const List* jsonlist = asList(json); const List* jsonlist = asList(json);
if(jsonlist) { if(jsonlist) {
// This is batch call // This is batch call
std::vector<xmlrpc::XmlRpcResponse> results; std::vector<rpc::RpcResponse> results;
for(List::ValueType::const_iterator i = jsonlist->begin(), for(List::ValueType::const_iterator i = jsonlist->begin(),
eoi = jsonlist->end(); i != eoi; ++i) { eoi = jsonlist->end(); i != eoi; ++i) {
const Dict* jsondict = asDict(*i); const Dict* jsondict = asDict(*i);
if(jsondict) { if(jsondict) {
xmlrpc::XmlRpcResponse r = processJsonRpcRequest(jsondict); rpc::RpcResponse r = processJsonRpcRequest(jsondict);
results.push_back(r); results.push_back(r);
} }
} }
sendJsonRpcBatchResponse(results, callback); sendJsonRpcBatchResponse(results, callback);
} else { } else {
xmlrpc::XmlRpcResponse res rpc::RpcResponse res
(createJsonRpcErrorResponse (createJsonRpcErrorResponse
(-32600, "Invalid Request.", SharedHandle<ValueBase>())); (-32600, "Invalid Request.", SharedHandle<ValueBase>()));
sendJsonRpcResponse(res, callback); sendJsonRpcResponse(res, callback);

View File

@ -39,7 +39,7 @@
#include "SharedHandle.h" #include "SharedHandle.h"
#include "TimerA2.h" #include "TimerA2.h"
#include "ValueBase.h" #include "ValueBase.h"
#include "XmlRpcResponse.h" #include "RpcResponse.h"
namespace aria2 { namespace aria2 {
@ -60,12 +60,12 @@ private:
const SharedHandle<ValueBase>& id, const SharedHandle<ValueBase>& id,
const std::string& callback); const std::string& callback);
void sendJsonRpcResponse void sendJsonRpcResponse
(const xmlrpc::XmlRpcResponse& res, (const rpc::RpcResponse& res,
const std::string& callback); const std::string& callback);
void sendJsonRpcBatchResponse void sendJsonRpcBatchResponse
(const std::vector<xmlrpc::XmlRpcResponse>& results, (const std::vector<rpc::RpcResponse>& results,
const std::string& callback); const std::string& callback);
xmlrpc::XmlRpcResponse processJsonRpcRequest(const Dict* jsondict); rpc::RpcResponse processJsonRpcRequest(const Dict* jsondict);
void addHttpServerResponseCommand(); void addHttpServerResponseCommand();
public: public:
HttpServerBodyCommand(cuid_t cuid, HttpServerBodyCommand(cuid_t cuid,

View File

@ -211,7 +211,17 @@ SRCS = Socket.h\
uri.cc uri.h\ uri.cc uri.h\
Triplet.h\ Triplet.h\
cookie_helper.cc cookie_helper.h\ cookie_helper.cc cookie_helper.h\
json.cc json.h json.cc json.h\
HttpServerBodyCommand.cc HttpServerBodyCommand.h\
RpcRequest.cc RpcRequest.h\
RpcMethod.cc RpcMethod.h\
RpcMethodImpl.cc RpcMethodImpl.h\
RpcMethodFactory.cc RpcMethodFactory.h\
RpcResponse.cc RpcResponse.h\
HttpListenCommand.cc HttpListenCommand.h\
HttpServerCommand.cc HttpServerCommand.h\
HttpServerResponseCommand.cc HttpServerResponseCommand.h\
HttpServer.cc HttpServer.h
if ENABLE_XML_RPC if ENABLE_XML_RPC
SRCS += XmlRpcRequestParserController.cc XmlRpcRequestParserController.h\ SRCS += XmlRpcRequestParserController.cc XmlRpcRequestParserController.h\
@ -219,17 +229,7 @@ SRCS += XmlRpcRequestParserController.cc XmlRpcRequestParserController.h\
XmlRpcRequestParserState.h\ XmlRpcRequestParserState.h\
XmlRpcRequestParserStateImpl.cc XmlRpcRequestParserStateImpl.h\ XmlRpcRequestParserStateImpl.cc XmlRpcRequestParserStateImpl.h\
XmlRpcElements.cc XmlRpcElements.h\ XmlRpcElements.cc XmlRpcElements.h\
XmlRpcRequest.cc XmlRpcRequest.h\ XmlRpcRequestProcessor.h
XmlRpcRequestProcessor.h\
HttpServerBodyCommand.cc HttpServerBodyCommand.h\
XmlRpcMethod.cc XmlRpcMethod.h\
XmlRpcMethodImpl.cc XmlRpcMethodImpl.h\
XmlRpcMethodFactory.cc XmlRpcMethodFactory.h\
XmlRpcResponse.cc XmlRpcResponse.h\
HttpListenCommand.cc HttpListenCommand.h\
HttpServerCommand.cc HttpServerCommand.h\
HttpServerResponseCommand.cc HttpServerResponseCommand.h\
HttpServer.cc HttpServer.h
if HAVE_LIBXML2 if HAVE_LIBXML2
SRCS += Xml2XmlRpcRequestProcessor.cc Xml2XmlRpcRequestProcessor.h SRCS += Xml2XmlRpcRequestProcessor.cc Xml2XmlRpcRequestProcessor.h

View File

@ -228,7 +228,6 @@ OptionHandlers OptionHandlerFactory::createOptionHandlers()
handlers.push_back(op); handlers.push_back(op);
} }
#endif // ENABLE_DIRECT_IO #endif // ENABLE_DIRECT_IO
#ifdef ENABLE_XML_RPC
{ {
SharedHandle<OptionHandler> op(new BooleanOptionHandler SharedHandle<OptionHandler> op(new BooleanOptionHandler
(PREF_ENABLE_XML_RPC, (PREF_ENABLE_XML_RPC,
@ -238,7 +237,6 @@ OptionHandlers OptionHandlerFactory::createOptionHandlers()
op->addTag(TAG_XML_RPC); op->addTag(TAG_XML_RPC);
handlers.push_back(op); handlers.push_back(op);
} }
#endif // ENABLE_XML_RPC
{ {
std::string params[] = { std::string params[] = {
#ifdef HAVE_EPOLL #ifdef HAVE_EPOLL
@ -568,7 +566,6 @@ OptionHandlers OptionHandlerFactory::createOptionHandlers()
op->addTag(TAG_ADVANCED); op->addTag(TAG_ADVANCED);
handlers.push_back(op); handlers.push_back(op);
} }
#ifdef ENABLE_XML_RPC
{ {
SharedHandle<OptionHandler> op(new BooleanOptionHandler SharedHandle<OptionHandler> op(new BooleanOptionHandler
(PREF_XML_RPC_LISTEN_ALL, (PREF_XML_RPC_LISTEN_ALL,
@ -610,7 +607,6 @@ OptionHandlers OptionHandlerFactory::createOptionHandlers()
op->addTag(TAG_XML_RPC); op->addTag(TAG_XML_RPC);
handlers.push_back(op); handlers.push_back(op);
} }
#endif // ENABLE_XML_RPC
// HTTP/FTP options // HTTP/FTP options
{ {
SharedHandle<OptionHandler> op(new NumberOptionHandler SharedHandle<OptionHandler> op(new NumberOptionHandler

View File

@ -100,11 +100,9 @@ RequestGroupMan::~RequestGroupMan() {}
bool RequestGroupMan::downloadFinished() bool RequestGroupMan::downloadFinished()
{ {
#ifdef ENABLE_XML_RPC
if(xmlRpc_) { if(xmlRpc_) {
return false; return false;
} }
#endif // ENABLE_XML_RPC
return requestGroups_.empty() && reservedGroups_.empty(); return requestGroups_.empty() && reservedGroups_.empty();
} }

View File

@ -32,7 +32,7 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#include "XmlRpcMethod.h" #include "RpcMethod.h"
#include "DownloadEngine.h" #include "DownloadEngine.h"
#include "LogFactory.h" #include "LogFactory.h"
#include "RecoverableException.h" #include "RecoverableException.h"
@ -42,24 +42,24 @@
#include "Option.h" #include "Option.h"
#include "array_fun.h" #include "array_fun.h"
#include "download_helper.h" #include "download_helper.h"
#include "XmlRpcRequest.h" #include "RpcRequest.h"
#include "XmlRpcResponse.h" #include "RpcResponse.h"
#include "prefs.h" #include "prefs.h"
#include "fmt.h" #include "fmt.h"
#include "DlAbortEx.h" #include "DlAbortEx.h"
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
XmlRpcMethod::XmlRpcMethod() RpcMethod::RpcMethod()
: optionParser_(OptionParser::getInstance()), : optionParser_(OptionParser::getInstance()),
jsonRpc_(false) jsonRpc_(false)
{} {}
XmlRpcMethod::~XmlRpcMethod() {} RpcMethod::~RpcMethod() {}
SharedHandle<ValueBase> XmlRpcMethod::createErrorResponse SharedHandle<ValueBase> RpcMethod::createErrorResponse
(const Exception& e) (const Exception& e)
{ {
SharedHandle<Dict> params = Dict::g(); SharedHandle<Dict> params = Dict::g();
@ -68,14 +68,14 @@ SharedHandle<ValueBase> XmlRpcMethod::createErrorResponse
return params; return params;
} }
XmlRpcResponse XmlRpcMethod::execute RpcResponse RpcMethod::execute
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
try { try {
return XmlRpcResponse(0, process(req, e), req.id); return RpcResponse(0, process(req, e), req.id);
} catch(RecoverableException& e) { } catch(RecoverableException& e) {
A2_LOG_DEBUG_EX(EX_EXCEPTION_CAUGHT, e); A2_LOG_DEBUG_EX(EX_EXCEPTION_CAUGHT, e);
return XmlRpcResponse(1, createErrorResponse(e), req.id); return RpcResponse(1, createErrorResponse(e), req.id);
} }
} }
@ -123,7 +123,7 @@ void gatherOption
} }
} // namespace } // namespace
void XmlRpcMethod::gatherRequestOption void RpcMethod::gatherRequestOption
(const SharedHandle<Option>& option, const Dict* optionsDict) (const SharedHandle<Option>& option, const Dict* optionsDict)
{ {
if(optionsDict) { if(optionsDict) {
@ -162,7 +162,7 @@ const std::set<std::string>& listChangeableOptions()
return options; return options;
} }
void XmlRpcMethod::gatherChangeableOption void RpcMethod::gatherChangeableOption
(const SharedHandle<Option>& option, const Dict* optionsDict) (const SharedHandle<Option>& option, const Dict* optionsDict)
{ {
if(optionsDict) { if(optionsDict) {
@ -172,7 +172,7 @@ void XmlRpcMethod::gatherChangeableOption
} }
} }
void XmlRpcMethod::applyChangeableOption(Option* dest, Option* src) const void RpcMethod::applyChangeableOption(Option* dest, Option* src) const
{ {
applyOption(listChangeableOptions().begin(), listChangeableOptions().end(), applyOption(listChangeableOptions().begin(), listChangeableOptions().end(),
dest, src); dest, src);
@ -191,7 +191,7 @@ const std::set<std::string>& listChangeableGlobalOptions()
return options; return options;
} }
void XmlRpcMethod::gatherChangeableGlobalOption void RpcMethod::gatherChangeableGlobalOption
(const SharedHandle<Option>& option, const Dict* optionsDict) (const SharedHandle<Option>& option, const Dict* optionsDict)
{ {
if(optionsDict) { if(optionsDict) {
@ -201,13 +201,13 @@ void XmlRpcMethod::gatherChangeableGlobalOption
} }
} }
void XmlRpcMethod::applyChangeableGlobalOption(Option* dest, Option* src) const void RpcMethod::applyChangeableGlobalOption(Option* dest, Option* src) const
{ {
applyOption(listChangeableGlobalOptions().begin(), applyOption(listChangeableGlobalOptions().begin(),
listChangeableGlobalOptions().end(), listChangeableGlobalOptions().end(),
dest, src); dest, src);
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -32,8 +32,8 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#ifndef D_XML_RPC_METHOD_H #ifndef D_RPC_METHOD_H
#define D_XML_RPC_METHOD_H #define D_RPC_METHOD_H
#include "common.h" #include "common.h"
@ -49,28 +49,28 @@ class OptionParser;
class Option; class Option;
class Exception; class Exception;
namespace xmlrpc { namespace rpc {
struct XmlRpcRequest; struct RpcRequest;
struct XmlRpcResponse; struct RpcResponse;
// This class offers abstract implementation of processing XML-RPC // This class offers abstract implementation of processing RPC
// request. You have to inherit this class and implement process() // request. You have to inherit this class and implement process()
// method to add new XML-RPC API. // method to add new RPC API.
// //
// There is XmlRpcMethodFactory class which instantiates XmlRpcMethod // There is RpcMethodFactory class which instantiates RpcMethod
// subclass. If you add new XmlRpcMethod subclass, don't forget to add // subclass. If you add new RpcMethod subclass, don't forget to add it
// it to XmlRpcMethodFactory. // to RpcMethodFactory.
class XmlRpcMethod { class RpcMethod {
private: private:
SharedHandle<OptionParser> optionParser_; SharedHandle<OptionParser> optionParser_;
bool jsonRpc_; bool jsonRpc_;
protected: protected:
// Subclass must implement this function to fulfil XmlRpcRequest // Subclass must implement this function to fulfil RpcRequest req.
// req. The return value of this method is used as a return value // The return value of this method is used as a return value of RPC
// of XML-RPC request. // request.
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e) = 0; (const RpcRequest& req, DownloadEngine* e) = 0;
void gatherRequestOption void gatherRequestOption
(const SharedHandle<Option>& option, const Dict* optionsDict); (const SharedHandle<Option>& option, const Dict* optionsDict);
@ -78,14 +78,14 @@ protected:
void gatherChangeableOption void gatherChangeableOption
(const SharedHandle<Option>& option, const Dict* optionDict); (const SharedHandle<Option>& option, const Dict* optionDict);
// Copy options which is changeable in XML-RPC changeOption command // Copy options which is changeable in RPC changeOption command to
// to dest. // dest.
void applyChangeableOption(Option* dest, Option* src) const; void applyChangeableOption(Option* dest, Option* src) const;
void gatherChangeableGlobalOption(const SharedHandle<Option>& option, void gatherChangeableGlobalOption(const SharedHandle<Option>& option,
const Dict* optionDict); const Dict* optionDict);
// Copy options which is changeable in XML-RPC changeGlobalOption // Copy options which is changeable in RPC changeGlobalOption
// command to dest. // command to dest.
void applyChangeableGlobalOption(Option* dest, Option* src) const; void applyChangeableGlobalOption(Option* dest, Option* src) const;
@ -96,13 +96,13 @@ protected:
return optionParser_; return optionParser_;
} }
public: public:
XmlRpcMethod(); RpcMethod();
virtual ~XmlRpcMethod(); virtual ~RpcMethod();
// Do work to fulfill XmlRpcRequest req and returns its result as // Do work to fulfill RpcRequest req and returns its result as
// XmlRpcResponse. This method delegates to process() method. // RpcResponse. This method delegates to process() method.
XmlRpcResponse execute(const XmlRpcRequest& req, DownloadEngine* e); RpcResponse execute(const RpcRequest& req, DownloadEngine* e);
// Set whether JSON-RPC style parameter handling. // Set whether JSON-RPC style parameter handling.
void setJsonRpc(bool f) void setJsonRpc(bool f)
{ {
@ -114,8 +114,8 @@ public:
} }
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_METHOD_H #endif // D_RPC_METHOD_H

127
src/RpcMethodFactory.cc Normal file
View File

@ -0,0 +1,127 @@
/* <!-- copyright */
/*
* aria2 - The high speed download utility
*
* Copyright (C) 2009 Tatsuhiro Tsujikawa
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the
* OpenSSL library under certain conditions as described in each
* individual source file, and distribute linked combinations
* including the two.
* You must obey the GNU General Public License in all respects
* for all of the code used other than OpenSSL. If you modify
* file(s) with this exception, you may extend this exception to your
* version of the file(s), but you are not obligated to do so. If you
* do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source
* files in the program, then also delete it here.
*/
/* copyright --> */
#include "RpcMethodFactory.h"
#include "RpcMethodImpl.h"
#include "OptionParser.h"
#include "OptionHandler.h"
namespace aria2 {
namespace rpc {
SharedHandle<RpcMethod>
RpcMethodFactory::create(const std::string& methodName)
{
if(methodName == AddUriRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new AddUriRpcMethod());
#ifdef ENABLE_BITTORRENT
} else if(methodName == AddTorrentRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new AddTorrentRpcMethod());
#endif // ENABLE_BITTORRENT
#ifdef ENABLE_METALINK
}
else if(methodName == AddMetalinkRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new AddMetalinkRpcMethod());
#endif // ENABLE_METALINK
}
else if(methodName == RemoveRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new RemoveRpcMethod());
} else if(methodName == PauseRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new PauseRpcMethod());
} else if(methodName == ForcePauseRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ForcePauseRpcMethod());
} else if(methodName == PauseAllRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new PauseAllRpcMethod());
} else if(methodName == ForcePauseAllRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ForcePauseAllRpcMethod());
} else if(methodName == UnpauseRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new UnpauseRpcMethod());
} else if(methodName == UnpauseAllRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new UnpauseAllRpcMethod());
} else if(methodName == ForceRemoveRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ForceRemoveRpcMethod());
} else if(methodName == ChangePositionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ChangePositionRpcMethod());
} else if(methodName == TellStatusRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new TellStatusRpcMethod());
} else if(methodName == GetUrisRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetUrisRpcMethod());
} else if(methodName == GetFilesRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetFilesRpcMethod());
#ifdef ENABLE_BITTORRENT
}
else if(methodName == GetPeersRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetPeersRpcMethod());
#endif // ENABLE_BITTORRENT
} else if(methodName == GetServersRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetServersRpcMethod());
} else if(methodName == TellActiveRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new TellActiveRpcMethod());
} else if(methodName == TellWaitingRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new TellWaitingRpcMethod());
} else if(methodName == TellStoppedRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new TellStoppedRpcMethod());
} else if(methodName == GetOptionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetOptionRpcMethod());
} else if(methodName == ChangeUriRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ChangeUriRpcMethod());
} else if(methodName == ChangeOptionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ChangeOptionRpcMethod());
} else if(methodName == GetGlobalOptionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetGlobalOptionRpcMethod());
} else if(methodName == ChangeGlobalOptionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ChangeGlobalOptionRpcMethod());
} else if(methodName == PurgeDownloadResultRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new PurgeDownloadResultRpcMethod());
} else if(methodName == RemoveDownloadResultRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new RemoveDownloadResultRpcMethod());
} else if(methodName == GetVersionRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetVersionRpcMethod());
} else if(methodName == GetSessionInfoRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new GetSessionInfoRpcMethod());
} else if(methodName == ShutdownRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ShutdownRpcMethod());
} else if(methodName == ForceShutdownRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new ForceShutdownRpcMethod());
} else if(methodName == SystemMulticallRpcMethod::getMethodName()) {
return SharedHandle<RpcMethod>(new SystemMulticallRpcMethod());
} else {
return SharedHandle<RpcMethod>(new NoSuchMethodRpcMethod());
}
}
} // namespace rpc
} // namespace aria2

View File

@ -32,8 +32,8 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#ifndef D_XML_RPC_METHOD_FACTORY_H #ifndef D_RPC_METHOD_FACTORY_H
#define D_XML_RPC_METHOD_FACTORY_H #define D_RPC_METHOD_FACTORY_H
#include "common.h" #include "common.h"
@ -43,17 +43,17 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcMethod; class RpcMethod;
class XmlRpcMethodFactory { class RpcMethodFactory {
public: public:
static SharedHandle<XmlRpcMethod> create(const std::string& methodName); static SharedHandle<RpcMethod> create(const std::string& methodName);
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_METHOD_FACTORY_H #endif // D_RPC_METHOD_FACTORY_H

View File

@ -32,7 +32,7 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#include "XmlRpcMethodImpl.h" #include "RpcMethodImpl.h"
#include <cassert> #include <cassert>
#include <algorithm> #include <algorithm>
@ -49,7 +49,7 @@
#include "util.h" #include "util.h"
#include "RequestGroupMan.h" #include "RequestGroupMan.h"
#include "fmt.h" #include "fmt.h"
#include "XmlRpcRequest.h" #include "RpcRequest.h"
#include "PieceStorage.h" #include "PieceStorage.h"
#include "DownloadContext.h" #include "DownloadContext.h"
#include "DiskAdaptor.h" #include "DiskAdaptor.h"
@ -58,8 +58,8 @@
#include "message.h" #include "message.h"
#include "FeatureConfig.h" #include "FeatureConfig.h"
#include "array_fun.h" #include "array_fun.h"
#include "XmlRpcMethodFactory.h" #include "RpcMethodFactory.h"
#include "XmlRpcResponse.h" #include "RpcResponse.h"
#include "SegmentMan.h" #include "SegmentMan.h"
#include "TimedHaltCommand.h" #include "TimedHaltCommand.h"
#include "PeerStat.h" #include "PeerStat.h"
@ -77,7 +77,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace { namespace {
const SharedHandle<String> VLB_TRUE = String::g("true"); const SharedHandle<String> VLB_TRUE = String::g("true");
@ -173,8 +173,8 @@ findRequestGroup(const SharedHandle<RequestGroupMan>& rgman, gid_t gid)
} // namespace } // namespace
namespace { namespace {
void getPosParam(const XmlRpcRequest& req, size_t posParamIndex, void getPosParam(const RpcRequest& req, size_t posParamIndex,
bool& posGiven, size_t& pos) bool& posGiven, size_t& pos)
{ {
const Integer* p = req.getIntegerParam(posParamIndex); const Integer* p = req.getIntegerParam(posParamIndex);
if(p) { if(p) {
@ -192,7 +192,7 @@ void getPosParam(const XmlRpcRequest& req, size_t posParamIndex,
namespace { namespace {
gid_t getRequiredGidParam gid_t getRequiredGidParam
(const XmlRpcRequest& req, size_t posParamIndex) (const RpcRequest& req, size_t posParamIndex)
{ {
const String* gidParam = req.getStringParam(posParamIndex); const String* gidParam = req.getStringParam(posParamIndex);
if(gidParam) { if(gidParam) {
@ -219,8 +219,8 @@ void extractUris(OutputIterator out, const List* src)
} }
} // namespace } // namespace
SharedHandle<ValueBase> AddUriXmlRpcMethod::process SharedHandle<ValueBase> AddUriRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
std::vector<std::string> uris; std::vector<std::string> uris;
extractUris(std::back_inserter(uris), req.getListParam(0)); extractUris(std::back_inserter(uris), req.getListParam(0));
@ -260,8 +260,8 @@ std::string getHexSha1(const std::string& s)
} // namespace } // namespace
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
SharedHandle<ValueBase> AddTorrentXmlRpcMethod::process SharedHandle<ValueBase> AddTorrentRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const String* torrentParam = req.getStringParam(0); const String* torrentParam = req.getStringParam(0);
if(!torrentParam) { if(!torrentParam) {
@ -307,8 +307,8 @@ SharedHandle<ValueBase> AddTorrentXmlRpcMethod::process
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
#ifdef ENABLE_METALINK #ifdef ENABLE_METALINK
SharedHandle<ValueBase> AddMetalinkXmlRpcMethod::process SharedHandle<ValueBase> AddMetalinkRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const String* metalinkParam = req.getStringParam(0); const String* metalinkParam = req.getStringParam(0);
if(!metalinkParam) { if(!metalinkParam) {
@ -362,7 +362,7 @@ SharedHandle<ValueBase> AddMetalinkXmlRpcMethod::process
namespace { namespace {
SharedHandle<ValueBase> removeDownload SharedHandle<ValueBase> removeDownload
(const XmlRpcRequest& req, DownloadEngine* e, bool forceRemove) (const RpcRequest& req, DownloadEngine* e, bool forceRemove)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -393,14 +393,14 @@ SharedHandle<ValueBase> removeDownload
} }
} // namespace } // namespace
SharedHandle<ValueBase> RemoveXmlRpcMethod::process SharedHandle<ValueBase> RemoveRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return removeDownload(req, e, false); return removeDownload(req, e, false);
} }
SharedHandle<ValueBase> ForceRemoveXmlRpcMethod::process SharedHandle<ValueBase> ForceRemoveRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return removeDownload(req, e, true); return removeDownload(req, e, true);
} }
@ -433,7 +433,7 @@ bool pauseRequestGroup
namespace { namespace {
SharedHandle<ValueBase> pauseDownload SharedHandle<ValueBase> pauseDownload
(const XmlRpcRequest& req, DownloadEngine* e, bool forcePause) (const RpcRequest& req, DownloadEngine* e, bool forcePause)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -454,14 +454,14 @@ SharedHandle<ValueBase> pauseDownload
} }
} // namespace } // namespace
SharedHandle<ValueBase> PauseXmlRpcMethod::process SharedHandle<ValueBase> PauseRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return pauseDownload(req, e, false); return pauseDownload(req, e, false);
} }
SharedHandle<ValueBase> ForcePauseXmlRpcMethod::process SharedHandle<ValueBase> ForcePauseRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return pauseDownload(req, e, true); return pauseDownload(req, e, true);
} }
@ -479,7 +479,7 @@ void pauseRequestGroups
namespace { namespace {
SharedHandle<ValueBase> pauseAllDownloads SharedHandle<ValueBase> pauseAllDownloads
(const XmlRpcRequest& req, DownloadEngine* e, bool forcePause) (const RpcRequest& req, DownloadEngine* e, bool forcePause)
{ {
const std::deque<SharedHandle<RequestGroup> >& groups = const std::deque<SharedHandle<RequestGroup> >& groups =
e->getRequestGroupMan()->getRequestGroups(); e->getRequestGroupMan()->getRequestGroups();
@ -492,20 +492,20 @@ SharedHandle<ValueBase> pauseAllDownloads
} }
} // namespace } // namespace
SharedHandle<ValueBase> PauseAllXmlRpcMethod::process SharedHandle<ValueBase> PauseAllRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return pauseAllDownloads(req, e, false); return pauseAllDownloads(req, e, false);
} }
SharedHandle<ValueBase> ForcePauseAllXmlRpcMethod::process SharedHandle<ValueBase> ForcePauseAllRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return pauseAllDownloads(req, e, true); return pauseAllDownloads(req, e, true);
} }
SharedHandle<ValueBase> UnpauseXmlRpcMethod::process SharedHandle<ValueBase> UnpauseRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
SharedHandle<RequestGroup> group = SharedHandle<RequestGroup> group =
@ -521,8 +521,8 @@ SharedHandle<ValueBase> UnpauseXmlRpcMethod::process
return createGIDResponse(gid); return createGIDResponse(gid);
} }
SharedHandle<ValueBase> UnpauseAllXmlRpcMethod::process SharedHandle<ValueBase> UnpauseAllRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const std::deque<SharedHandle<RequestGroup> >& groups = const std::deque<SharedHandle<RequestGroup> >& groups =
e->getRequestGroupMan()->getReservedGroups(); e->getRequestGroupMan()->getReservedGroups();
@ -862,8 +862,8 @@ void gatherStoppedDownload
} }
} }
SharedHandle<ValueBase> GetFilesXmlRpcMethod::process SharedHandle<ValueBase> GetFilesRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
SharedHandle<List> files = List::g(); SharedHandle<List> files = List::g();
@ -887,8 +887,8 @@ SharedHandle<ValueBase> GetFilesXmlRpcMethod::process
return files; return files;
} }
SharedHandle<ValueBase> GetUrisXmlRpcMethod::process SharedHandle<ValueBase> GetUrisRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
SharedHandle<RequestGroup> group = SharedHandle<RequestGroup> group =
@ -907,8 +907,8 @@ SharedHandle<ValueBase> GetUrisXmlRpcMethod::process
} }
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
SharedHandle<ValueBase> GetPeersXmlRpcMethod::process SharedHandle<ValueBase> GetPeersRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -929,8 +929,8 @@ SharedHandle<ValueBase> GetPeersXmlRpcMethod::process
} }
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
SharedHandle<ValueBase> TellStatusXmlRpcMethod::process SharedHandle<ValueBase> TellStatusRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -972,8 +972,8 @@ SharedHandle<ValueBase> TellStatusXmlRpcMethod::process
return entryDict; return entryDict;
} }
SharedHandle<ValueBase> TellActiveXmlRpcMethod::process SharedHandle<ValueBase> TellActiveRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const List* keysParam = req.getListParam(0); const List* keysParam = req.getListParam(0);
std::vector<std::string> keys; std::vector<std::string> keys;
@ -994,12 +994,12 @@ SharedHandle<ValueBase> TellActiveXmlRpcMethod::process
} }
const std::deque<SharedHandle<RequestGroup> >& const std::deque<SharedHandle<RequestGroup> >&
TellWaitingXmlRpcMethod::getItems(DownloadEngine* e) const TellWaitingRpcMethod::getItems(DownloadEngine* e) const
{ {
return e->getRequestGroupMan()->getReservedGroups(); return e->getRequestGroupMan()->getReservedGroups();
} }
void TellWaitingXmlRpcMethod::createEntry void TellWaitingRpcMethod::createEntry
(const SharedHandle<Dict>& entryDict, (const SharedHandle<Dict>& entryDict,
const SharedHandle<RequestGroup>& item, const SharedHandle<RequestGroup>& item,
DownloadEngine* e, DownloadEngine* e,
@ -1016,12 +1016,12 @@ void TellWaitingXmlRpcMethod::createEntry
} }
const std::deque<SharedHandle<DownloadResult> >& const std::deque<SharedHandle<DownloadResult> >&
TellStoppedXmlRpcMethod::getItems(DownloadEngine* e) const TellStoppedRpcMethod::getItems(DownloadEngine* e) const
{ {
return e->getRequestGroupMan()->getDownloadResults(); return e->getRequestGroupMan()->getDownloadResults();
} }
void TellStoppedXmlRpcMethod::createEntry void TellStoppedRpcMethod::createEntry
(const SharedHandle<Dict>& entryDict, (const SharedHandle<Dict>& entryDict,
const SharedHandle<DownloadResult>& item, const SharedHandle<DownloadResult>& item,
DownloadEngine* e, DownloadEngine* e,
@ -1030,15 +1030,15 @@ void TellStoppedXmlRpcMethod::createEntry
gatherStoppedDownload(entryDict, item, keys); gatherStoppedDownload(entryDict, item, keys);
} }
SharedHandle<ValueBase> PurgeDownloadResultXmlRpcMethod::process SharedHandle<ValueBase> PurgeDownloadResultRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
e->getRequestGroupMan()->purgeDownloadResult(); e->getRequestGroupMan()->purgeDownloadResult();
return VLB_OK; return VLB_OK;
} }
SharedHandle<ValueBase> RemoveDownloadResultXmlRpcMethod::process SharedHandle<ValueBase> RemoveDownloadResultRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
if(!e->getRequestGroupMan()->removeDownloadResult(gid)) { if(!e->getRequestGroupMan()->removeDownloadResult(gid)) {
@ -1049,8 +1049,8 @@ SharedHandle<ValueBase> RemoveDownloadResultXmlRpcMethod::process
return VLB_OK; return VLB_OK;
} }
SharedHandle<ValueBase> ChangeOptionXmlRpcMethod::process SharedHandle<ValueBase> ChangeOptionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -1085,8 +1085,8 @@ SharedHandle<ValueBase> ChangeOptionXmlRpcMethod::process
return VLB_OK; return VLB_OK;
} }
SharedHandle<ValueBase> ChangeGlobalOptionXmlRpcMethod::process SharedHandle<ValueBase> ChangeGlobalOptionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const Dict* optionsParam = req.getDictParam(0); const Dict* optionsParam = req.getDictParam(0);
if(!optionsParam) { if(!optionsParam) {
@ -1124,8 +1124,8 @@ SharedHandle<ValueBase> ChangeGlobalOptionXmlRpcMethod::process
return VLB_OK; return VLB_OK;
} }
SharedHandle<ValueBase> GetVersionXmlRpcMethod::process SharedHandle<ValueBase> GetVersionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
SharedHandle<Dict> result = Dict::g(); SharedHandle<Dict> result = Dict::g();
result->put(KEY_VERSION, PACKAGE_VERSION); result->put(KEY_VERSION, PACKAGE_VERSION);
@ -1156,8 +1156,8 @@ void pushRequestOption
} }
} // namespace } // namespace
SharedHandle<ValueBase> GetOptionXmlRpcMethod::process SharedHandle<ValueBase> GetOptionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
@ -1174,8 +1174,8 @@ SharedHandle<ValueBase> GetOptionXmlRpcMethod::process
return result; return result;
} }
SharedHandle<ValueBase> GetGlobalOptionXmlRpcMethod::process SharedHandle<ValueBase> GetGlobalOptionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
SharedHandle<Dict> result = Dict::g(); SharedHandle<Dict> result = Dict::g();
for(std::map<std::string, std::string>::const_iterator i = for(std::map<std::string, std::string>::const_iterator i =
@ -1188,8 +1188,8 @@ SharedHandle<ValueBase> GetGlobalOptionXmlRpcMethod::process
return result; return result;
} }
SharedHandle<ValueBase> ChangePositionXmlRpcMethod::process SharedHandle<ValueBase> ChangePositionRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
const Integer* posParam = req.getIntegerParam(1); const Integer* posParam = req.getIntegerParam(1);
@ -1216,16 +1216,16 @@ SharedHandle<ValueBase> ChangePositionXmlRpcMethod::process
return result; return result;
} }
SharedHandle<ValueBase> GetSessionInfoXmlRpcMethod::process SharedHandle<ValueBase> GetSessionInfoRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
SharedHandle<Dict> result = Dict::g(); SharedHandle<Dict> result = Dict::g();
result->put(KEY_SESSION_ID, util::toHex(e->getSessionId())); result->put(KEY_SESSION_ID, util::toHex(e->getSessionId()));
return result; return result;
} }
SharedHandle<ValueBase> GetServersXmlRpcMethod::process SharedHandle<ValueBase> GetServersRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
SharedHandle<RequestGroup> group = SharedHandle<RequestGroup> group =
@ -1263,8 +1263,8 @@ SharedHandle<ValueBase> GetServersXmlRpcMethod::process
return result; return result;
} }
SharedHandle<ValueBase> ChangeUriXmlRpcMethod::process SharedHandle<ValueBase> ChangeUriRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
gid_t gid = getRequiredGidParam(req, 0); gid_t gid = getRequiredGidParam(req, 0);
const Integer* indexParam = req.getIntegerParam(1); const Integer* indexParam = req.getIntegerParam(1);
@ -1332,30 +1332,30 @@ SharedHandle<ValueBase> ChangeUriXmlRpcMethod::process
namespace { namespace {
SharedHandle<ValueBase> goingShutdown SharedHandle<ValueBase> goingShutdown
(const XmlRpcRequest& req, DownloadEngine* e, bool forceHalt) (const RpcRequest& req, DownloadEngine* e, bool forceHalt)
{ {
// Schedule shutdown after 3seconds to give time to client to // Schedule shutdown after 3seconds to give time to client to
// receive XML-RPC response. // receive RPC response.
e->addRoutineCommand(new TimedHaltCommand(e->newCUID(), e, 3, forceHalt)); e->addRoutineCommand(new TimedHaltCommand(e->newCUID(), e, 3, forceHalt));
A2_LOG_INFO("Scheduled shutdown in 3 seconds."); A2_LOG_INFO("Scheduled shutdown in 3 seconds.");
return VLB_OK; return VLB_OK;
} }
} // namespace } // namespace
SharedHandle<ValueBase> ShutdownXmlRpcMethod::process SharedHandle<ValueBase> ShutdownRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return goingShutdown(req, e, false); return goingShutdown(req, e, false);
} }
SharedHandle<ValueBase> ForceShutdownXmlRpcMethod::process SharedHandle<ValueBase> ForceShutdownRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
return goingShutdown(req, e, true); return goingShutdown(req, e, true);
} }
SharedHandle<ValueBase> SystemMulticallXmlRpcMethod::process SharedHandle<ValueBase> SystemMulticallRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const List* methodSpecs = req.getListParam(0); const List* methodSpecs = req.getListParam(0);
if(!methodSpecs) { if(!methodSpecs) {
@ -1383,11 +1383,11 @@ SharedHandle<ValueBase> SystemMulticallXmlRpcMethod::process
(DL_ABORT_EX("Recursive system.multicall forbidden."))); (DL_ABORT_EX("Recursive system.multicall forbidden.")));
continue; continue;
} }
SharedHandle<XmlRpcMethod> method = SharedHandle<RpcMethod> method =
XmlRpcMethodFactory::create(methodName->s()); RpcMethodFactory::create(methodName->s());
XmlRpcRequest innerReq RpcRequest innerReq
(methodName->s(), static_pointer_cast<List>(methodDict->get(KEY_PARAMS))); (methodName->s(), static_pointer_cast<List>(methodDict->get(KEY_PARAMS)));
XmlRpcResponse res = method->execute(innerReq, e); RpcResponse res = method->execute(innerReq, e);
if(res.code == 0) { if(res.code == 0) {
SharedHandle<List> l = List::g(); SharedHandle<List> l = List::g();
l->append(res.param); l->append(res.param);
@ -1399,12 +1399,12 @@ SharedHandle<ValueBase> SystemMulticallXmlRpcMethod::process
return list; return list;
} }
SharedHandle<ValueBase> NoSuchMethodXmlRpcMethod::process SharedHandle<ValueBase> NoSuchMethodRpcMethod::process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
throw DL_ABORT_EX(fmt("No such method: %s", req.methodName.c_str())); throw DL_ABORT_EX(fmt("No such method: %s", req.methodName.c_str()));
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -32,16 +32,16 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#ifndef D_XML_RPC_METHOD_IMPL_H #ifndef D_RPC_METHOD_IMPL_H
#define D_XML_RPC_METHOD_IMPL_H #define D_RPC_METHOD_IMPL_H
#include "XmlRpcMethod.h" #include "RpcMethod.h"
#include <cassert> #include <cassert>
#include <deque> #include <deque>
#include <algorithm> #include <algorithm>
#include "XmlRpcRequest.h" #include "RpcRequest.h"
#include "ValueBase.h" #include "ValueBase.h"
#include "TorrentAttribute.h" #include "TorrentAttribute.h"
#include "DlAbortEx.h" #include "DlAbortEx.h"
@ -51,7 +51,7 @@ namespace aria2 {
struct DownloadResult; struct DownloadResult;
class RequestGroup; class RequestGroup;
namespace xmlrpc { namespace rpc {
template<typename OutputIterator> template<typename OutputIterator>
void toStringList(OutputIterator out, const List* src) void toStringList(OutputIterator out, const List* src)
@ -68,10 +68,10 @@ void toStringList(OutputIterator out, const List* src)
} }
} }
class AddUriXmlRpcMethod:public XmlRpcMethod { class AddUriRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -80,10 +80,10 @@ public:
} }
}; };
class RemoveXmlRpcMethod:public XmlRpcMethod { class RemoveRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -92,10 +92,10 @@ public:
} }
}; };
class ForceRemoveXmlRpcMethod:public XmlRpcMethod { class ForceRemoveRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -104,10 +104,10 @@ public:
} }
}; };
class PauseXmlRpcMethod:public XmlRpcMethod { class PauseRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -116,10 +116,10 @@ public:
} }
}; };
class ForcePauseXmlRpcMethod:public XmlRpcMethod { class ForcePauseRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -128,10 +128,10 @@ public:
} }
}; };
class PauseAllXmlRpcMethod:public XmlRpcMethod { class PauseAllRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -140,10 +140,10 @@ public:
} }
}; };
class ForcePauseAllXmlRpcMethod:public XmlRpcMethod { class ForcePauseAllRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -152,10 +152,10 @@ public:
} }
}; };
class UnpauseXmlRpcMethod:public XmlRpcMethod { class UnpauseRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -164,10 +164,10 @@ public:
} }
}; };
class UnpauseAllXmlRpcMethod:public XmlRpcMethod { class UnpauseAllRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -177,10 +177,10 @@ public:
}; };
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
class AddTorrentXmlRpcMethod:public XmlRpcMethod { class AddTorrentRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -191,10 +191,10 @@ public:
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
#ifdef ENABLE_METALINK #ifdef ENABLE_METALINK
class AddMetalinkXmlRpcMethod:public XmlRpcMethod { class AddMetalinkRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -204,10 +204,10 @@ public:
}; };
#endif // ENABLE_METALINK #endif // ENABLE_METALINK
class PurgeDownloadResultXmlRpcMethod:public XmlRpcMethod { class PurgeDownloadResultRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -216,10 +216,10 @@ public:
} }
}; };
class RemoveDownloadResultXmlRpcMethod:public XmlRpcMethod { class RemoveDownloadResultRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -228,10 +228,10 @@ public:
} }
}; };
class GetUrisXmlRpcMethod:public XmlRpcMethod { class GetUrisRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -240,10 +240,10 @@ public:
} }
}; };
class GetFilesXmlRpcMethod:public XmlRpcMethod { class GetFilesRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -253,10 +253,10 @@ public:
}; };
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
class GetPeersXmlRpcMethod:public XmlRpcMethod { class GetPeersRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -266,10 +266,10 @@ public:
}; };
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
class GetServersXmlRpcMethod:public XmlRpcMethod { class GetServersRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -278,10 +278,10 @@ public:
} }
}; };
class TellStatusXmlRpcMethod:public XmlRpcMethod { class TellStatusRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -290,10 +290,10 @@ public:
} }
}; };
class TellActiveXmlRpcMethod:public XmlRpcMethod { class TellActiveRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -303,7 +303,7 @@ public:
}; };
template<typename T> template<typename T>
class AbstractPaginationXmlRpcMethod:public XmlRpcMethod { class AbstractPaginationRpcMethod:public RpcMethod {
private: private:
template<typename InputIterator> template<typename InputIterator>
std::pair<InputIterator, InputIterator> std::pair<InputIterator, InputIterator>
@ -349,7 +349,7 @@ private:
} }
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e) (const RpcRequest& req, DownloadEngine* e)
{ {
const SharedHandle<List>& params = req.params; const SharedHandle<List>& params = req.params;
checkPaginationParams(params); checkPaginationParams(params);
@ -384,8 +384,8 @@ protected:
const std::vector<std::string>& keys) const = 0; const std::vector<std::string>& keys) const = 0;
}; };
class TellWaitingXmlRpcMethod: class TellWaitingRpcMethod:
public AbstractPaginationXmlRpcMethod<RequestGroup> { public AbstractPaginationRpcMethod<RequestGroup> {
protected: protected:
virtual const std::deque<SharedHandle<RequestGroup> >& virtual const std::deque<SharedHandle<RequestGroup> >&
getItems(DownloadEngine* e) const; getItems(DownloadEngine* e) const;
@ -403,8 +403,8 @@ public:
} }
}; };
class TellStoppedXmlRpcMethod: class TellStoppedRpcMethod:
public AbstractPaginationXmlRpcMethod<DownloadResult> { public AbstractPaginationRpcMethod<DownloadResult> {
protected: protected:
virtual const std::deque<SharedHandle<DownloadResult> >& virtual const std::deque<SharedHandle<DownloadResult> >&
getItems(DownloadEngine* e) const; getItems(DownloadEngine* e) const;
@ -422,10 +422,10 @@ public:
} }
}; };
class ChangeOptionXmlRpcMethod:public XmlRpcMethod { class ChangeOptionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -434,10 +434,10 @@ public:
} }
}; };
class ChangeGlobalOptionXmlRpcMethod:public XmlRpcMethod { class ChangeGlobalOptionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -446,10 +446,10 @@ public:
} }
}; };
class GetVersionXmlRpcMethod:public XmlRpcMethod { class GetVersionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -458,10 +458,10 @@ public:
} }
}; };
class GetOptionXmlRpcMethod:public XmlRpcMethod { class GetOptionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -470,10 +470,10 @@ public:
} }
}; };
class GetGlobalOptionXmlRpcMethod:public XmlRpcMethod { class GetGlobalOptionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -482,10 +482,10 @@ public:
} }
}; };
class ChangePositionXmlRpcMethod:public XmlRpcMethod { class ChangePositionRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -494,10 +494,10 @@ public:
} }
}; };
class ChangeUriXmlRpcMethod:public XmlRpcMethod { class ChangeUriRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -506,10 +506,10 @@ public:
} }
}; };
class GetSessionInfoXmlRpcMethod:public XmlRpcMethod { class GetSessionInfoRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -518,10 +518,10 @@ public:
} }
}; };
class ShutdownXmlRpcMethod:public XmlRpcMethod { class ShutdownRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -530,10 +530,10 @@ public:
} }
}; };
class ForceShutdownXmlRpcMethod:public XmlRpcMethod { class ForceShutdownRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -542,10 +542,10 @@ public:
} }
}; };
class SystemMulticallXmlRpcMethod:public XmlRpcMethod { class SystemMulticallRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
public: public:
static const std::string& getMethodName() static const std::string& getMethodName()
{ {
@ -554,10 +554,10 @@ public:
} }
}; };
class NoSuchMethodXmlRpcMethod:public XmlRpcMethod { class NoSuchMethodRpcMethod:public RpcMethod {
protected: protected:
virtual SharedHandle<ValueBase> process virtual SharedHandle<ValueBase> process
(const XmlRpcRequest& req, DownloadEngine* e); (const RpcRequest& req, DownloadEngine* e);
}; };
// Helper function to store data to entryDict from ds. This function // Helper function to store data to entryDict from ds. This function
@ -579,8 +579,8 @@ void gatherBitTorrentMetadata
const SharedHandle<TorrentAttribute>& torrentAttrs); const SharedHandle<TorrentAttribute>& torrentAttrs);
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_METHOD_IMPL_H #endif // D_RPC_METHOD_IMPL_H

View File

@ -32,30 +32,30 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#include "XmlRpcRequest.h" #include "RpcRequest.h"
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
XmlRpcRequest::XmlRpcRequest(const std::string& methodName, RpcRequest::RpcRequest(const std::string& methodName,
const SharedHandle<List>& params) const SharedHandle<List>& params)
: methodName(methodName), params(params) : methodName(methodName), params(params)
{} {}
XmlRpcRequest::XmlRpcRequest(const std::string& methodName, RpcRequest::RpcRequest(const std::string& methodName,
const SharedHandle<List>& params, const SharedHandle<List>& params,
const SharedHandle<ValueBase>& id) const SharedHandle<ValueBase>& id)
: methodName(methodName), params(params), id(id) : methodName(methodName), params(params), id(id)
{} {}
XmlRpcRequest::XmlRpcRequest(const XmlRpcRequest& c) RpcRequest::RpcRequest(const RpcRequest& c)
: methodName(c.methodName), params(c.params), id(c.id) : methodName(c.methodName), params(c.params), id(c.id)
{} {}
XmlRpcRequest::~XmlRpcRequest() {} RpcRequest::~RpcRequest() {}
XmlRpcRequest& XmlRpcRequest::operator=(const XmlRpcRequest& c) RpcRequest& RpcRequest::operator=(const RpcRequest& c)
{ {
if(this != &c) { if(this != &c) {
methodName = c.methodName; methodName = c.methodName;
@ -64,7 +64,7 @@ XmlRpcRequest& XmlRpcRequest::operator=(const XmlRpcRequest& c)
return *this; return *this;
} }
const String* XmlRpcRequest::getStringParam(size_t index) const const String* RpcRequest::getStringParam(size_t index) const
{ {
const String* stringParam = 0; const String* stringParam = 0;
if(params->size() > index) { if(params->size() > index) {
@ -73,7 +73,7 @@ const String* XmlRpcRequest::getStringParam(size_t index) const
return stringParam; return stringParam;
} }
const Integer* XmlRpcRequest::getIntegerParam(size_t index) const const Integer* RpcRequest::getIntegerParam(size_t index) const
{ {
const Integer* integerParam = 0; const Integer* integerParam = 0;
if(params->size() > index) { if(params->size() > index) {
@ -82,7 +82,7 @@ const Integer* XmlRpcRequest::getIntegerParam(size_t index) const
return integerParam; return integerParam;
} }
const List* XmlRpcRequest::getListParam(size_t index) const const List* RpcRequest::getListParam(size_t index) const
{ {
const List* listParam = 0; const List* listParam = 0;
if(params->size() > index) { if(params->size() > index) {
@ -91,7 +91,7 @@ const List* XmlRpcRequest::getListParam(size_t index) const
return listParam; return listParam;
} }
const Dict* XmlRpcRequest::getDictParam(size_t index) const const Dict* RpcRequest::getDictParam(size_t index) const
{ {
const Dict* dictParam = 0; const Dict* dictParam = 0;
if(params->size() > index) { if(params->size() > index) {
@ -100,6 +100,6 @@ const Dict* XmlRpcRequest::getDictParam(size_t index) const
return dictParam; return dictParam;
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -32,8 +32,8 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#ifndef D_XML_RPC_REQUEST_H #ifndef D_RPC_REQUEST_H
#define D_XML_RPC_REQUEST_H #define D_RPC_REQUEST_H
#include "common.h" #include "common.h"
@ -43,25 +43,25 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
struct XmlRpcRequest { struct RpcRequest {
std::string methodName; std::string methodName;
SharedHandle<List> params; SharedHandle<List> params;
SharedHandle<ValueBase> id; SharedHandle<ValueBase> id;
XmlRpcRequest(const std::string& methodName, RpcRequest(const std::string& methodName,
const SharedHandle<List>& params); const SharedHandle<List>& params);
XmlRpcRequest(const std::string& methodName, RpcRequest(const std::string& methodName,
const SharedHandle<List>& params, const SharedHandle<List>& params,
const SharedHandle<ValueBase>& id); const SharedHandle<ValueBase>& id);
~XmlRpcRequest(); ~RpcRequest();
XmlRpcRequest(const XmlRpcRequest& c); RpcRequest(const RpcRequest& c);
XmlRpcRequest& operator=(const XmlRpcRequest& c); RpcRequest& operator=(const RpcRequest& c);
const String* getStringParam(size_t index) const; const String* getStringParam(size_t index) const;
@ -72,8 +72,8 @@ struct XmlRpcRequest {
const Dict* getDictParam(size_t index) const; const Dict* getDictParam(size_t index) const;
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_REQUEST_H #endif // D_RPC_REQUEST_H

View File

@ -32,7 +32,7 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#include "XmlRpcResponse.h" #include "RpcResponse.h"
#include <cassert> #include <cassert>
#include <sstream> #include <sstream>
@ -45,7 +45,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace { namespace {
template<typename OutputStream> template<typename OutputStream>
@ -121,22 +121,22 @@ std::string encodeAll
} }
} // namespace } // namespace
XmlRpcResponse::XmlRpcResponse RpcResponse::RpcResponse
(int code, (int code,
const SharedHandle<ValueBase>& param, const SharedHandle<ValueBase>& param,
const SharedHandle<ValueBase>& id) const SharedHandle<ValueBase>& id)
: code(code), param(param), id(id) : code(code), param(param), id(id)
{} {}
XmlRpcResponse::XmlRpcResponse(const XmlRpcResponse& c) RpcResponse::RpcResponse(const RpcResponse& c)
: code(c.code), : code(c.code),
param(c.param), param(c.param),
id(c.id) id(c.id)
{} {}
XmlRpcResponse::~XmlRpcResponse() {} RpcResponse::~RpcResponse() {}
XmlRpcResponse& XmlRpcResponse::operator=(const XmlRpcResponse& c) RpcResponse& RpcResponse::operator=(const RpcResponse& c)
{ {
if(this != &c) { if(this != &c) {
code = c.code; code = c.code;
@ -145,7 +145,7 @@ XmlRpcResponse& XmlRpcResponse::operator=(const XmlRpcResponse& c)
return *this; return *this;
} }
std::string XmlRpcResponse::toXml(bool gzip) const std::string RpcResponse::toXml(bool gzip) const
{ {
if(gzip) { if(gzip) {
#ifdef HAVE_ZLIB #ifdef HAVE_ZLIB
@ -189,7 +189,7 @@ OutputStream& encodeJsonAll
} }
} // namespace } // namespace
std::string XmlRpcResponse::toJson(const std::string& callback, bool gzip) const std::string RpcResponse::toJson(const std::string& callback, bool gzip) const
{ {
if(gzip) { if(gzip) {
#ifdef HAVE_ZLIB #ifdef HAVE_ZLIB
@ -209,14 +209,14 @@ namespace {
template<typename OutputStream> template<typename OutputStream>
OutputStream& encodeJsonBatchAll OutputStream& encodeJsonBatchAll
(OutputStream& o, (OutputStream& o,
const std::vector<XmlRpcResponse>& results, const std::vector<RpcResponse>& results,
const std::string& callback) const std::string& callback)
{ {
o << "["; o << "[";
if(!results.empty()) { if(!results.empty()) {
encodeJsonAll(o, results[0].code, results[0].param, results[0].id,callback); encodeJsonAll(o, results[0].code, results[0].param, results[0].id,callback);
} }
for(std::vector<XmlRpcResponse>::const_iterator i = results.begin()+1, for(std::vector<RpcResponse>::const_iterator i = results.begin()+1,
eoi = results.end(); i != eoi; ++i) { eoi = results.end(); i != eoi; ++i) {
o << ","; o << ",";
encodeJsonAll(o, (*i).code, (*i).param, (*i).id, callback); encodeJsonAll(o, (*i).code, (*i).param, (*i).id, callback);
@ -227,7 +227,7 @@ OutputStream& encodeJsonBatchAll
} // namespace } // namespace
std::string toJsonBatch std::string toJsonBatch
(const std::vector<XmlRpcResponse>& results, (const std::vector<RpcResponse>& results,
const std::string& callback, const std::string& callback,
bool gzip) bool gzip)
{ {
@ -245,6 +245,6 @@ std::string toJsonBatch
} }
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -32,8 +32,8 @@
* files in the program, then also delete it here. * files in the program, then also delete it here.
*/ */
/* copyright --> */ /* copyright --> */
#ifndef D_XML_RPC_RESPONSE_H #ifndef D_RPC_RESPONSE_H
#define D_XML_RPC_RESPONSE_H #define D_RPC_RESPONSE_H
#include "common.h" #include "common.h"
@ -44,9 +44,9 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
struct XmlRpcResponse { struct RpcResponse {
// 0 for success, non-zero for error // 0 for success, non-zero for error
int code; int code;
@ -54,16 +54,16 @@ struct XmlRpcResponse {
SharedHandle<ValueBase> id; SharedHandle<ValueBase> id;
XmlRpcResponse RpcResponse
(int code, (int code,
const SharedHandle<ValueBase>& param, const SharedHandle<ValueBase>& param,
const SharedHandle<ValueBase>& id); const SharedHandle<ValueBase>& id);
XmlRpcResponse(const XmlRpcResponse& c); RpcResponse(const RpcResponse& c);
~XmlRpcResponse(); ~RpcResponse();
XmlRpcResponse& operator=(const XmlRpcResponse& c); RpcResponse& operator=(const RpcResponse& c);
std::string toXml(bool gzip = false) const; std::string toXml(bool gzip = false) const;
@ -73,12 +73,12 @@ struct XmlRpcResponse {
}; };
std::string toJsonBatch std::string toJsonBatch
(const std::vector<XmlRpcResponse>& results, (const std::vector<RpcResponse>& results,
const std::string& callback, const std::string& callback,
bool gzip = false); bool gzip = false);
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_RESPONSE_H #endif // D_RPC_RESPONSE_H

View File

@ -45,7 +45,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace { namespace {
struct SessionData { struct SessionData {
@ -148,7 +148,7 @@ XmlRpcRequestProcessor::XmlRpcRequestProcessor() {}
XmlRpcRequestProcessor::~XmlRpcRequestProcessor() {} XmlRpcRequestProcessor::~XmlRpcRequestProcessor() {}
XmlRpcRequest RpcRequest
XmlRpcRequestProcessor::parseMemory(const std::string& xml) XmlRpcRequestProcessor::parseMemory(const std::string& xml)
{ {
stm_.reset(new XmlRpcRequestParserStateMachine()); stm_.reset(new XmlRpcRequestParserStateMachine());
@ -162,10 +162,10 @@ XmlRpcRequestProcessor::parseMemory(const std::string& xml)
if(!asList(stm_->getCurrentFrameValue())) { if(!asList(stm_->getCurrentFrameValue())) {
throw DL_ABORT_EX("Bad XML-RPC parameter list"); throw DL_ABORT_EX("Bad XML-RPC parameter list");
} }
return XmlRpcRequest(stm_->getMethodName(), return RpcRequest(stm_->getMethodName(),
static_pointer_cast<List>(stm_->getCurrentFrameValue())); static_pointer_cast<List>(stm_->getCurrentFrameValue()));
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -40,11 +40,11 @@
#include <string> #include <string>
#include "SharedHandle.h" #include "SharedHandle.h"
#include "XmlRpcRequest.h" #include "RpcRequest.h"
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserStateMachine; class XmlRpcRequestParserStateMachine;
@ -56,10 +56,10 @@ public:
~XmlRpcRequestProcessor(); ~XmlRpcRequestProcessor();
XmlRpcRequest parseMemory(const std::string& xml); RpcRequest parseMemory(const std::string& xml);
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -35,7 +35,7 @@
#include "XmlRpcElements.h" #include "XmlRpcElements.h"
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace elements { namespace elements {
const std::string METHOD_CALL("methodCall"); const std::string METHOD_CALL("methodCall");
@ -57,5 +57,5 @@ const std::string ARRAY("array");
const std::string DATA("data"); const std::string DATA("data");
} // namespace elements } // namespace elements
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -40,7 +40,7 @@
#include <string> #include <string>
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
namespace elements { namespace elements {
extern const std::string METHOD_CALL; extern const std::string METHOD_CALL;
@ -62,7 +62,7 @@ extern const std::string ARRAY;
extern const std::string DATA; extern const std::string DATA;
} // namespace elements } // namespace elements
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2
#endif // D_XML_RPC_ELEMENTS_H #endif // D_XML_RPC_ELEMENTS_H

View File

@ -1,127 +0,0 @@
/* <!-- copyright */
/*
* aria2 - The high speed download utility
*
* Copyright (C) 2009 Tatsuhiro Tsujikawa
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the
* OpenSSL library under certain conditions as described in each
* individual source file, and distribute linked combinations
* including the two.
* You must obey the GNU General Public License in all respects
* for all of the code used other than OpenSSL. If you modify
* file(s) with this exception, you may extend this exception to your
* version of the file(s), but you are not obligated to do so. If you
* do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source
* files in the program, then also delete it here.
*/
/* copyright --> */
#include "XmlRpcMethodFactory.h"
#include "XmlRpcMethodImpl.h"
#include "OptionParser.h"
#include "OptionHandler.h"
namespace aria2 {
namespace xmlrpc {
SharedHandle<XmlRpcMethod>
XmlRpcMethodFactory::create(const std::string& methodName)
{
if(methodName == AddUriXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new AddUriXmlRpcMethod());
#ifdef ENABLE_BITTORRENT
} else if(methodName == AddTorrentXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new AddTorrentXmlRpcMethod());
#endif // ENABLE_BITTORRENT
#ifdef ENABLE_METALINK
}
else if(methodName == AddMetalinkXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new AddMetalinkXmlRpcMethod());
#endif // ENABLE_METALINK
}
else if(methodName == RemoveXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new RemoveXmlRpcMethod());
} else if(methodName == PauseXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new PauseXmlRpcMethod());
} else if(methodName == ForcePauseXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ForcePauseXmlRpcMethod());
} else if(methodName == PauseAllXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new PauseAllXmlRpcMethod());
} else if(methodName == ForcePauseAllXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ForcePauseAllXmlRpcMethod());
} else if(methodName == UnpauseXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new UnpauseXmlRpcMethod());
} else if(methodName == UnpauseAllXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new UnpauseAllXmlRpcMethod());
} else if(methodName == ForceRemoveXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ForceRemoveXmlRpcMethod());
} else if(methodName == ChangePositionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ChangePositionXmlRpcMethod());
} else if(methodName == TellStatusXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new TellStatusXmlRpcMethod());
} else if(methodName == GetUrisXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetUrisXmlRpcMethod());
} else if(methodName == GetFilesXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetFilesXmlRpcMethod());
#ifdef ENABLE_BITTORRENT
}
else if(methodName == GetPeersXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetPeersXmlRpcMethod());
#endif // ENABLE_BITTORRENT
} else if(methodName == GetServersXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetServersXmlRpcMethod());
} else if(methodName == TellActiveXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new TellActiveXmlRpcMethod());
} else if(methodName == TellWaitingXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new TellWaitingXmlRpcMethod());
} else if(methodName == TellStoppedXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new TellStoppedXmlRpcMethod());
} else if(methodName == GetOptionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetOptionXmlRpcMethod());
} else if(methodName == ChangeUriXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ChangeUriXmlRpcMethod());
} else if(methodName == ChangeOptionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ChangeOptionXmlRpcMethod());
} else if(methodName == GetGlobalOptionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetGlobalOptionXmlRpcMethod());
} else if(methodName == ChangeGlobalOptionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ChangeGlobalOptionXmlRpcMethod());
} else if(methodName == PurgeDownloadResultXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new PurgeDownloadResultXmlRpcMethod());
} else if(methodName == RemoveDownloadResultXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new RemoveDownloadResultXmlRpcMethod());
} else if(methodName == GetVersionXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetVersionXmlRpcMethod());
} else if(methodName == GetSessionInfoXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new GetSessionInfoXmlRpcMethod());
} else if(methodName == ShutdownXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ShutdownXmlRpcMethod());
} else if(methodName == ForceShutdownXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new ForceShutdownXmlRpcMethod());
} else if(methodName == SystemMulticallXmlRpcMethod::getMethodName()) {
return SharedHandle<XmlRpcMethod>(new SystemMulticallXmlRpcMethod());
} else {
return SharedHandle<XmlRpcMethod>(new NoSuchMethodXmlRpcMethod());
}
}
} // namespace xmlrpc
} // namespace aria2

View File

@ -38,7 +38,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
void XmlRpcRequestParserController::pushFrame() void XmlRpcRequestParserController::pushFrame()
{ {
@ -92,6 +92,6 @@ XmlRpcRequestParserController::getCurrentFrameValue() const
return currentFrame_.value_; return currentFrame_.value_;
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -44,7 +44,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserController { class XmlRpcRequestParserController {
private: private:
@ -89,7 +89,7 @@ public:
const std::string& getMethodName() const { return methodName_; } const std::string& getMethodName() const { return methodName_; }
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -42,7 +42,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserStateMachine; class XmlRpcRequestParserStateMachine;
@ -61,7 +61,7 @@ public:
virtual bool needsCharactersBuffering() const = 0; virtual bool needsCharactersBuffering() const = 0;
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -41,7 +41,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
// InitialXmlRpcRequestParserState // InitialXmlRpcRequestParserState
@ -324,6 +324,6 @@ void ArrayValueXmlRpcRequestParserState::endElement
stm->popArrayFrame(); stm->popArrayFrame();
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -39,7 +39,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class InitialXmlRpcRequestParserState:public XmlRpcRequestParserState { class InitialXmlRpcRequestParserState:public XmlRpcRequestParserState {
public: public:
@ -231,7 +231,7 @@ class ArrayValueXmlRpcRequestParserState:public ValueXmlRpcRequestParserState {
const std::string& characters); const std::string& characters);
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -36,7 +36,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
InitialXmlRpcRequestParserState* InitialXmlRpcRequestParserState*
XmlRpcRequestParserStateMachine::initialState_ = XmlRpcRequestParserStateMachine::initialState_ =
@ -113,6 +113,6 @@ XmlRpcRequestParserStateMachine::~XmlRpcRequestParserStateMachine()
delete controller_; delete controller_;
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -47,7 +47,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserStateMachine { class XmlRpcRequestParserStateMachine {
private: private:
@ -165,7 +165,7 @@ public:
void pushArrayValueState() { stateStack_.push(arrayValueState_); } void pushArrayValueState() { stateStack_.push(arrayValueState_); }
}; };
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -262,11 +262,7 @@ error_code::Value main(int argc, char* argv[])
op->remove(PREF_INPUT_FILE); op->remove(PREF_INPUT_FILE);
op->remove(PREF_INDEX_OUT); op->remove(PREF_INDEX_OUT);
op->remove(PREF_SELECT_FILE); op->remove(PREF_SELECT_FILE);
if( if(!op->getAsBool(PREF_ENABLE_XML_RPC) && requestGroups.empty()) {
#ifdef ENABLE_XML_RPC
!op->getAsBool(PREF_ENABLE_XML_RPC) &&
#endif // ENABLE_XML_RPC
requestGroups.empty()) {
std::cout << MSG_NO_FILES_TO_DOWNLOAD << std::endl; std::cout << MSG_NO_FILES_TO_DOWNLOAD << std::endl;
} else { } else {
exitStatus = MultiUrlRequestInfo(requestGroups, op, getStatCalc(op), exitStatus = MultiUrlRequestInfo(requestGroups, op, getStatCalc(op),

View File

@ -184,10 +184,7 @@ void option_processing(Option& op, std::vector<std::string>& uris,
showUsage(TAG_HELP, oparser); showUsage(TAG_HELP, oparser);
exit(e.getErrorCode()); exit(e.getErrorCode());
} }
if( if(!op.getAsBool(PREF_ENABLE_XML_RPC) &&
#ifdef ENABLE_XML_RPC
!op.getAsBool(PREF_ENABLE_XML_RPC) &&
#endif // ENABLE_XML_RPC
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
op.blank(PREF_TORRENT_FILE) && op.blank(PREF_TORRENT_FILE) &&
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT

View File

@ -78,12 +78,12 @@ aria2c_SOURCES = AllTest.cc\
TripletTest.cc\ TripletTest.cc\
CookieHelperTest.cc\ CookieHelperTest.cc\
JsonTest.cc\ JsonTest.cc\
XmlRpcResponseTest.cc RpcResponseTest.cc\
RpcMethodTest.cc
if ENABLE_XML_RPC if ENABLE_XML_RPC
aria2c_SOURCES += XmlRpcRequestParserControllerTest.cc\ aria2c_SOURCES += XmlRpcRequestParserControllerTest.cc\
XmlRpcRequestProcessorTest.cc\ XmlRpcRequestProcessorTest.cc
XmlRpcMethodTest.cc
endif # ENABLE_XML_RPC endif # ENABLE_XML_RPC
if HAVE_SOME_FALLOCATE if HAVE_SOME_FALLOCATE

View File

@ -1,4 +1,4 @@
#include "XmlRpcMethod.h" #include "RpcMethod.h"
#include <cppunit/extensions/HelperMacros.h> #include <cppunit/extensions/HelperMacros.h>
@ -7,11 +7,11 @@
#include "Option.h" #include "Option.h"
#include "RequestGroupMan.h" #include "RequestGroupMan.h"
#include "RequestGroup.h" #include "RequestGroup.h"
#include "XmlRpcMethodImpl.h" #include "RpcMethodImpl.h"
#include "OptionParser.h" #include "OptionParser.h"
#include "OptionHandler.h" #include "OptionHandler.h"
#include "XmlRpcRequest.h" #include "RpcRequest.h"
#include "XmlRpcResponse.h" #include "RpcResponse.h"
#include "prefs.h" #include "prefs.h"
#include "TestUtil.h" #include "TestUtil.h"
#include "DownloadContext.h" #include "DownloadContext.h"
@ -28,11 +28,11 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcMethodTest:public CppUnit::TestFixture { class RpcMethodTest:public CppUnit::TestFixture {
CPPUNIT_TEST_SUITE(XmlRpcMethodTest); CPPUNIT_TEST_SUITE(RpcMethodTest);
CPPUNIT_TEST(testAddUri); CPPUNIT_TEST(testAddUri);
CPPUNIT_TEST(testAddUri_withoutUri); CPPUNIT_TEST(testAddUri_withoutUri);
CPPUNIT_TEST(testAddUri_notUri); CPPUNIT_TEST(testAddUri_notUri);
@ -85,7 +85,7 @@ public:
{ {
RequestGroup::resetGIDCounter(); RequestGroup::resetGIDCounter();
option_.reset(new Option()); option_.reset(new Option());
option_->put(PREF_DIR, A2_TEST_OUT_DIR"/aria2_XmlRpcMethodTest"); option_->put(PREF_DIR, A2_TEST_OUT_DIR"/aria2_RpcMethodTest");
option_->put(PREF_SEGMENT_SIZE, "1048576"); option_->put(PREF_SEGMENT_SIZE, "1048576");
File(option_->get(PREF_DIR)).mkdirs(); File(option_->get(PREF_DIR)).mkdirs();
e_.reset e_.reset
@ -143,7 +143,7 @@ public:
}; };
CPPUNIT_TEST_SUITE_REGISTRATION(XmlRpcMethodTest); CPPUNIT_TEST_SUITE_REGISTRATION(RpcMethodTest);
namespace { namespace {
std::string getString(const Dict* dict, const std::string& key) std::string getString(const Dict* dict, const std::string& key)
@ -152,15 +152,15 @@ std::string getString(const Dict* dict, const std::string& key)
} }
} // namespace } // namespace
void XmlRpcMethodTest::testAddUri() void RpcMethodTest::testAddUri()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append("http://localhost/"); urisParam->append("http://localhost/");
req.params->append(urisParam); req.params->append(urisParam);
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
const std::deque<SharedHandle<RequestGroup> > rgs = const std::deque<SharedHandle<RequestGroup> > rgs =
e_->getRequestGroupMan()->getReservedGroups(); e_->getRequestGroupMan()->getReservedGroups();
@ -174,7 +174,7 @@ void XmlRpcMethodTest::testAddUri()
opt->put(PREF_DIR, "/sink"); opt->put(PREF_DIR, "/sink");
req.params->append(opt); req.params->append(opt);
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL(std::string("/sink"), CPPUNIT_ASSERT_EQUAL(std::string("/sink"),
e_->getRequestGroupMan()->findReservedGroup(2)-> e_->getRequestGroupMan()->findReservedGroup(2)->
@ -182,50 +182,50 @@ void XmlRpcMethodTest::testAddUri()
} }
} }
void XmlRpcMethodTest::testAddUri_withoutUri() void RpcMethodTest::testAddUri_withoutUri()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddUri_notUri() void RpcMethodTest::testAddUri_notUri()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append("not uri"); urisParam->append("not uri");
req.params->append(urisParam); req.params->append(urisParam);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddUri_withBadOption() void RpcMethodTest::testAddUri_withBadOption()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append("http://localhost"); urisParam->append("http://localhost");
req.params->append(urisParam); req.params->append(urisParam);
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_FILE_ALLOCATION, "badvalue"); opt->put(PREF_FILE_ALLOCATION, "badvalue");
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddUri_withPosition() void RpcMethodTest::testAddUri_withPosition()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req1(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req1(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam1 = List::g(); SharedHandle<List> urisParam1 = List::g();
urisParam1->append("http://uri1"); urisParam1->append("http://uri1");
req1.params->append(urisParam1); req1.params->append(urisParam1);
XmlRpcResponse res1 = m.execute(req1, e_.get()); RpcResponse res1 = m.execute(req1, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res1.code); CPPUNIT_ASSERT_EQUAL(0, res1.code);
XmlRpcRequest req2(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req2(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam2 = List::g(); SharedHandle<List> urisParam2 = List::g();
urisParam2->append("http://uri2"); urisParam2->append("http://uri2");
req2.params->append(urisParam2); req2.params->append(urisParam2);
@ -240,32 +240,32 @@ void XmlRpcMethodTest::testAddUri_withPosition()
CPPUNIT_ASSERT_EQUAL(std::string("http://uri2"), uri); CPPUNIT_ASSERT_EQUAL(std::string("http://uri2"), uri);
} }
void XmlRpcMethodTest::testAddUri_withBadPosition() void RpcMethodTest::testAddUri_withBadPosition()
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append("http://localhost/"); urisParam->append("http://localhost/");
req.params->append(urisParam); req.params->append(urisParam);
req.params->append(Dict::g()); req.params->append(Dict::g());
req.params->append(Integer::g(-1)); req.params->append(Integer::g(-1));
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
void XmlRpcMethodTest::testAddTorrent() void RpcMethodTest::testAddTorrent()
{ {
File(e_->getOption()->get(PREF_DIR)+ File(e_->getOption()->get(PREF_DIR)+
"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").remove(); "/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").remove();
AddTorrentXmlRpcMethod m; AddTorrentRpcMethod m;
XmlRpcRequest req(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddTorrentRpcMethod::getMethodName(), List::g());
req.params->append(readFile(A2_TEST_DIR"/single.torrent")); req.params->append(readFile(A2_TEST_DIR"/single.torrent"));
SharedHandle<List> uris = List::g(); SharedHandle<List> uris = List::g();
uris->append("http://localhost/aria2-0.8.2.tar.bz2"); uris->append("http://localhost/aria2-0.8.2.tar.bz2");
req.params->append(uris); req.params->append(uris);
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT CPPUNIT_ASSERT
(File(e_->getOption()->get(PREF_DIR)+ (File(e_->getOption()->get(PREF_DIR)+
"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").exists()); "/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").exists());
@ -285,14 +285,14 @@ void XmlRpcMethodTest::testAddTorrent()
getRemainingUris()[0]); getRemainingUris()[0]);
} }
// with options // with options
std::string dir = A2_TEST_OUT_DIR"/aria2_XmlRpcMethodTest_testAddTorrent"; std::string dir = A2_TEST_OUT_DIR"/aria2_RpcMethodTest_testAddTorrent";
File(dir).mkdirs(); File(dir).mkdirs();
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_DIR, dir); opt->put(PREF_DIR, dir);
File(dir+"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").remove(); File(dir+"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").remove();
req.params->append(opt); req.params->append(opt);
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL CPPUNIT_ASSERT_EQUAL
(dir+"/aria2-0.8.2.tar.bz2", (dir+"/aria2-0.8.2.tar.bz2",
@ -302,34 +302,34 @@ void XmlRpcMethodTest::testAddTorrent()
} }
} }
void XmlRpcMethodTest::testAddTorrent_withoutTorrent() void RpcMethodTest::testAddTorrent_withoutTorrent()
{ {
AddTorrentXmlRpcMethod m; AddTorrentRpcMethod m;
XmlRpcRequest req(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddTorrentRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddTorrent_notBase64Torrent() void RpcMethodTest::testAddTorrent_notBase64Torrent()
{ {
AddTorrentXmlRpcMethod m; AddTorrentRpcMethod m;
XmlRpcRequest req(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddTorrentRpcMethod::getMethodName(), List::g());
req.params->append("not torrent"); req.params->append("not torrent");
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddTorrent_withPosition() void RpcMethodTest::testAddTorrent_withPosition()
{ {
AddTorrentXmlRpcMethod m; AddTorrentRpcMethod m;
XmlRpcRequest req1(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req1(AddTorrentRpcMethod::getMethodName(), List::g());
req1.params->append(readFile(A2_TEST_DIR"/test.torrent")); req1.params->append(readFile(A2_TEST_DIR"/test.torrent"));
req1.params->append(List::g()); req1.params->append(List::g());
req1.params->append(Dict::g()); req1.params->append(Dict::g());
XmlRpcResponse res1 = m.execute(req1, e_.get()); RpcResponse res1 = m.execute(req1, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res1.code); CPPUNIT_ASSERT_EQUAL(0, res1.code);
XmlRpcRequest req2(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req2(AddTorrentRpcMethod::getMethodName(), List::g());
req2.params->append(readFile(A2_TEST_DIR"/single.torrent")); req2.params->append(readFile(A2_TEST_DIR"/single.torrent"));
req2.params->append(List::g()); req2.params->append(List::g());
req2.params->append(Dict::g()); req2.params->append(Dict::g());
@ -344,15 +344,15 @@ void XmlRpcMethodTest::testAddTorrent_withPosition()
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
#ifdef ENABLE_METALINK #ifdef ENABLE_METALINK
void XmlRpcMethodTest::testAddMetalink() void RpcMethodTest::testAddMetalink()
{ {
File(e_->getOption()->get(PREF_DIR)+ File(e_->getOption()->get(PREF_DIR)+
"/c908634fbc257fd56f0114912c2772aeeb4064f4.metalink").remove(); "/c908634fbc257fd56f0114912c2772aeeb4064f4.metalink").remove();
AddMetalinkXmlRpcMethod m; AddMetalinkRpcMethod m;
XmlRpcRequest req(AddMetalinkXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddMetalinkRpcMethod::getMethodName(), List::g());
req.params->append(readFile(A2_TEST_DIR"/2files.metalink")); req.params->append(readFile(A2_TEST_DIR"/2files.metalink"));
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = asList(res.param); const List* resParams = asList(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
@ -374,14 +374,14 @@ void XmlRpcMethodTest::testAddMetalink()
deb->getFirstFilePath()); deb->getFirstFilePath());
} }
// with options // with options
std::string dir = A2_TEST_OUT_DIR"/aria2_XmlRpcMethodTest_testAddMetalink"; std::string dir = A2_TEST_OUT_DIR"/aria2_RpcMethodTest_testAddMetalink";
File(dir).mkdirs(); File(dir).mkdirs();
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_DIR, dir); opt->put(PREF_DIR, dir);
File(dir+"/c908634fbc257fd56f0114912c2772aeeb4064f4.metalink").remove(); File(dir+"/c908634fbc257fd56f0114912c2772aeeb4064f4.metalink").remove();
req.params->append(opt); req.params->append(opt);
{ {
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL(dir+"/aria2-5.0.0.tar.bz2", CPPUNIT_ASSERT_EQUAL(dir+"/aria2-5.0.0.tar.bz2",
e_->getRequestGroupMan()->findReservedGroup(3)-> e_->getRequestGroupMan()->findReservedGroup(3)->
@ -391,39 +391,39 @@ void XmlRpcMethodTest::testAddMetalink()
} }
} }
void XmlRpcMethodTest::testAddMetalink_withoutMetalink() void RpcMethodTest::testAddMetalink_withoutMetalink()
{ {
AddMetalinkXmlRpcMethod m; AddMetalinkRpcMethod m;
XmlRpcRequest req(AddMetalinkXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddMetalinkRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddMetalink_notBase64Metalink() void RpcMethodTest::testAddMetalink_notBase64Metalink()
{ {
AddMetalinkXmlRpcMethod m; AddMetalinkRpcMethod m;
XmlRpcRequest req(AddMetalinkXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddMetalinkRpcMethod::getMethodName(), List::g());
req.params->append("not metalink"); req.params->append("not metalink");
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testAddMetalink_withPosition() void RpcMethodTest::testAddMetalink_withPosition()
{ {
AddUriXmlRpcMethod m1; AddUriRpcMethod m1;
XmlRpcRequest req1(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req1(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam1 = List::g(); SharedHandle<List> urisParam1 = List::g();
urisParam1->append("http://uri"); urisParam1->append("http://uri");
req1.params->append(urisParam1); req1.params->append(urisParam1);
XmlRpcResponse res1 = m1.execute(req1, e_.get()); RpcResponse res1 = m1.execute(req1, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res1.code); CPPUNIT_ASSERT_EQUAL(0, res1.code);
AddMetalinkXmlRpcMethod m2; AddMetalinkRpcMethod m2;
XmlRpcRequest req2("ari2.addMetalink", List::g()); RpcRequest req2("ari2.addMetalink", List::g());
req2.params->append(readFile(A2_TEST_DIR"/2files.metalink")); req2.params->append(readFile(A2_TEST_DIR"/2files.metalink"));
req2.params->append(Dict::g()); req2.params->append(Dict::g());
req2.params->append(Integer::g(0)); req2.params->append(Integer::g(0));
XmlRpcResponse res2 = m2.execute(req2, e_.get()); RpcResponse res2 = m2.execute(req2, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res2.code); CPPUNIT_ASSERT_EQUAL(0, res2.code);
CPPUNIT_ASSERT_EQUAL(e_->getOption()->get(PREF_DIR)+"/aria2-5.0.0.tar.bz2", CPPUNIT_ASSERT_EQUAL(e_->getOption()->get(PREF_DIR)+"/aria2-5.0.0.tar.bz2",
@ -433,13 +433,13 @@ void XmlRpcMethodTest::testAddMetalink_withPosition()
#endif // ENABLE_METALINK #endif // ENABLE_METALINK
void XmlRpcMethodTest::testChangeOption() void RpcMethodTest::testChangeOption()
{ {
SharedHandle<RequestGroup> group(new RequestGroup(option_)); SharedHandle<RequestGroup> group(new RequestGroup(option_));
e_->getRequestGroupMan()->addReservedGroup(group); e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionXmlRpcMethod m; ChangeOptionRpcMethod m;
XmlRpcRequest req(ChangeOptionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_DOWNLOAD_LIMIT, "100K"); opt->put(PREF_MAX_DOWNLOAD_LIMIT, "100K");
@ -453,7 +453,7 @@ void XmlRpcMethodTest::testChangeOption()
e_->getBtRegistry()->put(group->getGID(), btObject); e_->getBtRegistry()->put(group->getGID(), btObject);
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
SharedHandle<Option> option = group->getOption(); SharedHandle<Option> option = group->getOption();
@ -476,56 +476,56 @@ void XmlRpcMethodTest::testChangeOption()
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
} }
void XmlRpcMethodTest::testChangeOption_withBadOption() void RpcMethodTest::testChangeOption_withBadOption()
{ {
SharedHandle<RequestGroup> group(new RequestGroup(option_)); SharedHandle<RequestGroup> group(new RequestGroup(option_));
e_->getRequestGroupMan()->addReservedGroup(group); e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionXmlRpcMethod m; ChangeOptionRpcMethod m;
XmlRpcRequest req(ChangeOptionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_DOWNLOAD_LIMIT, "badvalue"); opt->put(PREF_MAX_DOWNLOAD_LIMIT, "badvalue");
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testChangeOption_withNotAllowedOption() void RpcMethodTest::testChangeOption_withNotAllowedOption()
{ {
SharedHandle<RequestGroup> group(new RequestGroup(option_)); SharedHandle<RequestGroup> group(new RequestGroup(option_));
e_->getRequestGroupMan()->addReservedGroup(group); e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionXmlRpcMethod m; ChangeOptionRpcMethod m;
XmlRpcRequest req(ChangeOptionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "100K"); opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "100K");
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testChangeOption_withoutGid() void RpcMethodTest::testChangeOption_withoutGid()
{ {
ChangeOptionXmlRpcMethod m; ChangeOptionRpcMethod m;
XmlRpcRequest req(ChangeOptionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testChangeGlobalOption() void RpcMethodTest::testChangeGlobalOption()
{ {
ChangeGlobalOptionXmlRpcMethod m; ChangeGlobalOptionRpcMethod m;
XmlRpcRequest req RpcRequest req
(ChangeGlobalOptionXmlRpcMethod::getMethodName(), List::g()); (ChangeGlobalOptionRpcMethod::getMethodName(), List::g());
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "100K"); opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "100K");
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
opt->put(PREF_MAX_OVERALL_UPLOAD_LIMIT, "50K"); opt->put(PREF_MAX_OVERALL_UPLOAD_LIMIT, "50K");
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL CPPUNIT_ASSERT_EQUAL
@ -542,73 +542,53 @@ void XmlRpcMethodTest::testChangeGlobalOption()
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
} }
void XmlRpcMethodTest::testChangeGlobalOption_withBadOption() void RpcMethodTest::testChangeGlobalOption_withBadOption()
{ {
ChangeGlobalOptionXmlRpcMethod m; ChangeGlobalOptionRpcMethod m;
XmlRpcRequest req RpcRequest req
(ChangeGlobalOptionXmlRpcMethod::getMethodName(), List::g()); (ChangeGlobalOptionRpcMethod::getMethodName(), List::g());
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "badvalue"); opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT, "badvalue");
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testChangeGlobalOption_withNotAllowedOption() void RpcMethodTest::testChangeGlobalOption_withNotAllowedOption()
{ {
ChangeGlobalOptionXmlRpcMethod m; ChangeGlobalOptionRpcMethod m;
XmlRpcRequest req RpcRequest req
(ChangeGlobalOptionXmlRpcMethod::getMethodName(), List::g()); (ChangeGlobalOptionRpcMethod::getMethodName(), List::g());
SharedHandle<Dict> opt = Dict::g(); SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_DOWNLOAD_LIMIT, "100K"); opt->put(PREF_MAX_DOWNLOAD_LIMIT, "100K");
req.params->append(opt); req.params->append(opt);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testNoSuchMethod() void RpcMethodTest::testNoSuchMethod()
{ {
NoSuchMethodXmlRpcMethod m; NoSuchMethodRpcMethod m;
XmlRpcRequest req("make.hamburger", List::g()); RpcRequest req("make.hamburger", List::g());
XmlRpcResponse res = m.execute(req, 0); RpcResponse res = m.execute(req, 0);
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
CPPUNIT_ASSERT_EQUAL(std::string("No such method: make.hamburger"), CPPUNIT_ASSERT_EQUAL(std::string("No such method: make.hamburger"),
getString(asDict(res.param), "faultString")); getString(asDict(res.param), "faultString"));
CPPUNIT_ASSERT_EQUAL
(std::string("<?xml version=\"1.0\"?>"
"<methodResponse>"
"<fault>"
"<value>"
"<struct>"
"<member>"
"<name>faultCode</name><value><int>1</int></value>"
"</member>"
"<member>"
"<name>faultString</name>"
"<value>"
"<string>No such method: make.hamburger</string>"
"</value>"
"</member>"
"</struct>"
"</value>"
"</fault>"
"</methodResponse>"),
res.toXml());
} }
void XmlRpcMethodTest::testTellStatus_withoutGid() void RpcMethodTest::testTellStatus_withoutGid()
{ {
TellStatusXmlRpcMethod m; TellStatusRpcMethod m;
XmlRpcRequest req(TellStatusXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(TellStatusRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
namespace { namespace {
void addUri(const std::string& uri, const SharedHandle<DownloadEngine>& e) void addUri(const std::string& uri, const SharedHandle<DownloadEngine>& e)
{ {
AddUriXmlRpcMethod m; AddUriRpcMethod m;
XmlRpcRequest req(AddUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddUriRpcMethod::getMethodName(), List::g());
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append(uri); urisParam->append(uri);
req.params->append(urisParam); req.params->append(urisParam);
@ -621,15 +601,15 @@ namespace {
void addTorrent void addTorrent
(const std::string& torrentFile, const SharedHandle<DownloadEngine>& e) (const std::string& torrentFile, const SharedHandle<DownloadEngine>& e)
{ {
AddTorrentXmlRpcMethod m; AddTorrentRpcMethod m;
XmlRpcRequest req(AddTorrentXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(AddTorrentRpcMethod::getMethodName(), List::g());
req.params->append(readFile(torrentFile)); req.params->append(readFile(torrentFile));
XmlRpcResponse res = m.execute(req, e.get()); RpcResponse res = m.execute(req, e.get());
} }
} // namespace } // namespace
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
void XmlRpcMethodTest::testTellWaiting() void RpcMethodTest::testTellWaiting()
{ {
addUri("http://1/", e_); addUri("http://1/", e_);
addUri("http://2/", e_); addUri("http://2/", e_);
@ -640,11 +620,11 @@ void XmlRpcMethodTest::testTellWaiting()
addUri("http://4/", e_); addUri("http://4/", e_);
#endif // !ENABLE_BITTORRENT #endif // !ENABLE_BITTORRENT
TellWaitingXmlRpcMethod m; TellWaitingRpcMethod m;
XmlRpcRequest req(TellWaitingXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(TellWaitingRpcMethod::getMethodName(), List::g());
req.params->append(Integer::g(1)); req.params->append(Integer::g(1));
req.params->append(Integer::g(2)); req.params->append(Integer::g(2));
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = asList(res.param); const List* resParams = asList(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
@ -653,7 +633,7 @@ void XmlRpcMethodTest::testTellWaiting()
CPPUNIT_ASSERT_EQUAL(std::string("3"), CPPUNIT_ASSERT_EQUAL(std::string("3"),
getString(asDict(resParams->get(1)), "gid")); getString(asDict(resParams->get(1)), "gid"));
// waiting.size() == offset+num // waiting.size() == offset+num
req = XmlRpcRequest(TellWaitingXmlRpcMethod::getMethodName(), List::g()); req = RpcRequest(TellWaitingRpcMethod::getMethodName(), List::g());
req.params->append(Integer::g(1)); req.params->append(Integer::g(1));
req.params->append(Integer::g(3)); req.params->append(Integer::g(3));
res = m.execute(req, e_.get()); res = m.execute(req, e_.get());
@ -661,7 +641,7 @@ void XmlRpcMethodTest::testTellWaiting()
resParams = asList(res.param); resParams = asList(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)3, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)3, resParams->size());
// waiting.size() < offset+num // waiting.size() < offset+num
req = XmlRpcRequest(TellWaitingXmlRpcMethod::getMethodName(), List::g()); req = RpcRequest(TellWaitingRpcMethod::getMethodName(), List::g());
req.params->append(Integer::g(1)); req.params->append(Integer::g(1));
req.params->append(Integer::g(4)); req.params->append(Integer::g(4));
res = m.execute(req, e_.get()); res = m.execute(req, e_.get());
@ -669,7 +649,7 @@ void XmlRpcMethodTest::testTellWaiting()
resParams = asList(res.param); resParams = asList(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)3, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)3, resParams->size());
// negative offset // negative offset
req = XmlRpcRequest(TellWaitingXmlRpcMethod::getMethodName(), List::g()); req = RpcRequest(TellWaitingRpcMethod::getMethodName(), List::g());
req.params->append(Integer::g(-1)); req.params->append(Integer::g(-1));
req.params->append(Integer::g(2)); req.params->append(Integer::g(2));
res = m.execute(req, e_.get()); res = m.execute(req, e_.get());
@ -700,19 +680,19 @@ void XmlRpcMethodTest::testTellWaiting()
CPPUNIT_ASSERT_EQUAL((size_t)1, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)1, resParams->size());
} }
void XmlRpcMethodTest::testTellWaiting_fail() void RpcMethodTest::testTellWaiting_fail()
{ {
TellWaitingXmlRpcMethod m; TellWaitingRpcMethod m;
XmlRpcRequest req(TellWaitingXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(TellWaitingRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testGetVersion() void RpcMethodTest::testGetVersion()
{ {
GetVersionXmlRpcMethod m; GetVersionRpcMethod m;
XmlRpcRequest req(GetVersionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(GetVersionRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
const Dict* resParams = asDict(res.param); const Dict* resParams = asDict(res.param);
CPPUNIT_ASSERT_EQUAL(std::string(PACKAGE_VERSION), CPPUNIT_ASSERT_EQUAL(std::string(PACKAGE_VERSION),
@ -730,7 +710,7 @@ void XmlRpcMethodTest::testGetVersion()
features); features);
} }
void XmlRpcMethodTest::testGatherStoppedDownload() void RpcMethodTest::testGatherStoppedDownload()
{ {
std::vector<SharedHandle<FileEntry> > fileEntries; std::vector<SharedHandle<FileEntry> > fileEntries;
std::vector<gid_t> followedBy; std::vector<gid_t> followedBy;
@ -763,7 +743,7 @@ void XmlRpcMethodTest::testGatherStoppedDownload()
CPPUNIT_ASSERT(entry->containsKey("gid")); CPPUNIT_ASSERT(entry->containsKey("gid"));
} }
void XmlRpcMethodTest::testGatherProgressCommon() void RpcMethodTest::testGatherProgressCommon()
{ {
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0,"aria2.tar.bz2")); SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0,"aria2.tar.bz2"));
std::string uris[] = { "http://localhost/aria2.tar.bz2" }; std::string uris[] = { "http://localhost/aria2.tar.bz2" };
@ -813,7 +793,7 @@ void XmlRpcMethodTest::testGatherProgressCommon()
} }
#ifdef ENABLE_BITTORRENT #ifdef ENABLE_BITTORRENT
void XmlRpcMethodTest::testGatherBitTorrentMetadata() void RpcMethodTest::testGatherBitTorrentMetadata()
{ {
SharedHandle<Option> option(new Option()); SharedHandle<Option> option(new Option());
option->put(PREF_DIR, "."); option->put(PREF_DIR, ".");
@ -857,30 +837,30 @@ void XmlRpcMethodTest::testGatherBitTorrentMetadata()
} }
#endif // ENABLE_BITTORRENT #endif // ENABLE_BITTORRENT
void XmlRpcMethodTest::testChangePosition() void RpcMethodTest::testChangePosition()
{ {
e_->getRequestGroupMan()->addReservedGroup e_->getRequestGroupMan()->addReservedGroup
(SharedHandle<RequestGroup>(new RequestGroup(option_))); (SharedHandle<RequestGroup>(new RequestGroup(option_)));
e_->getRequestGroupMan()->addReservedGroup e_->getRequestGroupMan()->addReservedGroup
(SharedHandle<RequestGroup>(new RequestGroup(option_))); (SharedHandle<RequestGroup>(new RequestGroup(option_)));
ChangePositionXmlRpcMethod m; ChangePositionRpcMethod m;
XmlRpcRequest req(ChangePositionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangePositionRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
req.params->append(Integer::g(1)); req.params->append(Integer::g(1));
req.params->append("POS_SET"); req.params->append("POS_SET");
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL((int64_t)1, asInteger(res.param)->i()); CPPUNIT_ASSERT_EQUAL((int64_t)1, asInteger(res.param)->i());
CPPUNIT_ASSERT_EQUAL CPPUNIT_ASSERT_EQUAL
((gid_t)1, e_->getRequestGroupMan()->getReservedGroups()[1]->getGID()); ((gid_t)1, e_->getRequestGroupMan()->getReservedGroups()[1]->getGID());
} }
void XmlRpcMethodTest::testChangePosition_fail() void RpcMethodTest::testChangePosition_fail()
{ {
ChangePositionXmlRpcMethod m; ChangePositionRpcMethod m;
XmlRpcRequest req(ChangePositionXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangePositionRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
req.params->append("1"); req.params->append("1");
@ -889,7 +869,7 @@ void XmlRpcMethodTest::testChangePosition_fail()
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testChangeUri() void RpcMethodTest::testChangeUri()
{ {
SharedHandle<FileEntry> files[3]; SharedHandle<FileEntry> files[3];
for(int i = 0; i < 3; ++i) { for(int i = 0; i < 3; ++i) {
@ -904,8 +884,8 @@ void XmlRpcMethodTest::testChangeUri()
group->setDownloadContext(dctx); group->setDownloadContext(dctx);
e_->getRequestGroupMan()->addReservedGroup(group); e_->getRequestGroupMan()->addReservedGroup(group);
ChangeUriXmlRpcMethod m; ChangeUriRpcMethod m;
XmlRpcRequest req(ChangeUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeUriRpcMethod::getMethodName(), List::g());
req.params->append("1"); // GID req.params->append("1"); // GID
req.params->append(Integer::g(2)); // index of FileEntry req.params->append(Integer::g(2)); // index of FileEntry
SharedHandle<List> removeuris = List::g(); SharedHandle<List> removeuris = List::g();
@ -919,7 +899,7 @@ void XmlRpcMethodTest::testChangeUri()
adduris->append("baduri"); adduris->append("baduri");
adduris->append("http://example.org/added3"); adduris->append("http://example.org/added3");
req.params->append(adduris); req.params->append(adduris);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL((int64_t)2, asInteger(asList(res.param)->get(0))->i()); CPPUNIT_ASSERT_EQUAL((int64_t)2, asInteger(asList(res.param)->get(0))->i());
CPPUNIT_ASSERT_EQUAL((int64_t)3, asInteger(asList(res.param)->get(1))->i()); CPPUNIT_ASSERT_EQUAL((int64_t)3, asInteger(asList(res.param)->get(1))->i());
@ -962,7 +942,7 @@ void XmlRpcMethodTest::testChangeUri()
CPPUNIT_ASSERT_EQUAL(std::string("http://example.org/added1-2"), uris[1]); CPPUNIT_ASSERT_EQUAL(std::string("http://example.org/added1-2"), uris[1]);
} }
void XmlRpcMethodTest::testChangeUri_fail() void RpcMethodTest::testChangeUri_fail()
{ {
SharedHandle<FileEntry> files[3]; SharedHandle<FileEntry> files[3];
for(int i = 0; i < 3; ++i) { for(int i = 0; i < 3; ++i) {
@ -974,15 +954,15 @@ void XmlRpcMethodTest::testChangeUri_fail()
group->setDownloadContext(dctx); group->setDownloadContext(dctx);
e_->getRequestGroupMan()->addReservedGroup(group); e_->getRequestGroupMan()->addReservedGroup(group);
ChangeUriXmlRpcMethod m; ChangeUriRpcMethod m;
XmlRpcRequest req(ChangeUriXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ChangeUriRpcMethod::getMethodName(), List::g());
req.params->append("1"); // GID req.params->append("1"); // GID
req.params->append(Integer::g(1)); // index of FileEntry req.params->append(Integer::g(1)); // index of FileEntry
SharedHandle<List> removeuris = List::g(); SharedHandle<List> removeuris = List::g();
req.params->append(removeuris); req.params->append(removeuris);
SharedHandle<List> adduris = List::g(); SharedHandle<List> adduris = List::g();
req.params->append(adduris); req.params->append(adduris);
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
req.params->set(0, String::g("2")); req.params->set(0, String::g("2"));
@ -1014,17 +994,17 @@ void XmlRpcMethodTest::testChangeUri_fail()
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
void XmlRpcMethodTest::testGetSessionInfo() void RpcMethodTest::testGetSessionInfo()
{ {
GetSessionInfoXmlRpcMethod m; GetSessionInfoRpcMethod m;
XmlRpcRequest req(GetSessionInfoXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(GetSessionInfoRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL(util::toHex(e_->getSessionId()), CPPUNIT_ASSERT_EQUAL(util::toHex(e_->getSessionId()),
getString(asDict(res.param), "sessionId")); getString(asDict(res.param), "sessionId"));
} }
void XmlRpcMethodTest::testPause() void RpcMethodTest::testPause()
{ {
const std::string URIS[] = { const std::string URIS[] = {
"http://url1", "http://url1",
@ -1038,43 +1018,43 @@ void XmlRpcMethodTest::testPause()
CPPUNIT_ASSERT_EQUAL((size_t)3, groups.size()); CPPUNIT_ASSERT_EQUAL((size_t)3, groups.size());
e_->getRequestGroupMan()->addReservedGroup(groups); e_->getRequestGroupMan()->addReservedGroup(groups);
{ {
PauseXmlRpcMethod m; PauseRpcMethod m;
XmlRpcRequest req(PauseXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(PauseRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
} }
CPPUNIT_ASSERT(groups[0]->isPauseRequested()); CPPUNIT_ASSERT(groups[0]->isPauseRequested());
{ {
UnpauseXmlRpcMethod m; UnpauseRpcMethod m;
XmlRpcRequest req(UnpauseXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(UnpauseRpcMethod::getMethodName(), List::g());
req.params->append("1"); req.params->append("1");
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
} }
CPPUNIT_ASSERT(!groups[0]->isPauseRequested()); CPPUNIT_ASSERT(!groups[0]->isPauseRequested());
{ {
PauseAllXmlRpcMethod m; PauseAllRpcMethod m;
XmlRpcRequest req(PauseAllXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(PauseAllRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
} }
for(size_t i = 0; i < groups.size(); ++i) { for(size_t i = 0; i < groups.size(); ++i) {
CPPUNIT_ASSERT(groups[i]->isPauseRequested()); CPPUNIT_ASSERT(groups[i]->isPauseRequested());
} }
{ {
UnpauseAllXmlRpcMethod m; UnpauseAllRpcMethod m;
XmlRpcRequest req(UnpauseAllXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(UnpauseAllRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
} }
for(size_t i = 0; i < groups.size(); ++i) { for(size_t i = 0; i < groups.size(); ++i) {
CPPUNIT_ASSERT(!groups[i]->isPauseRequested()); CPPUNIT_ASSERT(!groups[i]->isPauseRequested());
} }
{ {
ForcePauseAllXmlRpcMethod m; ForcePauseAllRpcMethod m;
XmlRpcRequest req(ForcePauseAllXmlRpcMethod::getMethodName(), List::g()); RpcRequest req(ForcePauseAllRpcMethod::getMethodName(), List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
} }
for(size_t i = 0; i < groups.size(); ++i) { for(size_t i = 0; i < groups.size(); ++i) {
@ -1082,15 +1062,15 @@ void XmlRpcMethodTest::testPause()
} }
} }
void XmlRpcMethodTest::testSystemMulticall() void RpcMethodTest::testSystemMulticall()
{ {
SystemMulticallXmlRpcMethod m; SystemMulticallRpcMethod m;
XmlRpcRequest req("system.multicall", List::g()); RpcRequest req("system.multicall", List::g());
SharedHandle<List> reqparams = List::g(); SharedHandle<List> reqparams = List::g();
req.params->append(reqparams); req.params->append(reqparams);
for(int i = 0; i < 2; ++i) { for(int i = 0; i < 2; ++i) {
SharedHandle<Dict> dict = Dict::g(); SharedHandle<Dict> dict = Dict::g();
dict->put("methodName", AddUriXmlRpcMethod::getMethodName()); dict->put("methodName", AddUriRpcMethod::getMethodName());
SharedHandle<List> params = List::g(); SharedHandle<List> params = List::g();
SharedHandle<List> urisParam = List::g(); SharedHandle<List> urisParam = List::g();
urisParam->append("http://localhost/"+util::itos(i)); urisParam->append("http://localhost/"+util::itos(i));
@ -1116,16 +1096,16 @@ void XmlRpcMethodTest::testSystemMulticall()
{ {
// missing params // missing params
SharedHandle<Dict> dict = Dict::g(); SharedHandle<Dict> dict = Dict::g();
dict->put("methodName", GetVersionXmlRpcMethod::getMethodName()); dict->put("methodName", GetVersionRpcMethod::getMethodName());
reqparams->append(dict); reqparams->append(dict);
} }
{ {
SharedHandle<Dict> dict = Dict::g(); SharedHandle<Dict> dict = Dict::g();
dict->put("methodName", GetVersionXmlRpcMethod::getMethodName()); dict->put("methodName", GetVersionRpcMethod::getMethodName());
dict->put("params", List::g()); dict->put("params", List::g());
reqparams->append(dict); reqparams->append(dict);
} }
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code); CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = asList(res.param); const List* resParams = asList(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)7, resParams->size()); CPPUNIT_ASSERT_EQUAL((size_t)7, resParams->size());
@ -1152,14 +1132,14 @@ void XmlRpcMethodTest::testSystemMulticall()
CPPUNIT_ASSERT(asList(resParams->get(6))); CPPUNIT_ASSERT(asList(resParams->get(6)));
} }
void XmlRpcMethodTest::testSystemMulticall_fail() void RpcMethodTest::testSystemMulticall_fail()
{ {
SystemMulticallXmlRpcMethod m; SystemMulticallRpcMethod m;
XmlRpcRequest req("system.multicall", List::g()); RpcRequest req("system.multicall", List::g());
XmlRpcResponse res = m.execute(req, e_.get()); RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(1, res.code); CPPUNIT_ASSERT_EQUAL(1, res.code);
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -1,29 +1,35 @@
#include "XmlRpcResponse.h" #include "RpcResponse.h"
#include <cppunit/extensions/HelperMacros.h> #include <cppunit/extensions/HelperMacros.h>
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcResponseTest:public CppUnit::TestFixture { class RpcResponseTest:public CppUnit::TestFixture {
CPPUNIT_TEST_SUITE(XmlRpcResponseTest); CPPUNIT_TEST_SUITE(RpcResponseTest);
CPPUNIT_TEST(testToJson); CPPUNIT_TEST(testToJson);
#ifdef ENABLE_XML_RPC
CPPUNIT_TEST(testToXml);
#endif // ENABLE_XML_RPC
CPPUNIT_TEST_SUITE_END(); CPPUNIT_TEST_SUITE_END();
public: public:
void testToJson(); void testToJson();
#ifdef ENABLE_XML_RPC
void testToXml();
#endif // ENABLE_XML_RPC
}; };
CPPUNIT_TEST_SUITE_REGISTRATION(XmlRpcResponseTest); CPPUNIT_TEST_SUITE_REGISTRATION(RpcResponseTest);
void XmlRpcResponseTest::testToJson() void RpcResponseTest::testToJson()
{ {
std::vector<XmlRpcResponse> results; std::vector<RpcResponse> results;
{ {
SharedHandle<List> param = List::g(); SharedHandle<List> param = List::g();
param->append(Integer::g(1)); param->append(Integer::g(1));
SharedHandle<String> id = String::g("9"); SharedHandle<String> id = String::g("9");
XmlRpcResponse res(0, param, id); RpcResponse res(0, param, id);
results.push_back(res); results.push_back(res);
std::string s = res.toJson("", false); std::string s = res.toJson("", false);
CPPUNIT_ASSERT_EQUAL(std::string("{\"id\":\"9\"," CPPUNIT_ASSERT_EQUAL(std::string("{\"id\":\"9\","
@ -36,7 +42,7 @@ void XmlRpcResponseTest::testToJson()
SharedHandle<Dict> param = Dict::g(); SharedHandle<Dict> param = Dict::g();
param->put("code", Integer::g(1)); param->put("code", Integer::g(1));
param->put("message", "HELLO ERROR"); param->put("message", "HELLO ERROR");
XmlRpcResponse res(1, param, Null::g()); RpcResponse res(1, param, Null::g());
results.push_back(res); results.push_back(res);
std::string s = res.toJson("", false); std::string s = res.toJson("", false);
CPPUNIT_ASSERT_EQUAL(std::string("{\"error\":{\"code\":1," CPPUNIT_ASSERT_EQUAL(std::string("{\"error\":{\"code\":1,"
@ -63,6 +69,37 @@ void XmlRpcResponseTest::testToJson()
} }
} }
} // namespace xmlrpc #ifdef ENABLE_XML_RPC
void RpcResponseTest::testToXml()
{
SharedHandle<Dict> param = Dict::g();
param->put("faultCode", Integer::g(1));
param->put("faultString", "No such method: make.hamburger");
RpcResponse res(1, param, Null::g());
std::string s = res.toXml(false);
CPPUNIT_ASSERT_EQUAL
(std::string("<?xml version=\"1.0\"?>"
"<methodResponse>"
"<fault>"
"<value>"
"<struct>"
"<member>"
"<name>faultCode</name><value><int>1</int></value>"
"</member>"
"<member>"
"<name>faultString</name>"
"<value>"
"<string>No such method: make.hamburger</string>"
"</value>"
"</member>"
"</struct>"
"</value>"
"</fault>"
"</methodResponse>"),
s);
}
#endif // ENABLE_XML_RPC
} // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -4,7 +4,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestParserControllerTest:public CppUnit::TestFixture { class XmlRpcRequestParserControllerTest:public CppUnit::TestFixture {
@ -157,6 +157,6 @@ void XmlRpcRequestParserControllerTest::testPopArrayFrame_compound()
CPPUNIT_ASSERT_EQUAL(std::string("jp"), asString(countryList->get(0))->s()); CPPUNIT_ASSERT_EQUAL(std::string("jp"), asString(countryList->get(0))->s());
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2

View File

@ -7,7 +7,7 @@
namespace aria2 { namespace aria2 {
namespace xmlrpc { namespace rpc {
class XmlRpcRequestProcessorTest:public CppUnit::TestFixture { class XmlRpcRequestProcessorTest:public CppUnit::TestFixture {
@ -30,7 +30,7 @@ CPPUNIT_TEST_SUITE_REGISTRATION(XmlRpcRequestProcessorTest);
void XmlRpcRequestProcessorTest::testParseMemory() void XmlRpcRequestProcessorTest::testParseMemory()
{ {
XmlRpcRequestProcessor proc; XmlRpcRequestProcessor proc;
XmlRpcRequest req = RpcRequest req =
proc.parseMemory("<?xml version=\"1.0\"?>" proc.parseMemory("<?xml version=\"1.0\"?>"
"<methodCall>" "<methodCall>"
" <methodName>aria2.addURI</methodName>" " <methodName>aria2.addURI</methodName>"
@ -95,7 +95,7 @@ void XmlRpcRequestProcessorTest::testParseMemory_shouldFail()
// success // success
} }
{ {
XmlRpcRequest req = RpcRequest req =
proc.parseMemory("<methodCall>" proc.parseMemory("<methodCall>"
" <methodName>aria2.addURI</methodName>" " <methodName>aria2.addURI</methodName>"
" <params>" " <params>"
@ -104,16 +104,16 @@ void XmlRpcRequestProcessorTest::testParseMemory_shouldFail()
CPPUNIT_ASSERT(req.params); CPPUNIT_ASSERT(req.params);
} }
try { try {
XmlRpcRequest req = RpcRequest req =
proc.parseMemory("<methodCall>" proc.parseMemory("<methodCall>"
" <methodName>aria2.addURI</methodName>" " <methodName>aria2.addURI</methodName>"
"</methodCall>"); "</methodCall>");
CPPUNIT_FAIL("exception must be thrown."); CPPUNIT_FAIL("exception must be thrown.");
} catch(RecoverableException& e) { } catch(RecoverableException& e) {
// success // success
} }
} }
} // namespace xmlrpc } // namespace rpc
} // namespace aria2 } // namespace aria2