summaryrefslogtreecommitdiff
path: root/common/include/tfe_kafka_logger.h
blob: 82db3d767c89ca6fa88907a91ca13031cf00156b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#ifndef _TFE_KAFKA_LOGGER_H
#define _TFE_KAFKA_LOGGER_H

#ifdef __cpluscplus
extern "C"
{
#endif

#include <tfe_utils.h>
#include <librdkafka/rdkafka.h>

enum kafka_topic_type
{   
    TOPIC_LOGGER,
    TOPIC_BUCKET,
    TOPIC_MC_CACHE,
    TOPIC_MAX
};

typedef struct tfe_kafka_logger_s
{
    int enable;
    int t_vsys_id;

    unsigned int local_ip_num;
    char local_ip_str[TFE_SYMBOL_MAX];

    char topic_name[TOPIC_MAX][TFE_STRING_MAX];
    char broker_list[TFE_STRING_MAX];

    rd_kafka_t *kafka_handle;
    rd_kafka_topic_t *kafka_topic[TOPIC_MAX];
} tfe_kafka_logger_t;

tfe_kafka_logger_t *tfe_kafka_logger_create(int enable, const char *nic_name, const char *brokerlist, const char *sasl_username, const char *sasl_passwd, void *local_logger);
int tfe_kafka_logger_topic_new(tfe_kafka_logger_t *logger, const char *topic_name, int topic_id, void *local_logger);
void tfe_kafka_logger_destroy(tfe_kafka_logger_t *logger);
int tfe_kafka_logger_send(tfe_kafka_logger_t *logger, int topic_id, const char *data, int len);

#ifdef __cpluscplus
}
#endif

#endif