2020-06-29 04:44:35 +02:00
|
|
|
using System;
|
2019-08-29 17:24:42 +02:00
|
|
|
using System.Linq;
|
2017-09-13 08:47:34 +02:00
|
|
|
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
2020-01-19 13:57:50 +01:00
|
|
|
using Microsoft.EntityFrameworkCore.Design;
|
2017-09-27 15:09:59 +02:00
|
|
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
2017-09-13 08:47:34 +02:00
|
|
|
|
|
|
|
namespace BTCPayServer.Data
|
|
|
|
{
|
2020-01-19 13:57:50 +01:00
|
|
|
public class DesignTimeDbContextFactory : IDesignTimeDbContextFactory<ApplicationDbContext>
|
2017-10-27 10:53:04 +02:00
|
|
|
{
|
2020-01-19 13:57:50 +01:00
|
|
|
public ApplicationDbContext CreateDbContext(string[] args)
|
2017-10-27 10:53:04 +02:00
|
|
|
{
|
2020-05-28 21:38:17 +02:00
|
|
|
|
2020-01-19 13:57:50 +01:00
|
|
|
var builder = new DbContextOptionsBuilder<ApplicationDbContext>();
|
2020-05-28 21:38:17 +02:00
|
|
|
|
2020-01-19 13:57:50 +01:00
|
|
|
builder.UseSqlite("Data Source=temp.db");
|
2020-05-28 21:38:17 +02:00
|
|
|
|
2020-01-19 13:57:50 +01:00
|
|
|
return new ApplicationDbContext(builder.Options, true);
|
2017-10-27 10:53:04 +02:00
|
|
|
}
|
2020-01-19 13:57:50 +01:00
|
|
|
}
|
2020-05-28 21:38:17 +02:00
|
|
|
|
2020-01-19 13:57:50 +01:00
|
|
|
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
|
|
|
|
{
|
|
|
|
private readonly bool _designTime;
|
2019-12-15 13:58:16 +01:00
|
|
|
|
2020-01-19 13:57:50 +01:00
|
|
|
public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options, bool designTime = false)
|
2017-10-27 10:53:04 +02:00
|
|
|
: base(options)
|
|
|
|
{
|
2020-01-19 13:57:50 +01:00
|
|
|
_designTime = designTime;
|
2017-10-27 10:53:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public DbSet<InvoiceData> Invoices
|
|
|
|
{
|
|
|
|
get; set;
|
|
|
|
}
|
2020-06-24 10:51:00 +02:00
|
|
|
public DbSet<RefundData> Refunds
|
|
|
|
{
|
|
|
|
get; set;
|
|
|
|
}
|
2017-10-27 10:53:04 +02:00
|
|
|
|
2020-04-13 08:17:28 +02:00
|
|
|
public DbSet<PlannedTransaction> PlannedTransactions { get; set; }
|
2020-04-13 08:43:25 +02:00
|
|
|
public DbSet<PayjoinLock> PayjoinLocks { get; set; }
|
2020-05-28 21:38:17 +02:00
|
|
|
public DbSet<AppData> Apps { get; set; }
|
|
|
|
public DbSet<InvoiceEventData> InvoiceEvents { get; set; }
|
2020-04-16 07:25:52 +02:00
|
|
|
public DbSet<OffchainTransactionData> OffchainTransactions { get; set; }
|
2020-05-28 21:38:17 +02:00
|
|
|
public DbSet<HistoricalAddressInvoiceData> HistoricalAddressInvoices { get; set; }
|
|
|
|
public DbSet<PendingInvoiceData> PendingInvoices { get; set; }
|
|
|
|
public DbSet<PaymentData> Payments { get; set; }
|
|
|
|
public DbSet<PaymentRequestData> PaymentRequests { get; set; }
|
2020-06-24 03:34:09 +02:00
|
|
|
public DbSet<PullPaymentData> PullPayments { get; set; }
|
|
|
|
public DbSet<PayoutData> Payouts { get; set; }
|
2019-08-02 17:42:30 +02:00
|
|
|
public DbSet<WalletData> Wallets { get; set; }
|
|
|
|
public DbSet<WalletTransactionData> WalletTransactions { get; set; }
|
2020-05-28 21:38:17 +02:00
|
|
|
public DbSet<StoreData> Stores { get; set; }
|
|
|
|
public DbSet<UserStore> UserStore { get; set; }
|
|
|
|
public DbSet<AddressInvoiceData> AddressInvoices { get; set; }
|
|
|
|
public DbSet<SettingData> Settings { get; set; }
|
|
|
|
public DbSet<PairingCodeData> PairingCodes { get; set; }
|
|
|
|
public DbSet<PairedSINData> PairedSINData { get; set; }
|
|
|
|
public DbSet<APIKeyData> ApiKeys { get; set; }
|
|
|
|
public DbSet<StoredFile> Files { get; set; }
|
|
|
|
public DbSet<U2FDevice> U2FDevices { get; set; }
|
2020-05-28 22:15:24 +02:00
|
|
|
public DbSet<NotificationData> Notifications { get; set; }
|
2019-08-02 17:42:30 +02:00
|
|
|
|
2017-10-27 10:53:04 +02:00
|
|
|
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
|
|
|
{
|
|
|
|
var isConfigured = optionsBuilder.Options.Extensions.OfType<RelationalOptionsExtension>().Any();
|
|
|
|
if (!isConfigured)
|
|
|
|
optionsBuilder.UseSqlite("Data Source=temp.db");
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override void OnModelCreating(ModelBuilder builder)
|
|
|
|
{
|
|
|
|
base.OnModelCreating(builder);
|
2020-05-28 22:15:24 +02:00
|
|
|
NotificationData.OnModelCreating(builder);
|
2020-06-27 14:55:16 +02:00
|
|
|
InvoiceData.OnModelCreating(builder);
|
|
|
|
PaymentData.OnModelCreating(builder);
|
|
|
|
Data.UserStore.OnModelCreating(builder);
|
|
|
|
APIKeyData.OnModelCreating(builder);
|
|
|
|
AppData.OnModelCreating(builder);
|
|
|
|
AddressInvoiceData.OnModelCreating(builder);
|
|
|
|
PairingCodeData.OnModelCreating(builder);
|
|
|
|
PendingInvoiceData.OnModelCreating(builder);
|
|
|
|
Data.PairedSINData.OnModelCreating(builder);
|
|
|
|
HistoricalAddressInvoiceData.OnModelCreating(builder);
|
|
|
|
InvoiceEventData.OnModelCreating(builder);
|
|
|
|
PaymentRequestData.OnModelCreating(builder);
|
|
|
|
WalletTransactionData.OnModelCreating(builder);
|
2020-06-24 03:34:09 +02:00
|
|
|
PullPaymentData.OnModelCreating(builder);
|
|
|
|
PayoutData.OnModelCreating(builder);
|
2020-06-24 10:51:00 +02:00
|
|
|
RefundData.OnModelCreating(builder);
|
2020-10-06 17:56:55 +02:00
|
|
|
U2FDevice.OnModelCreating(builder);
|
|
|
|
|
2020-03-09 09:44:44 +01:00
|
|
|
if (Database.IsSqlite() && !_designTime)
|
|
|
|
{
|
|
|
|
// SQLite does not have proper support for DateTimeOffset via Entity Framework Core, see the limitations
|
|
|
|
// here: https://docs.microsoft.com/en-us/ef/core/providers/sqlite/limitations#query-limitations
|
|
|
|
// To work around this, when the Sqlite database provider is used, all model properties of type DateTimeOffset
|
|
|
|
// use the DateTimeOffsetToBinaryConverter
|
|
|
|
// Based on: https://github.com/aspnet/EntityFrameworkCore/issues/10784#issuecomment-415769754
|
|
|
|
// This only supports millisecond precision, but should be sufficient for most use cases.
|
|
|
|
foreach (var entityType in builder.Model.GetEntityTypes())
|
|
|
|
{
|
|
|
|
var properties = entityType.ClrType.GetProperties().Where(p => p.PropertyType == typeof(DateTimeOffset));
|
|
|
|
foreach (var property in properties)
|
|
|
|
{
|
|
|
|
builder
|
|
|
|
.Entity(entityType.Name)
|
|
|
|
.Property(property.Name)
|
|
|
|
.HasConversion(new Microsoft.EntityFrameworkCore.Storage.ValueConversion.DateTimeOffsetToBinaryConverter());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2017-10-27 10:53:04 +02:00
|
|
|
}
|
|
|
|
}
|
2019-05-02 14:01:08 +02:00
|
|
|
|
2017-09-13 08:47:34 +02:00
|
|
|
}
|