#17554: Placing content items transactions within transaction scopes.

--HG--
branch : 1.x
This commit is contained in:
Andre Rodrigues
2011-03-28 17:02:48 -07:00
parent 136e214ed1
commit 2f4f44f016

View File

@@ -126,44 +126,52 @@ namespace Orchard.Core.Contents.Controllers {
[HttpPost, ActionName("List")] [HttpPost, ActionName("List")]
[FormValueRequired("submit.BulkEdit")] [FormValueRequired("submit.BulkEdit")]
public ActionResult ListPOST(ContentOptions options, IEnumerable<int> itemIds, string returnUrl) { public ActionResult ListPOST(ContentOptions options, IEnumerable<int> itemIds, string returnUrl) {
if (itemIds != null) { try {
switch (options.BulkAction) { if (itemIds != null) {
case ContentsBulkAction.None: switch (options.BulkAction) {
break; case ContentsBulkAction.None:
case ContentsBulkAction.PublishNow: break;
foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) { case ContentsBulkAction.PublishNow:
if (!Services.Authorizer.Authorize(Permissions.PublishContent, item, T("Couldn't publish selected content."))) foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) {
return new HttpUnauthorizedResult(); if (!Services.Authorizer.Authorize(Permissions.PublishContent, item, T("Couldn't publish selected content."))) {
_transactionManager.Cancel();
return new HttpUnauthorizedResult();
}
_contentManager.Publish(item); _contentManager.Publish(item);
Services.ContentManager.Flush(); }
} Services.Notifier.Information(T("Content successfully published."));
Services.Notifier.Information(T("Content successfully published.")); break;
break; case ContentsBulkAction.Unpublish:
case ContentsBulkAction.Unpublish: foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) {
foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) { if (!Services.Authorizer.Authorize(Permissions.PublishContent, item, T("Couldn't unpublish selected content."))) {
if (!Services.Authorizer.Authorize(Permissions.PublishContent, item, T("Couldn't unpublish selected content."))) _transactionManager.Cancel();
return new HttpUnauthorizedResult(); return new HttpUnauthorizedResult();
}
_contentManager.Unpublish(item); _contentManager.Unpublish(item);
Services.ContentManager.Flush(); }
} Services.Notifier.Information(T("Content successfully unpublished."));
Services.Notifier.Information(T("Content successfully unpublished.")); break;
break; case ContentsBulkAction.Remove:
case ContentsBulkAction.Remove: foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) {
foreach (var item in itemIds.Select(itemId => _contentManager.GetLatest(itemId))) { if (!Services.Authorizer.Authorize(Permissions.DeleteContent, item, T("Couldn't remove selected content."))) {
if (!Services.Authorizer.Authorize(Permissions.DeleteContent, item, T("Couldn't remove selected content."))) _transactionManager.Cancel();
return new HttpUnauthorizedResult(); return new HttpUnauthorizedResult();
}
_contentManager.Remove(item); _contentManager.Remove(item);
Services.ContentManager.Flush(); }
} Services.Notifier.Information(T("Content successfully removed."));
Services.Notifier.Information(T("Content successfully removed.")); break;
break; default:
default: throw new ArgumentOutOfRangeException();
throw new ArgumentOutOfRangeException(); }
} }
} }
catch {
_transactionManager.Cancel();
}
return this.RedirectLocal(returnUrl, () => RedirectToAction("List")); return this.RedirectLocal(returnUrl, () => RedirectToAction("List"));
} }