fog-vcloud-director 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.editorconfig +11 -0
- data/.gitignore +17 -0
- data/.hound.yml +2 -0
- data/.rubocop.yml +240 -0
- data/.ruby-gemset +1 -0
- data/.travis.yml +15 -0
- data/Gemfile +4 -0
- data/LICENSE.md +20 -0
- data/README.md +962 -0
- data/Rakefile +19 -0
- data/fog-vcloud-director.gemspec +31 -0
- data/lib/fog/vcloud_director.rb +1 -0
- data/lib/fog/vcloud_director/compute.rb +916 -0
- data/lib/fog/vcloud_director/core.rb +69 -0
- data/lib/fog/vcloud_director/generators/compute/compose_common.rb +122 -0
- data/lib/fog/vcloud_director/generators/compute/compose_vapp.rb +25 -0
- data/lib/fog/vcloud_director/generators/compute/create_snapshot.rb +25 -0
- data/lib/fog/vcloud_director/generators/compute/customization.rb +105 -0
- data/lib/fog/vcloud_director/generators/compute/disks.rb +186 -0
- data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +243 -0
- data/lib/fog/vcloud_director/generators/compute/instantiate_vapp_template_params.rb +30 -0
- data/lib/fog/vcloud_director/generators/compute/metadata.rb +104 -0
- data/lib/fog/vcloud_director/generators/compute/org_vdc_network.rb +88 -0
- data/lib/fog/vcloud_director/generators/compute/recompose_vapp.rb +34 -0
- data/lib/fog/vcloud_director/generators/compute/vapp.rb +28 -0
- data/lib/fog/vcloud_director/generators/compute/vm.rb +32 -0
- data/lib/fog/vcloud_director/generators/compute/vm_network.rb +119 -0
- data/lib/fog/vcloud_director/models/compute/catalog.rb +22 -0
- data/lib/fog/vcloud_director/models/compute/catalog_item.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/catalog_items.rb +33 -0
- data/lib/fog/vcloud_director/models/compute/catalogs.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/custom_field.rb +18 -0
- data/lib/fog/vcloud_director/models/compute/custom_fields.rb +67 -0
- data/lib/fog/vcloud_director/models/compute/disk.rb +53 -0
- data/lib/fog/vcloud_director/models/compute/disks.rb +44 -0
- data/lib/fog/vcloud_director/models/compute/media.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/medias.rb +75 -0
- data/lib/fog/vcloud_director/models/compute/network.rb +25 -0
- data/lib/fog/vcloud_director/models/compute/networks.rb +62 -0
- data/lib/fog/vcloud_director/models/compute/organization.rb +37 -0
- data/lib/fog/vcloud_director/models/compute/organizations.rb +28 -0
- data/lib/fog/vcloud_director/models/compute/tag.rb +31 -0
- data/lib/fog/vcloud_director/models/compute/tags.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/task.rb +55 -0
- data/lib/fog/vcloud_director/models/compute/tasks.rb +36 -0
- data/lib/fog/vcloud_director/models/compute/template_vm.rb +52 -0
- data/lib/fog/vcloud_director/models/compute/template_vms.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/vapp.rb +144 -0
- data/lib/fog/vcloud_director/models/compute/vapp_template.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/vapp_templates.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vapps.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vdc.rb +45 -0
- data/lib/fog/vcloud_director/models/compute/vdcs.rb +37 -0
- data/lib/fog/vcloud_director/models/compute/vm.rb +197 -0
- data/lib/fog/vcloud_director/models/compute/vm_customization.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vm_customizations.rb +29 -0
- data/lib/fog/vcloud_director/models/compute/vm_network.rb +27 -0
- data/lib/fog/vcloud_director/models/compute/vm_networks.rb +19 -0
- data/lib/fog/vcloud_director/models/compute/vms.rb +46 -0
- data/lib/fog/vcloud_director/parsers/compute/disks.rb +53 -0
- data/lib/fog/vcloud_director/parsers/compute/metadata.rb +61 -0
- data/lib/fog/vcloud_director/parsers/compute/network.rb +104 -0
- data/lib/fog/vcloud_director/parsers/compute/vm.rb +86 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_customization.rb +55 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_network.rb +107 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_parser_helper.rb +62 -0
- data/lib/fog/vcloud_director/parsers/compute/vms.rb +68 -0
- data/lib/fog/vcloud_director/parsers/compute/vms_by_metadata.rb +37 -0
- data/lib/fog/vcloud_director/query.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk.rb +60 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_logout.rb +18 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media.rb +122 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_network.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/delete_shadow_vm.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_metadata_item_metadata.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_allocated_ip_addresses.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +63 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +48 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalogs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_catalog.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_cpu_rasd_item.rb +65 -0
- data/lib/fog/vcloud_director/requests/compute/get_current_session.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk.rb +123 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_owner.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_rasd_items_list.rb +90 -0
- data/lib/fog/vcloud_director/requests/compute/get_edge_gateway.rb +109 -0
- data/lib/fog/vcloud_director/requests/compute/get_entity.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +736 -0
- data/lib/fog/vcloud_director/requests/compute/get_groups_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp.rb +69 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_href.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media.rb +111 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_drives_rasd_items_list.rb +92 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_owner.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_medias_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_memory_rasd_item.rb +64 -0
- data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_network.rb +67 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_cards_items_list.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_complete.rb +78 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp.rb +61 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp.rb +68 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_operating_system_section.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_settings.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_vdc_gateways.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization.rb +100 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp_template.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_request.rb +19 -0
- data/lib/fog/vcloud_director/requests/compute/get_runtime_info_section_type.rb +57 -0
- data/lib/fog/vcloud_director/requests/compute/get_serial_ports_items_list.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_shadow_vm.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_snapshot_section.rb +55 -0
- data/lib/fog/vcloud_director/requests/compute/get_startup_section.rb +64 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_systems_info.rb +239 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_versions.rb +1159 -0
- data/lib/fog/vcloud_director/requests/compute/get_task.rb +168 -0
- data/lib/fog/vcloud_director/requests/compute/get_task_list.rb +130 -0
- data/lib/fog/vcloud_director/requests/compute/get_template_vm.rb +74 -0
- data/lib/fog/vcloud_director/requests/compute/get_template_vms.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_thumbnail.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_users_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +176 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata.rb +84 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_owner.rb +58 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_customization_system_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata_item_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_owner.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_templates_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapps_in_lease_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_vcloud.rb +76 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc.rb +174 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdcs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_virtual_hardware_section.rb +29 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm.rb +74 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_capabilities.rb +61 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_compliance_results.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_customization.rb +31 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +56 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_pending_question.rb +34 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_by_metadata.rb +20 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_disk_attached_to.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_in_lease_from_query.rb +150 -0
- data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +173 -0
- data/lib/fog/vcloud_director/requests/compute/post_acquire_ticket.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_answer_vm_pending_question.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_attach_disk.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_cancel_task.rb +43 -0
- data/lib/fog/vcloud_director/requests/compute/post_capture_vapp.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/post_check_vm_compliance.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_media.rb +102 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp_template.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_compose_vapp.rb +45 -0
- data/lib/fog/vcloud_director/requests/compute/post_configure_edge_gateway_services.rb +73 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_catalog_item.rb +56 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_org_vdc_network.rb +171 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_snapshot.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/post_deploy_vapp.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_detach_disk.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_discard_vapp_state.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/post_eject_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_enter_maintenance_mode.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/post_exit_maintenance_mode.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/post_insert_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_install_vmware_tools.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_instantiate_vapp_template.rb +196 -0
- data/lib/fog/vcloud_director/requests/compute/post_login_session.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_off_vapp.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +71 -0
- data/lib/fog/vcloud_director/requests/compute/post_reboot_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_recompose_vapp.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/post_reconfigure_vm.rb +118 -0
- data/lib/fog/vcloud_director/requests/compute/post_remove_all_snapshots.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_reset_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_revert_snapshot.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_shutdown_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_suspend_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_undeploy_vapp.rb +66 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_catalog_item_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_disk_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_media_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +86 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_template_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_upgrade_hw_version.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_disk.rb +133 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_media.rb +120 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_vapp_template.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_catalog_item_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_cpu.rb +88 -0
- data/lib/fog/vcloud_director/requests/compute/put_disk_metadata_item_metadata.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_disks.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +141 -0
- data/lib/fog/vcloud_director/requests/compute/put_media_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_memory.rb +89 -0
- data/lib/fog/vcloud_director/requests/compute/put_metadata_value.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/put_network.rb +162 -0
- data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +152 -0
- data/lib/fog/vcloud_director/requests/compute/put_product_sections.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_metadata_item_metadata.rb +85 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_name_and_description.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_template_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm.rb +72 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm_capabilities.rb +44 -0
- data/lib/fog/vcloud_director/version.rb +5 -0
- data/spec/spec_helper.rb +15 -0
- data/spec/vcloud_director/generators/compute/instantiate_vapp_template_params_spec.rb +68 -0
- data/spec/vcloud_director/requests/compute/instantiate_vapp_template_spec.rb +78 -0
- data/spec/vcloud_director/spec_helper.rb +11 -0
- data/tasks/bundler.rake +3 -0
- data/tasks/console.rake +12 -0
- data/tasks/lint.rake +3 -0
- data/tasks/test.rake +13 -0
- data/tests/helper.rb +32 -0
- data/tests/helpers/collection_helper.rb +97 -0
- data/tests/helpers/compute/flavors_helper.rb +32 -0
- data/tests/helpers/compute/server_helper.rb +25 -0
- data/tests/helpers/compute/servers_helper.rb +10 -0
- data/tests/helpers/formats_helper.rb +98 -0
- data/tests/helpers/formats_helper_tests.rb +110 -0
- data/tests/helpers/mock_helper.rb +95 -0
- data/tests/helpers/model_helper.rb +31 -0
- data/tests/helpers/responds_to_helper.rb +11 -0
- data/tests/helpers/schema_validator_tests.rb +107 -0
- data/tests/helpers/succeeds_helper.rb +9 -0
- data/tests/lorem.txt +1 -0
- data/tests/vcloud_director/ensure_list_tests.rb +84 -0
- data/tests/vcloud_director/fixtures/test.iso +1 -0
- data/tests/vcloud_director/fixtures/vapp.xml +532 -0
- data/tests/vcloud_director/fixtures/vm.xml +213 -0
- data/tests/vcloud_director/generators/compute/compose_vapp_tests.rb +108 -0
- data/tests/vcloud_director/models/compute/catalog_items_tests.rb +42 -0
- data/tests/vcloud_director/models/compute/catalogs_tests.rb +40 -0
- data/tests/vcloud_director/models/compute/helper.rb +60 -0
- data/tests/vcloud_director/models/compute/media_tests.rb +58 -0
- data/tests/vcloud_director/models/compute/network_tests.rb +108 -0
- data/tests/vcloud_director/models/compute/organizations_tests.rb +18 -0
- data/tests/vcloud_director/models/compute/tasks_tests.rb +56 -0
- data/tests/vcloud_director/models/compute/vapp_life_cycle_tests.rb +93 -0
- data/tests/vcloud_director/models/compute/vapp_template_tests.rb +29 -0
- data/tests/vcloud_director/models/compute/vapp_tests.rb +61 -0
- data/tests/vcloud_director/models/compute/vdcs_tests.rb +54 -0
- data/tests/vcloud_director/models/compute/vms_tests.rb +101 -0
- data/tests/vcloud_director/requests/compute/admin_tests.rb +16 -0
- data/tests/vcloud_director/requests/compute/catalog_tests.rb +42 -0
- data/tests/vcloud_director/requests/compute/disk_tests.rb +178 -0
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +217 -0
- data/tests/vcloud_director/requests/compute/groups_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/helper.rb +32 -0
- data/tests/vcloud_director/requests/compute/media_tests.rb +195 -0
- data/tests/vcloud_director/requests/compute/network_tests.rb +186 -0
- data/tests/vcloud_director/requests/compute/organization_tests.rb +37 -0
- data/tests/vcloud_director/requests/compute/ovf_descriptor_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/query_tests.rb +99 -0
- data/tests/vcloud_director/requests/compute/schema_helper.rb +663 -0
- data/tests/vcloud_director/requests/compute/session_tests.rb +14 -0
- data/tests/vcloud_director/requests/compute/supported_systems_tests.rb +11 -0
- data/tests/vcloud_director/requests/compute/task_tests.rb +35 -0
- data/tests/vcloud_director/requests/compute/users_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/vapp_tests.rb +123 -0
- data/tests/vcloud_director/requests/compute/vdc_storage_profile_tests.rb +27 -0
- data/tests/vcloud_director/requests/compute/vdc_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/versions_tests.rb +13 -0
- data/tests/vcloud_director/requests/compute/vm_tests.rb +185 -0
- data/tests/watchr.rb +22 -0
- metadata +461 -0
@@ -0,0 +1,123 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve a disk.
|
6
|
+
#
|
7
|
+
# @param [String] id Object identifier of the disk.
|
8
|
+
# @return [Excon::Response]
|
9
|
+
# * body<~Hash>:
|
10
|
+
# * :href<~String> - The URI of the disk.
|
11
|
+
# * :type<~String> - The MIME type of the disk.
|
12
|
+
# * :id<~String> - The disk identifier, expressed in URN format.
|
13
|
+
# * :name<~String> - The name of the disk.
|
14
|
+
# * :status<~String> - Creation status of the disk.
|
15
|
+
# * :busSubType<~String> - Disk bus sub type.
|
16
|
+
# * :busType<~String> - Disk bus type.
|
17
|
+
# * :size<~String> - Size of the disk.
|
18
|
+
# * :Description<~String> - Optional description.
|
19
|
+
# * :Tasks<~Hash> - A list of queued, running, or recently
|
20
|
+
# completed tasks associated with this disk.
|
21
|
+
# * :StorageProfile<~Hash> - Storage profile of the disk.
|
22
|
+
# * :Owner<~Hash> - Disk owner.
|
23
|
+
#
|
24
|
+
# @raise [Fog::Compute::VcloudDirector::Forbidden]
|
25
|
+
#
|
26
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-Disk.html
|
27
|
+
# @since vCloud API version 5.1
|
28
|
+
def get_disk(id)
|
29
|
+
response = request(
|
30
|
+
:expects => 200,
|
31
|
+
:idempotent => true,
|
32
|
+
:method => 'GET',
|
33
|
+
:parser => Fog::ToHashDocument.new,
|
34
|
+
:path => "disk/#{id}"
|
35
|
+
)
|
36
|
+
ensure_list! response.body, :Link
|
37
|
+
ensure_list! response.body, :Tasks, :Task
|
38
|
+
ensure_list! response.body, :Files, :File
|
39
|
+
response
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
class Mock
|
44
|
+
def get_disk(id)
|
45
|
+
unless data[:disks][id]
|
46
|
+
raise Fog::Compute::VcloudDirector::Forbidden.new(
|
47
|
+
'No access to entity "com.vmware.vcloud.entity.disk:%s".' % id
|
48
|
+
)
|
49
|
+
end
|
50
|
+
|
51
|
+
body = {
|
52
|
+
:xmlns => xmlns,
|
53
|
+
:xmlns_xsi => xmlns_xsi,
|
54
|
+
:xsi_schemaLocation => xsi_schema_location
|
55
|
+
}.merge(disk_body(id))
|
56
|
+
|
57
|
+
Excon::Response.new(
|
58
|
+
:status => 200,
|
59
|
+
:headers => {'Content-Type' => "#{body[:type]};version=#{@version}"},
|
60
|
+
:body => body
|
61
|
+
)
|
62
|
+
end
|
63
|
+
|
64
|
+
private
|
65
|
+
|
66
|
+
def disk_body(id)
|
67
|
+
disk = data[:disks][id]
|
68
|
+
storage_class_id = disk[:vdc_storage_class]
|
69
|
+
|
70
|
+
body = {
|
71
|
+
:href => make_href("disk/#{id}"),
|
72
|
+
:type => 'application/vnd.vmware.vcloud.disk+xml',
|
73
|
+
:id => "urn:vcloud:disk:#{id}",
|
74
|
+
:name => disk[:name],
|
75
|
+
:status => disk[:status].to_s,
|
76
|
+
:busSubType => disk[:bus_sub_type],
|
77
|
+
:busType => disk[:bus_type],
|
78
|
+
:size => disk[:size].to_s,
|
79
|
+
:Link => [
|
80
|
+
{
|
81
|
+
:href => make_href("vdc/#{disk[:vdc_id]}"),
|
82
|
+
:rel => 'up',
|
83
|
+
:type => 'application/vnd.vmware.vcloud.vdc+xml'
|
84
|
+
}
|
85
|
+
],
|
86
|
+
:Description => disk[:description],
|
87
|
+
:Tasks => {
|
88
|
+
# FIXME: there's only one for now
|
89
|
+
:Task => disk[:tasks].map {|task_id| task_body(task_id)}.first
|
90
|
+
},
|
91
|
+
:Files => {
|
92
|
+
:File => []
|
93
|
+
},
|
94
|
+
:StorageProfile => {
|
95
|
+
:href => make_href("vdcStorageProfile/#{storage_class_id}"),
|
96
|
+
:name => data[:vdc_storage_classes][storage_class_id][:name],
|
97
|
+
:type => 'application/vnd.vmware.vcloud.vdcStorageProfile+xml',
|
98
|
+
},
|
99
|
+
:Owner => {
|
100
|
+
:type => 'application/vnd.vmware.vcloud.owner+xml',
|
101
|
+
:User => {
|
102
|
+
:href => make_href("admin/user/#{user_uuid}"),
|
103
|
+
:name => user_name,
|
104
|
+
:type => 'application/vnd.vmware.admin.user+xml',
|
105
|
+
}
|
106
|
+
}
|
107
|
+
}
|
108
|
+
|
109
|
+
if api_version.to_f >= 5.1
|
110
|
+
storage_class_id = disk[:vdc_storage_class]
|
111
|
+
body[:VdcStorageProfile] = {
|
112
|
+
:href => make_href("vdcStorageProfile/#{storage_class_id}"),
|
113
|
+
:name => data[:vdc_storage_classes][storage_class_id][:name],
|
114
|
+
:type => 'application/vnd.vmware.vcloud.vdcStorageProfile+xml',
|
115
|
+
}
|
116
|
+
end
|
117
|
+
|
118
|
+
body
|
119
|
+
end
|
120
|
+
end
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve metadata associated with the disk.
|
6
|
+
#
|
7
|
+
# @param [String] id Object identifier of the disk.
|
8
|
+
# @return [Excon::Response]
|
9
|
+
# * body<~Hash>:
|
10
|
+
#
|
11
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-DiskMetadata.html
|
12
|
+
# @since vCloud API version 5.1
|
13
|
+
def get_disk_metadata(id)
|
14
|
+
request(
|
15
|
+
:expects => 200,
|
16
|
+
:idempotent => true,
|
17
|
+
:method => 'GET',
|
18
|
+
:parser => Fog::ToHashDocument.new,
|
19
|
+
:path => "disk/#{id}/metadata"
|
20
|
+
)
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve the value of the specified key from disk metadata.
|
6
|
+
#
|
7
|
+
# @param [String] id Object identifier of the disk.
|
8
|
+
# @param [String] key Key of the metadata.
|
9
|
+
# @return [Excon::Response]
|
10
|
+
# * body<~Hash>:
|
11
|
+
#
|
12
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-DiskMetadataItem-metadata.html
|
13
|
+
# @since vCloud API version 5.1
|
14
|
+
def get_disk_metadata_item_metadata(id, key)
|
15
|
+
request(
|
16
|
+
:expects => 200,
|
17
|
+
:idempotent => true,
|
18
|
+
:method => 'GET',
|
19
|
+
:parser => Fog::ToHashDocument.new,
|
20
|
+
:path => "disk/#{id}/metadata/#{URI.escape(key)})"
|
21
|
+
)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve the owner of a disk.
|
6
|
+
#
|
7
|
+
# @param [String] id Object identifier of the disk.
|
8
|
+
# @return [Excon::Response]
|
9
|
+
# * body<~Hash>:
|
10
|
+
# * :href<~String> - The URI of the disk.
|
11
|
+
# * :type<~String> - The MIME type of the disk.
|
12
|
+
# * :Link<~Hash>:
|
13
|
+
# * :href<~String> -
|
14
|
+
# * :type<~String> -
|
15
|
+
# * :rel<~String> -
|
16
|
+
# * :User<~Hash> - Reference to the user who is the owner of this
|
17
|
+
# disk.
|
18
|
+
# * :href<~String> - The URI of the user.
|
19
|
+
# * :name<~String> - The name of the user.
|
20
|
+
# * :type<~String> - The MIME type of the user.
|
21
|
+
#
|
22
|
+
# @raise [Fog::Compute::VcloudDirector::Forbidden]
|
23
|
+
#
|
24
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-DiskOwner.html
|
25
|
+
# @since vCloud API version 5.1
|
26
|
+
def get_disk_owner(id)
|
27
|
+
request(
|
28
|
+
:expects => 200,
|
29
|
+
:idempotent => true,
|
30
|
+
:method => 'GET',
|
31
|
+
:parser => Fog::ToHashDocument.new,
|
32
|
+
:path => "disk/#{id}/owner"
|
33
|
+
)
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
class Mock
|
38
|
+
def get_disk_owner(id)
|
39
|
+
unless data[:disks][id]
|
40
|
+
raise Fog::Compute::VcloudDirector::Forbidden.new(
|
41
|
+
'No access to entity "com.vmware.vcloud.entity.disk:%s".' % id
|
42
|
+
)
|
43
|
+
end
|
44
|
+
|
45
|
+
body = {
|
46
|
+
:xmlns => xmlns,
|
47
|
+
:xmlns_xsi => xmlns_xsi,
|
48
|
+
:xsi_schemaLocation => xsi_schema_location,
|
49
|
+
:Link => {
|
50
|
+
:href => make_href("disk/#{id}"),
|
51
|
+
:type => 'application/vnd.vmware.vcloud.disk+xml',
|
52
|
+
:rel => 'up'
|
53
|
+
},
|
54
|
+
:User => {
|
55
|
+
:href => make_href("admin/user/#{user_uuid}"),
|
56
|
+
:name => user_name,
|
57
|
+
:type => 'application/vnd.vmware.admin.user+xml',
|
58
|
+
}
|
59
|
+
}
|
60
|
+
|
61
|
+
Excon::Response.new(
|
62
|
+
:status => 200,
|
63
|
+
:headers => {'Content-Type' => "#{body[:type]};version=#{@version}"},
|
64
|
+
:body => body
|
65
|
+
)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
@@ -0,0 +1,94 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieves a disk list by using REST API general QueryHandler.
|
6
|
+
#
|
7
|
+
# @param [Hash] options
|
8
|
+
# @option options [String] :sortAsc (Sorted by database ID) Sort
|
9
|
+
# results by attribute-name in ascending order. attribute-name cannot
|
10
|
+
# include metadata.
|
11
|
+
# @option options [String] :sortDesc (Sorted by database ID) Sort
|
12
|
+
# results by attribute-name in descending order. attribute-name
|
13
|
+
# cannot include metadata.
|
14
|
+
# @option options [Integer] :page (1) If the query results span
|
15
|
+
# multiple pages, return this page.
|
16
|
+
# @option options [Integer] :pageSize (25) Number of results per page,
|
17
|
+
# to a maximum of 128.
|
18
|
+
# @option options [String] :format (records) One of the following
|
19
|
+
# types:
|
20
|
+
# - *references* Returns a reference to each object, including its
|
21
|
+
# :name, :type, and :href attributes.
|
22
|
+
# - *records* Returns all database records for each object, with each
|
23
|
+
# record as an attribute.
|
24
|
+
# - *idrecords* Identical to the records format, except that object
|
25
|
+
# references are returned in :id format rather than :href format.
|
26
|
+
# @option options [Array<String>] :fields (all static attribute names)
|
27
|
+
# List of attribute names or metadata key names to return.
|
28
|
+
# @option options [Integer] :offset (0) Integer value specifying the
|
29
|
+
# first record to return. Record numbers < offset are not returned.
|
30
|
+
# @option options [String] :filter (none) Filter expression.
|
31
|
+
# @return [Excon::Response]
|
32
|
+
# * hash<~Hash>:
|
33
|
+
# * :href<~String> - The URI of the entity.
|
34
|
+
# * :type<~String> - The MIME type of the entity.
|
35
|
+
# * :name<~String> - Query name that generated this result set.
|
36
|
+
# * :page<~String> - Page of the result set that this container
|
37
|
+
# holds. The first page is page number 1.
|
38
|
+
# * :pageSize<~String> - Page size, as a number of records or
|
39
|
+
# references.
|
40
|
+
# * :total<~String> - Total number of records or references in the
|
41
|
+
# container.
|
42
|
+
# * :Link<~Array<Hash>>:
|
43
|
+
# * :href<~String> - Contains the URI to the entity.
|
44
|
+
# * :type<~String> - Contains the type of the entity.
|
45
|
+
# * :rel<~String> - Defines the relationship of the link to the
|
46
|
+
# object that contains it.
|
47
|
+
# * :DiskRecord<~Array<Hash>>:
|
48
|
+
# * TODO
|
49
|
+
# * :firstPage<~Integer> - First page in the result set.
|
50
|
+
# * :previousPage<~Integer> - Previous page in the result set.
|
51
|
+
# * :nextPage<~Integer> - Next page in the result set.
|
52
|
+
# * :lastPage<~Integer> - Last page in the result set.
|
53
|
+
#
|
54
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-DisksFromQuery.html
|
55
|
+
# @since vCloud API version 1.5
|
56
|
+
def get_disks_from_query(options={})
|
57
|
+
query = []
|
58
|
+
query << "sortAsc=#{options[:sortAsc]}" if options[:sortAsc]
|
59
|
+
query << "sortDesc=#{options[:sortDesc]}" if options[:sortDesc]
|
60
|
+
query << "page=#{options[:page]}" if options[:page]
|
61
|
+
query << "pageSize=#{options[:pageSize]}" if options[:pageSize]
|
62
|
+
query << "format=#{options[:format]}" if options[:format]
|
63
|
+
query << "fields=#{Array(options[:fields]).join(',')}" if options[:fields]
|
64
|
+
query << "offset=#{options[:offset]}" if options[:offset]
|
65
|
+
query << "filter=#{options[:filter]}" if options[:filter]
|
66
|
+
|
67
|
+
response = request(
|
68
|
+
:expects => 200,
|
69
|
+
:idempotent => true,
|
70
|
+
:method => 'GET',
|
71
|
+
:parser => Fog::ToHashDocument.new,
|
72
|
+
:path => 'disks/query',
|
73
|
+
:query => query.map {|q| URI.escape(q)}.join('&')
|
74
|
+
)
|
75
|
+
ensure_list! response.body, :Link
|
76
|
+
ensure_list! response.body,
|
77
|
+
response.body[:type] == 'application/vnd.vmware.vcloud.query.references+xml' ?
|
78
|
+
:DiskReference : :DiskRecord
|
79
|
+
|
80
|
+
%w[firstPage previousPage nextPage lastPage].each do |rel|
|
81
|
+
if link = response.body[:Link].find {|l| l[:rel] == rel}
|
82
|
+
href = Nokogiri::XML.fragment(link[:href])
|
83
|
+
query = CGI.parse(URI.parse(href.text).query)
|
84
|
+
response.body[rel.to_sym] = query['page'].first.to_i
|
85
|
+
response.body[:pageSize] ||= query['pageSize'].first.to_i
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
response
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve all RASD items that specify hard disk and hard disk
|
6
|
+
# controller properties of a VM.
|
7
|
+
#
|
8
|
+
# @param [String] id Object identifier of the VM.
|
9
|
+
# @return [Excon::Response]
|
10
|
+
# * body<~Hash>:
|
11
|
+
#
|
12
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-DisksRasdItemsList.html
|
13
|
+
# @since vCloud API version 0.9
|
14
|
+
def get_disks_rasd_items_list(id)
|
15
|
+
request(
|
16
|
+
:expects => 200,
|
17
|
+
:idempotent => true,
|
18
|
+
:method => 'GET',
|
19
|
+
:parser => Fog::ToHashDocument.new,
|
20
|
+
:path => "vApp/#{id}/virtualHardwareSection/disks"
|
21
|
+
)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
class Mock
|
26
|
+
|
27
|
+
def get_disks_rasd_items_list(id)
|
28
|
+
type = 'application/vnd.vmware.vcloud.rasdItemsList+xml'
|
29
|
+
|
30
|
+
unless vm = data[:vms][id]
|
31
|
+
raise Fog::Compute::VcloudDirector::Forbidden.new(
|
32
|
+
'This operation is denied.'
|
33
|
+
)
|
34
|
+
end
|
35
|
+
|
36
|
+
body = {
|
37
|
+
:type => type,
|
38
|
+
:href => make_href("vApp/#{id}/virtualHardwareSection/disks"),
|
39
|
+
:Link => {
|
40
|
+
:rel=>"edit",
|
41
|
+
:type=>"application/vnd.vmware.vcloud.rasdItemsList+xml",
|
42
|
+
:href=>make_href("vApp/#{id}/virtualHardwareSection/disks"),
|
43
|
+
},
|
44
|
+
:Item => [
|
45
|
+
get_disks_rasd_items_list_body(id, vm),
|
46
|
+
get_media_rasd_item_ide_controller_body(id, vm),
|
47
|
+
].flatten
|
48
|
+
}
|
49
|
+
|
50
|
+
Excon::Response.new(
|
51
|
+
:status => 200,
|
52
|
+
:headers => {'Content-Type' => "#{type};version=#{api_version}"},
|
53
|
+
:body => body
|
54
|
+
)
|
55
|
+
end
|
56
|
+
|
57
|
+
def get_disks_rasd_items_list_body(id, vm)
|
58
|
+
[
|
59
|
+
{
|
60
|
+
:"rasd:Address"=>"0",
|
61
|
+
:"rasd:Description"=>"SCSI Controller",
|
62
|
+
:"rasd:ElementName"=>"SCSI Controller 0",
|
63
|
+
:"rasd:InstanceID"=>"2",
|
64
|
+
:"rasd:ResourceSubType"=>"lsilogic",
|
65
|
+
:"rasd:ResourceType"=>"6"
|
66
|
+
},
|
67
|
+
|
68
|
+
# TODO: Add support for adding disks
|
69
|
+
{
|
70
|
+
:"rasd:AddressOnParent"=>"0",
|
71
|
+
:"rasd:Description"=>"Hard disk",
|
72
|
+
:"rasd:ElementName"=>"Hard disk 1",
|
73
|
+
:"rasd:HostResource"=>{
|
74
|
+
:ns12_capacity=>"51200",
|
75
|
+
:ns12_busSubType=>"lsilogic",
|
76
|
+
:ns12_busType=>"6"
|
77
|
+
},
|
78
|
+
:"rasd:InstanceID"=>"2000",
|
79
|
+
:"rasd:Parent"=>"2",
|
80
|
+
:"rasd:ResourceType"=>"17"
|
81
|
+
},
|
82
|
+
|
83
|
+
]
|
84
|
+
end
|
85
|
+
|
86
|
+
end
|
87
|
+
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
@@ -0,0 +1,109 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class VcloudDirector
|
4
|
+
class Real
|
5
|
+
# Retrieve an edge gateway.
|
6
|
+
#
|
7
|
+
# @param [String] id Object identifier of the edge gateway.
|
8
|
+
# @return [Excon::Response]
|
9
|
+
# * body<~Hash>:
|
10
|
+
#
|
11
|
+
# @raise [Fog::Compute::VcloudDirector::Forbidden]
|
12
|
+
#
|
13
|
+
# @see http://pubs.vmware.com/vcd-51/topic/com.vmware.vcloud.api.reference.doc_51/doc/operations/GET-EdgeGateway.html
|
14
|
+
# @since vCloud API version 5.1
|
15
|
+
def get_edge_gateway(id)
|
16
|
+
response = request(
|
17
|
+
:expects => 200,
|
18
|
+
:idempotent => true,
|
19
|
+
:method => 'GET',
|
20
|
+
:parser => Fog::ToHashDocument.new,
|
21
|
+
:path => "admin/edgeGateway/#{id}"
|
22
|
+
)
|
23
|
+
|
24
|
+
ensure_list! response.body[:Configuration], :GatewayInterfaces, :GatewayInterface
|
25
|
+
|
26
|
+
edge_gateway_service_configuration = response.body[:Configuration][:EdgeGatewayServiceConfiguration]
|
27
|
+
|
28
|
+
ensure_list! edge_gateway_service_configuration[:FirewallService], :FirewallRule if edge_gateway_service_configuration[:FirewallService]
|
29
|
+
ensure_list! edge_gateway_service_configuration[:NatService], :NatRule if edge_gateway_service_configuration[:NatService]
|
30
|
+
|
31
|
+
if edge_gateway_service_configuration[:LoadBalancerService]
|
32
|
+
|
33
|
+
ensure_list! edge_gateway_service_configuration[:LoadBalancerService], :Pool
|
34
|
+
edge_gateway_service_configuration[:LoadBalancerService][:Pool].each do |pool|
|
35
|
+
ensure_list! pool, :ServicePort
|
36
|
+
ensure_list! pool, :Member
|
37
|
+
pool[:Member].each do |member|
|
38
|
+
ensure_list! member, :ServicePort
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
ensure_list! edge_gateway_service_configuration[:LoadBalancerService], :VirtualServer
|
43
|
+
edge_gateway_service_configuration[:LoadBalancerService][:VirtualServer].each do |virtual_server|
|
44
|
+
ensure_list! virtual_server, :ServiceProfile
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
response
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
class Mock
|
54
|
+
def get_edge_gateway(id)
|
55
|
+
unless edge_gateway = data[:edge_gateways][id]
|
56
|
+
raise Fog::Compute::VcloudDirector::Forbidden.new(
|
57
|
+
"No access to entity \"(com.vmware.vcloud.entity.gateway:#{id})\""
|
58
|
+
)
|
59
|
+
end
|
60
|
+
|
61
|
+
vdc_id = edge_gateway[:vdc]
|
62
|
+
body = {
|
63
|
+
:xmlns => xmlns,
|
64
|
+
:xmlns_xsi => xmlns_xsi,
|
65
|
+
:status => "1",
|
66
|
+
:name => edge_gateway[:name],
|
67
|
+
:id => "urn:vcloud:gateway:#{id}",
|
68
|
+
:type => "application/vnd.vmware.admin.edgeGateway+xml",
|
69
|
+
:href => make_href("admin/edgeGateway/#{id}"),
|
70
|
+
:xsi_schemaLocation => xsi_schema_location,
|
71
|
+
:Link =>[{:rel => "up",
|
72
|
+
:type => "application/vnd.vmware.vcloud.vdc+xml",
|
73
|
+
:href => make_href("vdc/#{vdc_id}")},
|
74
|
+
{:rel => "edgeGateway:redeploy",
|
75
|
+
:href => make_href("admin/edgeGateway/#{id}/action/redeploy")},
|
76
|
+
{:rel => "edgeGateway:configureServices",
|
77
|
+
:type => "application/vnd.vmware.admin.edgeGatewayServiceConfiguration+xml",
|
78
|
+
:href => make_href("admin/edgeGateway/#{id}/action/configureServices")},
|
79
|
+
{:rel => "edgeGateway:reapplyServices",
|
80
|
+
:href => make_href("admin/edgeGateway/#{id}/action/reapplyServices")},
|
81
|
+
{:rel => "edgeGateway:syncSyslogSettings",
|
82
|
+
:href => make_href("admin/edgeGateway/#{id}/action/syncSyslogServerSettings")}],
|
83
|
+
:Description => "vCloud CI (nft00052i2)",
|
84
|
+
:Configuration => edge_gateway[:Configuration].dup
|
85
|
+
}
|
86
|
+
|
87
|
+
body[:Configuration][:GatewayInterfaces][:GatewayInterface] += edge_gateway[:networks].map do |network|
|
88
|
+
extras = {
|
89
|
+
:Network => {
|
90
|
+
:type => "application/vnd.vmware.admin.network+xml",
|
91
|
+
:name => "anything",
|
92
|
+
:href => make_href("admin/network/#{network}")
|
93
|
+
},
|
94
|
+
:Name => data[:networks][network][:name],
|
95
|
+
:DisplayName => data[:networks][network][:name]
|
96
|
+
}
|
97
|
+
data[:networks][network].merge extras
|
98
|
+
end
|
99
|
+
|
100
|
+
Excon::Response.new(
|
101
|
+
:status => 200,
|
102
|
+
:headers => {'Content-Type' => "#{body[:type]};version=#{api_version}"},
|
103
|
+
:body => body
|
104
|
+
)
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|