|
|
@ -1,4 +1,6 @@ |
|
|
|
/*jshint maxcomplexity:15*/ |
|
|
|
var domain = require('domain'); |
|
|
|
|
|
|
|
var caching = function (args) { |
|
|
|
args = args || {}; |
|
|
|
var self = {}; |
|
|
@ -40,38 +42,43 @@ var caching = function (args) { |
|
|
|
ttl = undefined; |
|
|
|
} |
|
|
|
|
|
|
|
if (self.queues[key]) { |
|
|
|
self.queues[key].push({cb: cb, domain: process.domain}); |
|
|
|
return; |
|
|
|
} |
|
|
|
|
|
|
|
self.queues[key] = [{cb: cb, domain: process.domain}]; |
|
|
|
|
|
|
|
function fillCallbacks(err, data) { |
|
|
|
self.queues[key].forEach(function(task) { |
|
|
|
var taskDomain = task.domain || domain.create(); |
|
|
|
taskDomain.bind(task.cb)(err, data); |
|
|
|
}); |
|
|
|
delete self.queues[key]; |
|
|
|
} |
|
|
|
|
|
|
|
self.store.get(key, function (err, result) { |
|
|
|
if (err && (!self.ignoreCacheErrors)) { |
|
|
|
cb(err); |
|
|
|
fillCallbacks(err); |
|
|
|
} else if (result) { |
|
|
|
cb.call(cb, null, result); |
|
|
|
} else if (self.queues[key]) { |
|
|
|
self.queues[key].push(cb); |
|
|
|
fillCallbacks(null, result); |
|
|
|
} else { |
|
|
|
self.queues[key] = [cb]; |
|
|
|
|
|
|
|
work(function () { |
|
|
|
var work_args = Array.prototype.slice.call(arguments, 0); |
|
|
|
if (work_args[0]) { // assume first arg is an error
|
|
|
|
self.queues[key].forEach(function (done) { |
|
|
|
done.call(null, work_args[0]); |
|
|
|
}); |
|
|
|
delete self.queues[key]; |
|
|
|
domain |
|
|
|
.create() |
|
|
|
.on('error', function(err) { |
|
|
|
fillCallbacks(err); |
|
|
|
}) |
|
|
|
.bind(work)(function (err, data) { |
|
|
|
if (err) { |
|
|
|
fillCallbacks(err); |
|
|
|
return; |
|
|
|
} |
|
|
|
// Subsequently assume second arg is result.
|
|
|
|
self.store.set(key, work_args[1], ttl, function (err) { |
|
|
|
self.store.set(key, data, ttl, function (err) { |
|
|
|
if (err && (!self.ignoreCacheErrors)) { |
|
|
|
self.queues[key].forEach(function (done) { |
|
|
|
done.call(null, err); |
|
|
|
}); |
|
|
|
fillCallbacks(err); |
|
|
|
} else { |
|
|
|
self.queues[key].forEach(function (done) { |
|
|
|
done.apply(null, work_args); |
|
|
|
}); |
|
|
|
fillCallbacks(null, data); |
|
|
|
} |
|
|
|
|
|
|
|
delete self.queues[key]; |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|