Engage Secure Supply Chain Analysis for OSS build (#2043)

This commit is contained in:
Tian L 2023-08-17 11:20:05 +08:00 committed by GitHub
commit 9107540a87
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 3 additions and 33 deletions

View file

@ -37,11 +37,9 @@ jobs:
- checkout: self - checkout: self
fetchDepth: 1 fetchDepth: 1
- ${{ if eq(variables['Build.Reason'], 'PullRequest') }}: - ${{ if eq(parameters.isOSSBuild, true) }}:
- powershell: | - task: nuget-security-analysis@0
$(Build.SourcesDirectory)\build\scripts\VerifyNugetConfig.ps1 -FilePath "$(Build.SourcesDirectory)\nuget.config" displayName: Secure Supply Chain Analysis
displayName: Verify nuget config
failOnStderr: true
- ${{ if eq(parameters.isReleaseBuild, true) }}: - ${{ if eq(parameters.isReleaseBuild, true) }}:
- task: UniversalPackages@0 - task: UniversalPackages@0

View file

@ -1,28 +0,0 @@
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License.
<#
.SYNOPSIS
Verify the specified nuget.config. Throw to fail the pipeline if the config is ill-formed.
.PARAMETER FilePath
The path pointing to the nuget.config file to be verified by this script.
.EXAMPLE
VerifyNugetConfig -FilePath .\nuget.config
#>
param([Parameter(Mandatory)][string]$FilePath)
$doc = [XML](Get-Content $FilePath)
$sources = (Select-Xml $doc -XPath "//configuration/packageSources").Node
$count = 0
foreach($src in $sources.ChildNodes){
if ($src.Name -eq "add"){
++$count
}
elseif ($src.Name -eq "clear"){
$count = 0
}
}
if ($count -gt 1){
throw "Adding multiple package sources is not allowed in nuget.config."
}