madsim_rdkafka::admin

Struct AdminClient

Source
pub struct AdminClient<C: ClientContext> { /* private fields */ }
Expand description

A client for the Kafka admin API.

AdminClient provides programmatic access to managing a Kafka cluster, notably manipulating topics, partitions, and configuration parameters.

Implementations§

Source§

impl<C: ClientContext> AdminClient<C>

Source

pub fn create_topics<'a, I>( &self, topics: I, opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<TopicResult>>>
where I: IntoIterator<Item = &'a NewTopic<'a>>,

Creates new topics according to the provided NewTopic specifications.

Note that while the API supports creating multiple topics at once, it is not transactional. Creation of some topics may succeed while others fail. Be sure to check the result of each individual operation.

Source

pub fn delete_topics( &self, topic_names: &[&str], opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<TopicResult>>>

Deletes the named topics.

Note that while the API supports deleting multiple topics at once, it is not transactional. Deletion of some topics may succeed while others fail. Be sure to check the result of each individual operation.

Source

pub fn delete_groups( &self, group_names: &[&str], opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<GroupResult>>>

Deletes the named groups.

Source

pub fn create_partitions<'a, I>( &self, partitions: I, opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<TopicResult>>>
where I: IntoIterator<Item = &'a NewPartitions<'a>>,

Adds additional partitions to existing topics according to the provided NewPartitions specifications.

Note that while the API supports creating partitions for multiple topics at once, it is not transactional. Creation of partitions for some topics may succeed while others fail. Be sure to check the result of each individual operation.

Source

pub fn describe_configs<'a, I>( &self, configs: I, opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<ConfigResourceResult>>>
where I: IntoIterator<Item = &'a ResourceSpecifier<'a>>,

Retrieves the configuration parameters for the specified resources.

Note that while the API supports describing multiple configurations at once, it is not transactional. There is no guarantee that you will see a consistent snapshot of the configuration across different resources.

Source

pub fn alter_configs<'a, I>( &self, configs: I, opts: &AdminOptions, ) -> impl Future<Output = KafkaResult<Vec<AlterConfigsResult>>>
where I: IntoIterator<Item = &'a AlterConfig<'a>>,

Sets configuration parameters for the specified resources.

Note that while the API supports altering multiple resources at once, it is not transactional. Alteration of some resources may succeed while others fail. Be sure to check the result of each individual operation.

Source

pub fn inner(&self) -> &Client<C>

Returns the client underlying this admin client.

Trait Implementations§

Source§

impl<C: ClientContext> Drop for AdminClient<C>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl FromClientConfig for AdminClient<DefaultClientContext>

Source§

fn from_config<'life0, 'async_trait>( config: &'life0 ClientConfig, ) -> Pin<Box<dyn Future<Output = KafkaResult<AdminClient<DefaultClientContext>>> + Send + 'async_trait>>
where 'life0: 'async_trait,

Creates a client from a client configuration. The default client context will be used.
Source§

impl<C: ClientContext> FromClientConfigAndContext<C> for AdminClient<C>

Source§

fn from_config_and_context<'life0, 'async_trait>( config: &'life0 ClientConfig, context: C, ) -> Pin<Box<dyn Future<Output = KafkaResult<AdminClient<C>>> + Send + 'async_trait>>
where 'life0: 'async_trait,

Creates a client from a client configuration and a client context.

Auto Trait Implementations§

§

impl<C> Freeze for AdminClient<C>

§

impl<C> !RefUnwindSafe for AdminClient<C>

§

impl<C> Send for AdminClient<C>

§

impl<C> Sync for AdminClient<C>

§

impl<C> Unpin for AdminClient<C>

§

impl<C> !UnwindSafe for AdminClient<C>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.