IBackgroundJobStore.cs 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. using System.Collections.Generic;
  2. using System.Threading.Tasks;
  3. namespace Abp.BackgroundJobs
  4. {
  5. /// <summary>
  6. /// Defines interface to store/get background jobs.
  7. /// </summary>
  8. public interface IBackgroundJobStore
  9. {
  10. /// <summary>
  11. /// Gets a BackgroundJobInfo based on the given jobId.
  12. /// </summary>
  13. /// <param name="jobId">The Job Unique Identifier.</param>
  14. /// <returns>The BackgroundJobInfo object.</returns>
  15. Task<BackgroundJobInfo> GetAsync(long jobId);
  16. /// <summary>
  17. /// Inserts a background job.
  18. /// </summary>
  19. /// <param name="jobInfo">Job information.</param>
  20. Task InsertAsync(BackgroundJobInfo jobInfo);
  21. /// <summary>
  22. /// Gets waiting jobs. It should get jobs based on these:
  23. /// Conditions: !IsAbandoned And NextTryTime &lt;= Clock.Now.
  24. /// Order by: Priority DESC, TryCount ASC, NextTryTime ASC.
  25. /// Maximum result: <paramref name="maxResultCount"/>.
  26. /// </summary>
  27. /// <param name="maxResultCount">Maximum result count.</param>
  28. Task<List<BackgroundJobInfo>> GetWaitingJobsAsync(int maxResultCount);
  29. /// <summary>
  30. /// Deletes a job.
  31. /// </summary>
  32. /// <param name="jobInfo">Job information.</param>
  33. Task DeleteAsync(BackgroundJobInfo jobInfo);
  34. /// <summary>
  35. /// Updates a job.
  36. /// </summary>
  37. /// <param name="jobInfo">Job information.</param>
  38. Task UpdateAsync(BackgroundJobInfo jobInfo);
  39. }
  40. }