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
data/lib/fog/core/deprecation.rb
CHANGED
@@ -2,12 +2,18 @@ module Fog
|
|
2
2
|
module Deprecation
|
3
3
|
|
4
4
|
def deprecate(older, newer)
|
5
|
-
|
5
|
+
module_eval <<-EOS, __FILE__, __LINE__
|
6
6
|
def #{older}(*args)
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
7
|
+
Formatador.display_line("[yellow][WARN] #{self} => ##{older} is deprecated, use ##{newer} instead[/] [light_black](#{caller.first})[/]")
|
8
|
+
send(:#{newer}, *args)
|
9
|
+
end
|
10
|
+
EOS
|
11
|
+
end
|
12
|
+
|
13
|
+
def self_deprecate(older, newer)
|
14
|
+
module_eval <<-EOS, __FILE__, __LINE__
|
15
|
+
def self.#{older}(*args)
|
16
|
+
Formatador.display_line("[yellow][WARN] #{self} => ##{older} is deprecated, use ##{newer} instead[/] [light_black](#{caller.first})[/]")
|
11
17
|
send(:#{newer}, *args)
|
12
18
|
end
|
13
19
|
EOS
|
@@ -0,0 +1,34 @@
|
|
1
|
+
module Fog
|
2
|
+
|
3
|
+
@mocking = false
|
4
|
+
|
5
|
+
def self.mock!
|
6
|
+
@mocking = true
|
7
|
+
end
|
8
|
+
|
9
|
+
def self.mock?
|
10
|
+
@mocking
|
11
|
+
end
|
12
|
+
|
13
|
+
def self.mocking?
|
14
|
+
@mocking
|
15
|
+
end
|
16
|
+
|
17
|
+
module Mock
|
18
|
+
@delay = 1
|
19
|
+
def self.delay
|
20
|
+
@delay
|
21
|
+
end
|
22
|
+
|
23
|
+
def self.delay=(new_delay)
|
24
|
+
raise ArgumentError, "delay must be non-negative" unless new_delay >= 0
|
25
|
+
@delay = new_delay
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.not_implemented
|
29
|
+
raise Fog::Errors::MockNotImplemented.new("Contributions welcome!")
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
data/lib/fog/core/model.rb
CHANGED
@@ -39,7 +39,15 @@ module Fog
|
|
39
39
|
def wait_for(timeout=600, interval=1, &block)
|
40
40
|
reload
|
41
41
|
Fog.wait_for(timeout, interval) do
|
42
|
-
|
42
|
+
retries = 3
|
43
|
+
if reload
|
44
|
+
retries = 3
|
45
|
+
elsif retries > 0
|
46
|
+
retries -= 1
|
47
|
+
sleep(1)
|
48
|
+
elsif retries == 0
|
49
|
+
raise Fog::Errors::Error.new("Reload failed, #{self.class} #{self.identity} went away.")
|
50
|
+
end
|
43
51
|
instance_eval(&block)
|
44
52
|
end
|
45
53
|
end
|
data/lib/fog/core/service.rb
CHANGED
@@ -18,26 +18,6 @@ module Fog
|
|
18
18
|
|
19
19
|
class << self
|
20
20
|
|
21
|
-
# this is to accomodate Real implementations of Service subclasses
|
22
|
-
# NOTE: it might be good to enforce parameter specs to Mock classes as well.
|
23
|
-
def inject_parameter_specs
|
24
|
-
lambda do |spec|
|
25
|
-
implementation = "Real"
|
26
|
-
self.const_set(implementation, Class.new) unless self.const_defined? implementation
|
27
|
-
realclass = self.const_get implementation
|
28
|
-
|
29
|
-
if realclass.declared_parameters_for(:'self.new', :required).empty?
|
30
|
-
required = declared_parameters_for(:'self.new', :required)
|
31
|
-
realclass.send(:requires, *required)
|
32
|
-
end
|
33
|
-
|
34
|
-
if realclass.declared_parameters_for(:'self.new', :optional).empty?
|
35
|
-
optional = declared_parameters_for(:'self.new', :optional)
|
36
|
-
realclass.send(:recognizes, *optional)
|
37
|
-
end
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
21
|
def inherited(child)
|
42
22
|
child.class_eval <<-EOS, __FILE__, __LINE__
|
43
23
|
module Collections
|
@@ -54,16 +34,16 @@ module Fog
|
|
54
34
|
EOS
|
55
35
|
end
|
56
36
|
|
57
|
-
def requirements
|
58
|
-
declared_parameters_for :'self.new', :required
|
59
|
-
end
|
60
|
-
|
61
37
|
def new(options={})
|
62
|
-
|
63
|
-
|
38
|
+
# attempt to load credentials from config file
|
39
|
+
begin
|
40
|
+
default_credentials = Fog.credentials.reject {|key, value| !(recognized | requirements).include?(key)}
|
64
41
|
options = default_credentials.merge(options)
|
42
|
+
rescue LoadError
|
43
|
+
# if there are no configured credentials, do nothing
|
65
44
|
end
|
66
45
|
|
46
|
+
validate_options(options)
|
67
47
|
setup_requirements
|
68
48
|
|
69
49
|
if Fog.mocking?
|
@@ -133,10 +113,44 @@ module Fog
|
|
133
113
|
@requests ||= []
|
134
114
|
end
|
135
115
|
|
116
|
+
def requires(*args)
|
117
|
+
requirements.concat(args)
|
118
|
+
end
|
119
|
+
|
120
|
+
def requirements
|
121
|
+
@requirements ||= []
|
122
|
+
end
|
123
|
+
|
124
|
+
def recognizes(*args)
|
125
|
+
recognized.concat(args)
|
126
|
+
end
|
127
|
+
|
128
|
+
def recognized
|
129
|
+
@recognized ||= []
|
130
|
+
end
|
131
|
+
|
132
|
+
def reset_data(keys=Mock.data.keys)
|
133
|
+
Mock.reset_data(keys)
|
134
|
+
end
|
135
|
+
|
136
136
|
def reset_data(keys=Mock.data.keys)
|
137
137
|
Mock.reset_data(keys)
|
138
138
|
end
|
139
139
|
|
140
|
+
def validate_options(options)
|
141
|
+
missing = requirements - options.keys
|
142
|
+
unless missing.empty?
|
143
|
+
raise ArgumentError, "Missing required arguments: #{missing.join(', ')}"
|
144
|
+
end
|
145
|
+
|
146
|
+
unless recognizes.empty?
|
147
|
+
unrecognized = options.keys - requirements - recognized
|
148
|
+
unless unrecognized.empty?
|
149
|
+
raise ArgumentError, "Unrecognized arguments: #{unrecognized.join(', ')}"
|
150
|
+
end
|
151
|
+
end
|
152
|
+
end
|
153
|
+
|
140
154
|
end
|
141
155
|
|
142
156
|
end
|
data/lib/fog/core/storage.rb
CHANGED
@@ -0,0 +1,21 @@
|
|
1
|
+
module Fog
|
2
|
+
class Time < ::Time
|
3
|
+
class << self
|
4
|
+
|
5
|
+
def now
|
6
|
+
::Time.now - offset
|
7
|
+
end
|
8
|
+
|
9
|
+
def now=(new_now)
|
10
|
+
old_now = ::Time.now
|
11
|
+
@offset = old_now - new_now
|
12
|
+
new_now
|
13
|
+
end
|
14
|
+
|
15
|
+
def offset
|
16
|
+
@offset ||= 0
|
17
|
+
end
|
18
|
+
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
module Fog
|
2
|
+
|
3
|
+
def self.wait_for(timeout=600, interval=1, &block)
|
4
|
+
duration = 0
|
5
|
+
start = Time.now
|
6
|
+
until yield || duration > timeout
|
7
|
+
sleep(interval)
|
8
|
+
duration = Time.now - start
|
9
|
+
end
|
10
|
+
if duration > timeout
|
11
|
+
false
|
12
|
+
else
|
13
|
+
{ :duration => duration }
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
end
|
data/lib/fog/go_grid.rb
CHANGED
data/lib/fog/go_grid/compute.rb
CHANGED
@@ -2,8 +2,8 @@ module Fog
|
|
2
2
|
module GoGrid
|
3
3
|
class Compute < Fog::Service
|
4
4
|
|
5
|
-
requires :go_grid_api_key, :go_grid_shared_secret
|
6
|
-
recognizes :host, :path, :port, :scheme, :persistent
|
5
|
+
requires :go_grid_api_key, :go_grid_shared_secret
|
6
|
+
recognizes :host, :path, :port, :scheme, :persistent
|
7
7
|
|
8
8
|
model_path 'fog/go_grid/models/compute'
|
9
9
|
model :image
|
data/lib/fog/google.rb
CHANGED
@@ -83,11 +83,12 @@ module Fog
|
|
83
83
|
|
84
84
|
response.status = 200
|
85
85
|
response.body = {
|
86
|
-
'
|
87
|
-
'
|
88
|
-
'
|
89
|
-
'
|
90
|
-
'
|
86
|
+
'CommonPrefixes' => [],
|
87
|
+
'Contents' => truncated_contents,
|
88
|
+
'IsTruncated' => truncated_contents.size != contents.size,
|
89
|
+
'Marker' => options['marker'],
|
90
|
+
'Name' => bucket['Name'],
|
91
|
+
'Prefix' => options['prefix']
|
91
92
|
}
|
92
93
|
if options['max-keys'] && options['max-keys'] < response.body['Contents'].length
|
93
94
|
response.body['IsTruncated'] = true
|
@@ -23,9 +23,9 @@ module Fog
|
|
23
23
|
end
|
24
24
|
url({
|
25
25
|
:headers => {},
|
26
|
-
:host =>
|
26
|
+
:host => @host,
|
27
27
|
:method => 'GET',
|
28
|
-
:path =>
|
28
|
+
:path => "#{bucket_name}/#{object_name}"
|
29
29
|
}, expires)
|
30
30
|
end
|
31
31
|
|
@@ -42,9 +42,9 @@ module Fog
|
|
42
42
|
end
|
43
43
|
url({
|
44
44
|
:headers => {},
|
45
|
-
:host =>
|
45
|
+
:host => @host,
|
46
46
|
:method => 'GET',
|
47
|
-
:path =>
|
47
|
+
:path => "#{bucket_name}/#{object_name}"
|
48
48
|
}, expires)
|
49
49
|
end
|
50
50
|
|
@@ -23,9 +23,9 @@ module Fog
|
|
23
23
|
end
|
24
24
|
url({
|
25
25
|
:headers => {},
|
26
|
-
:host =>
|
26
|
+
:host => @host,
|
27
27
|
:method => 'PUT',
|
28
|
-
:path =>
|
28
|
+
:path => "#{bucket_name}/#{object_name}"
|
29
29
|
}, expires)
|
30
30
|
end
|
31
31
|
|
@@ -42,9 +42,9 @@ module Fog
|
|
42
42
|
end
|
43
43
|
url({
|
44
44
|
:headers => {},
|
45
|
-
:host =>
|
45
|
+
:host => @host,
|
46
46
|
:method => 'PUT',
|
47
|
-
:path =>
|
47
|
+
:path => "#{bucket_name}/#{object_name}"
|
48
48
|
}, expires)
|
49
49
|
end
|
50
50
|
|
data/lib/fog/google/storage.rb
CHANGED
@@ -2,8 +2,8 @@ module Fog
|
|
2
2
|
module Google
|
3
3
|
class Storage < Fog::Service
|
4
4
|
|
5
|
-
requires :google_storage_access_key_id, :google_storage_secret_access_key
|
6
|
-
recognizes :host, :port, :scheme, :persistent
|
5
|
+
requires :google_storage_access_key_id, :google_storage_secret_access_key
|
6
|
+
recognizes :host, :port, :scheme, :persistent
|
7
7
|
|
8
8
|
model_path 'fog/google/models/storage'
|
9
9
|
collection :directories
|
@@ -57,7 +57,8 @@ module Fog
|
|
57
57
|
query << "GoogleAccessKeyId=#{@google_storage_access_key_id}"
|
58
58
|
query << "Signature=#{CGI.escape(signature(params))}"
|
59
59
|
query << "Expires=#{params[:headers]['Date']}"
|
60
|
-
|
60
|
+
path = CGI.escape(params[:path]).gsub('%2F', '/')
|
61
|
+
"http://#{params[:host]}/#{path}?#{query.join('&')}"
|
61
62
|
end
|
62
63
|
|
63
64
|
end
|
data/lib/fog/linode.rb
CHANGED
data/lib/fog/linode/bin.rb
CHANGED
@@ -3,9 +3,11 @@ class Linode < Fog::Bin
|
|
3
3
|
|
4
4
|
def class_for(key)
|
5
5
|
case key
|
6
|
-
when :compute
|
6
|
+
when :compute
|
7
7
|
Fog::Linode::Compute
|
8
|
-
|
8
|
+
when :dns
|
9
|
+
Fog::Linode::DNS
|
10
|
+
else
|
9
11
|
raise ArgumentError, "Unsupported #{self} service: #{key}"
|
10
12
|
end
|
11
13
|
end
|
@@ -24,7 +26,7 @@ class Linode < Fog::Bin
|
|
24
26
|
end
|
25
27
|
|
26
28
|
def services
|
27
|
-
[:compute]
|
29
|
+
[:compute, :dns]
|
28
30
|
end
|
29
31
|
|
30
32
|
end
|
data/lib/fog/linode/compute.rb
CHANGED
@@ -2,8 +2,8 @@ module Fog
|
|
2
2
|
module Linode
|
3
3
|
class Compute < Fog::Service
|
4
4
|
|
5
|
-
requires :linode_api_key
|
6
|
-
recognizes :port, :scheme, :persistent
|
5
|
+
requires :linode_api_key
|
6
|
+
recognizes :port, :scheme, :persistent
|
7
7
|
|
8
8
|
model_path 'fog/linode/models/compute'
|
9
9
|
|
@@ -13,10 +13,14 @@ module Fog
|
|
13
13
|
request :avail_kernels
|
14
14
|
request :avail_linodeplans
|
15
15
|
request :avail_stackscripts
|
16
|
+
# request :linode_boot
|
16
17
|
request :linode_create
|
17
18
|
request :linode_delete
|
18
19
|
request :linode_list
|
19
20
|
request :linode_reboot
|
21
|
+
# request :linode_resize
|
22
|
+
# request :linode_shutdown
|
23
|
+
# request :linode_update
|
20
24
|
|
21
25
|
class Mock
|
22
26
|
|
@@ -0,0 +1,80 @@
|
|
1
|
+
module Fog
|
2
|
+
module Linode
|
3
|
+
class DNS < Fog::Service
|
4
|
+
|
5
|
+
requires :linode_api_key
|
6
|
+
recognizes :port, :scheme, :persistent
|
7
|
+
|
8
|
+
model_path 'fog/linode/models/dns'
|
9
|
+
|
10
|
+
request_path 'fog/linode/requests/dns'
|
11
|
+
request :domain_create
|
12
|
+
request :domain_delete
|
13
|
+
request :domain_list
|
14
|
+
request :domain_update
|
15
|
+
request :domain_resource_create
|
16
|
+
request :domain_resource_delete
|
17
|
+
request :domain_resource_list
|
18
|
+
request :domain_resource_update
|
19
|
+
|
20
|
+
class Mock
|
21
|
+
|
22
|
+
def self.data
|
23
|
+
@data ||= Hash.new do |hash, key|
|
24
|
+
hash[key] = {}
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.reset_data(keys=data.keys)
|
29
|
+
for key in [*keys]
|
30
|
+
data.delete(key)
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def initialize(options={})
|
35
|
+
@linode_api_key = options[:linode_api_key]
|
36
|
+
@data = self.class.data[@linode_api_key]
|
37
|
+
end
|
38
|
+
|
39
|
+
end
|
40
|
+
|
41
|
+
class Real
|
42
|
+
|
43
|
+
def initialize(options={})
|
44
|
+
require 'json'
|
45
|
+
@linode_api_key = options[:linode_api_key]
|
46
|
+
@host = options[:host] || "api.linode.com"
|
47
|
+
@port = options[:port] || 443
|
48
|
+
@scheme = options[:scheme] || 'https'
|
49
|
+
@connection = Fog::Connection.new("#{@scheme}://#{@host}:#{@port}", options[:persistent])
|
50
|
+
end
|
51
|
+
|
52
|
+
def reload
|
53
|
+
@connection.reset
|
54
|
+
end
|
55
|
+
|
56
|
+
def request(params)
|
57
|
+
params[:query] ||= {}
|
58
|
+
params[:query].merge!(:api_key => @linode_api_key)
|
59
|
+
|
60
|
+
response = @connection.request(params.merge!({:host => @host}))
|
61
|
+
|
62
|
+
unless response.body.empty?
|
63
|
+
response.body = JSON.parse(response.body)
|
64
|
+
if data = response.body['ERRORARRAY'].first
|
65
|
+
error = case data['ERRORCODE']
|
66
|
+
when 5
|
67
|
+
Fog::Linode::DNS::NotFound
|
68
|
+
else
|
69
|
+
Fog::Linode::DNS::Error
|
70
|
+
end
|
71
|
+
raise error.new(data['ERRORMESSAGE'])
|
72
|
+
end
|
73
|
+
end
|
74
|
+
response
|
75
|
+
end
|
76
|
+
|
77
|
+
end
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|