1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284 |
- #ifndef _RDKAFKACPP_H_
- #define _RDKAFKACPP_H_
- #include <string>
- #include <list>
- #include <vector>
- #include <stdint.h>
- #ifdef _MSC_VER
- #undef RD_EXPORT
- #ifdef LIBRDKAFKA_STATICLIB
- #define RD_EXPORT
- #else
- #ifdef LIBRDKAFKACPP_EXPORTS
- #define RD_EXPORT __declspec(dllexport)
- #else
- #define RD_EXPORT __declspec(dllimport)
- #endif
- #endif
- #else
- #define RD_EXPORT
- #endif
- extern "C" {
-
- struct rd_kafka_s;
- struct rd_kafka_topic_s;
- struct rd_kafka_message_s;
- };
- namespace RdKafka {
- #define RD_KAFKA_VERSION 0x000b04ff
- RD_EXPORT
- int version ();
- RD_EXPORT
- std::string version_str();
- RD_EXPORT
- std::string get_debug_contexts();
- RD_EXPORT
- int wait_destroyed(int timeout_ms);
- enum ErrorCode {
-
-
- ERR__BEGIN = -200,
-
- ERR__BAD_MSG = -199,
-
- ERR__BAD_COMPRESSION = -198,
-
- ERR__DESTROY = -197,
-
- ERR__FAIL = -196,
-
- ERR__TRANSPORT = -195,
-
- ERR__CRIT_SYS_RESOURCE = -194,
-
- ERR__RESOLVE = -193,
-
- ERR__MSG_TIMED_OUT = -192,
-
- ERR__PARTITION_EOF = -191,
-
- ERR__UNKNOWN_PARTITION = -190,
-
- ERR__FS = -189,
-
- ERR__UNKNOWN_TOPIC = -188,
-
- ERR__ALL_BROKERS_DOWN = -187,
-
- ERR__INVALID_ARG = -186,
-
- ERR__TIMED_OUT = -185,
-
- ERR__QUEUE_FULL = -184,
-
- ERR__ISR_INSUFF = -183,
-
- ERR__NODE_UPDATE = -182,
-
- ERR__SSL = -181,
-
- ERR__WAIT_COORD = -180,
-
- ERR__UNKNOWN_GROUP = -179,
-
- ERR__IN_PROGRESS = -178,
-
- ERR__PREV_IN_PROGRESS = -177,
-
- ERR__EXISTING_SUBSCRIPTION = -176,
-
- ERR__ASSIGN_PARTITIONS = -175,
-
- ERR__REVOKE_PARTITIONS = -174,
-
- ERR__CONFLICT = -173,
-
- ERR__STATE = -172,
-
- ERR__UNKNOWN_PROTOCOL = -171,
-
- ERR__NOT_IMPLEMENTED = -170,
-
- ERR__AUTHENTICATION = -169,
-
- ERR__NO_OFFSET = -168,
-
- ERR__OUTDATED = -167,
-
- ERR__TIMED_OUT_QUEUE = -166,
-
- ERR__UNSUPPORTED_FEATURE = -165,
-
- ERR__WAIT_CACHE = -164,
-
- ERR__INTR = -163,
-
- ERR__KEY_SERIALIZATION = -162,
-
- ERR__VALUE_SERIALIZATION = -161,
-
- ERR__KEY_DESERIALIZATION = -160,
-
- ERR__VALUE_DESERIALIZATION = -159,
-
- ERR__PARTIAL = -158,
-
- ERR__READ_ONLY = -157,
-
- ERR__NOENT = -156,
-
- ERR__UNDERFLOW = -155,
-
- ERR__END = -100,
-
-
- ERR_UNKNOWN = -1,
-
- ERR_NO_ERROR = 0,
-
- ERR_OFFSET_OUT_OF_RANGE = 1,
-
- ERR_INVALID_MSG = 2,
-
- ERR_UNKNOWN_TOPIC_OR_PART = 3,
-
- ERR_INVALID_MSG_SIZE = 4,
-
- ERR_LEADER_NOT_AVAILABLE = 5,
-
- ERR_NOT_LEADER_FOR_PARTITION = 6,
-
- ERR_REQUEST_TIMED_OUT = 7,
-
- ERR_BROKER_NOT_AVAILABLE = 8,
-
- ERR_REPLICA_NOT_AVAILABLE = 9,
-
- ERR_MSG_SIZE_TOO_LARGE = 10,
-
- ERR_STALE_CTRL_EPOCH = 11,
-
- ERR_OFFSET_METADATA_TOO_LARGE = 12,
-
- ERR_NETWORK_EXCEPTION = 13,
-
- ERR_GROUP_LOAD_IN_PROGRESS = 14,
-
- ERR_GROUP_COORDINATOR_NOT_AVAILABLE = 15,
-
- ERR_NOT_COORDINATOR_FOR_GROUP = 16,
-
- ERR_TOPIC_EXCEPTION = 17,
-
- ERR_RECORD_LIST_TOO_LARGE = 18,
-
- ERR_NOT_ENOUGH_REPLICAS = 19,
-
- ERR_NOT_ENOUGH_REPLICAS_AFTER_APPEND = 20,
-
- ERR_INVALID_REQUIRED_ACKS = 21,
-
- ERR_ILLEGAL_GENERATION = 22,
-
- ERR_INCONSISTENT_GROUP_PROTOCOL = 23,
-
- ERR_INVALID_GROUP_ID = 24,
-
- ERR_UNKNOWN_MEMBER_ID = 25,
-
- ERR_INVALID_SESSION_TIMEOUT = 26,
-
- ERR_REBALANCE_IN_PROGRESS = 27,
-
- ERR_INVALID_COMMIT_OFFSET_SIZE = 28,
-
- ERR_TOPIC_AUTHORIZATION_FAILED = 29,
-
- ERR_GROUP_AUTHORIZATION_FAILED = 30,
-
- ERR_CLUSTER_AUTHORIZATION_FAILED = 31,
-
- ERR_INVALID_TIMESTAMP = 32,
-
- ERR_UNSUPPORTED_SASL_MECHANISM = 33,
-
- ERR_ILLEGAL_SASL_STATE = 34,
-
- ERR_UNSUPPORTED_VERSION = 35,
-
- ERR_TOPIC_ALREADY_EXISTS = 36,
-
- ERR_INVALID_PARTITIONS = 37,
-
- ERR_INVALID_REPLICATION_FACTOR = 38,
-
- ERR_INVALID_REPLICA_ASSIGNMENT = 39,
-
- ERR_INVALID_CONFIG = 40,
-
- ERR_NOT_CONTROLLER = 41,
-
- ERR_INVALID_REQUEST = 42,
-
- ERR_UNSUPPORTED_FOR_MESSAGE_FORMAT = 43,
-
- ERR_POLICY_VIOLATION = 44,
-
- ERR_OUT_OF_ORDER_SEQUENCE_NUMBER = 45,
-
- ERR_DUPLICATE_SEQUENCE_NUMBER = 46,
-
- ERR_INVALID_PRODUCER_EPOCH = 47,
-
- ERR_INVALID_TXN_STATE = 48,
-
- ERR_INVALID_PRODUCER_ID_MAPPING = 49,
-
- ERR_INVALID_TRANSACTION_TIMEOUT = 50,
-
- ERR_CONCURRENT_TRANSACTIONS = 51,
-
- ERR_TRANSACTION_COORDINATOR_FENCED = 52,
-
- ERR_TRANSACTIONAL_ID_AUTHORIZATION_FAILED = 53,
-
- ERR_SECURITY_DISABLED = 54,
-
- ERR_OPERATION_NOT_ATTEMPTED = 55
- };
- RD_EXPORT
- std::string err2str(RdKafka::ErrorCode err);
- class Producer;
- class Message;
- class Queue;
- class Event;
- class Topic;
- class TopicPartition;
- class Metadata;
- class KafkaConsumer;
- class RD_EXPORT DeliveryReportCb {
- public:
-
- virtual void dr_cb (Message &message) = 0;
- virtual ~DeliveryReportCb() { }
- };
- class RD_EXPORT PartitionerCb {
- public:
-
- virtual int32_t partitioner_cb (const Topic *topic,
- const std::string *key,
- int32_t partition_cnt,
- void *msg_opaque) = 0;
- virtual ~PartitionerCb() { }
- };
- class PartitionerKeyPointerCb {
- public:
-
- virtual int32_t partitioner_cb (const Topic *topic,
- const void *key,
- size_t key_len,
- int32_t partition_cnt,
- void *msg_opaque) = 0;
- virtual ~PartitionerKeyPointerCb() { }
- };
- class RD_EXPORT EventCb {
- public:
-
- virtual void event_cb (Event &event) = 0;
- virtual ~EventCb() { }
- };
- class RD_EXPORT Event {
- public:
-
- enum Type {
- EVENT_ERROR,
- EVENT_STATS,
- EVENT_LOG,
- EVENT_THROTTLE
- };
-
- enum Severity {
- EVENT_SEVERITY_EMERG = 0,
- EVENT_SEVERITY_ALERT = 1,
- EVENT_SEVERITY_CRITICAL = 2,
- EVENT_SEVERITY_ERROR = 3,
- EVENT_SEVERITY_WARNING = 4,
- EVENT_SEVERITY_NOTICE = 5,
- EVENT_SEVERITY_INFO = 6,
- EVENT_SEVERITY_DEBUG = 7
- };
- virtual ~Event () { }
-
-
- virtual Type type () const = 0;
-
- virtual ErrorCode err () const = 0;
-
- virtual Severity severity () const = 0;
-
- virtual std::string fac () const = 0;
-
- virtual std::string str () const = 0;
-
- virtual int throttle_time () const = 0;
-
- virtual std::string broker_name () const = 0;
-
- virtual int broker_id () const = 0;
- };
- class RD_EXPORT ConsumeCb {
- public:
-
- virtual void consume_cb (Message &message, void *opaque) = 0;
- virtual ~ConsumeCb() { }
- };
- class RD_EXPORT RebalanceCb {
- public:
-
- virtual void rebalance_cb (RdKafka::KafkaConsumer *consumer,
- RdKafka::ErrorCode err,
- std::vector<TopicPartition*>&partitions) = 0;
- virtual ~RebalanceCb() { }
- };
- class RD_EXPORT OffsetCommitCb {
- public:
-
- virtual void offset_commit_cb(RdKafka::ErrorCode err,
- std::vector<TopicPartition*>&offsets) = 0;
- virtual ~OffsetCommitCb() { }
- };
- class RD_EXPORT SocketCb {
- public:
-
- virtual int socket_cb (int domain, int type, int protocol) = 0;
- virtual ~SocketCb() { }
- };
- class RD_EXPORT OpenCb {
- public:
-
- virtual int open_cb (const std::string &path, int flags, int mode) = 0;
- virtual ~OpenCb() { }
- };
- class RD_EXPORT Conf {
- public:
-
- enum ConfType {
- CONF_GLOBAL,
- CONF_TOPIC
- };
-
- enum ConfResult {
- CONF_UNKNOWN = -2,
- CONF_INVALID = -1,
- CONF_OK = 0
- };
-
- static Conf *create (ConfType type);
- virtual ~Conf () { }
-
- virtual Conf::ConfResult set (const std::string &name,
- const std::string &value,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- DeliveryReportCb *dr_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- EventCb *event_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- const Conf *topic_conf,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- PartitionerCb *partitioner_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- PartitionerKeyPointerCb *partitioner_kp_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name, SocketCb *socket_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name, OpenCb *open_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- RebalanceCb *rebalance_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult set (const std::string &name,
- OffsetCommitCb *offset_commit_cb,
- std::string &errstr) = 0;
-
- virtual Conf::ConfResult get(const std::string &name,
- std::string &value) const = 0;
-
- virtual Conf::ConfResult get(DeliveryReportCb *&dr_cb) const = 0;
-
- virtual Conf::ConfResult get(EventCb *&event_cb) const = 0;
-
- virtual Conf::ConfResult get(PartitionerCb *&partitioner_cb) const = 0;
-
- virtual Conf::ConfResult get(PartitionerKeyPointerCb *&partitioner_kp_cb) const = 0;
-
- virtual Conf::ConfResult get(SocketCb *&socket_cb) const = 0;
-
- virtual Conf::ConfResult get(OpenCb *&open_cb) const = 0;
-
- virtual Conf::ConfResult get(RebalanceCb *&rebalance_cb) const = 0;
-
- virtual Conf::ConfResult get(OffsetCommitCb *&offset_commit_cb) const = 0;
-
- virtual std::list<std::string> *dump () = 0;
-
- virtual Conf::ConfResult set (const std::string &name, ConsumeCb *consume_cb,
- std::string &errstr) = 0;
- };
- class RD_EXPORT Handle {
- public:
- virtual ~Handle() { }
-
- virtual const std::string name () const = 0;
-
- virtual const std::string memberid () const = 0;
-
- virtual int poll (int timeout_ms) = 0;
-
- virtual int outq_len () = 0;
-
- virtual ErrorCode metadata (bool all_topics, const Topic *only_rkt,
- Metadata **metadatap, int timeout_ms) = 0;
-
- virtual ErrorCode pause (std::vector<TopicPartition*> &partitions) = 0;
-
- virtual ErrorCode resume (std::vector<TopicPartition*> &partitions) = 0;
-
- virtual ErrorCode query_watermark_offsets (const std::string &topic,
- int32_t partition,
- int64_t *low, int64_t *high,
- int timeout_ms) = 0;
-
- virtual ErrorCode get_watermark_offsets (const std::string &topic,
- int32_t partition,
- int64_t *low, int64_t *high) = 0;
-
- virtual ErrorCode offsetsForTimes (std::vector<TopicPartition*> &offsets,
- int timeout_ms) = 0;
-
- virtual Queue *get_partition_queue (const TopicPartition *partition) = 0;
-
- virtual ErrorCode set_log_queue (Queue *queue) = 0;
-
- virtual void yield () = 0;
-
- virtual const std::string clusterid (int timeout_ms) = 0;
-
- virtual struct rd_kafka_s *c_ptr () = 0;
- };
- class RD_EXPORT TopicPartition {
- public:
-
- static TopicPartition *create (const std::string &topic, int partition);
- static TopicPartition *create (const std::string &topic, int partition,
- int64_t offset);
- virtual ~TopicPartition() = 0;
-
- static void destroy (std::vector<TopicPartition*> &partitions);
-
- virtual const std::string &topic () const = 0;
-
- virtual int partition () const = 0;
-
- virtual int64_t offset () const = 0;
-
- virtual void set_offset (int64_t offset) = 0;
-
- virtual ErrorCode err () const = 0;
- };
- class RD_EXPORT Topic {
- public:
-
- static const int32_t PARTITION_UA;
-
- static const int64_t OFFSET_BEGINNING;
- static const int64_t OFFSET_END;
- static const int64_t OFFSET_STORED;
- static const int64_t OFFSET_INVALID;
-
- static Topic *create (Handle *base, const std::string &topic_str,
- Conf *conf, std::string &errstr);
- virtual ~Topic () = 0;
-
- virtual const std::string name () const = 0;
-
- virtual bool partition_available (int32_t partition) const = 0;
-
- virtual ErrorCode offset_store (int32_t partition, int64_t offset) = 0;
-
- virtual struct rd_kafka_topic_s *c_ptr () = 0;
- };
- class RD_EXPORT MessageTimestamp {
- public:
- enum MessageTimestampType {
- MSG_TIMESTAMP_NOT_AVAILABLE,
- MSG_TIMESTAMP_CREATE_TIME,
- MSG_TIMESTAMP_LOG_APPEND_TIME
- };
- MessageTimestampType type;
- int64_t timestamp;
- };
- class RD_EXPORT Message {
- public:
-
-
- virtual std::string errstr() const = 0;
-
- virtual ErrorCode err () const = 0;
-
- virtual Topic *topic () const = 0;
-
- virtual std::string topic_name () const = 0;
-
- virtual int32_t partition () const = 0;
-
- virtual void *payload () const = 0 ;
-
- virtual size_t len () const = 0;
-
- virtual const std::string *key () const = 0;
-
- virtual const void *key_pointer () const = 0 ;
-
- virtual size_t key_len () const = 0;
-
- virtual int64_t offset () const = 0;
-
- virtual MessageTimestamp timestamp () const = 0;
-
- virtual void *msg_opaque () const = 0;
- virtual ~Message () = 0;
-
- virtual int64_t latency () const = 0;
-
- virtual struct rd_kafka_message_s *c_ptr () = 0;
- };
- class RD_EXPORT Queue {
- public:
-
- static Queue *create (Handle *handle);
-
- virtual ErrorCode forward (Queue *dst) = 0;
-
- virtual Message *consume (int timeout_ms) = 0;
-
- virtual int poll (int timeout_ms) = 0;
- virtual ~Queue () = 0;
-
- virtual void io_event_enable (int fd, const void *payload, size_t size) = 0;
- };
- class RD_EXPORT KafkaConsumer : public virtual Handle {
- public:
-
- static KafkaConsumer *create (Conf *conf, std::string &errstr);
- virtual ~KafkaConsumer () = 0;
-
- virtual ErrorCode assignment (std::vector<RdKafka::TopicPartition*> &partitions) = 0;
-
- virtual ErrorCode subscription (std::vector<std::string> &topics) = 0;
-
- virtual ErrorCode subscribe (const std::vector<std::string> &topics) = 0;
-
- virtual ErrorCode unsubscribe () = 0;
-
- virtual ErrorCode assign (const std::vector<TopicPartition*> &partitions) = 0;
-
- virtual ErrorCode unassign () = 0;
-
- virtual Message *consume (int timeout_ms) = 0;
-
- virtual ErrorCode commitSync () = 0;
-
- virtual ErrorCode commitAsync () = 0;
-
- virtual ErrorCode commitSync (Message *message) = 0;
-
- virtual ErrorCode commitAsync (Message *message) = 0;
-
- virtual ErrorCode commitSync (std::vector<TopicPartition*> &offsets) = 0;
-
- virtual ErrorCode commitAsync (const std::vector<TopicPartition*> &offsets) = 0;
-
- virtual ErrorCode commitSync (OffsetCommitCb *offset_commit_cb) = 0;
-
- virtual ErrorCode commitSync (std::vector<TopicPartition*> &offsets,
- OffsetCommitCb *offset_commit_cb) = 0;
-
- virtual ErrorCode committed (std::vector<TopicPartition*> &partitions,
- int timeout_ms) = 0;
-
- virtual ErrorCode position (std::vector<TopicPartition*> &partitions) = 0;
-
-
- virtual ErrorCode close () = 0;
-
- virtual ErrorCode seek (const TopicPartition &partition, int timeout_ms) = 0;
-
- virtual ErrorCode offsets_store (std::vector<TopicPartition*> &offsets) = 0;
- };
- class RD_EXPORT Consumer : public virtual Handle {
- public:
-
- static Consumer *create (Conf *conf, std::string &errstr);
- virtual ~Consumer () = 0;
-
- virtual ErrorCode start (Topic *topic, int32_t partition, int64_t offset) = 0;
-
- virtual ErrorCode start (Topic *topic, int32_t partition, int64_t offset,
- Queue *queue) = 0;
-
- virtual ErrorCode stop (Topic *topic, int32_t partition) = 0;
-
- virtual ErrorCode seek (Topic *topic, int32_t partition, int64_t offset,
- int timeout_ms) = 0;
-
- virtual Message *consume (Topic *topic, int32_t partition,
- int timeout_ms) = 0;
-
- virtual Message *consume (Queue *queue, int timeout_ms) = 0;
-
- virtual int consume_callback (Topic *topic, int32_t partition,
- int timeout_ms,
- ConsumeCb *consume_cb,
- void *opaque) = 0;
-
- virtual int consume_callback (Queue *queue, int timeout_ms,
- RdKafka::ConsumeCb *consume_cb,
- void *opaque) = 0;
-
- static int64_t OffsetTail(int64_t offset);
- };
- class RD_EXPORT Producer : public virtual Handle {
- public:
-
- static Producer *create (Conf *conf, std::string &errstr);
- virtual ~Producer () = 0;
-
- enum {
- RK_MSG_FREE = 0x1,
- RK_MSG_COPY = 0x2,
- RK_MSG_BLOCK = 0x4
-
-
- #ifndef MSG_COPY
- ,
- MSG_FREE = RK_MSG_FREE,
- MSG_COPY = RK_MSG_COPY
- #endif
-
- };
-
- virtual ErrorCode produce (Topic *topic, int32_t partition,
- int msgflags,
- void *payload, size_t len,
- const std::string *key,
- void *msg_opaque) = 0;
-
- virtual ErrorCode produce (Topic *topic, int32_t partition,
- int msgflags,
- void *payload, size_t len,
- const void *key, size_t key_len,
- void *msg_opaque) = 0;
-
- virtual ErrorCode produce (const std::string topic_name, int32_t partition,
- int msgflags,
- void *payload, size_t len,
- const void *key, size_t key_len,
- int64_t timestamp,
- void *msg_opaque) = 0;
-
- virtual ErrorCode produce (Topic *topic, int32_t partition,
- const std::vector<char> *payload,
- const std::vector<char> *key,
- void *msg_opaque) = 0;
-
- virtual ErrorCode flush (int timeout_ms) = 0;
- };
- class BrokerMetadata {
- public:
-
- virtual int32_t id() const = 0;
-
- virtual const std::string host() const = 0;
-
- virtual int port() const = 0;
- virtual ~BrokerMetadata() = 0;
- };
- class PartitionMetadata {
- public:
-
- typedef std::vector<int32_t> ReplicasVector;
-
- typedef std::vector<int32_t> ISRSVector;
-
- typedef ReplicasVector::const_iterator ReplicasIterator;
-
- typedef ISRSVector::const_iterator ISRSIterator;
-
- virtual int32_t id() const = 0;
-
- virtual ErrorCode err() const = 0;
-
- virtual int32_t leader() const = 0;
-
- virtual const std::vector<int32_t> *replicas() const = 0;
-
- virtual const std::vector<int32_t> *isrs() const = 0;
- virtual ~PartitionMetadata() = 0;
- };
- class TopicMetadata {
- public:
-
- typedef std::vector<const PartitionMetadata*> PartitionMetadataVector;
-
- typedef PartitionMetadataVector::const_iterator PartitionMetadataIterator;
-
- virtual const std::string topic() const = 0;
-
- virtual const PartitionMetadataVector *partitions() const = 0;
-
- virtual ErrorCode err() const = 0;
- virtual ~TopicMetadata() = 0;
- };
- class Metadata {
- public:
-
- typedef std::vector<const BrokerMetadata*> BrokerMetadataVector;
-
- typedef std::vector<const TopicMetadata*> TopicMetadataVector;
-
- typedef BrokerMetadataVector::const_iterator BrokerMetadataIterator;
-
- typedef TopicMetadataVector::const_iterator TopicMetadataIterator;
-
- virtual const BrokerMetadataVector *brokers() const = 0;
-
- virtual const TopicMetadataVector *topics() const = 0;
-
- virtual int32_t orig_broker_id() const = 0;
-
- virtual const std::string orig_broker_name() const = 0;
- virtual ~Metadata() = 0;
- };
- }
- #endif
|