New: Report-System using globally available Interfaces.
This commit is contained in:
27
Server/Repository/AdminModules/AdminModulesContext.cs
Normal file
27
Server/Repository/AdminModules/AdminModulesContext.cs
Normal file
@@ -0,0 +1,27 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Oqtane.Modules;
|
||||
using Oqtane.Repository;
|
||||
using Oqtane.Infrastructure;
|
||||
using Oqtane.Repository.Databases.Interfaces;
|
||||
using SZUAbsolventenverein.Module.ReportSystem.Models;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.AdminModules.Repository
|
||||
{
|
||||
public class AdminModulesContext : DBContextBase, ITransientService, IMultiDatabase
|
||||
{
|
||||
public virtual DbSet<Models.AdminModules> AdminModules { get; set; }
|
||||
|
||||
public AdminModulesContext(IDBContextDependencies DBContextDependencies) : base(DBContextDependencies)
|
||||
{
|
||||
// ContextBase handles multi-tenant database connections
|
||||
}
|
||||
|
||||
protected override void OnModelCreating(ModelBuilder builder)
|
||||
{
|
||||
base.OnModelCreating(builder);
|
||||
|
||||
builder.Entity<Models.AdminModules>().ToTable(ActiveDatabase.RewriteName("SZUAbsolventenvereinAdminModules"));
|
||||
}
|
||||
}
|
||||
}
|
||||
75
Server/Repository/AdminModules/AdminModulesRepository.cs
Normal file
75
Server/Repository/AdminModules/AdminModulesRepository.cs
Normal file
@@ -0,0 +1,75 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using System.Linq;
|
||||
using System.Collections.Generic;
|
||||
using Oqtane.Modules;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.AdminModules.Repository
|
||||
{
|
||||
public interface IAdminModulesRepository
|
||||
{
|
||||
IEnumerable<Models.AdminModules> GetAdminModuless(int ModuleId);
|
||||
Models.AdminModules GetAdminModules(int AdminModulesId);
|
||||
Models.AdminModules GetAdminModules(int AdminModulesId, bool tracking);
|
||||
Models.AdminModules AddAdminModules(Models.AdminModules AdminModules);
|
||||
Models.AdminModules UpdateAdminModules(Models.AdminModules AdminModules);
|
||||
void DeleteAdminModules(int AdminModulesId);
|
||||
}
|
||||
|
||||
public class AdminModulesRepository : IAdminModulesRepository, ITransientService
|
||||
{
|
||||
private readonly IDbContextFactory<AdminModulesContext> _factory;
|
||||
|
||||
public AdminModulesRepository(IDbContextFactory<AdminModulesContext> factory)
|
||||
{
|
||||
_factory = factory;
|
||||
}
|
||||
|
||||
public IEnumerable<Models.AdminModules> GetAdminModuless(int ModuleId)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
return db.AdminModules.Where(item => item.ModuleId == ModuleId).ToList();
|
||||
}
|
||||
|
||||
public Models.AdminModules GetAdminModules(int AdminModulesId)
|
||||
{
|
||||
return GetAdminModules(AdminModulesId, true);
|
||||
}
|
||||
|
||||
public Models.AdminModules GetAdminModules(int AdminModulesId, bool tracking)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
if (tracking)
|
||||
{
|
||||
return db.AdminModules.Find(AdminModulesId);
|
||||
}
|
||||
else
|
||||
{
|
||||
return db.AdminModules.AsNoTracking().FirstOrDefault(item => item.AdminModulesId == AdminModulesId);
|
||||
}
|
||||
}
|
||||
|
||||
public Models.AdminModules AddAdminModules(Models.AdminModules AdminModules)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
db.AdminModules.Add(AdminModules);
|
||||
db.SaveChanges();
|
||||
return AdminModules;
|
||||
}
|
||||
|
||||
public Models.AdminModules UpdateAdminModules(Models.AdminModules AdminModules)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
db.Entry(AdminModules).State = EntityState.Modified;
|
||||
db.SaveChanges();
|
||||
return AdminModules;
|
||||
}
|
||||
|
||||
public void DeleteAdminModules(int AdminModulesId)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
Models.AdminModules AdminModules = db.AdminModules.Find(AdminModulesId);
|
||||
db.AdminModules.Remove(AdminModules);
|
||||
db.SaveChanges();
|
||||
}
|
||||
}
|
||||
}
|
||||
24
Server/Repository/ReportingSystem/ReportingContext.cs
Normal file
24
Server/Repository/ReportingSystem/ReportingContext.cs
Normal file
@@ -0,0 +1,24 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Oqtane.Modules;
|
||||
using Oqtane.Repository;
|
||||
using Oqtane.Infrastructure;
|
||||
using Oqtane.Repository.Databases.Interfaces;
|
||||
using SZUAbsolventenverein.Module.ReportSystem.Models;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.AdminModules.Repository
|
||||
{
|
||||
public class ReportingContext : DBContextBase, ITransientService, IMultiDatabase
|
||||
{
|
||||
public virtual DbSet<Reporting> Reportings { get; set; }
|
||||
|
||||
public ReportingContext(IDBContextDependencies DBContextDependencies) : base(DBContextDependencies)
|
||||
{}
|
||||
|
||||
protected override void OnModelCreating(ModelBuilder builder)
|
||||
{
|
||||
base.OnModelCreating(builder);
|
||||
builder.Entity<Reporting>().ToTable(ActiveDatabase.RewriteName("SZUAbsolventenvereinReportings"));
|
||||
}
|
||||
}
|
||||
}
|
||||
77
Server/Repository/ReportingSystem/ReportingRepository.cs
Normal file
77
Server/Repository/ReportingSystem/ReportingRepository.cs
Normal file
@@ -0,0 +1,77 @@
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using System.Linq;
|
||||
using System.Collections.Generic;
|
||||
using Oqtane.Modules;
|
||||
using SZUAbsolventenverein.Module.AdminModules.Repository;
|
||||
using SZUAbsolventenverein.Module.ReportSystem.Models;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.ReportSystem.Repository
|
||||
{
|
||||
public interface IReportingRepository
|
||||
{
|
||||
IEnumerable<Reporting> GetReportings();
|
||||
Reporting GetReporting(int ReportingID);
|
||||
Reporting GetReporting(int ReportingID, bool tracking);
|
||||
Reporting AddReporting(Reporting Reporting);
|
||||
Reporting UpdateReporting(Reporting Reporting);
|
||||
void DeleteReporting(int ReportingID);
|
||||
}
|
||||
|
||||
public class ReportingRepository : IReportingRepository, ITransientService
|
||||
{
|
||||
private readonly IDbContextFactory<ReportingContext> _factory;
|
||||
|
||||
public ReportingRepository(IDbContextFactory<ReportingContext> factory)
|
||||
{
|
||||
_factory = factory;
|
||||
}
|
||||
|
||||
public IEnumerable<Reporting> GetReportings()
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
return db.Reportings.ToList();
|
||||
}
|
||||
|
||||
public Reporting GetReporting(int ReportingID)
|
||||
{
|
||||
return GetReporting(ReportingID, true);
|
||||
}
|
||||
|
||||
public Reporting GetReporting(int ReportingID, bool tracking)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
if (tracking)
|
||||
{
|
||||
return db.Reportings.Find(ReportingID);
|
||||
}
|
||||
else
|
||||
{
|
||||
return db.Reportings.AsNoTracking().FirstOrDefault(item => item.ReportingID == ReportingID);
|
||||
}
|
||||
}
|
||||
|
||||
public Reporting AddReporting(Reporting Reporting)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
db.Reportings.Add(Reporting);
|
||||
db.SaveChanges();
|
||||
return Reporting;
|
||||
}
|
||||
|
||||
public Reporting UpdateReporting(Reporting Reporting)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
db.Entry(Reporting).State = EntityState.Modified;
|
||||
db.SaveChanges();
|
||||
return Reporting;
|
||||
}
|
||||
|
||||
public void DeleteReporting(int ReportingID)
|
||||
{
|
||||
using var db = _factory.CreateDbContext();
|
||||
var Reporting = db.Reportings.Find(ReportingID);
|
||||
db.Reportings.Remove(Reporting);
|
||||
db.SaveChanges();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user