Scanner Fix (#2998)
This commit is contained in:
parent
6139b3fbdf
commit
11635c6696
6 changed files with 78 additions and 4 deletions
59
API/Data/ManualMigrations/MigrateSeriesLowestFolderPath.cs
Normal file
59
API/Data/ManualMigrations/MigrateSeriesLowestFolderPath.cs
Normal file
|
@ -0,0 +1,59 @@
|
|||
using System;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using API.Entities;
|
||||
using API.Services;
|
||||
using API.Services.Tasks.Scanner.Parser;
|
||||
using Kavita.Common.EnvironmentInfo;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.Extensions.Logging;
|
||||
|
||||
namespace API.Data.ManualMigrations;
|
||||
#nullable enable
|
||||
|
||||
/// <summary>
|
||||
/// Some linux-based users are having non-rooted LowestFolderPaths. This will attempt to fix it or null them.
|
||||
/// Fixed in v0.8.2
|
||||
/// </summary>
|
||||
public static class MigrateSeriesLowestFolderPath
|
||||
{
|
||||
public static async Task Migrate(DataContext dataContext, ILogger<Program> logger, IDirectoryService directoryService)
|
||||
{
|
||||
if (await dataContext.ManualMigrationHistory.AnyAsync(m => m.Name == "MigrateSeriesLowestFolderPath"))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
logger.LogCritical("Running MigrateSeriesLowestFolderPath migration - Please be patient, this may take some time. This is not an error");
|
||||
|
||||
var seriesWithFolderPath =
|
||||
await dataContext.Series.Where(s => !string.IsNullOrEmpty(s.LowestFolderPath))
|
||||
.Include(s => s.Library)
|
||||
.ThenInclude(l => l.Folders)
|
||||
.ToListAsync();
|
||||
|
||||
foreach (var series in seriesWithFolderPath)
|
||||
{
|
||||
var isValidPath = series.Library.Folders
|
||||
.Any(folder => Parser.NormalizePath(series.LowestFolderPath!).StartsWith(Parser.NormalizePath(folder.Path), StringComparison.OrdinalIgnoreCase));
|
||||
|
||||
if (isValidPath) continue;
|
||||
series.LowestFolderPath = null;
|
||||
dataContext.Entry(series).State = EntityState.Modified;
|
||||
}
|
||||
|
||||
await dataContext.SaveChangesAsync();
|
||||
|
||||
|
||||
|
||||
dataContext.ManualMigrationHistory.Add(new ManualMigrationHistory()
|
||||
{
|
||||
Name = "MigrateSeriesLowestFolderPath",
|
||||
ProductVersion = BuildInfo.Version.ToString(),
|
||||
RanAt = DateTime.UtcNow
|
||||
});
|
||||
await dataContext.SaveChangesAsync();
|
||||
|
||||
logger.LogCritical("Running MigrateSeriesLowestFolderPath migration - Completed. This is not an error");
|
||||
}
|
||||
}
|
|
@ -3,7 +3,9 @@ using System.Linq;
|
|||
using System.Text.RegularExpressions;
|
||||
using System.Threading.Tasks;
|
||||
using API.DTOs.Filtering.v2;
|
||||
using API.Entities;
|
||||
using API.Helpers;
|
||||
using Kavita.Common.EnvironmentInfo;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.Extensions.Logging;
|
||||
|
||||
|
@ -29,7 +31,7 @@ public static class MigrateSmartFilterEncoding
|
|||
|
||||
logger.LogCritical("Running MigrateSmartFilterEncoding migration - Please be patient, this may take some time. This is not an error");
|
||||
|
||||
var smartFilters = dataContext.AppUserSmartFilter.ToList();
|
||||
var smartFilters = await dataContext.AppUserSmartFilter.ToListAsync();
|
||||
foreach (var filter in smartFilters)
|
||||
{
|
||||
if (!ShouldMigrateFilter(filter.Filter)) continue;
|
||||
|
@ -43,6 +45,14 @@ public static class MigrateSmartFilterEncoding
|
|||
await unitOfWork.CommitAsync();
|
||||
}
|
||||
|
||||
dataContext.ManualMigrationHistory.Add(new ManualMigrationHistory()
|
||||
{
|
||||
Name = "MigrateSmartFilterEncoding",
|
||||
ProductVersion = BuildInfo.Version.ToString(),
|
||||
RanAt = DateTime.UtcNow
|
||||
});
|
||||
await dataContext.SaveChangesAsync();
|
||||
|
||||
logger.LogCritical("Running MigrateSmartFilterEncoding migration - Completed. This is not an error");
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue