| 12
 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
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 
 |  #!/usr/bin/env pwsh -c
<#
.DESCRIPTION
Creates a GitHub pull request for a given branch if it doesn't already exist
.PARAMETER RepoOwner
The GitHub repository owner to create the pull request against.
.PARAMETER RepoName
The GitHub repository name to create the pull request against.
.PARAMETER BaseBranch
The base or target branch we want the pull request to be against.
.PARAMETER PROwner
The owner of the branch we want to create a pull request for.
.PARAMETER PRBranch
The branch which we want to create a pull request for.
.PARAMETER AuthToken
A personal access token
.PARAMETER PRTitle
The title of the pull request.
.PARAMETER PRBody
The body message for the pull request. 
.PARAMETER PRLabels
The labels added to the PRs. Multple labels seperated by comma, e.g "bug, service"
.PARAMETER UserReviewers
User reviewers to request after opening the PR. Users should be a comma-
separated list with no preceding `@` symbol (e.g. "user1,usertwo,user3")
.PARAMETER TeamReviewers
List of github teams to add as reviewers
.PARAMETER Assignees
Users to assign to the PR after opening. Users should be a comma-separated list
with no preceding `@` symbol (e.g. "user1,usertwo,user3")
.PARAMETER CloseAfterOpenForTesting
Close the PR after opening to save on CI resources and prevent alerts to code
owners, assignees, requested reviewers, or others.
.PARAMETER OpenAsDraft
Opens the PR as a draft
#>
[CmdletBinding(SupportsShouldProcess = $true)]
param(
  [Parameter(Mandatory = $true)]
  [string]$RepoOwner,
  [Parameter(Mandatory = $true)]
  [string]$RepoName,
  [Parameter(Mandatory = $true)]
  [string]$BaseBranch,
  [Parameter(Mandatory = $true)]
  [string]$PROwner,
  [Parameter(Mandatory = $true)]
  [string]$PRBranch,
  [Parameter(Mandatory = $true)]
  [string]$AuthToken,
  [Parameter(Mandatory = $true)]
  [string]$PRTitle,
  [Parameter(Mandatory = $false)]
  [string]$PRBody = $PRTitle,
  [string]$PRLabels,
  [string]$UserReviewers,
  [string]$TeamReviewers,
  [string]$Assignees,
  [boolean]$CloseAfterOpenForTesting=$false,
  [boolean]$OpenAsDraft=$false,
  [boolean]$AddBuildSummary=($null -ne $env:SYSTEM_TEAMPROJECTID)
)
. (Join-Path $PSScriptRoot common.ps1)
try {
  $resp = Get-GitHubPullRequests -RepoOwner $RepoOwner -RepoName $RepoName `
  -Head "${PROwner}:${PRBranch}" -Base $BaseBranch -AuthToken $AuthToken
}
catch { 
  LogError "Get-GitHubPullRequests failed with exception:`n$_"
  exit 1
}
$resp | Write-Verbose
if ($resp.Count -gt 0) {
  $existingPr = $resp[0]
  $existingUrl = $existingPr.html_url
  $existingNumber = $existingPr.number
  $existingTitle = $existingPr.title
  LogDebug "Pull request already exists $existingUrl"
  # setting variable to reference the pull request by number
  Write-Host "##vso[task.setvariable variable=Submitted.PullRequest.Number]$existingNumber"
  if ($AddBuildSummary) {
    $summaryPath = New-TemporaryFile
    $summaryMarkdown = "**PR:** [Azure/$RepoName#$existingNumber]($existingUrl)"
    $summaryMarkdown += "`n**Title:** $existingTitle"
    $summaryMarkdown | Out-File $summaryPath
    Write-Host "##vso[task.addattachment type=Distributedtask.Core.Summary;name=Existing Pull Request;]$summaryPath"
  }
}
else {
  try {
    $resp = New-GitHubPullRequest `
      -RepoOwner $RepoOwner `
      -RepoName $RepoName `
      -Title $PRTitle `
      -Head "${PROwner}:${PRBranch}" `
      -Base $BaseBranch `
      -Body $PRBody `
      -Maintainer_Can_Modify $true `
      -Draft:$OpenAsDraft `
      -AuthToken $AuthToken
    $resp | Write-Verbose
    $prNumber = $resp.number
    $prUrl = $resp.html_url
    LogDebug "Pull request created $prUrl"
  
    $prOwnerUser = $resp.user.login
    # setting variable to reference the pull request by number
    Write-Host "##vso[task.setvariable variable=Submitted.PullRequest.Number]$prNumber"
    # ensure that the user that was used to create the PR is not attempted to add as a reviewer
    # we cast to an array to ensure that length-1 arrays actually stay as array values
    # we also filter out dependabot user who doesn't have write permission to avoid errors
    $cleanedUsers = @(SplitParameterArray -members $UserReviewers) | ? { $_ -ne $prOwnerUser -and $null -ne $_ -and $_ -inotlike "dependabot*" }
    $cleanedTeamReviewers = @(SplitParameterArray -members $TeamReviewers) | ? { $_ -ne $prOwnerUser -and $null -ne $_ }
    if ($cleanedUsers -or $cleanedTeamReviewers) {
      Add-GitHubPullRequestReviewers -RepoOwner $RepoOwner -RepoName $RepoName -PrNumber $prNumber `
      -Users $cleanedUsers -Teams $cleanedTeamReviewers -AuthToken $AuthToken
    }
    if ($CloseAfterOpenForTesting) {
      $prState = "closed"
      LogDebug "Updating $prUrl state to closed because this was only testing."
    }
    else {
      $prState = "open"
    }
    # Clean assignees - remove null entries and bot accounts
    $cleanedAssignees = @(SplitParameterArray -members $Assignees) | ? { 
      $null -ne $_ -and $_ -inotlike "dependabot*" -and $_ -inotlike "copilot*" 
    }
    Update-GitHubIssue -RepoOwner $RepoOwner -RepoName $RepoName -IssueNumber $prNumber `
    -State $prState -Labels $PRLabels -Assignees $cleanedAssignees -AuthToken $AuthToken
    if ($AddBuildSummary) {
      $summaryPath = New-TemporaryFile
      $summaryMarkdown = "**PR:** [Azure/$RepoName#$prNumber]($prUrl)"
      $summaryMarkdown += "`n**Title:** $PRTitle"
      $summaryMarkdown | Out-File $summaryPath
      Write-Host "##vso[task.addattachment type=Distributedtask.Core.Summary;name=Pull Request Created;]$summaryPath"
    }
  }
  catch {
    LogError "Call to GitHub API failed with exception:`n$_"
    exit 1
  }
}
 |