mirror of
https://github.com/Tyrrrz/DiscordChatExporter.git
synced 2025-06-07 01:51:18 -04:00
Add retry policy to MediaDownloader to accommodate short network outages during download (#404)
This commit is contained in:
parent
ddb4856516
commit
09acfcff59
1 changed files with 18 additions and 7 deletions
|
@ -1,11 +1,14 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Net;
|
||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
using System.Text.RegularExpressions;
|
using System.Text.RegularExpressions;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using DiscordChatExporter.Domain.Internal;
|
using DiscordChatExporter.Domain.Internal;
|
||||||
using DiscordChatExporter.Domain.Internal.Extensions;
|
using DiscordChatExporter.Domain.Internal.Extensions;
|
||||||
|
using Polly;
|
||||||
|
using Polly.Retry;
|
||||||
|
|
||||||
namespace DiscordChatExporter.Domain.Exporting
|
namespace DiscordChatExporter.Domain.Exporting
|
||||||
{
|
{
|
||||||
|
@ -13,27 +16,35 @@ namespace DiscordChatExporter.Domain.Exporting
|
||||||
{
|
{
|
||||||
private readonly HttpClient _httpClient = Singleton.HttpClient;
|
private readonly HttpClient _httpClient = Singleton.HttpClient;
|
||||||
private readonly string _workingDirPath;
|
private readonly string _workingDirPath;
|
||||||
|
private readonly AsyncRetryPolicy _httpRequestPolicy;
|
||||||
|
|
||||||
private readonly Dictionary<string, string> _pathMap = new Dictionary<string, string>();
|
private readonly Dictionary<string, string> _pathMap = new Dictionary<string, string>();
|
||||||
|
|
||||||
public MediaDownloader(string workingDirPath)
|
public MediaDownloader(string workingDirPath)
|
||||||
{
|
{
|
||||||
_workingDirPath = workingDirPath;
|
_workingDirPath = workingDirPath;
|
||||||
|
|
||||||
|
_httpRequestPolicy = Policy
|
||||||
|
.Handle<IOException>()
|
||||||
|
.WaitAndRetryAsync(8, i => TimeSpan.FromSeconds(0.5 * i));
|
||||||
}
|
}
|
||||||
|
|
||||||
public async ValueTask<string> DownloadAsync(string url)
|
public async ValueTask<string> DownloadAsync(string url)
|
||||||
{
|
{
|
||||||
if (_pathMap.TryGetValue(url, out var cachedFilePath))
|
return await _httpRequestPolicy.ExecuteAsync(async () =>
|
||||||
return cachedFilePath;
|
{
|
||||||
|
if (_pathMap.TryGetValue(url, out var cachedFilePath))
|
||||||
|
return cachedFilePath;
|
||||||
|
|
||||||
var fileName = GetFileNameFromUrl(url);
|
var fileName = GetFileNameFromUrl(url);
|
||||||
var filePath = PathEx.MakeUniqueFilePath(Path.Combine(_workingDirPath, fileName));
|
var filePath = PathEx.MakeUniqueFilePath(Path.Combine(_workingDirPath, fileName));
|
||||||
|
|
||||||
Directory.CreateDirectory(_workingDirPath);
|
Directory.CreateDirectory(_workingDirPath);
|
||||||
|
|
||||||
await _httpClient.DownloadAsync(url, filePath);
|
await _httpClient.DownloadAsync(url, filePath);
|
||||||
|
|
||||||
return _pathMap[url] = filePath;
|
return _pathMap[url] = filePath;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue