2018-04-04 09:12:35 -05:00
|
|
|
import { createQueue } from 'kue';
|
2018-04-05 04:43:06 -05:00
|
|
|
|
2018-04-04 09:12:35 -05:00
|
|
|
import config from '../config';
|
|
|
|
import db from './processors/db';
|
|
|
|
import http from './processors/http';
|
|
|
|
|
|
|
|
const queue = createQueue({
|
|
|
|
redis: {
|
|
|
|
port: config.redis.port,
|
|
|
|
host: config.redis.host,
|
|
|
|
auth: config.redis.pass
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
export function createHttp(data) {
|
|
|
|
return queue
|
|
|
|
.create('http', data)
|
|
|
|
.attempts(16)
|
|
|
|
.backoff({ delay: 16384, type: 'exponential' });
|
|
|
|
}
|
|
|
|
|
|
|
|
export function createDb(data) {
|
|
|
|
return queue.create('db', data);
|
|
|
|
}
|
|
|
|
|
2018-04-05 09:24:51 -05:00
|
|
|
export function deliver(user, content, to) {
|
|
|
|
return createHttp({
|
|
|
|
type: 'deliver',
|
|
|
|
user,
|
|
|
|
content,
|
|
|
|
to
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-04-05 04:43:06 -05:00
|
|
|
export default function() {
|
2018-04-04 09:12:35 -05:00
|
|
|
queue.process('db', db);
|
|
|
|
|
|
|
|
/*
|
|
|
|
256 is the default concurrency limit of Mozilla Firefox and Google
|
|
|
|
Chromium.
|
|
|
|
a8af215e691f3a2205a3758d2d96e9d328e100ff - chromium/src.git - Git at Google
|
|
|
|
https://chromium.googlesource.com/chromium/src.git/+/a8af215e691f3a2205a3758d2d96e9d328e100ff
|
|
|
|
Network.http.max-connections - MozillaZine Knowledge Base
|
|
|
|
http://kb.mozillazine.org/Network.http.max-connections
|
|
|
|
*/
|
|
|
|
queue.process('http', 256, http);
|
|
|
|
}
|