pub struct DescribeClusterService;Expand description
A Service using Storage as Context taking DescribeClusterRequest returning DescribeClusterResponse.
use rama::{Context, Layer, Service as _, layer::MapStateLayer};
use tansu_sans_io::{DescribeClusterRequest, EndpointType, ErrorCode};
use tansu_storage::{DescribeClusterService, Error, StorageContainer};
use url::Url;
const HOST: &str = "localhost";
const PORT: i32 = 9092;
const NODE_ID: i32 = 111;
let storage = StorageContainer::builder()
.cluster_id("tansu")
.node_id(NODE_ID)
.advertised_listener(Url::parse(&format!("tcp://{HOST}:{PORT}"))?)
.storage(Url::parse("memory://tansu/")?)
.build()
.await?;
let service = MapStateLayer::new(|_| storage).into_layer(DescribeClusterService);
let response = service
.serve(
Context::default(),
DescribeClusterRequest::default()
.endpoint_type(Some(EndpointType::Broker.into()))
.include_cluster_authorized_operations(false),
)
.await?;
let brokers = response.brokers.unwrap_or_default();
assert_eq!(1, brokers.len());
assert_eq!(NODE_ID, brokers[0].broker_id);
assert_eq!(HOST, brokers[0].host.as_str());
assert_eq!(PORT, brokers[0].port);Trait Implementations§
Source§impl Clone for DescribeClusterService
impl Clone for DescribeClusterService
Source§fn clone(&self) -> DescribeClusterService
fn clone(&self) -> DescribeClusterService
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 DescribeClusterService
impl Debug for DescribeClusterService
Source§impl Default for DescribeClusterService
impl Default for DescribeClusterService
Source§fn default() -> DescribeClusterService
fn default() -> DescribeClusterService
Returns the “default value” for a type. Read more
Source§impl Hash for DescribeClusterService
impl Hash for DescribeClusterService
Source§impl Ord for DescribeClusterService
impl Ord for DescribeClusterService
Source§fn cmp(&self, other: &DescribeClusterService) -> Ordering
fn cmp(&self, other: &DescribeClusterService) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl PartialEq for DescribeClusterService
impl PartialEq for DescribeClusterService
Source§impl PartialOrd for DescribeClusterService
impl PartialOrd for DescribeClusterService
Source§impl<G> Service<G, DescribeClusterRequest> for DescribeClusterServicewhere
G: Storage,
impl<G> Service<G, DescribeClusterRequest> for DescribeClusterServicewhere
G: Storage,
impl Copy for DescribeClusterService
impl Eq for DescribeClusterService
impl StructuralPartialEq for DescribeClusterService
Auto Trait Implementations§
impl Freeze for DescribeClusterService
impl RefUnwindSafe for DescribeClusterService
impl Send for DescribeClusterService
impl Sync for DescribeClusterService
impl Unpin for DescribeClusterService
impl UnsafeUnpin for DescribeClusterService
impl UnwindSafe for DescribeClusterService
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<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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