From f71de429a18907c4b19fe9c18fd1cd14927d66f2 Mon Sep 17 00:00:00 2001 From: Lukas Bischofberger Date: Sat, 21 Jul 2018 14:52:26 +0200 Subject: [PATCH] Add config for container ssh IP --- lib/vagrant-lxc/action/fetch_ip_with_lxc_info.rb | 1 + lib/vagrant-lxc/config.rb | 4 ++++ 2 files changed, 5 insertions(+) diff --git a/lib/vagrant-lxc/action/fetch_ip_with_lxc_info.rb b/lib/vagrant-lxc/action/fetch_ip_with_lxc_info.rb index 38882ac6..50d56a3f 100644 --- a/lib/vagrant-lxc/action/fetch_ip_with_lxc_info.rb +++ b/lib/vagrant-lxc/action/fetch_ip_with_lxc_info.rb @@ -21,6 +21,7 @@ def assigned_ip(env) fetch_ip_tries = config.fetch_ip_tries driver = env[:machine].provider.driver ip = '' + return config.ssh_ip_addr if not config.ssh_ip_addr.nil? retryable(:on => LXC::Errors::ExecuteError, :tries => fetch_ip_tries, :sleep => 3) do unless ip = get_container_ip_from_ip_addr(driver) # retry diff --git a/lib/vagrant-lxc/config.rb b/lib/vagrant-lxc/config.rb index 0a117c39..66f14102 100644 --- a/lib/vagrant-lxc/config.rb +++ b/lib/vagrant-lxc/config.rb @@ -24,6 +24,8 @@ class Config < Vagrant.plugin("2", :config) attr_accessor :fetch_ip_tries + attr_accessor :ssh_ip_addr + # Whether the container needs to be privileged. Defaults to true (unprivileged containers # is a very new feature in vagrant-lxc). If false, will try creating an unprivileged # container. If it can't, will revert to the old "sudo wrapper" method to create a privileged @@ -37,6 +39,7 @@ def initialize @container_name = UNSET_VALUE @tmpfs_mount_size = UNSET_VALUE @fetch_ip_tries = UNSET_VALUE + @ssh_ip_addr = UNSET_VALUE @privileged = UNSET_VALUE end @@ -66,6 +69,7 @@ def finalize! @existing_container_name = nil if @existing_container_name == UNSET_VALUE @tmpfs_mount_size = '2G' if @tmpfs_mount_size == UNSET_VALUE @fetch_ip_tries = 10 if @fetch_ip_tries == UNSET_VALUE + @ssh_ip_addr = nil if @ssh_ip_addr == UNSET_VALUE @privileged = true if @privileged == UNSET_VALUE end end