Class: VagrantPlugins::WinAzure::Provider
- Inherits:
-
Object
- Object
- VagrantPlugins::WinAzure::Provider
- Defined in:
- lib/vagrant-azure/provider.rb
Instance Attribute Summary collapse
-
#driver ⇒ Object
readonly
Returns the value of attribute driver.
Instance Method Summary collapse
- #action(name) ⇒ Object
-
#initialize(machine) ⇒ Provider
constructor
A new instance of Provider.
- #machine_id_changed ⇒ Object
- #rdp_info ⇒ Object
- #ssh_info ⇒ Object
- #state ⇒ Object
- #to_s ⇒ Object
- #winrm_info ⇒ Object
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
#driver ⇒ Object (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_changed ⇒ Object
33 34 35 |
# File 'lib/vagrant-azure/provider.rb', line 33 def machine_id_changed @driver = Driver.new(@machine) end |
#rdp_info ⇒ Object
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_info ⇒ Object
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 |
#state ⇒ Object
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_s ⇒ Object
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_info ⇒ Object
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 |