Skip to content

Commit

Permalink
feat: clone once not every
Browse files Browse the repository at this point in the history
  • Loading branch information
pauldambra committed Mar 21, 2024
1 parent c491bf2 commit d2d0ed0
Showing 1 changed file with 11 additions and 12 deletions.
23 changes: 11 additions & 12 deletions plugin-server/src/main/ingestion-queues/session-recording/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -255,38 +255,37 @@ export const reduceRecordingMessages = (messages: IncomingRecordingMessage[]): I
const reducedMessages: Record<string, IncomingRecordingMessage> = {}

for (const message of messages) {
const clonedMessage = cloneObject(message)
const key = `${clonedMessage.team_id}-${clonedMessage.session_id}`
const key = `${message.team_id}-${message.session_id}`
if (!reducedMessages[key]) {
reducedMessages[key] = clonedMessage
// cloning the object here so that when we mutate it
// we're not also mutating its reference in the inbound messages array
// this is maybe overly defensive, but better safe than sorry
reducedMessages[key] = cloneObject(message)
} else {
const existingMessage = reducedMessages[key]
for (const [windowId, events] of Object.entries(clonedMessage.eventsByWindowId)) {
for (const [windowId, events] of Object.entries(message.eventsByWindowId)) {
if (existingMessage.eventsByWindowId[windowId]) {
existingMessage.eventsByWindowId[windowId].push(...events)
} else {
existingMessage.eventsByWindowId[windowId] = events
}
}
existingMessage.metadata.rawSize += clonedMessage.metadata.rawSize
existingMessage.metadata.rawSize += message.metadata.rawSize

// Update the events ranges
existingMessage.metadata.lowOffset = Math.min(
existingMessage.metadata.lowOffset,
clonedMessage.metadata.lowOffset
message.metadata.lowOffset
)

existingMessage.metadata.highOffset = Math.max(
existingMessage.metadata.highOffset,
clonedMessage.metadata.highOffset
message.metadata.highOffset
)

// Update the events ranges
existingMessage.eventsRange.start = Math.min(
existingMessage.eventsRange.start,
clonedMessage.eventsRange.start
)
existingMessage.eventsRange.end = Math.max(existingMessage.eventsRange.end, clonedMessage.eventsRange.end)
existingMessage.eventsRange.start = Math.min(existingMessage.eventsRange.start, message.eventsRange.start)
existingMessage.eventsRange.end = Math.max(existingMessage.eventsRange.end, message.eventsRange.end)
}
}

Expand Down

0 comments on commit d2d0ed0

Please sign in to comment.