mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-06 22:19:25 +08:00
* fix: add license code * fix: bug * fix: bug * fix: upgrade * fix: improve * chore: add copyright information to the file header * fix: d.ts bug * fix: bug * fix: e2e bug * fix: merge main --------- Co-authored-by: chenos <chenlinxh@gmail.com>
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
/**
|
|
* This file is part of the NocoBase (R) project.
|
|
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
* Authors: NocoBase Team.
|
|
*
|
|
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
*/
|
|
|
|
import { RecordableHistogram, performance } from 'perf_hooks';
|
|
|
|
export const prePerfHooksWrap = (handler: any, options?: { name?: string }) => {
|
|
const { name } = options || {};
|
|
return async (ctx: any, next: any) => {
|
|
if (!ctx.getPerfHistogram) {
|
|
return await handler(ctx, next);
|
|
}
|
|
const histogram = ctx.getPerfHistogram(name || handler) as RecordableHistogram;
|
|
const start = performance.now();
|
|
await handler(ctx, async () => {
|
|
const duration = performance.now() - start;
|
|
histogram.record(Math.ceil(duration * 1e6));
|
|
await next();
|
|
});
|
|
};
|
|
};
|
|
|
|
export const postPerfHooksWrap = (handler: any, options: { name?: string }) => {
|
|
const { name } = options || {};
|
|
return async (ctx: any, next: any) => {
|
|
if (!ctx.getPerfHistogram) {
|
|
return await handler(ctx, next);
|
|
}
|
|
await next();
|
|
const histogram = ctx.getPerfHistogram(name || handler) as RecordableHistogram;
|
|
const start = performance.now();
|
|
await handler(ctx, async () => {});
|
|
const duration = performance.now() - start;
|
|
histogram.record(Math.ceil(duration * 1e6));
|
|
};
|
|
};
|