/src/ntopng/include/flow_alerts/IECInvalidCommandTransitionAlert.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 _IEC_INVALID_COMMAND_TRANSITION_ALERT_H_ |
23 | | #define _IEC_INVALID_COMMAND_TRANSITION_ALERT_H_ |
24 | | |
25 | | #include "ntop_includes.h" |
26 | | |
27 | | class IECInvalidCommandTransitionAlert : public FlowAlert { |
28 | | private: |
29 | | u_int32_t packet_epoch; |
30 | | u_int32_t transitions_m_to_c, transitions_c_to_m, transitions_c_to_c; |
31 | | |
32 | | ndpi_serializer *getAlertJSON(ndpi_serializer *serializer); |
33 | | |
34 | | public: |
35 | 2 | static FlowAlertType getClassType() { |
36 | 2 | return {NDPI_NO_RISK, flow_alert_iec_invalid_command_transition, alert_category_security}; |
37 | 2 | } |
38 | 2 | static u_int8_t getDefaultScore() { return SCORE_LEVEL_NOTICE; }; |
39 | | |
40 | 0 | inline u_int32_t get_packet_epoch() { return packet_epoch; }; |
41 | 0 | inline u_int32_t get_transitions_m_to_c() { return transitions_m_to_c; }; |
42 | 0 | inline u_int32_t get_transitions_c_to_m() { return transitions_c_to_m; }; |
43 | 0 | inline u_int32_t get_transitions_c_to_c() { return transitions_c_to_c; }; |
44 | | |
45 | | IECInvalidCommandTransitionAlert(FlowCheck *c, Flow *f, struct timeval *_time, |
46 | | u_int32_t _transitions_m_to_c, |
47 | | u_int32_t _transitions_c_to_m, |
48 | | u_int32_t _transitions_c_to_c) |
49 | 0 | : FlowAlert(c, f) { |
50 | 0 | transitions_m_to_c = _transitions_m_to_c; |
51 | 0 | transitions_c_to_m = _transitions_c_to_m; |
52 | 0 | transitions_c_to_c = _transitions_c_to_c; |
53 | 0 | packet_epoch = _time->tv_sec; |
54 | 0 | setAlertScore(getDefaultScore()); |
55 | 0 | }; |
56 | 0 | ~IECInvalidCommandTransitionAlert(){}; |
57 | | |
58 | 0 | bool autoAck() const { return false; }; |
59 | | |
60 | 0 | FlowAlertType getAlertType() const { return getClassType(); } |
61 | | }; |
62 | | |
63 | | #endif /* _IEC_INVALID_COMMAND_TRANSITION_ALERT_H_ */ |