Fix a couple things broken in d9bf0a4

Slight revert from said commit. We really do need the
IncomingPushMessageSignal protobuf at the UI layer, mostly because
it contains the 'source' attribute, without which we don't know
who sent the message.

Also fix a crash when there are no attachments on a message.
This commit is contained in:
lilia 2014-05-22 21:59:34 -07:00
parent 6064afd43d
commit 1e672030de
2 changed files with 8 additions and 4 deletions

View file

@ -603,7 +603,9 @@ window.textsecure.crypto = new function() {
case 0: //TYPE_MESSAGE_PLAINTEXT case 0: //TYPE_MESSAGE_PLAINTEXT
return Promise.resolve(decodePushMessageContentProtobuf(getString(proto.message))); return Promise.resolve(decodePushMessageContentProtobuf(getString(proto.message)));
case 1: //TYPE_MESSAGE_CIPHERTEXT case 1: //TYPE_MESSAGE_CIPHERTEXT
return decryptWhisperMessage(proto.source, getString(proto.message)); return decryptWhisperMessage(proto.source, getString(proto.message)).then(function(result) {
return {message:result, pushMessage: proto};
});
case 3: //TYPE_MESSAGE_PREKEY_BUNDLE case 3: //TYPE_MESSAGE_PREKEY_BUNDLE
if (proto.message.readUint8() != (2 << 4 | 2)) if (proto.message.readUint8() != (2 << 4 | 2))
throw new Error("Bad version byte"); throw new Error("Bad version byte");
@ -612,7 +614,7 @@ window.textsecure.crypto = new function() {
return decryptWhisperMessage(proto.source, getString(preKeyProto.message), sessions[0]).then(function(result) { return decryptWhisperMessage(proto.source, getString(preKeyProto.message), sessions[0]).then(function(result) {
if (sessions[1] !== undefined) if (sessions[1] !== undefined)
crypto_storage.saveSession(proto.source, sessions[1]); crypto_storage.saveSession(proto.source, sessions[1]);
return result; return {message: result, pushMessage:proto};
}); });
}); });
} }

View file

@ -22,8 +22,10 @@ var Whisper = Whisper || {};
this.$el.find('.message-text').text(this.model.get('body')); this.$el.find('.message-text').text(this.model.get('body'));
var attachments = this.model.get('attachments'); var attachments = this.model.get('attachments');
for (var i = 0; i < attachments.length; i++) if (attachments) {
this.$el.find('.message-attachment').append('<img src="' + attachments[i] + '" />'); for (var i = 0; i < attachments.length; i++)
this.$el.find('.message-attachment').append('<img src="' + attachments[i] + '" />');
}
this.$el.find('.metadata').text(this.formatTimestamp()); this.$el.find('.metadata').text(this.formatTimestamp());
return this; return this;