Public/Get-SDPSite.ps1
|
function Get-SDPSite { <# .SYNOPSIS Retrieves one or more sites from ServiceDesk Plus. .PARAMETER Id The ID of the site to retrieve. .PARAMETER PageSize Number of records per page (1–100). Defaults to 100. .PARAMETER StartIndex 1-based starting index for the page. Defaults to 1. .PARAMETER All Automatically pages through all results and returns every site. .EXAMPLE Get-SDPSite -Id '3' .EXAMPLE Get-SDPSite -All #> [CmdletBinding(DefaultParameterSetName = 'List')] [OutputType('SDPSite')] param( [Parameter(Mandatory, ParameterSetName = 'Id', ValueFromPipelineByPropertyName)] [string]$Id, [Parameter(ParameterSetName = 'List')] [ValidateRange(1, 100)] [int]$PageSize = 100, [Parameter(ParameterSetName = 'List')] [int]$StartIndex = 1, [Parameter(ParameterSetName = 'List')] [switch]$All ) process { if ($PSCmdlet.ParameterSetName -eq 'Id') { $response = Invoke-SDPRestMethod -Endpoint "sites/$Id" [SDPSite]::new($response.site) return } $listInfo = @{ row_count = $PageSize } if ($All) { $index = $StartIndex do { $listInfo['start_index'] = $index $response = Invoke-SDPRestMethod -Endpoint 'sites' -InputData @{ list_info = $listInfo } foreach ($s in $response.sites) { [SDPSite]::new($s) } $index += $PageSize } while ($response.list_info.has_more_rows) } else { $listInfo['start_index'] = $StartIndex $response = Invoke-SDPRestMethod -Endpoint 'sites' -InputData @{ list_info = $listInfo } foreach ($s in $response.sites) { [SDPSite]::new($s) } } } } |