1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-10 23:29:53 +02:00

New: Log when testing for matching Remote Path Mapping

This commit is contained in:
bakerboy448 2023-07-19 20:11:05 -05:00 committed by GitHub
parent 6d53d2a153
commit 360d989cb0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -101,12 +101,12 @@ private void ValidateMapping(List<RemotePathMapping> existing, RemotePathMapping
if (remotePath.IsEmpty) if (remotePath.IsEmpty)
{ {
throw new ArgumentException("Invalid RemotePath"); throw new ArgumentException("Invalid RemotePath. RemotePath cannot be empty.");
} }
if (localPath.IsEmpty || !localPath.IsRooted) if (localPath.IsEmpty || !localPath.IsRooted)
{ {
throw new ArgumentException("Invalid LocalPath"); throw new ArgumentException("Invalid LocalPath. LocalPath cannot be empty and must not be the root.");
} }
if (!_diskProvider.FolderExists(localPath.FullPath)) if (!_diskProvider.FolderExists(localPath.FullPath))
@ -116,7 +116,7 @@ private void ValidateMapping(List<RemotePathMapping> existing, RemotePathMapping
if (existing.Exists(r => r.Host == mapping.Host && r.RemotePath == mapping.RemotePath)) if (existing.Exists(r => r.Host == mapping.Host && r.RemotePath == mapping.RemotePath))
{ {
throw new InvalidOperationException("RemotePath already mounted."); throw new InvalidOperationException("RemotePath already configured.");
} }
} }
@ -127,11 +127,14 @@ public OsPath RemapRemoteToLocal(string host, OsPath remotePath)
return remotePath; return remotePath;
} }
_logger.Trace("Evaluating remote path remote mappings for match to host [{0}] and remote path [{1}]", host, remotePath.FullPath);
foreach (var mapping in All()) foreach (var mapping in All())
{ {
_logger.Trace("Checking configured remote path mapping: {0} - {1}", mapping.Host, mapping.RemotePath);
if (host.Equals(mapping.Host, StringComparison.InvariantCultureIgnoreCase) && new OsPath(mapping.RemotePath).Contains(remotePath)) if (host.Equals(mapping.Host, StringComparison.InvariantCultureIgnoreCase) && new OsPath(mapping.RemotePath).Contains(remotePath))
{ {
var localPath = new OsPath(mapping.LocalPath) + (remotePath - new OsPath(mapping.RemotePath)); var localPath = new OsPath(mapping.LocalPath) + (remotePath - new OsPath(mapping.RemotePath));
_logger.Debug("Remapped remote path [{0}] to local path [{1}] for host [{2}]", remotePath, localPath, host);
return localPath; return localPath;
} }
@ -147,11 +150,14 @@ public OsPath RemapLocalToRemote(string host, OsPath localPath)
return localPath; return localPath;
} }
_logger.Trace("Evaluating remote path local mappings for match to host [{0}] and local path [{1}]", host, localPath.FullPath);
foreach (var mapping in All()) foreach (var mapping in All())
{ {
_logger.Trace("Checking configured remote path mapping {0} - {1}", mapping.Host, mapping.RemotePath);
if (host.Equals(mapping.Host, StringComparison.InvariantCultureIgnoreCase) && new OsPath(mapping.LocalPath).Contains(localPath)) if (host.Equals(mapping.Host, StringComparison.InvariantCultureIgnoreCase) && new OsPath(mapping.LocalPath).Contains(localPath))
{ {
var remotePath = new OsPath(mapping.RemotePath) + (localPath - new OsPath(mapping.LocalPath)); var remotePath = new OsPath(mapping.RemotePath) + (localPath - new OsPath(mapping.LocalPath));
_logger.Debug("Remapped local path [{0}] to remote path [{1}] for host [{2}]", localPath, remotePath, host);
return remotePath; return remotePath;
} }