46 lines
1.8 KiB
C#
46 lines
1.8 KiB
C#
using Microsoft.EntityFrameworkCore.Migrations;
|
|
using Microsoft.EntityFrameworkCore.Migrations.Operations;
|
|
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
|
|
using Oqtane.Databases.Interfaces;
|
|
using Oqtane.Interfaces;
|
|
|
|
// ReSharper disable MemberCanBePrivate.Global
|
|
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
|
|
|
namespace Oqtane.Migrations.EntityBuilders
|
|
{
|
|
public class AliasEntityBuilder : AuditableBaseEntityBuilder<AliasEntityBuilder>
|
|
{
|
|
private const string _entityTableName = "Alias";
|
|
private readonly PrimaryKey<AliasEntityBuilder> _primaryKey = new("PK_Alias", x => x.AliasId);
|
|
private readonly ForeignKey<AliasEntityBuilder> _tenantForeignKey = new("FK_Alias_Tenant", x => x.TenantId, "Tenant", "TenantId", ReferentialAction.Cascade);
|
|
|
|
public AliasEntityBuilder(MigrationBuilder migrationBuilder, IDatabase database) : base(migrationBuilder, database)
|
|
{
|
|
EntityTableName = _entityTableName;
|
|
PrimaryKey = _primaryKey;
|
|
ForeignKeys.Add(_tenantForeignKey);
|
|
}
|
|
|
|
protected override AliasEntityBuilder BuildTable(ColumnsBuilder table)
|
|
{
|
|
AliasId = AddAutoIncrementColumn(table,"AliasId");
|
|
Name = AddStringColumn(table, "Name", 200);
|
|
TenantId = AddIntegerColumn(table, "TenantId");
|
|
SiteId = AddIntegerColumn(table, "SiteId");
|
|
|
|
AddAuditableColumns(table);
|
|
|
|
return this;
|
|
}
|
|
|
|
public OperationBuilder<AddColumnOperation> AliasId { get; private set; }
|
|
|
|
public OperationBuilder<AddColumnOperation> Name { get; private set; }
|
|
|
|
public OperationBuilder<AddColumnOperation> SiteId { get; private set; }
|
|
|
|
public OperationBuilder<AddColumnOperation> TenantId { get; private set; }
|
|
}
|
|
}
|