mirror of
https://github.com/tokio-rs/axum.git
synced 2025-01-01 08:56:15 +01:00
Add shared mutable state documentation (#1759)
Co-authored-by: Vagelis Prokopiou <vagelis.prokopiou@gmail.com> Co-authored-by: Jonas Platte <jplatte+git@posteo.de> Co-authored-by: David Pedersen <david.pdrsn@gmail.com>
This commit is contained in:
parent
fa36b49769
commit
1f224396a2
1 changed files with 43 additions and 0 deletions
|
@ -295,6 +295,49 @@ use std::{
|
|||
///
|
||||
/// In general however we recommend you implement `Clone` for all your state types to avoid
|
||||
/// potential type errors.
|
||||
///
|
||||
/// # Shared mutable state
|
||||
///
|
||||
/// [As state is global within a `Router`][global] you can't directly get a mutable reference to
|
||||
/// the state.
|
||||
///
|
||||
/// The most basic solution is to use an `Arc<Mutex<_>>`. Which kind of mutex you need depends on
|
||||
/// your use case. See [the tokio docs] for more details.
|
||||
///
|
||||
/// Note that holding a locked `std::sync::Mutex` across `.await` points will result in `!Send`
|
||||
/// futures which are incompatible with axum. If you need to hold a mutex across `.await` points,
|
||||
/// consider using a `tokio::sync::Mutex` instead.
|
||||
///
|
||||
/// ## Example
|
||||
///
|
||||
/// ```
|
||||
/// use axum::{Router, routing::get, extract::State};
|
||||
/// use std::sync::{Arc, Mutex};
|
||||
///
|
||||
/// #[derive(Clone)]
|
||||
/// struct AppState {
|
||||
/// data: Arc<Mutex<String>>,
|
||||
/// }
|
||||
///
|
||||
/// async fn handler(State(state): State<AppState>) {
|
||||
/// let mut data = state.data.lock().expect("mutex was poisoned");
|
||||
/// *data = "updated foo".to_owned();
|
||||
///
|
||||
/// // ...
|
||||
/// }
|
||||
///
|
||||
/// let state = AppState {
|
||||
/// data: Arc::new(Mutex::new("foo".to_owned())),
|
||||
/// };
|
||||
///
|
||||
/// let app = Router::new()
|
||||
/// .route("/", get(handler))
|
||||
/// .with_state(state);
|
||||
/// # let _: Router = app;
|
||||
/// ```
|
||||
///
|
||||
/// [global]: crate::Router::with_state
|
||||
/// [the tokio docs]: https://docs.rs/tokio/1.25.0/tokio/sync/struct.Mutex.html#which-kind-of-mutex-should-you-use
|
||||
#[derive(Debug, Default, Clone, Copy)]
|
||||
pub struct State<S>(pub S);
|
||||
|
||||
|
|
Loading…
Reference in a new issue