2fb86a435e
ASP.NET Core 10 Razor Pages + PostgreSQL/EF Core. RTL Persian, Jalali dates, self-hosted Vazirmatn, teal/coral brand. Features: - Shift listings: browse/filter (city, district, role, type, pay), weekly Jalali calendar, detail + interest handoff, near-me distance sort - Hiring (استخدام) listings with employment type + salary range - Pattern-engine recommendations + anonymous interest tracking (visitor cookie) - Heuristic Persian listing-parser + admin queue (raw channel post → shift/job) - Phone-OTP cookie auth + visitor-history linking + profile Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
419 lines
14 KiB
C#
419 lines
14 KiB
C#
// <auto-generated />
|
|
using System;
|
|
using JobsMedical.Web.Data;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
|
using Microsoft.EntityFrameworkCore.Migrations;
|
|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
|
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
|
|
|
|
#nullable disable
|
|
|
|
namespace JobsMedical.Web.Migrations
|
|
{
|
|
[DbContext(typeof(AppDbContext))]
|
|
[Migration("20260602202926_InitialCreate")]
|
|
partial class InitialCreate
|
|
{
|
|
/// <inheritdoc />
|
|
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
|
{
|
|
#pragma warning disable 612, 618
|
|
modelBuilder
|
|
.HasAnnotation("ProductVersion", "10.0.0")
|
|
.HasAnnotation("Relational:MaxIdentifierLength", 63);
|
|
|
|
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Application", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("timestamp with time zone");
|
|
|
|
b.Property<int>("DoctorId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<string>("Message")
|
|
.HasMaxLength(500)
|
|
.HasColumnType("character varying(500)");
|
|
|
|
b.Property<int>("ShiftId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<int>("Status")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("DoctorId");
|
|
|
|
b.HasIndex("ShiftId", "DoctorId")
|
|
.IsUnique();
|
|
|
|
b.ToTable("Applications");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.City", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<bool>("IsActive")
|
|
.HasColumnType("boolean");
|
|
|
|
b.Property<string>("Name")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("character varying(100)");
|
|
|
|
b.Property<string>("Province")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("character varying(100)");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.ToTable("Cities");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.DoctorProfile", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<string>("Bio")
|
|
.HasMaxLength(1000)
|
|
.HasColumnType("character varying(1000)");
|
|
|
|
b.Property<int?>("CityId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<bool>("IsVerified")
|
|
.HasColumnType("boolean");
|
|
|
|
b.Property<string>("LicenseNo")
|
|
.HasMaxLength(20)
|
|
.HasColumnType("character varying(20)");
|
|
|
|
b.Property<string>("Specialty")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("character varying(100)");
|
|
|
|
b.Property<int>("UserId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<int>("YearsExperience")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("CityId");
|
|
|
|
b.HasIndex("UserId")
|
|
.IsUnique();
|
|
|
|
b.ToTable("DoctorProfiles");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Facility", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<string>("Address")
|
|
.HasMaxLength(500)
|
|
.HasColumnType("character varying(500)");
|
|
|
|
b.Property<string>("BaleId")
|
|
.HasMaxLength(50)
|
|
.HasColumnType("character varying(50)");
|
|
|
|
b.Property<int>("CityId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("timestamp with time zone");
|
|
|
|
b.Property<bool>("IsVerified")
|
|
.HasColumnType("boolean");
|
|
|
|
b.Property<double?>("Lat")
|
|
.HasColumnType("double precision");
|
|
|
|
b.Property<double?>("Lng")
|
|
.HasColumnType("double precision");
|
|
|
|
b.Property<string>("Name")
|
|
.IsRequired()
|
|
.HasMaxLength(200)
|
|
.HasColumnType("character varying(200)");
|
|
|
|
b.Property<int?>("OwnerUserId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<string>("Phone")
|
|
.HasMaxLength(20)
|
|
.HasColumnType("character varying(20)");
|
|
|
|
b.Property<int>("Type")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("CityId");
|
|
|
|
b.HasIndex("OwnerUserId");
|
|
|
|
b.ToTable("Facilities");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.RawListing", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("FetchedAt")
|
|
.HasColumnType("timestamp with time zone");
|
|
|
|
b.Property<int?>("LinkedShiftId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<string>("ParsedJson")
|
|
.HasColumnType("text");
|
|
|
|
b.Property<string>("RawText")
|
|
.IsRequired()
|
|
.HasColumnType("text");
|
|
|
|
b.Property<string>("SourceChannel")
|
|
.IsRequired()
|
|
.HasMaxLength(200)
|
|
.HasColumnType("character varying(200)");
|
|
|
|
b.Property<string>("SourceUrl")
|
|
.HasMaxLength(500)
|
|
.HasColumnType("character varying(500)");
|
|
|
|
b.Property<int>("Status")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("LinkedShiftId");
|
|
|
|
b.ToTable("RawListings");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Shift", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("timestamp with time zone");
|
|
|
|
b.Property<DateOnly>("Date")
|
|
.HasColumnType("date");
|
|
|
|
b.Property<string>("Description")
|
|
.HasMaxLength(1500)
|
|
.HasColumnType("character varying(1500)");
|
|
|
|
b.Property<TimeOnly>("EndTime")
|
|
.HasColumnType("time without time zone");
|
|
|
|
b.Property<int>("FacilityId")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<long?>("PayAmount")
|
|
.HasColumnType("bigint");
|
|
|
|
b.Property<int>("PayType")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<int>("ShiftType")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<int>("Source")
|
|
.HasColumnType("integer");
|
|
|
|
b.Property<string>("SourceUrl")
|
|
.HasMaxLength(500)
|
|
.HasColumnType("character varying(500)");
|
|
|
|
b.Property<string>("SpecialtyRequired")
|
|
.IsRequired()
|
|
.HasMaxLength(100)
|
|
.HasColumnType("character varying(100)");
|
|
|
|
b.Property<TimeOnly>("StartTime")
|
|
.HasColumnType("time without time zone");
|
|
|
|
b.Property<int>("Status")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("FacilityId");
|
|
|
|
b.HasIndex("Date", "Status");
|
|
|
|
b.ToTable("Shifts");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.User", b =>
|
|
{
|
|
b.Property<int>("Id")
|
|
.ValueGeneratedOnAdd()
|
|
.HasColumnType("integer");
|
|
|
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
|
|
b.Property<DateTime>("CreatedAt")
|
|
.HasColumnType("timestamp with time zone");
|
|
|
|
b.Property<string>("FullName")
|
|
.HasMaxLength(150)
|
|
.HasColumnType("character varying(150)");
|
|
|
|
b.Property<bool>("IsPhoneVerified")
|
|
.HasColumnType("boolean");
|
|
|
|
b.Property<string>("Phone")
|
|
.IsRequired()
|
|
.HasMaxLength(20)
|
|
.HasColumnType("character varying(20)");
|
|
|
|
b.Property<int>("Role")
|
|
.HasColumnType("integer");
|
|
|
|
b.HasKey("Id");
|
|
|
|
b.HasIndex("Phone")
|
|
.IsUnique();
|
|
|
|
b.ToTable("Users");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Application", b =>
|
|
{
|
|
b.HasOne("JobsMedical.Web.Models.User", "Doctor")
|
|
.WithMany("Applications")
|
|
.HasForeignKey("DoctorId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.HasOne("JobsMedical.Web.Models.Shift", "Shift")
|
|
.WithMany("Applications")
|
|
.HasForeignKey("ShiftId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.Navigation("Doctor");
|
|
|
|
b.Navigation("Shift");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.DoctorProfile", b =>
|
|
{
|
|
b.HasOne("JobsMedical.Web.Models.City", "City")
|
|
.WithMany()
|
|
.HasForeignKey("CityId");
|
|
|
|
b.HasOne("JobsMedical.Web.Models.User", "User")
|
|
.WithOne("DoctorProfile")
|
|
.HasForeignKey("JobsMedical.Web.Models.DoctorProfile", "UserId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.Navigation("City");
|
|
|
|
b.Navigation("User");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Facility", b =>
|
|
{
|
|
b.HasOne("JobsMedical.Web.Models.City", "City")
|
|
.WithMany("Facilities")
|
|
.HasForeignKey("CityId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.HasOne("JobsMedical.Web.Models.User", "OwnerUser")
|
|
.WithMany()
|
|
.HasForeignKey("OwnerUserId")
|
|
.OnDelete(DeleteBehavior.SetNull);
|
|
|
|
b.Navigation("City");
|
|
|
|
b.Navigation("OwnerUser");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.RawListing", b =>
|
|
{
|
|
b.HasOne("JobsMedical.Web.Models.Shift", "LinkedShift")
|
|
.WithMany()
|
|
.HasForeignKey("LinkedShiftId");
|
|
|
|
b.Navigation("LinkedShift");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Shift", b =>
|
|
{
|
|
b.HasOne("JobsMedical.Web.Models.Facility", "Facility")
|
|
.WithMany("Shifts")
|
|
.HasForeignKey("FacilityId")
|
|
.OnDelete(DeleteBehavior.Cascade)
|
|
.IsRequired();
|
|
|
|
b.Navigation("Facility");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.City", b =>
|
|
{
|
|
b.Navigation("Facilities");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Facility", b =>
|
|
{
|
|
b.Navigation("Shifts");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.Shift", b =>
|
|
{
|
|
b.Navigation("Applications");
|
|
});
|
|
|
|
modelBuilder.Entity("JobsMedical.Web.Models.User", b =>
|
|
{
|
|
b.Navigation("Applications");
|
|
|
|
b.Navigation("DoctorProfile");
|
|
});
|
|
#pragma warning restore 612, 618
|
|
}
|
|
}
|
|
}
|