Async getSessionsForNumber
This commit is contained in:
parent
9e7d8c0a08
commit
666f6baaca
4 changed files with 33 additions and 31 deletions
|
@ -172,9 +172,7 @@
|
||||||
getSession: function(identifier) {
|
getSession: function(identifier) {
|
||||||
if (identifier === null || identifier === undefined)
|
if (identifier === null || identifier === undefined)
|
||||||
throw new Error("Tried to get session for undefined/null key");
|
throw new Error("Tried to get session for undefined/null key");
|
||||||
return new Promise(function(resolve) {
|
return textsecure.storage.sessions.getSessionsForNumber(identifier);
|
||||||
resolve(textsecure.storage.sessions.getSessionsForNumber(identifier));
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
putSession: function(identifier, record) {
|
putSession: function(identifier, record) {
|
||||||
if (identifier === null || identifier === undefined)
|
if (identifier === null || identifier === undefined)
|
||||||
|
|
|
@ -38096,16 +38096,18 @@ axolotlInternal.RecipientRecord = function() {
|
||||||
|
|
||||||
window.textsecure.storage.sessions = {
|
window.textsecure.storage.sessions = {
|
||||||
getSessionsForNumber: function(encodedNumber) {
|
getSessionsForNumber: function(encodedNumber) {
|
||||||
var number = textsecure.utils.unencodeNumber(encodedNumber)[0];
|
return Promise.resolve((function() {
|
||||||
var deviceId = textsecure.utils.unencodeNumber(encodedNumber)[1];
|
var number = textsecure.utils.unencodeNumber(encodedNumber)[0];
|
||||||
|
var deviceId = textsecure.utils.unencodeNumber(encodedNumber)[1];
|
||||||
|
|
||||||
var sessions = textsecure.storage.get("sessions" + number);
|
var sessions = textsecure.storage.get("sessions" + number);
|
||||||
if (sessions === undefined)
|
if (sessions === undefined)
|
||||||
return undefined;
|
return undefined;
|
||||||
if (sessions[deviceId] === undefined)
|
if (sessions[deviceId] === undefined)
|
||||||
return undefined;
|
return undefined;
|
||||||
|
|
||||||
return sessions[deviceId];
|
return sessions[deviceId];
|
||||||
|
})());
|
||||||
},
|
},
|
||||||
|
|
||||||
putSessionsForDevice: function(encodedNumber, record) {
|
putSessionsForDevice: function(encodedNumber, record) {
|
||||||
|
@ -39807,12 +39809,12 @@ window.textsecure.messaging = function() {
|
||||||
var getDevicesAndSendToNumber = function(number) {
|
var getDevicesAndSendToNumber = function(number) {
|
||||||
var devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
var devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
||||||
|
|
||||||
var promises = [];
|
return Promise.all(devicesForNumber.map(function(device) {
|
||||||
for (var j in devicesForNumber)
|
return textsecure.protocol_wrapper.hasOpenSession(device.encodedNumber).then(function(result) {
|
||||||
if (!textsecure.protocol_wrapper.hasOpenSession(devicesForNumber[j].encodedNumber))
|
if (!result)
|
||||||
promises[promises.length] = getKeysForNumber(number, [parseInt(textsecure.utils.unencodeNumber(devicesForNumber[j].encodedNumber)[1])]);
|
return getKeysForNumber(number, [parseInt(textsecure.utils.unencodeNumber(device.encodedNumber)[1])]);
|
||||||
|
});
|
||||||
Promise.all(promises).then(function() {
|
})).then(function() {
|
||||||
devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
||||||
|
|
||||||
if (devicesForNumber.length == 0) {
|
if (devicesForNumber.length == 0) {
|
||||||
|
|
|
@ -210,12 +210,12 @@ window.textsecure.messaging = function() {
|
||||||
var getDevicesAndSendToNumber = function(number) {
|
var getDevicesAndSendToNumber = function(number) {
|
||||||
var devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
var devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
||||||
|
|
||||||
var promises = [];
|
return Promise.all(devicesForNumber.map(function(device) {
|
||||||
for (var j in devicesForNumber)
|
return textsecure.protocol_wrapper.hasOpenSession(device.encodedNumber).then(function(result) {
|
||||||
if (!textsecure.protocol_wrapper.hasOpenSession(devicesForNumber[j].encodedNumber))
|
if (!result)
|
||||||
promises[promises.length] = getKeysForNumber(number, [parseInt(textsecure.utils.unencodeNumber(devicesForNumber[j].encodedNumber)[1])]);
|
return getKeysForNumber(number, [parseInt(textsecure.utils.unencodeNumber(device.encodedNumber)[1])]);
|
||||||
|
});
|
||||||
Promise.all(promises).then(function() {
|
})).then(function() {
|
||||||
devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
devicesForNumber = textsecure.storage.devices.getDeviceObjectsForNumber(number);
|
||||||
|
|
||||||
if (devicesForNumber.length == 0) {
|
if (devicesForNumber.length == 0) {
|
||||||
|
|
|
@ -25,16 +25,18 @@
|
||||||
|
|
||||||
window.textsecure.storage.sessions = {
|
window.textsecure.storage.sessions = {
|
||||||
getSessionsForNumber: function(encodedNumber) {
|
getSessionsForNumber: function(encodedNumber) {
|
||||||
var number = textsecure.utils.unencodeNumber(encodedNumber)[0];
|
return Promise.resolve((function() {
|
||||||
var deviceId = textsecure.utils.unencodeNumber(encodedNumber)[1];
|
var number = textsecure.utils.unencodeNumber(encodedNumber)[0];
|
||||||
|
var deviceId = textsecure.utils.unencodeNumber(encodedNumber)[1];
|
||||||
|
|
||||||
var sessions = textsecure.storage.get("sessions" + number);
|
var sessions = textsecure.storage.get("sessions" + number);
|
||||||
if (sessions === undefined)
|
if (sessions === undefined)
|
||||||
return undefined;
|
return undefined;
|
||||||
if (sessions[deviceId] === undefined)
|
if (sessions[deviceId] === undefined)
|
||||||
return undefined;
|
return undefined;
|
||||||
|
|
||||||
return sessions[deviceId];
|
return sessions[deviceId];
|
||||||
|
})());
|
||||||
},
|
},
|
||||||
|
|
||||||
putSessionsForDevice: function(encodedNumber, record) {
|
putSessionsForDevice: function(encodedNumber, record) {
|
||||||
|
|
Loading…
Reference in a new issue