simp-cli 1.0.12

Sign up to get free protection for your applications and to get access to all the features.
Files changed (150) hide show
  1. checksums.yaml +15 -0
  2. data/LICENSE +27 -0
  3. data/README.md +48 -0
  4. data/Rakefile +142 -0
  5. data/bin/simp +5 -0
  6. data/lib/simp/cli.rb +88 -0
  7. data/lib/simp/cli/commands/bootstrap.rb +275 -0
  8. data/lib/simp/cli/commands/check.rb +163 -0
  9. data/lib/simp/cli/commands/cleancerts.rb +114 -0
  10. data/lib/simp/cli/commands/config.rb +235 -0
  11. data/lib/simp/cli/commands/doc.rb +14 -0
  12. data/lib/simp/cli/commands/passgen.rb +128 -0
  13. data/lib/simp/cli/commands/puppeteval.rb +82 -0
  14. data/lib/simp/cli/commands/runpuppet.rb +95 -0
  15. data/lib/simp/cli/config/item.rb +456 -0
  16. data/lib/simp/cli/config/item/add_ldap_to_hiera.rb +43 -0
  17. data/lib/simp/cli/config/item/answers_yaml_file_writer.rb +58 -0
  18. data/lib/simp/cli/config/item/certificates.rb +39 -0
  19. data/lib/simp/cli/config/item/client_nets.rb +65 -0
  20. data/lib/simp/cli/config/item/common_runlevel_default.rb +32 -0
  21. data/lib/simp/cli/config/item/dns_search.rb +48 -0
  22. data/lib/simp/cli/config/item/dns_servers.rb +57 -0
  23. data/lib/simp/cli/config/item/failover_log_servers.rb +27 -0
  24. data/lib/simp/cli/config/item/gateway.rb +32 -0
  25. data/lib/simp/cli/config/item/grub_password.rb +51 -0
  26. data/lib/simp/cli/config/item/hostname.rb +24 -0
  27. data/lib/simp/cli/config/item/hostname_conf.rb +48 -0
  28. data/lib/simp/cli/config/item/ipaddress.rb +46 -0
  29. data/lib/simp/cli/config/item/is_master_yum_server.rb +23 -0
  30. data/lib/simp/cli/config/item/ldap_base_dn.rb +38 -0
  31. data/lib/simp/cli/config/item/ldap_bind_dn.rb +34 -0
  32. data/lib/simp/cli/config/item/ldap_bind_hash.rb +28 -0
  33. data/lib/simp/cli/config/item/ldap_bind_pw.rb +24 -0
  34. data/lib/simp/cli/config/item/ldap_master.rb +33 -0
  35. data/lib/simp/cli/config/item/ldap_root_dn.rb +42 -0
  36. data/lib/simp/cli/config/item/ldap_root_hash.rb +35 -0
  37. data/lib/simp/cli/config/item/ldap_sync_dn.rb +24 -0
  38. data/lib/simp/cli/config/item/ldap_sync_hash.rb +28 -0
  39. data/lib/simp/cli/config/item/ldap_sync_pw.rb +26 -0
  40. data/lib/simp/cli/config/item/ldap_uri.rb +43 -0
  41. data/lib/simp/cli/config/item/log_servers.rb +27 -0
  42. data/lib/simp/cli/config/item/netmask.rb +39 -0
  43. data/lib/simp/cli/config/item/network_conf.rb +63 -0
  44. data/lib/simp/cli/config/item/network_dhcp.rb +27 -0
  45. data/lib/simp/cli/config/item/network_interface.rb +41 -0
  46. data/lib/simp/cli/config/item/network_setup_nic.rb +28 -0
  47. data/lib/simp/cli/config/item/ntp_servers.rb +69 -0
  48. data/lib/simp/cli/config/item/puppet_autosign.rb +66 -0
  49. data/lib/simp/cli/config/item/puppet_ca.rb +31 -0
  50. data/lib/simp/cli/config/item/puppet_ca_port.rb +28 -0
  51. data/lib/simp/cli/config/item/puppet_conf.rb +98 -0
  52. data/lib/simp/cli/config/item/puppet_fileserver.rb +104 -0
  53. data/lib/simp/cli/config/item/puppet_hosts_entry.rb +44 -0
  54. data/lib/simp/cli/config/item/puppet_server.rb +30 -0
  55. data/lib/simp/cli/config/item/puppet_server_ip.rb +25 -0
  56. data/lib/simp/cli/config/item/puppetdb_port.rb +25 -0
  57. data/lib/simp/cli/config/item/puppetdb_server.rb +26 -0
  58. data/lib/simp/cli/config/item/remove_ldap_from_hiera.rb +47 -0
  59. data/lib/simp/cli/config/item/rename_fqdn_yaml.rb +40 -0
  60. data/lib/simp/cli/config/item/rsync_base.rb +37 -0
  61. data/lib/simp/cli/config/item/rsync_server.rb +44 -0
  62. data/lib/simp/cli/config/item/rsync_timeout.rb +26 -0
  63. data/lib/simp/cli/config/item/set_grub_password.rb +19 -0
  64. data/lib/simp/cli/config/item/simp_yum_servers.rb +30 -0
  65. data/lib/simp/cli/config/item/use_auditd.rb +19 -0
  66. data/lib/simp/cli/config/item/use_fips.rb +46 -0
  67. data/lib/simp/cli/config/item/use_iptables.rb +22 -0
  68. data/lib/simp/cli/config/item/use_ldap.rb +19 -0
  69. data/lib/simp/cli/config/item/use_selinux.rb +32 -0
  70. data/lib/simp/cli/config/item/yum_repositories.rb +75 -0
  71. data/lib/simp/cli/config/item_list_factory.rb +236 -0
  72. data/lib/simp/cli/config/questionnaire.rb +86 -0
  73. data/lib/simp/cli/config/utils.rb +128 -0
  74. data/lib/simp/cli/lib/utils.rb +114 -0
  75. data/lib/simp/simp.rb +77 -0
  76. data/spec/lib/simp/cli/commands/config_spec.rb +42 -0
  77. data/spec/lib/simp/cli/config/item/add_ldap_to_hiera_spec.rb +58 -0
  78. data/spec/lib/simp/cli/config/item/answers_yaml_file_writer_spec.rb +86 -0
  79. data/spec/lib/simp/cli/config/item/certificates_spec.rb +50 -0
  80. data/spec/lib/simp/cli/config/item/client_nets_spec.rb +66 -0
  81. data/spec/lib/simp/cli/config/item/common_runlevel_default_spec.rb +27 -0
  82. data/spec/lib/simp/cli/config/item/dns_search_spec.rb +74 -0
  83. data/spec/lib/simp/cli/config/item/dns_servers_spec.rb +76 -0
  84. data/spec/lib/simp/cli/config/item/failover_log_servers_spec.rb +49 -0
  85. data/spec/lib/simp/cli/config/item/files/FakeCA/cacertkey +1 -0
  86. data/spec/lib/simp/cli/config/item/files/FakeCA/gencerts_nopass.sh +10 -0
  87. data/spec/lib/simp/cli/config/item/files/autosign.conf.new +11 -0
  88. data/spec/lib/simp/cli/config/item/files/autosign.conf.used +15 -0
  89. data/spec/lib/simp/cli/config/item/files/fileserver.conf +41 -0
  90. data/spec/lib/simp/cli/config/item/files/hosts +2 -0
  91. data/spec/lib/simp/cli/config/item/files/hosts.old_puppet_entry +3 -0
  92. data/spec/lib/simp/cli/config/item/files/puppet.conf +25 -0
  93. data/spec/lib/simp/cli/config/item/files/puppet.your.domain.yaml +21 -0
  94. data/spec/lib/simp/cli/config/item/files/resolv.conf__multiple +10 -0
  95. data/spec/lib/simp/cli/config/item/files/resolv.conf__single +4 -0
  96. data/spec/lib/simp/cli/config/item/files/rsyncd.conf +225 -0
  97. data/spec/lib/simp/cli/config/item/gateway_spec.rb +23 -0
  98. data/spec/lib/simp/cli/config/item/grub_password_spec.rb +24 -0
  99. data/spec/lib/simp/cli/config/item/hostname_conf_spec.rb +27 -0
  100. data/spec/lib/simp/cli/config/item/hostname_spec.rb +22 -0
  101. data/spec/lib/simp/cli/config/item/ipaddress_spec.rb +40 -0
  102. data/spec/lib/simp/cli/config/item/is_master_yum_server_spec.rb +29 -0
  103. data/spec/lib/simp/cli/config/item/ldap_base_dn_spec.rb +23 -0
  104. data/spec/lib/simp/cli/config/item/ldap_bind_dn_spec.rb +23 -0
  105. data/spec/lib/simp/cli/config/item/ldap_bind_hash_spec.rb +23 -0
  106. data/spec/lib/simp/cli/config/item/ldap_bind_pw_spec.rb +21 -0
  107. data/spec/lib/simp/cli/config/item/ldap_master_spec.rb +37 -0
  108. data/spec/lib/simp/cli/config/item/ldap_root_dn_spec.rb +23 -0
  109. data/spec/lib/simp/cli/config/item/ldap_root_hash_spec.rb +23 -0
  110. data/spec/lib/simp/cli/config/item/ldap_sync_dn_spec.rb +22 -0
  111. data/spec/lib/simp/cli/config/item/ldap_sync_hash_spec.rb +23 -0
  112. data/spec/lib/simp/cli/config/item/ldap_sync_pw_spec.rb +21 -0
  113. data/spec/lib/simp/cli/config/item/ldap_uri_spec.rb +32 -0
  114. data/spec/lib/simp/cli/config/item/log_servers_spec.rb +49 -0
  115. data/spec/lib/simp/cli/config/item/netmask_spec.rb +28 -0
  116. data/spec/lib/simp/cli/config/item/network_conf_spec.rb +63 -0
  117. data/spec/lib/simp/cli/config/item/network_dhcp_spec.rb +11 -0
  118. data/spec/lib/simp/cli/config/item/network_interface_spec.rb +26 -0
  119. data/spec/lib/simp/cli/config/item/network_setup_nic_spec.rb +29 -0
  120. data/spec/lib/simp/cli/config/item/ntp_servers_spec.rb +43 -0
  121. data/spec/lib/simp/cli/config/item/puppet_autosign_spec.rb +55 -0
  122. data/spec/lib/simp/cli/config/item/puppet_ca_port_spec.rb +23 -0
  123. data/spec/lib/simp/cli/config/item/puppet_ca_spec.rb +22 -0
  124. data/spec/lib/simp/cli/config/item/puppet_conf_spec.rb +110 -0
  125. data/spec/lib/simp/cli/config/item/puppet_fileserver_spec.rb +53 -0
  126. data/spec/lib/simp/cli/config/item/puppet_hosts_entry_spec.rb +85 -0
  127. data/spec/lib/simp/cli/config/item/puppet_server_ip_spec.rb +24 -0
  128. data/spec/lib/simp/cli/config/item/puppet_server_spec.rb +22 -0
  129. data/spec/lib/simp/cli/config/item/puppetdb_port_spec.rb +25 -0
  130. data/spec/lib/simp/cli/config/item/puppetdb_server_spec.rb +25 -0
  131. data/spec/lib/simp/cli/config/item/remove_ldap_from_hiera_spec.rb +58 -0
  132. data/spec/lib/simp/cli/config/item/rename_fqdn_yaml_spec.rb +63 -0
  133. data/spec/lib/simp/cli/config/item/rsync_base_spec.rb +28 -0
  134. data/spec/lib/simp/cli/config/item/rsync_server_spec.rb +41 -0
  135. data/spec/lib/simp/cli/config/item/rsync_timeout_spec.rb +21 -0
  136. data/spec/lib/simp/cli/config/item/set_grub_password_spec.rb +29 -0
  137. data/spec/lib/simp/cli/config/item/simp_yum_servers_spec.rb +41 -0
  138. data/spec/lib/simp/cli/config/item/spec_helper.rb +22 -0
  139. data/spec/lib/simp/cli/config/item/use_auditd_spec.rb +29 -0
  140. data/spec/lib/simp/cli/config/item/use_fips_spec.rb +29 -0
  141. data/spec/lib/simp/cli/config/item/use_iptables_spec.rb +29 -0
  142. data/spec/lib/simp/cli/config/item/use_ldap_spec.rb +29 -0
  143. data/spec/lib/simp/cli/config/item/use_selinux_spec.rb +24 -0
  144. data/spec/lib/simp/cli/config/item/yum_repositories_spec.rb +94 -0
  145. data/spec/lib/simp/cli/config/item_spec.rb +106 -0
  146. data/spec/lib/simp/cli/config/spec_helper.rb +1 -0
  147. data/spec/lib/simp/cli/config/utils_spec.rb +131 -0
  148. data/spec/lib/simp/cli/spec_helper.rb +1 -0
  149. data/spec/spec_helper.rb +91 -0
  150. metadata +391 -0
@@ -0,0 +1,28 @@
1
+ require 'highline/import'
2
+ require 'puppet'
3
+ require File.expand_path( '../item', File.dirname(__FILE__) )
4
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
5
+
6
+ module Simp; end
7
+ class Simp::Cli; end
8
+ module Simp::Cli::Config
9
+ class Item::PuppetCAPort < Item
10
+ def initialize
11
+ super
12
+ @key = 'puppet::ca_port'
13
+ @description = 'The port which the Puppet CA will listen on (8141 by default).'
14
+ end
15
+
16
+ def os_value
17
+ Puppet.settings.setting( 'ca_port' ).value
18
+ end
19
+
20
+ def validate( x )
21
+ (x.to_s =~ /^\d+$/ ? true : false ) && x.to_i > 0 && x.to_i <= 65535
22
+ end
23
+
24
+ def recommended_value
25
+ 8141
26
+ end
27
+ end
28
+ end
@@ -0,0 +1,98 @@
1
+ require 'highline/import'
2
+ require File.expand_path( '../item', File.dirname(__FILE__) )
3
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
4
+
5
+ module Simp; end
6
+ class Simp::Cli; end
7
+ module Simp::Cli::Config
8
+ class Item::PuppetConf < ActionItem
9
+ attr_accessor :file
10
+
11
+ def initialize
12
+ super
13
+ @key = 'puppet::conf'
14
+ @description = 'silent item; configures /etc/puppet/puppet.conf'
15
+ # FIXME: this path will change with Puppet Enterprise; should this autodetect?
16
+ @file = '/etc/puppet/puppet.conf'
17
+ end
18
+
19
+ # NOTE: This is (mostly) lifted straight from the old simp config
20
+ # TODO: refactor sed statements to pure ruby,
21
+ # consider using IO handles instead of File.open (easier to test in memory)?
22
+ # or use Puppet::Settings ( https://github.com/puppetlabs/puppet/blob/master/lib/puppet/settings.rb )?
23
+ def apply
24
+ say_green "Updating #{@file}..." if !@silent
25
+ if @skip_apply
26
+ say_yellow "WARNING: directed to skip Puppet configuration of #{file}" if !@silent
27
+ return
28
+ end
29
+
30
+ backup_file = "#{@file}.pre_simpconfig"
31
+ FileUtils.cp("#{@file}", backup_file)
32
+ `sed -i '/^\s*server.*/d' #{@file}`
33
+ `sed -i '/.*trusted_node_data.*/d' #{@file}`
34
+ `sed -i '/.*digest_algorithm.*/d' #{@file}`
35
+ `sed -i '/.*stringify_facts.*/d' #{@file}`
36
+ `sed -i '/.*environment_path.*/d' #{@file}`
37
+ `sed -i '/^.main./ a \\ trusted_node_data = true\' #{@file}`
38
+ `sed -i '/^.main./ a \\ digest_algorithm = sha256\' #{@file}`
39
+ `sed -i '/^.main./ a \\ stringify_facts = false\' #{@file}`
40
+ `sed -i '/^.main./ a \\ environmentpath = /etc/puppet/environments\' #{@file}`
41
+ `sed -i '/trusted_node_data/ a \\ server = #{@config_items.fetch( 'puppet::server' ).value}\' #{@file}`
42
+ keylength = @config_items.fetch( 'use_fips', nil )? '2048' : '4096'
43
+ `sed -i '/^.main./ a \\ keylength = #{keylength}\' #{@file}`
44
+
45
+ # do not die if config items aren't found
46
+ puppet_server = 'puppet.change.me'
47
+ puppet_ca = 'puppetca.change.me'
48
+ puppet_ca_port = '8141'
49
+ if item = @config_items.fetch( 'puppet::server', nil )
50
+ puppet_server = item.value
51
+ end
52
+ if item = @config_items.fetch( 'puppet::ca', nil )
53
+ puppet_ca = item.value
54
+ end
55
+ if item = @config_items.fetch( 'puppet::ca_port', nil )
56
+ puppet_ca_port = item.value
57
+ end
58
+
59
+ puppet_conf = File.readlines(@file)
60
+ File.open("#{@file}", 'w') do |out_file|
61
+ line_check = {
62
+ 'server' => false,
63
+ 'ca_server' => false,
64
+ 'ca_port' => false
65
+ }
66
+ puppet_conf.each do |line|
67
+ if line !~ /^\s*(#{line_check.keys.join('|')})(\s*=\s*)/
68
+ out_file.puts line
69
+ else
70
+ $1.chomp
71
+ line_check[$1] = true
72
+ case $1
73
+ when 'server' then
74
+ out_file.puts " #{$1}#{$2}#{puppet_server}"
75
+ when 'ca_server' then
76
+ out_file.puts " #{$1}#{$2}#{puppet_ca}"
77
+ when 'ca_port' then
78
+ out_file.puts " #{$1}#{$2}#{puppet_ca_port}"
79
+ end
80
+ end
81
+ end
82
+ line_check.keys.each do |key|
83
+ if not line_check[key] then
84
+ case key
85
+ when 'server' then
86
+ out_file.puts " server = #{puppet_server}"
87
+ when 'ca_server' then
88
+ out_file.puts " ca_server = #{puppet_ca}"
89
+ when 'ca_port' then
90
+ out_file.puts " ca_port = #{puppet_ca_port}"
91
+ end
92
+ end
93
+ end
94
+ end
95
+
96
+ end
97
+ end
98
+ end
@@ -0,0 +1,104 @@
1
+ require 'highline/import'
2
+ require File.expand_path( '../item', File.dirname(__FILE__) )
3
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
4
+
5
+ module Simp; end
6
+ class Simp::Cli; end
7
+ module Simp::Cli::Config
8
+ class Item::PuppetFileServer < ActionItem
9
+
10
+ attr_accessor :file
11
+
12
+ def initialize
13
+ super
14
+ @key = 'puppet::fileserver'
15
+ @description = 'silent item; configures /etc/puppet/fileserver.conf'
16
+ @file = '/etc/puppet/fileserver.conf'
17
+ end
18
+
19
+ def apply
20
+ say_green " updating Puppet configurations in #{@file}..." if !@silent
21
+
22
+ conf = @file
23
+
24
+ require 'fileutils'
25
+ FileUtils.cp(conf, "#{conf}.pre_simpconfig")
26
+
27
+ hostname = @config_items.fetch( 'hostname' ) #FIXME: should this be hostname or puppet_server?
28
+ domain = hostname.value.split('.')[1..-1].join('.')
29
+
30
+ if !domain or domain.empty?
31
+ raise "Could not determine domain from hostname '#{hostname}"
32
+ end
33
+
34
+ default_entries = ['facts','plugins','keydist','cacerts','mcollective']
35
+
36
+ fileserver_default = <<-EOM
37
+ [facts]
38
+ path /etc/puppet/facts
39
+ allow *.#{domain}
40
+
41
+ [plugins]
42
+ allow *.#{domain}
43
+
44
+ [keydist]
45
+ path /etc/puppet/keydist/%H
46
+ allow *.#{domain}
47
+
48
+ [cacerts]
49
+ path /etc/puppet/keydist/cacerts
50
+ allow *.#{domain}
51
+
52
+ [mcollective]
53
+ path /etc/puppet/keydist/mcollective
54
+ allow *.#{domain}
55
+ EOM
56
+
57
+ # Complete crib from StackOverflow
58
+ fileserver_default.gsub!(/^#{fileserver_default[/\A\s*/]}/,'')
59
+
60
+ fileserver_new = []
61
+
62
+ fileserver_old = File.read(conf).split("\n")
63
+
64
+ # Preserve any beginning comments
65
+ while fileserver_old[0] =~ /^\s*(#.*|\s*)$/ do
66
+ fileserver_new << fileserver_old.shift
67
+ end
68
+
69
+ # Add in our defaults
70
+ fileserver_new << fileserver_default
71
+
72
+ # Read the rest of the file, ignoring any section that we're going to
73
+ # replace.
74
+ key = nil
75
+ comments = []
76
+ fileserver_old.each do |line|
77
+ if line =~ /\[(.*)\]/ then
78
+ key = $1.strip
79
+ comments = []
80
+ end
81
+
82
+ next if default_entries.include?(key)
83
+
84
+ fileserver_new << line
85
+ end
86
+
87
+ # If the last entry was a default entry key, preserve the trailing file
88
+ # comments (if any)
89
+ if default_entries.include?(key) then
90
+ fileserver_new << "\n"
91
+ fileserver_new += comments
92
+ end
93
+
94
+ # Smash duplicates
95
+ fileserver_new.each_with_index do |x,i|
96
+ fileserver_new.delete(i) unless fileserver_new[i] != fileserver_new[i + 1]
97
+ end
98
+
99
+ File.open(conf,'w'){|x| x.puts(fileserver_new.join("\n"))}
100
+
101
+ true
102
+ end
103
+ end
104
+ end
@@ -0,0 +1,44 @@
1
+ require "resolv"
2
+ require 'highline/import'
3
+ require File.expand_path( '../item', File.dirname(__FILE__) )
4
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
5
+
6
+ module Simp; end
7
+ class Simp::Cli; end
8
+ module Simp::Cli::Config
9
+ class Item::PuppetHostsEntry < ActionItem
10
+ attr_accessor :file
11
+
12
+ def initialize
13
+ super
14
+ @key = 'puppet::hosts_entry'
15
+ @description = %Q{Ensures an entry for the puppet server in /etc/hosts (apply-only; noop).}
16
+ @file = '/etc/hosts'
17
+ end
18
+
19
+ def apply
20
+ puppet_server = @config_items.fetch( 'puppet::server' ).value
21
+ puppet_server_ip = @config_items.fetch( 'puppet::server::ip' ).value
22
+ status = false
23
+
24
+ say_green "Updating #{@file}..." if !@silent
25
+
26
+ values = Array.new
27
+ File.readlines(@file).each do |line|
28
+ next if line =~ /\s*#/
29
+ next if line =~ /#{puppet_server}/ and @value.eql?(puppet_server)
30
+ next if line =~ /localdomain/
31
+ next if line =~ /localdomain6/
32
+ next if line =~ /\spuppet(\s|$)/ # remove alias 'puppet'
33
+ values.push(line)
34
+ end
35
+ File.open(@file,'w') {|fh|
36
+ fh.puts('127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4')
37
+ fh.puts('::1 localhost localhost.localdomain localhost6 localhost6.localdomain6')
38
+ fh.puts("#{puppet_server_ip} #{puppet_server} #{puppet_server.split('.').first}")
39
+ fh.puts(values)
40
+ }
41
+ true
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,30 @@
1
+ require 'highline/import'
2
+ require 'puppet'
3
+ require File.expand_path( '../item', File.dirname(__FILE__) )
4
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
5
+
6
+ module Simp; end
7
+ class Simp::Cli; end
8
+ module Simp::Cli::Config
9
+ class Item::PuppetServer < Item
10
+ def initialize
11
+ super
12
+ @key = 'puppet::server'
13
+ @description = %q{The Hostname or FQDN of the puppet server.}
14
+ end
15
+
16
+ def os_value
17
+ Puppet.settings.setting( 'server' ).value
18
+ end
19
+
20
+ def validate( x )
21
+ Simp::Cli::Config::Utils.validate_hostname( x ) ||
22
+ Simp::Cli::Config::Utils.validate_fqdn( x )
23
+ end
24
+
25
+ def recommended_value
26
+ item = @config_items.fetch( 'hostname', nil )
27
+ item.value if item
28
+ end
29
+ end
30
+ end
@@ -0,0 +1,25 @@
1
+ require File.expand_path( '../item', File.dirname(__FILE__) )
2
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
3
+
4
+ module Simp; end
5
+ class Simp::Cli; end
6
+ module Simp::Cli::Config
7
+ class Item::PuppetServerIP < Item
8
+ def initialize
9
+ super
10
+ @key = 'puppet::server::ip'
11
+ @description = %Q{The Puppet server's IP address.\nThis is used to configure /etc/hosts properly.}
12
+ end
13
+
14
+
15
+ # Always recommend the configured IP
16
+ def recommended_value
17
+ @config_items.fetch( 'ipaddress' ).value
18
+ end
19
+
20
+
21
+ def validate( x )
22
+ Simp::Cli::Config::Utils.validate_ip x
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,25 @@
1
+ require File.expand_path( '../item', File.dirname(__FILE__) )
2
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
3
+
4
+ module Simp; end
5
+ class Simp::Cli; end
6
+
7
+ module Simp::Cli::Config
8
+ class Item::PuppetDBPort < Item
9
+ def initialize
10
+ super
11
+ @key = 'puppetdb::master::config::puppetdb_port'
12
+ @description = %Q{The PuppetDB server port number}
13
+ @value = recommended_value
14
+ end
15
+
16
+ def recommended_value
17
+ '8139'
18
+ end
19
+
20
+ def validate string
21
+ ( string =~ /^\d+$/ ? true : false ) &&
22
+ ( string.to_i > 1 && string.to_i < 65536 )
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,26 @@
1
+ require File.expand_path( '../item', File.dirname(__FILE__) )
2
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
3
+
4
+ module Simp; end
5
+ class Simp::Cli; end
6
+
7
+ module Simp::Cli::Config
8
+ class Item::PuppetDBServer < Item
9
+ def initialize
10
+ super
11
+ @key = 'puppetdb::master::config::puppetdb_server'
12
+ @description = %Q{The dns name or ip of the puppetdb server}
13
+ @value = recommended_value
14
+ end
15
+
16
+ def recommended_value
17
+ "%{hiera('puppet::server')}"
18
+ end
19
+
20
+ def validate string
21
+ Simp::Cli::Config::Utils.validate_fqdn( string ) ||
22
+ Simp::Cli::Config::Utils.validate_ip( string ) ||
23
+ Simp::Cli::Config::Utils.validate_hiera_lookup( string )
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,47 @@
1
+ require "resolv"
2
+ require File.expand_path( '../item', File.dirname(__FILE__) )
3
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
4
+
5
+ module Simp; end
6
+ class Simp::Cli; end
7
+ module Simp::Cli::Config
8
+ class Item::RemoveLdapFromHiera < ActionItem
9
+ attr_accessor :dir
10
+
11
+ def initialize
12
+ super
13
+ @key = 'puppet::remove_ldap_from_hiera'
14
+ @description = %Q{Removes any ldap classes from hieradata/hosts/puppet.your.domain.yaml (apply-only; noop).}
15
+ @dir = "/etc/puppet/environments/simp/hieradata/hosts"
16
+ @file = nil
17
+ end
18
+
19
+ def apply
20
+ success = true
21
+ fqdn = @config_items.fetch( 'hostname' ).value
22
+ file = File.join( @dir, "#{fqdn}.yaml")
23
+
24
+ say_green 'Removing ldap classes from the <domain>.yaml file' if !@silent
25
+
26
+ if File.exists?(file)
27
+ lines = File.open(file,'r').readlines
28
+
29
+ File.open(file, 'w') do |f|
30
+ lines.each do |line|
31
+ line.chomp!
32
+ f.puts line if !strip_line?(line)
33
+ end
34
+ end
35
+ else
36
+ success = false
37
+ say_yellow "WARNING: file not found: #{file}"
38
+ end
39
+ success
40
+ end
41
+
42
+
43
+ def strip_line?( line )
44
+ (line =~ /^\s*-\s+(([a-z_:'"]*::)*(open)*ldap|(open)*ldap[a-z_:'"]*)/m) ? true : false
45
+ end
46
+ end
47
+ end
@@ -0,0 +1,40 @@
1
+ require "resolv"
2
+ require 'highline/import'
3
+ require File.expand_path( '../item', File.dirname(__FILE__) )
4
+ require File.expand_path( '../utils', File.dirname(__FILE__) )
5
+
6
+ module Simp; end
7
+ class Simp::Cli; end
8
+ module Simp::Cli::Config
9
+ class Item::RenameFqdnYaml < ActionItem
10
+ attr_accessor :file
11
+
12
+ def initialize
13
+ super
14
+ @key = 'puppet::rename_fqdn_yaml'
15
+ @description = %Q{Renames hieradata/hosts/puppet.your.domain.yaml (apply-only; noop).}
16
+ @file = '/etc/puppet/environments/simp/hieradata/hosts/puppet.your.domain.yaml'
17
+ end
18
+
19
+ def apply
20
+ result = true
21
+ fqdn = @config_items.fetch( 'hostname' ).value
22
+ new_file = File.join( File.dirname( @file ), "#{fqdn}.yaml" )
23
+ say_green 'Moving default <domain>.yaml file' if !@silent
24
+
25
+ if File.exists?(@file)
26
+ if File.exists?( new_file )
27
+ result = false
28
+ diff = `diff #{new_file} #{@file}`
29
+ say_yellow "WARNING: #{File.basename( new_file )} exists, but the content differs from the original system content. Review and consider updating:\n#{diff}" if !diff.empty?
30
+ else
31
+ File.rename( @file, new_file )
32
+ end
33
+ else
34
+ result = false
35
+ say_yellow "WARNING: file not found: #{@file}"
36
+ end
37
+ true
38
+ end
39
+ end
40
+ end