2018-10-23 17:17:39 +00:00
|
|
|
require "log4r"
|
|
|
|
|
2013-04-04 06:18:12 +00:00
|
|
|
module VagrantPlugins
|
|
|
|
module GuestDebian
|
|
|
|
module Cap
|
|
|
|
class ChangeHostName
|
2018-10-16 18:54:58 +00:00
|
|
|
|
|
|
|
extend Vagrant::Util::GuestInspection::Linux
|
|
|
|
|
2013-04-04 06:18:12 +00:00
|
|
|
def self.change_host_name(machine, name)
|
2018-10-23 17:17:39 +00:00
|
|
|
@logger = Log4r::Logger.new("vagrant::guest::debian::changehostname")
|
2016-06-05 01:31:41 +00:00
|
|
|
comm = machine.communicate
|
|
|
|
|
2016-06-23 02:29:46 +00:00
|
|
|
if !comm.test("hostname -f | grep '^#{name}$'", sudo: false)
|
2016-06-05 01:31:41 +00:00
|
|
|
basename = name.split(".", 2)[0]
|
|
|
|
comm.sudo <<-EOH.gsub(/^ {14}/, '')
|
|
|
|
# Set the hostname
|
2016-06-23 01:32:33 +00:00
|
|
|
echo '#{basename}' > /etc/hostname
|
2016-06-25 19:51:58 +00:00
|
|
|
|
2016-06-05 01:31:41 +00:00
|
|
|
# Prepend ourselves to /etc/hosts
|
|
|
|
grep -w '#{name}' /etc/hosts || {
|
2018-01-26 11:02:17 +00:00
|
|
|
if grep -w '^127\\.0\\.1\\.1' /etc/hosts ; then
|
|
|
|
sed -i'' 's/^127\\.0\\.1\\.1\\s.*$/127.0.1.1\\t#{name}\\t#{basename}/' /etc/hosts
|
|
|
|
else
|
|
|
|
sed -i'' '1i 127.0.1.1\\t#{name}\\t#{basename}' /etc/hosts
|
|
|
|
fi
|
2016-06-05 01:31:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Update mailname
|
|
|
|
echo '#{name}' > /etc/mailname
|
|
|
|
|
2018-10-16 18:54:58 +00:00
|
|
|
EOH
|
|
|
|
|
|
|
|
if hostnamectl?(comm)
|
|
|
|
comm.sudo("hostnamectl set-hostname '#{basename}'")
|
|
|
|
else
|
|
|
|
comm.sudo <<-EOH.gsub(/^ {14}/, '')
|
|
|
|
hostname -F /etc/hostname
|
2016-06-25 19:51:58 +00:00
|
|
|
# Restart hostname services
|
|
|
|
if test -f /etc/init.d/hostname; then
|
|
|
|
/etc/init.d/hostname start || true
|
2016-06-05 01:31:41 +00:00
|
|
|
fi
|
|
|
|
|
2016-06-25 19:51:58 +00:00
|
|
|
if test -f /etc/init.d/hostname.sh; then
|
|
|
|
/etc/init.d/hostname.sh start || true
|
2016-06-05 01:31:41 +00:00
|
|
|
fi
|
2018-10-16 18:54:58 +00:00
|
|
|
EOH
|
|
|
|
end
|
|
|
|
|
2018-10-23 17:17:39 +00:00
|
|
|
init_restart_command = "/etc/init.d/networking restart"
|
|
|
|
ifdownup_restart_command = "ifdown --exclude=lo -a && ifup --exclude=lo -a"
|
|
|
|
systemctl_restart_command = "systemctl stop ifup@eth0.service && systemctl start ifup@eth0.service"
|
2018-10-16 18:54:58 +00:00
|
|
|
|
2018-10-23 17:17:39 +00:00
|
|
|
restart_command = ifdownup_restart_command
|
2018-10-16 18:54:58 +00:00
|
|
|
if systemd?(comm)
|
|
|
|
if systemd_networkd?(comm)
|
2018-10-23 17:17:39 +00:00
|
|
|
@logger.debug("Attempting to restart networking with systemd-networkd")
|
2018-10-16 18:54:58 +00:00
|
|
|
restart_command = "systemctl restart systemd-networkd.service"
|
|
|
|
elsif systemd_controlled?(comm, "NetworkManager.service")
|
2018-10-23 17:17:39 +00:00
|
|
|
@logger.debug("Attempting to restart networking with NetworkManager")
|
2018-10-16 18:54:58 +00:00
|
|
|
restart_command = "systemctl restart NetworkManager.service"
|
2018-10-23 17:17:39 +00:00
|
|
|
else
|
|
|
|
@logger.debug("Attempting to restart networking with ifup@.service")
|
|
|
|
restart_command = systemctl_restart_command
|
2018-10-16 18:54:58 +00:00
|
|
|
end
|
2018-10-23 17:17:39 +00:00
|
|
|
else
|
|
|
|
@logger.debug("Attempting to restart networking with ifdown/ifup net tools")
|
|
|
|
end
|
|
|
|
|
|
|
|
if !comm.test(restart_command, sudo: true)
|
|
|
|
@logger.debug("Attempting to restart networking with init networking service")
|
|
|
|
comm.sudo(init_restart_command)
|
2018-10-16 18:54:58 +00:00
|
|
|
end
|
2013-04-04 06:18:12 +00:00
|
|
|
end
|
2014-05-05 01:32:33 +00:00
|
|
|
end
|
2013-04-04 06:18:12 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|