pub struct MetadataService;Expand description
A Service using Storage as Context taking MetadataRequest returning MetadataRequest.
use rama::{Context, Layer as _, Service, layer::MapStateLayer};
use tansu_sans_io::MetadataRequest;
use tansu_storage::{Error, MetadataService, 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(MetadataService);
let response = service
.serve(
Context::default(),
MetadataRequest::default()
.allow_auto_topic_creation(Some(false))
.include_cluster_authorized_operations(Some(false))
.include_topic_authorized_operations(Some(false))
.topics(Some([].into())),
)
.await?;
let brokers = response.brokers.as_deref().unwrap_or_default();
assert_eq!(1, brokers.len());
assert_eq!(HOST, brokers[0].host);
assert_eq!(PORT, brokers[0].port);
assert_eq!(NODE_ID, brokers[0].node_id);
assert!(brokers[0].rack.is_none());Trait Implementations§
Source§impl Clone for MetadataService
impl Clone for MetadataService
Source§fn clone(&self) -> MetadataService
fn clone(&self) -> MetadataService
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 MetadataService
impl Debug for MetadataService
Source§impl Default for MetadataService
impl Default for MetadataService
Source§fn default() -> MetadataService
fn default() -> MetadataService
Returns the “default value” for a type. Read more
Source§impl Hash for MetadataService
impl Hash for MetadataService
Source§impl Ord for MetadataService
impl Ord for MetadataService
Source§fn cmp(&self, other: &MetadataService) -> Ordering
fn cmp(&self, other: &MetadataService) -> 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 MetadataService
impl PartialEq for MetadataService
Source§impl PartialOrd for MetadataService
impl PartialOrd for MetadataService
Source§impl<G> Service<G, MetadataRequest> for MetadataServicewhere
G: Storage,
impl<G> Service<G, MetadataRequest> for MetadataServicewhere
G: Storage,
impl Copy for MetadataService
impl Eq for MetadataService
impl StructuralPartialEq for MetadataService
Auto Trait Implementations§
impl Freeze for MetadataService
impl RefUnwindSafe for MetadataService
impl Send for MetadataService
impl Sync for MetadataService
impl Unpin for MetadataService
impl UnsafeUnpin for MetadataService
impl UnwindSafe for MetadataService
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