2023-05-16 17:37:12 +00:00
|
|
|
// Copyright 2023 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2024-07-24 20:14:11 +00:00
|
|
|
import type { ReadonlyMessageAttributesType } from '../model-types.d';
|
2023-05-16 17:37:12 +00:00
|
|
|
import type { LoggerType } from '../types/Logging';
|
|
|
|
import { assertDev } from './assert';
|
|
|
|
|
|
|
|
export type GetMessageSentTimestampOptionsType = Readonly<{
|
|
|
|
includeEdits?: boolean;
|
|
|
|
log: LoggerType;
|
|
|
|
}>;
|
|
|
|
|
|
|
|
export function getMessageSentTimestamp(
|
|
|
|
{
|
|
|
|
editMessageTimestamp,
|
|
|
|
sent_at: sentAt,
|
|
|
|
timestamp,
|
|
|
|
}: Pick<
|
2024-07-24 20:14:11 +00:00
|
|
|
ReadonlyMessageAttributesType,
|
2023-05-16 17:37:12 +00:00
|
|
|
'editMessageTimestamp' | 'sent_at' | 'timestamp'
|
|
|
|
>,
|
|
|
|
{ includeEdits = true, log }: GetMessageSentTimestampOptionsType
|
|
|
|
): number {
|
|
|
|
if (includeEdits && editMessageTimestamp) {
|
|
|
|
return editMessageTimestamp;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (sentAt) {
|
|
|
|
return sentAt;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (timestamp) {
|
|
|
|
log.error('message lacked sent_at. Falling back to timestamp');
|
|
|
|
return timestamp;
|
|
|
|
}
|
|
|
|
|
|
|
|
assertDev(
|
|
|
|
false,
|
|
|
|
'message lacked sent_at and timestamp. Falling back to current time'
|
|
|
|
);
|
|
|
|
return Date.now();
|
|
|
|
}
|