2011-01-14 14:12:43 +00:00
|
|
|
module Vagrant
|
2011-12-16 05:05:19 +00:00
|
|
|
module Guest
|
2011-01-14 14:12:43 +00:00
|
|
|
# A general Vagrant system implementation for "freebsd".
|
|
|
|
#
|
|
|
|
# Contributed by Kenneth Vestergaard <kvs@binarysolutions.dk>
|
|
|
|
class FreeBSD < Base
|
|
|
|
# A custom config class which will be made accessible via `config.freebsd`
|
|
|
|
# This is not necessary for all system implementers, of course. However,
|
|
|
|
# generally, Vagrant tries to make almost every aspect of its execution
|
|
|
|
# configurable, and this assists that goal.
|
|
|
|
class FreeBSDConfig < Vagrant::Config::Base
|
|
|
|
attr_accessor :halt_timeout
|
|
|
|
attr_accessor :halt_check_interval
|
|
|
|
|
|
|
|
def initialize
|
|
|
|
@halt_timeout = 30
|
|
|
|
@halt_check_interval = 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Here for whenever it may be used.
|
|
|
|
class FreeBSDError < Errors::VagrantError
|
2011-12-16 05:07:43 +00:00
|
|
|
error_namespace("vagrant.guest.freebsd")
|
2011-01-14 14:12:43 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def halt
|
2012-01-07 04:03:56 +00:00
|
|
|
vm.channel.sudo("shutdown -p now")
|
2011-01-14 14:12:43 +00:00
|
|
|
|
|
|
|
# Wait until the VM's state is actually powered off. If this doesn't
|
|
|
|
# occur within a reasonable amount of time (15 seconds by default),
|
|
|
|
# then simply return and allow Vagrant to kill the machine.
|
|
|
|
count = 0
|
2011-12-22 21:38:30 +00:00
|
|
|
while vm.state != :poweroff
|
2011-01-14 14:12:43 +00:00
|
|
|
count += 1
|
|
|
|
|
2011-12-10 21:44:45 +00:00
|
|
|
return if count >= vm.config.freebsd.halt_timeout
|
|
|
|
sleep vm.config.freebsd.halt_check_interval
|
2011-01-14 14:12:43 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-01-22 00:02:12 +00:00
|
|
|
# TODO: Error/warning about this.
|
2011-01-14 14:12:43 +00:00
|
|
|
# def mount_shared_folder(ssh, name, guestpath)
|
|
|
|
# ssh.exec!("sudo mkdir -p #{guestpath}")
|
|
|
|
# # Using a custom mount method here; could use improvement.
|
|
|
|
# ssh.exec!("sudo mount -t vboxfs v-root #{guestpath}")
|
2011-12-10 21:44:45 +00:00
|
|
|
# ssh.exec!("sudo chown #{vm.config.ssh.username} #{guestpath}")
|
2011-01-14 14:12:43 +00:00
|
|
|
# end
|
|
|
|
|
|
|
|
def mount_nfs(ip, folders)
|
|
|
|
folders.each do |name, opts|
|
2012-01-07 04:03:56 +00:00
|
|
|
vm.channel.sudo("mkdir -p #{opts[:guestpath]}")
|
|
|
|
vm.channel.sudo("mount #{ip}:#{opts[:hostpath]} #{opts[:guestpath]}")
|
2011-01-14 14:12:43 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-01-27 20:19:15 +00:00
|
|
|
def configure_networks(networks)
|
2011-01-14 14:12:43 +00:00
|
|
|
# Remove any previous host only network additions to the
|
|
|
|
# interface file.
|
2012-01-27 20:19:15 +00:00
|
|
|
vm.channel.sudo("sed -e '/^#VAGRANT-BEGIN-HOSTONLY/,/^#VAGRANT-END-HOSTONLY/ d' /etc/rc.conf > /tmp/rc.conf")
|
|
|
|
vm.channel.sudo("mv /tmp/rc.conf /etc/rc.conf")
|
2011-01-14 14:12:43 +00:00
|
|
|
|
2012-01-27 20:19:15 +00:00
|
|
|
networks.each do |network|
|
|
|
|
entry = "#VAGRANT-BEGIN-HOSTONLY\nifconfig_em#{network[:interface]}=\"inet #{network[:ip]} netmask #{network[:netmask]}\"\n#VAGRANT-END-HOSTONLY\n"
|
|
|
|
vm.channel.upload(StringIO.new(entry), "/tmp/vagrant-network-entry")
|
2011-01-14 14:12:43 +00:00
|
|
|
|
2012-01-27 20:19:15 +00:00
|
|
|
vm.channel.sudo("su -m root -c 'cat /tmp/vagrant-network-entry >> /etc/rc.conf'")
|
|
|
|
vm.channel.sudo("ifconfig em#{network[:interface]} inet #{network[:ip]} netmask #{network[:netmask]}")
|
2011-01-14 14:12:43 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|