From 6e656deb5942b2a57c511bf6d4bdb3a65072b261 Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Thu, 25 Nov 2021 01:45:49 +0000 Subject: [PATCH] init: Check all releases (#21417) (#21419) (cherry picked from commit 69e1b68fbb76d2a6d96ba354c76927b3deb37fd1) Co-authored-by: Jon Cinque --- install/src/command.rs | 71 +++++++++++++++++++++++++----------------- 1 file changed, 43 insertions(+), 28 deletions(-) diff --git a/install/src/command.rs b/install/src/command.rs index 736b15d51b3a99..e91c0298f7a1a5 100644 --- a/install/src/command.rs +++ b/install/src/command.rs @@ -859,39 +859,54 @@ fn check_for_newer_github_release( version_filter: Option, prerelease_allowed: bool, ) -> reqwest::Result> { - let url = - reqwest::Url::parse("https://api.github.com/repos/solana-labs/solana/releases").unwrap(); + let mut page = 1; + const PER_PAGE: usize = 100; let client = reqwest::blocking::Client::builder() .user_agent("solana-install") .build()?; - let request = client.get(url).build()?; - let response = client.execute(request)?; - - let mut releases = response - .json::()? - .0 - .into_iter() - .filter_map( - |GithubRelease { - tag_name, - prerelease, - }| { - if let Ok(version) = semver_of(&tag_name) { - if (prerelease_allowed || !prerelease) - && version_filter - .as_ref() - .map_or(true, |version_filter| version_filter.matches(&version)) - { - return Some(version); - } - } - None - }, + let mut all_releases = vec![]; + let mut releases = vec![]; + + while page == 1 || releases.len() == PER_PAGE { + let url = reqwest::Url::parse_with_params( + "https://api.github.com/repos/solana-labs/solana/releases", + &[ + ("per_page", &format!("{}", PER_PAGE)), + ("page", &format!("{}", page)), + ], ) - .collect::>(); + .unwrap(); + let request = client.get(url).build()?; + let response = client.execute(request)?; + + releases = response + .json::()? + .0 + .into_iter() + .filter_map( + |GithubRelease { + tag_name, + prerelease, + }| { + if let Ok(version) = semver_of(&tag_name) { + if (prerelease_allowed || !prerelease) + && version_filter + .as_ref() + .map_or(true, |version_filter| version_filter.matches(&version)) + { + return Some(version); + } + } + None + }, + ) + .collect::>(); + all_releases.extend_from_slice(&releases); + page += 1; + } - releases.sort(); - Ok(releases.pop().map(|r| r.to_string())) + all_releases.sort(); + Ok(all_releases.pop().map(|r| r.to_string())) } pub enum SemverUpdateType {