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,44 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/disk'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Disks < Collection
|
8
|
+
model Fog::Compute::VcloudDirector::Disk
|
9
|
+
|
10
|
+
attribute :vm
|
11
|
+
|
12
|
+
def create(size)
|
13
|
+
item_list unless @disks
|
14
|
+
data = Fog::Generators::Compute::VcloudDirector::Disks.new(@disks)
|
15
|
+
data.add_hard_disk(size)
|
16
|
+
response = service.put_disks(vm.id, data.disks)
|
17
|
+
service.process_task(response.body)
|
18
|
+
end
|
19
|
+
|
20
|
+
def get_by_id(item_id)
|
21
|
+
item = item_list.find{ |i| i[:id] == item_id}
|
22
|
+
item.merge!(:all_disks => @disks, :vm => vm) if item
|
23
|
+
item
|
24
|
+
end
|
25
|
+
|
26
|
+
def item_list
|
27
|
+
@disks = service.get_vm_disks(vm.id).body
|
28
|
+
items = @disks[:disks]
|
29
|
+
items.each do |disk|
|
30
|
+
disk[:all_disks] = @disks
|
31
|
+
disk[:vm] = vm
|
32
|
+
end
|
33
|
+
items
|
34
|
+
end
|
35
|
+
|
36
|
+
# Returns only disk drives (OVF resource type 17) and not controllers,
|
37
|
+
# etc. See <https://blogs.vmware.com/vapp/2009/11/virtual-hardware-in-ovf-part-1.html>
|
38
|
+
def storage_only
|
39
|
+
select {|d| d.resource_type == 17}
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Compute
|
5
|
+
class VcloudDirector
|
6
|
+
class Media < Model
|
7
|
+
identity :id
|
8
|
+
|
9
|
+
attribute :href
|
10
|
+
attribute :type
|
11
|
+
attribute :name
|
12
|
+
attribute :status, :type => :integer
|
13
|
+
attribute :image_type, :aliases => :imageType
|
14
|
+
attribute :size, :type => :integer
|
15
|
+
attribute :description, :aliases => :Description
|
16
|
+
|
17
|
+
# @return [Boolean]
|
18
|
+
def destroy
|
19
|
+
requires :id
|
20
|
+
response = service.delete_media(id)
|
21
|
+
service.process_task(response.body)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,75 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/media'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Medias < Collection
|
8
|
+
model Fog::Compute::VcloudDirector::Media
|
9
|
+
|
10
|
+
attribute :vdc
|
11
|
+
|
12
|
+
# @param [String] name The name of the entity.
|
13
|
+
# @param [#read] io The input object to read from.
|
14
|
+
# @param [String] image_type Media image type. One of: iso, floppy.
|
15
|
+
# @return [Media]
|
16
|
+
def create(name, io, image_type='iso')
|
17
|
+
requires :vdc
|
18
|
+
|
19
|
+
response = service.post_upload_media(vdc.id, name, image_type, io.size)
|
20
|
+
service.add_id_from_href!(response.body)
|
21
|
+
media = new(response.body)
|
22
|
+
|
23
|
+
# Perhaps this would be better implemented as media#upload.
|
24
|
+
|
25
|
+
file = response.body[:Files][:File].first
|
26
|
+
file[:Link] = [file[:Link]] if file[:Link].is_a?(Hash)
|
27
|
+
link = file[:Link].find {|l| l[:rel] == 'upload:default'}
|
28
|
+
|
29
|
+
headers = {
|
30
|
+
'Content-Length' => io.size,
|
31
|
+
'Content-Type' => 'application/octet-stream',
|
32
|
+
'x-vcloud-authorization' => service.vcloud_token
|
33
|
+
}
|
34
|
+
chunker = lambda do
|
35
|
+
# to_s will convert the nil received after everything is read to
|
36
|
+
# the final empty chunk.
|
37
|
+
io.read(Excon.defaults[:chunk_size]).to_s
|
38
|
+
end
|
39
|
+
Excon.put(
|
40
|
+
link[:href],
|
41
|
+
:expects => 200,
|
42
|
+
:headers => headers,
|
43
|
+
:request_block => chunker)
|
44
|
+
|
45
|
+
service.process_task(response.body[:Tasks][:Task])
|
46
|
+
|
47
|
+
media.reload
|
48
|
+
media
|
49
|
+
end
|
50
|
+
|
51
|
+
private
|
52
|
+
|
53
|
+
# @param [String] item_id
|
54
|
+
# @return [Media]
|
55
|
+
def get_by_id(item_id)
|
56
|
+
item = service.get_media(item_id).body
|
57
|
+
%w(:Link).each {|key_to_delete| item.delete(key_to_delete)}
|
58
|
+
service.add_id_from_href!(item)
|
59
|
+
item
|
60
|
+
end
|
61
|
+
|
62
|
+
# @return [Array<Media>]
|
63
|
+
def item_list
|
64
|
+
data = service.get_vdc(vdc.id).body
|
65
|
+
return [] if data[:ResourceEntities].empty?
|
66
|
+
items = data[:ResourceEntities][:ResourceEntity].select do |resource|
|
67
|
+
resource[:type] == 'application/vnd.vmware.vcloud.media+xml'
|
68
|
+
end
|
69
|
+
items.each {|item| service.add_id_from_href!(item)}
|
70
|
+
items
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Compute
|
5
|
+
class VcloudDirector
|
6
|
+
class Network < Model
|
7
|
+
identity :id
|
8
|
+
|
9
|
+
attribute :name
|
10
|
+
attribute :type
|
11
|
+
attribute :href
|
12
|
+
attribute :description
|
13
|
+
attribute :is_inherited
|
14
|
+
attribute :is_shared
|
15
|
+
attribute :fence_mode
|
16
|
+
attribute :gateway
|
17
|
+
attribute :netmask
|
18
|
+
attribute :dns1
|
19
|
+
attribute :dns2
|
20
|
+
attribute :dns_suffix
|
21
|
+
attribute :ip_ranges, :type => :array
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/network'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Networks < Collection
|
8
|
+
|
9
|
+
include Fog::VcloudDirector::Query
|
10
|
+
|
11
|
+
model Fog::Compute::VcloudDirector::Network
|
12
|
+
|
13
|
+
attribute :organization
|
14
|
+
attribute :vdc
|
15
|
+
|
16
|
+
def query_type
|
17
|
+
"orgVdcNetwork"
|
18
|
+
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
def get_by_id(item_id)
|
23
|
+
raw_network = service.get_network_complete(item_id).body
|
24
|
+
data = {}
|
25
|
+
data[:type] = raw_network[:type]
|
26
|
+
data[:href] = raw_network[:href]
|
27
|
+
service.add_id_from_href!(data)
|
28
|
+
data[:name] = raw_network[:name]
|
29
|
+
data[:description] = raw_network[:Description]
|
30
|
+
data[:is_shared] = raw_network[:IsShared]
|
31
|
+
net_config = raw_network[:Configuration]
|
32
|
+
data[:fence_mode] = net_config[:FenceMode]
|
33
|
+
ip_scope = net_config[:IpScopes][:IpScope]
|
34
|
+
data[:is_inherited] = ip_scope[:IsInherited]
|
35
|
+
data[:gateway] = ip_scope[:Gateway]
|
36
|
+
data[:netmask] = ip_scope[:Netmask]
|
37
|
+
data[:dns1] = ip_scope[:Dns1]
|
38
|
+
data[:dns2] = ip_scope[:Dns2]
|
39
|
+
data[:dns_suffix] = ip_scope[:DnsSuffix]
|
40
|
+
data[:ip_ranges] = []
|
41
|
+
raw_ip_ranges = ip_scope[:IpRanges][:IpRange]
|
42
|
+
data[:ip_ranges] = raw_ip_ranges.map do |ip_range|
|
43
|
+
{ :start_address => ip_range[:StartAddress],
|
44
|
+
:end_address => ip_range[:EndAddress] }
|
45
|
+
end
|
46
|
+
data
|
47
|
+
end
|
48
|
+
|
49
|
+
def item_list
|
50
|
+
items = if vdc
|
51
|
+
vdc.available_networks.select {|link| link[:type] == "application/vnd.vmware.vcloud.network+xml"}
|
52
|
+
else
|
53
|
+
data = service.get_organization(organization.id).body
|
54
|
+
data[:Link].select { |link| link[:type] == "application/vnd.vmware.vcloud.orgNetwork+xml" }
|
55
|
+
end
|
56
|
+
items.each{|item| service.add_id_from_href!(item) }
|
57
|
+
items
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Compute
|
5
|
+
class VcloudDirector
|
6
|
+
class Organization < Model
|
7
|
+
identity :id
|
8
|
+
|
9
|
+
attribute :name
|
10
|
+
attribute :type
|
11
|
+
attribute :href
|
12
|
+
attribute :description, :aliases => :Description
|
13
|
+
attribute :full_name, :aliases => :FullName
|
14
|
+
|
15
|
+
def vdcs
|
16
|
+
requires :id
|
17
|
+
service.vdcs(:organization => self)
|
18
|
+
end
|
19
|
+
|
20
|
+
def catalogs
|
21
|
+
requires :id
|
22
|
+
service.catalogs(:organization => self)
|
23
|
+
end
|
24
|
+
|
25
|
+
def networks
|
26
|
+
requires :id
|
27
|
+
service.networks(:organization => self)
|
28
|
+
end
|
29
|
+
|
30
|
+
def tasks
|
31
|
+
requires :id
|
32
|
+
service.tasks(:organization => self)
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/organization'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Organizations < Collection
|
8
|
+
model Fog::Compute::VcloudDirector::Organization
|
9
|
+
|
10
|
+
private
|
11
|
+
|
12
|
+
def get_by_id(org_id)
|
13
|
+
org = service.get_organization(org_id).body
|
14
|
+
org.delete(:Link)
|
15
|
+
service.add_id_from_href!(org)
|
16
|
+
org
|
17
|
+
end
|
18
|
+
|
19
|
+
def item_list
|
20
|
+
data = service.get_organizations.body
|
21
|
+
orgs = data[:Org]
|
22
|
+
orgs.each {|org| service.add_id_from_href!(org)}
|
23
|
+
orgs
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,31 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Compute
|
5
|
+
class VcloudDirector
|
6
|
+
class Tag < Model
|
7
|
+
identity :id
|
8
|
+
attribute :value
|
9
|
+
|
10
|
+
def value=(new_value)
|
11
|
+
has_changed = ( value != new_value )
|
12
|
+
not_first_set = !value.nil?
|
13
|
+
attributes[:value] = new_value
|
14
|
+
if not_first_set && has_changed
|
15
|
+
response = service.put_vapp_metadata_item_metadata(vm.id, id, value)
|
16
|
+
service.process_task(response.body)
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def destroy
|
21
|
+
response = service.delete_vapp_metadata_item_metadata(vm.id, id)
|
22
|
+
service.process_task(response.body)
|
23
|
+
end
|
24
|
+
|
25
|
+
def vm
|
26
|
+
attributes[:vm]
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/tag'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Tags < Collection
|
8
|
+
model Fog::Compute::VcloudDirector::Tag
|
9
|
+
|
10
|
+
attribute :vm
|
11
|
+
|
12
|
+
def get_by_name(tag_name)
|
13
|
+
get(tag_name)
|
14
|
+
end
|
15
|
+
|
16
|
+
def get_by_id(item_id)
|
17
|
+
item_list unless @items
|
18
|
+
@items.find{ |i| i[:id] == item_id}
|
19
|
+
end
|
20
|
+
|
21
|
+
def create(key,value)
|
22
|
+
response = service.post_update_vapp_metadata(vm.id, { key => value} )
|
23
|
+
service.process_task(response.body)
|
24
|
+
end
|
25
|
+
|
26
|
+
def hash_items
|
27
|
+
@tags = service.get_metadata(vm.id).body
|
28
|
+
@tags[:metadata]
|
29
|
+
end
|
30
|
+
|
31
|
+
private
|
32
|
+
|
33
|
+
def item_list
|
34
|
+
@items =[]
|
35
|
+
hash_items.each_pair{ |k,v| @items << {:id => k, :value => v }.merge(:vm => vm) }
|
36
|
+
@items
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,55 @@
|
|
1
|
+
require 'fog/core/model'
|
2
|
+
|
3
|
+
module Fog
|
4
|
+
module Compute
|
5
|
+
class VcloudDirector
|
6
|
+
class Task < Fog::Model
|
7
|
+
identity :id
|
8
|
+
|
9
|
+
attribute :href
|
10
|
+
attribute :type
|
11
|
+
attribute :name
|
12
|
+
attribute :end_time, :aliases => :endTime, :type => :time
|
13
|
+
attribute :expiry_time, :aliases => :expiryTime, :type => :time
|
14
|
+
attribute :operation
|
15
|
+
attribute :operation_name, :aliases => :operationName
|
16
|
+
attribute :start_time, :aliases => :startTime, :type => :time
|
17
|
+
attribute :status
|
18
|
+
attribute :description, :aliases => :Description
|
19
|
+
attribute :error, :aliases => :Error
|
20
|
+
attribute :progress, :aliases => :Progress, :type => :integer
|
21
|
+
|
22
|
+
# Since 5.1
|
23
|
+
attribute :operation_key, :aliases => :operationKey
|
24
|
+
attribute :cancel_requested, :aliases => :cancelRequested, :type => :boolean
|
25
|
+
attribute :service_namespace, :aliases => :serviceNamespace
|
26
|
+
attribute :details, :aliases => :Details
|
27
|
+
|
28
|
+
def ready?
|
29
|
+
status == 'success'
|
30
|
+
end
|
31
|
+
|
32
|
+
def success?
|
33
|
+
status == 'success'
|
34
|
+
end
|
35
|
+
|
36
|
+
def non_running?
|
37
|
+
if @service.show_progress? && (@last_progress ||= 0) < 100
|
38
|
+
if status == 'running' || status == 'queued'
|
39
|
+
Fog::Formatador.redisplay_progressbar(progress, 100, :label => operation_name, :started_at => start_time)
|
40
|
+
@last_progress = progress
|
41
|
+
elsif status == 'success'
|
42
|
+
Fog::Formatador.redisplay_progressbar(100, 100, :label => operation_name, :started_at => start_time)
|
43
|
+
@last_progress = 100
|
44
|
+
end
|
45
|
+
end
|
46
|
+
! %w(running queued).include?(status)
|
47
|
+
end
|
48
|
+
|
49
|
+
def cancel
|
50
|
+
service.post_cancel_task(id)
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/vcloud_director/models/compute/task'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class VcloudDirector
|
7
|
+
class Tasks < Collection
|
8
|
+
|
9
|
+
include Fog::VcloudDirector::Query
|
10
|
+
|
11
|
+
model Fog::Compute::VcloudDirector::Task
|
12
|
+
|
13
|
+
attribute :organization
|
14
|
+
|
15
|
+
def query_type
|
16
|
+
"task"
|
17
|
+
end
|
18
|
+
|
19
|
+
def get(id)
|
20
|
+
data = service.get_task(id).body
|
21
|
+
return nil unless data
|
22
|
+
data[:id] = data[:href].split('/').last
|
23
|
+
data[:progress] ||= 0
|
24
|
+
new(data)
|
25
|
+
end
|
26
|
+
|
27
|
+
private
|
28
|
+
|
29
|
+
def item_list
|
30
|
+
data = service.get_task_list(organization.id).body
|
31
|
+
data[:Task].each {|task| service.add_id_from_href!(task)}
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|