implement
This commit is contained in:
@@ -18,6 +18,11 @@ public abstract class DomainModel<TId> where TId : DomainId
|
||||
Id = id;
|
||||
}
|
||||
|
||||
public string GetModelName()
|
||||
{
|
||||
return this.GetType().Name;
|
||||
}
|
||||
|
||||
public IReadOnlyList<IDomainEvent> GetDomainEvents() => _domainEvents.ToList();
|
||||
|
||||
public void ClearDomainEvents() => _domainEvents.Clear();
|
||||
|
||||
38
dotnet/AipsCore/Domain/Abstract/Validation/AbstractErrors.cs
Normal file
38
dotnet/AipsCore/Domain/Abstract/Validation/AbstractErrors.cs
Normal file
@@ -0,0 +1,38 @@
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Common.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Abstract.Validation;
|
||||
|
||||
public abstract class AbstractErrors<TModel, TId>
|
||||
where TModel : DomainModel<TId>
|
||||
where TId : DomainId
|
||||
{
|
||||
public static string GetModelName()
|
||||
{
|
||||
return typeof(TModel).Name;
|
||||
}
|
||||
|
||||
public static string Prefix()
|
||||
{
|
||||
return GetModelName().ToLower();
|
||||
}
|
||||
|
||||
protected static string GetFullCode(string code)
|
||||
{
|
||||
return $"{Prefix()}_{code}";
|
||||
}
|
||||
|
||||
protected static ValidationError CreateValidationError(string code, string errorMessage)
|
||||
{
|
||||
return new ValidationError(GetFullCode(code), errorMessage);
|
||||
}
|
||||
|
||||
public static ValidationError NotFound(TId id)
|
||||
{
|
||||
const string code = "not_found";
|
||||
string message = $"{GetModelName()} with id '{id}' was not found!";
|
||||
|
||||
return CreateValidationError(code,message);
|
||||
}
|
||||
}
|
||||
@@ -10,4 +10,9 @@ public class ValidationException : Exception
|
||||
{
|
||||
ValidationErrors = validationErrors;
|
||||
}
|
||||
|
||||
public ValidationException(ValidationError validationError)
|
||||
: this([validationError])
|
||||
{
|
||||
}
|
||||
}
|
||||
@@ -22,4 +22,9 @@ public record DomainId : AbstractValueObject
|
||||
new MinLengthRule(IdValue, 5)
|
||||
];
|
||||
}
|
||||
|
||||
public override string ToString()
|
||||
{
|
||||
return IdValue;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
using AipsCore.Domain.Abstract.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.User.Validation;
|
||||
|
||||
public class UserErrors : AbstractErrors<User, UserId>
|
||||
{
|
||||
|
||||
}
|
||||
@@ -0,0 +1,18 @@
|
||||
using AipsCore.Domain.Abstract.Validation;
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
public class WhiteboardErrors : AbstractErrors<Whiteboard, WhiteboardId>
|
||||
{
|
||||
public static ValidationError UserAlreadyAdded(UserId userId)
|
||||
{
|
||||
string code = "user_already_added";
|
||||
string message = $"User with id '{userId}' already added to this whiteboard";
|
||||
|
||||
return CreateValidationError(code, message);
|
||||
}
|
||||
|
||||
}
|
||||
@@ -0,0 +1,42 @@
|
||||
using System.Runtime.InteropServices.Swift;
|
||||
using AipsCore.Domain.Abstract;
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.Whiteboard.Enums;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.External;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard : DomainModel<WhiteboardId>
|
||||
{
|
||||
public async Task AddUserAsync(
|
||||
User.User user,
|
||||
IWhiteboardMembershipRepository membershipRepository,
|
||||
CancellationToken cancellationToken = default)
|
||||
{
|
||||
var membership
|
||||
= await membershipRepository.GetByWhiteboardAndUserAsync(this.Id, user.Id, cancellationToken);
|
||||
|
||||
if (membership is not null)
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.UserAlreadyAdded(user.Id));
|
||||
}
|
||||
|
||||
membership = WhiteboardMembership.WhiteboardMembership.Create(
|
||||
this.Id.ToString(),
|
||||
user.Id.ToString(),
|
||||
false,
|
||||
false,
|
||||
this.GetCanJoin(),
|
||||
DateTime.Now
|
||||
);
|
||||
|
||||
await membershipRepository.AddAsync(membership, cancellationToken);
|
||||
}
|
||||
|
||||
private bool GetCanJoin()
|
||||
{
|
||||
return this.JoinPolicy == WhiteboardJoinPolicy.FreeToJoin;
|
||||
}
|
||||
}
|
||||
@@ -5,7 +5,7 @@ using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public class Whiteboard : DomainModel<WhiteboardId>
|
||||
public partial class Whiteboard : DomainModel<WhiteboardId>
|
||||
{
|
||||
public UserId WhiteboardOwnerId { get; private set; }
|
||||
public WhiteboardCode Code { get; private set; }
|
||||
|
||||
@@ -1,9 +1,11 @@
|
||||
using AipsCore.Domain.Abstract;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership.External;
|
||||
|
||||
public interface IWhiteboardMembershipRepository : IAbstractRepository<WhiteboardMembership, WhiteboardMembershipId>
|
||||
{
|
||||
|
||||
Task<WhiteboardMembership?> GetByWhiteboardAndUserAsync(WhiteboardId whiteboardId, UserId userId, CancellationToken cancellationToken = default);
|
||||
}
|
||||
@@ -17,4 +17,10 @@ public record WhiteboardMembershipEditingEnabled : AbstractValueObject
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
public static WhiteboardMembershipEditingEnabled Enabled
|
||||
=> new WhiteboardMembershipEditingEnabled(true);
|
||||
|
||||
public static WhiteboardMembershipEditingEnabled Disabled
|
||||
=> new WhiteboardMembershipEditingEnabled(false);
|
||||
}
|
||||
Reference in New Issue
Block a user