|
| 1 | +use anyhow::{anyhow, Result}; |
| 2 | +use core::time; |
1 | 3 | use serde_json::Value; |
2 | 4 | use std::{ |
3 | 5 | fs::File, |
4 | 6 | io::Write, |
5 | 7 | path::{Path, PathBuf}, |
| 8 | + thread::sleep, |
6 | 9 | }; |
7 | 10 |
|
8 | 11 | use multiversx_sc_meta_lib::print_util::println_green; |
9 | 12 |
|
10 | 13 | use super::system_info::{get_system_info, SystemInfo}; |
11 | 14 |
|
| 15 | +const API_LIMIT_EXCEEDED: &str = "api rate limit exceeded for"; |
| 16 | +const MAX_RETRIES: u64 = 5; |
| 17 | +const RETRY_DELAY: time::Duration = time::Duration::from_secs(2); |
12 | 18 | const USER_AGENT: &str = "multiversx-sc-meta"; |
13 | 19 | const SCENARIO_CLI_RELEASES_BASE_URL: &str = |
14 | 20 | "https://api.github.com/repos/multiversx/mx-chain-scenario-cli-go/releases"; |
@@ -78,20 +84,35 @@ impl ScenarioGoInstaller { |
78 | 84 | } |
79 | 85 | } |
80 | 86 |
|
81 | | - async fn get_scenario_go_release_json(&self) -> Result<String, reqwest::Error> { |
| 87 | + async fn get_scenario_go_release_json(&self) -> Result<String> { |
82 | 88 | let release_url = self.release_url(); |
83 | 89 | println_green(format!("Retrieving release info: {release_url}")); |
84 | 90 |
|
85 | | - let response = reqwest::Client::builder() |
86 | | - .user_agent(&self.user_agent) |
87 | | - .build()? |
88 | | - .get(release_url) |
89 | | - .send() |
90 | | - .await? |
91 | | - .text() |
92 | | - .await?; |
| 91 | + let mut wait_time = RETRY_DELAY; |
| 92 | + |
| 93 | + for i in 0..MAX_RETRIES { |
| 94 | + let response = reqwest::Client::builder() |
| 95 | + .user_agent(&self.user_agent) |
| 96 | + .build()? |
| 97 | + .get(&release_url) |
| 98 | + .send() |
| 99 | + .await? |
| 100 | + .text() |
| 101 | + .await?; |
| 102 | + |
| 103 | + if !response.to_lowercase().contains(API_LIMIT_EXCEEDED) { |
| 104 | + return Ok(response); |
| 105 | + } |
| 106 | + |
| 107 | + println!("API rate limit exceeded, attempt {i} retrying..."); |
| 108 | + sleep(wait_time); |
| 109 | + wait_time += RETRY_DELAY; |
| 110 | + } |
93 | 111 |
|
94 | | - Ok(response) |
| 112 | + Err(anyhow!( |
| 113 | + "Failed to retrieve release info after {} retries", |
| 114 | + MAX_RETRIES |
| 115 | + )) |
95 | 116 | } |
96 | 117 |
|
97 | 118 | fn parse_scenario_go_release(&self, raw_json: &str) -> ScenarioGoRelease { |
|
0 commit comments