You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
2.4 KiB
68 lines
2.4 KiB
7 years ago
|
using System.Linq;
|
||
7 years ago
|
using Lidarr.Http;
|
||
3 years ago
|
using Lidarr.Http.Extensions;
|
||
|
using Microsoft.AspNetCore.Mvc;
|
||
5 years ago
|
using NzbDrone.Core.Instrumentation;
|
||
7 years ago
|
|
||
7 years ago
|
namespace Lidarr.Api.V1.Logs
|
||
7 years ago
|
{
|
||
3 years ago
|
[V1ApiController]
|
||
|
public class LogController : Controller
|
||
7 years ago
|
{
|
||
|
private readonly ILogService _logService;
|
||
|
|
||
3 years ago
|
public LogController(ILogService logService)
|
||
7 years ago
|
{
|
||
|
_logService = logService;
|
||
|
}
|
||
|
|
||
3 years ago
|
[HttpGet]
|
||
|
public PagingResource<LogResource> GetLogs()
|
||
7 years ago
|
{
|
||
3 years ago
|
var pagingResource = Request.ReadPagingResourceFromRequest<LogResource>();
|
||
7 years ago
|
var pageSpec = pagingResource.MapToPagingSpec<LogResource, Log>();
|
||
|
|
||
|
if (pageSpec.SortKey == "time")
|
||
|
{
|
||
|
pageSpec.SortKey = "id";
|
||
|
}
|
||
|
|
||
7 years ago
|
var levelFilter = pagingResource.Filters.FirstOrDefault(f => f.Key == "level");
|
||
|
|
||
|
if (levelFilter != null)
|
||
7 years ago
|
{
|
||
7 years ago
|
switch (levelFilter.Value)
|
||
7 years ago
|
{
|
||
7 years ago
|
case "fatal":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal");
|
||
7 years ago
|
break;
|
||
7 years ago
|
case "error":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error");
|
||
7 years ago
|
break;
|
||
7 years ago
|
case "warn":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn");
|
||
7 years ago
|
break;
|
||
7 years ago
|
case "info":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info");
|
||
7 years ago
|
break;
|
||
7 years ago
|
case "debug":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug");
|
||
7 years ago
|
break;
|
||
7 years ago
|
case "trace":
|
||
|
pageSpec.FilterExpressions.Add(h => h.Level == "Fatal" || h.Level == "Error" || h.Level == "Warn" || h.Level == "Info" || h.Level == "Debug" || h.Level == "Trace");
|
||
7 years ago
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
3 years ago
|
var response = pageSpec.ApplyToPage(_logService.Paged, LogResourceMapper.ToResource);
|
||
7 years ago
|
|
||
|
if (pageSpec.SortKey == "id")
|
||
|
{
|
||
|
response.SortKey = "time";
|
||
|
}
|
||
|
|
||
|
return response;
|
||
|
}
|
||
|
}
|
||
7 years ago
|
}
|