forked from stratosphereips/StratosphereLinuxIPS
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathslips.py
More file actions
executable file
·72 lines (60 loc) · 2.32 KB
/
slips.py
File metadata and controls
executable file
·72 lines (60 loc) · 2.32 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/bin/env python3
# Stratosphere Linux IPS. A machine-learning Intrusion Detection System
# Copyright (C) 2021 Sebastian Garcia
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
# Contact: eldraco@gmail.com, sebastian.garcia@agents.fel.cvut.cz, stratosphere@aic.fel.cvut.cz
from __future__ import print_function
import sys
import os
import time
import warnings
# Ignore warnings on CPU from tensorflow
os.environ['TF_CPP_MIN_LOG_LEVEL'] = '2'
# Ignore warnings in general
warnings.filterwarnings('ignore')
####################
# Main
####################
if __name__ == '__main__':
if sys.version_info[0] < 3:
sys.exit("Slips can only run on python3+ .. Stopping.")
from slips.main import Main
from slips.daemon import Daemon
slips = Main()
# checker = Checker(slips)
# checker.check_python_version()
if slips.args.stopdaemon:
# -S is provided
daemon = Daemon(slips)
if not daemon.pid:
# pidfile doesn't exist
print("Trying to stop Slips daemon.\n Daemon is not running.")
else:
daemon.stop()
# it takes about 5 seconds for the stop_slips msg
# to arrive in the channel, so give slips time to stop
time.sleep(3)
print('Daemon stopped.')
elif slips.args.daemon:
daemon = Daemon(slips)
if daemon.pid is not None:
print('pidfile already exists. Daemon already running?'
.format(daemon.pidfile))
else:
print('Slips daemon started.')
daemon.start()
else:
# interactive mode
slips.start()
slips.cpu_profiler_release()
slips.memory_profiler_release()