Bridge.cpp 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #include "Bridge.h"
  2. #include <Logging.h>
  3. #include <functional>
  4. #include <sstream>
  5. namespace ToonBridge {
  6. namespace Toon {
  7. Bridge::Bridge(int port, const ToonSettings& toonSettings, const MQTTSettings& mqttSettings) :
  8. m_mqttClient(mqttSettings.hostname, mqttSettings.port),
  9. m_messageHandler(m_mqttClient, mqttSettings.topic),
  10. m_port(port),
  11. m_toonSettings(toonSettings),
  12. m_mqttSettings(mqttSettings)
  13. {
  14. Start();
  15. }
  16. Bridge::~Bridge()
  17. {
  18. std::stringstream ss;
  19. ss << m_mqttSettings.topic << "/BridgeState";
  20. MQTT::MQTTMessage message;
  21. message.topic = ss.str();
  22. message.payload = "Stop";
  23. m_mqttClient.Send(message);
  24. }
  25. void Bridge::Wait()
  26. {
  27. m_pHttpServer->Wait();
  28. }
  29. void Bridge::Start()
  30. {
  31. Http::HttpServer::CallbackMethod httpCallback = std::bind(&Bridge::HttpCallback, this, std::placeholders::_1, std::placeholders::_2);
  32. m_pHttpServer.reset(new Http::HttpServer(m_port, httpCallback));
  33. m_pWebSocketSubscription.reset(new WebSocketSubscription(m_toonSettings));
  34. m_messageHandler.Connect(std::bind(&Bridge::ReconnectCallback, this, m_pWebSocketSubscription.get()));
  35. m_messageCheckTimer.StartContinuous(300000, static_cast<std::function<void()>>(std::bind(&Bridge::CheckMessageReceived, this)));
  36. std::stringstream ss;
  37. ss << m_mqttSettings.topic << "/BridgeState";
  38. MQTT::MQTTMessage message;
  39. message.topic = ss.str();
  40. message.payload = ss.str();
  41. m_mqttClient.Send(message);
  42. }
  43. Http::HttpServer::HttpReply Bridge::HttpCallback(const std::string& uri, const std::vector<Http::HttpPostData>& postData)
  44. {
  45. Http::HttpServer::HttpReply reply;
  46. reply.status = Http::HttpServer::HttpReply::Status::Ok;
  47. try
  48. {
  49. if (postData.size() > 0)
  50. {
  51. for (auto& item : postData)
  52. {
  53. if (item.name == "data")
  54. m_messageHandler.HandleMessage(item.value);
  55. }
  56. }
  57. }
  58. catch (const std::exception& e)
  59. {
  60. std::string data;
  61. for (auto& item : postData)
  62. {
  63. if (item.name == "data")
  64. data = (item.value);
  65. }
  66. }
  67. {
  68. std::unique_lock<std::mutex> lock(m_mutex);
  69. m_messageReceived = true;
  70. }
  71. return reply;
  72. }
  73. void Bridge::ReconnectCallback(ToonBridge::Toon::WebSocketSubscription* pSubscription)
  74. {
  75. std::stringstream ss;
  76. ss << "Bridge::TimeToLiveCallback() - TTL Expired, reconnecting" << std::endl;
  77. Logging::Log(Logging::Severity::Info, ss.str());
  78. pSubscription->Reconnect();
  79. }
  80. void Bridge::CheckMessageReceived()
  81. {
  82. bool messageReceived;
  83. {
  84. std::unique_lock<std::mutex> lock(m_mutex);
  85. messageReceived = m_messageReceived;
  86. m_messageReceived = false;
  87. }
  88. if (!messageReceived)
  89. {
  90. std::stringstream ss;
  91. ss << "Bridge::CheckMessageReceived() - No message received for 5 minutes, reconnecting" << std::endl;
  92. Logging::Log(Logging::Severity::Info, ss.str());
  93. m_pWebSocketSubscription->Reconnect();
  94. }
  95. }
  96. } // namespace Toon
  97. } // namespace ToonBridge