Merge pull request #331 from kmruddy/master
CISTag Module Improvements and Get-TriggeredAlarm Addition
This commit is contained in:
@@ -40,7 +40,7 @@ function Get-CISTag {
|
|||||||
} else {
|
} else {
|
||||||
$tagArray = @()
|
$tagArray = @()
|
||||||
$tagIdList = $tagSvc.list() | Select-Object -ExpandProperty Value
|
$tagIdList = $tagSvc.list() | Select-Object -ExpandProperty Value
|
||||||
[integer]$counter = 1
|
[int]$counter = 1
|
||||||
foreach ($t in $tagIdList) {
|
foreach ($t in $tagIdList) {
|
||||||
$tagArray += $tagSvc.get($t)
|
$tagArray += $tagSvc.get($t)
|
||||||
$counter++
|
$counter++
|
||||||
@@ -49,11 +49,11 @@ function Get-CISTag {
|
|||||||
}
|
}
|
||||||
if ($PSBoundParameters.ContainsKey("Name")) {
|
if ($PSBoundParameters.ContainsKey("Name")) {
|
||||||
if ($vCenterConn){
|
if ($vCenterConn){
|
||||||
$tagOutput = $vCTagList | where {$_.Name -eq $Name}
|
$tagOutput = $vCTagList | Where-Object {$_.Name -eq $Name}
|
||||||
} else {$tagOutput = $tagArray | Where {$_.Name -eq $Name}}
|
} else {$tagOutput = $tagArray | Where-Object {$_.Name -eq $Name}}
|
||||||
} elseif ($PSBoundParameters.ContainsKey("Category")) {
|
} elseif ($PSBoundParameters.ContainsKey("Category")) {
|
||||||
if ($vCenterConn){
|
if ($vCenterConn){
|
||||||
$tagOutput = $vCTagList | where {$_.Category -eq $Category}
|
$tagOutput = $vCTagList | Where-Object {$_.Category -eq $Category}
|
||||||
} else {
|
} else {
|
||||||
$tagCatid = Get-CISTagCategory -Name $Category | Select-Object -ExpandProperty Id
|
$tagCatid = Get-CISTagCategory -Name $Category | Select-Object -ExpandProperty Id
|
||||||
$tagIdList = $tagSvc.list_tags_for_category($tagCatid)
|
$tagIdList = $tagSvc.list_tags_for_category($tagCatid)
|
||||||
@@ -199,7 +199,7 @@ function Get-CISTagCategory {
|
|||||||
$tagCatArray += $tagCatSvc.get($tc)
|
$tagCatArray += $tagCatSvc.get($tc)
|
||||||
}
|
}
|
||||||
if ($PSBoundParameters.ContainsKey("Name")) {
|
if ($PSBoundParameters.ContainsKey("Name")) {
|
||||||
$tagCatOutput = $tagCatArray | Where {$_.Name -eq $Name}
|
$tagCatOutput = $tagCatArray | Where-Object {$_.Name -eq $Name}
|
||||||
} else {
|
} else {
|
||||||
$tagCatOutput = $tagCatArray
|
$tagCatOutput = $tagCatArray
|
||||||
}
|
}
|
||||||
@@ -336,8 +336,10 @@ function Get-CISTagAssignment {
|
|||||||
$tagAssocSvc = Get-CisService -Name com.vmware.cis.tagging.tag_association
|
$tagAssocSvc = Get-CisService -Name com.vmware.cis.tagging.tag_association
|
||||||
if ($PSBoundParameters.ContainsKey("ObjectId")) {
|
if ($PSBoundParameters.ContainsKey("ObjectId")) {
|
||||||
if ($ObjectId.split('-')[0] -eq 'vm') {
|
if ($ObjectId.split('-')[0] -eq 'vm') {
|
||||||
$objType = 'VirtualMachine'
|
$objType = "VirtualMachine"
|
||||||
} else {Write-Warning 'Only VirtualMachine types currently supported.'; break}
|
} elseif ($ObjectId.Split('-')[0] -eq 'datastore') {
|
||||||
|
$objType = 'Datastore'
|
||||||
|
} else {Write-Warning 'Only VirtualMachine and Datastore types currently supported.'; break}
|
||||||
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
||||||
$objObject.id = $ObjectId
|
$objObject.id = $ObjectId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -354,8 +356,15 @@ function Get-CISTagAssignment {
|
|||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
$dsSvc = Get-CisService com.vmware.vcenter.datastore
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -366,7 +375,7 @@ function Get-CISTagAssignment {
|
|||||||
$tagIdOutput = @()
|
$tagIdOutput = @()
|
||||||
$tagCategories = Get-CISTagCategory | Sort-Object -Property Name
|
$tagCategories = Get-CISTagCategory | Sort-Object -Property Name
|
||||||
if ($Category) {
|
if ($Category) {
|
||||||
$tagCatId = $tagCategories | where {$_.Name -eq $Category} | Select-Object -ExpandProperty Id
|
$tagCatId = $tagCategories | Where-Object {$_.Name -eq $Category} | Select-Object -ExpandProperty Id
|
||||||
$tagIdOutput += $tagSvc.list_tags_for_category($tagCatId)
|
$tagIdOutput += $tagSvc.list_tags_for_category($tagCatId)
|
||||||
} else {
|
} else {
|
||||||
foreach ($tagCat in $tagCategories) {
|
foreach ($tagCat in $tagCategories) {
|
||||||
@@ -380,9 +389,9 @@ function Get-CISTagAssignment {
|
|||||||
foreach ($tagId in $tagIdOutput) {
|
foreach ($tagId in $tagIdOutput) {
|
||||||
$tagAttObj = @()
|
$tagAttObj = @()
|
||||||
if ($Entity) {
|
if ($Entity) {
|
||||||
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId) | where {$_.type -eq $viObject.type -and $_.id -eq $viObject.Value}
|
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId) | Where-Object {$_.type -eq $viObject.type -and $_.id -eq $viObject.Value}
|
||||||
} else {
|
} else {
|
||||||
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId) | where {$_.id -eq $ObjectId}
|
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId) | Where-Object {$_.id -eq $ObjectId}
|
||||||
}
|
}
|
||||||
foreach ($obj in $tagAttObj) {
|
foreach ($obj in $tagAttObj) {
|
||||||
if ($obj.type -eq "VirtualMachine") {
|
if ($obj.type -eq "VirtualMachine") {
|
||||||
@@ -390,10 +399,14 @@ function Get-CISTagAssignment {
|
|||||||
$filterVmObj = $vmsvc.help.list.filter.create()
|
$filterVmObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmObj.vms.add($obj.Id) | Out-Null
|
$filterVmObj.vms.add($obj.Id) | Out-Null
|
||||||
$objName = $vmSvc.list($filterVmObj) | Select-Object -ExpandProperty Name
|
$objName = $vmSvc.list($filterVmObj) | Select-Object -ExpandProperty Name
|
||||||
}
|
} elseif ($obj.type -eq "Datastore") {
|
||||||
else {$objName = 'Object Not Found'}
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsObj = $dsSvc.help.list.filter.create()
|
||||||
|
$filterDsObj.datastores.add($obj.Id) | Out-Null
|
||||||
|
$objName = $dsSvc.list($filterDsObj) | Select-Object -ExpandProperty Name
|
||||||
|
} else {$objName = 'Object Not Found'}
|
||||||
$tempObject = "" | Select-Object Tag, Entity
|
$tempObject = "" | Select-Object Tag, Entity
|
||||||
$tempObject.Tag = $tagReference | where {$_.id -eq $tagId} | Select-Object -ExpandProperty Name
|
$tempObject.Tag = $tagReference | Where-Object {$_.id -eq $tagId} | Select-Object -ExpandProperty Name
|
||||||
$tempObject.Entity = $objName
|
$tempObject.Entity = $objName
|
||||||
$tagOutput += $tempObject
|
$tagOutput += $tempObject
|
||||||
}
|
}
|
||||||
@@ -404,8 +417,10 @@ function Get-CISTagAssignment {
|
|||||||
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId)
|
$tagAttObj += $tagAssocSvc.list_attached_objects($tagId)
|
||||||
if ($global:DefaultVIServer -and $global:DefaultVIServer.Name -eq $global:DefaultCisServers.Name) {
|
if ($global:DefaultVIServer -and $global:DefaultVIServer.Name -eq $global:DefaultCisServers.Name) {
|
||||||
[Boolean]$vCenterConn = $true
|
[Boolean]$vCenterConn = $true
|
||||||
} elseif ($tagAttObj.Type -contains 'VirtualMachine') {
|
} elseif ($tagAttObj.Type -contains "VirtualMachine") {
|
||||||
if (-Not $vmSvc) {$vmSvc = Get-CisService -Name com.vmware.vcenter.vm}
|
if (-Not $vmSvc) {$vmSvc = Get-CisService -Name com.vmware.vcenter.vm}
|
||||||
|
} elseif ($tagAttObj.Type -contains "Datastore") {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
}
|
}
|
||||||
foreach ($obj in $tagAttObj) {
|
foreach ($obj in $tagAttObj) {
|
||||||
if ($vCenterConn) {
|
if ($vCenterConn) {
|
||||||
@@ -417,9 +432,13 @@ function Get-CISTagAssignment {
|
|||||||
$filterVmObj = $vmsvc.help.list.filter.create()
|
$filterVmObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmObj.vms.add($obj.Id) | Out-Null
|
$filterVmObj.vms.add($obj.Id) | Out-Null
|
||||||
$objName = $vmSvc.list($filterVmObj) | Select-Object -ExpandProperty Name
|
$objName = $vmSvc.list($filterVmObj) | Select-Object -ExpandProperty Name
|
||||||
|
} elseif ($obj.type -eq "Datastore") {
|
||||||
|
$filterDsObj = $dsSvc.help.list.filter.create()
|
||||||
|
$filterDsObj.datastores.add($obj.Id) | Out-Null
|
||||||
|
$objName = $dsSvc.list($filterDsObj) | Select-Object -ExpandProperty Name
|
||||||
} else {$objName = 'Object Not Found'}
|
} else {$objName = 'Object Not Found'}
|
||||||
$tempObject = "" | Select-Object Tag, Entity
|
$tempObject = "" | Select-Object Tag, Entity
|
||||||
$tempObject.Tag = $tagReference | where {$_.id -eq $tagId} | Select-Object -ExpandProperty Name
|
$tempObject.Tag = $tagReference | Where-Object {$_.id -eq $tagId} | Select-Object -ExpandProperty Name
|
||||||
$tempObject.Entity = $objName
|
$tempObject.Entity = $objName
|
||||||
$tagOutput += $tempObject
|
$tagOutput += $tempObject
|
||||||
}
|
}
|
||||||
@@ -479,12 +498,19 @@ function New-CISTagAssignment {
|
|||||||
$objObject.id = $viObject.Value
|
$objObject.id = $viObject.Value
|
||||||
$objObject.type = $viObject.type
|
$objObject.type = $viObject.type
|
||||||
} else {
|
} else {
|
||||||
$vmSvc = Get-CisService -Name com.vmware.vcenter.vm
|
if (-Not $vmSvc) {$vmSvc = Get-CisService -Name com.vmware.vcenter.vm}
|
||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -500,12 +526,19 @@ function New-CISTagAssignment {
|
|||||||
$objObject.id = $viObject.Value
|
$objObject.id = $viObject.Value
|
||||||
$objObject.type = $viObject.type
|
$objObject.type = $viObject.type
|
||||||
} else {
|
} else {
|
||||||
$vmSvc = Get-CisService -Name com.vmware.vcenter.vm
|
if (-Not $vmSvc) {$vmSvc = Get-CisService -Name com.vmware.vcenter.vm}
|
||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsObj = $dsSvc.help.list.filter.create()
|
||||||
|
$filterDsObj.datastores.add($obj.Id) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsObj) | Select-Object -ExpandProperty Datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -521,12 +554,19 @@ function New-CISTagAssignment {
|
|||||||
$objObject.id = $viObject.Value
|
$objObject.id = $viObject.Value
|
||||||
$objObject.type = $viObject.type
|
$objObject.type = $viObject.type
|
||||||
} else {
|
} else {
|
||||||
$vmSvc = Get-CisService -Name com.vmware.vcenter.vm
|
if (-Not $vmSvc) {$vmSvc = Get-CisService -Name com.vmware.vcenter.vm}
|
||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
$objObject = $tagAssocSvc.help.list_attached_tags.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -535,8 +575,10 @@ function New-CISTagAssignment {
|
|||||||
}
|
}
|
||||||
} elseif ($PSBoundParameters.ContainsKey("TagId") -and $PSBoundParameters.ContainsKey("ObjectId")) {
|
} elseif ($PSBoundParameters.ContainsKey("TagId") -and $PSBoundParameters.ContainsKey("ObjectId")) {
|
||||||
if ($ObjectId.split('-')[0] -eq 'vm') {
|
if ($ObjectId.split('-')[0] -eq 'vm') {
|
||||||
$objType = 'VirtualMachine'
|
$objType = "VirtualMachine"
|
||||||
} else {Write-Warning 'Only VirtualMachine types currently supported.'; break}
|
} elseif ($ObjectId.Split('-')[0] -eq 'datastore') {
|
||||||
|
$objType = 'Datastore'
|
||||||
|
} else {Write-Warning 'Only VirtualMachine and Datastore types currently supported.'; break}
|
||||||
if ($TagId -is [array] -and $ObjectId -isnot [array]) {
|
if ($TagId -is [array] -and $ObjectId -isnot [array]) {
|
||||||
$objObject = $tagAssocSvc.help.attach_multiple_tags_to_object.object_id.create()
|
$objObject = $tagAssocSvc.help.attach_multiple_tags_to_object.object_id.create()
|
||||||
$objObject.id = $ObjectId
|
$objObject.id = $ObjectId
|
||||||
@@ -621,8 +663,15 @@ function Remove-CISTagAssignment {
|
|||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.detach_multiple_tags_from_object.object_id.create()
|
$objObject = $tagAssocSvc.help.detach_multiple_tags_from_object.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -642,8 +691,15 @@ function Remove-CISTagAssignment {
|
|||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.detach_tag_from_multiple_objects.object_ids.element.create()
|
$objObject = $tagAssocSvc.help.detach_tag_from_multiple_objects.object_ids.element.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -663,8 +719,15 @@ function Remove-CISTagAssignment {
|
|||||||
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
$filterVmNameObj = $vmsvc.help.list.filter.create()
|
||||||
$filterVmNameObj.names.add($Entity) | Out-Null
|
$filterVmNameObj.names.add($Entity) | Out-Null
|
||||||
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
$objId = $vmSvc.list($filterVmNameObj) | Select-Object -ExpandProperty vm
|
||||||
if ($objId) {$objType = 'VirtualMachine'}
|
if ($objId) {$objType = "VirtualMachine"}
|
||||||
else {Write-Warning "No entities found."; break}
|
else {
|
||||||
|
if (-Not $dsSvc) {$dsSvc = Get-CisService -Name com.vmware.vcenter.datastore}
|
||||||
|
$filterDsNameObj = $dsSvc.Help.list.filter.Create()
|
||||||
|
$filterDsNameObj.names.add($Entity) | Out-Null
|
||||||
|
$objId = $dsSvc.list($filterDsNameObj) | Select-Object -ExpandProperty datastore
|
||||||
|
if ($objId) {$objType = "Datastore"}
|
||||||
|
else {Write-Warning "No entities found."; break}
|
||||||
|
}
|
||||||
$objObject = $tagAssocSvc.help.detach.object_id.create()
|
$objObject = $tagAssocSvc.help.detach.object_id.create()
|
||||||
$objObject.id = $objId
|
$objObject.id = $objId
|
||||||
$objObject.type = $objType
|
$objObject.type = $objType
|
||||||
@@ -673,8 +736,10 @@ function Remove-CISTagAssignment {
|
|||||||
}
|
}
|
||||||
} elseif ($PSBoundParameters.ContainsKey("TagId") -and $PSBoundParameters.ContainsKey("ObjectId")) {
|
} elseif ($PSBoundParameters.ContainsKey("TagId") -and $PSBoundParameters.ContainsKey("ObjectId")) {
|
||||||
if ($ObjectId.split('-')[0] -eq 'vm') {
|
if ($ObjectId.split('-')[0] -eq 'vm') {
|
||||||
$objType = 'VirtualMachine'
|
$objType = "VirtualMachine"
|
||||||
} else {Write-Warning 'Only VirtualMachine types currently supported.'; break}
|
} elseif ($ObjectId.Split('-')[0] -eq 'datastore') {
|
||||||
|
$objType = 'Datastore'
|
||||||
|
}else {Write-Warning 'Only VirtualMachine types currently supported.'; break}
|
||||||
if ($TagId -is [array] -and $ObjectId -isnot [array]) {
|
if ($TagId -is [array] -and $ObjectId -isnot [array]) {
|
||||||
$objObject = $tagAssocSvc.help.detach_multiple_tags_from_object.object_id.create()
|
$objObject = $tagAssocSvc.help.detach_multiple_tags_from_object.object_id.create()
|
||||||
$objObject.id = $ObjectId
|
$objObject.id = $ObjectId
|
||||||
|
|||||||
62
Scripts/Get-TriggeredAlarm.ps1
Normal file
62
Scripts/Get-TriggeredAlarm.ps1
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
function Get-TriggeredAlarm {
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
This function lists the triggered alarms for the specified entity in vCenter
|
||||||
|
.DESCRIPTION
|
||||||
|
List the triggered alarms for the given object
|
||||||
|
.NOTES
|
||||||
|
Author: Kyle Ruddy, @kmruddy, kmruddy.com
|
||||||
|
.PARAMETER VM
|
||||||
|
Specifies the name of the VM
|
||||||
|
.PARAMETER VMHost
|
||||||
|
Specifies the name of the VMHost
|
||||||
|
.PARAMETER Datacenter
|
||||||
|
Specifies the name of the Datacenter
|
||||||
|
.PARAMETER Datastore
|
||||||
|
Specifies the name of the Datastore
|
||||||
|
.EXAMPLE
|
||||||
|
Get-TriggeredAlarm -VM VMname
|
||||||
|
|
||||||
|
Entity Alarm AlarmStatus AlarmMoRef EntityMoRef
|
||||||
|
---- ---- ---- ---- ----
|
||||||
|
VMname Name Yellow Alarm-MoRef Entity-MoRef
|
||||||
|
#>
|
||||||
|
|
||||||
|
[CmdletBinding()]
|
||||||
|
param(
|
||||||
|
[string]$VM,
|
||||||
|
[string]$VMHost,
|
||||||
|
[string]$Datacenter,
|
||||||
|
[string]$Datastore
|
||||||
|
)
|
||||||
|
BEGIN {
|
||||||
|
switch ($PSBoundParameters.Keys) {
|
||||||
|
'VM' {$entity = Get-VM -Name $vm -ErrorAction SilentlyContinue}
|
||||||
|
'VMHost' {$entity = Get-VMHost -Name $VMHost -ErrorAction SilentlyContinue}
|
||||||
|
'Datacenter' {$entity = Get-Datacenter -Name $Datacenter -ErrorAction SilentlyContinue}
|
||||||
|
'Datastore' {$entity = Get-Datastore -Name $Datastore -ErrorAction SilentlyContinue}
|
||||||
|
default {$entity = $null}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($null -eq $entity) {
|
||||||
|
Write-Warning "No vSphere object found."
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
PROCESS {
|
||||||
|
if ($entity.ExtensionData.TriggeredAlarmState -ne "") {
|
||||||
|
$alarmOutput = @()
|
||||||
|
foreach ($alarm in $entity.ExtensionData.TriggeredAlarmState) {
|
||||||
|
$tempObj = "" | Select-Object -Property Entity, Alarm, AlarmStatus, AlarmMoRef, EntityMoRef
|
||||||
|
$tempObj.Entity = Get-View $alarm.Entity | Select-Object -ExpandProperty Name
|
||||||
|
$tempObj.Alarm = Get-View $alarm.Alarm | Select-Object -ExpandProperty Info | Select-Object -ExpandProperty Name
|
||||||
|
$tempObj.AlarmStatus = $alarm.OverallStatus
|
||||||
|
$tempObj.AlarmMoRef = $alarm.Alarm
|
||||||
|
$tempObj.EntityMoRef = $alarm.Entity
|
||||||
|
$alarmOutput += $tempObj
|
||||||
|
}
|
||||||
|
$alarmOutput | Format-Table -AutoSize
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user