Class: Vagrant::Hosts::BSD

Inherits:
Base
  • Object
show all
Includes:
Util, Util::Retryable
Defined in:
lib/vagrant/hosts/bsd.rb

Overview

Represents a BSD host, such as FreeBSD and Darwin (Mac OS X).

Direct Known Subclasses

FreeBSD

Class Method Summary collapse

Instance Method Summary collapse

Methods included from Util::Retryable

#retryable

Constructor Details

#initialize(*args) ⇒ BSD

Returns a new instance of BSD.



22
23
24
25
26
27
28
# File 'lib/vagrant/hosts/bsd.rb', line 22

def initialize(*args)
  super

  @logger = Log4r::Logger.new("vagrant::hosts::bsd")
  @nfs_restart_command = "sudo nfsd restart"
  @nfs_exports_template = "nfs/exports"
end

Class Method Details

.match?Boolean

Returns:

  • (Boolean)


12
13
14
# File 'lib/vagrant/hosts/bsd.rb', line 12

def self.match?
  Util::Platform.darwin? || Util::Platform.bsd?
end

.precedenceObject



16
17
18
19
20
# File 'lib/vagrant/hosts/bsd.rb', line 16

def self.precedence
  # Set a lower precedence because this is a generic OS. We
  # want specific distros to match first.
  2
end

Instance Method Details

#nfs?Boolean

Returns:

  • (Boolean)


30
31
32
33
34
# File 'lib/vagrant/hosts/bsd.rb', line 30

def nfs?
  retryable(:tries => 10, :on => TypeError) do
    system("which nfsd > /dev/null 2>&1")
  end
end

#nfs_export(id, ip, folders) ⇒ Object



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/vagrant/hosts/bsd.rb', line 36

def nfs_export(id, ip, folders)
  output = TemplateRenderer.render(@nfs_exports_template,
                                   :uuid => id,
                                   :ip => ip,
                                   :folders => folders)

  # The sleep ensures that the output is truly flushed before any `sudo`
  # commands are issued.
  @ui.info I18n.t("vagrant.hosts.bsd.nfs_export")
  sleep 0.5

  # First, clean up the old entry
  nfs_cleanup(id)

  # Output the rendered template into the exports
  output.split("\n").each do |line|
    line = line.gsub('"', '\"')
    system(%Q[sudo su root -c "echo '#{line}' >> /etc/exports"])
  end

  # We run restart here instead of "update" just in case nfsd
  # is not starting
  system(@nfs_restart_command)
end

#nfs_prune(valid_ids) ⇒ Object



61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# File 'lib/vagrant/hosts/bsd.rb', line 61

def nfs_prune(valid_ids)
  return if !File.exist?("/etc/exports")

  @logger.info("Pruning invalid NFS entries...")

  output = false

  File.read("/etc/exports").lines.each do |line|
    if line =~ /^# VAGRANT-BEGIN: (.+?)$/
      if valid_ids.include?($1.to_s)
        @logger.debug("Valid ID: #{$1.to_s}")
      else
        if !output
          # We want to warn the user but we only want to output once
          @ui.info I18n.t("vagrant.hosts.bsd.nfs_prune")
          output = true
        end

        @logger.info("Invalid ID, pruning: #{$1.to_s}")
        nfs_cleanup($1.to_s)
      end
    end
  end
end