2022-07-15 17:01:51 +08:00
|
|
|
import { Logs } from '@logto/schemas';
|
2022-05-16 14:43:33 +08:00
|
|
|
import { object, string } from 'zod';
|
|
|
|
|
|
|
|
import koaGuard from '@/middleware/koa-guard';
|
|
|
|
import koaPagination from '@/middleware/koa-pagination';
|
2022-05-25 14:59:02 +08:00
|
|
|
import { countLogs, findLogById, findLogs } from '@/queries/log';
|
2022-05-16 14:43:33 +08:00
|
|
|
|
2022-10-21 13:14:17 +08:00
|
|
|
import type { AuthedRouter } from './types';
|
2022-05-16 14:43:33 +08:00
|
|
|
|
|
|
|
export default function logRoutes<T extends AuthedRouter>(router: T) {
|
|
|
|
router.get(
|
|
|
|
'/logs',
|
|
|
|
koaPagination(),
|
|
|
|
koaGuard({
|
|
|
|
query: object({
|
|
|
|
userId: string().optional(),
|
|
|
|
applicationId: string().optional(),
|
|
|
|
logType: string().optional(),
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
async (ctx, next) => {
|
|
|
|
const { limit, offset } = ctx.pagination;
|
|
|
|
const {
|
|
|
|
query: { userId, applicationId, logType },
|
|
|
|
} = ctx.guard;
|
|
|
|
|
|
|
|
const [{ count }, logs] = await Promise.all([
|
|
|
|
countLogs({ logType, applicationId, userId }),
|
|
|
|
findLogs(limit, offset, { logType, userId, applicationId }),
|
|
|
|
]);
|
|
|
|
|
|
|
|
// Return totalCount to pagination middleware
|
|
|
|
ctx.pagination.totalCount = count;
|
|
|
|
ctx.body = logs;
|
|
|
|
|
|
|
|
return next();
|
|
|
|
}
|
|
|
|
);
|
2022-05-25 14:59:02 +08:00
|
|
|
|
|
|
|
router.get(
|
|
|
|
'/logs/:id',
|
2022-07-15 17:01:51 +08:00
|
|
|
koaGuard({ params: object({ id: string().min(1) }), response: Logs.guard }),
|
2022-05-25 14:59:02 +08:00
|
|
|
async (ctx, next) => {
|
|
|
|
const {
|
|
|
|
params: { id },
|
|
|
|
} = ctx.guard;
|
|
|
|
|
|
|
|
ctx.body = await findLogById(id);
|
|
|
|
|
|
|
|
return next();
|
|
|
|
}
|
|
|
|
);
|
2022-05-16 14:43:33 +08:00
|
|
|
}
|