use serde::{de::DeserializeOwned, Serialize};
use crate::error::BatchError;
pub trait ItemReader<R> {
fn read(&self) -> Option<Result<R, BatchError>>;
}
pub trait ItemProcessor<R, W> {
fn process<'a>(&'a self, item: &'a R) -> W;
}
pub trait ItemWriter<W> {
fn write(&self, items: &[W]) -> Result<(), BatchError>;
fn flush(&self) -> Result<(), BatchError> {
Ok(())
}
fn open(&self) -> Result<(), BatchError> {
Ok(())
}
fn close(&self) -> Result<(), BatchError> {
Ok(())
}
}
#[derive(Default)]
pub struct DefaultProcessor {}
impl<R: Serialize, W: DeserializeOwned> ItemProcessor<R, W> for DefaultProcessor {
fn process<'a>(&'a self, item: &'a R) -> W {
let serialised = serde_json::to_string(&item).unwrap();
serde_json::from_str(&serialised).unwrap()
}
}