Adds perf metrics for each tRPC endpoint
parent
2ba8f99302
commit
87befdbdf4
|
@ -1,3 +1,5 @@
|
|||
import { performance } from "@calcom/lib/server/perfObserver";
|
||||
|
||||
import * as trpc from "@trpc/server";
|
||||
|
||||
import { Context } from "./createContext";
|
||||
|
@ -6,7 +8,13 @@ import { Context } from "./createContext";
|
|||
* Helper function to create a router with context
|
||||
*/
|
||||
export function createRouter() {
|
||||
return trpc.router<Context>();
|
||||
return trpc.router<Context>().middleware(async ({ path, type, next }) => {
|
||||
performance.mark("Start");
|
||||
const result = await next();
|
||||
performance.mark("End");
|
||||
performance.measure(`[${result.ok ? "OK" : "ERROR"}][$1] ${type} '${path}'`, "Start", "End");
|
||||
return result;
|
||||
});
|
||||
}
|
||||
|
||||
export function createProtectedRouter() {
|
||||
|
|
|
@ -8,9 +8,11 @@ type Handle<T> = (req: NextApiRequest, res: NextApiResponse) => Promise<T>;
|
|||
/** Allows us to get type inference from API handler responses */
|
||||
function defaultResponder<T>(f: Handle<T>) {
|
||||
return async (req: NextApiRequest, res: NextApiResponse) => {
|
||||
let ok = false;
|
||||
try {
|
||||
performance.mark("Start");
|
||||
const result = await f(req, res);
|
||||
ok = true;
|
||||
if (result) res.json(result);
|
||||
} catch (err) {
|
||||
const error = getServerErrorFromUnkown(err);
|
||||
|
@ -18,7 +20,7 @@ function defaultResponder<T>(f: Handle<T>) {
|
|||
res.json({ message: error.message });
|
||||
} finally {
|
||||
performance.mark("End");
|
||||
performance.measure("Measuring endpoint: " + req.url, "Start", "End");
|
||||
performance.measure(`[${ok ? "OK" : "ERROR"}][$1] ${req.method} '${req.url}'`, "Start", "End");
|
||||
}
|
||||
};
|
||||
}
|
||||
|
|
|
@ -8,7 +8,8 @@ export const perfObserver =
|
|||
globalThis.perfObserver ||
|
||||
new PerformanceObserver((items) => {
|
||||
items.getEntries().forEach((entry) => {
|
||||
console.log(entry); // fake call to our custom logging solution
|
||||
// Log entry duration in seconds with four decimal places.
|
||||
console.log(entry.name.replace("$1", `${(entry.duration / 1000.0).toFixed(4)}s`));
|
||||
});
|
||||
});
|
||||
|
||||
|
|
Loading…
Reference in New Issue