Struct FileSource
pub struct FileSource<T, const REQUIRED: bool = true>(/* private fields */);Expand description
Specifies a configuration source that reads from a file and deserializes it into a type, T.
§Example
use cipherstash_client::config::{
CipherStashConfigFile,
FileSource,
ZeroKMSConfigBuilder
};
let source = FileSource::<CipherStashConfigFile>::default();
let client = ZeroKMSConfigBuilder::default()
.add_source(source)
.build();§Optional files
Normally, if the file is not found, the source will return an error. You can mark the source as optional to ignore the error.
let source = FileSource::<CipherStashConfigFile>::default().optional();
let client = ZeroKMSConfigBuilder::default()
.add_source(source)
.build();Alternatively, you can specify that a file is required using the REQUIRED type parameter:
let source = FileSource::<CipherStashConfigFile, true>::default();§Specifying a path
By default, the file is loaded from the current working directory.
You can specify the directory path with the with_path method.
You can chain the optional method to mark the source as optional.
// Load the file from `some/place/cipherstash.toml`
// Ignore if the file is not found
let source = FileSource::<CipherStashConfigFile>::default()
.with_path("some/place")
.optional();
let client = ZeroKMSConfigBuilder::default()
.add_source(source)
.build();§Specifying a filename
You can also specify the filename to use with the with_filename method.
// Load the file from `some/place/myconfig.toml`
let source = FileSource::<CipherStashConfigFile>::default()
.with_filename("myconfig.toml");§Built in file sources
The following built-in file sources are available:
- [CipherStashConfigFile]: Loads the
cipherstash.tomlfile. - [CipherStashSecretConfigFile]: Loads the
cipherstash_secret.tomlfile. - [LocalConfigSource]: Loads the
config.tomlfile normally found in~/.cipherstash/.
See [CipherStashConfigFile] and [CipherStashSecretConfigFile] for details on the configuration files.
§Custom file sources
To create a custom file source, implement the IntoFileSource trait.
use cipherstash_client::config::{IntoFileSource, FileSource};
use std::path::PathBuf;
use cts_common::Crn;
use serde::{Deserialize, Serialize};
#[derive(Debug, Serialize, Deserialize)]
pub struct MyConfig {
workspace_crn: Crn,
}
impl IntoFileSource for MyConfig {
fn default_path() -> PathBuf {
PathBuf::from("~/.cipherstash/")
}
fn filename() -> String {
"myconfig.toml".to_string()
}
}
// The `ConfigSource` trait must also be implemented for any builder type you want to use.
use cipherstash_client::config::{ConfigError, ConfigSource, ZeroKMSConfigBuilder};
impl ConfigSource<ZeroKMSConfigBuilder> for MyConfig {
fn add_to_builder(&self, builder: ZeroKMSConfigBuilder) -> Result<ZeroKMSConfigBuilder, ConfigError> {
Ok(builder.workspace_crn(self.workspace_crn.clone()))
}
}Implementations§
§impl<T, const REQUIRED: bool> FileSource<T, REQUIRED>where
T: IntoFileSource,
impl<T, const REQUIRED: bool> FileSource<T, REQUIRED>where
T: IntoFileSource,
pub fn save(&self, value: T) -> Result<(), ConfigError>where
T: Serialize,
pub fn with_path(self, path: impl Into<PathBuf>) -> Self
pub fn with_path(self, path: impl Into<PathBuf>) -> Self
Specify the path of the file to load instead of the one returned via IntoFileSource::default_path.
§Example
use cipherstash_client::config::{FileSource, UserConfigSource};
FileSource::<UserConfigSource>::default()
.with_path("some_dir/myconfig.toml");pub fn with_path_opt(self, path: Option<impl Into<PathBuf>>) -> Self
pub fn with_path_opt(self, path: Option<impl Into<PathBuf>>) -> Self
Like Self::with_path, but allows the path to be optional.
pub fn with_filename(self, filename: impl Into<String>) -> Self
§impl<T> FileSource<T, true>
impl<T> FileSource<T, true>
pub fn load(&self) -> Result<T, ConfigError>where
T: IntoFileSource + DeserializeOwned,
pub fn optional(self) -> FileSource<T, false>
pub fn optional(self) -> FileSource<T, false>
Converts the source to an optional source.
§impl<T> FileSource<T, false>
impl<T> FileSource<T, false>
pub fn load_opt(&self) -> Result<Option<T>, ConfigError>where
T: IntoFileSource + DeserializeOwned,
pub fn required(self) -> FileSource<T, true>
pub fn required(self) -> FileSource<T, true>
Converts the source to a required source.
Trait Implementations§
§impl<B, T> ConfigSource<B> for FileSource<T, true>
impl<B, T> ConfigSource<B> for FileSource<T, true>
fn add_to_builder(&self, builder: B) -> Result<B, ConfigError>
§impl<B, T> ConfigSource<B> for FileSource<T, false>
impl<B, T> ConfigSource<B> for FileSource<T, false>
fn add_to_builder(&self, builder: B) -> Result<B, ConfigError>
§impl<T: Debug, const REQUIRED: bool> Debug for FileSource<T, REQUIRED>
impl<T: Debug, const REQUIRED: bool> Debug for FileSource<T, REQUIRED>
Auto Trait Implementations§
impl<T, const REQUIRED: bool> Freeze for FileSource<T, REQUIRED>
impl<T, const REQUIRED: bool> RefUnwindSafe for FileSource<T, REQUIRED>where
T: RefUnwindSafe,
impl<T, const REQUIRED: bool> Send for FileSource<T, REQUIRED>where
T: Send,
impl<T, const REQUIRED: bool> Sync for FileSource<T, REQUIRED>where
T: Sync,
impl<T, const REQUIRED: bool> Unpin for FileSource<T, REQUIRED>where
T: Unpin,
impl<T, const REQUIRED: bool> UnwindSafe for FileSource<T, REQUIRED>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoSql for T
impl<T> IntoSql for T
Source§fn into_sql<T>(self) -> Self::Expression
fn into_sql<T>(self) -> Self::Expression
self to an expression for Diesel’s query builder. Read moreSource§fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
&self to an expression for Diesel’s query builder. Read moreSource§impl<D> OwoColorize for D
impl<D> OwoColorize for D
Source§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
Source§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
Source§fn black(&self) -> FgColorDisplay<'_, Black, Self>
fn black(&self) -> FgColorDisplay<'_, Black, Self>
Source§fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
fn on_black(&self) -> BgColorDisplay<'_, Black, Self>
Source§fn red(&self) -> FgColorDisplay<'_, Red, Self>
fn red(&self) -> FgColorDisplay<'_, Red, Self>
Source§fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
fn on_red(&self) -> BgColorDisplay<'_, Red, Self>
Source§fn green(&self) -> FgColorDisplay<'_, Green, Self>
fn green(&self) -> FgColorDisplay<'_, Green, Self>
Source§fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
fn on_green(&self) -> BgColorDisplay<'_, Green, Self>
Source§fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
fn yellow(&self) -> FgColorDisplay<'_, Yellow, Self>
Source§fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
fn on_yellow(&self) -> BgColorDisplay<'_, Yellow, Self>
Source§fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
fn blue(&self) -> FgColorDisplay<'_, Blue, Self>
Source§fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
fn on_blue(&self) -> BgColorDisplay<'_, Blue, Self>
Source§fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
fn magenta(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
fn purple(&self) -> FgColorDisplay<'_, Magenta, Self>
Source§fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_purple(&self) -> BgColorDisplay<'_, Magenta, Self>
Source§fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
fn cyan(&self) -> FgColorDisplay<'_, Cyan, Self>
Source§fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
fn on_cyan(&self) -> BgColorDisplay<'_, Cyan, Self>
Source§fn white(&self) -> FgColorDisplay<'_, White, Self>
fn white(&self) -> FgColorDisplay<'_, White, Self>
Source§fn on_white(&self) -> BgColorDisplay<'_, White, Self>
fn on_white(&self) -> BgColorDisplay<'_, White, Self>
Source§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
Source§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
Source§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
Source§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
Source§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
Source§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
Source§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
Source§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
Source§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
Source§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
Source§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
Source§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
Source§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
Source§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
Source§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
Source§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
Source§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
Source§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
Source§fn bold(&self) -> BoldDisplay<'_, Self>
fn bold(&self) -> BoldDisplay<'_, Self>
Source§fn dimmed(&self) -> DimDisplay<'_, Self>
fn dimmed(&self) -> DimDisplay<'_, Self>
Source§fn italic(&self) -> ItalicDisplay<'_, Self>
fn italic(&self) -> ItalicDisplay<'_, Self>
Source§fn underline(&self) -> UnderlineDisplay<'_, Self>
fn underline(&self) -> UnderlineDisplay<'_, Self>
Source§fn blink(&self) -> BlinkDisplay<'_, Self>
fn blink(&self) -> BlinkDisplay<'_, Self>
Source§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
Source§fn reversed(&self) -> ReversedDisplay<'_, Self>
fn reversed(&self) -> ReversedDisplay<'_, Self>
Source§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
Source§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg or
a color-specific method, such as OwoColorize::green, Read moreSource§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg or
a color-specific method, such as OwoColorize::on_yellow, Read more