evlog 2.19.0 → 2.19.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (166) hide show
  1. package/README.md +14 -16
  2. package/dist/adapters/axiom.d.mts +3 -3
  3. package/dist/adapters/axiom.d.mts.map +1 -1
  4. package/dist/adapters/axiom.mjs +10 -14
  5. package/dist/adapters/axiom.mjs.map +1 -1
  6. package/dist/adapters/better-stack.d.mts +2 -2
  7. package/dist/adapters/better-stack.d.mts.map +1 -1
  8. package/dist/adapters/better-stack.mjs +9 -13
  9. package/dist/adapters/better-stack.mjs.map +1 -1
  10. package/dist/adapters/datadog.d.mts +3 -3
  11. package/dist/adapters/datadog.mjs +9 -5
  12. package/dist/adapters/datadog.mjs.map +1 -1
  13. package/dist/adapters/fs.d.mts +1 -1
  14. package/dist/adapters/fs.d.mts.map +1 -1
  15. package/dist/adapters/fs.mjs +14 -1
  16. package/dist/adapters/fs.mjs.map +1 -1
  17. package/dist/adapters/hyperdx.d.mts +2 -2
  18. package/dist/adapters/hyperdx.mjs +3 -3
  19. package/dist/adapters/hyperdx.mjs.map +1 -1
  20. package/dist/adapters/memory.d.mts +2 -3
  21. package/dist/adapters/memory.d.mts.map +1 -1
  22. package/dist/adapters/memory.mjs +2 -3
  23. package/dist/adapters/memory.mjs.map +1 -1
  24. package/dist/adapters/otlp.d.mts +4 -4
  25. package/dist/adapters/otlp.mjs +17 -9
  26. package/dist/adapters/otlp.mjs.map +1 -1
  27. package/dist/adapters/posthog.d.mts +2 -2
  28. package/dist/adapters/posthog.mjs +5 -5
  29. package/dist/adapters/posthog.mjs.map +1 -1
  30. package/dist/adapters/sentry.d.mts +3 -3
  31. package/dist/adapters/sentry.mjs +5 -5
  32. package/dist/adapters/sentry.mjs.map +1 -1
  33. package/dist/ai/index.d.mts +1 -1
  34. package/dist/{audit-BFwTUxBJ.mjs → audit-BQt8yAHo.mjs} +28 -24
  35. package/dist/audit-BQt8yAHo.mjs.map +1 -0
  36. package/dist/{audit-BUAajsPU.d.mts → audit-D7v6JHj0.d.mts} +8 -1
  37. package/dist/audit-D7v6JHj0.d.mts.map +1 -0
  38. package/dist/better-auth/index.d.mts +1 -1
  39. package/dist/browser.d.mts +1 -1
  40. package/dist/deferred-drain-jeajC8QF.mjs +36 -0
  41. package/dist/deferred-drain-jeajC8QF.mjs.map +1 -0
  42. package/dist/{define-DGwZkZ7x.d.mts → define-DTQpu4f6.d.mts} +3 -3
  43. package/dist/{define-DGwZkZ7x.d.mts.map → define-DTQpu4f6.d.mts.map} +1 -1
  44. package/dist/{drain-D_fy7m0n.mjs → drain-fDb-eNwz.mjs} +34 -3
  45. package/dist/drain-fDb-eNwz.mjs.map +1 -0
  46. package/dist/elysia/index.d.mts +2 -2
  47. package/dist/elysia/index.mjs +2 -2
  48. package/dist/enrich-error-stack-next.node-Dgm_rCf5.mjs +120 -0
  49. package/dist/enrich-error-stack-next.node-Dgm_rCf5.mjs.map +1 -0
  50. package/dist/{enricher-CuMbbdqp.d.mts → enricher-CBRmQw6e.d.mts} +2 -2
  51. package/dist/{enricher-CuMbbdqp.d.mts.map → enricher-CBRmQw6e.d.mts.map} +1 -1
  52. package/dist/enrichers.d.mts +2 -2
  53. package/dist/{error-DwajXSKM.d.mts → error-CpghjrkY.d.mts} +2 -2
  54. package/dist/{error-DwajXSKM.d.mts.map → error-CpghjrkY.d.mts.map} +1 -1
  55. package/dist/error.d.mts +1 -1
  56. package/dist/{errors-CAq8pYpW.d.mts → errors-BLU4Tfpe.d.mts} +2 -2
  57. package/dist/{errors-CAq8pYpW.d.mts.map → errors-BLU4Tfpe.d.mts.map} +1 -1
  58. package/dist/express/index.d.mts +2 -2
  59. package/dist/express/index.mjs +1 -1
  60. package/dist/fastify/index.d.mts +2 -2
  61. package/dist/fastify/index.mjs +1 -1
  62. package/dist/{fork-CYm453dq.mjs → fork-CgGlAaHa.mjs} +2 -2
  63. package/dist/{fork-CYm453dq.mjs.map → fork-CgGlAaHa.mjs.map} +1 -1
  64. package/dist/hono/index.d.mts +2 -2
  65. package/dist/hono/index.mjs +1 -1
  66. package/dist/{http-Bept5EIC.mjs → http-ChVS9GYc.mjs} +2 -2
  67. package/dist/{http-Bept5EIC.mjs.map → http-ChVS9GYc.mjs.map} +1 -1
  68. package/dist/http.d.mts +1 -1
  69. package/dist/{index-CE7kH0II.d.mts → index-EvnrXvQM.d.mts} +3 -3
  70. package/dist/{index-CE7kH0II.d.mts.map → index-EvnrXvQM.d.mts.map} +1 -1
  71. package/dist/index.d.mts +8 -8
  72. package/dist/index.mjs +1 -1
  73. package/dist/instrumentation-create-BrjQtSKD.d.mts +115 -0
  74. package/dist/instrumentation-create-BrjQtSKD.d.mts.map +1 -0
  75. package/dist/{integration-CR601uyW.mjs → integration-DYp2uw8O.mjs} +2 -2
  76. package/dist/{integration-CR601uyW.mjs.map → integration-DYp2uw8O.mjs.map} +1 -1
  77. package/dist/{logger-BccCJUyD.d.mts → logger-mHIWxBhJ.d.mts} +7 -3
  78. package/dist/logger-mHIWxBhJ.d.mts.map +1 -0
  79. package/dist/logger.d.mts +2 -2
  80. package/dist/logger.mjs +1 -1
  81. package/dist/{middleware-DQ6-h8h0.d.mts → middleware-B_k4Mrzg.d.mts} +2 -2
  82. package/dist/{middleware-DQ6-h8h0.d.mts.map → middleware-B_k4Mrzg.d.mts.map} +1 -1
  83. package/dist/nestjs/index.d.mts +2 -2
  84. package/dist/nestjs/index.mjs +1 -1
  85. package/dist/next/client.d.mts +1 -1
  86. package/dist/next/index.d.mts +4 -4
  87. package/dist/next/index.d.mts.map +1 -1
  88. package/dist/next/index.mjs +16 -3
  89. package/dist/next/index.mjs.map +1 -1
  90. package/dist/next/instrumentation/create.d.mts +2 -0
  91. package/dist/next/instrumentation/create.mjs +155 -0
  92. package/dist/next/instrumentation/create.mjs.map +1 -0
  93. package/dist/next/instrumentation.d.mts +2 -77
  94. package/dist/next/instrumentation.mjs +32 -81
  95. package/dist/next/instrumentation.mjs.map +1 -1
  96. package/dist/next/stream.d.mts +1 -1
  97. package/dist/next/stream.mjs +2 -2
  98. package/dist/next/stream.mjs.map +1 -1
  99. package/dist/nitro/errorHandler.mjs +15 -4
  100. package/dist/nitro/errorHandler.mjs.map +1 -1
  101. package/dist/nitro/module.d.mts +2 -2
  102. package/dist/nitro/plugin.mjs +89 -4
  103. package/dist/nitro/plugin.mjs.map +1 -1
  104. package/dist/nitro/v3/index.d.mts +2 -2
  105. package/dist/nitro/v3/module.d.mts +1 -1
  106. package/dist/nitro/v3/plugin.mjs +4 -4
  107. package/dist/nitro/v3/plugin.mjs.map +1 -1
  108. package/dist/nitro/v3/useLogger.d.mts +1 -1
  109. package/dist/{nitro-zCXTylj4.d.mts → nitro-_Hda8Deo.d.mts} +2 -2
  110. package/dist/{nitro-zCXTylj4.d.mts.map → nitro-_Hda8Deo.d.mts.map} +1 -1
  111. package/dist/nuxt/module.d.mts +1 -1
  112. package/dist/nuxt/module.mjs +2 -2
  113. package/dist/orpc/index.d.mts +2 -2
  114. package/dist/orpc/index.mjs +1 -1
  115. package/dist/{package-CUhII9DA.mjs → package-CNV_CXs8.mjs} +2 -2
  116. package/dist/package-CNV_CXs8.mjs.map +1 -0
  117. package/dist/{parseError-Cagr-Ctc.d.mts → parseError-BeBXEd2V.d.mts} +2 -2
  118. package/dist/parseError-BeBXEd2V.d.mts.map +1 -0
  119. package/dist/pipeline.d.mts +0 -19
  120. package/dist/pipeline.d.mts.map +1 -1
  121. package/dist/pipeline.mjs +12 -0
  122. package/dist/pipeline.mjs.map +1 -1
  123. package/dist/{pretty-error-CVVgwlTn.mjs → pretty-error-THg0U0w9.mjs} +37 -27
  124. package/dist/pretty-error-THg0U0w9.mjs.map +1 -0
  125. package/dist/{pretty-error-snippet.node-c_bzjg7g.mjs → pretty-error-snippet.node-itfCajBM.mjs} +3 -2
  126. package/dist/{pretty-error-snippet.node-c_bzjg7g.mjs.map → pretty-error-snippet.node-itfCajBM.mjs.map} +1 -1
  127. package/dist/react-router/index.d.mts +2 -2
  128. package/dist/react-router/index.mjs +1 -1
  129. package/dist/runtime/client/log.d.mts +1 -1
  130. package/dist/runtime/server/routes/_evlog/ingest.post.d.mts +7 -0
  131. package/dist/runtime/server/routes/_evlog/ingest.post.mjs +39 -3
  132. package/dist/runtime/server/routes/_evlog/ingest.post.mjs.map +1 -1
  133. package/dist/runtime/server/useLogger.d.mts +1 -1
  134. package/dist/runtime/utils/parseError.d.mts +2 -2
  135. package/dist/{source-location-xkDGiERl.mjs → source-location-CHOPF2nd.mjs} +2 -1
  136. package/dist/{source-location-xkDGiERl.mjs.map → source-location-CHOPF2nd.mjs.map} +1 -1
  137. package/dist/stream.d.mts +1 -1
  138. package/dist/stream.mjs +1 -1
  139. package/dist/sveltekit/index.d.mts +2 -2
  140. package/dist/sveltekit/index.mjs +1 -1
  141. package/dist/toolkit.d.mts +20 -6
  142. package/dist/toolkit.d.mts.map +1 -1
  143. package/dist/toolkit.mjs +6 -6
  144. package/dist/types.d.mts +1 -1
  145. package/dist/{useLogger-Dv52PDpH.d.mts → useLogger-Cfv8Ck8b.d.mts} +2 -2
  146. package/dist/{useLogger-Dv52PDpH.d.mts.map → useLogger-Cfv8Ck8b.d.mts.map} +1 -1
  147. package/dist/{utils-DmNbZwBZ.d.mts → utils-CJJG0ZYW.d.mts} +2 -2
  148. package/dist/{utils-DmNbZwBZ.d.mts.map → utils-CJJG0ZYW.d.mts.map} +1 -1
  149. package/dist/utils.d.mts +1 -1
  150. package/dist/utils.mjs +2 -1
  151. package/dist/utils.mjs.map +1 -1
  152. package/dist/vite/index.d.mts +1 -1
  153. package/dist/vite/index.mjs +1 -1
  154. package/dist/workers.d.mts +1 -1
  155. package/dist/workers.mjs +1 -1
  156. package/package.json +12 -1
  157. package/dist/audit-BFwTUxBJ.mjs.map +0 -1
  158. package/dist/audit-BUAajsPU.d.mts.map +0 -1
  159. package/dist/drain-D_fy7m0n.mjs.map +0 -1
  160. package/dist/enrich-drain-CG_2Nix-.mjs +0 -122
  161. package/dist/enrich-drain-CG_2Nix-.mjs.map +0 -1
  162. package/dist/logger-BccCJUyD.d.mts.map +0 -1
  163. package/dist/next/instrumentation.d.mts.map +0 -1
  164. package/dist/package-CUhII9DA.mjs.map +0 -1
  165. package/dist/parseError-Cagr-Ctc.d.mts.map +0 -1
  166. package/dist/pretty-error-CVVgwlTn.mjs.map +0 -1
@@ -1,5 +1,5 @@
1
1
  import { t as getNitroRuntimeConfigRecord } from "./nitroConfigBridge-BkVWnSV3.mjs";
2
- import { r as httpPost } from "./http-Bept5EIC.mjs";
2
+ import { r as httpPost } from "./http-ChVS9GYc.mjs";
3
3
  //#region src/shared/config.ts
4
4
  /** Read the full Nitro `useRuntimeConfig()` record (or `undefined` outside Nitro). */
5
5
  function getRuntimeConfig() {
@@ -21,6 +21,37 @@ async function resolveAdapterConfig(namespace, fields, overrides) {
21
21
  for (const { key, env } of fields) config[key] = overrides?.[key] ?? evlogNs?.[key] ?? rootNs?.[key] ?? resolveEnv(env);
22
22
  return config;
23
23
  }
24
+ /**
25
+ * Format environment variable names for user-facing messages.
26
+ * Drops internal `NUXT_*` aliases; joins alternatives with `, ` and fields with `/`.
27
+ */
28
+ function formatPublicEnvKeys(...envLists) {
29
+ return envLists.map((list) => {
30
+ const all = (list ?? []).filter((k) => !!k);
31
+ const publicKeys = all.filter((k) => !k.startsWith("NUXT_"));
32
+ return [...new Set(publicKeys.length > 0 ? publicKeys : all)].join(", ");
33
+ }).filter((part) => part.length > 0).join("/");
34
+ }
35
+ const warnedDeprecatedAliases = /* @__PURE__ */ new Set();
36
+ /**
37
+ * Copy a deprecated config field onto its replacement when the replacement is
38
+ * unset, warning once per adapter/field pair.
39
+ */
40
+ function applyDeprecatedAlias(config, opts) {
41
+ const record = config;
42
+ if (record[opts.to] === void 0 || record[opts.to] === null) {
43
+ const fromValue = record[opts.from];
44
+ if (fromValue !== void 0 && fromValue !== null) {
45
+ const warnKey = `${opts.adapter}:${opts.from}`;
46
+ if (!warnedDeprecatedAliases.has(warnKey)) {
47
+ warnedDeprecatedAliases.add(warnKey);
48
+ console.warn(`[evlog/${opts.adapter}] \`${opts.from}\` is deprecated, use \`${opts.to}\` instead.`);
49
+ }
50
+ record[opts.to] = fromValue;
51
+ }
52
+ }
53
+ return config;
54
+ }
24
55
  function shouldProbeRuntimeConfig(fields, overrides) {
25
56
  return fields.some(({ key, env }) => {
26
57
  if (overrides?.[key] !== void 0) return false;
@@ -112,6 +143,6 @@ function defineHttpDrain(options) {
112
143
  });
113
144
  }
114
145
  //#endregion
115
- export { resolveAdapterConfig as i, defineHttpDrain as n, getRuntimeConfig as r, defineDrain as t };
146
+ export { getRuntimeConfig as a, formatPublicEnvKeys as i, defineHttpDrain as n, resolveAdapterConfig as o, applyDeprecatedAlias as r, defineDrain as t };
116
147
 
117
- //# sourceMappingURL=drain-D_fy7m0n.mjs.map
148
+ //# sourceMappingURL=drain-fDb-eNwz.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drain-fDb-eNwz.mjs","names":[],"sources":["../src/shared/config.ts","../src/shared/drain.ts"],"sourcesContent":["import { getNitroRuntimeConfigRecord } from './nitroConfigBridge'\n\n/** Read the full Nitro `useRuntimeConfig()` record (or `undefined` outside Nitro). */\nexport function getRuntimeConfig(): Promise<Record<string, any> | undefined> {\n return getNitroRuntimeConfigRecord()\n}\n\n/**\n * Description of a single adapter config field. `env` is the ordered list of\n * environment variables to fall back to, e.g. `['NUXT_AXIOM_API_KEY', 'AXIOM_API_KEY']`.\n */\nexport interface ConfigField<T> {\n key: keyof T & string\n env?: string[]\n}\n\n/**\n * Resolve adapter configuration with the standard priority chain:\n *\n * 1. `overrides` passed to the drain factory\n * 2. `runtimeConfig.evlog.{namespace}.{key}` (Nitro)\n * 3. `runtimeConfig.{namespace}.{key}` (Nitro)\n * 4. `process.env[envKey]` for each env in `field.env`\n */\nexport async function resolveAdapterConfig<T>(\n namespace: string,\n fields: ConfigField<T>[],\n overrides?: Partial<T>,\n): Promise<Partial<T>> {\n const runtimeConfig = shouldProbeRuntimeConfig(fields, overrides)\n ? await getRuntimeConfig()\n : undefined\n const evlogNs = runtimeConfig?.evlog?.[namespace]\n const rootNs = runtimeConfig?.[namespace]\n\n const config: Record<string, unknown> = {}\n\n for (const { key, env } of fields) {\n config[key] =\n overrides?.[key]\n ?? evlogNs?.[key]\n ?? rootNs?.[key]\n ?? resolveEnv(env)\n }\n\n return config as Partial<T>\n}\n\n/**\n * Format environment variable names for user-facing messages.\n * Drops internal `NUXT_*` aliases; joins alternatives with `, ` and fields with `/`.\n */\nexport function formatPublicEnvKeys(...envLists: (string[] | undefined)[]): string {\n return envLists\n .map((list) => {\n const all = (list ?? []).filter((k): k is string => !!k)\n const publicKeys = all.filter(k => !k.startsWith('NUXT_'))\n const keys = [...new Set(publicKeys.length > 0 ? publicKeys : all)]\n return keys.join(', ')\n })\n .filter(part => part.length > 0)\n .join('/')\n}\n\nconst warnedDeprecatedAliases = new Set<string>()\n\n/**\n * Copy a deprecated config field onto its replacement when the replacement is\n * unset, warning once per adapter/field pair.\n */\nexport function applyDeprecatedAlias<T extends object>(\n config: T,\n opts: {\n adapter: string\n from: keyof T & string\n to: keyof T & string\n },\n): T {\n const record = config as Record<string, unknown>\n if (record[opts.to] === undefined || record[opts.to] === null) {\n const fromValue = record[opts.from]\n if (fromValue !== undefined && fromValue !== null) {\n const warnKey = `${opts.adapter}:${opts.from}`\n if (!warnedDeprecatedAliases.has(warnKey)) {\n warnedDeprecatedAliases.add(warnKey)\n console.warn(`[evlog/${opts.adapter}] \\`${opts.from}\\` is deprecated, use \\`${opts.to}\\` instead.`)\n }\n record[opts.to] = fromValue\n }\n }\n return config\n}\n\n// Avoid the Nitro virtual-module import when env/overrides already resolve\n// every env-backed field — optional tuning fields (timeout, retries) should\n// not trigger a runtime probe in non-Nitro runtimes.\nfunction shouldProbeRuntimeConfig<T>(\n fields: ConfigField<T>[],\n overrides?: Partial<T>,\n): boolean {\n return fields.some(({ key, env }) => {\n if (overrides?.[key] !== undefined) return false\n if (!env) return false\n return resolveEnv(env) === undefined\n })\n}\n\nfunction resolveEnv(envKeys?: string[]): string | undefined {\n if (!envKeys) return undefined\n for (const key of envKeys) {\n const val = process.env[key]\n if (val) return val\n }\n return undefined\n}\n","import type { DrainContext, WideEvent } from '../types'\nimport { httpPost } from './http'\n\n/**\n * Drain definition backed by an arbitrary `send` function. Use this for\n * non-HTTP transports (filesystem, in-memory queue, native SDK). For HTTP\n * backends, use `defineHttpDrain` instead.\n */\nexport interface DrainOptions<TConfig> {\n /** Stable identifier used in error logs. */\n name: string\n /** Return `null` to skip draining (e.g. missing API key in dev). */\n resolve: () => TConfig | null | Promise<TConfig | null>\n send: (events: WideEvent[], config: TConfig) => Promise<void>\n}\n\n/**\n * Build a drain callback. Errors raised by `send` are logged with the drain\n * name and swallowed, so a failing drain never breaks the request pipeline.\n *\n * @example\n * ```ts\n * export function createMyDrain(overrides?: Partial<MyConfig>) {\n * return defineDrain<MyConfig>({\n * name: 'my-drain',\n * resolve: () => ({ url: process.env.MY_URL ?? null }),\n * send: async (events, config) => { ... },\n * })\n * }\n * ```\n */\nexport function defineDrain<TConfig>(options: DrainOptions<TConfig>): (ctx: DrainContext | DrainContext[]) => Promise<void> {\n return async (ctx: DrainContext | DrainContext[]) => {\n const contexts = Array.isArray(ctx) ? ctx : [ctx]\n if (contexts.length === 0) return\n\n const config = await options.resolve()\n if (!config) return\n\n try {\n await options.send(contexts.map(c => c.event), config)\n } catch (error) {\n console.error(`[evlog/${options.name}] Failed to send events:`, error)\n }\n }\n}\n\nexport interface HttpDrainRequest {\n url: string\n /** Caller is responsible for `Content-Type`. */\n headers: Record<string, string>\n body: string\n}\n\n/** Adapters only need to ship config + `encode()` — no manual `fetch`. */\nexport interface HttpDrainOptions<TConfig> {\n /** Stable identifier used in error logs. */\n name: string\n /** Return `null` to skip draining (e.g. missing API key in dev). */\n resolve: () => TConfig | null | Promise<TConfig | null>\n /** Return `null` to skip the batch without raising. */\n encode: (events: WideEvent[], config: TConfig) => HttpDrainRequest | null\n /** @default 5000 */\n timeout?: number\n /** @default 2 */\n retries?: number\n /** Read the timeout off the resolved config (falls back to `timeout`). */\n resolveTimeout?: (config: TConfig) => number | undefined\n /** Read the retry count off the resolved config (falls back to `retries`). */\n resolveRetries?: (config: TConfig) => number | undefined\n}\n\nconst DEFAULT_HTTP_TIMEOUT = 5000\n\n/**\n * Build an HTTP drain. Timeouts/retries are resolved from the config (with\n * overrides via `resolveTimeout` / `resolveRetries`) and forwarded to\n * {@link httpPost}.\n *\n * @example\n * ```ts\n * export function createMyDrain(overrides?: Partial<MyConfig>) {\n * return defineHttpDrain<MyConfig>({\n * name: 'my',\n * resolve: async () => {\n * const cfg = await resolveAdapterConfig<MyConfig>('my', FIELDS, overrides)\n * return cfg.apiKey ? cfg as MyConfig : null\n * },\n * encode: (events, config) => ({\n * url: `${config.endpoint ?? 'https://api.my.com'}/ingest`,\n * headers: { 'Content-Type': 'application/json', Authorization: `Bearer ${config.apiKey}` },\n * body: JSON.stringify(events),\n * }),\n * })\n * }\n * ```\n */\nexport function defineHttpDrain<TConfig>(options: HttpDrainOptions<TConfig>): (ctx: DrainContext | DrainContext[]) => Promise<void> {\n return defineDrain<TConfig>({\n name: options.name,\n resolve: options.resolve,\n send: async (events, config) => {\n if (events.length === 0) return\n const request = options.encode(events, config)\n if (!request) return\n const timeout = options.resolveTimeout?.(config)\n ?? (config as { timeout?: number }).timeout\n ?? options.timeout\n ?? DEFAULT_HTTP_TIMEOUT\n const retries = options.resolveRetries?.(config)\n ?? (config as { retries?: number }).retries\n ?? options.retries\n await httpPost({\n url: request.url,\n headers: request.headers,\n body: request.body,\n timeout,\n retries,\n label: options.name,\n source: options.name,\n })\n },\n })\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { rt as RequestLogger } from "../audit-BUAajsPU.mjs";
2
- import { t as BaseEvlogOptions } from "../middleware-DQ6-h8h0.mjs";
1
+ import { rt as RequestLogger } from "../audit-D7v6JHj0.mjs";
2
+ import { t as BaseEvlogOptions } from "../middleware-B_k4Mrzg.mjs";
3
3
  import { Elysia } from "elysia";
4
4
 
5
5
  //#region src/elysia/index.d.ts
@@ -1,5 +1,5 @@
1
- import { t as attachForkToLogger } from "../fork-CYm453dq.mjs";
2
- import { t as defineFrameworkIntegration } from "../integration-CR601uyW.mjs";
1
+ import { t as attachForkToLogger } from "../fork-CgGlAaHa.mjs";
2
+ import { t as defineFrameworkIntegration } from "../integration-DYp2uw8O.mjs";
3
3
  import { AsyncLocalStorage } from "node:async_hooks";
4
4
  import { Elysia } from "elysia";
5
5
  //#region src/elysia/index.ts
@@ -0,0 +1,120 @@
1
+ import { a as isFrameworkRuntimePath } from "./pretty-error-THg0U0w9.mjs";
2
+ import { createRequire } from "node:module";
3
+ import { isAbsolute, relative } from "node:path";
4
+ import { fileURLToPath, pathToFileURL } from "node:url";
5
+ import { existsSync, readFileSync } from "node:fs";
6
+ //#region src/shared/enrich-error-stack-next.node.ts
7
+ const require = createRequire(import.meta.url);
8
+ function formatMappedFrame(methodName, sourceURL, line1, column1) {
9
+ let sourceLocation = line1 !== null ? `:${line1}` : "";
10
+ if (column1 !== null && sourceLocation !== "") sourceLocation += `:${column1}`;
11
+ let fileLocation;
12
+ if (sourceURL !== null && sourceURL.startsWith("file://") && URL.canParse(sourceURL)) fileLocation = relative(process.cwd(), fileURLToPath(sourceURL));
13
+ else if (sourceURL !== null && sourceURL.startsWith("/")) fileLocation = relative(process.cwd(), sourceURL);
14
+ else fileLocation = sourceURL ?? "unknown";
15
+ return methodName ? ` at ${methodName} (${fileLocation}${sourceLocation})` : ` at ${fileLocation}${sourceLocation}`;
16
+ }
17
+ function shouldSkipMappedSource(source) {
18
+ const normalized = source.replace(/\\/g, "/");
19
+ return normalized.includes("node_modules") || normalized.includes("/packages/evlog/") || isFrameworkRuntimePath(normalized);
20
+ }
21
+ function resolveFrameFile(frame) {
22
+ if (!frame.file) return null;
23
+ if (frame.file.startsWith("file://")) try {
24
+ return fileURLToPath(frame.file);
25
+ } catch {
26
+ return frame.file;
27
+ }
28
+ if (isAbsolute(frame.file)) return frame.file;
29
+ return null;
30
+ }
31
+ function getSourceMapConsumer(frameFile, cache) {
32
+ const cached = cache.get(frameFile);
33
+ if (cached !== void 0) return cached;
34
+ const mapPath = `${frameFile}.map`;
35
+ if (!existsSync(mapPath)) {
36
+ cache.set(frameFile, null);
37
+ return null;
38
+ }
39
+ try {
40
+ const sourceMapModule = require("next/dist/compiled/source-map");
41
+ const payload = JSON.parse(readFileSync(mapPath, "utf8"));
42
+ const chunkUrl = pathToFileURL(frameFile).href;
43
+ const consumer = new sourceMapModule.SourceMapConsumer(payload, `${chunkUrl}.map`);
44
+ cache.set(frameFile, consumer);
45
+ return consumer;
46
+ } catch {
47
+ cache.set(frameFile, null);
48
+ return null;
49
+ }
50
+ }
51
+ function mapFrame(frame, cache) {
52
+ if (frame.file?.startsWith("node:")) return {
53
+ frame,
54
+ skipped: true
55
+ };
56
+ const frameFile = resolveFrameFile(frame);
57
+ if (!frameFile || frame.line1 === null) return {
58
+ frame,
59
+ skipped: false
60
+ };
61
+ const consumer = getSourceMapConsumer(frameFile, cache);
62
+ if (!consumer) {
63
+ if (frameFile.includes(".next/")) return {
64
+ frame,
65
+ skipped: true
66
+ };
67
+ return {
68
+ frame,
69
+ skipped: false
70
+ };
71
+ }
72
+ const sourcePosition = consumer.originalPositionFor({
73
+ line: frame.line1,
74
+ column: (frame.column1 ?? 1) - 1
75
+ });
76
+ if (!sourcePosition.source || sourcePosition.line === null) return {
77
+ frame,
78
+ skipped: frameFile.includes(".next/")
79
+ };
80
+ if (shouldSkipMappedSource(sourcePosition.source)) return {
81
+ frame,
82
+ skipped: true
83
+ };
84
+ return {
85
+ frame: {
86
+ ...frame,
87
+ file: sourcePosition.source,
88
+ line1: sourcePosition.line,
89
+ column1: sourcePosition.column === null ? null : sourcePosition.column + 1,
90
+ methodName: sourcePosition.name ?? frame.methodName
91
+ },
92
+ skipped: false
93
+ };
94
+ }
95
+ /**
96
+ * Rewrite `error.stack` with Turbopack/Webpack source-mapped frames in Next.js dev.
97
+ * Reads sibling `.map` files for `.next` chunks (same resolution as the dev overlay).
98
+ */
99
+ function enrichErrorStackFromNextDev(error) {
100
+ if (process.env.NODE_ENV === "production") return;
101
+ if (!error.stack) return;
102
+ try {
103
+ const { parseStack } = require("next/dist/server/lib/parse-stack");
104
+ const frames = parseStack(error.stack);
105
+ if (frames.length === 0) return;
106
+ const cache = /* @__PURE__ */ new Map();
107
+ const mappedLines = [];
108
+ for (const frame of frames) {
109
+ const { frame: mapped, skipped } = mapFrame(frame, cache);
110
+ if (skipped) continue;
111
+ mappedLines.push(formatMappedFrame(mapped.methodName, mapped.file, mapped.line1, mapped.column1));
112
+ }
113
+ if (mappedLines.length === 0) return;
114
+ error.stack = `${error.name || "Error"}: ${error.message}\n${mappedLines.join("\n")}`;
115
+ } catch {}
116
+ }
117
+ //#endregion
118
+ export { enrichErrorStackFromNextDev };
119
+
120
+ //# sourceMappingURL=enrich-error-stack-next.node-Dgm_rCf5.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enrich-error-stack-next.node-Dgm_rCf5.mjs","names":[],"sources":["../src/shared/enrich-error-stack-next.node.ts"],"sourcesContent":["import { existsSync, readFileSync } from 'node:fs'\nimport { createRequire } from 'node:module'\nimport { isAbsolute, relative } from 'node:path'\nimport { pathToFileURL, fileURLToPath } from 'node:url'\nimport { isFrameworkRuntimePath } from './pretty-error'\n\n/** Parsed stack frame from Next.js `parseStack`. */\ninterface NextParsedFrame {\n file: string | null\n line1: number | null\n column1: number | null\n methodName: string | null\n arguments: string[]\n}\n\ntype SourceMapConsumerInstance = {\n originalPositionFor: (pos: { line: number, column: number }) => {\n source: string | null\n line: number | null\n column: number | null\n name: string | null\n }\n}\n\nconst require = createRequire(import.meta.url)\n\nfunction formatMappedFrame(\n methodName: string | null,\n sourceURL: string | null,\n line1: number | null,\n column1: number | null,\n): string {\n let sourceLocation = line1 !== null ? `:${line1}` : ''\n if (column1 !== null && sourceLocation !== '') {\n sourceLocation += `:${column1}`\n }\n\n let fileLocation: string\n if (sourceURL !== null && sourceURL.startsWith('file://') && URL.canParse(sourceURL)) {\n fileLocation = relative(process.cwd(), fileURLToPath(sourceURL))\n } else if (sourceURL !== null && sourceURL.startsWith('/')) {\n fileLocation = relative(process.cwd(), sourceURL)\n } else {\n fileLocation = sourceURL ?? 'unknown'\n }\n\n return methodName\n ? ` at ${methodName} (${fileLocation}${sourceLocation})`\n : ` at ${fileLocation}${sourceLocation}`\n}\n\nfunction shouldSkipMappedSource(source: string): boolean {\n const normalized = source.replace(/\\\\/g, '/')\n return normalized.includes('node_modules')\n || normalized.includes('/packages/evlog/')\n || isFrameworkRuntimePath(normalized)\n}\n\nfunction resolveFrameFile(frame: NextParsedFrame): string | null {\n if (!frame.file) return null\n if (frame.file.startsWith('file://')) {\n try {\n return fileURLToPath(frame.file)\n } catch {\n return frame.file\n }\n }\n if (isAbsolute(frame.file)) return frame.file\n return null\n}\n\nfunction getSourceMapConsumer(\n frameFile: string,\n cache: Map<string, SourceMapConsumerInstance | null>,\n): SourceMapConsumerInstance | null {\n const cached = cache.get(frameFile)\n if (cached !== undefined) return cached\n\n const mapPath = `${frameFile}.map`\n if (!existsSync(mapPath)) {\n cache.set(frameFile, null)\n return null\n }\n\n try {\n const sourceMapModule = require('next/dist/compiled/source-map') as {\n SourceMapConsumer: new(payload: unknown, sourceMapURL: string) => SourceMapConsumerInstance\n }\n const payload = JSON.parse(readFileSync(mapPath, 'utf8')) as unknown\n const chunkUrl = pathToFileURL(frameFile).href\n const consumer = new sourceMapModule.SourceMapConsumer(payload, `${chunkUrl}.map`)\n cache.set(frameFile, consumer)\n return consumer\n } catch {\n cache.set(frameFile, null)\n return null\n }\n}\n\nfunction mapFrame(\n frame: NextParsedFrame,\n cache: Map<string, SourceMapConsumerInstance | null>,\n): { frame: NextParsedFrame, skipped: boolean } {\n if (frame.file?.startsWith('node:')) {\n return { frame, skipped: true }\n }\n\n const frameFile = resolveFrameFile(frame)\n if (!frameFile || frame.line1 === null) {\n return { frame, skipped: false }\n }\n\n const consumer = getSourceMapConsumer(frameFile, cache)\n if (!consumer) {\n if (frameFile.includes('.next/')) {\n return { frame, skipped: true }\n }\n return { frame, skipped: false }\n }\n\n const sourcePosition = consumer.originalPositionFor({\n line: frame.line1,\n column: (frame.column1 ?? 1) - 1,\n })\n\n if (!sourcePosition.source || sourcePosition.line === null) {\n return { frame, skipped: frameFile.includes('.next/') }\n }\n\n if (shouldSkipMappedSource(sourcePosition.source)) {\n return { frame, skipped: true }\n }\n\n return {\n frame: {\n ...frame,\n file: sourcePosition.source,\n line1: sourcePosition.line,\n column1: sourcePosition.column === null ? null : sourcePosition.column + 1,\n methodName: sourcePosition.name ?? frame.methodName,\n },\n skipped: false,\n }\n}\n\n/**\n * Rewrite `error.stack` with Turbopack/Webpack source-mapped frames in Next.js dev.\n * Reads sibling `.map` files for `.next` chunks (same resolution as the dev overlay).\n */\nexport function enrichErrorStackFromNextDev(error: Error): void {\n if (process.env.NODE_ENV === 'production') return\n if (!error.stack) return\n\n try {\n const { parseStack } = require('next/dist/server/lib/parse-stack') as {\n parseStack: (stack: string, distDir?: string) => NextParsedFrame[]\n }\n\n const frames = parseStack(error.stack)\n if (frames.length === 0) return\n\n const cache = new Map<string, SourceMapConsumerInstance | null>()\n const mappedLines: string[] = []\n\n for (const frame of frames) {\n const { frame: mapped, skipped } = mapFrame(frame, cache)\n if (skipped) continue\n mappedLines.push(formatMappedFrame(mapped.methodName, mapped.file, mapped.line1, mapped.column1))\n }\n\n if (mappedLines.length === 0) return\n\n error.stack = `${error.name || 'Error'}: ${error.message}\\n${mappedLines.join('\\n')}`\n } catch {\n // Next internals unavailable — keep the original stack\n }\n}\n"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { V as EnrichContext, ft as WideEvent } from "./audit-BUAajsPU.mjs";
1
+ import { V as EnrichContext, ft as WideEvent } from "./audit-D7v6JHj0.mjs";
2
2
 
3
3
  //#region src/shared/enricher.d.ts
4
4
  interface EnricherOptions {
@@ -39,4 +39,4 @@ interface EnricherDefinition<T> {
39
39
  declare function defineEnricher<T>(def: EnricherDefinition<T>, options?: EnricherOptions): (ctx: EnrichContext) => void;
40
40
  //#endregion
41
41
  export { EnricherOptions as n, defineEnricher as r, EnricherDefinition as t };
42
- //# sourceMappingURL=enricher-CuMbbdqp.d.mts.map
42
+ //# sourceMappingURL=enricher-CBRmQw6e.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"enricher-CuMbbdqp.d.mts","names":[],"sources":["../src/shared/enricher.ts"],"mappings":";;;UAGiB,eAAA;;AAAjB;;;EAKE,SAAA;AAAA;AAAA,UAGe,kBAAA;EAAkB;EAEjC,IAAA;EAKc;;;;EAAd,KAAA,SAAc,SAAA;EAPoB;EASlC,OAAA,GAAU,GAAA,EAAK,aAAA,KAAkB,CAAA;AAAA;;;;;;;;AAoBnC;;;;;;;;;;iBAAgB,cAAA,GAAA,CACd,GAAA,EAAK,kBAAA,CAAmB,CAAA,GACxB,OAAA,GAAS,eAAA,IACP,GAAA,EAAK,aAAA"}
1
+ {"version":3,"file":"enricher-CBRmQw6e.d.mts","names":[],"sources":["../src/shared/enricher.ts"],"mappings":";;;UAGiB,eAAA;;AAAjB;;;EAKE,SAAA;AAAA;AAAA,UAGe,kBAAA;EAAkB;EAEjC,IAAA;EAKc;;;;EAAd,KAAA,SAAc,SAAA;EAPoB;EASlC,OAAA,GAAU,GAAA,EAAK,aAAA,KAAkB,CAAA;AAAA;;;;;;;;AAoBnC;;;;;;;;;;iBAAgB,cAAA,GAAA,CACd,GAAA,EAAK,kBAAA,CAAmB,CAAA,GACxB,OAAA,GAAS,eAAA,IACP,GAAA,EAAK,aAAA"}
@@ -1,5 +1,5 @@
1
- import { V as EnrichContext } from "./audit-BUAajsPU.mjs";
2
- import { n as EnricherOptions } from "./enricher-CuMbbdqp.mjs";
1
+ import { V as EnrichContext } from "./audit-D7v6JHj0.mjs";
2
+ import { n as EnricherOptions } from "./enricher-CBRmQw6e.mjs";
3
3
 
4
4
  //#region src/enrichers/index.d.ts
5
5
  interface UserAgentInfo {
@@ -1,4 +1,4 @@
1
- import { W as ErrorOptions } from "./audit-BUAajsPU.mjs";
1
+ import { W as ErrorOptions } from "./audit-D7v6JHj0.mjs";
2
2
 
3
3
  //#region src/error.d.ts
4
4
  /**
@@ -72,4 +72,4 @@ declare class EvlogError extends Error {
72
72
  declare function createError(options: ErrorOptions | string): EvlogError;
73
73
  //#endregion
74
74
  export { createError as n, EvlogError as t };
75
- //# sourceMappingURL=error-DwajXSKM.d.mts.map
75
+ //# sourceMappingURL=error-CpghjrkY.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"error-DwajXSKM.d.mts","names":[],"sources":["../src/error.ts"],"mappings":";;;;;AAsBA;;;;;;;;;;;;;;cAAa,UAAA,SAAmB,KAAA;EAc1B;EAAA,SAXK,IAAA;;WAEA,MAAA;EAAA,SACA,GAAA;EAAA,SACA,GAAA;EAAA,SACA,IAAA;EAgDL;;;;EAAA,IA1CA,QAAA,CAAA,GAAY,MAAA;cAIJ,OAAA,EAAS,YAAA;EAkDZ;EAAA,IAtBL,UAAA,CAAA;EA2DM;EAAA,IAtDN,UAAA,CAAA;EAsDY;EAAA,IAjDZ,aAAA,CAAA;EAsFqB;EAAA,IAjFrB,IAAA,CAAA;IAAU,IAAA;IAAe,GAAA;IAAc,GAAA;IAAc,IAAA;EAAA;EAOhD,QAAA,CAAA;EAqCT,MAAA,CAAA,GAAU,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;iBAqCI,WAAA,CAAY,OAAA,EAAS,YAAA,YAAwB,UAAA"}
1
+ {"version":3,"file":"error-CpghjrkY.d.mts","names":[],"sources":["../src/error.ts"],"mappings":";;;;;AAsBA;;;;;;;;;;;;;;cAAa,UAAA,SAAmB,KAAA;EAc1B;EAAA,SAXK,IAAA;;WAEA,MAAA;EAAA,SACA,GAAA;EAAA,SACA,GAAA;EAAA,SACA,IAAA;EAgDL;;;;EAAA,IA1CA,QAAA,CAAA,GAAY,MAAA;cAIJ,OAAA,EAAS,YAAA;EAkDZ;EAAA,IAtBL,UAAA,CAAA;EA2DM;EAAA,IAtDN,UAAA,CAAA;EAsDY;EAAA,IAjDZ,aAAA,CAAA;EAsFqB;EAAA,IAjFrB,IAAA,CAAA;IAAU,IAAA;IAAe,GAAA;IAAc,GAAA;IAAc,IAAA;EAAA;EAOhD,QAAA,CAAA;EAqCT,MAAA,CAAA,GAAU,MAAA;AAAA;;;;;;;;;;;;;;;;;;;;;;;iBAqCI,WAAA,CAAY,OAAA,EAAS,YAAA,YAAwB,UAAA"}
package/dist/error.d.mts CHANGED
@@ -1,2 +1,2 @@
1
- import { n as createError, t as EvlogError } from "./error-DwajXSKM.mjs";
1
+ import { n as createError, t as EvlogError } from "./error-CpghjrkY.mjs";
2
2
  export { EvlogError, createError, createError as createEvlogError };
@@ -1,4 +1,4 @@
1
- import { at as RouteConfig } from "./audit-BUAajsPU.mjs";
1
+ import { at as RouteConfig } from "./audit-D7v6JHj0.mjs";
2
2
 
3
3
  //#region src/shared/routes.d.ts
4
4
  declare function shouldLog(path: string, include?: string[], exclude?: string[]): boolean;
@@ -36,4 +36,4 @@ declare function getServiceForPath(path: string, routes?: Record<string, RouteCo
36
36
  declare function extractErrorStatus(error: unknown): number;
37
37
  //#endregion
38
38
  export { getServiceForPath as n, shouldLog as r, extractErrorStatus as t };
39
- //# sourceMappingURL=errors-CAq8pYpW.d.mts.map
39
+ //# sourceMappingURL=errors-BLU4Tfpe.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors-CAq8pYpW.d.mts","names":[],"sources":["../src/shared/routes.ts","../src/shared/errors.ts"],"mappings":";;;iBAGgB,SAAA,CAAU,IAAA,UAAc,OAAA,aAAoB,OAAA;;AAA5D;;;;;;;;;AAsCA;;;;;;;;;;;iBAAgB,iBAAA,CAAkB,IAAA,UAAc,MAAA,GAAS,MAAA,SAAe,WAAA;;;;;;AAtCxE;;;;iBCIgB,kBAAA,CAAmB,KAAA"}
1
+ {"version":3,"file":"errors-BLU4Tfpe.d.mts","names":[],"sources":["../src/shared/routes.ts","../src/shared/errors.ts"],"mappings":";;;iBAGgB,SAAA,CAAU,IAAA,UAAc,OAAA,aAAoB,OAAA;;AAA5D;;;;;;;;;AAsCA;;;;;;;;;;;iBAAgB,iBAAA,CAAkB,IAAA,UAAc,MAAA,GAAS,MAAA,SAAe,WAAA;;;;;;AAtCxE;;;;iBCIgB,kBAAA,CAAmB,KAAA"}
@@ -1,5 +1,5 @@
1
- import { rt as RequestLogger } from "../audit-BUAajsPU.mjs";
2
- import { t as BaseEvlogOptions } from "../middleware-DQ6-h8h0.mjs";
1
+ import { rt as RequestLogger } from "../audit-D7v6JHj0.mjs";
2
+ import { t as BaseEvlogOptions } from "../middleware-B_k4Mrzg.mjs";
3
3
  import { RequestHandler } from "express";
4
4
 
5
5
  //#region src/express/index.d.ts
@@ -1,4 +1,4 @@
1
- import { t as defineFrameworkIntegration } from "../integration-CR601uyW.mjs";
1
+ import { t as defineFrameworkIntegration } from "../integration-DYp2uw8O.mjs";
2
2
  import { t as bindNodeResponseLifecycle } from "../nodeResponse-CIEEbrNE.mjs";
3
3
  import { t as createLoggerStorage } from "../storage-7X37OToT.mjs";
4
4
  //#region src/express/index.ts
@@ -1,5 +1,5 @@
1
- import { rt as RequestLogger } from "../audit-BUAajsPU.mjs";
2
- import { t as BaseEvlogOptions } from "../middleware-DQ6-h8h0.mjs";
1
+ import { rt as RequestLogger } from "../audit-D7v6JHj0.mjs";
2
+ import { t as BaseEvlogOptions } from "../middleware-B_k4Mrzg.mjs";
3
3
  import { FastifyPluginCallback } from "fastify";
4
4
 
5
5
  //#region src/fastify/index.d.ts
@@ -1,4 +1,4 @@
1
- import { t as defineFrameworkIntegration } from "../integration-CR601uyW.mjs";
1
+ import { t as defineFrameworkIntegration } from "../integration-DYp2uw8O.mjs";
2
2
  import { t as createLoggerStorage } from "../storage-7X37OToT.mjs";
3
3
  //#region src/fastify/index.ts
4
4
  const { storage, useLogger } = createLoggerStorage("plugin context. Make sure app.register(evlog) is called before your routes.");
@@ -1,4 +1,4 @@
1
- import { D as createPluginRunner, E as shouldKeep, F as resolveRedactConfig, M as isGloballyRedacted, P as redactEvent, g as createRequestLogger, j as getEmptyPluginRunner, v as getGlobalDrain, w as markWideEventDrainStarted, x as isEnabled, y as getGlobalPluginRunner } from "./audit-BFwTUxBJ.mjs";
1
+ import { D as createPluginRunner, E as shouldKeep, F as resolveRedactConfig, M as isGloballyRedacted, P as redactEvent, g as createRequestLogger, j as getEmptyPluginRunner, v as getGlobalDrain, w as markWideEventDrainStarted, x as isEnabled, y as getGlobalPluginRunner } from "./audit-BQt8yAHo.mjs";
2
2
  import { t as extractErrorStatus } from "./errors-DA0cyr8q.mjs";
3
3
  import { n as shouldLog, t as getServiceForPath } from "./routes-4rMzRyTk.mjs";
4
4
  import { r as shouldDeferEmitForResponse, t as bindStreamingResponseLifecycle } from "./streamResponse-CmQ3qUbF.mjs";
@@ -250,4 +250,4 @@ function forkBackgroundLogger(options) {
250
250
  //#endregion
251
251
  export { runEnrichAndDrain as a, resolveMiddlewarePluginRunner as i, forkBackgroundLogger as n, createMiddlewareLogger as r, attachForkToLogger as t };
252
252
 
253
- //# sourceMappingURL=fork-CYm453dq.mjs.map
253
+ //# sourceMappingURL=fork-CgGlAaHa.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"fork-CYm453dq.mjs","names":[],"sources":["../src/shared/middleware.ts","../src/shared/fork.ts"],"sourcesContent":["import type { DrainContext, EnrichContext, RedactConfig, RequestLogger, RouteConfig, TailSamplingContext, WideEvent } from '../types'\nimport { createRequestLogger, getGlobalDrain, getGlobalPluginRunner, isEnabled, markWideEventDrainStarted, shouldKeep } from '../logger'\nimport { isGloballyRedacted, redactEvent, resolveRedactConfig } from '../redact'\nimport { extractErrorStatus } from './errors'\nimport type { EvlogPlugin, PluginRunner } from './plugin'\nimport { createPluginRunner, getEmptyPluginRunner } from './plugin'\nimport { shouldLog, getServiceForPath } from './routes'\nimport { bindStreamingResponseLifecycle, shouldDeferEmitForResponse } from './streamResponse'\n\n/**\n * Base options shared by every framework integration. Re-exported via\n * `evlog/toolkit` so custom integrations can extend it.\n */\nexport interface BaseEvlogOptions {\n /** Route glob patterns to include. If unset, all routes are logged. */\n include?: string[]\n /** Route glob patterns to exclude. Takes precedence over `include`. */\n exclude?: string[]\n /** Per-route service overrides. */\n routes?: Record<string, RouteConfig>\n /** Drain callback invoked with every emitted event. */\n drain?: (ctx: DrainContext) => void | Promise<void>\n /** Enrich callback invoked after emit, before drain. */\n enrich?: (ctx: EnrichContext) => void | Promise<void>\n /** Tail sampling callback. Set `ctx.shouldKeep = true` to force-keep. */\n keep?: (ctx: TailSamplingContext) => void | Promise<void>\n /**\n * PII auto-redaction. `true` enables built-in patterns; pass an object for\n * fine-grained control. Applied before enrich/drain.\n */\n redact?: boolean | RedactConfig\n /** Plugins for this middleware, merged with globally-registered ones. */\n plugins?: EvlogPlugin[]\n}\n\n/** Internal options accepted by `createMiddlewareLogger`. */\nexport interface MiddlewareLoggerOptions extends BaseEvlogOptions {\n method: string\n path: string\n requestId?: string\n /** Pre-filtered safe request headers used for enrich/drain context. */\n headers?: Record<string, string>\n}\n\nexport interface MiddlewareLoggerResult {\n logger: RequestLogger\n finish: (opts?: { status?: number; error?: Error }) => Promise<WideEvent | null>\n /**\n * Finish request logging, deferring emit until a streaming response body completes.\n * Returns the original response or a wrapped copy when the body is a stream.\n */\n finishResponse: (response: Response, opts?: { status?: number }) => Promise<Response>\n skipped: boolean\n}\n\nconst noopResult: MiddlewareLoggerResult = {\n logger: {\n set() {},\n error() {},\n info() {},\n warn() {},\n setLevel() {},\n emit() {\n return null \n },\n getContext() {\n return {} \n },\n },\n finish: () => Promise.resolve(null),\n finishResponse: (response) => Promise.resolve(response),\n skipped: true,\n}\n\n// Memoizes the merged runner per local plugins array (stable across requests\n// because it lives in the middleware factory closure). Invalidated when\n// `initLogger` swaps the global runner, so the merge cost is paid once.\nconst runnerCache = new WeakMap<EvlogPlugin[], { global: PluginRunner; merged: PluginRunner }>()\n\n/**\n * Resolve the plugin runner for a middleware invocation by merging local\n * plugins with the globally-registered ones (deduplicated by `name`).\n */\nexport function resolveMiddlewarePluginRunner(options: { plugins?: EvlogPlugin[] }): PluginRunner {\n const global = getGlobalPluginRunner()\n const local = options.plugins\n if (!local || local.length === 0) return global\n\n const cached = runnerCache.get(local)\n if (cached && cached.global === global) return cached.merged\n\n const merged = new Map<string, EvlogPlugin>()\n for (const plugin of global.plugins) merged.set(plugin.name, plugin)\n for (const plugin of local) merged.set(plugin.name, plugin)\n if (merged.size === 0) return getEmptyPluginRunner()\n\n const runner = createPluginRunner(Array.from(merged.values()))\n runnerCache.set(local, { global, merged: runner })\n return runner\n}\n\n/** Copy redacted fields onto the emitted event without replacing its identity. */\nfunction assignRedactedEvent(target: WideEvent, redacted: Partial<WideEvent>): void {\n for (const key of Object.keys(target) as Array<keyof WideEvent>) {\n if (!(key in redacted)) {\n delete target[key]\n }\n }\n Object.assign(target, redacted)\n}\n\n/**\n * Apply redact, enrich, and drain to an emitted wide event — the same\n * pipeline used by {@link createMiddlewareLogger}'s `finish`.\n */\n// eslint-disable-next-line max-params\nexport async function runEnrichAndDrain(\n emittedEvent: WideEvent,\n options: MiddlewareLoggerOptions,\n requestInfo: { method: string; path: string; requestId?: string },\n responseStatus?: number,\n plugins?: PluginRunner,\n): Promise<void> {\n const runner = plugins ?? resolveMiddlewarePluginRunner(options)\n const resolvedRedact = resolveRedactConfig(options.redact)\n if (resolvedRedact && !isGloballyRedacted(emittedEvent)) {\n assignRedactedEvent(emittedEvent, redactEvent(emittedEvent, resolvedRedact) as Partial<WideEvent>)\n }\n\n if (options.enrich || runner.hasEnrich) {\n const enrichCtx: EnrichContext = {\n event: emittedEvent,\n request: requestInfo,\n headers: options.headers,\n response: { status: responseStatus },\n }\n if (options.enrich) {\n try {\n await options.enrich(enrichCtx)\n } catch (err) {\n console.error('[evlog] enrich failed:', err)\n }\n }\n if (runner.hasEnrich) {\n await runner.runEnrich(enrichCtx)\n }\n }\n\n markWideEventDrainStarted(emittedEvent)\n\n const drain = options.drain ?? getGlobalDrain()\n const hasUserDrain = !!drain\n const hasPluginDrain = runner.hasDrain\n if (hasUserDrain || hasPluginDrain) {\n const drainCtx: DrainContext = {\n event: emittedEvent,\n request: requestInfo,\n headers: options.headers,\n }\n const tasks: Array<Promise<unknown>> = []\n if (hasUserDrain) {\n tasks.push(\n (async () => {\n try {\n await drain!(drainCtx)\n } catch (err) {\n console.error('[evlog] drain failed:', err)\n }\n })(),\n )\n }\n if (hasPluginDrain) {\n tasks.push(runner.runDrain(drainCtx))\n }\n await Promise.all(tasks)\n }\n}\n\n/**\n * Create a request logger with the full middleware pipeline: route filtering,\n * service overrides, duration tracking, tail sampling, emit, enrich, drain.\n *\n * Framework adapters extract method/path/requestId/headers, call this once\n * per request, and call `finish({ status | error })` when the response ends.\n * If `skipped` is `true`, the route was filtered out — bypass logging.\n */\nexport function createMiddlewareLogger(options: MiddlewareLoggerOptions): MiddlewareLoggerResult {\n if (!isEnabled()) return noopResult\n\n const { method, path, requestId, include, exclude, routes, keep } = options\n\n if (!shouldLog(path, include, exclude)) {\n return noopResult\n }\n\n const resolvedRequestId = requestId || crypto.randomUUID()\n\n const logger = createRequestLogger({\n method,\n path,\n requestId: resolvedRequestId,\n }, { _deferDrain: true })\n\n const routeService = getServiceForPath(path, routes)\n if (routeService) {\n logger.set({ service: routeService })\n }\n\n const pluginRunner = resolveMiddlewarePluginRunner(options)\n if (pluginRunner.hasExtendLogger) {\n pluginRunner.applyExtendLogger(logger)\n }\n\n const startTime = Date.now()\n const requestInfo = { method, path, requestId: resolvedRequestId }\n\n if (pluginRunner.hasRequestLifecycle) {\n pluginRunner.runOnRequestStart({\n logger,\n request: requestInfo,\n headers: options.headers,\n })\n }\n\n const finish = (opts?: { status?: number; error?: Error }): Promise<WideEvent | null> => {\n return performFinish(logger, opts)\n }\n\n const finishResponse = async (response: Response, opts?: { status?: number }): Promise<Response> => {\n const status = opts?.status ?? response.status\n if (!shouldDeferEmitForResponse(response)) {\n await performFinish(logger, { status })\n return response\n }\n\n return bindStreamingResponseLifecycle(response, async (meta) => {\n await performFinish(logger, {\n status: meta.status ?? status,\n error: meta.error,\n })\n })\n }\n\n async function performFinish(\n requestLogger: RequestLogger,\n opts?: { status?: number; error?: Error },\n ): Promise<WideEvent | null> {\n const { status, error } = opts ?? {}\n\n if (error) {\n requestLogger.error(error)\n const errorStatus = extractErrorStatus(error)\n requestLogger.set({ status: errorStatus })\n } else if (status !== undefined) {\n requestLogger.set({ status })\n }\n\n const durationMs = Date.now() - startTime\n\n const resolvedStatus = error\n ? extractErrorStatus(error)\n : status ?? (requestLogger.getContext().status as number | undefined)\n\n const tailCtx: TailSamplingContext = {\n status: resolvedStatus,\n duration: durationMs,\n path,\n method,\n context: requestLogger.getContext(),\n shouldKeep: false,\n }\n\n if (keep) {\n await keep(tailCtx)\n }\n if (pluginRunner.hasKeep) {\n await pluginRunner.runKeep(tailCtx)\n }\n\n const forceKeep = tailCtx.shouldKeep || shouldKeep(tailCtx)\n const emittedEvent = requestLogger.emit({ _forceKeep: forceKeep })\n\n if (\n emittedEvent\n && (options.enrich || options.drain || pluginRunner.hasEnrich || pluginRunner.hasDrain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, options, requestInfo, resolvedStatus, pluginRunner)\n }\n\n if (pluginRunner.hasRequestLifecycle) {\n pluginRunner.runOnRequestFinish({\n logger: requestLogger,\n request: requestInfo,\n headers: options.headers,\n event: emittedEvent,\n status: resolvedStatus,\n durationMs,\n error,\n })\n }\n\n return emittedEvent\n }\n\n return { logger, finish, finishResponse, skipped: false }\n}\n","import type { AsyncLocalStorage } from 'node:async_hooks'\nimport type { RequestLogger } from '../types'\nimport { createRequestLogger, getGlobalDrain } from '../logger'\nimport { extractErrorStatus } from './errors'\nimport type { MiddlewareLoggerOptions } from './middleware'\nimport { runEnrichAndDrain } from './middleware'\n\n/**\n * Optional hooks for integrations that track active loggers (e.g. Elysia `activeLoggers`).\n */\nexport interface ForkLifecycle {\n /** Called after the child logger is installed in storage, before `fn` runs. */\n onChildEnter?: (child: RequestLogger) => void\n /** Called after the child has finished (emit + enrich/drain), success or failure. */\n onChildExit?: (child: RequestLogger) => void\n}\n\n/**\n * Options for {@link forkBackgroundLogger}.\n *\n * @beta Part of `evlog/toolkit`\n */\nexport interface ForkBackgroundLoggerOptions {\n storage: AsyncLocalStorage<RequestLogger>\n parent: RequestLogger\n middlewareOptions: MiddlewareLoggerOptions\n label: string\n fn: () => void | Promise<void>\n lifecycle?: ForkLifecycle\n}\n\n/**\n * Attach {@link RequestLogger.fork} to a request logger. Replaces any existing `fork`.\n */\nexport function attachForkToLogger(\n storage: AsyncLocalStorage<RequestLogger>,\n parent: RequestLogger,\n middlewareOptions: MiddlewareLoggerOptions,\n lifecycle?: ForkLifecycle,\n): void {\n const log = parent as RequestLogger & { fork?: (label: string, fn: () => void | Promise<void>) => void }\n log.fork = (label: string, fn: () => void | Promise<void>) => {\n forkBackgroundLogger({ storage, parent, middlewareOptions, label, fn, lifecycle })\n }\n}\n\n/**\n * Run background work under a child request logger so `useLogger()` resolves to the\n * child while `fn` runs. The child emits a separate wide event when `fn` settles,\n * with `operation` and `_parentRequestId` set for correlation.\n *\n * @beta Part of `evlog/toolkit` — used by framework integrations; prefer `log.fork()`\n * on the request logger when available.\n */\nexport function forkBackgroundLogger(options: ForkBackgroundLoggerOptions): void {\n const { storage, parent, middlewareOptions, label, fn, lifecycle } = options\n\n const parentCtx = parent.getContext() as Record<string, unknown>\n const parentRequestId = parentCtx.requestId\n if (typeof parentRequestId !== 'string' || parentRequestId.length === 0) {\n throw new Error(\n '[evlog] log.fork() requires the parent logger to have a requestId. '\n + 'Ensure the request was created by evlog middleware.',\n )\n }\n\n const method = String(parentCtx.method ?? middlewareOptions.method)\n const path = String(parentCtx.path ?? middlewareOptions.path)\n\n const child = createRequestLogger(\n {\n method,\n path,\n requestId: crypto.randomUUID(),\n },\n { _deferDrain: true },\n )\n\n child.set({\n operation: label,\n _parentRequestId: parentRequestId,\n })\n\n const childRequestInfo = {\n method,\n path,\n requestId: child.getContext().requestId as string,\n }\n\n storage.run(child, () => {\n lifecycle?.onChildEnter?.(child)\n void Promise.resolve()\n .then(() => fn())\n .then(async () => {\n const emittedEvent = child.emit()\n const ctxStatus = child.getContext().status\n const status = (emittedEvent?.status\n ?? (typeof ctxStatus === 'number' ? ctxStatus : undefined)) as number | undefined\n if (\n emittedEvent\n && (middlewareOptions.enrich || middlewareOptions.drain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, middlewareOptions, childRequestInfo, status)\n }\n })\n .catch(async (err: unknown) => {\n const error = err instanceof Error ? err : new Error(String(err))\n child.error(error)\n child.set({ status: extractErrorStatus(error) })\n const emittedEvent = child.emit()\n const status = extractErrorStatus(error)\n if (\n emittedEvent\n && (middlewareOptions.enrich || middlewareOptions.drain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, middlewareOptions, childRequestInfo, status)\n }\n })\n .finally(() => {\n lifecycle?.onChildExit?.(child)\n })\n })\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"fork-CgGlAaHa.mjs","names":[],"sources":["../src/shared/middleware.ts","../src/shared/fork.ts"],"sourcesContent":["import type { DrainContext, EnrichContext, RedactConfig, RequestLogger, RouteConfig, TailSamplingContext, WideEvent } from '../types'\nimport { createRequestLogger, getGlobalDrain, getGlobalPluginRunner, isEnabled, markWideEventDrainStarted, shouldKeep } from '../logger'\nimport { isGloballyRedacted, redactEvent, resolveRedactConfig } from '../redact'\nimport { extractErrorStatus } from './errors'\nimport type { EvlogPlugin, PluginRunner } from './plugin'\nimport { createPluginRunner, getEmptyPluginRunner } from './plugin'\nimport { shouldLog, getServiceForPath } from './routes'\nimport { bindStreamingResponseLifecycle, shouldDeferEmitForResponse } from './streamResponse'\n\n/**\n * Base options shared by every framework integration. Re-exported via\n * `evlog/toolkit` so custom integrations can extend it.\n */\nexport interface BaseEvlogOptions {\n /** Route glob patterns to include. If unset, all routes are logged. */\n include?: string[]\n /** Route glob patterns to exclude. Takes precedence over `include`. */\n exclude?: string[]\n /** Per-route service overrides. */\n routes?: Record<string, RouteConfig>\n /** Drain callback invoked with every emitted event. */\n drain?: (ctx: DrainContext) => void | Promise<void>\n /** Enrich callback invoked after emit, before drain. */\n enrich?: (ctx: EnrichContext) => void | Promise<void>\n /** Tail sampling callback. Set `ctx.shouldKeep = true` to force-keep. */\n keep?: (ctx: TailSamplingContext) => void | Promise<void>\n /**\n * PII auto-redaction. `true` enables built-in patterns; pass an object for\n * fine-grained control. Applied before enrich/drain.\n */\n redact?: boolean | RedactConfig\n /** Plugins for this middleware, merged with globally-registered ones. */\n plugins?: EvlogPlugin[]\n}\n\n/** Internal options accepted by `createMiddlewareLogger`. */\nexport interface MiddlewareLoggerOptions extends BaseEvlogOptions {\n method: string\n path: string\n requestId?: string\n /** Pre-filtered safe request headers used for enrich/drain context. */\n headers?: Record<string, string>\n}\n\nexport interface MiddlewareLoggerResult {\n logger: RequestLogger\n finish: (opts?: { status?: number; error?: Error }) => Promise<WideEvent | null>\n /**\n * Finish request logging, deferring emit until a streaming response body completes.\n * Returns the original response or a wrapped copy when the body is a stream.\n */\n finishResponse: (response: Response, opts?: { status?: number }) => Promise<Response>\n skipped: boolean\n}\n\nconst noopResult: MiddlewareLoggerResult = {\n logger: {\n set() {},\n error() {},\n info() {},\n warn() {},\n setLevel() {},\n emit() {\n return null \n },\n getContext() {\n return {} \n },\n },\n finish: () => Promise.resolve(null),\n finishResponse: (response) => Promise.resolve(response),\n skipped: true,\n}\n\n// Memoizes the merged runner per local plugins array (stable across requests\n// because it lives in the middleware factory closure). Invalidated when\n// `initLogger` swaps the global runner, so the merge cost is paid once.\nconst runnerCache = new WeakMap<EvlogPlugin[], { global: PluginRunner; merged: PluginRunner }>()\n\n/**\n * Resolve the plugin runner for a middleware invocation by merging local\n * plugins with the globally-registered ones (deduplicated by `name`).\n */\nexport function resolveMiddlewarePluginRunner(options: { plugins?: EvlogPlugin[] }): PluginRunner {\n const global = getGlobalPluginRunner()\n const local = options.plugins\n if (!local || local.length === 0) return global\n\n const cached = runnerCache.get(local)\n if (cached && cached.global === global) return cached.merged\n\n const merged = new Map<string, EvlogPlugin>()\n for (const plugin of global.plugins) merged.set(plugin.name, plugin)\n for (const plugin of local) merged.set(plugin.name, plugin)\n if (merged.size === 0) return getEmptyPluginRunner()\n\n const runner = createPluginRunner(Array.from(merged.values()))\n runnerCache.set(local, { global, merged: runner })\n return runner\n}\n\n/** Copy redacted fields onto the emitted event without replacing its identity. */\nfunction assignRedactedEvent(target: WideEvent, redacted: Partial<WideEvent>): void {\n for (const key of Object.keys(target) as Array<keyof WideEvent>) {\n if (!(key in redacted)) {\n delete target[key]\n }\n }\n Object.assign(target, redacted)\n}\n\n/**\n * Apply redact, enrich, and drain to an emitted wide event — the same\n * pipeline used by {@link createMiddlewareLogger}'s `finish`.\n */\n// eslint-disable-next-line max-params\nexport async function runEnrichAndDrain(\n emittedEvent: WideEvent,\n options: MiddlewareLoggerOptions,\n requestInfo: { method: string; path: string; requestId?: string },\n responseStatus?: number,\n plugins?: PluginRunner,\n): Promise<void> {\n const runner = plugins ?? resolveMiddlewarePluginRunner(options)\n const resolvedRedact = resolveRedactConfig(options.redact)\n if (resolvedRedact && !isGloballyRedacted(emittedEvent)) {\n assignRedactedEvent(emittedEvent, redactEvent(emittedEvent, resolvedRedact) as Partial<WideEvent>)\n }\n\n if (options.enrich || runner.hasEnrich) {\n const enrichCtx: EnrichContext = {\n event: emittedEvent,\n request: requestInfo,\n headers: options.headers,\n response: { status: responseStatus },\n }\n if (options.enrich) {\n try {\n await options.enrich(enrichCtx)\n } catch (err) {\n console.error('[evlog] enrich failed:', err)\n }\n }\n if (runner.hasEnrich) {\n await runner.runEnrich(enrichCtx)\n }\n }\n\n markWideEventDrainStarted(emittedEvent)\n\n const drain = options.drain ?? getGlobalDrain()\n const hasUserDrain = !!drain\n const hasPluginDrain = runner.hasDrain\n if (hasUserDrain || hasPluginDrain) {\n const drainCtx: DrainContext = {\n event: emittedEvent,\n request: requestInfo,\n headers: options.headers,\n }\n const tasks: Array<Promise<unknown>> = []\n if (hasUserDrain) {\n tasks.push(\n (async () => {\n try {\n await drain!(drainCtx)\n } catch (err) {\n console.error('[evlog] drain failed:', err)\n }\n })(),\n )\n }\n if (hasPluginDrain) {\n tasks.push(runner.runDrain(drainCtx))\n }\n await Promise.all(tasks)\n }\n}\n\n/**\n * Create a request logger with the full middleware pipeline: route filtering,\n * service overrides, duration tracking, tail sampling, emit, enrich, drain.\n *\n * Framework adapters extract method/path/requestId/headers, call this once\n * per request, and call `finish({ status | error })` when the response ends.\n * If `skipped` is `true`, the route was filtered out — bypass logging.\n */\nexport function createMiddlewareLogger(options: MiddlewareLoggerOptions): MiddlewareLoggerResult {\n if (!isEnabled()) return noopResult\n\n const { method, path, requestId, include, exclude, routes, keep } = options\n\n if (!shouldLog(path, include, exclude)) {\n return noopResult\n }\n\n const resolvedRequestId = requestId || crypto.randomUUID()\n\n const logger = createRequestLogger({\n method,\n path,\n requestId: resolvedRequestId,\n }, { _deferDrain: true })\n\n const routeService = getServiceForPath(path, routes)\n if (routeService) {\n logger.set({ service: routeService })\n }\n\n const pluginRunner = resolveMiddlewarePluginRunner(options)\n if (pluginRunner.hasExtendLogger) {\n pluginRunner.applyExtendLogger(logger)\n }\n\n const startTime = Date.now()\n const requestInfo = { method, path, requestId: resolvedRequestId }\n\n if (pluginRunner.hasRequestLifecycle) {\n pluginRunner.runOnRequestStart({\n logger,\n request: requestInfo,\n headers: options.headers,\n })\n }\n\n const finish = (opts?: { status?: number; error?: Error }): Promise<WideEvent | null> => {\n return performFinish(logger, opts)\n }\n\n const finishResponse = async (response: Response, opts?: { status?: number }): Promise<Response> => {\n const status = opts?.status ?? response.status\n if (!shouldDeferEmitForResponse(response)) {\n await performFinish(logger, { status })\n return response\n }\n\n return bindStreamingResponseLifecycle(response, async (meta) => {\n await performFinish(logger, {\n status: meta.status ?? status,\n error: meta.error,\n })\n })\n }\n\n async function performFinish(\n requestLogger: RequestLogger,\n opts?: { status?: number; error?: Error },\n ): Promise<WideEvent | null> {\n const { status, error } = opts ?? {}\n\n if (error) {\n requestLogger.error(error)\n const errorStatus = extractErrorStatus(error)\n requestLogger.set({ status: errorStatus })\n } else if (status !== undefined) {\n requestLogger.set({ status })\n }\n\n const durationMs = Date.now() - startTime\n\n const resolvedStatus = error\n ? extractErrorStatus(error)\n : status ?? (requestLogger.getContext().status as number | undefined)\n\n const tailCtx: TailSamplingContext = {\n status: resolvedStatus,\n duration: durationMs,\n path,\n method,\n context: requestLogger.getContext(),\n shouldKeep: false,\n }\n\n if (keep) {\n await keep(tailCtx)\n }\n if (pluginRunner.hasKeep) {\n await pluginRunner.runKeep(tailCtx)\n }\n\n const forceKeep = tailCtx.shouldKeep || shouldKeep(tailCtx)\n const emittedEvent = requestLogger.emit({ _forceKeep: forceKeep })\n\n if (\n emittedEvent\n && (options.enrich || options.drain || pluginRunner.hasEnrich || pluginRunner.hasDrain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, options, requestInfo, resolvedStatus, pluginRunner)\n }\n\n if (pluginRunner.hasRequestLifecycle) {\n pluginRunner.runOnRequestFinish({\n logger: requestLogger,\n request: requestInfo,\n headers: options.headers,\n event: emittedEvent,\n status: resolvedStatus,\n durationMs,\n error,\n })\n }\n\n return emittedEvent\n }\n\n return { logger, finish, finishResponse, skipped: false }\n}\n","import type { AsyncLocalStorage } from 'node:async_hooks'\nimport type { RequestLogger } from '../types'\nimport { createRequestLogger, getGlobalDrain } from '../logger'\nimport { extractErrorStatus } from './errors'\nimport type { MiddlewareLoggerOptions } from './middleware'\nimport { runEnrichAndDrain } from './middleware'\n\n/**\n * Optional hooks for integrations that track active loggers (e.g. Elysia `activeLoggers`).\n */\nexport interface ForkLifecycle {\n /** Called after the child logger is installed in storage, before `fn` runs. */\n onChildEnter?: (child: RequestLogger) => void\n /** Called after the child has finished (emit + enrich/drain), success or failure. */\n onChildExit?: (child: RequestLogger) => void\n}\n\n/**\n * Options for {@link forkBackgroundLogger}.\n *\n * @beta Part of `evlog/toolkit`\n */\nexport interface ForkBackgroundLoggerOptions {\n storage: AsyncLocalStorage<RequestLogger>\n parent: RequestLogger\n middlewareOptions: MiddlewareLoggerOptions\n label: string\n fn: () => void | Promise<void>\n lifecycle?: ForkLifecycle\n}\n\n/**\n * Attach {@link RequestLogger.fork} to a request logger. Replaces any existing `fork`.\n */\nexport function attachForkToLogger(\n storage: AsyncLocalStorage<RequestLogger>,\n parent: RequestLogger,\n middlewareOptions: MiddlewareLoggerOptions,\n lifecycle?: ForkLifecycle,\n): void {\n const log = parent as RequestLogger & { fork?: (label: string, fn: () => void | Promise<void>) => void }\n log.fork = (label: string, fn: () => void | Promise<void>) => {\n forkBackgroundLogger({ storage, parent, middlewareOptions, label, fn, lifecycle })\n }\n}\n\n/**\n * Run background work under a child request logger so `useLogger()` resolves to the\n * child while `fn` runs. The child emits a separate wide event when `fn` settles,\n * with `operation` and `_parentRequestId` set for correlation.\n *\n * @beta Part of `evlog/toolkit` — used by framework integrations; prefer `log.fork()`\n * on the request logger when available.\n */\nexport function forkBackgroundLogger(options: ForkBackgroundLoggerOptions): void {\n const { storage, parent, middlewareOptions, label, fn, lifecycle } = options\n\n const parentCtx = parent.getContext() as Record<string, unknown>\n const parentRequestId = parentCtx.requestId\n if (typeof parentRequestId !== 'string' || parentRequestId.length === 0) {\n throw new Error(\n '[evlog] log.fork() requires the parent logger to have a requestId. '\n + 'Ensure the request was created by evlog middleware.',\n )\n }\n\n const method = String(parentCtx.method ?? middlewareOptions.method)\n const path = String(parentCtx.path ?? middlewareOptions.path)\n\n const child = createRequestLogger(\n {\n method,\n path,\n requestId: crypto.randomUUID(),\n },\n { _deferDrain: true },\n )\n\n child.set({\n operation: label,\n _parentRequestId: parentRequestId,\n })\n\n const childRequestInfo = {\n method,\n path,\n requestId: child.getContext().requestId as string,\n }\n\n storage.run(child, () => {\n lifecycle?.onChildEnter?.(child)\n void Promise.resolve()\n .then(() => fn())\n .then(async () => {\n const emittedEvent = child.emit()\n const ctxStatus = child.getContext().status\n const status = (emittedEvent?.status\n ?? (typeof ctxStatus === 'number' ? ctxStatus : undefined)) as number | undefined\n if (\n emittedEvent\n && (middlewareOptions.enrich || middlewareOptions.drain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, middlewareOptions, childRequestInfo, status)\n }\n })\n .catch(async (err: unknown) => {\n const error = err instanceof Error ? err : new Error(String(err))\n child.error(error)\n child.set({ status: extractErrorStatus(error) })\n const emittedEvent = child.emit()\n const status = extractErrorStatus(error)\n if (\n emittedEvent\n && (middlewareOptions.enrich || middlewareOptions.drain || getGlobalDrain())\n ) {\n await runEnrichAndDrain(emittedEvent, middlewareOptions, childRequestInfo, status)\n }\n })\n .finally(() => {\n lifecycle?.onChildExit?.(child)\n })\n })\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { rt as RequestLogger } from "../audit-BUAajsPU.mjs";
2
- import { t as BaseEvlogOptions } from "../middleware-DQ6-h8h0.mjs";
1
+ import { rt as RequestLogger } from "../audit-D7v6JHj0.mjs";
2
+ import { t as BaseEvlogOptions } from "../middleware-B_k4Mrzg.mjs";
3
3
  import { MiddlewareHandler } from "hono";
4
4
 
5
5
  //#region src/hono/index.d.ts
@@ -1,5 +1,5 @@
1
1
  import { r as shouldDeferEmitForResponse } from "../streamResponse-CmQ3qUbF.mjs";
2
- import { t as defineFrameworkIntegration } from "../integration-CR601uyW.mjs";
2
+ import { t as defineFrameworkIntegration } from "../integration-DYp2uw8O.mjs";
3
3
  //#region src/hono/index.ts
4
4
  const integration = defineFrameworkIntegration({
5
5
  name: "hono",
@@ -1,4 +1,4 @@
1
- import { n as version } from "./package-CUhII9DA.mjs";
1
+ import { n as version } from "./package-CNV_CXs8.mjs";
2
2
  //#region src/shared/http.ts
3
3
  /**
4
4
  * Minimal HTTP transport for drain adapters: abort-based timeouts, exponential
@@ -79,4 +79,4 @@ async function httpPost({ url, headers, body, timeout, label, retries = 2, userA
79
79
  //#endregion
80
80
  export { withEvlogIdentityHeaders as i, EVLOG_VERSION as n, httpPost as r, EVLOG_USER_AGENT as t };
81
81
 
82
- //# sourceMappingURL=http-Bept5EIC.mjs.map
82
+ //# sourceMappingURL=http-ChVS9GYc.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"http-Bept5EIC.mjs","names":["PKG_VERSION"],"sources":["../src/shared/http.ts"],"sourcesContent":["/**\n * Minimal HTTP transport for drain adapters: abort-based timeouts, exponential\n * backoff on `5xx` / network errors, response bodies truncated in error messages.\n *\n * Identifies every outgoing request as coming from evlog via:\n * - `User-Agent: evlog/<version>` (Node / server runtimes only — browsers strip this)\n * - `X-Evlog-Source: <source>` when {@link HttpPostOptions.source} is set\n */\n\nimport { version as PKG_VERSION } from '../../package.json'\n\n/** Build-time evlog package version, e.g. `2.16.0`. */\nexport const EVLOG_VERSION: string = PKG_VERSION\n\n/** Default `User-Agent` value injected into outgoing drain requests. */\nexport const EVLOG_USER_AGENT = `evlog/${EVLOG_VERSION}`\n\nexport interface HttpPostOptions {\n url: string\n /** Caller is responsible for `Content-Type`. */\n headers: Record<string, string>\n /** Pre-serialized request body. */\n body: string\n /** Abort the request after this many milliseconds. */\n timeout: number\n /** Prefix used in error messages. */\n label: string\n /**\n * Retries network errors, aborts, and `5xx` responses with exponential backoff.\n * @default 2\n */\n retries?: number\n /**\n * Override the default `User-Agent: evlog/<version>` header. Pass `false` or\n * an empty string to suppress it entirely (e.g. when the underlying transport\n * forbids overriding `User-Agent`).\n */\n userAgent?: string | false\n /**\n * When set, sends `X-Evlog-Source: <source>` so the receiving system can\n * distinguish evlog traffic from other clients. Typically the adapter name\n * (`axiom`, `datadog`, ...) or `client` for browser-originated drains.\n */\n source?: string\n}\n\nfunction hasHeader(headers: Record<string, string>, target: string): boolean {\n const lower = target.toLowerCase()\n for (const key of Object.keys(headers)) {\n if (key.toLowerCase() === lower) return true\n }\n return false\n}\n\n/**\n * Returns a copy of `headers` with evlog identity headers injected when\n * absent. Caller-provided values always win.\n *\n * @internal Exposed for tests. Use {@link httpPost} from drains.\n */\nexport function withEvlogIdentityHeaders(\n headers: Record<string, string>,\n { userAgent, source }: { userAgent?: string | false; source?: string } = {},\n): Record<string, string> {\n const out = { ...headers }\n if (userAgent !== false && !hasHeader(out, 'user-agent')) {\n const ua = typeof userAgent === 'string' && userAgent.length > 0 ? userAgent : EVLOG_USER_AGENT\n out['User-Agent'] = ua\n }\n if (source && !hasHeader(out, 'x-evlog-source')) {\n out['X-Evlog-Source'] = source\n }\n return out\n}\n\nfunction isRetryable(error: unknown): boolean {\n if (error instanceof DOMException && error.name === 'AbortError') return true\n if (error instanceof TypeError) return true\n if (error instanceof Error) {\n const match = error.message.match(/API error: (\\d+)/)\n if (match) return Number.parseInt(match[1]) >= 500\n }\n return false\n}\n\n/**\n * POST a body with timeout + retry. Throws label-prefixed errors with a\n * truncated response body. Safe to call from any drain `send()`.\n */\nexport async function httpPost({ url, headers, body, timeout, label, retries = 2, userAgent, source }: HttpPostOptions): Promise<void> {\n const normalizedRetries = Number.isFinite(retries) && retries >= 0 ? Math.floor(retries) : 2\n const finalHeaders = withEvlogIdentityHeaders(headers, { userAgent, source })\n\n let lastError: Error | undefined\n\n for (let attempt = 0; attempt <= normalizedRetries; attempt++) {\n const controller = new AbortController()\n const timeoutId = setTimeout(() => controller.abort(), timeout)\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: finalHeaders,\n body,\n signal: controller.signal,\n })\n\n if (!response.ok) {\n const text = await response.text().catch(() => 'Unknown error')\n const safeText = text.length > 200 ? `${text.slice(0, 200)}...[truncated]` : text\n throw new Error(`${label} API error: ${response.status} ${response.statusText} - ${safeText}`)\n }\n\n clearTimeout(timeoutId)\n return\n } catch (error) {\n clearTimeout(timeoutId)\n\n if (error instanceof DOMException && error.name === 'AbortError') {\n lastError = new Error(`${label} request timed out after ${timeout}ms`)\n } else {\n lastError = error as Error\n }\n\n if (!isRetryable(error) || attempt === normalizedRetries) {\n throw lastError\n }\n\n await new Promise<void>(r => setTimeout(r, 200 * 2 ** attempt))\n }\n }\n\n throw lastError!\n}\n"],"mappings":";;;;;;;;;;;AAYA,MAAa,gBAAwBA;;AAGrC,MAAa,mBAAmB,SAAS;AA+BzC,SAAS,UAAU,SAAiC,QAAyB;CAC3E,MAAM,QAAQ,OAAO,aAAa;AAClC,MAAK,MAAM,OAAO,OAAO,KAAK,QAAQ,CACpC,KAAI,IAAI,aAAa,KAAK,MAAO,QAAO;AAE1C,QAAO;;;;;;;;AAST,SAAgB,yBACd,SACA,EAAE,WAAW,WAA4D,EAAE,EACnD;CACxB,MAAM,MAAM,EAAE,GAAG,SAAS;AAC1B,KAAI,cAAc,SAAS,CAAC,UAAU,KAAK,aAAa,CAEtD,KAAI,gBADO,OAAO,cAAc,YAAY,UAAU,SAAS,IAAI,YAAY;AAGjF,KAAI,UAAU,CAAC,UAAU,KAAK,iBAAiB,CAC7C,KAAI,oBAAoB;AAE1B,QAAO;;AAGT,SAAS,YAAY,OAAyB;AAC5C,KAAI,iBAAiB,gBAAgB,MAAM,SAAS,aAAc,QAAO;AACzE,KAAI,iBAAiB,UAAW,QAAO;AACvC,KAAI,iBAAiB,OAAO;EAC1B,MAAM,QAAQ,MAAM,QAAQ,MAAM,mBAAmB;AACrD,MAAI,MAAO,QAAO,OAAO,SAAS,MAAM,GAAG,IAAI;;AAEjD,QAAO;;;;;;AAOT,eAAsB,SAAS,EAAE,KAAK,SAAS,MAAM,SAAS,OAAO,UAAU,GAAG,WAAW,UAA0C;CACrI,MAAM,oBAAoB,OAAO,SAAS,QAAQ,IAAI,WAAW,IAAI,KAAK,MAAM,QAAQ,GAAG;CAC3F,MAAM,eAAe,yBAAyB,SAAS;EAAE;EAAW;EAAQ,CAAC;CAE7E,IAAI;AAEJ,MAAK,IAAI,UAAU,GAAG,WAAW,mBAAmB,WAAW;EAC7D,MAAM,aAAa,IAAI,iBAAiB;EACxC,MAAM,YAAY,iBAAiB,WAAW,OAAO,EAAE,QAAQ;AAE/D,MAAI;GACF,MAAM,WAAW,MAAM,MAAM,KAAK;IAChC,QAAQ;IACR,SAAS;IACT;IACA,QAAQ,WAAW;IACpB,CAAC;AAEF,OAAI,CAAC,SAAS,IAAI;IAChB,MAAM,OAAO,MAAM,SAAS,MAAM,CAAC,YAAY,gBAAgB;IAC/D,MAAM,WAAW,KAAK,SAAS,MAAM,GAAG,KAAK,MAAM,GAAG,IAAI,CAAC,kBAAkB;AAC7E,UAAM,IAAI,MAAM,GAAG,MAAM,cAAc,SAAS,OAAO,GAAG,SAAS,WAAW,KAAK,WAAW;;AAGhG,gBAAa,UAAU;AACvB;WACO,OAAO;AACd,gBAAa,UAAU;AAEvB,OAAI,iBAAiB,gBAAgB,MAAM,SAAS,aAClD,6BAAY,IAAI,MAAM,GAAG,MAAM,2BAA2B,QAAQ,IAAI;OAEtE,aAAY;AAGd,OAAI,CAAC,YAAY,MAAM,IAAI,YAAY,kBACrC,OAAM;AAGR,SAAM,IAAI,SAAc,MAAK,WAAW,GAAG,MAAM,KAAK,QAAQ,CAAC;;;AAInE,OAAM"}
1
+ {"version":3,"file":"http-ChVS9GYc.mjs","names":["PKG_VERSION"],"sources":["../src/shared/http.ts"],"sourcesContent":["/**\n * Minimal HTTP transport for drain adapters: abort-based timeouts, exponential\n * backoff on `5xx` / network errors, response bodies truncated in error messages.\n *\n * Identifies every outgoing request as coming from evlog via:\n * - `User-Agent: evlog/<version>` (Node / server runtimes only — browsers strip this)\n * - `X-Evlog-Source: <source>` when {@link HttpPostOptions.source} is set\n */\n\nimport { version as PKG_VERSION } from '../../package.json'\n\n/** Build-time evlog package version, e.g. `2.16.0`. */\nexport const EVLOG_VERSION: string = PKG_VERSION\n\n/** Default `User-Agent` value injected into outgoing drain requests. */\nexport const EVLOG_USER_AGENT = `evlog/${EVLOG_VERSION}`\n\nexport interface HttpPostOptions {\n url: string\n /** Caller is responsible for `Content-Type`. */\n headers: Record<string, string>\n /** Pre-serialized request body. */\n body: string\n /** Abort the request after this many milliseconds. */\n timeout: number\n /** Prefix used in error messages. */\n label: string\n /**\n * Retries network errors, aborts, and `5xx` responses with exponential backoff.\n * @default 2\n */\n retries?: number\n /**\n * Override the default `User-Agent: evlog/<version>` header. Pass `false` or\n * an empty string to suppress it entirely (e.g. when the underlying transport\n * forbids overriding `User-Agent`).\n */\n userAgent?: string | false\n /**\n * When set, sends `X-Evlog-Source: <source>` so the receiving system can\n * distinguish evlog traffic from other clients. Typically the adapter name\n * (`axiom`, `datadog`, ...) or `client` for browser-originated drains.\n */\n source?: string\n}\n\nfunction hasHeader(headers: Record<string, string>, target: string): boolean {\n const lower = target.toLowerCase()\n for (const key of Object.keys(headers)) {\n if (key.toLowerCase() === lower) return true\n }\n return false\n}\n\n/**\n * Returns a copy of `headers` with evlog identity headers injected when\n * absent. Caller-provided values always win.\n *\n * @internal Exposed for tests. Use {@link httpPost} from drains.\n */\nexport function withEvlogIdentityHeaders(\n headers: Record<string, string>,\n { userAgent, source }: { userAgent?: string | false; source?: string } = {},\n): Record<string, string> {\n const out = { ...headers }\n if (userAgent !== false && !hasHeader(out, 'user-agent')) {\n const ua = typeof userAgent === 'string' && userAgent.length > 0 ? userAgent : EVLOG_USER_AGENT\n out['User-Agent'] = ua\n }\n if (source && !hasHeader(out, 'x-evlog-source')) {\n out['X-Evlog-Source'] = source\n }\n return out\n}\n\nfunction isRetryable(error: unknown): boolean {\n if (error instanceof DOMException && error.name === 'AbortError') return true\n if (error instanceof TypeError) return true\n if (error instanceof Error) {\n const match = error.message.match(/API error: (\\d+)/)\n if (match) return Number.parseInt(match[1]) >= 500\n }\n return false\n}\n\n/**\n * POST a body with timeout + retry. Throws label-prefixed errors with a\n * truncated response body. Safe to call from any drain `send()`.\n */\nexport async function httpPost({ url, headers, body, timeout, label, retries = 2, userAgent, source }: HttpPostOptions): Promise<void> {\n const normalizedRetries = Number.isFinite(retries) && retries >= 0 ? Math.floor(retries) : 2\n const finalHeaders = withEvlogIdentityHeaders(headers, { userAgent, source })\n\n let lastError: Error | undefined\n\n for (let attempt = 0; attempt <= normalizedRetries; attempt++) {\n const controller = new AbortController()\n const timeoutId = setTimeout(() => controller.abort(), timeout)\n\n try {\n const response = await fetch(url, {\n method: 'POST',\n headers: finalHeaders,\n body,\n signal: controller.signal,\n })\n\n if (!response.ok) {\n const text = await response.text().catch(() => 'Unknown error')\n const safeText = text.length > 200 ? `${text.slice(0, 200)}...[truncated]` : text\n throw new Error(`${label} API error: ${response.status} ${response.statusText} - ${safeText}`)\n }\n\n clearTimeout(timeoutId)\n return\n } catch (error) {\n clearTimeout(timeoutId)\n\n if (error instanceof DOMException && error.name === 'AbortError') {\n lastError = new Error(`${label} request timed out after ${timeout}ms`)\n } else {\n lastError = error as Error\n }\n\n if (!isRetryable(error) || attempt === normalizedRetries) {\n throw lastError\n }\n\n await new Promise<void>(r => setTimeout(r, 200 * 2 ** attempt))\n }\n }\n\n throw lastError!\n}\n"],"mappings":";;;;;;;;;;;AAYA,MAAa,gBAAwBA;;AAGrC,MAAa,mBAAmB,SAAS;AA+BzC,SAAS,UAAU,SAAiC,QAAyB;CAC3E,MAAM,QAAQ,OAAO,aAAa;AAClC,MAAK,MAAM,OAAO,OAAO,KAAK,QAAQ,CACpC,KAAI,IAAI,aAAa,KAAK,MAAO,QAAO;AAE1C,QAAO;;;;;;;;AAST,SAAgB,yBACd,SACA,EAAE,WAAW,WAA4D,EAAE,EACnD;CACxB,MAAM,MAAM,EAAE,GAAG,SAAS;AAC1B,KAAI,cAAc,SAAS,CAAC,UAAU,KAAK,aAAa,CAEtD,KAAI,gBADO,OAAO,cAAc,YAAY,UAAU,SAAS,IAAI,YAAY;AAGjF,KAAI,UAAU,CAAC,UAAU,KAAK,iBAAiB,CAC7C,KAAI,oBAAoB;AAE1B,QAAO;;AAGT,SAAS,YAAY,OAAyB;AAC5C,KAAI,iBAAiB,gBAAgB,MAAM,SAAS,aAAc,QAAO;AACzE,KAAI,iBAAiB,UAAW,QAAO;AACvC,KAAI,iBAAiB,OAAO;EAC1B,MAAM,QAAQ,MAAM,QAAQ,MAAM,mBAAmB;AACrD,MAAI,MAAO,QAAO,OAAO,SAAS,MAAM,GAAG,IAAI;;AAEjD,QAAO;;;;;;AAOT,eAAsB,SAAS,EAAE,KAAK,SAAS,MAAM,SAAS,OAAO,UAAU,GAAG,WAAW,UAA0C;CACrI,MAAM,oBAAoB,OAAO,SAAS,QAAQ,IAAI,WAAW,IAAI,KAAK,MAAM,QAAQ,GAAG;CAC3F,MAAM,eAAe,yBAAyB,SAAS;EAAE;EAAW;EAAQ,CAAC;CAE7E,IAAI;AAEJ,MAAK,IAAI,UAAU,GAAG,WAAW,mBAAmB,WAAW;EAC7D,MAAM,aAAa,IAAI,iBAAiB;EACxC,MAAM,YAAY,iBAAiB,WAAW,OAAO,EAAE,QAAQ;AAE/D,MAAI;GACF,MAAM,WAAW,MAAM,MAAM,KAAK;IAChC,QAAQ;IACR,SAAS;IACT;IACA,QAAQ,WAAW;IACpB,CAAC;AAEF,OAAI,CAAC,SAAS,IAAI;IAChB,MAAM,OAAO,MAAM,SAAS,MAAM,CAAC,YAAY,gBAAgB;IAC/D,MAAM,WAAW,KAAK,SAAS,MAAM,GAAG,KAAK,MAAM,GAAG,IAAI,CAAC,kBAAkB;AAC7E,UAAM,IAAI,MAAM,GAAG,MAAM,cAAc,SAAS,OAAO,GAAG,SAAS,WAAW,KAAK,WAAW;;AAGhG,gBAAa,UAAU;AACvB;WACO,OAAO;AACd,gBAAa,UAAU;AAEvB,OAAI,iBAAiB,gBAAgB,MAAM,SAAS,aAClD,6BAAY,IAAI,MAAM,GAAG,MAAM,2BAA2B,QAAQ,IAAI;OAEtE,aAAY;AAGd,OAAI,CAAC,YAAY,MAAM,IAAI,YAAY,kBACrC,OAAM;AAGR,SAAM,IAAI,SAAc,MAAK,WAAW,GAAG,MAAM,KAAK,QAAQ,CAAC;;;AAInE,OAAM"}
package/dist/http.d.mts CHANGED
@@ -1,4 +1,4 @@
1
- import { B as DrainContext } from "./audit-BUAajsPU.mjs";
1
+ import { B as DrainContext } from "./audit-D7v6JHj0.mjs";
2
2
  import { DrainPipelineOptions, PipelineDrainFn } from "./pipeline.mjs";
3
3
 
4
4
  //#region src/http.d.ts
@@ -1,5 +1,5 @@
1
- import { A as AuditActionDefinition, L as AuditTarget } from "./audit-BUAajsPU.mjs";
2
- import { t as EvlogError } from "./error-DwajXSKM.mjs";
1
+ import { A as AuditActionDefinition, L as AuditTarget } from "./audit-D7v6JHj0.mjs";
2
+ import { t as EvlogError } from "./error-CpghjrkY.mjs";
3
3
  //#region src/catalog.d.ts
4
4
  /**
5
5
  * Static metadata for a single entry in an error catalog.
@@ -217,4 +217,4 @@ type AuditCatalog<TPrefix extends string, TMap extends AuditCatalogMap> = { [K i
217
217
  declare function defineAuditCatalog<const TPrefix extends string, const TMap extends AuditCatalogMap>(prefix: TPrefix, map: TMap): AuditCatalog<TPrefix, TMap>;
218
218
  //#endregion
219
219
  export { DefinedError as a, ErrorCatalogMap as c, defineAuditCatalog as d, defineError as f, DefinedCatalogAudit as i, ErrorFactoryOpts as l, AuditCatalogEntry as n, ErrorCatalog as o, defineErrorCatalog as p, AuditCatalogMap as r, ErrorCatalogEntry as s, AuditCatalog as t, ErrorFactoryOverrides as u };
220
- //# sourceMappingURL=index-CE7kH0II.d.mts.map
220
+ //# sourceMappingURL=index-EvnrXvQM.d.mts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-CE7kH0II.d.mts","names":[],"sources":["../src/catalog.ts"],"mappings":"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"}
1
+ {"version":3,"file":"index-EvnrXvQM.d.mts","names":[],"sources":["../src/catalog.ts"],"mappings":"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"}
package/dist/index.d.mts CHANGED
@@ -1,9 +1,9 @@
1
- import { $ as RedactConfig, A as AuditActionDefinition, B as DrainContext, C as buildAuditFields, Ct as enricherPlugin, D as withAudit, E as signed, F as AuditPatchOp, G as FieldContext, H as EnvironmentContext, I as AuditSeverity, J as InternalFields, K as H3EventContext, L as AuditTarget, M as AuditChanges, N as AuditFields, O as withAuditMethods, P as AuditLoggerMethod, Q as ParsedError, R as BaseWideEvent, S as auditRedactPreset, St as drainPlugin, T as mockAudit, U as ErrorCode, V as EnrichContext, W as ErrorOptions, X as LogLevel, Y as Log, Z as LoggerConfig, _ as WithAuditOptions, _t as PluginSetupContext, a as AuditInput, b as auditEnricher, c as AuditOnlyOptions, ct as ServerEvent, d as DefinedAuditAction, dt as TransportConfig, et as RegisteredAuditCatalogs, f as DrainFn, ft as WideEvent, g as WithAuditContext, gt as PluginRunner, h as SignedOptions, ht as EvlogPlugin, i as AuditEnricherOptions, it as RequestLoggerOptions, j as AuditActor, k as AuditAction, l as AuditableLogger, lt as TailSamplingCondition, m as SignedChainState, mt as ClientLogContext, n as AuditDeniedError, o as AuditMatcher, ot as SamplingConfig, p as MockAudit, q as IngestPayload, r as AuditDiffOptions, rt as RequestLogger, s as AuditMethod, st as SamplingRates, t as AUDIT_SCHEMA_VERSION, tt as RegisteredErrorCatalogs, u as DefineAuditActionOptions, ut as TailSamplingContext, v as audit, vt as RequestFinishContext, w as defineAuditAction, x as auditOnly, xt as definePlugin, y as auditDiff, yt as RequestLifecycleContext, z as DeepPartial } from "./audit-BUAajsPU.mjs";
2
- import { n as createError, t as EvlogError } from "./error-DwajXSKM.mjs";
3
- import { a as DefinedError, c as ErrorCatalogMap, d as defineAuditCatalog, f as defineError, i as DefinedCatalogAudit, l as ErrorFactoryOpts, n as AuditCatalogEntry, o as ErrorCatalog, p as defineErrorCatalog, r as AuditCatalogMap, s as ErrorCatalogEntry, t as AuditCatalog, u as ErrorFactoryOverrides } from "./index-CE7kH0II.mjs";
4
- import { c as isEnabled, i as getEnvironment, n as createLogger, p as shouldKeep, r as createRequestLogger, s as initLogger, t as _log } from "./logger-BccCJUyD.mjs";
5
- import { h as isLevelEnabled } from "./utils-DmNbZwBZ.mjs";
6
- import { t as useLogger } from "./useLogger-Dv52PDpH.mjs";
7
- import { t as parseError } from "./parseError-Cagr-Ctc.mjs";
8
- import { i as toMiddlewareOptions, n as defineEvlog, r as toLoggerConfig, t as EvlogConfig } from "./define-DGwZkZ7x.mjs";
1
+ import { $ as RedactConfig, A as AuditActionDefinition, B as DrainContext, C as buildAuditFields, Ct as enricherPlugin, D as withAudit, E as signed, F as AuditPatchOp, G as FieldContext, H as EnvironmentContext, I as AuditSeverity, J as InternalFields, K as H3EventContext, L as AuditTarget, M as AuditChanges, N as AuditFields, O as withAuditMethods, P as AuditLoggerMethod, Q as ParsedError, R as BaseWideEvent, S as auditRedactPreset, St as drainPlugin, T as mockAudit, U as ErrorCode, V as EnrichContext, W as ErrorOptions, X as LogLevel, Y as Log, Z as LoggerConfig, _ as WithAuditOptions, _t as PluginSetupContext, a as AuditInput, b as auditEnricher, c as AuditOnlyOptions, ct as ServerEvent, d as DefinedAuditAction, dt as TransportConfig, et as RegisteredAuditCatalogs, f as DrainFn, ft as WideEvent, g as WithAuditContext, gt as PluginRunner, h as SignedOptions, ht as EvlogPlugin, i as AuditEnricherOptions, it as RequestLoggerOptions, j as AuditActor, k as AuditAction, l as AuditableLogger, lt as TailSamplingCondition, m as SignedChainState, mt as ClientLogContext, n as AuditDeniedError, o as AuditMatcher, ot as SamplingConfig, p as MockAudit, q as IngestPayload, r as AuditDiffOptions, rt as RequestLogger, s as AuditMethod, st as SamplingRates, t as AUDIT_SCHEMA_VERSION, tt as RegisteredErrorCatalogs, u as DefineAuditActionOptions, ut as TailSamplingContext, v as audit, vt as RequestFinishContext, w as defineAuditAction, x as auditOnly, xt as definePlugin, y as auditDiff, yt as RequestLifecycleContext, z as DeepPartial } from "./audit-D7v6JHj0.mjs";
2
+ import { n as createError, t as EvlogError } from "./error-CpghjrkY.mjs";
3
+ import { a as DefinedError, c as ErrorCatalogMap, d as defineAuditCatalog, f as defineError, i as DefinedCatalogAudit, l as ErrorFactoryOpts, n as AuditCatalogEntry, o as ErrorCatalog, p as defineErrorCatalog, r as AuditCatalogMap, s as ErrorCatalogEntry, t as AuditCatalog, u as ErrorFactoryOverrides } from "./index-EvnrXvQM.mjs";
4
+ import { a as getEnvironment, c as initLogger, i as createRequestLogger, l as isEnabled, m as shouldKeep, n as _log, r as createLogger } from "./logger-mHIWxBhJ.mjs";
5
+ import { h as isLevelEnabled } from "./utils-CJJG0ZYW.mjs";
6
+ import { t as useLogger } from "./useLogger-Cfv8Ck8b.mjs";
7
+ import { t as parseError } from "./parseError-BeBXEd2V.mjs";
8
+ import { i as toMiddlewareOptions, n as defineEvlog, r as toLoggerConfig, t as EvlogConfig } from "./define-DTQpu4f6.mjs";
9
9
  export { AUDIT_SCHEMA_VERSION, AuditAction, AuditActionDefinition, AuditActor, AuditCatalog, AuditCatalogEntry, AuditCatalogMap, AuditChanges, AuditDeniedError, AuditDiffOptions, AuditEnricherOptions, AuditFields, AuditInput, AuditLoggerMethod, AuditMatcher, AuditMethod, AuditOnlyOptions, AuditPatchOp, AuditSeverity, AuditTarget, AuditableLogger, BaseWideEvent, ClientLogContext, DeepPartial, DefineAuditActionOptions, DefinedAuditAction, DefinedCatalogAudit, DefinedError, DrainContext, DrainFn, EnrichContext, EnvironmentContext, ErrorCatalog, ErrorCatalogEntry, ErrorCatalogMap, ErrorCode, ErrorFactoryOpts, ErrorFactoryOverrides, ErrorOptions, EvlogConfig, EvlogError, EvlogPlugin, FieldContext, H3EventContext, IngestPayload, InternalFields, Log, LogLevel, LoggerConfig, MockAudit, ParsedError, PluginRunner, PluginSetupContext, RedactConfig, RegisteredAuditCatalogs, RegisteredErrorCatalogs, RequestFinishContext, RequestLifecycleContext, RequestLogger, RequestLoggerOptions, SamplingConfig, SamplingRates, ServerEvent, SignedChainState, SignedOptions, TailSamplingCondition, TailSamplingContext, TransportConfig, WideEvent, WithAuditContext, WithAuditOptions, audit, auditDiff, auditEnricher, auditOnly, auditRedactPreset, buildAuditFields, createError, createError as createEvlogError, createLogger, createRequestLogger, defineAuditAction, defineAuditCatalog, defineError, defineErrorCatalog, defineEvlog, definePlugin, drainPlugin, enricherPlugin, getEnvironment, initLogger, isEnabled, isLevelEnabled, _log as log, mockAudit, parseError, shouldKeep, signed, toLoggerConfig, toMiddlewareOptions, useLogger, withAudit, withAuditMethods };
package/dist/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  import { isLevelEnabled } from "./utils.mjs";
2
- import { A as enricherPlugin, E as shouldKeep, O as definePlugin, _ as getEnvironment, a as auditEnricher, b as initLogger, c as buildAuditFields, d as signed, f as withAudit, g as createRequestLogger, h as createLogger, i as auditDiff, k as drainPlugin, l as defineAuditAction, m as _log, n as AuditDeniedError, o as auditOnly, p as withAuditMethods, r as audit, s as auditRedactPreset, t as AUDIT_SCHEMA_VERSION, u as mockAudit, x as isEnabled } from "./audit-BFwTUxBJ.mjs";
2
+ import { A as enricherPlugin, E as shouldKeep, O as definePlugin, _ as getEnvironment, a as auditEnricher, b as initLogger, c as buildAuditFields, d as signed, f as withAudit, g as createRequestLogger, h as createLogger, i as auditDiff, k as drainPlugin, l as defineAuditAction, m as _log, n as AuditDeniedError, o as auditOnly, p as withAuditMethods, r as audit, s as auditRedactPreset, t as AUDIT_SCHEMA_VERSION, u as mockAudit, x as isEnabled } from "./audit-BQt8yAHo.mjs";
3
3
  import { EvlogError, createError } from "./error.mjs";
4
4
  import { useLogger } from "./runtime/server/useLogger.mjs";
5
5
  import { parseError } from "./runtime/utils/parseError.mjs";