RT
This commit is contained in:
@@ -1,6 +1,9 @@
|
||||
using AipsCore.Application.Abstract.MessageBroking;
|
||||
using AipsCore.Application.Common.Message.MoveShape;
|
||||
using AipsCore.Application.Abstract;
|
||||
using AipsCore.Application.Models.Shape.Command.MoveShape;
|
||||
using AipsCore.Application.Models.Whiteboard.Command.AcceptUserRequestToJoin;
|
||||
using AipsCore.Application.Models.Whiteboard.Command.RejectUserRequestToJoin;
|
||||
using AipsCore.Application.Models.Whiteboard.Query.GetMembershipStatus;
|
||||
using AipsCore.Domain.Models.WhiteboardMembership.Enums;
|
||||
using AipsRT.Model.Whiteboard;
|
||||
using AipsRT.Model.Whiteboard.Shapes;
|
||||
using AipsRT.Model.Whiteboard.Structs;
|
||||
@@ -15,27 +18,95 @@ public class WhiteboardHub : Hub
|
||||
{
|
||||
private readonly WhiteboardManager _whiteboardManager;
|
||||
private readonly IMessagingService _messagingService;
|
||||
private readonly IDispatcher _dispatcher;
|
||||
|
||||
public WhiteboardHub(WhiteboardManager whiteboardManager, IMessagingService messagingService)
|
||||
public WhiteboardHub(WhiteboardManager whiteboardManager, IMessagingService messagingService, IDispatcher dispatcher)
|
||||
{
|
||||
_whiteboardManager = whiteboardManager;
|
||||
_messagingService = messagingService;
|
||||
_dispatcher = dispatcher;
|
||||
}
|
||||
|
||||
public async Task JoinWhiteboard(Guid whiteboardId)
|
||||
{
|
||||
if (!_whiteboardManager.WhiteboardExists(whiteboardId))
|
||||
{
|
||||
await _whiteboardManager.AddWhiteboard(whiteboardId);
|
||||
}
|
||||
|
||||
await Groups.AddToGroupAsync(Context.ConnectionId, whiteboardId.ToString());
|
||||
|
||||
var whiteboard = _whiteboardManager.GetWhiteboard(whiteboardId)!;
|
||||
|
||||
var state = _whiteboardManager.GetWhiteboard(whiteboardId)!;
|
||||
var userId = CurrentUserId;
|
||||
var ownerId = whiteboard.OwnerId;
|
||||
|
||||
_whiteboardManager.AddUserToWhiteboard(Guid.Parse(Context.UserIdentifier!), whiteboardId);
|
||||
WhiteboardMembershipStatus status;
|
||||
|
||||
if (userId == ownerId)
|
||||
{
|
||||
status = WhiteboardMembershipStatus.Accepted;
|
||||
}
|
||||
else
|
||||
{
|
||||
status = await _dispatcher.Execute(new GetMembershipStatusQuery(whiteboardId.ToString(), userId.ToString()));
|
||||
}
|
||||
|
||||
await Clients.Caller.SendAsync("InitWhiteboard", state);
|
||||
await Clients.GroupExcept(whiteboardId.ToString(), Context.ConnectionId)
|
||||
.SendAsync("Joined", Context.UserIdentifier!);
|
||||
if (status == WhiteboardMembershipStatus.Accepted)
|
||||
{
|
||||
_whiteboardManager.AddUserToWhiteboard(userId, whiteboardId);
|
||||
whiteboard.AcceptUser(userId);
|
||||
|
||||
var state = _whiteboardManager.GetWhiteboard(whiteboardId)!;
|
||||
await Clients.Caller.SendAsync("InitWhiteboard", state);
|
||||
|
||||
await Clients.GroupExcept(whiteboardId.ToString(), Context.ConnectionId).SendAsync("Joined", Context.UserIdentifier!);
|
||||
}
|
||||
else
|
||||
{
|
||||
_whiteboardManager.AddPendingUser(userId, whiteboardId);
|
||||
|
||||
await Clients.Caller.SendAsync("WaitingForApproval", userId.ToString());
|
||||
|
||||
await Clients.User(ownerId.ToString()).SendAsync("UserWaitingForApproval", userId.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
public async Task AcceptUser(Guid targetUserId)
|
||||
{
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
await _messagingService.AcceptedUser(new AcceptUserRequestToJoinCommand(whiteboard.WhiteboardId.ToString(), targetUserId.ToString()));
|
||||
|
||||
_whiteboardManager.MovePendingToAccepted(targetUserId, whiteboard.WhiteboardId);
|
||||
|
||||
await Clients.User(targetUserId.ToString()).SendAsync("Accepted");
|
||||
await Clients.User(targetUserId.ToString()).SendAsync("InitWhiteboard", whiteboard);
|
||||
}
|
||||
|
||||
public async Task RejectUser(Guid targetUserId)
|
||||
{
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
await _messagingService.RejectedUser(new RejectUserRequestToJoinCommand(whiteboard.WhiteboardId.ToString(), targetUserId.ToString()));
|
||||
|
||||
_whiteboardManager.RemovePendingUser(targetUserId, whiteboard.WhiteboardId);
|
||||
|
||||
await Clients.User(targetUserId.ToString()).SendAsync("Rejected");
|
||||
}
|
||||
|
||||
public async Task CancelJoinRequest()
|
||||
{
|
||||
var userId = CurrentUserId;
|
||||
var whiteboard = _whiteboardManager.GetWhiteboardForUser(userId);
|
||||
|
||||
if (whiteboard != null)
|
||||
{
|
||||
_whiteboardManager.RemovePendingUser(userId, whiteboard.WhiteboardId);
|
||||
|
||||
await Clients.User(whiteboard.OwnerId.ToString())
|
||||
.SendAsync("UserCanceledJoinRequest", userId.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
public async Task LeaveWhiteboard(Guid whiteboardId)
|
||||
@@ -60,6 +131,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task AddRectangle(Rectangle rectangle)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
rectangle.OwnerId = CurrentUserId;
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
@@ -72,6 +145,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task AddArrow(Arrow arrow)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
arrow.OwnerId = CurrentUserId;
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
@@ -84,6 +159,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task AddLine(Line line)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
line.OwnerId = CurrentUserId;
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
@@ -96,6 +173,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task AddTextShape(TextShape textShape)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
textShape.OwnerId = CurrentUserId;
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
@@ -108,6 +187,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task MoveShape(MoveShapeCommand moveShape)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
var whiteboard = CurrentWhiteboard;
|
||||
|
||||
var shape = whiteboard.Shapes.Find(s => s.Id.ToString() == moveShape.ShapeId);
|
||||
@@ -125,6 +206,8 @@ public class WhiteboardHub : Hub
|
||||
|
||||
public async Task PlaceShape(MoveShapeCommand moveShape)
|
||||
{
|
||||
if (!_whiteboardManager.IsAccepted(CurrentUserId)) return;
|
||||
|
||||
await MoveShape(moveShape);
|
||||
|
||||
await _messagingService.MoveShape(moveShape);
|
||||
|
||||
Reference in New Issue
Block a user