forked from StartAutomating/PSDevOps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathUpdate-ADOBuild.ps1
126 lines (108 loc) · 4.32 KB
/
Update-ADOBuild.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
function Update-ADOBuild
{
<#
.Synopsis
Updates builds and build definitions
.Description
Updates builds and build definitions in Azure DevOps.
.Link
https://docs.microsoft.com/en-us/rest/api/azure/devops/build/builds/update%20build?view=azure-devops-rest-5.1
.Link
https://docs.microsoft.com/en-us/rest/api/azure/devops/build/definitions/update?view=azure-devops-rest-5.1
.Example
Update-ADOBuild -Organization MyOrg -Project MyProject -BuildID 1 -Build @{KeepForever=$true}
#>
[CmdletBinding(DefaultParameterSetName='build/builds/{buildId}',SupportsShouldProcess)]
[OutputType('PSDevOps.Build','PSDevOps.Build.Definition')]
param(
# The Organization
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[Alias('Org')]
[string]
$Organization,
# The Project
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[string]
$Project,
# The server. By default https://dev.azure.com/.
[Parameter(ValueFromPipelineByPropertyName)]
[uri]
$Server = "https://dev.azure.com/",
# The api version. By default, 5.1.
[string]
$ApiVersion = "5.1",
# The Build ID
[Parameter(Mandatory,ParameterSetName='build/builds/{buildId}',ValueFromPipelineByPropertyName)]
[string]
$BuildID,
# The updated build information. This only needs to contain the changed information.
[Parameter(Mandatory,ParameterSetName='build/builds/{buildId}',ValueFromPipelineByPropertyName)]
[PSObject]
$Build,
# The Build Definition ID
[Parameter(Mandatory,ParameterSetName='build/definitions/{definitionId}',ValueFromPipelineByPropertyName)]
[string]
$DefinitionID,
# The new build definition. This needs to contain the entire definition.
[Parameter(Mandatory,ParameterSetName='build/definitions/{definitionId}',ValueFromPipeline)]
[PSObject]
$Definition)
dynamicParam { . $GetInvokeParameters -DynamicParameter }
begin {
#region Copy Invoke-ADORestAPI parameters
$invokeParams = . $getInvokeParameters $PSBoundParameters
#endregion Copy Invoke-ADORestAPI parameters
}
process {
$invokeParams.Uri = # First construct the URI. It's made up of:
"$(@(
"$server".TrimEnd('/') # * The Server
$Organization # * The Organization
$Project # * The Project
'_apis' #* '_apis'
. $ReplaceRouteParameter $PSCmdlet.ParameterSetName #* and the replaced route parameters.
) -join '/')?$( # Followed by a query string, containing
@(
if ($Server -ne 'https://dev.azure.com/' -and
-not $PSBoundParameters.ApiVersion) {
$ApiVersion = '2.0'
}
if ($ApiVersion) { # an api-version (if one exists)
"api-version=$ApiVersion"
}
) -join '&'
)"
$subtypename = @($pscmdlet.ParameterSetName -replace '/{\w+}', '' -split '/')[-1].TrimEnd('s')
$subtypeName =
if ($subtypename -eq 'Build') {
''
} else {
'.' + $subtypename.Substring(0,1).ToUpper() + $subtypename.Substring(1)
}
$invokeParams.PSTypeName = @( # Prepare a list of typenames so we can customize formatting:
"$Organization.$Project.Build$subTypeName" # * $Organization.$Project.Build
"$Organization.Build$subTypeName" # * $Organization.Build
"StartAutomating.PSDevOps.Build$subTypeName" # * PSDevOps.Build
)
$additionalProperty = @{
Organization = $Organization
Project = $Project
Server = $Server
}
$invokeParams.Property = $additionalProperty
if ($psCmdlet.ParameterSetName -eq 'build/builds/{buildId}') {
$invokeParams.Method = 'PATCH'
$invokeParams.Body = $Build
} else {
$invokeParams.Method = 'PUT'
$invokeParams.Body = $Definition
}
if ($WhatIfPreference) {
$invokeParams.Remove('PersonalAccessToken')
return $invokeParams
}
if ($PSCmdlet.ShouldProcess("$($invokeParams.Method) $($invokeParams.Uri)")) {
Invoke-ADORestAPI @invokeParams
}
}
}