version 3

This commit is contained in:
2025-12-17 00:34:41 +03:30
parent 139924db94
commit 74e8480a68
38 changed files with 5399 additions and 70 deletions

View File

@@ -116,6 +116,67 @@ namespace GreenHome.Infrastructure.Migrations
b.ToTable("AlertConditions", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.AlertLog", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int?>("AlertConditionId")
.HasColumnType("int");
b.Property<int>("AlertType")
.HasColumnType("int");
b.Property<int>("DeviceId")
.HasColumnType("int");
b.Property<string>("ErrorMessage")
.HasMaxLength(2000)
.HasColumnType("nvarchar(2000)");
b.Property<string>("Message")
.IsRequired()
.HasMaxLength(1000)
.HasColumnType("nvarchar(1000)");
b.Property<int>("NotificationType")
.HasColumnType("int");
b.Property<string>("PhoneNumber")
.IsRequired()
.HasMaxLength(20)
.HasColumnType("nvarchar(20)");
b.Property<long>("ProcessingTimeMs")
.HasColumnType("bigint");
b.Property<DateTime>("SentAt")
.HasColumnType("datetime2");
b.Property<int>("Status")
.HasColumnType("int");
b.Property<int>("UserId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("AlertConditionId");
b.HasIndex("AlertType");
b.HasIndex("Status");
b.HasIndex("DeviceId", "SentAt");
b.HasIndex("UserId", "SentAt");
b.ToTable("AlertLogs", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.AlertNotification", b =>
{
b.Property<int>("Id")
@@ -124,7 +185,7 @@ namespace GreenHome.Infrastructure.Migrations
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("AlertConditionId")
b.Property<int?>("AlertConditionId")
.HasColumnType("int");
b.Property<int>("DeviceId")
@@ -199,6 +260,142 @@ namespace GreenHome.Infrastructure.Migrations
b.ToTable("AlertRules", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.Checklist", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2");
b.Property<int>("CreatedByUserId")
.HasColumnType("int");
b.Property<string>("Description")
.HasMaxLength(1000)
.HasColumnType("nvarchar(1000)");
b.Property<int>("DeviceId")
.HasColumnType("int");
b.Property<bool>("IsActive")
.HasColumnType("bit");
b.Property<string>("Title")
.IsRequired()
.HasMaxLength(200)
.HasColumnType("nvarchar(200)");
b.HasKey("Id");
b.HasIndex("CreatedByUserId");
b.HasIndex("DeviceId", "IsActive");
b.ToTable("Checklists", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.ChecklistCompletion", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ChecklistId")
.HasColumnType("int");
b.Property<DateTime>("CompletedAt")
.HasColumnType("datetime2");
b.Property<int>("CompletedByUserId")
.HasColumnType("int");
b.Property<string>("Notes")
.HasMaxLength(2000)
.HasColumnType("nvarchar(2000)");
b.Property<string>("PersianDate")
.IsRequired()
.HasMaxLength(10)
.HasColumnType("nvarchar(10)");
b.HasKey("Id");
b.HasIndex("CompletedByUserId");
b.HasIndex("ChecklistId", "PersianDate");
b.ToTable("ChecklistCompletions", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.ChecklistItem", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ChecklistId")
.HasColumnType("int");
b.Property<string>("Description")
.HasMaxLength(1000)
.HasColumnType("nvarchar(1000)");
b.Property<bool>("IsRequired")
.HasColumnType("bit");
b.Property<int>("Order")
.HasColumnType("int");
b.Property<string>("Title")
.IsRequired()
.HasMaxLength(300)
.HasColumnType("nvarchar(300)");
b.HasKey("Id");
b.HasIndex("ChecklistId", "Order");
b.ToTable("ChecklistItems", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.ChecklistItemCompletion", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("ChecklistCompletionId")
.HasColumnType("int");
b.Property<int>("ChecklistItemId")
.HasColumnType("int");
b.Property<bool>("IsChecked")
.HasColumnType("bit");
b.Property<string>("Note")
.HasMaxLength(500)
.HasColumnType("nvarchar(500)");
b.HasKey("Id");
b.HasIndex("ChecklistCompletionId");
b.HasIndex("ChecklistItemId");
b.ToTable("ChecklistItemCompletions", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.DailyReport", b =>
{
b.Property<int>("Id")
@@ -298,6 +495,79 @@ namespace GreenHome.Infrastructure.Migrations
b.ToTable("Devices", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.DevicePost", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<int>("AuthorUserId")
.HasColumnType("int");
b.Property<string>("Content")
.IsRequired()
.HasMaxLength(5000)
.HasColumnType("nvarchar(max)");
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2");
b.Property<int>("DeviceId")
.HasColumnType("int");
b.Property<DateTime?>("UpdatedAt")
.HasColumnType("datetime2");
b.HasKey("Id");
b.HasIndex("AuthorUserId");
b.HasIndex("DeviceId", "CreatedAt");
b.ToTable("DevicePosts", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.DevicePostImage", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ContentType")
.IsRequired()
.HasMaxLength(100)
.HasColumnType("nvarchar(100)");
b.Property<int>("DevicePostId")
.HasColumnType("int");
b.Property<string>("FileName")
.IsRequired()
.HasMaxLength(255)
.HasColumnType("nvarchar(255)");
b.Property<string>("FilePath")
.IsRequired()
.HasMaxLength(500)
.HasColumnType("nvarchar(500)");
b.Property<long>("FileSize")
.HasColumnType("bigint");
b.Property<DateTime>("UploadedAt")
.HasColumnType("datetime2");
b.HasKey("Id");
b.HasIndex("DevicePostId");
b.ToTable("DevicePostImages", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.DeviceSettings", b =>
{
b.Property<int>("Id")
@@ -306,6 +576,9 @@ namespace GreenHome.Infrastructure.Migrations
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<decimal?>("AreaSquareMeters")
.HasColumnType("decimal(18,2)");
b.Property<string>("City")
.IsRequired()
.HasMaxLength(100)
@@ -323,6 +596,21 @@ namespace GreenHome.Infrastructure.Migrations
b.Property<decimal?>("Longitude")
.HasColumnType("decimal(9,6)");
b.Property<int>("MinimumCallIntervalMinutes")
.ValueGeneratedOnAdd()
.HasColumnType("int")
.HasDefaultValue(60);
b.Property<int>("MinimumSmsIntervalMinutes")
.ValueGeneratedOnAdd()
.HasColumnType("int")
.HasDefaultValue(15);
b.Property<string>("ProductType")
.IsRequired()
.HasMaxLength(100)
.HasColumnType("nvarchar(100)");
b.Property<string>("Province")
.IsRequired()
.HasMaxLength(100)
@@ -347,6 +635,11 @@ namespace GreenHome.Infrastructure.Migrations
b.Property<int>("UserId")
.HasColumnType("int");
b.Property<bool>("ReceiveAlerts")
.ValueGeneratedOnAdd()
.HasColumnType("bit")
.HasDefaultValue(true);
b.HasKey("DeviceId", "UserId");
b.HasIndex("UserId");
@@ -354,6 +647,49 @@ namespace GreenHome.Infrastructure.Migrations
b.ToTable("DeviceUsers", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.ReportImage", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<string>("ContentType")
.IsRequired()
.HasMaxLength(100)
.HasColumnType("nvarchar(100)");
b.Property<string>("Description")
.HasMaxLength(500)
.HasColumnType("nvarchar(500)");
b.Property<string>("FileName")
.IsRequired()
.HasMaxLength(255)
.HasColumnType("nvarchar(255)");
b.Property<string>("FilePath")
.IsRequired()
.HasMaxLength(500)
.HasColumnType("nvarchar(500)");
b.Property<long>("FileSize")
.HasColumnType("bigint");
b.Property<DateTime>("UploadedAt")
.HasColumnType("datetime2");
b.Property<int>("UserDailyReportId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("UserDailyReportId");
b.ToTable("ReportImages", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.TelemetryRecord", b =>
{
b.Property<int>("Id")
@@ -448,6 +784,68 @@ namespace GreenHome.Infrastructure.Migrations
b.ToTable("Users", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.UserDailyReport", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
b.Property<DateTime>("CreatedAt")
.HasColumnType("datetime2");
b.Property<int>("DeviceId")
.HasColumnType("int");
b.Property<string>("Notes")
.HasMaxLength(2000)
.HasColumnType("nvarchar(2000)");
b.Property<string>("Observations")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<string>("Operations")
.IsRequired()
.HasColumnType("nvarchar(max)");
b.Property<string>("PersianDate")
.IsRequired()
.HasMaxLength(10)
.HasColumnType("nvarchar(10)");
b.Property<int>("PersianDay")
.HasColumnType("int");
b.Property<int>("PersianMonth")
.HasColumnType("int");
b.Property<int>("PersianYear")
.HasColumnType("int");
b.Property<string>("Title")
.IsRequired()
.HasMaxLength(200)
.HasColumnType("nvarchar(200)");
b.Property<DateTime>("UpdatedAt")
.HasColumnType("datetime2");
b.Property<int>("UserId")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("UserId");
b.HasIndex("DeviceId", "PersianDate");
b.HasIndex("DeviceId", "PersianYear", "PersianMonth");
b.ToTable("UserDailyReports", (string)null);
});
modelBuilder.Entity("GreenHome.Domain.VerificationCode", b =>
{
b.Property<int>("Id")
@@ -513,13 +911,38 @@ namespace GreenHome.Infrastructure.Migrations
b.Navigation("Device");
});
modelBuilder.Entity("GreenHome.Domain.AlertLog", b =>
{
b.HasOne("GreenHome.Domain.AlertCondition", "AlertCondition")
.WithMany()
.HasForeignKey("AlertConditionId")
.OnDelete(DeleteBehavior.SetNull);
b.HasOne("GreenHome.Domain.Device", "Device")
.WithMany()
.HasForeignKey("DeviceId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.HasOne("GreenHome.Domain.User", "User")
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("AlertCondition");
b.Navigation("Device");
b.Navigation("User");
});
modelBuilder.Entity("GreenHome.Domain.AlertNotification", b =>
{
b.HasOne("GreenHome.Domain.AlertCondition", "AlertCondition")
.WithMany()
.HasForeignKey("AlertConditionId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
.OnDelete(DeleteBehavior.Restrict);
b.HasOne("GreenHome.Domain.Device", "Device")
.WithMany()
@@ -551,6 +974,74 @@ namespace GreenHome.Infrastructure.Migrations
b.Navigation("AlertCondition");
});
modelBuilder.Entity("GreenHome.Domain.Checklist", b =>
{
b.HasOne("GreenHome.Domain.User", "CreatedByUser")
.WithMany()
.HasForeignKey("CreatedByUserId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.HasOne("GreenHome.Domain.Device", "Device")
.WithMany()
.HasForeignKey("DeviceId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("CreatedByUser");
b.Navigation("Device");
});
modelBuilder.Entity("GreenHome.Domain.ChecklistCompletion", b =>
{
b.HasOne("GreenHome.Domain.Checklist", "Checklist")
.WithMany("Completions")
.HasForeignKey("ChecklistId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("GreenHome.Domain.User", "CompletedByUser")
.WithMany()
.HasForeignKey("CompletedByUserId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("Checklist");
b.Navigation("CompletedByUser");
});
modelBuilder.Entity("GreenHome.Domain.ChecklistItem", b =>
{
b.HasOne("GreenHome.Domain.Checklist", "Checklist")
.WithMany("Items")
.HasForeignKey("ChecklistId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Checklist");
});
modelBuilder.Entity("GreenHome.Domain.ChecklistItemCompletion", b =>
{
b.HasOne("GreenHome.Domain.ChecklistCompletion", "ChecklistCompletion")
.WithMany("ItemCompletions")
.HasForeignKey("ChecklistCompletionId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("GreenHome.Domain.ChecklistItem", "ChecklistItem")
.WithMany()
.HasForeignKey("ChecklistItemId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("ChecklistCompletion");
b.Navigation("ChecklistItem");
});
modelBuilder.Entity("GreenHome.Domain.DailyReport", b =>
{
b.HasOne("GreenHome.Domain.Device", "Device")
@@ -573,6 +1064,36 @@ namespace GreenHome.Infrastructure.Migrations
b.Navigation("User");
});
modelBuilder.Entity("GreenHome.Domain.DevicePost", b =>
{
b.HasOne("GreenHome.Domain.User", "AuthorUser")
.WithMany()
.HasForeignKey("AuthorUserId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.HasOne("GreenHome.Domain.Device", "Device")
.WithMany()
.HasForeignKey("DeviceId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("AuthorUser");
b.Navigation("Device");
});
modelBuilder.Entity("GreenHome.Domain.DevicePostImage", b =>
{
b.HasOne("GreenHome.Domain.DevicePost", "DevicePost")
.WithMany("Images")
.HasForeignKey("DevicePostId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("DevicePost");
});
modelBuilder.Entity("GreenHome.Domain.DeviceSettings", b =>
{
b.HasOne("GreenHome.Domain.Device", "Device")
@@ -603,20 +1124,72 @@ namespace GreenHome.Infrastructure.Migrations
b.Navigation("User");
});
modelBuilder.Entity("GreenHome.Domain.ReportImage", b =>
{
b.HasOne("GreenHome.Domain.UserDailyReport", "UserDailyReport")
.WithMany("Images")
.HasForeignKey("UserDailyReportId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("UserDailyReport");
});
modelBuilder.Entity("GreenHome.Domain.UserDailyReport", b =>
{
b.HasOne("GreenHome.Domain.Device", "Device")
.WithMany()
.HasForeignKey("DeviceId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("GreenHome.Domain.User", "User")
.WithMany()
.HasForeignKey("UserId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("Device");
b.Navigation("User");
});
modelBuilder.Entity("GreenHome.Domain.AlertCondition", b =>
{
b.Navigation("Rules");
});
modelBuilder.Entity("GreenHome.Domain.Checklist", b =>
{
b.Navigation("Completions");
b.Navigation("Items");
});
modelBuilder.Entity("GreenHome.Domain.ChecklistCompletion", b =>
{
b.Navigation("ItemCompletions");
});
modelBuilder.Entity("GreenHome.Domain.Device", b =>
{
b.Navigation("DeviceUsers");
});
modelBuilder.Entity("GreenHome.Domain.DevicePost", b =>
{
b.Navigation("Images");
});
modelBuilder.Entity("GreenHome.Domain.User", b =>
{
b.Navigation("DeviceUsers");
});
modelBuilder.Entity("GreenHome.Domain.UserDailyReport", b =>
{
b.Navigation("Images");
});
#pragma warning restore 612, 618
}
}