Class: VagrantPlugins::ProfitBricks::Provider

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

Instance Method Summary collapse

Constructor Details

#initialize(machine) ⇒ Provider

Returns a new instance of Provider.



10
11
12
# File 'lib/vagrant-profitbricks/provider.rb', line 10

def initialize(machine)
  @machine = machine
end

Instance Method Details

#action(name) ⇒ Object



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

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 Action.send(action_method) if Action.respond_to?(action_method)
  nil
end

#ssh_infoObject



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

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



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

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_id]

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

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

#to_sObject



47
48
49
# File 'lib/vagrant-profitbricks/provider.rb', line 47

def to_s
  'ProfitBricks Cloud'
end