forked from StartAutomating/PSDevOps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Get-ADOTask.ps1
93 lines (83 loc) · 3.56 KB
/
Get-ADOTask.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
function Get-ADOTask
{
<#
.Synopsis
Gets Azure DevOps Tasks
.Description
Gets Tasks and Task Groups from Azure DevOps
.Example
Get-ADOTask -Organization StartAutomating
.Example
Get-ADOTask -Organization StartAutomating -YAMLSchema
.Link
Convert-ADOPipeline
#>
[CmdletBinding(DefaultParameterSetName='/{Organization}/_apis/distributedTask/Tasks')]
[OutputType('PSDevOps.Task')]
param(
# The organization
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[Alias('Org')]
[string]
$Organization,
# The project. Required to get task groups.
[Parameter(Mandatory,ValueFromPipelineByPropertyName,
ParameterSetName='/{Organization}/{Project}/_apis/distributedTask/taskGroups/')]
[string]
$Project,
# If set, will get task groups related to a project.
[Parameter(Mandatory,ValueFromPipelineByPropertyName,
ParameterSetName='/{Organization}/{Project}/_apis/distributedTask/taskGroups/')]
[Alias('TaskGroups','TG')]
[switch]
$TaskGroup,
# If set, will get the schema for YAML tasks within an organization.
[Parameter(Mandatory,ValueFromPipelineByPropertyName,
ParameterSetName='/{Organization}/_apis/distributedTask/yamlSchema')]
[Alias('Schema', 'YS')]
[switch]
$YAMLSchema,
# 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/"
)
dynamicParam { . $GetInvokeParameters -DynamicParameter }
begin {
#region Copy Invoke-ADORestAPI parameters
$invokeParams = . $getInvokeParameters $PSBoundParameters
#endregion Copy Invoke-ADORestAPI parameters
}
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.
) -as [string[]] -ne '' -join '/'
# We want to decorate our return value. Handily enough, both URIs contain a distinct name in the last URL segment.
$typename = @($psCmdlet.ParameterSetName -split '/')[-1].TrimEnd('s') # We just need to drop the 's'
$typeNames = @(
"$organization.$typename"
if ($Project) { "$organization.$Project.$typename" }
"PSDevOps.$typename"
)
$invokeResult = Invoke-ADORestAPI -Uri $uri @invokeParams
if ($invokeResult -is [string]) { # The /tasks endpoint returns malformed JSON.
$invokeResult = ($invokeResult -replace '""', '"_blank"') | # we have to fix it, by replacing blank strings with "_blank"
Microsoft.PowerShell.Utility\ConvertFrom-Json | # then we use the built-in ConvertFrom-JSON
Select-Object -ExpandProperty Value # and expand out the .Value property.
$invokeResult = foreach ($ir in $invokeResult) {
$ir.pstypenames.clear()
foreach ($tn in $typeNames) {
$ir.pstypenames.Add($tn)
}
$ir
}
}
$invokeResult | # Now that we've fixed the result
Add-Member NoteProperty Organization $Organization -Force -PassThru | # add on the .Organization property
Add-Member NoteProperty Server $Server -Force -PassThru # and the .Server property.
}
}