aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--manifests/vserver.pp44
1 files changed, 31 insertions, 13 deletions
diff --git a/manifests/vserver.pp b/manifests/vserver.pp
index 105d5e3..968e949 100644
--- a/manifests/vserver.pp
+++ b/manifests/vserver.pp
@@ -33,7 +33,7 @@ define vs_create($in_domain, $legacy = false, $distro = 'etch') {
# ensure: present, stopped, running
-define vserver($ensure, $context, $in_domain = '', $mark = '', $legacy = false) {
+define vserver($ensure, $context, $in_domain = '', $mark = '', $legacy = false, $distro = '') {
case $in_domain { '': {}
default: { err("${fqdn}: vserver ${name} uses deprecated \$in_domain" ) }
@@ -48,9 +48,10 @@ define vserver($ensure, $context, $in_domain = '', $mark = '', $legacy = false)
# TODO: wasn't there a syntax for using arrays as case selectors??
case $ensure {
- present: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, } }
- running: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, } }
- stopped: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, } }
+ present: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, distro => $distro, } }
+ running: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, distro => $distro, } }
+ stopped: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, distro => $distro, } }
+ absent: { vs_create{$name: in_domain => $in_domain, legacy => $legacy, distro => $distro, } }
default: { err("${fqdn}: vserver(${vs_name}): unknown ensure '${ensure}'") }
}
@@ -79,15 +80,16 @@ define vserver($ensure, $context, $in_domain = '', $mark = '', $legacy = false)
}
case $ensure {
- stopped: {
- exec { "vserver ${vs_name} stop":
- onlyif => "test -e \$(readlink -f /etc/vservers/${vs_name}/run || echo /doesntexist )",
- require => Exec["vs_create_${vs_name}"],
- # fake the restart exec in the stopped case, so the dependencies are fulfilled
- alias => "vs_restart_${vs_name}",
- }
- file { $mark_file: ensure => absent, }
- }
+
+
+ present: {
+ # don't start or stop the vserver, just make sure it exists, we just run a dummy status test here
+ exec { "vserver ${vs_name} status":
+ require => Exec["vs_create_${vs_name}"],
+ alias => "vs_restart_${vs_name}",
+ }
+ }
+
running: {
exec { "vserver ${vs_name} start":
unless => "test -e \$(readlink -f /etc/vservers/${vs_name}/run)",
@@ -114,6 +116,22 @@ define vserver($ensure, $context, $in_domain = '', $mark = '', $legacy = false)
}
}
}
+
+ stopped: {
+ exec { "vserver ${vs_name} stop":
+ onlyif => "test -e \$(readlink -f /etc/vservers/${vs_name}/run || echo /doesntexist )",
+ require => Exec["vs_create_${vs_name}"],
+ # fake the restart exec in the stopped case, so the dependencies are fulfilled
+ alias => "vs_restart_${vs_name}",
+ }
+ file { $mark_file: ensure => absent, }
+ }
+
+ absent: {
+ exec { "vserver ${vs_name} delete":
+ onlyif => "test -e \$(readlink -f /etc/vservers/${vs_name}/run || echo /doesntexist )",
+ }
+ }
}
}