New: DB-Migration / Repositories und Models für den Premiumbereich
This commit is contained in:
42
Server/Migrations/01000001_AddPremiumTables.cs
Normal file
42
Server/Migrations/01000001_AddPremiumTables.cs
Normal file
@@ -0,0 +1,42 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations;
|
||||
using SZUAbsolventenverein.Module.PremiumArea.Migrations.EntityBuilders;
|
||||
using SZUAbsolventenverein.Module.PremiumArea.Repository;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.PremiumArea.Migrations
|
||||
{
|
||||
[DbContext(typeof(PremiumAreaContext))]
|
||||
[Migration("SZUAbsolventenverein.Module.PremiumArea.01.00.00.01")]
|
||||
public class AddPremiumTables : MultiDatabaseMigration
|
||||
{
|
||||
public AddPremiumTables(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var engAppBuilder = new EngineerApplicationEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
engAppBuilder.Create();
|
||||
|
||||
var userPremBuilder = new UserPremiumEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
userPremBuilder.Create();
|
||||
|
||||
var premEventBuilder = new PremiumEventEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
premEventBuilder.Create();
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var engAppBuilder = new EngineerApplicationEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
engAppBuilder.Drop();
|
||||
|
||||
var userPremBuilder = new UserPremiumEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
userPremBuilder.Drop();
|
||||
|
||||
var premEventBuilder = new PremiumEventEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
premEventBuilder.Drop();
|
||||
}
|
||||
}
|
||||
}
|
||||
90
Server/Migrations/01000002_AddReportAndFileColumns.cs
Normal file
90
Server/Migrations/01000002_AddReportAndFileColumns.cs
Normal file
@@ -0,0 +1,90 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations;
|
||||
using SZUAbsolventenverein.Module.PremiumArea.Migrations.EntityBuilders;
|
||||
using SZUAbsolventenverein.Module.PremiumArea.Repository;
|
||||
using System;
|
||||
|
||||
namespace SZUAbsolventenverein.Module.PremiumArea.Migrations
|
||||
{
|
||||
[DbContext(typeof(PremiumAreaContext))]
|
||||
[Migration("SZUAbsolventenverein.Module.PremiumArea.01.00.00.02")]
|
||||
public class AddReportAndFileColumns : MultiDatabaseMigration
|
||||
{
|
||||
public AddReportAndFileColumns(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
// Add FileId (nullable int) - assuming missing
|
||||
migrationBuilder.AddColumn<int>(
|
||||
name: "FileId",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
nullable: true);
|
||||
|
||||
// Add PdfFileName (string 256)
|
||||
migrationBuilder.AddColumn<string>(
|
||||
name: "PdfFileName",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
maxLength: 256,
|
||||
nullable: true);
|
||||
|
||||
// Add ApprovedOn (DateTime nullable) - might exist but adding if missing?
|
||||
// MigrationBuilder will fail if exists. We assume schema drift needs this.
|
||||
// If it exists, user must handle.
|
||||
migrationBuilder.AddColumn<DateTime>(
|
||||
name: "ApprovedOn",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
nullable: true);
|
||||
|
||||
// Add IsReported (bool not null default false)
|
||||
migrationBuilder.AddColumn<bool>(
|
||||
name: "IsReported",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
nullable: false,
|
||||
defaultValue: false);
|
||||
|
||||
// Add ReportReason (string max nullable)
|
||||
migrationBuilder.AddColumn<string>(
|
||||
name: "ReportReason",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
nullable: true);
|
||||
|
||||
// Add ReportCount (int not null default 0)
|
||||
migrationBuilder.AddColumn<int>(
|
||||
name: "ReportCount",
|
||||
table: "SZUAbsolventenvereinEngineerApplications",
|
||||
nullable: false,
|
||||
defaultValue: 0);
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
migrationBuilder.DropColumn(
|
||||
name: "IsReported",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
|
||||
migrationBuilder.DropColumn(
|
||||
name: "ReportReason",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
|
||||
migrationBuilder.DropColumn(
|
||||
name: "ReportCount",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
|
||||
migrationBuilder.DropColumn(
|
||||
name: "FileId",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
|
||||
migrationBuilder.DropColumn(
|
||||
name: "PdfFileName",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
|
||||
migrationBuilder.DropColumn(
|
||||
name: "ApprovedOn",
|
||||
table: "SZUAbsolventenvereinEngineerApplications");
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -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