mirror of
https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka.git
synced 2025-10-31 18:47:48 +00:00
61 lines
1.8 KiB
C++
61 lines
1.8 KiB
C++
#ifndef CPPKAFKA_KAFKA_HANDLE_BASE_H
|
|
#define CPPKAFKA_KAFKA_HANDLE_BASE_H
|
|
|
|
#include <string>
|
|
#include <memory>
|
|
#include <chrono>
|
|
#include <librdkafka/rdkafka.h>
|
|
#include "metadata.h"
|
|
#include "topic_partition.h"
|
|
#include "topic_partition_list.h"
|
|
#include "configuration.h"
|
|
|
|
namespace cppkafka {
|
|
|
|
class Topic;
|
|
class TopicConfiguration;
|
|
|
|
class KafkaHandleBase {
|
|
public:
|
|
virtual ~KafkaHandleBase() = default;
|
|
KafkaHandleBase(const KafkaHandleBase&) = delete;
|
|
KafkaHandleBase(KafkaHandleBase&&) = delete;
|
|
KafkaHandleBase& operator=(const KafkaHandleBase&) = delete;
|
|
KafkaHandleBase& operator=(KafkaHandleBase&&) = delete;
|
|
|
|
void pause_partitions(const TopicPartitionList& topic_partitions);
|
|
void resume_partitions(const TopicPartitionList& topic_partitions);
|
|
|
|
void set_timeout(const std::chrono::milliseconds& timeout);
|
|
|
|
rd_kafka_t* get_handle();
|
|
Topic get_topic(const std::string& name);
|
|
Topic get_topic(const std::string& name, TopicConfiguration config);
|
|
Metadata get_metadata();
|
|
Metadata get_metadata(const Topic& topic);
|
|
std::chrono::milliseconds get_timeout() const;
|
|
const Configuration& get_configuration() const;
|
|
protected:
|
|
KafkaHandleBase(Configuration config);
|
|
KafkaHandleBase(rd_kafka_t* handle);
|
|
|
|
void set_handle(rd_kafka_t* handle);
|
|
void check_error(rd_kafka_resp_err_t error);
|
|
rd_kafka_conf_t* get_configuration_handle();
|
|
private:
|
|
static const std::chrono::milliseconds DEFAULT_TIMEOUT;
|
|
|
|
using HandlePtr = std::unique_ptr<rd_kafka_t, decltype(&rd_kafka_destroy)>;
|
|
|
|
Topic get_topic(const std::string& name, rd_kafka_topic_conf_t* conf);
|
|
Metadata get_metadata(rd_kafka_topic_t* topic_ptr);
|
|
|
|
HandlePtr handle_;
|
|
std::chrono::milliseconds timeout_ms_;
|
|
Configuration config_;
|
|
};
|
|
|
|
} // cppkafka
|
|
|
|
#endif // CPPKAFKA_KAFKA_HANDLE_BASE_H
|