serialize.rs 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. use serde::Serialize;
  2. use base64::engine::general_purpose::STANDARD;
  3. use base64::Engine;
  4. #[allow(unused)]
  5. pub(crate) fn serde_to_writable<T: Serialize>(
  6. value: &T,
  7. write_to: &mut impl std::io::Write,
  8. ) -> Result<(), ciborium::ser::Error<std::io::Error>> {
  9. let mut serialized = Vec::new();
  10. ciborium::into_writer(value, &mut serialized)?;
  11. write_to.write_all(STANDARD.encode(serialized).as_bytes())?;
  12. Ok(())
  13. }
  14. #[cfg(feature = "ssr")]
  15. /// Encode data into a element. This is inteded to be used in the server to send data to the client.
  16. pub(crate) fn encode_props_in_element<T: Serialize>(
  17. data: &T,
  18. write_to: &mut impl std::io::Write,
  19. ) -> Result<(), ciborium::ser::Error<std::io::Error>> {
  20. write_to.write_all(
  21. r#"<meta hidden="true" id="dioxus-storage-props" data-serialized=""#.as_bytes(),
  22. )?;
  23. serde_to_writable(data, write_to)?;
  24. Ok(write_to.write_all(r#"" />"#.as_bytes())?)
  25. }
  26. #[cfg(feature = "ssr")]
  27. /// Encode data into a element. This is inteded to be used in the server to send data to the client.
  28. pub(crate) fn encode_in_element(
  29. data: &super::HTMLData,
  30. write_to: &mut impl std::io::Write,
  31. ) -> Result<(), ciborium::ser::Error<std::io::Error>> {
  32. write_to.write_all(
  33. r#"<meta hidden="true" id="dioxus-storage-data" data-serialized=""#.as_bytes(),
  34. )?;
  35. serde_to_writable(&data, write_to)?;
  36. Ok(write_to.write_all(r#"" />"#.as_bytes())?)
  37. }