Granular permission back end done

This commit is contained in:
2026-04-11 19:03:45 +09:30
parent 3fe90355e0
commit 611f695db6
51 changed files with 3322 additions and 803 deletions
@@ -0,0 +1,499 @@
// <auto-generated />
using System;
using FJPSite.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace FJPSite.Migrations
{
[DbContext(typeof(ApplicationDbContext))]
[Migration("20260409010423_CreateIdentity")]
partial class CreateIdentity
{
/// <inheritdoc />
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "10.0.5")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("FJPSite.Data.Authorisation.Action", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Action");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Feature");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ActionId")
.HasColumnType("int");
b.Property<int>("FeatureId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("ActionId");
b.HasIndex("FeatureId");
b.ToTable("FeatureAction");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<bool>("IsActive")
.HasColumnType("bit");
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Module");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureId")
.HasColumnType("int");
b.Property<int>("ModuleId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("FeatureId");
b.HasIndex("ModuleId");
b.ToTable("ModuleFeature");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureActionId")
.HasColumnType("int");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("FeatureActionId");
b.HasIndex("RoleId");
b.ToTable("RolePermission");
});
modelBuilder.Entity("FJPSite.Data.Identity.UserEntity", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<int>("AccessFailedCount")
.HasColumnType("int");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Email")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<bool>("EmailConfirmed")
.HasColumnType("bit");
b.Property<string>("Firstname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("LockoutEnabled")
.HasColumnType("bit");
b.Property<DateTimeOffset?>("LockoutEnd")
.HasColumnType("datetimeoffset");
b.Property<string>("NormalizedEmail")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedUserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("PasswordHash")
.HasColumnType("nvarchar(max)");
b.Property<string>("PhoneNumber")
.HasColumnType("nvarchar(max)");
b.Property<bool>("PhoneNumberConfirmed")
.HasColumnType("bit");
b.Property<string>("SecurityStamp")
.HasColumnType("nvarchar(max)");
b.Property<string>("Surname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("TwoFactorEnabled")
.HasColumnType("bit");
b.Property<string>("UserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedEmail")
.HasDatabaseName("EmailIndex");
b.HasIndex("NormalizedUserName")
.IsUnique()
.HasDatabaseName("UserNameIndex")
.HasFilter("[NormalizedUserName] IS NOT NULL");
b.ToTable("AspNetUsers", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Identity.UserRole", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Name")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedName")
.IsUnique()
.HasDatabaseName("RoleNameIndex")
.HasFilter("[NormalizedName] IS NOT NULL");
b.ToTable("AspNetRoles", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("RoleId");
b.ToTable("AspNetRoleClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("UserId");
b.ToTable("AspNetUserClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderKey")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderDisplayName")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("LoginProvider", "ProviderKey");
b.HasIndex("UserId");
b.ToTable("AspNetUserLogins", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("RoleId")
.HasColumnType("nvarchar(450)");
b.HasKey("UserId", "RoleId");
b.HasIndex("RoleId");
b.ToTable("AspNetUserRoles", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Name")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Value")
.HasColumnType("nvarchar(max)");
b.HasKey("UserId", "LoginProvider", "Name");
b.ToTable("AspNetUserTokens", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.HasOne("FJPSite.Data.Authorisation.Action", "Action")
.WithMany("Features")
.HasForeignKey("ActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Actions")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Action");
b.Navigation("Feature");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Modules")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Module", "Module")
.WithMany("Features")
.HasForeignKey("ModuleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Feature");
b.Navigation("Module");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.HasOne("FJPSite.Data.Authorisation.FeatureAction", "FeatureAction")
.WithMany("RolePermissions")
.HasForeignKey("FeatureActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserRole", "Role")
.WithMany("Permissions")
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("FeatureAction");
b.Navigation("Role");
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserRole", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserRole", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Action", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Navigation("Actions");
b.Navigation("Modules");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Navigation("RolePermissions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Identity.UserRole", b =>
{
b.Navigation("Permissions");
});
#pragma warning restore 612, 618
}
}
}
@@ -0,0 +1,392 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace FJPSite.Migrations
{
/// <inheritdoc />
public partial class CreateIdentity : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "Action",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
Name = table.Column<string>(type: "nvarchar(max)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Action", x => x.Id);
});
migrationBuilder.CreateTable(
name: "AspNetRoles",
columns: table => new
{
Id = table.Column<string>(type: "nvarchar(450)", nullable: false),
Name = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
NormalizedName = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
ConcurrencyStamp = table.Column<string>(type: "nvarchar(max)", nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetRoles", x => x.Id);
});
migrationBuilder.CreateTable(
name: "AspNetUsers",
columns: table => new
{
Id = table.Column<string>(type: "nvarchar(450)", nullable: false),
Firstname = table.Column<string>(type: "nvarchar(max)", nullable: false),
Surname = table.Column<string>(type: "nvarchar(max)", nullable: false),
UserName = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
NormalizedUserName = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
Email = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
NormalizedEmail = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: true),
EmailConfirmed = table.Column<bool>(type: "bit", nullable: false),
PasswordHash = table.Column<string>(type: "nvarchar(max)", nullable: true),
SecurityStamp = table.Column<string>(type: "nvarchar(max)", nullable: true),
ConcurrencyStamp = table.Column<string>(type: "nvarchar(max)", nullable: true),
PhoneNumber = table.Column<string>(type: "nvarchar(max)", nullable: true),
PhoneNumberConfirmed = table.Column<bool>(type: "bit", nullable: false),
TwoFactorEnabled = table.Column<bool>(type: "bit", nullable: false),
LockoutEnd = table.Column<DateTimeOffset>(type: "datetimeoffset", nullable: true),
LockoutEnabled = table.Column<bool>(type: "bit", nullable: false),
AccessFailedCount = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUsers", x => x.Id);
});
migrationBuilder.CreateTable(
name: "Feature",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
Name = table.Column<string>(type: "nvarchar(max)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Feature", x => x.Id);
});
migrationBuilder.CreateTable(
name: "Module",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
Name = table.Column<string>(type: "nvarchar(max)", nullable: false),
IsActive = table.Column<bool>(type: "bit", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Module", x => x.Id);
});
migrationBuilder.CreateTable(
name: "AspNetRoleClaims",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
RoleId = table.Column<string>(type: "nvarchar(450)", nullable: false),
ClaimType = table.Column<string>(type: "nvarchar(max)", nullable: true),
ClaimValue = table.Column<string>(type: "nvarchar(max)", nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetRoleClaims", x => x.Id);
table.ForeignKey(
name: "FK_AspNetRoleClaims_AspNetRoles_RoleId",
column: x => x.RoleId,
principalTable: "AspNetRoles",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "AspNetUserClaims",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
UserId = table.Column<string>(type: "nvarchar(450)", nullable: false),
ClaimType = table.Column<string>(type: "nvarchar(max)", nullable: true),
ClaimValue = table.Column<string>(type: "nvarchar(max)", nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUserClaims", x => x.Id);
table.ForeignKey(
name: "FK_AspNetUserClaims_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "AspNetUserLogins",
columns: table => new
{
LoginProvider = table.Column<string>(type: "nvarchar(128)", maxLength: 128, nullable: false),
ProviderKey = table.Column<string>(type: "nvarchar(128)", maxLength: 128, nullable: false),
ProviderDisplayName = table.Column<string>(type: "nvarchar(max)", nullable: true),
UserId = table.Column<string>(type: "nvarchar(450)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUserLogins", x => new { x.LoginProvider, x.ProviderKey });
table.ForeignKey(
name: "FK_AspNetUserLogins_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "AspNetUserRoles",
columns: table => new
{
UserId = table.Column<string>(type: "nvarchar(450)", nullable: false),
RoleId = table.Column<string>(type: "nvarchar(450)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUserRoles", x => new { x.UserId, x.RoleId });
table.ForeignKey(
name: "FK_AspNetUserRoles_AspNetRoles_RoleId",
column: x => x.RoleId,
principalTable: "AspNetRoles",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_AspNetUserRoles_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "AspNetUserTokens",
columns: table => new
{
UserId = table.Column<string>(type: "nvarchar(450)", nullable: false),
LoginProvider = table.Column<string>(type: "nvarchar(128)", maxLength: 128, nullable: false),
Name = table.Column<string>(type: "nvarchar(128)", maxLength: 128, nullable: false),
Value = table.Column<string>(type: "nvarchar(max)", nullable: true)
},
constraints: table =>
{
table.PrimaryKey("PK_AspNetUserTokens", x => new { x.UserId, x.LoginProvider, x.Name });
table.ForeignKey(
name: "FK_AspNetUserTokens_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "FeatureAction",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
FeatureId = table.Column<int>(type: "int", nullable: false),
ActionId = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_FeatureAction", x => x.Id);
table.ForeignKey(
name: "FK_FeatureAction_Action_ActionId",
column: x => x.ActionId,
principalTable: "Action",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_FeatureAction_Feature_FeatureId",
column: x => x.FeatureId,
principalTable: "Feature",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "ModuleFeature",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
ModuleId = table.Column<int>(type: "int", nullable: false),
FeatureId = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_ModuleFeature", x => x.Id);
table.ForeignKey(
name: "FK_ModuleFeature_Feature_FeatureId",
column: x => x.FeatureId,
principalTable: "Feature",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_ModuleFeature_Module_ModuleId",
column: x => x.ModuleId,
principalTable: "Module",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateTable(
name: "RolePermission",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
RoleId = table.Column<string>(type: "nvarchar(450)", nullable: false),
FeatureActionId = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_RolePermission", x => x.Id);
table.ForeignKey(
name: "FK_RolePermission_AspNetRoles_RoleId",
column: x => x.RoleId,
principalTable: "AspNetRoles",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_RolePermission_FeatureAction_FeatureActionId",
column: x => x.FeatureActionId,
principalTable: "FeatureAction",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateIndex(
name: "IX_AspNetRoleClaims_RoleId",
table: "AspNetRoleClaims",
column: "RoleId");
migrationBuilder.CreateIndex(
name: "RoleNameIndex",
table: "AspNetRoles",
column: "NormalizedName",
unique: true,
filter: "[NormalizedName] IS NOT NULL");
migrationBuilder.CreateIndex(
name: "IX_AspNetUserClaims_UserId",
table: "AspNetUserClaims",
column: "UserId");
migrationBuilder.CreateIndex(
name: "IX_AspNetUserLogins_UserId",
table: "AspNetUserLogins",
column: "UserId");
migrationBuilder.CreateIndex(
name: "IX_AspNetUserRoles_RoleId",
table: "AspNetUserRoles",
column: "RoleId");
migrationBuilder.CreateIndex(
name: "EmailIndex",
table: "AspNetUsers",
column: "NormalizedEmail");
migrationBuilder.CreateIndex(
name: "UserNameIndex",
table: "AspNetUsers",
column: "NormalizedUserName",
unique: true,
filter: "[NormalizedUserName] IS NOT NULL");
migrationBuilder.CreateIndex(
name: "IX_FeatureAction_ActionId",
table: "FeatureAction",
column: "ActionId");
migrationBuilder.CreateIndex(
name: "IX_FeatureAction_FeatureId",
table: "FeatureAction",
column: "FeatureId");
migrationBuilder.CreateIndex(
name: "IX_ModuleFeature_FeatureId",
table: "ModuleFeature",
column: "FeatureId");
migrationBuilder.CreateIndex(
name: "IX_ModuleFeature_ModuleId",
table: "ModuleFeature",
column: "ModuleId");
migrationBuilder.CreateIndex(
name: "IX_RolePermission_FeatureActionId",
table: "RolePermission",
column: "FeatureActionId");
migrationBuilder.CreateIndex(
name: "IX_RolePermission_RoleId",
table: "RolePermission",
column: "RoleId");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "AspNetRoleClaims");
migrationBuilder.DropTable(
name: "AspNetUserClaims");
migrationBuilder.DropTable(
name: "AspNetUserLogins");
migrationBuilder.DropTable(
name: "AspNetUserRoles");
migrationBuilder.DropTable(
name: "AspNetUserTokens");
migrationBuilder.DropTable(
name: "ModuleFeature");
migrationBuilder.DropTable(
name: "RolePermission");
migrationBuilder.DropTable(
name: "AspNetUsers");
migrationBuilder.DropTable(
name: "Module");
migrationBuilder.DropTable(
name: "AspNetRoles");
migrationBuilder.DropTable(
name: "FeatureAction");
migrationBuilder.DropTable(
name: "Action");
migrationBuilder.DropTable(
name: "Feature");
}
}
}
@@ -0,0 +1,542 @@
// <auto-generated />
using System;
using FJPSite.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace FJPSite.Migrations
{
[DbContext(typeof(ApplicationDbContext))]
[Migration("20260409123724_CreatePermissions")]
partial class CreatePermissions
{
/// <inheritdoc />
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "10.0.5")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Features");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ActionId")
.HasColumnType("int");
b.Property<int>("FeatureId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("ActionId");
b.HasIndex("FeatureId");
b.ToTable("FeatureActions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<bool>("IsActive")
.HasColumnType("bit");
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Modules");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureId")
.HasColumnType("int");
b.Property<int>("ModuleId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("FeatureId");
b.HasIndex("ModuleId");
b.ToTable("ModuleFeatures");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.PermissionAction", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Actions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureActionId")
.HasColumnType("int");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("FeatureActionId");
b.HasIndex("RoleId");
b.ToTable("RolePermissions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.UserPermission", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureActionId")
.HasColumnType("int");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("FeatureActionId");
b.HasIndex("UserId");
b.ToTable("UserPermissions");
});
modelBuilder.Entity("FJPSite.Data.Identity.RoleEntity", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Name")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedName")
.IsUnique()
.HasDatabaseName("RoleNameIndex")
.HasFilter("[NormalizedName] IS NOT NULL");
b.ToTable("AspNetRoles", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Identity.UserEntity", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<int>("AccessFailedCount")
.HasColumnType("int");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Email")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<bool>("EmailConfirmed")
.HasColumnType("bit");
b.Property<string>("Firstname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("LockoutEnabled")
.HasColumnType("bit");
b.Property<DateTimeOffset?>("LockoutEnd")
.HasColumnType("datetimeoffset");
b.Property<string>("NormalizedEmail")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedUserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("PasswordHash")
.HasColumnType("nvarchar(max)");
b.Property<string>("PhoneNumber")
.HasColumnType("nvarchar(max)");
b.Property<bool>("PhoneNumberConfirmed")
.HasColumnType("bit");
b.Property<string>("SecurityStamp")
.HasColumnType("nvarchar(max)");
b.Property<string>("Surname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("TwoFactorEnabled")
.HasColumnType("bit");
b.Property<string>("UserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedEmail")
.HasDatabaseName("EmailIndex");
b.HasIndex("NormalizedUserName")
.IsUnique()
.HasDatabaseName("UserNameIndex")
.HasFilter("[NormalizedUserName] IS NOT NULL");
b.ToTable("AspNetUsers", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("RoleId");
b.ToTable("AspNetRoleClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("UserId");
b.ToTable("AspNetUserClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderKey")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderDisplayName")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("LoginProvider", "ProviderKey");
b.HasIndex("UserId");
b.ToTable("AspNetUserLogins", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("RoleId")
.HasColumnType("nvarchar(450)");
b.HasKey("UserId", "RoleId");
b.HasIndex("RoleId");
b.ToTable("AspNetUserRoles", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Name")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Value")
.HasColumnType("nvarchar(max)");
b.HasKey("UserId", "LoginProvider", "Name");
b.ToTable("AspNetUserTokens", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.HasOne("FJPSite.Data.Authorisation.PermissionAction", "Action")
.WithMany("Features")
.HasForeignKey("ActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Actions")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Action");
b.Navigation("Feature");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Modules")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Module", "Module")
.WithMany("Features")
.HasForeignKey("ModuleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Feature");
b.Navigation("Module");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.HasOne("FJPSite.Data.Authorisation.FeatureAction", "FeatureAction")
.WithMany("RolePermissions")
.HasForeignKey("FeatureActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.RoleEntity", "Role")
.WithMany("Permissions")
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("FeatureAction");
b.Navigation("Role");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.UserPermission", b =>
{
b.HasOne("FJPSite.Data.Authorisation.FeatureAction", "FeatureAction")
.WithMany()
.HasForeignKey("FeatureActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserEntity", "User")
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("FeatureAction");
b.Navigation("User");
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.RoleEntity", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.RoleEntity", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Navigation("Actions");
b.Navigation("Modules");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Navigation("RolePermissions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.PermissionAction", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Identity.RoleEntity", b =>
{
b.Navigation("Permissions");
});
#pragma warning restore 612, 618
}
}
}
@@ -0,0 +1,423 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace FJPSite.Migrations
{
/// <inheritdoc />
public partial class CreatePermissions : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_FeatureAction_Action_ActionId",
table: "FeatureAction");
migrationBuilder.DropForeignKey(
name: "FK_FeatureAction_Feature_FeatureId",
table: "FeatureAction");
migrationBuilder.DropForeignKey(
name: "FK_ModuleFeature_Feature_FeatureId",
table: "ModuleFeature");
migrationBuilder.DropForeignKey(
name: "FK_ModuleFeature_Module_ModuleId",
table: "ModuleFeature");
migrationBuilder.DropForeignKey(
name: "FK_RolePermission_AspNetRoles_RoleId",
table: "RolePermission");
migrationBuilder.DropForeignKey(
name: "FK_RolePermission_FeatureAction_FeatureActionId",
table: "RolePermission");
migrationBuilder.DropTable(
name: "Action");
migrationBuilder.DropPrimaryKey(
name: "PK_RolePermission",
table: "RolePermission");
migrationBuilder.DropPrimaryKey(
name: "PK_ModuleFeature",
table: "ModuleFeature");
migrationBuilder.DropPrimaryKey(
name: "PK_Module",
table: "Module");
migrationBuilder.DropPrimaryKey(
name: "PK_FeatureAction",
table: "FeatureAction");
migrationBuilder.DropPrimaryKey(
name: "PK_Feature",
table: "Feature");
migrationBuilder.RenameTable(
name: "RolePermission",
newName: "RolePermissions");
migrationBuilder.RenameTable(
name: "ModuleFeature",
newName: "ModuleFeatures");
migrationBuilder.RenameTable(
name: "Module",
newName: "Modules");
migrationBuilder.RenameTable(
name: "FeatureAction",
newName: "FeatureActions");
migrationBuilder.RenameTable(
name: "Feature",
newName: "Features");
migrationBuilder.RenameIndex(
name: "IX_RolePermission_RoleId",
table: "RolePermissions",
newName: "IX_RolePermissions_RoleId");
migrationBuilder.RenameIndex(
name: "IX_RolePermission_FeatureActionId",
table: "RolePermissions",
newName: "IX_RolePermissions_FeatureActionId");
migrationBuilder.RenameIndex(
name: "IX_ModuleFeature_ModuleId",
table: "ModuleFeatures",
newName: "IX_ModuleFeatures_ModuleId");
migrationBuilder.RenameIndex(
name: "IX_ModuleFeature_FeatureId",
table: "ModuleFeatures",
newName: "IX_ModuleFeatures_FeatureId");
migrationBuilder.RenameIndex(
name: "IX_FeatureAction_FeatureId",
table: "FeatureActions",
newName: "IX_FeatureActions_FeatureId");
migrationBuilder.RenameIndex(
name: "IX_FeatureAction_ActionId",
table: "FeatureActions",
newName: "IX_FeatureActions_ActionId");
migrationBuilder.AddPrimaryKey(
name: "PK_RolePermissions",
table: "RolePermissions",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_ModuleFeatures",
table: "ModuleFeatures",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_Modules",
table: "Modules",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_FeatureActions",
table: "FeatureActions",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_Features",
table: "Features",
column: "Id");
migrationBuilder.CreateTable(
name: "Actions",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
Name = table.Column<string>(type: "nvarchar(max)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Actions", x => x.Id);
});
migrationBuilder.CreateTable(
name: "UserPermissions",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
UserId = table.Column<string>(type: "nvarchar(450)", nullable: false),
FeatureActionId = table.Column<int>(type: "int", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_UserPermissions", x => x.Id);
table.ForeignKey(
name: "FK_UserPermissions_AspNetUsers_UserId",
column: x => x.UserId,
principalTable: "AspNetUsers",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
table.ForeignKey(
name: "FK_UserPermissions_FeatureActions_FeatureActionId",
column: x => x.FeatureActionId,
principalTable: "FeatureActions",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
});
migrationBuilder.CreateIndex(
name: "IX_UserPermissions_FeatureActionId",
table: "UserPermissions",
column: "FeatureActionId");
migrationBuilder.CreateIndex(
name: "IX_UserPermissions_UserId",
table: "UserPermissions",
column: "UserId");
migrationBuilder.AddForeignKey(
name: "FK_FeatureActions_Actions_ActionId",
table: "FeatureActions",
column: "ActionId",
principalTable: "Actions",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_FeatureActions_Features_FeatureId",
table: "FeatureActions",
column: "FeatureId",
principalTable: "Features",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ModuleFeatures_Features_FeatureId",
table: "ModuleFeatures",
column: "FeatureId",
principalTable: "Features",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ModuleFeatures_Modules_ModuleId",
table: "ModuleFeatures",
column: "ModuleId",
principalTable: "Modules",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_RolePermissions_AspNetRoles_RoleId",
table: "RolePermissions",
column: "RoleId",
principalTable: "AspNetRoles",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_RolePermissions_FeatureActions_FeatureActionId",
table: "RolePermissions",
column: "FeatureActionId",
principalTable: "FeatureActions",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_FeatureActions_Actions_ActionId",
table: "FeatureActions");
migrationBuilder.DropForeignKey(
name: "FK_FeatureActions_Features_FeatureId",
table: "FeatureActions");
migrationBuilder.DropForeignKey(
name: "FK_ModuleFeatures_Features_FeatureId",
table: "ModuleFeatures");
migrationBuilder.DropForeignKey(
name: "FK_ModuleFeatures_Modules_ModuleId",
table: "ModuleFeatures");
migrationBuilder.DropForeignKey(
name: "FK_RolePermissions_AspNetRoles_RoleId",
table: "RolePermissions");
migrationBuilder.DropForeignKey(
name: "FK_RolePermissions_FeatureActions_FeatureActionId",
table: "RolePermissions");
migrationBuilder.DropTable(
name: "Actions");
migrationBuilder.DropTable(
name: "UserPermissions");
migrationBuilder.DropPrimaryKey(
name: "PK_RolePermissions",
table: "RolePermissions");
migrationBuilder.DropPrimaryKey(
name: "PK_Modules",
table: "Modules");
migrationBuilder.DropPrimaryKey(
name: "PK_ModuleFeatures",
table: "ModuleFeatures");
migrationBuilder.DropPrimaryKey(
name: "PK_Features",
table: "Features");
migrationBuilder.DropPrimaryKey(
name: "PK_FeatureActions",
table: "FeatureActions");
migrationBuilder.RenameTable(
name: "RolePermissions",
newName: "RolePermission");
migrationBuilder.RenameTable(
name: "Modules",
newName: "Module");
migrationBuilder.RenameTable(
name: "ModuleFeatures",
newName: "ModuleFeature");
migrationBuilder.RenameTable(
name: "Features",
newName: "Feature");
migrationBuilder.RenameTable(
name: "FeatureActions",
newName: "FeatureAction");
migrationBuilder.RenameIndex(
name: "IX_RolePermissions_RoleId",
table: "RolePermission",
newName: "IX_RolePermission_RoleId");
migrationBuilder.RenameIndex(
name: "IX_RolePermissions_FeatureActionId",
table: "RolePermission",
newName: "IX_RolePermission_FeatureActionId");
migrationBuilder.RenameIndex(
name: "IX_ModuleFeatures_ModuleId",
table: "ModuleFeature",
newName: "IX_ModuleFeature_ModuleId");
migrationBuilder.RenameIndex(
name: "IX_ModuleFeatures_FeatureId",
table: "ModuleFeature",
newName: "IX_ModuleFeature_FeatureId");
migrationBuilder.RenameIndex(
name: "IX_FeatureActions_FeatureId",
table: "FeatureAction",
newName: "IX_FeatureAction_FeatureId");
migrationBuilder.RenameIndex(
name: "IX_FeatureActions_ActionId",
table: "FeatureAction",
newName: "IX_FeatureAction_ActionId");
migrationBuilder.AddPrimaryKey(
name: "PK_RolePermission",
table: "RolePermission",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_Module",
table: "Module",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_ModuleFeature",
table: "ModuleFeature",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_Feature",
table: "Feature",
column: "Id");
migrationBuilder.AddPrimaryKey(
name: "PK_FeatureAction",
table: "FeatureAction",
column: "Id");
migrationBuilder.CreateTable(
name: "Action",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("SqlServer:Identity", "1, 1"),
Name = table.Column<string>(type: "nvarchar(max)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_Action", x => x.Id);
});
migrationBuilder.AddForeignKey(
name: "FK_FeatureAction_Action_ActionId",
table: "FeatureAction",
column: "ActionId",
principalTable: "Action",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_FeatureAction_Feature_FeatureId",
table: "FeatureAction",
column: "FeatureId",
principalTable: "Feature",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ModuleFeature_Feature_FeatureId",
table: "ModuleFeature",
column: "FeatureId",
principalTable: "Feature",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ModuleFeature_Module_ModuleId",
table: "ModuleFeature",
column: "ModuleId",
principalTable: "Module",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_RolePermission_AspNetRoles_RoleId",
table: "RolePermission",
column: "RoleId",
principalTable: "AspNetRoles",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_RolePermission_FeatureAction_FeatureActionId",
table: "RolePermission",
column: "FeatureActionId",
principalTable: "FeatureAction",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
}
}
}
@@ -0,0 +1,539 @@
// <auto-generated />
using System;
using FJPSite.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace FJPSite.Migrations
{
[DbContext(typeof(ApplicationDbContext))]
partial class ApplicationDbContextModelSnapshot : ModelSnapshot
{
protected override void BuildModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "10.0.5")
.HasAnnotation("Relational:MaxIdentifierLength", 128);
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Features");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ActionId")
.HasColumnType("int");
b.Property<int>("FeatureId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("ActionId");
b.HasIndex("FeatureId");
b.ToTable("FeatureActions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<bool>("IsActive")
.HasColumnType("bit");
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Modules");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureId")
.HasColumnType("int");
b.Property<int>("ModuleId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("FeatureId");
b.HasIndex("ModuleId");
b.ToTable("ModuleFeatures");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.PermissionAction", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("Name")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.HasKey("Id");
b.ToTable("Actions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureActionId")
.HasColumnType("int");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("FeatureActionId");
b.HasIndex("RoleId");
b.ToTable("RolePermissions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.UserPermission", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("FeatureActionId")
.HasColumnType("int");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("FeatureActionId");
b.HasIndex("UserId");
b.ToTable("UserPermissions");
});
modelBuilder.Entity("FJPSite.Data.Identity.RoleEntity", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Name")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedName")
.IsUnique()
.HasDatabaseName("RoleNameIndex")
.HasFilter("[NormalizedName] IS NOT NULL");
b.ToTable("AspNetRoles", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Identity.UserEntity", b =>
{
b.Property<string>("Id")
.HasColumnType("nvarchar(450)");
b.Property<int>("AccessFailedCount")
.HasColumnType("int");
b.Property<string>("ConcurrencyStamp")
.IsConcurrencyToken()
.HasColumnType("nvarchar(max)");
b.Property<string>("Email")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<bool>("EmailConfirmed")
.HasColumnType("bit");
b.Property<string>("Firstname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("LockoutEnabled")
.HasColumnType("bit");
b.Property<DateTimeOffset?>("LockoutEnd")
.HasColumnType("datetimeoffset");
b.Property<string>("NormalizedEmail")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("NormalizedUserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.Property<string>("PasswordHash")
.HasColumnType("nvarchar(max)");
b.Property<string>("PhoneNumber")
.HasColumnType("nvarchar(max)");
b.Property<bool>("PhoneNumberConfirmed")
.HasColumnType("bit");
b.Property<string>("SecurityStamp")
.HasColumnType("nvarchar(max)");
b.Property<string>("Surname")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<bool>("TwoFactorEnabled")
.HasColumnType("bit");
b.Property<string>("UserName")
.HasMaxLength(256)
.HasColumnType("nvarchar(256)");
b.HasKey("Id");
b.HasIndex("NormalizedEmail")
.HasDatabaseName("EmailIndex");
b.HasIndex("NormalizedUserName")
.IsUnique()
.HasDatabaseName("UserNameIndex")
.HasFilter("[NormalizedUserName] IS NOT NULL");
b.ToTable("AspNetUsers", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("RoleId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("RoleId");
b.ToTable("AspNetRoleClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ClaimType")
.HasColumnType("nvarchar(max)");
b.Property<string>("ClaimValue")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("Id");
b.HasIndex("UserId");
b.ToTable("AspNetUserClaims", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderKey")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("ProviderDisplayName")
.HasColumnType("nvarchar(max)");
b.Property<string>("UserId")
.IsRequired()
.HasColumnType("nvarchar(450)");
b.HasKey("LoginProvider", "ProviderKey");
b.HasIndex("UserId");
b.ToTable("AspNetUserLogins", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("RoleId")
.HasColumnType("nvarchar(450)");
b.HasKey("UserId", "RoleId");
b.HasIndex("RoleId");
b.ToTable("AspNetUserRoles", (string)null);
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.Property<string>("UserId")
.HasColumnType("nvarchar(450)");
b.Property<string>("LoginProvider")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Name")
.HasMaxLength(128)
.HasColumnType("nvarchar(128)");
b.Property<string>("Value")
.HasColumnType("nvarchar(max)");
b.HasKey("UserId", "LoginProvider", "Name");
b.ToTable("AspNetUserTokens", (string)null);
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.HasOne("FJPSite.Data.Authorisation.PermissionAction", "Action")
.WithMany("Features")
.HasForeignKey("ActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Actions")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Action");
b.Navigation("Feature");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.ModuleFeature", b =>
{
b.HasOne("FJPSite.Data.Authorisation.Feature", "Feature")
.WithMany("Modules")
.HasForeignKey("FeatureId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Authorisation.Module", "Module")
.WithMany("Features")
.HasForeignKey("ModuleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Feature");
b.Navigation("Module");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.RolePermission", b =>
{
b.HasOne("FJPSite.Data.Authorisation.FeatureAction", "FeatureAction")
.WithMany("RolePermissions")
.HasForeignKey("FeatureActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.RoleEntity", "Role")
.WithMany("Permissions")
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("FeatureAction");
b.Navigation("Role");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.UserPermission", b =>
{
b.HasOne("FJPSite.Data.Authorisation.FeatureAction", "FeatureAction")
.WithMany()
.HasForeignKey("FeatureActionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserEntity", "User")
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("FeatureAction");
b.Navigation("User");
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.RoleEntity", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.RoleEntity", null)
.WithMany()
.HasForeignKey("RoleId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<string>", b =>
{
b.HasOne("FJPSite.Data.Identity.UserEntity", null)
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Feature", b =>
{
b.Navigation("Actions");
b.Navigation("Modules");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.FeatureAction", b =>
{
b.Navigation("RolePermissions");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.Module", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Authorisation.PermissionAction", b =>
{
b.Navigation("Features");
});
modelBuilder.Entity("FJPSite.Data.Identity.RoleEntity", b =>
{
b.Navigation("Permissions");
});
#pragma warning restore 612, 618
}
}
}