-
Notifications
You must be signed in to change notification settings - Fork 144
VMware: HTTPAPI connection plugin
This document describes the design philosophy, milestones and objectives to create a VMware ecosystem based on the new ReST API introduced in vSphere 6.x, using the HTTPAPI connection plugin, developed by Ansible's Networking Team. We will be listing all ReST API related requirements. Feel free to edit this page.
- Develop a REST API infrastructure in Ansible for dealing with VMware infrastructure
- Develop guidelines, design specifications with community to drive this effort
- Write documentation for installation and user scenarios for httpapi plugin
- Try to target modules related to Content library, tagging etc. as part of this effort
- Develop a role like network-engine for Ansible VMware
- Unit testing for VMware REST API infrastructure.
- Create a Mock server in Flask or something as
GOVCSIM
does not support REST APIs
- GET or queries will default to retrieve multiple objects if the filter specs warrant it.
- Any other command, such as PUT, POST, PATCH or DELETE, or any state other than query, such as 'present' or 'absent', will default to assert a single object.
- Should filter specs result in an operand of more objects than asserted, the command will fail.
- Setting 'allow_multiples' to True will force that command to allow processing of multiple objects.
- The new module library will be divided into sections loosely based on VMware's PowerCLI library, originally laid out in Vmware Vsphere Powercli Reference: Automating Vsphere Administration, second edition, January 2016, by Luc Dekens, Alan Renouf, Jonathan Medd, et al.
- Each section will be maintained in its own directory.
- Variables with an 'id' suffix, [OBJECT]_id, contain VMware's internal object id name, e.g. cluster_id. The value of these variables can be used directly in an API request.
- Variables with a 'name' suffix, [OBJECT]_name, contain the display name of the object, e.g. cluster_name. The value of these variables will usually require a lookup to obtain VMware's corresponding internal object id. Such look ups returning multiple ids is where the 'allow_multiples' assert comes into play.
- Filters are specified as filter.[OBJECT][SUFFIX], e.g. filter.cluster_id filters on VMware's internal object id, while filter.cluster_name filters on the cluster's display name.
- Filters by name will have to make additional calls to convert name to one or more internal id's.
This section provides direct implementation of VMware ReST API commands. Consists of a single module that implements all APIs, and multiple modules that each implement all relevant commands for a single API entity, as specified by VMware's Swagger document. Multiple related API entities may be combined into a single module if deemed more efficient. It is recommended that the individual modules simply parse their params and pass to vmware_commands for execution to minimize redundant coding. The modules are
- vmware_commands
- implements all VMware ReSTful APIs
- commands can be placed into a list to be executed in order
- commands are of the form [COMMAND] [API] [OBJECT] [ACTION] [param:value]...
- COMMAND is one of GET, PATCH, POST, PUT, or DELETE
- API is one of APPLIANCE, CIS, CONTENT, VAPI, or VCENTER
- OBJECT is a valid API entity defined in VMware's Swagger document
- ACTION is an optional field usually required for a PATCH, POST or PUT
- Optional parameters can be specified as colon-separated name-value pairs
- relevant filters and modifiers can be specified per command
- supports all command filters and modifiers
- vmware_appliance_access
- implements
- /appliance/access/consolecli
- /appliance/access/dcui
- /appliance/access/shell
- /appliance/access/ssh
- commands
- PUT
- params
- consolecli: bool
- dcui: bool
- shell: bool
- ssh: bool
- implements
- vmware_appliance_access_facts
- implements
- /appliance/access/consolecli
- /appliance/access/dcui
- /appliance/access/shell
- /appliance/access/ssh
- commands
- GET
- implements
- vmware_appliance_health_facts
- implements
- /appliance/health
- /appliance/health/applmgmt
- /appliance/health/databasestorage
- /appliance/health/load
- /appliance/health/mem
- /appliance/health/softwarepackages
- /appliance/health/storage
- /appliance/health/swap
- /appliance/health/system
- /appliance/health/system/lastcheck
- commands
- GET
- implements
- vmware_appliance_accounts
- implements
- /appliance/local-accounts
- commands
- PATCH
- PUT
- POST
- DELETE
- params
- config:
- max_days_between_password_change: int
- inactive_after_password_expiration: bool
- days_after_password_expiration: int
- password_expires: bool
- full_name: string
- email: string
- enabled: bool
- roles: [string]
- password: string
- password_expires_at: date-time
- old_password: string
- warn_days_before_password_expiration: int
- min_days_between_password_change: int
- username: string
- state: one of ['present','absent']
- config:
- implements
- vmware_appliance_accounts_facts
- implements
- /appliance/local-accounts
- commands
- GET
- params
- username: string
- implements
- vmware_appliance_accounts_policy
- implements
- /appliance/local-accounts/global-policy
- commands
- PUT
- params
- policy:
- max_days: int
- warn_days: int
- min_days: int
- policy:
- implements
- vmware_appliance_accounts_policy_facts
- implements
- /appliance/local-accounts/global-policy
- commands
- GET
- implements
- vmware_appliance_logging
- implements
- /appliance/logging/forwarding
- commands
- PUT
- POST
- actions
- test
- params
- cfg_list: array of
- hostname: string
- port: int
- protocol: one of ['TLS',]
- send_test_message: string
- cfg_list: array of
- implements
- vmware_appliance_logging_facts
- implements
- /appliance/logging/forwarding
- commands
- GET
- implements
- vmware_appliance_monitoring_facts
- implements
- /appliance/monitoring
- /appliance/monitoring/query
- commands
- GET
- params
- stat: string
- query: bool
- implements
- vmware_appliance_networking
- implements
- /appliance/networking
- /appliance/networking/dns/domains
- /appliance/networking/dns/hostname
- /appliance/networking/dns/hostname/test
- /appliance/networking/dns/servers
- /appliance/networking/dns/servers/test
- /appliance/networking/firewall/inbound
- /appliance/networking/interfaces
- /appliance/networking/interfaces/ipv4
- /appliance/networking/interfaces/ipv6
- /appliance/networking/noproxy
- /appliance/networking/proxy
- commands
- PATCH
- PUT
- POST
- DELETE
- actions
- reset
- test
- params
- ipv6_enabled: bool
- dns_test: bool
- sets both hostname_test and servers_test
- domain: string
- domains: [string]
- hostname: string
- hostname_test: bool
- interface_name: string
- prefix: int
- address: string
- default_gateway: string
- mode: one of ['DHCP','STATIC']
- interface_name: string
- addresses: array of
- prefix: int
- address: string
- dhcp: bool
- default_gateway: string
- autoconf: bool
- addresses: array of
- protocol: string
- server: string
- enabled: bool
- port: int
- password: string
- username: string
- proxy_test: bool
- reset: bool
- rules: array of
- policy: one of ['accept','deny','ignore']
- prefix: int
- address: string
- interface_name: string
- server: string
- servers: [string]
- servers_config:
- servers: [string]
- mode: 'dhcp'
- servers_test: bool
- implements
- vmware_appliance_networking_facts
- implements
- /appliance/networking
- /appliance/networking/dns/domains
- /appliance/networking/dns/hostname
- /appliance/networking/dns/servers
- /appliance/networking/firewall/inbound
- /appliance/networking/interfaces
- /appliance/networking/interfaces/ipv4
- /appliance/networking/interfaces/ipv6
- /appliance/networking/noproxy
- /appliance/networking/proxy
- commands
- GET
- params
- protocol: string
- implements
- vmware_appliance_ntp
- implements
- /appliance/ntp
- /appliance/ntp/test
- commands
- PUT
- POST
- params
- servers: [string]
- implements
- vmware_appliance_ntp_facts
- implements
- /appliance/ntp
- commands
- GET
- implements
- vmware_appliance_recovery
- implements
- /appliance/recovery/backup/job
- /appliance/recovery/backup/schedules
- /appliance/recovery/backup/schedules/update
- /appliance/recovery/reconciliation/job
- /appliance/recovery/restore/job
- commands
- PUT
- POST
- DELETE
- actions
- run
- params
- job_id: string
- backup_piece:
- location: string
- parts: [string]
- location_password: string
- comment: string
- location_type: one of ['FTP',]
- backup_password: string
- location_user: string
- reconciliation_job:
- ignore_warning: bool
- sso_admin_user_password: string
- sso_admin_user_name: string
- restore_piece:
- ignore_warnings: bool
- sso_admin_user_password: string
- location: string
- location_password: string
- sso_admin_user_name: string
- location_type: one of ['FTP',]
- backup_password: string
- location_user: string
- schedule: string
- location: string
- parts: [string]
- location_password: string
- max_count: int
- enable: bool
- recurrence_info:
- days: ['MONDAY','TUESDAY','WEDNESDAY','THURSDAY','FRIDAY','SATURDAY','SUNDAY']
- minute: int[0:59]
- hour: int[0:23]
- location_user: string
- state: one of ['present','absent']
- implements
- vmware_appliance_recovery_facts
- implements
- /appliance/recovery
- /appliance/recovery/backup/validate
- /appliance/recovery/backup/job
- /appliance/recovery/backup/job/details
- /appliance/recovery/backup/parts
- /appliance/recovery/backup/schedules
- /appliance/recovery/backup/system-name
- /appliance/recovery/backup/reconciliation/job
- /appliance/recovery/restore/validate
- /appliance/recovery/restore/job
- commands
- GET
- POST
- params
- job_id: string
- parts_id: string
- schedule: string
- system_name: string
- archive: string
- implements
- vmware_appliance_services
- implements
- /appliance/services
- commands
- POST
- params
- service: string
- state: one of ['present','absent']
- if service is running and state is 'present', then restart
- alternatively, always restart when state is 'present'
- implements
- vmware_appliance_services_facts
- implements
- /appliance/services
- commands
- GET
- params
- service: string
- implements
- vmware_appliance_shutdown
- implements
- /appliance/shutdown/cancel
- /appliance/shutdown/poweroff
- /appliance/shutdown/reboot
- commands
- POST
- implements
- vmware_appliance_shutdown_facts
- implements
- /appliance/shutdown
- commands
- GET
- implements
- vmware_appliance_system
- implements
- /appliance/system/storage
- /appliance/system/storage/resize
- /appliance/system/time/timezone
- /appliance/timesync
- commands
- POST
- PUT
- actions
- resize-ex
- params
- timezone_name: string
- timesync_mode: one of ['ENABLED','DISABLED']
- implements
- vmware_appliance_system_facts
- implements
- /appliance/system/storage
- /appliance/system/time
- /appliance/system/time/timezone
- /appliance/system/uptime
- /appliance/system/version
- /appliance/timesync
- commands
- GET
- implements
- vmware_appliance_techpreview
- implements
- /appliance/techpreview/monitoring/snmp
- /appliance/techpreview/monitoring/snmp/disable
- /appliance/techpreview/monitoring/snmp/enable
- /appliance/techpreview/monitoring/snmp/hash
- /appliance/techpreview/monitoring/snmp/reset
- /appliance/techpreview/monitoring/snmp/test
- commands
- PUT
- POST
- params
- snmp: one of ['DISABLE','ENABLE','HASH','RESET','TEST']
- implements
- vmware_appliance_techpreview_facts
- implements
- /appliance/techpreview/monitoring/snmp
- /appliance/techpreview/monitoring/snmp/limits
- /appliance/techpreview/monitoring/snmp/stats
- /appliance/techpreview/services/status/get
- commands
- GET
- POST
- implements
- vmware_appliance_update
- implements
- /appliance/update
- /appliance/update/pending
- commands
- POST
- PUT
- DELETE
- actions
- cancel
- install
- precheck
- stage
- stage-and-install
- validate
- params
- version: string
- user_data: [ [key]: [value] ] for 'install' action
- policy:
- custom_url: string
- auto_storage: bool
- check_schedule:
- day: ['MONDAY','TUESDAY','WEDNESDAY','THURSDAY','FRIDAY','SATURDAY','SUNDAY']
- hour: int
- minute: int
- password: string
- username: string
- implements
- vmware_appliance_update_facts
- implements
- /appliance/update
- /appliance/update/pending
- /appliance/update/policy
- /appliance/update/staged
- commands
- GET
- params
- version: string
- implements
- vmware_appliance_vmon
- implements
- /appliance/vmon/service
- commands
- PATCH
- POST
- params
- service: string
- startup_type: one of ['AUTOMATIC','MANUAL']
- state: one of ['present','absent']
- if service is running, send restart on 'present' or always send 'restart'
- implements
- vmware_appliance_vmon_facts
- implements
- /appliance/vmon/service
- commands
- GET
- params
- service: string
- implements
- vmware_cis_category
- implements
- /com/vmware/cis/tagging/category
- commands
- PATCH
- POST
- DELETE
- actions
- add-to-used-by
- remove-from-used-by
- revoke-propagating-permissions
- params
- category: string
- description: string
- cardinality: one of ['SINGLE', 'MULTIPLE']
- associable_types: ['All','Clusters','Content Libraries','Datacenters','Datastores','Datastore Clusters','Distributed Port Groups','Distributed Switches','Folders','Hosts','Library Items','Networks','Resource Pools','vApps','Virtual Machines']
- used_by_entity: string
- state: one of ['present','absent']
- implements
- vmware_cis_category_facts
- implements
- /com/vmware/cis/tagging/category
- commands
- GET
- POST
- actions
- list-used-categories
- params
- category: string
- used_by_entity: string
- implements
- vmware_cis_session
- implements
- /com/vmware/cis/session
- commands
- POST
- DELETE
- params
- state: one of ['present','absent']
- this is primarily what the VMware plugin to HTTPAPI uses to log in and out
- implements
- vmware_cis_session_facts
- implements
- /com/vmware/cis/session
- commands
- POST
- actions
- get
- the only relevant action may be to retrieve the current session information
- implements
- vmware_cis_tag
- implements
- /com/vmware/cis/tagging/tag
- commands
- PATCH
- POST
- DELETE
- actions
- add-to-used-by
- remove-from-used-by
- revoke-propagating-permissions
- params
- tag: string
- name: string
- category: string
- description: string
- used_by_entity: string
- state: one of ['present','absent','revoked']
- implements
- vmware_cis_tag_facts
- implements
- /com/vmware/cis/tagging/tag
- commands
- GET
- POST
- actions
- list-used-tags
- list-tags-for-category
- params
- tag: string
- used_by_entity: string
- implements
- vmware_cis_tag_association
- implements
- /com/vmware/cis/tagging/tag_association
- commands
- POST
- actions
- attach-multiple-tags-to-object
- detach-multiple-tags-from-object
- attach
- attach-tag-to-multiple-objects
- detach
- detach-tag-from-multiple-objects
- params
- tag: string
- object_id:
- id: string
- type: string
- object_name: string
- implements
- vmware_cis_tag_association_facts
- implements
- /com/vmware/cis/tagging/tag_association
- commands
- POST
- actions
- list-attachable-tags
- list-attached-objects-on-tags
- list-attached-tags
- list-attached-tags-on-objects
- list-attached-objects
- params
- tag: string
- tag_ids: [string]
- object_id:
- id: string
- type: string
- object_name: string
- implements
- vmware_cis_tasks
- implements
- /cis/tasks
- commands
- POST
- actions
- cancel
- params
- task_id: string
- implements
- vmware_cis_tasks_facts
- implements
- /cis/tasks
- commands
- GET
- params
- task_id: string
- implements
- vmware_content_configuration
- implements
- /com/vmware/content/configuration
- commands
- PATCH
- params
- model:
- maximum_concurrent_item_syncs: int
- automatic_sync_start_hour: int
- automatic_sync_stop_hour: int
- automatic_sync_enabled: bool
- model:
- implements
- vmware_content_configuration_facts
- implements
- /com/vmware/content/configuration
- commands
- POST
- actions
- get
- implements
- vmware_content_library
- NOTE: this module needs further research into what are the actual params updated. This will not modify the publishinfo of a local library nor the subscriptioninfo of a subscribed library, so why these are specified is unclear.
- implements
- /com/vmware/content/library
- /com/vmware/content/library/subscriptions
- /com/vmware/content/library/local-library
- /com/vmware/content/library/subscribed-library
- commands
- PATCH
- POST
- actions
- delete
- publish
- probe
- evict
- sync
- params
- library: string
- update_spec:
- name: string
- last_sync_time: date-time
- optimization_info:
- optimize_remote_publishing: true
- id: string
- type: one of ['LOCAL','SUBSCRIBED']
- storage_backings:
- storage_uri: string
- type: one of ['DATASTORE',]
- datastore_id: string
- version
- server_guid: string
- publish_info
- current_password: string
- published: bool
- persist_json_enabled: bool
- publish_url: string
- authentication_method: one of ['BASIC',]
- user_name: string
- password: string
- creation_time: date-time
- last_modified_time: date-time
- subscription_info:
- subscription_url: string
- on_demand: bool
- source_info:
- source_library: string
- subscription: string
- password: string
- user_name: string
- authentication_method: one of ['BASIC',]
- ssl_thumbprint: string
- automatic_sync_enabled: bool
- description: string
- vmware_content_library_facts
- implements
- /com/vmware/content/library
- /com/vmware/content/library/subscriptions
- /com/vmware/content/local-library
- /com/vmware/content/subscribed-library
- commands
- GET
- POST
- actions
- find
- get
- params
- library: string
- library_type: one of ['LOCAL','SUBSCRIBED']
- implements
- vmware_content_item
- Much of the implemented APIs will be hidden from the user. The user will specify library and item names, then identify the files to download or update. Download and update sessions have a five minute life span and require keep-alive to extend them.
- implements
- /com/vmware/content/library/item
- /com/vmware/content/library/item/download-session
- /com/vmware/content/library/item/download-session/file
- /com/vmware/content/library/item/update-session
- /com/vmware/content/library/item/update-session/file
- /com/vmware/content/library/subscribed-item
- /vcenter/vm-template/library-items
- commands
- PATCH
- POST
- DELETE
- actions
- publish
- copy
- prepare
- cancel
- fail
- keep-alive
- complete
- evict
- sync
- deploy
- params
- library_item: string
- item_spec: used for item_create_spec, item_update_spec, destination_create_spec
- name: string
- description: string
- content_version: string
- last_sync_time: date-time
- library: string
- cached: bool
- id: string
- type: string
- version: string
- size: int
- creation_time: date-time
- last_modified_time: date-time
- metadata_version: string
- source_id: string
- publish_spec:
- force_sync_content: bool
- subscriptions: [ subscription: string ]
- vm_create_spec:
- description: string
- source_vm: string
- library: string
- name: string
- disk_storage_overrides: array of
- value:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- key: string
- value:
- placement:
- resource_pool: string
- folder: string
- host: string
- cluster: string
- vm_home_storage:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- disk_storage:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- deploy_spec:
- guest_customization:
- name: string
- description: string
- disk_storage:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- name: string
- disk_storage_overrides: array of
- value:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- key: string
- value:
- hardware_customization:
- disks_to_remove: [string]
- disks_to_update: array of
- value:
- capacity: int
- key: string
- value:
- cpu_update:
- num_cpus: int
- num_cores_per_socket: int
- memory_update:
- memory: int
- nics: array of
- value:
- network: string
- key: string
- value:
- vm_home_strategy:
- storage_policy:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- datastore: string
- storage_policy:
- placement:
- resource_pool: string
- folder: string
- host: string
- cluster: string
- powered_on: bool
- guest_customization:
- client_token: string
- client_error_message: string
- progress: int
- endpoint_type: one of ['DIRECT','HTTPS']
- file_name: string
- download_session_id: string
- update_session_id: string
- vmware_content_item_facts
- implements
- /com/vmware/content/library/item
- /com/vmware/content/library/item/download-session
- /com/vmware/content/library/item/download-session/file
- /com/vmware/content/library/item/file
- /com/vmware/content/library/item/storage
- /com/vmware/content/library/item/update-session
- /com/vmware/content/library/item/update-session/file
- /vcenter/vm-template/library-items
- commands
- GET
- POST
- actions
- find
- get
- library: string
- library_item: string
- find_spec:
- name: string
- library_id: string
- cached: bool
- type: string
- source: string
- download_session_id
- update_session_id
- implements
- vmware_vapi_metadata_authentication_component
- vmware_vapi_metadata_authentication_package
- vmware_vapi_metadata_authentication_service
- vmware_vapi_metadata_authentication_service_operation
- vmware_vapi_metadata_cli_command
- vmware_vapi_metadata_cli_namespace
- vmware_vapi_metadata_metamodel_component
- vmware_vapi_metadata_metamodel_enumeration
- vmware_vapi_metadata_metamodel_package
- vmware_vapi_metadata_metamodel_resource
- vmware_vapi_metadata_metamodel_resource_model
- vmware_vapi_metadata_metamodel_service
- vmware_vapi_metadata_metamodel_service_operation
- vmware_vapi_metadata_metamodel_structure
- vmware_vapi_metadata_privilege_package
- vmware_vapi_metadata_privilege_service
- vmware_vapi_metadata_privilege_service_operation
- vmware_vapi_rest_navigation_component
- vmware_vapi_rest_navigation_options
- vmware_vapi_vcenter_activation
- vmware_vcenter_certificate
- implements
- /vcenter/certificate-management/vcenter/tls
- /vcenter/certificate-management/vcenter/tls-csr
- /vcenter/certificate-management/vcenter/trusted-root-chains
- commands
- PUT
- POST
- DELETE
- actions
- renew
- params
- cert: string
- key: string
- duration: int
- csr_spec:
- subject_alt_name: string
- key_size: int
- country: string
- organization_unit: string
- locality: string
- common_name: string
- email_address: string
- organization: string
- state_or_province: string
- chain_spec:
- chain: string
- cert_chain: [string]
- state: one of ['present','absent']
- implements
- vmware_vcenter_certificate_facts
- implements
- /vcenter/certificate-management/vcenter/tls
- /vcenter/certificate-management/vcenter/trusted-root-chains
- commands
- GET
- params
- chain: string
- implements
- vmware_vcenter_cluster_facts
- implements
- /vcenter/cluster
- commands
- GET
- params
- cluster: string
- filter.datacenters: [string]
- filter.folders: [string]
- filter.clusters: [string]
- filter.names: [string]
- implements
- vmware_vcenter_datacenter
- implements
- /vcenter/datacenter
- commands
- POST
- DELETE
- params
- datacenter: string
- name: string
- folder: string
- state: one of ['present','absent']
- implements
- vmware_vcenter_datacenter_facts
- implements
- /vcenter/datacenter
- commands
- GET
- params
- filter.datacenters: [string]
- filter.folders: [string]
- filter.names: [string]
- implements
- vmware_vcenter_datastore_facts
- implements
- /vcenter/datastore
- /vcenter/datastore/default-policy
- commands
- GET
- params
- datastore: string
- filter.datastores: [string]
- filter.datacenters: [string]
- filter.folders: [string]
- filter.types: ['','VMFS','NFS','NFS41','CIFS','VSAN','VFFS','VVOL']
- filter.names: [string]
- implements
- vmware_vcenter_deployment
- implements
- /vcenter/deployment
- /vcenter/deployment/history
- /vcenter/deployment/install
- /vcenter/deployment/install/psc/replicated
- /vcenter/deployment/install/psc/standalone
- /vcenter/deployment/install/remote-psc
- /vcenter/deployment/question
- /vcenter/deployment/upgrade
- /vcenter/system-config/deployment-type
- /vcenter/topology/pscs
- commands
- POST
- actions
- rollback
- cancel_import
- pause_import
- resume_import
- start_import
- cancel_install
- check_install
- start_install
- check_replicated_psc
- check_standalone_psc
- check_remote_psc
- answer
- cancel_upgrade
- check_upgrade
- start_upgrade
- reconfigure
- convert-to-vcsa-embedded
- register_psc
- decommission_psc
- params
- import_spec:
- description: string
- name: string
- install_spec:
- auto_answer: bool
- vcsa_external:
- ssl_thumbprint: string
- sso_admin_password: string
- ssl_verify: bool
- https_port: int
- psc_hostname: string
- vcsa_embedded:
- ceip_enabled: bool
- replicated:
- partner_hostname: string
- sso_admin_password: string
- https_port: int
- ssl_thumbprint: string
- ssl_verify: bool
- standalone:
- sso_admin_password: string
- sso_domain_name: string
- psc:
- ceip_enabled: bool
- replicated:
- sso_site_name: string
- sso_admin_password: string
- ssl_verify: bool
- partner_hostname: string
- https_port: int
- ssl_thumbprint: string
- standalone:
- sso_site_name: string
- sso_admin_password: string
- sso_domain_name: string
- replicated_psc_spec:
- sso_site_name: string
- sso_admin_password: string
- ssl_verify: bool
- partner_hostname: string
- https_port: int
- ssl_thumbprint: string
- standalone_psc_spec:
- sso_site_name: string
- sso_admin_password: string
- sso_domain_name: string
- remote_psc_spec:
- ssl_thumbprint: string
- sso_admin_password: string
- ssl_verify: bool
- https_port: int
- psc_hostname: string
- answer_spec:
- answer_val: string
- question_id: string
- upgrade_spec:
- auto_answer: bool
- source_appliance:
- ssh_verify: bool
- ssl_verify: bool
- sso_admin_username: string
- hostname: string
- ssh_thumbprint: string
- root_password: string
- sso_admin_password: string
- ssl_thumbprint: string
- https_port: int
- psc:
- ceip_enabled: bool
- source_location:
- ssl_verify: bool
- hostname: string
- username: string
- password: string
- ssl_thumbprint: string
- https_port: int
- history:
- data_set: one of ["EVENTS","TASKS","EVENTS_TASKS"]
- defer_import: bool
- vcsa_embedded:
- ceip_enabled: bool
- decommission_spec:
- sso_admin_password: string
- sso_admin_username: string
- ssl_thumbprint: string
- ssl_verify: bool
- only_precheck: bool
- import_spec:
- implements
- vmware_vcenter_deployment_facts
- implements
- /vcenter/deployment
- /vcenter/deployment/history
- /vcenter/deployment/install
- /vcenter/deployment/install/initial-config/remote-psc/thumbprint
- /vcenter/deployment/question
- /vcenter/deployment/upgrade
- /vcenter/system-config/deployment-type
- /vcenter/system-config/psc-registration
- commands
- GET
- implements
- vmware_vcenter_folder_facts
- implements
- /vcenter/folder
- commands
- GET
- params
- filter.datacenters: [string]
- filter.folders: [string]
- filter.names: [string]
- filter.parent_folders: [string]
- filter.type: string
- implements
- vmware_vcenter_guest_customization_facts
- implements
- /vcenter/guest/customization-specs
- commands
- GET
- params
- filter.names: [string]
- filter.OS_type: string
- implements
- vmware_vcenter_host
- implements
- /vcenter/host
- commands
- POST
- DELETE
- actions
- connect
- disconnect
- params
- add_spec:
- user_name: string
- thumbprint_verification: one of ['NONE']
- hostname: string
- folder: string
- password: string
- force_add: bool
- thumbprint: string
- port: int
- host: string
- state: one of ['present','absent','disconnected']
- add_spec:
- implements
- vmware_vcenter_host_facts
- implements
- /vcenter/host
- commands
- GET
- params
- filter.clusters: [string]
- filter.names: [string]
- filter.standalone: bool
- filter.connection_states: any of ['',CONNECTED','DISCONNECTED','NOT RESPONDING']
- filter.folders: [string]
- filter.datacenters: [string]
- filter.hosts: [string]
- implements
- vmware_vcenter_inventory_facts
- implements
- /com/vmware/vcenter/inventory/datastore
- /com/vmware/vcenter/inventory/network
- commands
- POST
- actions
- find
- params
- datastores: [string]
- networks: [string]
- implements
- vmware_vcenter_network_facts
- implements
- /vcenter/network
- commands
- GET
- params
- filter.networks: [string]
- filter.names: [string]
- filter.folders: [string]
- filter.datacenters: [string]
- filter.types: any of ['','STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK']
- implements
- vmware_vcenter_ovf
- implements
- /com/vmware/vcenter/ovf/library-item
- commands
- POST
- actions
- deploy
- params
- create_source:
- id: string
- type: string
- create_spec:
- description: string
- flags: [string]
- name: string
- create_target:
- library: string
- library_item: string
- client_token: string
- ovf_library_item: string
- deployment_spec:
- additional_parameters: [ dict ]
- network_mappings: array of
- key: string
- value: string
- accept_all_EULA: bool
- storage_mappings: array of
- key: string
- value:
- provisioning: one of ['thick','thin']
- datastore: string
- type: one of ['DATASTORE']
- storage_profile: string
- annotation: string
- storage_provisioning: one of ['thick','thin']
- default_datastore: string
- flags: [string]
- storage_profile: string
- name: string
- locale: string
- state: one of ['present','absent']
- create_source:
- implements
- vmware_vcenter_ovf_facts
- implements
- /com/vmware/vcenter/ovf/capability
- /com/vmware/vcenter/ovf/export-flag
- /com/vmware/vcenter/ovf/import-flag
- /com/vmware/vcenter/ovf/library-item
- commands
- GET
- POST
- actions
- filter
- params
- ovf_library_item: string
- folder: string
- resource_pool: string
- host: string
- implements
- vmware_vcenter_resource_pool_facts
- implements
- /vcenter/resource-pool
- commands
- GET
- params
- resource_pool: string
- filter.clusters: [string]
- filter.names: [string]
- filter.parent_resource_pools: [string]
- filter.resource_pools: [string]
- filter.datacenters: [string]
- filter.hosts: [string]
- implements
- vmware_vcenter_service
- implements
- /vcenter/services
- commands
- PATCH
- POST
- actions
- restart
- start
- stop
- params
- service: string
- update_spec:
- startup_type: one of ['MANUAL','AUTOMATIC']
- implements
- vmware_vcenter_service_facts
- implements
- /vcenter/services
- commands
- GET
- params
- service: string
- implements
- vmware_vcenter_storage_policies
- vmware_vcenter_storage_policies_facts
- implements
- /vcenter/storage/policies
- /vcenter/storage/policies/entities/compliance
- commands
- GET
- POST
- actions
- check-compatibility
- params
- policy: string
- datastores: [string]
- filter.policies: [string]
- filter.status: any of ['','COMPLIANT','NON_COMPLIANT','UNKNOWN','UNKNOWN_COMPLIANCE','NOT_APPLICABLE','OUT_OF_DATE']
- filter.vms: [string]
- implements
- vmware_vcenter_vcha
- implements
- /vcenter/vcha/cluster
- /vcenter/vcha/cluster/mode
- /vcenter/vcha/cluster/passive
- /vcenter/vcha/cluster/witness
- commands
- POST
- PUT
- actions
- deploy
- failover
- undeploy
- mode
- check_passive
- redeploy_passive
- check_witness
- redeploy_witness
- validate
- params
- deploy_spec:
- witness:
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- ha_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- placement:
- passive:
- failover_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6:
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- ha_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- failover_ip:
- deployment: one of ['AUTO']
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- active:
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- ha_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- ha_network: string
- witness:
- failover_spec:
- planned: bool
- undeploy_spec:
- force_delete: bool
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- vms:
- witness:
- vm: string
- bios_uuid: string
- passive:
- vm: string
- bios_uuid: string
- witness:
- mode_spec:
- mode: one of ['ENABLED','DISABLED','MAINTENANCE']
- check_passive_spec:
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- placement:
- redeploy_passive_spec:
- failover_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6:
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- ha_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- failover_ip:
- check_witness_spec:
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- placement:
- redeploy_witness_spec:
- placement:
- name: string
- management_network: string
- resource_pool: string
- ha_network: string
- host: string
- ha_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- management_network_type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- folder: string
- storage:
- datastore: string
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- ha_ip:
- default_gateway: string
- ipv4:
- prefix: int
- address: string
- subnet_mask: string
- ipv6
- prefix: int
- address: string
- dns_servers: [string]
- ip_family: one of ['IPV4']
- placement:
- validate_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- deploy_spec:
- implements
- vmware_vcenter_vcha_facts
- implements
- /vcenter/vcha/capabilities
- /vcenter/vcha/cluster
- /vcenter/vcha/cluster/active
- /vcenter/vcha/cluster/deployment-type
- /vcenter/vcha/cluster/mode
- /vcenter/vcha/operations
- commands
- GET
- POST
- actions
- get
- params
- partial: bool
- vc_spec:
- active_location:
- port: int
- ssl_thumbprint: string
- password: string
- hostname: string
- username: string
- active_location:
- implements
- vmware_vcenter_vm
- implements
- /com/vmware/vcenter/iso/image
- /vcenter/vm
- /vcenter/vm/vm_id/guest/power
- /vcenter/vm/vm_id/hardware
- /vcenter/vm/vm_id/hardware/adapter/sata
- /vcenter/vm/vm_id/hardware/adapter/scsi
- /vcenter/vm/vm_id/hardware/boot
- /vcenter/vm/vm_id/hardware/boot/device
- /vcenter/vm/vm_id/hardware/cdrom
- /vcenter/vm/vm_id/hardware/cpu
- /vcenter/vm/vm_id/hardware/disk
- /vcenter/vm/vm_id/hardware/ethernet
- /vcenter/vm/vm_id/hardware/floppy
- /vcenter/vm/vm_id/hardware/memory
- /vcenter/vm/vm_id/hardware/parallel
- /vcenter/vm/vm_id/hardware/serial
- /vcenter/vm/vm_id/power
- /vcenter/vm/vm_id/storage/policy
- commands
- POST
- PATCH
- PUT
- DELETE
- actions
- mount_iso
- unmount_iso
- upgrade
- connect_cdrom
- disconnect_cdrom
- connect_floppy
- disconnect_floppy
- connect_nic
- disconnect_nic
- connect_parallel
- disconnect_parallel
- connect_serial
- disconnect_serial
- reboot
- shutdown
- standby
- reset
- start
- stop
- suspend
- check
- params
- state: one of ['present','absent']
- vm: string
- adapter: string
- cdrom: string
- disk: string
- floppy: string
- library_item: string
- nic: string
- parallel_port: string
- serial_port: string
- create_spec:
- name: string
- sata_adapters: array of
- bus: int
- type: one of ['AHCI']
- pci_slot_number: int
- placement:
- datastore: string
- cluster: string
- folder: string
- resource_pool: string
- host: string
- hardware_version: one of ['VMX_O3']
- memory:
- size_MiB: int
- hot_add_enabled: bool
- storage_policy:
- policy: string
- scsi_adapter: array of
- bus: int
- type: one of ['BUSLOGIC']
- sharing: one of ['NONE']
- pci_slot_number: int
- disks: array of
- ide:
- master: bool
- primary: bool
- scsi:
- bus: int
- unit: int
- backing:
- vmdk_file: string
- type: one of ['VMDK_FILE']
- sata:
- bus: int
- unit: int
- type: one of ['IDE','SCSI','SATA']
- new_vmdk:
- storage_policy:
- policy: string
- name: string
- capacity: int
- storage_policy:
- ide:
- cdroms: array of
- allow_guest_control: bool
- ide:
- master: bool
- primary: bool
- backing:
- host_device: string
- device_access_type: one of ['EMULATION']
- type: one of ['ISO_FILE']
- iso_file: string
- sata:
- bus: int
- unit: int
- type: one of ['IDE']
- start_connected: bool
- parallel_ports: array of
- allow_guest_control: bool
- backing:
- file: string
- type: one of ['FILE']
- host_device: string
- start_connected: bool
- cpu:
- hot_remove_enabled: bool
- count: int
- hot_add_enabled: bool
- cores_per_socket: int
- serial_ports:
- allow_guest_control: bool
- start_connected: bool
- backing:
- network_location: string
- no_rx_loss: bool
- host_device: string
- file: string
- type: one of ['FILE']
- pipe: string
- proxy: string
- yield_on_poll: bool
- guest_os: one of ['DOS']
- boot_devices: array of
- type: one of ['CDROM']
- nics: array of
- mac_address: string
- mac_type: one of ['MANUAL']
- allow_guest_control: bool
- pci_slot_number: int
- backing:
- distributed_port: string
- network: string
- type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- upt_compatibility_enabled: bool
- type: one of ['E1000']
- wake_on_lan_enabled: bool
- start_connected: bool
- boot:
- enter_setup_mode: bool
- retry_delay: int
- delay: int
- retry: bool
- efi_legacy_boot: bool
- type: one of ['BIOS']
- network_protocol: one of ['IPV4']
- floppies: array of
- allow_guest_control: bool
- backing:
- image_file: string
- type: one of ['IMAGE_FILE']
- host_device: string
- start_connected: bool
- boot_patch_spec:
- retry_delay: int
- enter_setup_mode: bool
- delay: int
- efi_legacy_boot: bool
- type: one of ['BIOS']
- retry: bool
- network_protocol: one of ['IPV4']
- boot_device_spec:
- devices: array of
- nic: string
- type: one of ['CDROM']
- disks: [string]
- devices: array of
- cdrom_create_spec:
- allow_guest_control: bool
- ide:
- master: bool
- primary: bool
- backing:
- host_device: string
- device_access_type: one of ['EMULATION']
- type: one of ['ISO_FILE']
- iso_file: string
- sata:
- bus: int
- unit: int
- type: one of ['IDE']
- start_connected: bool
- cdrom_patch_spec:
- allow_guest_control: bool
- backing:
- host_device: string
- device_access_type: one of ['EMULATION']
- type: one of ['ISO_FILE']
- iso_file: string
- start_connected: bool
- check_spec:
- disks: [string]
- vm_home: bool
- cpu_spec:
- hot_remove_enabled: bool
- count: int
- hot_add_enabled: bool
- cores_per_socket: int
- disk_update_spec:
- backing:
- vmdk_file: string
- type: one of ['VMDK_FILE']
- backing:
- disk_create_spec:
- sata:
- unit: int
- bus: int
- ide:
- primary: bool
- master: bool
- type: one of ['IDE','SATA','SCSI']
- new_vmdk:
- name: string
- capacity: int
- storage_policy:
- policy: string
- scsi:
- unit: int
- bus: int
- backlog:
- vmdk_file: string
- type: one of ['VMDK_FILE']
- sata:
- floppy_spec:
- allow_guest_control: bool
- backing:
- image_file: string
- type: one of ['IMAGE_FILE']
- host_device: string
- start_connected: bool
- hardware_upgrade_spec:
- version: one of ['VMX_03']
- hardware_patch_spec:
- upgrade_version: one of ['VMX_03']
- upgrade_policy: one of ['NEVER']
- memory_spec:
- size_MiB: int
- hot_add_enabled: bool
- nic_spec:
- mac_address: string
- mac_type: one of ['MANUAL']
- allow_guest_control: bool
- pci_slot_number: int
- backing:
- distributed_port: string
- network: string
- type: one of ['STANDARD_PORTGROUP','DISTRIBUTED_PORTGROUP','OPAQUE_NETWORK]
- upt_compatibility_enabled: bool
- type: one of ['E1000']
- wake_on_lan_enabled: bool
- start_connected: bool
- parallel_spec:
- allow_guest_control: bool
- backing:
- file: string
- type: one of ['FILE']
- host_device: string
- start_connected: bool
- policy_spec:
- disks: array of
- key: string
- value:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- vm_home:
- policy: string
- type: one of ['USE_SPECIFIED_POLICY']
- disks: array of
- sata_create_spec:
- type: one of ['AHCI']
- pci_slot_number: int
- bus: int
- scsi_create_spec:
- sharing: one of ['NONE']
- type: one of ['BUSLOGIC']
- pci_slot_number: int
- bus: int
- scsi_update_spec:
- sharing: one of ['NONE']
- serial_spec:
- allow_guest_control: bool
- yield_on_poll: bool
- backing:
- network_location: string
- pipe: string
- proxy: string
- no_rx_loss: bool
- host_device: string
- file: string
- type: one of ['FILE']
- start_connected: bool
- implements
- vmware_vcenter_vm_facts
- implements
- /vcenter/vm/vm_id/guest/identity
- /vcenter/vm/vm_id/guest/local-filesystem
- /vcenter/vm/vm_id/guest/power
- /vcenter/vm/vm_id/hardware
- /vcenter/vm/vm_id/hardware/adapter/sata
- /vcenter/vm/vm_id/hardware/adapter/scsi
- /vcenter/vm/vm_id/hardware/boot
- /vcenter/vm/vm_id/hardware/boot/device
- /vcenter/vm/vm_id/hardware/cdrom
- /vcenter/vm/vm_id/hardware/cpu
- /vcenter/vm/vm_id/hardware/disk
- /vcenter/vm/vm_id/hardware/ethernet
- /vcenter/vm/vm_id/hardware/floppy
- /vcenter/vm/vm_id/hardware/memory
- /vcenter/vm/vm_id/hardware/parallel
- /vcenter/vm/vm_id/hardware/serial
- /vcenter/vm/vm_id/power
- /vcenter/vm/vm_id/storage/policy
- /vcenter/vm/vm_id/storage/policy/compliance
- commands
- GET
- params
- vm: string
- filter.names: [string]
- filter.hosts: [string]
- filter.datacenters: [string]
- filter.resource_pools: [string]
- filter.clusters: [string]
- filter.power_states: any of ['','POWERED_OFF','POWERED_ON','SUSPENDED']
- filter.folders: [string]
- filter.vms: [string]
- implements
Administer permissions or grant access to areas of vSphere or vCenter
Manipulate vCenter Alarms
- I cannot find any ReST APIs that manage vCenter alarms
Perform operations across an entire cluster. The modules are
- vmware_cluster_capacity
- vmware_cluster_reboot
Manipulate vCenter tasks and events
- I cannot find any ReST APIs that manage tasks and events
Manipulate vCenter inventory, including metadata such as tags, attributes and folders. Some APIs are missing critical functionality, like creating folders. The modules are
- vmware_inventory_backup
- vmware_inventory_restore
Manage VMware licensing in vCenter
- I cannot find any ReST APIs that manage licensing of vCenters
Generic networking tasks
Networking tasks specific to NSX and NSX-T
Manage vCenter sessions
Manage statistics from vCenter
- I cannot find any ReST APIs that manage vCenter statistics
Interface with Site Recovery Manager
- I cannot find any ReST APIs that manage Site Recovery Manager
Generic storage tasks, working with datastores and datastore clusters
Storage tasks specific to ISCSI
Storage tasks specific to VSAN
Managing vApps and their contents
- I cannot find any ReST APIs that manage vApps
Interfacing with vCloud Director
- I cannot find any ReST APIs that manage vCloud Director
Management of VMs, individually or in groups
Management of ESXi hosts, individually or in groups
Interfacing with vRealize Orchestrator
- I cannot find any ReST APIs that manage vRealize Orchestrator
[Akasurde]: Create a wiki page for collaboration[Akasurde]: Push VMware httpapi plugin upstream for review- [Paul Knight]: Start design specification document for VMware httpapi plugin - IN PROGRESS
- [Paul Knight]: Review this doc and add comments
This Wiki is used for quick notes, not for support or documentation.
Working groups are now in the Ansible forum
Ansible project:
Community,
Contributor Experience,
Docs,
News,
Outreach,
RelEng,
Testing
Cloud:
AWS,
Azure,
CloudStack,
Container,
DigitalOcean,
Docker,
hcloud,
Kubernetes,
Linode,
OpenStack,
oVirt,
Virt,
VMware
Networking:
ACI,
AVI,
F5,
Meraki,
Network,
NXOS
Ansible Developer Tools:
Ansible-developer-tools
Software:
Crypto,
Foreman,
GDrive,
GitLab,
Grafana,
IPA,
JBoss,
MongoDB,
MySQL,
PostgreSQL,
RabbitMQ,
Zabbix
System:
AIX,
BSD,
HP-UX,
macOS,
Remote Management,
Solaris,
Windows
Security:
Security-Automation,
Lockdown
Tooling:
AWX,
Galaxy,
Molecule
Plugins:
httpapi