stately_files/
state.rs

1//! Application state for file management handlers.
2
3use serde::{Deserialize, Serialize};
4
5use crate::settings::Dirs;
6
7/// State extracted by file handlers to access directory configuration.
8///
9/// Use with axum's `FromRef` to extract from your application state:
10///
11/// ```rust,ignore
12/// use axum::extract::FromRef;
13/// use stately_files::state::FileState;
14///
15/// #[derive(Clone)]
16/// struct AppState {
17///     dirs: Dirs,
18///     // ... other fields
19/// }
20///
21/// impl FromRef<AppState> for FileState {
22///     fn from_ref(state: &AppState) -> Self {
23///         FileState { base: Some(state.dirs.clone()) }
24///     }
25/// }
26/// ```
27#[derive(Debug, Clone, PartialEq, Hash, Serialize, Deserialize)]
28pub struct FileState {
29    /// Optional directory configuration override.
30    /// If `None`, handlers use the global [`Dirs::get()`](crate::settings::Dirs::get) defaults.
31    #[serde(skip_serializing_if = "Option::is_none")]
32    pub base: Option<Dirs>,
33}
34
35impl FileState {
36    /// Creates a new `FileState` with custom directory configuration.
37    pub fn new(dirs: Dirs) -> Self { Self { base: Some(dirs) } }
38
39    /// Creates a `FileState` that uses global defaults.
40    pub fn default_dirs() -> Self { Self { base: None } }
41}
42
43impl Default for FileState {
44    fn default() -> Self { Self::default_dirs() }
45}