Bridge.cpp 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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::TimeToLiveCallback, this, m_pWebSocketSubscription.get(), std::placeholders::_1));
  35. std::stringstream ss;
  36. ss << m_mqttSettings.topic << "/BridgeState";
  37. MQTT::MQTTMessage message;
  38. message.topic = ss.str();
  39. message.payload = ss.str();
  40. m_mqttClient.Send(message);
  41. }
  42. Http::HttpServer::HttpReply Bridge::HttpCallback(const std::string& uri, const std::vector<Http::HttpPostData>& postData)
  43. {
  44. Http::HttpServer::HttpReply reply;
  45. reply.status = Http::HttpServer::HttpReply::Status::Ok;
  46. try
  47. {
  48. if (postData.size() > 0)
  49. {
  50. for (auto& data : postData)
  51. {
  52. if (data.name == "data")
  53. m_messageHandler.HandleMessage(data.value);
  54. }
  55. }
  56. }
  57. catch (const std::exception& e)
  58. {
  59. std::stringstream ss;
  60. ss << "Bridge::HttpCallback() - Error: " << e.what() << std::endl;
  61. Logging::Log(Logging::Severity::Error, ss.str());
  62. }
  63. return reply;
  64. }
  65. void Bridge::TimeToLiveCallback(ToonBridge::Toon::WebSocketSubscription* pSubscription, int timeToLive)
  66. {
  67. if (timeToLive < 20)
  68. pSubscription->Reconnect();
  69. }
  70. } // namespace Toon
  71. } // namespace ToonBridge