Struct ZeroKMSBuilder
pub struct ZeroKMSBuilder<C, ClientKeyState = ()>where
C: Credentials<Token = ServiceToken>,{ /* private fields */ }Expand description
A builder for creating ZeroKMS and ZeroKMSWithClientKey clients.
This provides an ergonomic API for constructing ZeroKMS clients with various configuration options.
§Examples
§Basic usage
use cipherstash_client::zerokms::ZeroKMSBuilder;
use cipherstash_client::credentials::{StaticCredentials, ServiceToken};
use cts_common::Crn;
let token = ServiceToken::new("your-token".to_string(), 3600);
let credentials = StaticCredentials::new(token);
let crn = Crn::try_from("crn:us-east-1.aws:DCMBTGHEX5R2RMR4")?;
let zerokms = ZeroKMSBuilder::new(crn, credentials)?
.with_request_timeout(30)
.with_max_concurrent_reqs(20)
.build()?;§With client key for encryption/decryption
use cipherstash_client::zerokms::{ZeroKMSBuilder, ClientKey};
use cipherstash_client::credentials::{StaticCredentials, ServiceToken};
use cts_common::Crn;
use uuid::Uuid;
let token = ServiceToken::new("your-token".to_string(), 3600);
let credentials = StaticCredentials::new(token);
let crn = Crn::try_from("crn:us-east-1.aws:DCMBTGHEX5R2RMR4")?;
let client_id = Uuid::parse_str("550e8400-e29b-41d4-a716-446655440000")?;
let client_key = ClientKey::from_hex_v1(client_id, "a4627031...")?;
let zerokms = ZeroKMSBuilder::new(crn, credentials)?
.with_client_key(client_key)
.build()?;Implementations§
§impl<C> ZeroKMSBuilder<C, ()>where
C: Credentials<Token = ServiceToken>,
impl<C> ZeroKMSBuilder<C, ()>where
C: Credentials<Token = ServiceToken>,
pub fn new<T>(crn: T, credentials: C) -> Result<Self, ZeroKMSBuilderError>
pub fn new<T>(crn: T, credentials: C) -> Result<Self, ZeroKMSBuilderError>
Create a new ZeroKMSBuilder.
§Arguments
crn- The CRN (CipherStash Resource Name) identifying the workspace and regioncredentials- Credentials provider for obtaining access tokens
§Examples
use cipherstash_client::zerokms::ZeroKMSBuilder;
use cipherstash_client::credentials::{StaticCredentials, ServiceToken};
use cts_common::Crn;
let token = ServiceToken::new("your-token".to_string(), 3600);
let credentials = StaticCredentials::new(token);
let crn = "crn:us-east-1.aws:DCMBTGHEX5R2RMR4";
let builder = ZeroKMSBuilder::new(crn, credentials)?;pub fn with_request_timeout(self, timeout_secs: u64) -> Self
pub fn with_request_timeout(self, timeout_secs: u64) -> Self
Set the request timeout in seconds.
If not set, defaults to 10 seconds.
§Examples
let builder = ZeroKMSBuilder::new(crn, credentials)?
.with_request_timeout(30);pub fn with_max_keys_per_req(self, max_keys: usize) -> Self
pub fn with_max_keys_per_req(self, max_keys: usize) -> Self
Set the maximum number of keys per request.
Defaults to 500 if not set.
§Examples
let builder = ZeroKMSBuilder::new(crn, credentials)?
.with_max_keys_per_req(50);pub fn with_max_concurrent_reqs(self, max_concurrent: usize) -> Self
pub fn with_max_concurrent_reqs(self, max_concurrent: usize) -> Self
Set the maximum number of concurrent requests.
Defaults to 5 if not set.
§Examples
let builder = ZeroKMSBuilder::new(crn, credentials)?
.with_max_concurrent_reqs(20);pub fn with_base_url(self, base_url: Url) -> Self
pub fn with_base_url(self, base_url: Url) -> Self
Override the base URL for the ZeroKMS service.
This bypasses the default service discovery mechanism and connects directly to the specified URL. Useful for:
- Connecting to local development servers
- Testing against non-production environments
- Custom deployment configurations
§Examples
let builder = ZeroKMSBuilder::new(crn, credentials)?
.with_base_url(Url::parse("http://localhost:3000")?);pub fn with_client_key(
self,
client_key: ClientKey,
) -> ZeroKMSBuilder<C, ClientKey>
pub fn with_client_key( self, client_key: ClientKey, ) -> ZeroKMSBuilder<C, ClientKey>
Add a client key to enable encryption and decryption operations.
This transforms the builder into one that will build a ZeroKMSWithClientKey instead of a plain ZeroKMS.
§Examples
let client_id = Uuid::parse_str("550e8400-e29b-41d4-a716-446655440000")?;
let client_key = ClientKey::from_hex_v1(client_id, "a4627031...")?;
let builder = ZeroKMSBuilder::new(crn, credentials)?
.with_client_key(client_key);§impl<C> ZeroKMSBuilder<C, ClientKey>where
C: Credentials<Token = ServiceToken>,
impl<C> ZeroKMSBuilder<C, ClientKey>where
C: Credentials<Token = ServiceToken>,
pub fn build(self) -> Result<ZeroKMSWithClientKey<C>, ZeroKMSBuilderError>
pub fn build(self) -> Result<ZeroKMSWithClientKey<C>, ZeroKMSBuilderError>
Build a ZeroKMSWithClientKey client.
This is only available after calling with_client_key.
§Examples
let client_id = Uuid::parse_str("550e8400-e29b-41d4-a716-446655440000")?;
let client_key = ClientKey::from_hex_v1(client_id, "a4627031...")?;
let zerokms = ZeroKMSBuilder::new(crn, credentials)?
.with_client_key(client_key)
.build()?;Auto Trait Implementations§
impl<C, ClientKeyState> Freeze for ZeroKMSBuilder<C, ClientKeyState>
impl<C, ClientKeyState> RefUnwindSafe for ZeroKMSBuilder<C, ClientKeyState>where
C: RefUnwindSafe,
ClientKeyState: RefUnwindSafe,
impl<C, ClientKeyState> Send for ZeroKMSBuilder<C, ClientKeyState>where
ClientKeyState: Send,
impl<C, ClientKeyState> Sync for ZeroKMSBuilder<C, ClientKeyState>where
ClientKeyState: Sync,
impl<C, ClientKeyState> Unpin for ZeroKMSBuilder<C, ClientKeyState>
impl<C, ClientKeyState> UnwindSafe for ZeroKMSBuilder<C, ClientKeyState>where
C: UnwindSafe,
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> 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<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