Public/Get-SDPOrgUser.ps1
|
function Get-SDPOrgUser { <# .SYNOPSIS Retrieves one or more org users from ServiceDesk Plus. .DESCRIPTION Use the Id parameter set to fetch a single org user by ID. Use the List parameter set (default) to retrieve a paged list, optionally sorted. .PARAMETER Id The ID of the org user 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 SortField Field name to sort by (e.g. 'name'). .PARAMETER SortOrder Sort direction: 'asc' or 'desc'. .PARAMETER All Automatically pages through all results and returns every org user. .EXAMPLE Get-SDPOrgUser -Id '12345' .EXAMPLE Get-SDPOrgUser -All #> [CmdletBinding(DefaultParameterSetName = 'List')] [OutputType('SDPOrgUser')] 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')] [string]$SortField, [Parameter(ParameterSetName = 'List')] [ValidateSet('asc', 'desc')] [string]$SortOrder, [Parameter(ParameterSetName = 'List')] [switch]$All ) process { if ($PSCmdlet.ParameterSetName -eq 'Id') { $response = Invoke-SDPRestMethod -Endpoint "orgusers/$Id" [SDPOrgUser]::new($response.orguser) return } $listInfo = @{ row_count = $PageSize } if ($SortField) { $listInfo['sort_field'] = $SortField } if ($SortOrder) { $listInfo['sort_order'] = $SortOrder } if ($All) { $index = $StartIndex do { $listInfo['start_index'] = $index $response = Invoke-SDPRestMethod -Endpoint 'orgusers' -InputData @{ list_info = $listInfo } foreach ($u in $response.orgusers) { [SDPOrgUser]::new($u) } $index += $PageSize } while ($response.list_info.has_more_rows) } else { $listInfo['start_index'] = $StartIndex $response = Invoke-SDPRestMethod -Endpoint 'orgusers' -InputData @{ list_info = $listInfo } foreach ($u in $response.orgusers) { [SDPOrgUser]::new($u) } } } } |