akissa/vagrant-rimu

View on GitHub
lib/vagrant-rimu/provider.rb

Summary

Maintainability
A
0 mins
Test Coverage
require 'vagrant'

require 'vagrant-rimu/actions'

module VagrantPlugins
  module Rimu
    class Provider < Vagrant.plugin('2', :provider)

      def initialize(machine)
        @machine = machine
      end

      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

      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

      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

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