diff options
| author | CyberRex <hspwinx86@gmail.com> | 2023-03-22 08:58:23 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-03-22 08:58:23 +0900 |
| commit | 7331de0bcef74bde0789259830f98be2b063de57 (patch) | |
| tree | de7fd2a258b716f1bc37cd051b5503f445b00c16 /packages/backend/src/server/api/endpoints/admin/queue | |
| parent | New Crowdin updates (#10369) (diff) | |
| download | sharkey-7331de0bcef74bde0789259830f98be2b063de57.tar.gz sharkey-7331de0bcef74bde0789259830f98be2b063de57.tar.bz2 sharkey-7331de0bcef74bde0789259830f98be2b063de57.zip | |
feat: queue force promote (#10370)
* feat: queue force promote
* Update CHANGELOG.md
* small fix
Diffstat (limited to 'packages/backend/src/server/api/endpoints/admin/queue')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/admin/queue/promote.ts | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/admin/queue/promote.ts b/packages/backend/src/server/api/endpoints/admin/queue/promote.ts new file mode 100644 index 0000000000..4e57e6613e --- /dev/null +++ b/packages/backend/src/server/api/endpoints/admin/queue/promote.ts @@ -0,0 +1,52 @@ +import { Injectable } from '@nestjs/common'; +import { Endpoint } from '@/server/api/endpoint-base.js'; +import { ModerationLogService } from '@/core/ModerationLogService.js'; +import { QueueService } from '@/core/QueueService.js'; + +export const meta = { + tags: ['admin'], + + requireCredential: true, + requireModerator: true, +} as const; + +export const paramDef = { + type: 'object', + properties: { + type: { type: 'string', enum: ['deliver', 'inbox'] }, + }, + required: ['type'], +} as const; + +// eslint-disable-next-line import/no-default-export +@Injectable() +export default class extends Endpoint<typeof meta, typeof paramDef> { + constructor( + private moderationLogService: ModerationLogService, + private queueService: QueueService, + ) { + super(meta, paramDef, async (ps, me) => { + let delayedQueues; + + switch (ps.type) { + case 'deliver': + delayedQueues = await this.queueService.deliverQueue.getDelayed(); + for (let queueIndex = 0; queueIndex < delayedQueues.length; queueIndex++) { + const queue = delayedQueues[queueIndex]; + await queue.promote(); + } + break; + + case 'inbox': + delayedQueues = await this.queueService.inboxQueue.getDelayed(); + for (let queueIndex = 0; queueIndex < delayedQueues.length; queueIndex++) { + const queue = delayedQueues[queueIndex]; + await queue.promote(); + } + break; + } + + this.moderationLogService.insertModerationLog(me, 'promoteQueue'); + }); + } +} |