Refactor relay consistency check

Check the device list for relay consitency and throw an exception before
attempting to encrypt to any of the mismatched devices.

// FREEBIE
This commit is contained in:
lilia 2015-09-23 11:36:29 -07:00
parent bafc61600c
commit acaf7b8de2
2 changed files with 12 additions and 34 deletions

View file

@ -39690,24 +39690,13 @@ window.textsecure.messaging = function() {
// message == DataMessage or ContentMessage proto // message == DataMessage or ContentMessage proto
function sendMessageToDevices(timestamp, number, deviceObjectList, message) { function sendMessageToDevices(timestamp, number, deviceObjectList, message) {
var relay = undefined; var relay = deviceObjectList[0].relay;
return Promise.all(deviceObjectList.map(function(device) { for (var i=1; i < deviceObjectList.length; ++i) {
if (device.relay !== undefined) { if (deviceObjectList[i].relay !== relay) {
if (relay === undefined) throw new Error("Mismatched relays for number " + number);
relay = device.relay;
else if (relay != device.relay)
return new Promise(function() {
throw new Error("Mismatched relays for number " + number);
});
} else {
if (relay === undefined)
relay = "";
else if (relay != "")
return new Promise(function() {
throw new Error("Mismatched relays for number " + number);
});
} }
}
return Promise.all(deviceObjectList.map(function(device) {
return textsecure.protocol_wrapper.encryptMessageFor(device, message).then(function(encryptedMsg) { return textsecure.protocol_wrapper.encryptMessageFor(device, message).then(function(encryptedMsg) {
return textsecure.protocol_wrapper.getRegistrationId(device.encodedNumber).then(function(registrationId) { return textsecure.protocol_wrapper.getRegistrationId(device.encodedNumber).then(function(registrationId) {
return textsecure.storage.devices.removeTempKeysFromDevice(device.encodedNumber).then(function() { return textsecure.storage.devices.removeTempKeysFromDevice(device.encodedNumber).then(function() {

View file

@ -9,24 +9,13 @@ window.textsecure.messaging = function() {
// message == DataMessage or ContentMessage proto // message == DataMessage or ContentMessage proto
function sendMessageToDevices(timestamp, number, deviceObjectList, message) { function sendMessageToDevices(timestamp, number, deviceObjectList, message) {
var relay = undefined; var relay = deviceObjectList[0].relay;
return Promise.all(deviceObjectList.map(function(device) { for (var i=1; i < deviceObjectList.length; ++i) {
if (device.relay !== undefined) { if (deviceObjectList[i].relay !== relay) {
if (relay === undefined) throw new Error("Mismatched relays for number " + number);
relay = device.relay;
else if (relay != device.relay)
return new Promise(function() {
throw new Error("Mismatched relays for number " + number);
});
} else {
if (relay === undefined)
relay = "";
else if (relay != "")
return new Promise(function() {
throw new Error("Mismatched relays for number " + number);
});
} }
}
return Promise.all(deviceObjectList.map(function(device) {
return textsecure.protocol_wrapper.encryptMessageFor(device, message).then(function(encryptedMsg) { return textsecure.protocol_wrapper.encryptMessageFor(device, message).then(function(encryptedMsg) {
return textsecure.protocol_wrapper.getRegistrationId(device.encodedNumber).then(function(registrationId) { return textsecure.protocol_wrapper.getRegistrationId(device.encodedNumber).then(function(registrationId) {
return textsecure.storage.devices.removeTempKeysFromDevice(device.encodedNumber).then(function() { return textsecure.storage.devices.removeTempKeysFromDevice(device.encodedNumber).then(function() {