aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2015-12-12 21:31:37 -0500
committerLuke Pulverenti <luke.pulverenti@gmail.com>2015-12-12 21:31:37 -0500
commitd78e2764d81083be26d0b51873dc689d6d8f0117 (patch)
treeb53278872983b5c1d0dc779d8cd0449c0f47fb25 /MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs
parentd341cd39aa293dd6d98554650ad637e1f3603179 (diff)
randomize people task default start time
Diffstat (limited to 'MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs')
-rw-r--r--MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs11
1 files changed, 9 insertions, 2 deletions
diff --git a/MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs b/MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs
index bfa4fe944..05c3db63c 100644
--- a/MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs
+++ b/MediaBrowser.Server.Implementations/ScheduledTasks/PeopleValidationTask.cs
@@ -4,6 +4,7 @@ using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
+using MediaBrowser.Controller;
namespace MediaBrowser.Server.Implementations.ScheduledTasks
{
@@ -17,13 +18,16 @@ namespace MediaBrowser.Server.Implementations.ScheduledTasks
/// </summary>
private readonly ILibraryManager _libraryManager;
+ private readonly IServerApplicationHost _appHost;
+
/// <summary>
/// Initializes a new instance of the <see cref="PeopleValidationTask" /> class.
/// </summary>
/// <param name="libraryManager">The library manager.</param>
- public PeopleValidationTask(ILibraryManager libraryManager)
+ public PeopleValidationTask(ILibraryManager libraryManager, IServerApplicationHost appHost)
{
_libraryManager = libraryManager;
+ _appHost = appHost;
}
/// <summary>
@@ -32,9 +36,12 @@ namespace MediaBrowser.Server.Implementations.ScheduledTasks
/// <returns>IEnumerable{BaseTaskTrigger}.</returns>
public IEnumerable<ITaskTrigger> GetDefaultTriggers()
{
+ // Randomize the default start hour because this operation can really hammer internet metadata providers
+ var startHour = new Random(_appHost.SystemId.GetHashCode()).Next(0, 8);
+
return new ITaskTrigger[]
{
- new DailyTrigger { TimeOfDay = TimeSpan.FromHours(3) },
+ new DailyTrigger { TimeOfDay = TimeSpan.FromHours(startHour) },
};
}