Skip to content

Commit

Permalink
bigtable: add timeout to token refresh (solana-labs#28728)
Browse files Browse the repository at this point in the history
Co-authored-by: Kirill Fomichev <fanatid@ya.ru>
2 people authored and nickfrosty committed Jan 4, 2023

Unverified

This commit is not signed, but one or more authors requires that any commit attributed to them is signed.
1 parent 4ba6631 commit 8d0c001
Showing 1 changed file with 14 additions and 6 deletions.
20 changes: 14 additions & 6 deletions storage-bigtable/src/access_token.rs
Original file line number Diff line number Diff line change
@@ -16,6 +16,7 @@ use {
},
time::Instant,
},
tokio::time,
};

fn load_credentials(filepath: Option<String>) -> Result<Credentials, String> {
@@ -109,15 +110,22 @@ impl AccessToken {
}

info!("Refreshing token");
let new_token = Self::get_token(&self.credentials, &self.scope).await;
match time::timeout(
time::Duration::from_secs(5),
Self::get_token(&self.credentials, &self.scope),
)
.await
{
let mut token_w = self.token.write().unwrap();
match new_token {
Ok(new_token) => *token_w = new_token,
Err(err) => warn!("{}", err),
Ok(new_token) => match (new_token, self.token.write()) {
(Ok(new_token), Ok(mut token_w)) => *token_w = new_token,
(Ok(_new_token), Err(err)) => warn!("{}", err),
(Err(err), _) => warn!("{}", err),
},
Err(_) => {
warn!("Token refresh timeout")
}
self.refresh_active.store(false, Ordering::Relaxed);
}
self.refresh_active.store(false, Ordering::Relaxed);
}

/// Return an access token suitable for use in an HTTP authorization header

0 comments on commit 8d0c001

Please sign in to comment.