gapinc-fog 1.12.1.2.1 → 1.14.0
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +1 -0
- data/.travis.yml +16 -1
- data/Gemfile.1.8.7 +10 -0
- data/README.md +23 -2
- data/Rakefile +2 -2
- data/changelog.txt +276 -0
- data/fog.gemspec +4 -6
- data/lib/fog/atmos/models/storage/file.rb +2 -2
- data/lib/fog/aws/elb.rb +3 -0
- data/lib/fog/aws/elb/policy_types.rb +441 -430
- data/lib/fog/aws/models/auto_scaling/activities.rb +11 -3
- data/lib/fog/aws/models/auto_scaling/groups.rb +6 -3
- data/lib/fog/aws/models/auto_scaling/policies.rb +7 -3
- data/lib/fog/aws/models/compute/volume.rb +1 -1
- data/lib/fog/aws/models/elb/backend_server_description.rb +11 -0
- data/lib/fog/aws/models/elb/backend_server_descriptions.rb +22 -0
- data/lib/fog/aws/models/elb/load_balancer.rb +15 -2
- data/lib/fog/aws/models/elb/policies.rb +28 -13
- data/lib/fog/aws/models/elb/policy.rb +20 -10
- 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/models/rds/log_file.rb +26 -0
- data/lib/fog/aws/models/rds/log_files.rb +50 -0
- data/lib/fog/aws/models/rds/server.rb +1 -0
- data/lib/fog/aws/models/rds/snapshots.rb +20 -13
- data/lib/fog/aws/parsers/auto_scaling/describe_policies.rb +5 -5
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +44 -13
- data/lib/fog/aws/parsers/rds/db_parser.rb +28 -6
- data/lib/fog/aws/parsers/rds/describe_db_log_files.rb +44 -0
- data/lib/fog/aws/parsers/rds/describe_orderable_db_instance_options.rb +47 -0
- data/lib/fog/aws/parsers/rds/download_db_logfile_portion.rb +26 -0
- data/lib/fog/aws/parsers/storage/complete_multipart_upload.rb +1 -1
- data/lib/fog/aws/parsers/sts/assume_role.rb +30 -0
- data/lib/fog/aws/rds.rb +13 -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/elb/create_app_cookie_stickiness_policy.rb +0 -2
- data/lib/fog/aws/requests/elb/create_lb_cookie_stickiness_policy.rb +0 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +7 -0
- data/lib/fog/aws/requests/elb/create_load_balancer_policy.rb +11 -8
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +21 -1
- data/lib/fog/aws/requests/elb/set_load_balancer_policies_for_backend_server.rb +67 -0
- data/lib/fog/aws/requests/rds/describe_db_log_files.rb +67 -0
- data/lib/fog/aws/requests/rds/describe_orderable_db_instance_options.rb +76 -0
- data/lib/fog/aws/requests/rds/download_db_logfile_portion.rb +63 -0
- data/lib/fog/aws/requests/ses/send_raw_email.rb +1 -1
- data/lib/fog/aws/requests/ses/verify_domain_identity.rb +1 -1
- data/lib/fog/aws/requests/storage/complete_multipart_upload.rb +6 -2
- data/lib/fog/aws/requests/storage/get_object.rb +1 -1
- data/lib/fog/aws/requests/sts/assume_role.rb +46 -0
- data/lib/fog/aws/ses.rb +25 -9
- data/lib/fog/aws/sts.rb +22 -6
- data/lib/fog/bin/openstack.rb +5 -0
- data/lib/fog/bin/rackspace.rb +4 -0
- 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/servers.rb +1 -1
- data/lib/fog/compute/models/server.rb +16 -10
- data/lib/fog/core.rb +1 -0
- data/lib/fog/core/collection.rb +18 -0
- data/lib/fog/core/mock.rb +16 -0
- data/lib/fog/digitalocean/compute.rb +32 -3
- data/lib/fog/digitalocean/models/compute/server.rb +43 -14
- data/lib/fog/digitalocean/models/compute/servers.rb +27 -4
- data/lib/fog/digitalocean/models/compute/ssh_keys.rb +2 -3
- data/lib/fog/digitalocean/requests/compute/create_server.rb +9 -7
- data/lib/fog/digitalocean/requests/compute/destroy_server.rb +3 -0
- data/lib/fog/digitalocean/requests/compute/list_images.rb +6 -6
- data/lib/fog/dnsimple/dns.rb +4 -1
- data/lib/fog/dnsimple/models/dns/record.rb +3 -3
- data/lib/fog/dnsimple/requests/dns/create_domain.rb +36 -0
- data/lib/fog/dnsimple/requests/dns/create_record.rb +27 -0
- data/lib/fog/dnsimple/requests/dns/delete_domain.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/delete_record.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/get_domain.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/get_record.rb +24 -0
- data/lib/fog/dnsimple/requests/dns/list_domains.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/list_records.rb +12 -0
- data/lib/fog/dnsimple/requests/dns/update_record.rb +20 -0
- data/lib/fog/glesys/models/compute/server.rb +6 -0
- data/lib/fog/google/README.md +28 -0
- data/lib/fog/google/Rakefile +17 -0
- data/lib/fog/google/examples/bootstrap.rb +9 -0
- data/lib/fog/google/examples/create.rb +37 -0
- data/lib/fog/google/examples/eric-fail.rb +19 -0
- data/lib/fog/google/examples/get_list_images.rb +27 -0
- data/lib/fog/google/examples/launch_micro_instance.rb +21 -0
- data/lib/fog/google/examples/metadata.rb +18 -0
- data/lib/fog/google/models/compute/disks.rb +16 -6
- data/lib/fog/google/models/compute/flavors.rb +2 -1
- data/lib/fog/google/models/compute/image.rb +16 -17
- data/lib/fog/google/models/compute/images.rb +38 -5
- data/lib/fog/google/models/compute/server.rb +2 -2
- data/lib/fog/google/models/compute/servers.rb +8 -5
- data/lib/fog/google/models/storage/file.rb +7 -1
- data/lib/fog/google/parsers/storage/access_control_list.rb +2 -2
- data/lib/fog/google/requests/compute/insert_server.rb +1 -2
- data/lib/fog/google/requests/compute/list_images.rb +3 -2
- data/lib/fog/google/requests/storage/get_object.rb +1 -1
- data/lib/fog/hp/requests/storage/get_object.rb +1 -1
- data/lib/fog/ibm/requests/compute/create_instance.rb +20 -15
- data/lib/fog/internet_archive/requests/storage/get_object.rb +1 -1
- data/lib/fog/metering.rb +25 -0
- data/lib/fog/openstack.rb +2 -1
- data/lib/fog/openstack/metering.rb +215 -0
- data/lib/fog/openstack/models/compute/server.rb +5 -2
- data/lib/fog/openstack/models/metering/resource.rb +24 -0
- data/lib/fog/openstack/models/metering/resources.rb +25 -0
- data/lib/fog/openstack/models/volume/volume.rb +3 -1
- data/lib/fog/openstack/models/volume/volumes.rb +2 -1
- data/lib/fog/openstack/network.rb +24 -1
- data/lib/fog/openstack/requests/compute/create_server.rb +19 -1
- data/lib/fog/openstack/requests/compute/get_host_details.rb +2 -1
- data/lib/fog/openstack/requests/metering/get_resource.rb +32 -0
- data/lib/fog/openstack/requests/metering/get_samples.rb +55 -0
- data/lib/fog/openstack/requests/metering/get_statistics.rb +56 -0
- data/lib/fog/openstack/requests/metering/list_meters.rb +50 -0
- data/lib/fog/openstack/requests/metering/list_resources.rb +32 -0
- data/lib/fog/openstack/requests/network/delete_quota.rb +26 -0
- data/lib/fog/openstack/requests/network/get_quota.rb +31 -0
- data/lib/fog/openstack/requests/network/get_quotas.rb +31 -0
- data/lib/fog/openstack/requests/network/update_quota.rb +33 -0
- data/lib/fog/openstack/requests/storage/put_object.rb +8 -5
- data/lib/fog/openstack/requests/volume/create_volume.rb +4 -2
- data/lib/fog/rackspace.rb +24 -4
- data/lib/fog/rackspace/block_storage.rb +8 -4
- data/lib/fog/rackspace/cdn.rb +21 -4
- data/lib/fog/rackspace/compute_v2.rb +15 -4
- data/lib/fog/rackspace/errors.rb +12 -5
- data/lib/fog/rackspace/mock_data.rb +18 -7
- data/lib/fog/rackspace/models/compute_v2/key_pair.rb +56 -0
- data/lib/fog/rackspace/models/compute_v2/key_pairs.rb +43 -0
- data/lib/fog/rackspace/models/compute_v2/server.rb +7 -2
- data/lib/fog/rackspace/models/compute_v2/servers.rb +2 -1
- data/lib/fog/rackspace/models/identity/service_catalog.rb +34 -16
- data/lib/fog/rackspace/models/monitoring/agent_token.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/agent_tokens.rb +28 -0
- data/lib/fog/rackspace/models/monitoring/alarm.rb +51 -0
- data/lib/fog/rackspace/models/monitoring/alarm_example.rb +26 -0
- data/lib/fog/rackspace/models/monitoring/alarm_examples.rb +31 -0
- data/lib/fog/rackspace/models/monitoring/alarms.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/base.rb +36 -0
- data/lib/fog/rackspace/models/monitoring/check.rb +75 -0
- data/lib/fog/rackspace/models/monitoring/check_type.rb +15 -0
- data/lib/fog/rackspace/models/monitoring/check_types.rb +23 -0
- data/lib/fog/rackspace/models/monitoring/checks.rb +40 -0
- data/lib/fog/rackspace/models/monitoring/data_point.rb +18 -0
- data/lib/fog/rackspace/models/monitoring/data_points.rb +49 -0
- data/lib/fog/rackspace/models/monitoring/entities.rb +48 -0
- data/lib/fog/rackspace/models/monitoring/entity.rb +64 -0
- data/lib/fog/rackspace/models/monitoring/metric.rb +25 -0
- data/lib/fog/rackspace/models/monitoring/metrics.rb +27 -0
- data/lib/fog/rackspace/monitoring.rb +149 -0
- data/lib/fog/rackspace/requests/compute_v2/create_keypair.rb +53 -0
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +10 -8
- data/lib/fog/rackspace/requests/compute_v2/delete_keypair.rb +36 -0
- data/lib/fog/rackspace/requests/compute_v2/get_keypair.rb +41 -0
- data/lib/fog/rackspace/requests/compute_v2/list_keypairs.rb +37 -0
- data/lib/fog/rackspace/requests/monitoring/create_agent_token.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_alarm.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_check.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/create_entity.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/delete_agent_token.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/delete_alarm.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/delete_check.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/delete_entity.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/evaluate_alarm_example.rb +21 -0
- data/lib/fog/rackspace/requests/monitoring/get_agent_token.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_alarm.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_alarm_example.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_check.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/get_entity.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_agent_tokens.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_alarm_examples.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_alarms.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_check_types.rb +17 -0
- data/lib/fog/rackspace/requests/monitoring/list_checks.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_data_points.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_entities.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/list_metrics.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_notification_plans.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/list_overview.rb +19 -0
- data/lib/fog/rackspace/requests/monitoring/update_alarm.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/update_check.rb +18 -0
- data/lib/fog/rackspace/requests/monitoring/update_entity.rb +18 -0
- data/lib/fog/rackspace/requests/storage/delete_multiple_objects.rb +75 -0
- data/lib/fog/rackspace/requests/storage/delete_static_large_object.rb +50 -0
- data/lib/fog/rackspace/requests/storage/put_dynamic_obj_manifest.rb +44 -0
- data/lib/fog/rackspace/requests/storage/put_object.rb +1 -1
- data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +3 -30
- data/lib/fog/rackspace/requests/storage/put_static_obj_manifest.rb +60 -0
- data/lib/fog/rackspace/storage.rb +24 -16
- data/lib/fog/riakcs/provisioning.rb +2 -1
- data/lib/fog/riakcs/usage.rb +2 -1
- data/lib/fog/vcloud/compute.rb +1 -1
- data/lib/fog/vcloud/requests/compute/configure_vm.rb +2 -2
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +131 -0
- data/lib/fog/vsphere/models/compute/server.rb +5 -1
- data/lib/fog/vsphere/requests/compute/get_datacenter.rb +3 -1
- data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +20 -38
- data/lib/fog/vsphere/requests/compute/list_datacenters.rb +1 -0
- data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +8 -114
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +18 -9
- data/lib/fog/vsphere/requests/compute/vm_power_off.rb +2 -0
- data/lib/fog/xenserver/compute.rb +14 -12
- data/lib/fog/xenserver/models/compute/console.rb +27 -0
- data/lib/fog/xenserver/models/compute/consoles.rb +25 -0
- data/lib/fog/xenserver/models/compute/server.rb +6 -2
- data/lib/fog/xenserver/models/compute/servers.rb +5 -0
- data/lib/fog/xenserver/requests/compute/create_server.rb +4 -0
- data/lib/fog/xml/sax_parser_connection.rb +3 -0
- data/lib/tasks/changelog_task.rb +2 -0
- data/tests/aws/models/compute/volume_tests.rb +1 -1
- data/tests/aws/models/elb/model_tests.rb +28 -1
- data/tests/aws/models/rds/instance_option_tests.rb +14 -0
- data/tests/aws/parsers/elb/describe_load_balancers.rb +65 -0
- data/tests/aws/requests/elb/helper.rb +2 -1
- data/tests/aws/requests/elb/listener_tests.rb +1 -1
- data/tests/aws/requests/elb/load_balancer_tests.rb +5 -1
- data/tests/aws/requests/elb/policy_tests.rb +85 -6
- data/tests/aws/requests/iam/helper.rb +4 -1
- data/tests/aws/requests/iam/server_certificate_tests.rb +2 -2
- data/tests/aws/requests/rds/helper.rb +35 -0
- data/tests/aws/requests/rds/instance_option_tests.rb +21 -0
- data/tests/aws/requests/rds/log_file_tests.rb +19 -0
- data/tests/aws/requests/sts/assume_role_tests.rb +19 -0
- data/tests/core/mocking_tests.rb +15 -0
- data/tests/digitalocean/helper.rb +23 -16
- data/tests/digitalocean/models/compute/flavor_tests.rb +2 -2
- data/tests/digitalocean/models/compute/image_tests.rb +2 -2
- data/tests/digitalocean/models/compute/region_tests.rb +2 -2
- data/tests/digitalocean/models/compute/server_tests.rb +11 -3
- data/tests/digitalocean/models/compute/servers_tests.rb +14 -28
- data/tests/digitalocean/models/compute/ssh_key_tests.rb +7 -3
- data/tests/digitalocean/models/compute/ssh_keys_tests.rb +5 -1
- data/tests/digitalocean/requests/compute/create_server_tests.rb +3 -6
- data/tests/digitalocean/requests/compute/destroy_server_tests.rb +1 -2
- data/tests/digitalocean/requests/compute/get_server_details_tests.rb +1 -1
- data/tests/digitalocean/requests/compute/get_ssh_key_tests.rb +4 -1
- data/tests/digitalocean/requests/compute/list_ssh_keys_tests.rb +5 -2
- data/tests/dnsimple/requests/dns/dns_tests.rb +30 -26
- data/tests/helper.rb +2 -2
- data/tests/helpers/collection_helper.rb +4 -4
- data/tests/helpers/mock_helper.rb +2 -0
- data/tests/openstack/requests/metering/meter_tests.rb +52 -0
- data/tests/openstack/requests/metering/resource_tests.rb +19 -0
- data/tests/openstack/requests/network/quota_tests.rb +65 -0
- data/tests/openstack/requests/storage/object_tests.rb +27 -2
- data/tests/rackspace/block_storage_tests.rb +2 -1
- data/tests/rackspace/cdn_tests.rb +9 -0
- data/tests/rackspace/compute_v2_tests.rb +16 -15
- data/tests/rackspace/databases_tests.rb +1 -1
- data/tests/rackspace/load_balancer_tests.rb +1 -1
- data/tests/rackspace/models/compute_v2/keypairs_tests.rb +47 -0
- data/tests/rackspace/models/identity/service_catalog_tests.rb +54 -29
- data/tests/rackspace/models/monitoring/agent_token_tests.rb +9 -0
- data/tests/rackspace/models/monitoring/agent_tokens_tests.rb +9 -0
- data/tests/rackspace/models/monitoring/alarm_example_tests.rb +18 -0
- data/tests/rackspace/models/monitoring/alarm_examples_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/alarm_tests.rb +56 -0
- data/tests/rackspace/models/monitoring/alarms_tests.rb +25 -0
- data/tests/rackspace/models/monitoring/check_tests.rb +50 -0
- data/tests/rackspace/models/monitoring/check_types_tests.rb +14 -0
- data/tests/rackspace/models/monitoring/checks_tests.rb +16 -0
- data/tests/rackspace/models/monitoring/data_points_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/entities_tests.rb +14 -0
- data/tests/rackspace/models/monitoring/entity_tests.rb +26 -0
- data/tests/rackspace/models/monitoring/metric_tests.rb +19 -0
- data/tests/rackspace/models/monitoring/metrics_tests.rb +17 -0
- data/tests/rackspace/monitoring_tests.rb +72 -0
- data/tests/rackspace/requests/compute_v2/keypair_tests.rb +55 -0
- data/tests/rackspace/requests/monitoring/agent_tests.rb +34 -0
- data/tests/rackspace/requests/monitoring/alarm_example_tests.rb +30 -0
- data/tests/rackspace/requests/monitoring/alarm_tests.rb +56 -0
- data/tests/rackspace/requests/monitoring/check_tests.rb +40 -0
- data/tests/rackspace/requests/monitoring/entity_tests.rb +37 -0
- data/tests/rackspace/requests/monitoring/helper.rb +78 -0
- data/tests/rackspace/requests/monitoring/list_tests.rb +60 -0
- data/tests/rackspace/requests/storage/large_object_tests.rb +303 -59
- data/tests/rackspace/requests/storage/object_tests.rb +73 -18
- data/tests/vsphere/models/compute/server_tests.rb +1 -1
- data/tests/vsphere/requests/compute/list_virtual_machines_tests.rb +2 -2
- data/tests/vsphere/requests/compute/vm_clone_tests.rb +14 -8
- data/tests/xenserver/compute_tests.rb +5 -5
- data/tests/xenserver/models/compute/console_test.rb +35 -0
- data/tests/xenserver/models/compute/consoles_test.rb +19 -0
- data/tests/xenserver/models/compute/server_tests.rb +25 -18
- data/tests/xenserver/models/compute/servers_tests.rb +1 -0
- metadata +177 -14
@@ -35,8 +35,6 @@ module Fog
|
|
35
35
|
response = Excon::Response.new
|
36
36
|
response.status = 200
|
37
37
|
|
38
|
-
load_balancer['Policies']['AppCookieStickinessPolicies'] << { 'CookieName' => cookie_name, 'PolicyName' => policy_name }
|
39
|
-
|
40
38
|
create_load_balancer_policy(lb_name, policy_name, 'AppCookieStickinessPolicyType', {'CookieName' => cookie_name})
|
41
39
|
|
42
40
|
response.body = {
|
@@ -37,8 +37,6 @@ module Fog
|
|
37
37
|
response = Excon::Response.new
|
38
38
|
response.status = 200
|
39
39
|
|
40
|
-
load_balancer['Policies']['LBCookieStickinessPolicies'] << { 'CookieExpirationPeriod' => cookie_expiration_period, 'PolicyName' => policy_name }
|
41
|
-
|
42
40
|
create_load_balancer_policy(lb_name, policy_name, 'LBCookieStickinessPolicyType', {'CookieExpirationPeriod' => cookie_expiration_period})
|
43
41
|
|
44
42
|
response.body = {
|
@@ -74,6 +74,7 @@ module Fog
|
|
74
74
|
|
75
75
|
dns_name = Fog::AWS::ELB::Mock.dns_name(lb_name, @region)
|
76
76
|
|
77
|
+
|
77
78
|
Fog::Compute::AWS::Mock.data[@region][@aws_access_key_id][:security_groups]['amazon-elb-sg'] ||= {
|
78
79
|
'groupDescription' => 'amazon-elb-sg',
|
79
80
|
'groupName' => 'amazon-elb-sg',
|
@@ -85,6 +86,11 @@ module Fog
|
|
85
86
|
|
86
87
|
self.data[:load_balancers][lb_name] = {
|
87
88
|
'AvailabilityZones' => availability_zones,
|
89
|
+
'BackendServerDescriptions' => [],
|
90
|
+
# Hack to facilitate not updating the local data structure
|
91
|
+
# (BackendServerDescriptions) until we do a subsequent
|
92
|
+
# describe as that is how AWS behaves.
|
93
|
+
'BackendServerDescriptionsRemote' => [],
|
88
94
|
'Subnets' => options[:subnet_ids] || [],
|
89
95
|
'Scheme' => options[:scheme].nil? ? 'internet-facing' : options[:scheme],
|
90
96
|
'SecurityGroups' => options[:security_groups].nil? ? [] : options[:security_groups],
|
@@ -105,6 +111,7 @@ module Fog
|
|
105
111
|
'Policies' => {
|
106
112
|
'AppCookieStickinessPolicies' => [],
|
107
113
|
'LBCookieStickinessPolicies' => [],
|
114
|
+
'OtherPolicies' => [],
|
108
115
|
'Proper' => []
|
109
116
|
},
|
110
117
|
'SourceSecurityGroup' => {
|
@@ -33,12 +33,12 @@ module Fog
|
|
33
33
|
params.merge!(Fog::AWS.indexed_param('PolicyAttributes.member.%d.AttributeValue', attribute_value))
|
34
34
|
|
35
35
|
request({
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
36
|
+
'Action' => 'CreateLoadBalancerPolicy',
|
37
|
+
'LoadBalancerName' => lb_name,
|
38
|
+
'PolicyName' => name,
|
39
|
+
'PolicyTypeName' => type_name,
|
40
|
+
:parser => Fog::Parsers::AWS::ELB::Empty.new
|
41
|
+
}.merge!(params))
|
42
42
|
end
|
43
43
|
|
44
44
|
end
|
@@ -46,12 +46,15 @@ module Fog
|
|
46
46
|
class Mock
|
47
47
|
def create_load_balancer_policy(lb_name, name, type_name, attributes = {})
|
48
48
|
if load_balancer = self.data[:load_balancers][lb_name]
|
49
|
-
raise Fog::AWS::
|
50
|
-
raise Fog::AWS::
|
49
|
+
raise Fog::AWS::ELB::DuplicatePolicyName, name if policy = load_balancer['Policies']['Proper'].find { |p| p['PolicyName'] == name }
|
50
|
+
raise Fog::AWS::ELB::PolicyTypeNotFound, type_name unless policy_type = self.data[:policy_types].find { |pt| pt['PolicyTypeName'] == type_name }
|
51
51
|
|
52
52
|
response = Excon::Response.new
|
53
53
|
|
54
54
|
attributes = attributes.map do |key, value|
|
55
|
+
if key == "CookieExpirationPeriod" && !value
|
56
|
+
value = 0
|
57
|
+
end
|
55
58
|
{"AttributeName" => key, "AttributeValue" => value.to_s}
|
56
59
|
end
|
57
60
|
|
@@ -20,6 +20,9 @@ module Fog
|
|
20
20
|
# * 'DescribeLoadBalancersResult'<~Hash>:
|
21
21
|
# * 'LoadBalancerDescriptions'<~Array>
|
22
22
|
# * 'AvailabilityZones'<~Array> - list of availability zones covered by this load balancer
|
23
|
+
# * 'BackendServerDescriptions'<~Array>:
|
24
|
+
# * 'InstancePort'<~Integer> - the port on which the back-end server is listening
|
25
|
+
# * 'PolicyNames'<~Array> - list of policy names enabled for the back-end server
|
23
26
|
# * 'CanonicalHostedZoneName'<~String> - name of the Route 53 hosted zone associated with the load balancer
|
24
27
|
# * 'CanonicalHostedZoneNameID'<~String> - ID of the Route 53 hosted zone associated with the load balancer
|
25
28
|
# * 'CreatedTime'<~Time> - time load balancer was created
|
@@ -41,6 +44,7 @@ module Fog
|
|
41
44
|
# * 'Policies'<~Hash>:
|
42
45
|
# * 'LBCookieStickinessPolicies'<~Array> - list of Load Balancer Generated Cookie Stickiness policies for the LoadBalancer
|
43
46
|
# * 'AppCookieStickinessPolicies'<~Array> - list of Application Generated Cookie Stickiness policies for the LoadBalancer
|
47
|
+
# * 'OtherPolicies'<~Array> - list of policy names other than the stickiness policies
|
44
48
|
# * 'SourceSecurityGroup'<~Hash>:
|
45
49
|
# * 'GroupName'<~String> - Name of the source security group to use with inbound security group rules
|
46
50
|
# * 'OwnerAlias'<~String> - Owner of the source security group
|
@@ -101,7 +105,23 @@ module Fog
|
|
101
105
|
'DescribeLoadBalancersResult' => {
|
102
106
|
'LoadBalancerDescriptions' => load_balancers.map do |lb|
|
103
107
|
lb['Instances'] = lb['Instances'].map { |i| i['InstanceId'] }
|
104
|
-
lb['Policies'] = lb['Policies'].
|
108
|
+
lb['Policies'] = lb['Policies']['Proper'].inject({'AppCookieStickinessPolicies' => [], 'LBCookieStickinessPolicies' => [], 'OtherPolicies' => []}) { |m, policy|
|
109
|
+
case policy['PolicyTypeName']
|
110
|
+
when 'AppCookieStickinessPolicyType'
|
111
|
+
cookie_name = policy['PolicyAttributeDescriptions'].detect{|h| h['AttributeName'] == 'CookieName'}['AttributeValue']
|
112
|
+
m['AppCookieStickinessPolicies'] << { 'PolicyName' => policy['PolicyName'], 'CookieName' => cookie_name }
|
113
|
+
when 'LBCookieStickinessPolicyType'
|
114
|
+
cookie_expiration_period = policy['PolicyAttributeDescriptions'].detect{|h| h['AttributeName'] == 'CookieExpirationPeriod'}['AttributeValue'].to_i
|
115
|
+
lb_policy = { 'PolicyName' => policy['PolicyName'] }
|
116
|
+
lb_policy['CookieExpirationPeriod'] = cookie_expiration_period if cookie_expiration_period > 0
|
117
|
+
m['LBCookieStickinessPolicies'] << lb_policy
|
118
|
+
else
|
119
|
+
m['OtherPolicies'] << policy['PolicyName']
|
120
|
+
end
|
121
|
+
m
|
122
|
+
}
|
123
|
+
|
124
|
+
lb['BackendServerDescriptions'] = lb.delete('BackendServerDescriptionsRemote')
|
105
125
|
lb
|
106
126
|
end
|
107
127
|
}
|
@@ -0,0 +1,67 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class ELB
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/aws/parsers/elb/empty'
|
7
|
+
|
8
|
+
# Replaces the current set of policies associated with a port on which the back-end server is listening with a new set of policies.
|
9
|
+
# After the policies have been created using CreateLoadBalancerPolicy, they can be applied here as a list.
|
10
|
+
#
|
11
|
+
# ==== Parameters
|
12
|
+
# * lb_name<~String> - Name of the ELB
|
13
|
+
# * instance_port<~Integer> - The port on the instance that the ELB will forward traffic to
|
14
|
+
# * policy_names<~Array> - Array of Strings listing the policies to set for the backend port
|
15
|
+
# ==== Returns
|
16
|
+
# * response<~Excon::Response>:
|
17
|
+
# * body<~Hash>:
|
18
|
+
# * 'ResponseMetadata'<~Hash>:
|
19
|
+
# * 'RequestId'<~String> - Id of request
|
20
|
+
def set_load_balancer_policies_for_backend_server(lb_name, instance_port, policy_names)
|
21
|
+
params = {'InstancePort' => instance_port}
|
22
|
+
if policy_names.any?
|
23
|
+
params.merge!(Fog::AWS.indexed_param('PolicyNames.member', policy_names))
|
24
|
+
else
|
25
|
+
params['PolicyNames'] = ''
|
26
|
+
end
|
27
|
+
|
28
|
+
request({ 'Action' => 'SetLoadBalancerPoliciesForBackendServer',
|
29
|
+
'LoadBalancerName' => lb_name,
|
30
|
+
:parser => Fog::Parsers::AWS::ELB::Empty.new
|
31
|
+
}.merge!(params))
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
class Mock
|
36
|
+
def set_load_balancer_policies_for_backend_server(lb_name, instance_port, policy_names)
|
37
|
+
if load_balancer = self.data[:load_balancers][lb_name]
|
38
|
+
# Ensure policies exist
|
39
|
+
policy_names.each do |policy_name|
|
40
|
+
unless load_balancer['Policies']['Proper'].find { |p| p['PolicyName'] == policy_name }
|
41
|
+
raise Fog::AWS::ELB::PolicyNotFound, "There is no policy with name #{policy_name} for load balancer #{lb_name}"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
# Update backend policies:
|
46
|
+
description = load_balancer['BackendServerDescriptionsRemote'].find{|d| d["InstancePort"] == instance_port } || {}
|
47
|
+
description["InstancePort"] = instance_port
|
48
|
+
description["PolicyNames"] = policy_names
|
49
|
+
load_balancer['BackendServerDescriptionsRemote'].delete_if{|d| d["InstancePort"] == instance_port }
|
50
|
+
load_balancer['BackendServerDescriptionsRemote'] << description
|
51
|
+
|
52
|
+
Excon::Response.new.tap do |response|
|
53
|
+
response.status = 200
|
54
|
+
response.body = {
|
55
|
+
'ResponseMetadata' => {
|
56
|
+
'RequestId' => Fog::AWS::Mock.request_id
|
57
|
+
}
|
58
|
+
}
|
59
|
+
end
|
60
|
+
else
|
61
|
+
raise Fog::AWS::ELB::NotFound
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class RDS
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/aws/parsers/rds/describe_db_log_files'
|
7
|
+
|
8
|
+
# Describe log files for a DB instance
|
9
|
+
# http://docs.amazonwebservices.com/AmazonRDS/latest/APIReference/API_DescribeDBLogFiles.html
|
10
|
+
# ==== Parameters
|
11
|
+
# * DBInstanceIdentifier <~String> - ID of instance to retrieve information for. Required.
|
12
|
+
# * Options <~Hash> - Hash of options. Optional. The following keys are used:
|
13
|
+
# * :file_last_written <~Long> - Filter available log files for those written after this time. Optional.
|
14
|
+
# * :file_size <~Long> - Filters the available log files for files larger than the specified size. Optional.
|
15
|
+
# * :filename_contains <~String> - Filters the available log files for log file names that contain the specified string. 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
|
+
# ==== Returns
|
19
|
+
# * response<~Excon::Response>:
|
20
|
+
# * body<~Hash>:
|
21
|
+
def describe_db_log_files(rds_id=nil, opts={})
|
22
|
+
params = {}
|
23
|
+
params['DBInstanceIdentifier'] = rds_id if rds_id
|
24
|
+
params['Marker'] = opts[:marker] if opts[:marker]
|
25
|
+
params['MaxRecords'] = opts[:max_records] if opts[:max_records]
|
26
|
+
params['FilenameContains'] = opts[:filename_contains] if opts[:filename_contains]
|
27
|
+
params['FileSize'] = opts[:file_size] if opts[:file_size]
|
28
|
+
params['FileLastWritten'] = opts[:file_last_written] if opts[:file_last_written]
|
29
|
+
|
30
|
+
request({
|
31
|
+
'Action' => 'DescribeDBLogFiles',
|
32
|
+
:parser => Fog::Parsers::AWS::RDS::DescribeDBLogFiles.new(rds_id)
|
33
|
+
}.merge(params))
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
class Mock
|
38
|
+
|
39
|
+
def describe_db_log_files(rds_id=nil, opts={})
|
40
|
+
response = Excon::Response.new
|
41
|
+
log_file_set = []
|
42
|
+
|
43
|
+
if rds_id
|
44
|
+
if server = self.data[:servers][rds_id]
|
45
|
+
log_file_set << {"LastWritten" => Time.parse('2013-07-05 17:00:00 -0700'), "LogFileName" => "error/mysql-error.log", "Size" => 0}
|
46
|
+
log_file_set << {"LastWritten" => Time.parse('2013-07-05 17:10:00 -0700'), "LogFileName" => "error/mysql-error-running.log", "Size" => 0}
|
47
|
+
log_file_set << {"LastWritten" => Time.parse('2013-07-05 17:20:00 -0700'), "LogFileName" => "error/mysql-error-running.log.0", "Size" => 8220}
|
48
|
+
log_file_set << {"LastWritten" => Time.parse('2013-07-05 17:30:00 -0700'), "LogFileName" => "error/mysql-error-running.log.1", "Size" => 0}
|
49
|
+
else
|
50
|
+
raise Fog::AWS::RDS::NotFound.new("DBInstance #{rds_id} not found")
|
51
|
+
end
|
52
|
+
else
|
53
|
+
raise Fog::AWS::RDS::NotFound.new('An identifier for an RDS instance must be provided')
|
54
|
+
end
|
55
|
+
|
56
|
+
response.status = 200
|
57
|
+
response.body = {
|
58
|
+
"ResponseMetadata" => { "RequestId" => Fog::AWS::Mock.request_id },
|
59
|
+
"DescribeDBLogFilesResult" => { "DBLogFiles" => log_file_set }
|
60
|
+
}
|
61
|
+
response
|
62
|
+
end
|
63
|
+
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -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
|
@@ -0,0 +1,63 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class RDS
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/aws/parsers/rds/download_db_logfile_portion'
|
7
|
+
|
8
|
+
# Retrieve a portion of a log file of a db instance
|
9
|
+
# http://docs.amazonwebservices.com/AmazonRDS/latest/APIReference/API_DownloadDBLogFilePortion.html
|
10
|
+
# ==== Parameters
|
11
|
+
# * DBInstanceIdentifier <~String> - ID of instance to retrieve information for. Required.
|
12
|
+
# * LogFileName <~String> - The name of the log file to be downloaded. Required.
|
13
|
+
# * Options <~Hash> - Hash of options. Optional. The following keys are used:
|
14
|
+
# * :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.
|
15
|
+
# * :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.
|
16
|
+
# * :number_of_lines <~Integer> - The number of lines to download. Optional.
|
17
|
+
# ==== Returns
|
18
|
+
# * response<~Excon::Response>:
|
19
|
+
# * body<~Hash>:
|
20
|
+
def download_db_logfile_portion(identifier=nil, filename=nil, opts={})
|
21
|
+
params = {}
|
22
|
+
params['DBInstanceIdentifier'] = identifier if identifier
|
23
|
+
params['LogFileName'] = filename if filename
|
24
|
+
params['Marker'] = opts[:marker] if opts[:marker]
|
25
|
+
params['MaxRecords'] = opts[:max_records] if opts[:max_records]
|
26
|
+
params['NumberOfLines'] = opts[:number_of_lines] if opts[:number_of_lines]
|
27
|
+
|
28
|
+
request({
|
29
|
+
'Action' => 'DownloadDBLogFilePortion',
|
30
|
+
:parser => Fog::Parsers::AWS::RDS::DownloadDBLogFilePortion.new
|
31
|
+
}.merge(params))
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
35
|
+
|
36
|
+
class Mock
|
37
|
+
|
38
|
+
def download_db_logfile_portion(identifier=nil, filename=nil, opts={})
|
39
|
+
response = Excon::Response.new
|
40
|
+
server_set = []
|
41
|
+
if identifier
|
42
|
+
if server = self.data[:servers][identifier]
|
43
|
+
server_set << server
|
44
|
+
else
|
45
|
+
raise Fog::AWS::RDS::NotFound.new("DBInstance #{identifier} not found")
|
46
|
+
end
|
47
|
+
else
|
48
|
+
server_set = self.data[:servers].values
|
49
|
+
end
|
50
|
+
|
51
|
+
response.status = 200
|
52
|
+
response.body = {
|
53
|
+
"ResponseMetadata" => { "RequestId"=> Fog::AWS::Mock.request_id },
|
54
|
+
"DescribeDBInstancesResult" => { "DBInstances" => server_set }
|
55
|
+
}
|
56
|
+
response
|
57
|
+
end
|
58
|
+
|
59
|
+
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
@@ -30,7 +30,7 @@ module Fog
|
|
30
30
|
|
31
31
|
request({
|
32
32
|
'Action' => 'SendRawEmail',
|
33
|
-
'RawMessage.Data' => Base64.encode64(raw_message).chomp!,
|
33
|
+
'RawMessage.Data' => Base64.encode64(raw_message.to_s).chomp!,
|
34
34
|
:parser => Fog::Parsers::AWS::SES::SendRawEmail.new
|
35
35
|
}.merge(params))
|
36
36
|
end
|
@@ -16,7 +16,7 @@ module Fog
|
|
16
16
|
# * 'ResponseMetadata'<~Hash>:
|
17
17
|
# * 'VerificationToken'<~String> - Verification token
|
18
18
|
# * 'RequestId'<~String> - Id of request
|
19
|
-
def
|
19
|
+
def verify_domain_identity(domain)
|
20
20
|
request({
|
21
21
|
'Action' => 'VerifyDomainIdentity',
|
22
22
|
'Domain' => domain,
|
@@ -13,12 +13,16 @@ module Fog
|
|
13
13
|
# @param [Array<String>] parts Array of etags as Strings for parts
|
14
14
|
#
|
15
15
|
# @return [Excon::Response]
|
16
|
-
# *
|
16
|
+
# * body [Hash]: (success)
|
17
17
|
# * Bucket [String] - bucket of new object
|
18
|
-
# * ETag [String] - etag of new object
|
18
|
+
# * ETag [String] - etag of new object
|
19
19
|
# * Key [String] - key of new object
|
20
20
|
# * Location [String] - location of new object
|
21
|
+
# * body [Hash]: (failure)
|
22
|
+
# * Code [String] - Error status code
|
23
|
+
# * Message [String] - Error description
|
21
24
|
#
|
25
|
+
# @note This request could fail and still return +200 OK+, so it's important that you check the response.
|
22
26
|
# @see http://docs.amazonwebservices.com/AmazonS3/latest/API/mpUploadComplete.html
|
23
27
|
#
|
24
28
|
def complete_multipart_upload(bucket_name, object_name, upload_id, parts)
|
@@ -87,7 +87,7 @@ module Fog
|
|
87
87
|
if (object && !object[:delete_marker])
|
88
88
|
if options['If-Match'] && options['If-Match'] != object['ETag']
|
89
89
|
response.status = 412
|
90
|
-
elsif options['If-Modified-Since'] && options['If-Modified-Since']
|
90
|
+
elsif options['If-Modified-Since'] && options['If-Modified-Since'] >= Time.parse(object['Last-Modified'])
|
91
91
|
response.status = 304
|
92
92
|
elsif options['If-None-Match'] && options['If-None-Match'] == object['ETag']
|
93
93
|
response.status = 304
|