icinga2/jsonrpc/jsonrpcclient.cpp

94 lines
3.1 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. *
******************************************************************************/
2012-03-28 13:24:49 +02:00
#include "i2-jsonrpc.h"
using namespace icinga;
/**
* Constructor for the JsonRpcClient class.
*
* @param role The role of the underlying TCP client.
* @param sslContext SSL context for the TLS connection.
*/
JsonRpcClient::JsonRpcClient(TcpClientRole role, shared_ptr<SSL_CTX> sslContext)
: TlsClient(role, sslContext) { }
2012-04-24 14:02:15 +02:00
2012-03-28 13:24:49 +02:00
void JsonRpcClient::Start(void)
{
TlsClient::Start();
2012-03-28 13:24:49 +02:00
OnDataAvailable.connect(bind(&JsonRpcClient::DataAvailableHandler, this, _1));
2012-03-28 13:24:49 +02:00
}
/**
* Sends a message to the connected peer.
*
* @param message The message.
*/
2012-05-16 11:30:54 +02:00
void JsonRpcClient::SendMessage(const MessagePart& message)
2012-03-28 13:24:49 +02:00
{
Netstring::WriteStringToFIFO(GetSendQueue(), message.ToJsonString());
2012-03-28 13:24:49 +02:00
}
/**
* Processes inbound data.
*
* @param - Event arguments for the event.
* @returns 0
*/
2012-05-10 13:46:04 +02:00
int JsonRpcClient::DataAvailableHandler(const EventArgs&)
2012-03-28 13:24:49 +02:00
{
2012-05-10 13:46:04 +02:00
for (;;) {
2012-03-28 13:24:49 +02:00
try {
string jsonString;
2012-05-16 11:30:54 +02:00
MessagePart message;
if (!Netstring::ReadStringFromFIFO(GetRecvQueue(), &jsonString))
break;
2012-05-16 11:30:54 +02:00
message = MessagePart(jsonString);
NewMessageEventArgs nea;
nea.Source = shared_from_this();
nea.Message = message;
OnNewMessage(nea);
2012-04-18 15:22:25 +02:00
} catch (const Exception& ex) {
2012-05-17 19:14:03 +02:00
Application::Log("Exception while processing message from JSON-RPC client: " + string(ex.GetMessage()));
2012-03-28 13:24:49 +02:00
Close();
return 0;
2012-03-28 13:24:49 +02:00
}
}
return 0;
}
2012-04-24 14:02:15 +02:00
/**
* Factory function for JSON-RPC clients.
*
* @param role The role of the underlying TCP client.
* @param sslContext SSL context for the TLS connection.
* @returns A new JSON-RPC client.
*/
JsonRpcClient::Ptr icinga::JsonRpcClientFactory(TcpClientRole role, shared_ptr<SSL_CTX> sslContext)
2012-04-24 14:02:15 +02:00
{
return make_shared<JsonRpcClient>(role, sslContext);
}