From 6b1d06e8af908175803060fedd9d1b7be9c92a40 Mon Sep 17 00:00:00 2001 From: metamuffin Date: Tue, 26 Nov 2024 17:28:27 +0100 Subject: inspect node for debugging --- src/modules/inspect.rs | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 src/modules/inspect.rs (limited to 'src/modules/inspect.rs') diff --git a/src/modules/inspect.rs b/src/modules/inspect.rs new file mode 100644 index 0000000..1ad6522 --- /dev/null +++ b/src/modules/inspect.rs @@ -0,0 +1,42 @@ +use super::{Node, NodeContext, NodeKind, NodeRequest, NodeResponse}; +use crate::{config::DynNode, error::ServiceError}; +use anyhow::Result; +use futures::Future; +use log::debug; +use serde::Deserialize; +use std::{pin::Pin, sync::Arc}; + +pub struct InspectKind; + +#[derive(Deserialize)] +pub struct Inspect { + next: DynNode, +} + +impl NodeKind for InspectKind { + fn name(&self) -> &'static str { + "inspect" + } + fn instanciate(&self, config: serde_yml::Value) -> Result> { + Ok(Arc::new(serde_yml::from_value::(config)?)) + } +} + +impl Node for Inspect { + fn handle<'a>( + &'a self, + context: &'a mut NodeContext, + request: NodeRequest, + ) -> Pin> + Send + Sync + 'a>> { + Box::pin(async move { + debug!( + "address: {:?}\nversion: {:?}\nuri: {:?}\nheaders: {:#?}", + context.addr, + request.version(), + request.uri(), + request.headers(), + ); + Ok(self.next.handle(context, request).await?) + }) + } +} -- cgit v1.2.3-70-g09d2