From 4c69edebe048433977304241e3dbfb9e8a2ab968 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Mon, 22 Apr 2013 11:46:23 -0400 Subject: fixes #180 - Deleting users doesn't remove all associated data. --- .../Library/UserManager.cs | 28 +++++++++++++++++++++- 1 file changed, 27 insertions(+), 1 deletion(-) (limited to 'MediaBrowser.Server.Implementations/Library/UserManager.cs') diff --git a/MediaBrowser.Server.Implementations/Library/UserManager.cs b/MediaBrowser.Server.Implementations/Library/UserManager.cs index 816a72616..e6ffe075d 100644 --- a/MediaBrowser.Server.Implementations/Library/UserManager.cs +++ b/MediaBrowser.Server.Implementations/Library/UserManager.cs @@ -1,4 +1,5 @@ -using MediaBrowser.Common.Events; +using System.IO; +using MediaBrowser.Common.Events; using MediaBrowser.Common.Extensions; using MediaBrowser.Controller.Configuration; using MediaBrowser.Controller.Dto; @@ -485,6 +486,31 @@ namespace MediaBrowser.Server.Implementations.Library await UserRepository.DeleteUser(user, CancellationToken.None).ConfigureAwait(false); + if (user.Configuration.UseCustomLibrary) + { + var path = user.RootFolderPath; + + try + { + Directory.Delete(path, true); + } + catch (IOException ex) + { + _logger.ErrorException("Error deleting directory {0}", ex, path); + } + + path = user.ConfigurationFilePath; + + try + { + File.Delete(path); + } + catch (IOException ex) + { + _logger.ErrorException("Error deleting file {0}", ex, path); + } + } + OnUserDeleted(user); // Force this to be lazy loaded again -- cgit v1.2.3