Avoid udev rule masking and configure ifaces with sed instead.

This commit is contained in:
me 2013-12-05 15:16:59 +01:00
parent 6f187c898a
commit 158d82ea39
1 changed files with 12 additions and 1 deletions

View File

@ -18,9 +18,20 @@ module VagrantPlugins
temp.write(entry)
temp.close
# Only consider nth line of sed's output below. There certainly is a
# better way to do this
snth = network[:interface] + 1
machine.communicate.upload(temp.path, "/tmp/vagrant_network")
machine.communicate.sudo("ln -sf /dev/null /etc/udev/rules.d/80-net-name-slot.rules")
machine.communicate.sudo("mv /tmp/vagrant_network /etc/netctl/eth#{network[:interface]}")
# A hack not to rely on udev rule 80-net-name-slot.rules masking:
# ln -sf /dev/null /etc/udev/80-net-name-slot.rules that
# I assume this to be the most portable solution because
# otherwise we would need to rely on the Virtual Machine implementation
# to provide details on the configured interfaces, e.g mac address
# to write a custom udev rule.
machine.communicate.sudo("sed -i s/eth#{network[:interface]}/`systemctl list-units -t device | sed -n 's/.*subsystem.net-devices-\\(.*\\).device.*/\\1/p' | sed -n #{snth}p`/g /etc/netctl/eth#{network[:interface]}")
machine.communicate.sudo("netctl start eth#{network[:interface]}")
end
end