fog 1.17.0 → 1.18.0
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +19 -1
- data/changelog.txt +408 -0
- data/fog.gemspec +3 -3
- data/fogkeytest1.pem +27 -0
- data/lib/fog/aws/compute.rb +0 -1
- data/lib/fog/aws/data_pipeline.rb +0 -1
- data/lib/fog/aws/models/auto_scaling/group.rb +1 -1
- data/lib/fog/aws/models/compute/route_table.rb +1 -1
- data/lib/fog/aws/models/compute/server.rb +1 -1
- data/lib/fog/aws/parsers/compute/describe_internet_gateways.rb +1 -1
- data/lib/fog/aws/requests/compute/create_internet_gateway.rb +5 -4
- data/lib/fog/aws/requests/compute/create_tags.rb +2 -0
- data/lib/fog/aws/requests/compute/create_volume.rb +1 -1
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +1 -1
- data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +1 -1
- data/lib/fog/aws/requests/compute/run_instances.rb +1 -1
- data/lib/fog/bin/hp.rb +17 -0
- data/lib/fog/compute.rb +11 -0
- data/lib/fog/ecloud/compute.rb +8 -3
- data/lib/fog/ecloud/models/compute/admin_organization.rb +4 -4
- data/lib/fog/ecloud/models/compute/catalog_item.rb +1 -1
- data/lib/fog/ecloud/models/compute/compute_pool.rb +8 -8
- data/lib/fog/ecloud/models/compute/environment.rb +15 -15
- data/lib/fog/ecloud/models/compute/firewall_acl.rb +1 -1
- data/lib/fog/ecloud/models/compute/internet_service.rb +1 -1
- data/lib/fog/ecloud/models/compute/internet_services.rb +1 -1
- data/lib/fog/ecloud/models/compute/location.rb +1 -1
- data/lib/fog/ecloud/models/compute/monitor.rb +1 -1
- data/lib/fog/ecloud/models/compute/network.rb +1 -1
- data/lib/fog/ecloud/models/compute/node.rb +1 -1
- data/lib/fog/ecloud/models/compute/nodes.rb +1 -1
- data/lib/fog/ecloud/models/compute/organization.rb +10 -10
- data/lib/fog/ecloud/models/compute/row.rb +1 -1
- data/lib/fog/ecloud/models/compute/rows.rb +1 -1
- data/lib/fog/ecloud/models/compute/server.rb +9 -9
- data/lib/fog/ecloud/models/compute/templates.rb +3 -1
- data/lib/fog/ecloud/models/compute/user.rb +2 -2
- data/lib/fog/ecloud/models/compute/virtual_machine_assigned_ip.rb +1 -1
- data/lib/fog/ecloud/requests/compute/get_virtual_machine_assigned_ips.rb +1 -1
- data/lib/fog/google/models/compute/disk.rb +5 -5
- data/lib/fog/google/models/compute/disks.rb +9 -2
- data/lib/fog/hp.rb +108 -19
- data/lib/fog/hp/CHANGELOG.hp +33 -0
- data/lib/fog/hp/block_storage.rb +5 -3
- data/lib/fog/hp/block_storage_v2.rb +164 -0
- data/lib/fog/hp/cdn.rb +3 -2
- data/lib/fog/hp/compute.rb +5 -4
- data/lib/fog/hp/compute_v2.rb +312 -0
- data/lib/fog/hp/dns.rb +135 -0
- data/lib/fog/hp/lb.rb +170 -0
- data/lib/fog/hp/models/block_storage_v2/snapshot.rb +76 -0
- data/lib/fog/hp/models/block_storage_v2/snapshots.rb +43 -0
- data/lib/fog/hp/models/block_storage_v2/volume.rb +139 -0
- data/lib/fog/hp/models/block_storage_v2/volume_backup.rb +58 -0
- data/lib/fog/hp/models/block_storage_v2/volume_backups.rb +42 -0
- data/lib/fog/hp/models/block_storage_v2/volumes.rb +42 -0
- data/lib/fog/hp/models/compute/image.rb +1 -1
- data/lib/fog/hp/models/compute/server.rb +41 -20
- data/lib/fog/hp/models/compute_v2/address.rb +70 -0
- data/lib/fog/hp/models/compute_v2/addresses.rb +29 -0
- data/lib/fog/hp/models/compute_v2/availability_zone.rb +22 -0
- data/lib/fog/hp/models/compute_v2/availability_zones.rb +29 -0
- data/lib/fog/hp/models/compute_v2/flavor.rb +22 -0
- data/lib/fog/hp/models/compute_v2/flavors.rb +42 -0
- data/lib/fog/hp/models/compute_v2/image.rb +87 -0
- data/lib/fog/hp/models/compute_v2/images.rb +43 -0
- data/lib/fog/hp/models/compute_v2/key_pair.rb +54 -0
- data/lib/fog/hp/models/compute_v2/key_pairs.rb +31 -0
- data/lib/fog/hp/models/compute_v2/meta.rb +29 -0
- data/lib/fog/hp/models/compute_v2/meta_parent.rb +33 -0
- data/lib/fog/hp/models/compute_v2/metadata.rb +79 -0
- data/lib/fog/hp/models/compute_v2/server.rb +339 -0
- data/lib/fog/hp/models/compute_v2/servers.rb +56 -0
- data/lib/fog/hp/models/compute_v2/volume_attachment.rb +42 -0
- data/lib/fog/hp/models/compute_v2/volume_attachments.rb +30 -0
- data/lib/fog/hp/models/dns/domain.rb +55 -0
- data/lib/fog/hp/models/dns/domains.rb +28 -0
- data/lib/fog/hp/models/dns/record.rb +59 -0
- data/lib/fog/hp/models/dns/records.rb +32 -0
- data/lib/fog/hp/models/lb/algorithm.rb +24 -0
- data/lib/fog/hp/models/lb/algorithms.rb +26 -0
- data/lib/fog/hp/models/lb/load_balancer.rb +83 -0
- data/lib/fog/hp/models/lb/load_balancers.rb +26 -0
- data/lib/fog/hp/models/lb/node.rb +53 -0
- data/lib/fog/hp/models/lb/nodes.rb +30 -0
- data/lib/fog/hp/models/lb/protocol.rb +25 -0
- data/lib/fog/hp/models/lb/protocols.rb +26 -0
- data/lib/fog/hp/models/lb/virtual_ip.rb +34 -0
- data/lib/fog/hp/models/lb/virtual_ips.rb +33 -0
- data/lib/fog/hp/models/network/floating_ip.rb +45 -0
- data/lib/fog/hp/models/network/floating_ips.rb +36 -0
- data/lib/fog/hp/models/network/network.rb +56 -0
- data/lib/fog/hp/models/network/networks.rb +36 -0
- data/lib/fog/hp/models/network/port.rb +54 -0
- data/lib/fog/hp/models/network/ports.rb +36 -0
- data/lib/fog/hp/models/network/router.rb +66 -0
- data/lib/fog/hp/models/network/routers.rb +36 -0
- data/lib/fog/hp/models/network/security_group.rb +30 -0
- data/lib/fog/hp/models/network/security_group_rule.rb +35 -0
- data/lib/fog/hp/models/network/security_group_rules.rb +36 -0
- data/lib/fog/hp/models/network/security_groups.rb +36 -0
- data/lib/fog/hp/models/network/subnet.rb +49 -0
- data/lib/fog/hp/models/network/subnets.rb +36 -0
- data/lib/fog/hp/models/storage/directories.rb +1 -1
- data/lib/fog/hp/models/storage/directory.rb +41 -8
- data/lib/fog/hp/models/storage/meta.rb +29 -0
- data/lib/fog/hp/models/storage/meta_parent.rb +23 -0
- data/lib/fog/hp/models/storage/metadata.rb +82 -0
- data/lib/fog/hp/network.rb +198 -0
- data/lib/fog/hp/requests/block_storage_v2/create_snapshot.rb +76 -0
- data/lib/fog/hp/requests/block_storage_v2/create_volume.rb +90 -0
- data/lib/fog/hp/requests/block_storage_v2/create_volume_backup.rb +83 -0
- data/lib/fog/hp/requests/block_storage_v2/delete_snapshot.rb +38 -0
- data/lib/fog/hp/requests/block_storage_v2/delete_volume.rb +38 -0
- data/lib/fog/hp/requests/block_storage_v2/delete_volume_backup.rb +38 -0
- data/lib/fog/hp/requests/block_storage_v2/get_snapshot_details.rb +54 -0
- data/lib/fog/hp/requests/block_storage_v2/get_volume_backup_details.rb +55 -0
- data/lib/fog/hp/requests/block_storage_v2/get_volume_details.rb +58 -0
- data/lib/fog/hp/requests/block_storage_v2/list_snapshots.rb +57 -0
- data/lib/fog/hp/requests/block_storage_v2/list_snapshots_detail.rb +54 -0
- data/lib/fog/hp/requests/block_storage_v2/list_volume_backups.rb +52 -0
- data/lib/fog/hp/requests/block_storage_v2/list_volume_backups_detail.rb +58 -0
- data/lib/fog/hp/requests/block_storage_v2/list_volumes.rb +61 -0
- data/lib/fog/hp/requests/block_storage_v2/list_volumes_detail.rb +59 -0
- data/lib/fog/hp/requests/block_storage_v2/restore_volume_backup.rb +97 -0
- data/lib/fog/hp/requests/block_storage_v2/update_snapshot.rb +69 -0
- data/lib/fog/hp/requests/block_storage_v2/update_volume.rb +70 -0
- data/lib/fog/hp/requests/compute/get_console_output.rb +0 -2
- data/lib/fog/hp/requests/compute/get_vnc_console.rb +45 -0
- data/lib/fog/hp/requests/compute_v2/add_security_group.rb +40 -0
- data/lib/fog/hp/requests/compute_v2/allocate_address.rb +53 -0
- data/lib/fog/hp/requests/compute_v2/associate_address.rb +46 -0
- data/lib/fog/hp/requests/compute_v2/attach_volume.rb +80 -0
- data/lib/fog/hp/requests/compute_v2/create_image.rb +63 -0
- data/lib/fog/hp/requests/compute_v2/create_key_pair.rb +73 -0
- data/lib/fog/hp/requests/compute_v2/create_persistent_server.rb +183 -0
- data/lib/fog/hp/requests/compute_v2/create_server.rb +168 -0
- data/lib/fog/hp/requests/compute_v2/delete_image.rb +44 -0
- data/lib/fog/hp/requests/compute_v2/delete_key_pair.rb +38 -0
- data/lib/fog/hp/requests/compute_v2/delete_meta.rb +55 -0
- data/lib/fog/hp/requests/compute_v2/delete_server.rb +43 -0
- data/lib/fog/hp/requests/compute_v2/detach_volume.rb +47 -0
- data/lib/fog/hp/requests/compute_v2/disassociate_address.rb +39 -0
- data/lib/fog/hp/requests/compute_v2/get_address.rb +48 -0
- data/lib/fog/hp/requests/compute_v2/get_console_output.rb +41 -0
- data/lib/fog/hp/requests/compute_v2/get_flavor_details.rb +57 -0
- data/lib/fog/hp/requests/compute_v2/get_image_details.rb +55 -0
- data/lib/fog/hp/requests/compute_v2/get_key_pair.rb +44 -0
- data/lib/fog/hp/requests/compute_v2/get_meta.rb +57 -0
- data/lib/fog/hp/requests/compute_v2/get_server_details.rb +72 -0
- data/lib/fog/hp/requests/compute_v2/get_server_volume_details.rb +47 -0
- data/lib/fog/hp/requests/compute_v2/get_vnc_console.rb +45 -0
- data/lib/fog/hp/requests/compute_v2/get_windows_password.rb +43 -0
- data/lib/fog/hp/requests/compute_v2/list_addresses.rb +44 -0
- data/lib/fog/hp/requests/compute_v2/list_availability_zones.rb +47 -0
- data/lib/fog/hp/requests/compute_v2/list_flavors.rb +53 -0
- data/lib/fog/hp/requests/compute_v2/list_flavors_detail.rb +53 -0
- data/lib/fog/hp/requests/compute_v2/list_images.rb +52 -0
- data/lib/fog/hp/requests/compute_v2/list_images_detail.rb +66 -0
- data/lib/fog/hp/requests/compute_v2/list_key_pairs.rb +42 -0
- data/lib/fog/hp/requests/compute_v2/list_limits.rb +62 -0
- data/lib/fog/hp/requests/compute_v2/list_metadata.rb +56 -0
- data/lib/fog/hp/requests/compute_v2/list_server_addresses.rb +42 -0
- data/lib/fog/hp/requests/compute_v2/list_server_addresses_by_network.rb +46 -0
- data/lib/fog/hp/requests/compute_v2/list_server_volumes.rb +49 -0
- data/lib/fog/hp/requests/compute_v2/list_servers.rb +53 -0
- data/lib/fog/hp/requests/compute_v2/list_servers_detail.rb +80 -0
- data/lib/fog/hp/requests/compute_v2/reboot_server.rb +34 -0
- data/lib/fog/hp/requests/compute_v2/rebuild_server.rb +82 -0
- data/lib/fog/hp/requests/compute_v2/release_address.rb +38 -0
- data/lib/fog/hp/requests/compute_v2/remove_security_group.rb +37 -0
- data/lib/fog/hp/requests/compute_v2/server_action.rb +25 -0
- data/lib/fog/hp/requests/compute_v2/set_metadata.rb +60 -0
- data/lib/fog/hp/requests/compute_v2/update_meta.rb +61 -0
- data/lib/fog/hp/requests/compute_v2/update_metadata.rb +60 -0
- data/lib/fog/hp/requests/compute_v2/update_server.rb +73 -0
- data/lib/fog/hp/requests/dns/create_domain.rb +66 -0
- data/lib/fog/hp/requests/dns/create_record.rb +79 -0
- data/lib/fog/hp/requests/dns/delete_domain.rb +37 -0
- data/lib/fog/hp/requests/dns/delete_record.rb +36 -0
- data/lib/fog/hp/requests/dns/get_domain.rb +43 -0
- data/lib/fog/hp/requests/dns/get_record.rb +47 -0
- data/lib/fog/hp/requests/dns/get_servers_hosting_domain.rb +62 -0
- data/lib/fog/hp/requests/dns/list_domains.rb +38 -0
- data/lib/fog/hp/requests/dns/list_records_in_a_domain.rb +55 -0
- data/lib/fog/hp/requests/dns/update_domain.rb +62 -0
- data/lib/fog/hp/requests/dns/update_record.rb +70 -0
- data/lib/fog/hp/requests/lb/create_load_balancer.rb +110 -0
- data/lib/fog/hp/requests/lb/create_load_balancer_node.rb +72 -0
- data/lib/fog/hp/requests/lb/delete_load_balancer.rb +36 -0
- data/lib/fog/hp/requests/lb/delete_load_balancer_node.rb +47 -0
- data/lib/fog/hp/requests/lb/get_load_balancer.rb +60 -0
- data/lib/fog/hp/requests/lb/get_load_balancer_node.rb +54 -0
- data/lib/fog/hp/requests/lb/list_algorithms.rb +32 -0
- data/lib/fog/hp/requests/lb/list_limits.rb +40 -0
- data/lib/fog/hp/requests/lb/list_load_balancer_nodes.rb +41 -0
- data/lib/fog/hp/requests/lb/list_load_balancer_virtual_ips.rb +44 -0
- data/lib/fog/hp/requests/lb/list_load_balancers.rb +41 -0
- data/lib/fog/hp/requests/lb/list_protocols.rb +34 -0
- data/lib/fog/hp/requests/lb/list_versions.rb +27 -0
- data/lib/fog/hp/requests/lb/update_load_balancer.rb +47 -0
- data/lib/fog/hp/requests/lb/update_load_balancer_node.rb +59 -0
- data/lib/fog/hp/requests/network/add_router_interface.rb +75 -0
- data/lib/fog/hp/requests/network/associate_floating_ip.rb +71 -0
- data/lib/fog/hp/requests/network/create_floating_ip.rb +69 -0
- data/lib/fog/hp/requests/network/create_network.rb +68 -0
- data/lib/fog/hp/requests/network/create_port.rb +92 -0
- data/lib/fog/hp/requests/network/create_router.rb +64 -0
- data/lib/fog/hp/requests/network/create_security_group.rb +100 -0
- data/lib/fog/hp/requests/network/create_security_group_rule.rb +83 -0
- data/lib/fog/hp/requests/network/create_subnet.rb +97 -0
- data/lib/fog/hp/requests/network/delete_floating_ip.rb +34 -0
- data/lib/fog/hp/requests/network/delete_network.rb +34 -0
- data/lib/fog/hp/requests/network/delete_port.rb +34 -0
- data/lib/fog/hp/requests/network/delete_router.rb +34 -0
- data/lib/fog/hp/requests/network/delete_security_group.rb +36 -0
- data/lib/fog/hp/requests/network/delete_security_group_rule.rb +36 -0
- data/lib/fog/hp/requests/network/delete_subnet.rb +34 -0
- data/lib/fog/hp/requests/network/disassociate_floating_ip.rb +71 -0
- data/lib/fog/hp/requests/network/get_floating_ip.rb +47 -0
- data/lib/fog/hp/requests/network/get_network.rb +49 -0
- data/lib/fog/hp/requests/network/get_port.rb +53 -0
- data/lib/fog/hp/requests/network/get_router.rb +46 -0
- data/lib/fog/hp/requests/network/get_security_group.rb +56 -0
- data/lib/fog/hp/requests/network/get_security_group_rule.rb +51 -0
- data/lib/fog/hp/requests/network/get_subnet.rb +52 -0
- data/lib/fog/hp/requests/network/list_floating_ips.rb +46 -0
- data/lib/fog/hp/requests/network/list_networks.rb +48 -0
- data/lib/fog/hp/requests/network/list_ports.rb +52 -0
- data/lib/fog/hp/requests/network/list_routers.rb +45 -0
- data/lib/fog/hp/requests/network/list_security_group_rules.rb +52 -0
- data/lib/fog/hp/requests/network/list_security_groups.rb +57 -0
- data/lib/fog/hp/requests/network/list_subnets.rb +51 -0
- data/lib/fog/hp/requests/network/remove_router_interface.rb +67 -0
- data/lib/fog/hp/requests/network/update_network.rb +62 -0
- data/lib/fog/hp/requests/network/update_port.rb +75 -0
- data/lib/fog/hp/requests/network/update_router.rb +62 -0
- data/lib/fog/hp/requests/network/update_subnet.rb +72 -0
- data/lib/fog/hp/requests/storage/post_container.rb +38 -0
- data/lib/fog/hp/requests/storage/post_object.rb +56 -0
- data/lib/fog/hp/simple_http_instrumentor.rb +59 -0
- data/lib/fog/hp/storage.rb +6 -6
- data/lib/fog/internet_archive/models/storage/file.rb +1 -1
- data/lib/fog/internet_archive/requests/storage/head_object.rb +2 -2
- data/lib/fog/openstack/identity.rb +1 -1
- data/lib/fog/openstack/models/storage/file.rb +1 -1
- data/lib/fog/rackspace.rb +4 -1
- data/lib/fog/rackspace/docs/compute_v2.md +2 -2
- data/lib/fog/rackspace/docs/storage.md +1 -1
- data/lib/fog/rackspace/examples/compute_v2/create_image.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +1 -1
- data/lib/fog/rackspace/examples/storage/create_cdn_directory.rb +1 -1
- data/lib/fog/rackspace/examples/storage/delete_directory.rb +1 -1
- data/lib/fog/rackspace/examples/storage/delete_file.rb +1 -1
- data/lib/fog/rackspace/examples/storage/download_file.rb +1 -1
- data/lib/fog/rackspace/models/compute_v2/images.rb +1 -1
- data/lib/fog/rackspace/models/compute_v2/metadata.rb +2 -2
- data/lib/fog/rackspace/models/compute_v2/server.rb +2 -2
- data/lib/fog/rackspace/models/compute_v2/servers.rb +1 -1
- data/lib/fog/rackspace/models/storage/file.rb +19 -0
- data/lib/fog/rackspace/models/storage/files.rb +25 -0
- data/lib/fog/rackspace/monitoring.rb +20 -1
- data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +1 -1
- data/lib/fog/rackspace/requests/monitoring/get_monitoring_zone.rb +15 -0
- data/lib/fog/rackspace/requests/monitoring/list_monitoring_zones.rb +15 -0
- data/lib/fog/rackspace/requests/storage/get_object_http_url.rb +30 -0
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +2 -1
- data/lib/fog/rackspace/storage.rb +1 -0
- data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +10 -8
- data/lib/fog/vcloud_director/requests/compute/get_edge_gateway.rb +2 -0
- data/lib/fog/vcloud_director/requests/compute/get_task.rb +10 -1
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +1 -0
- data/lib/fog/vsphere/models/compute/server.rb +2 -2
- data/lib/fog/vsphere/models/compute/volume.rb +59 -4
- data/lib/fog/vsphere/models/compute/volumes.rb +22 -7
- data/lib/fog/vsphere/requests/compute/create_vm.rb +9 -3
- data/lib/fog/vsphere/requests/compute/list_vm_volumes.rb +3 -1
- data/lib/fog/vsphere/requests/compute/modify_vm_volume.rb +26 -0
- data/lib/tasks/changelog_task.rb +2 -0
- data/tests/aws/requests/compute/internet_gateway_tests.rb +5 -0
- data/tests/compute/helper.rb +6 -4
- data/tests/ecloud/compute/models/server_tests.rb +34 -41
- data/tests/hp/block_storage_tests.rb +47 -0
- data/tests/hp/cdn_tests.rb +23 -0
- data/tests/hp/compute_tests.rb +22 -0
- data/tests/hp/models/block_storage_v2/snapshot_tests.rb +22 -0
- data/tests/hp/models/block_storage_v2/snapshots_tests.rb +10 -0
- data/tests/hp/models/block_storage_v2/volume_backup_tests.rb +22 -0
- data/tests/hp/models/block_storage_v2/volume_backups_tests.rb +9 -0
- data/tests/hp/models/block_storage_v2/volume_tests.rb +22 -0
- data/tests/hp/models/block_storage_v2/volumes_tests.rb +5 -0
- data/tests/hp/models/compute_v2/address_tests.rb +23 -0
- data/tests/hp/models/compute_v2/addresses_tests.rb +7 -0
- data/tests/hp/models/compute_v2/availability_zone_tests.rb +13 -0
- data/tests/hp/models/compute_v2/availability_zones_tests.rb +13 -0
- data/tests/hp/models/compute_v2/key_pair_tests.rb +29 -0
- data/tests/hp/models/compute_v2/key_pairs_tests.rb +7 -0
- data/tests/hp/models/compute_v2/metadata_image_tests.rb +60 -0
- data/tests/hp/models/compute_v2/metadata_server_tests.rb +56 -0
- data/tests/hp/models/compute_v2/server_tests.rb +45 -0
- data/tests/hp/models/compute_v2/servers_tests.rb +9 -0
- data/tests/hp/models/compute_v2/volume_attachment_tests.rb +40 -0
- data/tests/hp/models/compute_v2/volume_attachments_tests.rb +17 -0
- data/tests/hp/models/dns/domain_tests.rb +25 -0
- data/tests/hp/models/dns/domains_tests.rb +14 -0
- data/tests/hp/models/dns/record_tests.rb +29 -0
- data/tests/hp/models/dns/records_tests.rb +9 -0
- data/tests/hp/models/lb/algorithms_tests.rb +15 -0
- data/tests/hp/models/lb/load_balancer_node_tests.rb +9 -0
- data/tests/hp/models/lb/load_balancer_nodes_tests.rb +27 -0
- data/tests/hp/models/lb/load_balancer_tests.rb +6 -0
- data/tests/hp/models/lb/load_balancer_virtual_ips_tests.rb +22 -0
- data/tests/hp/models/lb/load_balancers_tests.rb +22 -0
- data/tests/hp/models/lb/protocols_tests.rb +15 -0
- data/tests/hp/models/network/floating_ip_tests.rb +37 -0
- data/tests/hp/models/network/floating_ips_tests.rb +8 -0
- data/tests/hp/models/network/network_tests.rb +25 -0
- data/tests/hp/models/network/networks_tests.rb +15 -0
- data/tests/hp/models/network/port_tests.rb +30 -0
- data/tests/hp/models/network/ports_tests.rb +21 -0
- data/tests/hp/models/network/router_tests.rb +55 -0
- data/tests/hp/models/network/routers_tests.rb +19 -0
- data/tests/hp/models/network/security_group_rule_tests.rb +25 -0
- data/tests/hp/models/network/security_group_rules_tests.rb +23 -0
- data/tests/hp/models/network/security_group_tests.rb +20 -0
- data/tests/hp/models/network/security_groups_tests.rb +20 -0
- data/tests/hp/models/network/subnet_tests.rb +30 -0
- data/tests/hp/models/network/subnets_tests.rb +22 -0
- data/tests/hp/models/storage/directory_tests.rb +70 -0
- data/tests/hp/requests/block_storage_v2/snapshot_tests.rb +69 -0
- data/tests/hp/requests/block_storage_v2/volume_backup_tests.rb +117 -0
- data/tests/hp/requests/block_storage_v2/volume_tests.rb +106 -0
- data/tests/hp/requests/compute_v2/address_tests.rb +80 -0
- data/tests/hp/requests/compute_v2/availability_zone_tests.rb +19 -0
- data/tests/hp/requests/compute_v2/flavor_tests.rb +45 -0
- data/tests/hp/requests/compute_v2/image_tests.rb +86 -0
- data/tests/hp/requests/compute_v2/key_pair_tests.rb +66 -0
- data/tests/hp/requests/compute_v2/metadata_tests.rb +101 -0
- data/tests/hp/requests/compute_v2/persistent_server_tests.rb +67 -0
- data/tests/hp/requests/compute_v2/server_address_tests.rb +46 -0
- data/tests/hp/requests/compute_v2/server_security_group_tests.rb +43 -0
- data/tests/hp/requests/compute_v2/server_tests.rb +113 -0
- data/tests/hp/requests/compute_v2/server_volume_tests.rb +85 -0
- data/tests/hp/requests/dns/domain_tests.rb +72 -0
- data/tests/hp/requests/dns/records_tests.rb +65 -0
- data/tests/hp/requests/lb/algorithms_tests.rb +15 -0
- data/tests/hp/requests/lb/limits_tests.rb +18 -0
- data/tests/hp/requests/lb/load_balancer_nodes_tests.rb +47 -0
- data/tests/hp/requests/lb/load_balancer_tests.rb +56 -0
- data/tests/hp/requests/lb/protocols_tests.rb +15 -0
- data/tests/hp/requests/lb/versions_tests.rb +17 -0
- data/tests/hp/requests/lb/virtual_ips_tests.rb +34 -0
- data/tests/hp/requests/network/floating_ip_tests.rb +70 -0
- data/tests/hp/requests/network/network_tests.rb +57 -0
- data/tests/hp/requests/network/port_tests.rb +71 -0
- data/tests/hp/requests/network/router_tests.rb +108 -0
- data/tests/hp/requests/network/security_group_rule_tests.rb +58 -0
- data/tests/hp/requests/network/security_group_tests.rb +48 -0
- data/tests/hp/requests/network/subnet_tests.rb +71 -0
- data/tests/hp/requests/storage/container_tests.rb +9 -1
- data/tests/hp/requests/storage/object_tests.rb +15 -1
- data/tests/hp/storage_tests.rb +25 -0
- data/tests/rackspace/cdn_tests.rb +1 -1
- data/tests/rackspace/models/compute_v2/metadata_tests.rb +1 -1
- data/tests/rackspace/models/identity/service_catalog_tests.rb +1 -1
- data/tests/rackspace/models/storage/file_tests.rb +19 -6
- data/tests/rackspace/models/storage/files_tests.rb +44 -0
- data/tests/rackspace/requests/monitoring/helper.rb +64 -0
- data/tests/rackspace/requests/monitoring/list_tests.rb +14 -2
- data/tests/rackspace/requests/storage/large_object_tests.rb +8 -6
- data/tests/rackspace/requests/storage/object_tests.rb +11 -0
- data/tests/rackspace/storage_tests.rb +4 -4
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +48 -44
- data/tests/vcloud_director/requests/compute/network_tests.rb +2 -0
- metadata +356 -5
@@ -26,7 +26,7 @@ module Fog
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def create(options)
|
29
|
-
options[:uri] = "/
|
29
|
+
options[:uri] = "#{service.base_path}/internetServices/publicIps/#{public_ip_id}/action/createInternetService"
|
30
30
|
options[:protocol] ||= "TCP"
|
31
31
|
options[:enabled] ||= true
|
32
32
|
options[:description] ||= ""
|
@@ -11,7 +11,7 @@ module Fog
|
|
11
11
|
attribute :type, :aliases => :Type
|
12
12
|
|
13
13
|
def catalog(org_href)
|
14
|
-
@catalog ||= Fog::Compute::Ecloud::Catalog.new(:service => service, :href => "/
|
14
|
+
@catalog ||= Fog::Compute::Ecloud::Catalog.new(:service => service, :href => "#{service.base_path}/admin/catalog/organizations/#{org_href.scan(/\d+/)[0]}/locations/#{id}")
|
15
15
|
end
|
16
16
|
|
17
17
|
def id
|
@@ -18,7 +18,7 @@ module Fog
|
|
18
18
|
attribute :receive_string, :aliases => :ReceiveString
|
19
19
|
|
20
20
|
def edit(options = {})
|
21
|
-
href = "/
|
21
|
+
href = "#{service.base_path}/internetServices/#{internet_service_id}/monitor?type="
|
22
22
|
case type
|
23
23
|
when "application/vnd.tmrk.cloud.pingMonitor"
|
24
24
|
options[:uri] = href + "ping"
|
@@ -14,7 +14,7 @@ module Fog
|
|
14
14
|
attribute :rnat_address, :aliases => :RnatAddress
|
15
15
|
|
16
16
|
def rnats
|
17
|
-
@rnats ||= Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "
|
17
|
+
@rnats ||= Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "#{service.base_path}/rnats/networks/#{id}")
|
18
18
|
end
|
19
19
|
|
20
20
|
def ips
|
@@ -18,7 +18,7 @@ module Fog
|
|
18
18
|
end
|
19
19
|
|
20
20
|
def tasks
|
21
|
-
@tasks ||= Fog::Compute::Ecloud::Tasks.new(:service => service, :href => "/
|
21
|
+
@tasks ||= Fog::Compute::Ecloud::Tasks.new(:service => service, :href => "#{service.base_path}/tasks/virtualMachines/#{id}")
|
22
22
|
end
|
23
23
|
|
24
24
|
def delete
|
@@ -26,7 +26,7 @@ module Fog
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def create(options)
|
29
|
-
options[:uri] = "/
|
29
|
+
options[:uri] = "#{service.base_path}/nodeServices/internetServices/#{internet_service_id}/action/createNodeService"
|
30
30
|
options[:protocol] ||= "TCP"
|
31
31
|
options[:enabled] ||= true
|
32
32
|
options[:description] ||= ""
|
@@ -20,51 +20,51 @@ module Fog
|
|
20
20
|
end
|
21
21
|
|
22
22
|
def tags
|
23
|
-
@tags ||= self.service.tags(:href => "/
|
23
|
+
@tags ||= self.service.tags(:href => "#{service.base_path}/deviceTags/organizations/#{id}")
|
24
24
|
end
|
25
25
|
|
26
26
|
def admin
|
27
|
-
@admin ||= self.service.admin_organizations.new(:href => "/
|
27
|
+
@admin ||= self.service.admin_organizations.new(:href => "#{service.base_path}/admin/organizations/#{id}")
|
28
28
|
end
|
29
29
|
|
30
30
|
def users
|
31
|
-
@users ||= self.service.users(:href => "/
|
31
|
+
@users ||= self.service.users(:href => "#{service.base_path}/admin/users/organizations/#{id}")
|
32
32
|
end
|
33
33
|
|
34
34
|
def support_tickets(type = :open)
|
35
35
|
case type
|
36
36
|
when :open
|
37
|
-
@support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "/
|
37
|
+
@support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "#{service.base_path}/admin/tickets/organizations/#{id}/active")
|
38
38
|
when :closed
|
39
|
-
@support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "/
|
39
|
+
@support_tickets ||= Fog::Compute::Ecloud::SupportTickets.new(:service => service, :href => "#{service.base_path}/admin/tickets/organizations/#{id}/closed")
|
40
40
|
end
|
41
41
|
end
|
42
42
|
|
43
43
|
def edit_authentication_levels(options = {})
|
44
|
-
options[:uri] = "/
|
44
|
+
options[:uri] = "#{service.base_path}/admin/organizations/#{id}/authenticationLevels"
|
45
45
|
data = service.admin_edit_authentication_levels(options).body
|
46
46
|
level = Fog::Compute::Ecloud::AdminOrganizations.new(:service => service, :href => data[:href])[0]
|
47
47
|
end
|
48
48
|
|
49
49
|
def edit_password_complexity_rules(options = {})
|
50
|
-
options[:uri] = "/
|
50
|
+
options[:uri] = "#{service.base_path}/admin/organizations/#{id}/passwordComplexityRules"
|
51
51
|
data = service.admin_edit_password_complexity_rules(options).body
|
52
52
|
level = Fog::Compute::Ecloud::PasswordComplexityRules.new(:service => service, :href => data[:href])[0]
|
53
53
|
end
|
54
54
|
|
55
55
|
def edit_login_banner(options = {})
|
56
|
-
options[:uri] = "/
|
56
|
+
options[:uri] = "#{service.base_path}/admin/organizations/#{id}/loginBanner"
|
57
57
|
data = service.admin_edit_login_banner(options).body
|
58
58
|
banner = Fog::Compute::Ecloud::LoginBanners.new(:service => service, :href => data[:href])[0]
|
59
59
|
end
|
60
60
|
|
61
61
|
def enable_support_access(options = {})
|
62
|
-
options[:uri] = "/
|
62
|
+
options[:uri] = "#{service.base_path}/admin/organizations/#{id}/action/enableSupportAccess"
|
63
63
|
service.admin_enable_support_access(options[:uri])
|
64
64
|
end
|
65
65
|
|
66
66
|
def disable_support_access(options = {})
|
67
|
-
options[:uri] = "/
|
67
|
+
options[:uri] = "#{service.base_path}/admin/organizations/#{id}/action/disableSupportAccess"
|
68
68
|
service.admin_disable_support_access(options[:uri])
|
69
69
|
end
|
70
70
|
|
@@ -33,7 +33,7 @@ module Fog
|
|
33
33
|
end
|
34
34
|
|
35
35
|
def create_group(options = {})
|
36
|
-
options[:uri] = "/
|
36
|
+
options[:uri] = "#{service.base_path}/layoutGroups/environments/#{environment_id}/action/createLayoutGroup"
|
37
37
|
options[:row_name] = name
|
38
38
|
options[:href] = href
|
39
39
|
data = service.groups_create(options).body
|
@@ -26,7 +26,7 @@ module Fog
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def create(options = {})
|
29
|
-
options[:uri] = "/
|
29
|
+
options[:uri] = "#{service.base_path}/layoutRows/environments/#{environment_id}/action/createLayoutRow"
|
30
30
|
data = service.rows_create(options).body
|
31
31
|
new(data)
|
32
32
|
end
|
@@ -39,11 +39,11 @@ module Fog
|
|
39
39
|
end
|
40
40
|
|
41
41
|
def tasks
|
42
|
-
@tasks ||= self.service.tasks(:href => "/
|
42
|
+
@tasks ||= self.service.tasks(:href => "#{service.base_path}/tasks/virtualMachines/#{id}")
|
43
43
|
end
|
44
44
|
|
45
45
|
def processes
|
46
|
-
@processes ||= Fog::Compute::Ecloud::GuestProcesses.new(:service, service, :href => "/
|
46
|
+
@processes ||= Fog::Compute::Ecloud::GuestProcesses.new(:service, service, :href => "#{service.base_path}/virtualMachines/#{id}/guest/processes")
|
47
47
|
end
|
48
48
|
|
49
49
|
def hardware_configuration=(hardware_configuration)
|
@@ -51,12 +51,12 @@ module Fog
|
|
51
51
|
end
|
52
52
|
|
53
53
|
def hardware_configuration
|
54
|
-
@hardware_configuration ||= self.service.hardware_configurations.new(:href => "/
|
54
|
+
@hardware_configuration ||= self.service.hardware_configurations.new(:href => "#{service.base_path}/virtualMachines/#{id}/hardwareConfiguration")
|
55
55
|
@hardware_configuration.reload
|
56
56
|
end
|
57
57
|
|
58
58
|
def configuration
|
59
|
-
@configuration ||= Fog::Compute::Ecloud::ServerConfigurationOptions.new(:service => service, :href => "/
|
59
|
+
@configuration ||= Fog::Compute::Ecloud::ServerConfigurationOptions.new(:service => service, :href => "#{service.base_path}/virtualMachines/#{id}/configurationOptions")[0]
|
60
60
|
end
|
61
61
|
|
62
62
|
def ips
|
@@ -64,7 +64,7 @@ module Fog
|
|
64
64
|
end
|
65
65
|
|
66
66
|
def networks
|
67
|
-
@networks ||= self.service.networks(:href => "/
|
67
|
+
@networks ||= self.service.networks(:href => "#{service.base_path}/virtualMachines/#{id}/assignedIps")
|
68
68
|
end
|
69
69
|
|
70
70
|
def power_on
|
@@ -108,16 +108,16 @@ module Fog
|
|
108
108
|
options[:ips][index] = ip
|
109
109
|
end
|
110
110
|
end
|
111
|
-
data = service.virtual_machine_copy("/
|
111
|
+
data = service.virtual_machine_copy("#{service.base_path}/virtualMachines/computePools/#{compute_pool_id}/action/copyVirtualMachine", options).body
|
112
112
|
elsif options[:type] == :identical
|
113
|
-
data = service.virtual_machine_copy_identical("/
|
113
|
+
data = service.virtual_machine_copy_identical("#{service.base_path}/virtualMachines/computePools/#{compute_pool_id}/action/copyIdenticalVirtualMachine", options).body
|
114
114
|
end
|
115
115
|
vm = collection.from_data(data)
|
116
116
|
vm
|
117
117
|
end
|
118
118
|
|
119
119
|
def rnats
|
120
|
-
rnats = Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "/
|
120
|
+
rnats = Fog::Compute::Ecloud::Rnats.new(:service => service, :href => "#{service.base_path}/rnats/environments/#{environment_id}")
|
121
121
|
associations = nil
|
122
122
|
rnats.each do |rnat|
|
123
123
|
if rnats.index(rnat) == 0
|
@@ -148,7 +148,7 @@ module Fog
|
|
148
148
|
|
149
149
|
def create_rnat(options)
|
150
150
|
options[:host_ip_href] ||= ips.first.href
|
151
|
-
options[:uri] = "/
|
151
|
+
options[:uri] = "#{service.base_path}/rnats/environments/#{environment_id}/action/createAssociation"
|
152
152
|
data = service.rnat_associations_create_device(options).body
|
153
153
|
rnat = Fog::Compute::Ecloud::Associations.new(:service => service, :href => data[:href])[0]
|
154
154
|
end
|
@@ -14,7 +14,9 @@ module Fog
|
|
14
14
|
data = service.get_templates(href).body[:Families]
|
15
15
|
data[:Family].is_a?(Hash) ? data = [data[:Family]] : data = data[:Family]
|
16
16
|
data.each do |d|
|
17
|
-
d[:Categories][:Category]
|
17
|
+
cats = d[:Categories][:Category]
|
18
|
+
cats = [cats] if cats.is_a?(Hash)
|
19
|
+
cats.each do |cat|
|
18
20
|
cat[:OperatingSystems][:OperatingSystem].is_a?(Hash) ? cat = [cat[:OperatingSystems][:OperatingSystem]] : cat = cat[:OperatingSystems][:OperatingSystem]
|
19
21
|
cat.each do |os|
|
20
22
|
os[:Templates][:Template].is_a?(Hash) ? os = [os[:Templates][:Template]] : os = os[:Templates][:Template]
|
@@ -19,11 +19,11 @@ module Fog
|
|
19
19
|
attribute :is_multifactor_authentication_enabled, :aliases => :IsMultifactorAuthenticationEnabled, :type => :boolean
|
20
20
|
|
21
21
|
def roles
|
22
|
-
@roles = Fog::Compute::Ecloud::Roles.new(:service => service, :href => "/
|
22
|
+
@roles = Fog::Compute::Ecloud::Roles.new(:service => service, :href => "#{service.base_path}/admin/roles/users/#{id}")
|
23
23
|
end
|
24
24
|
|
25
25
|
def api_keys
|
26
|
-
@api_keys = Fog::Compute::Ecloud::ApiKeys.new(:service => service, :href => "/
|
26
|
+
@api_keys = Fog::Compute::Ecloud::ApiKeys.new(:service => service, :href => "#{service.base_path}/admin/apiKeys/users/#{id}")
|
27
27
|
end
|
28
28
|
|
29
29
|
def id
|
@@ -18,7 +18,7 @@ module Fog
|
|
18
18
|
network_id = @network.href.match(/(\d+)$/)[1]
|
19
19
|
address_ip = network_address[:IpAddresses][:IpAddress]
|
20
20
|
@address = self.service.ip_addresses.new(
|
21
|
-
:href => "/
|
21
|
+
:href => "#{service.base_path}/ipaddresses/networks/#{network_id}/#{address_ip}",
|
22
22
|
:name => address_ip
|
23
23
|
)
|
24
24
|
end
|
@@ -5,7 +5,7 @@ module Fog
|
|
5
5
|
class Real
|
6
6
|
def get_virtual_machine_assigned_ips(virtual_machine_id)
|
7
7
|
request(
|
8
|
-
:uri => "/
|
8
|
+
:uri => "#{base_path}/virtualmachines/#{virtual_machine_id}/assignedips",
|
9
9
|
:parse => true
|
10
10
|
)
|
11
11
|
end
|
@@ -84,7 +84,7 @@ module Fog
|
|
84
84
|
self
|
85
85
|
end
|
86
86
|
|
87
|
-
def create_snapshot(
|
87
|
+
def create_snapshot(snapshot_name, snapshot_description="")
|
88
88
|
requires :name
|
89
89
|
requires :zone_name
|
90
90
|
|
@@ -93,18 +93,18 @@ module Fog
|
|
93
93
|
end
|
94
94
|
|
95
95
|
options = {
|
96
|
-
'name' =>
|
97
|
-
'description' =>
|
96
|
+
'name' => snapshot_name,
|
97
|
+
'description' => snapshot_description,
|
98
98
|
}
|
99
99
|
|
100
100
|
service.insert_snapshot(name, self.zone, service.project, options)
|
101
101
|
data = service.backoff_if_unfound {
|
102
|
-
service.get_snapshot(
|
102
|
+
service.get_snapshot(snapshot_name, service.project).body
|
103
103
|
}
|
104
104
|
service.snapshots.merge_attributes(data)
|
105
105
|
|
106
106
|
# Try to return the representation of the snapshot we created
|
107
|
-
service.snapshots.get(
|
107
|
+
service.snapshots.get(snapshot_name)
|
108
108
|
end
|
109
109
|
|
110
110
|
RUNNING_STATE = "READY"
|
@@ -9,8 +9,15 @@ module Fog
|
|
9
9
|
|
10
10
|
model Fog::Compute::Google::Disk
|
11
11
|
|
12
|
-
def all(
|
13
|
-
|
12
|
+
def all(filters={})
|
13
|
+
if filters['zone'].nil?
|
14
|
+
data = []
|
15
|
+
service.list_zones.body['items'].each do |zone|
|
16
|
+
data += service.list_disks(zone['name']).body["items"] || []
|
17
|
+
end
|
18
|
+
else
|
19
|
+
data = service.list_disks(filters['zone']).body["items"] || []
|
20
|
+
end
|
14
21
|
load(data)
|
15
22
|
end
|
16
23
|
|
data/lib/fog/hp.rb
CHANGED
@@ -1,11 +1,12 @@
|
|
1
1
|
require 'fog/core'
|
2
|
+
require 'fog/hp/simple_http_instrumentor'
|
2
3
|
|
3
4
|
module Fog
|
4
5
|
module HP
|
5
6
|
|
6
7
|
# define a specific version for the HP Provider
|
7
8
|
unless const_defined?(:VERSION)
|
8
|
-
VERSION = '0.0.
|
9
|
+
VERSION = '0.0.22'
|
9
10
|
end
|
10
11
|
|
11
12
|
extend Fog::Provider
|
@@ -55,10 +56,14 @@ module Fog
|
|
55
56
|
end
|
56
57
|
end
|
57
58
|
|
59
|
+
service(:block_storage, 'hp/block_storage', 'BlockStorage')
|
60
|
+
service(:block_storage_v2, 'hp/block_storage_v2', 'BlockStorageV2')
|
58
61
|
service(:cdn, 'hp/cdn', 'CDN')
|
59
62
|
service(:compute, 'hp/compute', 'Compute')
|
63
|
+
service(:dns, 'hp/dns', 'DNS')
|
64
|
+
service(:lb, 'hp/lb', 'LB')
|
65
|
+
service(:network, 'hp/network', 'Network')
|
60
66
|
service(:storage, 'hp/storage', 'Storage')
|
61
|
-
service(:block_storage, 'hp/block_storage', 'BlockStorage')
|
62
67
|
|
63
68
|
# legacy swauth 1.0/1.1 style authentication
|
64
69
|
def self.authenticate_v1(options, connection_options = {})
|
@@ -99,8 +104,43 @@ module Fog
|
|
99
104
|
}
|
100
105
|
end
|
101
106
|
|
107
|
+
def self.service_catalog(options, connection_options = {})
|
108
|
+
creds = authenticate_v2(options, connection_options)
|
109
|
+
return {} if creds.nil?
|
110
|
+
return {} if creds[:service_catalog].nil?
|
111
|
+
return creds[:service_catalog]
|
112
|
+
end
|
113
|
+
|
102
114
|
# keystone based control services style authentication
|
103
115
|
def self.authenticate_v2(options, connection_options = {})
|
116
|
+
unless options[:credentials].nil?
|
117
|
+
expires = true
|
118
|
+
begin
|
119
|
+
expire = DateTime.parse(options[:credentials][:expires])
|
120
|
+
expires = false if expire > DateTime.now
|
121
|
+
rescue
|
122
|
+
end
|
123
|
+
if expires
|
124
|
+
options = options.clone
|
125
|
+
options.delete(:credentials)
|
126
|
+
else
|
127
|
+
service_catalog = options[:credentials][:service_catalog]
|
128
|
+
type = options[:hp_service_type]
|
129
|
+
zone = options[:hp_avl_zone]
|
130
|
+
begin
|
131
|
+
creds = options[:credentials].clone
|
132
|
+
creds[:endpoint_url] = get_endpoint_url(service_catalog, type, zone)
|
133
|
+
begin
|
134
|
+
creds[:cdn_endpoint_url] = get_endpoint_url(service_catalog, "CDN", zone)
|
135
|
+
rescue
|
136
|
+
end
|
137
|
+
return creds
|
138
|
+
rescue
|
139
|
+
end
|
140
|
+
options = options.clone
|
141
|
+
options.delete(:credentials)
|
142
|
+
end
|
143
|
+
end
|
104
144
|
hp_auth_uri = options[:hp_auth_uri] || "https://region-a.geo-1.identity.hpcloudsvc.com:35357/v2.0/tokens"
|
105
145
|
# append /tokens if missing from auth uri
|
106
146
|
@hp_auth_uri = hp_auth_uri.include?('tokens')? hp_auth_uri : hp_auth_uri + "tokens"
|
@@ -170,18 +210,22 @@ module Fog
|
|
170
210
|
|
171
211
|
### fish out auth_token and endpoint for the service
|
172
212
|
auth_token = body['access']['token']['id']
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
213
|
+
expires = body['access']['token']['expires']
|
214
|
+
service_catalog = get_service_catalog(body['access']['serviceCatalog'])
|
215
|
+
endpoint_url = get_endpoint_url(service_catalog, @hp_service_type, @hp_avl_zone)
|
216
|
+
begin
|
217
|
+
cdn_endpoint_url = get_endpoint_url(service_catalog, "CDN", @hp_avl_zone)
|
218
|
+
rescue
|
177
219
|
end
|
178
220
|
|
179
|
-
|
221
|
+
creds = {
|
180
222
|
:auth_token => auth_token,
|
223
|
+
:expires => expires,
|
224
|
+
:service_catalog => service_catalog,
|
181
225
|
:endpoint_url => endpoint_url,
|
182
226
|
:cdn_endpoint_url => cdn_endpoint_url
|
183
227
|
}
|
184
|
-
|
228
|
+
return creds
|
185
229
|
end
|
186
230
|
|
187
231
|
# CGI.escape, but without special treatment on spaces
|
@@ -191,22 +235,50 @@ module Fog
|
|
191
235
|
end
|
192
236
|
end
|
193
237
|
|
238
|
+
# converts any attributes hash from aliased keys to original attribute keys
|
239
|
+
def self.convert_aliased_attributes_to_original(model, attributes)
|
240
|
+
original_attributes = {}
|
241
|
+
attributes.each do |k, v|
|
242
|
+
if orig_key = model.aliases.invert[k]
|
243
|
+
original_attributes[orig_key] = v
|
244
|
+
else
|
245
|
+
original_attributes[k] = v
|
246
|
+
end
|
247
|
+
end
|
248
|
+
original_attributes
|
249
|
+
end
|
250
|
+
|
194
251
|
private
|
195
252
|
|
196
|
-
def self.
|
197
|
-
raise "Unable to parse service catalog." unless
|
198
|
-
|
199
|
-
|
200
|
-
s["name"]
|
253
|
+
def self.get_service_catalog(body)
|
254
|
+
raise "Unable to parse service catalog." unless body
|
255
|
+
service_catalog = {}
|
256
|
+
body.each do |s|
|
257
|
+
name = s["name"]
|
258
|
+
next if name.nil?
|
259
|
+
name = name.to_sym
|
260
|
+
next if s['endpoints'].nil?
|
261
|
+
service_catalog[name] = {}
|
262
|
+
s['endpoints'].each do |ep|
|
263
|
+
next if ep['region'].nil?
|
264
|
+
next if ep['publicURL'].nil?
|
265
|
+
next if ep['publicURL'].empty?
|
266
|
+
service_catalog[name][ep['region'].to_sym] = ep['publicURL']
|
267
|
+
end
|
201
268
|
end
|
202
|
-
|
203
|
-
|
204
|
-
|
269
|
+
return service_catalog
|
270
|
+
end
|
271
|
+
|
272
|
+
def self.get_endpoint_url(service_catalog, service_type, avl_zone)
|
273
|
+
return nil if service_type.nil?
|
274
|
+
service_type = service_type.to_sym
|
275
|
+
avl_zone = avl_zone.to_sym
|
276
|
+
unless service_catalog[service_type].nil?
|
277
|
+
unless service_catalog[service_type][avl_zone].nil?
|
278
|
+
return service_catalog[service_type][avl_zone]
|
205
279
|
end
|
206
|
-
endpoint_url = endpoint['publicURL'] if endpoint
|
207
|
-
raise "Unable to retrieve endpoint service url for availability zone '#{avl_zone}' from service catalog. " if endpoint_url.nil?
|
208
|
-
return endpoint_url
|
209
280
|
end
|
281
|
+
raise "Unable to retrieve endpoint service url for availability zone '#{avl_zone}' from service catalog. "
|
210
282
|
end
|
211
283
|
|
212
284
|
def self.set_user_agent_header(conn_opts, base_str, client_str)
|
@@ -257,6 +329,23 @@ module Fog
|
|
257
329
|
ip.join('.')
|
258
330
|
end
|
259
331
|
|
332
|
+
def self.uuid
|
333
|
+
# pattern of 8-4-4-4-12 hexadecimal digits
|
334
|
+
uuid = []
|
335
|
+
[8,4,4,4,12].each do |x|
|
336
|
+
uuid << Fog::Mock.random_hex(x)
|
337
|
+
end
|
338
|
+
uuid.join('-')
|
339
|
+
end
|
340
|
+
|
341
|
+
def self.mac_address
|
342
|
+
mac_add = []
|
343
|
+
6.times do
|
344
|
+
mac_add << Fog::Mock.random_hex(2)
|
345
|
+
end
|
346
|
+
mac_add.join(':')
|
347
|
+
end
|
348
|
+
|
260
349
|
end
|
261
350
|
|
262
351
|
end
|