vsphere-automation-cis
The Ruby gem for the vSphere CIS API
- API version: 2.0.0
- Package version: 0.2.0
Installation
Add this line to your application's Gemfile:
gem 'vsphere-automation-cis'
And then execute:
$ bundle
Or install it yourself as:
$ gem install vsphere-automation-cis
Getting Started
Please follow the installation procedure and then run the following code:
# Load the gem
require 'vsphere-automation-cis'
# Setup authorization
VSphereAutomation.configure do |config|
# Configure HTTP basic authorization: basic_auth
config.username = 'YOUR USERNAME'
config.password = 'YOUR PASSWORD'
end
api_instance = VSphereAutomation::CIS::SessionApi.new
vmware_use_header_authn = 'vmware_use_header_authn_example' # String | Custom header to protect against CSRF attacks in browser based clients
begin
#Creates a session with the API. This is the equivalent of login. This operation exchanges user credentials supplied in the security context for a session identifier that is to be used for authenticating subsequent calls. To authenticate subsequent calls clients are expected to include the session key.
result = api_instance.create(vmware_use_header_authn)
p result
rescue VSphereAutomation::ApiError => e
puts "Exception when calling SessionApi->create: #{e}"
end
Documentation for API Endpoints
All URIs are relative to https://<vcenter>/rest
Class | Method | HTTP request | Description |
---|---|---|---|
VSphereAutomation::CIS::SessionApi |
create | POST /com/vmware/cis/session | Creates a session with the API. This is the equivalent of login. This operation exchanges user credentials supplied in the security context for a session identifier that is to be used for authenticating subsequent calls. To authenticate subsequent calls clients are expected to include the session key. |
VSphereAutomation::CIS::SessionApi |
delete | DELETE /com/vmware/cis/session | Terminates the validity of a session token. This is the equivalent of log out. A session identifier is expected as part of the request. |
VSphereAutomation::CIS::SessionApi |
get | POST /com/vmware/cis/session?~action=get | Returns information about the current session. This operation expects a valid session identifier to be supplied. A side effect of invoking this operation may be a change to the session's last accessed time to the current time if this is supported by the session implementation. Invoking any other operation in the API will also update the session's last accessed time. This API is meant to serve the needs of various front end projects that may want to display the name of the user. Examples of this include various web based user interfaces and logging facilities. |
VSphereAutomation::CIS::TaggingCategoryApi |
add_to_used_by | POST /com/vmware/cis/tagging/category/id:category_id?~action=add-to-used-by | Adds the usedByEntity to the CategoryModel#usedBy subscribers set for the specified category. If the usedByEntity is already in the set, then this becomes an idempotent no-op. To invoke this operation, you need the modify CategoryModel#usedBy privilege on the category. |
VSphereAutomation::CIS::TaggingCategoryApi |
create | POST /com/vmware/cis/tagging/category | Creates a category. To invoke this operation, you need the create category privilege. |
VSphereAutomation::CIS::TaggingCategoryApi |
delete | DELETE /com/vmware/cis/tagging/category/id:category_id | Deletes an existing category. To invoke this operation, you need the delete privilege on the category. |
VSphereAutomation::CIS::TaggingCategoryApi |
get | GET /com/vmware/cis/tagging/category/id:category_id | Fetches the category information for the given category identifier. In order to view the category information, you need the read privilege on the category. |
VSphereAutomation::CIS::TaggingCategoryApi |
list | GET /com/vmware/cis/tagging/category | Enumerates the categories in the system. To invoke this operation, you need the read privilege on the individual categories. The list will only contain those categories for which you have read privileges. |
VSphereAutomation::CIS::TaggingCategoryApi |
list_used_categories | POST /com/vmware/cis/tagging/category?~action=list-used-categories | Enumerates all categories for which the usedByEntity is part of the CategoryModel#usedBy subscribers set. To invoke this operation, you need the read privilege on the individual categories. |
VSphereAutomation::CIS::TaggingCategoryApi |
remove_from_used_by | POST /com/vmware/cis/tagging/category/id:category_id | Removes the usedByEntity from the CategoryModel#usedBy subscribers set. If the usedByEntity is not using this category, then this becomes a no-op. To invoke this operation, you need the modify CategoryModel#usedBy privilege on the category. |
VSphereAutomation::CIS::TaggingCategoryApi |
revoke_propagating_permissions | POST /com/vmware/cis/tagging/category/id:category_id?~action=revoke-propagating-permissions | Revokes all propagating permissions on the given category. You should then attach a direct permission with tagging privileges on the given category. To invoke this operation, you need category related privileges (direct or propagating) on the concerned category. |
VSphereAutomation::CIS::TaggingCategoryApi |
update | PATCH /com/vmware/cis/tagging/category/id:category_id | Updates an existing category. To invoke this operation, you need the edit privilege on the category. |
VSphereAutomation::CIS::TaggingTagApi |
add_to_used_by | POST /com/vmware/cis/tagging/tag/id:tag_id | Adds the usedByEntity to the TagModel#usedBy subscribers set. If the usedByEntity is already in the set, then this becomes a no-op. To invoke this operation, you need the modify TagModel#usedBy privilege on the tag. |
VSphereAutomation::CIS::TaggingTagApi |
create | POST /com/vmware/cis/tagging/tag | Creates a tag. To invoke this operation, you need the create tag privilege on the input category. |
VSphereAutomation::CIS::TaggingTagApi |
delete | DELETE /com/vmware/cis/tagging/tag/id:tag_id | Deletes an existing tag. To invoke this operation, you need the delete privilege on the tag. |
VSphereAutomation::CIS::TaggingTagApi |
get | GET /com/vmware/cis/tagging/tag/id:tag_id | Fetches the tag information for the given tag identifier. To invoke this operation, you need the read privilege on the tag in order to view the tag info. |
VSphereAutomation::CIS::TaggingTagApi |
list | GET /com/vmware/cis/tagging/tag | Enumerates the tags in the system. To invoke this operation, you need read privilege on the individual tags. The list will only contain tags for which you have read privileges. |
VSphereAutomation::CIS::TaggingTagApi |
list_tags_for_category | POST /com/vmware/cis/tagging/tag/id:category_id | Enumerates all tags for the given category. To invoke this operation, you need the read privilege on the given category and the individual tags in that category. |
VSphereAutomation::CIS::TaggingTagApi |
list_used_tags | POST /com/vmware/cis/tagging/tag?~action=list-used-tags | Enumerates all tags for which the usedByEntity is part of the TagModel#usedBy subscribers set. To invoke this operation, you need the read privilege on the individual tags. |
VSphereAutomation::CIS::TaggingTagApi |
remove_from_used_by | POST /com/vmware/cis/tagging/tag/id:tag_id?~action=remove-from-used-by | Removes the usedByEntity from the TagModel#usedBy subscribers set. If the usedByEntity is not using this tag, then this becomes a no-op. To invoke this operation, you need modify TagModel#usedBy privilege on the tag. |
VSphereAutomation::CIS::TaggingTagApi |
revoke_propagating_permissions | POST /com/vmware/cis/tagging/tag/id:tag_id?~action=revoke-propagating-permissions | Revokes all propagating permissions on the given tag. You should then attach a direct permission with tagging privileges on the given tag. To invoke this operation, you need tag related privileges (direct or propagating) on the concerned tag. |
VSphereAutomation::CIS::TaggingTagApi |
update | PATCH /com/vmware/cis/tagging/tag/id:tag_id | Updates an existing tag. To invoke this operation, you need the edit privilege on the tag. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
attach | POST /com/vmware/cis/tagging/tag-association/id:tag_id?~action=attach | Attaches the given tag to the input object. The tag needs to meet the cardinality (CategoryModel#cardinality) and associability (CategoryModel#associableTypes) criteria in order to be eligible for attachment. If the tag is already attached to the object, then this operation is a no-op and an error will not be thrown. To invoke this operation, you need the attach tag privilege on the tag and the read privilege on the object. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
attach_multiple_tags_to_object | POST /com/vmware/cis/tagging/tag-association?~action=attach-multiple-tags-to-object | Attaches the given tags to the input object. If a tag is already attached to the object, then the individual operation is a no-op and an error will not be added to BatchResult#errorMessages. To invoke this operation, you need the read privilege on the object and the attach tag privilege on each tag. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
attach_tag_to_multiple_objects | POST /com/vmware/cis/tagging/tag-association/id:tag_id | Attaches the given tag to the input objects. If a tag is already attached to the object, then the individual operation is a no-op and an error will not be added to BatchResult#errorMessages. To invoke this operation, you need the attach tag privilege on the tag and the read privilege on each object. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
detach | POST /com/vmware/cis/tagging/tag-association/id:tag_id?~action=detach | Detaches the tag from the given object. If the tag is already removed from the object, then this operation is a no-op and an error will not be thrown. To invoke this operation, you need the attach tag privilege on the tag and the read privilege on the object. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
detach_multiple_tags_from_object | POST /com/vmware/cis/tagging/tag-association?~action=detach-multiple-tags-from-object | Detaches the given tags from the input object. If a tag is already removed from the object, then the individual operation is a no-op and an error will not be added to BatchResult#errorMessages. To invoke this operation, you need the read privilege on the object and the attach tag privilege each tag. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
detach_tag_from_multiple_objects | POST /com/vmware/cis/tagging/tag-association/id:tag_id?~action=detach-tag-from-multiple-objects | Detaches the given tag from the input objects. If a tag is already removed from the object, then the individual operation is a no-op and an error will not be added to BatchResult#errorMessages. To invoke this operation, you need the attach tag privilege on the tag and the read privilege on each object. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
list_attachable_tags | POST /com/vmware/cis/tagging/tag-association?~action=list-attachable-tags | Fetches the list of attachable tags for the given object, omitting the tags that have already been attached. Criteria for attachability is calculated based on tagging cardinality (CategoryModel#cardinality) and associability (CategoryModel#associableTypes) constructs. To invoke this operation, you need the read privilege on the input object. The list will only contain those tags for which you have read privileges. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
list_attached_objects | POST /com/vmware/cis/tagging/tag-association/id:tag_id?~action=list-attached-objects | Fetches the list of attached objects for the given tag. To invoke this operation, you need the read privilege on the input tag. Only those objects for which you have the read privilege will be returned. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
list_attached_objects_on_tags | POST /com/vmware/cis/tagging/tag-association?~action=list-attached-objects-on-tags | Fetches the list of TagToObjects describing the input tag identifiers and the objects they are attached to. To invoke this operation, you need the read privilege on each input tag. The TagToObjects#objectIds will only contain those objects for which you have the read privilege. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
list_attached_tags | POST /com/vmware/cis/tagging/tag-association?~action=list-attached-tags | Fetches the list of tags attached to the given object. To invoke this operation, you need the read privilege on the input object. The list will only contain those tags for which you have the read privileges. |
VSphereAutomation::CIS::TaggingTagAssociationApi |
list_attached_tags_on_objects | POST /com/vmware/cis/tagging/tag-association | Fetches the list of ObjectToTags describing the input object identifiers and the tags attached to each object. To invoke this operation, you need the read privilege on each input object. The ObjectToTags#tagIds will only contain those tags for which you have the read privilege. |
VSphereAutomation::CIS::TasksApi |
cancel | POST /cis/tasks/task | Cancel a running operation associated with the task. This is the best effort attempt. Operation may not be cancelled anymore once it reaches certain stage. |
VSphereAutomation::CIS::TasksApi |
get | GET /cis/tasks/task | Returns information about a task. |
VSphereAutomation::CIS::TasksApi |
list | GET /cis/tasks | Returns information about at most 1000 visible (subject to permission checks) tasks matching the Tasks.FilterSpec. All tasks must be in the same provider. |
Documentation for Models
- VSphereAutomation::CIS::CisSessionCreateResult
- VSphereAutomation::CIS::CisSessionInfo
- VSphereAutomation::CIS::CisSessionResult
- VSphereAutomation::CIS::CisTaggingCategoryAddToUsedBy
- VSphereAutomation::CIS::CisTaggingCategoryCreate
- VSphereAutomation::CIS::CisTaggingCategoryCreateResult
- VSphereAutomation::CIS::CisTaggingCategoryCreateSpec
- VSphereAutomation::CIS::CisTaggingCategoryListResult
- VSphereAutomation::CIS::CisTaggingCategoryListUsedCategories
- VSphereAutomation::CIS::CisTaggingCategoryListUsedCategoriesResult
- VSphereAutomation::CIS::CisTaggingCategoryModel
- VSphereAutomation::CIS::CisTaggingCategoryModelCardinality
- VSphereAutomation::CIS::CisTaggingCategoryRemoveFromUsedBy
- VSphereAutomation::CIS::CisTaggingCategoryResult
- VSphereAutomation::CIS::CisTaggingCategoryUpdate
- VSphereAutomation::CIS::CisTaggingCategoryUpdateSpec
- VSphereAutomation::CIS::CisTaggingTagAddToUsedBy
- VSphereAutomation::CIS::CisTaggingTagAssociationAttach
- VSphereAutomation::CIS::CisTaggingTagAssociationAttachMultipleTagsToObject
- VSphereAutomation::CIS::CisTaggingTagAssociationAttachMultipleTagsToObjectResult
- VSphereAutomation::CIS::CisTaggingTagAssociationAttachTagToMultipleObjects
- VSphereAutomation::CIS::CisTaggingTagAssociationAttachTagToMultipleObjectsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationBatchResult
- VSphereAutomation::CIS::CisTaggingTagAssociationDetach
- VSphereAutomation::CIS::CisTaggingTagAssociationDetachMultipleTagsFromObject
- VSphereAutomation::CIS::CisTaggingTagAssociationDetachMultipleTagsFromObjectResult
- VSphereAutomation::CIS::CisTaggingTagAssociationDetachTagFromMultipleObjects
- VSphereAutomation::CIS::CisTaggingTagAssociationDetachTagFromMultipleObjectsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachableTags
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachableTagsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedObjectsOnTags
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedObjectsOnTagsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedObjectsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedTags
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedTagsOnObjects
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedTagsOnObjectsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationListAttachedTagsResult
- VSphereAutomation::CIS::CisTaggingTagAssociationObjectToTags
- VSphereAutomation::CIS::CisTaggingTagAssociationTagToObjects
- VSphereAutomation::CIS::CisTaggingTagCreate
- VSphereAutomation::CIS::CisTaggingTagCreateResult
- VSphereAutomation::CIS::CisTaggingTagCreateSpec
- VSphereAutomation::CIS::CisTaggingTagListResult
- VSphereAutomation::CIS::CisTaggingTagListTagsForCategoryResult
- VSphereAutomation::CIS::CisTaggingTagListUsedTags
- VSphereAutomation::CIS::CisTaggingTagListUsedTagsResult
- VSphereAutomation::CIS::CisTaggingTagModel
- VSphereAutomation::CIS::CisTaggingTagRemoveFromUsedBy
- VSphereAutomation::CIS::CisTaggingTagResult
- VSphereAutomation::CIS::CisTaggingTagUpdate
- VSphereAutomation::CIS::CisTaggingTagUpdateSpec
- VSphereAutomation::CIS::CisTaskInfo
- VSphereAutomation::CIS::CisTaskProgress
- VSphereAutomation::CIS::CisTaskStatus
- VSphereAutomation::CIS::CisTasksFilterSpec
- VSphereAutomation::CIS::CisTasksGetSpec
- VSphereAutomation::CIS::CisTasksListResult
- VSphereAutomation::CIS::CisTasksListResultValue
- VSphereAutomation::CIS::CisTasksResult
- VSphereAutomation::CIS::FilterSpecTargets
- VSphereAutomation::CIS::VapiStdDynamicID
- VSphereAutomation::CIS::VapiStdErrorsAlreadyExists
- VSphereAutomation::CIS::VapiStdErrorsAlreadyExistsError
- VSphereAutomation::CIS::VapiStdErrorsError
- VSphereAutomation::CIS::VapiStdErrorsErrorError
- VSphereAutomation::CIS::VapiStdErrorsInvalidArgument
- VSphereAutomation::CIS::VapiStdErrorsInvalidArgumentError
- VSphereAutomation::CIS::VapiStdErrorsNotAllowedInCurrentState
- VSphereAutomation::CIS::VapiStdErrorsNotAllowedInCurrentStateError
- VSphereAutomation::CIS::VapiStdErrorsNotFound
- VSphereAutomation::CIS::VapiStdErrorsNotFoundError
- VSphereAutomation::CIS::VapiStdErrorsResourceInaccessible
- VSphereAutomation::CIS::VapiStdErrorsResourceInaccessibleError
- VSphereAutomation::CIS::VapiStdErrorsServiceUnavailable
- VSphereAutomation::CIS::VapiStdErrorsServiceUnavailableError
- VSphereAutomation::CIS::VapiStdErrorsUnauthenticated
- VSphereAutomation::CIS::VapiStdErrorsUnauthenticatedError
- VSphereAutomation::CIS::VapiStdErrorsUnauthorized
- VSphereAutomation::CIS::VapiStdErrorsUnauthorizedError
- VSphereAutomation::CIS::VapiStdErrorsUnsupported
- VSphereAutomation::CIS::VapiStdErrorsUnsupportedError
- VSphereAutomation::CIS::VapiStdLocalizableMessage