* ContentVersion cleanup backoffice UI (#11637) * init rollback ui prototype * add busy state to button, deselect version, add pagination status * add localisation * style current version * disable rollback button when nothing is selected * stop click event * Endpoints for paginated content versions. Light on tests, tight on time. * Endpoints to "pin" content versions * camel case json output. Not sure why json formatter not set for controller, bit risky to add it now * wire up paging * wire up pin/unpin * rename getPagedRollbackVersions to getPagedContentVersions * prevent selection of current version and current draft * add current draft and current version to UI * remove pointer if the row is not selectable * Improve warning for globally disabled cleanup feature. * Fix current loses prevent cleanup state on publish. * Added umbracoLog audit entries for "pin" / "unpin" * Match v9 defaults for keepVersions settings * Fix - losing preventCleanup on save current with content changes * update pin/unpin button labels * fix pagination bug * add missing " * always send culture when a doc type can vary Co-authored-by: Mads Rasmussen <madsr@hey.com> # Conflicts: # src/Umbraco.Core/ContentEditing/ContentVersionMetaViewModel.cs # src/Umbraco.Core/Models/HistoricContentVersionMeta.cs # src/Umbraco.Infrastructure/Services/Implement/ContentService.cs # src/Umbraco.Tests/Persistence/Repositories/DocumentVersionRepository_Tests_Integration.cs # src/Umbraco.Tests/Services/ContentVersionCleanupService_Tests_UnitTests.cs # src/Umbraco.Web.BackOffice/Controllers/ContentController.cs # src/Umbraco.Web.UI.Client/src/common/resources/content.resource.js # src/Umbraco.Web.UI/config/umbracoSettings.Release.config # src/Umbraco.Web.UI/umbraco/config/lang/en.xml # src/Umbraco.Web.UI/umbraco/config/lang/en_us.xml # src/Umbraco.Web/Umbraco.Web.csproj * Added tests * Misc - missed translation update * Bugfix - DocumentVersionRepository.Get should not join culture variation * Bugfix - Missing write lock * Removed unnecessary view model * Misc - kill some warnings * Misc - Kill some more warnings * Fixed cypress rollback test * Bugfix - Policy returns items to delete not items to keep. Switch to inverse behavior. # Conflicts: # src/Umbraco.Tests/Services/DefaultContentVersionCleanupPolicy_Tests_UnitTests.cs Co-authored-by: Paul Johnson <pmj@umbraco.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NPoco;
|
||||
using Umbraco.Cms.Core;
|
||||
using Umbraco.Cms.Core.Models;
|
||||
using Umbraco.Cms.Core.Persistence.Repositories;
|
||||
@@ -14,10 +15,8 @@ namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
||||
{
|
||||
private readonly IScopeAccessor _scopeAccessor;
|
||||
|
||||
public DocumentVersionRepository(IScopeAccessor scopeAccessor)
|
||||
{
|
||||
public DocumentVersionRepository(IScopeAccessor scopeAccessor) =>
|
||||
_scopeAccessor = scopeAccessor ?? throw new ArgumentNullException(nameof(scopeAccessor));
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
/// <remarks>
|
||||
@@ -25,14 +24,19 @@ namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
||||
/// Never includes current published version.<br/>
|
||||
/// Never includes versions marked as "preventCleanup".<br/>
|
||||
/// </remarks>
|
||||
public IReadOnlyCollection<HistoricContentVersionMeta> GetDocumentVersionsEligibleForCleanup()
|
||||
public IReadOnlyCollection<ContentVersionMeta> GetDocumentVersionsEligibleForCleanup()
|
||||
{
|
||||
var query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
|
||||
query.Select(@"umbracoDocument.nodeId as contentId,
|
||||
umbracoContent.contentTypeId as contentTypeId,
|
||||
umbracoContentVersion.id as versionId,
|
||||
umbracoContentVersion.versionDate as versionDate")
|
||||
umbracoContentVersion.userId as userId,
|
||||
umbracoContentVersion.versionDate as versionDate,
|
||||
umbracoDocumentVersion.published as currentPublishedVersion,
|
||||
umbracoContentVersion.[current] as currentDraftVersion,
|
||||
umbracoContentVersion.preventCleanup as preventCleanup,
|
||||
umbracoUser.userName as username")
|
||||
.From<DocumentDto>()
|
||||
.InnerJoin<ContentDto>()
|
||||
.On<DocumentDto, ContentDto>(left => left.NodeId, right => right.NodeId)
|
||||
@@ -40,17 +44,19 @@ namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
||||
.On<ContentDto, ContentVersionDto>(left => left.NodeId, right => right.NodeId)
|
||||
.InnerJoin<DocumentVersionDto>()
|
||||
.On<ContentVersionDto, DocumentVersionDto>(left => left.Id, right => right.Id)
|
||||
.LeftJoin<UserDto>()
|
||||
.On<UserDto, ContentVersionDto>(left => left.Id, right => right.UserId)
|
||||
.Where<ContentVersionDto>(x => !x.Current) // Never delete current draft version
|
||||
.Where<ContentVersionDto>(x => !x.PreventCleanup) // Never delete "pinned" versions
|
||||
.Where<DocumentVersionDto>(x => !x.Published); // Never delete published version
|
||||
|
||||
return _scopeAccessor.AmbientScope.Database.Fetch<HistoricContentVersionMeta>(query);
|
||||
return _scopeAccessor.AmbientScope.Database.Fetch<ContentVersionMeta>(query);
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public IReadOnlyCollection<ContentVersionCleanupPolicySettings> GetCleanupPolicies()
|
||||
{
|
||||
var query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
|
||||
query.Select<ContentVersionCleanupPolicyDto>()
|
||||
.From<ContentVersionCleanupPolicyDto>();
|
||||
@@ -58,21 +64,63 @@ namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
||||
return _scopeAccessor.AmbientScope.Database.Fetch<ContentVersionCleanupPolicySettings>(query);
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public IEnumerable<ContentVersionMeta> GetPagedItemsByContentId(int contentId, long pageIndex, int pageSize, out long totalRecords, int? languageId = null)
|
||||
{
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
|
||||
query.Select(@"umbracoDocument.nodeId as contentId,
|
||||
umbracoContent.contentTypeId as contentTypeId,
|
||||
umbracoContentVersion.id as versionId,
|
||||
umbracoContentVersion.userId as userId,
|
||||
umbracoContentVersion.versionDate as versionDate,
|
||||
umbracoDocumentVersion.published as currentPublishedVersion,
|
||||
umbracoContentVersion.[current] as currentDraftVersion,
|
||||
umbracoContentVersion.preventCleanup as preventCleanup,
|
||||
umbracoUser.userName as username")
|
||||
.From<DocumentDto>()
|
||||
.InnerJoin<ContentDto>()
|
||||
.On<DocumentDto, ContentDto>(left => left.NodeId, right => right.NodeId)
|
||||
.InnerJoin<ContentVersionDto>()
|
||||
.On<ContentDto, ContentVersionDto>(left => left.NodeId, right => right.NodeId)
|
||||
.InnerJoin<DocumentVersionDto>()
|
||||
.On<ContentVersionDto, DocumentVersionDto>(left => left.Id, right => right.Id)
|
||||
.LeftJoin<UserDto>()
|
||||
.On<UserDto, ContentVersionDto>(left => left.Id, right => right.UserId)
|
||||
.LeftJoin<ContentVersionCultureVariationDto>()
|
||||
.On<ContentVersionCultureVariationDto, ContentVersionDto>(left => left.VersionId, right => right.Id)
|
||||
.Where<ContentVersionDto>(x => x.NodeId == contentId);
|
||||
|
||||
// TODO: If there's not a better way to write this then we need a better way to write this.
|
||||
query = languageId.HasValue
|
||||
? query.Where<ContentVersionCultureVariationDto>(x => x.LanguageId == languageId.Value)
|
||||
: query.Where("umbracoContentVersionCultureVariation.languageId is null");
|
||||
|
||||
query = query.OrderByDescending<ContentVersionDto>(x => x.Id);
|
||||
|
||||
Page<ContentVersionMeta> page = _scopeAccessor.AmbientScope.Database.Page<ContentVersionMeta>(pageIndex + 1, pageSize, query);
|
||||
|
||||
totalRecords = page.TotalItems;
|
||||
|
||||
return page.Items;
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
/// <remarks>
|
||||
/// Deletes in batches of <see cref="Constants.Sql.MaxParameterCount"/>
|
||||
/// </remarks>
|
||||
public void DeleteVersions(IEnumerable<int> versionIds)
|
||||
{
|
||||
foreach (var group in versionIds.InGroupsOf(Constants.Sql.MaxParameterCount))
|
||||
foreach (IEnumerable<int> group in versionIds.InGroupsOf(Constants.Sql.MaxParameterCount))
|
||||
{
|
||||
var groupedVersionIds = group.ToList();
|
||||
|
||||
// Note: We had discussed doing this in a single SQL Command.
|
||||
// If you can work out how to make that work with SQL CE, let me know!
|
||||
// Can use test PerformContentVersionCleanup_WithNoKeepPeriods_DeletesEverythingExceptActive to try things out.
|
||||
/* Note: We had discussed doing this in a single SQL Command.
|
||||
* If you can work out how to make that work with SQL CE, let me know!
|
||||
* Can use test PerformContentVersionCleanup_WithNoKeepPeriods_DeletesEverythingExceptActive to try things out.
|
||||
*/
|
||||
|
||||
var query = _scopeAccessor.AmbientScope.SqlContext.Sql()
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql()
|
||||
.Delete<PropertyDataDto>()
|
||||
.WhereIn<PropertyDataDto>(x => x.VersionId, groupedVersionIds);
|
||||
_scopeAccessor.AmbientScope.Database.Execute(query);
|
||||
@@ -93,5 +141,43 @@ namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
||||
_scopeAccessor.AmbientScope.Database.Execute(query);
|
||||
}
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public void SetPreventCleanup(int versionId, bool preventCleanup)
|
||||
{
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql()
|
||||
.Update<ContentVersionDto>(x => x.Set(y => y.PreventCleanup, preventCleanup))
|
||||
.Where<ContentVersionDto>(x => x.Id == versionId);
|
||||
|
||||
_scopeAccessor.AmbientScope.Database.Execute(query);
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
public ContentVersionMeta Get(int versionId)
|
||||
{
|
||||
Sql<ISqlContext> query = _scopeAccessor.AmbientScope.SqlContext.Sql();
|
||||
|
||||
query.Select(@"umbracoDocument.nodeId as contentId,
|
||||
umbracoContent.contentTypeId as contentTypeId,
|
||||
umbracoContentVersion.id as versionId,
|
||||
umbracoContentVersion.userId as userId,
|
||||
umbracoContentVersion.versionDate as versionDate,
|
||||
umbracoDocumentVersion.published as currentPublishedVersion,
|
||||
umbracoContentVersion.[current] as currentDraftVersion,
|
||||
umbracoContentVersion.preventCleanup as preventCleanup,
|
||||
umbracoUser.userName as username")
|
||||
.From<DocumentDto>()
|
||||
.InnerJoin<ContentDto>()
|
||||
.On<DocumentDto, ContentDto>(left => left.NodeId, right => right.NodeId)
|
||||
.InnerJoin<ContentVersionDto>()
|
||||
.On<ContentDto, ContentVersionDto>(left => left.NodeId, right => right.NodeId)
|
||||
.InnerJoin<DocumentVersionDto>()
|
||||
.On<ContentVersionDto, DocumentVersionDto>(left => left.Id, right => right.Id)
|
||||
.LeftJoin<UserDto>()
|
||||
.On<UserDto, ContentVersionDto>(left => left.Id, right => right.UserId)
|
||||
.Where<ContentVersionDto>(x => x.Id == versionId);
|
||||
|
||||
return _scopeAccessor.AmbientScope.Database.Single<ContentVersionMeta>(query);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user