#16825: Exception in background task

--HG--
branch : dev
This commit is contained in:
Dave Reed
2010-12-09 11:34:57 -08:00
parent 9dcb8178b5
commit 1295cc8949
4 changed files with 41 additions and 6 deletions

View File

@@ -1,27 +1,29 @@
using JetBrains.Annotations;
using Orchard.ContentManagement;
using Orchard.Core.Common.Scheduling;
using Orchard.Logging;
using Orchard.Tasks.Scheduling;
namespace Orchard.ArchiveLater.Handlers {
[UsedImplicitly]
public class UnpublishingTaskHandler : IScheduledTaskHandler {
public class UnpublishingTaskHandler : OwnedScheduledTaskHandler {
private readonly IContentManager _contentManager;
public UnpublishingTaskHandler(IContentManager contentManager) {
public UnpublishingTaskHandler(IContentManager contentManager, IOrchardServices orchardServices) : base(orchardServices) {
_contentManager = contentManager;
Logger = NullLogger.Instance;
}
public ILogger Logger { get; set; }
public void Process(ScheduledTaskContext context) {
public override void Process(ScheduledTaskContext context) {
if (context.Task.TaskType == "Unpublish") {
Logger.Information("Unpublishing item #{0} version {1} scheduled at {2} utc",
context.Task.ContentItem.Id,
context.Task.ContentItem.Version,
context.Task.ScheduledUtc);
SetCurrentUser(context.Task.ContentItem);
_contentManager.Unpublish(context.Task.ContentItem);
}
}

View File

@@ -1,27 +1,29 @@
using JetBrains.Annotations;
using Orchard.ContentManagement;
using Orchard.Core.Common.Scheduling;
using Orchard.Logging;
using Orchard.Tasks.Scheduling;
namespace Orchard.PublishLater.Handlers {
[UsedImplicitly]
public class PublishingTaskHandler : IScheduledTaskHandler {
public class PublishingTaskHandler : OwnedScheduledTaskHandler {
private readonly IContentManager _contentManager;
public PublishingTaskHandler(IContentManager contentManager) {
public PublishingTaskHandler(IContentManager contentManager, IOrchardServices orchardServices) : base(orchardServices) {
_contentManager = contentManager;
Logger = NullLogger.Instance;
}
public ILogger Logger { get; set; }
public void Process(ScheduledTaskContext context) {
public override void Process(ScheduledTaskContext context) {
if (context.Task.TaskType == "Publish") {
Logger.Information("Publishing item #{0} version {1} scheduled at {2} utc",
context.Task.ContentItem.Id,
context.Task.ContentItem.Version,
context.Task.ScheduledUtc);
SetCurrentUser(context.Task.ContentItem);
_contentManager.Publish(context.Task.ContentItem);
}
}