[Windows] Add checksum verification for GitHub CLI (#8360)

This commit is contained in:
Erik Bershel
2023-09-26 13:08:31 +02:00
committed by GitHub
parent 9eabbcd8d0
commit a1206f1a5c

View File

@@ -1,15 +1,25 @@
################################################################################ ################################################################################
## File: Install-GitHub-CLI.ps1 ## File: Install-GitHub-CLI.ps1
## Desc: Install GitHub CLI ## Desc: Install GitHub CLI
## Supply chain security: GitHub CLI - checksum validation
################################################################################ ################################################################################
Write-Host "Get the latest gh version..." Write-Host "Get the latest gh version..."
$Name = "gh_windows_amd64.msi" $repoUrl = "https://api.github.com/repos/cli/cli/releases/latest"
$Assets = (Invoke-RestMethod -Uri "https://api.github.com/repos/cli/cli/releases/latest").assets $installerFile = "gh_windows_amd64.msi"
$DownloadUrl = ($Assets.browser_download_url -match "windows_amd64.msi") | Select-Object -First 1 $assets = (Invoke-RestMethod -Uri $repoUrl).assets
$downloadUrl = ($assets.browser_download_url -match "windows_amd64.msi") | Select-Object -First 1
$packagePath = Start-DownloadWithRetry -Url $downloadUrl -Name $installerFile
Install-Binary -Url $DownloadUrl -Name $Name #region Supply chain security - GitHub CLI
$fileHash = (Get-FileHash -Path $packagePath -Algorithm SHA256).Hash
$hashUrl = ($assets.browser_download_url -match "checksums.txt") | Select-Object -First 1
$externalHash = (Invoke-RestMethod -Uri $hashURL).ToString().Split("`n").Where({ $_ -ilike "*windows_amd64.msi*" }).Split(' ')[0]
Use-ChecksumComparison $fileHash $externalHash
#endregion
Install-Binary -FilePath $packagePath
Add-MachinePathItem "C:\Program Files (x86)\GitHub CLI" Add-MachinePathItem "C:\Program Files (x86)\GitHub CLI"