using Microsoft.EntityFrameworkCore.Migrations; using Microsoft.EntityFrameworkCore.Migrations.Operations; using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders; using Oqtane.Interfaces; // ReSharper disable MemberCanBePrivate.Global // ReSharper disable UnusedAutoPropertyAccessor.Global namespace Oqtane.Migrations.EntityBuilders { public class UserRoleEntityBuilder : AuditableBaseEntityBuilder { private const string _entityTableName = "UserRole"; private readonly PrimaryKey _primaryKey = new("PK_UserRole", x => x.UserRoleId); private readonly ForeignKey _userForeignKey = new("FK_UserRole_User", x => x.UserId, "User", "UserId", ReferentialAction.Cascade); private readonly ForeignKey _roleForeignKey = new("FK_UserRole_Role", x => x.RoleId, "Role", "RoleId", ReferentialAction.NoAction); public UserRoleEntityBuilder(MigrationBuilder migrationBuilder, IOqtaneDatabase database) : base(migrationBuilder, database) { EntityTableName = _entityTableName; PrimaryKey = _primaryKey; ForeignKeys.Add(_userForeignKey); ForeignKeys.Add(_roleForeignKey); } protected override UserRoleEntityBuilder BuildTable(ColumnsBuilder table) { UserRoleId = AddAutoIncrementColumn(table,"UserRoleId"); UserId = AddIntegerColumn(table,"UserId"); RoleId = AddIntegerColumn(table,"RoleId"); EffectiveDate = AddDateTimeColumn(table,"EffectiveDate", true); ExpiryDate = AddDateTimeColumn(table,"ExpiryDate", true); AddAuditableColumns(table); return this; } public OperationBuilder UserRoleId { get; set; } public OperationBuilder UserId { get; set; } public OperationBuilder RoleId { get; set; } public OperationBuilder EffectiveDate { get; set; } public OperationBuilder ExpiryDate { get; set; } } }