1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-31 11:24:23 +02:00

60 lines
1.7 KiB
C#
Raw Normal View History

2013-03-23 17:08:23 -07:00
using System;
using System.Data.SQLite;
2013-03-24 20:51:32 -07:00
using Marr.Data;
using Marr.Data.Reflection;
2013-03-24 23:13:53 -07:00
using NzbDrone.Core.Datastore.Migration.Framework;
2013-03-24 20:51:32 -07:00
2013-03-23 17:08:23 -07:00
namespace NzbDrone.Core.Datastore
{
public interface IDbFactory
{
2013-03-24 23:13:53 -07:00
IDatabase Create(string dbPath, MigrationType migrationType = MigrationType.Main);
2013-03-23 17:08:23 -07:00
}
public class DbFactory : IDbFactory
{
2013-03-24 23:13:53 -07:00
private readonly IMigrationController _migrationController;
2013-03-23 17:08:23 -07:00
static DbFactory()
2013-03-23 17:08:23 -07:00
{
MapRepository.Instance.ReflectionStrategy = new SimpleReflectionStrategy();
2013-03-24 23:13:53 -07:00
TableMapping.Map();
}
public DbFactory(IMigrationController migrationController)
{
2013-03-24 23:13:53 -07:00
_migrationController = migrationController;
}
2013-03-23 21:56:59 -07:00
2013-03-24 23:13:53 -07:00
public IDatabase Create(string dbPath, MigrationType migrationType = MigrationType.Main)
{
var connectionString = GetConnectionString(dbPath);
2013-03-23 17:08:23 -07:00
2013-03-24 23:13:53 -07:00
_migrationController.MigrateToLatest(connectionString, migrationType);
2013-05-11 13:06:57 -07:00
return new Database(() =>
{
var dataMapper = new DataMapper(SQLiteFactory.Instance, connectionString)
{
SqlMode = SqlModes.Text,
};
return dataMapper;
});
2013-03-24 20:51:32 -07:00
}
2013-03-23 17:08:23 -07:00
private string GetConnectionString(string dbPath)
{
var connectionBuilder = new SQLiteConnectionStringBuilder();
connectionBuilder.DataSource = dbPath;
connectionBuilder.CacheSize = (int)-10.Megabytes();
connectionBuilder.DateTimeKind = DateTimeKind.Utc;
2013-05-23 18:41:32 -07:00
connectionBuilder.JournalMode = SQLiteJournalModeEnum.Wal;
return connectionBuilder.ConnectionString;
2013-03-23 17:08:23 -07:00
}
}
}