Creation of EF Core Migrations - these execute using EF Tools, but are not integrated to run programmatically
This commit is contained in:
@ -0,0 +1,65 @@
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
|
||||
using Oqtane.Migrations.Extensions;
|
||||
|
||||
// ReSharper disable MemberCanBePrivate.Global
|
||||
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
||||
|
||||
namespace Oqtane.Migrations.EntityBuilders
|
||||
{
|
||||
public class NotificationEntityBuilder : DeletableBaseEntityBuilder<NotificationEntityBuilder>
|
||||
{
|
||||
private const string _entityTableName = "Notification";
|
||||
private readonly PrimaryKey<NotificationEntityBuilder> _primaryKey = new("PK_Notification", x => x.NotificationId);
|
||||
private readonly ForeignKey<NotificationEntityBuilder> _siteForeignKey = new("FK_Notification_Site", x => x.SiteId, "Site", "SiteId", ReferentialAction.Cascade);
|
||||
|
||||
public NotificationEntityBuilder(MigrationBuilder migrationBuilder) : base(migrationBuilder)
|
||||
{
|
||||
EntityTableName = _entityTableName;
|
||||
PrimaryKey = _primaryKey;
|
||||
ForeignKeys.Add(_siteForeignKey);
|
||||
}
|
||||
|
||||
protected override NotificationEntityBuilder BuildTable(ColumnsBuilder table)
|
||||
{
|
||||
NotificationId = table.AddAutoIncrementColumn("NotificationId");
|
||||
SiteId = table.AddIntegerColumn("SiteId");
|
||||
FromUserId = table.AddIntegerColumn("FromUserId", true);
|
||||
ToUserId = table.AddIntegerColumn("ToUserId", true);
|
||||
ToEmail = table.AddStringColumn("ToEmail", 256);
|
||||
ParentId = table.AddIntegerColumn("ParentId", true);
|
||||
Subject = table.AddStringColumn("Subject", 256);
|
||||
Body = table.AddMaxStringColumn("Body");
|
||||
CreatedOn = table.AddDateTimeColumn("CreatedOn");
|
||||
IsDelivered = table.AddBooleanColumn("IsDelivered");
|
||||
DeliveredOn = table.AddDateTimeColumn("DeliveredOn", true);
|
||||
|
||||
AddDeletableColumns(table);
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
public OperationBuilder<AddColumnOperation> NotificationId { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> SiteId { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> FromUserId { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> ToUserId { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> ToEmail { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> ParentId { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Subject { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Body { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> CreatedOn { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> IsDelivered { get; set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> DeliveredOn { get; set; }
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user