|
@ -7,6 +7,8 @@ var multi_caching = function (caches) { |
|
|
var self = {}; |
|
|
var self = {}; |
|
|
if (!Array.isArray(caches)) { throw new Error('multi_caching requires an array of caches'); } |
|
|
if (!Array.isArray(caches)) { throw new Error('multi_caching requires an array of caches'); } |
|
|
|
|
|
|
|
|
|
|
|
self.queues = {}; |
|
|
|
|
|
|
|
|
function get_from_highest_priority_cache(key, cb) { |
|
|
function get_from_highest_priority_cache(key, cb) { |
|
|
var i = 0; |
|
|
var i = 0; |
|
|
async.forEachSeries(caches, function (cache, async_cb) { |
|
|
async.forEachSeries(caches, function (cache, async_cb) { |
|
@ -41,21 +43,38 @@ var multi_caching = function (caches) { |
|
|
*/ |
|
|
*/ |
|
|
self.wrap = function (key, work, cb) { |
|
|
self.wrap = function (key, work, cb) { |
|
|
get_from_highest_priority_cache(key, function (err, result, index) { |
|
|
get_from_highest_priority_cache(key, function (err, result, index) { |
|
|
if (err) { return cb(err); } |
|
|
if (err) { |
|
|
if (result) { |
|
|
return cb(err); |
|
|
|
|
|
} else if (result) { |
|
|
var caches_to_update = caches.slice(0, index); |
|
|
var caches_to_update = caches.slice(0, index); |
|
|
set_in_multiple_caches(caches_to_update, key, result, function (err) { |
|
|
set_in_multiple_caches(caches_to_update, key, result, function (err) { |
|
|
cb(err, result); |
|
|
cb(err, result); |
|
|
}); |
|
|
}); |
|
|
|
|
|
} else if (self.queues[key]) { |
|
|
|
|
|
self.queues[key].push(cb); |
|
|
} else { |
|
|
} else { |
|
|
|
|
|
self.queues[key] = [cb]; |
|
|
work(function () { |
|
|
work(function () { |
|
|
var work_args = Array.prototype.slice.call(arguments, 0); |
|
|
var work_args = Array.prototype.slice.call(arguments, 0); |
|
|
if (work_args[0]) { // assume first arg is an error
|
|
|
if (work_args[0]) { // assume first arg is an error
|
|
|
return cb(work_args[0]); |
|
|
self.queues[key].forEach(function (done) { |
|
|
|
|
|
done.call(null, work_args[0]); |
|
|
|
|
|
}); |
|
|
|
|
|
delete self.queues[key]; |
|
|
|
|
|
return; |
|
|
} |
|
|
} |
|
|
set_in_multiple_caches(caches, key, work_args[1], function (err) { |
|
|
set_in_multiple_caches(caches, key, work_args[1], function (err) { |
|
|
if (err) { return cb(err); } |
|
|
if (err) { |
|
|
cb.apply(null, work_args); |
|
|
self.queues[key].forEach(function (done) { |
|
|
|
|
|
done.call(null, err); |
|
|
|
|
|
}); |
|
|
|
|
|
delete self.queues[key]; |
|
|
|
|
|
return; |
|
|
|
|
|
} |
|
|
|
|
|
self.queues[key].forEach(function (done) { |
|
|
|
|
|
done.apply(null, work_args); |
|
|
|
|
|
}); |
|
|
|
|
|
delete self.queues[key]; |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|