fog 1.10.0 → 1.10.1
Sign up to get free protection for your applications and to get access to all the features.
- data/benchs/load_times.rb +31 -0
- data/changelog.txt +320 -0
- data/fog.gemspec +3 -3
- data/lib/fog.rb +42 -15
- data/lib/fog/aws/auto_scaling.rb +1 -1
- data/lib/fog/aws/beanstalk.rb +1 -1
- data/lib/fog/aws/cloud_formation.rb +1 -1
- data/lib/fog/aws/compute.rb +1 -1
- data/lib/fog/aws/elasticache.rb +1 -1
- data/lib/fog/aws/elb.rb +1 -1
- data/lib/fog/aws/iam.rb +1 -1
- data/lib/fog/aws/models/beanstalk/environment.rb +6 -2
- data/lib/fog/aws/models/cdn/distributions.rb +2 -1
- data/lib/fog/aws/models/cdn/distributions_helper.rb +2 -1
- data/lib/fog/aws/models/cdn/streaming_distributions.rb +2 -1
- data/lib/fog/aws/models/compute/server.rb +1 -1
- data/lib/fog/aws/models/storage/directory.rb +1 -1
- data/lib/fog/aws/models/storage/file.rb +1 -1
- data/lib/fog/aws/parsers/beanstalk/describe_environment_resources.rb +11 -0
- data/lib/fog/aws/rds.rb +1 -1
- data/lib/fog/aws/requests/cdn/delete_distribution.rb +5 -7
- data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +5 -7
- data/lib/fog/aws/requests/cdn/get_distribution.rb +28 -31
- data/lib/fog/aws/requests/cdn/get_distribution_list.rb +29 -33
- data/lib/fog/aws/requests/cdn/get_invalidation.rb +15 -13
- data/lib/fog/aws/requests/cdn/get_invalidation_list.rb +15 -17
- data/lib/fog/aws/requests/cdn/get_streaming_distribution.rb +23 -26
- data/lib/fog/aws/requests/cdn/get_streaming_distribution_list.rb +29 -33
- data/lib/fog/aws/requests/cdn/post_distribution.rb +40 -42
- data/lib/fog/aws/requests/cdn/post_invalidation.rb +14 -18
- data/lib/fog/aws/requests/cdn/post_streaming_distribution.rb +28 -30
- data/lib/fog/aws/requests/cdn/put_distribution_config.rb +41 -43
- data/lib/fog/aws/requests/cdn/put_streaming_distribution_config.rb +31 -33
- data/lib/fog/aws/requests/cloud_formation/create_stack.rb +16 -20
- data/lib/fog/aws/requests/cloud_formation/delete_stack.rb +5 -8
- data/lib/fog/aws/requests/cloud_formation/describe_stack_events.rb +19 -22
- data/lib/fog/aws/requests/cloud_formation/describe_stack_resources.rb +18 -21
- data/lib/fog/aws/requests/cloud_formation/describe_stacks.rb +18 -21
- data/lib/fog/aws/requests/cloud_formation/get_template.rb +7 -10
- data/lib/fog/aws/requests/cloud_formation/update_stack.rb +12 -16
- data/lib/fog/aws/requests/cloud_formation/validate_template.rb +9 -12
- data/lib/fog/aws/requests/compute/associate_address.rb +13 -7
- data/lib/fog/aws/requests/compute/describe_reserved_instances_offerings.rb +16 -2
- data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +10 -0
- data/lib/fog/aws/requests/iam/update_server_certificate.rb +27 -0
- data/lib/fog/aws/requests/storage/get_object.rb +6 -2
- data/lib/fog/aws/storage.rb +6 -4
- data/lib/fog/aws/sts.rb +1 -1
- data/lib/fog/bin.rb +2 -0
- data/lib/fog/bin/digitalocean.rb +31 -0
- data/lib/fog/bin/riakcs.rb +27 -0
- data/lib/fog/cloudstack/compute.rb +3 -0
- data/lib/fog/cloudstack/models/compute/snapshot.rb +46 -0
- data/lib/fog/cloudstack/models/compute/snapshots.rb +25 -0
- data/lib/fog/cloudstack/requests/compute/create_snapshot.rb +24 -0
- data/lib/fog/compute.rb +3 -0
- data/lib/fog/compute/models/server.rb +6 -7
- data/lib/fog/core.rb +10 -5
- data/lib/fog/core/errors.rb +2 -0
- data/lib/fog/core/scp.rb +3 -3
- data/lib/fog/core/ssh.rb +1 -1
- data/lib/fog/digitalocean.rb +9 -0
- data/lib/fog/digitalocean/CHANGELOG.md +6 -0
- data/lib/fog/digitalocean/compute.rb +107 -0
- data/lib/fog/digitalocean/examples/getting_started.md +106 -0
- data/lib/fog/digitalocean/models/compute/flavor.rb +14 -0
- data/lib/fog/digitalocean/models/compute/flavors.rb +25 -0
- data/lib/fog/digitalocean/models/compute/image.rb +15 -0
- data/lib/fog/digitalocean/models/compute/images.rb +25 -0
- data/lib/fog/digitalocean/models/compute/region.rb +14 -0
- data/lib/fog/digitalocean/models/compute/regions.rb +25 -0
- data/lib/fog/digitalocean/models/compute/server.rb +150 -0
- data/lib/fog/digitalocean/models/compute/servers.rb +27 -0
- data/lib/fog/digitalocean/models/compute/ssh_key.rb +28 -0
- data/lib/fog/digitalocean/models/compute/ssh_keys.rb +27 -0
- data/lib/fog/digitalocean/requests/compute/create_server.rb +68 -0
- data/lib/fog/digitalocean/requests/compute/create_ssh_key.rb +38 -0
- data/lib/fog/digitalocean/requests/compute/destroy_server.rb +34 -0
- data/lib/fog/digitalocean/requests/compute/destroy_ssh_key.rb +37 -0
- data/lib/fog/digitalocean/requests/compute/get_server_details.rb +35 -0
- data/lib/fog/digitalocean/requests/compute/get_ssh_key.rb +39 -0
- data/lib/fog/digitalocean/requests/compute/list_flavors.rb +38 -0
- data/lib/fog/digitalocean/requests/compute/list_images.rb +49 -0
- data/lib/fog/digitalocean/requests/compute/list_regions.rb +34 -0
- data/lib/fog/digitalocean/requests/compute/list_servers.rb +31 -0
- data/lib/fog/digitalocean/requests/compute/list_ssh_keys.rb +31 -0
- data/lib/fog/digitalocean/requests/compute/power_cycle_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/power_off_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/power_on_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/reboot_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/shutdown_server.rb +36 -0
- data/lib/fog/dreamhost/CHANGELOG.md +8 -0
- data/lib/fog/glesys/models/compute/server.rb +3 -3
- data/lib/fog/google/storage.rb +1 -1
- data/lib/fog/hp.rb +1 -1
- data/lib/fog/hp/CHANGELOG.hp +12 -2
- data/lib/fog/hp/block_storage.rb +1 -0
- data/lib/fog/hp/cdn.rb +1 -0
- data/lib/fog/hp/compute.rb +1 -0
- data/lib/fog/hp/models/compute/server.rb +14 -8
- data/lib/fog/hp/models/storage/directories.rb +1 -1
- data/lib/fog/hp/models/storage/directory.rb +28 -3
- data/lib/fog/hp/models/storage/files.rb +1 -1
- data/lib/fog/hp/requests/compute/create_server.rb +4 -14
- data/lib/fog/hp/storage.rb +2 -0
- data/lib/fog/internet_archive.rb +3 -1
- data/lib/fog/internet_archive/models/storage/directory.rb +25 -42
- data/lib/fog/internet_archive/models/storage/file.rb +45 -64
- data/lib/fog/internet_archive/models/storage/ia_attributes.rb +39 -0
- data/lib/fog/internet_archive/requests/storage/delete_multiple_objects.rb +4 -78
- data/lib/fog/internet_archive/requests/storage/delete_object.rb +2 -70
- data/lib/fog/internet_archive/requests/storage/get_object.rb +1 -22
- data/lib/fog/internet_archive/requests/storage/get_object_acl.rb +0 -4
- data/lib/fog/internet_archive/requests/storage/get_service.rb +1 -2
- data/lib/fog/internet_archive/requests/storage/head_object.rb +0 -4
- data/lib/fog/internet_archive/requests/storage/post_object_hidden_fields.rb +1 -1
- data/lib/fog/internet_archive/requests/storage/put_object.rb +2 -17
- data/lib/fog/internet_archive/requests/storage/put_object_acl.rb +0 -5
- data/lib/fog/internet_archive/storage.rb +6 -18
- data/lib/fog/joyent.rb +2 -0
- data/lib/fog/libvirt/requests/compute/get_node_info.rb +1 -1
- data/lib/fog/openstack/CHANGELOG.md +47 -0
- data/lib/fog/openstack/examples/identity/basics.rb +69 -0
- data/lib/fog/openstack/examples/image/upload-test-image.rb +77 -0
- data/lib/fog/openstack/examples/network/network_subnets_routers.rb +63 -0
- data/lib/fog/openstack/examples/storage/set-account-quota.rb +66 -0
- data/lib/fog/openstack/image.rb +4 -0
- data/lib/fog/openstack/models/compute/server.rb +4 -2
- data/lib/fog/openstack/models/network/floating_ip.rb +2 -2
- data/lib/fog/openstack/models/network/floating_ips.rb +1 -1
- data/lib/fog/openstack/models/network/router.rb +56 -0
- data/lib/fog/openstack/models/network/routers.rb +34 -0
- data/lib/fog/openstack/network.rb +15 -2
- data/lib/fog/openstack/requests/compute/create_server.rb +11 -0
- data/lib/fog/openstack/requests/compute/rebuild_server.rb +9 -1
- data/lib/fog/openstack/requests/network/add_router_interface.rb +48 -0
- data/lib/fog/openstack/requests/network/create_network.rb +57 -2
- data/lib/fog/openstack/requests/network/create_router.rb +57 -0
- data/lib/fog/openstack/requests/network/delete_router.rb +30 -0
- data/lib/fog/openstack/requests/network/get_router.rb +32 -0
- data/lib/fog/openstack/requests/network/list_routers.rb +27 -0
- data/lib/fog/openstack/requests/network/remove_router_interface.rb +36 -0
- data/lib/fog/openstack/requests/network/update_router.rb +85 -0
- data/lib/fog/openstack/storage.rb +57 -0
- data/lib/fog/ovirt/compute.rb +4 -0
- data/lib/fog/ovirt/models/compute/quota.rb +21 -0
- data/lib/fog/ovirt/models/compute/quotas.rb +24 -0
- data/lib/fog/ovirt/models/compute/server.rb +2 -1
- data/lib/fog/ovirt/models/compute/volume.rb +1 -0
- data/lib/fog/ovirt/requests/compute/get_quota.rb +19 -0
- data/lib/fog/ovirt/requests/compute/list_quotas.rb +21 -0
- data/lib/fog/ovirt/requests/compute/mock_files/quotas.xml +7 -0
- data/lib/fog/rackspace.rb +11 -0
- data/lib/fog/rackspace/block_storage.rb +73 -20
- data/lib/fog/rackspace/cdn.rb +57 -19
- data/lib/fog/rackspace/compute.rb +53 -28
- data/lib/fog/rackspace/compute_v2.rb +99 -22
- data/lib/fog/rackspace/databases.rb +74 -18
- data/lib/fog/rackspace/dns.rb +55 -22
- data/lib/fog/rackspace/docs/block_storage.md +417 -0
- data/lib/fog/rackspace/docs/compute_v2.md +114 -55
- data/lib/fog/rackspace/docs/getting_started.md +20 -10
- data/lib/fog/rackspace/docs/storage.md +496 -0
- data/lib/fog/rackspace/examples/README.md +1 -1
- data/lib/fog/rackspace/examples/block_storage/create_snapshot.rb +118 -0
- data/lib/fog/rackspace/examples/block_storage/create_volume.rb +58 -0
- data/lib/fog/rackspace/examples/block_storage/delete_volume.rb +53 -0
- data/lib/fog/rackspace/examples/compute_v2/create_image.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/create_server.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +4 -4
- data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +3 -3
- data/lib/fog/rackspace/examples/compute_v2/server_metadata.rb +2 -2
- data/lib/fog/rackspace/examples/storage/create_cdn_directory.rb +44 -0
- data/lib/fog/rackspace/examples/storage/create_private_directory.rb +46 -0
- data/lib/fog/rackspace/examples/storage/delete_directory.rb +62 -0
- data/lib/fog/rackspace/examples/storage/delete_file.rb +70 -0
- data/lib/fog/rackspace/examples/storage/download_file.rb +75 -0
- data/lib/fog/rackspace/examples/storage/lorem.txt +1 -0
- data/lib/fog/rackspace/examples/storage/storage_metadata.rb +82 -0
- data/lib/fog/rackspace/examples/storage/upload_file.rb +45 -0
- data/lib/fog/rackspace/identity.rb +10 -3
- data/lib/fog/rackspace/load_balancers.rb +76 -18
- data/lib/fog/rackspace/models/block_storage/snapshot.rb +42 -0
- data/lib/fog/rackspace/models/block_storage/snapshots.rb +15 -0
- data/lib/fog/rackspace/models/block_storage/volume.rb +65 -0
- data/lib/fog/rackspace/models/block_storage/volume_type.rb +6 -0
- data/lib/fog/rackspace/models/block_storage/volume_types.rb +15 -0
- data/lib/fog/rackspace/models/block_storage/volumes.rb +15 -0
- data/lib/fog/rackspace/models/compute_v2/attachment.rb +8 -0
- data/lib/fog/rackspace/models/compute_v2/attachments.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/image.rb +10 -2
- data/lib/fog/rackspace/models/compute_v2/images.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/meta_parent.rb +1 -1
- data/lib/fog/rackspace/models/compute_v2/metadata.rb +17 -5
- data/lib/fog/rackspace/models/compute_v2/metadatum.rb +8 -0
- data/lib/fog/rackspace/models/compute_v2/server.rb +72 -13
- data/lib/fog/rackspace/models/compute_v2/servers.rb +16 -2
- data/lib/fog/rackspace/models/dns/zones.rb +5 -9
- data/lib/fog/rackspace/models/identity/service_catalog.rb +83 -0
- data/lib/fog/rackspace/models/storage/account.rb +26 -0
- data/lib/fog/rackspace/models/storage/directories.rb +23 -3
- data/lib/fog/rackspace/models/storage/directory.rb +89 -5
- data/lib/fog/rackspace/models/storage/file.rb +112 -2
- data/lib/fog/rackspace/models/storage/files.rb +78 -0
- data/lib/fog/rackspace/models/storage/metadata.rb +28 -5
- data/lib/fog/rackspace/requests/block_storage/create_snapshot.rb +24 -0
- data/lib/fog/rackspace/requests/block_storage/create_volume.rb +29 -0
- data/lib/fog/rackspace/requests/block_storage/delete_snapshot.rb +10 -0
- data/lib/fog/rackspace/requests/block_storage/delete_volume.rb +11 -0
- data/lib/fog/rackspace/requests/block_storage/get_snapshot.rb +20 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume.rb +24 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume_type.rb +14 -0
- data/lib/fog/rackspace/requests/block_storage/list_snapshots.rb +17 -0
- data/lib/fog/rackspace/requests/block_storage/list_volume_types.rb +13 -0
- data/lib/fog/rackspace/requests/block_storage/list_volumes.rb +21 -0
- data/lib/fog/rackspace/requests/cdn/delete_object.rb +5 -1
- data/lib/fog/rackspace/requests/cdn/get_containers.rb +5 -0
- data/lib/fog/rackspace/requests/cdn/head_container.rb +5 -0
- data/lib/fog/rackspace/requests/cdn/post_container.rb +6 -1
- data/lib/fog/rackspace/requests/cdn/put_container.rb +6 -1
- data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/create_image.rb +9 -4
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +9 -5
- data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_image.rb +5 -1
- data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_server.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +8 -4
- data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +6 -1
- data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +8 -3
- data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/update_server.rb +4 -0
- data/lib/fog/rackspace/requests/storage/copy_object.rb +4 -0
- data/lib/fog/rackspace/requests/storage/delete_container.rb +4 -1
- data/lib/fog/rackspace/requests/storage/delete_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/get_container.rb +4 -0
- data/lib/fog/rackspace/requests/storage/get_containers.rb +4 -0
- data/lib/fog/rackspace/requests/storage/get_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +7 -4
- data/lib/fog/rackspace/requests/storage/head_container.rb +4 -0
- data/lib/fog/rackspace/requests/storage/head_containers.rb +4 -0
- data/lib/fog/rackspace/requests/storage/head_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/post_set_meta_temp_url_key.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_container.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +4 -1
- data/lib/fog/rackspace/service.rb +78 -0
- data/lib/fog/rackspace/storage.rb +62 -22
- data/lib/fog/riakcs.rb +122 -0
- data/lib/fog/riakcs/provisioning.rb +100 -0
- data/lib/fog/riakcs/requests/provisioning/create_user.rb +77 -0
- data/lib/fog/riakcs/requests/provisioning/disable_user.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/enable_user.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/get_user.rb +41 -0
- data/lib/fog/riakcs/requests/provisioning/list_users.rb +43 -0
- data/lib/fog/riakcs/requests/provisioning/regrant_secret.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/update_user.rb +23 -0
- data/lib/fog/riakcs/requests/usage/get_usage.rb +68 -0
- data/lib/fog/riakcs/usage.rb +66 -0
- data/lib/fog/vcloud/compute.rb +1 -1
- data/lib/fog/vcloud/models/compute/catalog_item.rb +8 -0
- data/lib/fog/vcloud/models/compute/server.rb +1 -0
- data/lib/fog/vcloud/requests/compute/configure_vm_network.rb +1 -2
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +1 -1
- data/lib/fog/vsphere/models/compute/servers.rb +9 -9
- data/lib/fog/xenserver.rb +2 -0
- data/lib/fog/xenserver/CHANGELOG.md +7 -1
- data/lib/fog/xenserver/compute.rb +6 -0
- data/lib/fog/xenserver/examples/networks-and-vlans.rb +45 -0
- data/lib/fog/xenserver/models/compute/network.rb +33 -0
- data/lib/fog/xenserver/models/compute/vlan.rb +80 -0
- data/lib/fog/xenserver/models/compute/vlans.rb +39 -0
- data/lib/fog/xenserver/requests/compute/create_network.rb +42 -0
- data/lib/fog/xenserver/requests/compute/create_vlan.rb +35 -0
- data/lib/fog/xenserver/requests/compute/destroy_network.rb +33 -0
- data/lib/fog/xenserver/requests/compute/destroy_vlan.rb +32 -0
- data/lib/fog/zerigo/models/dns/records.rb +15 -12
- data/lib/tasks/changelog_task.rb +1 -0
- data/tests/aws/requests/compute/address_tests.rb +4 -0
- data/tests/aws/requests/iam/server_certificate_tests.rb +32 -0
- data/tests/cloudstack/compute/models/snapshot_tests.rb +34 -0
- data/tests/digitalocean/helper.rb +44 -0
- data/tests/digitalocean/models/compute/flavor_tests.rb +30 -0
- data/tests/digitalocean/models/compute/image_tests.rb +31 -0
- data/tests/digitalocean/models/compute/region_tests.rb +30 -0
- data/tests/digitalocean/models/compute/server_tests.rb +84 -0
- data/tests/digitalocean/models/compute/servers_tests.rb +35 -0
- data/tests/digitalocean/models/compute/ssh_key_tests.rb +40 -0
- data/tests/digitalocean/models/compute/ssh_keys_tests.rb +28 -0
- data/tests/digitalocean/requests/compute/create_server_tests.rb +28 -0
- data/tests/digitalocean/requests/compute/create_ssh_key_tests.rb +22 -0
- data/tests/digitalocean/requests/compute/destroy_server_tests.rb +15 -0
- data/tests/digitalocean/requests/compute/destroy_ssh_key_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/get_server_details_tests.rb +13 -0
- data/tests/digitalocean/requests/compute/get_ssh_key_tests.rb +22 -0
- data/tests/digitalocean/requests/compute/list_flavors_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/list_images_tests.rb +24 -0
- data/tests/digitalocean/requests/compute/list_regions_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/list_servers_tests.rb +26 -0
- data/tests/digitalocean/requests/compute/list_ssh_keys_tests.rb +21 -0
- data/tests/digitalocean/requests/compute/power_cycle_server_tests.rb +20 -0
- data/tests/digitalocean/requests/compute/power_state_tests.rb +25 -0
- data/tests/digitalocean/requests/compute/reboot_server_tests.rb +14 -0
- data/tests/helpers/collection_helper.rb +36 -1
- data/tests/helpers/mock_helper.rb +2 -0
- data/tests/internet_archive/models/storage/directory_tests.rb +24 -32
- data/tests/internet_archive/models/storage/file_tests.rb +16 -35
- data/tests/internet_archive/models/storage/files_tests.rb +33 -31
- data/tests/internet_archive/models/storage/url_tests.rb +1 -1
- data/tests/internet_archive/requests/storage/bucket_tests.rb +34 -38
- data/tests/internet_archive/requests/storage/multipart_upload_tests.rb +1 -1
- data/tests/openstack/models/network/network_tests.rb +17 -0
- data/tests/openstack/models/network/router_tests.rb +38 -0
- data/tests/openstack/models/network/routers_tests.rb +21 -0
- data/tests/openstack/requests/network/network_tests.rb +61 -10
- data/tests/openstack/requests/network/router_tests.rb +75 -0
- data/tests/openstack/storage_tests.rb +19 -0
- data/tests/ovirt/requests/compute/list_quotas_tests.rb +12 -0
- data/tests/rackspace/block_storage_tests.rb +101 -0
- data/tests/rackspace/cdn_tests.rb +144 -52
- data/tests/rackspace/compute_tests.rb +88 -0
- data/tests/rackspace/compute_v2_tests.rb +101 -0
- data/tests/rackspace/databases_tests.rb +98 -0
- data/tests/rackspace/dns_tests.rb +82 -0
- data/tests/rackspace/load_balancer_tests.rb +99 -0
- data/tests/rackspace/models/compute_v2/image_tests.rb +51 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +51 -0
- data/tests/rackspace/models/identity/service_catalog_tests.rb +81 -0
- data/tests/rackspace/models/storage/file_tests.rb +10 -1
- data/tests/rackspace/rackspace_tests.rb +21 -0
- data/tests/rackspace/requests/compute_v2/metadata_tests.rb +2 -2
- data/tests/rackspace/requests/storage/object_tests.rb +2 -2
- data/tests/rackspace/storage_tests.rb +99 -3
- data/tests/riakcs/requests/provisioning/provisioning_tests.rb +174 -0
- data/tests/riakcs/requests/usage/usage_tests.rb +29 -0
- data/tests/xenserver/models/compute/network_tests.rb +18 -6
- data/tests/xenserver/models/compute/vlan_tests.rb +76 -0
- data/tests/xenserver/models/compute/vlans_tests.rb +36 -0
- data/tests/xenserver/requests/compute/create_network_tests.rb +20 -0
- data/tests/xenserver/requests/compute/create_vlan_tests.rb +36 -0
- data/tests/xenserver/requests/compute/destroy_network_tests.rb +13 -0
- data/tests/xenserver/requests/compute/destroy_vlan_tests.rb +36 -0
- metadata +178 -21
- data/lib/fog/internet_archive/models/storage/version.rb +0 -36
- data/lib/fog/internet_archive/models/storage/versions.rb +0 -38
- data/lib/fog/internet_archive/parsers/storage/get_bucket_object_versions.rb +0 -88
- data/lib/fog/internet_archive/parsers/storage/get_bucket_versioning.rb +0 -24
- data/lib/fog/internet_archive/requests/storage/get_bucket_object_versions.rb +0 -162
- data/lib/fog/internet_archive/requests/storage/get_bucket_versioning.rb +0 -69
- data/lib/fog/internet_archive/requests/storage/put_bucket_versioning.rb +0 -75
- data/lib/fog/openstack/README.identity.md +0 -69
- data/lib/fog/providers.rb +0 -34
- data/lib/fog/rackspace/examples/compute_v2/README.md +0 -47
- data/tests/internet_archive/models/storage/version_tests.rb +0 -52
- data/tests/internet_archive/models/storage/versions_tests.rb +0 -56
- data/tests/internet_archive/requests/storage/versioning_tests.rb +0 -258
@@ -1,36 +1,39 @@
|
|
1
1
|
require 'fog/core/model'
|
2
2
|
require 'fog/internet_archive/models/storage/files'
|
3
|
-
require 'fog/internet_archive/models/storage/
|
3
|
+
require 'fog/internet_archive/models/storage/ia_attributes.rb'
|
4
4
|
|
5
5
|
module Fog
|
6
6
|
module Storage
|
7
7
|
class InternetArchive
|
8
8
|
|
9
9
|
class Directory < Fog::Model
|
10
|
-
VALID_ACLS = ['private', 'public-read', 'public-read-write', 'authenticated-read']
|
11
10
|
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
attr_reader :acl
|
11
|
+
extend Fog::Storage::IAAttributes::ClassMethods
|
12
|
+
include Fog::Storage::IAAttributes::InstanceMethods
|
16
13
|
|
17
14
|
identity :key, :aliases => ['Name', 'name']
|
18
15
|
|
19
16
|
attribute :creation_date, :aliases => 'CreationDate'
|
20
17
|
|
18
|
+
# treat these differently
|
19
|
+
attribute :collections
|
20
|
+
attribute :subjects
|
21
|
+
|
22
|
+
ia_metadata_attribute :ignore_preexisting_bucket
|
23
|
+
ia_metadata_attribute :interactive_priority
|
24
|
+
|
25
|
+
# acl for internet archive is always public-read
|
26
|
+
def acl
|
27
|
+
'public-read'
|
28
|
+
end
|
29
|
+
|
21
30
|
def acl=(new_acl)
|
22
|
-
|
23
|
-
raise ArgumentError.new("acl must be one of [#{VALID_ACLS.join(', ')}]")
|
24
|
-
else
|
25
|
-
@acl = new_acl
|
26
|
-
end
|
31
|
+
'public-read'
|
27
32
|
end
|
28
33
|
|
34
|
+
# See http://archive.org/help/abouts3.txt
|
29
35
|
def destroy
|
30
|
-
|
31
|
-
service.delete_bucket(key)
|
32
|
-
true
|
33
|
-
rescue Excon::Errors::NotFound
|
36
|
+
Fog::Logger.warning("fog: Internet Archive does not support deleting a Bucket (i.e. Item). For details see: See http://archive.org/help/abouts3.txt")
|
34
37
|
false
|
35
38
|
end
|
36
39
|
|
@@ -63,37 +66,13 @@ module Fog
|
|
63
66
|
@payer = new_payer
|
64
67
|
end
|
65
68
|
|
66
|
-
def versioning?
|
67
|
-
requires :key
|
68
|
-
data = service.get_bucket_versioning(key)
|
69
|
-
data.body['VersioningConfiguration']['Status'] == 'Enabled'
|
70
|
-
end
|
71
|
-
|
72
|
-
def versioning=(new_versioning)
|
73
|
-
requires :key
|
74
|
-
service.put_bucket_versioning(key, new_versioning ? 'Enabled' : 'Suspended')
|
75
|
-
end
|
76
|
-
|
77
|
-
def versions
|
78
|
-
@versions ||= Fog::Storage::InternetArchive::Versions.new(:directory => self, :service => service)
|
79
|
-
end
|
80
|
-
|
81
69
|
def public=(new_public)
|
82
|
-
|
83
|
-
new_public
|
70
|
+
'public-read'
|
84
71
|
end
|
85
72
|
|
86
73
|
def public_url
|
87
74
|
requires :key
|
88
|
-
|
89
|
-
if key.to_s =~ Fog::InternetArchive::COMPLIANT_BUCKET_NAMES
|
90
|
-
"https://#{key}.s3.#{Fog::InternetArchive::DOMAIN_NAME}"
|
91
|
-
else
|
92
|
-
"https://s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{key}"
|
93
|
-
end
|
94
|
-
else
|
95
|
-
nil
|
96
|
-
end
|
75
|
+
"http://#{Fog::InternetArchive::DOMAIN_NAME}/details/#{key}"
|
97
76
|
end
|
98
77
|
|
99
78
|
def save
|
@@ -101,7 +80,11 @@ module Fog
|
|
101
80
|
|
102
81
|
options = {}
|
103
82
|
|
104
|
-
options['x-
|
83
|
+
options['x-archive-ignore-preexisting-bucket'] = ignore_preexisting_bucket if ignore_preexisting_bucket
|
84
|
+
options['x-archive-interactive-priority'] = interactive_priority if interactive_priority
|
85
|
+
|
86
|
+
set_metadata_array_headers(:collections, options)
|
87
|
+
set_metadata_array_headers(:subjects, options)
|
105
88
|
|
106
89
|
if location = attributes[:location] || (self.service.region != 'us-east-1' && self.service.region)
|
107
90
|
options['LocationConstraint'] = location
|
@@ -1,16 +1,26 @@
|
|
1
1
|
require 'fog/core/model'
|
2
|
-
require 'fog/internet_archive/models/storage/
|
2
|
+
require 'fog/internet_archive/models/storage/ia_attributes.rb'
|
3
3
|
|
4
4
|
module Fog
|
5
5
|
module Storage
|
6
6
|
class InternetArchive
|
7
7
|
|
8
8
|
class File < Fog::Model
|
9
|
+
|
10
|
+
extend Fog::Storage::IAAttributes::ClassMethods
|
11
|
+
include Fog::Storage::IAAttributes::InstanceMethods
|
12
|
+
|
9
13
|
# @see AWS Object docs http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectOps.html
|
10
14
|
|
11
|
-
|
15
|
+
# @note Chunk size to use for multipart uploads.
|
16
|
+
# Use small chunk sizes to minimize memory. E.g. 5242880 = 5mb
|
17
|
+
attr_accessor :multipart_chunk_size
|
12
18
|
|
13
19
|
attr_writer :body
|
20
|
+
|
21
|
+
|
22
|
+
identity :key, :aliases => 'Key'
|
23
|
+
|
14
24
|
attribute :cache_control, :aliases => 'Cache-Control'
|
15
25
|
attribute :content_disposition, :aliases => 'Content-Disposition'
|
16
26
|
attribute :content_encoding, :aliases => 'Content-Encoding'
|
@@ -22,31 +32,28 @@ module Fog
|
|
22
32
|
attribute :last_modified, :aliases => ['Last-Modified', 'LastModified']
|
23
33
|
attribute :metadata
|
24
34
|
attribute :owner, :aliases => 'Owner'
|
25
|
-
attribute :storage_class, :aliases => ['x-amz-storage-class', 'StorageClass']
|
26
|
-
attribute :encryption, :aliases => 'x-amz-server-side-encryption'
|
27
|
-
attribute :version, :aliases => 'x-amz-version-id'
|
28
|
-
|
29
|
-
# @note Chunk size to use for multipart uploads.
|
30
|
-
# Use small chunk sizes to minimize memory. E.g. 5242880 = 5mb
|
31
|
-
attr_accessor :multipart_chunk_size
|
32
35
|
|
36
|
+
# treat these differently
|
37
|
+
attribute :collections
|
38
|
+
attribute :subjects
|
39
|
+
|
40
|
+
ia_metadata_attribute :auto_make_bucket
|
41
|
+
ia_metadata_attribute :cascade_delete
|
42
|
+
ia_metadata_attribute :ignore_preexisting_bucket
|
43
|
+
ia_metadata_attribute :interactive_priority
|
44
|
+
ia_metadata_attribute :keep_old_version
|
45
|
+
ia_metadata_attribute :queue_derive
|
46
|
+
ia_metadata_attribute :size_hint
|
47
|
+
|
48
|
+
# acl for internet archive is always public-read
|
49
|
+
def acl
|
50
|
+
'public-read'
|
51
|
+
end
|
33
52
|
|
34
|
-
# Set file's access control list (ACL).
|
35
|
-
#
|
36
|
-
# valid acls: private, public-read, public-read-write, authenticated-read
|
37
|
-
#
|
38
|
-
# @param [String] new_acl one of valid options
|
39
|
-
# @return [String] @acl
|
40
|
-
#
|
41
53
|
def acl=(new_acl)
|
42
|
-
|
43
|
-
unless valid_acls.include?(new_acl)
|
44
|
-
raise ArgumentError.new("acl must be one of [#{valid_acls.join(', ')}]")
|
45
|
-
end
|
46
|
-
@acl = new_acl
|
54
|
+
'public-read'
|
47
55
|
end
|
48
56
|
|
49
|
-
|
50
57
|
# Get file's body if exists, else ' '.
|
51
58
|
#
|
52
59
|
# @return [File]
|
@@ -101,23 +108,20 @@ module Fog
|
|
101
108
|
# required attributes: directory, key
|
102
109
|
#
|
103
110
|
# @param options [Hash]
|
104
|
-
# @option options versionId []
|
105
111
|
# @return [Boolean] true if successful
|
106
112
|
#
|
107
113
|
def destroy(options = {})
|
108
114
|
requires :directory, :key
|
109
|
-
|
115
|
+
options['x-archive-cascade-delete'] = cascade_delete if cascade_delete
|
110
116
|
service.delete_object(directory.key, key, options)
|
111
117
|
true
|
112
118
|
end
|
113
119
|
|
114
|
-
|
115
120
|
remove_method :metadata
|
116
121
|
def metadata
|
117
|
-
attributes.reject {|key, value| !(key.to_s =~ /^x-amz
|
122
|
+
attributes.reject {|key, value| !(key.to_s =~ /^x-(amz||archive)-meta/)}
|
118
123
|
end
|
119
124
|
|
120
|
-
|
121
125
|
remove_method :metadata=
|
122
126
|
def metadata=(new_metadata)
|
123
127
|
merge_attributes(new_metadata)
|
@@ -143,18 +147,11 @@ module Fog
|
|
143
147
|
# @return [String] new_puplic
|
144
148
|
#
|
145
149
|
def public=(new_public)
|
146
|
-
|
147
|
-
@acl = 'public-read'
|
148
|
-
else
|
149
|
-
@acl = 'private'
|
150
|
-
end
|
151
|
-
new_public
|
150
|
+
'public-read'
|
152
151
|
end
|
153
152
|
|
154
153
|
|
155
|
-
# Get
|
156
|
-
# Checks persmissions before creating.
|
157
|
-
# Defaults to s3 subdomain or compliant bucket name
|
154
|
+
# Get publicly acessible url via http GET.
|
158
155
|
#
|
159
156
|
# required attributes: directory, key
|
160
157
|
#
|
@@ -162,15 +159,7 @@ module Fog
|
|
162
159
|
#
|
163
160
|
def public_url
|
164
161
|
requires :directory, :key
|
165
|
-
|
166
|
-
if directory.key.to_s =~ Fog::InternetArchive::COMPLIANT_BUCKET_NAMES
|
167
|
-
"https://#{directory.key}.s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
|
168
|
-
else
|
169
|
-
"https://s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{directory.key}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
|
170
|
-
end
|
171
|
-
else
|
172
|
-
nil
|
173
|
-
end
|
162
|
+
"http://#{Fog::InternetArchive::DOMAIN_NAME}/download/#{directory.key}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
|
174
163
|
end
|
175
164
|
|
176
165
|
# Save file with body as contents to directory.key with name key via http PUT
|
@@ -178,7 +167,6 @@ module Fog
|
|
178
167
|
# required attributes: body, directory, key
|
179
168
|
#
|
180
169
|
# @param [Hash] options
|
181
|
-
# @option options [String] acl sets x-amz-acl HTTP header. Valid values include, private | public-read | public-read-write | authenticated-read | bucket-owner-read | bucket-owner-full-control
|
182
170
|
# @option options [String] cache_controle sets Cache-Control header. For example, 'No-cache'
|
183
171
|
# @option options [String] content_disposition sets Content-Disposition HTTP header. For exampple, 'attachment; filename=testing.txt'
|
184
172
|
# @option options [String] content_encoding sets Content-Encoding HTTP header. For example, 'x-gzip'
|
@@ -192,9 +180,8 @@ module Fog
|
|
192
180
|
def save(options = {})
|
193
181
|
requires :body, :directory, :key
|
194
182
|
if options != {}
|
195
|
-
Fog::Logger.deprecation("options param is deprecated
|
183
|
+
Fog::Logger.deprecation("options param is deprecated [light_black](#{caller.first})[/]")
|
196
184
|
end
|
197
|
-
options['x-amz-acl'] ||= @acl if @acl
|
198
185
|
options['Cache-Control'] = cache_control if cache_control
|
199
186
|
options['Content-Disposition'] = content_disposition if content_disposition
|
200
187
|
options['Content-Encoding'] = content_encoding if content_encoding
|
@@ -202,8 +189,15 @@ module Fog
|
|
202
189
|
options['Content-Type'] = content_type if content_type
|
203
190
|
options['Expires'] = expires if expires
|
204
191
|
options.merge!(metadata)
|
205
|
-
|
206
|
-
options['x-
|
192
|
+
|
193
|
+
options['x-archive-auto-make-bucket'] = auto_make_bucket if auto_make_bucket
|
194
|
+
options['x-archive-interactive-priority'] = interactive_priority if interactive_priority
|
195
|
+
options['x-archive-keep-old-version'] = keep_old_version if keep_old_version
|
196
|
+
options['x-archive-queue-derive'] = queue_derive if queue_derive
|
197
|
+
options['x-archive-size-hint'] = size_hint.to_i.to_s if size_hint
|
198
|
+
|
199
|
+
set_metadata_array_headers(:collections, options)
|
200
|
+
set_metadata_array_headers(:subjects, options)
|
207
201
|
|
208
202
|
if multipart_chunk_size && body.respond_to?(:read)
|
209
203
|
data = multipart_save(options)
|
@@ -212,7 +206,7 @@ module Fog
|
|
212
206
|
data = service.put_object(directory.key, key, body, options)
|
213
207
|
merge_attributes(data.headers.reject {|key, value| ['Content-Length', 'Content-Type'].include?(key)})
|
214
208
|
end
|
215
|
-
self.etag.gsub!('"','')
|
209
|
+
self.etag.gsub!('"','') if self.etag
|
216
210
|
self.content_length = Fog::Storage.get_body_size(body)
|
217
211
|
self.content_type ||= Fog::Storage.get_content_type(body)
|
218
212
|
true
|
@@ -232,19 +226,6 @@ module Fog
|
|
232
226
|
collection.get_url(key, expires, options)
|
233
227
|
end
|
234
228
|
|
235
|
-
|
236
|
-
# File version if exists or creates new version.
|
237
|
-
# @return [Fog::Storage::InternetArchive::Version]
|
238
|
-
#
|
239
|
-
def versions
|
240
|
-
@versions ||= begin
|
241
|
-
Fog::Storage::InternetArchive::Versions.new(
|
242
|
-
:file => self,
|
243
|
-
:service => service
|
244
|
-
)
|
245
|
-
end
|
246
|
-
end
|
247
|
-
|
248
229
|
private
|
249
230
|
|
250
231
|
def directory=(new_directory)
|
@@ -0,0 +1,39 @@
|
|
1
|
+
module Fog
|
2
|
+
module Storage
|
3
|
+
module IAAttributes
|
4
|
+
|
5
|
+
# you can add other x-archive-metadata-* values, but these are standard
|
6
|
+
IA_STANDARD_METADATA_FIELDS = %q[hidden, title, collection, creator, mediatype, description, date, subject, licenseurl , pick, noindex, notes, rights, contributor, language, coverage, credits]
|
7
|
+
|
8
|
+
# for x-archive-metadata-mediatype, these are the valid values
|
9
|
+
IA_VALID_MEDIA_TYPES = %q[audio, data, etree, image, movies, software, texts, web]
|
10
|
+
|
11
|
+
module ClassMethods
|
12
|
+
def ia_metadata_attribute(name)
|
13
|
+
attribute(name, :aliases=>['amz','archive'].collect{|p|"x-#{p}-#{name.to_s.tr('_','-')}"})
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
module InstanceMethods
|
18
|
+
# set_metadata_array_headers(:collections, options)
|
19
|
+
def set_metadata_array_headers(array_attribute, options={})
|
20
|
+
attr_values = Array(self.send(array_attribute))
|
21
|
+
opt_values = options.collect do |key,value|
|
22
|
+
options.delete(key) if (key.to_s =~ /^x-(amz||archive)-meta(\d*)-#{array_attribute.to_s[0..-2]}/)
|
23
|
+
end
|
24
|
+
values = (attr_values + opt_values).compact.sort.uniq
|
25
|
+
# got the values, now add them back to the options
|
26
|
+
if values.size == 1
|
27
|
+
options["x-archive-meta-#{array_attribute.to_s[0..-2]}"] = values.first
|
28
|
+
elsif values.size > 1
|
29
|
+
values[0,99].each_with_index do |value, i|
|
30
|
+
options["x-archive-meta#{format("%02d", i+1)}-#{array_attribute.to_s[0..-2]}"] = value
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -34,14 +34,9 @@ module Fog
|
|
34
34
|
def delete_multiple_objects(bucket_name, object_names, options = {})
|
35
35
|
data = "<Delete>"
|
36
36
|
data << "<Quiet>true</Quiet>" if options.delete(:quiet)
|
37
|
-
version_ids = options.delete('versionId')
|
38
37
|
object_names.each do |object_name|
|
39
38
|
data << "<Object>"
|
40
39
|
data << "<Key>#{CGI.escapeHTML(object_name)}</Key>"
|
41
|
-
object_version = version_ids.nil? ? nil : version_ids[object_name]
|
42
|
-
if object_version
|
43
|
-
data << "<VersionId>#{CGI.escapeHTML(object_version)}</VersionId>"
|
44
|
-
end
|
45
40
|
data << "</Object>"
|
46
41
|
end
|
47
42
|
data << "</Delete>"
|
@@ -71,12 +66,9 @@ module Fog
|
|
71
66
|
if bucket = self.data[:buckets][bucket_name]
|
72
67
|
response.status = 200
|
73
68
|
response.body = { 'DeleteResult' => [] }
|
74
|
-
version_ids = options.delete('versionId')
|
75
69
|
object_names.each do |object_name|
|
76
|
-
object_version = version_ids.nil? ? nil : version_ids[object_name]
|
77
70
|
response.body['DeleteResult'] << delete_object_helper(bucket,
|
78
|
-
object_name
|
79
|
-
object_version)
|
71
|
+
object_name)
|
80
72
|
end
|
81
73
|
else
|
82
74
|
response.status = 404
|
@@ -87,79 +79,13 @@ module Fog
|
|
87
79
|
|
88
80
|
private
|
89
81
|
|
90
|
-
def delete_object_helper(bucket, object_name
|
82
|
+
def delete_object_helper(bucket, object_name)
|
91
83
|
response = { 'Deleted' => {} }
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
if version_id
|
96
|
-
version = bucket[:objects][object_name].find { |object| object['VersionId'] == version_id}
|
97
|
-
|
98
|
-
# S3 special cases the 'null' value to not error out if no such version exists.
|
99
|
-
if version || (version_id == 'null')
|
100
|
-
bucket[:objects][object_name].delete(version)
|
101
|
-
bucket[:objects].delete(object_name) if bucket[:objects][object_name].empty?
|
102
|
-
|
103
|
-
response['Deleted'] = { 'Key' => object_name,
|
104
|
-
'VersionId' => version_id,
|
105
|
-
'DeleteMarker' => 'true',
|
106
|
-
'DeleteMarkerVersionId' => version_id
|
107
|
-
}
|
108
|
-
else
|
109
|
-
response = delete_error_body(object_name,
|
110
|
-
version_id,
|
111
|
-
'InvalidVersion',
|
112
|
-
'Invalid version ID specified')
|
113
|
-
end
|
114
|
-
else
|
115
|
-
delete_marker = {
|
116
|
-
:delete_marker => true,
|
117
|
-
'Key' => object_name,
|
118
|
-
'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null',
|
119
|
-
'Last-Modified' => Fog::Time.now.to_date_header
|
120
|
-
}
|
121
|
-
|
122
|
-
# When versioning is suspended, a delete marker is placed if the last object ID is not the value 'null',
|
123
|
-
# otherwise the last object is replaced.
|
124
|
-
if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
|
125
|
-
bucket[:objects][object_name].shift
|
126
|
-
end
|
127
|
-
|
128
|
-
bucket[:objects][object_name].unshift(delete_marker)
|
129
|
-
|
130
|
-
response['Deleted'] = { 'Key' => object_name,
|
131
|
-
'VersionId' => delete_marker['VersionId'],
|
132
|
-
'DeleteMarkerVersionId' =>
|
133
|
-
delete_marker['VersionId'],
|
134
|
-
'DeleteMarker' => 'true',
|
135
|
-
}
|
136
|
-
end
|
137
|
-
else
|
138
|
-
if version_id && version_id != 'null'
|
139
|
-
response = delete_error_body(object_name,
|
140
|
-
version_id,
|
141
|
-
'InvalidVersion',
|
142
|
-
'Invalid version ID specified')
|
143
|
-
response = invalid_version_id_payload(version_id)
|
144
|
-
else
|
145
|
-
bucket[:objects].delete(object_name)
|
146
|
-
response['Deleted'] = { 'Key' => object_name }
|
147
|
-
end
|
148
|
-
end
|
84
|
+
bucket[:objects].delete(object_name)
|
85
|
+
response['Deleted'] = { 'Key' => object_name }
|
149
86
|
response
|
150
87
|
end
|
151
88
|
|
152
|
-
def delete_error_body(key, version_id, message, code)
|
153
|
-
{
|
154
|
-
'Error' => {
|
155
|
-
'Code' => code,
|
156
|
-
'Message' => message,
|
157
|
-
'VersionId' => version_id,
|
158
|
-
'Key' => key,
|
159
|
-
}
|
160
|
-
}
|
161
|
-
end
|
162
|
-
|
163
89
|
end
|
164
90
|
end
|
165
91
|
end
|