fix(install.ps1): pin PortableGit instead of hitting rate-limited GitHub API (#28943)
The Windows installer fetched the latest git-for-windows release via api.github.com/repos/git-for-windows/git/releases/latest, which is rate-limited to 60 requests/hour/IP for unauthenticated callers. Users behind CGNAT, corporate NAT, dorm WiFi, or shared ISP routinely hit the limit, and the installer aborts asking them to install Git manually. Switch to a pinned release tag (v2.54.0.windows.1) and a static github.com/.../releases/download/<tag>/<asset> URL. Static download URLs are served by GitHub's blob storage and are not subject to the API rate limit. Trade-offs: - We have to bump the pin when we want a newer Git for Windows. The installer doesn't depend on Git features beyond 'works', so this is a once-a-year maintenance cost at most. - Loses the (cosmetic) MB size display, since we no longer have asset metadata. Replaced with the version string in the 'Downloading ...' line instead.
This commit is contained in:
@@ -538,33 +538,35 @@ function Install-Git {
|
|||||||
"32-bit-mingit"
|
"32-bit-mingit"
|
||||||
}
|
}
|
||||||
|
|
||||||
$releaseApi = "https://api.github.com/repos/git-for-windows/git/releases/latest"
|
# Pinned git-for-windows release. We deliberately do NOT hit
|
||||||
$release = Invoke-RestMethod -Uri $releaseApi -UseBasicParsing -Headers @{ "User-Agent" = "hermes-installer" }
|
# api.github.com/repos/.../releases/latest here: that endpoint
|
||||||
|
# is rate-limited to 60 requests/hour/IP for unauthenticated
|
||||||
|
# callers, and users behind CGNAT / corporate NAT / dorm WiFi
|
||||||
|
# routinely hit the limit, breaking the installer.
|
||||||
|
# Static github.com/.../releases/download/<tag>/<asset> URLs
|
||||||
|
# are not subject to the API rate limit.
|
||||||
|
$gitTag = "v2.54.0.windows.1"
|
||||||
|
$gitVer = "2.54.0"
|
||||||
|
$gitVerTag = "$gitVer.windows.1"
|
||||||
|
|
||||||
if ($arch -eq "32-bit-mingit") {
|
if ($arch -eq "32-bit-mingit") {
|
||||||
Write-Warn "32-bit Windows detected -- PortableGit is 64-bit only. Installing MinGit 32-bit as a last resort; bash-dependent Hermes features (terminal tool, agent-browser) will not work on this machine."
|
Write-Warn "32-bit Windows detected -- PortableGit is 64-bit only. Installing MinGit 32-bit as a last resort; bash-dependent Hermes features (terminal tool, agent-browser) will not work on this machine."
|
||||||
$assetPattern = "MinGit-*-32-bit.zip"
|
$assetName = "MinGit-$gitVer-32-bit.zip"
|
||||||
$downloadIsZip = $true
|
$downloadIsZip = $true
|
||||||
} elseif ($arch -eq "arm64") {
|
} elseif ($arch -eq "arm64") {
|
||||||
$assetPattern = "PortableGit-*-arm64.7z.exe"
|
$assetName = "PortableGit-$gitVer-arm64.7z.exe"
|
||||||
$downloadIsZip = $false
|
$downloadIsZip = $false
|
||||||
} else {
|
} else {
|
||||||
$assetPattern = "PortableGit-*-64-bit.7z.exe"
|
$assetName = "PortableGit-$gitVer-64-bit.7z.exe"
|
||||||
$downloadIsZip = $false
|
$downloadIsZip = $false
|
||||||
}
|
}
|
||||||
|
|
||||||
$asset = $release.assets | Where-Object { $_.name -like $assetPattern } | Select-Object -First 1
|
$downloadUrl = "https://github.com/git-for-windows/git/releases/download/$gitTag/$assetName"
|
||||||
|
|
||||||
if (-not $asset) {
|
|
||||||
throw "Could not find $assetPattern in latest git-for-windows release"
|
|
||||||
}
|
|
||||||
|
|
||||||
$downloadUrl = $asset.browser_download_url
|
|
||||||
$downloadExt = if ($downloadIsZip) { "zip" } else { "7z.exe" }
|
$downloadExt = if ($downloadIsZip) { "zip" } else { "7z.exe" }
|
||||||
$tmpFile = "$env:TEMP\$($asset.name)"
|
$tmpFile = "$env:TEMP\$assetName"
|
||||||
$gitDir = "$HermesHome\git"
|
$gitDir = "$HermesHome\git"
|
||||||
|
|
||||||
Write-Info "Downloading $($asset.name) ($([math]::Round($asset.size / 1MB, 1)) MB)..."
|
Write-Info "Downloading $assetName (Git for Windows $gitVerTag)..."
|
||||||
Invoke-WebRequest -Uri $downloadUrl -OutFile $tmpFile -UseBasicParsing
|
Invoke-WebRequest -Uri $downloadUrl -OutFile $tmpFile -UseBasicParsing
|
||||||
|
|
||||||
if (Test-Path $gitDir) {
|
if (Test-Path $gitDir) {
|
||||||
|
|||||||
Reference in New Issue
Block a user