Skip to content

Commit

Permalink
Merge branch 'main' into better-limiter
Browse files Browse the repository at this point in the history
  • Loading branch information
Eric-Joker authored Aug 5, 2024
2 parents fa6f26a + bf071c4 commit a317b09
Show file tree
Hide file tree
Showing 5 changed files with 23 additions and 23 deletions.
4 changes: 2 additions & 2 deletions src/Starward.Core/Gacha/GachaLogClient.cs
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@ public abstract class GachaLogClient

protected const string WEB_CACHE_SR_PATH = @"StarRail_Data\webCaches\Cache\Cache_Data\data_2";

protected const string API_PREFIX_SR_CN = "https://api-takumi.mihoyo.com/common/gacha_record/api/getGachaLog";
protected const string API_PREFIX_SR_OS = "https://api-os-takumi.mihoyo.com/common/gacha_record/api/getGachaLog";
protected const string API_PREFIX_SR_CN = "https://public-operation-hkrpg.mihoyo.com/common/gacha_record/api/getGachaLog";
protected const string API_PREFIX_SR_OS = "https://public-operation-hkrpg-sg.hoyoverse.com/common/gacha_record/api/getGachaLog";

protected static ReadOnlySpan<byte> SPAN_WEB_PREFIX_SR_CN => "https://webstatic.mihoyo.com/hkrpg/event/e20211215gacha-v2/index.html"u8;
protected static ReadOnlySpan<byte> SPAN_WEB_PREFIX_SR_OS => "https://gs.hoyoverse.com/hkrpg/event/e20211215gacha-v2/index.html"u8;
Expand Down
2 changes: 1 addition & 1 deletion src/Starward.Core/Gacha/Genshin/GenshinGachaClient.cs
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ protected override string GetGachaUrlPrefix(string gachaUrl, string? lang = null
}
return gachaUrl;
}
match = Regex.Match(gachaUrl, @"(https://hk4e-api[!-z]+)");
match = Regex.Match(gachaUrl, @"(https://public-operation-hk4e[!-z]+)");
if (match.Success)
{
gachaUrl = match.Groups[1].Value;
Expand Down
2 changes: 1 addition & 1 deletion src/Starward.Core/Gacha/StarRail/StarRailGachaClient.cs
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ protected override string GetGachaUrlPrefix(string gachaUrl, string? lang = null
}
return gachaUrl;
}
match = Regex.Match(gachaUrl, @"(https://api[!-z]+)");
match = Regex.Match(gachaUrl, @"(https://public-operation-hkrpg[!-z]+)");
if (match.Success)
{
gachaUrl = match.Groups[1].Value;
Expand Down
5 changes: 2 additions & 3 deletions src/Starward/Services/Download/InstallGameManager.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using CommunityToolkit.Mvvm.Messaging;
using CommunityToolkit.Mvvm.Messaging;
using Starward.Core;
using Starward.Helpers;
using Starward.Messages;
Expand All @@ -23,7 +23,6 @@ private InstallGameManager()
_services = new();
int speed = AppConfig.SpeedLimitKBPerSecond * 1024;
SpeedLimitBytesPerSecond = speed == 0 ? int.MaxValue : speed;
GlobalRateLimiter = GetRateLimiter(SpeedLimitBytesPerSecond);
}


Expand All @@ -35,7 +34,7 @@ private InstallGameManager()
public static int SpeedLimitBytesPerSecond { get; set; }


public static TokenBucketRateLimiter GlobalRateLimiter;
public static TokenBucketRateLimiter GlobalRateLimiter = GetRateLimiter(SpeedLimitBytesPerSecond);


public static bool IsEnableSpeedLimit => SpeedLimitBytesPerSecond != int.MaxValue;
Expand Down
33 changes: 17 additions & 16 deletions src/Starward/Services/Download/InstallGameService.cs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Logging;
using Starward.Core;
using Starward.Core.HoYoPlay;
using Starward.Services.InstallGame;
Expand All @@ -21,6 +21,7 @@
using System.Text;
using System.Text.Json.Nodes;
using System.Threading;
using System.Threading.RateLimiting;
using System.Threading.Tasks;
using Vanara.PInvoke;

Expand Down Expand Up @@ -245,7 +246,7 @@ await Task.Run(() =>
{
File.SetAttributes(file, FileAttributes.Normal);
}
});
}).ConfigureAwait(false);
CurrentGameBiz = gameBiz;
_installPath = installPath;
_initialized = true;
Expand Down Expand Up @@ -984,15 +985,15 @@ protected async Task CleanGameDeprecatedFilesAsync()
{
File.Delete(file);
}
foreach (var file in await _hoYoPlayService.GetGameDeprecatedFilesAsync(CurrentGameBiz))
foreach (var file in await _hoYoPlayService.GetGameDeprecatedFilesAsync(CurrentGameBiz).ConfigureAwait(false))
{
var path = Path.Combine(_installPath, file.Name);
if (File.Exists(path))
{
File.Delete(path);
}
}
await WriteConfigFileAsync();
await WriteConfigFileAsync().ConfigureAwait(false);
CurrentTaskFinished();
}

Expand Down Expand Up @@ -1129,19 +1130,19 @@ protected async Task ExecuteTaskItemAsync(CancellationToken cancellationToken =
case InstallGameItemType.None:
break;
case InstallGameItemType.Download:
await DownloadItemAsync(item, cancellationToken);
await DownloadItemAsync(item, cancellationToken).ConfigureAwait(false);
Interlocked.Increment(ref _finishCount);
break;
case InstallGameItemType.Verify:
await VerifyItemAsync(item, cancellationToken);
await VerifyItemAsync(item, cancellationToken).ConfigureAwait(false);
Interlocked.Increment(ref _finishCount);
break;
case InstallGameItemType.Decompress:
await DecompressItemAsync(item, cancellationToken);
await DecompressItemAsync(item, cancellationToken).ConfigureAwait(false);
Interlocked.Increment(ref _finishCount);
break;
case InstallGameItemType.HardLink:
await HardLinkItemAsync(item, cancellationToken);
await HardLinkItemAsync(item, cancellationToken).ConfigureAwait(false);
Interlocked.Increment(ref _finishCount);
break;
default:
Expand All @@ -1152,7 +1153,7 @@ protected async Task ExecuteTaskItemAsync(CancellationToken cancellationToken =
{
// network error
_installItemQueue.Enqueue(item);
await Task.Delay(1000, CancellationToken.None);
await Task.Delay(1000, CancellationToken.None).ConfigureAwait(false);
}
catch (Exception ex) when (ex is OperationCanceledException or TaskCanceledException)
{
Expand Down Expand Up @@ -1182,7 +1183,7 @@ protected async Task ExecuteTaskItemAsync(CancellationToken cancellationToken =

protected async Task DownloadItemAsync(InstallGameItem item, CancellationToken cancellationToken = default)
{
const int BUFFER_SIZE = 1 << 14;
const int BUFFER_SIZE = 1 << 10;
string file = item.Path;
string file_tmp = item.Path + "_tmp";
string file_target;
Expand Down Expand Up @@ -1277,7 +1278,7 @@ protected async Task VerifyItemAsync(InstallGameItem item, CancellationToken can
var buffer = ArrayPool<byte>.Shared.Rent(BUFFER_SIZE);
try
{
await _verifyGlobalSemaphore.WaitAsync(cancellationToken);
await _verifyGlobalSemaphore.WaitAsync(cancellationToken).ConfigureAwait(false);
using var fs = File.OpenRead(file_target);
if (fs.Length != item.Size)
{
Expand Down Expand Up @@ -1324,7 +1325,7 @@ protected async Task DecompressItemAsync(InstallGameItem item, CancellationToken
{
try
{
await _decompressSemaphore.WaitAsync();
await _decompressSemaphore.WaitAsync(cancellationToken).ConfigureAwait(false);
using var fs = new FileSliceStream(item.DecompressPackageFiles);
if (item.DecompressPackageFiles[0].Contains(".7z", StringComparison.CurrentCultureIgnoreCase))
{
Expand All @@ -1341,7 +1342,7 @@ await Task.Run(() =>
};
extra.Extract(item.DecompressPath, true);
_finishBytes += fs.Length - sum;
}).ConfigureAwait(false);
}, cancellationToken).ConfigureAwait(false);
}
else
{
Expand All @@ -1366,8 +1367,8 @@ await Task.Run(async () =>
}
}
_finishBytes += fs.Length - sum;
await ApplyDiffFilesAsync(item.DecompressPath);
}).ConfigureAwait(false);
await ApplyDiffFilesAsync(item.DecompressPath).ConfigureAwait(false);
}, cancellationToken).ConfigureAwait(false);
}
fs.Dispose();
foreach (var file in item.DecompressPackageFiles)
Expand Down Expand Up @@ -1471,7 +1472,7 @@ protected async Task HardLinkItemAsync(InstallGameItem item, CancellationToken c
var buffer = ArrayPool<byte>.Shared.Rent(BUFFER_SIZE);
try
{
await _verifyGlobalSemaphore.WaitAsync(cancellationToken);
await _verifyGlobalSemaphore.WaitAsync(cancellationToken).ConfigureAwait(false);
using var fs = File.OpenRead(file_source);
if (fs.Length != item.Size)
{
Expand Down

0 comments on commit a317b09

Please sign in to comment.