signal-desktop/js/message_requests.js

119 lines
3.3 KiB
JavaScript
Raw Normal View History

2020-10-30 20:34:04 +00:00
// Copyright 2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
2020-05-27 21:37:06 +00:00
/* global
Backbone,
Whisper,
ConversationController,
*/
/* eslint-disable more/no-then */
// eslint-disable-next-line func-names
(function () {
2020-05-27 21:37:06 +00:00
window.Whisper = window.Whisper || {};
Whisper.MessageRequests = new (Backbone.Collection.extend({
forConversation(conversation) {
if (conversation.get('e164')) {
const syncByE164 = this.findWhere({
threadE164: conversation.get('e164'),
2020-05-27 21:37:06 +00:00
});
if (syncByE164) {
window.log.info(
2020-11-20 17:30:45 +00:00
`Found early message request response for E164 ${conversation.idForLogging()}`
2020-05-27 21:37:06 +00:00
);
this.remove(syncByE164);
return syncByE164;
}
}
if (conversation.get('uuid')) {
const syncByUuid = this.findWhere({
threadUuid: conversation.get('uuid'),
2020-05-27 21:37:06 +00:00
});
if (syncByUuid) {
window.log.info(
2020-11-20 17:30:45 +00:00
`Found early message request response for UUID ${conversation.idForLogging()}`
2020-05-27 21:37:06 +00:00
);
this.remove(syncByUuid);
return syncByUuid;
}
}
2020-11-20 17:30:45 +00:00
// V1 Group
2020-05-27 21:37:06 +00:00
if (conversation.get('groupId')) {
const syncByGroupId = this.findWhere({
groupId: conversation.get('groupId'),
2020-05-27 21:37:06 +00:00
});
if (syncByGroupId) {
window.log.info(
2020-11-20 17:30:45 +00:00
`Found early message request response for group v1 ID ${conversation.idForLogging()}`
);
this.remove(syncByGroupId);
return syncByGroupId;
}
}
// V2 group
if (conversation.get('groupId')) {
const syncByGroupId = this.findWhere({
groupV2Id: conversation.get('groupId'),
});
if (syncByGroupId) {
window.log.info(
`Found early message request response for group v2 ID ${conversation.idForLogging()}`
2020-05-27 21:37:06 +00:00
);
this.remove(syncByGroupId);
return syncByGroupId;
}
}
return null;
},
async onResponse(sync) {
try {
const threadE164 = sync.get('threadE164');
const threadUuid = sync.get('threadUuid');
const groupId = sync.get('groupId');
2020-11-20 17:30:45 +00:00
const groupV2Id = sync.get('groupV2Id');
let conversation;
2020-11-20 17:30:45 +00:00
// We multiplex between GV1/GV2 groups here, but we don't kick off migrations
if (groupV2Id) {
conversation = ConversationController.get(groupV2Id);
}
if (!conversation && groupId) {
conversation = ConversationController.get(groupId);
}
if (!conversation && (threadE164 || threadUuid)) {
conversation = ConversationController.get(
ConversationController.ensureContactIds({
e164: threadE164,
uuid: threadUuid,
})
);
}
2020-05-27 21:37:06 +00:00
if (!conversation) {
window.log(
2020-11-20 17:30:45 +00:00
`Received message request response for unknown conversation: groupv2(${groupV2Id}) group(${groupId}) ${threadUuid} ${threadE164}`
2020-05-27 21:37:06 +00:00
);
return;
}
conversation.applyMessageRequestResponse(sync.get('type'), {
fromSync: true,
});
this.remove(sync);
} catch (error) {
window.log.error(
'MessageRequests.onResponse error:',
error && error.stack ? error.stack : error
);
}
},
}))();
})();