nocobase/packages/core/utils/src/perf-hooks.ts
jack zhang 62b2b5c68b
chore: add copyright information to the file header (#4028)
* 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>
2024-04-30 15:51:31 +08:00

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));
};
};