New: DB-Migration / Repositories und Models für den Premiumbereich

This commit is contained in:
2026-02-11 10:51:26 +01:00
parent de2312838b
commit 54f90ea3fb
13 changed files with 558 additions and 2 deletions

View File

@@ -0,0 +1,61 @@
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Migrations.Operations;
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
using Oqtane.Databases.Interfaces;
using Oqtane.Migrations;
using Oqtane.Migrations.EntityBuilders;
using SZUAbsolventenverein.Module.PremiumArea.Models;
namespace SZUAbsolventenverein.Module.PremiumArea.Migrations.EntityBuilders
{
public class EngineerApplicationEntityBuilder : AuditableBaseEntityBuilder<EngineerApplicationEntityBuilder>
{
private const string _entityTableName = "SZUAbsolventenvereinEngineerApplications";
private readonly PrimaryKey<EngineerApplicationEntityBuilder> _primaryKey = new("PK_SZUAbsolventenvereinEngineerApplications", x => x.ApplicationId);
private readonly ForeignKey<EngineerApplicationEntityBuilder> _moduleForeignKey = new("FK_SZUAbsolventenvereinEngineerApplications_Module", x => x.ModuleId, "Module", "ModuleId", ReferentialAction.Cascade);
public EngineerApplicationEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
{
EntityTableName = _entityTableName;
PrimaryKey = _primaryKey;
ForeignKeys.Add(_moduleForeignKey);
}
protected override EngineerApplicationEntityBuilder BuildTable(ColumnsBuilder table)
{
ApplicationId = AddAutoIncrementColumn(table, "ApplicationId");
UserId = AddIntegerColumn(table, "UserId");
ModuleId = AddIntegerColumn(table, "ModuleId");
FileId = AddIntegerColumn(table, "FileId", true);
PdfFileName = AddStringColumn(table, "PdfFileName", 256);
Status = AddStringColumn(table, "Status", 50);
AdminReviewedBy = AddIntegerColumn(table, "AdminReviewedBy", true);
AdminReviewedAt = AddDateTimeColumn(table, "AdminReviewedAt", true);
AdminNote = AddMaxStringColumn(table, "AdminNote");
SubmittedOn = AddDateTimeColumn(table, "SubmittedOn", true);
ApprovedOn = AddDateTimeColumn(table, "ApprovedOn", true);
IsReported = AddBooleanColumn(table, "IsReported", false);
ReportReason = AddMaxStringColumn(table, "ReportReason", true);
ReportCount = AddIntegerColumn(table, "ReportCount", false);
AddAuditableColumns(table);
return this;
}
public OperationBuilder<AddColumnOperation> ApplicationId { get; set; }
public OperationBuilder<AddColumnOperation> UserId { get; set; }
public OperationBuilder<AddColumnOperation> ModuleId { get; set; }
public OperationBuilder<AddColumnOperation> FileId { get; set; }
public OperationBuilder<AddColumnOperation> PdfFileName { get; set; }
public OperationBuilder<AddColumnOperation> Status { get; set; }
public OperationBuilder<AddColumnOperation> AdminReviewedBy { get; set; }
public OperationBuilder<AddColumnOperation> AdminReviewedAt { get; set; }
public OperationBuilder<AddColumnOperation> AdminNote { get; set; }
public OperationBuilder<AddColumnOperation> SubmittedOn { get; set; }
public OperationBuilder<AddColumnOperation> ApprovedOn { get; set; }
public OperationBuilder<AddColumnOperation> IsReported { get; set; }
public OperationBuilder<AddColumnOperation> ReportReason { get; set; }
public OperationBuilder<AddColumnOperation> ReportCount { get; set; }
}
}

View File

@@ -0,0 +1,38 @@
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Migrations.Operations;
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
using Oqtane.Databases.Interfaces;
using Oqtane.Migrations;
using Oqtane.Migrations.EntityBuilders;
namespace SZUAbsolventenverein.Module.PremiumArea.Migrations.EntityBuilders
{
public class PremiumEventEntityBuilder : AuditableBaseEntityBuilder<PremiumEventEntityBuilder>
{
private const string _entityTableName = "SZUAbsolventenvereinPremiumEvents";
private readonly PrimaryKey<PremiumEventEntityBuilder> _primaryKey = new("PK_SZUAbsolventenvereinPremiumEvents", x => x.Id);
public PremiumEventEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
{
EntityTableName = _entityTableName;
PrimaryKey = _primaryKey;
}
protected override PremiumEventEntityBuilder BuildTable(ColumnsBuilder table)
{
Id = AddAutoIncrementColumn(table, "Id");
UserId = AddIntegerColumn(table, "UserId");
DeltaDays = AddIntegerColumn(table, "DeltaDays");
Source = AddStringColumn(table, "Source", 50);
ReferenceId = AddMaxStringColumn(table, "ReferenceId");
AddAuditableColumns(table);
return this;
}
public OperationBuilder<AddColumnOperation> Id { get; set; }
public OperationBuilder<AddColumnOperation> UserId { get; set; }
public OperationBuilder<AddColumnOperation> DeltaDays { get; set; }
public OperationBuilder<AddColumnOperation> Source { get; set; }
public OperationBuilder<AddColumnOperation> ReferenceId { get; set; }
}
}

View File

@@ -0,0 +1,36 @@
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Migrations.Operations;
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
using Oqtane.Databases.Interfaces;
using Oqtane.Migrations;
using Oqtane.Migrations.EntityBuilders;
namespace SZUAbsolventenverein.Module.PremiumArea.Migrations.EntityBuilders
{
public class UserPremiumEntityBuilder : AuditableBaseEntityBuilder<UserPremiumEntityBuilder>
{
private const string _entityTableName = "SZUAbsolventenvereinUserPremium";
private readonly PrimaryKey<UserPremiumEntityBuilder> _primaryKey = new("PK_SZUAbsolventenvereinUserPremium", x => x.Id);
public UserPremiumEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
{
EntityTableName = _entityTableName;
PrimaryKey = _primaryKey;
}
protected override UserPremiumEntityBuilder BuildTable(ColumnsBuilder table)
{
Id = AddAutoIncrementColumn(table, "Id");
UserId = AddIntegerColumn(table, "UserId");
PremiumUntil = AddDateTimeColumn(table, "PremiumUntil", true);
Source = AddStringColumn(table, "Source", 50);
AddAuditableColumns(table);
return this;
}
public OperationBuilder<AddColumnOperation> Id { get; set; }
public OperationBuilder<AddColumnOperation> UserId { get; set; }
public OperationBuilder<AddColumnOperation> PremiumUntil { get; set; }
public OperationBuilder<AddColumnOperation> Source { get; set; }
}
}