Headless CMS and Content Managment Hub
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

129 lines
4.8 KiB

// ==========================================================================
// Squidex Headless CMS
// ==========================================================================
// Copyright (c) Squidex UG (haftungsbeschraenkt)
// All rights reserved. Licensed under the MIT license.
// ==========================================================================
using System.Collections.Generic;
using System.Threading.Tasks;
using Squidex.Domain.Apps.Core;
using Squidex.Domain.Apps.Core.Contents;
using Squidex.Domain.Apps.Core.DefaultValues;
using Squidex.Domain.Apps.Core.ValidateContent;
using Squidex.Domain.Apps.Entities.Apps;
using Squidex.Domain.Apps.Entities.Contents.Repositories;
using Squidex.Domain.Apps.Entities.Schemas;
using Squidex.Infrastructure;
using Squidex.Infrastructure.Json;
using Squidex.Infrastructure.Translations;
using Squidex.Infrastructure.Validation;
using Squidex.Log;
namespace Squidex.Domain.Apps.Entities.Contents.DomainObject.Guards
{
public static class ValidationExtensions
{
public static void MustDeleteDraft(this OperationContext context)
{
if (context.Content.NewStatus == null)
{
throw new DomainException(T.Get("contents.draftToDeleteNotFound"));
}
}
public static void MustCreateDraft(this OperationContext context)
{
if (context.Content.EditingStatus() != Status.Published)
{
throw new DomainException(T.Get("contents.draftNotCreateForUnpublished"));
}
}
public static void MustHaveData(this OperationContext context, ContentData? data)
{
if (data == null)
{
context.AddError(Not.Defined(nameof(data)), nameof(data)).ThrowOnErrors();
}
}
public static async Task ValidateInputAsync(this OperationContext context, ContentData data, bool optimize, bool published)
{
var validator = GetValidator(context, optimize, published);
await validator.ValidateInputAsync(data);
context.AddErrors(validator.Errors).ThrowOnErrors();
}
public static async Task ValidateInputPartialAsync(this OperationContext context, ContentData data, bool optimize, bool published)
{
var validator = GetValidator(context, optimize, published);
await validator.ValidateInputPartialAsync(data);
context.AddErrors(validator.Errors).ThrowOnErrors();
}
public static async Task ValidateContentAsync(this OperationContext context, ContentData data, bool optimize, bool published)
{
var validator = GetValidator(context, optimize, published);
await validator.ValidateContentAsync(data);
context.AddErrors(validator.Errors).ThrowOnErrors();
}
public static async Task ValidateContentAndInputAsync(this OperationContext operation, ContentData data, bool optimize, bool published)
{
var validator = GetValidator(operation, optimize, published);
await validator.ValidateInputAsync(data);
await validator.ValidateContentAsync(data);
operation.AddErrors(validator.Errors).ThrowOnErrors();
}
public static void GenerateDefaultValues(this OperationContext context, ContentData data)
{
data.GenerateDefaultValues(context.Schema.SchemaDef, context.Partition());
}
public static async Task CheckReferrersAsync(this OperationContext context)
{
var contentRepository = context.Resolve<IContentRepository>();
var hasReferrer = await contentRepository.HasReferrersAsync(context.App.Id, context.ContentId, SearchScope.All);
if (hasReferrer)
{
throw new DomainException(T.Get("contents.referenced"));
}
}
private static ContentValidator GetValidator(this OperationContext context, bool optimize, bool published)
{
var validationContext =
new ValidationContext(context.Resolve<IJsonSerializer>(),
context.App.NamedId(),
context.Schema.NamedId(),
context.SchemaDef,
context.ContentId)
.Optimized(optimize).AsPublishing(published);
var validator =
new ContentValidator(context.Partition(),
validationContext,
context.Resolve<IEnumerable<IValidatorsFactory>>(),
context.Resolve<ISemanticLog>());
return validator;
}
private static PartitionResolver Partition(this OperationContext context)
{
return context.App.PartitionResolver();
}
}
}