diff --git a/LibraryManagement.Api/Brokers/Storages/StorageBroker.Reader.cs b/LibraryManagement.Api/Brokers/Storages/StorageBroker.Reader.cs new file mode 100644 index 0000000..58bd89a --- /dev/null +++ b/LibraryManagement.Api/Brokers/Storages/StorageBroker.Reader.cs @@ -0,0 +1,15 @@ +//----------------------------------------------------------- +// Copyright (c) Coalition of Good-Hearted Engineers +// Free To Use To Build Reliable Library Management Solutions +//----------------------------------------------------------- + +using LibraryManagement.Api.Models.Foundations.Readers; +using Microsoft.EntityFrameworkCore; + +namespace LibraryManagement.Api.Brokers.Storages +{ + public partial class StorageBroker + { + public DbSet Readers { get; set; } + } +} diff --git a/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.Designer.cs b/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.Designer.cs new file mode 100644 index 0000000..52cd524 --- /dev/null +++ b/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.Designer.cs @@ -0,0 +1,96 @@ +// +using System; +using LibraryManagement.Api.Brokers.Storages; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Infrastructure; +using Microsoft.EntityFrameworkCore.Metadata; +using Microsoft.EntityFrameworkCore.Migrations; +using Microsoft.EntityFrameworkCore.Storage.ValueConversion; + +#nullable disable + +namespace LibraryManagement.Api.Migrations +{ + [DbContext(typeof(StorageBroker))] + [Migration("20250719194034_AddReaderRelationToBook")] + partial class AddReaderRelationToBook + { + /// + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "8.0.18") + .HasAnnotation("Relational:MaxIdentifierLength", 128); + + SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Books.Book", b => + { + b.Property("BookId") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("Author") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("BookTitle") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Genre") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("ReaderId") + .HasColumnType("uniqueidentifier"); + + b.HasKey("BookId"); + + b.HasIndex("ReaderId"); + + b.ToTable("Books"); + }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Readers.Reader", b => + { + b.Property("ReaderId") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DateOfBirth") + .HasColumnType("datetimeoffset"); + + b.Property("FirstName") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("LastName") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("ReaderId"); + + b.ToTable("Readers"); + }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Books.Book", b => + { + b.HasOne("LibraryManagement.Api.Models.Foundations.Readers.Reader", "Reader") + .WithMany("Books") + .HasForeignKey("ReaderId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("Reader"); + }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Readers.Reader", b => + { + b.Navigation("Books"); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.cs b/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.cs new file mode 100644 index 0000000..2da3dcd --- /dev/null +++ b/LibraryManagement.Api/Migrations/20250719194034_AddReaderRelationToBook.cs @@ -0,0 +1,56 @@ +using Microsoft.EntityFrameworkCore.Migrations; + +#nullable disable + +namespace LibraryManagement.Api.Migrations +{ + /// + public partial class AddReaderRelationToBook : Migration + { + /// + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.CreateTable( + name: "Readers", + columns: table => new + { + ReaderId = table.Column(type: "uniqueidentifier", nullable: false), + FirstName = table.Column(type: "nvarchar(max)", nullable: false), + LastName = table.Column(type: "nvarchar(max)", nullable: false), + DateOfBirth = table.Column(type: "datetimeoffset", nullable: false) + }, + constraints: table => + { + table.PrimaryKey("PK_Readers", x => x.ReaderId); + }); + + migrationBuilder.CreateIndex( + name: "IX_Books_ReaderId", + table: "Books", + column: "ReaderId"); + + migrationBuilder.AddForeignKey( + name: "FK_Books_Readers_ReaderId", + table: "Books", + column: "ReaderId", + principalTable: "Readers", + principalColumn: "ReaderId", + onDelete: ReferentialAction.Cascade); + } + + /// + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropForeignKey( + name: "FK_Books_Readers_ReaderId", + table: "Books"); + + migrationBuilder.DropTable( + name: "Readers"); + + migrationBuilder.DropIndex( + name: "IX_Books_ReaderId", + table: "Books"); + } + } +} diff --git a/LibraryManagement.Api/Migrations/StorageBrokerModelSnapshot.cs b/LibraryManagement.Api/Migrations/StorageBrokerModelSnapshot.cs index 5441c5c..11924dd 100644 --- a/LibraryManagement.Api/Migrations/StorageBrokerModelSnapshot.cs +++ b/LibraryManagement.Api/Migrations/StorageBrokerModelSnapshot.cs @@ -45,8 +45,48 @@ protected override void BuildModel(ModelBuilder modelBuilder) b.HasKey("BookId"); + b.HasIndex("ReaderId"); + b.ToTable("Books"); }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Readers.Reader", b => + { + b.Property("ReaderId") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DateOfBirth") + .HasColumnType("datetimeoffset"); + + b.Property("FirstName") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("LastName") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("ReaderId"); + + b.ToTable("Readers"); + }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Books.Book", b => + { + b.HasOne("LibraryManagement.Api.Models.Foundations.Readers.Reader", "Reader") + .WithMany("Books") + .HasForeignKey("ReaderId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("Reader"); + }); + + modelBuilder.Entity("LibraryManagement.Api.Models.Foundations.Readers.Reader", b => + { + b.Navigation("Books"); + }); #pragma warning restore 612, 618 } } diff --git a/LibraryManagement.Api/Models/Foundations/Books/Book.cs b/LibraryManagement.Api/Models/Foundations/Books/Book.cs index a040264..6ea3203 100644 --- a/LibraryManagement.Api/Models/Foundations/Books/Book.cs +++ b/LibraryManagement.Api/Models/Foundations/Books/Book.cs @@ -3,6 +3,8 @@ // Free To Use To Build Reliable Library Management Solutions //----------------------------------------------------------- +using LibraryManagement.Api.Models.Foundations.Readers; + namespace LibraryManagement.Api.Models.Foundations.Books { public class Book @@ -12,5 +14,6 @@ public class Book public string BookTitle { get; set; } public string Author { get; set; } public string Genre { get; set; } + public Reader Reader { get; set; } } } diff --git a/LibraryManagement.Api/Models/Foundations/Readers/Reader.cs b/LibraryManagement.Api/Models/Foundations/Readers/Reader.cs new file mode 100644 index 0000000..e86f5b5 --- /dev/null +++ b/LibraryManagement.Api/Models/Foundations/Readers/Reader.cs @@ -0,0 +1,18 @@ +//----------------------------------------------------------- +// Copyright (c) Coalition of Good-Hearted Engineers +// Free To Use To Build Reliable Library Management Solutions +//----------------------------------------------------------- + +using LibraryManagement.Api.Models.Foundations.Books; + +namespace LibraryManagement.Api.Models.Foundations.Readers +{ + public class Reader + { + public Guid ReaderId { get; set; } + public string FirstName { get; set; } + public string LastName { get; set; } + public DateTimeOffset DateOfBirth { get; set; } + public List Books { get; set; } + } +}