X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fcore%2Fstore-private.h;h=a2121f45c211dad50003007e6a438f9958725638;hb=444db0c3fae176a18166120dd19a7e01ee95823c;hp=0db46f84b5d6c28393d8a7d49b8e8dd453471335;hpb=e5d944cf9ebf73282feccd6bda92e25f0d7523a2;p=sysdb.git diff --git a/src/core/store-private.h b/src/core/store-private.h index 0db46f8..a2121f4 100644 --- a/src/core/store-private.h +++ b/src/core/store-private.h @@ -33,6 +33,7 @@ #define SDB_CORE_STORE_PRIVATE_H 1 #include "core/store.h" +#include "utils/avltree.h" #include #include @@ -41,7 +42,7 @@ extern "C" { #endif -struct sdb_store_base { +struct sdb_store_obj { sdb_object_t super; /* object type */ @@ -50,33 +51,61 @@ struct sdb_store_base { /* common meta information */ sdb_time_t last_update; sdb_time_t interval; /* moving average */ - sdb_store_base_t *parent; + char **backends; + size_t backends_num; + sdb_store_obj_t *parent; }; -#define STORE_BASE(obj) ((sdb_store_base_t *)(obj)) -#define STORE_CONST_BASE(obj) ((const sdb_store_base_t *)(obj)) +#define STORE_OBJ(obj) ((sdb_store_obj_t *)(obj)) +#define STORE_CONST_OBJ(obj) ((const sdb_store_obj_t *)(obj)) typedef struct { - sdb_store_base_t super; + sdb_store_obj_t super; sdb_data_t value; } sdb_attribute_t; -#define SDB_ATTR(obj) ((sdb_attribute_t *)(obj)) -#define SDB_CONST_ATTR(obj) ((const sdb_attribute_t *)(obj)) +#define ATTR(obj) ((sdb_attribute_t *)(obj)) +#define CONST_ATTR(obj) ((const sdb_attribute_t *)(obj)) typedef struct { - sdb_store_base_t super; + sdb_store_obj_t super; - sdb_llist_t *children; - sdb_llist_t *attributes; -} sdb_store_obj_t; -#define SDB_STORE_OBJ(obj) ((sdb_store_obj_t *)(obj)) -#define SDB_CONST_STORE_OBJ(obj) ((const sdb_store_obj_t *)(obj)) + sdb_avltree_t *attributes; +} sdb_service_t; +#define SVC(obj) ((sdb_service_t *)(obj)) +#define CONST_SVC(obj) ((const sdb_service_t *)(obj)) -/* shortcuts for accessing the sdb_store_obj_t attributes - * of inheriting objects */ +typedef struct { + sdb_store_obj_t super; + + sdb_avltree_t *services; + sdb_avltree_t *attributes; +} sdb_host_t; +#define HOST(obj) ((sdb_host_t *)(obj)) +#define CONST_HOST(obj) ((const sdb_host_t *)(obj)) + +/* shortcuts for accessing service/host attributes */ #define _last_update super.last_update #define _interval super.interval +/* + * conditionals + */ + +/* compares a host using the specified conditional */ +typedef int (*cmp_cb)(sdb_host_t *, sdb_store_cond_t *); + +struct sdb_store_cond { + sdb_object_t super; + cmp_cb cmp; +}; + +typedef struct { + sdb_store_cond_t super; + char *name; + sdb_data_t value; +} attr_cond_t; +#define ATTR_C(obj) ((attr_cond_t *)(obj)) + /* * matchers */ @@ -89,8 +118,28 @@ enum { MATCHER_NOT, MATCHER_NAME, MATCHER_ATTR, + MATCHER_LT, + MATCHER_LE, + MATCHER_EQ, + MATCHER_GE, + MATCHER_GT, + MATCHER_ISNULL, }; +#define MATCHER_SYM(t) \ + (((t) == MATCHER_OR) ? "OR" \ + : ((t) == MATCHER_AND) ? "AND" \ + : ((t) == MATCHER_NOT) ? "NOT" \ + : ((t) == MATCHER_NAME) ? "NAME" \ + : ((t) == MATCHER_ATTR) ? "ATTR" \ + : ((t) == MATCHER_LT) ? "<" \ + : ((t) == MATCHER_LE) ? "<=" \ + : ((t) == MATCHER_EQ) ? "=" \ + : ((t) == MATCHER_GE) ? ">=" \ + : ((t) == MATCHER_GT) ? ">" \ + : ((t) == MATCHER_ISNULL) ? "IS NULL" \ + : "UNKNOWN") + /* match the name of something */ typedef struct { char *name; @@ -137,12 +186,23 @@ typedef struct { typedef struct { sdb_store_matcher_t super; char *name; - /* XXX: this needs to be more flexible; - * add support for type-specific operators */ string_matcher_t value; } attr_matcher_t; #define ATTR_M(m) ((attr_matcher_t *)(m)) +typedef struct { + sdb_store_matcher_t super; + char *attr_name; /* we only support matching attributes */ +} isnull_matcher_t; +#define ISNULL_M(m) ((isnull_matcher_t *)(m)) + +/* match using conditionals */ +typedef struct { + sdb_store_matcher_t super; + sdb_store_cond_t *cond; +} cond_matcher_t; +#define COND_M(m) ((cond_matcher_t *)(m)) + #ifdef __cplusplus } /* extern "C" */ #endif