Handle create link access dennied on Windows

This commit is contained in:
Ádám Kovács
2022-11-02 11:10:08 +01:00
parent 8e5ddf84ab
commit 642c30d1ce

View File

@@ -1,3 +1,4 @@
using System.Runtime.InteropServices;
using Alma.Configuration.Module; using Alma.Configuration.Module;
using Alma.Configuration.Repository; using Alma.Configuration.Repository;
using Alma.Data; using Alma.Data;
@@ -86,21 +87,17 @@ public class LinkCommand : ICommand
moduleConfiguration)).ToList(); moduleConfiguration)).ToList();
if (moduleConfigurationFile is not null) itemsToLink.RemoveAll(i => i.SourcePath == moduleConfigurationFileFullPath); if (moduleConfigurationFile is not null) itemsToLink.RemoveAll(i => i.SourcePath == moduleConfigurationFileFullPath);
foreach (var itemToLink in itemsToLink)
{
Console.WriteLine($"Link: '{itemToLink.SourcePath}' '{itemToLink.TargetPath}'");
}
var successfulLinks = CreateLinks(itemsToLink); var successfulLinks = CreateLinks(itemsToLink);
await _metadataHandler.SaveLinkedItemsAsync(successfulLinks, moduleDir, currentTargetDirectory); await _metadataHandler.SaveLinkedItemsAsync(successfulLinks, moduleDir, currentTargetDirectory);
//await _metadataHandler.SaveLinkedItemsAsync(itemsToLink, moduleDir, currentTargetDirectory);
} }
private List<ItemToLink> CreateLinks(List<ItemToLink> itemsToLink) private List<ItemToLink> CreateLinks(List<ItemToLink> itemsToLink)
{ {
var successfulLinks = new List<ItemToLink>(); var successfulLinks = new List<ItemToLink>();
try
{
foreach (var itemToLink in itemsToLink) foreach (var itemToLink in itemsToLink)
{ {
if (File.Exists(itemToLink.TargetPath) || Directory.Exists(itemToLink.TargetPath)) if (File.Exists(itemToLink.TargetPath) || Directory.Exists(itemToLink.TargetPath))
@@ -112,13 +109,15 @@ public class LinkCommand : ICommand
var sourceFileExists = File.Exists(itemToLink.SourcePath); var sourceFileExists = File.Exists(itemToLink.SourcePath);
var sourceDirectoryExists = Directory.Exists(itemToLink.SourcePath); var sourceDirectoryExists = Directory.Exists(itemToLink.SourcePath);
Console.WriteLine($"Linking: '{itemToLink.SourcePath}' '{itemToLink.TargetPath}'");
if (sourceFileExists) if (sourceFileExists)
{ {
File.CreateSymbolicLink(itemToLink.TargetPath, itemToLink.SourcePath); File.CreateSymbolicLink(itemToLink.TargetPath, itemToLink.SourcePath);
} }
else if (sourceDirectoryExists) else if (sourceDirectoryExists)
{ {
File.CreateSymbolicLink(itemToLink.TargetPath, itemToLink.SourcePath); Directory.CreateSymbolicLink(itemToLink.TargetPath, itemToLink.SourcePath);
} }
else else
{ {
@@ -128,6 +127,15 @@ public class LinkCommand : ICommand
successfulLinks.Add(itemToLink); successfulLinks.Add(itemToLink);
} }
}
catch (IOException e)
{
Console.WriteLine("An error occured while creating links: " + e.Message);
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows))
{
Console.WriteLine("On Windows symlinks can be greated only with Administrator privileges.");
}
}
return successfulLinks; return successfulLinks;
} }