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
5d9fe425
Commit
5d9fe425
authored
Nov 07, 2016
by
Franco Fichtner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
firewall: final transition to lightweight bogon.txz set
parent
e9d9a983
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
54 additions
and
67 deletions
+54
-67
rc.update_bogons
src/etc/rc.update_bogons
+54
-67
No files found.
src/etc/rc.update_bogons
View file @
5d9fe425
...
@@ -9,34 +9,10 @@ if [ -n "${CORE_ABI}" -a -n "${SYS_ABI}" ]; then
...
@@ -9,34 +9,10 @@ if [ -n "${CORE_ABI}" -a -n "${SYS_ABI}" ]; then
URL
=
"
${
URL
}
/
${
SYS_ABI
}
/
${
CORE_ABI
}
"
URL
=
"
${
URL
}
/
${
SYS_ABI
}
/
${
CORE_ABI
}
"
fi
fi
URL4
=
"
${
URL
}
/bogons/fullbogons-ipv4.txt"
URL
=
"
${
URL
}
/sets/bogons.txz"
URL6
=
"
${
URL
}
/bogons/fullbogons-ipv6.txt"
proc_error
=
proc_error
=
process_url
()
{
local
file
=
$1
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
if
!
opnsense-verify
-q
${
file
}
;
then
echo
"Could not verify
${
url
}
"
| logger
proc_error
=
"true"
return
1
fi
return
0
}
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.
...
@@ -49,54 +25,65 @@ fi
...
@@ -49,54 +25,65 @@ fi
echo
"rc.update_bogons is beginning the update cycle."
| logger
echo
"rc.update_bogons is beginning the update cycle."
| logger
if
process_url /tmp/bogons
"
${
URL4
}
"
;
then
rm
-rf
/tmp/bogons
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
mkdir
-p
/tmp/bogons
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
ENTRIES_V4
=
`
pfctl
-vvsTables
|
awk
'/-\tbogons$/ {getline; print $2}'
`
fetch
-a
-T
30
-q
-o
/tmp/bogons/bogons.txz.sig
"
${
URL
}
.sig"
LINES_V4
=
`
wc
-l
/tmp/bogons |
awk
'{ print $1 }'
`
fetch
-a
-T
30
-q
-o
/tmp/bogons/bogons.txz
"
${
URL
}
"
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V4
:-
0
}
+
LINES_V4
))
]
;
then
if
[
!
-f
/tmp/bogons/bogons.txz
]
;
then
echo
"Could not download
${
URL
}
"
| logger
proc_error
=
"true"
elif
!
opnsense-verify
-q
/tmp/bogons/bogons.txz
;
then
echo
"Could not verify
${
URL
}
"
| logger
proc_error
=
"true"
elif
!
tar
-C
/tmp/bogons
-xJf
/tmp/bogons/bogons.txz
;
then
echo
"Could not extract
${
URL
}
"
| logger
proc_error
=
"true"
fi
if
[
-n
"
${
proc_error
}
"
]
;
then
# Relaunch and sleep
sh /usr/local/etc/rc.update_bogons &
exit
fi
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
ENTRIES_V4
=
`
pfctl
-vvsTables
|
awk
'/-\tbogons$/ {getline; print $2}'
`
LINES_V4
=
`
wc
-l
/tmp/bogons/fullbogons-ipv4.txt |
awk
'{ print $1 }'
`
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V4
:-
0
}
+
LINES_V4
))
]
;
then
# These bogons are removed as they are private. I'm not going
# These bogons are removed as they are private. I'm not going
# to question this now, adding a big WARNING instead. Here be
# to question this now, adding a big WARNING instead. Here be
# dragons...
# dragons...
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
-v
"^100.64.0.0/10|^192.168.0.0/16|^172.16.0.0/12|^10.0.0.0/8"
/tmp/bogons/fullbogons-ipv4.txt
>
/usr/local/etc/bogons
RESULT
=
`
/sbin/pfctl
-t
bogons
-T
replace
-f
/usr/local/etc/bogons 2>&1
`
RESULT
=
`
/sbin/pfctl
-t
bogons
-T
replace
-f
/usr/local/etc/bogons 2>&1
`
echo
"
$RESULT
"
|
awk
'{ print "Bogons V4 file downloaded: " $0 }'
| logger
echo
"
$RESULT
"
|
awk
'{ print "Bogons V4 file downloaded: " $0 }'
| logger
else
else
echo
"Not updating IPv4 bogons (increase table-entries limit)"
| logger
echo
"Not updating IPv4 bogons (increase table-entries limit)"
| logger
fi
rm
/tmp/bogons
*
fi
fi
if
process_url /tmp/bogonsv6
"
${
URL6
}
"
;
then
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
ENTRIES_MAX
=
`
pfctl
-s
memory |
awk
'/table-entries/ { print $4 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
BOGONS_V6_TABLE_COUNT
=
`
pfctl
-sTables
|
grep
^bogonsv6
$
|
wc
-l
|
awk
'{ print $1 }'
`
BOGONS_V6_TABLE_COUNT
=
`
pfctl
-sTables
|
grep
^bogonsv6
$
|
wc
-l
|
awk
'{ print $1 }'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
ENTRIES_TOT
=
`
pfctl
-vvsTables
|
awk
'/Addresses/ {s+=$2}; END {print s}'
`
LINES_V6
=
`
wc
-l
/tmp/bogons/fullbogons-ipv6.txt |
awk
'{ print $1 }'
`
LINES_V6
=
`
wc
-l
/tmp/bogonsv6 |
awk
'{ print $1 }'
`
if
[
$BOGONS_V6_TABLE_COUNT
-gt
0
]
;
then
if
[
$BOGONS_V6_TABLE_COUNT
-gt
0
]
;
then
ENTRIES_V6
=
`
pfctl
-vvsTables
|
awk
'/-\tbogonsv6$/ {getline; print $2}'
`
ENTRIES_V6
=
`
pfctl
-vvsTables
|
awk
'/-\tbogonsv6$/ {getline; print $2}'
`
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V6
:-
0
}
+
LINES_V6
))
]
;
then
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT-
${
ENTRIES_V6
:-
0
}
+
LINES_V6
))
]
;
then
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
egrep
-iv
"^fc00::/7"
/tmp/bogons/fullbogons-ipv6.txt
>
/usr/local/etc/bogonsv6
RESULT
=
`
/sbin/pfctl
-t
bogonsv6
-T
replace
-f
/usr/local/etc/bogonsv6 2>&1
`
RESULT
=
`
/sbin/pfctl
-t
bogonsv6
-T
replace
-f
/usr/local/etc/bogonsv6 2>&1
`
echo
"
$RESULT
"
|
awk
'{ print "Bogons V6 file downloaded: " $0 }'
| logger
echo
"
$RESULT
"
|
awk
'{ print "Bogons V6 file downloaded: " $0 }'
| logger
else
else
echo
"Not saving or updating IPv6 bogons (increase table-entries limit)"
| logger
echo
"Not saving or updating IPv6 bogons (increase table-entries limit)"
| logger
fi
fi
else
else
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT+LINES_V6
))
]
;
then
if
[
$ENTRIES_MAX
-gt
$((
2
*
ENTRIES_TOT+LINES_V6
))
]
;
then
egrep
-iv
"^fc00::/7"
/tmp/bogonsv6
>
/usr/local/etc/bogonsv6
egrep
-iv
"^fc00::/7"
/tmp/bogons/fullbogons-ipv6.txt
>
/usr/local/etc/bogonsv6
echo
"Bogons V6 file downloaded but not updating IPv6 bogons table because IPv6 Allow is off"
| logger
echo
"Bogons V6 file downloaded but not updating IPv6 bogons table because IPv6 Allow is off"
| logger
else
else
echo
"Not saving IPv6 bogons table (IPv6 Allow is off and table-entries limit is potentially too low)"
| logger
echo
"Not saving IPv6 bogons table (IPv6 Allow is off and table-entries limit is potentially too low)"
| logger
fi
fi
fi
rm
/tmp/bogonsv6
*
fi
if
[
-n
"
${
proc_error
}
"
]
;
then
# Relaunch and sleep
sh /usr/local/etc/rc.update_bogons &
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