2020-10-30 15:34:04 -05:00
|
|
|
// Copyright 2020 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2021-10-26 14:15:33 -05:00
|
|
|
import type { DeleteModel } from '../messageModifiers/Deletes';
|
|
|
|
import type { MessageModel } from '../models/messages';
|
2021-09-17 14:27:53 -04:00
|
|
|
import * as log from '../logging/log';
|
2022-03-04 11:22:31 -08:00
|
|
|
import { DAY } from './durations';
|
2020-07-27 14:15:32 -04:00
|
|
|
|
|
|
|
export async function deleteForEveryone(
|
2020-09-24 13:57:54 -07:00
|
|
|
message: MessageModel,
|
2021-06-17 10:15:10 -07:00
|
|
|
doe: DeleteModel,
|
2020-09-14 14:56:35 -07:00
|
|
|
shouldPersist = true
|
2020-07-27 14:15:32 -04:00
|
|
|
): Promise<void> {
|
2021-08-13 09:02:28 -07:00
|
|
|
const messageTimestamp =
|
|
|
|
message.get('serverTimestamp') || message.get('sent_at') || 0;
|
|
|
|
|
2020-07-27 14:15:32 -04:00
|
|
|
// Make sure the server timestamps for the DOE and the matching message
|
|
|
|
// are less than one day apart
|
2021-08-13 09:02:28 -07:00
|
|
|
const delta = Math.abs(doe.get('serverTimestamp') - messageTimestamp);
|
|
|
|
|
2022-03-04 11:22:31 -08:00
|
|
|
if (delta > DAY) {
|
2021-09-17 14:27:53 -04:00
|
|
|
log.info('Received late DOE. Dropping.', {
|
2020-07-27 14:15:32 -04:00
|
|
|
fromId: doe.get('fromId'),
|
|
|
|
targetSentTimestamp: doe.get('targetSentTimestamp'),
|
|
|
|
messageServerTimestamp: message.get('serverTimestamp'),
|
2021-08-13 09:02:28 -07:00
|
|
|
messageSentAt: message.get('sent_at'),
|
2020-07-27 14:15:32 -04:00
|
|
|
deleteServerTimestamp: doe.get('serverTimestamp'),
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
await message.handleDeleteForEveryone(doe, shouldPersist);
|
|
|
|
}
|