New: DB-Migration / Repositories und Models für den Premiumbereich
This commit is contained in:
@@ -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; }
|
||||
}
|
||||
}
|
||||
@@ -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; }
|
||||
}
|
||||
}
|
||||
36
Server/Migrations/EntityBuilders/UserPremiumEntityBuilder.cs
Normal file
36
Server/Migrations/EntityBuilders/UserPremiumEntityBuilder.cs
Normal 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; }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user