Files
SPT-Server-Build/Core/Controllers/ClientLogController.cs
T
2025-01-16 20:22:31 +00:00

59 lines
1.7 KiB
C#

using Core.Annotations;
using Core.Models.Spt.Logging;
using Core.Models.Utils;
using LogLevel = Core.Models.Spt.Logging.LogLevel;
namespace Core.Controllers;
[Injectable]
public class ClientLogController
{
protected ISptLogger<ClientLogController> _logger;
public ClientLogController(
ISptLogger<ClientLogController> logger
)
{
_logger = logger;
}
/// <summary>
/// Handle /singleplayer/log
/// </summary>
/// <param name="logRequest"></param>
public void ClientLog(ClientLogRequest logRequest)
{
var message = $"[{logRequest.Source}] {logRequest.Message}";
/* TODO: what do we do with this?
var color = logRequest.Color ?? LogTextColor.White;
var backgroundColor = logRequest.BackgroundColor ?? LogBackgroundColor.Default;
*/
// Allow supporting either string or enum levels
// Required due to the C# modules serializing enums as their name
switch (logRequest.Level)
{
case LogLevel.Error:
this._logger.Error(message);
break;
case LogLevel.Warn:
this._logger.Warning(message);
break;
case LogLevel.Success:
case LogLevel.Info:
this._logger.Info(message);
break;
case LogLevel.Custom:
this._logger.Info(message /* TODO: , color.ToString(), backgroundColor.ToString()*/);
break;
case LogLevel.Debug:
this._logger.Debug(message);
break;
default:
this._logger.Info(message);
break;
}
}
}