2019-04-09 06:52:20 +02:00
|
|
|
/*
|
|
|
|
* ws_cobra_subscribe.cpp
|
|
|
|
* Author: Benjamin Sergeant
|
|
|
|
* Copyright (c) 2019 Machine Zone, Inc. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <atomic>
|
2019-09-23 19:25:23 +02:00
|
|
|
#include <chrono>
|
2020-03-09 23:25:43 +01:00
|
|
|
#include <iostream>
|
2019-04-21 20:20:17 +02:00
|
|
|
#include <ixcobra/IXCobraConnection.h>
|
2019-08-02 00:22:24 +02:00
|
|
|
#include <spdlog/spdlog.h>
|
2019-09-23 19:25:23 +02:00
|
|
|
#include <sstream>
|
|
|
|
#include <thread>
|
2019-08-02 00:22:24 +02:00
|
|
|
|
2019-04-09 06:52:20 +02:00
|
|
|
namespace ix
|
|
|
|
{
|
2020-03-09 23:25:43 +01:00
|
|
|
void writeToStdout(bool fluentd, Json::FastWriter& jsonWriter, const Json::Value& msg)
|
|
|
|
{
|
|
|
|
Json::Value enveloppe;
|
|
|
|
if (fluentd)
|
|
|
|
{
|
|
|
|
enveloppe["producer"] = "cobra";
|
|
|
|
enveloppe["consumer"] = "fluentd";
|
|
|
|
enveloppe["message"] = msg;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
enveloppe = msg;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::cout << jsonWriter.write(enveloppe);
|
|
|
|
}
|
|
|
|
|
2020-03-11 18:48:27 +01:00
|
|
|
int ws_cobra_subscribe_main(const ix::CobraConfig& config,
|
2019-08-02 00:22:24 +02:00
|
|
|
const std::string& channel,
|
|
|
|
const std::string& filter,
|
2019-12-20 05:49:28 +01:00
|
|
|
bool quiet,
|
2020-03-11 20:40:32 +01:00
|
|
|
bool fluentd)
|
2019-04-09 06:52:20 +02:00
|
|
|
{
|
|
|
|
ix::CobraConnection conn;
|
2020-03-11 20:40:32 +01:00
|
|
|
conn.configure(config);
|
2019-04-09 06:52:20 +02:00
|
|
|
conn.connect();
|
|
|
|
|
|
|
|
Json::FastWriter jsonWriter;
|
|
|
|
|
2019-08-02 00:22:24 +02:00
|
|
|
// Display incoming messages
|
|
|
|
std::atomic<int> msgPerSeconds(0);
|
|
|
|
std::atomic<int> msgCount(0);
|
2019-09-12 20:43:52 +02:00
|
|
|
|
2019-09-23 19:25:23 +02:00
|
|
|
auto timer = [&msgPerSeconds, &msgCount] {
|
2019-08-02 00:22:24 +02:00
|
|
|
while (true)
|
|
|
|
{
|
2019-12-25 06:55:34 +01:00
|
|
|
spdlog::info("#messages {} msg/s {}", msgCount, msgPerSeconds);
|
2019-08-02 00:22:24 +02:00
|
|
|
|
|
|
|
msgPerSeconds = 0;
|
|
|
|
auto duration = std::chrono::seconds(1);
|
|
|
|
std::this_thread::sleep_for(duration);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
std::thread t(timer);
|
|
|
|
|
2019-04-09 06:52:20 +02:00
|
|
|
conn.setEventCallback(
|
2020-03-09 23:25:43 +01:00
|
|
|
[&conn, &channel, &jsonWriter, &filter, &msgCount, &msgPerSeconds, &quiet, &fluentd](
|
2019-09-23 19:25:23 +02:00
|
|
|
ix::CobraConnectionEventType eventType,
|
|
|
|
const std::string& errMsg,
|
|
|
|
const ix::WebSocketHttpHeaders& headers,
|
|
|
|
const std::string& subscriptionId,
|
|
|
|
CobraConnection::MsgId msgId) {
|
2019-04-09 06:52:20 +02:00
|
|
|
if (eventType == ix::CobraConnection_EventType_Open)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::info("Subscriber connected");
|
2019-04-19 18:48:46 +02:00
|
|
|
|
|
|
|
for (auto it : headers)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::info("{}: {}", it.first, it.second);
|
2019-04-19 18:48:46 +02:00
|
|
|
}
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
|
|
|
else if (eventType == ix::CobraConnection_EventType_Authenticated)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::info("Subscriber authenticated");
|
2020-03-09 23:25:43 +01:00
|
|
|
conn.subscribe(channel,
|
|
|
|
filter,
|
|
|
|
[&jsonWriter, &quiet, &msgPerSeconds, &msgCount, &fluentd](
|
|
|
|
const Json::Value& msg) {
|
|
|
|
if (!quiet)
|
|
|
|
{
|
|
|
|
writeToStdout(fluentd, jsonWriter, msg);
|
|
|
|
}
|
2019-08-02 00:22:24 +02:00
|
|
|
|
2020-03-09 23:25:43 +01:00
|
|
|
msgPerSeconds++;
|
|
|
|
msgCount++;
|
|
|
|
});
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
|
|
|
else if (eventType == ix::CobraConnection_EventType_Subscribed)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::info("Subscriber: subscribed to channel {}", subscriptionId);
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
|
|
|
else if (eventType == ix::CobraConnection_EventType_UnSubscribed)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::info("Subscriber: unsubscribed from channel {}", subscriptionId);
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
|
|
|
else if (eventType == ix::CobraConnection_EventType_Error)
|
|
|
|
{
|
2019-08-02 00:22:24 +02:00
|
|
|
spdlog::error("Subscriber: error {}", errMsg);
|
2019-04-09 06:52:20 +02:00
|
|
|
}
|
2019-09-01 01:46:44 +02:00
|
|
|
else if (eventType == ix::CobraConnection_EventType_Published)
|
|
|
|
{
|
|
|
|
spdlog::error("Published message hacked: {}", msgId);
|
|
|
|
}
|
2019-12-25 02:16:41 +01:00
|
|
|
else if (eventType == ix::CobraConnection_EventType_Pong)
|
|
|
|
{
|
|
|
|
spdlog::info("Received websocket pong");
|
|
|
|
}
|
2019-09-23 19:25:23 +02:00
|
|
|
});
|
2019-04-09 06:52:20 +02:00
|
|
|
|
|
|
|
while (true)
|
|
|
|
{
|
2019-12-02 18:52:52 +01:00
|
|
|
auto duration = std::chrono::seconds(1);
|
2019-04-09 06:52:20 +02:00
|
|
|
std::this_thread::sleep_for(duration);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2019-09-23 19:25:23 +02:00
|
|
|
} // namespace ix
|