2017-10-31 01:28:29 +00:00
|
|
|
using System.Collections.Generic;
|
2017-09-04 02:20:56 +00:00
|
|
|
using System.IO;
|
|
|
|
using System.Linq;
|
2020-01-03 12:49:24 +00:00
|
|
|
using Lidarr.Http;
|
2017-09-04 02:20:56 +00:00
|
|
|
using Nancy;
|
|
|
|
using Nancy.Responses;
|
2020-01-03 12:49:24 +00:00
|
|
|
using NLog;
|
2017-09-04 02:20:56 +00:00
|
|
|
using NzbDrone.Common.Disk;
|
|
|
|
using NzbDrone.Core.Configuration;
|
|
|
|
|
2017-10-31 01:28:29 +00:00
|
|
|
namespace Lidarr.Api.V1.Logs
|
2017-09-04 02:20:56 +00:00
|
|
|
{
|
|
|
|
public abstract class LogFileModuleBase : LidarrRestModule<LogFileResource>
|
|
|
|
{
|
|
|
|
protected const string LOGFILE_ROUTE = @"/(?<filename>[-.a-zA-Z0-9]+?\.txt)";
|
|
|
|
|
|
|
|
private readonly IDiskProvider _diskProvider;
|
|
|
|
private readonly IConfigFileProvider _configFileProvider;
|
|
|
|
|
|
|
|
public LogFileModuleBase(IDiskProvider diskProvider,
|
|
|
|
IConfigFileProvider configFileProvider,
|
|
|
|
string route)
|
|
|
|
: base("log/file" + route)
|
|
|
|
{
|
|
|
|
_diskProvider = diskProvider;
|
|
|
|
_configFileProvider = configFileProvider;
|
|
|
|
GetResourceAll = GetLogFilesResponse;
|
|
|
|
|
2020-01-03 12:49:24 +00:00
|
|
|
Get(LOGFILE_ROUTE, options => GetLogFileResponse(options.filename));
|
2017-09-04 02:20:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private List<LogFileResource> GetLogFilesResponse()
|
|
|
|
{
|
|
|
|
var result = new List<LogFileResource>();
|
|
|
|
|
|
|
|
var files = GetLogFiles().ToList();
|
|
|
|
|
|
|
|
for (int i = 0; i < files.Count; i++)
|
|
|
|
{
|
|
|
|
var file = files[i];
|
|
|
|
var filename = Path.GetFileName(file);
|
2020-01-03 12:49:24 +00:00
|
|
|
|
2017-09-04 02:20:56 +00:00
|
|
|
result.Add(new LogFileResource
|
|
|
|
{
|
|
|
|
Id = i + 1,
|
|
|
|
Filename = filename,
|
|
|
|
LastWriteTime = _diskProvider.FileGetLastWrite(file),
|
2017-10-31 01:28:29 +00:00
|
|
|
ContentsUrl = string.Format("{0}/api/v1/{1}/{2}", _configFileProvider.UrlBase, Resource, filename),
|
2017-09-04 02:20:56 +00:00
|
|
|
DownloadUrl = string.Format("{0}/{1}/{2}", _configFileProvider.UrlBase, DownloadUrlRoot, filename)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return result.OrderByDescending(l => l.LastWriteTime).ToList();
|
|
|
|
}
|
|
|
|
|
2019-09-12 20:32:51 +00:00
|
|
|
private object GetLogFileResponse(string filename)
|
2017-09-04 02:20:56 +00:00
|
|
|
{
|
2019-08-22 20:15:25 +00:00
|
|
|
LogManager.Flush();
|
|
|
|
|
2017-09-04 02:20:56 +00:00
|
|
|
var filePath = GetLogFilePath(filename);
|
|
|
|
|
|
|
|
if (!_diskProvider.FileExists(filePath))
|
2020-01-03 12:49:24 +00:00
|
|
|
{
|
2017-09-04 02:20:56 +00:00
|
|
|
return new NotFoundResponse();
|
2020-01-03 12:49:24 +00:00
|
|
|
}
|
2017-09-04 02:20:56 +00:00
|
|
|
|
|
|
|
var data = _diskProvider.ReadAllText(filePath);
|
2020-01-03 12:49:24 +00:00
|
|
|
|
2017-09-04 02:20:56 +00:00
|
|
|
return new TextResponse(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected abstract IEnumerable<string> GetLogFiles();
|
|
|
|
protected abstract string GetLogFilePath(string filename);
|
|
|
|
|
|
|
|
protected abstract string DownloadUrlRoot { get; }
|
|
|
|
}
|
2017-10-31 01:28:29 +00:00
|
|
|
}
|