Decoder.cpp 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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(double& value)
  69. {
  70. m_stream >> value;
  71. return !m_stream.handle_any_error();
  72. }
  73. bool Decoder::decode(String& value)
  74. {
  75. i32 length = 0;
  76. m_stream >> length;
  77. if (m_stream.handle_any_error())
  78. return false;
  79. if (length < 0) {
  80. value = {};
  81. return true;
  82. }
  83. if (length == 0) {
  84. value = String::empty();
  85. return true;
  86. }
  87. char* text_buffer = nullptr;
  88. auto text_impl = StringImpl::create_uninitialized(static_cast<size_t>(length), text_buffer);
  89. m_stream >> Bytes { text_buffer, static_cast<size_t>(length) };
  90. value = *text_impl;
  91. return !m_stream.handle_any_error();
  92. }
  93. bool Decoder::decode(ByteBuffer& value)
  94. {
  95. i32 length = 0;
  96. m_stream >> length;
  97. if (m_stream.handle_any_error())
  98. return false;
  99. if (length < 0) {
  100. value = {};
  101. return true;
  102. }
  103. if (length == 0) {
  104. value = {};
  105. return true;
  106. }
  107. if (auto buffer_result = ByteBuffer::create_uninitialized(length); buffer_result.has_value())
  108. value = buffer_result.release_value();
  109. else
  110. return false;
  111. m_stream >> value.bytes();
  112. return !m_stream.handle_any_error();
  113. }
  114. bool Decoder::decode(URL& value)
  115. {
  116. String string;
  117. if (!decode(string))
  118. return false;
  119. value = URL(string);
  120. return true;
  121. }
  122. bool Decoder::decode(Dictionary& dictionary)
  123. {
  124. u64 size = 0;
  125. m_stream >> size;
  126. if (m_stream.handle_any_error())
  127. return false;
  128. if (size >= (size_t)NumericLimits<i32>::max()) {
  129. VERIFY_NOT_REACHED();
  130. }
  131. for (size_t i = 0; i < size; ++i) {
  132. String key;
  133. if (!decode(key))
  134. return false;
  135. String value;
  136. if (!decode(value))
  137. return false;
  138. dictionary.add(move(key), move(value));
  139. }
  140. return true;
  141. }
  142. bool Decoder::decode([[maybe_unused]] File& file)
  143. {
  144. #ifdef __serenity__
  145. int fd = recvfd(m_sockfd, O_CLOEXEC);
  146. if (fd < 0) {
  147. dbgln("recvfd: {}", strerror(errno));
  148. return false;
  149. }
  150. file = File(fd, File::ConstructWithReceivedFileDescriptor);
  151. return true;
  152. #else
  153. [[maybe_unused]] auto fd = m_sockfd;
  154. warnln("fd passing is not supported on this platform, sorry :(");
  155. return false;
  156. #endif
  157. }
  158. bool decode(Decoder& decoder, Core::AnonymousBuffer& buffer)
  159. {
  160. bool valid = false;
  161. if (!decoder.decode(valid))
  162. return false;
  163. if (!valid) {
  164. buffer = {};
  165. return true;
  166. }
  167. u32 size;
  168. if (!decoder.decode(size))
  169. return false;
  170. IPC::File anon_file;
  171. if (!decoder.decode(anon_file))
  172. return false;
  173. buffer = Core::AnonymousBuffer::create_from_anon_fd(anon_file.take_fd(), size);
  174. return buffer.is_valid();
  175. }
  176. bool decode(Decoder& decoder, Core::DateTime& datetime)
  177. {
  178. i64 timestamp = -1;
  179. if (!decoder.decode(timestamp))
  180. return false;
  181. datetime = Core::DateTime::from_timestamp(static_cast<time_t>(timestamp));
  182. return true;
  183. }
  184. }