using System; using System.Collections.Generic; using NLog; using PetaPoco; namespace NzbDrone.Core.Instrumentation { public class LogProvider { private readonly IDatabase _database; private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); public LogProvider(IDatabase database) { _database = database; } public IList<Log> GetAllLogs() { return _database.Fetch<Log>(); } public IList<Log> TopLogs(int count) { var logs = _database.Fetch<Log>("SELECT TOP " + count + " * FROM Logs ORDER BY Time Desc"); logs.Add(new Log { Time = DateTime.Now.AddYears(-100), Level = "Info", Logger = "Core.Instrumentation.LogProvider", Message = String.Format("Number of logs currently shown: {0}. More may exist, check 'All' to see everything", Math.Min(count, logs.Count)) }); return logs; } public Page<Log> GetPagedLogs(int pageNumber, int pageSize) { return _database.Page<Log>(pageNumber, pageSize, "SELECT * FROM Logs ORDER BY Time DESC"); } public void DeleteAll() { _database.Delete<Log>(""); Logger.Info("Cleared Log History"); } } }