2023-08-09 00:53:06 +00:00
|
|
|
// Copyright 2022 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import type { CallLogEventSyncEvent } from '../textsecure/messageReceiverEvents';
|
|
|
|
import * as log from '../logging/log';
|
2024-06-26 00:58:38 +00:00
|
|
|
import type { CallLogEventTarget } from '../types/CallDisposition';
|
2023-08-09 00:53:06 +00:00
|
|
|
import { CallLogEvent } from '../types/CallDisposition';
|
|
|
|
import { missingCaseError } from './missingCaseError';
|
2024-06-26 00:58:38 +00:00
|
|
|
import { strictAssert } from './assert';
|
|
|
|
import { updateDeletedMessages } from './callDisposition';
|
2023-08-09 00:53:06 +00:00
|
|
|
|
|
|
|
export async function onCallLogEventSync(
|
|
|
|
syncEvent: CallLogEventSyncEvent
|
|
|
|
): Promise<void> {
|
2024-06-26 00:58:38 +00:00
|
|
|
const { data, confirm } = syncEvent;
|
|
|
|
const { type, peerId, callId, timestamp } = data.callLogEventDetails;
|
|
|
|
|
|
|
|
const target: CallLogEventTarget = {
|
|
|
|
peerId,
|
|
|
|
callId,
|
|
|
|
timestamp,
|
|
|
|
};
|
2023-08-09 00:53:06 +00:00
|
|
|
|
|
|
|
log.info(
|
2024-06-26 00:58:38 +00:00
|
|
|
`onCallLogEventSync: Processing event (Event: ${type}, CallId: ${callId}, Timestamp: ${timestamp})`
|
2023-08-09 00:53:06 +00:00
|
|
|
);
|
|
|
|
|
2024-06-26 00:58:38 +00:00
|
|
|
if (type === CallLogEvent.Clear) {
|
|
|
|
log.info('onCallLogEventSync: Clearing call history');
|
2023-09-27 19:42:30 +00:00
|
|
|
try {
|
2024-06-26 00:58:38 +00:00
|
|
|
const messageIds = await window.Signal.Data.clearCallHistory(target);
|
|
|
|
updateDeletedMessages(messageIds);
|
2023-09-27 19:42:30 +00:00
|
|
|
} finally {
|
|
|
|
// We want to reset the call history even if the clear fails.
|
|
|
|
window.reduxActions.callHistory.resetCallHistory();
|
|
|
|
}
|
2023-08-09 00:53:06 +00:00
|
|
|
confirm();
|
2024-06-26 00:58:38 +00:00
|
|
|
} else if (type === CallLogEvent.MarkedAsRead) {
|
|
|
|
log.info('onCallLogEventSync: Marking call history read');
|
|
|
|
try {
|
|
|
|
await window.Signal.Data.markAllCallHistoryRead(target);
|
|
|
|
} finally {
|
|
|
|
window.reduxActions.callHistory.updateCallHistoryUnreadCount();
|
|
|
|
}
|
|
|
|
confirm();
|
|
|
|
} else if (type === CallLogEvent.MarkedAsReadInConversation) {
|
|
|
|
log.info('onCallLogEventSync: Marking call history read in conversation');
|
2024-03-11 18:18:55 +00:00
|
|
|
try {
|
2024-06-26 00:58:38 +00:00
|
|
|
strictAssert(peerId, 'Missing peerId');
|
|
|
|
await window.Signal.Data.markAllCallHistoryReadInConversation(target);
|
2024-03-11 18:18:55 +00:00
|
|
|
} finally {
|
|
|
|
window.reduxActions.callHistory.updateCallHistoryUnreadCount();
|
|
|
|
}
|
|
|
|
confirm();
|
2023-08-09 00:53:06 +00:00
|
|
|
} else {
|
2024-06-26 00:58:38 +00:00
|
|
|
throw missingCaseError(type);
|
2023-08-09 00:53:06 +00:00
|
|
|
}
|
|
|
|
}
|