From 31c2d9853288fa1addac3c7c3b97a9e9d084c531 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Fri, 5 Apr 2013 15:34:33 -0400 Subject: Added a display preferences manager --- .../Library/DisplayPreferencesManager.cs | 93 ++++++++++++++++++++++ 1 file changed, 93 insertions(+) create mode 100644 MediaBrowser.Server.Implementations/Library/DisplayPreferencesManager.cs (limited to 'MediaBrowser.Server.Implementations/Library/DisplayPreferencesManager.cs') diff --git a/MediaBrowser.Server.Implementations/Library/DisplayPreferencesManager.cs b/MediaBrowser.Server.Implementations/Library/DisplayPreferencesManager.cs new file mode 100644 index 000000000..a8e51a75b --- /dev/null +++ b/MediaBrowser.Server.Implementations/Library/DisplayPreferencesManager.cs @@ -0,0 +1,93 @@ +using MediaBrowser.Controller; +using MediaBrowser.Controller.Library; +using MediaBrowser.Model.Entities; +using MediaBrowser.Model.Logging; +using System; +using System.Collections.Concurrent; +using System.Threading; +using System.Threading.Tasks; + +namespace MediaBrowser.Server.Implementations.Library +{ + /// + /// Class DisplayPreferencesManager + /// + public class DisplayPreferencesManager : IDisplayPreferencesManager + { + /// + /// The _logger + /// + private readonly ILogger _logger; + + /// + /// The _display preferences + /// + private readonly ConcurrentDictionary> _displayPreferences = new ConcurrentDictionary>(); + + /// + /// Initializes a new instance of the class. + /// + /// The logger. + public DisplayPreferencesManager(ILogger logger) + { + _logger = logger; + } + + /// + /// Gets the display preferences. + /// + /// The display preferences id. + /// DisplayPreferences. + public Task GetDisplayPreferences(Guid displayPreferencesId) + { + return _displayPreferences.GetOrAdd(displayPreferencesId, keyName => RetrieveDisplayPreferences(displayPreferencesId)); + } + + /// + /// Retrieves the display preferences. + /// + /// The display preferences id. + /// DisplayPreferences. + private async Task RetrieveDisplayPreferences(Guid displayPreferencesId) + { + var displayPreferences = await Kernel.Instance.DisplayPreferencesRepository.GetDisplayPreferences(displayPreferencesId).ConfigureAwait(false); + + return displayPreferences ?? new DisplayPreferences { Id = displayPreferencesId }; + } + + /// + /// Saves display preferences for an item + /// + /// The display preferences. + /// The cancellation token. + /// Task. + public async Task SaveDisplayPreferences(DisplayPreferences displayPreferences, CancellationToken cancellationToken) + { + if (displayPreferences == null) + { + throw new ArgumentNullException("displayPreferences"); + } + if (displayPreferences.Id == Guid.Empty) + { + throw new ArgumentNullException("displayPreferences.Id"); + } + + try + { + await Kernel.Instance.DisplayPreferencesRepository.SaveDisplayPreferences(displayPreferences, + cancellationToken).ConfigureAwait(false); + + var newValue = Task.FromResult(displayPreferences); + + // Once it succeeds, put it into the dictionary to make it available to everyone else + _displayPreferences.AddOrUpdate(displayPreferences.Id, newValue, delegate { return newValue; }); + } + catch (Exception ex) + { + _logger.ErrorException("Error saving display preferences", ex); + + throw; + } + } + } +} -- cgit v1.2.3