using System; using Microsoft.EntityFrameworkCore.Migrations; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; #nullable disable namespace Clarity.Server.Data.Migrations { /// public partial class InitialCreate : Migration { /// protected override void Up(MigrationBuilder migrationBuilder) { migrationBuilder.CreateTable( name: "Profiles", columns: table => new { Id = table.Column(type: "uuid", nullable: false), KeycloakSubject = table.Column(type: "text", nullable: false), FirstName = table.Column(type: "text", nullable: false), MiddleName = table.Column(type: "text", nullable: false), LastName = table.Column(type: "text", nullable: false), Ssn = table.Column(type: "text", nullable: false), OnboardingComplete = table.Column(type: "boolean", nullable: false), CreatedAt = table.Column(type: "timestamp with time zone", nullable: false), EncryptedDek = table.Column(type: "bytea", nullable: false), Tenant = table.Column(type: "text", nullable: false) }, constraints: table => { table.PrimaryKey("PK_Profiles", x => x.Id); }); migrationBuilder.CreateTable( name: "SysParams", columns: table => new { Id = table.Column(type: "integer", nullable: false) .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), EncryptedKek = table.Column(type: "text", nullable: false) }, constraints: table => { table.PrimaryKey("PK_SysParams", x => x.Id); }); migrationBuilder.CreateIndex( name: "IX_Profiles_KeycloakSubject", table: "Profiles", column: "KeycloakSubject", unique: true); } /// protected override void Down(MigrationBuilder migrationBuilder) { migrationBuilder.DropTable( name: "Profiles"); migrationBuilder.DropTable( name: "SysParams"); } } }