|
|
|
@ -909,56 +909,63 @@ MessageReceiver.prototype.extend({
|
|
|
|
|
p = this.handleEndSession(envelope.source);
|
|
|
|
|
}
|
|
|
|
|
return p.then(() =>
|
|
|
|
|
this.processDecrypted(envelope, msg, envelope.source).then(message => {
|
|
|
|
|
const groupId = message.group && message.group.id;
|
|
|
|
|
const isBlocked = this.isGroupBlocked(groupId);
|
|
|
|
|
const isMe = envelope.source === textsecure.storage.user.getNumber();
|
|
|
|
|
const conversation = window.ConversationController.get(envelope.source);
|
|
|
|
|
const isLeavingGroup = Boolean(
|
|
|
|
|
message.group &&
|
|
|
|
|
message.group.type === textsecure.protobuf.GroupContext.Type.QUIT
|
|
|
|
|
);
|
|
|
|
|
const friendRequest =
|
|
|
|
|
envelope.type === textsecure.protobuf.Envelope.Type.FRIEND_REQUEST;
|
|
|
|
|
|
|
|
|
|
// Check if we need to update any profile names
|
|
|
|
|
if (!isMe && conversation) {
|
|
|
|
|
let profile = null;
|
|
|
|
|
if (message.profile) {
|
|
|
|
|
profile = JSON.parse(message.profile.encodeJSON());
|
|
|
|
|
this.processDecrypted(envelope, msg, envelope.source).then(
|
|
|
|
|
async message => {
|
|
|
|
|
const groupId = message.group && message.group.id;
|
|
|
|
|
const isBlocked = this.isGroupBlocked(groupId);
|
|
|
|
|
const isMe = envelope.source === textsecure.storage.user.getNumber();
|
|
|
|
|
const conversation = window.ConversationController.get(
|
|
|
|
|
envelope.source
|
|
|
|
|
);
|
|
|
|
|
const isLeavingGroup = Boolean(
|
|
|
|
|
message.group &&
|
|
|
|
|
message.group.type === textsecure.protobuf.GroupContext.Type.QUIT
|
|
|
|
|
);
|
|
|
|
|
const friendRequest =
|
|
|
|
|
envelope.type === textsecure.protobuf.Envelope.Type.FRIEND_REQUEST;
|
|
|
|
|
|
|
|
|
|
// Check if we need to update any profile names
|
|
|
|
|
if (!isMe && conversation) {
|
|
|
|
|
let profile = null;
|
|
|
|
|
if (message.profile) {
|
|
|
|
|
profile = JSON.parse(message.profile.encodeJSON());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Update the conversation
|
|
|
|
|
await conversation.setProfile(profile);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Update the conversation
|
|
|
|
|
conversation.setProfile(profile);
|
|
|
|
|
}
|
|
|
|
|
if (friendRequest && isMe) {
|
|
|
|
|
window.log.info('refusing to add a friend request to ourselves');
|
|
|
|
|
throw new Error('Cannot add a friend request for ourselves!');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (friendRequest && isMe) {
|
|
|
|
|
window.log.info('refusing to add a friend request to ourselves');
|
|
|
|
|
throw new Error('Cannot add a friend request for ourselves!');
|
|
|
|
|
}
|
|
|
|
|
if (groupId && isBlocked && !(isMe && isLeavingGroup)) {
|
|
|
|
|
window.log.warn(
|
|
|
|
|
`Message ${this.getEnvelopeId(
|
|
|
|
|
envelope
|
|
|
|
|
)} ignored; destined for blocked group`
|
|
|
|
|
);
|
|
|
|
|
return this.removeFromCache(envelope);
|
|
|
|
|
}
|
|
|
|
|
if (!message.body) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (groupId && isBlocked && !(isMe && isLeavingGroup)) {
|
|
|
|
|
window.log.warn(
|
|
|
|
|
`Message ${this.getEnvelopeId(
|
|
|
|
|
envelope
|
|
|
|
|
)} ignored; destined for blocked group`
|
|
|
|
|
);
|
|
|
|
|
return this.removeFromCache(envelope);
|
|
|
|
|
const ev = new Event('message');
|
|
|
|
|
ev.confirm = this.removeFromCache.bind(this, envelope);
|
|
|
|
|
ev.data = {
|
|
|
|
|
friendRequest,
|
|
|
|
|
source: envelope.source,
|
|
|
|
|
sourceDevice: envelope.sourceDevice,
|
|
|
|
|
timestamp: envelope.timestamp.toNumber(),
|
|
|
|
|
receivedAt: envelope.receivedAt,
|
|
|
|
|
unidentifiedDeliveryReceived: envelope.unidentifiedDeliveryReceived,
|
|
|
|
|
message,
|
|
|
|
|
};
|
|
|
|
|
return this.dispatchAndWait(ev);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const ev = new Event('message');
|
|
|
|
|
ev.confirm = this.removeFromCache.bind(this, envelope);
|
|
|
|
|
ev.data = {
|
|
|
|
|
friendRequest,
|
|
|
|
|
source: envelope.source,
|
|
|
|
|
sourceDevice: envelope.sourceDevice,
|
|
|
|
|
timestamp: envelope.timestamp.toNumber(),
|
|
|
|
|
receivedAt: envelope.receivedAt,
|
|
|
|
|
unidentifiedDeliveryReceived: envelope.unidentifiedDeliveryReceived,
|
|
|
|
|
message,
|
|
|
|
|
};
|
|
|
|
|
return this.dispatchAndWait(ev);
|
|
|
|
|
})
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
handleLegacyMessage(envelope) {
|
|
|
|
@ -994,7 +1001,7 @@ MessageReceiver.prototype.extend({
|
|
|
|
|
if (content.syncMessage)
|
|
|
|
|
return this.handleSyncMessage(envelope, content.syncMessage);
|
|
|
|
|
if (content.dataMessage)
|
|
|
|
|
return this.handleDataMessage(envelope, content.dataMessage);
|
|
|
|
|
await this.handleDataMessage(envelope, content.dataMessage);
|
|
|
|
|
if (content.nullMessage)
|
|
|
|
|
return this.handleNullMessage(envelope, content.nullMessage);
|
|
|
|
|
if (content.callMessage)
|
|
|
|
@ -1004,13 +1011,19 @@ MessageReceiver.prototype.extend({
|
|
|
|
|
if (content.typingMessage)
|
|
|
|
|
return this.handleTypingMessage(envelope, content.typingMessage);
|
|
|
|
|
|
|
|
|
|
// Trigger conversation friend request event for empty message
|
|
|
|
|
const conversation = window.ConversationController.get(envelope.source);
|
|
|
|
|
if (conversation) {
|
|
|
|
|
conversation.onFriendRequestAccepted();
|
|
|
|
|
conversation.notifyFriendRequest(envelope.source, 'accepted');
|
|
|
|
|
// Trigger conversation friend request event
|
|
|
|
|
if (
|
|
|
|
|
envelope.type === textsecure.protobuf.Envelope.Type.PREKEY_BUNDLE &&
|
|
|
|
|
(content.dataMessage === null || content.dataMessage.flags === null)
|
|
|
|
|
) {
|
|
|
|
|
const conversation = window.ConversationController.get(envelope.source);
|
|
|
|
|
if (conversation) {
|
|
|
|
|
conversation.onFriendRequestAccepted();
|
|
|
|
|
conversation.notifyFriendRequest(envelope.source, 'accepted');
|
|
|
|
|
}
|
|
|
|
|
this.removeFromCache(envelope);
|
|
|
|
|
}
|
|
|
|
|
this.removeFromCache(envelope);
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
},
|
|
|
|
|
handleCallMessage(envelope) {
|
|
|
|
|