Decoder.cpp 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. /*
  2. * Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <AK/MemoryStream.h>
  7. #include <AK/URL.h>
  8. #include <LibCore/AnonymousBuffer.h>
  9. #include <LibCore/DateTime.h>
  10. #include <LibIPC/Decoder.h>
  11. #include <LibIPC/Dictionary.h>
  12. #include <LibIPC/File.h>
  13. #include <errno.h>
  14. #include <fcntl.h>
  15. #include <string.h>
  16. #include <sys/socket.h>
  17. namespace IPC {
  18. bool Decoder::decode(bool& value)
  19. {
  20. m_stream >> value;
  21. return !m_stream.handle_any_error();
  22. }
  23. bool Decoder::decode(u8& value)
  24. {
  25. m_stream >> value;
  26. return !m_stream.handle_any_error();
  27. }
  28. bool Decoder::decode(u16& value)
  29. {
  30. m_stream >> value;
  31. return !m_stream.handle_any_error();
  32. }
  33. bool Decoder::decode(u32& value)
  34. {
  35. m_stream >> value;
  36. return !m_stream.handle_any_error();
  37. }
  38. bool Decoder::decode(u64& value)
  39. {
  40. m_stream >> value;
  41. return !m_stream.handle_any_error();
  42. }
  43. bool Decoder::decode(i8& value)
  44. {
  45. m_stream >> value;
  46. return !m_stream.handle_any_error();
  47. }
  48. bool Decoder::decode(i16& value)
  49. {
  50. m_stream >> value;
  51. return !m_stream.handle_any_error();
  52. }
  53. bool Decoder::decode(i32& value)
  54. {
  55. m_stream >> value;
  56. return !m_stream.handle_any_error();
  57. }
  58. bool Decoder::decode(i64& value)
  59. {
  60. m_stream >> value;
  61. return !m_stream.handle_any_error();
  62. }
  63. bool Decoder::decode(float& value)
  64. {
  65. m_stream >> value;
  66. return !m_stream.handle_any_error();
  67. }
  68. bool Decoder::decode(String& value)
  69. {
  70. i32 length = 0;
  71. m_stream >> length;
  72. if (m_stream.handle_any_error())
  73. return false;
  74. if (length < 0) {
  75. value = {};
  76. return true;
  77. }
  78. if (length == 0) {
  79. value = String::empty();
  80. return true;
  81. }
  82. char* text_buffer = nullptr;
  83. auto text_impl = StringImpl::create_uninitialized(static_cast<size_t>(length), text_buffer);
  84. m_stream >> Bytes { text_buffer, static_cast<size_t>(length) };
  85. value = *text_impl;
  86. return !m_stream.handle_any_error();
  87. }
  88. bool Decoder::decode(ByteBuffer& value)
  89. {
  90. i32 length = 0;
  91. m_stream >> length;
  92. if (m_stream.handle_any_error())
  93. return false;
  94. if (length < 0) {
  95. value = {};
  96. return true;
  97. }
  98. if (length == 0) {
  99. value = {};
  100. return true;
  101. }
  102. if (auto buffer_result = ByteBuffer::create_uninitialized(length); buffer_result.has_value())
  103. value = buffer_result.release_value();
  104. else
  105. return false;
  106. m_stream >> value.bytes();
  107. return !m_stream.handle_any_error();
  108. }
  109. bool Decoder::decode(URL& value)
  110. {
  111. String string;
  112. if (!decode(string))
  113. return false;
  114. value = URL(string);
  115. return true;
  116. }
  117. bool Decoder::decode(Dictionary& dictionary)
  118. {
  119. u64 size = 0;
  120. m_stream >> size;
  121. if (m_stream.handle_any_error())
  122. return false;
  123. if (size >= (size_t)NumericLimits<i32>::max()) {
  124. VERIFY_NOT_REACHED();
  125. }
  126. for (size_t i = 0; i < size; ++i) {
  127. String key;
  128. if (!decode(key))
  129. return false;
  130. String value;
  131. if (!decode(value))
  132. return false;
  133. dictionary.add(move(key), move(value));
  134. }
  135. return true;
  136. }
  137. bool Decoder::decode([[maybe_unused]] File& file)
  138. {
  139. #ifdef __serenity__
  140. int fd = recvfd(m_sockfd, O_CLOEXEC);
  141. if (fd < 0) {
  142. dbgln("recvfd: {}", strerror(errno));
  143. return false;
  144. }
  145. file = File(fd, File::ConstructWithReceivedFileDescriptor);
  146. return true;
  147. #else
  148. [[maybe_unused]] auto fd = m_sockfd;
  149. warnln("fd passing is not supported on this platform, sorry :(");
  150. return false;
  151. #endif
  152. }
  153. bool decode(Decoder& decoder, Core::AnonymousBuffer& buffer)
  154. {
  155. bool valid = false;
  156. if (!decoder.decode(valid))
  157. return false;
  158. if (!valid) {
  159. buffer = {};
  160. return true;
  161. }
  162. u32 size;
  163. if (!decoder.decode(size))
  164. return false;
  165. IPC::File anon_file;
  166. if (!decoder.decode(anon_file))
  167. return false;
  168. buffer = Core::AnonymousBuffer::create_from_anon_fd(anon_file.take_fd(), size);
  169. return buffer.is_valid();
  170. }
  171. bool decode(Decoder& decoder, Core::DateTime& datetime)
  172. {
  173. i64 timestamp = -1;
  174. if (!decoder.decode(timestamp))
  175. return false;
  176. datetime = Core::DateTime::from_timestamp(static_cast<time_t>(timestamp));
  177. return true;
  178. }
  179. }