2011-04-20 10:44:13 +03:00
|
|
|
using NzbDrone.Core.Model.Notification;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Providers.Jobs
|
|
|
|
{
|
|
|
|
public interface IJob
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// Name of the timer.
|
|
|
|
/// This is the name that will be visible in all UI elements
|
2011-08-22 03:48:37 +03:00
|
|
|
/// </summary>\\\
|
2011-04-20 10:44:13 +03:00
|
|
|
string Name { get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Default Interval that this job should run at. In seconds.
|
|
|
|
/// </summary>
|
2011-05-11 21:25:32 +03:00
|
|
|
/// <remarks>Setting this value to 0 means the job will not be
|
|
|
|
/// executed by the schedule and is only triggered manually.</remarks>
|
2011-04-20 10:44:13 +03:00
|
|
|
int DefaultInterval { get; }
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Starts the job
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="notification">Notification object that is passed in by JobProvider.
|
|
|
|
/// this object should be used to update the progress on the UI</param>
|
|
|
|
/// <param name="targetId">The that should be used to limit the target of this job</param>
|
2011-08-22 03:48:37 +03:00
|
|
|
/// /// <param name="secondaryTargetId">The that should be used to limit the target of this job</param>
|
|
|
|
void Start(ProgressNotification notification, int targetId, int secondaryTargetId);
|
2011-04-20 10:44:13 +03:00
|
|
|
}
|
|
|
|
}
|