CartoDB-SQL-API/lib/batch/pubsub/job-subscriber.js

55 lines
1.6 KiB
JavaScript
Raw Normal View History

'use strict';
2016-10-12 00:41:59 +08:00
var Channel = require('./channel');
2016-10-12 00:28:46 +08:00
var debug = require('./../util/debug')('pubsub:subscriber');
var error = require('./../util/debug')('pubsub:subscriber:error');
2019-12-24 01:19:08 +08:00
function JobSubscriber (pool) {
this.pool = pool;
}
module.exports = JobSubscriber;
JobSubscriber.prototype.subscribe = function (onJobHandler, callback) {
var self = this;
self.pool.acquire(Channel.DB)
.then(client => {
self.client = client;
client.removeAllListeners('message');
client.unsubscribe(Channel.NAME);
client.subscribe(Channel.NAME);
client.on('message', function (channel, user) {
debug('message received in channel=%s from user=%s', channel, user);
onJobHandler(user);
});
client.on('error', function () {
self.unsubscribe();
self.pool.release(Channel.DB, client)
.catch(err => error('Error releasing redis client: ' + err.message));
self.subscribe(onJobHandler);
});
if (callback) {
callback();
}
})
.catch(err => {
error('Error adquiring redis client: ' + err.message);
if (callback) {
return callback(err);
}
});
};
JobSubscriber.prototype.unsubscribe = function (callback) {
if (this.client && this.client.connected) {
this.client.unsubscribe(Channel.NAME, callback);
} else {
if (callback) {
return callback(null);
}
}
};