mirror of
https://github.com/ntop/ntopng.git
synced 2026-04-30 16:09:32 +00:00
129 lines
5.2 KiB
C++
129 lines
5.2 KiB
C++
/*
|
|
*
|
|
* (C) 2013-17 - ntop.org
|
|
*
|
|
*
|
|
* 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
|
|
* (at your option) 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, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
*/
|
|
|
|
#ifndef _REDIS_H_
|
|
#define _REDIS_H_
|
|
|
|
#include "ntop_includes.h"
|
|
|
|
class Host;
|
|
|
|
class Redis {
|
|
private:
|
|
redisContext *redis;
|
|
Mutex *l;
|
|
char *redis_host;
|
|
char *redis_password;
|
|
u_int32_t num_requests, num_reconnections;
|
|
u_int16_t redis_port;
|
|
u_int8_t redis_db_id;
|
|
pthread_t esThreadLoop;
|
|
pthread_t lsThreadLoop;
|
|
bool operational;
|
|
StringCache_t *stringCache;
|
|
u_int numCached;
|
|
|
|
void reconnectRedis();
|
|
int msg_push(const char *cmd, const char *queue_name, char *msg, u_int queue_trim_size, bool trace_errors = true);
|
|
int oneOperator(const char *operation, char *key);
|
|
int twoOperators(const char *operation, char *op1, char *op2);
|
|
int pushHost(const char* ns_cache, const char* ns_list, char *hostname,
|
|
bool dont_check_for_existence, bool localHost);
|
|
int popHost(const char* ns_list, char *hostname, u_int hostname_len);
|
|
void addToCache(char *key, char *value, u_int expire_secs);
|
|
bool isCacheable(char *key);
|
|
bool expireCache(char *key, u_int expire_sec);
|
|
|
|
public:
|
|
Redis(const char *redis_host = (char*)"127.0.0.1",
|
|
const char *redis_password = NULL,
|
|
u_int16_t redis_port = 6379, u_int8_t _redis_db_id = 0);
|
|
~Redis();
|
|
|
|
char* getVersion(char *str, u_int str_len);
|
|
void setDefaults();
|
|
inline bool isOperational() { return(operational); };
|
|
int expire(char *key, u_int expire_sec);
|
|
int get(char *key, char *rsp, u_int rsp_len, bool cache_it = false);
|
|
int hashGet(char *key, char *member, char *rsp, u_int rsp_len);
|
|
int hashDel(char *key, char *field);
|
|
int hashSet(char *key, char *field, char *value);
|
|
int delHash(char *key, char *member);
|
|
int set(char *key, char *value, u_int expire_secs=0);
|
|
char* popSet(char *pop_name, char *rsp, u_int rsp_len);
|
|
int keys(const char *pattern, char ***keys_p);
|
|
int hashKeys(const char *pattern, char ***keys_p);
|
|
int hashGetAll(const char *key, char ***keys_p, char ***values_p);
|
|
int del(char *key);
|
|
int zIncr(char *key, char *member);
|
|
int zTrim(char *key, u_int trim_len);
|
|
int zRevRange(const char *pattern, char ***keys_p);
|
|
int pushHostToResolve(char *hostname, bool dont_check_for_existence, bool localHost);
|
|
int popHostToResolve(char *hostname, u_int hostname_len);
|
|
|
|
int pushHostToTrafficFiltering(char *hostname, bool dont_check_for_existence, bool localHost);
|
|
int popHostToTrafficFiltering(char *hostname, u_int hostname_len);
|
|
|
|
char* getTrafficFilteringCategory(char *numeric_ip, char *buf, u_int buf_len, bool query_httpbl_if_unknown);
|
|
int popDomainToCategorize(char *domainname, u_int domainname_len);
|
|
|
|
int getAddress(char *numeric_ip, char *rsp, u_int rsp_len, bool queue_if_not_found);
|
|
int getAddressTrafficFiltering(char *numeric_ip, NetworkInterface *iface,
|
|
char *rsp, u_int rsp_len, bool queue_if_not_found);
|
|
int setResolvedAddress(char *numeric_ip, char *symbolic_ip);
|
|
int setTrafficFilteringAddress(char* numeric_ip, char* httpbl);
|
|
|
|
int hashIncr(char *key, char *field, u_int32_t value);
|
|
|
|
int addHostToDBDump(NetworkInterface *iface, IpAddress *ip, char *name);
|
|
|
|
int sadd(const char *set_name, char *item);
|
|
int srem(const char *set_name, char *item);
|
|
int smembers(lua_State* vm, char *setName);
|
|
int smembers(const char *set_name, char ***members);
|
|
|
|
void setHostId(NetworkInterface *iface, char *daybuf, char *host_name, u_int32_t id);
|
|
u_int32_t host_to_id(NetworkInterface *iface, char *daybuf, char *host_name, bool *new_key);
|
|
int id_to_host(char *daybuf, char *host_idx, char *buf, u_int buf_len);
|
|
int lpush(const char *queue_name, char *msg, u_int queue_trim_size, bool trace_errors = true);
|
|
int rpush(const char *queue_name, char *msg, u_int queue_trim_size);
|
|
int lindex(const char *queue_name, int idx, char *buf, u_int buf_len);
|
|
u_int llen(const char *queue_name);
|
|
int lset(const char *queue_name, u_int32_t idx, const char *value);
|
|
int lrem(const char *queue_name, const char *value);
|
|
int lrange(const char *list_name, char ***elements, int start_offset, int end_offset);
|
|
int lpop(const char *queue_name, char *buf, u_int buf_len);
|
|
int lpop(const char *queue_name, char ***elements, u_int num_elements);
|
|
int flushDb();
|
|
void flushCache();
|
|
/**
|
|
* @brief Increment a redis key and return its new value
|
|
*
|
|
* @param key The key whose value will be incremented.
|
|
*/
|
|
u_int32_t incrKey(char *key);
|
|
int rename(char *oldk, char *newk) { return(twoOperators("RENAME", oldk, newk)); };
|
|
void lua(lua_State *vm);
|
|
char* dump(char *key);
|
|
int restore(char *key, char *buf);
|
|
};
|
|
|
|
#endif /* _REDIS_H_ */
|