add some file statistics metrics

This commit is contained in:
rootdarkarchon
2022-12-20 05:02:03 +01:00
parent ea344468f2
commit 7d3297e1e8
4 changed files with 122 additions and 24 deletions

View File

@@ -4,34 +4,36 @@ using Microsoft.Extensions.Logging;
using System.IO;
using System.Linq;
using System.Security.Claims;
using System.Threading.Tasks;
namespace MareSynchronosStaticFilesServer
namespace MareSynchronosStaticFilesServer;
[Route("/cache")]
public class FilesController : Controller
{
[Route("/cache")]
public class FilesController : Controller
private readonly ILogger<FilesController> _logger;
private readonly IConfiguration _configuration;
private readonly FileStatisticsService _fileStatisticsService;
public FilesController(ILogger<FilesController> logger, IConfiguration configuration, FileStatisticsService fileStatisticsService)
{
private readonly ILogger<FilesController> logger;
private readonly IConfiguration configuration;
_logger = logger;
_configuration = configuration;
_fileStatisticsService = fileStatisticsService;
}
public FilesController(ILogger<FilesController> logger, IConfiguration configuration)
{
this.logger = logger;
this.configuration = configuration;
}
[HttpGet("{fileId}")]
public IActionResult GetFile(string fileId)
{
var authedUser = HttpContext.User.Claims.FirstOrDefault(f => string.Equals(f.Type, ClaimTypes.NameIdentifier, System.StringComparison.Ordinal))?.Value ?? "Unknown";
_logger.LogInformation($"GetFile:{authedUser}:{fileId}");
[HttpGet("{fileId}")]
public IActionResult GetFile(string fileId)
{
var authedUser = HttpContext.User.Claims.FirstOrDefault(f => string.Equals(f.Type, ClaimTypes.NameIdentifier, System.StringComparison.Ordinal))?.Value ?? "Unknown";
logger.LogInformation($"GetFile:{authedUser}:{fileId}");
FileInfo fi = new(Path.Combine(_configuration.GetRequiredSection("MareSynchronos")["CacheDirectory"], fileId));
if (!fi.Exists) return NotFound();
FileInfo fi = new(Path.Combine(configuration.GetRequiredSection("MareSynchronos")["CacheDirectory"], fileId));
if (!fi.Exists) return NotFound();
_fileStatisticsService.LogFile(fileId, fi.Length);
var fileStream = new FileStream(fi.FullName, FileMode.Open, FileAccess.Read, FileShare.Read);
var fileStream = new FileStream(fi.FullName, FileMode.Open, FileAccess.Read, FileShare.Read);
return File(fileStream, "application/octet-stream");
}
return File(fileStream, "application/octet-stream");
}
}