122 lines
4.8 KiB
C#
122 lines
4.8 KiB
C#
using System;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Identity;
|
|
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore.Migrations;
|
|
using Microsoft.Extensions.Configuration;
|
|
using Oqtane.Databases.Interfaces;
|
|
using Oqtane.Extensions;
|
|
using Oqtane.Infrastructure;
|
|
using Oqtane.Migrations.Framework;
|
|
using Oqtane.Models;
|
|
using Oqtane.Repository.Databases.Interfaces;
|
|
using Oqtane.Shared;
|
|
|
|
// ReSharper disable CheckNamespace
|
|
// ReSharper disable MemberCanBePrivate.Global
|
|
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
|
|
|
namespace Oqtane.Repository
|
|
{
|
|
public class TenantDBContext : IdentityUserContext<IdentityUser>, IMultiDatabase
|
|
{
|
|
private readonly ITenantManager _tenantManager;
|
|
private readonly IHttpContextAccessor _accessor;
|
|
private readonly IConfigurationRoot _config;
|
|
private string _connectionString = "";
|
|
private string _databaseType = "";
|
|
|
|
public TenantDBContext(DbContextOptions<TenantDBContext> options, IDBContextDependencies DBContextDependencies) : base(options)
|
|
{
|
|
_tenantManager = DBContextDependencies.TenantManager;
|
|
_accessor = DBContextDependencies.Accessor;
|
|
_config = DBContextDependencies.Config;
|
|
}
|
|
|
|
public IDatabase ActiveDatabase { get; set; }
|
|
|
|
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
|
{
|
|
optionsBuilder.ReplaceService<IMigrationsAssembly, MultiDatabaseMigrationsAssembly>();
|
|
|
|
if (string.IsNullOrEmpty(_connectionString))
|
|
{
|
|
Tenant tenant = _tenantManager.GetTenant();
|
|
if (tenant != null)
|
|
{
|
|
_connectionString = _config.GetConnectionString(tenant.DBConnectionString);
|
|
if (_connectionString != null)
|
|
{
|
|
_connectionString = _connectionString.Replace($"|{Constants.DataDirectory}|", AppDomain.CurrentDomain.GetData(Constants.DataDirectory)?.ToString());
|
|
_databaseType = tenant.DBType;
|
|
}
|
|
else
|
|
{
|
|
// tenant connection string does not exist in appsettings.json
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!string.IsNullOrEmpty(_databaseType))
|
|
{
|
|
var type = Type.GetType(_databaseType);
|
|
ActiveDatabase = Activator.CreateInstance(type) as IDatabase;
|
|
}
|
|
|
|
if (!string.IsNullOrEmpty(_connectionString) && ActiveDatabase != null)
|
|
{
|
|
optionsBuilder.UseOqtaneDatabase(ActiveDatabase, _connectionString);
|
|
}
|
|
|
|
base.OnConfiguring(optionsBuilder);
|
|
}
|
|
|
|
protected override void OnModelCreating(ModelBuilder builder)
|
|
{
|
|
base.OnModelCreating(builder);
|
|
|
|
ActiveDatabase.UpdateIdentityStoreTableNames(builder);
|
|
}
|
|
|
|
public override int SaveChanges()
|
|
{
|
|
DbContextUtils.SaveChanges(this, _accessor);
|
|
|
|
return base.SaveChanges();
|
|
}
|
|
|
|
public override Task<int> SaveChangesAsync(CancellationToken cancellationToken = default)
|
|
{
|
|
DbContextUtils.SaveChanges(this, _accessor);
|
|
|
|
return base.SaveChangesAsync(cancellationToken);
|
|
}
|
|
|
|
public virtual DbSet<Site> Site { get; set; }
|
|
public virtual DbSet<Page> Page { get; set; }
|
|
public virtual DbSet<PageModule> PageModule { get; set; }
|
|
public virtual DbSet<Module> Module { get; set; }
|
|
public virtual DbSet<User> User { get; set; }
|
|
public virtual DbSet<Profile> Profile { get; set; }
|
|
public virtual DbSet<Role> Role { get; set; }
|
|
public virtual DbSet<UserRole> UserRole { get; set; }
|
|
public virtual DbSet<Permission> Permission { get; set; }
|
|
public virtual DbSet<Setting> Setting { get; set; }
|
|
public virtual DbSet<Log> Log { get; set; }
|
|
public virtual DbSet<Notification> Notification { get; set; }
|
|
public virtual DbSet<Folder> Folder { get; set; }
|
|
public virtual DbSet<File> File { get; set; }
|
|
public virtual DbSet<Language> Language { get; set; }
|
|
public virtual DbSet<Visitor> Visitor { get; set; }
|
|
public virtual DbSet<UrlMapping> UrlMapping { get; set; }
|
|
public virtual DbSet<SearchContent> SearchContent { get; set; }
|
|
public virtual DbSet<SearchContentProperty> SearchContentProperty { get; set; }
|
|
public virtual DbSet<SearchContentWord> SearchContentWord { get; set; }
|
|
public virtual DbSet<SearchWord> SearchWord { get; set; }
|
|
public virtual DbSet<MigrationHistory> MigrationHistory { get; set; }
|
|
}
|
|
}
|