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
|
2020-11-18 15:15:42 +00:00
|
|
|
(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({
|
2020-07-10 18:28:49 +00:00
|
|
|
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({
|
2020-07-10 18:28:49 +00:00
|
|
|
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({
|
2020-07-10 18:28:49 +00:00
|
|
|
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-07-10 18:28:49 +00:00
|
|
|
|
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
|
|
|
|
);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}))();
|
|
|
|
})();
|