Public/Pam/PamFolders/Get-DSPamFolders.ps1

function Get-DSPamFolders {
    <#
    .SYNOPSIS
     
    .DESCRIPTION
     
    .EXAMPLE
     
    .NOTES
     
    .LINK
    #>

    [CmdletBinding()]
    param(        
        [switch]$IncludeRoot
    )
        
    BEGIN {
        Write-Verbose '[Get-DSPamFolders] begin...'
    
        $URI = "$Script:DSBaseURI/api/pam/folders"

        if ([string]::IsNullOrWhiteSpace($Global:DSSessionToken)) {
            throw "Session does not seem authenticated, call New-DSSession."
        }
    }
    
    PROCESS {
        try {       
            $params = @{
                Uri            = $URI
                Method         = 'GET'
                LegacyResponse = $true
            }

            Write-Verbose "[Get-DSPamFolders] about to call with $params.Uri"

            [ServerResponse] $response = Invoke-DS @params

            #a "root" folder is returned that is more akin to a hidden placeholder for defaults.
            #we do need it for creating folders at the root though...
            if ($false -eq $IncludeRoot.IsPresent) {
                if ($null -ne $response.Body.data) {
                    if ($response.Body.data -is [system.array]) {
                        $root = $response.Body.data | Where-Object { $true -eq $_.isRoot }
                        #the @() ensures that its an array even if 0 or 1 results
                        $response.Body.data = @($response.Body.data | Where-Object { $_ -ne $root })
                    }
                }
            }

            if ($response.isSuccess) { 
                Write-Verbose "[Get-DSPamFolders] was successfull"
            }

            If ([System.Management.Automation.ActionPreference]::SilentlyContinue -ne $DebugPreference) {
                Write-Debug "[Response.Body] $($response.Body)"
            }

            return $response
        }
        catch {
            $exc = $_.Exception
            If ([System.Management.Automation.ActionPreference]::SilentlyContinue -ne $DebugPreference) {
                Write-Debug "[Exception] $exc"
            } 
        }
    }
    
    END {
        If ($response.isSuccess) {
            Write-Verbose '[Get-DSPamFolders] Completed Successfully.'
        }
        else {
            Write-Verbose '[Get-DSPamFolders] ended with errors...'
        }
    }
}