2017-09-13 08:47:34 +02:00
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Threading.Tasks;
|
2018-06-05 05:51:37 +02:00
|
|
|
|
using Microsoft.EntityFrameworkCore.Migrations;
|
|
|
|
|
using Npgsql.EntityFrameworkCore.PostgreSQL.Migrations;
|
|
|
|
|
using JetBrains.Annotations;
|
|
|
|
|
using Npgsql.EntityFrameworkCore.PostgreSQL.Migrations.Operations;
|
|
|
|
|
using Microsoft.EntityFrameworkCore.Metadata;
|
2017-09-13 08:47:34 +02:00
|
|
|
|
|
|
|
|
|
namespace BTCPayServer.Data
|
|
|
|
|
{
|
2017-10-27 10:53:04 +02:00
|
|
|
|
public enum DatabaseType
|
|
|
|
|
{
|
|
|
|
|
Sqlite,
|
2018-10-27 16:15:21 +02:00
|
|
|
|
Postgres,
|
|
|
|
|
MySQL,
|
2017-10-27 10:53:04 +02:00
|
|
|
|
}
|
|
|
|
|
public class ApplicationDbContextFactory
|
|
|
|
|
{
|
|
|
|
|
string _ConnectionString;
|
|
|
|
|
DatabaseType _Type;
|
|
|
|
|
public ApplicationDbContextFactory(DatabaseType type, string connectionString)
|
|
|
|
|
{
|
|
|
|
|
_ConnectionString = connectionString ?? throw new ArgumentNullException(nameof(connectionString));
|
|
|
|
|
_Type = type;
|
|
|
|
|
}
|
2017-09-13 08:47:34 +02:00
|
|
|
|
|
2018-07-19 12:31:17 +02:00
|
|
|
|
|
|
|
|
|
public DatabaseType Type
|
|
|
|
|
{
|
|
|
|
|
get
|
|
|
|
|
{
|
|
|
|
|
return _Type;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-27 10:53:04 +02:00
|
|
|
|
public ApplicationDbContext CreateContext()
|
|
|
|
|
{
|
|
|
|
|
var builder = new DbContextOptionsBuilder<ApplicationDbContext>();
|
|
|
|
|
ConfigureBuilder(builder);
|
|
|
|
|
return new ApplicationDbContext(builder.Options);
|
|
|
|
|
}
|
2017-09-27 15:09:59 +02:00
|
|
|
|
|
2018-06-05 05:51:37 +02:00
|
|
|
|
class CustomNpgsqlMigrationsSqlGenerator : NpgsqlMigrationsSqlGenerator
|
|
|
|
|
{
|
2019-10-03 09:36:02 +02:00
|
|
|
|
public CustomNpgsqlMigrationsSqlGenerator(MigrationsSqlGeneratorDependencies dependencies, IMigrationsAnnotationProvider annotations, Npgsql.EntityFrameworkCore.PostgreSQL.Infrastructure.Internal.INpgsqlOptions opts) : base(dependencies, annotations, opts)
|
2018-06-05 05:51:37 +02:00
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override void Generate(NpgsqlCreateDatabaseOperation operation, IModel model, MigrationCommandListBuilder builder)
|
|
|
|
|
{
|
|
|
|
|
builder
|
|
|
|
|
.Append("CREATE DATABASE ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier(operation.Name));
|
|
|
|
|
|
|
|
|
|
// POSTGRES gotcha: Indexed Text column (even if PK) are not used if we are not using C locale
|
|
|
|
|
builder
|
|
|
|
|
.Append(" TEMPLATE ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier("template0"));
|
|
|
|
|
|
|
|
|
|
builder
|
|
|
|
|
.Append(" LC_CTYPE ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier("C"));
|
|
|
|
|
|
|
|
|
|
builder
|
|
|
|
|
.Append(" LC_COLLATE ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier("C"));
|
|
|
|
|
|
|
|
|
|
builder
|
|
|
|
|
.Append(" ENCODING ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier("UTF8"));
|
|
|
|
|
|
|
|
|
|
if (operation.Tablespace != null)
|
|
|
|
|
{
|
|
|
|
|
builder
|
|
|
|
|
.Append(" TABLESPACE ")
|
|
|
|
|
.Append(Dependencies.SqlGenerationHelper.DelimitIdentifier(operation.Tablespace));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
builder.AppendLine(Dependencies.SqlGenerationHelper.StatementTerminator);
|
|
|
|
|
|
|
|
|
|
EndStatement(builder, suppressTransaction: true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-27 10:53:04 +02:00
|
|
|
|
public void ConfigureBuilder(DbContextOptionsBuilder builder)
|
|
|
|
|
{
|
|
|
|
|
if (_Type == DatabaseType.Sqlite)
|
2019-08-29 17:24:42 +02:00
|
|
|
|
builder.UseSqlite(_ConnectionString, o => o.MigrationsAssembly("BTCPayServer.Data"));
|
2017-10-27 10:53:04 +02:00
|
|
|
|
else if (_Type == DatabaseType.Postgres)
|
2018-06-05 05:51:37 +02:00
|
|
|
|
builder
|
2019-09-06 10:49:38 +02:00
|
|
|
|
.UseNpgsql(_ConnectionString, o => o.MigrationsAssembly("BTCPayServer.Data").EnableRetryOnFailure(10))
|
2018-06-05 05:51:37 +02:00
|
|
|
|
.ReplaceService<IMigrationsSqlGenerator, CustomNpgsqlMigrationsSqlGenerator>();
|
2018-10-27 16:15:21 +02:00
|
|
|
|
else if (_Type == DatabaseType.MySQL)
|
2019-09-06 10:49:38 +02:00
|
|
|
|
builder.UseMySql(_ConnectionString, o => o.MigrationsAssembly("BTCPayServer.Data").EnableRetryOnFailure(10));
|
2017-10-27 10:53:04 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2017-09-13 08:47:34 +02:00
|
|
|
|
}
|