Fix #3977: use db context factory.

This commit is contained in:
Ben 2024-03-17 21:29:32 +08:00
parent 0f3b0309e8
commit 40cc0f721d

View File

@ -10,15 +10,15 @@ namespace Oqtane.Repository
{
public class PageModuleRepository : IPageModuleRepository
{
private TenantDBContext _db;
private IDbContextFactory<TenantDBContext> _dbContextFactory;
private readonly IModuleDefinitionRepository _moduleDefinitions;
private readonly IModuleRepository _modules;
private readonly IPermissionRepository _permissions;
private readonly ISettingRepository _settings;
public PageModuleRepository(TenantDBContext context, IModuleDefinitionRepository moduleDefinitions, IModuleRepository modules, IPermissionRepository permissions, ISettingRepository settings)
public PageModuleRepository(IDbContextFactory<TenantDBContext> dbContextFactory, IModuleDefinitionRepository moduleDefinitions, IModuleRepository modules, IPermissionRepository permissions, ISettingRepository settings)
{
_db = context;
_dbContextFactory = dbContextFactory;
_moduleDefinitions = moduleDefinitions;
_modules = modules;
_permissions = permissions;
@ -27,7 +27,9 @@ namespace Oqtane.Repository
public IEnumerable<PageModule> GetPageModules(int siteId)
{
var pagemodules = _db.PageModule
using(var db = _dbContextFactory.CreateDbContext())
{
var pagemodules = db.PageModule
.Include(item => item.Module) // eager load modules
.Where(item => item.Module.SiteId == siteId).ToList();
if (pagemodules.Any())
@ -42,19 +44,27 @@ namespace Oqtane.Repository
return pagemodules;
}
}
public PageModule AddPageModule(PageModule pageModule)
{
_db.PageModule.Add(pageModule);
_db.SaveChanges();
using (var db = _dbContextFactory.CreateDbContext())
{
db.PageModule.Add(pageModule);
db.SaveChanges();
return pageModule;
}
}
public PageModule UpdatePageModule(PageModule pageModule)
{
_db.Entry(pageModule).State = EntityState.Modified;
_db.SaveChanges();
using (var db = _dbContextFactory.CreateDbContext())
{
db.Entry(pageModule).State = EntityState.Modified;
db.SaveChanges();
return pageModule;
}
}
public PageModule GetPageModule(int pageModuleId)
{
@ -62,16 +72,18 @@ namespace Oqtane.Repository
}
public PageModule GetPageModule(int pageModuleId, bool tracking)
{
using (var db = _dbContextFactory.CreateDbContext())
{
PageModule pagemodule;
if (tracking)
{
pagemodule = _db.PageModule.Include(item => item.Module) // eager load modules
pagemodule = db.PageModule.Include(item => item.Module) // eager load modules
.FirstOrDefault(item => item.PageModuleId == pageModuleId);
}
else
{
pagemodule = _db.PageModule.AsNoTracking().Include(item => item.Module) // eager load modules
pagemodule = db.PageModule.AsNoTracking().Include(item => item.Module) // eager load modules
.FirstOrDefault(item => item.PageModuleId == pageModuleId);
}
if (pagemodule != null)
@ -82,10 +94,13 @@ namespace Oqtane.Repository
}
return pagemodule;
}
}
public PageModule GetPageModule(int pageId, int moduleId)
{
PageModule pagemodule = _db.PageModule.Include(item => item.Module) // eager load modules
using (var db = _dbContextFactory.CreateDbContext())
{
PageModule pagemodule = db.PageModule.Include(item => item.Module) // eager load modules
.SingleOrDefault(item => item.PageId == pageId && item.ModuleId == moduleId);
if (pagemodule != null)
{
@ -95,14 +110,17 @@ namespace Oqtane.Repository
}
return pagemodule;
}
}
public void DeletePageModule(int pageModuleId)
{
PageModule pageModule = _db.PageModule.Include(item => item.Module) // eager load modules
using (var db = _dbContextFactory.CreateDbContext())
{
PageModule pageModule = db.PageModule.Include(item => item.Module) // eager load modules
.SingleOrDefault(item => item.PageModuleId == pageModuleId);
_settings.DeleteSettings(EntityNames.PageModule, pageModuleId);
_db.PageModule.Remove(pageModule);
_db.SaveChanges();
db.PageModule.Remove(pageModule);
db.SaveChanges();
// check if there are any remaining module instances in the site
var pageModules = GetPageModules(pageModule.Module.SiteId);
@ -111,6 +129,7 @@ namespace Oqtane.Repository
_modules.DeleteModule(pageModule.ModuleId);
}
}
}
private PageModule GetPageModule(PageModule pageModule, List<ModuleDefinition> moduleDefinitions, List<Permission> modulePermissions)
{