2013-03-02 15:17:04 +00:00
|
|
|
require 'vagrant-lxc/action/base_action'
|
2013-03-03 05:24:05 +00:00
|
|
|
|
|
|
|
require 'vagrant-lxc/action/after_create'
|
|
|
|
require 'vagrant-lxc/action/boot'
|
|
|
|
require 'vagrant-lxc/action/check_created'
|
|
|
|
require 'vagrant-lxc/action/check_running'
|
|
|
|
require 'vagrant-lxc/action/create'
|
|
|
|
require 'vagrant-lxc/action/created'
|
|
|
|
require 'vagrant-lxc/action/destroy'
|
2013-03-02 15:17:04 +00:00
|
|
|
require 'vagrant-lxc/action/handle_box_metadata'
|
2013-03-03 05:24:05 +00:00
|
|
|
require 'vagrant-lxc/action/is_running'
|
2013-03-05 03:58:37 +00:00
|
|
|
require 'vagrant-lxc/action/network'
|
2013-03-04 01:42:18 +00:00
|
|
|
require 'vagrant-lxc/action/share_folders'
|
2013-02-28 03:21:59 +00:00
|
|
|
|
|
|
|
module Vagrant
|
|
|
|
module LXC
|
2013-03-02 06:57:03 +00:00
|
|
|
module Action
|
2013-02-28 03:21:59 +00:00
|
|
|
# This action is responsible for reloading the machine, which
|
|
|
|
# brings it down, sucks in new configuration, and brings the
|
|
|
|
# machine back up with the new configuration.
|
|
|
|
def self.action_reload
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::Call, Created do |env1, b2|
|
|
|
|
if !env1[:result]
|
|
|
|
b2.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotCreated
|
|
|
|
next
|
|
|
|
end
|
|
|
|
|
|
|
|
b2.use Vagrant::Action::Builtin::ConfigValidate
|
|
|
|
b2.use action_halt
|
|
|
|
b2.use action_start
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# We could do this here as VirtualBox does, but at least for now its better
|
|
|
|
# to be explicit and have the full constant name in order to easily spot
|
|
|
|
# what we implemented and what is builtin on Vagrant.
|
|
|
|
#
|
|
|
|
# include Vagrant::Action::Builtin
|
|
|
|
|
|
|
|
# This action boots the VM, assuming the VM is in a state that requires
|
|
|
|
# a bootup (i.e. not saved).
|
|
|
|
def self.action_boot
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use ClearForwardedPorts
|
|
|
|
b.use Vagrant::Action::Builtin::Provision
|
|
|
|
b.use Vagrant::Action::Builtin::EnvSet, :port_collision_repair => true
|
|
|
|
b.use PrepareForwardedPortCollisionParams
|
2013-03-04 01:42:18 +00:00
|
|
|
# b.use ClearSharedFolders
|
2013-02-28 03:21:59 +00:00
|
|
|
b.use ShareFolders
|
|
|
|
b.use Network
|
|
|
|
b.use ForwardPorts
|
|
|
|
b.use SaneDefaults
|
|
|
|
b.use Customize
|
2013-03-04 04:09:12 +00:00
|
|
|
b.use AfterCreate
|
2013-02-28 03:21:59 +00:00
|
|
|
b.use Boot
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-04 04:10:09 +00:00
|
|
|
# This action just runs the provisioners on the machine.
|
|
|
|
def self.action_provision
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::ConfigValidate
|
|
|
|
b.use Vagrant::Action::Builtin::Call, Created do |env1, b2|
|
|
|
|
if !env1[:result]
|
|
|
|
b2.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotCreated
|
|
|
|
next
|
|
|
|
end
|
|
|
|
|
|
|
|
b2.use Vagrant::Action::Builtin::Call, IsRunning do |env2, b3|
|
|
|
|
if !env2[:result]
|
|
|
|
b3.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotRunning
|
|
|
|
next
|
|
|
|
end
|
|
|
|
|
|
|
|
# b3.use CheckAccessible
|
|
|
|
b3.use Vagrant::Action::Builtin::Provision
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-28 03:21:59 +00:00
|
|
|
# This action starts a container, assuming it is already created and exists.
|
|
|
|
# A precondition of this action is that the container exists.
|
|
|
|
def self.action_start
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::ConfigValidate
|
|
|
|
b.use Vagrant::Action::Builtin::Call, IsRunning do |env, b2|
|
|
|
|
# If the VM is running, then our work here is done, exit
|
|
|
|
next if env[:result]
|
|
|
|
# TODO: Check if has been saved / frozen and resume
|
|
|
|
b2.use action_boot
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# This action brings the machine up from nothing, including creating the
|
|
|
|
# container, configuring metadata, and booting.
|
|
|
|
def self.action_up
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::ConfigValidate
|
|
|
|
b.use Vagrant::Action::Builtin::Call, Created do |env, b2|
|
|
|
|
# If the VM is NOT created yet, then do the setup steps
|
|
|
|
if !env[:result]
|
2013-03-04 22:35:50 +00:00
|
|
|
b2.use Vagrant::Action::Builtin::HandleBoxUrl
|
2013-03-02 15:17:04 +00:00
|
|
|
b2.use HandleBoxMetadata
|
2013-02-28 03:21:59 +00:00
|
|
|
b2.use Create
|
|
|
|
end
|
|
|
|
end
|
|
|
|
b.use action_start
|
2013-03-04 01:42:18 +00:00
|
|
|
# b.use Vagrant::Action::Builtin::SetHostname
|
2013-02-28 03:21:59 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# This is the action that is primarily responsible for halting
|
|
|
|
# the virtual machine, gracefully or by force.
|
|
|
|
def self.action_halt
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::Call, Created do |env, b2|
|
|
|
|
if env[:result]
|
2013-03-03 06:22:44 +00:00
|
|
|
b2.use Vagrant::Action::Builtin::Call, Vagrant::Action::Builtin::GracefulHalt, :stopped, :running do |env2, b3|
|
|
|
|
if !env2[:result] && env2[:machine].provider.state.running?
|
2013-03-04 04:16:45 +00:00
|
|
|
# TODO: Container#halt is kinda graceful as well, if it doesn't
|
|
|
|
# or we can issue a lxc-stop. Might as well be handled by the
|
|
|
|
# container itself, who knows, we just need to handle it :P
|
2013-03-03 06:22:44 +00:00
|
|
|
env2[:machine].provider.container.halt
|
|
|
|
end
|
2013-02-28 03:21:59 +00:00
|
|
|
end
|
|
|
|
else
|
|
|
|
b2.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotCreated
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# This is the action that is primarily responsible for completely
|
|
|
|
# freeing the resources of the underlying virtual machine.
|
|
|
|
def self.action_destroy
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use Vagrant::Action::Builtin::Call, Created do |env1, b2|
|
|
|
|
if !env1[:result]
|
2013-03-04 02:16:02 +00:00
|
|
|
b2.use VagrantPlugins::ProviderVirtualBox::Action::MessageNotCreated
|
2013-02-28 03:21:59 +00:00
|
|
|
next
|
|
|
|
end
|
|
|
|
|
2013-03-03 05:37:34 +00:00
|
|
|
# TODO: Implement our own DestroyConfirm
|
2013-02-28 03:21:59 +00:00
|
|
|
b2.use Vagrant::Action::Builtin::Call, VagrantPlugins::ProviderVirtualBox::Action::DestroyConfirm do |env2, b3|
|
|
|
|
if env2[:result]
|
|
|
|
b3.use Vagrant::Action::Builtin::ConfigValidate
|
|
|
|
b3.use Vagrant::Action::Builtin::EnvSet, :force_halt => true
|
|
|
|
b3.use action_halt
|
|
|
|
b3.use Destroy
|
|
|
|
# TODO: VirtualBox provider has a CleanMachineFolder action, do we need something similar?
|
|
|
|
# TODO: VirtualBox provider has a DestroyUnusedNetworkInterfaces action, do we need something similar?
|
|
|
|
else
|
2013-03-03 05:37:34 +00:00
|
|
|
# TODO: Implement our own MessageWillNotDestroy
|
2013-02-28 03:21:59 +00:00
|
|
|
b3.use VagrantPlugins::ProviderVirtualBox::Action::MessageWillNotDestroy
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-03-02 19:48:15 +00:00
|
|
|
# This is the action that will exec into an SSH shell.
|
|
|
|
def self.action_ssh
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use CheckCreated
|
|
|
|
# b.use CheckAccessible
|
|
|
|
b.use CheckRunning
|
|
|
|
b.use Vagrant::Action::Builtin::SSHExec
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# This is the action that will run a single SSH command.
|
|
|
|
def self.action_ssh_run
|
|
|
|
Vagrant::Action::Builder.new.tap do |b|
|
|
|
|
b.use CheckLXC
|
|
|
|
b.use CheckCreated
|
|
|
|
# b.use CheckAccessible
|
|
|
|
b.use CheckRunning
|
|
|
|
b.use Vagrant::Action::Builtin::SSHRun
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-28 03:21:59 +00:00
|
|
|
# TODO: Check if our requirements are met.
|
|
|
|
class CheckLXC < BaseAction; end
|
|
|
|
|
|
|
|
# TODO: Implement port forwarding with rinetd
|
|
|
|
class ForwardPorts < BaseAction; end
|
|
|
|
|
|
|
|
# TODO: Find out which defaults are sane for LXC ;)
|
|
|
|
class SaneDefaults < BaseAction; end
|
|
|
|
|
|
|
|
# TODO: Find out if the actions below will be needed
|
|
|
|
class ClearForwardedPorts < BaseAction; end
|
|
|
|
class PrepareForwardedPortCollisionParams < BaseAction; end
|
|
|
|
class ClearSharedFolders < BaseAction; end
|
|
|
|
class Customize < BaseAction; end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|