aboutsummaryrefslogtreecommitdiff
path: root/manifests
diff options
context:
space:
mode:
authorThore Bödecker <me@foxxx0.de>2020-06-25 17:07:07 +0200
committerThore Bödecker <me@foxxx0.de>2020-06-30 18:05:47 +0200
commit856eca997158141e084b9e8c2002d7491a4720a1 (patch)
tree52103dc1a6e99ba629df558dfb0302840e78f834 /manifests
parent945faf68871dfdb9f9521cdadcdecfef65634d4b (diff)
downloadpuppet-ferm-856eca997158141e084b9e8c2002d7491a4720a1.tar.gz
puppet-ferm-856eca997158141e084b9e8c2002d7491a4720a1.tar.bz2
use proper types and validations for port handling
- implement validations for port ranges - add test cases for these scenarios
Diffstat (limited to 'manifests')
-rw-r--r--manifests/rule.pp46
1 files changed, 40 insertions, 6 deletions
diff --git a/manifests/rule.pp b/manifests/rule.pp
index e44d04a..f239402 100644
--- a/manifests/rule.pp
+++ b/manifests/rule.pp
@@ -59,8 +59,8 @@ define ferm::rule (
String $comment = $name,
Optional[Ferm::Actions] $action = undef,
Optional[Ferm::Policies] $policy = undef,
- Optional[Variant[Stdlib::Port,Array[Stdlib::Port]]] $dport = undef,
- Optional[Variant[Stdlib::Port,Array[Stdlib::Port]]] $sport = undef,
+ Optional[Ferm::Port] $dport = undef,
+ Optional[Ferm::Port] $sport = undef,
Optional[Variant[Array, String[1]]] $saddr = undef,
Optional[Variant[Array, String[1]]] $daddr = undef,
Optional[String[1]] $proto_options = undef,
@@ -95,26 +95,60 @@ define ferm::rule (
String => "proto ${proto}",
}
- # ferm supports implicit multiport using the "dports" shortcut
+
if $dport =~ Array {
$dports = join($dport, ' ')
$dport_real = "mod multiport destination-ports (${dports})"
} elsif $dport =~ Integer {
$dport_real = "dport ${dport}"
- } else {
+ } elsif String($dport) =~ /^\d*:\d+$/ {
+ $portrange = split($dport, /:/)
+ $lower = $portrange[0] ? {
+ '' => 0,
+ default => Integer($portrange[0]),
+ }
+ $upper = Integer($portrange[1])
+ assert_type(Tuple[Stdlib::Port, Stdlib::Port], [$lower, $upper]) |$expected, $actual| {
+ fail("The data type should be \'${expected}\', not \'${actual}\'. The data is [${lower}, ${upper}])}.")
+ ''
+ }
+ if $lower > $upper {
+ fail("Lower port number of the port range is larger than upper. ${lower}:${upper}")
+ }
+ $dport_real = "dport ${lower}:${upper}"
+ } elsif String($dport) == '' {
$dport_real = ''
+ } else {
+ fail("invalid destination-port: ${dport}")
}
- # ferm supports implicit multiport using the "sports" shortcut
if $sport =~ Array {
$sports = join($sport, ' ')
$sport_real = "mod multiport source-ports (${sports})"
} elsif $sport =~ Integer {
$sport_real = "sport ${sport}"
- } else {
+ } elsif String($sport) =~ /^\d*:\d+$/ {
+ $portrange = split($sport, /:/)
+ $lower = $portrange[0] ? {
+ '' => 0,
+ default => Integer($portrange[0]),
+ }
+ $upper = Integer($portrange[1])
+ assert_type(Tuple[Stdlib::Port, Stdlib::Port], [$lower, $upper]) |$expected, $actual| {
+ fail("The data type should be \'${expected}\', not \'${actual}\'. The data is [${lower}, ${upper}])}.")
+ ''
+ }
+ if $lower > $upper {
+ fail("Lower port number of the port range is larger than upper. ${lower}:${upper}")
+ }
+ $sport_real = "sport ${lower}:${upper}"
+ } elsif String($sport) == '' {
$sport_real = ''
+ } else {
+ fail("invalid source-port: ${sport}")
}
+
if $saddr =~ Array {
assert_type(Array[Stdlib::IP::Address], flatten($saddr)) |$expected, $actual| {
fail( "The data type should be \'${expected}\', not \'${actual}\'. The data is ${flatten($saddr)}." )