fog 0.3.31 → 0.3.32
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +3 -0
- data/.gitignore +10 -0
- data/Gemfile.lock +1 -4
- data/README.rdoc +29 -37
- data/Rakefile +5 -25
- data/bin/fog +1 -3
- data/examples/dns_methods.rb +389 -0
- data/examples/storage.rb +103 -0
- data/fog.gemspec +4 -778
- data/lib/fog.rb +5 -66
- data/lib/fog/aws.rb +3 -0
- data/lib/fog/aws/bin.rb +7 -2
- data/lib/fog/aws/cdn.rb +2 -2
- data/lib/fog/aws/compute.rb +2 -2
- data/lib/fog/aws/dns.rb +101 -0
- data/lib/fog/aws/elb.rb +2 -2
- data/lib/fog/aws/iam.rb +2 -2
- data/lib/fog/aws/models/compute/image.rb +1 -0
- data/lib/fog/aws/models/compute/server.rb +1 -1
- data/lib/fog/aws/models/compute/servers.rb +1 -13
- data/lib/fog/aws/parsers/compute/describe_images.rb +36 -34
- data/lib/fog/aws/parsers/dns/change_resource_record_sets.rb +26 -0
- data/lib/fog/aws/parsers/dns/create_hosted_zone.rb +55 -0
- data/lib/fog/aws/parsers/dns/delete_hosted_zone.rb +25 -0
- data/lib/fog/aws/parsers/dns/get_change.rb +26 -0
- data/lib/fog/aws/parsers/dns/get_hosted_zone.rb +43 -0
- data/lib/fog/aws/parsers/dns/list_hosted_zones.rb +35 -0
- data/lib/fog/aws/parsers/dns/list_resource_record_sets.rb +46 -0
- data/lib/fog/aws/requests/compute/describe_images.rb +1 -0
- data/lib/fog/aws/requests/dns/change_resource_record_sets.rb +90 -0
- data/lib/fog/aws/requests/dns/create_hosted_zone.rb +68 -0
- data/lib/fog/aws/requests/dns/delete_hosted_zone.rb +48 -0
- data/lib/fog/aws/requests/dns/get_change.rb +47 -0
- data/lib/fog/aws/requests/dns/get_hosted_zone.rb +51 -0
- data/lib/fog/aws/requests/dns/list_hosted_zones.rb +63 -0
- data/lib/fog/aws/requests/dns/list_resource_record_sets.rb +68 -0
- data/lib/fog/aws/requests/storage/get_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/put_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/sync_clock.rb +28 -0
- data/lib/fog/aws/simpledb.rb +2 -2
- data/lib/fog/aws/storage.rb +5 -3
- data/lib/fog/bluebox.rb +2 -0
- data/lib/fog/bluebox/compute.rb +2 -2
- data/lib/fog/brightbox.rb +2 -0
- data/lib/fog/brightbox/compute.rb +2 -2
- data/lib/fog/core.rb +21 -1
- data/lib/fog/core/bin.rb +3 -1
- data/lib/fog/core/compute.rb +1 -0
- data/lib/fog/core/credentials.rb +72 -50
- data/lib/fog/core/deprecation.rb +11 -5
- data/lib/fog/core/mock.rb +34 -0
- data/lib/fog/core/model.rb +9 -1
- data/lib/fog/core/service.rb +40 -26
- data/lib/fog/core/storage.rb +1 -0
- data/lib/fog/core/time.rb +21 -0
- data/lib/fog/core/wait_for.rb +17 -0
- data/lib/fog/go_grid.rb +2 -0
- data/lib/fog/go_grid/compute.rb +2 -2
- data/lib/fog/google.rb +2 -0
- data/lib/fog/google/requests/storage/get_bucket.rb +6 -5
- data/lib/fog/google/requests/storage/get_object_url.rb +4 -4
- data/lib/fog/google/requests/storage/put_object_url.rb +4 -4
- data/lib/fog/google/storage.rb +4 -3
- data/lib/fog/linode.rb +3 -0
- data/lib/fog/linode/bin.rb +5 -3
- data/lib/fog/linode/compute.rb +6 -2
- data/lib/fog/linode/dns.rb +80 -0
- data/lib/fog/linode/requests/dns/domain_create.rb +52 -0
- data/lib/fog/linode/requests/dns/domain_delete.rb +35 -0
- data/lib/fog/linode/requests/dns/domain_list.rb +50 -0
- data/lib/fog/linode/requests/dns/domain_resource_create.rb +53 -0
- data/lib/fog/linode/requests/dns/domain_resource_delete.rb +36 -0
- data/lib/fog/linode/requests/dns/domain_resource_list.rb +48 -0
- data/lib/fog/linode/requests/dns/domain_resource_update.rb +54 -0
- data/lib/fog/linode/requests/dns/domain_update.rb +48 -0
- data/lib/fog/local.rb +2 -0
- data/lib/fog/local/storage.rb +3 -3
- data/lib/fog/new_servers.rb +2 -0
- data/lib/fog/new_servers/compute.rb +2 -2
- data/lib/fog/rackspace.rb +2 -0
- data/lib/fog/rackspace/cdn.rb +2 -2
- data/lib/fog/rackspace/compute.rb +2 -2
- data/lib/fog/rackspace/storage.rb +2 -2
- data/lib/fog/slicehost.rb +3 -0
- data/lib/fog/slicehost/bin.rb +2 -0
- data/lib/fog/slicehost/compute.rb +2 -2
- data/lib/fog/slicehost/dns.rb +84 -0
- data/lib/fog/slicehost/parsers/dns/create_record.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/create_zone.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_record.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_records.rb +30 -0
- data/lib/fog/slicehost/parsers/dns/get_zone.rb +26 -0
- data/lib/fog/slicehost/parsers/dns/get_zones.rb +30 -0
- data/lib/fog/slicehost/requests/compute/create_slice.rb +2 -2
- data/lib/fog/slicehost/requests/compute/delete_slice.rb +3 -17
- data/lib/fog/slicehost/requests/dns/create_record.rb +61 -0
- data/lib/fog/slicehost/requests/dns/create_zone.rb +54 -0
- data/lib/fog/slicehost/requests/dns/delete_record.rb +31 -0
- data/lib/fog/slicehost/requests/dns/delete_zone.rb +31 -0
- data/lib/fog/slicehost/requests/dns/get_record.rb +40 -0
- data/lib/fog/slicehost/requests/dns/get_records.rb +41 -0
- data/lib/fog/slicehost/requests/dns/get_zone.rb +40 -0
- data/lib/fog/slicehost/requests/dns/get_zones.rb +38 -0
- data/lib/fog/terremark.rb +2 -0
- data/lib/fog/terremark/ecloud.rb +2 -4
- data/lib/fog/vcloud.rb +4 -2
- data/lib/fog/vcloud/bin.rb +3 -1
- data/lib/fog/vcloud/mock_data_classes.rb +77 -11
- data/lib/fog/vcloud/terremark/ecloud.rb +22 -7
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_service.rb +60 -0
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_services.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_service.rb +28 -13
- data/lib/fog/vcloud/terremark/ecloud/models/internet_services.rb +2 -2
- data/lib/fog/vcloud/terremark/ecloud/models/ip.rb +1 -1
- data/lib/fog/vcloud/terremark/ecloud/models/network.rb +4 -1
- data/lib/fog/vcloud/terremark/ecloud/models/server.rb +5 -5
- data/lib/fog/vcloud/terremark/ecloud/models/vdc.rb +6 -2
- data/lib/fog/vcloud/terremark/ecloud/requests/add_backup_internet_service.rb +111 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_internet_service.rb +2 -4
- data/lib/fog/vcloud/terremark/ecloud/requests/add_node.rb +1 -3
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_internet_service.rb +39 -27
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network.rb +1 -2
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network_ip.rb +21 -6
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_vapp.rb +2 -1
- data/lib/fog/vcloud/terremark/ecloud/requests/get_internet_services.rb +34 -17
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_extensions.rb +12 -10
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ip.rb +15 -10
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ips.rb +1 -12
- data/lib/fog/zerigo.rb +15 -0
- data/lib/fog/zerigo/bin.rb +25 -0
- data/lib/fog/zerigo/dns.rb +96 -0
- data/lib/fog/zerigo/parsers/dns/count_hosts.rb +24 -0
- data/lib/fog/zerigo/parsers/dns/count_zones.rb +24 -0
- data/lib/fog/zerigo/parsers/dns/create_host.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/create_zone.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/find_hosts.rb +30 -0
- data/lib/fog/zerigo/parsers/dns/get_host.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/get_zone.rb +56 -0
- data/lib/fog/zerigo/parsers/dns/get_zone_stats.rb +26 -0
- data/lib/fog/zerigo/parsers/dns/list_hosts.rb +30 -0
- data/lib/fog/zerigo/parsers/dns/list_zones.rb +30 -0
- data/lib/fog/zerigo/requests/dns/count_hosts.rb +36 -0
- data/lib/fog/zerigo/requests/dns/count_zones.rb +36 -0
- data/lib/fog/zerigo/requests/dns/create_host.rb +70 -0
- data/lib/fog/zerigo/requests/dns/create_zone.rb +97 -0
- data/lib/fog/zerigo/requests/dns/delete_host.rb +32 -0
- data/lib/fog/zerigo/requests/dns/delete_zone.rb +33 -0
- data/lib/fog/zerigo/requests/dns/find_hosts.rb +63 -0
- data/lib/fog/zerigo/requests/dns/get_host.rb +47 -0
- data/lib/fog/zerigo/requests/dns/get_zone.rb +57 -0
- data/lib/fog/zerigo/requests/dns/get_zone_stats.rb +44 -0
- data/lib/fog/zerigo/requests/dns/list_hosts.rb +48 -0
- data/lib/fog/zerigo/requests/dns/list_zones.rb +53 -0
- data/lib/fog/zerigo/requests/dns/update_host.rb +60 -0
- data/lib/fog/zerigo/requests/dns/update_zone.rb +78 -0
- data/spec/spec_helper.rb +0 -5
- data/spec/vcloud/spec_helper.rb +3 -2
- data/spec/vcloud/terremark/ecloud/models/backup_internet_service_spec.rb +49 -0
- data/spec/vcloud/terremark/ecloud/models/backup_internet_services_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/internet_service_spec.rb +32 -13
- data/spec/vcloud/terremark/ecloud/models/network_spec.rb +7 -4
- data/spec/vcloud/terremark/ecloud/models/server_spec.rb +20 -0
- data/spec/vcloud/terremark/ecloud/requests/add_backup_internet_service_spec.rb +60 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_internet_service_spec.rb +3 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_network_ip_spec.rb +55 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_vapp_spec.rb +9 -0
- data/spec/vcloud/terremark/ecloud/requests/get_internet_services_spec.rb +60 -14
- data/spec/vcloud/terremark/ecloud/requests/get_network_ip_spec.rb +2 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ips_spec.rb +3 -3
- data/tests/aws/requests/compute/image_tests.rb +15 -14
- data/tests/aws/requests/dns/dns_tests.rb +276 -0
- data/tests/brightbox/requests/compute/account_tests.rb +20 -9
- data/tests/brightbox/requests/compute/api_client_tests.rb +12 -4
- data/tests/brightbox/requests/compute/cloud_ip_tests.rb +20 -6
- data/tests/brightbox/requests/compute/image_tests.rb +9 -4
- data/tests/brightbox/requests/compute/interface_tests.rb +8 -2
- data/tests/brightbox/requests/compute/server_tests.rb +17 -5
- data/tests/brightbox/requests/compute/server_type_tests.rb +8 -4
- data/tests/brightbox/requests/compute/user_tests.rb +13 -5
- data/tests/brightbox/requests/compute/zone_tests.rb +8 -4
- data/tests/core/attribute_tests.rb +45 -0
- data/tests/helper.rb +0 -2
- data/tests/linode/requests/dns/dns_tests.rb +262 -0
- data/tests/rackspace/requests/compute/address_tests.rb +1 -1
- data/tests/rackspace/requests/compute/image_tests.rb +1 -1
- data/tests/slicehost/requests/dns_tests/dns_tests.rb +279 -0
- data/tests/zerigo/helper.rb +0 -0
- data/tests/zerigo/requests/dns/dns_tests.rb +374 -0
- metadata +280 -36
- data/spec/compact_progress_bar_formatter.rb +0 -195
- data/spec/core/attributes_spec.rb +0 -52
- data/spec/lorem.txt +0 -1
@@ -28,8 +28,7 @@ module Fog
|
|
28
28
|
|
29
29
|
def generate_configure_network_request(network_data)
|
30
30
|
builder = Builder::XmlMarkup.new
|
31
|
-
builder.Network(
|
32
|
-
:xmlns => "urn:tmrk:eCloudExtensions-2.3") {
|
31
|
+
builder.Network(ecloud_xmlns) {
|
33
32
|
builder.Id(network_data[:id])
|
34
33
|
builder.Href(network_data[:href])
|
35
34
|
builder.Name(network_data[:name])
|
@@ -2,14 +2,19 @@ module Fog
|
|
2
2
|
class Vcloud
|
3
3
|
module Terremark
|
4
4
|
class Ecloud
|
5
|
-
|
5
|
+
module Shared
|
6
|
+
private
|
6
7
|
|
7
|
-
def validate_network_ip_data(network_ip_data
|
8
|
+
def validate_network_ip_data(network_ip_data)
|
8
9
|
valid_opts = [:id, :href, :name, :status, :server, :rnat]
|
9
10
|
unless valid_opts.all? { |opt| network_ip_data.keys.include?(opt) }
|
10
11
|
raise ArgumentError.new("Required data missing: #{(valid_opts - network_ip_data.keys).map(&:inspect).join(", ")}")
|
11
12
|
end
|
12
13
|
end
|
14
|
+
end
|
15
|
+
|
16
|
+
class Real
|
17
|
+
include Shared
|
13
18
|
|
14
19
|
def configure_network_ip(network_ip_uri, network_ip_data)
|
15
20
|
validate_network_ip_data(network_ip_data)
|
@@ -28,8 +33,7 @@ module Fog
|
|
28
33
|
|
29
34
|
def generate_configure_network_ip_request(network_ip_data)
|
30
35
|
builder = Builder::XmlMarkup.new
|
31
|
-
builder.IpAddress(
|
32
|
-
:xmlns => "urn:tmrk:eCloudExtensions-2.3") {
|
36
|
+
builder.IpAddress(ecloud_xmlns) {
|
33
37
|
builder.Id(network_ip_data[:id])
|
34
38
|
builder.Href(network_ip_data[:href])
|
35
39
|
builder.Name(network_ip_data[:name])
|
@@ -38,13 +42,24 @@ module Fog
|
|
38
42
|
builder.RnatAddress(network_ip_data[:rnat])
|
39
43
|
}
|
40
44
|
end
|
41
|
-
|
42
45
|
end
|
43
46
|
|
44
47
|
class Mock
|
48
|
+
include Shared
|
45
49
|
|
46
50
|
def configure_network_ip(network_ip_uri, network_ip_data)
|
47
|
-
|
51
|
+
validate_network_ip_data(network_ip_data)
|
52
|
+
|
53
|
+
if network_ip = mock_data.network_ip_from_href(network_ip_uri)
|
54
|
+
network_ip[:rnat] = network_ip_data[:rnat]
|
55
|
+
|
56
|
+
builder = Builder::XmlMarkup.new
|
57
|
+
xml = network_ip_response(builder, network_ip, ecloud_xmlns)
|
58
|
+
|
59
|
+
mock_it 200, xml, { 'Content-Type' => 'application/vnd.tmrk.ecloud.ip+xml' }
|
60
|
+
else
|
61
|
+
mock_error 200, "401 Unauthorized"
|
62
|
+
end
|
48
63
|
end
|
49
64
|
end
|
50
65
|
end
|
@@ -13,7 +13,8 @@ module Fog
|
|
13
13
|
vdc = virtual_machine._parent
|
14
14
|
|
15
15
|
if vdc.internet_service_collection.items.detect {|is| is.node_collection.items.any? {|isn| isn.ip_address == virtual_machine.ip } } ||
|
16
|
-
virtual_machine.status != 2
|
16
|
+
virtual_machine.status != 2 ||
|
17
|
+
virtual_machine.network_ip.rnat_set?
|
17
18
|
mock_it 202, '', {}
|
18
19
|
else
|
19
20
|
vdc.virtual_machines.delete(virtual_machine)
|
@@ -38,26 +38,43 @@ module Fog
|
|
38
38
|
def generate_internet_services(services)
|
39
39
|
builder = Builder::XmlMarkup.new
|
40
40
|
|
41
|
-
builder.InternetServices(
|
41
|
+
builder.InternetServices("xmlns" => "urn:tmrk:eCloudExtensions-2.5", "xmlns:i" => "http://www.w3.org/2001/XMLSchema-instance") {|xml|
|
42
42
|
services.each do |service|
|
43
|
-
xml
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
xml.
|
58
|
-
xml.
|
43
|
+
generate_internet_service(xml, service)
|
44
|
+
end
|
45
|
+
}
|
46
|
+
end
|
47
|
+
|
48
|
+
def generate_internet_service(xml, service, by_itself = false)
|
49
|
+
xml.InternetService(by_itself ? { "xmlns" => "urn:tmrk:eCloudExtensions-2.5", "xmlns:i" => "http://www.w3.org/2001/XMLSchema-instance" } : {}) {
|
50
|
+
xml.Id service.object_id
|
51
|
+
xml.Href service.href
|
52
|
+
xml.Name service.name
|
53
|
+
if MockDataClasses::MockBackupInternetService === service
|
54
|
+
xml.PublicIpAddress "i:nil" => true
|
55
|
+
else
|
56
|
+
xml.PublicIpAddress {
|
57
|
+
xml.Id service._parent._parent.object_id
|
58
|
+
xml.Href service._parent._parent.href
|
59
|
+
xml.Name service._parent._parent.name
|
59
60
|
}
|
60
61
|
end
|
62
|
+
xml.Port service.port
|
63
|
+
xml.Protocol service.protocol
|
64
|
+
xml.Enabled service.enabled
|
65
|
+
xml.Timeout service.timeout
|
66
|
+
xml.Description service.description
|
67
|
+
xml.RedirectURL service.redirect_url
|
68
|
+
xml.Monitor "i:nil" => true
|
69
|
+
xml.IsBackupService MockDataClasses::MockBackupInternetService === service
|
70
|
+
if MockDataClasses::MockPublicIpInternetService === service && service.backup_service
|
71
|
+
xml.BackupService do
|
72
|
+
xml.Href service.backup_service.href
|
73
|
+
end
|
74
|
+
else
|
75
|
+
xml.BackupService "i:nil" => true
|
76
|
+
end
|
77
|
+
xml.BackupOf
|
61
78
|
}
|
62
79
|
end
|
63
80
|
end
|
@@ -12,16 +12,18 @@ module Fog
|
|
12
12
|
def get_network_extensions(network_extension_uri)
|
13
13
|
if network_extension = mock_data.network_extension_from_href(ensure_unparsed(network_extension_uri))
|
14
14
|
xml = Builder::XmlMarkup.new
|
15
|
-
mock_it 200,
|
16
|
-
xml.
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
15
|
+
mock_it 200, xml.Network(ecloud_xmlns) {
|
16
|
+
xml.Address network_extension.address
|
17
|
+
xml.RnatAddress network_extension.rnat
|
18
|
+
xml.Href network_extension.href
|
19
|
+
xml.Id network_extension.object_id
|
20
|
+
xml.Name network_extension.name
|
21
|
+
xml.GatewayAddress network_extension.gateway
|
22
|
+
xml.BroadcastAddress network_extension.broadcast
|
23
|
+
xml.NetworkType network_extension.type
|
24
|
+
xml.Vlan network_extension.vlan
|
25
|
+
xml.FriendlyName network_extension.friendly_name
|
26
|
+
}, { 'Content-Type' => "application/vnd.tmrk.ecloud.network+xml" }
|
25
27
|
else
|
26
28
|
mock_error 200, "401 Unauthorized"
|
27
29
|
end
|
@@ -16,16 +16,7 @@ module Fog
|
|
16
16
|
def get_network_ip(network_ip_uri)
|
17
17
|
if network_ip = mock_data.network_ip_from_href(network_ip_uri)
|
18
18
|
builder = Builder::XmlMarkup.new
|
19
|
-
xml = builder
|
20
|
-
builder.Id network_ip.object_id
|
21
|
-
builder.Href network_ip.href
|
22
|
-
builder.Name network_ip.name
|
23
|
-
|
24
|
-
builder.Status network_ip.status
|
25
|
-
if network_ip.used_by
|
26
|
-
builder.Server network_ip.used_by
|
27
|
-
end
|
28
|
-
end
|
19
|
+
xml = network_ip_response(builder, network_ip, ecloud_xmlns)
|
29
20
|
|
30
21
|
mock_it 200, xml, { 'Content-Type' => 'application/vnd.tmrk.ecloud.ip+xml' }
|
31
22
|
else
|
@@ -33,6 +24,20 @@ module Fog
|
|
33
24
|
end
|
34
25
|
end
|
35
26
|
|
27
|
+
def network_ip_response(builder, network_ip, xmlns = {})
|
28
|
+
builder.IpAddress(xmlns) do
|
29
|
+
builder.Id network_ip.object_id
|
30
|
+
builder.Href network_ip.href
|
31
|
+
builder.Name network_ip.name
|
32
|
+
|
33
|
+
builder.Status network_ip.status
|
34
|
+
if network_ip.used_by
|
35
|
+
builder.Server network_ip.used_by.name
|
36
|
+
end
|
37
|
+
|
38
|
+
builder.RnatAddress(network_ip.rnat)
|
39
|
+
end
|
40
|
+
end
|
36
41
|
end
|
37
42
|
end
|
38
43
|
end
|
@@ -20,18 +20,7 @@ module Fog
|
|
20
20
|
builder = Builder::XmlMarkup.new
|
21
21
|
xml = builder.IpAddresses do
|
22
22
|
network_ip_collection.ordered_ips.each do |network_ip|
|
23
|
-
builder
|
24
|
-
builder.Name network_ip.name
|
25
|
-
builder.Href network_ip.href
|
26
|
-
|
27
|
-
if network_ip.used_by
|
28
|
-
builder.Status("Assigned")
|
29
|
-
builder.Server(network_ip.used_by.name)
|
30
|
-
else
|
31
|
-
builder.Status("Available")
|
32
|
-
end
|
33
|
-
builder.RnatAddress(network_ip.rnat)
|
34
|
-
end
|
23
|
+
network_ip_response(builder, network_ip)
|
35
24
|
end
|
36
25
|
end
|
37
26
|
|
data/lib/fog/zerigo.rb
ADDED
@@ -0,0 +1,25 @@
|
|
1
|
+
class Zerigo < Fog::Bin
|
2
|
+
class << self
|
3
|
+
|
4
|
+
def class_for(key)
|
5
|
+
case key
|
6
|
+
when :dns
|
7
|
+
Fog::Zerigo::DNS
|
8
|
+
else
|
9
|
+
raise ArgumentError, "Unrecognized service: #{key}"
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def [](service)
|
14
|
+
@@connections ||= Hash.new do |hash, key|
|
15
|
+
hash[key] = class_for(key).new
|
16
|
+
end
|
17
|
+
@@connections[service]
|
18
|
+
end
|
19
|
+
|
20
|
+
def services
|
21
|
+
[:dns]
|
22
|
+
end
|
23
|
+
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,96 @@
|
|
1
|
+
module Fog
|
2
|
+
module Zerigo
|
3
|
+
class DNS < Fog::Service
|
4
|
+
|
5
|
+
requires :zerigo_email, :zerigo_token
|
6
|
+
recognizes :timeout, :persistent
|
7
|
+
|
8
|
+
# model_path 'fog/zerigo/models/dns'
|
9
|
+
# model :server
|
10
|
+
# collection :servers
|
11
|
+
|
12
|
+
request_path 'fog/zerigo/requests/dns'
|
13
|
+
request :list_zones
|
14
|
+
request :count_zones
|
15
|
+
request :get_zone
|
16
|
+
request :get_zone_stats
|
17
|
+
request :create_zone
|
18
|
+
request :update_zone
|
19
|
+
request :delete_zone
|
20
|
+
request :list_hosts
|
21
|
+
request :find_hosts
|
22
|
+
request :count_hosts
|
23
|
+
request :get_host
|
24
|
+
request :create_host
|
25
|
+
request :update_host
|
26
|
+
request :delete_host
|
27
|
+
|
28
|
+
class Mock
|
29
|
+
|
30
|
+
def self.data
|
31
|
+
@data ||= Hash.new do |hash, key|
|
32
|
+
hash[key] = {}
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def self.reset_data(keys=data.keys)
|
37
|
+
for key in [*keys]
|
38
|
+
data.delete(key)
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
def initialize(options={})
|
43
|
+
@zerigo_email = options[:zerigo_email]
|
44
|
+
@zerigo_token = options[:zerigo_token]
|
45
|
+
@data = self.class.data[@zerigo_email]
|
46
|
+
@data = self.class.data[@zerigo_password]
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
|
51
|
+
class Real
|
52
|
+
|
53
|
+
def initialize(options={})
|
54
|
+
@zerigo_email = options[:zerigo_email]
|
55
|
+
@zerigo_token = options[:zerigo_token]
|
56
|
+
@host = options[:host] || "ns.zerigo.com"
|
57
|
+
@port = options[:port] || 80
|
58
|
+
@scheme = options[:scheme] || 'http'
|
59
|
+
@connection = Fog::Connection.new("#{@scheme}://#{@host}:#{@port}", options[:persistent])
|
60
|
+
end
|
61
|
+
|
62
|
+
def reload
|
63
|
+
@connection.reset
|
64
|
+
end
|
65
|
+
|
66
|
+
def request(params)
|
67
|
+
params[:headers] ||= {}
|
68
|
+
key= "#{@zerigo_email}:#{@zerigo_token}"
|
69
|
+
params[:headers].merge!({
|
70
|
+
'Authorization' => "Basic #{Base64.encode64(key).delete("\r\n")}"
|
71
|
+
})
|
72
|
+
case params[:method]
|
73
|
+
when 'DELETE', 'GET', 'HEAD'
|
74
|
+
params[:headers]['Accept'] = 'application/xml'
|
75
|
+
when 'POST', 'PUT'
|
76
|
+
params[:headers]['Content-Type'] = 'application/xml'
|
77
|
+
end
|
78
|
+
|
79
|
+
begin
|
80
|
+
response = @connection.request(params.merge!({:host => @host}))
|
81
|
+
rescue Excon::Errors::HTTPStatusError => error
|
82
|
+
raise case error
|
83
|
+
when Excon::Errors::NotFound
|
84
|
+
Fog::Zerigo::DNS::NotFound.slurp(error)
|
85
|
+
else
|
86
|
+
error
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
response
|
91
|
+
end
|
92
|
+
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module Zerigo
|
4
|
+
module DNS
|
5
|
+
|
6
|
+
class CountHosts < Fog::Parsers::Base
|
7
|
+
|
8
|
+
def reset
|
9
|
+
@response = {}
|
10
|
+
end
|
11
|
+
|
12
|
+
def end_element(name)
|
13
|
+
case name
|
14
|
+
when 'count'
|
15
|
+
@response[name] = @value.to_i
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
20
|
+
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module Zerigo
|
4
|
+
module DNS
|
5
|
+
|
6
|
+
class CountZones < Fog::Parsers::Base
|
7
|
+
|
8
|
+
def reset
|
9
|
+
@response = {}
|
10
|
+
end
|
11
|
+
|
12
|
+
def end_element(name)
|
13
|
+
case name
|
14
|
+
when 'count'
|
15
|
+
@response[name] = @value.to_i
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
20
|
+
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module Zerigo
|
4
|
+
module DNS
|
5
|
+
|
6
|
+
class CreateHost < Fog::Parsers::Base
|
7
|
+
|
8
|
+
def reset
|
9
|
+
@response = {}
|
10
|
+
end
|
11
|
+
|
12
|
+
def end_element(name)
|
13
|
+
case name
|
14
|
+
when 'id', 'priority', 'ttl', 'zone-id'
|
15
|
+
@response[name] = @value.to_i
|
16
|
+
when 'data', 'fqdn', 'host-type', 'hostname', 'notes', 'zone-id', 'created-at', 'updated-at'
|
17
|
+
@response[name] = @value
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
end
|
22
|
+
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|