2019-02-03 20:35:58 -08:00
|
|
|
import * as Queue from 'bee-queue';
|
|
|
|
import config from '../config';
|
2018-04-04 07:12:35 -07:00
|
|
|
import http from './processors/http';
|
2018-05-07 02:20:15 -07:00
|
|
|
import { ILocalUser } from '../models/user';
|
2019-02-03 01:16:57 -08:00
|
|
|
import Logger from '../misc/logger';
|
2019-02-03 20:37:50 -08:00
|
|
|
import { program } from '../argv';
|
2018-04-04 07:12:35 -07:00
|
|
|
|
2019-02-03 20:37:50 -08:00
|
|
|
const enableQueue = config.redis != null && !program.disableQueue;
|
2019-02-03 20:35:58 -08:00
|
|
|
|
2019-02-03 23:41:53 -08:00
|
|
|
const queue = initializeQueue();
|
|
|
|
|
|
|
|
function initializeQueue() {
|
|
|
|
if (enableQueue) {
|
|
|
|
return new Queue('misskey', {
|
|
|
|
redis: {
|
|
|
|
port: config.redis.port,
|
|
|
|
host: config.redis.host,
|
|
|
|
password: config.redis.pass
|
|
|
|
},
|
|
|
|
|
|
|
|
removeOnSuccess: true,
|
|
|
|
removeOnFailure: true,
|
|
|
|
getEvents: false,
|
|
|
|
sendEvents: false,
|
|
|
|
storeJobs: false
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2019-02-03 20:35:58 -08:00
|
|
|
|
2018-07-25 16:11:47 -07:00
|
|
|
export function createHttpJob(data: any) {
|
2019-02-03 20:35:58 -08:00
|
|
|
if (enableQueue) {
|
|
|
|
return queue.createJob(data)
|
|
|
|
.retries(4)
|
|
|
|
.backoff('exponential', 16384) // 16s
|
|
|
|
.save();
|
|
|
|
} else {
|
|
|
|
return http({ data }, () => {});
|
|
|
|
}
|
2018-04-04 07:12:35 -07:00
|
|
|
}
|
|
|
|
|
2018-06-17 22:28:43 -07:00
|
|
|
export function deliver(user: ILocalUser, content: any, to: any) {
|
2018-11-15 12:47:29 -08:00
|
|
|
if (content == null) return;
|
|
|
|
|
2018-07-25 16:11:47 -07:00
|
|
|
createHttpJob({
|
2018-04-05 07:24:51 -07:00
|
|
|
type: 'deliver',
|
|
|
|
user,
|
|
|
|
content,
|
|
|
|
to
|
2018-07-25 16:11:47 -07:00
|
|
|
});
|
2018-04-05 07:24:51 -07:00
|
|
|
}
|
2019-02-03 01:16:57 -08:00
|
|
|
|
|
|
|
export const queueLogger = new Logger('queue');
|
2019-02-03 20:35:58 -08:00
|
|
|
|
|
|
|
export default function() {
|
|
|
|
if (enableQueue) {
|
|
|
|
queue.process(128, http);
|
|
|
|
}
|
|
|
|
}
|