]> git.donarmstrong.com Git - dsa-puppet.git/blob - modules/xinetd/manifests/service.pp
5a70318ffae9e21d24d042983fcb6819c83f9a59
[dsa-puppet.git] / modules / xinetd / manifests / service.pp
1 define xinetd::service (
2         $id,
3         $server,
4         $port,
5         $bind='',
6         $socket_type=stream,
7         $protocol=tcp,
8         $flags=IPv6,
9         $wait=no,
10         $user=root,
11         $server_args='',
12         $nice=10,
13         $instances=100,
14         $per_source=3,
15         $cps='0 0',
16         $ensure=present,
17         $ferm=true
18 ) {
19         include xinetd
20
21         $noop = $::hostname ? {
22                 villa    => false,
23                 lobos    => false,
24                 schein   => false,
25                 steffani => false,
26                 wieck    => false,
27                 default  => true
28         }
29
30         case $ensure {
31                 present,absent,file: {}
32                 default: { fail("Invalid ensure for '$name'") }
33         }
34
35         if $ferm {
36                 @ferm::rule { "dsa-xinetd-${name}":
37                         description => "Allow traffic to ${port}",
38                         rule        => "&SERVICE(${protocol}, ${port})"
39                 }
40         }
41
42         file { "/etc/xinetd.d/${name}":
43                 ensure  => $ensure,
44                 noop    => $noop,
45                 content => template('xinetd/service.erb'),
46                 notify  => Service['xinetd'],
47                 require => Package['xinetd'],
48         }
49 }