Sharkey/src/queue/index.ts

53 lines
1.2 KiB
TypeScript
Raw Normal View History

2018-04-04 07:12:35 -07:00
import { createQueue } from 'kue';
2018-04-05 02:43:06 -07:00
2018-04-04 07:12:35 -07:00
import config from '../config';
import http from './processors/http';
2018-05-07 02:20:15 -07:00
import { ILocalUser } from '../models/user';
2018-04-04 07:12:35 -07:00
const queue = createQueue({
redis: {
port: config.redis.port,
host: config.redis.host,
auth: config.redis.pass
}
});
2018-07-25 13:27:27 -07:00
process.once('SIGTERM', () => {
queue.shutdown(5000, (err: any) => {
console.log('Kue shutdown: ', err || '');
process.exit(0);
});
});
2018-06-17 22:28:43 -07:00
export function createHttp(data: any) {
2018-04-04 07:12:35 -07:00
return queue
.create('http', data)
2018-04-21 15:50:09 -07:00
.removeOnComplete(true)
2018-04-18 16:28:24 -07:00
.events(false)
.attempts(8)
2018-04-04 07:12:35 -07:00
.backoff({ delay: 16384, type: 'exponential' });
}
2018-06-17 22:28:43 -07:00
export function deliver(user: ILocalUser, content: any, to: any) {
2018-04-15 01:53:25 -07:00
createHttp({
2018-04-21 15:34:33 -07:00
title: 'deliver',
2018-04-05 07:24:51 -07:00
type: 'deliver',
user,
content,
to
2018-04-21 15:50:09 -07:00
}).save();
2018-04-05 07:24:51 -07:00
}
2018-04-05 02:43:06 -07:00
export default function() {
2018-04-04 07:12:35 -07:00
/*
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);
queue.process('http', 128, http);
2018-04-04 07:12:35 -07:00
}