#[non_exhaustive]pub struct StreamConfig {
pub storage_class: Option<StorageClass>,
pub retention_policy: Option<RetentionPolicy>,
pub timestamping: Option<TimestampingConfig>,
pub delete_on_empty: Option<DeleteOnEmptyConfig>,
}Expand description
Configuration for a stream.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.storage_class: Option<StorageClass>Storage class for the stream.
Defaults to Express.
retention_policy: Option<RetentionPolicy>Retention policy for records in the stream.
Defaults to 7 days of retention.
timestamping: Option<TimestampingConfig>Configuration for timestamping behavior.
See TimestampingConfig for defaults.
delete_on_empty: Option<DeleteOnEmptyConfig>Configuration for automatically deleting the stream when it becomes empty.
See DeleteOnEmptyConfig for defaults.
Implementations§
Source§impl StreamConfig
impl StreamConfig
Sourcepub fn new() -> Self
pub fn new() -> Self
Create a new StreamConfig with default settings.
Examples found in repository?
examples/create_basin.rs (line 19)
7async fn main() -> Result<(), Box<dyn std::error::Error>> {
8 let access_token =
9 std::env::var("S2_ACCESS_TOKEN").map_err(|_| "S2_ACCESS_TOKEN env var not set")?;
10 let basin_name: BasinName = std::env::var("S2_BASIN")
11 .map_err(|_| "S2_BASIN env var not set")?
12 .parse()?;
13
14 let config = S2Config::new(access_token);
15 let s2 = S2::new(config)?;
16
17 let input = CreateBasinInput::new(basin_name.clone()).with_config(
18 BasinConfig::new().with_default_stream_config(
19 StreamConfig::new().with_retention_policy(RetentionPolicy::Age(10 * 24 * 60 * 60)),
20 ),
21 );
22 let basin_info = s2.create_basin(input).await?;
23 println!("{basin_info:#?}");
24
25 let basin_config = s2.get_basin_config(basin_name).await?;
26 println!("{basin_config:#?}");
27
28 Ok(())
29}More examples
examples/create_stream.rs (line 24)
10async fn main() -> Result<(), Box<dyn std::error::Error>> {
11 let access_token =
12 std::env::var("S2_ACCESS_TOKEN").map_err(|_| "S2_ACCESS_TOKEN env var not set")?;
13 let basin_name: BasinName = std::env::var("S2_BASIN")
14 .map_err(|_| "S2_BASIN env var not set")?
15 .parse()?;
16 let stream_name: StreamName = std::env::var("S2_STREAM")
17 .map_err(|_| "S2_STREAM env var not set")?
18 .parse()?;
19
20 let s2 = S2::new(S2Config::new(access_token))?;
21 let basin = s2.basin(basin_name);
22
23 let input = CreateStreamInput::new(stream_name.clone()).with_config(
24 StreamConfig::new().with_timestamping(
25 TimestampingConfig::new().with_mode(TimestampingMode::ClientRequire),
26 ),
27 );
28 let stream_info = basin.create_stream(input).await?;
29 println!("{stream_info:#?}");
30
31 let stream_config = basin.get_stream_config(stream_name).await?;
32 println!("{stream_config:#?}");
33
34 Ok(())
35}Sourcepub fn with_storage_class(self, storage_class: StorageClass) -> Self
pub fn with_storage_class(self, storage_class: StorageClass) -> Self
Set the storage class for the stream.
Sourcepub fn with_retention_policy(self, retention_policy: RetentionPolicy) -> Self
pub fn with_retention_policy(self, retention_policy: RetentionPolicy) -> Self
Set the retention policy for records in the stream.
Examples found in repository?
examples/create_basin.rs (line 19)
7async fn main() -> Result<(), Box<dyn std::error::Error>> {
8 let access_token =
9 std::env::var("S2_ACCESS_TOKEN").map_err(|_| "S2_ACCESS_TOKEN env var not set")?;
10 let basin_name: BasinName = std::env::var("S2_BASIN")
11 .map_err(|_| "S2_BASIN env var not set")?
12 .parse()?;
13
14 let config = S2Config::new(access_token);
15 let s2 = S2::new(config)?;
16
17 let input = CreateBasinInput::new(basin_name.clone()).with_config(
18 BasinConfig::new().with_default_stream_config(
19 StreamConfig::new().with_retention_policy(RetentionPolicy::Age(10 * 24 * 60 * 60)),
20 ),
21 );
22 let basin_info = s2.create_basin(input).await?;
23 println!("{basin_info:#?}");
24
25 let basin_config = s2.get_basin_config(basin_name).await?;
26 println!("{basin_config:#?}");
27
28 Ok(())
29}Sourcepub fn with_timestamping(self, timestamping: TimestampingConfig) -> Self
pub fn with_timestamping(self, timestamping: TimestampingConfig) -> Self
Set the configuration for timestamping behavior.
Examples found in repository?
examples/create_stream.rs (lines 24-26)
10async fn main() -> Result<(), Box<dyn std::error::Error>> {
11 let access_token =
12 std::env::var("S2_ACCESS_TOKEN").map_err(|_| "S2_ACCESS_TOKEN env var not set")?;
13 let basin_name: BasinName = std::env::var("S2_BASIN")
14 .map_err(|_| "S2_BASIN env var not set")?
15 .parse()?;
16 let stream_name: StreamName = std::env::var("S2_STREAM")
17 .map_err(|_| "S2_STREAM env var not set")?
18 .parse()?;
19
20 let s2 = S2::new(S2Config::new(access_token))?;
21 let basin = s2.basin(basin_name);
22
23 let input = CreateStreamInput::new(stream_name.clone()).with_config(
24 StreamConfig::new().with_timestamping(
25 TimestampingConfig::new().with_mode(TimestampingMode::ClientRequire),
26 ),
27 );
28 let stream_info = basin.create_stream(input).await?;
29 println!("{stream_info:#?}");
30
31 let stream_config = basin.get_stream_config(stream_name).await?;
32 println!("{stream_config:#?}");
33
34 Ok(())
35}Sourcepub fn with_delete_on_empty(self, delete_on_empty: DeleteOnEmptyConfig) -> Self
pub fn with_delete_on_empty(self, delete_on_empty: DeleteOnEmptyConfig) -> Self
Set the configuration for automatically deleting the stream when it becomes empty.
Trait Implementations§
Source§impl Clone for StreamConfig
impl Clone for StreamConfig
Source§fn clone(&self) -> StreamConfig
fn clone(&self) -> StreamConfig
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for StreamConfig
impl Debug for StreamConfig
Source§impl Default for StreamConfig
impl Default for StreamConfig
Source§fn default() -> StreamConfig
fn default() -> StreamConfig
Returns the “default value” for a type. Read more
Source§impl From<StreamConfig> for StreamConfig
impl From<StreamConfig> for StreamConfig
Source§fn from(value: StreamConfig) -> Self
fn from(value: StreamConfig) -> Self
Converts to this type from the input type.
Source§impl From<StreamConfig> for StreamConfig
impl From<StreamConfig> for StreamConfig
Source§fn from(value: StreamConfig) -> Self
fn from(value: StreamConfig) -> Self
Converts to this type from the input type.
Source§impl PartialEq for StreamConfig
impl PartialEq for StreamConfig
impl Eq for StreamConfig
impl StructuralPartialEq for StreamConfig
Auto Trait Implementations§
impl Freeze for StreamConfig
impl RefUnwindSafe for StreamConfig
impl Send for StreamConfig
impl Sync for StreamConfig
impl Unpin for StreamConfig
impl UnwindSafe for StreamConfig
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
Mutably borrows from an owned value. Read more
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>
Converts
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>
Converts
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 more