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
@@ -0,0 +1,77 @@
|
|
1
|
+
require 'securerandom'
|
2
|
+
require 'rubygems/package'
|
3
|
+
require 'zlib'
|
4
|
+
require 'fog'
|
5
|
+
|
6
|
+
#
|
7
|
+
# Download CirrOS 0.3.0 image from launchpad (~6.5MB) to /tmp
|
8
|
+
# and upload it to Glance (the OpenStack Image Service).
|
9
|
+
#
|
10
|
+
# You will need to source OpenStack credentials since the script
|
11
|
+
# reads the following envionment variables:
|
12
|
+
#
|
13
|
+
# OS_PASSWORD
|
14
|
+
# OS_USERNAME
|
15
|
+
# OS_AUTH_URL
|
16
|
+
# OS_TENANT_NAME
|
17
|
+
#
|
18
|
+
# Should work with Fog >= 1.9, ruby 1.8.7 and 2.0
|
19
|
+
#
|
20
|
+
image_url = "https://launchpadlibrarian.net/83305869/cirros-0.3.0-x86_64-uec.tar.gz"
|
21
|
+
image_out = File.open("/tmp/cirros-image-#{SecureRandom.hex}", 'wb')
|
22
|
+
extract_path = "/tmp/cirros-#{SecureRandom.hex}-dir"
|
23
|
+
ami = "#{extract_path}/cirros-0.3.0-x86_64-blank.img"
|
24
|
+
aki = "#{extract_path}/cirros-0.3.0-x86_64-vmlinuz"
|
25
|
+
ari = "#{extract_path}/cirros-0.3.0-x86_64-initrd"
|
26
|
+
|
27
|
+
FileUtils.mkdir_p extract_path
|
28
|
+
|
29
|
+
# Efficient image write
|
30
|
+
puts "Downloading Cirros image..."
|
31
|
+
streamer = lambda do |chunk, remaining_bytes, total_bytes|
|
32
|
+
image_out.write chunk
|
33
|
+
end
|
34
|
+
Excon.get image_url, :response_block => streamer
|
35
|
+
image_out.close
|
36
|
+
puts "Image downloaded to #{image_out.path}"
|
37
|
+
|
38
|
+
puts "Extracting image contents to #{extract_path}..."
|
39
|
+
Gem::Package::TarReader.new(Zlib::GzipReader.open(image_out.path)).each do |entry|
|
40
|
+
FileUtils.mkdir_p "#{extract_path}/#{File.dirname(entry.full_name)}"
|
41
|
+
File.open "#{extract_path}/#{entry.full_name}", 'w' do |f|
|
42
|
+
f.write entry.read
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
image_service = Fog::Image.new({
|
47
|
+
:provider => 'OpenStack',
|
48
|
+
:openstack_api_key => ENV['OS_PASSWORD'],
|
49
|
+
:openstack_username => ENV["OS_USERNAME"],
|
50
|
+
:openstack_auth_url => ENV["OS_AUTH_URL"] + "/tokens",
|
51
|
+
:openstack_tenant => ENV["OS_TENANT_NAME"]
|
52
|
+
})
|
53
|
+
|
54
|
+
puts "Uploading AKI..."
|
55
|
+
aki = image_service.images.create :name => 'cirros-0.3.0-amd64-aki',
|
56
|
+
:size => File.size(aki),
|
57
|
+
:disk_format => 'aki',
|
58
|
+
:container_format => 'aki',
|
59
|
+
:location => aki
|
60
|
+
|
61
|
+
puts "Uploading ARI..."
|
62
|
+
ari = image_service.images.create :name => 'cirros-0.3.0-amd64-ari',
|
63
|
+
:size => File.size(ari),
|
64
|
+
:disk_format => 'ari',
|
65
|
+
:container_format => 'ari',
|
66
|
+
:location => ari
|
67
|
+
|
68
|
+
puts "Uploading AMI..."
|
69
|
+
image_service.images.create :name => 'cirros-0.3.0-amd64',
|
70
|
+
:size => File.size(ami),
|
71
|
+
:disk_format => 'ami',
|
72
|
+
:container_format => 'ami',
|
73
|
+
:location => ami,
|
74
|
+
:properties => {
|
75
|
+
'kernel_id' => aki.id,
|
76
|
+
'ramdisk_id' => ari.id
|
77
|
+
}
|
@@ -0,0 +1,63 @@
|
|
1
|
+
require 'fog/openstack'
|
2
|
+
|
3
|
+
#
|
4
|
+
# Quantum demo
|
5
|
+
#
|
6
|
+
# Create some routers, networks and subnets for
|
7
|
+
# a couple of tenants.
|
8
|
+
#
|
9
|
+
# Needs Fog >= 1.11.0
|
10
|
+
# Needs OpenStack credentials in ~/.fog
|
11
|
+
#
|
12
|
+
|
13
|
+
def create_tenant_network( tenant_name,
|
14
|
+
external_net,
|
15
|
+
router_name = 'router1',
|
16
|
+
subnet_range = '10.0.0.0/21',
|
17
|
+
subnet_gateway = '10.0.0.1',
|
18
|
+
private_network_name = 'private' )
|
19
|
+
|
20
|
+
network = Fog::Network[:openstack]
|
21
|
+
id = Fog::Identity[:openstack]
|
22
|
+
|
23
|
+
tenant = id.tenants.find { |t| t.name == tenant_name }
|
24
|
+
|
25
|
+
# Create a router for the tenant
|
26
|
+
router = network.routers.create :name => router_name,
|
27
|
+
:tenant_id => tenant.id,
|
28
|
+
:external_gateway_info => {
|
29
|
+
'network_id' => external_net.id
|
30
|
+
}
|
31
|
+
|
32
|
+
# Create a private network for the tenant
|
33
|
+
net = network.networks.create :name => private_network_name,
|
34
|
+
:tenant_id => tenant.id
|
35
|
+
|
36
|
+
# Create a subnet for the previous network and associate it
|
37
|
+
# with the tenant
|
38
|
+
subnet = network.subnets.create :name => 'net_10',
|
39
|
+
:network_id => net.id,
|
40
|
+
:ip_version => 4,
|
41
|
+
:gateway_ip => subnet_gateway,
|
42
|
+
:cidr => subnet_range,
|
43
|
+
:tenant_id => tenant.id,
|
44
|
+
:enable_dhcp => true
|
45
|
+
|
46
|
+
network.add_router_interface router.id, subnet.id
|
47
|
+
end
|
48
|
+
|
49
|
+
# Create a public shared network
|
50
|
+
public_net = network.networks.create :name => 'nova',
|
51
|
+
:router_external => true
|
52
|
+
|
53
|
+
# Create the public subnet
|
54
|
+
public_subnet = network.subnets.create :name => 'floating_ips_net',
|
55
|
+
:network_id => public_net.id,
|
56
|
+
:ip_version => 4,
|
57
|
+
:cidr => '1.2.3.0/24',
|
58
|
+
:enable_dhcp => false
|
59
|
+
|
60
|
+
|
61
|
+
# Create tenant networks
|
62
|
+
create_tenant_network, 'admin@example.net', public_net
|
63
|
+
create_tenant_network, 'demo@example.net', public_net
|
@@ -0,0 +1,66 @@
|
|
1
|
+
require 'fog'
|
2
|
+
require 'pp'
|
3
|
+
|
4
|
+
#
|
5
|
+
# This example sets the account quota (in bytes) for the tenant demo@test.lan
|
6
|
+
# using an admin account (admin has the reseller user role).
|
7
|
+
#
|
8
|
+
# Uses the account impersonation feature recently added to the
|
9
|
+
# OpenStack Storage service in Fog (See https://github.com/fog/fog/pull/1632).
|
10
|
+
#
|
11
|
+
# Should be available in Fog 1.10.0+1.
|
12
|
+
#
|
13
|
+
# Setting account quotas is only supported in Swift 1.8.0+
|
14
|
+
# using the brand new account_quota middleware introduced in
|
15
|
+
# OpenStack Grizzly (currently unreleased as of 2013/04/03).
|
16
|
+
#
|
17
|
+
# https://github.com/openstack/swift/blob/master/swift/common/middleware/account_quotas.py
|
18
|
+
#
|
19
|
+
|
20
|
+
auth_url = 'https://identity.test.lan/v2.0/tokens'
|
21
|
+
user = 'admin@test.lan'
|
22
|
+
password = 'secret'
|
23
|
+
|
24
|
+
Excon.defaults[:ssl_verify_peer] = false
|
25
|
+
|
26
|
+
#
|
27
|
+
# We are going to use the Identity (Keystone) service
|
28
|
+
# to retrieve the list of tenants available and find
|
29
|
+
# the tenant we want to set the quotas for.
|
30
|
+
#
|
31
|
+
id = Fog::Identity.new :provider => 'OpenStack',
|
32
|
+
:openstack_auth_url => auth_url,
|
33
|
+
:openstack_username => user,
|
34
|
+
:openstack_api_key => password
|
35
|
+
|
36
|
+
#
|
37
|
+
# Storage service (Swift)
|
38
|
+
#
|
39
|
+
st = Fog::Storage.new :provider => 'OpenStack',
|
40
|
+
:openstack_auth_url => auth_url,
|
41
|
+
:openstack_username => user,
|
42
|
+
:openstack_api_key => password
|
43
|
+
|
44
|
+
id.tenants.each do |t|
|
45
|
+
# We want to set the account quota for tenant demo@test.lan
|
46
|
+
next unless t.name == 'demo@test.lan'
|
47
|
+
|
48
|
+
# We've found the tenant, impersonate the account
|
49
|
+
# (the account prefix AUTH_ may be different for you, double check it).
|
50
|
+
puts "Changing account to #{t.name}"
|
51
|
+
st.change_account "AUTH_#{t.id}"
|
52
|
+
|
53
|
+
# Now we're adding the required header to the demo@test.lan
|
54
|
+
# tenant account, limiting the account bytes to 1048576 (1MB)
|
55
|
+
#
|
56
|
+
# Uploading more than 1MB will return 413: Request Entity Too Large
|
57
|
+
st.request :method => 'POST',
|
58
|
+
:headers => { 'X-Account-Meta-Quota-Bytes' => '1048576' }
|
59
|
+
|
60
|
+
# We can list the account details to verify the new
|
61
|
+
# header has been added
|
62
|
+
pp st.request :method => 'HEAD'
|
63
|
+
end
|
64
|
+
|
65
|
+
# Restore the account we were using initially (admin@test.lan)
|
66
|
+
st.reset_account_name
|
data/lib/fog/openstack/image.rb
CHANGED
@@ -206,6 +206,10 @@ module Fog
|
|
206
206
|
@host = uri.host
|
207
207
|
@path = uri.path
|
208
208
|
@path.sub!(/\/$/, '')
|
209
|
+
unless @path.match(/v1(\.1)*/)
|
210
|
+
raise Fog::OpenStack::Errors::ServiceUnavailable.new(
|
211
|
+
"OpenStack binding only supports version 1.1 (a.k.a. 1)")
|
212
|
+
end
|
209
213
|
@port = uri.port
|
210
214
|
@scheme = uri.scheme
|
211
215
|
true
|
@@ -40,7 +40,7 @@ module Fog
|
|
40
40
|
attribute :os_ext_sts_vm_state, :aliases => 'OS-EXT-STS:vm_state'
|
41
41
|
|
42
42
|
attr_reader :password
|
43
|
-
attr_writer :image_ref, :flavor_ref, :os_scheduler_hints
|
43
|
+
attr_writer :image_ref, :flavor_ref, :nics, :os_scheduler_hints
|
44
44
|
|
45
45
|
|
46
46
|
def initialize(attributes={})
|
@@ -50,6 +50,7 @@ module Fog
|
|
50
50
|
self.security_groups = attributes.delete(:security_groups)
|
51
51
|
self.min_count = attributes.delete(:min_count)
|
52
52
|
self.max_count = attributes.delete(:max_count)
|
53
|
+
self.nics = attributes.delete(:nics)
|
53
54
|
self.os_scheduler_hints = attributes.delete(:os_scheduler_hints)
|
54
55
|
|
55
56
|
super
|
@@ -256,7 +257,8 @@ module Fog
|
|
256
257
|
'security_groups' => @security_groups,
|
257
258
|
'min_count' => @min_count,
|
258
259
|
'max_count' => @max_count,
|
259
|
-
'
|
260
|
+
'nics' => @nics,
|
261
|
+
'os:scheduler_hints' => @os_scheduler_hints,
|
260
262
|
}
|
261
263
|
options['metadata'] = metadata.to_hash unless @metadata.nil?
|
262
264
|
options = options.reject {|key, value| value.nil?}
|
@@ -29,7 +29,7 @@ module Fog
|
|
29
29
|
|
30
30
|
def create
|
31
31
|
requires :floating_network_id
|
32
|
-
merge_attributes(
|
32
|
+
merge_attributes(service.create_floating_ip(self.floating_network_id,
|
33
33
|
|
34
34
|
|
35
35
|
self.attributes).body['floatingip'])
|
@@ -42,7 +42,7 @@ module Fog
|
|
42
42
|
|
43
43
|
def destroy
|
44
44
|
requires :id
|
45
|
-
|
45
|
+
service.delete_floating_ip(self.id)
|
46
46
|
true
|
47
47
|
end
|
48
48
|
|
@@ -0,0 +1,56 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Network
|
5
|
+
class OpenStack
|
6
|
+
# The Layer-3 Networking Extensions (router)
|
7
|
+
#
|
8
|
+
# A logical entity for forwarding packets across internal
|
9
|
+
# subnets and NATting them on external networks through
|
10
|
+
# an appropriate external gateway.
|
11
|
+
#
|
12
|
+
# @see http://docs.openstack.org/api/openstack-network/2.0/content/router_ext.html
|
13
|
+
class Router < Fog::Model
|
14
|
+
identity :id
|
15
|
+
|
16
|
+
attribute :name
|
17
|
+
attribute :admin_state_up
|
18
|
+
attribute :tenant_id
|
19
|
+
attribute :external_gateway_info
|
20
|
+
attribute :status
|
21
|
+
|
22
|
+
def initialize(attributes)
|
23
|
+
# Old 'connection' is renamed as service and should be used instead
|
24
|
+
prepare_service_value(attributes)
|
25
|
+
super
|
26
|
+
end
|
27
|
+
|
28
|
+
def save
|
29
|
+
requires :name
|
30
|
+
identity ? update : create
|
31
|
+
end
|
32
|
+
|
33
|
+
def create
|
34
|
+
requires :name
|
35
|
+
merge_attributes(service.create_router(self.name,
|
36
|
+
self.attributes).body['router'])
|
37
|
+
self
|
38
|
+
end
|
39
|
+
|
40
|
+
def update
|
41
|
+
requires :id
|
42
|
+
merge_attributes(service.update_router(self.id,
|
43
|
+
self.attributes).body['router'])
|
44
|
+
self
|
45
|
+
end
|
46
|
+
|
47
|
+
def destroy
|
48
|
+
requires :id
|
49
|
+
service.delete_router(self.id)
|
50
|
+
true
|
51
|
+
end
|
52
|
+
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/openstack/models/network/router'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Network
|
6
|
+
class OpenStack
|
7
|
+
class Routers < Fog::Collection
|
8
|
+
|
9
|
+
attribute :filters
|
10
|
+
|
11
|
+
model Fog::Network::OpenStack::Router
|
12
|
+
|
13
|
+
def initialize(attributes)
|
14
|
+
self.filters ||= {}
|
15
|
+
super
|
16
|
+
end
|
17
|
+
|
18
|
+
def all(filters = filters)
|
19
|
+
self.filters = filters
|
20
|
+
load(service.list_routers(filters).body['routers'])
|
21
|
+
end
|
22
|
+
|
23
|
+
def get(router_id)
|
24
|
+
if router = service.get_router(router_id).body['router']
|
25
|
+
new(router)
|
26
|
+
end
|
27
|
+
rescue Fog::Network::OpenStack::NotFound
|
28
|
+
nil
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -7,7 +7,7 @@ module Fog
|
|
7
7
|
requires :openstack_auth_url
|
8
8
|
recognizes :openstack_auth_token, :openstack_management_url, :persistent,
|
9
9
|
:openstack_service_type, :openstack_service_name, :openstack_tenant,
|
10
|
-
:openstack_api_key, :openstack_username,
|
10
|
+
:openstack_api_key, :openstack_username, :openstack_endpoint_type,
|
11
11
|
:current_user, :current_tenant
|
12
12
|
|
13
13
|
## MODELS
|
@@ -21,6 +21,8 @@ module Fog
|
|
21
21
|
collection :subnets
|
22
22
|
model :floating_ip
|
23
23
|
collection :floating_ips
|
24
|
+
model :router
|
25
|
+
collection :routers
|
24
26
|
|
25
27
|
## REQUESTS
|
26
28
|
#
|
@@ -55,6 +57,15 @@ module Fog
|
|
55
57
|
request :associate_floating_ip
|
56
58
|
request :disassociate_floating_ip
|
57
59
|
|
60
|
+
# Router CRUD
|
61
|
+
request :list_routers
|
62
|
+
request :create_router
|
63
|
+
request :delete_router
|
64
|
+
request :get_router
|
65
|
+
request :update_router
|
66
|
+
request :add_router_interface
|
67
|
+
request :remove_router_interface
|
68
|
+
|
58
69
|
# Tenant
|
59
70
|
request :set_tenant
|
60
71
|
|
@@ -66,6 +77,7 @@ module Fog
|
|
66
77
|
:ports => {},
|
67
78
|
:subnets => {},
|
68
79
|
:floating_ips => {},
|
80
|
+
:routers => {},
|
69
81
|
}
|
70
82
|
end
|
71
83
|
end
|
@@ -120,6 +132,7 @@ module Fog
|
|
120
132
|
@openstack_must_reauthenticate = false
|
121
133
|
@openstack_service_type = options[:openstack_service_type] || ['network']
|
122
134
|
@openstack_service_name = options[:openstack_service_name]
|
135
|
+
@openstack_endpoint_type = options[:openstack_endpoint_type] || 'adminURL'
|
123
136
|
|
124
137
|
@connection_options = options[:connection_options] || {}
|
125
138
|
|
@@ -192,7 +205,7 @@ module Fog
|
|
192
205
|
:openstack_auth_token => @openstack_auth_token,
|
193
206
|
:openstack_service_type => @openstack_service_type,
|
194
207
|
:openstack_service_name => @openstack_service_name,
|
195
|
-
:openstack_endpoint_type =>
|
208
|
+
:openstack_endpoint_type => @openstack_endpoint_type
|
196
209
|
}
|
197
210
|
|
198
211
|
credentials = Fog::OpenStack.authenticate_v2(options, @connection_options)
|
@@ -41,6 +41,17 @@ module Fog
|
|
41
41
|
end
|
42
42
|
end
|
43
43
|
|
44
|
+
if options['nics']
|
45
|
+
data['server']['networks'] =
|
46
|
+
Array(options['nics']).map do |nic|
|
47
|
+
{
|
48
|
+
'uuid' => nic['net_id'],
|
49
|
+
'fixed_ip' => nic['v4_fixed_ip'],
|
50
|
+
'port' => nic['port_id']
|
51
|
+
}
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
44
55
|
if options['os:scheduler_hints']
|
45
56
|
data['os:scheduler_hints'] = options['os:scheduler_hints']
|
46
57
|
end
|
@@ -11,7 +11,15 @@ module Fog
|
|
11
11
|
}}
|
12
12
|
body['rebuild']['adminPass'] = admin_pass if admin_pass
|
13
13
|
body['rebuild']['metadata'] = metadata if metadata
|
14
|
-
|
14
|
+
if personality
|
15
|
+
body['rebuild']['personality'] = []
|
16
|
+
for file in personality
|
17
|
+
body['rebuild']['personality'] << {
|
18
|
+
'contents' => Base64.encode64(file['contents']),
|
19
|
+
'path' => file['path']
|
20
|
+
}
|
21
|
+
end
|
22
|
+
end
|
15
23
|
server_action(server_id, body, 202)
|
16
24
|
end
|
17
25
|
|