forked from StartAutomating/PSDevOps
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathNew-ADOProject.ps1
121 lines (104 loc) · 4.25 KB
/
New-ADOProject.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
function New-ADOProject
{
<#
.Synopsis
Creates new projects in Azure DevOps.
.Description
Creates new projects in Azure DevOps or TFS.
.Link
https://docs.microsoft.com/en-us/rest/api/azure/devops/core/projects/list?view=azure-devops-rest-5.1
.Example
New-ADOProject -Organization StartAutomating -Project Formulaic -PersonalAccessToken $pat
#>
[CmdletBinding(SupportsShouldProcess=$true)]
param(
# The name of the project.
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[string]
$Name,
# The project description.
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[string]
$Description,
# The process template used by the project. By default, 'Agile'
[Parameter(ValueFromPipelineByPropertyName)]
[Alias('ProcessTemplate')]
[string]
$Process = 'Agile',
# If set, the project will be created as a public project.
# If not set, the project will be created as a private project.
[switch]
$Public,
# The project abbreviation
[string]
$Abbreviation,
# The Organization
[Parameter(Mandatory,ValueFromPipelineByPropertyName)]
[Alias('Org')]
[string]
$Organization,
# 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, 5.1.
# 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 = "5.1-preview")
dynamicParam { . $GetInvokeParameters -DynamicParameter }
begin {
#region Copy Invoke-ADORestAPI parameters
$invokeParams = . $getInvokeParameters $PSBoundParameters
#endregion Copy Invoke-ADORestAPI parameters
}
process {
if (-not ($Process -as [guid])) {
#region Get Work Processes
# Because the process was not a GUID, we have to call Get-ADOWorkProcess.
$getAdoWorkProcess = # To do this, first we get the commandmetadata for Invoke-ADORestAPI.
[Management.Automation.CommandMetaData]$ExecutionContext.SessionState.InvokeCommand.GetCommand('Get-ADOWorkProcess', 'Function')
$getWorkProcessParams = @{} + $PSBoundParameters # Then we copy our parameters
foreach ($k in @($getWorkProcessParams.Keys)) { # and walk thru each parameter name.
# If a parameter isn't found in Invoke-ADORestAPI
if (-not $getAdoWorkProcess.Parameters.ContainsKey($k)) {
$getWorkProcessParams.Remove($k) # we remove it.
}
}
$processExists = Get-ADOWorkProcess @getWorkProcessParams | Where-Object { $_.Name -eq $Process }
if (-not $processExists) {
Write-Error "No Work Process named $process exists in $Organization"
return
}
$process = $processExists.typeID
#region Get Work Processes
}
$uri = "$Server".TrimEnd('/'), $Organization, '_apis/projects?' -join '/'
if ($Server -ne 'https://dev.azure.com/' -and
-not $PSBoundParameters.ApiVersion) {
$ApiVersion = '2.0'
}
if ($ApiVersion) {
$uri += "api-version=$ApiVersion"
}
$body = @{
name = $Name
description = $Description
capabilities = @{
processTemplate = @{
templateTypeId = $process
}
versioncontrol = @{
sourceControlType = 'git'
}
}
visibility = if ($Public) { 'public' } else { 'private' }
} | ConvertTo-Json
if (-not $PSCmdlet.ShouldProcess("POST $uri $body")) { return }
Invoke-ADORestAPI @invokeParams -uri $uri -Method POST -Body $body -Property @{
Organization =$Organization
Server = $Server
}
}
}