2017-02-11 06:46:39 +00:00
|
|
|
using System.Linq;
|
|
|
|
using NzbDrone.Core.Instrumentation;
|
|
|
|
using Sonarr.Http;
|
2013-06-05 00:49:53 +00:00
|
|
|
|
|
|
|
namespace NzbDrone.Api.Logs
|
|
|
|
{
|
2017-02-11 06:46:39 +00:00
|
|
|
public class LogModule : SonarrRestModule<LogResource>
|
2013-06-05 00:49:53 +00:00
|
|
|
{
|
|
|
|
private readonly ILogService _logService;
|
|
|
|
|
|
|
|
public LogModule(ILogService logService)
|
|
|
|
{
|
|
|
|
_logService = logService;
|
|
|
|
GetResourcePaged = GetLogs;
|
|
|
|
}
|
|
|
|
|
|
|
|
private PagingResource<LogResource> GetLogs(PagingResource<LogResource> pagingResource)
|
|
|
|
{
|
2016-03-25 00:56:29 +00:00
|
|
|
var pageSpec = pagingResource.MapToPagingSpec<LogResource, Log>();
|
2013-09-16 00:48:39 +00:00
|
|
|
|
|
|
|
if (pageSpec.SortKey == "time")
|
|
|
|
{
|
|
|
|
pageSpec.SortKey = "id";
|
|
|
|
}
|
|
|
|
|
2017-02-11 06:46:39 +00:00
|
|
|
var filter = pagingResource.Filters.FirstOrDefault();
|
|
|
|
|
|
|
|
if (filter != null && filter.Key == "level")
|
2014-02-01 22:09:22 +00:00
|
|
|
{
|
2017-02-11 06:46:39 +00:00
|
|
|
switch (filter.Value)
|
2014-02-01 22:09:22 +00:00
|
|
|
{
|
|
|
|
case "Fatal":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
case "Error":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
case "Warn":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
case "Info":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
case "Debug":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
case "Trace":
|
2017-02-11 06:46:39 +00:00
|
|
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug" || h.Level == "Trace");
|
2014-02-01 22:09:22 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-03-25 00:56:29 +00:00
|
|
|
return ApplyToPage(_logService.Paged, pageSpec, LogResourceMapper.ToResource);
|
2013-06-05 00:49:53 +00:00
|
|
|
}
|
|
|
|
}
|
2017-02-11 06:46:39 +00:00
|
|
|
}
|