Fix bug in identity key conflict edge case

When resolving conflicts, we should not only discard the old key, but
set the new trusted key to the one the user has verified. Previously, we
would end up trusting the first-seen new key, which may not be the one
the user verified.

 // FREEBIE
This commit is contained in:
lilia 2015-07-31 11:14:43 -07:00
parent d808d255eb
commit ccfae3c78a
2 changed files with 11 additions and 7 deletions

View file

@ -258,7 +258,9 @@
} }
}, },
resolveConflicts: function(number) { resolveConflicts: function(conflict) {
var number = conflict.number;
var identityKey = conflict.identityKey;
if (this.isPrivate()) { if (this.isPrivate()) {
number = this.id; number = this.id;
} else if (!_.include(this.get('members'), number)) { } else if (!_.include(this.get('members'), number)) {
@ -270,12 +272,14 @@
} }
return textsecure.storage.axolotl.removeIdentityKey(number).then(function() { return textsecure.storage.axolotl.removeIdentityKey(number).then(function() {
return textsecure.storage.axolotl.putIdentityKey(number, identityKey).then(function() {
this.messageCollection.each(function(message) { this.messageCollection.each(function(message) {
if (message.hasKeyConflict(number)) { if (message.hasKeyConflict(number)) {
message.resolveConflict(number); message.resolveConflict(number);
} }
}); });
}.bind(this)); }.bind(this));
}.bind(this));
}, },
hashCode: function() { hashCode: function() {
if (this.hash === undefined) { if (this.hash === undefined) {

View file

@ -41,7 +41,7 @@
}, },
resolve: function() { resolve: function() {
new Promise(function(resolve) { new Promise(function(resolve) {
this.conversation.resolveConflicts(this.model.number).then(resolve); this.conversation.resolveConflicts(this.model).then(resolve);
}.bind(this)); }.bind(this));
this.trigger('resolve'); this.trigger('resolve');
this.remove(); this.remove();