fog 1.6.0 → 1.7.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/README.md +1 -0
- data/Rakefile +2 -1
- data/changelog.txt +184 -0
- data/docs/cdn/index.markdown +69 -3
- data/fog.gemspec +2 -2
- data/lib/fog.rb +2 -1
- data/lib/fog/atmos/models/storage/file.rb +16 -14
- data/lib/fog/aws/auto_scaling.rb +55 -13
- data/lib/fog/aws/cdn.rb +69 -9
- data/lib/fog/aws/cloud_watch.rb +15 -1
- data/lib/fog/aws/compute.rb +2 -0
- data/lib/fog/aws/models/auto_scaling/group.rb +10 -4
- data/lib/fog/aws/models/cdn/distribution.rb +93 -0
- data/lib/fog/aws/models/cdn/distribution_helper.rb +64 -0
- data/lib/fog/aws/models/cdn/distributions.rb +32 -0
- data/lib/fog/aws/models/cdn/distributions_helper.rb +47 -0
- data/lib/fog/aws/models/cdn/invalidation.rb +64 -0
- data/lib/fog/aws/models/cdn/invalidations.rb +54 -0
- data/lib/fog/aws/models/cdn/streaming_distribution.rb +77 -0
- data/lib/fog/aws/models/cdn/streaming_distributions.rb +32 -0
- data/lib/fog/aws/models/compute/server.rb +0 -23
- data/lib/fog/aws/models/compute/spot_request.rb +2 -24
- data/lib/fog/aws/models/rds/server.rb +18 -0
- data/lib/fog/aws/models/rds/subnet_group.rb +20 -0
- data/lib/fog/aws/models/rds/subnet_groups.rb +27 -0
- data/lib/fog/aws/models/storage/file.rb +1 -1
- data/lib/fog/aws/parsers/auto_scaling/describe_adjustment_types.rb +15 -2
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_groups.rb +39 -13
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_notification_types.rb +43 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_metric_collection_types.rb +3 -3
- data/lib/fog/aws/parsers/auto_scaling/describe_notification_configurations.rb +42 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_scaling_process_types.rb +15 -2
- data/lib/fog/aws/parsers/auto_scaling/describe_tags.rb +46 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_termination_policy_types.rb +44 -0
- data/lib/fog/aws/parsers/cdn/get_invalidation.rb +32 -0
- data/lib/fog/aws/parsers/cloud_formation/describe_stacks.rb +1 -1
- data/lib/fog/aws/parsers/cloud_watch/list_metrics.rb +1 -1
- data/lib/fog/aws/parsers/compute/describe_availability_zones.rb +13 -2
- data/lib/fog/aws/parsers/compute/describe_reserved_instances.rb +1 -1
- data/lib/fog/aws/parsers/elasticache/base.rb +0 -2
- data/lib/fog/aws/parsers/elasticache/engine_defaults_parser.rb +1 -1
- data/lib/fog/aws/parsers/elasticache/event_list.rb +2 -0
- data/lib/fog/aws/parsers/rds/base.rb +32 -0
- data/lib/fog/aws/parsers/rds/create_db_subnet_group.rb +38 -0
- data/lib/fog/aws/parsers/rds/describe_db_subnet_groups.rb +38 -0
- data/lib/fog/aws/parsers/rds/event_list.rb +40 -0
- data/lib/fog/aws/parsers/rds/subnet_group_parser.rb +38 -0
- data/lib/fog/aws/parsers/rds/tag_list_parser.rb +35 -0
- data/lib/fog/aws/rds.rb +24 -7
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +36 -16
- data/lib/fog/aws/requests/auto_scaling/create_launch_configuration.rb +19 -12
- data/lib/fog/aws/requests/auto_scaling/create_or_update_tags.rb +63 -0
- data/lib/fog/aws/requests/auto_scaling/delete_auto_scaling_group.rb +10 -3
- data/lib/fog/aws/requests/auto_scaling/delete_notification_configuration.rb +21 -5
- data/lib/fog/aws/requests/auto_scaling/delete_policy.rb +2 -2
- data/lib/fog/aws/requests/auto_scaling/delete_tags.rb +63 -0
- data/lib/fog/aws/requests/auto_scaling/describe_adjustment_types.rb +4 -3
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_groups.rb +17 -13
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_instances.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/describe_auto_scaling_notification_types.rb +55 -0
- data/lib/fog/aws/requests/auto_scaling/describe_metric_collection_types.rb +6 -5
- data/lib/fog/aws/requests/auto_scaling/describe_notification_configurations.rb +79 -0
- data/lib/fog/aws/requests/auto_scaling/describe_policies.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/describe_scaling_process_types.rb +4 -3
- data/lib/fog/aws/requests/auto_scaling/describe_tags.rb +74 -0
- data/lib/fog/aws/requests/auto_scaling/describe_termination_policy_types.rb +53 -0
- data/lib/fog/aws/requests/auto_scaling/disable_metrics_collection.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/enable_metrics_collection.rb +2 -2
- data/lib/fog/aws/requests/auto_scaling/put_notification_configuration.rb +30 -11
- data/lib/fog/aws/requests/auto_scaling/put_scaling_policy.rb +4 -4
- data/lib/fog/aws/requests/auto_scaling/put_scheduled_update_group_action.rb +8 -5
- data/lib/fog/aws/requests/auto_scaling/set_desired_capacity.rb +2 -2
- data/lib/fog/aws/requests/auto_scaling/set_instance_health.rb +2 -2
- data/lib/fog/aws/requests/auto_scaling/suspend_processes.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/update_auto_scaling_group.rb +30 -18
- data/lib/fog/aws/requests/cdn/delete_distribution.rb +31 -0
- data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +30 -0
- data/lib/fog/aws/requests/cdn/get_distribution.rb +28 -0
- data/lib/fog/aws/requests/cdn/get_distribution_list.rb +29 -0
- data/lib/fog/aws/requests/cdn/get_invalidation.rb +60 -0
- data/lib/fog/aws/requests/cdn/get_invalidation_list.rb +41 -0
- data/lib/fog/aws/requests/cdn/get_streaming_distribution.rb +26 -0
- data/lib/fog/aws/requests/cdn/get_streaming_distribution_list.rb +30 -0
- data/lib/fog/aws/requests/cdn/post_distribution.rb +44 -0
- data/lib/fog/aws/requests/cdn/post_invalidation.rb +33 -0
- data/lib/fog/aws/requests/cdn/post_streaming_distribution.rb +44 -0
- data/lib/fog/aws/requests/cdn/put_distribution_config.rb +28 -0
- data/lib/fog/aws/requests/cdn/put_streaming_distribution_config.rb +28 -0
- data/lib/fog/aws/requests/compute/create_image.rb +32 -5
- data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
- data/lib/fog/aws/requests/compute/create_volume.rb +2 -2
- data/lib/fog/aws/requests/compute/register_image.rb +1 -1
- data/lib/fog/aws/requests/elasticache/describe_events.rb +7 -4
- data/lib/fog/aws/requests/glacier/create_archive.rb +1 -1
- data/lib/fog/aws/requests/glacier/initiate_multipart_upload.rb +1 -1
- data/lib/fog/aws/requests/rds/add_tags_to_resource.rb +46 -0
- data/lib/fog/aws/requests/rds/create_db_instance.rb +2 -0
- data/lib/fog/aws/requests/rds/create_db_subnet_group.rb +58 -0
- data/lib/fog/aws/requests/rds/describe_db_subnet_groups.rb +63 -0
- data/lib/fog/aws/requests/rds/describe_events.rb +52 -0
- data/lib/fog/aws/requests/rds/list_tags_for_resource.rb +44 -0
- data/lib/fog/aws/requests/rds/remove_tags_from_resource.rb +44 -0
- data/lib/fog/aws/sqs.rb +1 -1
- data/lib/fog/aws/storage.rb +1 -1
- data/lib/fog/bin/openstack.rb +5 -0
- data/lib/fog/bluebox/models/compute/server.rb +0 -19
- data/lib/fog/bluebox/requests/compute/create_block.rb +8 -8
- data/lib/fog/brightbox/compute.rb +56 -7
- data/lib/fog/brightbox/models/compute/accounts.rb +29 -0
- data/lib/fog/brightbox/models/compute/api_client.rb +37 -0
- data/lib/fog/brightbox/models/compute/api_clients.rb +24 -0
- data/lib/fog/brightbox/models/compute/application.rb +27 -0
- data/lib/fog/brightbox/models/compute/applications.rb +28 -0
- data/lib/fog/brightbox/models/compute/server.rb +3 -1
- data/lib/fog/brightbox/models/compute/users.rb +1 -3
- data/lib/fog/brightbox/requests/compute/create_application.rb +13 -0
- data/lib/fog/brightbox/requests/compute/create_cloud_ip.rb +2 -2
- data/lib/fog/brightbox/requests/compute/destroy_application.rb +14 -0
- data/lib/fog/brightbox/requests/compute/get_account.rb +28 -4
- data/lib/fog/brightbox/requests/compute/get_application.rb +14 -0
- data/lib/fog/brightbox/requests/compute/get_authenticated_user.rb +19 -0
- data/lib/fog/brightbox/requests/compute/get_scoped_account.rb +19 -0
- data/lib/fog/brightbox/requests/compute/get_user.rb +28 -5
- data/lib/fog/brightbox/requests/compute/list_accounts.rb +13 -0
- data/lib/fog/brightbox/requests/compute/list_applications.rb +13 -0
- data/lib/fog/brightbox/requests/compute/reset_secret_application.rb +14 -0
- data/lib/fog/brightbox/requests/compute/update_account.rb +51 -3
- data/lib/fog/brightbox/requests/compute/update_application.rb +15 -0
- data/lib/fog/brightbox/requests/compute/update_firewall_rule.rb +4 -2
- data/lib/fog/brightbox/requests/compute/update_scoped_account.rb +37 -0
- data/lib/fog/clodo/models/compute/server.rb +7 -44
- data/lib/fog/compute/models/server.rb +23 -2
- data/lib/fog/core/time.rb +2 -0
- data/lib/fog/core/wait_for.rb +0 -2
- data/lib/fog/ecloud/models/compute/servers.rb +3 -1
- data/lib/fog/ecloud/requests/compute/get_servers.rb +1 -1
- data/lib/fog/ecloud/requests/compute/get_tasks.rb +1 -1
- data/lib/fog/go_grid/models/compute/server.rb +0 -4
- data/lib/fog/google/storage.rb +1 -1
- data/lib/fog/hp/models/compute/server.rb +1 -23
- data/lib/fog/hp/storage.rb +0 -1
- data/lib/fog/joyent/models/compute/server.rb +4 -0
- data/lib/fog/joyent/models/compute/servers.rb +4 -3
- data/lib/fog/libvirt/models/compute/server.rb +1 -27
- data/lib/fog/linode/models/compute/server.rb +0 -1
- data/lib/fog/local/models/storage/directory.rb +1 -1
- data/lib/fog/network.rb +26 -0
- data/lib/fog/ninefold/compute.rb +8 -0
- data/lib/fog/ninefold/requests/compute/assign_to_load_balancer_rule.rb +13 -0
- data/lib/fog/ninefold/requests/compute/create_load_balancer_rule.rb +11 -0
- data/lib/fog/ninefold/requests/compute/delete_load_balancer_rule.rb +11 -0
- data/lib/fog/ninefold/requests/compute/list_load_balancer_rule_instances.rb +15 -0
- data/lib/fog/ninefold/requests/compute/list_load_balancer_rules.rb +14 -0
- data/lib/fog/ninefold/requests/compute/remove_from_load_balancer_rule.rb +12 -0
- data/lib/fog/ninefold/requests/compute/update_load_balancer_rule.rb +15 -0
- data/lib/fog/ninefold/storage.rb +14 -112
- data/lib/fog/openstack.rb +4 -1
- data/lib/fog/openstack/compute.rb +20 -1
- data/lib/fog/openstack/identity.rb +67 -18
- data/lib/fog/openstack/image.rb +12 -4
- data/lib/fog/openstack/models/compute/security_group.rb +1 -1
- data/lib/fog/openstack/models/compute/server.rb +5 -23
- data/lib/fog/openstack/models/identity/tenants.rb +5 -3
- data/lib/fog/openstack/models/identity/users.rb +4 -1
- data/lib/fog/openstack/models/image/image.rb +6 -1
- data/lib/fog/openstack/models/network/network.rb +46 -0
- data/lib/fog/openstack/models/network/networks.rb +34 -0
- data/lib/fog/openstack/models/network/port.rb +52 -0
- data/lib/fog/openstack/models/network/ports.rb +34 -0
- data/lib/fog/openstack/models/network/subnet.rb +55 -0
- data/lib/fog/openstack/models/network/subnets.rb +34 -0
- data/lib/fog/openstack/network.rb +234 -0
- data/lib/fog/openstack/requests/compute/attach_volume.rb +10 -0
- data/lib/fog/openstack/requests/compute/create_security_group.rb +15 -11
- data/lib/fog/openstack/requests/compute/create_security_group_rule.rb +17 -15
- data/lib/fog/openstack/requests/compute/create_server.rb +7 -1
- data/lib/fog/openstack/requests/compute/create_volume.rb +10 -10
- data/lib/fog/openstack/requests/compute/create_volume_snapshot.rb +16 -1
- data/lib/fog/openstack/requests/compute/detach_volume.rb +5 -0
- data/lib/fog/openstack/requests/compute/get_snapshot_details.rb +4 -4
- data/lib/fog/openstack/requests/compute/get_volume_details.rb +9 -9
- data/lib/fog/openstack/requests/compute/list_security_groups.rb +3 -3
- data/lib/fog/openstack/requests/compute/list_volumes.rb +14 -14
- data/lib/fog/openstack/requests/identity/create_tenant.rb +3 -3
- data/lib/fog/openstack/requests/identity/create_user.rb +1 -1
- data/lib/fog/openstack/requests/identity/delete_role.rb +1 -1
- data/lib/fog/openstack/requests/identity/get_tenant.rb +1 -1
- data/lib/fog/openstack/requests/identity/list_roles.rb +7 -0
- data/lib/fog/openstack/requests/image/create_image.rb +36 -38
- data/lib/fog/openstack/requests/image/delete_image.rb +0 -2
- data/lib/fog/openstack/requests/image/list_public_images.rb +7 -25
- data/lib/fog/openstack/requests/image/list_public_images_detailed.rb +2 -41
- data/lib/fog/openstack/requests/image/update_image.rb +26 -21
- data/lib/fog/openstack/requests/image/update_image_members.rb +37 -0
- data/lib/fog/openstack/requests/network/create_network.rb +44 -0
- data/lib/fog/openstack/requests/network/create_port.rb +52 -0
- data/lib/fog/openstack/requests/network/create_subnet.rb +56 -0
- data/lib/fog/openstack/requests/network/delete_network.rb +30 -0
- data/lib/fog/openstack/requests/network/delete_port.rb +30 -0
- data/lib/fog/openstack/requests/network/delete_subnet.rb +30 -0
- data/lib/fog/openstack/requests/network/get_network.rb +42 -0
- data/lib/fog/openstack/requests/network/get_port.rb +48 -0
- data/lib/fog/openstack/requests/network/get_subnet.rb +49 -0
- data/lib/fog/openstack/requests/network/list_networks.rb +27 -0
- data/lib/fog/openstack/requests/network/list_ports.rb +27 -0
- data/lib/fog/openstack/requests/network/list_subnets.rb +27 -0
- data/lib/fog/openstack/requests/network/set_tenant.rb +21 -0
- data/lib/fog/openstack/requests/network/update_network.rb +41 -0
- data/lib/fog/openstack/requests/network/update_port.rb +44 -0
- data/lib/fog/openstack/requests/network/update_subnet.rb +44 -0
- data/lib/fog/openstack/requests/volume/create_volume.rb +10 -10
- data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +16 -1
- data/lib/fog/openstack/requests/volume/get_snapshot_details.rb +6 -6
- data/lib/fog/openstack/requests/volume/get_volume_details.rb +10 -10
- data/lib/fog/openstack/requests/volume/list_volumes.rb +14 -14
- data/lib/fog/openstack/volume.rb +10 -0
- data/lib/fog/rackspace/models/compute/server.rb +1 -24
- data/lib/fog/rackspace/models/compute_v2/server.rb +4 -2
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +1 -1
- data/lib/fog/storm_on_demand/models/compute/server.rb +1 -5
- data/lib/fog/virtual_box/models/compute/server.rb +2 -44
- data/lib/fog/vmfusion/models/compute/server.rb +3 -36
- data/lib/fog/vsphere/models/compute/server.rb +1 -1
- data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +2 -31
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +35 -7
- data/tests/aws/models/cdn/distribution_tests.rb +15 -0
- data/tests/aws/models/cdn/distributions_tests.rb +15 -0
- data/tests/aws/models/cdn/invalidation_tests.rb +32 -0
- data/tests/aws/models/cdn/invalidations_tests.rb +15 -0
- data/tests/aws/models/cdn/streaming_distribution_tests.rb +15 -0
- data/tests/aws/models/cdn/streaming_distributions_tests.rb +15 -0
- data/tests/aws/models/rds/tagging_tests.rb +20 -0
- data/tests/aws/requests/auto_scaling/auto_scaling_tests.rb +1 -11
- data/tests/aws/requests/auto_scaling/describe_types_tests.rb +102 -0
- data/tests/aws/requests/auto_scaling/helper.rb +47 -3
- data/tests/aws/requests/auto_scaling/notification_configuration_tests.rb +123 -0
- data/tests/aws/requests/auto_scaling/tag_tests.rb +62 -0
- data/tests/aws/requests/cdn/cdn_tests.rb +252 -0
- data/tests/aws/requests/compute/image_tests.rb +32 -1
- data/tests/aws/requests/compute/volume_tests.rb +3 -3
- data/tests/aws/requests/rds/describe_events.rb +16 -0
- data/tests/aws/requests/rds/helper.rb +26 -0
- data/tests/aws/requests/rds/subnet_groups_test.rb +48 -0
- data/tests/aws/requests/rds/tagging_tests.rb +78 -0
- data/tests/brightbox/requests/compute/account_tests.rb +24 -4
- data/tests/brightbox/requests/compute/application_test.rb +63 -0
- data/tests/brightbox/requests/compute/helper.rb +49 -1
- data/tests/helper.rb +4 -1
- data/tests/local/models/directory_tests.rb +16 -0
- data/tests/ninefold/requests/compute/helper.rb +53 -0
- data/tests/ninefold/requests/compute/load_balancer_tests.rb +66 -0
- data/tests/openstack/models/image/image_tests.rb +1 -0
- data/tests/openstack/models/network/network_tests.rb +24 -0
- data/tests/openstack/models/network/networks_tests.rb +21 -0
- data/tests/openstack/models/network/port_tests.rb +28 -0
- data/tests/openstack/models/network/ports_tests.rb +25 -0
- data/tests/openstack/models/network/subnet_tests.rb +30 -0
- data/tests/openstack/models/network/subnets_tests.rb +27 -0
- data/tests/openstack/requests/compute/image_tests.rb +3 -4
- data/tests/openstack/requests/compute/quota_tests.rb +2 -0
- data/tests/openstack/requests/compute/security_group_tests.rb +10 -10
- data/tests/openstack/requests/compute/server_tests.rb +3 -1
- data/tests/openstack/requests/compute/volume_tests.rb +11 -12
- data/tests/openstack/requests/identity/tenant_tests.rb +2 -1
- data/tests/openstack/requests/image/image_tests.rb +66 -45
- data/tests/openstack/requests/network/network_tests.rb +56 -0
- data/tests/openstack/requests/network/port_tests.rb +63 -0
- data/tests/openstack/requests/network/subnet_tests.rb +66 -0
- data/tests/rackspace/models/identity/user_tests.rb +1 -1
- data/tests/rackspace/models/identity/users_tests.rb +1 -1
- metadata +137 -13
- data/lib/fog/ninefold/models/storage/directories.rb +0 -48
- data/lib/fog/ninefold/models/storage/directory.rb +0 -53
- data/lib/fog/ninefold/models/storage/file.rb +0 -108
- data/lib/fog/ninefold/models/storage/files.rb +0 -73
- data/lib/fog/ninefold/requests/storage/delete_namespace.rb +0 -19
- data/lib/fog/ninefold/requests/storage/get_namespace.rb +0 -20
- data/lib/fog/ninefold/requests/storage/head_namespace.rb +0 -20
- data/lib/fog/ninefold/requests/storage/post_namespace.rb +0 -20
- data/lib/fog/ninefold/requests/storage/put_namespace.rb +0 -20
@@ -19,49 +19,10 @@ module Fog
|
|
19
19
|
end # class Real
|
20
20
|
|
21
21
|
class Mock
|
22
|
-
def list_public_images_detailed
|
22
|
+
def list_public_images_detailed(attribute=nil, query=nil)
|
23
23
|
response = Excon::Response.new
|
24
24
|
response.status = [200, 204][rand(1)]
|
25
|
-
response.body = {
|
26
|
-
"name"=>"cirros-0.3.0-x86_64-blank",
|
27
|
-
"size"=>25165824,
|
28
|
-
"min_disk"=>0,
|
29
|
-
"disk_format"=>"ami",
|
30
|
-
"created_at"=>"2012-02-21T07:32:26",
|
31
|
-
"container_format"=>"ami",
|
32
|
-
"deleted_at"=>nil,
|
33
|
-
"updated_at"=>"2012-02-21T07:32:29",
|
34
|
-
"checksum"=>"2f81976cae15c16ef0010c51e3a6c163",
|
35
|
-
"id"=>"0e09fbd6-43c5-448a-83e9-0d3d05f9747e",
|
36
|
-
"deleted"=>false,
|
37
|
-
"protected"=>false,
|
38
|
-
"is_public"=>true,
|
39
|
-
"status"=>"active",
|
40
|
-
"min_ram"=>0,
|
41
|
-
"owner"=>"ff528b20431645ebb5fa4b0a71ca002f",
|
42
|
-
"properties"=>{
|
43
|
-
"ramdisk_id"=>"b45aa128-cd36-4ad9-a026-1a1c2bfd8fdc",
|
44
|
-
"kernel_id"=>"cd28951e-e1c2-4bc5-95d3-f0495abbcdc5"}
|
45
|
-
},
|
46
|
-
{"name"=>"new image",
|
47
|
-
"size"=>0,
|
48
|
-
"min_disk"=>0,
|
49
|
-
"disk_format"=>nil,
|
50
|
-
"created_at"=>"2012-02-24T06:45:00",
|
51
|
-
"container_format"=>nil,
|
52
|
-
"deleted_at"=>nil,
|
53
|
-
"updated_at"=>"2012-02-24T06:45:00",
|
54
|
-
"checksum"=>nil,
|
55
|
-
"id"=>"e41304f3-2453-42b4-9829-2e220a737395",
|
56
|
-
"deleted"=>false,
|
57
|
-
"protected"=>false,
|
58
|
-
"is_public"=>false,
|
59
|
-
"status"=>"queued",
|
60
|
-
"min_ram"=>0,
|
61
|
-
"owner"=>"728ecc7c10614a1faa6fbabd1a68a4a0",
|
62
|
-
"properties"=>{}
|
63
|
-
}]
|
64
|
-
}
|
25
|
+
response.body = {'images' => self.data[:images].values}
|
65
26
|
response
|
66
27
|
end # def list_tenants
|
67
28
|
end # class Mock
|
@@ -11,6 +11,9 @@ module Fog
|
|
11
11
|
"x-image-meta-container-format" => attributes[:container_format],
|
12
12
|
"x-image-meta-size" => attributes[:size],
|
13
13
|
"x-image-meta-is-public" => attributes[:is_public],
|
14
|
+
"x-image-meta-min-ram" => attributes[:min_ram],
|
15
|
+
"x-image-meta-min-disk" => attributes[:min_disk],
|
16
|
+
"x-image-meta-checksum" => attributes[:checksum],
|
14
17
|
"x-image-meta-owner" => attributes[:owner]
|
15
18
|
}
|
16
19
|
|
@@ -21,7 +24,7 @@ module Fog
|
|
21
24
|
end
|
22
25
|
|
23
26
|
request(
|
24
|
-
:headers
|
27
|
+
:headers => data,
|
25
28
|
:expects => 200,
|
26
29
|
:method => 'PUT',
|
27
30
|
:path => "images/#{attributes[:id]}"
|
@@ -35,26 +38,28 @@ module Fog
|
|
35
38
|
def update_image(attributes)
|
36
39
|
response = Excon::Response.new
|
37
40
|
response.status = 200
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
41
|
+
image = self.images.last
|
42
|
+
response.body = {
|
43
|
+
'image'=> {
|
44
|
+
'name' => attributes[:name] || image.name,
|
45
|
+
'size' => image.size,
|
46
|
+
'min_disk' => (attributes[:min_disk] || image.min_disk).to_i,
|
47
|
+
'disk_format' => attributes[:disk_format] || image.disk_format,
|
48
|
+
'created_at' => image.created_at,
|
49
|
+
'container_format' => attributes[:container_format] || image.container_format,
|
50
|
+
'deleted_at' => nil,
|
51
|
+
'updated_at' => Time.now.to_s,
|
52
|
+
'checksum' => image.checksum,
|
53
|
+
'id' => attributes[:id],
|
54
|
+
'deleted' => false,
|
55
|
+
'protected' => false,
|
56
|
+
'is_public' => attributes[:is_public] || image.is_public,
|
57
|
+
'status' => image.status,
|
58
|
+
'min_ram' => (attributes[:min_ram] || image.min_ram).to_i,
|
59
|
+
'owner' => attributes[:owner] || image.owner,
|
60
|
+
'properties' => attributes[:properties] || image.properties
|
61
|
+
}
|
62
|
+
}
|
58
63
|
response
|
59
64
|
|
60
65
|
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
module Fog
|
2
|
+
module Image
|
3
|
+
class OpenStack
|
4
|
+
class Real
|
5
|
+
def update_image_members(image_id, members)
|
6
|
+
# Sample members
|
7
|
+
# [
|
8
|
+
# {'member_id' => 'tenant1', 'can_share' => true },
|
9
|
+
# {'member_id' => 'tenant2', 'can_share' => false }
|
10
|
+
# ]
|
11
|
+
data = { 'memberships' => members }
|
12
|
+
|
13
|
+
request(
|
14
|
+
:body => MultiJson.encode(data),
|
15
|
+
:expects => [200, 202],
|
16
|
+
:method => 'PUT',
|
17
|
+
:path => "images/#{image_id}/members"
|
18
|
+
)
|
19
|
+
end
|
20
|
+
end # class Real
|
21
|
+
|
22
|
+
class Mock
|
23
|
+
def update_image_members(image_id, members)
|
24
|
+
response = Excon::Response.new
|
25
|
+
response.status = [200, 202][rand(1)]
|
26
|
+
response.body = {
|
27
|
+
'members' => [
|
28
|
+
{ 'member_id'=>'ff528b20431645ebb5fa4b0a71ca002f', 'can_share' => false },
|
29
|
+
{ 'member_id'=>'ff528b20431645ebb5fa4b0a71ca002f', 'can_share' => true }
|
30
|
+
]
|
31
|
+
}
|
32
|
+
response
|
33
|
+
end
|
34
|
+
end # class Mock
|
35
|
+
end # class OpenStack
|
36
|
+
end # module Identity
|
37
|
+
end # module Fog
|
@@ -0,0 +1,44 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def create_network(options = {})
|
7
|
+
data = { 'network' => {} }
|
8
|
+
|
9
|
+
vanilla_options = [:name, :shared, :admin_state_up, :tenant_id]
|
10
|
+
vanilla_options.reject{ |o| options[o].nil? }.each do |key|
|
11
|
+
data['network'][key] = options[key]
|
12
|
+
end
|
13
|
+
|
14
|
+
request(
|
15
|
+
:body => Fog::JSON.encode(data),
|
16
|
+
:expects => [201],
|
17
|
+
:method => 'POST',
|
18
|
+
:path => 'networks'
|
19
|
+
)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
class Mock
|
24
|
+
def create_network(options = {})
|
25
|
+
response = Excon::Response.new
|
26
|
+
response.status = 201
|
27
|
+
data = {
|
28
|
+
'id' => Fog::Mock.random_numbers(6).to_s,
|
29
|
+
'name' => options[:name],
|
30
|
+
'shared' => options[:shared],
|
31
|
+
'subnets' => [],
|
32
|
+
'status' => 'ACTIVE',
|
33
|
+
'admin_state_up' => options[:admin_state_up],
|
34
|
+
'tenant_id' => options[:tenant_id],
|
35
|
+
}
|
36
|
+
self.data[:networks][data['id']] = data
|
37
|
+
response.body = { 'network' => data }
|
38
|
+
response
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def create_port(network_id, options = {})
|
7
|
+
data = {
|
8
|
+
'port' => {
|
9
|
+
'network_id' => network_id,
|
10
|
+
}
|
11
|
+
}
|
12
|
+
|
13
|
+
vanilla_options = [:name, :fixed_ips, :mac_address, :admin_state_up,
|
14
|
+
:device_owner, :device_id, :tenant_id]
|
15
|
+
vanilla_options.reject{ |o| options[o].nil? }.each do |key|
|
16
|
+
data['port'][key] = options[key]
|
17
|
+
end
|
18
|
+
|
19
|
+
request(
|
20
|
+
:body => Fog::JSON.encode(data),
|
21
|
+
:expects => [201],
|
22
|
+
:method => 'POST',
|
23
|
+
:path => 'ports'
|
24
|
+
)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
class Mock
|
29
|
+
def create_port(network_id, options = {})
|
30
|
+
response = Excon::Response.new
|
31
|
+
response.status = 201
|
32
|
+
data = {
|
33
|
+
'id' => Fog::Mock.random_numbers(6).to_s,
|
34
|
+
'name' => options[:name],
|
35
|
+
'network_id' => network_id,
|
36
|
+
'fixed_ips' => options[:fixed_ips],
|
37
|
+
'mac_address' => options[:mac_address],
|
38
|
+
'status' => 'ACTIVE',
|
39
|
+
'admin_state_up' => options[:admin_state_up],
|
40
|
+
'device_owner' => options[:device_owner],
|
41
|
+
'device_id' => options[:device_id],
|
42
|
+
'tenant_id' => options[:tenant_id],
|
43
|
+
}
|
44
|
+
self.data[:ports][data['id']] = data
|
45
|
+
response.body = { 'port' => data }
|
46
|
+
response
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def create_subnet(network_id, cidr, ip_version, options = {})
|
7
|
+
data = {
|
8
|
+
'subnet' => {
|
9
|
+
'network_id' => network_id,
|
10
|
+
'cidr' => cidr,
|
11
|
+
'ip_version' => ip_version,
|
12
|
+
}
|
13
|
+
}
|
14
|
+
|
15
|
+
vanilla_options = [:name, :gateway_ip, :allocation_pools,
|
16
|
+
:dns_nameservers, :host_routes, :enable_dhcp,
|
17
|
+
:tenant_id]
|
18
|
+
vanilla_options.reject{ |o| options[o].nil? }.each do |key|
|
19
|
+
data['subnet'][key] = options[key]
|
20
|
+
end
|
21
|
+
|
22
|
+
request(
|
23
|
+
:body => Fog::JSON.encode(data),
|
24
|
+
:expects => [201],
|
25
|
+
:method => 'POST',
|
26
|
+
:path => 'subnets'
|
27
|
+
)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
|
31
|
+
class Mock
|
32
|
+
def create_subnet(network_id, cidr, ip_version, options = {})
|
33
|
+
response = Excon::Response.new
|
34
|
+
response.status = 201
|
35
|
+
data = {
|
36
|
+
'id' => Fog::Mock.random_numbers(6).to_s,
|
37
|
+
'name' => options[:name],
|
38
|
+
'network_id' => network_id,
|
39
|
+
'cidr' => cidr,
|
40
|
+
'ip_version' => ip_version,
|
41
|
+
'gateway_ip' => options[:gateway_ip],
|
42
|
+
'allocation_pools' => options[:allocation_pools],
|
43
|
+
'dns_nameservers' => options[:dns_nameservers],
|
44
|
+
'host_routes' => options[:host_routes],
|
45
|
+
'enable_dhcp' => options[:enable_dhcp],
|
46
|
+
'tenant_id' => options[:tenant_id],
|
47
|
+
}
|
48
|
+
self.data[:subnets][data['id']] = data
|
49
|
+
response.body = { 'subnet' => data }
|
50
|
+
response
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def delete_network(network_id)
|
7
|
+
request(
|
8
|
+
:expects => 204,
|
9
|
+
:method => 'DELETE',
|
10
|
+
:path => "networks/#{network_id}"
|
11
|
+
)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class Mock
|
16
|
+
def delete_network(network_id)
|
17
|
+
response = Excon::Response.new
|
18
|
+
if list_networks.body['networks'].map { |r| r['id'] }.include? network_id
|
19
|
+
self.data[:networks].delete(network_id)
|
20
|
+
response.status = 204
|
21
|
+
response
|
22
|
+
else
|
23
|
+
raise Fog::Network::OpenStack::NotFound
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def delete_port(port_id)
|
7
|
+
request(
|
8
|
+
:expects => 204,
|
9
|
+
:method => 'DELETE',
|
10
|
+
:path => "ports/#{port_id}"
|
11
|
+
)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class Mock
|
16
|
+
def delete_port(port_id)
|
17
|
+
response = Excon::Response.new
|
18
|
+
if list_ports.body['ports'].map { |r| r['id'] }.include? port_id
|
19
|
+
self.data[:ports].delete(port_id)
|
20
|
+
response.status = 204
|
21
|
+
response
|
22
|
+
else
|
23
|
+
raise Fog::Network::OpenStack::NotFound
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def delete_subnet(subnet_id)
|
7
|
+
request(
|
8
|
+
:expects => 204,
|
9
|
+
:method => 'DELETE',
|
10
|
+
:path => "subnets/#{subnet_id}"
|
11
|
+
)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class Mock
|
16
|
+
def delete_subnet(subnet_id)
|
17
|
+
response = Excon::Response.new
|
18
|
+
if list_subnets.body['subnets'].map { |r| r['id'] }.include? subnet_id
|
19
|
+
self.data[:subnets].delete(subnet_id)
|
20
|
+
response.status = 204
|
21
|
+
response
|
22
|
+
else
|
23
|
+
raise Fog::Network::OpenStack::NotFound
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,42 @@
|
|
1
|
+
module Fog
|
2
|
+
module Network
|
3
|
+
class OpenStack
|
4
|
+
|
5
|
+
class Real
|
6
|
+
def get_network(network_id)
|
7
|
+
request(
|
8
|
+
:expects => [200],
|
9
|
+
:method => 'GET',
|
10
|
+
:path => "networks/#{network_id}"
|
11
|
+
)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
class Mock
|
16
|
+
def get_network(network_id)
|
17
|
+
response = Excon::Response.new
|
18
|
+
if data = self.data[:networks][network_id]
|
19
|
+
response.status = 200
|
20
|
+
response.body = {
|
21
|
+
'network' => {
|
22
|
+
'id' => 'e624a36d-762b-481f-9b50-4154ceb78bbb',
|
23
|
+
'name' => 'network_1',
|
24
|
+
'subnets' => [
|
25
|
+
'2e4ec6a4-0150-47f5-8523-e899ac03026e'
|
26
|
+
],
|
27
|
+
'shared' => false,
|
28
|
+
'status' => 'ACTIVE',
|
29
|
+
'admin_state_up' => true,
|
30
|
+
'tenant_id' => 'f8b26a6032bc47718a7702233ac708b9',
|
31
|
+
}
|
32
|
+
}
|
33
|
+
response
|
34
|
+
else
|
35
|
+
raise Fog::Network::OpenStack::NotFound
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|