fix #5897 - allow SQLite to drop columns, remove deprecated columns, and handle upgrade logic
This commit is contained in:
@@ -16,15 +16,18 @@ namespace Oqtane.Migrations.Tenant
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var folderEntityBuilder = new FolderEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
folderEntityBuilder.DropColumn("DeletedBy");
|
||||
folderEntityBuilder.DropColumn("DeletedOn");
|
||||
folderEntityBuilder.DropColumn("IsDeleted");
|
||||
if (ActiveDatabase.Name != "Sqlite")
|
||||
{
|
||||
var folderEntityBuilder = new FolderEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
folderEntityBuilder.DropColumn("DeletedBy");
|
||||
folderEntityBuilder.DropColumn("DeletedOn");
|
||||
folderEntityBuilder.DropColumn("IsDeleted");
|
||||
|
||||
var fileEntityBuilder = new FileEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
fileEntityBuilder.DropColumn("DeletedBy");
|
||||
fileEntityBuilder.DropColumn("DeletedOn");
|
||||
fileEntityBuilder.DropColumn("IsDeleted");
|
||||
var fileEntityBuilder = new FileEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
fileEntityBuilder.DropColumn("DeletedBy");
|
||||
fileEntityBuilder.DropColumn("DeletedOn");
|
||||
fileEntityBuilder.DropColumn("IsDeleted");
|
||||
}
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
|
||||
@@ -16,7 +16,7 @@ namespace Oqtane.Migrations.Tenant
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
// IsDeleted columns were removed in 3.2.2 however SQLite does not support column removal so they had to be restored
|
||||
// IsDeleted columns were removed in 3.2.2 however SQLite did not support column removal so they had to be restored
|
||||
if (ActiveDatabase.Name != "Sqlite")
|
||||
{
|
||||
var folderEntityBuilder = new FolderEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
|
||||
@@ -16,8 +16,11 @@ namespace Oqtane.Migrations.Tenant
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
var languageEntityBuilder = new LanguageEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
languageEntityBuilder.DropColumn("Name");
|
||||
if (ActiveDatabase.Name != "Sqlite")
|
||||
{
|
||||
var languageEntityBuilder = new LanguageEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
languageEntityBuilder.DropColumn("Name");
|
||||
}
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
|
||||
@@ -16,7 +16,7 @@ namespace Oqtane.Migrations.Tenant
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
// Name column was removed in 5.2.4 however SQLite does not support column removal so it had to be restored
|
||||
// Name column was removed in 5.2.4 however SQLite did not support column removal so it had to be restored
|
||||
if (ActiveDatabase.Name != "Sqlite")
|
||||
{
|
||||
var languageEntityBuilder = new LanguageEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
|
||||
@@ -18,7 +18,10 @@ namespace Oqtane.Migrations.Tenant
|
||||
{
|
||||
var siteEntityBuilder = new SiteEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
siteEntityBuilder.DropIndex("IX_Site"); // TenantId, Name
|
||||
siteEntityBuilder.DropColumn("TenantId");
|
||||
if (ActiveDatabase.Name != "Sqlite")
|
||||
{
|
||||
siteEntityBuilder.DropColumn("TenantId");
|
||||
}
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
|
||||
@@ -0,0 +1,60 @@
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Oqtane.Databases.Interfaces;
|
||||
using Oqtane.Migrations.EntityBuilders;
|
||||
using Oqtane.Repository;
|
||||
|
||||
namespace Oqtane.Migrations.Tenant
|
||||
{
|
||||
[DbContext(typeof(TenantDBContext))]
|
||||
[Migration("Tenant.10.00.02.01")]
|
||||
public class RemoveDeprecatedColumns : MultiDatabaseMigration
|
||||
{
|
||||
public RemoveDeprecatedColumns(IDatabase database) : base(database)
|
||||
{
|
||||
}
|
||||
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
// Oqtane 10.0.2 includes support for column removal in SQLite, so we can now clean up deprecated columns
|
||||
|
||||
// Folder columns were deprecated in Oqtane 3.2.2
|
||||
var folderEntityBuilder = new FolderEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
folderEntityBuilder.DropColumn("IsDeleted");
|
||||
if (ActiveDatabase.Name == "Sqlite")
|
||||
{
|
||||
/// the following columns were not added back in 3.2.3 but they still exist in SQLite databases
|
||||
folderEntityBuilder.DropColumn("DeletedBy");
|
||||
folderEntityBuilder.DropColumn("DeletedOn");
|
||||
}
|
||||
|
||||
// File columns were deprecated in Oqtane 3.2.2
|
||||
var fileEntityBuilder = new FileEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
// IsDeleted was added back in 3.2.3 for non-SQLLite databases
|
||||
fileEntityBuilder.DropColumn("IsDeleted");
|
||||
if (ActiveDatabase.Name == "Sqlite")
|
||||
{
|
||||
/// the following columns were not added back in 3.2.3 but they still exist in SQLite databases
|
||||
fileEntityBuilder.DropColumn("DeletedBy");
|
||||
fileEntityBuilder.DropColumn("DeletedOn");
|
||||
}
|
||||
|
||||
// Language columns were deprecated in Oqtane 5.2.4
|
||||
var languageEntityBuilder = new LanguageEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
languageEntityBuilder.DropColumn("Name");
|
||||
|
||||
// Site columns were deprecated in Oqtane 10.0.1
|
||||
var siteEntityBuilder = new SiteEntityBuilder(migrationBuilder, ActiveDatabase);
|
||||
if (ActiveDatabase.Name == "Sqlite")
|
||||
{
|
||||
/// the following column was removed for non-SQLite databases in 10.0.1
|
||||
siteEntityBuilder.DropColumn("TenantId");
|
||||
}
|
||||
}
|
||||
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
// not implemented
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user