From 3db92516bea0f473022f257dd61dfeafa6998c75 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Sun, 27 Apr 2014 15:30:12 -0400 Subject: updated nuget --- .../Notifications/NotificationManager.cs | 20 ++++++-------------- 1 file changed, 6 insertions(+), 14 deletions(-) (limited to 'MediaBrowser.Server.Implementations/Notifications/NotificationManager.cs') diff --git a/MediaBrowser.Server.Implementations/Notifications/NotificationManager.cs b/MediaBrowser.Server.Implementations/Notifications/NotificationManager.cs index 300d2c351..f3183ec0b 100644 --- a/MediaBrowser.Server.Implementations/Notifications/NotificationManager.cs +++ b/MediaBrowser.Server.Implementations/Notifications/NotificationManager.cs @@ -38,7 +38,9 @@ namespace MediaBrowser.Server.Implementations.Notifications null : _config.Configuration.NotificationOptions.GetOptions(notificationType); - var users = GetUserIds(request, options).Select(i => _userManager.GetUserById(new Guid(i))); + var users = GetUserIds(request, options) + .Except(request.UserIds) + .Select(i => _userManager.GetUserById(new Guid(i))); var title = GetTitle(request, options); @@ -81,20 +83,10 @@ namespace MediaBrowser.Server.Implementations.Notifications } } - if (options != null) + if (options != null && !string.IsNullOrWhiteSpace(request.NotificationType)) { - switch (options.SendToUserMode) - { - case SendToUserType.Admins: - return _userManager.Users.Where(i => i.Configuration.IsAdministrator) - .Select(i => i.Id.ToString("N")); - case SendToUserType.All: - return _userManager.Users.Select(i => i.Id.ToString("N")); - case SendToUserType.Custom: - return options.SendToUsers; - default: - throw new ArgumentException("Unrecognized SendToUserMode: " + options.SendToUserMode); - } + return _userManager.Users.Where(i => _config.Configuration.NotificationOptions.IsEnabledToSendToUser(request.NotificationType, i.Id.ToString("N"), i.Configuration)) + .Select(i => i.Id.ToString("N")); } return new List(); -- cgit v1.2.3