vagrant-softlayer 0.3.1 → 0.3.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +37 -24
- data/QUICKSTART.md +377 -0
- data/README.md +25 -20
- data/contrib/README.md +8 -1
- data/contrib/vagrant-softlayer-boxes +416 -408
- data/contrib/vagrant-softlayer-vlans +329 -0
- data/contrib/vagrantcloud/CENTOS_5_32.box +0 -0
- data/contrib/vagrantcloud/CENTOS_5_64.box +0 -0
- data/contrib/vagrantcloud/CENTOS_6_32.box +0 -0
- data/contrib/vagrantcloud/CENTOS_6_64.box +0 -0
- data/contrib/vagrantcloud/CENTOS_LATEST.box +0 -0
- data/contrib/vagrantcloud/CENTOS_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/CENTOS_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_5_32.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_5_64.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_6_32.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_6_64.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_LATEST.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/CLOUDLINUX_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_5_32.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_5_64.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_6_32.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_6_64.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_7_32.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_7_64.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_LATEST.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/DEBIAN_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/REDHAT_5_32.box +0 -0
- data/contrib/vagrantcloud/REDHAT_5_64.box +0 -0
- data/contrib/vagrantcloud/REDHAT_6_32.box +0 -0
- data/contrib/vagrantcloud/REDHAT_6_64.box +0 -0
- data/contrib/vagrantcloud/REDHAT_LATEST.box +0 -0
- data/contrib/vagrantcloud/REDHAT_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/REDHAT_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/SL_GENERIC.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_10_32.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_10_64.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_12_32.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_12_64.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_14_32.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_14_64.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_8_32.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_8_64.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_LATEST.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/UBUNTU_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/VYATTACE_6.5_64.box +0 -0
- data/contrib/vagrantcloud/VYATTACE_6.6_64.box +0 -0
- data/contrib/vagrantcloud/VYATTACE_LATEST.box +0 -0
- data/contrib/vagrantcloud/VYATTACE_LATEST_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-DC-SP2-1_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-DC-SP2-1_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-ENT-SP2-5_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-ENT-SP2-5_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-STD-SP2-5_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2003-STD-SP2-5_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-DC-R2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-DC-SP2_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-DC-SP2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-ENT-R2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-ENT-SP2_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-ENT-SP2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-STD-R2-SP1_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-STD-R2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-STD-SP2_32.box +0 -0
- data/contrib/vagrantcloud/WIN_2008-STD-SP2_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2012-DC_64.box +0 -0
- data/contrib/vagrantcloud/WIN_2012-STD_64.box +0 -0
- data/contrib/vagrantcloud/WIN_LATEST.box +0 -0
- data/contrib/vagrantcloud/WIN_LATEST_32.box +0 -0
- data/contrib/vagrantcloud/WIN_LATEST_64.box +0 -0
- data/lib/vagrant-softlayer/action.rb +20 -16
- data/lib/vagrant-softlayer/action/create_instance.rb +24 -8
- data/lib/vagrant-softlayer/action/setup_softlayer.rb +2 -1
- data/lib/vagrant-softlayer/action/sync_folders.rb +99 -99
- data/lib/vagrant-softlayer/action/wait_for_rebuild.rb +36 -36
- data/lib/vagrant-softlayer/config.rb +10 -2
- data/lib/vagrant-softlayer/errors.rb +33 -29
- data/lib/vagrant-softlayer/plugin.rb +77 -77
- data/lib/vagrant-softlayer/util/load_balancer.rb +103 -103
- data/lib/vagrant-softlayer/util/network.rb +75 -73
- data/lib/vagrant-softlayer/util/warden.rb +38 -38
- data/lib/vagrant-softlayer/version.rb +5 -5
- data/locales/en.yml +6 -0
- data/spec/vagrant-softlayer/config_spec.rb +4 -2
- data/vagrant-softlayer.gemspec +55 -55
- metadata +71 -2
@@ -1,29 +1,33 @@
|
|
1
|
-
module VagrantPlugins
|
2
|
-
module SoftLayer
|
3
|
-
module Errors
|
4
|
-
class VagrantSoftLayerError < Vagrant::Errors::VagrantError
|
5
|
-
error_namespace("vagrant_softlayer.errors")
|
6
|
-
end
|
7
|
-
|
8
|
-
class SLApiError < VagrantSoftLayerError
|
9
|
-
error_key(:api_error)
|
10
|
-
end
|
11
|
-
|
12
|
-
class SLCertificateError < VagrantSoftLayerError
|
13
|
-
error_key(:certificate_error)
|
14
|
-
end
|
15
|
-
|
16
|
-
class SLDNSZoneNotFound < VagrantSoftLayerError
|
17
|
-
error_key(:dns_zone_not_found)
|
18
|
-
end
|
19
|
-
|
20
|
-
class SLLoadBalancerNotFound < VagrantSoftLayerError
|
21
|
-
error_key(:load_balancer_not_found)
|
22
|
-
end
|
23
|
-
|
24
|
-
class SLSshKeyNotFound < VagrantSoftLayerError
|
25
|
-
error_key(:ssh_key_not_found)
|
26
|
-
end
|
27
|
-
|
28
|
-
|
29
|
-
|
1
|
+
module VagrantPlugins
|
2
|
+
module SoftLayer
|
3
|
+
module Errors
|
4
|
+
class VagrantSoftLayerError < Vagrant::Errors::VagrantError
|
5
|
+
error_namespace("vagrant_softlayer.errors")
|
6
|
+
end
|
7
|
+
|
8
|
+
class SLApiError < VagrantSoftLayerError
|
9
|
+
error_key(:api_error)
|
10
|
+
end
|
11
|
+
|
12
|
+
class SLCertificateError < VagrantSoftLayerError
|
13
|
+
error_key(:certificate_error)
|
14
|
+
end
|
15
|
+
|
16
|
+
class SLDNSZoneNotFound < VagrantSoftLayerError
|
17
|
+
error_key(:dns_zone_not_found)
|
18
|
+
end
|
19
|
+
|
20
|
+
class SLLoadBalancerNotFound < VagrantSoftLayerError
|
21
|
+
error_key(:load_balancer_not_found)
|
22
|
+
end
|
23
|
+
|
24
|
+
class SLSshKeyNotFound < VagrantSoftLayerError
|
25
|
+
error_key(:ssh_key_not_found)
|
26
|
+
end
|
27
|
+
|
28
|
+
class SLVlanIdNotFound < VagrantSoftLayerError
|
29
|
+
error_key(:vlan_id_not_found)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
@@ -1,77 +1,77 @@
|
|
1
|
-
begin
|
2
|
-
require "vagrant"
|
3
|
-
rescue LoadError
|
4
|
-
raise "The Vagrant SoftLayer plugin must be run within Vagrant."
|
5
|
-
end
|
6
|
-
|
7
|
-
# This is a sanity check to make sure no one is attempting to install
|
8
|
-
# this into an early Vagrant version.
|
9
|
-
if Vagrant::VERSION < "1.3.0"
|
10
|
-
raise "The Vagrant SoftLayer plugin is only compatible with Vagrant 1.3+"
|
11
|
-
end
|
12
|
-
|
13
|
-
module VagrantPlugins
|
14
|
-
module SoftLayer
|
15
|
-
class Plugin < Vagrant.plugin("2")
|
16
|
-
name "SoftLayer"
|
17
|
-
description <<-DESC
|
18
|
-
This plugin installs a provider that allows Vagrant to manage
|
19
|
-
SoftLayer CCI.
|
20
|
-
DESC
|
21
|
-
|
22
|
-
command(:rebuild) do
|
23
|
-
require_relative 'command/rebuild'
|
24
|
-
Command::Rebuild
|
25
|
-
end
|
26
|
-
|
27
|
-
config(:softlayer, :provider) do
|
28
|
-
require_relative "config"
|
29
|
-
Config
|
30
|
-
end
|
31
|
-
|
32
|
-
provider(:softlayer) do
|
33
|
-
init_logging
|
34
|
-
init_i18n
|
35
|
-
|
36
|
-
require_relative "provider"
|
37
|
-
Provider
|
38
|
-
end
|
39
|
-
|
40
|
-
# This initializes the I18n load path so that the plugin specific
|
41
|
-
# transations work.
|
42
|
-
def self.init_i18n
|
43
|
-
I18n.load_path << File.expand_path("locales/en.yml", SoftLayer.source_root)
|
44
|
-
I18n.reload!
|
45
|
-
end
|
46
|
-
|
47
|
-
# This sets up our log level to be whatever VAGRANT_LOG is.
|
48
|
-
def self.init_logging
|
49
|
-
require "log4r"
|
50
|
-
|
51
|
-
level = nil
|
52
|
-
begin
|
53
|
-
level = Log4r.const_get(ENV["VAGRANT_LOG"].upcase)
|
54
|
-
rescue NameError
|
55
|
-
# This means that the logging constant wasn't found,
|
56
|
-
# which is fine. We just keep `level` as `nil`. But
|
57
|
-
# we tell the user.
|
58
|
-
level = nil
|
59
|
-
end
|
60
|
-
|
61
|
-
# Some constants, such as "true" resolve to booleans, so the
|
62
|
-
# above error checking doesn't catch it. This will check to make
|
63
|
-
# sure that the log level is an integer, as Log4r requires.
|
64
|
-
level = nil if !level.is_a?(Integer)
|
65
|
-
|
66
|
-
# Set the logging level on all "vagrant" namespaced
|
67
|
-
# logs as long as we have a valid level.
|
68
|
-
if level
|
69
|
-
logger = Log4r::Logger.new("vagrant_softlayer")
|
70
|
-
logger.outputters = Log4r::Outputter.stderr
|
71
|
-
logger.level = level
|
72
|
-
logger = nil
|
73
|
-
end
|
74
|
-
end
|
75
|
-
end
|
76
|
-
end
|
77
|
-
end
|
1
|
+
begin
|
2
|
+
require "vagrant"
|
3
|
+
rescue LoadError
|
4
|
+
raise "The Vagrant SoftLayer plugin must be run within Vagrant."
|
5
|
+
end
|
6
|
+
|
7
|
+
# This is a sanity check to make sure no one is attempting to install
|
8
|
+
# this into an early Vagrant version.
|
9
|
+
if Vagrant::VERSION < "1.3.0"
|
10
|
+
raise "The Vagrant SoftLayer plugin is only compatible with Vagrant 1.3+"
|
11
|
+
end
|
12
|
+
|
13
|
+
module VagrantPlugins
|
14
|
+
module SoftLayer
|
15
|
+
class Plugin < Vagrant.plugin("2")
|
16
|
+
name "SoftLayer"
|
17
|
+
description <<-DESC
|
18
|
+
This plugin installs a provider that allows Vagrant to manage
|
19
|
+
SoftLayer CCI.
|
20
|
+
DESC
|
21
|
+
|
22
|
+
command(:rebuild) do
|
23
|
+
require_relative 'command/rebuild'
|
24
|
+
Command::Rebuild
|
25
|
+
end
|
26
|
+
|
27
|
+
config(:softlayer, :provider) do
|
28
|
+
require_relative "config"
|
29
|
+
Config
|
30
|
+
end
|
31
|
+
|
32
|
+
provider(:softlayer) do
|
33
|
+
init_logging
|
34
|
+
init_i18n
|
35
|
+
|
36
|
+
require_relative "provider"
|
37
|
+
Provider
|
38
|
+
end
|
39
|
+
|
40
|
+
# This initializes the I18n load path so that the plugin specific
|
41
|
+
# transations work.
|
42
|
+
def self.init_i18n
|
43
|
+
I18n.load_path << File.expand_path("locales/en.yml", SoftLayer.source_root)
|
44
|
+
I18n.reload!
|
45
|
+
end
|
46
|
+
|
47
|
+
# This sets up our log level to be whatever VAGRANT_LOG is.
|
48
|
+
def self.init_logging
|
49
|
+
require "log4r"
|
50
|
+
|
51
|
+
level = nil
|
52
|
+
begin
|
53
|
+
level = Log4r.const_get(ENV["VAGRANT_LOG"].upcase)
|
54
|
+
rescue NameError
|
55
|
+
# This means that the logging constant wasn't found,
|
56
|
+
# which is fine. We just keep `level` as `nil`. But
|
57
|
+
# we tell the user.
|
58
|
+
level = nil
|
59
|
+
end
|
60
|
+
|
61
|
+
# Some constants, such as "true" resolve to booleans, so the
|
62
|
+
# above error checking doesn't catch it. This will check to make
|
63
|
+
# sure that the log level is an integer, as Log4r requires.
|
64
|
+
level = nil if !level.is_a?(Integer)
|
65
|
+
|
66
|
+
# Set the logging level on all "vagrant" namespaced
|
67
|
+
# logs as long as we have a valid level.
|
68
|
+
if level
|
69
|
+
logger = Log4r::Logger.new("vagrant_softlayer")
|
70
|
+
logger.outputters = Log4r::Outputter.stderr
|
71
|
+
logger.level = level
|
72
|
+
logger = nil
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
77
|
+
end
|
@@ -1,103 +1,103 @@
|
|
1
|
-
module VagrantPlugins
|
2
|
-
module SoftLayer
|
3
|
-
module Util
|
4
|
-
# This mixin contains utility methods for load balancer management.
|
5
|
-
module LoadBalancer
|
6
|
-
# Whether load balancer management is enabled or not.
|
7
|
-
def enabled?
|
8
|
-
if @env[:machine].provider_config.load_balancers.empty?
|
9
|
-
@logger.debug("No load balancer has been defined. Going ahead.")
|
10
|
-
return false
|
11
|
-
end
|
12
|
-
|
13
|
-
# Currently we don't do load balancing for private machines.
|
14
|
-
if @env[:machine].provider_config.private_only
|
15
|
-
@logger.info("Load balancing doesn't work for private machines. Going ahead.")
|
16
|
-
return false
|
17
|
-
end
|
18
|
-
true
|
19
|
-
end
|
20
|
-
|
21
|
-
# Get existing stuff.
|
22
|
-
def read_load_balancers
|
23
|
-
mask = [
|
24
|
-
"id",
|
25
|
-
"ipAddress.ipAddress",
|
26
|
-
"virtualServers.serviceGroups.services.groupReferences",
|
27
|
-
"virtualServers.serviceGroups.services.healthChecks"
|
28
|
-
]
|
29
|
-
@logger.debug("Looking for existing load balancers.")
|
30
|
-
@load_balancers = sl_warden { @services["Account"].object_mask(mask).getAdcLoadBalancers }
|
31
|
-
@logger.debug("Got load balancer configuration:")
|
32
|
-
@logger.debug("-- #{@load_balancers}")
|
33
|
-
end
|
34
|
-
|
35
|
-
# For each load balancer, check if total connections
|
36
|
-
# are less than 100% and, if so, rebalance the allocations.
|
37
|
-
def rebalance!
|
38
|
-
read_load_balancers
|
39
|
-
|
40
|
-
@load_balancers.each do |load_balancer|
|
41
|
-
next if load_balancer["virtualServers"].empty?
|
42
|
-
next if 100 == load_balancer["virtualServers"].inject(0) { |sum, vs| sum += vs["allocation"] }
|
43
|
-
|
44
|
-
# Create allocation slots.
|
45
|
-
count = load_balancer["virtualServers"].count
|
46
|
-
allocation = [100 / count] * count
|
47
|
-
(100 % count).times { |i| allocation[i] += 1 }
|
48
|
-
|
49
|
-
# Rebalance allocations.
|
50
|
-
load_balancer["virtualServers"].each do |vs|
|
51
|
-
vs["allocation"] = allocation.pop
|
52
|
-
end
|
53
|
-
|
54
|
-
# Update the VIP object.
|
55
|
-
@logger.debug("Rebalancing VIP #{load_balancer['id']}")
|
56
|
-
@logger.debug("-- #{load_balancer}")
|
57
|
-
@services["VirtualIpAddress"].object_with_id(load_balancer["id"]).editObject("virtualServers" => load_balancer["virtualServers"])
|
58
|
-
end
|
59
|
-
end
|
60
|
-
|
61
|
-
# Initial setup.
|
62
|
-
def setup
|
63
|
-
# A plethora of service objects is required for managing
|
64
|
-
# load balancers. We instanciate'em all here.
|
65
|
-
@services = {
|
66
|
-
"Account" => ::SoftLayer::Service.new("SoftLayer_Account", @env[:sl_credentials])
|
67
|
-
}
|
68
|
-
[
|
69
|
-
"Health_Check_Type",
|
70
|
-
"Routing_Method",
|
71
|
-
"Routing_Type",
|
72
|
-
"Service",
|
73
|
-
"Service_Group",
|
74
|
-
"VirtualIpAddress",
|
75
|
-
"VirtualServer"
|
76
|
-
].each do |service|
|
77
|
-
@services[service] = ::SoftLayer::Service.new(
|
78
|
-
"SoftLayer_Network_Application_Delivery_Controller_LoadBalancer_#{service}",
|
79
|
-
@env[:sl_credentials]
|
80
|
-
)
|
81
|
-
end
|
82
|
-
|
83
|
-
# We create enumerations for the various configurables.
|
84
|
-
@enums = {}
|
85
|
-
[
|
86
|
-
"Health_Check_Type",
|
87
|
-
"Routing_Method",
|
88
|
-
"Routing_Type"
|
89
|
-
].each do |service|
|
90
|
-
{}.tap do |enum|
|
91
|
-
sl_warden { @services[service].getAllObjects }.each do |record|
|
92
|
-
enum[record["name"].upcase] = record["id"]
|
93
|
-
end
|
94
|
-
@enums[service] = enum
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
read_load_balancers
|
99
|
-
end
|
100
|
-
end
|
101
|
-
end
|
102
|
-
end
|
103
|
-
end
|
1
|
+
module VagrantPlugins
|
2
|
+
module SoftLayer
|
3
|
+
module Util
|
4
|
+
# This mixin contains utility methods for load balancer management.
|
5
|
+
module LoadBalancer
|
6
|
+
# Whether load balancer management is enabled or not.
|
7
|
+
def enabled?
|
8
|
+
if @env[:machine].provider_config.load_balancers.empty?
|
9
|
+
@logger.debug("No load balancer has been defined. Going ahead.")
|
10
|
+
return false
|
11
|
+
end
|
12
|
+
|
13
|
+
# Currently we don't do load balancing for private machines.
|
14
|
+
if @env[:machine].provider_config.private_only
|
15
|
+
@logger.info("Load balancing doesn't work for private machines. Going ahead.")
|
16
|
+
return false
|
17
|
+
end
|
18
|
+
true
|
19
|
+
end
|
20
|
+
|
21
|
+
# Get existing stuff.
|
22
|
+
def read_load_balancers
|
23
|
+
mask = [
|
24
|
+
"id",
|
25
|
+
"ipAddress.ipAddress",
|
26
|
+
"virtualServers.serviceGroups.services.groupReferences",
|
27
|
+
"virtualServers.serviceGroups.services.healthChecks"
|
28
|
+
]
|
29
|
+
@logger.debug("Looking for existing load balancers.")
|
30
|
+
@load_balancers = sl_warden { @services["Account"].object_mask(mask).getAdcLoadBalancers }
|
31
|
+
@logger.debug("Got load balancer configuration:")
|
32
|
+
@logger.debug("-- #{@load_balancers}")
|
33
|
+
end
|
34
|
+
|
35
|
+
# For each load balancer, check if total connections
|
36
|
+
# are less than 100% and, if so, rebalance the allocations.
|
37
|
+
def rebalance!
|
38
|
+
read_load_balancers
|
39
|
+
|
40
|
+
@load_balancers.each do |load_balancer|
|
41
|
+
next if load_balancer["virtualServers"].empty?
|
42
|
+
next if 100 == load_balancer["virtualServers"].inject(0) { |sum, vs| sum += vs["allocation"] }
|
43
|
+
|
44
|
+
# Create allocation slots.
|
45
|
+
count = load_balancer["virtualServers"].count
|
46
|
+
allocation = [100 / count] * count
|
47
|
+
(100 % count).times { |i| allocation[i] += 1 }
|
48
|
+
|
49
|
+
# Rebalance allocations.
|
50
|
+
load_balancer["virtualServers"].each do |vs|
|
51
|
+
vs["allocation"] = allocation.pop
|
52
|
+
end
|
53
|
+
|
54
|
+
# Update the VIP object.
|
55
|
+
@logger.debug("Rebalancing VIP #{load_balancer['id']}")
|
56
|
+
@logger.debug("-- #{load_balancer}")
|
57
|
+
@services["VirtualIpAddress"].object_with_id(load_balancer["id"]).editObject("virtualServers" => load_balancer["virtualServers"])
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
# Initial setup.
|
62
|
+
def setup
|
63
|
+
# A plethora of service objects is required for managing
|
64
|
+
# load balancers. We instanciate'em all here.
|
65
|
+
@services = {
|
66
|
+
"Account" => ::SoftLayer::Service.new("SoftLayer_Account", @env[:sl_credentials])
|
67
|
+
}
|
68
|
+
[
|
69
|
+
"Health_Check_Type",
|
70
|
+
"Routing_Method",
|
71
|
+
"Routing_Type",
|
72
|
+
"Service",
|
73
|
+
"Service_Group",
|
74
|
+
"VirtualIpAddress",
|
75
|
+
"VirtualServer"
|
76
|
+
].each do |service|
|
77
|
+
@services[service] = ::SoftLayer::Service.new(
|
78
|
+
"SoftLayer_Network_Application_Delivery_Controller_LoadBalancer_#{service}",
|
79
|
+
@env[:sl_credentials]
|
80
|
+
)
|
81
|
+
end
|
82
|
+
|
83
|
+
# We create enumerations for the various configurables.
|
84
|
+
@enums = {}
|
85
|
+
[
|
86
|
+
"Health_Check_Type",
|
87
|
+
"Routing_Method",
|
88
|
+
"Routing_Type"
|
89
|
+
].each do |service|
|
90
|
+
{}.tap do |enum|
|
91
|
+
sl_warden { @services[service].getAllObjects }.each do |record|
|
92
|
+
enum[record["name"].upcase] = record["id"]
|
93
|
+
end
|
94
|
+
@enums[service] = enum
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
98
|
+
read_load_balancers
|
99
|
+
end
|
100
|
+
end
|
101
|
+
end
|
102
|
+
end
|
103
|
+
end
|
@@ -1,73 +1,75 @@
|
|
1
|
-
module VagrantPlugins
|
2
|
-
module SoftLayer
|
3
|
-
module Util
|
4
|
-
module Network
|
5
|
-
# Gets hostname of the instance starting from the environment.
|
6
|
-
def hostname(env)
|
7
|
-
env[:machine].provider_config.hostname || env[:machine].config.vm.hostname
|
8
|
-
end
|
9
|
-
|
10
|
-
# Gets IP address of the instance starting from the environment.
|
11
|
-
#
|
12
|
-
# Returns the private IP address if the instance has been
|
13
|
-
# defined as private only, the public IP address otherwise.
|
14
|
-
def ip_address(env)
|
15
|
-
ip_address_record(env)[:address]
|
16
|
-
end
|
17
|
-
|
18
|
-
# Gets IP address ID of the instance starting from the environment.
|
19
|
-
#
|
20
|
-
# Returns the private IP address ID if the instance has been
|
21
|
-
# defined as private only, the public IP address ID otherwise.
|
22
|
-
def ip_address_id(env)
|
23
|
-
ip_address_record(env)[:id]
|
24
|
-
end
|
25
|
-
|
26
|
-
# Gets IP address record of the instance starting from the environment.
|
27
|
-
#
|
28
|
-
# Returns an hash with the following structure:
|
29
|
-
#
|
30
|
-
# :address
|
31
|
-
# :id
|
32
|
-
#
|
33
|
-
# Returns the private IP address record if the instance has been
|
34
|
-
# defined as private only, the public IP address record otherwise
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
#
|
48
|
-
#
|
49
|
-
# the
|
50
|
-
#
|
51
|
-
#
|
52
|
-
#
|
53
|
-
# The
|
54
|
-
#
|
55
|
-
#
|
56
|
-
#
|
57
|
-
# an
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
end
|
1
|
+
module VagrantPlugins
|
2
|
+
module SoftLayer
|
3
|
+
module Util
|
4
|
+
module Network
|
5
|
+
# Gets hostname of the instance starting from the environment.
|
6
|
+
def hostname(env)
|
7
|
+
env[:machine].provider_config.hostname || env[:machine].config.vm.hostname
|
8
|
+
end
|
9
|
+
|
10
|
+
# Gets IP address of the instance starting from the environment.
|
11
|
+
#
|
12
|
+
# Returns the private IP address if the instance has been
|
13
|
+
# defined as private only, the public IP address otherwise.
|
14
|
+
def ip_address(env)
|
15
|
+
ip_address_record(env)[:address]
|
16
|
+
end
|
17
|
+
|
18
|
+
# Gets IP address ID of the instance starting from the environment.
|
19
|
+
#
|
20
|
+
# Returns the private IP address ID if the instance has been
|
21
|
+
# defined as private only, the public IP address ID otherwise.
|
22
|
+
def ip_address_id(env)
|
23
|
+
ip_address_record(env)[:id]
|
24
|
+
end
|
25
|
+
|
26
|
+
# Gets IP address record of the instance starting from the environment.
|
27
|
+
#
|
28
|
+
# Returns an hash with the following structure:
|
29
|
+
#
|
30
|
+
# :address
|
31
|
+
# :id
|
32
|
+
#
|
33
|
+
# Returns the private IP address record if the instance has been
|
34
|
+
# defined as private only, the public IP address record otherwise
|
35
|
+
# unless the force_private_ip override is true.
|
36
|
+
def ip_address_record(env)
|
37
|
+
data_type = env[:machine].provider_config.private_only ? "primaryBackendNetworkComponent" : "primaryNetworkComponent"
|
38
|
+
data_type = "primaryBackendNetworkComponent" if env[:machine].provider_config.force_private_ip
|
39
|
+
mask = { data_type => { "primaryIpAddressRecord" => ["id", "ipAddress"] } }
|
40
|
+
record = sl_warden { env[:sl_machine].object_mask(mask).getObject }
|
41
|
+
return {
|
42
|
+
:address => record[data_type]["primaryIpAddressRecord"]["ipAddress"],
|
43
|
+
:id => record[data_type]["primaryIpAddressRecord"]["id"]
|
44
|
+
}
|
45
|
+
end
|
46
|
+
|
47
|
+
# Returns SSH keys starting from the configuration parameter.
|
48
|
+
#
|
49
|
+
# In the configuration, each key could be passed either as an
|
50
|
+
# id or as a label. The routine will detect this and lookup
|
51
|
+
# the id if needed.
|
52
|
+
#
|
53
|
+
# The first parameter is the current environment.
|
54
|
+
#
|
55
|
+
# The second parameter is useful for returning: if it is set
|
56
|
+
# the routine will return just the array of ids (this is needed,
|
57
|
+
# as an example, for reloading OS), otherwise an hash is
|
58
|
+
# returned (this latter case is needed instead for creating
|
59
|
+
# an instance).
|
60
|
+
def ssh_keys(env, ids_only = false)
|
61
|
+
account = ::SoftLayer::Service.new("SoftLayer_Account", env[:sl_credentials])
|
62
|
+
acc_keys = sl_warden { account.object_mask("id", "label").getSshKeys }
|
63
|
+
key_ids = []
|
64
|
+
Array(env[:machine].provider_config.ssh_key).each do |key|
|
65
|
+
pattern = key.is_a?(String) ? "label" : "id"
|
66
|
+
key_hash = acc_keys.find { |acc_key| acc_key[pattern] == key }
|
67
|
+
raise Errors::SLSshKeyNotFound, :key => key unless key_hash
|
68
|
+
key_ids << key_hash["id"]
|
69
|
+
end
|
70
|
+
return (ids_only ? key_ids : key_ids.map { |key_id| { :id => key_id } })
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|