/* Copyright 2016 Alex 'AdUser' Z (ad_user@runbox.com) * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */ #ifndef F2B_BACKEND_H_ #define F2B_BACKEND_H_ #include "config.h" #include "log.h" /** * @file * This header describes backend module definition and related routines */ /** backend module definition */ typedef struct f2b_backend_t { void *h; /**< dlopen handler */ void *cfg; /**< opaque pointer of module config */ /* handlers */ /** dlsym pointer to handler of @a create command */ void *(*create) (const char *id); /** dlsym pointer to handler of @a config command */ bool (*config) (void *cfg, const char *key, const char *value); /** dlsym pointer to handler of @a ready command */ bool (*ready) (void *cfg); /** dlsym pointer to handler of @a error command */ void (*logcb) (void *cfg, void (*cb)(log_msgtype_t lvl, const char *msg)); /** dlsym pointer to handler of @a start command */ bool (*start) (void *cfg); /** dlsym pointer to handler of @a stop command */ bool (*stop) (void *cfg); /** dlsym pointer to handler of @a ping command */ bool (*ping) (void *cfg); /** dlsym pointer to handler of @a ban command */ bool (*ban) (void *cfg, const char *ip); /** dlsym pointer to handler of @a check command */ bool (*check) (void *cfg, const char *ip); /** dlsym pointer to handler of @a unban command */ bool (*unban) (void *cfg, const char *ip); /** dlsym pointer to handler of @a destroy command */ void (*destroy) (void *cfg); } f2b_backend_t; /** * @brief Create module from config * @param config Pointer to section of config * @param id Backend id * @returns Pointer to module metadata of NULL on error */ f2b_backend_t * f2b_backend_create (f2b_config_section_t *config, const char *id); /** * @brief Free module metadata * @param b Pointer to module struct */ void f2b_backend_destroy(f2b_backend_t *b); /* helpers */ /** * @brief Start given backend * @param b Pointer to backend struct * @returns true on success, false on error with setting last error */ bool f2b_backend_start (f2b_backend_t *b); /** * @brief Stop given backend * @param b Pointer to backend struct * @returns true on success, false on error with setting last error */ bool f2b_backend_stop (f2b_backend_t *b); /** * @brief Perform maintenance of given backend * @param b Pointer to backend struct * @returns true on success, false on error with setting last error */ bool f2b_backend_ping (f2b_backend_t *b); /** * @brief Send command to ban given ip * @param b Pointer to backend struct * @param ip IP address * @returns true on success, false on error with setting last error */ bool f2b_backend_ban (f2b_backend_t *b, const char *ip); /** * @brief Check is given ip already banned by backend * @param b Pointer to backend struct * @param ip IP address * @returns true on success, false on error with setting last error * @note Not all backends support this command */ bool f2b_backend_check (f2b_backend_t *b, const char *ip); /** * @brief Send command to release given ip * @param b Pointer to backend struct * @param ip IP address * @returns true on success, false on error with setting last error */ bool f2b_backend_unban (f2b_backend_t *b, const char *ip); #endif /* F2B_BACKEND_H_ */