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
@@ -14,11 +14,7 @@ module Fog
|
|
14
14
|
# @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTObjectDELETE.html
|
15
15
|
|
16
16
|
def delete_object(bucket_name, object_name, options = {})
|
17
|
-
|
18
|
-
path = "#{CGI.escape(object_name)}?versionId=#{CGI.escape(version_id)}"
|
19
|
-
else
|
20
|
-
path = CGI.escape(object_name)
|
21
|
-
end
|
17
|
+
path = CGI.escape(object_name)
|
22
18
|
|
23
19
|
headers = options
|
24
20
|
request({
|
@@ -40,56 +36,7 @@ module Fog
|
|
40
36
|
if bucket = self.data[:buckets][bucket_name]
|
41
37
|
response.status = 204
|
42
38
|
|
43
|
-
|
44
|
-
|
45
|
-
if bucket[:versioning]
|
46
|
-
bucket[:objects][object_name] ||= []
|
47
|
-
|
48
|
-
if version_id
|
49
|
-
version = bucket[:objects][object_name].find { |object| object['VersionId'] == version_id}
|
50
|
-
|
51
|
-
# S3 special cases the 'null' value to not error out if no such version exists.
|
52
|
-
if version || (version_id == 'null')
|
53
|
-
bucket[:objects][object_name].delete(version)
|
54
|
-
bucket[:objects].delete(object_name) if bucket[:objects][object_name].empty?
|
55
|
-
|
56
|
-
response.headers['x-amz-delete-marker'] = 'true' if version[:delete_marker]
|
57
|
-
response.headers['x-amz-version-id'] = version_id
|
58
|
-
else
|
59
|
-
response.status = 400
|
60
|
-
response.body = invalid_version_id_payload(version_id)
|
61
|
-
raise(Excon::Errors.status_error({:expects => 200}, response))
|
62
|
-
end
|
63
|
-
else
|
64
|
-
delete_marker = {
|
65
|
-
:delete_marker => true,
|
66
|
-
'Key' => object_name,
|
67
|
-
'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null',
|
68
|
-
'Last-Modified' => Fog::Time.now.to_date_header
|
69
|
-
}
|
70
|
-
|
71
|
-
# When versioning is suspended, a delete marker is placed if the last object ID is not the value 'null',
|
72
|
-
# otherwise the last object is replaced.
|
73
|
-
if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
|
74
|
-
bucket[:objects][object_name].shift
|
75
|
-
end
|
76
|
-
|
77
|
-
bucket[:objects][object_name].unshift(delete_marker)
|
78
|
-
|
79
|
-
response.headers['x-amz-delete-marker'] = 'true'
|
80
|
-
response.headers['x-amz-version-id'] = delete_marker['VersionId']
|
81
|
-
end
|
82
|
-
else
|
83
|
-
if version_id && version_id != 'null'
|
84
|
-
response.status = 400
|
85
|
-
response.body = invalid_version_id_payload(version_id)
|
86
|
-
raise(Excon::Errors.status_error({:expects => 200}, response))
|
87
|
-
else
|
88
|
-
bucket[:objects].delete(object_name)
|
89
|
-
|
90
|
-
response.headers['x-amz-version-id'] = 'null'
|
91
|
-
end
|
92
|
-
end
|
39
|
+
bucket[:objects].delete(object_name)
|
93
40
|
else
|
94
41
|
response.status = 404
|
95
42
|
raise(Excon::Errors.status_error({:expects => 204}, response))
|
@@ -97,21 +44,6 @@ module Fog
|
|
97
44
|
response
|
98
45
|
end
|
99
46
|
|
100
|
-
private
|
101
|
-
|
102
|
-
def invalid_version_id_payload(version_id)
|
103
|
-
{
|
104
|
-
'Error' => {
|
105
|
-
'Code' => 'InvalidArgument',
|
106
|
-
'Message' => 'Invalid version id specified',
|
107
|
-
'ArgumentValue' => version_id,
|
108
|
-
'ArgumentName' => 'versionId',
|
109
|
-
'RequestId' => Fog::Mock.random_hex(16),
|
110
|
-
'HostId' => Fog::Mock.random_base64(65)
|
111
|
-
}
|
112
|
-
}
|
113
|
-
end
|
114
|
-
|
115
47
|
end
|
116
48
|
end
|
117
49
|
end
|
@@ -13,7 +13,6 @@ module Fog
|
|
13
13
|
# @option options If-None-Match [String] Returns object only if its etag differs from this value, otherwise returns 304 (Not Modified)
|
14
14
|
# @option options If-Unmodified-Since [Time] Returns object only if it has not been modified since this time, otherwise returns 412 (Precodition Failed).
|
15
15
|
# @option options Range [String] Range of object to download
|
16
|
-
# @option options versionId [String] specify a particular version to retrieve
|
17
16
|
#
|
18
17
|
# @return [Excon::Response] response:
|
19
18
|
# * body [String]- Contents of object
|
@@ -34,9 +33,6 @@ module Fog
|
|
34
33
|
end
|
35
34
|
|
36
35
|
params = { :headers => {} }
|
37
|
-
if version_id = options.delete('versionId')
|
38
|
-
params[:query] = {'versionId' => version_id}
|
39
|
-
end
|
40
36
|
params[:headers].merge!(options)
|
41
37
|
if options['If-Modified-Since']
|
42
38
|
params[:headers]['If-Modified-Since'] = Fog::Time.at(options['If-Modified-Since'].to_i).to_date_header
|
@@ -63,7 +59,6 @@ module Fog
|
|
63
59
|
class Mock # :nodoc:all
|
64
60
|
|
65
61
|
def get_object(bucket_name, object_name, options = {}, &block)
|
66
|
-
version_id = options.delete('versionId')
|
67
62
|
|
68
63
|
unless bucket_name
|
69
64
|
raise ArgumentError.new('bucket_name is required')
|
@@ -77,7 +72,7 @@ module Fog
|
|
77
72
|
if (bucket = self.data[:buckets][bucket_name])
|
78
73
|
object = nil
|
79
74
|
if bucket[:objects].has_key?(object_name)
|
80
|
-
object =
|
75
|
+
object = bucket[:objects][object_name].first
|
81
76
|
end
|
82
77
|
|
83
78
|
if (object && !object[:delete_marker])
|
@@ -98,8 +93,6 @@ module Fog
|
|
98
93
|
end
|
99
94
|
end
|
100
95
|
|
101
|
-
response.headers['x-amz-version-id'] = object['VersionId'] if bucket[:versioning]
|
102
|
-
|
103
96
|
body = object[:body]
|
104
97
|
if options['Range']
|
105
98
|
# since AWS S3 itself does not support multiple range headers, we will use only the first
|
@@ -122,20 +115,6 @@ module Fog
|
|
122
115
|
end
|
123
116
|
end
|
124
117
|
end
|
125
|
-
elsif version_id && !object
|
126
|
-
response.status = 400
|
127
|
-
response.body = {
|
128
|
-
'Error' => {
|
129
|
-
'Code' => 'InvalidArgument',
|
130
|
-
'Message' => 'Invalid version id specified',
|
131
|
-
'ArgumentValue' => version_id,
|
132
|
-
'ArgumentName' => 'versionId',
|
133
|
-
'RequestId' => Fog::Mock.random_hex(16),
|
134
|
-
'HostId' => Fog::Mock.random_base64(65)
|
135
|
-
}
|
136
|
-
}
|
137
|
-
|
138
|
-
raise(Excon::Errors.status_error({:expects => 200}, response))
|
139
118
|
else
|
140
119
|
response.status = 404
|
141
120
|
response.body = "...<Code>NoSuchKey<\/Code>..."
|
@@ -10,7 +10,6 @@ module Fog
|
|
10
10
|
# @param bucket_name [String] name of bucket containing object
|
11
11
|
# @param object_name [String] name of object to get access control list for
|
12
12
|
# @param options [Hash]
|
13
|
-
# @option options versionId [String] specify a particular version to retrieve
|
14
13
|
#
|
15
14
|
# @return [Excon::Response] response:
|
16
15
|
# * body [Hash]:
|
@@ -37,9 +36,6 @@ module Fog
|
|
37
36
|
raise ArgumentError.new('object_name is required')
|
38
37
|
end
|
39
38
|
query = {'acl' => nil}
|
40
|
-
if version_id = options.delete('versionId')
|
41
|
-
query['versionId'] = version_id
|
42
|
-
end
|
43
39
|
request({
|
44
40
|
:expects => 200,
|
45
41
|
:headers => {},
|
@@ -13,7 +13,6 @@ module Fog
|
|
13
13
|
# @option options [String] If-None-Match Returns object only if its etag differs from this value, otherwise returns 304 (Not Modified)
|
14
14
|
# @option options [Time] If-Unmodified-Since Returns object only if it has not been modified since this time, otherwise returns 412 (Precodition Failed).
|
15
15
|
# @option options [String] Range Range of object to download
|
16
|
-
# @option options [String] versionId specify a particular version to retrieve
|
17
16
|
#
|
18
17
|
# @return [Excon::Response] response:
|
19
18
|
# * body [String] Contents of object
|
@@ -32,9 +31,6 @@ module Fog
|
|
32
31
|
unless object_name
|
33
32
|
raise ArgumentError.new('object_name is required')
|
34
33
|
end
|
35
|
-
if version_id = options.delete('versionId')
|
36
|
-
query = {'versionId' => version_id}
|
37
|
-
end
|
38
34
|
headers = {}
|
39
35
|
headers['If-Modified-Since'] = Fog::Time.at(options['If-Modified-Since'].to_i).to_date_header if options['If-Modified-Since']
|
40
36
|
headers['If-Unmodified-Since'] = Fog::Time.at(options['If-Unmodified-Since'].to_i).to_date_header if options['If-Modified-Since']
|
@@ -4,7 +4,7 @@ module Fog
|
|
4
4
|
class Real
|
5
5
|
|
6
6
|
# Get a hash of hidden fields for form uploading to S3, in the form {:field_name => :field_value}
|
7
|
-
# Form should look like: <form action="http://#{bucket_name}
|
7
|
+
# Form should look like: <form action="http://#{bucket_name}.#{Fog::InternetArchive::API_DOMAIN_NAME}/" method="post" enctype="multipart/form-data">
|
8
8
|
# These hidden fields should then appear, followed by a field named 'file' which is either a textarea or file input.
|
9
9
|
#
|
10
10
|
# @param options Hash:
|
@@ -67,30 +67,16 @@ module Fog
|
|
67
67
|
'Key' => object_name,
|
68
68
|
'Last-Modified' => Fog::Time.now.to_date_header,
|
69
69
|
'Content-Length' => options['Content-Length'] || data[:headers]['Content-Length'],
|
70
|
-
'StorageClass' => options['x-amz-storage-class'] || 'STANDARD',
|
71
|
-
'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null'
|
72
70
|
}
|
73
71
|
|
74
72
|
for key, value in options
|
75
73
|
case key
|
76
|
-
when 'Cache-Control', 'Content-Disposition', 'Content-Encoding', 'Content-MD5', 'Expires', /^x-amz-meta-/
|
74
|
+
when 'Cache-Control', 'Content-Disposition', 'Content-Encoding', 'Content-MD5', 'Expires', /^x-amz-meta-/, /^x-archive-/
|
77
75
|
object[key] = value
|
78
76
|
end
|
79
77
|
end
|
80
78
|
|
81
|
-
|
82
|
-
bucket[:objects][object_name] ||= []
|
83
|
-
|
84
|
-
# When versioning is suspended, putting an object will create a new 'null' version if the latest version
|
85
|
-
# is a value other than 'null', otherwise it will replace the latest version.
|
86
|
-
if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
|
87
|
-
bucket[:objects][object_name].shift
|
88
|
-
end
|
89
|
-
|
90
|
-
bucket[:objects][object_name].unshift(object)
|
91
|
-
else
|
92
|
-
bucket[:objects][object_name] = [object]
|
93
|
-
end
|
79
|
+
bucket[:objects][object_name] = [object]
|
94
80
|
|
95
81
|
response.headers = {
|
96
82
|
'Content-Length' => object['Content-Length'],
|
@@ -99,7 +85,6 @@ module Fog
|
|
99
85
|
'Last-Modified' => object['Last-Modified'],
|
100
86
|
}
|
101
87
|
|
102
|
-
response.headers['x-amz-version-id'] = object['VersionId'] if object['VersionId'] != 'null'
|
103
88
|
else
|
104
89
|
response.status = 404
|
105
90
|
raise(Excon::Errors.status_error({:expects => 200}, response))
|
@@ -24,16 +24,11 @@ module Fog
|
|
24
24
|
# * Permission [String] Permission, in [FULL_CONTROL, WRITE, WRITE_ACP, READ, READ_ACP]
|
25
25
|
# @param acl [String] Permissions, must be in ['private', 'public-read', 'public-read-write', 'authenticated-read']
|
26
26
|
# @param options [Hash]
|
27
|
-
# @option options versionId [String] specify a particular version to retrieve
|
28
27
|
#
|
29
28
|
# @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTObjectPUTacl.html
|
30
29
|
|
31
30
|
def put_object_acl(bucket_name, object_name, acl, options = {})
|
32
31
|
query = {'acl' => nil}
|
33
|
-
if version_id = options.delete('versionId')
|
34
|
-
query['versionId'] = version_id
|
35
|
-
end
|
36
|
-
|
37
32
|
data = ""
|
38
33
|
headers = {}
|
39
34
|
|
@@ -33,9 +33,7 @@ module Fog
|
|
33
33
|
request :get_bucket_lifecycle
|
34
34
|
request :get_bucket_location
|
35
35
|
request :get_bucket_logging
|
36
|
-
request :get_bucket_object_versions
|
37
36
|
request :get_bucket_policy
|
38
|
-
request :get_bucket_versioning
|
39
37
|
request :get_bucket_website
|
40
38
|
request :get_object
|
41
39
|
request :get_object_acl
|
@@ -56,7 +54,6 @@ module Fog
|
|
56
54
|
request :put_bucket_lifecycle
|
57
55
|
request :put_bucket_logging
|
58
56
|
request :put_bucket_policy
|
59
|
-
request :put_bucket_versioning
|
60
57
|
request :put_bucket_website
|
61
58
|
request :put_object
|
62
59
|
request :put_object_acl
|
@@ -79,9 +76,10 @@ module Fog
|
|
79
76
|
|
80
77
|
def url(params, expires)
|
81
78
|
Fog::Logger.deprecation("Fog::Storage::InternetArchive => #url is deprecated, use #https_url instead [light_black](#{caller.first})[/]")
|
82
|
-
|
79
|
+
http_url(params, expires)
|
83
80
|
end
|
84
81
|
|
82
|
+
|
85
83
|
private
|
86
84
|
|
87
85
|
def scheme_host_path_query(params, expires)
|
@@ -201,13 +199,8 @@ module Fog
|
|
201
199
|
require 'mime/types'
|
202
200
|
setup_credentials(options)
|
203
201
|
options[:region] ||= 'us-east-1'
|
204
|
-
@host = options[:host] ||
|
205
|
-
|
206
|
-
"s3.#{Fog::InternetArchive::DOMAIN_NAME}"
|
207
|
-
else
|
208
|
-
"s3-#{options[:region]}.#{Fog::InternetArchive::DOMAIN_NAME}"
|
209
|
-
end
|
210
|
-
@scheme = options[:scheme] || 'https'
|
202
|
+
@host = options[:host] || Fog::InternetArchive::API_DOMAIN_NAME
|
203
|
+
@scheme = options[:scheme] || 'http'
|
211
204
|
@region = options[:region]
|
212
205
|
end
|
213
206
|
|
@@ -273,12 +266,7 @@ module Fog
|
|
273
266
|
else
|
274
267
|
options[:region] ||= 'us-east-1'
|
275
268
|
@region = options[:region]
|
276
|
-
@host = options[:host] ||
|
277
|
-
when 'us-east-1'
|
278
|
-
"s3.#{Fog::InternetArchive::DOMAIN_NAME}"
|
279
|
-
else
|
280
|
-
"s3-#{options[:region]}.#{Fog::InternetArchive::DOMAIN_NAME}"
|
281
|
-
end
|
269
|
+
@host = options[:host] || Fog::InternetArchive::API_DOMAIN_NAME
|
282
270
|
@path = options[:path] || '/'
|
283
271
|
@persistent = options.fetch(:persistent, false)
|
284
272
|
@port = options[:port] || 80
|
@@ -389,7 +377,7 @@ DATA
|
|
389
377
|
begin
|
390
378
|
response = @connection.request(params, &block)
|
391
379
|
rescue Excon::Errors::TemporaryRedirect => error
|
392
|
-
uri = URI.parse(error.response.headers['
|
380
|
+
uri = URI.parse(error.response.headers['location'])
|
393
381
|
Fog::Logger.warning("fog: followed redirect to #{uri.host}, connecting to the matching region will be more performant")
|
394
382
|
response = Fog::Connection.new("#{@scheme}://#{uri.host}:#{@port}", false, @connection_options).request(original_params, &block)
|
395
383
|
end
|
data/lib/fog/joyent.rb
CHANGED
@@ -14,7 +14,7 @@ module Fog
|
|
14
14
|
node_hash[:uri] = client.uri
|
15
15
|
xml = client.sys_info rescue nil
|
16
16
|
[:uuid, :manufacturer, :product, :serial].each do |attr|
|
17
|
-
node_hash[attr] = node_attr(attr, xml)
|
17
|
+
node_hash[attr] = node_attr(attr, xml) rescue nil
|
18
18
|
end if xml
|
19
19
|
|
20
20
|
node_hash[:hostname] = client.hostname
|
@@ -0,0 +1,47 @@
|
|
1
|
+
# 1.11.0 2013/04/04
|
2
|
+
|
3
|
+
## Storage
|
4
|
+
|
5
|
+
* Added storage (Swift) example to set account quotas:
|
6
|
+
|
7
|
+
https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/storage/set-account-quota.rb
|
8
|
+
|
9
|
+
* Added account impersonation to the storage service
|
10
|
+
|
11
|
+
Now it's possible to use an admin account with a reseller
|
12
|
+
role to impersonate other accounts and set account metadata
|
13
|
+
headers. See the account quotas example included in this release
|
14
|
+
|
15
|
+
## Network
|
16
|
+
|
17
|
+
* create_network request updated
|
18
|
+
|
19
|
+
Implements provider extensions when creating networks.
|
20
|
+
|
21
|
+
See http://docs.openstack.org/trunk/openstack-network/admin/content/provider_attributes.html
|
22
|
+
|
23
|
+
* Network Router support (Quantum)
|
24
|
+
|
25
|
+
Added router model/collection and related requests.
|
26
|
+
|
27
|
+
* New network service example
|
28
|
+
|
29
|
+
See https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/network/network_subnets_routers.rb
|
30
|
+
|
31
|
+
* :openstack_endpoint_type parameter was added to the network service
|
32
|
+
|
33
|
+
## Image
|
34
|
+
|
35
|
+
* Added basic image service example (Glance)
|
36
|
+
|
37
|
+
Download CirrOS 0.3.0 image from launchpad (~6.5MB) to /tmp
|
38
|
+
and upload it to Glance.
|
39
|
+
|
40
|
+
See https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/image/upload-test-image.rb
|
41
|
+
|
42
|
+
* Check for glance version (fog only supports v1)
|
43
|
+
|
44
|
+
## Compute
|
45
|
+
|
46
|
+
* create_server and the Server model where updated to allow booting a VM
|
47
|
+
with NICs (net_id, port_id, fixed_ip).
|
@@ -0,0 +1,69 @@
|
|
1
|
+
# OpenStack Identity Service (Keystone) Example
|
2
|
+
|
3
|
+
require 'fog'
|
4
|
+
require 'pp'
|
5
|
+
|
6
|
+
auth_url = "https://example.net/v2.0/tokens"
|
7
|
+
username = 'admin@example.net'
|
8
|
+
password = 'secret'
|
9
|
+
|
10
|
+
keystone = Fog::Identity.new :provider => 'OpenStack',
|
11
|
+
:openstack_auth_url => auth_url,
|
12
|
+
:openstack_username => username,
|
13
|
+
:openstack_api_key => password
|
14
|
+
# Optional, self-signed certs
|
15
|
+
#:connection_options => { :ssl_verify_peer => false }
|
16
|
+
|
17
|
+
#
|
18
|
+
# Listing keystone tenants
|
19
|
+
#
|
20
|
+
keystone.tenants.each do |tenant|
|
21
|
+
# <Fog::Identity::OpenStack::Tenant
|
22
|
+
# id="46b4ab...",
|
23
|
+
# description=nil,
|
24
|
+
# enabled=1,
|
25
|
+
# name="admin@example.net"
|
26
|
+
# >
|
27
|
+
pp tenant
|
28
|
+
end
|
29
|
+
|
30
|
+
#
|
31
|
+
# List users
|
32
|
+
#
|
33
|
+
keystone.users.each do |user|
|
34
|
+
# <Fog::Identity::OpenStack::User
|
35
|
+
# id="c975f...",
|
36
|
+
# email="quantum@example.net",
|
37
|
+
# enabled=true,
|
38
|
+
# name="quantum",
|
39
|
+
# tenant_id="00928...",
|
40
|
+
# password=nil
|
41
|
+
# >
|
42
|
+
# ...
|
43
|
+
pp user
|
44
|
+
end
|
45
|
+
|
46
|
+
#
|
47
|
+
# Create a new tenant
|
48
|
+
#
|
49
|
+
tenant = keystone.tenants.create :name => 'rubiojr@example.net',
|
50
|
+
:description => 'My foo tenant'
|
51
|
+
|
52
|
+
#
|
53
|
+
# Create a new user
|
54
|
+
#
|
55
|
+
user = keystone.users.create :name => 'rubiojr@example.net',
|
56
|
+
:tenant_id => tenant.id,
|
57
|
+
:password => 'rubiojr@example.net',
|
58
|
+
:email => 'rubiojr@example.net'
|
59
|
+
|
60
|
+
|
61
|
+
# Find the recently created tenant
|
62
|
+
tenant = keystone.tenants.find { |t| t.name == 'rubiojr@example.net' }
|
63
|
+
# Destroy the tenant
|
64
|
+
tenant.destroy
|
65
|
+
|
66
|
+
# Find the recently created user
|
67
|
+
user = keystone.users.find { |u| u.name == 'rubiojr@example.net' }
|
68
|
+
# Destroy the user
|
69
|
+
user.destroy
|