fog 1.9.0 → 1.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/Gemfile +1 -1
 - data/README.md +1 -1
 - data/changelog.txt +743 -0
 - data/fog.gemspec +3 -5
 - data/lib/fog/aws.rb +1 -0
 - data/lib/fog/aws/credential_fetcher.rb +1 -1
 - data/lib/fog/aws/data_pipeline.rb +114 -0
 - data/lib/fog/aws/dynamodb.rb +1 -1
 - data/lib/fog/aws/models/compute/flavors.rb +1 -1
 - data/lib/fog/aws/models/compute/spot_request.rb +2 -0
 - data/lib/fog/aws/models/data_pipeline/pipeline.rb +67 -0
 - data/lib/fog/aws/models/data_pipeline/pipelines.rb +36 -0
 - data/lib/fog/aws/parsers/cloud_watch/list_metrics.rb +1 -1
 - data/lib/fog/aws/parsers/compute/describe_instances.rb +1 -1
 - data/lib/fog/aws/parsers/compute/spot_instance_requests.rb +2 -0
 - data/lib/fog/aws/requests/compute/request_spot_instances.rb +1 -0
 - data/lib/fog/aws/requests/data_pipeline/activate_pipeline.rb +35 -0
 - data/lib/fog/aws/requests/data_pipeline/create_pipeline.rb +41 -0
 - data/lib/fog/aws/requests/data_pipeline/delete_pipeline.rb +35 -0
 - data/lib/fog/aws/requests/data_pipeline/describe_pipelines.rb +36 -0
 - data/lib/fog/aws/requests/data_pipeline/list_pipelines.rb +36 -0
 - data/lib/fog/aws/requests/data_pipeline/put_pipeline_definition.rb +72 -0
 - data/lib/fog/aws/requests/rds/describe_db_instances.rb +8 -9
 - data/lib/fog/aws/requests/storage/get_service.rb +1 -2
 - data/lib/fog/aws/requests/storage/list_multipart_uploads.rb +3 -3
 - data/lib/fog/aws/requests/storage/put_bucket_policy.rb +2 -2
 - data/lib/fog/aws/storage.rb +1 -1
 - data/lib/fog/bin.rb +2 -1
 - data/lib/fog/bin/aws.rb +4 -0
 - data/lib/fog/bin/bluebox.rb +2 -0
 - data/lib/fog/bin/dreamhost.rb +31 -0
 - data/lib/fog/bin/hp.rb +7 -0
 - data/lib/fog/bin/internet_archive.rb +34 -0
 - data/lib/fog/bin/openstack.rb +17 -2
 - data/lib/fog/bluebox.rb +1 -0
 - data/lib/fog/bluebox/blb.rb +85 -0
 - data/lib/fog/bluebox/models/blb/lb_application.rb +32 -0
 - data/lib/fog/bluebox/models/blb/lb_applications.rb +26 -0
 - data/lib/fog/bluebox/models/blb/lb_backend.rb +22 -0
 - data/lib/fog/bluebox/models/blb/lb_backends.rb +30 -0
 - data/lib/fog/bluebox/models/blb/lb_service.rb +35 -0
 - data/lib/fog/bluebox/models/blb/lb_services.rb +29 -0
 - data/lib/fog/bluebox/requests/blb/add_machine_to_lb_application.rb +33 -0
 - data/lib/fog/bluebox/requests/blb/add_machine_to_lb_backend.rb +31 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_application.rb +33 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_applications.rb +31 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_backend.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_backends.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_machine.rb +35 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_machines.rb +35 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_service.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/get_lb_services.rb +36 -0
 - data/lib/fog/bluebox/requests/blb/remove_machine_from_lb_backend.rb +28 -0
 - data/lib/fog/bluebox/requests/blb/update_lb_backend_machine.rb +29 -0
 - data/lib/fog/brightbox/compute.rb +1 -0
 - data/lib/fog/brightbox/requests/compute/create_firewall_policy.rb +1 -0
 - data/lib/fog/brightbox/requests/compute/update_firewall_policy.rb +25 -0
 - data/lib/fog/brightbox/requests/compute/update_server.rb +1 -0
 - data/lib/fog/cdn.rb +5 -12
 - data/lib/fog/compute.rb +7 -68
 - data/lib/fog/core/errors.rb +5 -1
 - data/lib/fog/core/scp.rb +1 -0
 - data/lib/fog/core/ssh.rb +1 -0
 - data/lib/fog/dns.rb +7 -27
 - data/lib/fog/dreamhost.rb +11 -0
 - data/lib/fog/dreamhost/dns.rb +86 -0
 - data/lib/fog/dreamhost/examples/dns/getting_started.md +105 -0
 - data/lib/fog/dreamhost/models/dns/record.rb +35 -0
 - data/lib/fog/dreamhost/models/dns/records.rb +38 -0
 - data/lib/fog/dreamhost/models/dns/zone.rb +59 -0
 - data/lib/fog/dreamhost/models/dns/zones.rb +41 -0
 - data/lib/fog/dreamhost/requests/dns/create_record.rb +32 -0
 - data/lib/fog/dreamhost/requests/dns/delete_record.rb +31 -0
 - data/lib/fog/dreamhost/requests/dns/list_records.rb +25 -0
 - data/lib/fog/ecloud/models/compute/detached_disks.rb +1 -5
 - data/lib/fog/ecloud/models/compute/internet_services.rb +1 -5
 - data/lib/fog/ecloud/models/compute/nodes.rb +1 -5
 - data/lib/fog/ecloud/models/compute/public_ips.rb +1 -5
 - data/lib/fog/ecloud/models/compute/servers.rb +2 -6
 - data/lib/fog/ecloud/requests/compute/get_detached_disk.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_internet_service.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_node.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_public_ip.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/get_server.rb +1 -1
 - data/lib/fog/ecloud/requests/compute/virtual_machine_create_from_template.rb +1 -1
 - data/lib/fog/glesys/compute.rb +5 -1
 - data/lib/fog/glesys/models/compute/ip.rb +47 -46
 - data/lib/fog/glesys/models/compute/ips.rb +95 -12
 - data/lib/fog/glesys/models/compute/server.rb +66 -5
 - data/lib/fog/glesys/models/compute/servers.rb +7 -1
 - data/lib/fog/glesys/models/compute/template.rb +8 -16
 - data/lib/fog/glesys/models/compute/templates.rb +23 -5
 - data/lib/fog/glesys/requests/compute/ip_details.rb +2 -2
 - data/lib/fog/glesys/requests/compute/server_details.rb +2 -2
 - data/lib/fog/glesys/requests/compute/template_list.rb +2 -2
 - data/lib/fog/hp.rb +56 -26
 - data/lib/fog/hp/CHANGELOG.hp +113 -0
 - data/lib/fog/hp/README_HP.rdoc +7 -6
 - data/lib/fog/hp/block_storage.rb +169 -0
 - data/lib/fog/hp/cdn.rb +29 -7
 - data/lib/fog/hp/compute.rb +88 -17
 - data/lib/fog/hp/models/block_storage/bootable_volumes.rb +28 -0
 - data/lib/fog/hp/models/block_storage/snapshot.rb +56 -0
 - data/lib/fog/hp/models/block_storage/snapshots.rb +29 -0
 - data/lib/fog/hp/models/block_storage/volume.rb +102 -0
 - data/lib/fog/hp/models/block_storage/volumes.rb +28 -0
 - data/lib/fog/hp/models/compute/address.rb +0 -1
 - data/lib/fog/hp/models/compute/image.rb +43 -4
 - data/lib/fog/hp/models/compute/images.rb +0 -5
 - data/lib/fog/hp/models/compute/key_pair.rb +0 -5
 - data/lib/fog/hp/models/compute/meta.rb +29 -0
 - data/lib/fog/hp/models/compute/metadata.rb +79 -0
 - data/lib/fog/hp/models/compute/server.rb +84 -20
 - data/lib/fog/hp/models/meta_parent.rb +33 -0
 - data/lib/fog/hp/models/storage/directories.rb +34 -9
 - data/lib/fog/hp/models/storage/directory.rb +111 -26
 - data/lib/fog/hp/models/storage/file.rb +10 -0
 - data/lib/fog/hp/models/storage/files.rb +8 -0
 - data/lib/fog/hp/models/storage/shared_directories.rb +55 -0
 - data/lib/fog/hp/models/storage/shared_directory.rb +39 -0
 - data/lib/fog/hp/models/storage/shared_file.rb +67 -0
 - data/lib/fog/hp/models/storage/shared_files.rb +64 -0
 - data/lib/fog/hp/requests/block_storage/create_snapshot.rb +76 -0
 - data/lib/fog/hp/requests/block_storage/create_volume.rb +87 -0
 - data/lib/fog/hp/requests/block_storage/delete_snapshot.rb +38 -0
 - data/lib/fog/hp/requests/block_storage/delete_volume.rb +38 -0
 - data/lib/fog/hp/requests/block_storage/get_bootable_volume_details.rb +59 -0
 - data/lib/fog/hp/requests/block_storage/get_snapshot_details.rb +54 -0
 - data/lib/fog/hp/requests/block_storage/get_volume_details.rb +58 -0
 - data/lib/fog/hp/requests/block_storage/list_bootable_volumes.rb +53 -0
 - data/lib/fog/hp/requests/block_storage/list_snapshots.rb +48 -0
 - data/lib/fog/hp/requests/block_storage/list_volumes.rb +52 -0
 - data/lib/fog/hp/requests/compute/attach_volume.rb +78 -0
 - data/lib/fog/hp/requests/compute/create_image.rb +5 -8
 - data/lib/fog/hp/requests/compute/create_persistent_server.rb +168 -0
 - data/lib/fog/hp/requests/compute/create_server.rb +36 -20
 - data/lib/fog/hp/requests/compute/delete_meta.rb +55 -0
 - data/lib/fog/hp/requests/compute/delete_security_group_rule.rb +4 -4
 - data/lib/fog/hp/requests/compute/detach_volume.rb +47 -0
 - data/lib/fog/hp/requests/compute/get_console_output.rb +43 -0
 - data/lib/fog/hp/requests/compute/get_meta.rb +57 -0
 - data/lib/fog/hp/requests/compute/get_windows_password.rb +43 -0
 - data/lib/fog/hp/requests/compute/list_metadata.rb +56 -0
 - data/lib/fog/hp/requests/compute/list_server_volumes.rb +49 -0
 - data/lib/fog/hp/requests/compute/set_metadata.rb +60 -0
 - data/lib/fog/hp/requests/compute/update_meta.rb +61 -0
 - data/lib/fog/hp/requests/compute/update_metadata.rb +60 -0
 - data/lib/fog/hp/requests/storage/delete_shared_object.rb +38 -0
 - data/lib/fog/hp/requests/storage/get_object.rb +12 -10
 - data/lib/fog/hp/requests/storage/get_object_temp_url.rb +31 -0
 - data/lib/fog/hp/requests/storage/get_shared_container.rb +75 -0
 - data/lib/fog/hp/requests/storage/get_shared_object.rb +66 -0
 - data/lib/fog/hp/requests/storage/head_container.rb +1 -0
 - data/lib/fog/hp/requests/storage/head_object.rb +1 -0
 - data/lib/fog/hp/requests/storage/head_shared_container.rb +45 -0
 - data/lib/fog/hp/requests/storage/head_shared_object.rb +39 -0
 - data/lib/fog/hp/requests/storage/put_container.rb +6 -6
 - data/lib/fog/hp/requests/storage/put_object.rb +12 -1
 - data/lib/fog/hp/requests/storage/put_shared_object.rb +85 -0
 - data/lib/fog/hp/storage.rb +175 -33
 - data/lib/fog/identity.rb +5 -4
 - data/lib/fog/image.rb +5 -6
 - data/lib/fog/internet_archive.rb +290 -0
 - data/lib/fog/internet_archive/models/storage/directories.rb +43 -0
 - data/lib/fog/internet_archive/models/storage/directory.rb +126 -0
 - data/lib/fog/internet_archive/models/storage/file.rb +286 -0
 - data/lib/fog/internet_archive/models/storage/files.rb +122 -0
 - data/lib/fog/internet_archive/models/storage/version.rb +36 -0
 - data/lib/fog/internet_archive/models/storage/versions.rb +38 -0
 - data/lib/fog/internet_archive/parsers/storage/access_control_list.rb +46 -0
 - data/lib/fog/internet_archive/parsers/storage/complete_multipart_upload.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/copy_object.rb +22 -0
 - data/lib/fog/internet_archive/parsers/storage/cors_configuration.rb +41 -0
 - data/lib/fog/internet_archive/parsers/storage/delete_multiple_objects.rb +50 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket.rb +62 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_lifecycle.rb +66 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_location.rb +20 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_logging.rb +40 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_object_versions.rb +88 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_versioning.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/get_bucket_website.rb +26 -0
 - data/lib/fog/internet_archive/parsers/storage/get_request_payment.rb +20 -0
 - data/lib/fog/internet_archive/parsers/storage/get_service.rb +32 -0
 - data/lib/fog/internet_archive/parsers/storage/initiate_multipart_upload.rb +24 -0
 - data/lib/fog/internet_archive/parsers/storage/list_multipart_uploads.rb +56 -0
 - data/lib/fog/internet_archive/parsers/storage/list_parts.rb +40 -0
 - data/lib/fog/internet_archive/requests/storage/abort_multipart_upload.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/acl_utils.rb +62 -0
 - data/lib/fog/internet_archive/requests/storage/complete_multipart_upload.rb +48 -0
 - data/lib/fog/internet_archive/requests/storage/copy_object.rb +81 -0
 - data/lib/fog/internet_archive/requests/storage/cors_utils.rb +41 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_cors.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_lifecycle.rb +27 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_policy.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_bucket_website.rb +29 -0
 - data/lib/fog/internet_archive/requests/storage/delete_multiple_objects.rb +167 -0
 - data/lib/fog/internet_archive/requests/storage/delete_object.rb +118 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket.rb +112 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_acl.rb +69 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_cors.rb +65 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_lifecycle.rb +38 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_location.rb +58 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_logging.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_object_versions.rb +162 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_policy.rb +34 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_versioning.rb +69 -0
 - data/lib/fog/internet_archive/requests/storage/get_bucket_website.rb +40 -0
 - data/lib/fog/internet_archive/requests/storage/get_object.rb +188 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_acl.rb +80 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_http_url.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_https_url.rb +37 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_torrent.rb +47 -0
 - data/lib/fog/internet_archive/requests/storage/get_object_url.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/get_request_payment.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/get_service.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/head_object.rb +66 -0
 - data/lib/fog/internet_archive/requests/storage/initiate_multipart_upload.rb +44 -0
 - data/lib/fog/internet_archive/requests/storage/list_multipart_uploads.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/list_parts.rb +55 -0
 - data/lib/fog/internet_archive/requests/storage/post_object_hidden_fields.rb +38 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket.rb +74 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_acl.rb +71 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_cors.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_lifecycle.rb +77 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_logging.rb +81 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_policy.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_versioning.rb +75 -0
 - data/lib/fog/internet_archive/requests/storage/put_bucket_website.rb +64 -0
 - data/lib/fog/internet_archive/requests/storage/put_object.rb +113 -0
 - data/lib/fog/internet_archive/requests/storage/put_object_acl.rb +80 -0
 - data/lib/fog/internet_archive/requests/storage/put_object_url.rb +48 -0
 - data/lib/fog/internet_archive/requests/storage/put_request_payment.rb +49 -0
 - data/lib/fog/internet_archive/requests/storage/sync_clock.rb +28 -0
 - data/lib/fog/internet_archive/requests/storage/upload_part.rb +41 -0
 - data/lib/fog/internet_archive/signaturev4.rb +73 -0
 - data/lib/fog/internet_archive/storage.rb +402 -0
 - data/lib/fog/joyent/models/compute/server.rb +1 -1
 - data/lib/fog/joyent/requests/compute/resize_machine.rb +2 -0
 - data/lib/fog/libvirt/models/compute/volume.rb +1 -1
 - data/lib/fog/network.rb +5 -6
 - data/lib/fog/openstack.rb +10 -0
 - data/lib/fog/openstack/compute.rb +11 -4
 - data/lib/fog/openstack/identity.rb +5 -2
 - data/lib/fog/openstack/models/compute/images.rb +2 -1
 - data/lib/fog/openstack/models/compute/metadata.rb +4 -5
 - data/lib/fog/openstack/models/compute/server.rb +36 -21
 - data/lib/fog/openstack/models/identity/role.rb +1 -1
 - data/lib/fog/openstack/models/network/floating_ip.rb +1 -1
 - data/lib/fog/openstack/models/network/floating_ips.rb +2 -2
 - data/lib/fog/openstack/models/network/network.rb +8 -0
 - data/lib/fog/openstack/models/storage/directories.rb +39 -0
 - data/lib/fog/openstack/models/storage/directory.rb +50 -0
 - data/lib/fog/openstack/models/storage/file.rb +150 -0
 - data/lib/fog/openstack/models/storage/files.rb +94 -0
 - data/lib/fog/openstack/requests/compute/allocate_address.rb +1 -1
 - data/lib/fog/openstack/requests/compute/delete_meta.rb +43 -0
 - data/lib/fog/openstack/requests/compute/get_limits.rb +1 -1
 - data/lib/fog/openstack/requests/compute/get_snapshot_details.rb +1 -1
 - data/lib/fog/openstack/requests/compute/get_volume_details.rb +1 -1
 - data/lib/fog/openstack/requests/compute/list_servers.rb +1 -1
 - data/lib/fog/openstack/requests/compute/list_tenants.rb +1 -0
 - data/lib/fog/openstack/requests/compute/remove_fixed_ip.rb +1 -1
 - data/lib/fog/openstack/requests/compute/update_meta.rb +46 -0
 - data/lib/fog/openstack/requests/compute/update_server.rb +1 -1
 - data/lib/fog/openstack/requests/identity/delete_user_role.rb +2 -2
 - data/lib/fog/openstack/requests/identity/get_user_by_name.rb +2 -2
 - data/lib/fog/openstack/requests/image/create_image.rb +1 -1
 - data/lib/fog/openstack/requests/network/associate_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/create_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/delete_floating_ip.rb +1 -1
 - data/lib/fog/openstack/requests/network/disassociate_floating_ip.rb +3 -3
 - data/lib/fog/openstack/requests/network/get_floating_ip.rb +1 -1
 - data/lib/fog/openstack/requests/network/list_floating_ips.rb +1 -1
 - data/lib/fog/openstack/requests/storage/copy_object.rb +27 -0
 - data/lib/fog/openstack/requests/storage/delete_container.rb +22 -0
 - data/lib/fog/openstack/requests/storage/delete_object.rb +23 -0
 - data/lib/fog/openstack/requests/storage/get_container.rb +44 -0
 - data/lib/fog/openstack/requests/storage/get_containers.rb +33 -0
 - data/lib/fog/openstack/requests/storage/get_object.rb +29 -0
 - data/lib/fog/openstack/requests/storage/get_object_https_url.rb +51 -0
 - data/lib/fog/openstack/requests/storage/head_container.rb +28 -0
 - data/lib/fog/openstack/requests/storage/head_containers.rb +25 -0
 - data/lib/fog/openstack/requests/storage/head_object.rb +23 -0
 - data/lib/fog/openstack/requests/storage/post_set_meta_temp_url_key.rb +37 -0
 - data/lib/fog/openstack/requests/storage/put_container.rb +22 -0
 - data/lib/fog/openstack/requests/storage/put_object.rb +30 -0
 - data/lib/fog/openstack/requests/storage/put_object_manifest.rb +25 -0
 - data/lib/fog/openstack/storage.rb +159 -0
 - data/lib/fog/openstack/volume.rb +4 -2
 - data/lib/fog/ovirt/compute.rb +1 -0
 - data/lib/fog/ovirt/models/compute/server.rb +2 -2
 - data/lib/fog/ovirt/models/compute/volume.rb +1 -0
 - data/lib/fog/ovirt/requests/compute/get_api_version.rb +16 -0
 - data/lib/fog/providers.rb +2 -1
 - data/lib/fog/rackspace/block_storage.rb +1 -0
 - data/lib/fog/rackspace/cdn.rb +61 -7
 - data/lib/fog/rackspace/compute_v2.rb +16 -3
 - data/lib/fog/rackspace/databases.rb +4 -3
 - data/lib/fog/rackspace/docs/compute_v2.md +663 -0
 - data/lib/fog/rackspace/docs/getting_started.md +9 -9
 - data/lib/fog/rackspace/examples/README.md +47 -0
 - data/lib/fog/rackspace/examples/compute_v2/README.md +47 -0
 - data/lib/fog/rackspace/examples/compute_v2/create_image.rb +61 -0
 - data/lib/fog/rackspace/examples/compute_v2/create_server.rb +89 -0
 - data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +61 -0
 - data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +56 -0
 - data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +93 -0
 - data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +106 -0
 - data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +69 -0
 - data/lib/fog/rackspace/examples/compute_v2/server_metadata.rb +85 -0
 - data/lib/fog/rackspace/identity.rb +1 -1
 - data/lib/fog/rackspace/load_balancers.rb +2 -2
 - data/lib/fog/rackspace/mock_data.rb +114 -96
 - data/lib/fog/rackspace/models/compute_v2/attachment.rb +16 -0
 - data/lib/fog/rackspace/models/compute_v2/attachments.rb +6 -0
 - data/lib/fog/rackspace/models/compute_v2/flavor.rb +18 -0
 - data/lib/fog/rackspace/models/compute_v2/flavors.rb +9 -1
 - data/lib/fog/rackspace/models/compute_v2/image.rb +52 -7
 - data/lib/fog/rackspace/models/compute_v2/images.rb +9 -0
 - data/lib/fog/rackspace/models/compute_v2/meta_parent.rb +9 -0
 - data/lib/fog/rackspace/models/compute_v2/metadata.rb +30 -7
 - data/lib/fog/rackspace/models/compute_v2/metadatum.rb +4 -0
 - data/lib/fog/rackspace/models/compute_v2/network.rb +27 -0
 - data/lib/fog/rackspace/models/compute_v2/networks.rb +23 -0
 - data/lib/fog/rackspace/models/compute_v2/server.rb +235 -24
 - data/lib/fog/rackspace/models/compute_v2/servers.rb +19 -1
 - data/lib/fog/rackspace/models/dns/zones.rb +35 -2
 - data/lib/fog/rackspace/models/identity/credentials.rb +3 -2
 - data/lib/fog/rackspace/models/storage/account.rb +24 -0
 - data/lib/fog/rackspace/models/storage/directories.rb +3 -0
 - data/lib/fog/rackspace/models/storage/directory.rb +68 -39
 - data/lib/fog/rackspace/models/storage/file.rb +38 -67
 - data/lib/fog/rackspace/models/storage/files.rb +11 -4
 - data/lib/fog/rackspace/models/storage/metadata.rb +129 -0
 - data/lib/fog/rackspace/requests/cdn/delete_object.rb +37 -0
 - data/lib/fog/rackspace/requests/cdn/get_containers.rb +34 -0
 - data/lib/fog/rackspace/requests/cdn/head_container.rb +24 -0
 - data/lib/fog/rackspace/requests/cdn/post_container.rb +21 -0
 - data/lib/fog/rackspace/requests/cdn/put_container.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +13 -0
 - data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +7 -0
 - data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/create_image.rb +9 -5
 - data/lib/fog/rackspace/requests/compute_v2/create_network.rb +36 -0
 - data/lib/fog/rackspace/requests/compute_v2/create_server.rb +38 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +2 -4
 - data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +6 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_network.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +4 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +14 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_image.rb +18 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_network.rb +21 -0
 - data/lib/fog/rackspace/requests/compute_v2/get_server.rb +32 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +12 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_images.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +8 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_networks.rb +18 -0
 - data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +31 -0
 - data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +5 -0
 - data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +37 -0
 - data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +10 -0
 - data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +9 -0
 - data/lib/fog/rackspace/requests/compute_v2/update_server.rb +9 -0
 - data/lib/fog/rackspace/requests/storage/get_object.rb +0 -1
 - data/lib/fog/rackspace/requests/storage/put_container.rb +2 -1
 - data/lib/fog/rackspace/storage.rb +14 -2
 - data/lib/fog/schema/data_validator.rb +154 -0
 - data/lib/fog/storage.rb +8 -24
 - data/lib/fog/terremark/models/shared/server.rb +5 -3
 - data/lib/fog/terremark/parser.rb +14 -13
 - data/lib/fog/terremark/parsers/shared/get_catalog.rb +5 -19
 - data/lib/fog/terremark/parsers/shared/get_catalog_item.rb +4 -14
 - data/lib/fog/terremark/parsers/shared/get_internet_services.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_keys_list.rb +4 -18
 - data/lib/fog/terremark/parsers/shared/get_network_ips.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_node_services.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_organization.rb +4 -3
 - data/lib/fog/terremark/parsers/shared/get_organizations.rb +3 -2
 - data/lib/fog/terremark/parsers/shared/get_public_ips.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/get_tasks_list.rb +4 -17
 - data/lib/fog/terremark/parsers/shared/get_vapp_template.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/get_vdc.rb +6 -38
 - data/lib/fog/terremark/parsers/shared/instantiate_vapp_template.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/internet_service.rb +2 -5
 - data/lib/fog/terremark/parsers/shared/network.rb +3 -11
 - data/lib/fog/terremark/parsers/shared/node_service.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/public_ip.rb +1 -1
 - data/lib/fog/terremark/parsers/shared/task.rb +3 -14
 - data/lib/fog/terremark/parsers/shared/vapp.rb +3 -14
 - data/lib/fog/vcloud/compute.rb +1 -0
 - data/lib/fog/vcloud/models/compute/server.rb +15 -2
 - data/lib/fog/vcloud/models/compute/vapp.rb +11 -0
 - data/lib/fog/vcloud/requests/compute/configure_vm_network.rb +37 -0
 - data/lib/fog/vcloud/requests/compute/instantiate_vapp_template.rb +8 -4
 - data/lib/fog/version.rb +1 -1
 - data/lib/fog/volume.rb +6 -6
 - data/lib/fog/vsphere/requests/compute/create_vm.rb +18 -3
 - data/lib/fog/vsphere/requests/compute/list_vm_interfaces.rb +1 -1
 - data/lib/fog/vsphere/requests/compute/vm_reconfig_hardware.rb +1 -1
 - data/tests/aws/models/data_pipeline/pipeline_tests.rb +8 -0
 - data/tests/aws/models/data_pipeline/pipelines_tests.rb +8 -0
 - data/tests/aws/models/rds/server_tests.rb +10 -9
 - data/tests/aws/requests/compute/image_tests.rb +2 -2
 - data/tests/aws/requests/compute/security_group_tests.rb +1 -1
 - data/tests/aws/requests/compute/spot_instance_tests.rb +3 -2
 - data/tests/aws/requests/data_pipeline/helper.rb +44 -0
 - data/tests/aws/requests/data_pipeline/pipeline_tests.rb +54 -0
 - data/tests/aws/requests/rds/instance_tests.rb +8 -5
 - data/tests/bluebox/requests/blb/helper.rb +64 -0
 - data/tests/bluebox/requests/blb/lb_tests.rb +75 -0
 - data/tests/brightbox/requests/compute/firewall_policy_tests.rb +7 -0
 - data/tests/brightbox/requests/compute/helper.rb +4 -2
 - data/tests/compute/helper.rb +8 -0
 - data/tests/core/user_agent_tests.rb +6 -0
 - data/tests/dreamhost/README.md +56 -0
 - data/tests/dreamhost/dns_tests.rb +20 -0
 - data/tests/dreamhost/helper.rb +19 -0
 - data/tests/dreamhost/models/dns/record_tests.rb +73 -0
 - data/tests/dreamhost/models/dns/records_tests.rb +29 -0
 - data/tests/dreamhost/models/dns/zone_tests.rb +62 -0
 - data/tests/dreamhost/models/dns/zones_tests.rb +29 -0
 - data/tests/dreamhost/requests/dns/create_record_tests.rb +39 -0
 - data/tests/dreamhost/requests/dns/delete_record_tests.rb +26 -0
 - data/tests/dreamhost/requests/dns/list_records_tests.rb +31 -0
 - data/tests/glesys/requests/compute/helper.rb +5 -5
 - data/tests/helper.rb +1 -1
 - data/tests/helpers/formats_helper.rb +63 -50
 - data/tests/helpers/formats_helper_tests.rb +87 -36
 - data/tests/helpers/mock_helper.rb +4 -1
 - data/tests/helpers/schema_validator_tests.rb +107 -0
 - data/tests/hp/models/block_storage/bootable_volume_tests.rb +23 -0
 - data/tests/hp/models/block_storage/snapshot_tests.rb +23 -0
 - data/tests/hp/models/block_storage/volume_tests.rb +21 -0
 - data/tests/hp/models/compute/address_tests.rb +1 -1
 - data/tests/hp/models/compute/addresses_tests.rb +1 -1
 - data/tests/hp/models/compute/key_pair_tests.rb +1 -1
 - data/tests/hp/models/compute/key_pairs_tests.rb +1 -1
 - data/tests/hp/models/compute/metadata_image_tests.rb +60 -0
 - data/tests/hp/models/compute/metadata_server_tests.rb +54 -0
 - data/tests/hp/models/compute/security_group_tests.rb +3 -1
 - data/tests/hp/models/compute/security_groups_tests.rb +1 -1
 - data/tests/hp/models/storage/directories_tests.rb +23 -0
 - data/tests/hp/models/storage/directory_tests.rb +62 -0
 - data/tests/hp/models/storage/file_tests.rb +44 -0
 - data/tests/hp/models/storage/files_tests.rb +38 -0
 - data/tests/hp/requests/block_storage/bootable_volume_tests.rb +78 -0
 - data/tests/hp/requests/block_storage/snapshot_tests.rb +56 -0
 - data/tests/hp/requests/block_storage/volume_tests.rb +94 -0
 - data/tests/hp/requests/cdn/container_tests.rb +1 -1
 - data/tests/hp/requests/compute/address_tests.rb +5 -6
 - data/tests/hp/requests/compute/flavor_tests.rb +1 -1
 - data/tests/hp/requests/compute/image_tests.rb +1 -1
 - data/tests/hp/requests/compute/key_pair_tests.rb +1 -1
 - data/tests/hp/requests/compute/metadata_tests.rb +70 -0
 - data/tests/hp/requests/compute/persistent_server_tests.rb +66 -0
 - data/tests/hp/requests/compute/security_group_rule_tests.rb +1 -1
 - data/tests/hp/requests/compute/security_group_tests.rb +1 -1
 - data/tests/hp/requests/compute/server_address_tests.rb +1 -1
 - data/tests/hp/requests/compute/server_tests.rb +5 -6
 - data/tests/hp/requests/compute/server_volume_tests.rb +76 -0
 - data/tests/hp/requests/storage/container_tests.rb +1 -1
 - data/tests/hp/requests/storage/object_tests.rb +9 -1
 - data/tests/hp/user_agent_tests.rb +13 -0
 - data/tests/internet_archive/models/storage/directory_tests.rb +51 -0
 - data/tests/internet_archive/models/storage/file_tests.rb +80 -0
 - data/tests/internet_archive/models/storage/files_tests.rb +56 -0
 - data/tests/internet_archive/models/storage/url_tests.rb +28 -0
 - data/tests/internet_archive/models/storage/version_tests.rb +52 -0
 - data/tests/internet_archive/models/storage/versions_tests.rb +56 -0
 - data/tests/internet_archive/requests/storage/acl_utils_tests.rb +209 -0
 - data/tests/internet_archive/requests/storage/bucket_tests.rb +328 -0
 - data/tests/internet_archive/requests/storage/cors_utils_tests.rb +108 -0
 - data/tests/internet_archive/requests/storage/multipart_upload_tests.rb +132 -0
 - data/tests/internet_archive/requests/storage/object_tests.rb +166 -0
 - data/tests/internet_archive/requests/storage/versioning_tests.rb +258 -0
 - data/tests/internet_archive/signaturev4_tests.rb +41 -0
 - data/tests/internet_archive/signed_params_tests.rb +5 -0
 - data/tests/openstack/models/compute/images_tests.rb +14 -0
 - data/tests/openstack/models/compute/server_tests.rb +42 -1
 - data/tests/openstack/models/identity/roles_tests.rb +1 -0
 - data/tests/openstack/models/identity/user_tests.rb +2 -2
 - data/tests/openstack/models/network/network_tests.rb +21 -1
 - data/tests/openstack/models/storage/file_tests.rb +178 -0
 - data/tests/openstack/requests/compute/limit_tests.rb +1 -1
 - data/tests/openstack/requests/compute/tenant_tests.rb +2 -2
 - data/tests/openstack/requests/identity/ec2_credentials_tests.rb +7 -4
 - data/tests/openstack/requests/identity/helper.rb +17 -0
 - data/tests/openstack/requests/identity/role_tests.rb +6 -0
 - data/tests/openstack/requests/identity/tenant_tests.rb +14 -12
 - data/tests/openstack/requests/identity/user_tests.rb +9 -5
 - data/tests/openstack/requests/storage/container_tests.rb +64 -0
 - data/tests/openstack/requests/storage/large_object_tests.rb +47 -0
 - data/tests/openstack/requests/storage/object_tests.rb +84 -0
 - data/tests/openstack/volume_tests.rb +15 -0
 - data/tests/rackspace/cdn_tests.rb +78 -0
 - data/tests/rackspace/helper.rb +9 -0
 - data/tests/rackspace/models/compute_v2/flavors_tests.rb +1 -1
 - data/tests/rackspace/models/compute_v2/image_tests.rb +2 -4
 - data/tests/rackspace/models/compute_v2/images_tests.rb +1 -1
 - data/tests/rackspace/models/compute_v2/metadata_tests.rb +5 -3
 - data/tests/rackspace/models/compute_v2/network_tests.rb +10 -0
 - data/tests/rackspace/models/compute_v2/networks_tests.rb +10 -0
 - data/tests/rackspace/models/compute_v2/server_tests.rb +8 -7
 - data/tests/rackspace/models/compute_v2/servers_tests.rb +5 -7
 - data/tests/rackspace/models/dns/zones_tests.rb +22 -0
 - data/tests/rackspace/models/identity/credentials_tests.rb +14 -5
 - data/tests/rackspace/models/storage/account_tests.rb +28 -0
 - data/tests/rackspace/models/storage/directories_tests.rb +29 -0
 - data/tests/rackspace/models/storage/directory_tests.rb +141 -0
 - data/tests/rackspace/models/storage/file_tests.rb +86 -11
 - data/tests/rackspace/models/storage/metadata_tests.rb +174 -0
 - data/tests/rackspace/requests/cdn/cdn_tests.rb +76 -0
 - data/tests/rackspace/requests/compute/image_tests.rb +2 -2
 - data/tests/rackspace/requests/compute_v2/image_tests.rb +6 -6
 - data/tests/rackspace/requests/compute_v2/network_tests.rb +49 -0
 - data/tests/rackspace/requests/identity/user_tests.rb +0 -4
 - data/tests/rackspace/requests/storage/container_tests.rb +8 -1
 - data/tests/rackspace/storage_tests.rb +8 -0
 - data/tests/storage/helper.rb +3 -0
 - metadata +341 -40
 - data/docs/storage/aws.markdown +0 -21
 - data/lib/fog/bin/virtual_box.rb +0 -57
 - data/lib/fog/rackspace/docs/cloud_servers.md +0 -65
 - data/lib/fog/rackspace/requests/identity/get_credentials.rb +0 -15
 - data/lib/fog/virtual_box.rb +0 -11
 - data/lib/fog/virtual_box/compute.rb +0 -59
 - data/lib/fog/virtual_box/models/compute/medium.rb +0 -87
 - data/lib/fog/virtual_box/models/compute/medium_format.rb +0 -34
 - data/lib/fog/virtual_box/models/compute/mediums.rb +0 -32
 - data/lib/fog/virtual_box/models/compute/nat_engine.rb +0 -65
 - data/lib/fog/virtual_box/models/compute/nat_redirect.rb +0 -91
 - data/lib/fog/virtual_box/models/compute/nat_redirects.rb +0 -41
 - data/lib/fog/virtual_box/models/compute/network_adapter.rb +0 -82
 - data/lib/fog/virtual_box/models/compute/network_adapters.rb +0 -42
 - data/lib/fog/virtual_box/models/compute/server.rb +0 -199
 - data/lib/fog/virtual_box/models/compute/servers.rb +0 -41
 - data/lib/fog/virtual_box/models/compute/storage_controller.rb +0 -83
 - data/lib/fog/virtual_box/models/compute/storage_controllers.rb +0 -38
 
| 
         @@ -0,0 +1,43 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            require 'fog/core/collection'
         
     | 
| 
      
 2 
     | 
    
         
            +
            require 'fog/internet_archive/models/storage/directory'
         
     | 
| 
      
 3 
     | 
    
         
            +
             
     | 
| 
      
 4 
     | 
    
         
            +
            module Fog
         
     | 
| 
      
 5 
     | 
    
         
            +
              module Storage
         
     | 
| 
      
 6 
     | 
    
         
            +
                class InternetArchive
         
     | 
| 
      
 7 
     | 
    
         
            +
             
     | 
| 
      
 8 
     | 
    
         
            +
                  class Directories < Fog::Collection
         
     | 
| 
      
 9 
     | 
    
         
            +
             
     | 
| 
      
 10 
     | 
    
         
            +
                    model Fog::Storage::InternetArchive::Directory
         
     | 
| 
      
 11 
     | 
    
         
            +
             
     | 
| 
      
 12 
     | 
    
         
            +
                    def all
         
     | 
| 
      
 13 
     | 
    
         
            +
                      data = service.get_service.body['Buckets']
         
     | 
| 
      
 14 
     | 
    
         
            +
                      load(data)
         
     | 
| 
      
 15 
     | 
    
         
            +
                    end
         
     | 
| 
      
 16 
     | 
    
         
            +
             
     | 
| 
      
 17 
     | 
    
         
            +
                    def get(key, options = {})
         
     | 
| 
      
 18 
     | 
    
         
            +
                      remap_attributes(options, {
         
     | 
| 
      
 19 
     | 
    
         
            +
                        :delimiter  => 'delimiter',
         
     | 
| 
      
 20 
     | 
    
         
            +
                        :marker     => 'marker',
         
     | 
| 
      
 21 
     | 
    
         
            +
                        :max_keys   => 'max-keys',
         
     | 
| 
      
 22 
     | 
    
         
            +
                        :prefix     => 'prefix'
         
     | 
| 
      
 23 
     | 
    
         
            +
                      })
         
     | 
| 
      
 24 
     | 
    
         
            +
                      data = service.get_bucket(key, options).body
         
     | 
| 
      
 25 
     | 
    
         
            +
                      directory = new(:key => data['Name'])
         
     | 
| 
      
 26 
     | 
    
         
            +
                      options = {}
         
     | 
| 
      
 27 
     | 
    
         
            +
                      for k, v in data
         
     | 
| 
      
 28 
     | 
    
         
            +
                        if ['CommonPrefixes', 'Delimiter', 'IsTruncated', 'Marker', 'MaxKeys', 'Prefix'].include?(k)
         
     | 
| 
      
 29 
     | 
    
         
            +
                          options[k] = v
         
     | 
| 
      
 30 
     | 
    
         
            +
                        end
         
     | 
| 
      
 31 
     | 
    
         
            +
                      end
         
     | 
| 
      
 32 
     | 
    
         
            +
                      directory.files.merge_attributes(options)
         
     | 
| 
      
 33 
     | 
    
         
            +
                      directory.files.load(data['Contents'])
         
     | 
| 
      
 34 
     | 
    
         
            +
                      directory
         
     | 
| 
      
 35 
     | 
    
         
            +
                    rescue Excon::Errors::NotFound
         
     | 
| 
      
 36 
     | 
    
         
            +
                      nil
         
     | 
| 
      
 37 
     | 
    
         
            +
                    end
         
     | 
| 
      
 38 
     | 
    
         
            +
             
     | 
| 
      
 39 
     | 
    
         
            +
                  end
         
     | 
| 
      
 40 
     | 
    
         
            +
             
     | 
| 
      
 41 
     | 
    
         
            +
                end
         
     | 
| 
      
 42 
     | 
    
         
            +
              end
         
     | 
| 
      
 43 
     | 
    
         
            +
            end
         
     | 
| 
         @@ -0,0 +1,126 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            require 'fog/core/model'
         
     | 
| 
      
 2 
     | 
    
         
            +
            require 'fog/internet_archive/models/storage/files'
         
     | 
| 
      
 3 
     | 
    
         
            +
            require 'fog/internet_archive/models/storage/versions'
         
     | 
| 
      
 4 
     | 
    
         
            +
             
     | 
| 
      
 5 
     | 
    
         
            +
            module Fog
         
     | 
| 
      
 6 
     | 
    
         
            +
              module Storage
         
     | 
| 
      
 7 
     | 
    
         
            +
                class InternetArchive
         
     | 
| 
      
 8 
     | 
    
         
            +
             
     | 
| 
      
 9 
     | 
    
         
            +
                  class Directory < Fog::Model
         
     | 
| 
      
 10 
     | 
    
         
            +
                    VALID_ACLS = ['private', 'public-read', 'public-read-write', 'authenticated-read']
         
     | 
| 
      
 11 
     | 
    
         
            +
             
     | 
| 
      
 12 
     | 
    
         
            +
                    # See http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTBucketPUT.html
         
     | 
| 
      
 13 
     | 
    
         
            +
                    INVALID_LOCATIONS = ['us-east-1']
         
     | 
| 
      
 14 
     | 
    
         
            +
             
     | 
| 
      
 15 
     | 
    
         
            +
                    attr_reader :acl
         
     | 
| 
      
 16 
     | 
    
         
            +
             
     | 
| 
      
 17 
     | 
    
         
            +
                    identity  :key,           :aliases => ['Name', 'name']
         
     | 
| 
      
 18 
     | 
    
         
            +
             
     | 
| 
      
 19 
     | 
    
         
            +
                    attribute :creation_date, :aliases => 'CreationDate'
         
     | 
| 
      
 20 
     | 
    
         
            +
             
     | 
| 
      
 21 
     | 
    
         
            +
                    def acl=(new_acl)
         
     | 
| 
      
 22 
     | 
    
         
            +
                      unless VALID_ACLS.include?(new_acl)
         
     | 
| 
      
 23 
     | 
    
         
            +
                        raise ArgumentError.new("acl must be one of [#{VALID_ACLS.join(', ')}]")
         
     | 
| 
      
 24 
     | 
    
         
            +
                      else
         
     | 
| 
      
 25 
     | 
    
         
            +
                        @acl = new_acl
         
     | 
| 
      
 26 
     | 
    
         
            +
                      end
         
     | 
| 
      
 27 
     | 
    
         
            +
                    end
         
     | 
| 
      
 28 
     | 
    
         
            +
             
     | 
| 
      
 29 
     | 
    
         
            +
                    def destroy
         
     | 
| 
      
 30 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 31 
     | 
    
         
            +
                      service.delete_bucket(key)
         
     | 
| 
      
 32 
     | 
    
         
            +
                      true
         
     | 
| 
      
 33 
     | 
    
         
            +
                    rescue Excon::Errors::NotFound
         
     | 
| 
      
 34 
     | 
    
         
            +
                      false
         
     | 
| 
      
 35 
     | 
    
         
            +
                    end
         
     | 
| 
      
 36 
     | 
    
         
            +
             
     | 
| 
      
 37 
     | 
    
         
            +
                    def location
         
     | 
| 
      
 38 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 39 
     | 
    
         
            +
                      attributes[:location] || bucket_location || self.service.region
         
     | 
| 
      
 40 
     | 
    
         
            +
                    end
         
     | 
| 
      
 41 
     | 
    
         
            +
             
     | 
| 
      
 42 
     | 
    
         
            +
                    def location=(new_location)
         
     | 
| 
      
 43 
     | 
    
         
            +
                      if INVALID_LOCATIONS.include?(new_location)
         
     | 
| 
      
 44 
     | 
    
         
            +
                        raise ArgumentError, "location must not include any of #{INVALID_LOCATIONS.join(', ')}. See http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTBucketPUT.html"
         
     | 
| 
      
 45 
     | 
    
         
            +
                      else
         
     | 
| 
      
 46 
     | 
    
         
            +
                        merge_attributes(:location => new_location)
         
     | 
| 
      
 47 
     | 
    
         
            +
                      end
         
     | 
| 
      
 48 
     | 
    
         
            +
                    end
         
     | 
| 
      
 49 
     | 
    
         
            +
             
     | 
| 
      
 50 
     | 
    
         
            +
                    def files
         
     | 
| 
      
 51 
     | 
    
         
            +
                      @files ||= Fog::Storage::InternetArchive::Files.new(:directory => self, :service => service)
         
     | 
| 
      
 52 
     | 
    
         
            +
                    end
         
     | 
| 
      
 53 
     | 
    
         
            +
             
     | 
| 
      
 54 
     | 
    
         
            +
                    def payer
         
     | 
| 
      
 55 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 56 
     | 
    
         
            +
                      data = service.get_request_payment(key)
         
     | 
| 
      
 57 
     | 
    
         
            +
                      data.body['Payer']
         
     | 
| 
      
 58 
     | 
    
         
            +
                    end
         
     | 
| 
      
 59 
     | 
    
         
            +
             
     | 
| 
      
 60 
     | 
    
         
            +
                    def payer=(new_payer)
         
     | 
| 
      
 61 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 62 
     | 
    
         
            +
                      service.put_request_payment(key, new_payer)
         
     | 
| 
      
 63 
     | 
    
         
            +
                      @payer = new_payer
         
     | 
| 
      
 64 
     | 
    
         
            +
                    end
         
     | 
| 
      
 65 
     | 
    
         
            +
             
     | 
| 
      
 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 
     | 
    
         
            +
                    def public=(new_public)
         
     | 
| 
      
 82 
     | 
    
         
            +
                      self.acl = new_public ? 'public-read' : 'private'
         
     | 
| 
      
 83 
     | 
    
         
            +
                      new_public
         
     | 
| 
      
 84 
     | 
    
         
            +
                    end
         
     | 
| 
      
 85 
     | 
    
         
            +
             
     | 
| 
      
 86 
     | 
    
         
            +
                    def public_url
         
     | 
| 
      
 87 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 88 
     | 
    
         
            +
                      if service.get_bucket_acl(key).body['AccessControlList'].detect {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'}
         
     | 
| 
      
 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
         
     | 
| 
      
 97 
     | 
    
         
            +
                    end
         
     | 
| 
      
 98 
     | 
    
         
            +
             
     | 
| 
      
 99 
     | 
    
         
            +
                    def save
         
     | 
| 
      
 100 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 101 
     | 
    
         
            +
             
     | 
| 
      
 102 
     | 
    
         
            +
                      options = {}
         
     | 
| 
      
 103 
     | 
    
         
            +
             
     | 
| 
      
 104 
     | 
    
         
            +
                      options['x-amz-acl'] = acl if acl
         
     | 
| 
      
 105 
     | 
    
         
            +
             
     | 
| 
      
 106 
     | 
    
         
            +
                      if location = attributes[:location] || (self.service.region != 'us-east-1' && self.service.region)
         
     | 
| 
      
 107 
     | 
    
         
            +
                        options['LocationConstraint'] = location
         
     | 
| 
      
 108 
     | 
    
         
            +
                      end
         
     | 
| 
      
 109 
     | 
    
         
            +
             
     | 
| 
      
 110 
     | 
    
         
            +
                      service.put_bucket(key, options)
         
     | 
| 
      
 111 
     | 
    
         
            +
             
     | 
| 
      
 112 
     | 
    
         
            +
                      true
         
     | 
| 
      
 113 
     | 
    
         
            +
                    end
         
     | 
| 
      
 114 
     | 
    
         
            +
             
     | 
| 
      
 115 
     | 
    
         
            +
                    private
         
     | 
| 
      
 116 
     | 
    
         
            +
             
     | 
| 
      
 117 
     | 
    
         
            +
                    def bucket_location
         
     | 
| 
      
 118 
     | 
    
         
            +
                      data = service.get_bucket_location(key)
         
     | 
| 
      
 119 
     | 
    
         
            +
                      data.body['LocationConstraint']
         
     | 
| 
      
 120 
     | 
    
         
            +
                    end
         
     | 
| 
      
 121 
     | 
    
         
            +
             
     | 
| 
      
 122 
     | 
    
         
            +
                  end
         
     | 
| 
      
 123 
     | 
    
         
            +
             
     | 
| 
      
 124 
     | 
    
         
            +
                end
         
     | 
| 
      
 125 
     | 
    
         
            +
              end
         
     | 
| 
      
 126 
     | 
    
         
            +
            end
         
     | 
| 
         @@ -0,0 +1,286 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            require 'fog/core/model'
         
     | 
| 
      
 2 
     | 
    
         
            +
            require 'fog/internet_archive/models/storage/versions'
         
     | 
| 
      
 3 
     | 
    
         
            +
             
     | 
| 
      
 4 
     | 
    
         
            +
            module Fog
         
     | 
| 
      
 5 
     | 
    
         
            +
              module Storage
         
     | 
| 
      
 6 
     | 
    
         
            +
                class InternetArchive
         
     | 
| 
      
 7 
     | 
    
         
            +
             
     | 
| 
      
 8 
     | 
    
         
            +
                  class File < Fog::Model
         
     | 
| 
      
 9 
     | 
    
         
            +
                    # @see AWS Object docs http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectOps.html 
         
     | 
| 
      
 10 
     | 
    
         
            +
             
     | 
| 
      
 11 
     | 
    
         
            +
                    identity  :key,             :aliases => 'Key'
         
     | 
| 
      
 12 
     | 
    
         
            +
             
     | 
| 
      
 13 
     | 
    
         
            +
                    attr_writer :body
         
     | 
| 
      
 14 
     | 
    
         
            +
                    attribute :cache_control,       :aliases => 'Cache-Control'
         
     | 
| 
      
 15 
     | 
    
         
            +
                    attribute :content_disposition, :aliases => 'Content-Disposition'
         
     | 
| 
      
 16 
     | 
    
         
            +
                    attribute :content_encoding,    :aliases => 'Content-Encoding'
         
     | 
| 
      
 17 
     | 
    
         
            +
                    attribute :content_length,      :aliases => ['Content-Length', 'Size'], :type => :integer
         
     | 
| 
      
 18 
     | 
    
         
            +
                    attribute :content_md5,         :aliases => 'Content-MD5'
         
     | 
| 
      
 19 
     | 
    
         
            +
                    attribute :content_type,        :aliases => 'Content-Type'
         
     | 
| 
      
 20 
     | 
    
         
            +
                    attribute :etag,                :aliases => ['Etag', 'ETag']
         
     | 
| 
      
 21 
     | 
    
         
            +
                    attribute :expires,             :aliases => 'Expires'
         
     | 
| 
      
 22 
     | 
    
         
            +
                    attribute :last_modified,       :aliases => ['Last-Modified', 'LastModified']
         
     | 
| 
      
 23 
     | 
    
         
            +
                    attribute :metadata
         
     | 
| 
      
 24 
     | 
    
         
            +
                    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 
     | 
    
         
            +
             
     | 
| 
      
 33 
     | 
    
         
            +
             
     | 
| 
      
 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 
     | 
    
         
            +
                    def acl=(new_acl)
         
     | 
| 
      
 42 
     | 
    
         
            +
                      valid_acls = ['private', 'public-read', 'public-read-write', 'authenticated-read']
         
     | 
| 
      
 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
         
     | 
| 
      
 47 
     | 
    
         
            +
                    end
         
     | 
| 
      
 48 
     | 
    
         
            +
             
     | 
| 
      
 49 
     | 
    
         
            +
             
     | 
| 
      
 50 
     | 
    
         
            +
                    # Get file's body if exists, else ' '.
         
     | 
| 
      
 51 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 52 
     | 
    
         
            +
                    # @return [File]
         
     | 
| 
      
 53 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 54 
     | 
    
         
            +
                    def body
         
     | 
| 
      
 55 
     | 
    
         
            +
                      attributes[:body] ||= if last_modified && (file = collection.get(identity))
         
     | 
| 
      
 56 
     | 
    
         
            +
                        file.body
         
     | 
| 
      
 57 
     | 
    
         
            +
                      else
         
     | 
| 
      
 58 
     | 
    
         
            +
                        ''
         
     | 
| 
      
 59 
     | 
    
         
            +
                      end
         
     | 
| 
      
 60 
     | 
    
         
            +
                    end
         
     | 
| 
      
 61 
     | 
    
         
            +
             
     | 
| 
      
 62 
     | 
    
         
            +
             
     | 
| 
      
 63 
     | 
    
         
            +
                    # Set body attribute.
         
     | 
| 
      
 64 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 65 
     | 
    
         
            +
                    # @param [File] new_body
         
     | 
| 
      
 66 
     | 
    
         
            +
                    # @return [File] attributes[:body]
         
     | 
| 
      
 67 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 68 
     | 
    
         
            +
                    def body=(new_body)
         
     | 
| 
      
 69 
     | 
    
         
            +
                      attributes[:body] = new_body
         
     | 
| 
      
 70 
     | 
    
         
            +
                    end
         
     | 
| 
      
 71 
     | 
    
         
            +
             
     | 
| 
      
 72 
     | 
    
         
            +
             
     | 
| 
      
 73 
     | 
    
         
            +
                    # Get the file instance's directory.
         
     | 
| 
      
 74 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 75 
     | 
    
         
            +
                    # @return [Fog::InternetArchive::Storage::Directory]
         
     | 
| 
      
 76 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 77 
     | 
    
         
            +
                    def directory
         
     | 
| 
      
 78 
     | 
    
         
            +
                      @directory
         
     | 
| 
      
 79 
     | 
    
         
            +
                    end
         
     | 
| 
      
 80 
     | 
    
         
            +
             
     | 
| 
      
 81 
     | 
    
         
            +
             
     | 
| 
      
 82 
     | 
    
         
            +
                    # Copy object from one bucket to other bucket.
         
     | 
| 
      
 83 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 84 
     | 
    
         
            +
                    #     required attributes: directory, key
         
     | 
| 
      
 85 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 86 
     | 
    
         
            +
                    # @param target_directory_key [String]
         
     | 
| 
      
 87 
     | 
    
         
            +
                    # @param target_file_key [String]
         
     | 
| 
      
 88 
     | 
    
         
            +
                    # @param options [Hash] options for copy_object method
         
     | 
| 
      
 89 
     | 
    
         
            +
                    # @return [String] Fog::InternetArchive::Files#head status of directory contents
         
     | 
| 
      
 90 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 91 
     | 
    
         
            +
                    def copy(target_directory_key, target_file_key, options = {})
         
     | 
| 
      
 92 
     | 
    
         
            +
                      requires :directory, :key
         
     | 
| 
      
 93 
     | 
    
         
            +
                      service.copy_object(directory.key, key, target_directory_key, target_file_key, options)
         
     | 
| 
      
 94 
     | 
    
         
            +
                      target_directory = service.directories.new(:key => target_directory_key)
         
     | 
| 
      
 95 
     | 
    
         
            +
                      target_directory.files.head(target_file_key)
         
     | 
| 
      
 96 
     | 
    
         
            +
                    end
         
     | 
| 
      
 97 
     | 
    
         
            +
             
     | 
| 
      
 98 
     | 
    
         
            +
             
     | 
| 
      
 99 
     | 
    
         
            +
                    # Destroy file via http DELETE.
         
     | 
| 
      
 100 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 101 
     | 
    
         
            +
                    #     required attributes: directory, key
         
     | 
| 
      
 102 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 103 
     | 
    
         
            +
                    # @param options [Hash]
         
     | 
| 
      
 104 
     | 
    
         
            +
                    # @option options versionId []
         
     | 
| 
      
 105 
     | 
    
         
            +
                    # @return [Boolean] true if successful
         
     | 
| 
      
 106 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 107 
     | 
    
         
            +
                    def destroy(options = {})
         
     | 
| 
      
 108 
     | 
    
         
            +
                      requires :directory, :key
         
     | 
| 
      
 109 
     | 
    
         
            +
                      attributes[:body] = nil if options['versionId'] == version
         
     | 
| 
      
 110 
     | 
    
         
            +
                      service.delete_object(directory.key, key, options)
         
     | 
| 
      
 111 
     | 
    
         
            +
                      true
         
     | 
| 
      
 112 
     | 
    
         
            +
                    end
         
     | 
| 
      
 113 
     | 
    
         
            +
             
     | 
| 
      
 114 
     | 
    
         
            +
             
     | 
| 
      
 115 
     | 
    
         
            +
                    remove_method :metadata
         
     | 
| 
      
 116 
     | 
    
         
            +
                    def metadata
         
     | 
| 
      
 117 
     | 
    
         
            +
                      attributes.reject {|key, value| !(key.to_s =~ /^x-amz-/)}
         
     | 
| 
      
 118 
     | 
    
         
            +
                    end
         
     | 
| 
      
 119 
     | 
    
         
            +
             
     | 
| 
      
 120 
     | 
    
         
            +
             
     | 
| 
      
 121 
     | 
    
         
            +
                    remove_method :metadata=
         
     | 
| 
      
 122 
     | 
    
         
            +
                    def metadata=(new_metadata)
         
     | 
| 
      
 123 
     | 
    
         
            +
                      merge_attributes(new_metadata)
         
     | 
| 
      
 124 
     | 
    
         
            +
                    end
         
     | 
| 
      
 125 
     | 
    
         
            +
             
     | 
| 
      
 126 
     | 
    
         
            +
             
     | 
| 
      
 127 
     | 
    
         
            +
                    remove_method :owner=
         
     | 
| 
      
 128 
     | 
    
         
            +
                    def owner=(new_owner)
         
     | 
| 
      
 129 
     | 
    
         
            +
                      if new_owner
         
     | 
| 
      
 130 
     | 
    
         
            +
                        attributes[:owner] = {
         
     | 
| 
      
 131 
     | 
    
         
            +
                          :display_name => new_owner['DisplayName'],
         
     | 
| 
      
 132 
     | 
    
         
            +
                          :id           => new_owner['ID']
         
     | 
| 
      
 133 
     | 
    
         
            +
                        }
         
     | 
| 
      
 134 
     | 
    
         
            +
                      end
         
     | 
| 
      
 135 
     | 
    
         
            +
                    end
         
     | 
| 
      
 136 
     | 
    
         
            +
             
     | 
| 
      
 137 
     | 
    
         
            +
             
     | 
| 
      
 138 
     | 
    
         
            +
                    # Set Access-Control-List permissions.
         
     | 
| 
      
 139 
     | 
    
         
            +
                    #   
         
     | 
| 
      
 140 
     | 
    
         
            +
                    #     valid new_publics: public_read, private
         
     | 
| 
      
 141 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 142 
     | 
    
         
            +
                    # @param [String] new_public
         
     | 
| 
      
 143 
     | 
    
         
            +
                    # @return [String] new_puplic 
         
     | 
| 
      
 144 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 145 
     | 
    
         
            +
                    def public=(new_public)
         
     | 
| 
      
 146 
     | 
    
         
            +
                      if new_public
         
     | 
| 
      
 147 
     | 
    
         
            +
                        @acl = 'public-read'
         
     | 
| 
      
 148 
     | 
    
         
            +
                      else
         
     | 
| 
      
 149 
     | 
    
         
            +
                        @acl = 'private'
         
     | 
| 
      
 150 
     | 
    
         
            +
                      end
         
     | 
| 
      
 151 
     | 
    
         
            +
                      new_public
         
     | 
| 
      
 152 
     | 
    
         
            +
                    end
         
     | 
| 
      
 153 
     | 
    
         
            +
             
     | 
| 
      
 154 
     | 
    
         
            +
             
     | 
| 
      
 155 
     | 
    
         
            +
                    # Get pubically acessible url via http GET.
         
     | 
| 
      
 156 
     | 
    
         
            +
                    # Checks persmissions before creating. 
         
     | 
| 
      
 157 
     | 
    
         
            +
                    # Defaults to s3 subdomain or compliant bucket name
         
     | 
| 
      
 158 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 159 
     | 
    
         
            +
                    #     required attributes: directory, key
         
     | 
| 
      
 160 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 161 
     | 
    
         
            +
                    # @return [String] public url
         
     | 
| 
      
 162 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 163 
     | 
    
         
            +
                    def public_url
         
     | 
| 
      
 164 
     | 
    
         
            +
                      requires :directory, :key
         
     | 
| 
      
 165 
     | 
    
         
            +
                      if service.get_object_acl(directory.key, key).body['AccessControlList'].detect {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'}
         
     | 
| 
      
 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
         
     | 
| 
      
 174 
     | 
    
         
            +
                    end
         
     | 
| 
      
 175 
     | 
    
         
            +
             
     | 
| 
      
 176 
     | 
    
         
            +
                    # Save file with body as contents to directory.key with name key via http PUT
         
     | 
| 
      
 177 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 178 
     | 
    
         
            +
                    #   required attributes: body, directory, key
         
     | 
| 
      
 179 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 180 
     | 
    
         
            +
                    # @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 
     | 
    
         
            +
                    # @option options [String] cache_controle sets Cache-Control header. For example, 'No-cache'
         
     | 
| 
      
 183 
     | 
    
         
            +
                    # @option options [String] content_disposition sets Content-Disposition HTTP header. For exampple, 'attachment; filename=testing.txt'
         
     | 
| 
      
 184 
     | 
    
         
            +
                    # @option options [String] content_encoding sets Content-Encoding HTTP header. For example, 'x-gzip'
         
     | 
| 
      
 185 
     | 
    
         
            +
                    # @option options [String] content_md5 sets Content-MD5. For example, '79054025255fb1a26e4bc422aef54eb4'
         
     | 
| 
      
 186 
     | 
    
         
            +
                    # @option options [String] content_type Content-Type. For example, 'text/plain'
         
     | 
| 
      
 187 
     | 
    
         
            +
                    # @option options [String] expires sets number of seconds before AWS Object expires.
         
     | 
| 
      
 188 
     | 
    
         
            +
                    # @option options [String] storage_class sets x-amz-storage-class HTTP header. Defaults to 'STANDARD'. Or, 'REDUCED_REDUNDANCY'
         
     | 
| 
      
 189 
     | 
    
         
            +
                    # @option options [String] encryption sets HTTP encryption header. Set to 'AES256' to encrypt files at rest on S3
         
     | 
| 
      
 190 
     | 
    
         
            +
                    # @return [Boolean] true if no errors
         
     | 
| 
      
 191 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 192 
     | 
    
         
            +
                    def save(options = {})
         
     | 
| 
      
 193 
     | 
    
         
            +
                      requires :body, :directory, :key
         
     | 
| 
      
 194 
     | 
    
         
            +
                      if options != {}
         
     | 
| 
      
 195 
     | 
    
         
            +
                        Fog::Logger.deprecation("options param is deprecated, use acl= instead [light_black](#{caller.first})[/]")
         
     | 
| 
      
 196 
     | 
    
         
            +
                      end
         
     | 
| 
      
 197 
     | 
    
         
            +
                      options['x-amz-acl'] ||= @acl if @acl
         
     | 
| 
      
 198 
     | 
    
         
            +
                      options['Cache-Control'] = cache_control if cache_control
         
     | 
| 
      
 199 
     | 
    
         
            +
                      options['Content-Disposition'] = content_disposition if content_disposition
         
     | 
| 
      
 200 
     | 
    
         
            +
                      options['Content-Encoding'] = content_encoding if content_encoding
         
     | 
| 
      
 201 
     | 
    
         
            +
                      options['Content-MD5'] = content_md5 if content_md5
         
     | 
| 
      
 202 
     | 
    
         
            +
                      options['Content-Type'] = content_type if content_type
         
     | 
| 
      
 203 
     | 
    
         
            +
                      options['Expires'] = expires if expires
         
     | 
| 
      
 204 
     | 
    
         
            +
                      options.merge!(metadata)
         
     | 
| 
      
 205 
     | 
    
         
            +
                      options['x-amz-storage-class'] = storage_class if storage_class
         
     | 
| 
      
 206 
     | 
    
         
            +
                      options['x-amz-server-side-encryption'] = encryption if encryption
         
     | 
| 
      
 207 
     | 
    
         
            +
             
     | 
| 
      
 208 
     | 
    
         
            +
                      if multipart_chunk_size && body.respond_to?(:read)
         
     | 
| 
      
 209 
     | 
    
         
            +
                        data = multipart_save(options)
         
     | 
| 
      
 210 
     | 
    
         
            +
                        merge_attributes(data.body)
         
     | 
| 
      
 211 
     | 
    
         
            +
                      else
         
     | 
| 
      
 212 
     | 
    
         
            +
                        data = service.put_object(directory.key, key, body, options)
         
     | 
| 
      
 213 
     | 
    
         
            +
                        merge_attributes(data.headers.reject {|key, value| ['Content-Length', 'Content-Type'].include?(key)})
         
     | 
| 
      
 214 
     | 
    
         
            +
                      end
         
     | 
| 
      
 215 
     | 
    
         
            +
                      self.etag.gsub!('"','')
         
     | 
| 
      
 216 
     | 
    
         
            +
                      self.content_length = Fog::Storage.get_body_size(body)
         
     | 
| 
      
 217 
     | 
    
         
            +
                      self.content_type ||= Fog::Storage.get_content_type(body)
         
     | 
| 
      
 218 
     | 
    
         
            +
                      true
         
     | 
| 
      
 219 
     | 
    
         
            +
                    end
         
     | 
| 
      
 220 
     | 
    
         
            +
             
     | 
| 
      
 221 
     | 
    
         
            +
             
     | 
| 
      
 222 
     | 
    
         
            +
                    # Get a url for file.
         
     | 
| 
      
 223 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 224 
     | 
    
         
            +
                    #     required attributes: key
         
     | 
| 
      
 225 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 226 
     | 
    
         
            +
                    # @param expires [String] number of seconds before url expires
         
     | 
| 
      
 227 
     | 
    
         
            +
                    # @param options [Hash]
         
     | 
| 
      
 228 
     | 
    
         
            +
                    # @return [String] url
         
     | 
| 
      
 229 
     | 
    
         
            +
                    # 
         
     | 
| 
      
 230 
     | 
    
         
            +
                    def url(expires, options = {})
         
     | 
| 
      
 231 
     | 
    
         
            +
                      requires :key
         
     | 
| 
      
 232 
     | 
    
         
            +
                      collection.get_url(key, expires, options)
         
     | 
| 
      
 233 
     | 
    
         
            +
                    end
         
     | 
| 
      
 234 
     | 
    
         
            +
             
     | 
| 
      
 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 
     | 
    
         
            +
                    private
         
     | 
| 
      
 249 
     | 
    
         
            +
             
     | 
| 
      
 250 
     | 
    
         
            +
                    def directory=(new_directory)
         
     | 
| 
      
 251 
     | 
    
         
            +
                      @directory = new_directory
         
     | 
| 
      
 252 
     | 
    
         
            +
                    end
         
     | 
| 
      
 253 
     | 
    
         
            +
             
     | 
| 
      
 254 
     | 
    
         
            +
                    def multipart_save(options)
         
     | 
| 
      
 255 
     | 
    
         
            +
                      # Initiate the upload
         
     | 
| 
      
 256 
     | 
    
         
            +
                      res = service.initiate_multipart_upload(directory.key, key, options)
         
     | 
| 
      
 257 
     | 
    
         
            +
                      upload_id = res.body["UploadId"]
         
     | 
| 
      
 258 
     | 
    
         
            +
             
     | 
| 
      
 259 
     | 
    
         
            +
                      # Store ETags of upload parts
         
     | 
| 
      
 260 
     | 
    
         
            +
                      part_tags = []
         
     | 
| 
      
 261 
     | 
    
         
            +
             
     | 
| 
      
 262 
     | 
    
         
            +
                      # Upload each part
         
     | 
| 
      
 263 
     | 
    
         
            +
                      # TODO: optionally upload chunks in parallel using threads
         
     | 
| 
      
 264 
     | 
    
         
            +
                      # (may cause network performance problems with many small chunks)
         
     | 
| 
      
 265 
     | 
    
         
            +
                      # TODO: Support large chunk sizes without reading the chunk into memory
         
     | 
| 
      
 266 
     | 
    
         
            +
                      body.rewind if body.respond_to?(:rewind)
         
     | 
| 
      
 267 
     | 
    
         
            +
                      while (chunk = body.read(multipart_chunk_size)) do
         
     | 
| 
      
 268 
     | 
    
         
            +
                        md5 = Base64.encode64(Digest::MD5.digest(chunk)).strip
         
     | 
| 
      
 269 
     | 
    
         
            +
                        part_upload = service.upload_part(directory.key, key, upload_id, part_tags.size + 1, chunk, 'Content-MD5' => md5 )
         
     | 
| 
      
 270 
     | 
    
         
            +
                        part_tags << part_upload.headers["ETag"]
         
     | 
| 
      
 271 
     | 
    
         
            +
                      end
         
     | 
| 
      
 272 
     | 
    
         
            +
             
     | 
| 
      
 273 
     | 
    
         
            +
                    rescue
         
     | 
| 
      
 274 
     | 
    
         
            +
                      # Abort the upload & reraise
         
     | 
| 
      
 275 
     | 
    
         
            +
                      service.abort_multipart_upload(directory.key, key, upload_id) if upload_id
         
     | 
| 
      
 276 
     | 
    
         
            +
                      raise
         
     | 
| 
      
 277 
     | 
    
         
            +
                    else
         
     | 
| 
      
 278 
     | 
    
         
            +
                      # Complete the upload
         
     | 
| 
      
 279 
     | 
    
         
            +
                      service.complete_multipart_upload(directory.key, key, upload_id, part_tags)
         
     | 
| 
      
 280 
     | 
    
         
            +
                    end
         
     | 
| 
      
 281 
     | 
    
         
            +
             
     | 
| 
      
 282 
     | 
    
         
            +
                  end
         
     | 
| 
      
 283 
     | 
    
         
            +
             
     | 
| 
      
 284 
     | 
    
         
            +
                end
         
     | 
| 
      
 285 
     | 
    
         
            +
              end
         
     | 
| 
      
 286 
     | 
    
         
            +
            end
         
     |