using Microsoft.EntityFrameworkCore.Migrations; #nullable disable namespace Bit.PostgresMigrations.Migrations; /// public partial class SetupProviderBilling : Migration { /// protected override void Up(MigrationBuilder migrationBuilder) { migrationBuilder.AddColumn( name: "ProviderId", table: "Transaction", type: "uuid", nullable: true); migrationBuilder.AddColumn( name: "GatewayCustomerId", table: "Provider", type: "text", nullable: true); migrationBuilder.AddColumn( name: "GatewaySubscriptionId", table: "Provider", type: "text", nullable: true); migrationBuilder.AddColumn( name: "GatewayType", table: "Provider", type: "smallint", nullable: true); migrationBuilder.CreateTable( name: "ProviderPlan", columns: table => new { Id = table.Column(type: "uuid", nullable: false), ProviderId = table.Column(type: "uuid", nullable: false), PlanType = table.Column(type: "smallint", nullable: false), SeatMinimum = table.Column(type: "integer", nullable: true), PurchasedSeats = table.Column(type: "integer", nullable: true), AllocatedSeats = table.Column(type: "integer", nullable: true) }, constraints: table => { table.PrimaryKey("PK_ProviderPlan", x => x.Id); table.ForeignKey( name: "FK_ProviderPlan_Provider_ProviderId", column: x => x.ProviderId, principalTable: "Provider", principalColumn: "Id", onDelete: ReferentialAction.Cascade); }); migrationBuilder.CreateIndex( name: "IX_Transaction_ProviderId", table: "Transaction", column: "ProviderId"); migrationBuilder.CreateIndex( name: "IX_ProviderPlan_Id_PlanType", table: "ProviderPlan", columns: new[] { "Id", "PlanType" }, unique: true); migrationBuilder.CreateIndex( name: "IX_ProviderPlan_ProviderId", table: "ProviderPlan", column: "ProviderId"); migrationBuilder.AddForeignKey( name: "FK_Transaction_Provider_ProviderId", table: "Transaction", column: "ProviderId", principalTable: "Provider", principalColumn: "Id"); } /// protected override void Down(MigrationBuilder migrationBuilder) { migrationBuilder.DropForeignKey( name: "FK_Transaction_Provider_ProviderId", table: "Transaction"); migrationBuilder.DropTable( name: "ProviderPlan"); migrationBuilder.DropIndex( name: "IX_Transaction_ProviderId", table: "Transaction"); migrationBuilder.DropColumn( name: "ProviderId", table: "Transaction"); migrationBuilder.DropColumn( name: "GatewayCustomerId", table: "Provider"); migrationBuilder.DropColumn( name: "GatewaySubscriptionId", table: "Provider"); migrationBuilder.DropColumn( name: "GatewayType", table: "Provider"); } }