1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-14 02:22:56 +08:00

More resilient API cancel/fail logic.

This commit is contained in:
Dean Herbert 2017-03-15 20:08:12 +09:00
parent 56868e3c06
commit 2b82f256d2
No known key found for this signature in database
GPG Key ID: 46D71BF4958ABB49

View File

@ -60,15 +60,18 @@ namespace osu.Game.Online.API
private bool cancelled;
private Action pendingFailure;
public void Perform(APIAccess api)
{
if (cancelled) return;
this.api = api;
if (checkAndProcessFailure())
return;
if (startTime == null)
startTime = DateTime.Now.TotalMilliseconds();
this.api = api;
if (remainingTime <= 0)
throw new TimeoutException(@"API request timeout hit");
@ -76,10 +79,16 @@ namespace osu.Game.Online.API
WebRequest.RetryCount = 0;
WebRequest.Headers[@"Authorization"] = $@"Bearer {api.AccessToken}";
WebRequest.BlockingPerform();
if (checkAndProcessFailure())
return;
if (WebRequest.Completed)
api.Scheduler.Add(delegate { Success?.Invoke(); });
if (!WebRequest.Aborted) //could have been aborted by a Cancel() call
WebRequest.BlockingPerform();
if (checkAndProcessFailure())
return;
api.Scheduler.Add(delegate { Success?.Invoke(); });
}
public void Cancel() => Fail(new OperationCanceledException(@"Request cancelled"));
@ -89,10 +98,22 @@ namespace osu.Game.Online.API
cancelled = true;
WebRequest?.Abort();
api.Scheduler.Add(delegate
{
Failure?.Invoke(e);
});
pendingFailure = () => Failure?.Invoke(e);
checkAndProcessFailure();
}
/// <summary>
/// Checked for cancellation or error. Also queues up the Failed event if we can.
/// </summary>
/// <returns>Whether we are in a failed or cancelled state.</returns>
private bool checkAndProcessFailure()
{
if (api == null || pendingFailure == null) return cancelled;
api.Scheduler.Add(pendingFailure);
pendingFailure = null;
return true;
}
}