/src/ntopng/include/flow_alerts/ElephantFlowAlert.h
Line | Count | Source |
1 | | /* |
2 | | * |
3 | | * (C) 2013-24 - ntop.org |
4 | | * |
5 | | * |
6 | | * This program is free software; you can redistribute it and/or modify |
7 | | * it under the terms of the GNU General Public License as published by |
8 | | * the Free Software Foundation; either version 3 of the License, or |
9 | | * (at your option) any later version. |
10 | | * |
11 | | * This program is distributed in the hope that it will be useful, |
12 | | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 | | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
14 | | * GNU General Public License for more details. |
15 | | * |
16 | | * You should have received a copy of the GNU General Public License |
17 | | * along with this program; if not, write to the Free Software Foundation, |
18 | | * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
19 | | * |
20 | | */ |
21 | | |
22 | | #ifndef _ELEPHANT_FLOW_ALERT_H_ |
23 | | #define _ELEPHANT_FLOW_ALERT_H_ |
24 | | |
25 | | #include "ntop_includes.h" |
26 | | |
27 | | class ElephantFlowAlert : public FlowAlert { |
28 | | private: |
29 | | u_int64_t l2r_th, r2l_th; |
30 | | |
31 | | ndpi_serializer *getAlertJSON(ndpi_serializer *serializer); |
32 | | |
33 | | public: |
34 | 2 | static FlowAlertType getClassType() { |
35 | 2 | return {NDPI_NO_RISK, flow_alert_elephant_flow, alert_category_security}; |
36 | 2 | } |
37 | 2 | static u_int8_t getDefaultScore() { return SCORE_LEVEL_WARNING; }; |
38 | | |
39 | 0 | inline u_int64_t get_l2r_threshold() { return l2r_th; }; |
40 | 0 | inline u_int64_t get_r2l_threshold() { return r2l_th; }; |
41 | | |
42 | | ElephantFlowAlert(FlowCheck *c, Flow *f, u_int64_t _l2r_th, u_int64_t _r2l_th) |
43 | 0 | : FlowAlert(c, f) { |
44 | 0 | l2r_th = _l2r_th; |
45 | 0 | r2l_th = _r2l_th; |
46 | 0 | setAlertScore(getDefaultScore()); |
47 | 0 | }; |
48 | 0 | ~ElephantFlowAlert(){}; |
49 | | |
50 | 0 | FlowAlertType getAlertType() const { return getClassType(); } |
51 | | }; |
52 | | |
53 | | #endif /* _ELEPHANT_FLOW_ALERT_H_ */ |