Move handleAttachment and processDecrypted
Make these internal methods on MessageReceiver. Todo: refactor identity key errors to use a given message receiver. // FREEBIE
This commit is contained in:
		
					parent
					
						
							
								a8f4bac2f7
							
						
					
				
			
			
				commit
				
					
						c8a1e090d2
					
				
			
		
					 3 changed files with 754 additions and 776 deletions
				
			
		| 
						 | 
				
			
			@ -113,111 +113,3 @@ window.textsecure.utils = function() {
 | 
			
		|||
    return self;
 | 
			
		||||
}();
 | 
			
		||||
 | 
			
		||||
function handleAttachment(attachment) {
 | 
			
		||||
    function getAttachment() {
 | 
			
		||||
        return TextSecureServer.getAttachment(attachment.id.toString());
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function decryptAttachment(encrypted) {
 | 
			
		||||
        return textsecure.crypto.decryptAttachment(
 | 
			
		||||
            encrypted,
 | 
			
		||||
            attachment.key.toArrayBuffer()
 | 
			
		||||
        );
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    function updateAttachment(data) {
 | 
			
		||||
        attachment.data = data;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return getAttachment().
 | 
			
		||||
    then(decryptAttachment).
 | 
			
		||||
    then(updateAttachment);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function processDecrypted(decrypted, source) {
 | 
			
		||||
 | 
			
		||||
    // Now that its decrypted, validate the message and clean it up for consumer processing
 | 
			
		||||
    // Note that messages may (generally) only perform one action and we ignore remaining fields
 | 
			
		||||
    // after the first action.
 | 
			
		||||
 | 
			
		||||
    if (decrypted.flags == null)
 | 
			
		||||
        decrypted.flags = 0;
 | 
			
		||||
 | 
			
		||||
    if ((decrypted.flags & textsecure.protobuf.DataMessage.Flags.END_SESSION)
 | 
			
		||||
                == textsecure.protobuf.DataMessage.Flags.END_SESSION) {
 | 
			
		||||
        decrypted.body = null;
 | 
			
		||||
        decrypted.attachments = [];
 | 
			
		||||
        decrypted.group = null;
 | 
			
		||||
        return Promise.resolve(decrypted);
 | 
			
		||||
    }
 | 
			
		||||
    if (decrypted.flags != 0) {
 | 
			
		||||
        throw new Error("Unknown flags in message");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    var promises = [];
 | 
			
		||||
 | 
			
		||||
    if (decrypted.group !== null) {
 | 
			
		||||
        decrypted.group.id = getString(decrypted.group.id);
 | 
			
		||||
 | 
			
		||||
        if (decrypted.group.type == textsecure.protobuf.GroupContext.Type.UPDATE) {
 | 
			
		||||
            if (decrypted.group.avatar !== null) {
 | 
			
		||||
                promises.push(handleAttachment(decrypted.group.avatar));
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        promises.push(textsecure.storage.groups.getNumbers(decrypted.group.id).then(function(existingGroup) {
 | 
			
		||||
            if (existingGroup === undefined) {
 | 
			
		||||
                if (decrypted.group.type != textsecure.protobuf.GroupContext.Type.UPDATE) {
 | 
			
		||||
                    throw new Error("Got message for unknown group");
 | 
			
		||||
                }
 | 
			
		||||
                return textsecure.storage.groups.createNewGroup(decrypted.group.members, decrypted.group.id);
 | 
			
		||||
            } else {
 | 
			
		||||
                var fromIndex = existingGroup.indexOf(source);
 | 
			
		||||
 | 
			
		||||
                if (fromIndex < 0) {
 | 
			
		||||
                    //TODO: This could be indication of a race...
 | 
			
		||||
                    throw new Error("Sender was not a member of the group they were sending from");
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                switch(decrypted.group.type) {
 | 
			
		||||
                case textsecure.protobuf.GroupContext.Type.UPDATE:
 | 
			
		||||
                    return textsecure.storage.groups.updateNumbers(
 | 
			
		||||
                        decrypted.group.id, decrypted.group.members
 | 
			
		||||
                    ).then(function(added) {
 | 
			
		||||
                        decrypted.group.added = added;
 | 
			
		||||
 | 
			
		||||
                        if (decrypted.group.avatar === null &&
 | 
			
		||||
                            decrypted.group.added.length == 0 &&
 | 
			
		||||
                            decrypted.group.name === null) {
 | 
			
		||||
                            return;
 | 
			
		||||
                        }
 | 
			
		||||
 | 
			
		||||
                        decrypted.body = null;
 | 
			
		||||
                        decrypted.attachments = [];
 | 
			
		||||
                    });
 | 
			
		||||
 | 
			
		||||
                    break;
 | 
			
		||||
                case textsecure.protobuf.GroupContext.Type.QUIT:
 | 
			
		||||
                    decrypted.body = null;
 | 
			
		||||
                    decrypted.attachments = [];
 | 
			
		||||
                    return textsecure.storage.groups.removeNumber(decrypted.group.id, source);
 | 
			
		||||
                case textsecure.protobuf.GroupContext.Type.DELIVER:
 | 
			
		||||
                    decrypted.group.name = null;
 | 
			
		||||
                    decrypted.group.members = [];
 | 
			
		||||
                    decrypted.group.avatar = null;
 | 
			
		||||
 | 
			
		||||
                    break;
 | 
			
		||||
                default:
 | 
			
		||||
                    throw new Error("Unknown group message type");
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        }));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    for (var i in decrypted.attachments) {
 | 
			
		||||
        promises.push(handleAttachment(decrypted.attachments[i]));
 | 
			
		||||
    }
 | 
			
		||||
    return Promise.all(promises).then(function() {
 | 
			
		||||
        return decrypted;
 | 
			
		||||
    });
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue