Refactored
This commit is contained in:
@@ -6,5 +6,6 @@ namespace AipsCore.Domain.Models.Whiteboard.External;
|
||||
public interface IWhiteboardRepository
|
||||
: IAbstractRepository<Whiteboard, WhiteboardId>, ISoftDeletableRepository<WhiteboardId>
|
||||
{
|
||||
Task<bool> WhiteboardCodeExists(WhiteboardCode whiteboardCode);
|
||||
Task<bool> WhiteboardCodeExistsAsync(WhiteboardCode whiteboardCode);
|
||||
Task<Whiteboard?> GetByCodeAsync(WhiteboardCode whiteboardCode, CancellationToken cancellationToken = default);
|
||||
}
|
||||
@@ -7,6 +7,38 @@ namespace AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
public class WhiteboardErrors : AbstractErrors<Whiteboard, WhiteboardId>
|
||||
{
|
||||
public static ValidationError NotFound(WhiteboardCode whiteboardCode)
|
||||
{
|
||||
const string code = "not_found";
|
||||
string message = $"Whiteboard with code '{whiteboardCode.CodeValue}' was not found!";
|
||||
|
||||
return CreateValidationError(code,message);
|
||||
}
|
||||
|
||||
public static ValidationError CannotJoin(WhiteboardCode whiteboardCode)
|
||||
{
|
||||
const string code = "cannot_join_whiteboard";
|
||||
string message = $"Cannot join the whiteboard with code '{whiteboardCode.CodeValue}'";
|
||||
|
||||
return CreateValidationError(code,message);
|
||||
}
|
||||
|
||||
public static ValidationError UserBanned(UserId userId)
|
||||
{
|
||||
const string code = "user_banned_from_whiteboard";
|
||||
string message = $"User with id '{userId}' is banned from this whiteboard.";
|
||||
|
||||
return CreateValidationError(code,message);
|
||||
}
|
||||
|
||||
public static ValidationError UserAlreadyTryingToJoin(UserId userId)
|
||||
{
|
||||
const string code = "user_already_trying_to_join_whiteboard";
|
||||
string message = $"User with id '{userId}' is already trying to join the whiteboard.";
|
||||
|
||||
return CreateValidationError(code,message);
|
||||
}
|
||||
|
||||
public static ValidationError UserAlreadyAdded(UserId userId)
|
||||
{
|
||||
string code = "user_already_added";
|
||||
|
||||
@@ -36,7 +36,7 @@ public record WhiteboardCode : AbstractValueObject
|
||||
{
|
||||
whiteboardCode = Generate();
|
||||
|
||||
codeExists = await whiteboardRepository.WhiteboardCodeExists(whiteboardCode);
|
||||
codeExists = await whiteboardRepository.WhiteboardCodeExistsAsync(whiteboardCode);
|
||||
} while (codeExists);
|
||||
|
||||
return whiteboardCode;
|
||||
|
||||
@@ -1,42 +1,47 @@
|
||||
using System.Runtime.InteropServices.Swift;
|
||||
using AipsCore.Domain.Abstract;
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.Enums;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.External;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.Enums;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard : DomainModel<WhiteboardId>
|
||||
public partial class Whiteboard
|
||||
{
|
||||
public async Task AddUserAsync(
|
||||
User.User user,
|
||||
IWhiteboardMembershipRepository membershipRepository,
|
||||
CancellationToken cancellationToken = default)
|
||||
public WhiteboardMembership.WhiteboardMembership RequestJoin(UserId userId)
|
||||
{
|
||||
var membership
|
||||
= await membershipRepository.GetByWhiteboardAndUserAsync(this.Id, user.Id, cancellationToken);
|
||||
return WhiteboardMembership.WhiteboardMembership.Create(
|
||||
Id.IdValue,
|
||||
userId.IdValue,
|
||||
false,
|
||||
DetermineJoinStatus(),
|
||||
DateTime.UtcNow);
|
||||
}
|
||||
|
||||
if (membership is not null)
|
||||
public void RequestReJoin(WhiteboardMembership.WhiteboardMembership membership)
|
||||
{
|
||||
switch (membership.Status)
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.UserAlreadyAdded(user.Id));
|
||||
case WhiteboardMembershipStatus.Banned:
|
||||
throw new ValidationException(WhiteboardErrors.UserBanned(membership.UserId));
|
||||
case WhiteboardMembershipStatus.Pending:
|
||||
throw new ValidationException(WhiteboardErrors.UserAlreadyTryingToJoin(membership.UserId));
|
||||
case WhiteboardMembershipStatus.Accepted:
|
||||
break;
|
||||
default:
|
||||
membership.UpdateStatus(DetermineJoinStatus());
|
||||
break;
|
||||
}
|
||||
|
||||
membership = WhiteboardMembership.WhiteboardMembership.Create(
|
||||
this.Id.IdValue,
|
||||
user.Id.IdValue,
|
||||
false,
|
||||
false,
|
||||
this.GetCanJoin(),
|
||||
DateTime.UtcNow
|
||||
);
|
||||
|
||||
await membershipRepository.AddAsync(membership, cancellationToken);
|
||||
}
|
||||
|
||||
private bool GetCanJoin()
|
||||
private WhiteboardMembershipStatus DetermineJoinStatus()
|
||||
{
|
||||
return this.JoinPolicy == WhiteboardJoinPolicy.FreeToJoin;
|
||||
return JoinPolicy switch
|
||||
{
|
||||
WhiteboardJoinPolicy.FreeToJoin => WhiteboardMembershipStatus.Accepted,
|
||||
WhiteboardJoinPolicy.RequestToJoin => WhiteboardMembershipStatus.Pending,
|
||||
WhiteboardJoinPolicy.Private => throw new ValidationException(WhiteboardErrors.CannotJoin(Code)),
|
||||
_ => throw new ArgumentOutOfRangeException()
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,18 +0,0 @@
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard
|
||||
{
|
||||
public void BanUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (WhiteboardOwnerId != currentUserId)
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanBanOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Ban();
|
||||
}
|
||||
}
|
||||
@@ -6,6 +6,11 @@ public partial class Whiteboard
|
||||
{
|
||||
public bool CanUserDelete(UserId userId)
|
||||
{
|
||||
return WhiteboardOwnerId.IdValue == userId.IdValue;
|
||||
return IsOwner(userId);
|
||||
}
|
||||
|
||||
public bool ShouldRequestToJoin(UserId userId)
|
||||
{
|
||||
return !IsOwner(userId);
|
||||
}
|
||||
}
|
||||
@@ -1,18 +0,0 @@
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard
|
||||
{
|
||||
public void KickUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (WhiteboardOwnerId != currentUserId)
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanKickOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Kick();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard
|
||||
{
|
||||
public void BanUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (IsOwner(currentUserId))
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanBanOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Ban();
|
||||
}
|
||||
|
||||
public void UnbanUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (IsOwner(currentUserId))
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanUnbanOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Unban();
|
||||
}
|
||||
|
||||
public void KickUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (IsOwner(currentUserId))
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanKickOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Kick();
|
||||
}
|
||||
|
||||
private bool IsOwner(UserId userId)
|
||||
{
|
||||
return WhiteboardOwnerId.IdValue == userId.IdValue;
|
||||
}
|
||||
}
|
||||
@@ -1,18 +0,0 @@
|
||||
using AipsCore.Domain.Common.Validation;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.Validation;
|
||||
|
||||
namespace AipsCore.Domain.Models.Whiteboard;
|
||||
|
||||
public partial class Whiteboard
|
||||
{
|
||||
public void UnbanUser(UserId currentUserId, WhiteboardMembership.WhiteboardMembership whiteboardMembership)
|
||||
{
|
||||
if (WhiteboardOwnerId != currentUserId)
|
||||
{
|
||||
throw new ValidationException(WhiteboardErrors.OnlyOwnerCanUnbanOtherUsers(currentUserId));
|
||||
}
|
||||
|
||||
whiteboardMembership.Unban();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,13 @@
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership.Enums;
|
||||
|
||||
public enum WhiteboardMembershipStatus
|
||||
{
|
||||
Pending,
|
||||
Accepted,
|
||||
Active,
|
||||
Inactive,
|
||||
Rejected,
|
||||
Cancelled,
|
||||
Kicked,
|
||||
Banned
|
||||
}
|
||||
@@ -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;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership.Validation;
|
||||
|
||||
public class WhiteboardMembershipErrors : AbstractErrors<WhiteboardMembership, WhiteboardMembershipId>
|
||||
{
|
||||
public static ValidationError NotFound(WhiteboardId whiteboardId, UserId userId)
|
||||
{
|
||||
const string code = "whiteboard_membership_not_found";
|
||||
string message = $"Whiteboard membership with whiteboard id {whiteboardId.IdValue} and user id {userId.IdValue} not found.";
|
||||
|
||||
return CreateValidationError(code, message);
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
using AipsCore.Domain.Abstract.Rule;
|
||||
using AipsCore.Domain.Abstract.ValueObject;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
public record WhiteboardMembershipCanJoin : AbstractValueObject
|
||||
{
|
||||
public bool CanJoinValue { get; init; }
|
||||
|
||||
public WhiteboardMembershipCanJoin(bool CanJoinValue)
|
||||
{
|
||||
this.CanJoinValue = CanJoinValue;
|
||||
Validate();
|
||||
}
|
||||
|
||||
protected override ICollection<IRule> GetValidationRules()
|
||||
{
|
||||
return [];
|
||||
}
|
||||
}
|
||||
@@ -1,20 +0,0 @@
|
||||
using AipsCore.Domain.Abstract.Rule;
|
||||
using AipsCore.Domain.Abstract.ValueObject;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
public record WhiteboardMembershipIsBanned : AbstractValueObject
|
||||
{
|
||||
public bool IsBannedValue { get; init; }
|
||||
|
||||
public WhiteboardMembershipIsBanned(bool IsBannedValue)
|
||||
{
|
||||
this.IsBannedValue = IsBannedValue;
|
||||
Validate();
|
||||
}
|
||||
|
||||
protected override ICollection<IRule> GetValidationRules()
|
||||
{
|
||||
return [];
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership;
|
||||
|
||||
public partial class WhiteboardMembership
|
||||
{
|
||||
public void Ban()
|
||||
{
|
||||
IsBanned = new WhiteboardMembershipIsBanned(true);
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership;
|
||||
|
||||
public partial class WhiteboardMembership
|
||||
{
|
||||
public void Kick()
|
||||
{
|
||||
CanJoin = new WhiteboardMembershipCanJoin(false);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,26 @@
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.Enums;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership;
|
||||
|
||||
public partial class WhiteboardMembership
|
||||
{
|
||||
public void Ban()
|
||||
{
|
||||
Status = WhiteboardMembershipStatus.Banned;
|
||||
}
|
||||
|
||||
public void Unban()
|
||||
{
|
||||
Status = WhiteboardMembershipStatus.Cancelled;
|
||||
}
|
||||
|
||||
public void Kick()
|
||||
{
|
||||
Status = WhiteboardMembershipStatus.Kicked;
|
||||
}
|
||||
|
||||
public void UpdateStatus(WhiteboardMembershipStatus newStatus)
|
||||
{
|
||||
Status = newStatus;
|
||||
}
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership;
|
||||
|
||||
public partial class WhiteboardMembership
|
||||
{
|
||||
public void Unban()
|
||||
{
|
||||
IsBanned = new WhiteboardMembershipIsBanned(false);
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,7 @@
|
||||
using AipsCore.Domain.Abstract;
|
||||
using AipsCore.Domain.Models.User.ValueObjects;
|
||||
using AipsCore.Domain.Models.Whiteboard.ValueObjects;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.Enums;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.ValueObjects;
|
||||
|
||||
namespace AipsCore.Domain.Models.WhiteboardMembership;
|
||||
@@ -9,97 +10,84 @@ public partial class WhiteboardMembership : DomainModel<WhiteboardMembershipId>
|
||||
{
|
||||
public WhiteboardId WhiteboardId { get; private set; }
|
||||
public UserId UserId { get; private set; }
|
||||
public WhiteboardMembershipIsBanned IsBanned { get; private set; }
|
||||
public WhiteboardMembershipEditingEnabled EditingEnabled { get; private set; }
|
||||
public WhiteboardMembershipCanJoin CanJoin { get; private set; }
|
||||
public WhiteboardMembershipStatus Status { get; private set; }
|
||||
public WhiteboardMembershipLastInteractedAt LastInteractedAt { get; private set; }
|
||||
|
||||
public WhiteboardMembership(
|
||||
WhiteboardMembershipId id,
|
||||
Whiteboard.Whiteboard owner,
|
||||
Whiteboard.Whiteboard whiteboard,
|
||||
User.User user,
|
||||
WhiteboardMembershipIsBanned isBanned,
|
||||
WhiteboardMembershipEditingEnabled editingEnabled,
|
||||
WhiteboardMembershipCanJoin canJoin,
|
||||
WhiteboardMembershipStatus status,
|
||||
WhiteboardMembershipLastInteractedAt lastInteractedAt)
|
||||
: base(id)
|
||||
{
|
||||
WhiteboardId = owner.Id;
|
||||
WhiteboardId = whiteboard.Id;
|
||||
UserId = user.Id;
|
||||
IsBanned = isBanned;
|
||||
EditingEnabled = editingEnabled;
|
||||
CanJoin = canJoin;
|
||||
Status = status;
|
||||
LastInteractedAt = lastInteractedAt;
|
||||
}
|
||||
|
||||
public WhiteboardMembership(
|
||||
WhiteboardMembershipId id,
|
||||
WhiteboardId ownerId,
|
||||
WhiteboardId whiteboardId,
|
||||
UserId userId,
|
||||
WhiteboardMembershipIsBanned isBanned,
|
||||
WhiteboardMembershipEditingEnabled editingEnabled,
|
||||
WhiteboardMembershipCanJoin canJoin,
|
||||
WhiteboardMembershipStatus status,
|
||||
WhiteboardMembershipLastInteractedAt lastInteractedAt)
|
||||
: base(id)
|
||||
{
|
||||
WhiteboardId = ownerId;
|
||||
WhiteboardId = whiteboardId;
|
||||
UserId = userId;
|
||||
IsBanned = isBanned;
|
||||
EditingEnabled = editingEnabled;
|
||||
CanJoin = canJoin;
|
||||
Status = status;
|
||||
LastInteractedAt = lastInteractedAt;
|
||||
}
|
||||
|
||||
public static WhiteboardMembership Create(
|
||||
string id,
|
||||
string ownerId,
|
||||
string whiteboardId,
|
||||
string userId,
|
||||
bool isBanned,
|
||||
bool editingEnabled,
|
||||
bool canJoin,
|
||||
WhiteboardMembershipStatus status,
|
||||
DateTime lastInteractedAt)
|
||||
{
|
||||
var whiteboardMembershipId = new WhiteboardMembershipId(id);
|
||||
var whiteboardId = new WhiteboardId(ownerId);
|
||||
var whiteboardIdVo = new WhiteboardId(whiteboardId);
|
||||
var userIdVo = new UserId(userId);
|
||||
var isBannedVo = new WhiteboardMembershipIsBanned(isBanned);
|
||||
var editingEnabledVo = new WhiteboardMembershipEditingEnabled(editingEnabled);
|
||||
var canJoinVo = new WhiteboardMembershipCanJoin(canJoin);
|
||||
var lastInteractedAtVo = new WhiteboardMembershipLastInteractedAt(lastInteractedAt);
|
||||
|
||||
return new WhiteboardMembership(
|
||||
whiteboardMembershipId,
|
||||
whiteboardId,
|
||||
userIdVo,
|
||||
isBannedVo,
|
||||
whiteboardIdVo,
|
||||
userIdVo,
|
||||
editingEnabledVo,
|
||||
canJoinVo,
|
||||
status,
|
||||
lastInteractedAtVo);
|
||||
}
|
||||
|
||||
public static WhiteboardMembership Create(
|
||||
string ownerId,
|
||||
string whiteboardId,
|
||||
string userId,
|
||||
bool isBanned,
|
||||
bool editingEnabled,
|
||||
bool canJoin,
|
||||
WhiteboardMembershipStatus status,
|
||||
DateTime lastInteractedAt)
|
||||
{
|
||||
var whiteboardMembershipId = WhiteboardMembershipId.Any();
|
||||
var whiteboardId = new WhiteboardId(ownerId);
|
||||
var whiteboardIdVo = new WhiteboardId(whiteboardId);
|
||||
var userIdVo = new UserId(userId);
|
||||
var isBannedVo = new WhiteboardMembershipIsBanned(isBanned);
|
||||
var editingEnabledVo = new WhiteboardMembershipEditingEnabled(editingEnabled);
|
||||
var canJoinVo = new WhiteboardMembershipCanJoin(canJoin);
|
||||
var lastInteractedAtVo = new WhiteboardMembershipLastInteractedAt(lastInteractedAt);
|
||||
|
||||
return new WhiteboardMembership(
|
||||
whiteboardMembershipId,
|
||||
whiteboardId,
|
||||
whiteboardIdVo,
|
||||
userIdVo,
|
||||
isBannedVo,
|
||||
editingEnabledVo,
|
||||
canJoinVo,
|
||||
status,
|
||||
lastInteractedAtVo);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user