summaryrefslogtreecommitdiffstats
path: root/src/sse.rs
diff options
context:
space:
mode:
authorToby Vincent <tobyv@tobyvin.dev>2024-09-28 00:54:46 -0500
committerToby Vincent <tobyv@tobyvin.dev>2024-09-28 00:58:45 -0500
commitcd774827dd14f68d8405c45d2d9da30b3fab050e (patch)
treea24e1cabb99170caa25edff53fc978111a1c9dd4 /src/sse.rs
parent04c7f7609e5bc3fadf95c53b37a9e6e12c4e539c (diff)
feat: refactor into pub-sub and impl SSE
Diffstat (limited to 'src/sse.rs')
-rw-r--r--src/sse.rs30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/sse.rs b/src/sse.rs
new file mode 100644
index 0000000..b4a8840
--- /dev/null
+++ b/src/sse.rs
@@ -0,0 +1,30 @@
+use axum::{
+ extract::{Path, State},
+ response::{
+ sse::{Event, KeepAlive},
+ Sse,
+ },
+ routing::get,
+ Router,
+};
+use futures::Stream;
+use tokio_stream::StreamExt;
+
+use crate::{service::ServiceHandles, Error};
+
+pub fn router() -> Router<ServiceHandles> {
+ axum::Router::new().route("/:name", get(sse_handler))
+}
+
+pub async fn sse_handler(
+ Path(name): Path<String>,
+ State(services): State<ServiceHandles>,
+) -> Result<Sse<impl Stream<Item = Result<Event, axum::Error>>>, Error> {
+ let stream = services
+ .get(&name)
+ .ok_or_else(|| Error::ServiceNotFound(name))?
+ .into_stream()
+ .map(|s| Event::default().json_data(s));
+
+ Ok(Sse::new(stream).keep_alive(KeepAlive::default()))
+}