misskey/src/queue/index.ts

165 lines
3.3 KiB
TypeScript
Raw Normal View History

2019-02-04 13:35:58 +09:00
import * as Queue from 'bee-queue';
2019-02-06 15:01:43 +09:00
import * as httpSignature from 'http-signature';
2019-02-06 15:01:43 +09:00
import config from '../config';
2018-05-07 18:20:15 +09:00
import { ILocalUser } from '../models/user';
2019-02-04 13:37:50 +09:00
import { program } from '../argv';
import handler from './processors';
import { queueLogger } from './logger';
2018-04-04 23:12:35 +09:00
const enableQueue = !program.disableQueue;
const enableQueueProcessing = !program.onlyServer && enableQueue;
const queueAvailable = config.redis != null;
2019-02-04 13:35:58 +09:00
const queue = initializeQueue();
function initializeQueue() {
if (queueAvailable && 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-04 13:35:58 +09:00
2019-02-06 15:01:43 +09:00
export function deliver(user: ILocalUser, content: any, to: any) {
if (content == null) return;
const data = {
type: 'deliver',
user,
content,
to
};
if (queueAvailable && enableQueueProcessing) {
2019-02-04 13:35:58 +09:00
return queue.createJob(data)
2019-02-06 15:01:43 +09:00
.retries(8)
2019-02-06 14:53:02 +09:00
.backoff('exponential', 1000)
2019-02-04 13:35:58 +09:00
.save();
} else {
return handler({ data }, () => {});
2019-02-04 13:35:58 +09:00
}
2018-04-04 23:12:35 +09:00
}
2019-02-06 15:01:43 +09:00
export function processInbox(activity: any, signature: httpSignature.IParsedSignature) {
const data = {
type: 'processInbox',
activity: activity,
signature
};
if (queueAvailable && enableQueueProcessing) {
2019-02-06 15:01:43 +09:00
return queue.createJob(data)
.retries(3)
.backoff('exponential', 500)
.save();
} else {
return handler({ data }, () => {});
}
2018-04-05 23:24:51 +09:00
}
2019-02-21 01:30:21 +09:00
export function createDeleteNotesJob(user: ILocalUser) {
const data = {
type: 'deleteNotes',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
}
export function createDeleteDriveFilesJob(user: ILocalUser) {
const data = {
type: 'deleteDriveFiles',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
}
export function createExportNotesJob(user: ILocalUser) {
const data = {
type: 'exportNotes',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
}
2019-02-04 13:35:58 +09:00
2019-02-06 21:21:49 +09:00
export function createExportFollowingJob(user: ILocalUser) {
const data = {
2019-02-06 21:21:49 +09:00
type: 'exportFollowing',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
2019-02-06 21:21:49 +09:00
}
export function createExportMuteJob(user: ILocalUser) {
const data = {
2019-02-06 21:21:49 +09:00
type: 'exportMute',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
2019-02-06 21:21:49 +09:00
}
export function createExportBlockingJob(user: ILocalUser) {
const data = {
2019-02-06 21:21:49 +09:00
type: 'exportBlocking',
user: user
};
if (queueAvailable && enableQueueProcessing) {
return queue.createJob(data).save();
} else {
return handler({ data }, () => {});
}
2019-02-06 21:21:49 +09:00
}
2019-02-04 13:35:58 +09:00
export default function() {
if (queueAvailable && enableQueueProcessing) {
queue.process(128, handler);
queueLogger.succ('Processing started');
2019-02-04 13:35:58 +09:00
}
return queue;
2019-02-04 13:35:58 +09:00
}
2019-02-06 15:24:59 +09:00
export function destroy() {
queue.destroy().then(n => {
queueLogger.succ(`All job removed (${n} jobs)`);
});
}