/** Node type: kafka * * @file * @author Juan Pablo NoreƱa * @copyright 2021, Universidad Nacional de Colombia * @license GNU General Public License (version 3) * * VILLASnode * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . *********************************************************************************/ #pragma once #include #include #include #include namespace villas { namespace node { /* Forward declarations */ class NodeCompat; struct kafka { struct CQueueSignalled queue; struct Pool pool; double timeout; /**< Timeout in seconds. */ char *server; /**< Hostname/IP:Port address of the bootstrap server. */ char *protocol; /**< Security protocol. */ char *produce; /**< Producer topic. */ char *consume; /**< Consumer topic. */ char *client_id; /**< Client ID. */ struct { rd_kafka_t *client; rd_kafka_topic_t *topic; } producer; struct { rd_kafka_t *client; char *group_id; /**< Group id. */ } consumer; struct { char *ca; /**< SSL CA file. */ } ssl; struct { char *mechanisms; /**< SASL mechanisms. */ char *username; /**< SSL CA path. */ char *password; /**< SSL certificate. */ } sasl; Format *formatter; }; int kafka_reverse(NodeCompat *n); char * kafka_print(NodeCompat *n); int kafka_init(NodeCompat *n); int kafka_prepare(NodeCompat *n); int kafka_parse(NodeCompat *n, json_t *json); int kafka_start(NodeCompat *n); int kafka_destroy(NodeCompat *n); int kafka_stop(NodeCompat *n); int kafka_type_start(SuperNode *sn); int kafka_type_stop(); int kafka_poll_fds(NodeCompat *n, int fds[]); int kafka_read(NodeCompat *n, struct Sample * const smps[], unsigned cnt); int kafka_write(NodeCompat *n, struct Sample * const smps[], unsigned cnt); } /* namespace node */ } /* namespace villas */