From 1564ca8593730f0cd5f4d69dcf5a860f73efccb4 Mon Sep 17 00:00:00 2001 From: Silvio Rhatto Date: Fri, 11 Sep 2015 22:02:36 -0300 Subject: Rename vserver to virtual --- manifests/base/virtual.pp | 35 ++++++ manifests/base/vserver.pp | 35 ------ manifests/role/nas/virtual.pp | 5 + manifests/role/nas/vserver.pp | 5 - manifests/role/virtual.pp | 3 + manifests/role/vserver.pp | 3 - manifests/subsystem/virtual/instance.pp | 207 ++++++++++++++++++++++++++++++++ manifests/subsystem/vm/instance.pp | 207 -------------------------------- 8 files changed, 250 insertions(+), 250 deletions(-) create mode 100644 manifests/base/virtual.pp delete mode 100644 manifests/base/vserver.pp create mode 100644 manifests/role/nas/virtual.pp delete mode 100644 manifests/role/nas/vserver.pp create mode 100644 manifests/role/virtual.pp delete mode 100644 manifests/role/vserver.pp create mode 100644 manifests/subsystem/virtual/instance.pp delete mode 100644 manifests/subsystem/vm/instance.pp diff --git a/manifests/base/virtual.pp b/manifests/base/virtual.pp new file mode 100644 index 0000000..7852d79 --- /dev/null +++ b/manifests/base/virtual.pp @@ -0,0 +1,35 @@ +class nodo::base::virtual { + class { 'ntp::timezone': } + class { 'syslog-ng::vserver': } + + backupninja::sys { "sys": + ensure => present, + partitions => false, + hardware => false, + dosfdisk => false, + dohwinfo => false, + } + + $hosting_type = hiera('nodo::vserver::hosting_type', 'direct') + + case $hosting_type { + "direct": { + # Apply munin and monkeysphere configuration for + # for directly hosted nodes. + Nodo::Subsystem::Monitor::Munin <<| title == $::hostname |>> + Nodo::Subsystem::Monkeysphere <<| title == $::hostname |>> + } + "third-party": { + # Apply munin and monkeysphere configuration for + # nodes hosted by third-parties. + nodo::subsystem::monitor::munin { "${::hostname}": } + monkeysphere_host { "${::hostname}": + port => hiera('nodo::vserver::ssh_port', '22'), + } + + # Nagios configuration + class { 'nodo::subsystem::monitor': } + } + } + +} diff --git a/manifests/base/vserver.pp b/manifests/base/vserver.pp deleted file mode 100644 index f904f32..0000000 --- a/manifests/base/vserver.pp +++ /dev/null @@ -1,35 +0,0 @@ -class nodo::base::vserver { - class { 'ntp::timezone': } - class { 'syslog-ng::vserver': } - - backupninja::sys { "sys": - ensure => present, - partitions => false, - hardware => false, - dosfdisk => false, - dohwinfo => false, - } - - $hosting_type = hiera('nodo::vserver::hosting_type', 'direct') - - case $hosting_type { - "direct": { - # Apply munin and monkeysphere configuration for - # for directly hosted nodes. - Nodo::Subsystem::Monitor::Munin <<| title == $::hostname |>> - Nodo::Subsystem::Monkeysphere <<| title == $::hostname |>> - } - "third-party": { - # Apply munin and monkeysphere configuration for - # nodes hosted by third-parties. - nodo::subsystem::monitor::munin { "${::hostname}": } - monkeysphere_host { "${::hostname}": - port => hiera('nodo::vserver::ssh_port', '22'), - } - - # Nagios configuration - class { 'nodo::subsystem::monitor': } - } - } - -} diff --git a/manifests/role/nas/virtual.pp b/manifests/role/nas/virtual.pp new file mode 100644 index 0000000..0beeaff --- /dev/null +++ b/manifests/role/nas/virtual.pp @@ -0,0 +1,5 @@ +class nodo::role::nas::virtual inherits nodo::base::virtual { + class { 'nodo::role::nas': + virtual => true, + } +} diff --git a/manifests/role/nas/vserver.pp b/manifests/role/nas/vserver.pp deleted file mode 100644 index da3786d..0000000 --- a/manifests/role/nas/vserver.pp +++ /dev/null @@ -1,5 +0,0 @@ -class nodo::role::nas::vserver inherits nodo::base::vserver { - class { 'nodo::role::nas': - virtual => true, - } -} diff --git a/manifests/role/virtual.pp b/manifests/role/virtual.pp new file mode 100644 index 0000000..bac5cde --- /dev/null +++ b/manifests/role/virtual.pp @@ -0,0 +1,3 @@ +# A general purpose virtual server +class nodo::role::virtual inherits nodo::base::virtual { +} diff --git a/manifests/role/vserver.pp b/manifests/role/vserver.pp deleted file mode 100644 index 0d8a364..0000000 --- a/manifests/role/vserver.pp +++ /dev/null @@ -1,3 +0,0 @@ -# A general purpose vserver -class nodo::role::vserver inherits nodo::base::vserver { -} diff --git a/manifests/subsystem/virtual/instance.pp b/manifests/subsystem/virtual/instance.pp new file mode 100644 index 0000000..726752f --- /dev/null +++ b/manifests/subsystem/virtual/instance.pp @@ -0,0 +1,207 @@ +# Define a virtual server instance +define nodo::subsystem::virtual::instance( + $context, + $distro = 'jessie', + $ensure = 'running', + $proxy = false, + $puppetmaster = false, + $gitd = false, + $mail = false, + $icecast = false, + $sound = false, + $tor = false, + $ticket = false, + $memory_limit = false, + $dns = false, + $jabber = false, + $mumble = false, + $gobby = false, + $yacy = false, + $rsync = false, + $avahi = false, + $munin_port = false, + $monkeysphere_ssh_port = false, + $implementation = false +) { + # Instance id + if $context <= 9 { + $id = "0$context" + } else { + $id = $context + } + + # Puppetmaster ssl port + case $puppetmaster_port { + '': { $puppetmaster_port = "8140" } + } + + # Set puppetmaster non-ssl port + case $puppetmaster_nonssl_port { + '': { $puppetmaster_nonssl_port = "8141" } + } + + # Tor port + case $tor_port { + '': { $tor_port = "9001" } + } + + $dev = hiera('nodo::subsystem::vm::interface', 'eth0') + + if $implementation == 'vserver' { + virtual::vserver { $name: + ensure => $ensure, + context => "$context", + mark => 'default', + distro => $distro, + interface => "${dev}:192.168.0.${context}/24", + hostname => "$name.$domain", + memory_limit => $memory_limit, + } + + # Some nodes need a lot of space at /tmp otherwise some admin + # tasks like backups might not run. + file { "/etc/vservers/${name}/fstab": + source => [ "puppet:///modules/site_nodo/etc/fstab/vserver/$name", + "puppet:///modules/nodo/etc/fstab/vserver" ], + owner => "root", + group => "root", + mode => 0644, + ensure => present, + notify => Exec["vs_restart_${name}"], + require => Exec["vs_create_${name}"], + } + + # Sound support + if $sound { + if !defined(File["/usr/local/sbin/create-sound-devices"]) { + file { "/usr/local/sbin/create-sound-devices": + ensure => present, + source => "puppet:///modules/nodo/sound/devices.sh", + owner => root, + group => root, + mode => 755, + } + } + exec { "/usr/local/sbin/create-sound-devices ${name}": + unless => "/usr/local/sbin/create-sound-devices ${name} --check", + user => root, + require => [ Exec["vs_create_${name}"], File["/usr/local/sbin/create-sound-devices"] ], + } + } + } + + # Create a munin virtual resource to be realized in the node + @@nodo::subsystem::monitor::munin { "${name}": + port => $munin_port ? { + false => "49$id", + default => $munin_port, + } + } + + # Create a monkeysphere virtual resource to be realized in the node + @@nodo::subsystem::monkeysphere { "$name": + port => $monkeysphere_ssh_port ? { + false => "22$id", + default => $monkeysphere_ssh_port, + } + } + + # Apply firewall rules just for running vservers + case $ensure { + 'running': { + firewall::virtual::ssh { "$name": + destination => "192.168.0.$context", + port_orig => "22$id", + port_dest => "22", + } + + firewall::virtual::munin { "$name": + destination => "192.168.0.$context", + port_orig => "49$id", + port_dest => "49$id", + } + + if $proxy { + class { + "firewall::virtual::http": destination => "192.168.0.$context"; + "firewall::virtual::https": destination => "192.168.0.$context"; + } + } + + if $puppetmaster { + class { + "firewall::virtual::puppetmaster": + destination => "192.168.0.$context", + puppetmaster_port => $puppetmaster_port, + puppetmaster_nonssl_port => $puppetmaster_nonssl_port, + } + } + + if $gitd { + class { + "firewall::virtual::gitd": destination => "192.168.0.$context"; + } + } + + if $icecast { + class { + "firewall::virtual::icecast": destination => "192.168.0.$context"; + } + } + + if $mail { + class { + "firewall::virtual::mail": destination => "192.168.0.$context"; + } + } + + if $dns { + class { + "firewall::virtual::dns": destination => "192.168.0.$context"; + } + } + + if $tor { + class { + "firewall::virtual::tor": destination => "192.168.0.$context"; + } + } + + if $jabber { + class { + "firewall::virtual::jabber": destination => "192.168.0.$context"; + } + } + + if $mumble { + class { + "firewall::virtual::mumble": destination => "192.168.0.$context"; + } + } + + if $gobby { + class { + "firewall::virtual::gobby": destination => "192.168.0.$context"; + } + } + + if $yacy { + class { + "firewall::virtual::yacy": destination => "192.168.0.$context"; + } + } + + if $rsync { + class { + "firewall::virtual::rsync": destination => "192.168.0.$context"; + } + } + + if $avahi { + class { + "firewall::virtual::mdns": destination => "192.168.0.$context"; + } + } + } + } +} diff --git a/manifests/subsystem/vm/instance.pp b/manifests/subsystem/vm/instance.pp deleted file mode 100644 index a7281bf..0000000 --- a/manifests/subsystem/vm/instance.pp +++ /dev/null @@ -1,207 +0,0 @@ -# Define a vserver instance -define nodo::subsystem::vm::instance( - $context, - $distro = 'jessie', - $ensure = 'running', - $proxy = false, - $puppetmaster = false, - $gitd = false, - $mail = false, - $icecast = false, - $sound = false, - $tor = false, - $ticket = false, - $memory_limit = false, - $dns = false, - $jabber = false, - $mumble = false, - $gobby = false, - $yacy = false, - $rsync = false, - $avahi = false, - $munin_port = false, - $monkeysphere_ssh_port = false, - $implementation = false -) { - # Instance id - if $context <= 9 { - $id = "0$context" - } else { - $id = $context - } - - # Puppetmaster ssl port - case $puppetmaster_port { - '': { $puppetmaster_port = "8140" } - } - - # Set puppetmaster non-ssl port - case $puppetmaster_nonssl_port { - '': { $puppetmaster_nonssl_port = "8141" } - } - - # Tor port - case $tor_port { - '': { $tor_port = "9001" } - } - - $dev = hiera('nodo::subsystem::vm::interface', 'eth0') - - if $implementation == 'vserver' { - virtual::vserver { $name: - ensure => $ensure, - context => "$context", - mark => 'default', - distro => $distro, - interface => "${dev}:192.168.0.${context}/24", - hostname => "$name.$domain", - memory_limit => $memory_limit, - } - - # Some nodes need a lot of space at /tmp otherwise some admin - # tasks like backups might not run. - file { "/etc/vservers/${name}/fstab": - source => [ "puppet:///modules/site_nodo/etc/fstab/vserver/$name", - "puppet:///modules/nodo/etc/fstab/vserver" ], - owner => "root", - group => "root", - mode => 0644, - ensure => present, - notify => Exec["vs_restart_${name}"], - require => Exec["vs_create_${name}"], - } - - # Sound support - if $sound { - if !defined(File["/usr/local/sbin/create-sound-devices"]) { - file { "/usr/local/sbin/create-sound-devices": - ensure => present, - source => "puppet:///modules/nodo/sound/devices.sh", - owner => root, - group => root, - mode => 755, - } - } - exec { "/usr/local/sbin/create-sound-devices ${name}": - unless => "/usr/local/sbin/create-sound-devices ${name} --check", - user => root, - require => [ Exec["vs_create_${name}"], File["/usr/local/sbin/create-sound-devices"] ], - } - } - } - - # Create a munin virtual resource to be realized in the node - @@nodo::subsystem::monitor::munin { "${name}": - port => $munin_port ? { - false => "49$id", - default => $munin_port, - } - } - - # Create a monkeysphere virtual resource to be realized in the node - @@nodo::subsystem::monkeysphere { "$name": - port => $monkeysphere_ssh_port ? { - false => "22$id", - default => $monkeysphere_ssh_port, - } - } - - # Apply firewall rules just for running vservers - case $ensure { - 'running': { - firewall::vm::ssh { "$name": - destination => "192.168.0.$context", - port_orig => "22$id", - port_dest => "22", - } - - firewall::vm::munin { "$name": - destination => "192.168.0.$context", - port_orig => "49$id", - port_dest => "49$id", - } - - if $proxy { - class { - "firewall::vm::http": destination => "192.168.0.$context"; - "firewall::vm::https": destination => "192.168.0.$context"; - } - } - - if $puppetmaster { - class { - "firewall::vm::puppetmaster": - destination => "192.168.0.$context", - puppetmaster_port => $puppetmaster_port, - puppetmaster_nonssl_port => $puppetmaster_nonssl_port, - } - } - - if $gitd { - class { - "firewall::vm::gitd": destination => "192.168.0.$context"; - } - } - - if $icecast { - class { - "firewall::vm::icecast": destination => "192.168.0.$context"; - } - } - - if $mail { - class { - "firewall::vm::mail": destination => "192.168.0.$context"; - } - } - - if $dns { - class { - "firewall::vm::dns": destination => "192.168.0.$context"; - } - } - - if $tor { - class { - "firewall::vm::tor": destination => "192.168.0.$context"; - } - } - - if $jabber { - class { - "firewall::vm::jabber": destination => "192.168.0.$context"; - } - } - - if $mumble { - class { - "firewall::vm::mumble": destination => "192.168.0.$context"; - } - } - - if $gobby { - class { - "firewall::vm::gobby": destination => "192.168.0.$context"; - } - } - - if $yacy { - class { - "firewall::vm::yacy": destination => "192.168.0.$context"; - } - } - - if $rsync { - class { - "firewall::vm::rsync": destination => "192.168.0.$context"; - } - } - - if $avahi { - class { - "firewall::vm::mdns": destination => "192.168.0.$context"; - } - } - } - } -} -- cgit v1.2.3