fog-maestrodev 1.14.0.20130806165225 → 1.15.0.20130829165835
Sign up to get free protection for your applications and to get access to all the features.
- data/changelog.txt +296 -0
- data/fog.gemspec +2 -2
- data/lib/fog/atmos/storage.rb +0 -3
- data/lib/fog/aws/cdn.rb +1 -2
- data/lib/fog/aws/compute.rb +52 -2
- data/lib/fog/aws/dns.rb +0 -1
- data/lib/fog/aws/models/auto_scaling/groups.rb +6 -3
- data/lib/fog/aws/models/compute/address.rb +1 -0
- data/lib/fog/aws/models/compute/flavors.rb +19 -0
- data/lib/fog/aws/models/compute/route_table.rb +69 -0
- data/lib/fog/aws/models/compute/route_tables.rb +92 -0
- data/lib/fog/aws/models/rds/instance_option.rb +21 -0
- data/lib/fog/aws/models/rds/instance_options.rb +30 -0
- data/lib/fog/aws/parsers/compute/associate_route_table.rb +20 -0
- data/lib/fog/aws/parsers/compute/create_route_table.rb +75 -0
- data/lib/fog/aws/parsers/compute/describe_account_attributes.rb +42 -0
- data/lib/fog/aws/parsers/compute/describe_route_tables.rb +85 -0
- data/lib/fog/aws/parsers/rds/describe_orderable_db_instance_options.rb +47 -0
- data/lib/fog/aws/rds.rb +5 -0
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_groups.rb +9 -1
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +15 -1
- data/lib/fog/aws/requests/compute/associate_dhcp_options.rb +2 -2
- data/lib/fog/aws/requests/compute/associate_route_table.rb +75 -0
- data/lib/fog/aws/requests/compute/attach_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/create_route.rb +89 -0
- data/lib/fog/aws/requests/compute/create_route_table.rb +70 -0
- data/lib/fog/aws/requests/compute/create_vpc.rb +16 -1
- data/lib/fog/aws/requests/compute/delete_dhcp_options.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_network_interface.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_route.rb +60 -0
- data/lib/fog/aws/requests/compute/delete_route_table.rb +51 -0
- data/lib/fog/aws/requests/compute/delete_subnet.rb +2 -2
- data/lib/fog/aws/requests/compute/delete_vpc.rb +2 -2
- data/lib/fog/aws/requests/compute/describe_account_attributes.rb +49 -0
- data/lib/fog/aws/requests/compute/describe_route_tables.rb +87 -0
- data/lib/fog/aws/requests/compute/detach_internet_gateway.rb +2 -2
- data/lib/fog/aws/requests/compute/detach_network_interface.rb +2 -2
- data/lib/fog/aws/requests/compute/disassociate_route_table.rb +57 -0
- data/lib/fog/aws/requests/compute/reset_network_interface_attribute.rb +2 -1
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +23 -9
- data/lib/fog/aws/requests/iam/upload_server_certificate.rb +1 -1
- data/lib/fog/aws/requests/rds/describe_orderable_db_instance_options.rb +76 -0
- data/lib/fog/aws/storage.rb +0 -2
- data/lib/fog/brightbox/models/compute/collaboration.rb +10 -2
- data/lib/fog/brightbox/models/compute/collaborations.rb +26 -2
- data/lib/fog/brightbox/models/compute/user_collaboration.rb +16 -1
- data/lib/fog/brightbox/models/compute/user_collaborations.rb +10 -2
- data/lib/fog/cloudstack/models/compute/server.rb +4 -0
- data/lib/fog/core/collection.rb +18 -0
- data/lib/fog/core/credentials.rb +6 -1
- data/lib/fog/google/compute.rb +17 -0
- data/lib/fog/google/examples/get_list_images.rb +27 -0
- data/lib/fog/google/examples/get_list_snapshots.rb +20 -0
- data/lib/fog/google/examples/image_create.rb +18 -0
- data/lib/fog/google/examples/launch_micro_instance.rb +10 -5
- data/lib/fog/google/examples/network.rb +21 -0
- data/lib/fog/google/models/compute/disk.rb +16 -5
- data/lib/fog/google/models/compute/image.rb +36 -18
- data/lib/fog/google/models/compute/images.rb +36 -10
- data/lib/fog/google/models/compute/server.rb +41 -11
- data/lib/fog/google/models/compute/servers.rb +1 -1
- data/lib/fog/google/models/compute/snapshot.rb +36 -0
- data/lib/fog/google/models/compute/snapshots.rb +28 -0
- data/lib/fog/google/requests/compute/delete_disk.rb +5 -1
- data/lib/fog/google/requests/compute/get_disk.rb +2 -1
- data/lib/fog/google/requests/compute/get_snapshot.rb +34 -0
- data/lib/fog/google/requests/compute/insert_disk.rb +23 -7
- data/lib/fog/google/requests/compute/insert_image.rb +16 -9
- data/lib/fog/google/requests/compute/insert_server.rb +22 -10
- data/lib/fog/google/requests/compute/list_disks.rb +1 -1
- data/lib/fog/google/requests/compute/list_snapshots.rb +30 -0
- data/lib/fog/google/storage.rb +1 -3
- data/lib/fog/hp/storage.rb +0 -2
- data/lib/fog/internet_archive/storage.rb +0 -2
- data/lib/fog/local/storage.rb +0 -2
- data/lib/fog/ninefold/storage.rb +0 -1
- data/lib/fog/openstack/models/storage/file.rb +2 -0
- data/lib/fog/openstack/requests/compute/add_flavor_access.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_volume.rb +8 -7
- data/lib/fog/openstack/requests/compute/list_tenants_with_flavor_access.rb +1 -1
- data/lib/fog/openstack/requests/compute/remove_flavor_access.rb +1 -1
- data/lib/fog/openstack/requests/image/create_image.rb +23 -23
- data/lib/fog/openstack/requests/image/update_image.rb +31 -33
- data/lib/fog/openstack/requests/storage/get_object_https_url.rb +3 -3
- data/lib/fog/openstack/requests/storage/post_set_meta_temp_url_key.rb +1 -1
- data/lib/fog/openstack/storage.rb +10 -11
- data/lib/fog/openstack.rb +10 -1
- data/lib/fog/rackspace/cdn.rb +13 -0
- data/lib/fog/rackspace/compute.rb +8 -4
- data/lib/fog/rackspace/compute_v2.rb +2 -0
- data/lib/fog/rackspace/databases.rb +4 -4
- data/lib/fog/rackspace/dns.rb +6 -6
- data/lib/fog/rackspace/examples/compute_v2/bootstrap_server.rb +98 -0
- data/lib/fog/rackspace/load_balancers.rb +5 -4
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +1 -2
- data/lib/fog/rackspace/models/compute_v2/images.rb +35 -3
- data/lib/fog/rackspace/models/compute_v2/metadatum.rb +2 -2
- data/lib/fog/rackspace/models/identity/service_catalog.rb +34 -16
- data/lib/fog/rackspace/models/load_balancers/load_balancer.rb +8 -3
- data/lib/fog/rackspace/models/monitoring/alarm.rb +16 -8
- data/lib/fog/rackspace/models/monitoring/base.rb +2 -8
- data/lib/fog/rackspace/monitoring.rb +14 -6
- data/lib/fog/rackspace/requests/compute_v2/list_flavors_detail.rb +39 -0
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +15 -5
- data/lib/fog/rackspace/requests/compute_v2/list_images_detail.rb +53 -0
- data/lib/fog/rackspace/requests/identity/create_token.rb +1 -1
- data/lib/fog/rackspace/requests/load_balancers/create_load_balancer.rb +12 -0
- data/lib/fog/rackspace/requests/load_balancers/get_stats.rb +31 -0
- data/lib/fog/rackspace/requests/monitoring/get_entity.rb +33 -0
- data/lib/fog/rackspace/service.rb +7 -0
- data/lib/fog/rackspace/storage.rb +6 -3
- data/lib/fog/rackspace.rb +8 -5
- data/lib/fog/riakcs/provisioning.rb +0 -1
- data/lib/fog/riakcs/usage.rb +2 -3
- data/lib/fog/storage.rb +2 -0
- data/lib/fog/vcloud/examples/README.md +54 -0
- data/lib/fog/vcloud/examples/creating_a_connection.md +20 -0
- data/lib/fog/vcloud/examples/creating_a_vapp.md +17 -0
- data/lib/fog/vcloud/examples/get_network_information.md +10 -0
- data/lib/fog/vcloud/examples/get_vapp_information.md +10 -0
- data/lib/fog/vcloud/examples/more_on_vapps.md +23 -0
- data/lib/fog/version.rb +1 -1
- data/lib/tasks/changelog_task.rb +1 -0
- data/tests/aws/models/elb/model_tests.rb +5 -0
- data/tests/aws/models/rds/instance_option_tests.rb +14 -0
- data/tests/aws/requests/compute/client_tests.rb +25 -0
- data/tests/aws/requests/compute/route_tests.rb +277 -0
- data/tests/aws/requests/rds/helper.rb +22 -0
- data/tests/aws/requests/rds/instance_option_tests.rb +21 -0
- data/tests/core/credential_tests.rb +21 -0
- data/tests/core/service_tests.rb +26 -0
- data/tests/openstack/authenticate_tests.rb +22 -0
- data/tests/openstack/models/storage/file_tests.rb +20 -1
- data/tests/openstack/requests/compute/flavor_tests.rb +27 -12
- data/tests/openstack/requests/compute/volume_tests.rb +10 -12
- data/tests/openstack/requests/image/image_tests.rb +30 -15
- data/tests/rackspace/block_storage_tests.rb +9 -4
- data/tests/rackspace/cdn_tests.rb +14 -0
- data/tests/rackspace/compute_tests.rb +10 -4
- data/tests/rackspace/compute_v2_tests.rb +9 -4
- data/tests/rackspace/databases_tests.rb +9 -4
- data/tests/rackspace/dns_tests.rb +9 -4
- data/tests/rackspace/helper.rb +21 -2
- data/tests/rackspace/identity_tests.rb +9 -4
- data/tests/rackspace/load_balancer_tests.rb +8 -4
- data/tests/rackspace/models/compute_v2/server_tests.rb +18 -21
- data/tests/rackspace/models/identity/service_catalog_tests.rb +54 -29
- data/tests/rackspace/models/load_balancers/load_balancer_tests.rb +5 -0
- data/tests/rackspace/models/monitoring/alarm_examples_tests.rb +1 -1
- data/tests/rackspace/models/monitoring/alarm_tests.rb +2 -2
- data/tests/rackspace/monitoring_tests.rb +9 -4
- data/tests/rackspace/requests/compute_v2/flavor_tests.rb +6 -0
- data/tests/rackspace/requests/compute_v2/image_tests.rb +4 -0
- data/tests/rackspace/requests/compute_v2/server_tests.rb +2 -2
- data/tests/rackspace/requests/load_balancers/get_stats_tests.rb +13 -0
- data/tests/rackspace/requests/load_balancers/helper.rb +9 -0
- data/tests/rackspace/requests/monitoring/alarm_tests.rb +4 -5
- data/tests/rackspace/requests/monitoring/entity_tests.rb +9 -1
- data/tests/rackspace/requests/storage/large_object_tests.rb +12 -4
- data/tests/rackspace/storage_tests.rb +23 -4
- data/tests/rackspace/url_encoding_tests.rb +3 -1
- metadata +117 -133
- checksums.yaml +0 -15
- data/lib/fog/aws/parsers/compute/associate_dhcp_options.rb +0 -24
- data/lib/fog/aws/parsers/compute/attach_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_dhcp_options.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_network_interface.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_subnet.rb +0 -24
- data/lib/fog/aws/parsers/compute/delete_vpc.rb +0 -24
- data/lib/fog/aws/parsers/compute/detach_internet_gateway.rb +0 -24
- data/lib/fog/aws/parsers/compute/detach_network_interface.rb +0 -24
@@ -0,0 +1,76 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class RDS
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/aws/parsers/rds/describe_orderable_db_instance_options'
|
7
|
+
|
8
|
+
# Describe all or specified load db instances
|
9
|
+
# http://docs.amazonwebservices.com/AmazonRDS/latest/APIReference/API_DescribeDBInstances.html
|
10
|
+
# ==== Parameters
|
11
|
+
# * Engine <~String> - The name of the engine to retrieve DB Instance options for. Required.
|
12
|
+
# * Options <~Hash> - Hash of options. Optional. The following keys are used:
|
13
|
+
# * :db_instance_class <~String> - Filter available offerings matching the specified DB Instance class. Optional.
|
14
|
+
# * :engine_version <~String> - Filters available offerings matching the specified engine version. Optional.
|
15
|
+
# * :license_model <~String> - Filters available offerings matching the specified license model. Optional.
|
16
|
+
# * :marker <~String> - The pagination token provided in the previous request. If this parameter is specified the response includes only records beyond the marker, up to MaxRecords. Optional.
|
17
|
+
# * :max_records <~Integer> - The maximum number of records to include in the response. If more records exist, a pagination token is included in the response. Optional.
|
18
|
+
# * :vpc <~Boolean> - Filter to show only the available VPC or non-VPC offerings. Optional.
|
19
|
+
# ==== Returns
|
20
|
+
# * response<~Excon::Response>:
|
21
|
+
# * body<~Hash>:
|
22
|
+
def describe_orderable_db_instance_options(engine=nil, opts={})
|
23
|
+
params = {}
|
24
|
+
params['Engine'] = engine if engine
|
25
|
+
params['DBInstanceClass'] = opts[:db_instance_class] if opts[:db_instance_class]
|
26
|
+
params['EngineVersion'] = opts[:engine_version] if opts[:engine_version]
|
27
|
+
params['LicenseModel'] = opts[:license_model] if opts[:license_model]
|
28
|
+
params['Marker'] = opts[:marker] if opts[:marker]
|
29
|
+
params['MaxRecords'] = opts[:max_records] if opts[:max_records]
|
30
|
+
params['Vpc'] = opts[:vpc] if opts[:vpc]
|
31
|
+
|
32
|
+
request({
|
33
|
+
'Action' => 'DescribeOrderableDBInstanceOptions',
|
34
|
+
:parser => Fog::Parsers::AWS::RDS::DescribeOrderableDBInstanceOptions.new
|
35
|
+
}.merge(params))
|
36
|
+
end
|
37
|
+
|
38
|
+
end
|
39
|
+
|
40
|
+
class Mock
|
41
|
+
|
42
|
+
def describe_orderable_db_instance_options(engine=nil, opts={})
|
43
|
+
instance_options = []
|
44
|
+
response = Excon::Response.new
|
45
|
+
if engine
|
46
|
+
(opts[:db_instance_class] || %w(db.m2.xlarge db.m1.large)).each do |size|
|
47
|
+
instance_options << {'MultiAZCapable' => true,
|
48
|
+
'Engine' => engine,
|
49
|
+
'LicenseModel' => opts[:license_model] || 'general-public-license',
|
50
|
+
'ReadReplicaCapable' => true,
|
51
|
+
'EngineVersion' => opts[:engine_version] || '5.6.12',
|
52
|
+
'AvailabilityZones' => [
|
53
|
+
{'Name' => 'us-east-1b', 'ProvisionedIopsCapable' => true},
|
54
|
+
{'Name' => 'us-east-1c', 'ProvisionedIopsCapable' => true},
|
55
|
+
{'Name' => 'us-east-1d', 'ProvisionedIopsCapable' => false},
|
56
|
+
{'Name' => 'us-east-1e', 'ProvisionedIopsCapable' => true}],
|
57
|
+
'DBInstanceClass' => size,
|
58
|
+
'Vpc' => opts[:vpc].nil? ? true : opts[:vpc]}
|
59
|
+
|
60
|
+
end
|
61
|
+
else
|
62
|
+
raise Fog::AWS::RDS::NotFound.new('An engine must be specified to retrieve orderable instance options')
|
63
|
+
end
|
64
|
+
|
65
|
+
response.status = 200
|
66
|
+
response.body = {
|
67
|
+
'ResponseMetadata' => { 'RequestId' => Fog::AWS::Mock.request_id },
|
68
|
+
'DescribeOrderableDBInstanceOptionsResult' => { 'OrderableDBInstanceOptions' => instance_options }
|
69
|
+
}
|
70
|
+
response
|
71
|
+
end
|
72
|
+
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|
data/lib/fog/aws/storage.rb
CHANGED
@@ -335,7 +335,6 @@ module Fog
|
|
335
335
|
end
|
336
336
|
|
337
337
|
def initialize(options={})
|
338
|
-
require 'mime/types'
|
339
338
|
@use_iam_profile = options[:use_iam_profile]
|
340
339
|
setup_credentials(options)
|
341
340
|
@region = options[:region] || DEFAULT_REGION
|
@@ -387,7 +386,6 @@ module Fog
|
|
387
386
|
# * S3 object with connection to aws.
|
388
387
|
def initialize(options={})
|
389
388
|
require 'fog/core/parser'
|
390
|
-
require 'mime/types'
|
391
389
|
|
392
390
|
@use_iam_profile = options[:use_iam_profile]
|
393
391
|
setup_credentials(options)
|
@@ -25,14 +25,22 @@ module Fog
|
|
25
25
|
:email => email
|
26
26
|
}.delete_if { |k, v| v.nil? || v == "" }
|
27
27
|
|
28
|
-
data =
|
28
|
+
data = service.create_collaboration(options)
|
29
|
+
merge_attributes(data)
|
30
|
+
true
|
31
|
+
end
|
32
|
+
|
33
|
+
def resend
|
34
|
+
requires :identity
|
35
|
+
data = service.resend_collaboration(identity)
|
29
36
|
merge_attributes(data)
|
30
37
|
true
|
31
38
|
end
|
32
39
|
|
33
40
|
def destroy
|
34
41
|
requires :identity
|
35
|
-
|
42
|
+
data = service.destroy_collaboration(identity)
|
43
|
+
merge_attributes(data)
|
36
44
|
true
|
37
45
|
end
|
38
46
|
|
@@ -8,13 +8,37 @@ module Fog
|
|
8
8
|
model Fog::Compute::Brightbox::Collaboration
|
9
9
|
|
10
10
|
def all
|
11
|
-
data =
|
11
|
+
data = service.list_collaborations
|
12
12
|
load(data)
|
13
13
|
end
|
14
14
|
|
15
|
+
def get(identifier)
|
16
|
+
return nil if identifier.nil? || identifier == ""
|
17
|
+
data = service.get_collaboration(identifier)
|
18
|
+
new(data)
|
19
|
+
rescue Excon::Errors::NotFound
|
20
|
+
nil
|
21
|
+
end
|
22
|
+
|
23
|
+
# Invites a user (via an email) to collaborate on the currently scoped
|
24
|
+
# account at the +role+ level.
|
25
|
+
#
|
26
|
+
# @param [String] email The email address to use for the invitation
|
27
|
+
# @param [String] role The role being granted. Only (+admin+ is
|
28
|
+
# currently supported
|
29
|
+
# @return [Fog::Compute::Brightbox::Collaboration]
|
30
|
+
#
|
31
|
+
def invite(email, role)
|
32
|
+
return nil if email.nil? || email == ""
|
33
|
+
return nil if role.nil? || role == ""
|
34
|
+
options = {:email => email, :role => role}
|
35
|
+
data = service.create_collaboration(options)
|
36
|
+
new(data)
|
37
|
+
end
|
38
|
+
|
15
39
|
def destroy
|
16
40
|
requires :identity
|
17
|
-
|
41
|
+
service.destroy_collaboration(identity)
|
18
42
|
true
|
19
43
|
end
|
20
44
|
end
|
@@ -17,9 +17,24 @@ module Fog
|
|
17
17
|
account['id'] || account[:id]
|
18
18
|
end
|
19
19
|
|
20
|
+
def accept
|
21
|
+
requires :identity
|
22
|
+
data = service.accept_user_collaboration(identity)
|
23
|
+
merge_attributes(data)
|
24
|
+
true
|
25
|
+
end
|
26
|
+
|
27
|
+
def reject
|
28
|
+
requires :identity
|
29
|
+
data = service.reject_user_collaboration(identity)
|
30
|
+
merge_attributes(data)
|
31
|
+
true
|
32
|
+
end
|
33
|
+
|
20
34
|
def destroy
|
21
35
|
requires :identity
|
22
|
-
|
36
|
+
data = service.destroy_user_collaboration(identity)
|
37
|
+
merge_attributes(data)
|
23
38
|
true
|
24
39
|
end
|
25
40
|
|
@@ -8,13 +8,21 @@ module Fog
|
|
8
8
|
model Fog::Compute::Brightbox::UserCollaboration
|
9
9
|
|
10
10
|
def all
|
11
|
-
data =
|
11
|
+
data = service.list_user_collaborations
|
12
12
|
load(data)
|
13
13
|
end
|
14
14
|
|
15
|
+
def get(identifier)
|
16
|
+
return nil if identifier.nil? || identifier == ""
|
17
|
+
data = service.get_user_collaboration(identifier)
|
18
|
+
new(data)
|
19
|
+
rescue Excon::Errors::NotFound
|
20
|
+
nil
|
21
|
+
end
|
22
|
+
|
15
23
|
def destroy
|
16
24
|
requires :identity
|
17
|
-
|
25
|
+
service.destroy_user_collaboration(identity)
|
18
26
|
true
|
19
27
|
end
|
20
28
|
end
|
@@ -34,6 +34,8 @@ module Fog
|
|
34
34
|
attribute :root_device_id, :aliases => 'rootdeviceid'
|
35
35
|
attribute :root_device_type, :aliases => 'rootdevicetype'
|
36
36
|
attribute :group
|
37
|
+
attribute :key_name, :aliases => 'keypair'
|
38
|
+
attribute :user_data, :aliases => 'userdata'
|
37
39
|
attribute :security_group_list, :type => :array, :aliases => 'securitygroup'
|
38
40
|
attribute :nics, :type => :array, :aliases => 'nic'
|
39
41
|
|
@@ -92,6 +94,8 @@ module Fog
|
|
92
94
|
'ipaddress' => ip_address,
|
93
95
|
'iptonetworklist' => ip_to_network_list,
|
94
96
|
'projectid' => project_id,
|
97
|
+
'keypair' => key_name,
|
98
|
+
'userdata' => user_data,
|
95
99
|
}
|
96
100
|
|
97
101
|
options.merge!('networkids' => network_ids) if network_ids
|
data/lib/fog/core/collection.rb
CHANGED
@@ -142,4 +142,22 @@ module Fog
|
|
142
142
|
end
|
143
143
|
|
144
144
|
end
|
145
|
+
|
146
|
+
# Base class for collection classes whose 'all' method returns only a single page of results and passes the
|
147
|
+
# 'Marker' option along as self.filters[:marker]
|
148
|
+
class PagedCollection < Collection
|
149
|
+
|
150
|
+
def each(filters=filters)
|
151
|
+
if block_given?
|
152
|
+
begin
|
153
|
+
page = self.all(filters)
|
154
|
+
# We need to explicitly use the base 'each' method here on the page, otherwise we get infinite recursion
|
155
|
+
base_each = Fog::Collection.instance_method(:each)
|
156
|
+
base_each.bind(page).call { |item| yield item }
|
157
|
+
end while self.filters[:marker]
|
158
|
+
end
|
159
|
+
self
|
160
|
+
end
|
161
|
+
|
162
|
+
end
|
145
163
|
end
|
data/lib/fog/core/credentials.rb
CHANGED
@@ -50,11 +50,16 @@ module Fog
|
|
50
50
|
@credentials = new_credentials
|
51
51
|
end
|
52
52
|
|
53
|
+
def self.symbolize_credential?(key)
|
54
|
+
![:headers].include?(key)
|
55
|
+
end
|
56
|
+
|
53
57
|
def self.symbolize_credentials(args)
|
54
58
|
if args.is_a? Hash
|
55
59
|
copy = Array.new
|
56
60
|
args.each do |key, value|
|
57
|
-
|
61
|
+
obj = symbolize_credential?(key) ? self.symbolize_credentials(value) : value
|
62
|
+
copy.push(key.to_sym, obj)
|
58
63
|
end
|
59
64
|
Hash[*copy]
|
60
65
|
else
|
data/lib/fog/google/compute.rb
CHANGED
@@ -19,6 +19,7 @@ module Fog
|
|
19
19
|
request :list_zones
|
20
20
|
request :list_global_operations
|
21
21
|
request :list_zone_operations
|
22
|
+
request :list_snapshots
|
22
23
|
|
23
24
|
request :get_server
|
24
25
|
request :get_disk
|
@@ -27,6 +28,7 @@ module Fog
|
|
27
28
|
request :get_machine_type
|
28
29
|
request :get_network
|
29
30
|
request :get_zone
|
31
|
+
request :get_snapshot
|
30
32
|
|
31
33
|
request :delete_disk
|
32
34
|
request :delete_firewall
|
@@ -56,6 +58,9 @@ module Fog
|
|
56
58
|
model :disk
|
57
59
|
collection :disks
|
58
60
|
|
61
|
+
model :snapshot
|
62
|
+
collection :snapshots
|
63
|
+
|
59
64
|
class Mock
|
60
65
|
include Collections
|
61
66
|
|
@@ -107,6 +112,18 @@ module Fog
|
|
107
112
|
@default_network = 'default'
|
108
113
|
end
|
109
114
|
|
115
|
+
# TODO: Total hack, create zone and zones model.
|
116
|
+
def zones
|
117
|
+
zones = []
|
118
|
+
self.list_zones.data[:body]["items"].each do |z|
|
119
|
+
if z["status"] == "UP"
|
120
|
+
zones.push z["name"]
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
return zones
|
125
|
+
end
|
126
|
+
|
110
127
|
def build_result(api_method, parameters, body_object=nil)
|
111
128
|
if body_object
|
112
129
|
result = @client.execute(
|
@@ -0,0 +1,27 @@
|
|
1
|
+
def test
|
2
|
+
connection = Fog::Compute.new({ :provider => "Google" })
|
3
|
+
|
4
|
+
# puts 'Listing images in all projects...'
|
5
|
+
# puts '---------------------------------'
|
6
|
+
images = connection.images.all
|
7
|
+
raise 'Could not LIST the images' unless images
|
8
|
+
# puts images.inspect
|
9
|
+
|
10
|
+
# puts 'Fetching a single image from a global project...'
|
11
|
+
# puts '------------------------------------------------'
|
12
|
+
img = connection.images.get('debian-6-squeeze-v20130515')
|
13
|
+
raise 'Could not GET the image' unless img
|
14
|
+
# puts img.inspect
|
15
|
+
|
16
|
+
# First, get the name of an image that is in the users 'project' (not global)
|
17
|
+
custom_img_name = images.detect { |img| img.project == img.service.project }
|
18
|
+
# Run the next test only if there is a custom image available
|
19
|
+
if custom_img_name
|
20
|
+
# puts 'Fetching a single image from the custom project'
|
21
|
+
# puts '----------------------------------------------'
|
22
|
+
img = connection.images.get(custom_img_name)
|
23
|
+
raise 'Could not GET the (custom) image' unless img
|
24
|
+
# puts img.inspect
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
def test
|
2
|
+
|
3
|
+
connection = Fog::Compute.new({ :provider => "Google" })
|
4
|
+
|
5
|
+
# puts 'Listing snapshots...'
|
6
|
+
# puts '---------------------------------'
|
7
|
+
snapshots = connection.snapshots.all
|
8
|
+
raise 'Could not LIST the snapshots' unless snapshots
|
9
|
+
# puts snapshots.inspect
|
10
|
+
|
11
|
+
# puts 'Fetching a single snapshot...'
|
12
|
+
# puts '------------------------------------------------'
|
13
|
+
snap = snapshots.first
|
14
|
+
if !snap.nil?
|
15
|
+
snap = connection.snapshots.get(snap)
|
16
|
+
raise 'Could not GET the snapshot' unless snap
|
17
|
+
# puts snap.inspect
|
18
|
+
end
|
19
|
+
|
20
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
def test
|
2
|
+
connection = Fog::Compute.new({ :provider => "Google" })
|
3
|
+
|
4
|
+
rawdisk = {
|
5
|
+
:source => nil, # 'http://some_valid_url_to_rootfs_tarball'
|
6
|
+
:container_type => 'TAR',
|
7
|
+
}
|
8
|
+
|
9
|
+
# Can't test this unless the 'source' points to a valid URL
|
10
|
+
return if rawdisk[:source].nil?
|
11
|
+
|
12
|
+
img = connection.image.create(:name => 'test-image',
|
13
|
+
:preferred_kernel => 'gce-v20130603',
|
14
|
+
:description => 'Test image (via fog)',
|
15
|
+
:raw_disk => rawdisk)
|
16
|
+
|
17
|
+
img.reload # will raise if image was not saved correctly
|
18
|
+
end
|
@@ -1,16 +1,21 @@
|
|
1
1
|
def test
|
2
2
|
connection = Fog::Compute.new({ :provider => "Google" })
|
3
3
|
time = Time.now.utc.to_i
|
4
|
-
disk = connection.disks.create({
|
4
|
+
disk = connection.disks.create({
|
5
|
+
:name => 'foggydisk',
|
6
|
+
:size_gb => 10,
|
7
|
+
:zone_name => 'us-central1-a',
|
8
|
+
:source_image => 'centos-6-v20130522',
|
9
|
+
})
|
5
10
|
|
6
11
|
disk.wait_for { disk.ready? }
|
7
12
|
params = {
|
8
13
|
:name => "fog-smoke-test-#{Time.now.to_i}",
|
9
14
|
:machine_type => "f1-micro",
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
15
|
+
:zone_name => "us-central1-a",
|
16
|
+
:disks => [ disk.get_as_boot_disk(true) ],
|
17
|
+
:user => ENV['USER'],
|
18
|
+
:kernel => 'gce-v20130522',
|
14
19
|
}
|
15
20
|
|
16
21
|
server = connection.servers.bootstrap params
|
@@ -0,0 +1,21 @@
|
|
1
|
+
def test
|
2
|
+
connection = Fog::Compute.new({ :provider => "Google" })
|
3
|
+
|
4
|
+
# we create a new private network
|
5
|
+
connection.insert_network('my-private-network', '10.240.0.0/16')
|
6
|
+
|
7
|
+
server = connection.servers.create({
|
8
|
+
:name => "fog-smoke-test-#{Time.now.to_i}",
|
9
|
+
:image_name => "debian-7-wheezy-v20130522",
|
10
|
+
:machine_type => "n1-standard-1",
|
11
|
+
:zone_name => "us-central1-a",
|
12
|
+
:private_key_path => File.expand_path("~/.ssh/id_rsa"),
|
13
|
+
:public_key_path => File.expand_path("~/.ssh/id_rsa.pub"),
|
14
|
+
:network => 'my-private-network',
|
15
|
+
:external_ip => false,
|
16
|
+
:user => ENV['USER'],
|
17
|
+
})
|
18
|
+
|
19
|
+
# The network won't have any firewall rules, so we won't be able to ssh in.
|
20
|
+
server.wait_for { ready? }
|
21
|
+
end
|
@@ -16,17 +16,28 @@ module Fog
|
|
16
16
|
attribute :description, :aliases => 'description'
|
17
17
|
attribute :size_gb, :aliases => 'sizeGb'
|
18
18
|
attribute :self_link, :aliases => 'selfLink'
|
19
|
-
attribute :
|
19
|
+
attribute :source_image, :aliases => 'sourceImage'
|
20
|
+
attribute :source_snapshot, :aliases => 'sourceSnapshot'
|
21
|
+
attribute :source_snapshot_id, :aliases => 'sourceSnapshot'
|
20
22
|
|
21
23
|
def save
|
22
|
-
|
24
|
+
requires :name
|
25
|
+
requires :zone_name
|
26
|
+
|
27
|
+
options = {}
|
28
|
+
if source_image.nil?
|
29
|
+
options['sourceSnapshot'] = source_snapshot
|
30
|
+
options['sizeGb'] = size_gb
|
31
|
+
end
|
32
|
+
|
33
|
+
data = service.insert_disk(name, zone_name, source_image, options).body
|
23
34
|
data = service.backoff_if_unfound {service.get_disk(name, zone_name).body}
|
24
35
|
service.disks.merge_attributes(data)
|
25
36
|
end
|
26
37
|
|
27
38
|
def destroy
|
28
|
-
requires :name, :
|
29
|
-
service.delete_disk(name,
|
39
|
+
requires :name, :zone_name
|
40
|
+
service.delete_disk(name, zone_name)
|
30
41
|
end
|
31
42
|
|
32
43
|
def zone
|
@@ -77,4 +88,4 @@ module Fog
|
|
77
88
|
end
|
78
89
|
end
|
79
90
|
end
|
80
|
-
end
|
91
|
+
end
|
@@ -12,28 +12,28 @@ module Fog
|
|
12
12
|
attribute :creation_timestamp, :aliases => 'creationTimestamp'
|
13
13
|
attribute :description
|
14
14
|
attribute :preferred_kernel, :aliases => 'preferredKernel'
|
15
|
+
|
16
|
+
# This attribute is not available in the representation of an
|
17
|
+
# 'image' returned by the GCE servser (see GCE API). However,
|
18
|
+
# images are a global resource and a user can query for images
|
19
|
+
# across projects. Therefore we try to remember which project
|
20
|
+
# the image belongs to by tracking it in this attribute.
|
15
21
|
attribute :project
|
16
22
|
|
17
|
-
|
18
|
-
|
23
|
+
# A RawDisk, e.g. -
|
24
|
+
# {
|
25
|
+
# :source => url_to_gcs_file,
|
26
|
+
# :container_type => 'TAR',
|
27
|
+
# :sha1Checksum => ,
|
28
|
+
# }
|
29
|
+
attribute :raw_disk
|
19
30
|
|
20
|
-
|
31
|
+
attribute :status
|
21
32
|
|
22
|
-
|
23
|
-
|
24
|
-
self.service.project,
|
25
|
-
'google',
|
26
|
-
'debian-cloud',
|
27
|
-
'centos-cloud',
|
28
|
-
].each do |owner|
|
29
|
-
begin
|
30
|
-
data = service.get_image(name, owner).body
|
31
|
-
data[:project] = owner
|
32
|
-
rescue
|
33
|
-
end
|
34
|
-
end
|
33
|
+
def reload
|
34
|
+
requires :name
|
35
35
|
|
36
|
-
|
36
|
+
data = service.get_image(name, self.project).body
|
37
37
|
|
38
38
|
self.merge_attributes(data)
|
39
39
|
self
|
@@ -41,8 +41,26 @@ module Fog
|
|
41
41
|
|
42
42
|
def save
|
43
43
|
requires :name
|
44
|
+
requires :preferred_kernel
|
45
|
+
requires :raw_disk
|
46
|
+
|
47
|
+
options = {
|
48
|
+
'preferredKernel' => preferred_kernel,
|
49
|
+
'rawDisk' => raw_disk,
|
50
|
+
'description' => description,
|
51
|
+
}
|
52
|
+
|
53
|
+
service.insert_image(name, options)
|
54
|
+
|
55
|
+
data = service.backoff_if_unfound {
|
56
|
+
service.get_image(self.name).body
|
57
|
+
}
|
58
|
+
|
59
|
+
# Track the name of the project in which we insert the image
|
60
|
+
data.merge!('project' => service.project)
|
61
|
+
self.project = self.service.project
|
44
62
|
|
45
|
-
|
63
|
+
service.images.merge_attributes(data)
|
46
64
|
end
|
47
65
|
|
48
66
|
def resource_url
|
@@ -9,27 +9,53 @@ module Fog
|
|
9
9
|
|
10
10
|
model Fog::Compute::Google::Image
|
11
11
|
|
12
|
+
GLOBAL_PROJECTS = [ 'google',
|
13
|
+
'debian-cloud',
|
14
|
+
'centos-cloud',
|
15
|
+
]
|
16
|
+
|
12
17
|
def all
|
13
18
|
data = []
|
14
|
-
[ self.service.project
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
19
|
+
all_projects = GLOBAL_PROJECTS + [ self.service.project ]
|
20
|
+
|
21
|
+
all_projects.each do |project|
|
22
|
+
images = service.list_images(project).body["items"] || []
|
23
|
+
|
24
|
+
# Keep track of the project in which we found the image(s)
|
25
|
+
images.each { |img| img[:project] = project }
|
26
|
+
data += images
|
20
27
|
end
|
28
|
+
|
21
29
|
load(data)
|
22
30
|
end
|
23
31
|
|
24
32
|
def get(identity)
|
25
|
-
|
33
|
+
# Search own project before global projects
|
34
|
+
all_projects = [ self.service.project ] + GLOBAL_PROJECTS
|
35
|
+
|
36
|
+
data = nil
|
37
|
+
all_projects.each do |project|
|
38
|
+
begin
|
39
|
+
data = service.get_image(identity, project).body
|
40
|
+
data[:project] = project
|
41
|
+
rescue Fog::Errors::Error
|
42
|
+
next
|
43
|
+
else
|
44
|
+
break
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
# If it wasn't found in any project, raise
|
49
|
+
if data.nil?
|
50
|
+
raise Fog::Errors::Error.new('Unable to find the specified image '\
|
51
|
+
'in the following projects: '\
|
52
|
+
"#{all_projects.join(', ')}")
|
53
|
+
end
|
54
|
+
|
26
55
|
new(data)
|
27
|
-
rescue Excon::Errors::NotFound
|
28
|
-
nil
|
29
56
|
end
|
30
57
|
|
31
58
|
end
|
32
|
-
|
33
59
|
end
|
34
60
|
end
|
35
61
|
end
|