#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

@@ -0,0 +1,30 @@
using System;
using Orchard.ContentManagement;
using Orchard.Core.Common.Models;
using Orchard.Security;
using Orchard.Tasks.Scheduling;
namespace Orchard.Core.Common.Scheduling {
public abstract class OwnedScheduledTaskHandler : IScheduledTaskHandler {
private readonly IOrchardServices _orchardServices;
protected OwnedScheduledTaskHandler(IOrchardServices orchardServices) {
_orchardServices = orchardServices;
}
protected void SetCurrentUser(ContentItem contentItem) {
IUser owner = null;
var commonPart = contentItem.As<CommonPart>();
if (commonPart != null) {
owner = commonPart.Owner;
}
if (owner == null) {
var superUser = _orchardServices.WorkContext.CurrentSite.SuperUser;
owner = _orchardServices.WorkContext.Resolve<IMembershipService>().GetUser(superUser);
}
_orchardServices.WorkContext.Resolve<IAuthenticationService>().SetAuthenticatedUserForRequest(owner);
}
public abstract void Process(ScheduledTaskContext context);
}
}

View File

@@ -227,6 +227,7 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Content Include="Common\Module.txt" /> <Content Include="Common\Module.txt" />
<Compile Include="Common\Scheduling\OwnedScheduledTaskHandler.cs" />
<Content Include="Common\Views\DefinitionTemplates\BodyTypePartSettings.cshtml" /> <Content Include="Common\Views\DefinitionTemplates\BodyTypePartSettings.cshtml" />
<Content Include="Common\Views\DefinitionTemplates\BodyPartSettings.cshtml" /> <Content Include="Common\Views\DefinitionTemplates\BodyPartSettings.cshtml" />
<Content Include="Common\Views\Fields.Common.Text.cshtml" /> <Content Include="Common\Views\Fields.Common.Text.cshtml" />

View File

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

View File

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