fog 1.4.0 → 1.5.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +1 -1
- data/.irbrc +5 -10
- data/{README.rdoc → README.md} +66 -61
- data/Rakefile +4 -6
- data/changelog.txt +491 -0
- data/docs/about/users.markdown +1 -0
- data/fog.gemspec +4 -4
- data/lib/fog.rb +1 -1
- data/lib/fog/aws.rb +4 -0
- data/lib/fog/aws/auto_scaling.rb +3 -0
- data/lib/fog/aws/cloud_watch.rb +28 -0
- data/lib/fog/aws/compute.rb +7 -1
- data/lib/fog/aws/elasticache.rb +64 -6
- data/lib/fog/aws/models/auto_scaling/configuration.rb +3 -1
- data/lib/fog/aws/models/auto_scaling/group.rb +10 -9
- data/lib/fog/aws/models/auto_scaling/policies.rb +33 -0
- data/lib/fog/aws/models/auto_scaling/policy.rb +46 -0
- data/lib/fog/aws/models/cloud_watch/alarm.rb +50 -2
- data/lib/fog/aws/models/cloud_watch/alarms.rb +18 -1
- data/lib/fog/aws/models/compute/address.rb +2 -2
- data/lib/fog/aws/models/dns/records.rb +5 -0
- data/lib/fog/aws/models/elasticache/cluster.rb +1 -1
- data/lib/fog/aws/models/iam/users.rb +26 -4
- data/lib/fog/aws/parsers/auto_scaling/describe_policies.rb +7 -5
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +1 -1
- data/lib/fog/aws/rds.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +8 -0
- data/lib/fog/aws/requests/auto_scaling/create_launch_configuration.rb +1 -2
- data/lib/fog/aws/requests/auto_scaling/delete_auto_scaling_group.rb +10 -2
- data/lib/fog/aws/requests/auto_scaling/delete_launch_configuration.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/delete_policy.rb +10 -1
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_instances.rb +0 -1
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +13 -1
- data/lib/fog/aws/requests/auto_scaling/put_scaling_policy.rb +20 -1
- data/lib/fog/aws/requests/auto_scaling/update_auto_scaling_group.rb +1 -1
- data/lib/fog/aws/requests/cloud_watch/delete_alarms.rb +19 -1
- data/lib/fog/aws/requests/cloud_watch/describe_alarms.rb +20 -2
- data/lib/fog/aws/requests/cloud_watch/put_metric_alarm.rb +9 -0
- data/lib/fog/aws/requests/compute/allocate_address.rb +4 -5
- data/lib/fog/aws/requests/compute/create_dhcp_options.rb +6 -5
- data/lib/fog/aws/requests/compute/create_internet_gateway.rb +7 -6
- data/lib/fog/aws/requests/compute/create_subnet.rb +11 -10
- data/lib/fog/aws/requests/compute/create_vpc.rb +8 -7
- data/lib/fog/aws/requests/compute/delete_dhcp_options.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_subnet.rb +1 -0
- data/lib/fog/aws/requests/compute/delete_vpc.rb +2 -1
- data/lib/fog/aws/requests/compute/describe_availability_zones.rb +1 -0
- data/lib/fog/aws/requests/compute/describe_dhcp_options.rb +1 -8
- data/lib/fog/aws/requests/compute/describe_instances.rb +3 -1
- data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +1 -8
- data/lib/fog/aws/requests/compute/describe_subnets.rb +1 -9
- data/lib/fog/aws/requests/compute/describe_vpcs.rb +1 -8
- data/lib/fog/aws/requests/compute/release_address.rb +12 -4
- data/lib/fog/aws/requests/compute/start_instances.rb +1 -0
- data/lib/fog/aws/requests/compute/stop_instances.rb +1 -0
- data/lib/fog/aws/requests/elasticache/create_cache_cluster.rb +26 -2
- data/lib/fog/aws/requests/elasticache/delete_cache_cluster.rb +10 -1
- data/lib/fog/aws/requests/elasticache/describe_cache_clusters.rb +16 -1
- data/lib/fog/aws/requests/elasticache/modify_cache_cluster.rb +35 -3
- data/lib/fog/aws/requests/elasticache/reboot_cache_cluster.rb +10 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +1 -1
- data/lib/fog/aws/requests/rds/describe_db_instances.rb +3 -3
- data/lib/fog/aws/sqs.rb +1 -1
- data/lib/fog/aws/storage.rb +1 -1
- data/lib/fog/bin/rackspace.rb +4 -0
- data/lib/fog/cloudstack/compute.rb +25 -18
- data/lib/fog/cloudstack/models/compute/image.rb +34 -34
- data/lib/fog/cloudstack/models/compute/job.rb +14 -1
- data/lib/fog/cloudstack/models/compute/jobs.rb +1 -1
- data/lib/fog/cloudstack/models/compute/security_group.rb +50 -0
- data/lib/fog/cloudstack/models/compute/security_group_rule.rb +62 -0
- data/lib/fog/cloudstack/models/compute/security_group_rules.rb +37 -0
- data/lib/fog/cloudstack/models/compute/security_groups.rb +27 -0
- data/lib/fog/cloudstack/models/compute/server.rb +63 -39
- data/lib/fog/cloudstack/models/compute/volume.rb +3 -7
- data/lib/fog/cloudstack/models/compute/zone.rb +1 -2
- data/lib/fog/cloudstack/requests/compute/assign_virtual_machine.rb +18 -0
- data/lib/fog/cloudstack/requests/compute/authorize_security_group_egress.rb +68 -0
- data/lib/fog/cloudstack/requests/compute/authorize_security_group_ingress.rb +55 -4
- data/lib/fog/cloudstack/requests/compute/create_security_group.rb +12 -4
- data/lib/fog/cloudstack/requests/compute/create_zone.rb +20 -0
- data/lib/fog/cloudstack/requests/compute/delete_security_group.rb +17 -0
- data/lib/fog/cloudstack/requests/compute/destroy_virtual_machine.rb +23 -1
- data/lib/fog/cloudstack/requests/compute/list_firewall_rules.rb +15 -0
- data/lib/fog/cloudstack/requests/compute/list_security_groups.rb +22 -4
- data/lib/fog/cloudstack/requests/compute/query_async_job_result.rb +15 -3
- data/lib/fog/cloudstack/requests/compute/revoke_security_group_egress.rb +42 -0
- data/lib/fog/cloudstack/requests/compute/revoke_security_group_ingress.rb +29 -3
- data/lib/fog/core.rb +1 -0
- data/lib/fog/core/attributes.rb +1 -1
- data/lib/fog/core/current_machine.rb +2 -2
- data/lib/fog/core/scp.rb +8 -0
- data/lib/fog/core/ssh.rb +8 -0
- data/lib/fog/dynect/dns.rb +14 -5
- data/lib/fog/ibm/requests/compute/create_instance.rb +1 -1
- data/lib/fog/libvirt/requests/compute/create_volume.rb +1 -1
- data/lib/fog/libvirt/requests/compute/list_volumes.rb +1 -1
- data/lib/fog/local/models/storage/file.rb +12 -1
- data/lib/fog/local/storage.rb +25 -1
- data/lib/fog/ninefold/compute.rb +1 -0
- data/lib/fog/openstack.rb +3 -1
- data/lib/fog/openstack/compute.rb +13 -2
- data/lib/fog/openstack/models/compute/servers.rb +10 -2
- data/lib/fog/openstack/requests/compute/create_flavor.rb +2 -2
- data/lib/fog/openstack/requests/compute/create_security_group.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_server.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_volume.rb +1 -1
- data/lib/fog/openstack/requests/compute/get_flavor_details.rb +7 -7
- data/lib/fog/openstack/requests/compute/get_quota.rb +1 -12
- data/lib/fog/openstack/requests/compute/get_quota_defaults.rb +1 -12
- data/lib/fog/openstack/requests/compute/get_volume_details.rb +1 -1
- data/lib/fog/openstack/requests/compute/list_flavors.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_flavors_detail.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_security_groups.rb +7 -7
- data/lib/fog/openstack/requests/compute/list_servers_detail.rb +4 -3
- data/lib/fog/openstack/requests/compute/list_volumes.rb +6 -8
- data/lib/fog/openstack/requests/compute/update_quota.rb +2 -15
- data/lib/fog/openstack/requests/identity/delete_role.rb +1 -1
- data/lib/fog/openstack/requests/identity/list_roles.rb +1 -1
- data/lib/fog/openstack/requests/image/create_image.rb +3 -1
- data/lib/fog/openstack/requests/image/list_public_images.rb +19 -1
- data/lib/fog/openstack/requests/image/list_public_images_detailed.rb +20 -2
- data/lib/fog/openstack/requests/image/update_image.rb +1 -1
- data/lib/fog/rackspace.rb +2 -0
- data/lib/fog/rackspace/databases.rb +121 -0
- data/lib/fog/rackspace/identity.rb +83 -0
- data/lib/fog/rackspace/load_balancers.rb +3 -0
- data/lib/fog/rackspace/models/databases/database.rb +32 -0
- data/lib/fog/rackspace/models/databases/databases.rb +31 -0
- data/lib/fog/rackspace/models/databases/flavor.rb +15 -0
- data/lib/fog/rackspace/models/databases/flavors.rb +25 -0
- data/lib/fog/rackspace/models/databases/instance.rb +104 -0
- data/lib/fog/rackspace/models/databases/instances.rb +25 -0
- data/lib/fog/rackspace/models/databases/user.rb +32 -0
- data/lib/fog/rackspace/models/databases/users.rb +31 -0
- data/lib/fog/rackspace/models/identity/credential.rb +13 -0
- data/lib/fog/rackspace/models/identity/credentials.rb +32 -0
- data/lib/fog/rackspace/models/identity/role.rb +14 -0
- data/lib/fog/rackspace/models/identity/roles.rb +32 -0
- data/lib/fog/rackspace/models/identity/tenant.rb +15 -0
- data/lib/fog/rackspace/models/identity/tenants.rb +28 -0
- data/lib/fog/rackspace/models/identity/user.rb +53 -0
- data/lib/fog/rackspace/models/identity/users.rb +36 -0
- data/lib/fog/rackspace/models/load_balancers/load_balancer.rb +17 -0
- data/lib/fog/rackspace/requests/databases/check_root_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/create_database.rb +24 -0
- data/lib/fog/rackspace/requests/databases/create_instance.rb +26 -0
- data/lib/fog/rackspace/requests/databases/create_user.rb +24 -0
- data/lib/fog/rackspace/requests/databases/delete_database.rb +15 -0
- data/lib/fog/rackspace/requests/databases/delete_instance.rb +15 -0
- data/lib/fog/rackspace/requests/databases/delete_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/enable_root_user.rb +15 -0
- data/lib/fog/rackspace/requests/databases/get_flavor.rb +15 -0
- data/lib/fog/rackspace/requests/databases/get_instance.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_databases.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_flavors.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_instances.rb +15 -0
- data/lib/fog/rackspace/requests/databases/list_users.rb +15 -0
- data/lib/fog/rackspace/requests/databases/resize_instance.rb +22 -0
- data/lib/fog/rackspace/requests/databases/resize_instance_volume.rb +24 -0
- data/lib/fog/rackspace/requests/databases/restart_instance.rb +20 -0
- data/lib/fog/rackspace/requests/identity/create_token.rb +25 -0
- data/lib/fog/rackspace/requests/identity/create_user.rb +25 -0
- data/lib/fog/rackspace/requests/identity/delete_user.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_credentials.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_user_by_id.rb +15 -0
- data/lib/fog/rackspace/requests/identity/get_user_by_name.rb +15 -0
- data/lib/fog/rackspace/requests/identity/list_credentials.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_tenants.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_user_roles.rb +22 -0
- data/lib/fog/rackspace/requests/identity/list_users.rb +22 -0
- data/lib/fog/rackspace/requests/identity/update_user.rb +24 -0
- data/lib/fog/rackspace/requests/load_balancers/get_ssl_termination.rb +15 -0
- data/lib/fog/rackspace/requests/load_balancers/remove_ssl_termination.rb +15 -0
- data/lib/fog/rackspace/requests/load_balancers/set_ssl_termination.rb +31 -0
- data/lib/fog/rackspace/storage.rb +1 -1
- data/lib/fog/vsphere/models/compute/server.rb +1 -0
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +2 -2
- data/tests/aws/models/compute/address_tests.rb +2 -1
- data/tests/aws/models/compute/volume_tests.rb +1 -1
- data/tests/aws/models/dns/records_tests.rb +19 -1
- data/tests/aws/models/storage/directory_tests.rb +1 -1
- data/tests/aws/models/storage/url_tests.rb +7 -1
- data/tests/aws/requests/auto_scaling/auto_scaling_tests.rb +4 -2
- data/tests/aws/requests/compute/address_tests.rb +19 -1
- data/tests/aws/requests/elasticache/cache_cluster_tests.rb +4 -4
- data/tests/aws/requests/elb/helper.rb +13 -2
- data/tests/aws/requests/iam/access_key_tests.rb +1 -3
- data/tests/cloudstack/compute/models/security_group_rule_tests.rb +29 -0
- data/tests/cloudstack/compute/models/security_group_tests.rb +16 -0
- data/tests/cloudstack/compute/models/security_groups_tests.rb +19 -0
- data/tests/cloudstack/compute/models/server_tests.rb +18 -0
- data/tests/cloudstack/compute/models/volume_tests.rb +34 -0
- data/tests/cloudstack/compute/models/volumes_tests.rb +17 -0
- data/tests/compute/helper.rb +10 -3
- data/tests/core/current_machine_tests.rb +32 -0
- data/tests/helper.rb +1 -1
- data/tests/helpers/mock_helper.rb +3 -0
- data/tests/hp/requests/compute/address_tests.rb +2 -1
- data/tests/joyent/requests/compute/datasets_tests.rb +12 -3
- data/tests/local/models/file_tests.rb +43 -0
- data/tests/local/storage_tests.rb +40 -0
- data/tests/openstack/requests/compute/flavor_tests.rb +1 -1
- data/tests/openstack/requests/compute/server_tests.rb +3 -3
- data/tests/openstack/requests/compute/volume_tests.rb +1 -1
- data/tests/openstack/requests/identity/role_tests.rb +1 -1
- data/tests/rackspace/databases_tests.rb +26 -0
- data/tests/rackspace/models/databases/database_tests.rb +17 -0
- data/tests/rackspace/models/databases/databases_tests.rb +17 -0
- data/tests/rackspace/models/databases/flavors_tests.rb +20 -0
- data/tests/rackspace/models/databases/instance_tests.rb +43 -0
- data/tests/rackspace/models/databases/instances_tests.rb +14 -0
- data/tests/rackspace/models/databases/user_tests.rb +21 -0
- data/tests/rackspace/models/databases/users_tests.rb +21 -0
- data/tests/rackspace/models/identity/credentials_tests.rb +16 -0
- data/tests/rackspace/models/identity/roles_tests.rb +16 -0
- data/tests/rackspace/models/identity/tenants_tests.rb +21 -0
- data/tests/rackspace/models/identity/user_tests.rb +17 -0
- data/tests/rackspace/models/identity/users_tests.rb +17 -0
- data/tests/rackspace/models/load_balancers/load_balancer_tests.rb +20 -0
- data/tests/rackspace/requests/databases/database_tests.rb +36 -0
- data/tests/rackspace/requests/databases/flavor_tests.rb +16 -0
- data/tests/rackspace/requests/databases/helper.rb +84 -0
- data/tests/rackspace/requests/databases/instance_tests.rb +77 -0
- data/tests/rackspace/requests/databases/user_tests.rb +37 -0
- data/tests/rackspace/requests/identity/tenants_tests.rb +21 -0
- data/tests/rackspace/requests/identity/token_tests.rb +63 -0
- data/tests/rackspace/requests/identity/user_tests.rb +107 -0
- data/tests/rackspace/requests/load_balancers/helper.rb +70 -1
- data/tests/rackspace/requests/load_balancers/ssl_termination_tests.rb +38 -0
- data/tests/storage/models/file_tests.rb +1 -1
- metadata +129 -13
- data/spec/core/current_machine_spec.rb +0 -32
- data/spec/lib/fog/aws/parsers/sqs/receive_message_spec.rb +0 -58
- data/spec/spec_helper.rb +0 -8
@@ -3,9 +3,6 @@ module Fog
|
|
3
3
|
class Cloudstack
|
4
4
|
class Real
|
5
5
|
|
6
|
-
# Creates an account.
|
7
|
-
#
|
8
|
-
# {CloudStack API Reference}[http://download.cloud.com/releases/2.2.0/api_2.2.4/global_admin/authorizeSecurityGroupIngress.html]
|
9
6
|
def revoke_security_group_ingress(options={})
|
10
7
|
options.merge!(
|
11
8
|
'command' => 'revokeSecurityGroupIngress'
|
@@ -14,6 +11,35 @@ module Fog
|
|
14
11
|
request(options)
|
15
12
|
end
|
16
13
|
|
14
|
+
end # Real
|
15
|
+
|
16
|
+
class Mock
|
17
|
+
def revoke_security_group_ingress(options={})
|
18
|
+
unless security_group_rule_id = options['id']
|
19
|
+
raise Fog::Compute::Cloudstack::BadRequest.new('Unable to execute API command missing parameter id')
|
20
|
+
end
|
21
|
+
|
22
|
+
security_group = self.data[:security_groups].values.find do |group|
|
23
|
+
(rule = (group['ingressrule'] || []).find{|r| r['ruleid'] == security_group_rule_id}) && group['ingressrule'].delete(rule)
|
24
|
+
end
|
25
|
+
|
26
|
+
job_id = Fog::Cloudstack.uuid
|
27
|
+
job = {
|
28
|
+
"cmd" => "com.cloud.api.commands.revokeSecurityGroupIngress",
|
29
|
+
"created" => Time.now.iso8601,
|
30
|
+
"jobid" => job_id,
|
31
|
+
"jobstatus" => 1,
|
32
|
+
"jobprocstatus" => 0,
|
33
|
+
"jobresultcode" => 0,
|
34
|
+
"jobresulttype" => "object",
|
35
|
+
"jobresult" => { "securitygroup" => security_group }
|
36
|
+
}
|
37
|
+
|
38
|
+
self.data[:jobs][job_id]= job
|
39
|
+
|
40
|
+
{"revokesecuritygroupingress" => { "jobid" => job_id }}
|
41
|
+
end
|
42
|
+
|
17
43
|
end
|
18
44
|
end
|
19
45
|
end
|
data/lib/fog/core.rb
CHANGED
data/lib/fog/core/attributes.rb
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
|
1
|
+
require 'thread'
|
2
2
|
module Fog
|
3
3
|
class CurrentMachine
|
4
4
|
@@lock = Mutex.new
|
@@ -24,7 +24,7 @@ module Fog
|
|
24
24
|
# puts "Service timeout"
|
25
25
|
# end
|
26
26
|
#
|
27
|
-
# @raise [
|
27
|
+
# @raise [Excon::Errors::Error] if the net/http request fails.
|
28
28
|
def self.ip_address
|
29
29
|
@@lock.synchronize do
|
30
30
|
@@ip_address ||= Excon.get(AMAZON_AWS_CHECK_IP).body.chomp
|
data/lib/fog/core/scp.rb
CHANGED
@@ -52,6 +52,14 @@ module Fog
|
|
52
52
|
raise ArgumentError.new(':key_data, :keys, :password or a loaded ssh-agent is required to initialize SSH')
|
53
53
|
end
|
54
54
|
|
55
|
+
if options[:key_data] || options[:keys]
|
56
|
+
options[:keys_only] = true
|
57
|
+
#Explicitly set these so net-ssh doesn't add the default keys
|
58
|
+
#as seen at https://github.com/net-ssh/net-ssh/blob/master/lib/net/ssh/authentication/session.rb#L131-146
|
59
|
+
options[:keys] = [] unless options[:keys]
|
60
|
+
options[:key_data] = [] unless options[:key_data]
|
61
|
+
end
|
62
|
+
|
55
63
|
@address = address
|
56
64
|
@username = username
|
57
65
|
@options = { :paranoid => false }.merge(options)
|
data/lib/fog/core/ssh.rb
CHANGED
@@ -46,6 +46,14 @@ module Fog
|
|
46
46
|
raise ArgumentError.new(':key_data, :keys, :password or a loaded ssh-agent is required to initialize SSH')
|
47
47
|
end
|
48
48
|
|
49
|
+
if options[:key_data] || options[:keys]
|
50
|
+
options[:keys_only] = true
|
51
|
+
#Explicitly set these so net-ssh doesn't add the default keys
|
52
|
+
#as seen at https://github.com/net-ssh/net-ssh/blob/master/lib/net/ssh/authentication/session.rb#L131-146
|
53
|
+
options[:keys] = [] unless options[:keys]
|
54
|
+
options[:key_data] = [] unless options[:key_data]
|
55
|
+
end
|
56
|
+
|
49
57
|
@address = address
|
50
58
|
@username = username
|
51
59
|
@options = { :paranoid => false }.merge(options)
|
data/lib/fog/dynect/dns.rb
CHANGED
@@ -65,7 +65,7 @@ module Fog
|
|
65
65
|
@dynect_password = options[:dynect_password]
|
66
66
|
|
67
67
|
@connection_options = options[:connection_options] || {}
|
68
|
-
@host =
|
68
|
+
@host = 'api2.dynect.net'
|
69
69
|
@port = options[:port] || 443
|
70
70
|
@path = options[:path] || '/REST'
|
71
71
|
@persistent = options[:persistent] || false
|
@@ -86,16 +86,25 @@ module Fog
|
|
86
86
|
params[:headers] ||= {}
|
87
87
|
params[:headers]['Content-Type'] = 'application/json'
|
88
88
|
params[:headers]['API-Version'] = @version
|
89
|
-
params[:headers]['Auth-Token'] = auth_token unless params[:path] ==
|
89
|
+
params[:headers]['Auth-Token'] = auth_token unless params[:path] == 'Session'
|
90
90
|
params[:path] = "#{@path}/#{params[:path]}" unless params[:path] =~ %r{^#{Regexp.escape(@path)}/}
|
91
|
+
|
91
92
|
response = @connection.request(params.merge!({:host => @host}))
|
92
93
|
|
93
|
-
if response.
|
94
|
-
response =
|
95
|
-
|
94
|
+
if response.body.empty?
|
95
|
+
response.body = {}
|
96
|
+
else
|
96
97
|
response.body = Fog::JSON.decode(response.body)
|
97
98
|
end
|
98
99
|
|
100
|
+
if response.body['status'] == 'failure'
|
101
|
+
raise Error, response.body['msgs'].first['INFO']
|
102
|
+
end
|
103
|
+
|
104
|
+
if response.status == 307 && params[:path] !~ %r{^/REST/Job/}
|
105
|
+
response = poll_job(response)
|
106
|
+
end
|
107
|
+
|
99
108
|
response
|
100
109
|
rescue Excon::Errors::HTTPStatusError => error
|
101
110
|
if @auth_token && error.message =~ /login: (Bad or expired credentials|inactivity logout)/
|
@@ -46,7 +46,7 @@ module Fog
|
|
46
46
|
'volumeID' => options[:volume_id],
|
47
47
|
'vlanID' => options[:vlan_id],
|
48
48
|
'SecondaryIP' => options[:secondary_ip],
|
49
|
-
'
|
49
|
+
'isMiniEphemeral' => options[:is_mini_ephemeral],
|
50
50
|
'Configuration Data' => options[:configuration_data],
|
51
51
|
'antiCollocationInstance' => options[:anti_collocation_instance],
|
52
52
|
}
|
@@ -20,7 +20,7 @@ module Fog
|
|
20
20
|
|
21
21
|
def volume_to_attributes(vol)
|
22
22
|
|
23
|
-
format_type = xml_element(vol.xml_desc, "/volume/target/format", "type")
|
23
|
+
format_type = xml_element(vol.xml_desc, "/volume/target/format", "type") rescue nil # not all volumes have types, e.g. LVM
|
24
24
|
return nil if format_type == "dir"
|
25
25
|
|
26
26
|
{
|
@@ -12,6 +12,8 @@ module Fog
|
|
12
12
|
# attribute :content_type, :aliases => 'Content-Type'
|
13
13
|
attribute :last_modified, :aliases => 'Last-Modified'
|
14
14
|
|
15
|
+
require 'uri'
|
16
|
+
|
15
17
|
def body
|
16
18
|
attributes[:body] ||= if last_modified
|
17
19
|
collection.get(identity).body
|
@@ -73,7 +75,16 @@ module Fog
|
|
73
75
|
end
|
74
76
|
|
75
77
|
def public_url
|
76
|
-
|
78
|
+
requires :directory, :key
|
79
|
+
|
80
|
+
if connection.endpoint
|
81
|
+
escaped_directory = URI.escape(directory.key)
|
82
|
+
escaped_key = URI.escape(key)
|
83
|
+
|
84
|
+
::File.join(connection.endpoint, escaped_directory, escaped_key)
|
85
|
+
else
|
86
|
+
nil
|
87
|
+
end
|
77
88
|
end
|
78
89
|
|
79
90
|
def save(options = {})
|
data/lib/fog/local/storage.rb
CHANGED
@@ -6,6 +6,7 @@ module Fog
|
|
6
6
|
class Local < Fog::Service
|
7
7
|
|
8
8
|
requires :local_root
|
9
|
+
recognizes :endpoint, :scheme, :host, :port, :path
|
9
10
|
|
10
11
|
model_path 'fog/local/models/storage'
|
11
12
|
collection :directories
|
@@ -13,8 +14,12 @@ module Fog
|
|
13
14
|
model :file
|
14
15
|
collection :files
|
15
16
|
|
17
|
+
require 'uri'
|
18
|
+
|
16
19
|
class Mock
|
17
20
|
|
21
|
+
attr_reader :endpoint
|
22
|
+
|
18
23
|
def self.data
|
19
24
|
@data ||= Hash.new do |hash, key|
|
20
25
|
hash[key] = {}
|
@@ -30,6 +35,8 @@ module Fog
|
|
30
35
|
|
31
36
|
require 'mime/types'
|
32
37
|
@local_root = ::File.expand_path(options[:local_root])
|
38
|
+
|
39
|
+
@endpoint = options[:endpoint] || build_endpoint_from_options(options)
|
33
40
|
end
|
34
41
|
|
35
42
|
def data
|
@@ -48,13 +55,23 @@ module Fog
|
|
48
55
|
self.class.data.delete(@local_root)
|
49
56
|
end
|
50
57
|
|
58
|
+
private
|
59
|
+
def build_endpoint_from_options(options)
|
60
|
+
return unless options[:host]
|
61
|
+
|
62
|
+
URI::Generic.build(options).to_s
|
63
|
+
end
|
51
64
|
end
|
52
65
|
|
53
66
|
class Real
|
54
67
|
|
68
|
+
attr_reader :endpoint
|
69
|
+
|
55
70
|
def initialize(options={})
|
56
71
|
require 'mime/types'
|
57
72
|
@local_root = ::File.expand_path(options[:local_root])
|
73
|
+
|
74
|
+
@endpoint = options[:endpoint] || build_endpoint_from_options(options)
|
58
75
|
end
|
59
76
|
|
60
77
|
def local_root
|
@@ -69,9 +86,16 @@ module Fog
|
|
69
86
|
require 'fileutils'
|
70
87
|
source_path = path_to(::File.join(source_directory_name, source_object_name))
|
71
88
|
target_path = path_to(::File.join(target_directory_name, target_object_name))
|
72
|
-
::FileUtils.mkdir_p(::File.dirname(
|
89
|
+
::FileUtils.mkdir_p(::File.dirname(target_path))
|
73
90
|
::FileUtils.copy_file(source_path, target_path)
|
74
91
|
end
|
92
|
+
|
93
|
+
private
|
94
|
+
def build_endpoint_from_options(options)
|
95
|
+
return unless options[:host]
|
96
|
+
|
97
|
+
URI::Generic.build(options).to_s
|
98
|
+
end
|
75
99
|
end
|
76
100
|
|
77
101
|
end
|
data/lib/fog/ninefold/compute.rb
CHANGED
data/lib/fog/openstack.rb
CHANGED
@@ -50,6 +50,7 @@ module Fog
|
|
50
50
|
connection = Fog::Connection.new(uri.to_s, false, connection_options)
|
51
51
|
@openstack_api_key = options[:openstack_api_key]
|
52
52
|
@openstack_username = options[:openstack_username]
|
53
|
+
|
53
54
|
response = connection.request({
|
54
55
|
:expects => [200, 204],
|
55
56
|
:headers => {
|
@@ -63,7 +64,8 @@ module Fog
|
|
63
64
|
|
64
65
|
return {
|
65
66
|
:token => response.headers['X-Auth-Token'],
|
66
|
-
:server_management_url => response.headers['X-Server-Management-Url']
|
67
|
+
:server_management_url => response.headers['X-Server-Management-Url'],
|
68
|
+
:identity_public_endpoint => response.headers['X-Keystone']
|
67
69
|
}
|
68
70
|
end
|
69
71
|
|
@@ -176,13 +176,24 @@ module Fog
|
|
176
176
|
'minRam' => 0,
|
177
177
|
'minDisk' => 0,
|
178
178
|
'metadata' => {},
|
179
|
-
'links' => []
|
179
|
+
'links' => [{"href"=>"http://nova1:8774/v1.1/admin/images/1", "rel"=>"self"}, {"href"=>"http://nova1:8774/admin/images/2", "rel"=>"bookmark"}]
|
180
180
|
}
|
181
181
|
},
|
182
182
|
:servers => {},
|
183
183
|
:key_pairs => {},
|
184
184
|
:security_groups => {},
|
185
|
-
:addresses => {}
|
185
|
+
:addresses => {},
|
186
|
+
:quota => {
|
187
|
+
'metadata_items' => 128,
|
188
|
+
'injected_file_content_bytes' => 10240,
|
189
|
+
'injected_files' => 5,
|
190
|
+
'gigabytes' => 1000,
|
191
|
+
'ram' => 51200,
|
192
|
+
'floating_ips' => 10,
|
193
|
+
'instances' => 10,
|
194
|
+
'volumes' => 10,
|
195
|
+
'cores' => 20,
|
196
|
+
}
|
186
197
|
}
|
187
198
|
end
|
188
199
|
end
|
@@ -7,10 +7,18 @@ module Fog
|
|
7
7
|
|
8
8
|
class Servers < Fog::Collection
|
9
9
|
|
10
|
+
attribute :filters
|
11
|
+
|
10
12
|
model Fog::Compute::OpenStack::Server
|
11
13
|
|
12
|
-
def
|
13
|
-
|
14
|
+
def initialize(attributes)
|
15
|
+
self.filters ||= {}
|
16
|
+
super
|
17
|
+
end
|
18
|
+
|
19
|
+
def all(filters = filters)
|
20
|
+
self.filters = filters
|
21
|
+
data = connection.list_servers_detail(filters).body['servers']
|
14
22
|
load(data)
|
15
23
|
end
|
16
24
|
|
@@ -55,7 +55,7 @@ module Fog
|
|
55
55
|
response.body = {
|
56
56
|
"flavor" => {
|
57
57
|
"vcpus" => attributes[:vcpus],
|
58
|
-
"disk" => attributes[:
|
58
|
+
"disk" => attributes[:disk],
|
59
59
|
"name" => attributes[:name],
|
60
60
|
"links" => [
|
61
61
|
{
|
@@ -70,7 +70,7 @@ module Fog
|
|
70
70
|
"rxtx_factor" => attributes[:rxtx_factor] || 1,
|
71
71
|
"OS-FLV-EXT-DATA:ephemeral" => attributes[:ephemeral] || 0,
|
72
72
|
"ram" => attributes[:ram],
|
73
|
-
"id" => 11,
|
73
|
+
"id" => "11",
|
74
74
|
"swap" => attributes[:swap] || ""
|
75
75
|
}
|
76
76
|
}
|
@@ -14,7 +14,7 @@ module Fog
|
|
14
14
|
|
15
15
|
vanilla_options = ['metadata', 'accessIPv4', 'accessIPv6',
|
16
16
|
'availability_zone', 'user_data', 'key_name',
|
17
|
-
'security_groups']
|
17
|
+
'security_groups', 'adminPass']
|
18
18
|
vanilla_options.select{|o| options[o]}.each do |key|
|
19
19
|
data['server'][key] = options[key]
|
20
20
|
end
|
@@ -18,13 +18,13 @@ module Fog
|
|
18
18
|
def get_flavor_details(flavor_ref)
|
19
19
|
response = Excon::Response.new
|
20
20
|
flavor = {
|
21
|
-
'1' => { 'id' => '1', 'name' => '256 server', 'ram' => 256, 'disk' => 10, 'links' => [] },
|
22
|
-
'2' => { 'id' => '2', 'name' => '512 server', 'ram' => 512, 'disk' => 20, 'links' => [] },
|
23
|
-
'3' => { 'id' => '3', 'name' => '1GB server', 'ram' => 1024, 'disk' => 40, 'links' => [] },
|
24
|
-
'4' => { 'id' => '4', 'name' => '2GB server', 'ram' => 2048, 'disk' => 80, 'links' => [] },
|
25
|
-
'5' => { 'id' => '5', 'name' => '4GB server', 'ram' => 4096, 'disk' => 160, 'links' => [] },
|
26
|
-
'6' => { 'id' => '6', 'name' => '8GB server', 'ram' => 8192, 'disk' => 320, 'links' => [] },
|
27
|
-
'7' => { 'id' => '7', 'name' => '15.5GB server', 'ram' => 15872, 'disk' => 620, 'links' => [] }
|
21
|
+
'1' => { 'id' => '1', 'name' => '256 server', 'ram' => 256, 'disk' => 10, 'swap' => '1', 'vcpus' => 1, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
22
|
+
'2' => { 'id' => '2', 'name' => '512 server', 'ram' => 512, 'disk' => 20, 'swap' => '1', 'vcpus' => 2, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
23
|
+
'3' => { 'id' => '3', 'name' => '1GB server', 'ram' => 1024, 'disk' => 40, 'swap' => '2', 'vcpus' => 2, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
24
|
+
'4' => { 'id' => '4', 'name' => '2GB server', 'ram' => 2048, 'disk' => 80, 'swap' => '4', 'vcpus' => 4, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
25
|
+
'5' => { 'id' => '5', 'name' => '4GB server', 'ram' => 4096, 'disk' => 160, 'swap' => '8', 'vcpus' => 8, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
26
|
+
'6' => { 'id' => '6', 'name' => '8GB server', 'ram' => 8192, 'disk' => 320, 'swap' => '16', 'vcpus' => 16, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] },
|
27
|
+
'7' => { 'id' => '7', 'name' => '15.5GB server', 'ram' => 15872, 'disk' => 620, 'swap' => '32', 'vcpus' => 32, 'OS-FLV-EXT-DATA:ephemeral' => 1, 'links' => [] }
|
28
28
|
}[flavor_ref]
|
29
29
|
if flavor
|
30
30
|
response.status = 200
|
@@ -19,18 +19,7 @@ module Fog
|
|
19
19
|
response = Excon::Response.new
|
20
20
|
response.status = 200
|
21
21
|
response.body = {
|
22
|
-
'quota_set' => {
|
23
|
-
'metadata_items' => 128,
|
24
|
-
'injected_file_content_bytes' => 10240,
|
25
|
-
'injected_files' => 5,
|
26
|
-
'gigabytes' => 1000,
|
27
|
-
'ram' => 51200,
|
28
|
-
'floating_ips' => 10,
|
29
|
-
'instances' => 10,
|
30
|
-
'volumes' => 10,
|
31
|
-
'cores' => 20,
|
32
|
-
'id' => tenant_id
|
33
|
-
}
|
22
|
+
'quota_set' => (self.data[:quota_updated] or self.data[:quota]).merge({'id' => tenant_id})
|
34
23
|
}
|
35
24
|
response
|
36
25
|
end
|