refactor(inventory): share retention cap + invariant-culture date format
Introduce InventoryHistoryConfig.RetentionRowsPerViewer as the single source of truth for the 300-row audit-log cap; InventoryTransaction aliases it and ItemAcquireHistoryController.Take() references it directly so the two sites cannot drift. Also adds CultureInfo.InvariantCulture to the AcquireTime.ToString() call, matching every other WireDateFormat site in the codebase. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
using System.Globalization;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using SVSim.Database;
|
||||
using SVSim.Database.Services.Inventory;
|
||||
using SVSim.EmulatedEntrypoint.Models.Dtos.ItemAcquireHistory;
|
||||
|
||||
namespace SVSim.EmulatedEntrypoint.Controllers;
|
||||
@@ -9,7 +11,6 @@ namespace SVSim.EmulatedEntrypoint.Controllers;
|
||||
public sealed class ItemAcquireHistoryController : SVSimController
|
||||
{
|
||||
private const string WireDateFormat = "yyyy-MM-dd HH:mm:ss";
|
||||
private const int PageSize = 300;
|
||||
|
||||
private readonly SVSimDbContext _db;
|
||||
|
||||
@@ -26,7 +27,7 @@ public sealed class ItemAcquireHistoryController : SVSimController
|
||||
.Where(h => h.ViewerId == viewerId)
|
||||
.OrderByDescending(h => h.AcquireTime)
|
||||
.ThenByDescending(h => h.Id)
|
||||
.Take(PageSize)
|
||||
.Take(InventoryHistoryConfig.RetentionRowsPerViewer)
|
||||
.AsNoTracking()
|
||||
.ToListAsync(ct);
|
||||
|
||||
@@ -38,7 +39,7 @@ public sealed class ItemAcquireHistoryController : SVSimController
|
||||
RewardDetailId = h.RewardDetailId.ToString(),
|
||||
RewardCount = h.RewardCount.ToString(),
|
||||
AcquireType = h.AcquireType.ToString(),
|
||||
AcquireTime = h.AcquireTime.ToString(WireDateFormat),
|
||||
AcquireTime = h.AcquireTime.ToString(WireDateFormat, CultureInfo.InvariantCulture),
|
||||
Message = h.Message,
|
||||
}).ToList(),
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user