fix #5897 - allow SQLite to drop columns, remove deprecated columns, and handle upgrade logic
This commit is contained in:
@@ -31,12 +31,15 @@ namespace Oqtane.Database.Sqlite
|
||||
|
||||
public override void DropColumn(MigrationBuilder builder, string name, string table)
|
||||
{
|
||||
// not implemented as SQLite does not support dropping columns
|
||||
// SQLite supports dropping columns starting with version 3.35.0 but EF Core does not implement it yet
|
||||
// note that a column cannot be dropped if it has a UNIQUE constraint, is part of a PRIMARY KEY, is indexed, or is referenced by other parts of the schema
|
||||
builder.Sql($"ALTER TABLE {table} DROP COLUMN {name};");
|
||||
}
|
||||
|
||||
public override void AlterStringColumn(MigrationBuilder builder, string name, string table, int length, bool nullable, bool unicode, string index)
|
||||
{
|
||||
// not implemented as SQLite does not support altering columns
|
||||
// note that column length does not need to be modified as SQLite uses a TEXT type which utilizes variable length strings
|
||||
}
|
||||
|
||||
public override string ConcatenateSql(params string[] values)
|
||||
|
||||
@@ -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
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -34,7 +34,6 @@ namespace Oqtane.Modules.Admin.Files.Manager
|
||||
if (folder.ModifiedOn >= lastIndexedOn)
|
||||
{
|
||||
changed = true;
|
||||
removed = folder.IsDeleted.Value;
|
||||
}
|
||||
|
||||
var files = _fileRepository.GetFiles(folder.FolderId);
|
||||
@@ -78,7 +77,7 @@ namespace Oqtane.Modules.Admin.Files.Manager
|
||||
Permissions = $"{EntityNames.Folder}:{folder.FolderId}",
|
||||
ContentModifiedBy = file.ModifiedBy,
|
||||
ContentModifiedOn = file.ModifiedOn,
|
||||
IsDeleted = (removed || file.IsDeleted.Value)
|
||||
IsDeleted = (removed)
|
||||
};
|
||||
searchContents.Add(searchContent);
|
||||
}
|
||||
|
||||
@@ -72,7 +72,6 @@ namespace Oqtane.Repository
|
||||
public File AddFile(File file)
|
||||
{
|
||||
using var db = _dbContextFactory.CreateDbContext();
|
||||
file.IsDeleted = false;
|
||||
db.File.Add(file);
|
||||
db.SaveChanges();
|
||||
file.Folder = _folderRepository.GetFolder(file.FolderId);
|
||||
|
||||
@@ -51,7 +51,6 @@ namespace Oqtane.Repository
|
||||
public Folder AddFolder(Folder folder)
|
||||
{
|
||||
using var db = _dbContextFactory.CreateDbContext();
|
||||
folder.IsDeleted = false;
|
||||
db.Folder.Add(folder);
|
||||
db.SaveChanges();
|
||||
_permissions.UpdatePermissions(folder.SiteId, EntityNames.Folder, folder.FolderId, folder.PermissionList);
|
||||
|
||||
Reference in New Issue
Block a user