GitHubProjectCards.ps1
# Copyright (c) Microsoft Corporation. All rights reserved. # Licensed under the MIT License. @{ GitHubProjectCardTypeName = 'GitHub.ProjectCard' }.GetEnumerator() | ForEach-Object { Set-Variable -Scope Script -Option ReadOnly -Name $_.Key -Value $_.Value } filter Get-GitHubProjectCard { <# .DESCRIPTION Get the cards for a given GitHub Project Column. The Git repo for this module can be found here: http://aka.ms/PowerShellForGitHub .PARAMETER Column ID of the column to retrieve cards for. .PARAMETER State Only cards with this State are returned. Options are all, archived, or NotArchived (default). .PARAMETER AccessToken If provided, this will be used as the AccessToken for authentication with the REST Api. Otherwise, will attempt to use the configured value or will run unauthenticated. .INPUTS GitHub.ProjectCard GitHub.ProjectColumn .OUTPUTS GitHub.ProjectCard .EXAMPLE Get-GitHubProjectCard -Column 999999 Get the the not_archived cards for column 999999. .EXAMPLE Get-GitHubProjectCard -Column 999999 -State All Gets all the cards for column 999999, no matter the State. .EXAMPLE Get-GitHubProjectCard -Column 999999 -State Archived Gets the archived cards for column 999999. .EXAMPLE Get-GitHubProjectCard -Card 999999 Gets the card with ID 999999. #> [CmdletBinding(DefaultParameterSetName = 'Card')] [OutputType({$script:GitHubProjectCardTypeName})] param( [Parameter( Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'Column')] [Alias('ColumnId')] [int64] $Column, [Parameter( Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'Card')] [Alias('CardId')] [int64] $Card, [ValidateSet('All', 'Archived', 'NotArchived')] [Alias('ArchivedState')] [string] $State = 'NotArchived', [string] $AccessToken ) Write-InvocationLog $telemetryProperties = @{} $uriFragment = [String]::Empty $description = [String]::Empty if ($PSCmdlet.ParameterSetName -eq 'Column') { $telemetryProperties['Column'] = $true $uriFragment = "/projects/columns/$Column/cards" $description = "Getting cards for column $Column" } elseif ($PSCmdlet.ParameterSetName -eq 'Card') { $telemetryProperties['Card'] = $true $uriFragment = "/projects/columns/cards/$Card" $description = "Getting project card $Card" } if ($PSBoundParameters.ContainsKey('State')) { $getParams = @() $Archived = $State.ToLower().Replace('notarchived','not_archived') $getParams += "archived_state=$Archived" $uriFragment = "$uriFragment`?" + ($getParams -join '&') $description += " with State '$Archived'" } $params = @{ 'UriFragment' = $uriFragment 'Description' = $description 'AccessToken' = $AccessToken 'TelemetryEventName' = $MyInvocation.MyCommand.Name 'TelemetryProperties' = $telemetryProperties 'AcceptHeader' = $script:inertiaAcceptHeader } return (Invoke-GHRestMethodMultipleResult @params | Add-GitHubProjectCardAdditionalProperties) } filter New-GitHubProjectCard { <# .DESCRIPTION Creates a new card for a GitHub project. The Git repo for this module can be found here: http://aka.ms/PowerShellForGitHub .PARAMETER Column ID of the column to create a card for. .PARAMETER Note The name of the column to create. .PARAMETER IssueId The ID of the issue you want to associate with this card (not to be confused with the Issue _number_ which you see in the URL and can refer to with a hashtag). .PARAMETER PullRequestId The ID of the pull request you want to associate with this card (not to be confused with the Pull Request _number_ which you see in the URL and can refer to with a hashtag). .PARAMETER AccessToken If provided, this will be used as the AccessToken for authentication with the REST Api. Otherwise, will attempt to use the configured value or will run unauthenticated. .INPUTS GitHub.IssueComment GitHub.Issue GitHub.PullRequest GitHub.ProjectCard GitHub.ProjectColumn .OUTPUTS GitHub.ProjectCard .EXAMPLE New-GitHubProjectCard -Column 999999 -Note 'Note on card' Creates a card on column 999999 with the note 'Note on card'. .EXAMPLE New-GitHubProjectCard -Column 999999 -IssueId 888888 Creates a card on column 999999 for the issue with ID 888888. .EXAMPLE New-GitHubProjectCard -Column 999999 -PullRequestId 888888 Creates a card on column 999999 for the pull request with ID 888888. #> [CmdletBinding( SupportsShouldProcess, DefaultParameterSetName = 'Note')] [OutputType({$script:GitHubProjectCardTypeName})] param( [Parameter( Mandatory, ValueFromPipelineByPropertyName)] [Alias('ColumnId')] [int64] $Column, [Parameter( Mandatory, ParameterSetName = 'Note')] [Alias('Content')] [string] $Note, [Parameter( Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'Issue')] [int64] $IssueId, [Parameter( Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'PullRequest')] [int64] $PullRequestId, [string] $AccessToken ) Write-InvocationLog $telemetryProperties = @{} $uriFragment = "/projects/columns/$Column/cards" $apiDescription = "Creating project card" if ($PSCmdlet.ParameterSetName -eq 'Note') { $telemetryProperties['Note'] = $true $hashBody = @{ 'note' = $Note } } elseif ($PSCmdlet.ParameterSetName -in ('Issue', 'PullRequest')) { $contentType = $PSCmdlet.ParameterSetName $telemetryProperties['ContentType'] = $contentType $hashBody = @{ 'content_type' = $contentType } if ($PSCmdlet.ParameterSetName -eq 'Issue') { $hashBody['content_id'] = $IssueId } else { $hashBody['content_id'] = $PullRequestId } } if (-not $PSCmdlet.ShouldProcess($Column, 'Create GitHub Project Card')) { return } $params = @{ 'UriFragment' = $uriFragment 'Body' = (ConvertTo-Json -InputObject $hashBody) 'Method' = 'Post' 'Description' = $apiDescription 'AccessToken' = $AccessToken 'TelemetryEventName' = $MyInvocation.MyCommand.Name 'TelemetryProperties' = $telemetryProperties 'AcceptHeader' = $script:inertiaAcceptHeader } return (Invoke-GHRestMethod @params | Add-GitHubProjectCardAdditionalProperties) } filter Set-GitHubProjectCard { <# .DESCRIPTION Modify a GitHub Project Card. The Git repo for this module can be found here: http://aka.ms/PowerShellForGitHub .PARAMETER Card ID of the card to modify. .PARAMETER Note The note content for the card. Only valid for cards without another type of content, so this cannot be specified if the card already has a content_id and content_type. .PARAMETER Archive Archive a project card. .PARAMETER Restore Restore a project card. .PARAMETER PassThru Returns the updated Project Card. By default, this cmdlet does not generate any output. You can use "Set-GitHubConfiguration -DefaultPassThru" to control the default behavior of this switch. .PARAMETER AccessToken If provided, this will be used as the AccessToken for authentication with the REST Api. Otherwise, will attempt to use the configured value or will run unauthenticated. .INPUTS GitHub.ProjectCard .OUTPUTS GitHub.ProjectCard .EXAMPLE Set-GitHubProjectCard -Card 999999 -Note UpdatedNote Sets the card note to 'UpdatedNote' for the card with ID 999999. .EXAMPLE Set-GitHubProjectCard -Card 999999 -Archive Archives the card with ID 999999. .EXAMPLE Set-GitHubProjectCard -Card 999999 -Restore Restores the card with ID 999999. #> [CmdletBinding( SupportsShouldProcess, DefaultParameterSetName = 'Note')] [OutputType({$script:GitHubProjectCardTypeName})] param( [Parameter( Mandatory, ValueFromPipelineByPropertyName)] [Alias('CardId')] [int64] $Card, [Alias('Content')] [string] $Note, [Parameter(ParameterSetName = 'Archive')] [switch] $Archive, [Parameter(ParameterSetName = 'Restore')] [switch] $Restore, [switch] $PassThru, [string] $AccessToken ) Write-InvocationLog $telemetryProperties = @{} $uriFragment = "/projects/columns/cards/$Card" $apiDescription = "Updating card $Card" $hashBody = @{} if ($PSBoundParameters.ContainsKey('Note')) { $telemetryProperties['Note'] = $true $hashBody.add('note', $Note) } if ($Archive) { $telemetryProperties['Archive'] = $true $hashBody.add('archived', $true) } if ($Restore) { $telemetryProperties['Restore'] = $true $hashBody.add('archived', $false) } if (-not $PSCmdlet.ShouldProcess($Card, 'Set GitHub Project Card')) { return } $params = @{ 'UriFragment' = $uriFragment 'Description' = $apiDescription 'Body' = (ConvertTo-Json -InputObject $hashBody) 'AccessToken' = $AccessToken 'Method' = 'Patch' 'TelemetryEventName' = $MyInvocation.MyCommand.Name 'TelemetryProperties' = $telemetryProperties 'AcceptHeader' = $script:inertiaAcceptHeader } $result = (Invoke-GHRestMethod @params | Add-GitHubProjectCardAdditionalProperties) if (Resolve-ParameterWithDefaultConfigurationValue -Name PassThru -ConfigValueName DefaultPassThru) { return $result } } filter Remove-GitHubProjectCard { <# .DESCRIPTION Removes a project card. The Git repo for this module can be found here: http://aka.ms/PowerShellForGitHub .PARAMETER Card ID of the card to remove. .PARAMETER Force If this switch is specified, you will not be prompted for confirmation of command execution. .PARAMETER AccessToken If provided, this will be used as the AccessToken for authentication with the REST Api. Otherwise, will attempt to use the configured value or will run unauthenticated. .INPUTS GitHub.ProjectCard .EXAMPLE Remove-GitHubProjectCard -Card 999999 Remove project card with ID 999999. .EXAMPLE Remove-GitHubProjectCard -Card 999999 -Confirm:$False Remove project card with ID 999999 without prompting for confirmation. .EXAMPLE Remove-GitHubProjectCard -Card 999999 -Force Remove project card with ID 999999 without prompting for confirmation. #> [CmdletBinding( SupportsShouldProcess, ConfirmImpact = 'High')] [Alias('Delete-GitHubProjectCard')] param( [Parameter( Mandatory, ValueFromPipelineByPropertyName)] [Alias('CardId')] [int64] $Card, [switch] $Force, [string] $AccessToken ) Write-InvocationLog $telemetryProperties = @{} $uriFragment = "/projects/columns/cards/$Card" $description = "Deleting card $Card" if ($Force -and (-not $Confirm)) { $ConfirmPreference = 'None' } if (-not $PSCmdlet.ShouldProcess($Card, 'Remove GitHub Project Card')) { return } $params = @{ 'UriFragment' = $uriFragment 'Description' = $description 'AccessToken' = $AccessToken 'Method' = 'Delete' 'TelemetryEventName' = $MyInvocation.MyCommand.Name 'TelemetryProperties' = $telemetryProperties 'AcceptHeader' = $script:inertiaAcceptHeader } return Invoke-GHRestMethod @params } filter Move-GitHubProjectCard { <# .DESCRIPTION Move a GitHub Project Card. The Git repo for this module can be found here: http://aka.ms/PowerShellForGitHub .PARAMETER Card ID of the card to move. .PARAMETER Top Moves the card to the top of the column. .PARAMETER Bottom Moves the card to the bottom of the column. .PARAMETER After Moves the card to the position after the card ID specified. .PARAMETER Column The ID of a column in the same project to move the card to. .PARAMETER AccessToken If provided, this will be used as the AccessToken for authentication with the REST Api. Otherwise, will attempt to use the configured value or will run unauthenticated. .INPUTS GitHub.ProjectCard GitHub.ProjectColumn .EXAMPLE Move-GitHubProjectCard -Card 999999 -Top Moves the project card with ID 999999 to the top of the column. .EXAMPLE Move-GitHubProjectCard -Card 999999 -Bottom Moves the project card with ID 999999 to the bottom of the column. .EXAMPLE Move-GitHubProjectCard -Card 999999 -After 888888 Moves the project card with ID 999999 to the position after the card ID 888888. Within the same column. .EXAMPLE Move-GitHubProjectCard -Card 999999 -After 888888 -Column 123456 Moves the project card with ID 999999 to the position after the card ID 888888, in the column with ID 123456. #> [CmdletBinding(SupportsShouldProcess)] param( [Parameter( Mandatory, ValueFromPipelineByPropertyName)] [Alias('CardId')] [int64] $Card, [switch] $Top, [switch] $Bottom, [int64] $After, [Parameter(ValueFromPipelineByPropertyName)] [Alias('ColumnId')] [int64] $Column, [string] $AccessToken ) Write-InvocationLog $telemetryProperties = @{} $uriFragment = "/projects/columns/cards/$Card/moves" $apiDescription = "Updating card $Card" if (-not ($Top -xor $Bottom -xor ($After -gt 0))) { $message = 'You must use one (and only one) of the parameters Top, Bottom or After.' Write-Log -Message $message -level Error throw $message } elseif ($Top) { $position = 'top' } elseif ($Bottom) { $position = 'bottom' } else { $position = "after:$After" } $hashBody = @{ 'position' = $Position } if ($PSBoundParameters.ContainsKey('Column')) { $telemetryProperties['Column'] = $true $hashBody.add('column_id', $Column) } if (-not $PSCmdlet.ShouldProcess($Card, 'Move GitHub Project Card')) { return } $params = @{ 'UriFragment' = $uriFragment 'Description' = $apiDescription 'Body' = (ConvertTo-Json -InputObject $hashBody) 'AccessToken' = $AccessToken 'Method' = 'Post' 'TelemetryEventName' = $MyInvocation.MyCommand.Name 'TelemetryProperties' = $telemetryProperties 'AcceptHeader' = $script:inertiaAcceptHeader } return Invoke-GHRestMethod @params } filter Add-GitHubProjectCardAdditionalProperties { <# .SYNOPSIS Adds type name and additional properties to ease pipelining to GitHub Project Card objects. .PARAMETER InputObject The GitHub object to add additional properties to. .PARAMETER TypeName The type that should be assigned to the object. .INPUTS [PSCustomObject] .OUTPUTS GitHub.ProjectCard #> [CmdletBinding()] [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSUseSingularNouns", "", Justification="Internal helper that is definitely adding more than one property.")] param( [Parameter( Mandatory, ValueFromPipeline)] [AllowNull()] [AllowEmptyCollection()] [PSCustomObject[]] $InputObject, [ValidateNotNullOrEmpty()] [string] $TypeName = $script:GitHubProjectCardTypeName ) foreach ($item in $InputObject) { $item.PSObject.TypeNames.Insert(0, $TypeName) if (-not (Get-GitHubConfiguration -Name DisablePipelineSupport)) { Add-Member -InputObject $item -Name 'CardId' -Value $item.id -MemberType NoteProperty -Force if ($item.project_url -match '^.*/projects/(\d+)$') { $projectId = $Matches[1] Add-Member -InputObject $item -Name 'ProjectId' -Value $projectId -MemberType NoteProperty -Force } if ($item.column_url -match '^.*/columns/(\d+)$') { $columnId = $Matches[1] Add-Member -InputObject $item -Name 'ColumnId' -Value $columnId -MemberType NoteProperty -Force } if ($null -ne $item.content_url) { $elements = Split-GitHubUri -Uri $item.content_url $repositoryUrl = Join-GitHubUri @elements Add-Member -InputObject $item -Name 'RepositoryUrl' -Value $repositoryUrl -MemberType NoteProperty -Force if ($item.content_url -match '^.*/issues/(\d+)$') { $issueNumber = $Matches[1] Add-Member -InputObject $item -Name 'IssueNumber' -Value $issueNumber -MemberType NoteProperty -Force } elseif ($item.content_url -match '^.*/pull/(\d+)$') { $pullRequestNumber = $Matches[1] Add-Member -InputObject $item -Name 'PullRequestNumber' -Value $pullRequestNumber -MemberType NoteProperty -Force } } if ($null -ne $item.creator) { $null = Add-GitHubUserAdditionalProperties -InputObject $item.creator } } Write-Output $item } } # SIG # Begin signature block # MIIjkQYJKoZIhvcNAQcCoIIjgjCCI34CAQExDzANBglghkgBZQMEAgEFADB5Bgor # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG # KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCDiSbZCu7mOwkzH # cuYKCvZBW3xzK1JjJwkH5BD9+UjSeaCCDYEwggX/MIID56ADAgECAhMzAAABh3IX # chVZQMcJAAAAAAGHMA0GCSqGSIb3DQEBCwUAMH4xCzAJBgNVBAYTAlVTMRMwEQYD # VQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNy # b3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMTH01pY3Jvc29mdCBDb2RlIFNpZ25p # bmcgUENBIDIwMTEwHhcNMjAwMzA0MTgzOTQ3WhcNMjEwMzAzMTgzOTQ3WjB0MQsw # CQYDVQQGEwJVUzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9u # ZDEeMBwGA1UEChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMR4wHAYDVQQDExVNaWNy # b3NvZnQgQ29ycG9yYXRpb24wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB # AQDOt8kLc7P3T7MKIhouYHewMFmnq8Ayu7FOhZCQabVwBp2VS4WyB2Qe4TQBT8aB # znANDEPjHKNdPT8Xz5cNali6XHefS8i/WXtF0vSsP8NEv6mBHuA2p1fw2wB/F0dH # sJ3GfZ5c0sPJjklsiYqPw59xJ54kM91IOgiO2OUzjNAljPibjCWfH7UzQ1TPHc4d # weils8GEIrbBRb7IWwiObL12jWT4Yh71NQgvJ9Fn6+UhD9x2uk3dLj84vwt1NuFQ # itKJxIV0fVsRNR3abQVOLqpDugbr0SzNL6o8xzOHL5OXiGGwg6ekiXA1/2XXY7yV # Fc39tledDtZjSjNbex1zzwSXAgMBAAGjggF+MIIBejAfBgNVHSUEGDAWBgorBgEE # AYI3TAgBBggrBgEFBQcDAzAdBgNVHQ4EFgQUhov4ZyO96axkJdMjpzu2zVXOJcsw # UAYDVR0RBEkwR6RFMEMxKTAnBgNVBAsTIE1pY3Jvc29mdCBPcGVyYXRpb25zIFB1 # ZXJ0byBSaWNvMRYwFAYDVQQFEw0yMzAwMTIrNDU4Mzg1MB8GA1UdIwQYMBaAFEhu # ZOVQBdOCqhc3NyK1bajKdQKVMFQGA1UdHwRNMEswSaBHoEWGQ2h0dHA6Ly93d3cu # bWljcm9zb2Z0LmNvbS9wa2lvcHMvY3JsL01pY0NvZFNpZ1BDQTIwMTFfMjAxMS0w # Ny0wOC5jcmwwYQYIKwYBBQUHAQEEVTBTMFEGCCsGAQUFBzAChkVodHRwOi8vd3d3 # Lm1pY3Jvc29mdC5jb20vcGtpb3BzL2NlcnRzL01pY0NvZFNpZ1BDQTIwMTFfMjAx # MS0wNy0wOC5jcnQwDAYDVR0TAQH/BAIwADANBgkqhkiG9w0BAQsFAAOCAgEAixmy # S6E6vprWD9KFNIB9G5zyMuIjZAOuUJ1EK/Vlg6Fb3ZHXjjUwATKIcXbFuFC6Wr4K # NrU4DY/sBVqmab5AC/je3bpUpjtxpEyqUqtPc30wEg/rO9vmKmqKoLPT37svc2NV # BmGNl+85qO4fV/w7Cx7J0Bbqk19KcRNdjt6eKoTnTPHBHlVHQIHZpMxacbFOAkJr # qAVkYZdz7ikNXTxV+GRb36tC4ByMNxE2DF7vFdvaiZP0CVZ5ByJ2gAhXMdK9+usx # zVk913qKde1OAuWdv+rndqkAIm8fUlRnr4saSCg7cIbUwCCf116wUJ7EuJDg0vHe # yhnCeHnBbyH3RZkHEi2ofmfgnFISJZDdMAeVZGVOh20Jp50XBzqokpPzeZ6zc1/g # yILNyiVgE+RPkjnUQshd1f1PMgn3tns2Cz7bJiVUaqEO3n9qRFgy5JuLae6UweGf # AeOo3dgLZxikKzYs3hDMaEtJq8IP71cX7QXe6lnMmXU/Hdfz2p897Zd+kU+vZvKI # 3cwLfuVQgK2RZ2z+Kc3K3dRPz2rXycK5XCuRZmvGab/WbrZiC7wJQapgBodltMI5 # GMdFrBg9IeF7/rP4EqVQXeKtevTlZXjpuNhhjuR+2DMt/dWufjXpiW91bo3aH6Ea # jOALXmoxgltCp1K7hrS6gmsvj94cLRf50QQ4U8Qwggd6MIIFYqADAgECAgphDpDS # AAAAAAADMA0GCSqGSIb3DQEBCwUAMIGIMQswCQYDVQQGEwJVUzETMBEGA1UECBMK # V2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UEChMVTWljcm9zb2Z0 # IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3NvZnQgUm9vdCBDZXJ0aWZpY2F0 # ZSBBdXRob3JpdHkgMjAxMTAeFw0xMTA3MDgyMDU5MDlaFw0yNjA3MDgyMTA5MDla # MH4xCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdS # ZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xKDAmBgNVBAMT # H01pY3Jvc29mdCBDb2RlIFNpZ25pbmcgUENBIDIwMTEwggIiMA0GCSqGSIb3DQEB # AQUAA4ICDwAwggIKAoICAQCr8PpyEBwurdhuqoIQTTS68rZYIZ9CGypr6VpQqrgG # OBoESbp/wwwe3TdrxhLYC/A4wpkGsMg51QEUMULTiQ15ZId+lGAkbK+eSZzpaF7S # 35tTsgosw6/ZqSuuegmv15ZZymAaBelmdugyUiYSL+erCFDPs0S3XdjELgN1q2jz # y23zOlyhFvRGuuA4ZKxuZDV4pqBjDy3TQJP4494HDdVceaVJKecNvqATd76UPe/7 # 4ytaEB9NViiienLgEjq3SV7Y7e1DkYPZe7J7hhvZPrGMXeiJT4Qa8qEvWeSQOy2u # M1jFtz7+MtOzAz2xsq+SOH7SnYAs9U5WkSE1JcM5bmR/U7qcD60ZI4TL9LoDho33 # X/DQUr+MlIe8wCF0JV8YKLbMJyg4JZg5SjbPfLGSrhwjp6lm7GEfauEoSZ1fiOIl # XdMhSz5SxLVXPyQD8NF6Wy/VI+NwXQ9RRnez+ADhvKwCgl/bwBWzvRvUVUvnOaEP # 6SNJvBi4RHxF5MHDcnrgcuck379GmcXvwhxX24ON7E1JMKerjt/sW5+v/N2wZuLB # l4F77dbtS+dJKacTKKanfWeA5opieF+yL4TXV5xcv3coKPHtbcMojyyPQDdPweGF # RInECUzF1KVDL3SV9274eCBYLBNdYJWaPk8zhNqwiBfenk70lrC8RqBsmNLg1oiM # CwIDAQABo4IB7TCCAekwEAYJKwYBBAGCNxUBBAMCAQAwHQYDVR0OBBYEFEhuZOVQ # BdOCqhc3NyK1bajKdQKVMBkGCSsGAQQBgjcUAgQMHgoAUwB1AGIAQwBBMAsGA1Ud # DwQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFHItOgIxkEO5FAVO # 4eqnxzHRI4k0MFoGA1UdHwRTMFEwT6BNoEuGSWh0dHA6Ly9jcmwubWljcm9zb2Z0 # LmNvbS9wa2kvY3JsL3Byb2R1Y3RzL01pY1Jvb0NlckF1dDIwMTFfMjAxMV8wM18y # Mi5jcmwwXgYIKwYBBQUHAQEEUjBQME4GCCsGAQUFBzAChkJodHRwOi8vd3d3Lm1p # Y3Jvc29mdC5jb20vcGtpL2NlcnRzL01pY1Jvb0NlckF1dDIwMTFfMjAxMV8wM18y # Mi5jcnQwgZ8GA1UdIASBlzCBlDCBkQYJKwYBBAGCNy4DMIGDMD8GCCsGAQUFBwIB # FjNodHRwOi8vd3d3Lm1pY3Jvc29mdC5jb20vcGtpb3BzL2RvY3MvcHJpbWFyeWNw # cy5odG0wQAYIKwYBBQUHAgIwNB4yIB0ATABlAGcAYQBsAF8AcABvAGwAaQBjAHkA # XwBzAHQAYQB0AGUAbQBlAG4AdAAuIB0wDQYJKoZIhvcNAQELBQADggIBAGfyhqWY # 4FR5Gi7T2HRnIpsLlhHhY5KZQpZ90nkMkMFlXy4sPvjDctFtg/6+P+gKyju/R6mj # 82nbY78iNaWXXWWEkH2LRlBV2AySfNIaSxzzPEKLUtCw/WvjPgcuKZvmPRul1LUd # d5Q54ulkyUQ9eHoj8xN9ppB0g430yyYCRirCihC7pKkFDJvtaPpoLpWgKj8qa1hJ # Yx8JaW5amJbkg/TAj/NGK978O9C9Ne9uJa7lryft0N3zDq+ZKJeYTQ49C/IIidYf # wzIY4vDFLc5bnrRJOQrGCsLGra7lstnbFYhRRVg4MnEnGn+x9Cf43iw6IGmYslmJ # aG5vp7d0w0AFBqYBKig+gj8TTWYLwLNN9eGPfxxvFX1Fp3blQCplo8NdUmKGwx1j # NpeG39rz+PIWoZon4c2ll9DuXWNB41sHnIc+BncG0QaxdR8UvmFhtfDcxhsEvt9B # xw4o7t5lL+yX9qFcltgA1qFGvVnzl6UJS0gQmYAf0AApxbGbpT9Fdx41xtKiop96 # eiL6SJUfq/tHI4D1nvi/a7dLl+LrdXga7Oo3mXkYS//WsyNodeav+vyL6wuA6mk7 # r/ww7QRMjt/fdW1jkT3RnVZOT7+AVyKheBEyIXrvQQqxP/uozKRdwaGIm1dxVk5I # RcBCyZt2WwqASGv9eZ/BvW1taslScxMNelDNMYIVZjCCFWICAQEwgZUwfjELMAkG # A1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQx # HjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEoMCYGA1UEAxMfTWljcm9z # b2Z0IENvZGUgU2lnbmluZyBQQ0EgMjAxMQITMwAAAYdyF3IVWUDHCQAAAAABhzAN # BglghkgBZQMEAgEFAKCBrjAZBgkqhkiG9w0BCQMxDAYKKwYBBAGCNwIBBDAcBgor # BgEEAYI3AgELMQ4wDAYKKwYBBAGCNwIBFTAvBgkqhkiG9w0BCQQxIgQgdI4SCxqp # SXS0dtsGPZ6fF9IZO9Z9I0NnMflof6kKRRQwQgYKKwYBBAGCNwIBDDE0MDKgFIAS # AE0AaQBjAHIAbwBzAG8AZgB0oRqAGGh0dHA6Ly93d3cubWljcm9zb2Z0LmNvbTAN # BgkqhkiG9w0BAQEFAASCAQBJ7Nj6PuPC8gpcJaoXx9KWMYUIUjqXYizzn/HewdN+ # epQOGe70ITpXBBFlecLZClkEr1AAsrgr9Q8FcBFwR7xn4Cb0VWtlxZOPr97zRUJD # Yo8v+uWJ4A7FJfNWkTKtUUTxuIM+gv1dA4XVDBfPVrrlZY+n+UpVNbJ947D6mWhS # SgMCk/L+SLC2jWLAIhNLX7pLBPLSykPpJi66ygk2Ivi4yN6/0am5UCDyk07dcf9d # nF1ffiq5x0qlgyJgqNqRfukW7kziVQuozAFZoDkv1NUhX01bdruuMgjM7Kt1rr8Q # Ed/rVELW6n7klxx7tyblG5ix7g4ioeY2Y8WfTGTEIYe/oYIS8DCCEuwGCisGAQQB # gjcDAwExghLcMIIS2AYJKoZIhvcNAQcCoIISyTCCEsUCAQMxDzANBglghkgBZQME # AgEFADCCAVQGCyqGSIb3DQEJEAEEoIIBQwSCAT8wggE7AgEBBgorBgEEAYRZCgMB # MDEwDQYJYIZIAWUDBAIBBQAEIDpPi4GXZbryK0ubgzYDcC1Mcue0iujXhFr5dm1M # SwAKAgZfFvwPYloYEjIwMjAwODE4MDMxNDI5LjkxWjAEgAIB9KCB1KSB0TCBzjEL # MAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1v # bmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEpMCcGA1UECxMgTWlj # cm9zb2Z0IE9wZXJhdGlvbnMgUHVlcnRvIFJpY28xJjAkBgNVBAsTHVRoYWxlcyBU # U1MgRVNOOjc4ODAtRTM5MC04MDE0MSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1T # dGFtcCBTZXJ2aWNloIIORDCCBPUwggPdoAMCAQICEzMAAAEooA6B4TbVT8IAAAAA # ASgwDQYJKoZIhvcNAQELBQAwfDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hp # bmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jw # b3JhdGlvbjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUtU3RhbXAgUENBIDIwMTAw # HhcNMTkxMjE5MDExNTAwWhcNMjEwMzE3MDExNTAwWjCBzjELMAkGA1UEBhMCVVMx # EzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoT # FU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEpMCcGA1UECxMgTWljcm9zb2Z0IE9wZXJh # dGlvbnMgUHVlcnRvIFJpY28xJjAkBgNVBAsTHVRoYWxlcyBUU1MgRVNOOjc4ODAt # RTM5MC04MDE0MSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1TdGFtcCBTZXJ2aWNl # MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnZGx1vdU24Y+zb8OClz2 # C3vssbQk+QPhVZOUQkuSrOdMmX5Ghl+I7A3qJZ8+7iT+SPyfBjum8uzU6wHLj3jK # 6yDiscvAc1Qk+3DVNzngw4uB1yiwDg3GSLvd8PKpbAO2M52TofuQ1zME+oAMPoH3 # yi3vv/BIAIEkjGb2oBS52q5Ll9zMIXT75pZRq8O7jpTdy/ocSMh1XZl0lNQqDhZQ # h1NgxBcjTzb6pKzjlYFmNwr3z+0h/Hy6ryrySxYX37NSMZMWIxooeGftxIKgSPsT # W1WZbTwhKlLrvxYU/b4DQ5DBpZwko0AIr4n4trsvPZsa6kKJ04bPlcN7BzWUP2cs # 9wIDAQABo4IBGzCCARcwHQYDVR0OBBYEFITi8oPxfrU3m9QBw050f1AEy6byMB8G # A1UdIwQYMBaAFNVjOlyKMZDzQ3t8RhvFM2hahW1VMFYGA1UdHwRPME0wS6BJoEeG # RWh0dHA6Ly9jcmwubWljcm9zb2Z0LmNvbS9wa2kvY3JsL3Byb2R1Y3RzL01pY1Rp # bVN0YVBDQV8yMDEwLTA3LTAxLmNybDBaBggrBgEFBQcBAQROMEwwSgYIKwYBBQUH # MAKGPmh0dHA6Ly93d3cubWljcm9zb2Z0LmNvbS9wa2kvY2VydHMvTWljVGltU3Rh # UENBXzIwMTAtMDctMDEuY3J0MAwGA1UdEwEB/wQCMAAwEwYDVR0lBAwwCgYIKwYB # BQUHAwgwDQYJKoZIhvcNAQELBQADggEBAItfZkcYhQuAOT+JxwdZTLCMPICwEeWG # Sa2YGniWV3Avd02jRtdlkeJJkH5zYrO8+pjrgGUQKNL8+q6vab1RpPU3QF5SjBEd # BPzzB3N33iBiopeYsNtVHzJ5WAGRw/8mJVZtd1DNzPURMeBauH67MDwHBSABocnD # 6ddhxwi4OA8kzVRN42X1Hk69/7rNHYTlkjgOsiq9LiMfhCygw9OfbsCM3tVm3hqa # hHEwsRxABLu89PUlRRpEWkUeaRRhWWfVgyzD///r3rxpG/LdyYKVLji7GSRogtuG # HWHT16NmMeGsSf6T0xxWRaK5jvbiMn/nu3KUzsD+PMhY2PUXxWWGTLIwggZxMIIE # WaADAgECAgphCYEqAAAAAAACMA0GCSqGSIb3DQEBCwUAMIGIMQswCQYDVQQGEwJV # UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE # ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMTIwMAYDVQQDEylNaWNyb3NvZnQgUm9v # dCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgMjAxMDAeFw0xMDA3MDEyMTM2NTVaFw0y # NTA3MDEyMTQ2NTVaMHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9u # MRAwDgYDVQQHEwdSZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRp # b24xJjAkBgNVBAMTHU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwMIIBIjAN # BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAqR0NvHcRijog7PwTl/X6f2mUa3RU # ENWlCgCChfvtfGhLLF/Fw+Vhwna3PmYrW/AVUycEMR9BGxqVHc4JE458YTBZsTBE # D/FgiIRUQwzXTbg4CLNC3ZOs1nMwVyaCo0UN0Or1R4HNvyRgMlhgRvJYR4YyhB50 # YWeRX4FUsc+TTJLBxKZd0WETbijGGvmGgLvfYfxGwScdJGcSchohiq9LZIlQYrFd # /XcfPfBXday9ikJNQFHRD5wGPmd/9WbAA5ZEfu/QS/1u5ZrKsajyeioKMfDaTgaR # togINeh4HLDpmc085y9Euqf03GS9pAHBIAmTeM38vMDJRF1eFpwBBU8iTQIDAQAB # o4IB5jCCAeIwEAYJKwYBBAGCNxUBBAMCAQAwHQYDVR0OBBYEFNVjOlyKMZDzQ3t8 # RhvFM2hahW1VMBkGCSsGAQQBgjcUAgQMHgoAUwB1AGIAQwBBMAsGA1UdDwQEAwIB # hjAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNX2VsuP6KJcYmjRPZSQW9fO # mhjEMFYGA1UdHwRPME0wS6BJoEeGRWh0dHA6Ly9jcmwubWljcm9zb2Z0LmNvbS9w # a2kvY3JsL3Byb2R1Y3RzL01pY1Jvb0NlckF1dF8yMDEwLTA2LTIzLmNybDBaBggr # BgEFBQcBAQROMEwwSgYIKwYBBQUHMAKGPmh0dHA6Ly93d3cubWljcm9zb2Z0LmNv # bS9wa2kvY2VydHMvTWljUm9vQ2VyQXV0XzIwMTAtMDYtMjMuY3J0MIGgBgNVHSAB # Af8EgZUwgZIwgY8GCSsGAQQBgjcuAzCBgTA9BggrBgEFBQcCARYxaHR0cDovL3d3 # dy5taWNyb3NvZnQuY29tL1BLSS9kb2NzL0NQUy9kZWZhdWx0Lmh0bTBABggrBgEF # BQcCAjA0HjIgHQBMAGUAZwBhAGwAXwBQAG8AbABpAGMAeQBfAFMAdABhAHQAZQBt # AGUAbgB0AC4gHTANBgkqhkiG9w0BAQsFAAOCAgEAB+aIUQ3ixuCYP4FxAz2do6Eh # b7Prpsz1Mb7PBeKp/vpXbRkws8LFZslq3/Xn8Hi9x6ieJeP5vO1rVFcIK1GCRBL7 # uVOMzPRgEop2zEBAQZvcXBf/XPleFzWYJFZLdO9CEMivv3/Gf/I3fVo/HPKZeUqR # UgCvOA8X9S95gWXZqbVr5MfO9sp6AG9LMEQkIjzP7QOllo9ZKby2/QThcJ8ySif9 # Va8v/rbljjO7Yl+a21dA6fHOmWaQjP9qYn/dxUoLkSbiOewZSnFjnXshbcOco6I8 # +n99lmqQeKZt0uGc+R38ONiU9MalCpaGpL2eGq4EQoO4tYCbIjggtSXlZOz39L9+ # Y1klD3ouOVd2onGqBooPiRa6YacRy5rYDkeagMXQzafQ732D8OE7cQnfXXSYIghh # 2rBQHm+98eEA3+cxB6STOvdlR3jo+KhIq/fecn5ha293qYHLpwmsObvsxsvYgrRy # zR30uIUBHoD7G4kqVDmyW9rIDVWZeodzOwjmmC3qjeAzLhIp9cAvVCch98isTtoo # uLGp25ayp0Kiyc8ZQU3ghvkqmqMRZjDTu3QyS99je/WZii8bxyGvWbWu3EQ8l1Bx # 16HSxVXjad5XwdHeMMD9zOZN+w2/XU/pnR4ZOC+8z1gFLu8NoFA12u8JJxzVs341 # Hgi62jbb01+P3nSISRKhggLSMIICOwIBATCB/KGB1KSB0TCBzjELMAkGA1UEBhMC # VVMxEzARBgNVBAgTCldhc2hpbmd0b24xEDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNV # BAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlvbjEpMCcGA1UECxMgTWljcm9zb2Z0IE9w # ZXJhdGlvbnMgUHVlcnRvIFJpY28xJjAkBgNVBAsTHVRoYWxlcyBUU1MgRVNOOjc4 # ODAtRTM5MC04MDE0MSUwIwYDVQQDExxNaWNyb3NvZnQgVGltZS1TdGFtcCBTZXJ2 # aWNloiMKAQEwBwYFKw4DAhoDFQAxPUsb8oASPReyIv2fubGZfVp9m6CBgzCBgKR+ # MHwxCzAJBgNVBAYTAlVTMRMwEQYDVQQIEwpXYXNoaW5ndG9uMRAwDgYDVQQHEwdS # ZWRtb25kMR4wHAYDVQQKExVNaWNyb3NvZnQgQ29ycG9yYXRpb24xJjAkBgNVBAMT # HU1pY3Jvc29mdCBUaW1lLVN0YW1wIFBDQSAyMDEwMA0GCSqGSIb3DQEBBQUAAgUA # 4uW6xjAiGA8yMDIwMDgxODA2MjYxNFoYDzIwMjAwODE5MDYyNjE0WjB3MD0GCisG # AQQBhFkKBAExLzAtMAoCBQDi5brGAgEAMAoCAQACAhDUAgH/MAcCAQACAhIuMAoC # BQDi5wxGAgEAMDYGCisGAQQBhFkKBAIxKDAmMAwGCisGAQQBhFkKAwKgCjAIAgEA # AgMHoSChCjAIAgEAAgMBhqAwDQYJKoZIhvcNAQEFBQADgYEAdFMI75+AHLvf0dg+ # C2KeEFaXPtHGs0+gmTz1pLcZ7M6eRZv4TCJspnC9e6prOV+9Zs7IG+YKJH3UZtOA # pwpNiyiIjiIg5b7Rz73+1fArjU6F/9bA1W/tvQcacHcXwTD1sST+LUfbpqh6L9Qa # 06I8yI2ybOcJhlWLt8POX1Zk5MExggMNMIIDCQIBATCBkzB8MQswCQYDVQQGEwJV # UzETMBEGA1UECBMKV2FzaGluZ3RvbjEQMA4GA1UEBxMHUmVkbW9uZDEeMBwGA1UE # ChMVTWljcm9zb2Z0IENvcnBvcmF0aW9uMSYwJAYDVQQDEx1NaWNyb3NvZnQgVGlt # ZS1TdGFtcCBQQ0EgMjAxMAITMwAAASigDoHhNtVPwgAAAAABKDANBglghkgBZQME # AgEFAKCCAUowGgYJKoZIhvcNAQkDMQ0GCyqGSIb3DQEJEAEEMC8GCSqGSIb3DQEJ # BDEiBCAEUHcba18Anvf57uyNrdJ1jrTnxvYxEUHadKXS5X1SOjCB+gYLKoZIhvcN # AQkQAi8xgeowgecwgeQwgb0EILxFaouvBVJ379wbEN8GpLhvW09eGg8WsLrXm9XW # 6BTaMIGYMIGApH4wfDELMAkGA1UEBhMCVVMxEzARBgNVBAgTCldhc2hpbmd0b24x # EDAOBgNVBAcTB1JlZG1vbmQxHjAcBgNVBAoTFU1pY3Jvc29mdCBDb3Jwb3JhdGlv # bjEmMCQGA1UEAxMdTWljcm9zb2Z0IFRpbWUtU3RhbXAgUENBIDIwMTACEzMAAAEo # oA6B4TbVT8IAAAAAASgwIgQgx31FxgLqvin+syYIRIlqe3LghchpZDZ0wCi0UQrn # Ln4wDQYJKoZIhvcNAQELBQAEggEAXLs2vHBRz8EIfzrl3iA+tomuniZ7BmdPqt1z # ruh11MKa8EwsyHwYyaeyGpnMBhJV/40CT1zhReO3eIPDmWteCPDrztKMVoUc+R41 # Z77HJtAkMUyV2OuR3E3vj+BG1cR/tfPQSSbRRoRj6VOgSDbUSSUJ8R80TfYCt+c/ # PaoWzuBgpNPZUAQQkNDXiXueNRLplTbHuoR/Z2Ui33A4sbQfiavJl5ca/DypWZ3g # MLIxO+zdChCK+hdGMZHggdRm/DJSNwR5wEKZ+r3qLw9oaTSkr5WYhlOg9v3qUbg1 # LonIqhG2nE/P0h4ORGVBOTBVIaNRpkRduQxCvVFReRez9O+BqQ== # SIG # End signature block |