374 lines
13 KiB
C#
374 lines
13 KiB
C#
// <auto-generated />
|
|
using System;
|
|
using GreenHome.Infrastructure;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
|
using Microsoft.EntityFrameworkCore.Metadata;
|
|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
|
|
|
#nullable disable
|
|
|
|
namespace GreenHome.Infrastructure.Migrations
|
|
{
|
|
[DbContext(typeof(GreenHomeDbContext))]
|
|
partial class GreenHomeDbContextModelSnapshot : ModelSnapshot
|
|
{
|
|
protected override void BuildModel(ModelBuilder modelBuilder)
|
|
{
|
|
#pragma warning disable 612, 618
|
|
modelBuilder
|
|
.HasAnnotation("ProductVersion", "9.0.9")
|
|
.HasAnnotation("Relational:MaxIdentifierLength", 128);
|
|
|
|
SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder);
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.AlertNotification", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<string>("AlertType")
|
|
.IsRequired()
|
|
.HasMaxLength(50)
|
|
.HasColumnType("nvarchar(50)");
|
|
|
|
b.Property<int>("DeviceId")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<string>("ErrorMessage")
|
|
.HasMaxLength(1000)
|
|
.HasColumnType("nvarchar(1000)");
|
|
|
|
b.Property<bool>("IsSent")
|
|
.HasColumnType("bit");
|
|
|
|
b.Property<string>("Message")
|
|
.IsRequired()
|
|
.HasMaxLength(500)
|
|
.HasColumnType("nvarchar(500)");
|
|
|
|
b.Property<string>("MessageOutboxIds")
|
|
.HasMaxLength(500)
|
|
.HasColumnType("nvarchar(500)");
|
|
|
|
b.Property<DateTime>("SentAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<int>("UserId")
|
|
.HasColumnType("int");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("UserId");
|
|
|
|
b.HasIndex("DeviceId", "UserId", "AlertType", "SentAt");
|
|
|
|
b.ToTable("AlertNotifications", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.Device", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<string>("DeviceName")
|
|
.IsRequired()
|
|
.HasMaxLength(10)
|
|
.HasColumnType("nvarchar(10)");
|
|
|
|
b.Property<string>("Location")
|
|
.IsRequired()
|
|
.HasMaxLength(250)
|
|
.HasColumnType("nvarchar(250)");
|
|
|
|
b.Property<string>("NeshanLocation")
|
|
.IsRequired()
|
|
.HasMaxLength(80)
|
|
.HasColumnType("nvarchar(80)");
|
|
|
|
b.Property<int>("UserId")
|
|
.HasColumnType("int");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("UserId");
|
|
|
|
b.ToTable("Devices", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.DeviceSettings", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<decimal>("DangerMaxTemperature")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("DangerMinTemperature")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<int>("DeviceId")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<int>("MaxGasPPM")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<decimal>("MaxHumidityPercent")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("MaxLux")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("MaxTemperature")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<int>("MinGasPPM")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<decimal>("MinHumidityPercent")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("MinLux")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("MinTemperature")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<DateTime>("UpdatedAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("DeviceId")
|
|
.IsUnique();
|
|
|
|
b.ToTable("DeviceSettings", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.DeviceUser", b =>
|
|
{
|
|
b.Property<int>("DeviceId")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<int>("UserId")
|
|
.HasColumnType("int");
|
|
|
|
b.HasKey("DeviceId", "UserId");
|
|
|
|
b.HasIndex("UserId");
|
|
|
|
b.ToTable("DeviceUsers", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.TelemetryRecord", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<int>("DeviceId")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<int>("GasPPM")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<decimal>("HumidityPercent")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("Lux")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<string>("PersianDate")
|
|
.IsRequired()
|
|
.HasMaxLength(10)
|
|
.HasColumnType("nvarchar(10)");
|
|
|
|
b.Property<int>("PersianMonth")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<int>("PersianYear")
|
|
.HasColumnType("int");
|
|
|
|
b.Property<decimal>("SoilPercent")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<decimal>("TemperatureC")
|
|
.HasColumnType("decimal(18,2)");
|
|
|
|
b.Property<DateTime>("TimestampUtc")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("DeviceId", "TimestampUtc");
|
|
|
|
b.HasIndex("DeviceId", "PersianYear", "PersianMonth");
|
|
|
|
b.ToTable("Telemetry", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.User", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<string>("Family")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("nvarchar(100)");
|
|
|
|
b.Property<DateTime?>("LastLoginAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<string>("Mobile")
|
|
.IsRequired()
|
|
.HasMaxLength(11)
|
|
.HasColumnType("nvarchar(11)");
|
|
|
|
b.Property<string>("Name")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("nvarchar(100)");
|
|
|
|
b.Property<int>("Role")
|
|
.HasColumnType("int");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("Mobile")
|
|
.IsUnique();
|
|
|
|
b.ToTable("Users", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.VerificationCode", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("int");
|
|
|
|
SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<string>("Code")
|
|
.IsRequired()
|
|
.HasMaxLength(4)
|
|
.HasColumnType("nvarchar(4)");
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<DateTime>("ExpiresAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.Property<bool>("IsUsed")
|
|
.HasColumnType("bit");
|
|
|
|
b.Property<string>("Mobile")
|
|
.IsRequired()
|
|
.HasMaxLength(11)
|
|
.HasColumnType("nvarchar(11)");
|
|
|
|
b.Property<DateTime?>("UsedAt")
|
|
.HasColumnType("datetime2");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("Mobile", "Code", "IsUsed");
|
|
|
|
b.ToTable("VerificationCodes", (string)null);
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.AlertNotification", b =>
|
|
{
|
|
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("Device");
|
|
|
|
b.Navigation("User");
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.Device", b =>
|
|
{
|
|
b.HasOne("GreenHome.Domain.User", "User")
|
|
.WithMany()
|
|
.HasForeignKey("UserId")
|
|
.OnDelete(DeleteBehavior.Restrict)
|
|
.IsRequired();
|
|
|
|
b.Navigation("User");
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.DeviceSettings", b =>
|
|
{
|
|
b.HasOne("GreenHome.Domain.Device", "Device")
|
|
.WithMany()
|
|
.HasForeignKey("DeviceId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.Navigation("Device");
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.DeviceUser", b =>
|
|
{
|
|
b.HasOne("GreenHome.Domain.Device", "Device")
|
|
.WithMany("DeviceUsers")
|
|
.HasForeignKey("DeviceId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.HasOne("GreenHome.Domain.User", "User")
|
|
.WithMany("DeviceUsers")
|
|
.HasForeignKey("UserId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.Navigation("Device");
|
|
|
|
b.Navigation("User");
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.Device", b =>
|
|
{
|
|
b.Navigation("DeviceUsers");
|
|
});
|
|
|
|
modelBuilder.Entity("GreenHome.Domain.User", b =>
|
|
{
|
|
b.Navigation("DeviceUsers");
|
|
});
|
|
#pragma warning restore 612, 618
|
|
}
|
|
}
|
|
}
|