Skip to content

Commit

Permalink
fix invalidation example?
Browse files Browse the repository at this point in the history
  • Loading branch information
oscartbeaumont committed Jul 17, 2024
1 parent 1458dc3 commit d7fc65c
Showing 1 changed file with 21 additions and 11 deletions.
32 changes: 21 additions & 11 deletions examples/axum/src/api/invalidation.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@
use std::{
collections::HashMap,
future::Future,
sync::{Arc, Mutex, PoisonError},
};

use async_stream::stream;
use futures::Stream;

Check failure on line 11 in examples/axum/src/api/invalidation.rs

View workflow job for this annotation

GitHub Actions / Clippy

unresolved import `futures`

error[E0432]: unresolved import `futures` --> examples/axum/src/api/invalidation.rs:11:5 | 11 | use futures::Stream; | ^^^^^^^ use of undeclared crate or module `futures`
use rspc::middleware::Middleware;
use serde::{Deserialize, Serialize};
use specta::Type;
Expand Down Expand Up @@ -47,11 +47,12 @@ pub fn mount() -> Router {
.procedure("get", {
<BaseProcedure>::builder()
// TODO: Why does `TCtx` need a hardcoded type???
.with(invalidation(|ctx: Context, key, _result| async move {
ctx.invalidation
.tx
.send(InvalidateEvent::InvalidateKey(key))
.unwrap();
.with(invalidation(|ctx: Context, key, event| {
if let InvalidateEvent::InvalidateKey(k) = event {
k == key
} else {
false
}
}))
.mutation(|ctx, key: String| async move {
let value = ctx
Expand All @@ -71,7 +72,13 @@ pub fn mount() -> Router {
.keys
.lock()
.unwrap_or_else(PoisonError::into_inner)
.insert(input.key, input.value);
.insert(input.key.clone(), input.value);

// This will trigger invalidation
ctx.invalidation
.tx
.send(InvalidateEvent::InvalidateKey(input.key))
.unwrap();

Ok(())
})
Expand All @@ -82,31 +89,34 @@ pub fn mount() -> Router {
Ok(stream! {
let mut tx = ctx.invalidation.tx.subscribe();
while let Ok(msg) = tx.recv().await {
// TODO: Run all the invalidation closures currently on `TCtx` to map the msg into a list of query keys to invalidate.

yield Ok(msg);
}
})
})
})
}

fn invalidation<TError, TCtx, TInput, TResult, F>(
handler: impl Fn(TCtx, TInput, &Result<TResult, TError>) -> F + Send + Sync + 'static,
fn invalidation<TError, TCtx, TInput, TResult>(
handler: impl Fn(TCtx, TInput, InvalidateEvent) -> bool + Send + Sync + 'static,
) -> Middleware<TError, TCtx, TInput, TResult>
where
TError: Send + 'static,
TCtx: Clone + Send + 'static,
TInput: Clone + Send + 'static,
TResult: Send + 'static,
F: Future<Output = ()> + Send + 'static,
{
let handler = Arc::new(handler);
Middleware::new(move |ctx: TCtx, input: TInput, next| {
let handler = handler.clone();
async move {
// TODO: Register this with `TCtx`
let ctx2 = ctx.clone();
let input2 = input.clone();
let result = next.exec(ctx, input).await;
handler(ctx2, input2, &result).await;

// TODO: Unregister this with `TCtx`
result
}
})
Expand Down

0 comments on commit d7fc65c

Please sign in to comment.