simp-cli 1.0.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/LICENSE +27 -0
- data/README.md +48 -0
- data/Rakefile +142 -0
- data/bin/simp +5 -0
- data/lib/simp/cli.rb +88 -0
- data/lib/simp/cli/commands/bootstrap.rb +275 -0
- data/lib/simp/cli/commands/check.rb +163 -0
- data/lib/simp/cli/commands/cleancerts.rb +114 -0
- data/lib/simp/cli/commands/config.rb +235 -0
- data/lib/simp/cli/commands/doc.rb +14 -0
- data/lib/simp/cli/commands/passgen.rb +128 -0
- data/lib/simp/cli/commands/puppeteval.rb +82 -0
- data/lib/simp/cli/commands/runpuppet.rb +95 -0
- data/lib/simp/cli/config/item.rb +456 -0
- data/lib/simp/cli/config/item/add_ldap_to_hiera.rb +43 -0
- data/lib/simp/cli/config/item/answers_yaml_file_writer.rb +58 -0
- data/lib/simp/cli/config/item/certificates.rb +39 -0
- data/lib/simp/cli/config/item/client_nets.rb +65 -0
- data/lib/simp/cli/config/item/common_runlevel_default.rb +32 -0
- data/lib/simp/cli/config/item/dns_search.rb +48 -0
- data/lib/simp/cli/config/item/dns_servers.rb +57 -0
- data/lib/simp/cli/config/item/failover_log_servers.rb +27 -0
- data/lib/simp/cli/config/item/gateway.rb +32 -0
- data/lib/simp/cli/config/item/grub_password.rb +51 -0
- data/lib/simp/cli/config/item/hostname.rb +24 -0
- data/lib/simp/cli/config/item/hostname_conf.rb +48 -0
- data/lib/simp/cli/config/item/ipaddress.rb +46 -0
- data/lib/simp/cli/config/item/is_master_yum_server.rb +23 -0
- data/lib/simp/cli/config/item/ldap_base_dn.rb +38 -0
- data/lib/simp/cli/config/item/ldap_bind_dn.rb +34 -0
- data/lib/simp/cli/config/item/ldap_bind_hash.rb +28 -0
- data/lib/simp/cli/config/item/ldap_bind_pw.rb +24 -0
- data/lib/simp/cli/config/item/ldap_master.rb +33 -0
- data/lib/simp/cli/config/item/ldap_root_dn.rb +42 -0
- data/lib/simp/cli/config/item/ldap_root_hash.rb +35 -0
- data/lib/simp/cli/config/item/ldap_sync_dn.rb +24 -0
- data/lib/simp/cli/config/item/ldap_sync_hash.rb +28 -0
- data/lib/simp/cli/config/item/ldap_sync_pw.rb +26 -0
- data/lib/simp/cli/config/item/ldap_uri.rb +43 -0
- data/lib/simp/cli/config/item/log_servers.rb +27 -0
- data/lib/simp/cli/config/item/netmask.rb +39 -0
- data/lib/simp/cli/config/item/network_conf.rb +63 -0
- data/lib/simp/cli/config/item/network_dhcp.rb +27 -0
- data/lib/simp/cli/config/item/network_interface.rb +41 -0
- data/lib/simp/cli/config/item/network_setup_nic.rb +28 -0
- data/lib/simp/cli/config/item/ntp_servers.rb +69 -0
- data/lib/simp/cli/config/item/puppet_autosign.rb +66 -0
- data/lib/simp/cli/config/item/puppet_ca.rb +31 -0
- data/lib/simp/cli/config/item/puppet_ca_port.rb +28 -0
- data/lib/simp/cli/config/item/puppet_conf.rb +98 -0
- data/lib/simp/cli/config/item/puppet_fileserver.rb +104 -0
- data/lib/simp/cli/config/item/puppet_hosts_entry.rb +44 -0
- data/lib/simp/cli/config/item/puppet_server.rb +30 -0
- data/lib/simp/cli/config/item/puppet_server_ip.rb +25 -0
- data/lib/simp/cli/config/item/puppetdb_port.rb +25 -0
- data/lib/simp/cli/config/item/puppetdb_server.rb +26 -0
- data/lib/simp/cli/config/item/remove_ldap_from_hiera.rb +47 -0
- data/lib/simp/cli/config/item/rename_fqdn_yaml.rb +40 -0
- data/lib/simp/cli/config/item/rsync_base.rb +37 -0
- data/lib/simp/cli/config/item/rsync_server.rb +44 -0
- data/lib/simp/cli/config/item/rsync_timeout.rb +26 -0
- data/lib/simp/cli/config/item/set_grub_password.rb +19 -0
- data/lib/simp/cli/config/item/simp_yum_servers.rb +30 -0
- data/lib/simp/cli/config/item/use_auditd.rb +19 -0
- data/lib/simp/cli/config/item/use_fips.rb +46 -0
- data/lib/simp/cli/config/item/use_iptables.rb +22 -0
- data/lib/simp/cli/config/item/use_ldap.rb +19 -0
- data/lib/simp/cli/config/item/use_selinux.rb +32 -0
- data/lib/simp/cli/config/item/yum_repositories.rb +75 -0
- data/lib/simp/cli/config/item_list_factory.rb +236 -0
- data/lib/simp/cli/config/questionnaire.rb +86 -0
- data/lib/simp/cli/config/utils.rb +128 -0
- data/lib/simp/cli/lib/utils.rb +114 -0
- data/lib/simp/simp.rb +77 -0
- data/spec/lib/simp/cli/commands/config_spec.rb +42 -0
- data/spec/lib/simp/cli/config/item/add_ldap_to_hiera_spec.rb +58 -0
- data/spec/lib/simp/cli/config/item/answers_yaml_file_writer_spec.rb +86 -0
- data/spec/lib/simp/cli/config/item/certificates_spec.rb +50 -0
- data/spec/lib/simp/cli/config/item/client_nets_spec.rb +66 -0
- data/spec/lib/simp/cli/config/item/common_runlevel_default_spec.rb +27 -0
- data/spec/lib/simp/cli/config/item/dns_search_spec.rb +74 -0
- data/spec/lib/simp/cli/config/item/dns_servers_spec.rb +76 -0
- data/spec/lib/simp/cli/config/item/failover_log_servers_spec.rb +49 -0
- data/spec/lib/simp/cli/config/item/files/FakeCA/cacertkey +1 -0
- data/spec/lib/simp/cli/config/item/files/FakeCA/gencerts_nopass.sh +10 -0
- data/spec/lib/simp/cli/config/item/files/autosign.conf.new +11 -0
- data/spec/lib/simp/cli/config/item/files/autosign.conf.used +15 -0
- data/spec/lib/simp/cli/config/item/files/fileserver.conf +41 -0
- data/spec/lib/simp/cli/config/item/files/hosts +2 -0
- data/spec/lib/simp/cli/config/item/files/hosts.old_puppet_entry +3 -0
- data/spec/lib/simp/cli/config/item/files/puppet.conf +25 -0
- data/spec/lib/simp/cli/config/item/files/puppet.your.domain.yaml +21 -0
- data/spec/lib/simp/cli/config/item/files/resolv.conf__multiple +10 -0
- data/spec/lib/simp/cli/config/item/files/resolv.conf__single +4 -0
- data/spec/lib/simp/cli/config/item/files/rsyncd.conf +225 -0
- data/spec/lib/simp/cli/config/item/gateway_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/grub_password_spec.rb +24 -0
- data/spec/lib/simp/cli/config/item/hostname_conf_spec.rb +27 -0
- data/spec/lib/simp/cli/config/item/hostname_spec.rb +22 -0
- data/spec/lib/simp/cli/config/item/ipaddress_spec.rb +40 -0
- data/spec/lib/simp/cli/config/item/is_master_yum_server_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/ldap_base_dn_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_bind_dn_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_bind_hash_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_bind_pw_spec.rb +21 -0
- data/spec/lib/simp/cli/config/item/ldap_master_spec.rb +37 -0
- data/spec/lib/simp/cli/config/item/ldap_root_dn_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_root_hash_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_sync_dn_spec.rb +22 -0
- data/spec/lib/simp/cli/config/item/ldap_sync_hash_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/ldap_sync_pw_spec.rb +21 -0
- data/spec/lib/simp/cli/config/item/ldap_uri_spec.rb +32 -0
- data/spec/lib/simp/cli/config/item/log_servers_spec.rb +49 -0
- data/spec/lib/simp/cli/config/item/netmask_spec.rb +28 -0
- data/spec/lib/simp/cli/config/item/network_conf_spec.rb +63 -0
- data/spec/lib/simp/cli/config/item/network_dhcp_spec.rb +11 -0
- data/spec/lib/simp/cli/config/item/network_interface_spec.rb +26 -0
- data/spec/lib/simp/cli/config/item/network_setup_nic_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/ntp_servers_spec.rb +43 -0
- data/spec/lib/simp/cli/config/item/puppet_autosign_spec.rb +55 -0
- data/spec/lib/simp/cli/config/item/puppet_ca_port_spec.rb +23 -0
- data/spec/lib/simp/cli/config/item/puppet_ca_spec.rb +22 -0
- data/spec/lib/simp/cli/config/item/puppet_conf_spec.rb +110 -0
- data/spec/lib/simp/cli/config/item/puppet_fileserver_spec.rb +53 -0
- data/spec/lib/simp/cli/config/item/puppet_hosts_entry_spec.rb +85 -0
- data/spec/lib/simp/cli/config/item/puppet_server_ip_spec.rb +24 -0
- data/spec/lib/simp/cli/config/item/puppet_server_spec.rb +22 -0
- data/spec/lib/simp/cli/config/item/puppetdb_port_spec.rb +25 -0
- data/spec/lib/simp/cli/config/item/puppetdb_server_spec.rb +25 -0
- data/spec/lib/simp/cli/config/item/remove_ldap_from_hiera_spec.rb +58 -0
- data/spec/lib/simp/cli/config/item/rename_fqdn_yaml_spec.rb +63 -0
- data/spec/lib/simp/cli/config/item/rsync_base_spec.rb +28 -0
- data/spec/lib/simp/cli/config/item/rsync_server_spec.rb +41 -0
- data/spec/lib/simp/cli/config/item/rsync_timeout_spec.rb +21 -0
- data/spec/lib/simp/cli/config/item/set_grub_password_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/simp_yum_servers_spec.rb +41 -0
- data/spec/lib/simp/cli/config/item/spec_helper.rb +22 -0
- data/spec/lib/simp/cli/config/item/use_auditd_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/use_fips_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/use_iptables_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/use_ldap_spec.rb +29 -0
- data/spec/lib/simp/cli/config/item/use_selinux_spec.rb +24 -0
- data/spec/lib/simp/cli/config/item/yum_repositories_spec.rb +94 -0
- data/spec/lib/simp/cli/config/item_spec.rb +106 -0
- data/spec/lib/simp/cli/config/spec_helper.rb +1 -0
- data/spec/lib/simp/cli/config/utils_spec.rb +131 -0
- data/spec/lib/simp/cli/spec_helper.rb +1 -0
- data/spec/spec_helper.rb +91 -0
- metadata +391 -0
@@ -0,0 +1,43 @@
|
|
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
|
+
# FIXME: what is this for?
|
10
|
+
class Item::LdapUri < ListItem
|
11
|
+
def initialize
|
12
|
+
super
|
13
|
+
@key = 'ldap::uri'
|
14
|
+
@description = %Q{List of OpenLDAP servers in URI form (ldap://server)}
|
15
|
+
end
|
16
|
+
|
17
|
+
|
18
|
+
def os_value
|
19
|
+
values = `grep URI /etc/openldap/ldap.conf`.split("\n").map do |line|
|
20
|
+
line =~ /^\s*URI\s+(.+)\s*/
|
21
|
+
$1
|
22
|
+
end.compact
|
23
|
+
values
|
24
|
+
end
|
25
|
+
|
26
|
+
|
27
|
+
def recommended_value
|
28
|
+
if item = @config_items.fetch( 'hostname', nil )
|
29
|
+
[ "ldap://#{item.value}" ]
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
|
34
|
+
def validate_item item
|
35
|
+
( item =~ %r{^ldap://.+} ) ? true : false &&
|
36
|
+
(
|
37
|
+
Simp::Cli::Config::Utils.validate_hostname( item ) ||
|
38
|
+
Simp::Cli::Config::Utils.validate_fqdn( item ) ||
|
39
|
+
Simp::Cli::Config::Utils.validate_ip( item )
|
40
|
+
)
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,27 @@
|
|
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::LogServers < ListItem
|
10
|
+
def initialize
|
11
|
+
super
|
12
|
+
@key = 'log_servers'
|
13
|
+
@description = %Q{Your log server(s). Only use hostnames here if at all possible.}
|
14
|
+
@allow_empty_list = true
|
15
|
+
end
|
16
|
+
|
17
|
+
def os_value
|
18
|
+
nil
|
19
|
+
end
|
20
|
+
|
21
|
+
def validate_item item
|
22
|
+
( Simp::Cli::Config::Utils.validate_hostname( item ) ||
|
23
|
+
Simp::Cli::Config::Utils.validate_fqdn( item ) ||
|
24
|
+
Simp::Cli::Config::Utils.validate_ip( item ) )
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,39 @@
|
|
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::Netmask < Item
|
9
|
+
def initialize
|
10
|
+
super
|
11
|
+
@key = 'netmask'
|
12
|
+
@description = %q{The netmask of the system.}
|
13
|
+
@__warning = false
|
14
|
+
end
|
15
|
+
|
16
|
+
def validate( x )
|
17
|
+
Simp::Cli::Config::Utils.validate_netmask x
|
18
|
+
end
|
19
|
+
|
20
|
+
# TODO: comment upon the hell-logic below
|
21
|
+
# TODO: possibly refactor ip and netmask os_value into shared parent
|
22
|
+
def os_value
|
23
|
+
netmask = nil
|
24
|
+
nic = @config_items.fetch('network::interface').value
|
25
|
+
if nic || @fact
|
26
|
+
@fact = @fact || "netmask_#{nic}"
|
27
|
+
netmask = super
|
28
|
+
if netmask.nil? and !@__warning
|
29
|
+
warning = "WARNING: #{@key}: No Netmask found for NIC #{nic}"
|
30
|
+
say "<%= color(%q{#{warning}}, YELLOW) %>\n"
|
31
|
+
@__warning = true
|
32
|
+
end
|
33
|
+
end
|
34
|
+
netmask
|
35
|
+
end
|
36
|
+
|
37
|
+
def recommended_value; os_value; end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,63 @@
|
|
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::NetworkConf < ActionItem
|
9
|
+
def initialize
|
10
|
+
super
|
11
|
+
@key = 'network::conf'
|
12
|
+
@description = 'action item; configures network interfaces'
|
13
|
+
@die_on_apply_fail = true
|
14
|
+
end
|
15
|
+
|
16
|
+
def apply
|
17
|
+
ci = {}
|
18
|
+
cmd = nil
|
19
|
+
|
20
|
+
dhcp = @config_items.fetch( 'dhcp' ).value
|
21
|
+
# BOOTPROTO=none is valid to spec; BOOTPROTO=static isn't
|
22
|
+
bootproto = (dhcp == 'static') ? 'none' : dhcp
|
23
|
+
interface = @config_items.fetch( 'network::interface' ).value
|
24
|
+
|
25
|
+
# apply the interface useing the SIMP classes
|
26
|
+
# NOTE: the "FACTER_ipaddress=XXX" helps puppet avoid a fatal error that
|
27
|
+
# occurs in the core ipaddress fact on offline systems.
|
28
|
+
cmd = %Q@FACTER_ipaddress=XXX puppet apply -e "network::add_eth{'#{interface}': bootproto => '#{bootproto}', onboot => 'yes'@
|
29
|
+
|
30
|
+
if bootproto == 'none'
|
31
|
+
ipaddress = @config_items.fetch( 'ipaddress' ).value
|
32
|
+
hostname = @config_items.fetch( 'hostname' ).value
|
33
|
+
netmask = @config_items.fetch( 'netmask' ).value
|
34
|
+
gateway = @config_items.fetch( 'gateway' ).value
|
35
|
+
dns_search = @config_items.fetch( 'dns::search' ).value
|
36
|
+
dns_servers = @config_items.fetch( 'dns::servers').value
|
37
|
+
|
38
|
+
resolv_domain = hostname.split('.')[1..-1].join('.')
|
39
|
+
cmd += %Q{, }
|
40
|
+
cmd += %Q@ipaddr => '#{ipaddress}', @
|
41
|
+
cmd += %Q@netmask => '#{netmask}', @
|
42
|
+
cmd += %Q@gateway => '#{gateway}' } @
|
43
|
+
cmd += %Q@class{ 'common::resolv': @
|
44
|
+
cmd += %Q@resolv_domain => '#{resolv_domain}', @
|
45
|
+
cmd += %Q@nameservers => #{ format_puppet_array( dns_servers ) }, @
|
46
|
+
cmd += %Q@search => #{ format_puppet_array( dns_search ) }, @
|
47
|
+
cmd += %Q@named_autoconf => false, @
|
48
|
+
end
|
49
|
+
cmd += %Q@}"@
|
50
|
+
# TODO: maybe good ideas
|
51
|
+
# - set $::domain with FACTER_domain=
|
52
|
+
# - set comon::resolv{ named_autofonf => false
|
53
|
+
|
54
|
+
puts cmd unless @silent
|
55
|
+
%x{#{cmd}}
|
56
|
+
end
|
57
|
+
|
58
|
+
def format_puppet_array v
|
59
|
+
v = [v] if v.kind_of? String
|
60
|
+
"['#{v.join "','"}']"
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
@@ -0,0 +1,27 @@
|
|
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::DHCP < Item
|
9
|
+
def initialize
|
10
|
+
super
|
11
|
+
@key = 'dhcp'
|
12
|
+
@description = %q{Whether or not to use DHCP to set up your network ("static" or "dhcp")}
|
13
|
+
end
|
14
|
+
|
15
|
+
def recommended_value
|
16
|
+
'static' # a puppet master is always recommended to be static.
|
17
|
+
end
|
18
|
+
|
19
|
+
def validate( x )
|
20
|
+
return ['dhcp', 'static' ].include?( x.to_s.downcase )
|
21
|
+
end
|
22
|
+
|
23
|
+
def not_valid_message
|
24
|
+
'Valid answers are "static" or "dhcp"'
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,41 @@
|
|
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
|
+
|
9
|
+
class Item::NetworkInterface < Item
|
10
|
+
def initialize
|
11
|
+
super
|
12
|
+
@key = 'network::interface'
|
13
|
+
@description = 'The network interface to use to connect to the network.'
|
14
|
+
end
|
15
|
+
|
16
|
+
# try to guess which NIC is likely to be used
|
17
|
+
# TODO IDEA: also use Facter to prefer NICs that already have IPs
|
18
|
+
def recommended_value
|
19
|
+
devices = acceptable_values
|
20
|
+
(
|
21
|
+
devices.select{|x| x.match(/^br/)}.first ||
|
22
|
+
devices.select{|x| x.match(/^eth/)}.first ||
|
23
|
+
devices.select{|x| x.match(/^em/)}.first ||
|
24
|
+
devices.first
|
25
|
+
)
|
26
|
+
end
|
27
|
+
|
28
|
+
def validate( x )
|
29
|
+
acceptable_values.include?( x )
|
30
|
+
end
|
31
|
+
|
32
|
+
def not_valid_message
|
33
|
+
"Acceptable values: \n" + acceptable_values.map{ |x| " #{x}" }.join("\n")
|
34
|
+
end
|
35
|
+
|
36
|
+
# helper method; provides a list of available NICs
|
37
|
+
def acceptable_values
|
38
|
+
Facter.value('interfaces').split(',').delete_if{|x| x == 'lo'}.sort
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,28 @@
|
|
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::SetupNIC < YesNoItem
|
9
|
+
def initialize
|
10
|
+
super
|
11
|
+
@key = 'network::setup_nic'
|
12
|
+
@description = %Q{Do you want to activate this NIC now?}
|
13
|
+
end
|
14
|
+
|
15
|
+
def recommended_value
|
16
|
+
os_value || 'yes'
|
17
|
+
end
|
18
|
+
|
19
|
+
def query_ask
|
20
|
+
# TODO: check, then
|
21
|
+
# The NIC does not currently have an IP, Netmask, or Gateway
|
22
|
+
nic = @config_items.fetch('network::interface').value
|
23
|
+
# @description.gsub( 'this NIC'
|
24
|
+
super
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,69 @@
|
|
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::NTPServers < ListItem
|
10
|
+
def initialize
|
11
|
+
super
|
12
|
+
@key = 'ntpd::servers'
|
13
|
+
@warnings = {
|
14
|
+
:no_ntp => "A consistent time source is critical to your systems' security.",
|
15
|
+
:warning_hw_clocks => "DO NOT run multiple production systems using individual hardware clocks!",
|
16
|
+
}
|
17
|
+
@description = "Your network's NTP time servers.\n\n#{@warnings.values.join("\n")}"
|
18
|
+
@allow_empty_list = true
|
19
|
+
end
|
20
|
+
|
21
|
+
def description
|
22
|
+
extra = ''
|
23
|
+
if @config_items.key? 'gateway'
|
24
|
+
gateway = @config_items.fetch('gateway').value
|
25
|
+
extra = "\nFor many networks, the default gateway (#{gateway}) provides an NTP server."
|
26
|
+
end
|
27
|
+
"#{@description}#{extra}"
|
28
|
+
end
|
29
|
+
|
30
|
+
def os_value( file='/etc/ntp/ntpservers' )
|
31
|
+
# TODO: make this a custom fact?
|
32
|
+
# TODO: is /etc/ntp/ntpservers being used in recent versions of SIMP?
|
33
|
+
servers = []
|
34
|
+
if File.readable? file
|
35
|
+
File.readlines( file ).map do |line|
|
36
|
+
line.strip!
|
37
|
+
if line !~ /^#/
|
38
|
+
servers << line
|
39
|
+
else
|
40
|
+
nil
|
41
|
+
end
|
42
|
+
end.compact
|
43
|
+
end
|
44
|
+
servers
|
45
|
+
end
|
46
|
+
|
47
|
+
def recommended_value
|
48
|
+
if (!os_value.empty?) && (os_value.first !~ /^127\./)
|
49
|
+
os_value
|
50
|
+
else
|
51
|
+
nil
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
# allow empty NTP servers, but reiterate warning because it's important.
|
56
|
+
def validate list
|
57
|
+
if !@silent && (list.is_a?(Array) || list.is_a?(String)) && list.empty?
|
58
|
+
say_red( "IMPORTANT: #{@warnings.fetch(:no_ntp)}" )
|
59
|
+
sleep 3 # TODO: should there be a standard timeout for Item delays?
|
60
|
+
end
|
61
|
+
super
|
62
|
+
end
|
63
|
+
|
64
|
+
def validate_item item
|
65
|
+
( Simp::Cli::Config::Utils.validate_ip( item ) ||
|
66
|
+
Simp::Cli::Config::Utils.validate_fqdn( item ) )
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require 'highline/import'
|
2
|
+
require File.expand_path( '../item', File.dirname(__FILE__) )
|
3
|
+
require File.expand_path( '../utils', File.dirname(__FILE__) )
|
4
|
+
module Simp; end
|
5
|
+
class Simp::Cli; end
|
6
|
+
module Simp::Cli::Config
|
7
|
+
class Item::PuppetAutosign < ActionItem
|
8
|
+
attr_accessor :file
|
9
|
+
def initialize
|
10
|
+
super
|
11
|
+
@key = 'puppet::autosign'
|
12
|
+
@description = %Q{By default, the only host eligible for autosign is the puppet master.}
|
13
|
+
@file = '/etc/puppet/autosign.conf'
|
14
|
+
end
|
15
|
+
|
16
|
+
def os_value
|
17
|
+
# TODO: make this a custom fact?
|
18
|
+
values = Array.new
|
19
|
+
File.readable?(@file) &&
|
20
|
+
File.readlines(@file).each do |line|
|
21
|
+
next if line =~ /^(\#|\s*$)/
|
22
|
+
|
23
|
+
# if we encounter 'puppet.your.domain' (the default value from a
|
24
|
+
# fresh simp-bootstrap RPM), infer this is a freshly installed system
|
25
|
+
# with no legitimate autosign entries.
|
26
|
+
if line =~ /^puppet.your.domain/
|
27
|
+
values = []
|
28
|
+
break
|
29
|
+
end
|
30
|
+
values << line.strip
|
31
|
+
end
|
32
|
+
if values.size == 0
|
33
|
+
nil
|
34
|
+
else
|
35
|
+
values
|
36
|
+
end
|
37
|
+
end
|
38
|
+
|
39
|
+
def recommended_value
|
40
|
+
item = os_value
|
41
|
+
if !item
|
42
|
+
item = @config_items.fetch( 'hostname', nil )
|
43
|
+
item = [ item.value ] if item
|
44
|
+
end
|
45
|
+
item
|
46
|
+
end
|
47
|
+
|
48
|
+
def apply
|
49
|
+
entries = recommended_value
|
50
|
+
say_green "Updating #{@file}..." if !@silent
|
51
|
+
File.open(@file, 'w') do |file|
|
52
|
+
file.puts "# You should place any hostnames/domains here that you wish to autosign.\n" +
|
53
|
+
"# The most security-conscious method is to list each individual hostname:\n" +
|
54
|
+
"# hosta.your.domain\n" +
|
55
|
+
"# hostb.your.domain\n" +
|
56
|
+
"#\n" +
|
57
|
+
"# Wildcard domains work, but absolutely should NOT be used unless you fully\n" +
|
58
|
+
"# trust your network.\n" +
|
59
|
+
"# *.your.domain\n\n"
|
60
|
+
entries.each do |entry|
|
61
|
+
file.puts(entry)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,31 @@
|
|
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::PuppetCA < Item
|
10
|
+
def initialize
|
11
|
+
super
|
12
|
+
@key = 'puppet::ca'
|
13
|
+
@description = 'The Puppet Certificate Authority'
|
14
|
+
end
|
15
|
+
|
16
|
+
def os_value
|
17
|
+
Puppet.settings.setting( 'ca_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
|
+
Simp::Cli::Config::Utils.validate_ip( x )
|
24
|
+
end
|
25
|
+
|
26
|
+
def recommended_value
|
27
|
+
item = @config_items.fetch( 'hostname', nil )
|
28
|
+
item.value if item
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|