summaryrefslogtreecommitdiff
path: root/packages/backend/src
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src')
-rw-r--r--packages/backend/src/server/api/endpoints/admin/queue/promote.ts24
1 files changed, 22 insertions, 2 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
index 9140f392cd..8330d6c82f 100644
--- a/packages/backend/src/server/api/endpoints/admin/queue/promote.ts
+++ b/packages/backend/src/server/api/endpoints/admin/queue/promote.ts
@@ -33,7 +33,17 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
delayedQueues = await this.queueService.deliverQueue.getDelayed();
for (let queueIndex = 0; queueIndex < delayedQueues.length; queueIndex++) {
const queue = delayedQueues[queueIndex];
- await queue.promote();
+ try {
+ await queue.promote();
+ } catch (e) {
+ if (e instanceof Error) {
+ if (e.message.indexOf('not in a delayed state') !== -1) {
+ throw e;
+ }
+ } else {
+ throw e;
+ }
+ }
}
break;
@@ -41,7 +51,17 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
delayedQueues = await this.queueService.inboxQueue.getDelayed();
for (let queueIndex = 0; queueIndex < delayedQueues.length; queueIndex++) {
const queue = delayedQueues[queueIndex];
- await queue.promote();
+ try {
+ await queue.promote();
+ } catch (e) {
+ if (e instanceof Error) {
+ if (e.message.indexOf('not in a delayed state') !== -1) {
+ throw e;
+ }
+ } else {
+ throw e;
+ }
+ }
}
break;
}