Class: VagrantPlugins::WinAzure::Provider

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

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(machine) ⇒ Provider

Returns a new instance of Provider.



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

def initialize(machine)
  @machine = machine

  # Load the driver
  machine_id_changed

  @machine.config.winrm.password = @machine.provider_config.vm_password || @machine.provider_config.vm_user
  @machine.config.winrm.username = @machine.provider_config.vm_user
end

Instance Attribute Details

#driverObject (readonly)

Returns the value of attribute driver.



12
13
14
# File 'lib/vagrant-azure/provider.rb', line 12

def driver
  @driver
end

Instance Method Details

#action(name) ⇒ Object



24
25
26
27
28
29
30
31
# File 'lib/vagrant-azure/provider.rb', line 24

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

#machine_id_changedObject



33
34
35
# File 'lib/vagrant-azure/provider.rb', line 33

def machine_id_changed
  @driver = Driver.new(@machine)
end

#rdp_infoObject



45
46
47
48
# File 'lib/vagrant-azure/provider.rb', line 45

def rdp_info
  env = @machine.action('read_rdp_info')
  env[:machine_ssh_info]
end

#ssh_infoObject



37
38
39
40
41
42
43
# File 'lib/vagrant-azure/provider.rb', line 37

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



55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/vagrant-azure/provider.rb', line 55

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 env
  env = @machine.action('read_state')
  state_id = env[:machine_state_id]

  short = "Machine's current state is #{state_id}"
  long = ""

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

#to_sObject



68
69
70
71
# File 'lib/vagrant-azure/provider.rb', line 68

def to_s
  id = @machine.id.nil? ? 'new' : @machine.id
  "Azure (#{id})"
end

#winrm_infoObject



50
51
52
53
# File 'lib/vagrant-azure/provider.rb', line 50

def winrm_info
  env = @machine.action('read_winrm_info')
  env[:machine_winrm_info]
end