FF-1615: Move and Copy now use common method to get additional files

This commit is contained in:
John Andrews
2024-06-17 08:41:13 +12:00
parent dc70c91ea9
commit 4ee50eeb20
12 changed files with 328 additions and 158 deletions

View File

@@ -1,26 +0,0 @@
using System.Diagnostics;
namespace FileFlows.BasicNodes.Helpers;
/// <summary>
/// File Helper
/// </summary>
public static class FileHelper
{
/// <summary>
/// Sets the last write time of a file
/// </summary>
/// <param name="filePath">the file path</param>
/// <param name="utcDate">the UTC to set</param>
public static void SetLastWriteTime(string filePath, DateTime utcDate)
=> System.IO.File.SetLastWriteTimeUtc(filePath, utcDate);
/// <summary>
/// Sets the last write time of a file
/// </summary>
/// <param name="filePath">the file path</param>
/// <param name="utcDate">the UTC to set</param>
public static void SetCreationTime(string filePath, DateTime utcDate)
=> System.IO.File.SetCreationTimeUtc(filePath, utcDate);
}

View File

@@ -0,0 +1,74 @@
using System.Text.RegularExpressions;
using FileFlows.Plugin;
using FileFlows.Plugin.Helpers;
using FileFlows.Plugin.Services;
namespace FileFlows.BasicNodes.Helpers;
/// <summary>
/// Folder Helper
/// </summary>
public static class FolderHelper
{
/// <summary>
/// Gets additional files matching the criteria
/// </summary>
/// <param name="logger">the logger to use</param>
/// <param name="fileService">the file serverice to use</param>
/// <param name="replaceVariables">the function to replace variables in the patterns</param>
/// <param name="shortNameLookup">the shortname of the source file to match against</param>
/// <param name="directory">the directory to search in</param>
/// <param name="patterns">the patterns of the additional files</param>
/// <returns>a list of additional files found</returns>
public static List<string> GetAdditionalFiles(ILogger logger, IFileService fileService,
Func<string, bool, bool, string> replaceVariables, string shortNameLookup, string directory, string[] patterns)
{
List<string> results = new();
if (string.IsNullOrWhiteSpace(directory) || patterns == null || patterns.Length < 1)
return results;
logger?.ILog("Additional Files: " + string.Join(", ", patterns));
try
{
logger?.ILog("Looking for additional files in directory: " + directory);
foreach (var additionalOrig in patterns)
{
string additional = replaceVariables(additionalOrig, true, true);
if (Regex.IsMatch(additionalOrig, @"^\.[a-z0-9A-Z]+$"))
additional = "*" + additional; // add the leading start for the search
logger?.ILog("Looking for additional files: " + additional);
var srcDirFiles = fileService.GetFiles(directory, additional).ValueOrDefault ?? new string[] { };
foreach (var addFile in srcDirFiles)
{
try
{
if (Regex.IsMatch(additional, @"\*\.[a-z0-9A-Z]+$"))
{
// make sure the file starts with same name
var addFileName = FileHelper.GetShortFileName(addFile);
if (addFileName.ToLowerInvariant().StartsWith(shortNameLookup.ToLowerInvariant()) ==
false)
continue;
}
logger?.ILog("Additional files: " + addFile);
results.Add(addFile);
}
catch (Exception ex)
{
logger?.ILog("Failed moving file: \"" + addFile + "\": " + ex.Message);
}
}
}
}
catch (Exception ex)
{
logger.WLog("Error moving additional files: " + ex.Message);
}
return results;
}
}