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
ce27c194
Commit
ce27c194
authored
Nov 05, 2016
by
Franco Fichtner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
firewall: rework bogons, use signatures, closes #1248
parent
23744c59
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
65 additions
and
81 deletions
+65
-81
rc.update_bogons
src/etc/rc.update_bogons
+65
-81
No files found.
src/etc/rc.update_bogons
View file @
ce27c194
#!/bin/sh
#!/bin/sh
# Global variables
v4url
=
"https://pkg.opnsense.org/bogons/fullbogons-ipv4.txt"
proc_error
=
""
v6url
=
"https://pkg.opnsense.org/bogons/fullbogons-ipv6.txt"
proc_error
=
# Download and extract if necessary
process_url
()
process_url
()
{
{
local
file
=
$1
local
file
=
$1
local
url
=
$2
local
url
=
$2
/usr/bin/fetch
-a
-T
30
-q
-o
${
file
}
.sig
"
${
url
}
.sig"
/usr/bin/fetch
-a
-T
30
-q
-o
${
file
}
"
${
url
}
"
if
[
!
-f
${
file
}
]
;
then
echo
"Could not download
${
url
}
"
| logger
proc_error
=
"true"
return
1
fi
/usr/bin/fetch
-a
-T
30
-q
-o
$file
"
${
url
}
"
if
opnsense-verify
-q
/tmp/bogons
;
then
echo
"Could not verify
${
url
}
"
| logger
proc_error
=
"true"
return
1
fi
if
[
!
-f
$file
]
;
then
return
0
echo
"Could not download
${
url
}
"
| logger
proc_error
=
"true"
fi
}
}
echo
"rc.update_bogons is starting up."
| logger
echo
"rc.update_bogons is starting up."
| logger
# Sleep for some time, unless an argument is specified.
# Sleep for some time, unless an argument is specified.
if
[
"
$1
"
=
"
"
]
;
then
if
[
-z
"
$1
"
]
;
then
# Grab a random value
# Grab a random value
value
=
`
od
-A
n
-d
-N2
/dev/random |
awk
'{ print $1 }'
`
value
=
`
od
-A
n
-d
-N2
/dev/random |
awk
'{ print $1 }'
`
echo
"rc.update_bogons is sleeping for
$value
"
| logger
echo
"rc.update_bogons is sleeping for
$value
"
| logger
...
@@ -29,80 +39,54 @@ fi
...
@@ -29,80 +39,54 @@ fi
echo
"rc.update_bogons is beginning the update cycle."
| logger
echo
"rc.update_bogons is beginning the update cycle."
| logger
v4url
=
"https://pkg.opnsense.org/bogons/fullbogons-ipv4.txt"
if
process_url /tmp/bogons
"
${
v4url
}
"
;
then
v6url
=
"https://pkg.opnsense.org/bogons/fullbogons-ipv6.txt"
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
process_url /tmp/bogons
"
${
v4url
}
"
ENTRIES_V4
=
`
pfctl
-vvsTables
|
awk
'/-\tbogons$/ {getline; print $2}'
`
process_url /tmp/bogonsv6
"
${
v6url
}
"
LINES_V4
=
`
wc
-l
/tmp/bogons |
awk
'{ print $1 }'
`
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V4
:-
0
}
+
LINES_V4
))
]
;
then
if
[
"
$proc_error
"
!=
""
]
;
then
# These bogons are removed as they are private. I'm not going
# Relaunch and sleep
# to question this now, adding a big WARNING instead. Here be
sh /usr/local/etc/rc.update_bogons &
# dragons...
exit
egrep
-v
"^100.64.0.0/10|^192.168.0.0/16|^172.16.0.0/12|^10.0.0.0/8"
/tmp/bogons
>
/usr/local/etc/bogons
RESULT
=
`
/sbin/pfctl
-t
bogons
-T
replace
-f
/usr/local/etc/bogons 2>&1
`
echo
"
$RESULT
"
|
awk
'{ print "Bogons V4 file downloaded: " $0 }'
| logger
else
echo
"Not updating IPv4 bogons (increase table-entries limit)"
| logger
fi
rm
/tmp/bogons
*
fi
fi
BOGON_V4_CKSUM
=
`
/usr/bin/fetch
-T
30
-q
-o
-
"
${
v4url
}
.md5"
|
awk
'{ print $4 }'
`
if
process_url /tmp/bogonsv6
"
${
v6url
}
"
;
then
ON_DISK_V4_CKSUM
=
`
md5 /tmp/bogons |
awk
'{ print $4 }'
`
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
BOGON_V6_CKSUM
=
`
/usr/bin/fetch
-T
30
-q
-o
-
"
${
v6url
}
.md5"
|
awk
'{ print $4 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
ON_DISK_V6_CKSUM
=
`
md5 /tmp/bogonsv6 |
awk
'{ print $4 }'
`
BOGONS_V6_TABLE_COUNT
=
`
pfctl
-sTables
|
grep
^bogonsv6
$
|
wc
-l
|
awk
'{ print $1 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
if
[
"
$BOGON_V4_CKSUM
"
=
"
$ON_DISK_V4_CKSUM
"
]
||
[
"
$BOGON_V6_CKSUM
"
=
"
$ON_DISK_V6_CKSUM
"
]
;
then
LINES_V6
=
`
wc
-l
/tmp/bogonsv6 |
awk
'{ print $1 }'
`
if
[
$BOGONS_V6_TABLE_COUNT
-gt
0
]
;
then
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
ENTRIES_V6
=
`
pfctl
-vvsTables
|
awk
'/-\tbogonsv6$/ {getline; print $2}'
`
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V6
:-
0
}
+
LINES_V6
))
]
;
then
if
[
"
$BOGON_V4_CKSUM
"
=
"
$ON_DISK_V4_CKSUM
"
]
;
then
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
RESULT
=
`
/sbin/pfctl
-t
bogonsv6
-T
replace
-f
/usr/local/etc/bogonsv6 2>&1
`
ENTRIES_V4
=
`
pfctl
-vvsTables
|
awk
'/-\tbogons$/ {getline; print $2}'
`
echo
"
$RESULT
"
|
awk
'{ print "Bogons V6 file downloaded: " $0 }'
| logger
LINES_V4
=
`
wc
-l
/tmp/bogons |
awk
'{ print $1 }'
`
else
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V4
:-
0
}
+
LINES_V4
))
]
;
then
echo
"Not saving or updating IPv6 bogons (increase table-entries limit)"
| logger
# These bogons are removed as they are private. I'm not going
fi
# to question this now, adding a big WARNING instead. Here be
else
# dragons...
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT+LINES_V6
))
]
;
then
egrep
-v
"^100.64.0.0/10|^192.168.0.0/16|^172.16.0.0/12|^10.0.0.0/8"
/tmp/bogons
>
/usr/local/etc/bogons
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
RESULT
=
`
/sbin/pfctl
-t
bogons
-T
replace
-f
/usr/local/etc/bogons 2>&1
`
echo
"Bogons V6 file downloaded but not updating IPv6 bogons table because IPv6 Allow is off"
| logger
echo
"
$RESULT
"
|
awk
'{ print "Bogons V4 file downloaded: " $0 }'
| logger
else
else
echo
"Not saving IPv6 bogons table (IPv6 Allow is off and table-entries limit is potentially too low)"
| logger
echo
"Not updating IPv4 bogons (increase table-entries limit)"
| logger
fi
fi
fi
rm
/tmp/bogons
rm
/tmp/bogonsv6
*
else
echo
"Could not download
${
v4url
}
(checksum mismatch)"
| logger
checksum_error
=
"true"
fi
if
[
"
$BOGON_V6_CKSUM
"
=
"
$ON_DISK_V6_CKSUM
"
]
;
then
BOGONS_V6_TABLE_COUNT
=
`
pfctl
-sTables
|
grep
^bogonsv6
$
|
wc
-l
|
awk
'{ print $1 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
LINES_V6
=
`
wc
-l
/tmp/bogonsv6 |
awk
'{ print $1 }'
`
if
[
$BOGONS_V6_TABLE_COUNT
-gt
0
]
;
then
ENTRIES_V6
=
`
pfctl
-vvsTables
|
awk
'/-\tbogonsv6$/ {getline; print $2}'
`
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V6
:-
0
}
+
LINES_V6
))
]
;
then
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
RESULT
=
`
/sbin/pfctl
-t
bogonsv6
-T
replace
-f
/usr/local/etc/bogonsv6 2>&1
`
echo
"
$RESULT
"
|
awk
'{ print "Bogons V6 file downloaded: " $0 }'
| logger
else
echo
"Not saving or updating IPv6 bogons (increase table-entries limit)"
| logger
fi
else
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT+LINES_V6
))
]
;
then
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
echo
"Bogons V6 file downloaded but not updating IPv6 bogons table because IPv6 Allow is off"
| logger
else
echo
"Not saving IPv6 bogons table (IPv6 Allow is off and table-entries limit is potentially too low)"
| logger
fi
fi
rm
/tmp/bogonsv6
else
echo
"Could not download
${
v6url
}
(checksum mismatch)"
| logger
checksum_error
=
"true"
fi
fi
fi
if
[
"
$checksum_error
"
!=
"
"
]
;
then
if
[
-n
"
${
proc_error
}
"
]
;
then
# Relaunch and sleep
# Relaunch and sleep
sh /usr/local/etc/rc.update_bogons &
sh /usr/local/etc/rc.update_bogons &
exit
exit
fi
fi
echo
"rc.update_bogons is ending the update cycle."
| logger
echo
"rc.update_bogons is ending the update cycle."
| logger
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