Lidarr/src/Lidarr.Api.V1/Logs/LogModule.cs

64 lines
2.3 KiB
C#
Raw Normal View History

2018-03-15 01:28:46 +00:00
using System.Linq;
2017-09-04 02:20:56 +00:00
using Lidarr.Http;
using NzbDrone.Core.Instrumentation;
2017-09-04 02:20:56 +00:00
2017-10-31 01:28:29 +00:00
namespace Lidarr.Api.V1.Logs
2017-09-04 02:20:56 +00:00
{
public class LogModule : LidarrRestModule<LogResource>
{
private readonly ILogService _logService;
public LogModule(ILogService logService)
{
_logService = logService;
GetResourcePaged = GetLogs;
}
private PagingResource<LogResource> GetLogs(PagingResource<LogResource> pagingResource)
{
var pageSpec = pagingResource.MapToPagingSpec<LogResource, Log>();
if (pageSpec.SortKey == "time")
{
pageSpec.SortKey = "id";
}
2018-03-15 01:28:46 +00:00
var levelFilter = pagingResource.Filters.FirstOrDefault(f => f.Key == "level");
if (levelFilter != null)
2017-09-04 02:20:56 +00:00
{
2018-03-15 01:28:46 +00:00
switch (levelFilter.Value)
2017-09-04 02:20:56 +00:00
{
2018-03-15 01:28:46 +00:00
case "fatal":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal");
2017-09-04 02:20:56 +00:00
break;
2018-03-15 01:28:46 +00:00
case "error":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error");
2017-09-04 02:20:56 +00:00
break;
2018-03-15 01:28:46 +00:00
case "warn":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn");
2017-09-04 02:20:56 +00:00
break;
2018-03-15 01:28:46 +00:00
case "info":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info");
2017-09-04 02:20:56 +00:00
break;
2018-03-15 01:28:46 +00:00
case "debug":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug");
2017-09-04 02:20:56 +00:00
break;
2018-03-15 01:28:46 +00:00
case "trace":
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug" || h.Level == "Trace");
2017-09-04 02:20:56 +00:00
break;
}
}
var response = ApplyToPage(_logService.Paged, pageSpec, LogResourceMapper.ToResource);
if (pageSpec.SortKey == "id")
{
response.SortKey = "time";
}
return response;
}
}
2018-03-15 01:28:46 +00:00
}