This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
tango-maat/include/maat.h

367 lines
13 KiB
C
Raw Normal View History

2022-11-17 05:05:35 +08:00
/*
**********************************************************************************************
* Maat: Deep Packet Inspection Policy Framework
2022-10-27 17:58:52 +08:00
2022-11-17 05:05:35 +08:00
* Maat is the Goddess of truth and justice in ancient Egyptian concept.
* Her feather was the measure that determined whether the souls (considered
* to reside in the heart) of the departed would reach the paradise of afterlife
* successfully.
* Authors: Liu WenTan <liuwentan@geedgenetworks.com>
* Date: 2022-10-31
* Copyright: (c) 2018-2023 Geedge Networks, Inc. All rights reserved.
2022-11-17 05:05:35 +08:00
***********************************************************************************************
*/
#ifndef _MAAT_H_
#define _MAAT_H_
2022-10-27 17:58:52 +08:00
#ifdef __cplusplus
2022-11-25 16:32:29 +08:00
extern "C"
{
#endif
2022-10-27 17:58:52 +08:00
#include <stdint.h>
#include <netinet/in.h>
2022-11-17 05:05:35 +08:00
/* maat instance handle */
struct maat;
2022-10-27 17:58:52 +08:00
2023-01-06 18:54:59 +08:00
struct maat_hit_path {
int Nth_scan;
int vtable_id; // 0 is not a virtual table.
int NOT_flag; // 1 means NOT clause(condition)
int clause_index; // 0 ~ 7
long long item_id;
long long sub_group_id;
long long top_group_id;
long long compile_id;
2023-01-06 18:54:59 +08:00
};
2023-06-05 15:14:45 +08:00
struct maat_hit_group {
long long item_id;
2023-02-22 15:22:41 +08:00
long long group_id;
2023-06-05 15:14:45 +08:00
int vtable_id;
2023-01-06 18:54:59 +08:00
};
2023-02-03 17:28:14 +08:00
enum maat_scan_status {
MAAT_SCAN_ERR = -1, //scan error
MAAT_SCAN_OK, //scan but not hit(group or compile)
MAAT_SCAN_HALF_HIT, //half hit: hit group, not hit compile
MAAT_SCAN_HIT //scan hit compile
2022-12-09 17:12:18 +08:00
};
enum maat_update_type {
MAAT_UPDATE_TYPE_INVALID = 0,
MAAT_UPDATE_TYPE_FULL,
MAAT_UPDATE_TYPE_INC
};
2023-11-24 15:36:27 +08:00
/**
* @brief auto means select engine automatically
* regex rules always use hyperscan
* literal rules: rule_num <= 50k, use hyperscan
* rule_num > 50k, use rulescan
*/
enum maat_expr_engine {
2023-11-24 15:36:27 +08:00
MAAT_EXPR_ENGINE_HS = 0, //hyperscan
MAAT_EXPR_ENGINE_RS, //rulescan
MAAT_EXPR_ENGINE_AUTO //default
};
struct ip_addr {
int ip_type; //4:IPV4, 6:IPV6
union {
unsigned int ipv4; //network order
unsigned int ipv6[4];//network order
};
};
2023-03-28 15:41:24 +08:00
enum log_level {
LOG_LEVEL_TRACE,
LOG_LEVEL_DEBUG,
LOG_LEVEL_INFO,
LOG_LEVEL_WARN,
LOG_LEVEL_ERROR,
LOG_LEVEL_FATAL
};
2023-06-16 15:59:30 +08:00
/* update_type: MAAT_UPDATE_TYPE_FULL or MAAT_UPDATE_TYPE_INC */
2022-11-25 16:32:29 +08:00
typedef void maat_start_callback_t(int update_type, void *u_param);
2023-06-16 15:59:30 +08:00
2022-11-25 16:32:29 +08:00
typedef void maat_update_callback_t(int table_id, const char *table_line, void *u_para);
2023-06-16 15:59:30 +08:00
2022-11-25 16:32:29 +08:00
typedef void maat_finish_callback_t(void *u_para);
typedef void maat_ex_new_func_t(const char *table_name, int table_id, const char *key,
const char *table_line, void **ad, long argl, void *argp);
2023-06-16 15:59:30 +08:00
typedef void maat_ex_free_func_t(int table_id, void **ad, long argl, void *argp);
2023-06-16 15:59:30 +08:00
typedef void maat_ex_dup_func_t(int table_id, void **to, void **from, long argl, void *argp);
2022-11-25 16:32:29 +08:00
/* maat_instance options API */
2022-11-17 05:05:35 +08:00
struct maat_options;
2023-06-16 15:59:30 +08:00
2023-01-30 21:59:35 +08:00
struct maat_options *maat_options_new(void);
2023-06-16 15:59:30 +08:00
2023-01-30 21:59:35 +08:00
void maat_options_free(struct maat_options *opts);
2023-06-16 15:59:30 +08:00
/**
* @brief set maat instance name
*
* @note The maximum length of instance_name is 15 bytes
*/
int maat_options_set_instance_name(struct maat_options *opts, const char *instance_name);
2023-01-06 18:54:59 +08:00
int maat_options_set_caller_thread_number(struct maat_options *opts, size_t n_thread);
2023-06-16 15:59:30 +08:00
2023-01-30 21:59:35 +08:00
int maat_options_set_accept_tags(struct maat_options *opts, const char *accept_tags);
2023-06-16 15:59:30 +08:00
2022-11-25 16:32:29 +08:00
int maat_options_set_rule_update_checking_interval_ms(struct maat_options *opts, int interval_ms);
2023-06-16 15:59:30 +08:00
2022-11-25 16:32:29 +08:00
int maat_options_set_gc_timeout_ms(struct maat_options *opts, int interval_ms);
2023-06-16 15:59:30 +08:00
2022-11-25 16:32:29 +08:00
int maat_options_set_deferred_load_on(struct maat_options *opts);
2023-06-16 15:59:30 +08:00
2023-03-30 10:00:38 +08:00
int maat_options_set_stat_on(struct maat_options *opts);
2023-06-16 15:59:30 +08:00
2023-03-30 10:00:38 +08:00
int maat_options_set_perf_on(struct maat_options *opts);
2023-06-16 15:59:30 +08:00
2023-03-16 11:59:46 +08:00
int maat_options_set_foreign_cont_dir(struct maat_options *opts, const char *dir);
2023-06-16 15:59:30 +08:00
int maat_options_set_logger(struct maat_options *opts, const char *log_path,
enum log_level level);
2023-03-02 10:18:20 +08:00
int maat_options_set_log_file_max_size(struct maat_options *opts, size_t max_size_mb);//default is 500MB, 0 for unlimited
2023-03-02 10:18:20 +08:00
int maat_options_set_iris(struct maat_options *opts, const char *full_directory,
const char *increment_directory);
2023-05-04 17:10:19 +08:00
2022-12-03 22:23:41 +08:00
int maat_options_set_json_file(struct maat_options *opts, const char *json_filename);
2023-05-04 17:10:19 +08:00
/**
* Indicate whether the JSON file is compressed by gzip
* flag: 1(compressed) 0(uncompressed)
* */
int maat_options_set_json_file_gzip_flag(struct maat_options *opts, int flag);
2023-05-04 17:10:19 +08:00
/* Specify the decryption key for the JSON file to be decrypted */
int maat_options_set_json_file_decrypt_key(struct maat_options *opts, const char *decrypt_key);
2023-03-02 10:18:20 +08:00
int maat_options_set_redis(struct maat_options *opts, const char *redis_ip,
uint16_t redis_port, int redis_db);
2023-04-20 15:34:56 +08:00
int maat_options_set_stat_file(struct maat_options *opts, const char *stat_filename);
int maat_options_set_expr_engine(struct maat_options *opts, enum maat_expr_engine engine);
int maat_options_set_hit_path_enabled(struct maat_options *opts);
int maat_options_set_hit_group_enabled(struct maat_options *opts);
2022-11-25 16:32:29 +08:00
/* maat_instance API */
struct maat *maat_new(struct maat_options *opts, const char *table_info_path);
2022-11-17 05:05:35 +08:00
void maat_free(struct maat *instance);
void maat_reload_log_level(struct maat *instance, enum log_level level);
/**
2024-03-29 08:37:40 +00:00
* For xx_plugin table, each thread can call this function initially, maat will maintain the
* thread_id internally and the number of times the xx_plugin_table_get_ex_data interface
* is called by different threads is counted.
*/
void maat_register_thread(struct maat *instance);
2023-03-02 10:18:20 +08:00
/* maat helper API */
int maat_helper_read_column(const char *table_line, int Nth_column,
size_t *column_offset, size_t *column_len);
2023-05-09 17:45:43 +08:00
/**
* verify if regex expression is legal
*
* @param The NULL-terminated expression to parse.
* @retval 1(legal) 0(illegal)
2023-05-09 17:45:43 +08:00
**/
int maat_helper_verify_regex_expression(const char *expression);
2023-03-02 10:18:20 +08:00
2022-11-25 16:32:29 +08:00
/* maat table API */
2023-03-01 17:44:07 +08:00
int maat_get_table_id(struct maat *instance, const char *table_name);
const char *maat_get_table_schema_tag(struct maat *instance, int table_id);
2023-01-30 21:59:35 +08:00
/* return 0 if success, otherwise return -1 */
int maat_table_callback_register(struct maat *instance, int table_id,
2022-11-25 16:32:29 +08:00
maat_start_callback_t *start,
maat_update_callback_t *update,
maat_finish_callback_t *finish,
void *u_para);
2023-02-09 22:13:15 +08:00
2022-11-25 16:32:29 +08:00
/* maat plugin table API */
int maat_plugin_table_ex_schema_register(struct maat *instance, const char *table_name,
maat_ex_new_func_t *new_func,
maat_ex_free_func_t *free_func,
maat_ex_dup_func_t *dup_func,
2023-01-06 18:54:59 +08:00
long argl, void *argp);
/**
* xx_plugin_table_get_ex_data
* returned data is duplicated by dup_func of maat_plugin_table_ex_schema_register,
* caller is responsible to free the data.
*
* free_func support gargbage collection(gc), gc timeout(default 0) can be configured
* in table_info which means maat will not call free_func until the timeout expires
*/
/**
* NOTE: only plugin table support three key type(integer, pointer, ip_addr)
* specified in table_info.conf. If use ip_addr key type, then key should be
* ip address in network order.
*/
void *maat_plugin_table_get_ex_data(struct maat *instance, int table_id,
const char *key, size_t key_len);
int maat_ip_plugin_table_get_ex_data(struct maat *instance, int table_id,
const struct ip_addr *ip_addr,
void **ex_data_array, size_t array_size);
/**
* NOTE: @retval -1(ERROR) 0(no ex_data) 1(only one ex_data)
* this function return only one ex_data if matched
*/
int maat_ipport_plugin_table_get_ex_data(struct maat *instance, int table_id,
const struct ip_addr *ip_addr, uint16_t port,
void **ex_data_array, size_t array_size);
2023-02-20 11:43:43 +08:00
int maat_fqdn_plugin_table_get_ex_data(struct maat *instance, int table_id,
const char *fqdn, void **ex_data_array,
size_t array_size);
2023-02-20 11:43:43 +08:00
int maat_bool_plugin_table_get_ex_data(struct maat *instance, int table_id,
2023-02-20 11:43:43 +08:00
unsigned long long *item_ids, size_t n_item,
void **ex_data_array, size_t array_size);
2022-11-25 16:32:29 +08:00
/* maat scan API */
2022-11-17 05:05:35 +08:00
struct maat_state;
2023-01-30 21:59:35 +08:00
/**
* @param instance: maat instance created by maat_new()
* @param table_id: the id of table which to be scanned
* @param thread_id: thread index
* @param results: array to store hit compile id
* @param n_result: the array size
* @param n_hit_result: the number of hit compile id
* @param state: scan mid status
*
2023-02-03 17:28:14 +08:00
* @retval MAAT_SCAN_ERR
* MAAT_SCAN_OK
* MAAT_SCAN_HALF_HIT
* MAAT_SCAN_HIT
2023-01-30 21:59:35 +08:00
*/
int maat_scan_flag(struct maat *instance, int table_id, long long flag,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
int maat_scan_integer(struct maat *instance, int table_id, long long integer,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
2023-01-30 21:59:35 +08:00
2023-03-27 15:52:47 +08:00
/**
* @param ip_addr: ipv4 address in network order
* @param port: port in host order. If the port is not specified, use -1. Note that 0 is a valid port.
2023-03-27 15:52:47 +08:00
*/
int maat_scan_ipv4_port(struct maat *instance, int table_id, uint32_t ip_addr, int port,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
int maat_scan_ipv6_port(struct maat *instance, int table_id, uint8_t *ip_addr, int port,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
int maat_scan_ipv4(struct maat *instance, int table_id, uint32_t ip_addr,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
int maat_scan_ipv6(struct maat *instance, int table_id, uint8_t *ip_addr,
long long *results, size_t n_result, size_t *n_hit_result,
struct maat_state *state);
2022-11-17 05:05:35 +08:00
2023-03-28 14:07:44 +08:00
int maat_scan_string(struct maat *instance, int table_id,
const char *data, size_t data_len,
long long *results, size_t n_result,
size_t *n_hit_result, struct maat_state *state);
int maat_scan_group(struct maat *instance, int table_id,
struct maat_hit_group *groups, size_t n_group,
long long *results, size_t n_result,
size_t *n_hit_result, struct maat_state *state);
int maat_scan_not_logic(struct maat *instance, int table_id,
long long *results, size_t n_result,
size_t *n_hit_result, struct maat_state *state);
2022-11-17 05:05:35 +08:00
struct maat_stream;
2023-03-28 14:07:44 +08:00
struct maat_stream *maat_stream_new(struct maat *instance, int table_id,
struct maat_state *state);
2022-11-17 05:05:35 +08:00
2023-03-28 14:07:44 +08:00
int maat_stream_scan(struct maat_stream *stream, const char *data, int data_len,
long long *results, size_t n_result, size_t *n_hit_result,
2023-03-23 11:57:17 +08:00
struct maat_state *state);
2022-11-17 05:05:35 +08:00
2023-03-28 14:07:44 +08:00
void maat_stream_free(struct maat_stream *stream);
2022-11-17 05:05:35 +08:00
2023-01-06 18:54:59 +08:00
/* maat state API */
struct maat_state *maat_state_new(struct maat *instance, int thread_id);
void maat_state_reset(struct maat_state *state);
2023-03-23 11:57:17 +08:00
void maat_state_free(struct maat_state *state);
int maat_state_set_scan_district(struct maat_state *state, int table_id,
const char *district, size_t district_len);
2023-01-30 21:59:35 +08:00
2023-03-23 11:57:17 +08:00
int maat_state_set_scan_compile_table(struct maat_state *state, int compile_table_id);
2023-01-30 21:59:35 +08:00
int maat_state_get_hit_paths(struct maat_state *state, struct maat_hit_path *path_array,
size_t array_size);
int maat_state_get_compile_table_ids(struct maat_state *state, long long *compile_ids,
size_t n_compile_ids, int *compile_table_ids);
2023-07-11 11:30:57 +08:00
/**
* @brief get the total number of scans after maat_state_new
*/
size_t maat_state_get_scan_count(struct maat_state *state);
2023-07-11 11:30:57 +08:00
/**
* @brief direct group means group corresponding to item
2023-07-11 11:30:57 +08:00
*
* NOTE: hit groups may be duplicated
*
2023-07-11 11:30:57 +08:00
*/
int maat_state_get_direct_hit_groups(struct maat_state *state,
struct maat_hit_group *group_array,
size_t array_size);
size_t maat_state_get_direct_hit_group_cnt(struct maat_state *state);
/**
* @brief indirect group means superior group
*
* NOTE: hit groups may be duplicated
*/
int maat_state_get_indirect_hit_groups(struct maat_state *state,
struct maat_hit_group *group_array,
size_t array_size);
size_t maat_state_get_indirect_hit_group_cnt(struct maat_state *state);
2022-10-27 17:58:52 +08:00
/**
* @brief get last scan hit groups(including direct/indirect)
*/
int maat_state_get_last_hit_groups(struct maat_state *state,
struct maat_hit_group *group_array,
size_t array_size);
size_t maat_state_get_last_hit_group_cnt(struct maat_state *state);
#ifdef __cplusplus
2022-11-25 16:32:29 +08:00
}
#endif
2022-10-26 14:41:22 +08:00
#endif