using System; using Marr.Data; using NLog; using NzbDrone.Common.Instrumentation; namespace NzbDrone.Core.Datastore { public interface IDatabase { IDataMapper GetDataMapper(); Version Version { get; } void Vacuum(); } public class Database : IDatabase { private readonly Func _datamapperFactory; private readonly Logger _logger = NzbDroneLogger.GetLogger(typeof(Database)); public Database(Func datamapperFactory) { _datamapperFactory = datamapperFactory; } public IDataMapper GetDataMapper() { return _datamapperFactory(); } public Version Version { get { var version = _datamapperFactory().ExecuteScalar("SELECT sqlite_version()").ToString(); return new Version(version); } } public void Vacuum() { try { _logger.Info("Vacuuming database"); _datamapperFactory().ExecuteNonQuery("Vacuum;"); _logger.Info("Database Compressed"); } catch (Exception e) { _logger.Error("An Error occurred while vacuuming database.", e); } } } }