message.hpp 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /**
  2. * Copyright (c) 2019-2020 Paul-Louis Ageneau
  3. *
  4. * This Source Code Form is subject to the terms of the Mozilla Public
  5. * License, v. 2.0. If a copy of the MPL was not distributed with this
  6. * file, You can obtain one at https://mozilla.org/MPL/2.0/.
  7. */
  8. #ifndef RTC_MESSAGE_H
  9. #define RTC_MESSAGE_H
  10. #include "common.hpp"
  11. #include "frameinfo.hpp"
  12. #include "reliability.hpp"
  13. #include <functional>
  14. namespace rtc {
  15. struct RTC_CPP_EXPORT Message : binary {
  16. enum Type { Binary, String, Control, Reset };
  17. Message(const Message &message) = default;
  18. Message(size_t size, Type type_ = Binary) : binary(size), type(type_) {}
  19. template <typename Iterator>
  20. Message(Iterator begin_, Iterator end_, Type type_ = Binary)
  21. : binary(begin_, end_), type(type_) {}
  22. Message(binary &&data, Type type_ = Binary) : binary(std::move(data)), type(type_) {}
  23. Type type;
  24. unsigned int stream = 0; // Stream id (SCTP stream or SSRC)
  25. unsigned int dscp = 0; // Differentiated Services Code Point
  26. shared_ptr<Reliability> reliability;
  27. shared_ptr<FrameInfo> frameInfo;
  28. };
  29. using message_ptr = shared_ptr<Message>;
  30. using message_callback = std::function<void(message_ptr message)>;
  31. using message_vector = std::vector<message_ptr>;
  32. inline size_t message_size_func(const message_ptr &m) {
  33. return m->type == Message::Binary || m->type == Message::String ? m->size() : 0;
  34. }
  35. template <typename Iterator>
  36. message_ptr make_message(Iterator begin, Iterator end, Message::Type type = Message::Binary,
  37. unsigned int stream = 0, shared_ptr<Reliability> reliability = nullptr) {
  38. auto message = std::make_shared<Message>(begin, end, type);
  39. message->stream = stream;
  40. message->reliability = reliability;
  41. return message;
  42. }
  43. template <typename Iterator>
  44. message_ptr make_message(Iterator begin, Iterator end, shared_ptr<FrameInfo> frameInfo) {
  45. auto message = std::make_shared<Message>(begin, end);
  46. message->frameInfo = frameInfo;
  47. return message;
  48. }
  49. // For backward compatibiity, do not use
  50. template <typename Iterator>
  51. [[deprecated]] message_ptr make_message(Iterator begin, Iterator end, Message::Type type,
  52. unsigned int stream, shared_ptr<FrameInfo> frameInfo) {
  53. auto message = std::make_shared<Message>(begin, end, type);
  54. message->stream = stream;
  55. message->frameInfo = frameInfo;
  56. return message;
  57. }
  58. RTC_CPP_EXPORT message_ptr make_message(size_t size, Message::Type type = Message::Binary,
  59. unsigned int stream = 0,
  60. shared_ptr<Reliability> reliability = nullptr);
  61. RTC_CPP_EXPORT message_ptr make_message(binary &&data, Message::Type type = Message::Binary,
  62. unsigned int stream = 0,
  63. shared_ptr<Reliability> reliability = nullptr);
  64. RTC_CPP_EXPORT message_ptr make_message(binary &&data, shared_ptr<FrameInfo> frameInfo);
  65. RTC_CPP_EXPORT message_ptr make_message(size_t size, message_ptr orig);
  66. RTC_CPP_EXPORT message_ptr make_message(message_variant data);
  67. #if RTC_ENABLE_MEDIA
  68. // Reconstructs a message_ptr from an opaque rtcMessage pointer that
  69. // was allocated by rtcCreateOpaqueMessage().
  70. message_ptr make_message_from_opaque_ptr(rtcMessage *&&message);
  71. #endif
  72. RTC_CPP_EXPORT message_variant to_variant(Message &&message);
  73. RTC_CPP_EXPORT message_variant to_variant(const Message &message);
  74. } // namespace rtc
  75. #endif