Class: VagrantSubutai::Provisioner

Inherits:
Object
  • Object
show all
Defined in:
lib/vagrant-subutai/provisioner.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(machine, config) ⇒ Provisioner

Initializes the provisioner with the machine that it will be provisioning along with the provisioner configuration (if there is any).

The provisioner should not do anything at this point except initialize internal state.

Parameters:

  • machine (Machine)

    The machine that this will be provisioning.

  • config (Object)

    Provisioner configuration, if one was set.



18
19
20
21
# File 'lib/vagrant-subutai/provisioner.rb', line 18

def initialize(machine, config)
  @machine = machine
  @config  = config
end

Instance Attribute Details

#configObject (readonly)

Returns the value of attribute config.



7
8
9
# File 'lib/vagrant-subutai/provisioner.rb', line 7

def config
  @config
end

#machineObject (readonly)

Returns the value of attribute machine.



6
7
8
# File 'lib/vagrant-subutai/provisioner.rb', line 6

def machine
  @machine
end

Instance Method Details

#cleanupObject

This is the method called when destroying a machine that allows for any state related to the machine created by the provisioner to be cleaned up.



62
63
# File 'lib/vagrant-subutai/provisioner.rb', line 62

def cleanup
end

#configure(root_config) ⇒ Object

Called with the root configuration of the machine so the provisioner can add some configuration on top of the machine.

During this step, and this step only, the provisioner should modify the root machine configuration to add any additional features it may need. Examples include sharing folders, networking, and so on. This step is guaranteed to be called before any of those steps are done so the provisioner may do that.

No return value is expected.



33
34
# File 'lib/vagrant-subutai/provisioner.rb', line 33

def configure(root_config)
end

#provisionObject

This is the method called when the actual provisioning should be done. The communicator is guaranteed to be ready at this point, and any shared folders or networks are already setup.

No return value is expected.



41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
# File 'lib/vagrant-subutai/provisioner.rb', line 41

def provision
  unless SubutaiConfig.get(:BLUEPRINT_NO_AUTO)
    # If Subutai.json exist
    if File.exist?(File.join(Dir.pwd, Configs::Blueprint::FILE_NAME))
      subutai_cli = Commands.new(ARGV, @machine.env)
      ip = subutai_cli.info(Configs::VagrantCommand::ARG_IP_ADDR)

      if ip.nil?
        STDOUT.puts 'We can\'t detect your PeerOS ip address!'
        exit
      end
      url = "https://#{ip}:#{Configs::SubutaiConsoleAPI::PORT}"

      subutai_cli.blueprint(url, 1)
    end
  end
end