Class: VagrantPlugins::Rimu::Provider

Inherits:
Object
  • Object
show all
Defined in:
lib/vagrant-rimu/provider.rb

Instance Method Summary collapse

Constructor Details

#initialize(machine) ⇒ Provider

Returns a new instance of Provider.



9
10
11
# File 'lib/vagrant-rimu/provider.rb', line 9

def initialize(machine)
  @machine = machine
end

Instance Method Details

#action(name) ⇒ Object



13
14
15
16
17
18
19
20
# File 'lib/vagrant-rimu/provider.rb', line 13

def action(name)
  # Attempt to get the action method from the Action class if it
  # exists, otherwise return nil to show that we don't support the
  # given action.
  action_method = "action_#{name}"
  return Actions.send(action_method) if Actions.respond_to?(action_method)
  nil
end

#ssh_infoObject



22
23
24
25
26
27
28
# File 'lib/vagrant-rimu/provider.rb', line 22

def ssh_info
  # Run a custom action called "read_ssh_info" which does what it
  # says and puts the resulting SSH info into the `:machine_ssh_info`
  # key in the environment.
  env = @machine.action("read_ssh_info")
  env[:machine_ssh_info]
end

#stateObject



30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/vagrant-rimu/provider.rb', line 30

def state
  # Run a custom action we define called "read_state" which does
  # what it says. It puts the state in the `:machine_state_id`
  # key in the environment.
  env = @machine.action("read_state")

  state_id = env[:machine_state]

  # Get the short and long description
  short = I18n.t("vagrant_rimu.states.short_#{state_id}")
  long  = I18n.t("vagrant_rimu.states.long_#{state_id}")

  # Return the MachineState object
  Vagrant::MachineState.new(state_id, short, long)
end

#to_sObject



46
47
48
49
50
51
52
53
# File 'lib/vagrant-rimu/provider.rb', line 46

def to_s
  if @machine.respond_to?('id') and ! @machine.id.nil?
    id = @machine.id
  else
    id = 'new'
  end
  "Rimu (#{id})"
end