summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorliuxueli <[email protected]>2020-06-05 16:53:25 +0800
committerliuxueli <[email protected]>2020-06-05 16:53:25 +0800
commitb67882bd6a8cd78efc513e244a68d72218a499d3 (patch)
treeacf51cf0d3e7f52d8d5ac1523855b3df41edb4e6
parent8a35de89df07d74824e039158c17e400ae666fd7 (diff)
提供函数接口,供KNI与HTTP业务层调用,实现统计数据统一出口v1.3.0
-rw-r--r--inc/tsg_statistic.h11
-rw-r--r--src/tsg_entry.cpp187
-rw-r--r--src/tsg_entry.h6
-rw-r--r--src/tsg_statistic.cpp29
4 files changed, 48 insertions, 185 deletions
diff --git a/inc/tsg_statistic.h b/inc/tsg_statistic.h
index 980ffef..be746a4 100644
--- a/inc/tsg_statistic.h
+++ b/inc/tsg_statistic.h
@@ -1,6 +1,16 @@
#ifndef __TSG_STATISTIC_H__
#define __TSG_STATISTIC_H__
+enum _STATISTIC_OPT_TYPE
+{
+ OPT_TYPE_ALERT_BYTES,
+ OPT_TYPE_BLOCK_BYTES,
+ OPT_TYPE_PINNING_YES,
+ OPT_TYPE_PINNING_MAYBE,
+ OPT_TYPE_PINNING_NOT,
+ _OPT_TYPE_MAX
+};
+
struct _traffic_info
{
long long con_num;
@@ -12,5 +22,6 @@ struct _traffic_info
int tsg_set_policy_flow(struct streaminfo *a_stream, Maat_rule_t *p_result, int thread_seq);
int tsg_set_intercept_flow(Maat_rule_t *p_result, struct _traffic_info *traffic_info, int thread_seq);
+int tsg_set_statistic_opt(int value, enum _STATISTIC_OPT_TYPE type, int thread_seq);
#endif
diff --git a/src/tsg_entry.cpp b/src/tsg_entry.cpp
index 2f53b3b..40f543e 100644
--- a/src/tsg_entry.cpp
+++ b/src/tsg_entry.cpp
@@ -42,7 +42,7 @@ static __attribute__((__used__)) const char * GIT_VERSION_UNKNOWN = NULL;
#endif
-char TSG_MASTER_VERSION_20200604=0;
+char TSG_MASTER_VERSION_20200605=0;
const char *tsg_conffile="tsgconf/main.conf";
g_tsg_para_t g_tsg_para;
@@ -196,136 +196,6 @@ static int init_context(void **pme, tsg_protocol_t proto, struct Maat_rule_t *p_
return 0;
}
-#if 0
-static int master_method_type(struct streaminfo *a_stream, struct Maat_rule_t *p_result)
-{
- cJSON *item=NULL;
- cJSON *object=NULL;
- char *tmp_buff=NULL;
- int method_type=-1;
-
- if(p_result->serv_def_len<128)
- {
- object=cJSON_Parse(p_result->service_defined);
-
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_DEBUG,
- "DO_ACTION",
- "Hit policy_id: %d service: %d action: %d user_reagion: %s addr: %s",
- p_result->config_id,
- p_result->service_id,
- (unsigned char)p_result->action,
- p_result->service_defined,
- printaddr(&a_stream->addr, a_stream->threadnum)
- );
- }
- else
- {
- tmp_buff=(char *)calloc(1, p_result->serv_def_len+1);
- Maat_read_rule(g_tsg_maat_feather, p_result, MAAT_RULE_SERV_DEFINE, tmp_buff, p_result->serv_def_len);
- object=cJSON_Parse(tmp_buff);
-
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_DEBUG,
- "DO_ACTION",
- "Hit policy_id: %d service: %d action: %d user_reagion: %s addr: %s",
- p_result->config_id,
- p_result->service_id,
- (unsigned char)p_result->action,
- tmp_buff,
- printaddr(&a_stream->addr, a_stream->threadnum)
- );
- }
-
- if(object==NULL)
- {
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_FATAL,
- "DO_ACTION",
- "Hit policy_id: %d service: %d action: %d user_reagion: %s addr: %s",
- p_result->config_id,
- p_result->service_id,
- (unsigned char)p_result->action,
- (tmp_buff==NULL) ? p_result->service_defined : tmp_buff,
- printaddr(&a_stream->addr, a_stream->threadnum)
- );
-
- if(tmp_buff!=NULL)
- {
- free(tmp_buff);
- tmp_buff=NULL;
- }
-
- return -1;
- }
-
- item=cJSON_GetObjectItem(object, "method");
- if(item!=NULL)
- {
- method_type=tsg_get_method_id(item->valuestring);
- }
-
- if(tmp_buff!=NULL)
- {
- free(tmp_buff);
- tmp_buff=NULL;
- }
-
- cJSON_Delete(object);
- object=NULL;
-
- return method_type;
-}
-
-
-static int master_do_deny(struct streaminfo *a_stream, struct Maat_rule_t *p_result, int thread_seq)
-{
- int opt_value=0;
- int method_type=-1;
- struct rst_tcp_para rst_paras;
-
- method_type=master_method_type(a_stream, p_result);
- switch(method_type)
- {
- case TSG_METHOD_TYPE_DROP:
- opt_value=1;
- MESA_set_stream_opt(a_stream, MSO_DROP_STREAM, (void *)&opt_value, sizeof(opt_value));
- break;
- case TSG_METHOD_TYPE_BLOCK:
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_FATAL,
- "TSG_ACTION_DENY",
- "Unsupport block of deny, policy_id: %d service: %d action: %d addr: %s",
- p_result[0].config_id,
- p_result[0].service_id,
- (unsigned char)p_result[0].action,
- printaddr(&a_stream->addr, thread_seq)
- );
- //break; // not break
- case TSG_METHOD_TYPE_RESET:
- opt_value=1;
- MESA_set_stream_opt(a_stream, MSO_TCP_RST_REMEDY, (void *)&opt_value, sizeof(opt_value));
-
- rst_paras.dir=DIR_DOUBLE;
- rst_paras.rst_pkt_num=1;
- rst_paras.signature_seed1=65535;
- rst_paras.signature_seed2=13;
- rst_paras.th_flags=4;
- rst_paras.__pad_no_use=0;
- MESA_rst_tcp(a_stream, &rst_paras, sizeof(rst_paras));
-
- opt_value=1;
- MESA_set_stream_opt(a_stream, MSO_DROP_STREAM, (void *)&opt_value, sizeof(opt_value));
- MESA_set_stream_opt(a_stream, MSO_TIMEOUT, (void *)&g_tsg_para.timeout, sizeof(g_tsg_para.timeout));
- break;
- default:
- break;
- }
-
- return 0;
-}
-#endif
-
static char *schema_index2string(tsg_protocol_t proto)
{
char *schema_field_value=NULL;
@@ -754,48 +624,9 @@ extern "C" char TSG_MASTER_TCP_ENTRY(struct streaminfo *a_tcp, void **pme, int t
switch((unsigned char)p_result->action)
{
case TSG_ACTION_DENY:
- #if 0 /* support block/alert(deny), Do action in fw_http_plug */
- master_do_deny(a_tcp, p_result, thread_seq);
- master_send_log(a_tcp, p_result, 1, &identify_info, thread_seq);
- FS_operate(g_tsg_para.fs2_handle, g_tsg_para.fs2_field_id[TSG_FS2_DENY], 0, FS_OP_ADD, 1);
-
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_DEBUG,
- "DENY",
- "Hit deny policy, policy_id: %d service: %d action: %d addr: %s",
- p_result[0].config_id,
- p_result[0].service_id,
- (unsigned char)p_result[0].action,
- printaddr(&a_tcp->addr, thread_seq)
- );
-
- return APP_STATE_DROPPKT|APP_STATE_KILL_OTHER;
- #endif
+ /* support block/alert(deny), Do action in fw_http_plug */
break;
case TSG_ACTION_MONITOR:
- #if 0
- if(q_result!=NULL && (p_result==q_result))
- {
- init_context(pme, identify_info.proto, p_result, thread_seq);
- if(identify_info.proto>PROTO_UNKONWN && identify_info.proto<PROTO_MAX)
- {
- _context=(struct _master_context *)*pme;
- memcpy(_context->domain, identify_info.domain, identify_info.domain_len);
- _context->domain_len=identify_info.domain_len;
- }
-
- MESA_handle_runtime_log(g_tsg_para.logger,
- RLOG_LV_DEBUG,
- "MONITOR",
- "Hit monitor policy, policy_id: %d service: %d action: %d addr: %s",
- p_result[0].config_id,
- p_result[0].service_id,
- (unsigned char)p_result[0].action,
- printaddr(&a_tcp->addr, thread_seq)
- );
- state=APP_STATE_GIVEME;
- }
- #endif
break;
case TSG_ACTION_BYPASS:
init_context(pme, identify_info.proto, p_result, thread_seq);
@@ -821,8 +652,6 @@ extern "C" char TSG_MASTER_TCP_ENTRY(struct streaminfo *a_tcp, void **pme, int t
break;
case TSG_ACTION_INTERCEPT:
FS_operate(g_tsg_para.fs2_handle, g_tsg_para.fs2_field_id[TSG_FS2_INTERCEPT], 0, FS_OP_ADD, 1);
-
- //tsg_set_policy_flow(a_tcp, p_result, thread_seq);
priority_label=(policy_priority_label_t *)dictator_malloc(thread_seq, sizeof(policy_priority_label_t));
@@ -911,7 +740,6 @@ extern "C" char TSG_MASTER_UDP_ENTRY(struct streaminfo *a_udp, void **pme, int t
if(ret>0)
{
hit_num+=ret;
- //q_result=tsg_policy_decision_criteria(a_tcp, all_result, hit_num, NULL, thread_seq);
FS_operate(g_tsg_para.fs2_handle, g_tsg_para.fs2_field_id[TSG_FS2_HIT_ADDR], 0, FS_OP_ADD, 1);
}
@@ -961,13 +789,6 @@ extern "C" char TSG_MASTER_UDP_ENTRY(struct streaminfo *a_udp, void **pme, int t
switch((unsigned char)p_result->action)
{
case TSG_ACTION_DENY:
- #if 0
- int opt_value=1;
- MESA_set_stream_opt(a_udp, MSO_DROP_STREAM, (void *)&opt_value, sizeof(opt_value));
- FS_operate(g_tsg_para.fs2_handle, g_tsg_para.fs2_field_id[TSG_FS2_DENY], 0, FS_OP_ADD, 1);
-
- return APP_STATE_DROPME|APP_STATE_DROPPKT;
- #endif
break;
case TSG_ACTION_BYPASS:
init_context(pme, identify_info.proto, p_result, thread_seq);
@@ -993,10 +814,6 @@ extern "C" char TSG_MASTER_UDP_ENTRY(struct streaminfo *a_udp, void **pme, int t
state=APP_STATE_GIVEME|APP_STATE_KILL_OTHER;
break;
case TSG_ACTION_MONITOR:
- #if 0
- init_context(pme, identify_info.proto, p_result, thread_seq);
- state=APP_STATE_GIVEME;
- #endif
break;
case TSG_ACTION_INTERCEPT:
case TSG_ACTION_MANIPULATE:
diff --git a/src/tsg_entry.h b/src/tsg_entry.h
index 9b303a9..2cc2040 100644
--- a/src/tsg_entry.h
+++ b/src/tsg_entry.h
@@ -190,6 +190,11 @@ typedef enum _tsg_statis_field_id
STATIS_INTERCEPT_OUT_BYTES,
STATIS_INTERCEPT_IN_PACKETS,
STATIS_INTERCEPT_OUT_PACKETS,
+ STATIS_ALERT_BYTES,
+ STATIS_BLOCK_BYTES,
+ STATIS_PINNING_NUM,
+ STATIS_MAYBE_PINNING_NUM,
+ STATIS_NOT_PINNING_NUM,
STATIS_MAX
}tsg_statis_field_id_t;
@@ -207,6 +212,7 @@ typedef struct _tsg_statistic
int cycle;
int fs_line_id;
int fs_field_id[STATIS_MAX];
+ long long statistic_opt[_OPT_TYPE_MAX];
struct _traffic_info *traffic_info[TSG_ACTION_MAX+1];
struct _traffic_info default_total_info;
screen_stat_handle_t fs2_handle;
diff --git a/src/tsg_statistic.cpp b/src/tsg_statistic.cpp
index a0d75b8..80349a2 100644
--- a/src/tsg_statistic.cpp
+++ b/src/tsg_statistic.cpp
@@ -13,6 +13,24 @@
tsg_statis_para_t g_tsg_statis_para;
+int tsg_set_statistic_opt(int value, enum _STATISTIC_OPT_TYPE type, int thread_seq)
+{
+ switch(type)
+ {
+ case OPT_TYPE_ALERT_BYTES:
+ case OPT_TYPE_BLOCK_BYTES:
+ case OPT_TYPE_PINNING_YES:
+ case OPT_TYPE_PINNING_NOT:
+ case OPT_TYPE_PINNING_MAYBE:
+ atomic_add(&(g_tsg_statis_para.statistic_opt[type]), value);
+ break;
+ default:
+ break;
+ }
+
+ return 0;
+}
+
int tsg_set_intercept_flow(Maat_rule_t *p_result, struct _traffic_info *traffic_info, int thread_seq)
{
struct _traffic_info *_info=NULL;
@@ -235,6 +253,12 @@ static void *tsg_statistic_thread(void *arg)
_get_traffic_info(&total_traffic_info, &policy_traffic_info, &default_traffic_info);
_set_traffic_info(&default_traffic_info, NULL, TSG_ACTION_NONE, 1);
+ FS_operate(g_tsg_statis_para.fs2_handle, g_tsg_statis_para.fs_line_id, g_tsg_statis_para.fs_field_id[STATIS_ALERT_BYTES], FS_OP_SET, g_tsg_statis_para.statistic_opt[OPT_TYPE_ALERT_BYTES]);
+ FS_operate(g_tsg_statis_para.fs2_handle, g_tsg_statis_para.fs_line_id, g_tsg_statis_para.fs_field_id[STATIS_BLOCK_BYTES], FS_OP_SET, g_tsg_statis_para.statistic_opt[OPT_TYPE_BLOCK_BYTES]);
+ FS_operate(g_tsg_statis_para.fs2_handle, g_tsg_statis_para.fs_line_id, g_tsg_statis_para.fs_field_id[STATIS_PINNING_NUM], FS_OP_SET, g_tsg_statis_para.statistic_opt[OPT_TYPE_PINNING_YES]);
+ FS_operate(g_tsg_statis_para.fs2_handle, g_tsg_statis_para.fs_line_id, g_tsg_statis_para.fs_field_id[STATIS_MAYBE_PINNING_NUM], FS_OP_SET, g_tsg_statis_para.statistic_opt[OPT_TYPE_PINNING_MAYBE]);
+ FS_operate(g_tsg_statis_para.fs2_handle, g_tsg_statis_para.fs_line_id, g_tsg_statis_para.fs_field_id[STATIS_NOT_PINNING_NUM], FS_OP_SET, g_tsg_statis_para.statistic_opt[OPT_TYPE_PINNING_NOT]);
+
FS_passive_output(g_tsg_statis_para.fs2_handle);
sleep(g_tsg_statis_para.cycle);
@@ -330,6 +354,11 @@ int tsg_statistic_init(const char *conffile, void *logger)
g_tsg_statis_para.fs_field_id[STATIS_INTERCEPT_IN_PACKETS]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"intercept_in_packets");
g_tsg_statis_para.fs_field_id[STATIS_INTERCEPT_OUT_PACKETS]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"intercept_out_packets");
+ g_tsg_statis_para.fs_field_id[STATIS_ALERT_BYTES]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"alert_bytes");
+ g_tsg_statis_para.fs_field_id[STATIS_BLOCK_BYTES]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"block_bytes");
+ g_tsg_statis_para.fs_field_id[STATIS_PINNING_NUM]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"pinning_num");
+ g_tsg_statis_para.fs_field_id[STATIS_MAYBE_PINNING_NUM]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"maybe_pinning_num");
+ g_tsg_statis_para.fs_field_id[STATIS_NOT_PINNING_NUM]=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_COLUMN, FS_CALC_SPEED, (char *)"not_pinning_num");
g_tsg_statis_para.fs_line_id=FS_register(g_tsg_statis_para.fs2_handle, FS_STYLE_LINE, FS_CALC_CURRENT, (const char *)"TRAFFIC");