Bridge.cpp 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  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),
  10. m_port(port),
  11. m_toonSettings(toonSettings),
  12. m_mqttSettings(mqttSettings)
  13. {
  14. Start();
  15. }
  16. Bridge::~Bridge()
  17. {
  18. MQTT::MQTTMessage message;
  19. message.topic = m_mqttSettings.topic;
  20. message.payload = "ToonBridge Stop";
  21. m_mqttClient.Send(message);
  22. }
  23. void Bridge::Wait()
  24. {
  25. m_pHttpServer->Wait();
  26. }
  27. void Bridge::Start()
  28. {
  29. Http::HttpServer::CallbackMethod httpCallback = std::bind(&Bridge::HttpCallback, this, std::placeholders::_1, std::placeholders::_2);
  30. m_pHttpServer.reset(new Http::HttpServer(m_port, httpCallback));
  31. m_pWebSocketSubscription.reset(new WebSocketSubscription(m_toonSettings));
  32. m_messageHandler.Connect(std::bind(&Bridge::TimeToLiveCallback, this, m_pWebSocketSubscription.get(), std::placeholders::_1));
  33. MQTT::MQTTMessage message;
  34. message.topic = m_mqttSettings.topic;
  35. message.payload = "ToonBridge Start";
  36. m_mqttClient.Send(message);
  37. }
  38. Http::HttpServer::HttpReply Bridge::HttpCallback(const std::string& uri, const std::vector<Http::HttpPostData>& postData)
  39. {
  40. Http::HttpServer::HttpReply reply;
  41. reply.status = Http::HttpServer::HttpReply::Status::Ok;
  42. try
  43. {
  44. if (postData.size() > 0)
  45. {
  46. for (auto& data : postData)
  47. {
  48. if (data.name == "data")
  49. m_messageHandler.HandleMessage(data.value);
  50. }
  51. }
  52. }
  53. catch (const std::exception& e)
  54. {
  55. std::stringstream ss;
  56. ss << "Bridge::HttpCallback() - Error: " << e.what() << std::endl;
  57. Logging::Log(Logging::Severity::Error, ss.str());
  58. }
  59. return reply;
  60. }
  61. void Bridge::TimeToLiveCallback(ToonBridge::Toon::WebSocketSubscription* pSubscription, int timeToLive)
  62. {
  63. if (timeToLive < 20)
  64. pSubscription->Reconnect();
  65. }
  66. } // namespace Toon
  67. } // namespace ToonBridge