mirror of
https://github.com/signalapp/Signal-Desktop.git
synced 2026-02-15 07:28:59 +00:00
Release Notes Channel: Fix behavior when conversation is blocked
This commit is contained in:
@@ -172,11 +172,34 @@ export class ReleaseNotesFetcher {
|
||||
log.info('ReleaseNotesFetcher: WebAPI unavailable');
|
||||
throw new Error('WebAPI unavailable');
|
||||
}
|
||||
|
||||
log.info('ReleaseNotesFetcher: Ensuring Signal conversation');
|
||||
const signalConversation =
|
||||
await window.ConversationController.getOrCreateSignalConversation();
|
||||
|
||||
const sortedNotes = [...notes].sort(
|
||||
(a: ManifestReleaseNoteType, b: ManifestReleaseNoteType) =>
|
||||
semver.compare(a.desktopMinVersion, b.desktopMinVersion)
|
||||
);
|
||||
|
||||
const newestNote = last(sortedNotes);
|
||||
strictAssert(newestNote, 'processReleaseNotes requires at least 1 note');
|
||||
|
||||
const versionWatermark = newestNote.desktopMinVersion;
|
||||
|
||||
if (signalConversation.isBlocked()) {
|
||||
log.info(
|
||||
`ReleaseNotesFetcher: Signal conversation is blocked, updating watermark to ${versionWatermark}`
|
||||
);
|
||||
drop(
|
||||
window.textsecure.storage.put(
|
||||
VERSION_WATERMARK_STORAGE_KEY,
|
||||
versionWatermark
|
||||
)
|
||||
);
|
||||
return;
|
||||
}
|
||||
|
||||
const hydratedNotesWithRawAttachments = (
|
||||
await Promise.all(
|
||||
sortedNotes.map(async note => {
|
||||
@@ -242,10 +265,6 @@ export class ReleaseNotesFetcher {
|
||||
return;
|
||||
}
|
||||
|
||||
log.info('ReleaseNotesFetcher: Ensuring Signal conversation');
|
||||
const signalConversation =
|
||||
await window.ConversationController.getOrCreateSignalConversation();
|
||||
|
||||
const messages: Array<MessageAttributesType> = [];
|
||||
hydratedNotes.forEach(
|
||||
({ hydratedNote: note, processedAttachment }, index) => {
|
||||
@@ -320,10 +339,6 @@ export class ReleaseNotesFetcher {
|
||||
signalConversation.set({ active_at: Date.now(), isArchived: false });
|
||||
drop(signalConversation.updateUnread());
|
||||
|
||||
const newestNote = last(sortedNotes);
|
||||
strictAssert(newestNote, 'processReleaseNotes requires at least 1 note');
|
||||
|
||||
const versionWatermark = newestNote.desktopMinVersion;
|
||||
log.info(
|
||||
`ReleaseNotesFetcher: Updating version watermark to ${versionWatermark}`
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user