icinga2/lib/remoting/requestmessage.h

139 lines
3.6 KiB
C
Raw Normal View History

/******************************************************************************
* Icinga 2 *
* Copyright (C) 2012 Icinga Development Team (http://www.icinga.org/) *
* *
* 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 *
2012-05-11 13:33:57 +02:00
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
#ifndef REQUESTMESSAGE_H
#define REQUESTMESSAGE_H
2012-04-18 15:22:25 +02:00
2013-03-17 20:19:29 +01:00
#include "remoting/i2-remoting.h"
#include "remoting/messagepart.h"
2012-04-18 15:22:25 +02:00
namespace icinga
{
2012-05-18 22:21:28 +02:00
/**
* A JSON-RPC request message.
*
2012-09-10 14:07:32 +02:00
* @ingroup remoting
2012-05-18 22:21:28 +02:00
*/
2012-09-10 14:07:32 +02:00
class I2_REMOTING_API RequestMessage : public MessagePart
2012-04-18 15:22:25 +02:00
{
public:
/**
* Constructor for the RequestMessage class.
*/
RequestMessage(void) : MessagePart() {
SetVersion("2.0");
}
/**
* Copy-constructor for the RequestMessage class.
*
* @param message The message that is to be copied.
*/
RequestMessage(const MessagePart& message) : MessagePart(message) { }
2012-04-18 15:22:25 +02:00
/**
* Retrieves the version of the JSON-RPC protocol.
*
* @param[out] value The value.
* @returns true if the value was retrieved, false otherwise.
*/
inline bool GetVersion(String *value) const
2012-04-18 15:22:25 +02:00
{
return Get("jsonrpc", value);
2012-04-18 15:22:25 +02:00
}
/**
* Sets the version of the JSON-RPC protocol that should be used.
*
* @param value The version.
*/
inline void SetVersion(const String& value)
2012-04-18 15:22:25 +02:00
{
Set("jsonrpc", value);
2012-04-18 15:22:25 +02:00
}
/**
* Retrieves the method of the JSON-RPC call.
*
* @param[out] value The method.
* @returns true if the value was retrieved, false otherwise.
*/
inline bool GetMethod(String *value) const
2012-04-18 15:22:25 +02:00
{
return Get("method", value);
2012-04-18 15:22:25 +02:00
}
/**
* Sets the method for the JSON-RPC call.
*
* @param value The method.
*/
inline void SetMethod(const String& value)
2012-04-18 15:22:25 +02:00
{
Set("method", value);
2012-04-18 15:22:25 +02:00
}
/**
* Retrieves the parameters of the JSON-RPC call.
*
* @param[out] value The parameters.
* @returns true if the value was retrieved, false otherwise.
*/
2012-05-16 11:30:54 +02:00
inline bool GetParams(MessagePart *value) const
2012-04-18 15:22:25 +02:00
{
return Get("params", value);
2012-04-18 15:22:25 +02:00
}
/**
* Sets the parameters for the JSON-RPC call.
*
* @param value The parameters.
*/
2012-05-16 11:30:54 +02:00
inline void SetParams(const MessagePart& value)
2012-04-18 15:22:25 +02:00
{
Set("params", value);
2012-04-18 15:22:25 +02:00
}
/**
* Retrieves the ID of the JSON-RPC call.
*
* @param[out] value The ID.
* @return true if the value was retrieved, false otherwise.
*/
inline bool GetID(String *value) const
2012-04-18 15:22:25 +02:00
{
return Get("id", value);
2012-04-18 15:22:25 +02:00
}
/**
* Sets the ID for the JSON-RPC call.
*
* @param value The ID.
*/
inline void SetID(const String& value)
2012-04-18 15:22:25 +02:00
{
Set("id", value);
2012-04-18 15:22:25 +02:00
}
};
}
#endif /* REQUESTMESSAGE_H */