StructuredSerialize.h 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * Copyright (c) 2022, Daniel Ehrenberg <dan@littledan.dev>
  3. * Copyright (c) 2022, Andrew Kaster <akaster@serenityos.org>
  4. * Copyright (c) 2024, Kenneth Myhra <kennethmyhra@serenityos.org>
  5. *
  6. * SPDX-License-Identifier: BSD-2-Clause
  7. */
  8. #pragma once
  9. #include <AK/Result.h>
  10. #include <AK/Types.h>
  11. #include <AK/Vector.h>
  12. #include <LibIPC/Forward.h>
  13. #include <LibJS/Forward.h>
  14. #include <LibJS/Runtime/DataView.h>
  15. #include <LibJS/Runtime/TypedArray.h>
  16. #include <LibWeb/WebIDL/ExceptionOr.h>
  17. // Structured serialize is an entirely different format from IPC because:
  18. // - It contains representation of type information
  19. // - It may contain circularities
  20. // - It is restricted to JS values
  21. namespace Web::HTML {
  22. using SerializationRecord = Vector<u32>;
  23. using SerializationMemory = HashMap<JS::Handle<JS::Value>, u32>;
  24. using DeserializationMemory = JS::MarkedVector<JS::Value>;
  25. struct TransferDataHolder {
  26. Vector<u8> data;
  27. Vector<IPC::File> fds;
  28. };
  29. struct SerializedTransferRecord {
  30. SerializationRecord serialized;
  31. Vector<TransferDataHolder> transfer_data_holders;
  32. };
  33. struct DeserializedTransferRecord {
  34. JS::Value deserialized;
  35. Vector<JS::Handle<JS::Object>> transferred_values;
  36. };
  37. enum class TransferType : u8 {
  38. MessagePort,
  39. };
  40. WebIDL::ExceptionOr<SerializationRecord> structured_serialize(JS::VM& vm, JS::Value);
  41. WebIDL::ExceptionOr<SerializationRecord> structured_serialize_for_storage(JS::VM& vm, JS::Value);
  42. WebIDL::ExceptionOr<SerializationRecord> structured_serialize_internal(JS::VM& vm, JS::Value, bool for_storage, SerializationMemory&);
  43. WebIDL::ExceptionOr<JS::Value> structured_deserialize(JS::VM& vm, SerializationRecord const& serialized, JS::Realm& target_realm, Optional<DeserializationMemory>);
  44. WebIDL::ExceptionOr<void> serialize_bytes(JS::VM& vm, Vector<u32>& vector, ReadonlyBytes bytes);
  45. WebIDL::ExceptionOr<void> serialize_string(JS::VM& vm, Vector<u32>& vector, DeprecatedFlyString const& string);
  46. WebIDL::ExceptionOr<void> serialize_string(JS::VM& vm, Vector<u32>& vector, String const& string);
  47. WebIDL::ExceptionOr<void> serialize_string(JS::VM& vm, Vector<u32>& vector, JS::PrimitiveString const& primitive_string);
  48. WebIDL::ExceptionOr<void> serialize_array_buffer(JS::VM& vm, Vector<u32>& vector, JS::ArrayBuffer const& array_buffer, bool for_storage);
  49. template<OneOf<JS::TypedArrayBase, JS::DataView> ViewType>
  50. WebIDL::ExceptionOr<void> serialize_viewed_array_buffer(JS::VM& vm, Vector<u32>& vector, ViewType const& view, bool for_storage, SerializationMemory& memory);
  51. WebIDL::ExceptionOr<ByteBuffer> deserialize_bytes(JS::VM& vm, ReadonlySpan<u32> vector, size_t& position);
  52. WebIDL::ExceptionOr<String> deserialize_string(JS::VM& vm, ReadonlySpan<u32> vector, size_t& position);
  53. WebIDL::ExceptionOr<JS::NonnullGCPtr<JS::PrimitiveString>> deserialize_string_primitive(JS::VM& vm, ReadonlySpan<u32> vector, size_t& position);
  54. WebIDL::ExceptionOr<JS::NonnullGCPtr<JS::BigInt>> deserialize_big_int_primitive(JS::VM& vm, ReadonlySpan<u32> vector, size_t& position);
  55. WebIDL::ExceptionOr<SerializedTransferRecord> structured_serialize_with_transfer(JS::VM& vm, JS::Value value, Vector<JS::Handle<JS::Object>> const& transfer_list);
  56. WebIDL::ExceptionOr<DeserializedTransferRecord> structured_deserialize_with_transfer(JS::VM& vm, SerializedTransferRecord&);
  57. }
  58. namespace IPC {
  59. template<>
  60. ErrorOr<void> encode(Encoder&, ::Web::HTML::SerializedTransferRecord const&);
  61. template<>
  62. ErrorOr<void> encode(Encoder&, ::Web::HTML::TransferDataHolder const&);
  63. template<>
  64. ErrorOr<::Web::HTML::SerializedTransferRecord> decode(Decoder&);
  65. template<>
  66. ErrorOr<::Web::HTML::TransferDataHolder> decode(Decoder&);
  67. }