2023-08-27 16:49:53 +02:00
|
|
|
use capnp::message::{Builder, HeapAllocator};
|
|
|
|
use capnp::message::{ReaderOptions, TypedReader};
|
2023-08-27 18:15:25 +02:00
|
|
|
use capnp::serialize::{self, OwnedSegments, SliceSegments};
|
2023-08-27 16:49:53 +02:00
|
|
|
|
|
|
|
use capnp::traits::{FromPointerReader, Owned};
|
|
|
|
use churn_domain::LogEvent;
|
|
|
|
|
|
|
|
mod models_capnp;
|
|
|
|
|
|
|
|
pub trait CapnpPackExt {
|
|
|
|
type Return;
|
|
|
|
|
2023-08-27 18:15:25 +02:00
|
|
|
fn serialize_capnp(&self) -> Vec<u8>;
|
|
|
|
fn deserialize_capnp(content: &Vec<u8>) -> anyhow::Result<Self::Return>;
|
2023-08-27 16:49:53 +02:00
|
|
|
|
2023-08-27 18:15:25 +02:00
|
|
|
fn capnp_to_string(builder: &Builder<HeapAllocator>) -> Vec<u8> {
|
2023-08-27 16:49:53 +02:00
|
|
|
let msg = serialize::write_message_to_words(builder);
|
2023-08-27 18:15:25 +02:00
|
|
|
msg
|
2023-08-27 16:49:53 +02:00
|
|
|
}
|
|
|
|
|
2023-08-27 18:15:25 +02:00
|
|
|
fn string_to_capnp<'a, S>(content: &'a Vec<u8>) -> TypedReader<SliceSegments, S>
|
2023-08-27 16:49:53 +02:00
|
|
|
where
|
|
|
|
S: Owned,
|
|
|
|
{
|
2023-08-27 18:15:25 +02:00
|
|
|
let log_event =
|
|
|
|
serialize::read_message_from_flat_slice(&mut content.as_slice(), ReaderOptions::new())
|
|
|
|
.unwrap();
|
2023-08-27 16:49:53 +02:00
|
|
|
|
|
|
|
let log_event = log_event.into_typed::<S>();
|
|
|
|
|
|
|
|
log_event
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl CapnpPackExt for LogEvent {
|
|
|
|
type Return = Self;
|
|
|
|
|
2023-08-27 18:15:25 +02:00
|
|
|
fn serialize_capnp(&self) -> Vec<u8> {
|
2023-08-27 16:49:53 +02:00
|
|
|
let mut builder = Builder::new_default();
|
|
|
|
|
|
|
|
let mut log_event = builder.init_root::<models_capnp::log_event::Builder>();
|
|
|
|
log_event.set_id(&self.id.to_string());
|
|
|
|
log_event.set_author(&self.author);
|
|
|
|
log_event.set_content(&self.content);
|
2023-08-27 18:15:25 +02:00
|
|
|
log_event.set_datetime(self.timestamp.timestamp());
|
2023-08-27 16:49:53 +02:00
|
|
|
|
|
|
|
Self::capnp_to_string(&builder)
|
|
|
|
}
|
|
|
|
|
2023-08-27 18:15:25 +02:00
|
|
|
fn deserialize_capnp(content: &Vec<u8>) -> anyhow::Result<Self> {
|
2023-08-27 16:49:53 +02:00
|
|
|
let log_event = Self::string_to_capnp::<models_capnp::log_event::Owned>(content);
|
|
|
|
let log_event = log_event.get()?;
|
|
|
|
|
|
|
|
Ok(Self {
|
|
|
|
id: uuid::Uuid::parse_str(log_event.get_id()?)?,
|
|
|
|
author: log_event.get_author()?.into(),
|
|
|
|
content: log_event.get_content()?.into(),
|
2023-08-27 18:15:25 +02:00
|
|
|
timestamp: chrono::DateTime::<chrono::Utc>::from_utc(
|
|
|
|
chrono::NaiveDateTime::from_timestamp_opt(log_event.get_datetime(), 0).unwrap(),
|
|
|
|
chrono::Utc,
|
|
|
|
),
|
2023-08-27 16:49:53 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|