ジョブの数を一覧できるように

This commit is contained in:
syuilo 2019-03-08 13:03:38 +09:00
parent 4ebaf529eb
commit f82fffeb58
3 changed files with 59 additions and 3 deletions

View file

@ -2,6 +2,34 @@
<div> <div>
<ui-card> <ui-card>
<template #title>{{ $t('operation') }}</template> <template #title>{{ $t('operation') }}</template>
<section>
<header>Deliver</header>
<ui-horizon-group inputs v-if="stats">
<ui-input :value="stats.deliver.waiting | number" type="text" readonly>
<span>Waiting</span>
</ui-input>
<ui-input :value="stats.deliver.active | number" type="text" readonly>
<span>Active</span>
</ui-input>
<ui-input :value="stats.deliver.delayed | number" type="text" readonly>
<span>Delayed</span>
</ui-input>
</ui-horizon-group>
</section>
<section>
<header>Inbox</header>
<ui-horizon-group inputs v-if="stats">
<ui-input :value="stats.inbox.waiting | number" type="text" readonly>
<span>Waiting</span>
</ui-input>
<ui-input :value="stats.inbox.active | number" type="text" readonly>
<span>Active</span>
</ui-input>
<ui-input :value="stats.inbox.delayed | number" type="text" readonly>
<span>Delayed</span>
</ui-input>
</ui-horizon-group>
</section>
<section> <section>
<ui-button @click="removeAllJobs">{{ $t('remove-all-jobs') }}</ui-button> <ui-button @click="removeAllJobs">{{ $t('remove-all-jobs') }}</ui-button>
</section> </section>
@ -18,9 +46,16 @@ export default Vue.extend({
data() { data() {
return { return {
stats: null
}; };
}, },
created() {
this.$root.api('admin/queue/stats').then(stats => {
this.stats = stats;
});
},
methods: { methods: {
async removeAllJobs() { async removeAllJobs() {
const process = async () => { const process = async () => {

View file

@ -21,9 +21,9 @@ function initializeQueue(name: string) {
} : null); } : null);
} }
const deliverQueue = initializeQueue('deliver'); export const deliverQueue = initializeQueue('deliver');
const inboxQueue = initializeQueue('inbox'); export const inboxQueue = initializeQueue('inbox');
const dbQueue = initializeQueue('db'); export const dbQueue = initializeQueue('db');
export function deliver(user: ILocalUser, content: any, to: any) { export function deliver(user: ILocalUser, content: any, to: any) {
if (content == null) return null; if (content == null) return null;

View file

@ -0,0 +1,21 @@
import define from '../../../define';
import { deliverQueue } from '../../../../../queue';
export const meta = {
tags: ['admin'],
requireCredential: true,
requireModerator: true,
params: {}
};
export default define(meta, async (ps) => {
const deliverJobCounts = await deliverQueue.getJobCounts();
const inboxJobCounts = await deliverQueue.getJobCounts();
return {
deliver: deliverJobCounts,
inbox: inboxJobCounts
};
});