From a80146c382739b55830db4507e7c7dbe48103105 Mon Sep 17 00:00:00 2001 From: "kumaran.pec@gmail.com" Date: Wed, 29 Jan 2020 23:03:43 +1100 Subject: [PATCH] Issue 576 - Update to make use of addition API query parameters and get all security tags by retrieving all pages --- module/PowerNSX.psm1 | 79 ++++++++++++++++++++++++++++++++++---------- 1 file changed, 62 insertions(+), 17 deletions(-) diff --git a/module/PowerNSX.psm1 b/module/PowerNSX.psm1 index 0ec43a51..dd4791d8 100644 --- a/module/PowerNSX.psm1 +++ b/module/PowerNSX.psm1 @@ -25098,7 +25098,6 @@ function New-NsxSecurityTag { } function Get-NsxSecurityTag { - <# .SYNOPSIS Retrieves an NSX Security Tag @@ -25112,40 +25111,40 @@ function Get-NsxSecurityTag { .EXAMPLE Get-NSXSecurityTag - Gets all Security Tags .EXAMPLE Get-NSXSecurityTag -name ST-Web-DMZ - Gets a specific Security Tag by name #> param ( + [Parameter (Mandatory=$false)] + #Get Security Tag by name + [ValidateNotNullOrEmpty()] + [string]$Name, - [Parameter (Mandatory=$false, Position=1)] - #Get Security Tag by name - [ValidateNotNullOrEmpty()] - [string]$Name, [Parameter (Mandatory=$false)] - #Get security tag by objectId - [string]$objectId, + #Get security tag by objectId + [string]$objectId, [Parameter (Mandatory=$false)] - #Include system security tags - [switch]$IncludeSystem=$false, - [Parameter (Mandatory=$False)] - #PowerNSX Connection object - [ValidateNotNullOrEmpty()] - [PSCustomObject]$Connection=$defaultNSXConnection + #Include system security tags + [switch]$IncludeSystem=$false, + + [Parameter (Mandatory=$False)] + #PowerNSX Connection object + [ValidateNotNullOrEmpty()] + [PSCustomObject]$Connection=$defaultNSXConnection ) +<# process { - if ( -not $PsBoundParameters.ContainsKey('objectId')) { #either all or by name $URI = "/api/2.0/services/securitytags/tag" [System.Xml.XmlDocument]$response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + if ( (Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTags/securityTag')) { if ( $PsBoundParameters.ContainsKey('Name')) { $tags = $response.securitytags.securitytag | where-object { $_.name -eq $name } @@ -25162,10 +25161,10 @@ function Get-NsxSecurityTag { } } else { - #Just getting a single Security group by object id $URI = "/api/2.0/services/securitytags/tag/$objectId" $response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + if ( (Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTag')) { $tags = $response.securitytag } @@ -25178,7 +25177,53 @@ function Get-NsxSecurityTag { } } } +#> + +process { + if ($PsBoundParameters.ContainsKey('Name')) { + $URI = "/api/2.0/services/securitytags/tag?filterBy=name&filterValue=$($name)" + $response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + + if ((Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTags/securityTag')) { + $tags = $response.securitytags.securitytag + } + } + elseif ($PsBoundParameters.ContainsKey('objectId')) { + $URI = "/api/2.0/services/securitytags/tag?filterBy=objectId&filterValue=$($objectId)" + $response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + + if ((Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTags/securityTag')) { + $tags = $response.securitytags.securitytag + } + } + else { + $startIndex = 0 + + $URI = "/api/2.0/services/securitytags/tag" + [System.Xml.XmlDocument]$response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + if ((Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTags/securityTag')) { + $totalCount = $response.securitytags.pagingInfo.totalCount + + while ($startIndex -le $totalCount) { + $URI = "/api/2.0/services/securitytags/tag?startIndex=$($startIndex)" + $response = invoke-nsxrestmethod -method "get" -uri $URI -connection $connection + $tags += $response.securitytags.securitytag + + $startIndex += 1024 + } + } + } + + if ( -not $IncludeSystem ) { + if ((Invoke-XPathQuery -QueryMethod SelectSingleNode -Node $response -Query 'descendant::securityTags/securityTag')) { + $tags | where-object { ( $_.systemResource -ne 'true') } + } + } + else { + $tags + } + } end {} }