deserialize.rs 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. use serde::de::DeserializeOwned;
  2. use base64::engine::general_purpose::STANDARD;
  3. use base64::Engine;
  4. use super::HTMLDataCursor;
  5. #[allow(unused)]
  6. pub(crate) fn serde_from_bytes<T: DeserializeOwned>(string: &[u8]) -> Option<T> {
  7. let decompressed = match STANDARD.decode(string) {
  8. Ok(bytes) => bytes,
  9. Err(err) => {
  10. tracing::error!("Failed to decode base64: {}", err);
  11. return None;
  12. }
  13. };
  14. match ciborium::from_reader(std::io::Cursor::new(decompressed)) {
  15. Ok(data) => Some(data),
  16. Err(err) => {
  17. tracing::error!("Failed to deserialize: {}", err);
  18. None
  19. }
  20. }
  21. }
  22. static SERVER_DATA: once_cell::sync::Lazy<Option<HTMLDataCursor>> =
  23. once_cell::sync::Lazy::new(|| {
  24. #[cfg(all(feature = "web", target_arch = "wasm32"))]
  25. {
  26. let window = web_sys::window()?.document()?;
  27. let element = match window.get_element_by_id("dioxus-storage-data") {
  28. Some(element) => element,
  29. None => {
  30. tracing::error!("Failed to get element by id: dioxus-storage-data");
  31. return None;
  32. }
  33. };
  34. let attribute = match element.get_attribute("data-serialized") {
  35. Some(attribute) => attribute,
  36. None => {
  37. tracing::error!("Failed to get attribute: data-serialized");
  38. return None;
  39. }
  40. };
  41. let data: super::HTMLData = serde_from_bytes(attribute.as_bytes())?;
  42. Some(data.cursor())
  43. }
  44. #[cfg(not(all(feature = "web", target_arch = "wasm32")))]
  45. {
  46. None
  47. }
  48. });
  49. pub(crate) fn take_server_data<T: DeserializeOwned>() -> Option<T> {
  50. SERVER_DATA.as_ref()?.take()
  51. }