Use sendfile for client file get as well

This commit is contained in:
Loporrit
2024-09-13 16:11:03 +00:00
parent 21c615cdb7
commit 49695b4403
6 changed files with 65 additions and 162 deletions

View File

@@ -10,15 +10,15 @@ namespace MareSynchronosStaticFilesServer.Controllers;
[Route(MareFiles.Cache)]
public class CacheController : ControllerBase
{
private readonly RequestFileStreamResultFactory _requestFileStreamResultFactory;
private readonly RequestBlockFileListResultFactory _requestBlockFileListResultFactory;
private readonly CachedFileProvider _cachedFileProvider;
private readonly RequestQueueService _requestQueue;
private readonly FileStatisticsService _fileStatisticsService;
public CacheController(ILogger<CacheController> logger, RequestFileStreamResultFactory requestFileStreamResultFactory,
public CacheController(ILogger<CacheController> logger, RequestBlockFileListResultFactory requestBlockFileListResultFactory,
CachedFileProvider cachedFileProvider, RequestQueueService requestQueue, FileStatisticsService fileStatisticsService) : base(logger)
{
_requestFileStreamResultFactory = requestFileStreamResultFactory;
_requestBlockFileListResultFactory = requestBlockFileListResultFactory;
_cachedFileProvider = cachedFileProvider;
_requestQueue = requestQueue;
_fileStatisticsService = fileStatisticsService;
@@ -33,23 +33,19 @@ public class CacheController : ControllerBase
_requestQueue.ActivateRequest(requestId);
Response.ContentType = "application/octet-stream";
long requestSize = 0;
var streamList = new List<Stream>();
var fileList = new List<FileInfo>(request.FileIds.Count);
foreach (var file in request.FileIds)
{
var fs = await _cachedFileProvider.GetAndDownloadFileStream(file);
if (fs == null) continue;
var headerBytes = Encoding.ASCII.GetBytes("#" + file + ":" + fs.Length.ToString(CultureInfo.InvariantCulture) + "#");
streamList.Add(new MemoryStream(headerBytes));
streamList.Add(fs);
requestSize += fs.Length;
var fi = await _cachedFileProvider.GetAndDownloadFile(file);
if (fi == null) continue;
requestSize += fi.Length;
fileList.Add(fi);
}
_fileStatisticsService.LogRequest(requestSize);
return _requestFileStreamResultFactory.Create(requestId, new ConcatenatedStreamReader(streamList));
return _requestBlockFileListResultFactory.Create(requestId, fileList);
}
}