Get-ADOAreaPath.ps1
function Get-ADOAreaPath { <# .Synopsis Gets area paths .Description Get area paths from Azure DevOps .Example Get-ADOAreaPath -Organization StartAutomating -Project PSDevOps .Link https://docs.microsoft.com/en-us/rest/api/azure/devops/wit/Classification%20Nodes/Get%20Classification%20Nodes?view=azure-devops-rest-5.1#get-the-root-area-tree .Link Add-ADOAreaPath .Link Remove-ADOAreaPath #> [CmdletBinding(DefaultParameterSetName='/{Organization}/{Project}/_apis/wit/classificationnodes/Areas')] [OutputType('PSDevOps.AreaPath')] param( # The Organization [Parameter(Mandatory,ValueFromPipelineByPropertyName)] [Alias('Org')] [string] $Organization, # The project name or identifier. [Parameter(Mandatory,ValueFromPipelineByPropertyName)] [Alias('ProjectID')] [string] $Project, # The AreaPath [Parameter(ValueFromPipelineByPropertyName)] [string] $AreaPath, # The server. By default https://dev.azure.com/. # To use against TFS, provide the tfs server URL (e.g. http://tfsserver:8080/tfs). [Parameter(ValueFromPipelineByPropertyName)] [uri] $Server = "https://dev.azure.com/", # The api version. By default, 2.0. # If targeting TFS, this will need to change to match your server version. # See: https://docs.microsoft.com/en-us/azure/devops/integrate/concepts/rest-api-versioning?view=azure-devops [string] $ApiVersion = "2.0", # The depth of items to get. By default, one. [int] $Depth = 1 ) dynamicParam { . $GetInvokeParameters -DynamicParameter } begin { #region Copy Invoke-ADORestAPI parameters $invokeParams = . $getInvokeParameters $PSBoundParameters #endregion Copy Invoke-ADORestAPI parameters $expandAreaPaths = { param([Parameter(ValueFromPipeline)]$node) process { if ($node.structureType -ne 'area') { return } $node.pstypenames.clear() foreach ($typeName in "$organization.AreaPath", "$organization.$Project.AreaPath", "PSDevOps.AreaPath" ) { $node.pstypenames.Add($typeName) } $node | Add-Member NoteProperty Organization $organization -Force -PassThru | Add-Member NoteProperty Project $Project -Force -PassThru | Add-Member NoteProperty Server $Server -Force -PassThru if ($node.haschildren) { $node.children | & $MyInvocation.MyCommand.ScriptBlock } } } } process { $uri = # The URI is comprised of: @( "$server".TrimEnd('/') # the Server (minus any trailing slashes), (. $ReplaceRouteParameter $PSCmdlet.ParameterSetName) # and any parameterized URLs in this parameter set. if ($AreaPath) { $AreaPath } ) -as [string[]] -ne '' -join '/' $uri += '?' # The URI has a query string containing: $uri += @( if ($Server -ne 'https://dev.azure.com/' -and -not $PSBoundParameters.ApiVersion) { $ApiVersion = '2.0' } if ($ApiVersion) { # the api-version "api-version=$apiVersion" } if ($Depth) { '$depth=' + $depth } ) -join '&' Invoke-ADORestAPI -Uri $uri @invokeParams | & $expandAreaPaths } } |