1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-12-14 11:23:42 +02:00

New: Improve path validation when handling paths from different OSes

This commit is contained in:
Mark McDowall 2023-03-23 17:34:19 -07:00
parent ed140dd396
commit 0321368cc3
18 changed files with 95 additions and 72 deletions

View File

@ -1,4 +1,5 @@
using NUnit.Framework; using NUnit.Framework;
using NzbDrone.Common.Disk;
using NzbDrone.Common.EnsureThat; using NzbDrone.Common.EnsureThat;
using NzbDrone.Test.Common; using NzbDrone.Test.Common;
@ -12,14 +13,14 @@ public class PathExtensionFixture : TestBase
public void EnsureWindowsPath(string path) public void EnsureWindowsPath(string path)
{ {
WindowsOnly(); WindowsOnly();
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
} }
[TestCase(@"/var/user/file with, comma.mkv")] [TestCase(@"/var/user/file with, comma.mkv")]
public void EnsureLinuxPath(string path) public void EnsureLinuxPath(string path)
{ {
PosixOnly(); PosixOnly();
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
} }
} }
} }

View File

@ -35,6 +35,7 @@ private IAppFolderInfo GetIAppDirectoryInfo()
[TestCase(@"\\Testserver\Test\file.ext", @"\\Testserver\Test\file.ext")] [TestCase(@"\\Testserver\Test\file.ext", @"\\Testserver\Test\file.ext")]
[TestCase(@"\\Testserver\Test\file.ext\\", @"\\Testserver\Test\file.ext")] [TestCase(@"\\Testserver\Test\file.ext\\", @"\\Testserver\Test\file.ext")]
[TestCase(@"\\Testserver\Test\file.ext \\", @"\\Testserver\Test\file.ext")] [TestCase(@"\\Testserver\Test\file.ext \\", @"\\Testserver\Test\file.ext")]
[TestCase(@"//CAPITAL//lower// ", @"\\CAPITAL\lower")]
public void Clean_Path_Windows(string dirty, string clean) public void Clean_Path_Windows(string dirty, string clean)
{ {
WindowsOnly(); WindowsOnly();

View File

@ -2,8 +2,6 @@
using System.Collections.Generic; using System.Collections.Generic;
using System.IO; using System.IO;
using System.Linq; using System.Linq;
using System.Security.AccessControl;
using System.Security.Principal;
using NLog; using NLog;
using NzbDrone.Common.EnsureThat; using NzbDrone.Common.EnsureThat;
using NzbDrone.Common.EnvironmentInfo; using NzbDrone.Common.EnvironmentInfo;
@ -67,7 +65,7 @@ public DateTime FileGetLastWrite(string path)
private void CheckFolderExists(string path) private void CheckFolderExists(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
if (!FolderExists(path)) if (!FolderExists(path))
{ {
@ -77,7 +75,7 @@ private void CheckFolderExists(string path)
private void CheckFileExists(string path) private void CheckFileExists(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
if (!FileExists(path)) if (!FileExists(path))
{ {
@ -95,19 +93,19 @@ public void EnsureFolder(string path)
public bool FolderExists(string path) public bool FolderExists(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return Directory.Exists(path); return Directory.Exists(path);
} }
public bool FileExists(string path) public bool FileExists(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return FileExists(path, PathStringComparison); return FileExists(path, PathStringComparison);
} }
public bool FileExists(string path, StringComparison stringComparison) public bool FileExists(string path, StringComparison stringComparison)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
switch (stringComparison) switch (stringComparison)
{ {
@ -127,7 +125,7 @@ public bool FileExists(string path, StringComparison stringComparison)
public bool FolderWritable(string path) public bool FolderWritable(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
try try
{ {
@ -146,35 +144,35 @@ public bool FolderWritable(string path)
public bool FolderEmpty(string path) public bool FolderEmpty(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return Directory.EnumerateFileSystemEntries(path).Empty(); return Directory.EnumerateFileSystemEntries(path).Empty();
} }
public string[] GetDirectories(string path) public string[] GetDirectories(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return Directory.GetDirectories(path); return Directory.GetDirectories(path);
} }
public string[] GetFiles(string path, SearchOption searchOption) public string[] GetFiles(string path, SearchOption searchOption)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return Directory.GetFiles(path, "*.*", searchOption); return Directory.GetFiles(path, "*.*", searchOption);
} }
public long GetFolderSize(string path) public long GetFolderSize(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return GetFiles(path, SearchOption.AllDirectories).Sum(e => new FileInfo(e).Length); return GetFiles(path, SearchOption.AllDirectories).Sum(e => new FileInfo(e).Length);
} }
public long GetFileSize(string path) public long GetFileSize(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
if (!FileExists(path)) if (!FileExists(path))
{ {
@ -187,13 +185,13 @@ public long GetFileSize(string path)
public void CreateFolder(string path) public void CreateFolder(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
Directory.CreateDirectory(path); Directory.CreateDirectory(path);
} }
public void DeleteFile(string path) public void DeleteFile(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
Logger.Trace("Deleting file: {0}", path); Logger.Trace("Deleting file: {0}", path);
RemoveReadOnly(path); RemoveReadOnly(path);
@ -203,8 +201,8 @@ public void DeleteFile(string path)
public void CloneFile(string source, string destination, bool overwrite = false) public void CloneFile(string source, string destination, bool overwrite = false)
{ {
Ensure.That(source, () => source).IsValidPath(); Ensure.That(source, () => source).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(destination, () => destination).IsValidPath(); Ensure.That(destination, () => destination).IsValidPath(PathValidationType.CurrentOs);
if (source.PathEquals(destination)) if (source.PathEquals(destination))
{ {
@ -221,8 +219,8 @@ protected virtual void CloneFileInternal(string source, string destination, bool
public void CopyFile(string source, string destination, bool overwrite = false) public void CopyFile(string source, string destination, bool overwrite = false)
{ {
Ensure.That(source, () => source).IsValidPath(); Ensure.That(source, () => source).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(destination, () => destination).IsValidPath(); Ensure.That(destination, () => destination).IsValidPath(PathValidationType.CurrentOs);
if (source.PathEquals(destination)) if (source.PathEquals(destination))
{ {
@ -239,8 +237,8 @@ protected virtual void CopyFileInternal(string source, string destination, bool
public void MoveFile(string source, string destination, bool overwrite = false) public void MoveFile(string source, string destination, bool overwrite = false)
{ {
Ensure.That(source, () => source).IsValidPath(); Ensure.That(source, () => source).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(destination, () => destination).IsValidPath(); Ensure.That(destination, () => destination).IsValidPath(PathValidationType.CurrentOs);
if (source.PathEquals(destination)) if (source.PathEquals(destination))
{ {
@ -258,8 +256,8 @@ public void MoveFile(string source, string destination, bool overwrite = false)
public void MoveFolder(string source, string destination) public void MoveFolder(string source, string destination)
{ {
Ensure.That(source, () => source).IsValidPath(); Ensure.That(source, () => source).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(destination, () => destination).IsValidPath(); Ensure.That(destination, () => destination).IsValidPath(PathValidationType.CurrentOs);
Directory.Move(source, destination); Directory.Move(source, destination);
} }
@ -288,7 +286,7 @@ public virtual bool TryCreateRefLink(string source, string destination)
public void DeleteFolder(string path, bool recursive) public void DeleteFolder(string path, bool recursive)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var files = Directory.GetFiles(path, "*.*", recursive ? SearchOption.AllDirectories : SearchOption.TopDirectoryOnly); var files = Directory.GetFiles(path, "*.*", recursive ? SearchOption.AllDirectories : SearchOption.TopDirectoryOnly);
Array.ForEach(files, RemoveReadOnly); Array.ForEach(files, RemoveReadOnly);
@ -298,28 +296,28 @@ public void DeleteFolder(string path, bool recursive)
public string ReadAllText(string filePath) public string ReadAllText(string filePath)
{ {
Ensure.That(filePath, () => filePath).IsValidPath(); Ensure.That(filePath, () => filePath).IsValidPath(PathValidationType.CurrentOs);
return File.ReadAllText(filePath); return File.ReadAllText(filePath);
} }
public void WriteAllText(string filename, string contents) public void WriteAllText(string filename, string contents)
{ {
Ensure.That(filename, () => filename).IsValidPath(); Ensure.That(filename, () => filename).IsValidPath(PathValidationType.CurrentOs);
RemoveReadOnly(filename); RemoveReadOnly(filename);
File.WriteAllText(filename, contents); File.WriteAllText(filename, contents);
} }
public void FolderSetLastWriteTime(string path, DateTime dateTime) public void FolderSetLastWriteTime(string path, DateTime dateTime)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
Directory.SetLastWriteTimeUtc(path, dateTime); Directory.SetLastWriteTimeUtc(path, dateTime);
} }
public void FileSetLastWriteTime(string path, DateTime dateTime) public void FileSetLastWriteTime(string path, DateTime dateTime)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
File.SetLastWriteTime(path, dateTime); File.SetLastWriteTime(path, dateTime);
} }
@ -341,14 +339,14 @@ public bool IsFileLocked(string file)
public virtual string GetPathRoot(string path) public virtual string GetPathRoot(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
return Path.GetPathRoot(path); return Path.GetPathRoot(path);
} }
public string GetParentFolder(string path) public string GetParentFolder(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var parent = Directory.GetParent(path.TrimEnd(Path.DirectorySeparatorChar)); var parent = Directory.GetParent(path.TrimEnd(Path.DirectorySeparatorChar));
@ -381,7 +379,7 @@ public FileAttributes GetFileAttributes(string path)
public void EmptyFolder(string path) public void EmptyFolder(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
foreach (var file in GetFiles(path, SearchOption.TopDirectoryOnly)) foreach (var file in GetFiles(path, SearchOption.TopDirectoryOnly))
{ {
@ -471,7 +469,7 @@ protected List<DriveInfo> GetDriveInfoMounts()
public List<DirectoryInfo> GetDirectoryInfos(string path) public List<DirectoryInfo> GetDirectoryInfos(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var di = new DirectoryInfo(path); var di = new DirectoryInfo(path);
@ -480,7 +478,7 @@ public List<DirectoryInfo> GetDirectoryInfos(string path)
public List<FileInfo> GetFileInfos(string path) public List<FileInfo> GetFileInfos(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var di = new DirectoryInfo(path); var di = new DirectoryInfo(path);

View File

@ -43,8 +43,8 @@ private string ResolveRealParentPath(string path)
public TransferMode TransferFolder(string sourcePath, string targetPath, TransferMode mode) public TransferMode TransferFolder(string sourcePath, string targetPath, TransferMode mode)
{ {
Ensure.That(sourcePath, () => sourcePath).IsValidPath(); Ensure.That(sourcePath, () => sourcePath).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(targetPath, () => targetPath).IsValidPath(); Ensure.That(targetPath, () => targetPath).IsValidPath(PathValidationType.CurrentOs);
sourcePath = ResolveRealParentPath(sourcePath); sourcePath = ResolveRealParentPath(sourcePath);
targetPath = ResolveRealParentPath(targetPath); targetPath = ResolveRealParentPath(targetPath);
@ -140,8 +140,8 @@ public int MirrorFolder(string sourcePath, string targetPath)
{ {
var filesCopied = 0; var filesCopied = 0;
Ensure.That(sourcePath, () => sourcePath).IsValidPath(); Ensure.That(sourcePath, () => sourcePath).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(targetPath, () => targetPath).IsValidPath(); Ensure.That(targetPath, () => targetPath).IsValidPath(PathValidationType.CurrentOs);
sourcePath = ResolveRealParentPath(sourcePath); sourcePath = ResolveRealParentPath(sourcePath);
targetPath = ResolveRealParentPath(targetPath); targetPath = ResolveRealParentPath(targetPath);
@ -255,8 +255,8 @@ private bool CompareFiles(string sourceFile, string targetFile)
public TransferMode TransferFile(string sourcePath, string targetPath, TransferMode mode, bool overwrite = false) public TransferMode TransferFile(string sourcePath, string targetPath, TransferMode mode, bool overwrite = false)
{ {
Ensure.That(sourcePath, () => sourcePath).IsValidPath(); Ensure.That(sourcePath, () => sourcePath).IsValidPath(PathValidationType.CurrentOs);
Ensure.That(targetPath, () => targetPath).IsValidPath(); Ensure.That(targetPath, () => targetPath).IsValidPath(PathValidationType.CurrentOs);
sourcePath = ResolveRealParentPath(sourcePath); sourcePath = ResolveRealParentPath(sourcePath);
targetPath = ResolveRealParentPath(targetPath); targetPath = ResolveRealParentPath(targetPath);

View File

@ -71,7 +71,7 @@ public FileSystemResult LookupContents(string query, bool includeFiles, bool all
if ( if (
allowFoldersWithoutTrailingSlashes && allowFoldersWithoutTrailingSlashes &&
query.IsPathValid() && query.IsPathValid(PathValidationType.CurrentOs) &&
_diskProvider.FolderExists(query)) _diskProvider.FolderExists(query))
{ {
return GetResult(query, includeFiles); return GetResult(query, includeFiles);

View File

@ -162,7 +162,7 @@ public string FileName
} }
} }
public bool IsValid => _path.IsPathValid(); public bool IsValid => _path.IsPathValid(PathValidationType.CurrentOs);
private int GetFileNameIndex() private int GetFileNameIndex()
{ {

View File

@ -0,0 +1,8 @@
namespace NzbDrone.Common.Disk
{
public enum PathValidationType
{
CurrentOs,
AnyOs
}
}

View File

@ -1,5 +1,6 @@
using System.Diagnostics; using System.Diagnostics;
using System.Text.RegularExpressions; using System.Text.RegularExpressions;
using NzbDrone.Common.Disk;
using NzbDrone.Common.EnsureThat.Resources; using NzbDrone.Common.EnsureThat.Resources;
using NzbDrone.Common.EnvironmentInfo; using NzbDrone.Common.EnvironmentInfo;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
@ -111,14 +112,14 @@ public static Param<string> IsRelativePath(this Param<string> param)
} }
[DebuggerStepThrough] [DebuggerStepThrough]
public static Param<string> IsValidPath(this Param<string> param) public static Param<string> IsValidPath(this Param<string> param, PathValidationType validationType)
{ {
if (string.IsNullOrWhiteSpace(param.Value)) if (string.IsNullOrWhiteSpace(param.Value))
{ {
throw ExceptionFactory.CreateForParamValidation(param.Name, ExceptionMessages.EnsureExtensions_IsNotNullOrWhiteSpace); throw ExceptionFactory.CreateForParamValidation(param.Name, ExceptionMessages.EnsureExtensions_IsNotNullOrWhiteSpace);
} }
if (param.Value.IsPathValid()) if (param.Value.IsPathValid(validationType))
{ {
return param; return param;
} }

View File

@ -30,12 +30,12 @@ public static class PathExtensions
public static string CleanFilePath(this string path) public static string CleanFilePath(this string path)
{ {
Ensure.That(path, () => path).IsNotNullOrWhiteSpace(); Ensure.That(path, () => path).IsNotNullOrWhiteSpace();
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.AnyOs);
var info = new FileInfo(path.Trim()); var info = new FileInfo(path.Trim());
// UNC // UNC
if (OsInfo.IsWindows && info.FullName.StartsWith(@"\\")) if (!info.FullName.Contains('/') && info.FullName.StartsWith(@"\\"))
{ {
return info.FullName.TrimEnd('/', '\\', ' '); return info.FullName.TrimEnd('/', '\\', ' ');
} }
@ -147,24 +147,24 @@ public static bool IsParentPath(this string parentPath, string childPath)
private static readonly Regex WindowsPathWithDriveRegex = new Regex(@"^[a-zA-Z]:\\", RegexOptions.Compiled); private static readonly Regex WindowsPathWithDriveRegex = new Regex(@"^[a-zA-Z]:\\", RegexOptions.Compiled);
public static bool IsPathValid(this string path) public static bool IsPathValid(this string path, PathValidationType validationType)
{ {
if (path.ContainsInvalidPathChars() || string.IsNullOrWhiteSpace(path)) if (path.ContainsInvalidPathChars() || string.IsNullOrWhiteSpace(path))
{ {
return false; return false;
} }
if (validationType == PathValidationType.AnyOs)
{
return IsPathValidForWindows(path) || IsPathValidForNonWindows(path);
}
if (OsInfo.IsNotWindows) if (OsInfo.IsNotWindows)
{ {
return path.StartsWith(Path.DirectorySeparatorChar.ToString()); return IsPathValidForNonWindows(path);
} }
if (path.StartsWith("\\") || WindowsPathWithDriveRegex.IsMatch(path)) return IsPathValidForWindows(path);
{
return true;
}
return false;
} }
public static bool ContainsInvalidPathChars(this string text) public static bool ContainsInvalidPathChars(this string text)
@ -375,5 +375,15 @@ public static string GetNlogConfigPath(this IAppFolderInfo appFolderInfo)
{ {
return Path.Combine(appFolderInfo.StartUpFolder, NLOG_CONFIG_FILE); return Path.Combine(appFolderInfo.StartUpFolder, NLOG_CONFIG_FILE);
} }
private static bool IsPathValidForWindows(string path)
{
return path.StartsWith("\\") || WindowsPathWithDriveRegex.IsMatch(path);
}
private static bool IsPathValidForNonWindows(string path)
{
return path.StartsWith("/");
}
} }
} }

View File

@ -1,4 +1,5 @@
using System.Collections.Generic; using System.Collections.Generic;
using NzbDrone.Common.Disk;
using NzbDrone.Common.EnvironmentInfo; using NzbDrone.Common.EnvironmentInfo;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;

View File

@ -70,7 +70,7 @@ public bool IsUpgradable(QualityProfile qualityProfile, QualityModel currentQual
if (newFormatScore <= currentFormatScore) if (newFormatScore <= currentFormatScore)
{ {
_logger.Debug("New item's custom formats [{0}] ({1}) do not improve on [{2}] ({3}, skipping", _logger.Debug("New item's custom formats [{0}] ({1}) do not improve on [{2}] ({3}), skipping",
newCustomFormats.ConcatToString(), newCustomFormats.ConcatToString(),
newFormatScore, newFormatScore,
currentCustomFormats.ConcatToString(), currentCustomFormats.ConcatToString(),

View File

@ -99,7 +99,7 @@ private EpisodeFile TransferFile(EpisodeFile episodeFile, Series series, List<Ep
{ {
Ensure.That(episodeFile, () => episodeFile).IsNotNull(); Ensure.That(episodeFile, () => episodeFile).IsNotNull();
Ensure.That(series, () => series).IsNotNull(); Ensure.That(series, () => series).IsNotNull();
Ensure.That(destinationFilePath, () => destinationFilePath).IsValidPath(); Ensure.That(destinationFilePath, () => destinationFilePath).IsValidPath(PathValidationType.CurrentOs);
var episodeFilePath = episodeFile.Path ?? Path.Combine(series.Path, episodeFile.RelativePath); var episodeFilePath = episodeFile.Path ?? Path.Combine(series.Path, episodeFile.RelativePath);

View File

@ -1,4 +1,5 @@
using System.IO; using System.IO;
using NzbDrone.Common.Disk;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
using NzbDrone.Core.Parser; using NzbDrone.Core.Parser;
using NzbDrone.Core.Parser.Model; using NzbDrone.Core.Parser.Model;

View File

@ -72,7 +72,7 @@ public List<RootFolder> AllWithUnmappedFolders()
{ {
try try
{ {
if (folder.Path.IsPathValid()) if (folder.Path.IsPathValid(PathValidationType.CurrentOs))
{ {
GetDetails(folder, seriesPaths, true); GetDetails(folder, seriesPaths, true);
} }

View File

@ -1,4 +1,5 @@
using FluentValidation.Validators; using FluentValidation.Validators;
using NzbDrone.Common.Disk;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
namespace NzbDrone.Core.Validation namespace NzbDrone.Core.Validation
@ -17,7 +18,7 @@ protected override bool IsValid(PropertyValidatorContext context)
return false; return false;
} }
return context.PropertyValue.ToString().IsPathValid(); return context.PropertyValue.ToString().IsPathValid(PathValidationType.CurrentOs);
} }
} }
} }

View File

@ -1,5 +1,6 @@
using FluentValidation; using FluentValidation;
using FluentValidation.Validators; using FluentValidation.Validators;
using NzbDrone.Common.Disk;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
namespace NzbDrone.Core.Validation.Paths namespace NzbDrone.Core.Validation.Paths
@ -26,7 +27,7 @@ protected override bool IsValid(PropertyValidatorContext context)
return false; return false;
} }
return context.PropertyValue.ToString().IsPathValid(); return context.PropertyValue.ToString().IsPathValid(PathValidationType.CurrentOs);
} }
} }
} }

View File

@ -40,7 +40,7 @@ public override IMount GetMount(string path)
public override long? GetAvailableSpace(string path) public override long? GetAvailableSpace(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var mount = GetMount(path); var mount = GetMount(path);
@ -217,7 +217,7 @@ protected override bool IsSpecialMount(IMount mount)
public override long? GetTotalSize(string path) public override long? GetTotalSize(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var mount = GetMount(path); var mount = GetMount(path);

View File

@ -35,7 +35,7 @@ public override IMount GetMount(string path)
public override string GetPathRoot(string path) public override string GetPathRoot(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var reparsePoint = GetReparsePoint(path); var reparsePoint = GetReparsePoint(path);
@ -44,7 +44,7 @@ public override string GetPathRoot(string path)
public override long? GetAvailableSpace(string path) public override long? GetAvailableSpace(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var root = GetPathRoot(path); var root = GetPathRoot(path);
@ -58,7 +58,7 @@ public override string GetPathRoot(string path)
public override void InheritFolderPermissions(string filename) public override void InheritFolderPermissions(string filename)
{ {
Ensure.That(filename, () => filename).IsValidPath(); Ensure.That(filename, () => filename).IsValidPath(PathValidationType.CurrentOs);
var fileInfo = new FileInfo(filename); var fileInfo = new FileInfo(filename);
var fs = fileInfo.GetAccessControl(AccessControlSections.Access); var fs = fileInfo.GetAccessControl(AccessControlSections.Access);
@ -121,7 +121,7 @@ public override void CopyPermissions(string sourcePath, string targetPath)
public override long? GetTotalSize(string path) public override long? GetTotalSize(string path)
{ {
Ensure.That(path, () => path).IsValidPath(); Ensure.That(path, () => path).IsValidPath(PathValidationType.CurrentOs);
var root = GetPathRoot(path); var root = GetPathRoot(path);
@ -135,7 +135,7 @@ public override void CopyPermissions(string sourcePath, string targetPath)
private static long DriveFreeSpaceEx(string folderName) private static long DriveFreeSpaceEx(string folderName)
{ {
Ensure.That(folderName, () => folderName).IsValidPath(); Ensure.That(folderName, () => folderName).IsValidPath(PathValidationType.CurrentOs);
if (!folderName.EndsWith("\\")) if (!folderName.EndsWith("\\"))
{ {
@ -156,7 +156,7 @@ private static long DriveFreeSpaceEx(string folderName)
private static long DriveTotalSizeEx(string folderName) private static long DriveTotalSizeEx(string folderName)
{ {
Ensure.That(folderName, () => folderName).IsValidPath(); Ensure.That(folderName, () => folderName).IsValidPath(PathValidationType.CurrentOs);
if (!folderName.EndsWith("\\")) if (!folderName.EndsWith("\\"))
{ {