signal-desktop/libtextsecure/task_with_timeout.js

71 lines
1.8 KiB
JavaScript
Raw Normal View History

2018-05-02 16:51:22 +00:00
(function() {
window.textsecure = window.textsecure || {};
2018-05-02 16:51:22 +00:00
window.textsecure.createTaskWithTimeout = function(task, id, options) {
options = options || {};
options.timeout = options.timeout || 1000 * 60 * 2; // two minutes
2018-05-02 16:51:22 +00:00
var errorForStack = new Error('for stack');
return function() {
return new Promise(function(resolve, reject) {
var complete = false;
var timer = setTimeout(
function() {
if (!complete) {
var message =
(id || '') +
' task did not complete in time. Calling stack: ' +
errorForStack.stack;
window.log.error(message);
2018-05-02 16:51:22 +00:00
return reject(new Error(message));
}
}.bind(this),
options.timeout
);
var clearTimer = function() {
try {
var localTimer = timer;
if (localTimer) {
timer = null;
clearTimeout(localTimer);
}
} catch (error) {
window.log.error(
2018-05-02 16:51:22 +00:00
id || '',
'task ran into problem canceling timer. Calling stack:',
errorForStack.stack
);
}
};
2018-05-02 16:51:22 +00:00
var success = function(result) {
clearTimer();
complete = true;
return resolve(result);
};
var failure = function(error) {
clearTimer();
complete = true;
return reject(error);
};
2018-05-02 16:51:22 +00:00
var promise;
try {
promise = task();
} catch (error) {
clearTimer();
throw error;
}
if (!promise || !promise.then) {
clearTimer();
complete = true;
return resolve(promise);
}
2018-05-02 16:51:22 +00:00
return promise.then(success, failure);
});
};
2018-05-02 16:51:22 +00:00
};
})();