diff --git a/keyserver/src/creators/message-creator.js b/keyserver/src/creators/message-creator.js --- a/keyserver/src/creators/message-creator.js +++ b/keyserver/src/creators/message-creator.js @@ -87,45 +87,65 @@ return []; } - const messageInfos: RawMessageInfo[] = []; - const newMessageDatas: MessageData[] = []; const existingMessages = await Promise.all( messageDatas.map(messageData => fetchMessageInfoForLocalID(viewer, messageDataLocalID(messageData)), ), ); - for (let i = 0; i < existingMessages.length; i++) { + + const existingMessageInfos: RawMessageInfo[] = []; + const newMessageDatas: MessageData[] = []; + for (let i = 0; i < messageDatas.length; i++) { const existingMessage = existingMessages[i]; if (existingMessage) { - messageInfos.push(existingMessage); + existingMessageInfos.push(existingMessage); } else { newMessageDatas.push(messageDatas[i]); } } if (newMessageDatas.length === 0) { - return shimUnsupportedRawMessageInfos(messageInfos, viewer.platformDetails); + return shimUnsupportedRawMessageInfos( + existingMessageInfos, + viewer.platformDetails, + ); } const ids = await createIDs('messages', newMessageDatas.length); + const returnMessageInfos: RawMessageInfo[] = []; const subthreadPermissionsToCheck: Set = new Set(); - const threadsToMessageIndices: Map = new Map(); const messageInsertRows = []; - for (let i = 0; i < newMessageDatas.length; i++) { - const messageData = newMessageDatas[i]; - const threadID = messageData.threadID; - const creatorID = messageData.creatorID; - if (messageData.type === messageTypes.CREATE_SUB_THREAD) { - subthreadPermissionsToCheck.add(messageData.childThreadID); + // Indices in threadsToMessageIndices point to newMessageInfos + const newMessageInfos: RawMessageInfo[] = []; + const threadsToMessageIndices: Map = new Map(); + + let nextNewMessageIndex = 0; + for (let i = 0; i < messageDatas.length; i++) { + const existingMessage = existingMessages[i]; + if (existingMessage) { + returnMessageInfos.push(existingMessage); + continue; } + const messageData = messageDatas[i]; + const threadID = messageData.threadID; + const creatorID = messageData.creatorID; + let messageIndices = threadsToMessageIndices.get(threadID); if (!messageIndices) { messageIndices = []; threadsToMessageIndices.set(threadID, messageIndices); } - messageIndices.push(i); + + const newMessageIndex = nextNewMessageIndex++; + messageIndices.push(newMessageIndex); + + const serverID = ids[newMessageIndex]; + + if (messageData.type === messageTypes.CREATE_SUB_THREAD) { + subthreadPermissionsToCheck.add(messageData.childThreadID); + } const content = messageSpecs[messageData.type].messageContentForServerDB?.( messageData, @@ -141,7 +161,7 @@ : null; messageInsertRows.push([ - ids[i], + serverID, threadID, creatorID, messageData.type, @@ -150,7 +170,9 @@ creation, targetMessageID, ]); - messageInfos.push(rawMessageInfoFromMessageData(messageData, ids[i])); + const rawMessageInfo = rawMessageInfoFromMessageData(messageData, serverID); + newMessageInfos.push(rawMessageInfo); // at newMessageIndex + returnMessageInfos.push(rawMessageInfo); // at i } if (viewer.isScriptViewer) { @@ -158,7 +180,7 @@ viewer, threadsToMessageIndices, subthreadPermissionsToCheck, - stripLocalIDs(messageInfos), + stripLocalIDs(newMessageInfos), updatesForCurrentSession, ); } else { @@ -169,7 +191,7 @@ viewer, threadsToMessageIndices, subthreadPermissionsToCheck, - stripLocalIDs(messageInfos), + stripLocalIDs(newMessageInfos), updatesForCurrentSession, ), ); @@ -189,7 +211,10 @@ return []; } - return shimUnsupportedRawMessageInfos(messageInfos, viewer.platformDetails); + return shimUnsupportedRawMessageInfos( + returnMessageInfos, + viewer.platformDetails, + ); } async function updateRepliesCount(