use std::path::Path;
use typst::diag::{FileError, FileResult};
use wasm_bindgen::prelude::*;
use crate::{Bytes, PathAccessModel};
#[derive(Debug, Clone)]
pub struct ProxyAccessModel {
pub context: JsValue,
pub mtime_fn: js_sys::Function,
pub is_file_fn: js_sys::Function,
pub real_path_fn: js_sys::Function,
pub read_all_fn: js_sys::Function,
}
impl PathAccessModel for ProxyAccessModel {
fn content(&self, src: &Path) -> FileResult<Bytes> {
let is_file = self
.is_file_fn
.call1(&self.context, &src.to_string_lossy().as_ref().into())
.map(|v| v.as_bool().unwrap())
.map_err(|e| {
web_sys::console::error_3(
&"tinymist-vfs::ProxyAccessModel::is_file failure".into(),
&src.to_string_lossy().as_ref().into(),
&e,
);
FileError::AccessDenied
});
if !is_file? {
return Err(FileError::IsDirectory);
}
let data = self
.read_all_fn
.call1(&self.context, &src.to_string_lossy().as_ref().into())
.map_err(|e| {
web_sys::console::error_3(
&"tinymist-vfs::ProxyAccessModel::read_all failure".into(),
&src.to_string_lossy().as_ref().into(),
&e,
);
FileError::AccessDenied
})?;
let data = if let Some(data) = data.dyn_ref::<js_sys::Uint8Array>() {
Bytes::new(data.to_vec())
} else {
return Err(FileError::AccessDenied);
};
Ok(data)
}
}
unsafe impl Send for ProxyAccessModel {}
unsafe impl Sync for ProxyAccessModel {}