Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
OpnSense
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
OpnSense
Commits
9f2d34e7
Commit
9f2d34e7
authored
Jul 01, 2015
by
Ad Schellevis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(ids) refactor static paths into single definition
parent
f45171e7
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
20 additions
and
13 deletions
+20
-13
installRules.py
src/opnsense/scripts/suricata/installRules.py
+5
-4
__init__.py
src/opnsense/scripts/suricata/lib/__init__.py
+3
-0
rulecache.py
src/opnsense/scripts/suricata/lib/rulecache.py
+4
-3
listAlertLogs.py
src/opnsense/scripts/suricata/listAlertLogs.py
+2
-1
queryAlertLog.py
src/opnsense/scripts/suricata/queryAlertLog.py
+3
-2
rule-updater.py
src/opnsense/scripts/suricata/rule-updater.py
+3
-3
No files found.
src/opnsense/scripts/suricata/installRules.py
View file @
9f2d34e7
...
@@ -31,14 +31,15 @@
...
@@ -31,14 +31,15 @@
Install suricata ruleset into opnsense.rules directory
Install suricata ruleset into opnsense.rules directory
"""
"""
import
os.path
import
os.path
import
lib.rulecache
from
ConfigParser
import
ConfigParser
from
ConfigParser
import
ConfigParser
import
lib.rulecache
from
lib
import
rule_source_directory
RuleCache
=
lib
.
rulecache
.
RuleCache
()
RuleCache
=
lib
.
rulecache
.
RuleCache
()
rule_config_fn
=
(
'
%
s../rules.config'
%
RuleCache
.
rule_source_dir
)
rule_config_fn
=
(
'
%
s../rules.config'
%
rule_source_directory
)
rule_target_dir
=
(
'
%
s../opnsense.rules'
%
RuleCache
.
rule_source_dir
)
rule_target_dir
=
(
'
%
s../opnsense.rules'
%
rule_source_directory
)
rule_yaml_list
=
(
'
%
s../installed_rules.yaml'
%
RuleCache
.
rule_source_dir
)
rule_yaml_list
=
(
'
%
s../installed_rules.yaml'
%
rule_source_directory
)
# parse OPNsense rule config
# parse OPNsense rule config
rule_updates
=
{}
rule_updates
=
{}
...
...
src/opnsense/scripts/suricata/lib/__init__.py
View file @
9f2d34e7
...
@@ -27,3 +27,6 @@
...
@@ -27,3 +27,6 @@
POSSIBILITY OF SUCH DAMAGE.
POSSIBILITY OF SUCH DAMAGE.
"""
"""
# define paths used by suricata
rule_source_directory
=
'/usr/local/etc/suricata/rules/'
suricata_alert_log
=
'/var/log/suricata/eve.json'
src/opnsense/scripts/suricata/lib/rulecache.py
View file @
9f2d34e7
...
@@ -34,20 +34,21 @@ import os.path
...
@@ -34,20 +34,21 @@ import os.path
import
glob
import
glob
import
sqlite3
import
sqlite3
import
shlex
import
shlex
from
lib
import
rule_source_directory
class
RuleCache
(
object
):
class
RuleCache
(
object
):
"""
"""
"""
"""
def
__init__
(
self
):
def
__init__
(
self
):
# suricata rule settings, source directory and cache json file to use
# suricata rule settings, source directory and cache json file to use
self
.
rule_source_dir
=
'/usr/local/etc/suricata/rules/'
self
.
cachefile
=
'
%
srules.sqlite'
%
rule_source_directory
self
.
cachefile
=
'
%
srules.sqlite'
%
self
.
rule_source_dir
self
.
_rule_fields
=
[
'sid'
,
'msg'
,
'classtype'
,
'rev'
,
'gid'
,
'source'
,
'enabled'
,
'reference'
]
self
.
_rule_fields
=
[
'sid'
,
'msg'
,
'classtype'
,
'rev'
,
'gid'
,
'source'
,
'enabled'
,
'reference'
]
self
.
_rule_defaults
=
{
'classtype'
:
'##none##'
}
self
.
_rule_defaults
=
{
'classtype'
:
'##none##'
}
def
listLocal
(
self
):
def
listLocal
(
self
):
all_rule_files
=
[]
all_rule_files
=
[]
for
filename
in
glob
.
glob
(
'
%
s*.rules'
%
(
self
.
rule_source_dir
)):
for
filename
in
glob
.
glob
(
'
%
s*.rules'
%
(
rule_source_directory
)):
all_rule_files
.
append
(
filename
)
all_rule_files
.
append
(
filename
)
return
all_rule_files
return
all_rule_files
...
...
src/opnsense/scripts/suricata/listAlertLogs.py
View file @
9f2d34e7
...
@@ -33,9 +33,10 @@
...
@@ -33,9 +33,10 @@
import
os
import
os
import
glob
import
glob
import
ujson
import
ujson
from
lib
import
suricata_alert_log
result
=
[]
result
=
[]
for
filename
in
sorted
(
glob
.
glob
(
'
/var/log/suricata/eve.json*'
)):
for
filename
in
sorted
(
glob
.
glob
(
'
%
s*'
%
suricata_alert_log
)):
row
=
dict
()
row
=
dict
()
row
[
'modified'
]
=
os
.
stat
(
filename
)
.
st_mtime
row
[
'modified'
]
=
os
.
stat
(
filename
)
.
st_mtime
row
[
'filename'
]
=
filename
.
split
(
'/'
)[
-
1
]
row
[
'filename'
]
=
filename
.
split
(
'/'
)[
-
1
]
...
...
src/opnsense/scripts/suricata/queryAlertLog.py
View file @
9f2d34e7
...
@@ -37,6 +37,7 @@ import shlex
...
@@ -37,6 +37,7 @@ import shlex
import
ujson
import
ujson
from
lib.log
import
reverse_log_reader
from
lib.log
import
reverse_log_reader
from
lib.params
import
updateParams
from
lib.params
import
updateParams
from
lib
import
suricata_alert_log
# handle parameters
# handle parameters
parameters
=
{
'limit'
:
'0'
,
'offset'
:
'0'
,
'filter'
:
''
,
'fileid'
:
''
}
parameters
=
{
'limit'
:
'0'
,
'offset'
:
'0'
,
'filter'
:
''
,
'fileid'
:
''
}
...
@@ -44,9 +45,9 @@ updateParams(parameters)
...
@@ -44,9 +45,9 @@ updateParams(parameters)
# choose logfile by number
# choose logfile by number
if
parameters
[
'fileid'
]
.
isdigit
():
if
parameters
[
'fileid'
]
.
isdigit
():
suricata_log
=
'
/var/log/suricata/eve.json.
%
d'
%
int
(
parameters
[
'fileid'
]
)
suricata_log
=
'
%
s.
%
d'
%
(
suricata_alert_log
,
int
(
parameters
[
'fileid'
])
)
else
:
else
:
suricata_log
=
'/var/log/suricata/eve.json'
suricata_log
=
suricata_alert_log
if
parameters
[
'limit'
]
.
isdigit
():
if
parameters
[
'limit'
]
.
isdigit
():
limit
=
int
(
parameters
[
'limit'
])
limit
=
int
(
parameters
[
'limit'
])
...
...
src/opnsense/scripts/suricata/rule-updater.py
View file @
9f2d34e7
...
@@ -36,6 +36,7 @@ import fcntl
...
@@ -36,6 +36,7 @@ import fcntl
from
ConfigParser
import
ConfigParser
from
ConfigParser
import
ConfigParser
from
lib
import
metadata
from
lib
import
metadata
from
lib
import
downloader
from
lib
import
downloader
from
lib
import
rule_source_directory
# check for a running update process, this may take a while so it's better to check...
# check for a running update process, this may take a while so it's better to check...
try
:
try
:
...
@@ -49,7 +50,6 @@ if __name__ == '__main__':
...
@@ -49,7 +50,6 @@ if __name__ == '__main__':
# load list of configured rules from generated config
# load list of configured rules from generated config
enabled_rulefiles
=
[]
enabled_rulefiles
=
[]
updater_conf
=
'/usr/local/etc/suricata/rule-updater.config'
updater_conf
=
'/usr/local/etc/suricata/rule-updater.config'
target_directory
=
'/usr/local/etc/suricata/rules/'
if
os
.
path
.
exists
(
updater_conf
):
if
os
.
path
.
exists
(
updater_conf
):
cnf
=
ConfigParser
()
cnf
=
ConfigParser
()
cnf
.
read
(
updater_conf
)
cnf
.
read
(
updater_conf
)
...
@@ -59,7 +59,7 @@ if __name__ == '__main__':
...
@@ -59,7 +59,7 @@ if __name__ == '__main__':
# download / remove rules
# download / remove rules
md
=
metadata
.
Metadata
()
md
=
metadata
.
Metadata
()
dl
=
downloader
.
Downloader
(
target_dir
=
target
_directory
)
dl
=
downloader
.
Downloader
(
target_dir
=
rule_source
_directory
)
for
rule
in
md
.
list_rules
():
for
rule
in
md
.
list_rules
():
if
'url'
in
rule
[
'source'
]:
if
'url'
in
rule
[
'source'
]:
download_proto
=
str
(
rule
[
'source'
][
'url'
])
.
split
(
':'
)[
0
]
.
lower
()
download_proto
=
str
(
rule
[
'source'
][
'url'
])
.
split
(
':'
)[
0
]
.
lower
()
...
@@ -67,7 +67,7 @@ if __name__ == '__main__':
...
@@ -67,7 +67,7 @@ if __name__ == '__main__':
if
rule
[
'filename'
]
not
in
enabled_rulefiles
:
if
rule
[
'filename'
]
not
in
enabled_rulefiles
:
try
:
try
:
# remove configurable but unselected file
# remove configurable but unselected file
os
.
remove
((
'
%
s/
%
s'
%
(
target
_directory
,
rule
[
'filename'
]))
.
replace
(
'//'
,
'/'
))
os
.
remove
((
'
%
s/
%
s'
%
(
rule_source
_directory
,
rule
[
'filename'
]))
.
replace
(
'//'
,
'/'
))
except
:
except
:
pass
pass
else
:
else
:
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment