Struct ZeroKMSConfig
pub struct ZeroKMSConfig<ClientKeyState = ()> { /* private fields */ }Expand description
Configuration for the ZeroKMS client library.
The ClientKeyState generic is used to specify whether the config has a client key or not. If
the client doesn’t have a ClientKey it can’t be used to encrypt or decrypt data.
use cipherstash_client::config::EnvSource;
let config = ZeroKMSConfig::builder()
.add_source(EnvSource::default())
.build()
.expect("failed to build config");
let client = config.create_client();Implementations§
§impl ZeroKMSConfig
impl ZeroKMSConfig
pub fn builder() -> ZeroKMSConfigBuilder
pub fn builder() -> ZeroKMSConfigBuilder
Create a new ZeroKMSConfigBuilder to build a ZeroKMS used to configure
access to ZeroKMS.
use cipherstash_client::{ZeroKMSConfig, config::EnvSource};
let config = ZeroKMSConfig::builder()
.add_source(EnvSource::default())
.build()
.expect("failed to build config");
let client = config.create_client();In situations where a ClientKey has been configured in the environment. You can use
ZeroKMSConfigBuilder::build_with_client_key.
use cipherstash_client::config::EnvSource;
let config = ZeroKMSConfig::builder()
.add_source(EnvSource::default())
.build_with_client_key()
.expect("failed to build config");
let client = config.create_client();pub fn clone_with_client_key(
&self,
client_key: ClientKey,
) -> ZeroKMSConfigWithClientKey
pub fn clone_with_client_key( &self, client_key: ClientKey, ) -> ZeroKMSConfigWithClientKey
pub fn create_client_with_credentials<C>(&self, credentials: C) -> ZeroKMS<C>where
C: Credentials<Token = ServiceToken>,
pub fn create_client_with_credentials<C>(&self, credentials: C) -> ZeroKMS<C>where
C: Credentials<Token = ServiceToken>,
Create a new ZeroKMS client instance with the provided credentials.
§Manually specifying a Service Token
use cipherstash_client::{ZeroKMSConfig, config::EnvSource};
use cipherstash_client::credentials::{ServiceToken, StaticCredentials};
// A service token returned by CTS federation
let token = ServiceToken::new("my-token", 100);
let config = ZeroKMSConfig::builder()
.add_source(EnvSource::default())
.build()
.expect("failed to build config")
.create_client_with_credentials(StaticCredentials::new(token));pub fn create_client(&self) -> ZeroKMS<ServiceCredentials>
pub fn create_client(&self) -> ZeroKMS<ServiceCredentials>
Create a new ZeroKMS client instance without a client key.
In order to encrypt and decrypt data use ZeroKMS<ClientKey>.
§impl ZeroKMSConfig<ClientKey>
impl ZeroKMSConfig<ClientKey>
pub fn create_client(&self) -> ZeroKMSWithClientKey<ServiceCredentials>
pub fn create_client(&self) -> ZeroKMSWithClientKey<ServiceCredentials>
Create a new ZeroKMS client instance that can be used for encryption and decryption.
pub fn create_client_with_credentials<C>(
&self,
credentials: C,
) -> ZeroKMSWithClientKey<C>where
C: Credentials<Token = ServiceToken>,
§impl<T> ZeroKMSConfig<T>
impl<T> ZeroKMSConfig<T>
pub fn workspace_dir(&self) -> PathBuf
pub fn workspace_dir(&self) -> PathBuf
The configuration directory for the current workspace.
pub fn workspace_id(&self) -> WorkspaceId
pub fn workspace_id(&self) -> WorkspaceId
The ID of the current workspace.
pub fn token_path(&self) -> PathBuf
pub fn token_path(&self) -> PathBuf
The path where the cached service token is stored.
pub fn decryption_log_path(&self) -> Option<PathBuf>
pub fn decryption_log_path(&self) -> Option<PathBuf>
The path to the decryption log file - if enabled.
pub fn credentials(&self) -> ServiceCredentials
pub fn credentials(&self) -> ServiceCredentials
Return a crate::credentials::Credentials provider that can retrieve an access token to
the ZeroKMS API.
Trait Implementations§
§impl<ClientKeyState: Clone> Clone for ZeroKMSConfig<ClientKeyState>
impl<ClientKeyState: Clone> Clone for ZeroKMSConfig<ClientKeyState>
§fn clone(&self) -> ZeroKMSConfig<ClientKeyState>
fn clone(&self) -> ZeroKMSConfig<ClientKeyState>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl<ClientKeyState> Freeze for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: Freeze,
impl<ClientKeyState> RefUnwindSafe for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: RefUnwindSafe,
impl<ClientKeyState> Send for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: Send,
impl<ClientKeyState> Sync for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: Sync,
impl<ClientKeyState> Unpin for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: Unpin,
impl<ClientKeyState> UnwindSafe for ZeroKMSConfig<ClientKeyState>where
ClientKeyState: 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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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