mirror of
https://github.com/plankanban/planka.git
synced 2025-07-24 07:39:44 +02:00
fix: Socket bug fixes and improvements
This commit is contained in:
parent
4e876922f8
commit
9f16881965
6 changed files with 53 additions and 32 deletions
|
@ -1,3 +1,5 @@
|
|||
const { v4: uuid } = require('uuid');
|
||||
|
||||
module.exports = {
|
||||
inputs: {
|
||||
record: {
|
||||
|
@ -29,18 +31,9 @@ module.exports = {
|
|||
const boardMembership = await BoardMembership.destroyOne(inputs.record.id);
|
||||
|
||||
if (boardMembership) {
|
||||
const notify = (room) => {
|
||||
sails.sockets.broadcast(
|
||||
`user:${boardMembership.userId}`,
|
||||
'boardMembershipDelete',
|
||||
{
|
||||
item: boardMembership,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
|
||||
const notifyBoard = () => {
|
||||
sails.sockets.broadcast(
|
||||
`board:${boardMembership.boardId}`,
|
||||
room,
|
||||
'boardMembershipDelete',
|
||||
{
|
||||
item: boardMembership,
|
||||
|
@ -54,15 +47,31 @@ module.exports = {
|
|||
inputs.project.id,
|
||||
);
|
||||
|
||||
if (!isProjectManager) {
|
||||
sails.sockets.removeRoomMembersFromRooms(
|
||||
`@user:${boardMembership.userId}`,
|
||||
`board:${boardMembership.boardId}`,
|
||||
() => {
|
||||
notify(`board:${boardMembership.boardId}`);
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
notify(`user:${boardMembership.userId}`);
|
||||
|
||||
if (isProjectManager) {
|
||||
notifyBoard();
|
||||
} else {
|
||||
// TODO: also remove if unsubscribed to user
|
||||
const tempRoom = uuid();
|
||||
|
||||
sails.sockets.addRoomMembersToRooms(`board:${boardMembership.boardId}`, tempRoom, () => {
|
||||
sails.sockets.removeRoomMembersFromRooms(
|
||||
`user:${boardMembership.userId}`,
|
||||
`board:${boardMembership.boardId}`,
|
||||
notifyBoard,
|
||||
tempRoom,
|
||||
() => {
|
||||
notify(tempRoom);
|
||||
sails.sockets.removeRoomMembersFromRooms(tempRoom, tempRoom);
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -17,16 +17,23 @@ module.exports = {
|
|||
const board = await Board.archiveOne(inputs.record.id);
|
||||
|
||||
if (board) {
|
||||
sails.sockets.leaveAll(`board:${board.id}`);
|
||||
sails.sockets.removeRoomMembersFromRooms(`board:${board.id}`, `board:${board.id}`);
|
||||
|
||||
const managerUserIds = await sails.helpers.projects.getManagerUserIds(board.projectId);
|
||||
const memberUserIds = await sails.helpers.boards.getMemberUserIds(board.id);
|
||||
|
||||
const userIds = _.union(managerUserIds, memberUserIds);
|
||||
|
||||
userIds.forEach((userId) => {
|
||||
sails.sockets.broadcast(
|
||||
`project:${board.projectId}`,
|
||||
`user:${userId}`,
|
||||
'boardDelete',
|
||||
{
|
||||
item: board,
|
||||
},
|
||||
inputs.request,
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
return board;
|
||||
|
|
|
@ -25,9 +25,10 @@ module.exports = {
|
|||
},
|
||||
|
||||
async fn(inputs) {
|
||||
const userIds = await sails.helpers.projects.getManagerAndBoardMemberUserIds(
|
||||
inputs.record.projectId,
|
||||
);
|
||||
const managerUserIds = await sails.helpers.projects.getManagerUserIds(inputs.record.projectId);
|
||||
const memberUserIds = await sails.helpers.boards.getMemberUserIds(inputs.record.id);
|
||||
|
||||
const userIds = _.union(managerUserIds, memberUserIds);
|
||||
|
||||
if (!_.isUndefined(inputs.values.position)) {
|
||||
const boards = await sails.helpers.projects.getBoards(
|
||||
|
|
|
@ -26,7 +26,7 @@ module.exports = {
|
|||
const userIds = _.union(managerUserIds, memberUserIds);
|
||||
|
||||
userIds.forEach((userId) => {
|
||||
sails.sockets.removeRoomMembersFromRooms(`user:${userId}`, boardRooms);
|
||||
sails.sockets.removeRoomMembersFromRooms(`@user:${userId}`, boardRooms);
|
||||
|
||||
sails.sockets.broadcast(
|
||||
`user:${userId}`,
|
||||
|
|
|
@ -123,13 +123,13 @@ module.exports = {
|
|||
if (user.id === inputs.user.id && inputs.request && inputs.request.isSocket) {
|
||||
const tempRoom = uuid();
|
||||
|
||||
sails.sockets.addRoomMembersToRooms(`user:${user.id}`, tempRoom, () => {
|
||||
sails.sockets.addRoomMembersToRooms(`@user:${user.id}`, tempRoom, () => {
|
||||
sails.sockets.leave(inputs.request, tempRoom, () => {
|
||||
sails.sockets.leaveAll(tempRoom);
|
||||
});
|
||||
});
|
||||
} else {
|
||||
sails.sockets.leaveAll(`user:${user.id}`);
|
||||
sails.sockets.leaveAll(`@user:${user.id}`);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -59,6 +59,10 @@ module.exports = function defineCurrentUserHook(sails) {
|
|||
accessToken,
|
||||
currentUser,
|
||||
});
|
||||
|
||||
if (req.isSocket) {
|
||||
sails.sockets.join(req, `@user:${currentUser.id}`);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue