1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 06:42:54 +08:00

Add thread-safety on access token validation logic.

This commit is contained in:
Dean Herbert 2017-05-11 19:35:07 +09:00
parent 7d221802a2
commit 4e881644f6

View File

@ -72,21 +72,28 @@ namespace osu.Game.Online.API
} }
} }
private static readonly object access_token_retrieval_lock = new object();
/// <summary> /// <summary>
/// Should be run before any API request to make sure we have a valid key. /// Should be run before any API request to make sure we have a valid key.
/// </summary> /// </summary>
private bool ensureAccessToken() private bool ensureAccessToken()
{ {
//todo: we need to mutex this to ensure only one authentication request is running at a time. // if we already have a valid access token, let's use it.
//If we already have a valid access token, let's use it.
if (accessTokenValid) return true; if (accessTokenValid) return true;
//If not, let's try using our refresh token to request a new access token. // we want to ensure only a single authentication update is happening at once.
if (!string.IsNullOrEmpty(Token?.RefreshToken)) lock (access_token_retrieval_lock)
AuthenticateWithRefresh(Token.RefreshToken); {
// re-check if valid, in case another requrest completed and revalidated our access.
if (accessTokenValid) return true;
return accessTokenValid; // if not, let's try using our refresh token to request a new access token.
if (!string.IsNullOrEmpty(Token?.RefreshToken))
AuthenticateWithRefresh(Token.RefreshToken);
return accessTokenValid;
}
} }
private bool accessTokenValid => Token?.IsValid ?? false; private bool accessTokenValid => Token?.IsValid ?? false;