@interfere/next 0.2.0-alpha.6 → 0.2.0-alpha.9
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.
- package/README.md +119 -0
- package/package.json +28 -28
- package/dist/_virtual/_rolldown/runtime.mjs +0 -13
- package/dist/config.d.mts +0 -11
- package/dist/config.d.mts.map +0 -1
- package/dist/config.mjs +0 -107
- package/dist/config.mjs.map +0 -1
- package/dist/instrument-client.d.mts +0 -2
- package/dist/instrument-client.mjs +0 -2
- package/dist/internal/build/configure-build.d.mts +0 -22
- package/dist/internal/build/configure-build.d.mts.map +0 -1
- package/dist/internal/build/configure-build.mjs +0 -87
- package/dist/internal/build/configure-build.mjs.map +0 -1
- package/dist/internal/build/injected.d.mts +0 -12
- package/dist/internal/build/injected.d.mts.map +0 -1
- package/dist/internal/build/injected.mjs +0 -9
- package/dist/internal/build/injected.mjs.map +0 -1
- package/dist/internal/build/release/destinations/vercel.d.mts +0 -6
- package/dist/internal/build/release/destinations/vercel.d.mts.map +0 -1
- package/dist/internal/build/release/destinations/vercel.mjs +0 -25
- package/dist/internal/build/release/destinations/vercel.mjs.map +0 -1
- package/dist/internal/build/release/git.d.mts +0 -4
- package/dist/internal/build/release/git.d.mts.map +0 -1
- package/dist/internal/build/release/git.mjs +0 -21
- package/dist/internal/build/release/git.mjs.map +0 -1
- package/dist/internal/build/release/index.d.mts +0 -7
- package/dist/internal/build/release/index.d.mts.map +0 -1
- package/dist/internal/build/release/index.mjs +0 -24
- package/dist/internal/build/release/index.mjs.map +0 -1
- package/dist/internal/build/release/sources/github.d.mts +0 -6
- package/dist/internal/build/release/sources/github.d.mts.map +0 -1
- package/dist/internal/build/release/sources/github.mjs +0 -15
- package/dist/internal/build/release/sources/github.mjs.map +0 -1
- package/dist/internal/build/release/types.d.mts +0 -11
- package/dist/internal/build/release/types.d.mts.map +0 -1
- package/dist/internal/build/release/types.mjs +0 -1
- package/dist/internal/build/source-maps/discover.d.mts +0 -14
- package/dist/internal/build/source-maps/discover.d.mts.map +0 -1
- package/dist/internal/build/source-maps/discover.mjs +0 -61
- package/dist/internal/build/source-maps/discover.mjs.map +0 -1
- package/dist/internal/build/source-maps/index.d.mts +0 -23
- package/dist/internal/build/source-maps/index.d.mts.map +0 -1
- package/dist/internal/build/source-maps/index.mjs +0 -33
- package/dist/internal/build/source-maps/index.mjs.map +0 -1
- package/dist/internal/build/value-injection-loader.d.mts +0 -10
- package/dist/internal/build/value-injection-loader.d.mts.map +0 -1
- package/dist/internal/build/value-injection-loader.mjs +0 -24
- package/dist/internal/build/value-injection-loader.mjs.map +0 -1
- package/dist/internal/env.d.mts +0 -16
- package/dist/internal/env.d.mts.map +0 -1
- package/dist/internal/env.mjs +0 -19
- package/dist/internal/env.mjs.map +0 -1
- package/dist/internal/logger.d.mts +0 -8
- package/dist/internal/logger.d.mts.map +0 -1
- package/dist/internal/logger.mjs +0 -44
- package/dist/internal/logger.mjs.map +0 -1
- package/dist/internal/route/cors.d.mts +0 -4
- package/dist/internal/route/cors.d.mts.map +0 -1
- package/dist/internal/route/cors.mjs +0 -15
- package/dist/internal/route/cors.mjs.map +0 -1
- package/dist/internal/route/handle-get.d.mts +0 -4
- package/dist/internal/route/handle-get.d.mts.map +0 -1
- package/dist/internal/route/handle-get.mjs +0 -15
- package/dist/internal/route/handle-get.mjs.map +0 -1
- package/dist/internal/route/handle-post.d.mts +0 -4
- package/dist/internal/route/handle-post.d.mts.map +0 -1
- package/dist/internal/route/handle-post.mjs +0 -105
- package/dist/internal/route/handle-post.mjs.map +0 -1
- package/dist/internal/route/sw-script.d.mts +0 -4
- package/dist/internal/route/sw-script.d.mts.map +0 -1
- package/dist/internal/route/sw-script.mjs +0 -32
- package/dist/internal/route/sw-script.mjs.map +0 -1
- package/dist/internal/server/capture.d.mts +0 -9
- package/dist/internal/server/capture.d.mts.map +0 -1
- package/dist/internal/server/capture.mjs +0 -46
- package/dist/internal/server/capture.mjs.map +0 -1
- package/dist/internal/server/dedupe.d.mts +0 -5
- package/dist/internal/server/dedupe.d.mts.map +0 -1
- package/dist/internal/server/dedupe.mjs +0 -11
- package/dist/internal/server/dedupe.mjs.map +0 -1
- package/dist/internal/server/envelope.d.mts +0 -14
- package/dist/internal/server/envelope.d.mts.map +0 -1
- package/dist/internal/server/envelope.mjs +0 -41
- package/dist/internal/server/envelope.mjs.map +0 -1
- package/dist/internal/server/mechanisms.d.mts +0 -7
- package/dist/internal/server/mechanisms.d.mts.map +0 -1
- package/dist/internal/server/mechanisms.mjs +0 -12
- package/dist/internal/server/mechanisms.mjs.map +0 -1
- package/dist/internal/server/normalize-request.d.mts +0 -7
- package/dist/internal/server/normalize-request.d.mts.map +0 -1
- package/dist/internal/server/normalize-request.mjs +0 -50
- package/dist/internal/server/normalize-request.mjs.map +0 -1
- package/dist/internal/server/runtime.d.mts +0 -14
- package/dist/internal/server/runtime.d.mts.map +0 -1
- package/dist/internal/server/runtime.mjs +0 -18
- package/dist/internal/server/runtime.mjs.map +0 -1
- package/dist/internal/server/session.d.mts +0 -11
- package/dist/internal/server/session.d.mts.map +0 -1
- package/dist/internal/server/session.mjs +0 -15
- package/dist/internal/server/session.mjs.map +0 -1
- package/dist/internal/server/transport.d.mts +0 -12
- package/dist/internal/server/transport.d.mts.map +0 -1
- package/dist/internal/server/transport.mjs +0 -17
- package/dist/internal/server/transport.mjs.map +0 -1
- package/dist/internal/server/types.d.mts +0 -17
- package/dist/internal/server/types.d.mts.map +0 -1
- package/dist/internal/server/types.mjs +0 -1
- package/dist/provider.d.mts +0 -2
- package/dist/provider.mjs +0 -3
- package/dist/route-handler.d.mts +0 -7
- package/dist/route-handler.d.mts.map +0 -1
- package/dist/route-handler.mjs +0 -18
- package/dist/route-handler.mjs.map +0 -1
- package/dist/server.d.mts +0 -8
- package/dist/server.d.mts.map +0 -1
- package/dist/server.mjs +0 -6
- package/dist/server.mjs.map +0 -1
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
//#region src/internal/route/sw-script.ts
|
|
2
|
-
const SW_SCRIPT = `\
|
|
3
|
-
importScripts('https://storage.googleapis.com/workbox-cdn/releases/7.3.0/workbox-sw.js');
|
|
4
|
-
|
|
5
|
-
self.addEventListener('install', function() { self.skipWaiting(); });
|
|
6
|
-
self.addEventListener('activate', function(e) { e.waitUntil(self.clients.claim()); });
|
|
7
|
-
|
|
8
|
-
workbox.setConfig({ debug: false });
|
|
9
|
-
|
|
10
|
-
workbox.routing.registerRoute(
|
|
11
|
-
function(ctx) {
|
|
12
|
-
return ctx.request.method === 'POST' && ctx.url.pathname.startsWith('/api/interfere/');
|
|
13
|
-
},
|
|
14
|
-
new workbox.strategies.NetworkOnly({
|
|
15
|
-
plugins: [
|
|
16
|
-
new workbox.backgroundSync.BackgroundSyncPlugin('interfere-queue', {
|
|
17
|
-
maxRetentionTime: 1440,
|
|
18
|
-
}),
|
|
19
|
-
{
|
|
20
|
-
fetchDidSucceed: function(ctx) {
|
|
21
|
-
if (ctx.response.status >= 500) {
|
|
22
|
-
throw new Error(ctx.request.url + ' returned ' + ctx.response.status);
|
|
23
|
-
}
|
|
24
|
-
return ctx.response;
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
],
|
|
28
|
-
}),
|
|
29
|
-
'POST'
|
|
30
|
-
);`;
|
|
31
|
-
//#endregion
|
|
32
|
-
export { SW_SCRIPT };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sw-script.mjs","names":[],"sources":["../../../src/internal/route/sw-script.ts"],"sourcesContent":["export const SW_SCRIPT = `\\\nimportScripts('https://storage.googleapis.com/workbox-cdn/releases/7.3.0/workbox-sw.js');\n\nself.addEventListener('install', function() { self.skipWaiting(); });\nself.addEventListener('activate', function(e) { e.waitUntil(self.clients.claim()); });\n\nworkbox.setConfig({ debug: false });\n\nworkbox.routing.registerRoute(\n function(ctx) {\n return ctx.request.method === 'POST' && ctx.url.pathname.startsWith('/api/interfere/');\n },\n new workbox.strategies.NetworkOnly({\n plugins: [\n new workbox.backgroundSync.BackgroundSyncPlugin('interfere-queue', {\n maxRetentionTime: 1440,\n }),\n {\n fetchDidSucceed: function(ctx) {\n if (ctx.response.status >= 500) {\n throw new Error(ctx.request.url + ' returned ' + ctx.response.status);\n }\n return ctx.response;\n },\n },\n ],\n }),\n 'POST'\n);`;\n"],"mappings":";AAAA,MAAa,YAAY"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { CaptureErrorContext, OnRequestErrorContext } from "./types.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/internal/server/capture.d.ts
|
|
4
|
-
declare function captureServerError(error: unknown, request?: unknown, context?: CaptureErrorContext): Promise<void>;
|
|
5
|
-
declare function captureOnRequestError(error: Error & {
|
|
6
|
-
digest?: string;
|
|
7
|
-
}, request: unknown, context: OnRequestErrorContext): Promise<void>;
|
|
8
|
-
//#endregion
|
|
9
|
-
export { captureOnRequestError, captureServerError };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"capture.d.mts","names":[],"sources":["../../../src/internal/server/capture.ts"],"mappings":";;;iBAcsB,kBAAA,CACpB,KAAA,WACA,OAAA,YACA,OAAA,GAAU,mBAAA,GACT,OAAA;AAAA,iBA4BmB,qBAAA,CACpB,KAAA,EAAO,KAAA;EAAU,MAAA;AAAA,GACjB,OAAA,WACA,OAAA,EAAS,qBAAA,GACR,OAAA"}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import { isErrorCaptured, markErrorCaptured } from "./dedupe.mjs";
|
|
2
|
-
import { ON_REQUEST_ERROR_MECHANISM } from "./mechanisms.mjs";
|
|
3
|
-
import { buildErrorEnvelope } from "./envelope.mjs";
|
|
4
|
-
import { normalizeRequest } from "./normalize-request.mjs";
|
|
5
|
-
import { resolveServerCaptureRuntime } from "./runtime.mjs";
|
|
6
|
-
import { sendEnvelope } from "./transport.mjs";
|
|
7
|
-
//#region src/internal/server/capture.ts
|
|
8
|
-
const DEFAULT_REQUEST = {
|
|
9
|
-
method: "GET",
|
|
10
|
-
path: "/",
|
|
11
|
-
headers: new Headers()
|
|
12
|
-
};
|
|
13
|
-
async function captureServerError(error, request, context) {
|
|
14
|
-
const runtime = resolveServerCaptureRuntime();
|
|
15
|
-
if (runtime.apiKey === null) return;
|
|
16
|
-
const normalizedRequest = normalizeRequest(request);
|
|
17
|
-
const envelope = buildErrorEnvelope({
|
|
18
|
-
error,
|
|
19
|
-
request: normalizedRequest,
|
|
20
|
-
context,
|
|
21
|
-
runtime
|
|
22
|
-
});
|
|
23
|
-
try {
|
|
24
|
-
await sendEnvelope({
|
|
25
|
-
envelope,
|
|
26
|
-
runtime,
|
|
27
|
-
traceparent: context?.traceparent ?? normalizedRequest?.headers.get("traceparent") ?? void 0
|
|
28
|
-
});
|
|
29
|
-
} catch {}
|
|
30
|
-
}
|
|
31
|
-
async function captureOnRequestError(error, request, context) {
|
|
32
|
-
if (isErrorCaptured(error)) return;
|
|
33
|
-
markErrorCaptured(error);
|
|
34
|
-
const normalizedRequest = normalizeRequest(request) ?? DEFAULT_REQUEST;
|
|
35
|
-
await captureServerError(error, normalizedRequest, {
|
|
36
|
-
mechanism: ON_REQUEST_ERROR_MECHANISM,
|
|
37
|
-
nextjs: {
|
|
38
|
-
...context,
|
|
39
|
-
requestMethod: normalizedRequest.method,
|
|
40
|
-
requestPath: normalizedRequest.path,
|
|
41
|
-
...error.digest ? { errorDigest: error.digest } : {}
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
//#endregion
|
|
46
|
-
export { captureOnRequestError, captureServerError };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"capture.mjs","names":[],"sources":["../../../src/internal/server/capture.ts"],"sourcesContent":["import { isErrorCaptured, markErrorCaptured } from \"./dedupe.js\";\nimport { buildErrorEnvelope } from \"./envelope.js\";\nimport { ON_REQUEST_ERROR_MECHANISM } from \"./mechanisms.js\";\nimport { normalizeRequest, TRACEPARENT_HEADER } from \"./normalize-request.js\";\nimport { resolveServerCaptureRuntime } from \"./runtime.js\";\nimport { sendEnvelope } from \"./transport.js\";\nimport type { CaptureErrorContext, OnRequestErrorContext } from \"./types.js\";\n\nconst DEFAULT_REQUEST = {\n method: \"GET\",\n path: \"/\",\n headers: new Headers(),\n};\n\nexport async function captureServerError(\n error: unknown,\n request?: unknown,\n context?: CaptureErrorContext\n): Promise<void> {\n const runtime = resolveServerCaptureRuntime();\n if (runtime.apiKey === null) {\n return;\n }\n\n const normalizedRequest = normalizeRequest(request);\n const envelope = buildErrorEnvelope({\n error,\n request: normalizedRequest,\n context,\n runtime,\n });\n\n try {\n await sendEnvelope({\n envelope,\n runtime,\n traceparent:\n context?.traceparent ??\n normalizedRequest?.headers.get(TRACEPARENT_HEADER) ??\n undefined,\n });\n } catch {\n /* best-effort */\n }\n}\n\nexport async function captureOnRequestError(\n error: Error & { digest?: string },\n request: unknown,\n context: OnRequestErrorContext\n): Promise<void> {\n if (isErrorCaptured(error)) {\n return;\n }\n markErrorCaptured(error);\n\n const normalizedRequest = normalizeRequest(request) ?? DEFAULT_REQUEST;\n\n await captureServerError(error, normalizedRequest, {\n mechanism: ON_REQUEST_ERROR_MECHANISM,\n nextjs: {\n ...context,\n requestMethod: normalizedRequest.method,\n requestPath: normalizedRequest.path,\n ...(error.digest ? { errorDigest: error.digest } : {}),\n },\n });\n}\n"],"mappings":";;;;;;;AAQA,MAAM,kBAAkB;CACtB,QAAQ;CACR,MAAM;CACN,SAAS,IAAI,SAAS;CACvB;AAED,eAAsB,mBACpB,OACA,SACA,SACe;CACf,MAAM,UAAU,6BAA6B;AAC7C,KAAI,QAAQ,WAAW,KACrB;CAGF,MAAM,oBAAoB,iBAAiB,QAAQ;CACnD,MAAM,WAAW,mBAAmB;EAClC;EACA,SAAS;EACT;EACA;EACD,CAAC;AAEF,KAAI;AACF,QAAM,aAAa;GACjB;GACA;GACA,aACE,SAAS,eACT,mBAAmB,QAAQ,IAAA,cAAuB,IAClD,KAAA;GACH,CAAC;SACI;;AAKV,eAAsB,sBACpB,OACA,SACA,SACe;AACf,KAAI,gBAAgB,MAAM,CACxB;AAEF,mBAAkB,MAAM;CAExB,MAAM,oBAAoB,iBAAiB,QAAQ,IAAI;AAEvD,OAAM,mBAAmB,OAAO,mBAAmB;EACjD,WAAW;EACX,QAAQ;GACN,GAAG;GACH,eAAe,kBAAkB;GACjC,aAAa,kBAAkB;GAC/B,GAAI,MAAM,SAAS,EAAE,aAAa,MAAM,QAAQ,GAAG,EAAE;GACtD;EACF,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dedupe.d.mts","names":[],"sources":["../../../src/internal/server/dedupe.ts"],"mappings":";iBAEgB,eAAA,CAAgB,KAAA;AAAA,iBAIhB,iBAAA,CAAkB,KAAA"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
//#region src/internal/server/dedupe.ts
|
|
2
|
-
const seenErrors = /* @__PURE__ */ new WeakSet();
|
|
3
|
-
function isErrorCaptured(error) {
|
|
4
|
-
return error instanceof Error && seenErrors.has(error);
|
|
5
|
-
}
|
|
6
|
-
function markErrorCaptured(error) {
|
|
7
|
-
if (!(error instanceof Error)) return;
|
|
8
|
-
seenErrors.add(error);
|
|
9
|
-
}
|
|
10
|
-
//#endregion
|
|
11
|
-
export { isErrorCaptured, markErrorCaptured };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dedupe.mjs","names":[],"sources":["../../../src/internal/server/dedupe.ts"],"sourcesContent":["const seenErrors = new WeakSet<Error>();\n\nexport function isErrorCaptured(error: unknown): boolean {\n return error instanceof Error && seenErrors.has(error);\n}\n\nexport function markErrorCaptured(error: unknown): void {\n if (!(error instanceof Error)) {\n return;\n }\n\n seenErrors.add(error);\n}\n"],"mappings":";AAAA,MAAM,6BAAa,IAAI,SAAgB;AAEvC,SAAgB,gBAAgB,OAAyB;AACvD,QAAO,iBAAiB,SAAS,WAAW,IAAI,MAAM;;AAGxD,SAAgB,kBAAkB,OAAsB;AACtD,KAAI,EAAE,iBAAiB,OACrB;AAGF,YAAW,IAAI,MAAM"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { CaptureErrorContext, NormalizedRequest } from "./types.mjs";
|
|
2
|
-
import { ServerCaptureRuntime } from "./runtime.mjs";
|
|
3
|
-
import { Envelope } from "@interfere/types/sdk/envelope";
|
|
4
|
-
|
|
5
|
-
//#region src/internal/server/envelope.d.ts
|
|
6
|
-
interface BuildErrorEnvelopeParams {
|
|
7
|
-
readonly context?: CaptureErrorContext;
|
|
8
|
-
readonly error: unknown;
|
|
9
|
-
readonly request: NormalizedRequest | null;
|
|
10
|
-
readonly runtime: ServerCaptureRuntime;
|
|
11
|
-
}
|
|
12
|
-
declare function buildErrorEnvelope(params: BuildErrorEnvelopeParams): Envelope<"error">;
|
|
13
|
-
//#endregion
|
|
14
|
-
export { buildErrorEnvelope };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"envelope.d.mts","names":[],"sources":["../../../src/internal/server/envelope.ts"],"mappings":";;;;;UAWU,wBAAA;EAAA,SACC,OAAA,GAAU,mBAAA;EAAA,SACV,KAAA;EAAA,SACA,OAAA,EAAS,iBAAA;EAAA,SACT,OAAA,EAAS,oBAAA;AAAA;AAAA,iBAGJ,kBAAA,CACd,MAAA,EAAQ,wBAAA,GACP,QAAA"}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import { DEFAULT_ERROR_MECHANISM } from "./mechanisms.mjs";
|
|
2
|
-
import { resolveSession } from "./session.mjs";
|
|
3
|
-
import { toError, toExceptions } from "@interfere/types/sdk/errors";
|
|
4
|
-
import { v7 } from "uuid";
|
|
5
|
-
//#region src/internal/server/envelope.ts
|
|
6
|
-
function buildErrorEnvelope(params) {
|
|
7
|
-
const { error, request, context, runtime } = params;
|
|
8
|
-
const session = resolveSession(request?.headers ?? new Headers());
|
|
9
|
-
let nextjsContext;
|
|
10
|
-
if (context?.nextjs) nextjsContext = toNextjsContext(context.nextjs);
|
|
11
|
-
else if (request) nextjsContext = toNextjsRequestContext(request);
|
|
12
|
-
return {
|
|
13
|
-
uuid: v7(),
|
|
14
|
-
v: 0,
|
|
15
|
-
type: "error",
|
|
16
|
-
payload: { exceptions: toExceptions(toError(error), context?.mechanism ?? DEFAULT_ERROR_MECHANISM) },
|
|
17
|
-
clientTs: Date.now(),
|
|
18
|
-
runtime: runtime.runtime,
|
|
19
|
-
environment: runtime.environment,
|
|
20
|
-
buildId: runtime.buildId,
|
|
21
|
-
releaseId: runtime.releaseId,
|
|
22
|
-
sessionId: session.id,
|
|
23
|
-
...session.source ? { sessionSource: session.source } : {},
|
|
24
|
-
...nextjsContext ? { context: nextjsContext } : {}
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
function toNextjsRequestContext(request) {
|
|
28
|
-
return {
|
|
29
|
-
runtime: "nextjs",
|
|
30
|
-
requestMethod: request.method,
|
|
31
|
-
requestPath: request.path
|
|
32
|
-
};
|
|
33
|
-
}
|
|
34
|
-
function toNextjsContext(context) {
|
|
35
|
-
return {
|
|
36
|
-
runtime: "nextjs",
|
|
37
|
-
...context
|
|
38
|
-
};
|
|
39
|
-
}
|
|
40
|
-
//#endregion
|
|
41
|
-
export { buildErrorEnvelope };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"envelope.mjs","names":["uuidv7"],"sources":["../../../src/internal/server/envelope.ts"],"sourcesContent":["import type { Envelope } from \"@interfere/types/sdk/envelope\";\nimport { toError, toExceptions } from \"@interfere/types/sdk/errors\";\nimport type { NextjsContext } from \"@interfere/types/sdk/plugins/context/next\";\n\nimport { v7 as uuidv7 } from \"uuid\";\n\nimport { DEFAULT_ERROR_MECHANISM } from \"./mechanisms.js\";\nimport type { ServerCaptureRuntime } from \"./runtime.js\";\nimport { resolveSession } from \"./session.js\";\nimport type { CaptureErrorContext, NormalizedRequest } from \"./types.js\";\n\ninterface BuildErrorEnvelopeParams {\n readonly context?: CaptureErrorContext;\n readonly error: unknown;\n readonly request: NormalizedRequest | null;\n readonly runtime: ServerCaptureRuntime;\n}\n\nexport function buildErrorEnvelope(\n params: BuildErrorEnvelopeParams\n): Envelope<\"error\"> {\n const { error, request, context, runtime } = params;\n const session = resolveSession(request?.headers ?? new Headers());\n\n let nextjsContext: NextjsContext | undefined;\n if (context?.nextjs) {\n nextjsContext = toNextjsContext(context.nextjs);\n } else if (request) {\n nextjsContext = toNextjsRequestContext(request);\n }\n\n return {\n uuid: uuidv7(),\n v: 0,\n type: \"error\",\n payload: {\n exceptions: toExceptions(\n toError(error),\n context?.mechanism ?? DEFAULT_ERROR_MECHANISM\n ),\n },\n clientTs: Date.now(),\n runtime: runtime.runtime,\n environment: runtime.environment,\n buildId: runtime.buildId,\n releaseId: runtime.releaseId,\n sessionId: session.id,\n ...(session.source ? { sessionSource: session.source } : {}),\n ...(nextjsContext ? { context: nextjsContext } : {}),\n };\n}\n\nfunction toNextjsRequestContext(request: NormalizedRequest): NextjsContext {\n return {\n runtime: \"nextjs\",\n requestMethod: request.method,\n requestPath: request.path,\n };\n}\n\nfunction toNextjsContext(\n context: Omit<NextjsContext, \"runtime\">\n): NextjsContext {\n return {\n runtime: \"nextjs\",\n ...context,\n };\n}\n"],"mappings":";;;;;AAkBA,SAAgB,mBACd,QACmB;CACnB,MAAM,EAAE,OAAO,SAAS,SAAS,YAAY;CAC7C,MAAM,UAAU,eAAe,SAAS,WAAW,IAAI,SAAS,CAAC;CAEjE,IAAI;AACJ,KAAI,SAAS,OACX,iBAAgB,gBAAgB,QAAQ,OAAO;UACtC,QACT,iBAAgB,uBAAuB,QAAQ;AAGjD,QAAO;EACL,MAAMA,IAAQ;EACd,GAAG;EACH,MAAM;EACN,SAAS,EACP,YAAY,aACV,QAAQ,MAAM,EACd,SAAS,aAAa,wBACvB,EACF;EACD,UAAU,KAAK,KAAK;EACpB,SAAS,QAAQ;EACjB,aAAa,QAAQ;EACrB,SAAS,QAAQ;EACjB,WAAW,QAAQ;EACnB,WAAW,QAAQ;EACnB,GAAI,QAAQ,SAAS,EAAE,eAAe,QAAQ,QAAQ,GAAG,EAAE;EAC3D,GAAI,gBAAgB,EAAE,SAAS,eAAe,GAAG,EAAE;EACpD;;AAGH,SAAS,uBAAuB,SAA2C;AACzE,QAAO;EACL,SAAS;EACT,eAAe,QAAQ;EACvB,aAAa,QAAQ;EACtB;;AAGH,SAAS,gBACP,SACe;AACf,QAAO;EACL,SAAS;EACT,GAAG;EACJ"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { ErrorMechanism } from "@interfere/types/sdk/plugins/payload/errors";
|
|
2
|
-
|
|
3
|
-
//#region src/internal/server/mechanisms.d.ts
|
|
4
|
-
declare const DEFAULT_ERROR_MECHANISM: ErrorMechanism;
|
|
5
|
-
declare const ON_REQUEST_ERROR_MECHANISM: ErrorMechanism;
|
|
6
|
-
//#endregion
|
|
7
|
-
export { DEFAULT_ERROR_MECHANISM, ON_REQUEST_ERROR_MECHANISM };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mechanisms.d.mts","names":[],"sources":["../../../src/internal/server/mechanisms.ts"],"mappings":";;;cAEa,uBAAA,EAAyB,cAAA;AAAA,cAKzB,0BAAA,EAA4B,cAAA"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
//#region src/internal/server/mechanisms.ts
|
|
2
|
-
const DEFAULT_ERROR_MECHANISM = {
|
|
3
|
-
type: "captureError",
|
|
4
|
-
handled: true
|
|
5
|
-
};
|
|
6
|
-
const ON_REQUEST_ERROR_MECHANISM = {
|
|
7
|
-
type: "onRequestError",
|
|
8
|
-
handled: false,
|
|
9
|
-
synthetic: false
|
|
10
|
-
};
|
|
11
|
-
//#endregion
|
|
12
|
-
export { DEFAULT_ERROR_MECHANISM, ON_REQUEST_ERROR_MECHANISM };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mechanisms.mjs","names":[],"sources":["../../../src/internal/server/mechanisms.ts"],"sourcesContent":["import type { ErrorMechanism } from \"@interfere/types/sdk/plugins/payload/errors\";\n\nexport const DEFAULT_ERROR_MECHANISM: ErrorMechanism = {\n type: \"captureError\",\n handled: true,\n};\n\nexport const ON_REQUEST_ERROR_MECHANISM: ErrorMechanism = {\n type: \"onRequestError\",\n handled: false,\n synthetic: false,\n};\n"],"mappings":";AAEA,MAAa,0BAA0C;CACrD,MAAM;CACN,SAAS;CACV;AAED,MAAa,6BAA6C;CACxD,MAAM;CACN,SAAS;CACT,WAAW;CACZ"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { NormalizedRequest } from "./types.mjs";
|
|
2
|
-
|
|
3
|
-
//#region src/internal/server/normalize-request.d.ts
|
|
4
|
-
declare const TRACEPARENT_HEADER = "traceparent";
|
|
5
|
-
declare function normalizeRequest(request: unknown): NormalizedRequest | null;
|
|
6
|
-
//#endregion
|
|
7
|
-
export { TRACEPARENT_HEADER, normalizeRequest };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"normalize-request.d.mts","names":[],"sources":["../../../src/internal/server/normalize-request.ts"],"mappings":";;;cAEa,kBAAA;AAAA,iBAEG,gBAAA,CAAiB,OAAA,YAAmB,iBAAA"}
|
|
@@ -1,50 +0,0 @@
|
|
|
1
|
-
//#region src/internal/server/normalize-request.ts
|
|
2
|
-
const TRACEPARENT_HEADER = "traceparent";
|
|
3
|
-
function normalizeRequest(request) {
|
|
4
|
-
if (request instanceof Request) return {
|
|
5
|
-
method: normalizeMethod(request.method),
|
|
6
|
-
path: normalizePath(request.url),
|
|
7
|
-
headers: request.headers
|
|
8
|
-
};
|
|
9
|
-
if (typeof request !== "object" || request === null) return null;
|
|
10
|
-
const value = request;
|
|
11
|
-
return {
|
|
12
|
-
method: normalizeMethod(value.method),
|
|
13
|
-
path: normalizePath(typeof value.path === "string" ? value.path : toStringOrDefault(value.url)),
|
|
14
|
-
headers: normalizeHeaders(value.headers)
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
function normalizeMethod(value) {
|
|
18
|
-
if (typeof value !== "string") return "GET";
|
|
19
|
-
const method = value.trim();
|
|
20
|
-
return method.length > 0 ? method.toUpperCase() : "GET";
|
|
21
|
-
}
|
|
22
|
-
function normalizePath(value) {
|
|
23
|
-
if (value.length === 0) return "/";
|
|
24
|
-
try {
|
|
25
|
-
return new URL(value, "http://localhost").pathname || "/";
|
|
26
|
-
} catch {
|
|
27
|
-
return value.startsWith("/") ? value : `/${value}`;
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
function toStringOrDefault(value, fallback = "/") {
|
|
31
|
-
if (typeof value !== "string") return fallback;
|
|
32
|
-
const trimmed = value.trim();
|
|
33
|
-
return trimmed.length > 0 ? trimmed : fallback;
|
|
34
|
-
}
|
|
35
|
-
function normalizeHeaders(value) {
|
|
36
|
-
if (value instanceof Headers) return new Headers(value);
|
|
37
|
-
if (typeof value !== "object" || value === null) return new Headers();
|
|
38
|
-
const headers = new Headers();
|
|
39
|
-
for (const [key, headerValue] of Object.entries(value)) {
|
|
40
|
-
if (headerValue === void 0) continue;
|
|
41
|
-
if (Array.isArray(headerValue)) {
|
|
42
|
-
headers.set(key, headerValue.join(", "));
|
|
43
|
-
continue;
|
|
44
|
-
}
|
|
45
|
-
headers.set(key, String(headerValue));
|
|
46
|
-
}
|
|
47
|
-
return headers;
|
|
48
|
-
}
|
|
49
|
-
//#endregion
|
|
50
|
-
export { TRACEPARENT_HEADER, normalizeRequest };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"normalize-request.mjs","names":[],"sources":["../../../src/internal/server/normalize-request.ts"],"sourcesContent":["import type { NormalizedRequest } from \"./types.js\";\n\nexport const TRACEPARENT_HEADER = \"traceparent\";\n\nexport function normalizeRequest(request: unknown): NormalizedRequest | null {\n if (request instanceof Request) {\n return {\n method: normalizeMethod(request.method),\n path: normalizePath(request.url),\n headers: request.headers,\n };\n }\n\n if (typeof request !== \"object\" || request === null) {\n return null;\n }\n\n const value = request as {\n headers?: unknown;\n method?: unknown;\n path?: unknown;\n url?: unknown;\n };\n\n return {\n method: normalizeMethod(value.method),\n path: normalizePath(\n typeof value.path === \"string\" ? value.path : toStringOrDefault(value.url)\n ),\n headers: normalizeHeaders(value.headers),\n };\n}\n\nfunction normalizeMethod(value: unknown): string {\n if (typeof value !== \"string\") {\n return \"GET\";\n }\n\n const method = value.trim();\n return method.length > 0 ? method.toUpperCase() : \"GET\";\n}\n\nfunction normalizePath(value: string): string {\n if (value.length === 0) {\n return \"/\";\n }\n\n try {\n const parsed = new URL(value, \"http://localhost\");\n return parsed.pathname || \"/\";\n } catch {\n return value.startsWith(\"/\") ? value : `/${value}`;\n }\n}\n\nfunction toStringOrDefault(value: unknown, fallback = \"/\"): string {\n if (typeof value !== \"string\") {\n return fallback;\n }\n\n const trimmed = value.trim();\n return trimmed.length > 0 ? trimmed : fallback;\n}\n\nfunction normalizeHeaders(value: unknown): Headers {\n if (value instanceof Headers) {\n return new Headers(value);\n }\n\n if (typeof value !== \"object\" || value === null) {\n return new Headers();\n }\n\n const headers = new Headers();\n for (const [key, headerValue] of Object.entries(value)) {\n if (headerValue === undefined) {\n continue;\n }\n\n if (Array.isArray(headerValue)) {\n headers.set(key, headerValue.join(\", \"));\n continue;\n }\n\n headers.set(key, String(headerValue));\n }\n\n return headers;\n}\n"],"mappings":";AAEA,MAAa,qBAAqB;AAElC,SAAgB,iBAAiB,SAA4C;AAC3E,KAAI,mBAAmB,QACrB,QAAO;EACL,QAAQ,gBAAgB,QAAQ,OAAO;EACvC,MAAM,cAAc,QAAQ,IAAI;EAChC,SAAS,QAAQ;EAClB;AAGH,KAAI,OAAO,YAAY,YAAY,YAAY,KAC7C,QAAO;CAGT,MAAM,QAAQ;AAOd,QAAO;EACL,QAAQ,gBAAgB,MAAM,OAAO;EACrC,MAAM,cACJ,OAAO,MAAM,SAAS,WAAW,MAAM,OAAO,kBAAkB,MAAM,IAAI,CAC3E;EACD,SAAS,iBAAiB,MAAM,QAAQ;EACzC;;AAGH,SAAS,gBAAgB,OAAwB;AAC/C,KAAI,OAAO,UAAU,SACnB,QAAO;CAGT,MAAM,SAAS,MAAM,MAAM;AAC3B,QAAO,OAAO,SAAS,IAAI,OAAO,aAAa,GAAG;;AAGpD,SAAS,cAAc,OAAuB;AAC5C,KAAI,MAAM,WAAW,EACnB,QAAO;AAGT,KAAI;AAEF,SADe,IAAI,IAAI,OAAO,mBAAmB,CACnC,YAAY;SACpB;AACN,SAAO,MAAM,WAAW,IAAI,GAAG,QAAQ,IAAI;;;AAI/C,SAAS,kBAAkB,OAAgB,WAAW,KAAa;AACjE,KAAI,OAAO,UAAU,SACnB,QAAO;CAGT,MAAM,UAAU,MAAM,MAAM;AAC5B,QAAO,QAAQ,SAAS,IAAI,UAAU;;AAGxC,SAAS,iBAAiB,OAAyB;AACjD,KAAI,iBAAiB,QACnB,QAAO,IAAI,QAAQ,MAAM;AAG3B,KAAI,OAAO,UAAU,YAAY,UAAU,KACzC,QAAO,IAAI,SAAS;CAGtB,MAAM,UAAU,IAAI,SAAS;AAC7B,MAAK,MAAM,CAAC,KAAK,gBAAgB,OAAO,QAAQ,MAAM,EAAE;AACtD,MAAI,gBAAgB,KAAA,EAClB;AAGF,MAAI,MAAM,QAAQ,YAAY,EAAE;AAC9B,WAAQ,IAAI,KAAK,YAAY,KAAK,KAAK,CAAC;AACxC;;AAGF,UAAQ,IAAI,KAAK,OAAO,YAAY,CAAC;;AAGvC,QAAO"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Env, Runtime } from "@interfere/types/sdk/runtime";
|
|
2
|
-
|
|
3
|
-
//#region src/internal/server/runtime.d.ts
|
|
4
|
-
interface ServerCaptureRuntime {
|
|
5
|
-
readonly apiKey: string | null;
|
|
6
|
-
readonly buildId: string;
|
|
7
|
-
readonly environment: Env;
|
|
8
|
-
readonly ingestUrl: string;
|
|
9
|
-
readonly releaseId: string | null;
|
|
10
|
-
readonly runtime: Runtime;
|
|
11
|
-
}
|
|
12
|
-
declare function resolveServerCaptureRuntime(): ServerCaptureRuntime;
|
|
13
|
-
//#endregion
|
|
14
|
-
export { ServerCaptureRuntime, resolveServerCaptureRuntime };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.d.mts","names":[],"sources":["../../../src/internal/server/runtime.ts"],"mappings":";;;UAMiB,oBAAA;EAAA,SACN,MAAA;EAAA,SACA,OAAA;EAAA,SACA,WAAA,EAAa,GAAA;EAAA,SACb,SAAA;EAAA,SACA,SAAA;EAAA,SACA,OAAA,EAAS,OAAA;AAAA;AAAA,iBAGJ,2BAAA,CAAA,GAA+B,oBAAA"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { readInterfereEnv } from "../env.mjs";
|
|
2
|
-
import { API_PATHS } from "@interfere/constants/api";
|
|
3
|
-
import { inferRuntime } from "@interfere/types/sdk/runtime";
|
|
4
|
-
//#region src/internal/server/runtime.ts
|
|
5
|
-
function resolveServerCaptureRuntime() {
|
|
6
|
-
const env = readInterfereEnv();
|
|
7
|
-
if (env.release.sourceId === null) throw new Error("[interfere] Missing NEXT_PUBLIC_INTERFERE_BUILD_ID at runtime. Ensure withInterfere() wraps your Next.js config.");
|
|
8
|
-
return {
|
|
9
|
-
apiKey: env.apiKey,
|
|
10
|
-
ingestUrl: `${env.apiUrl}${API_PATHS.INGEST}`,
|
|
11
|
-
environment: env.nodeEnvironment,
|
|
12
|
-
runtime: inferRuntime({ nextRuntime: env.nextRuntime }),
|
|
13
|
-
buildId: env.release.sourceId,
|
|
14
|
-
releaseId: env.release.destinationId
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
//#endregion
|
|
18
|
-
export { resolveServerCaptureRuntime };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.mjs","names":[],"sources":["../../../src/internal/server/runtime.ts"],"sourcesContent":["import { API_PATHS } from \"@interfere/constants/api\";\nimport type { Env, Runtime } from \"@interfere/types/sdk/runtime\";\nimport { inferRuntime } from \"@interfere/types/sdk/runtime\";\n\nimport { readInterfereEnv } from \"../env.js\";\n\nexport interface ServerCaptureRuntime {\n readonly apiKey: string | null;\n readonly buildId: string;\n readonly environment: Env;\n readonly ingestUrl: string;\n readonly releaseId: string | null;\n readonly runtime: Runtime;\n}\n\nexport function resolveServerCaptureRuntime(): ServerCaptureRuntime {\n const env = readInterfereEnv();\n\n if (env.release.sourceId === null) {\n throw new Error(\n \"[interfere] Missing NEXT_PUBLIC_INTERFERE_BUILD_ID at runtime. \" +\n \"Ensure withInterfere() wraps your Next.js config.\"\n );\n }\n\n return {\n apiKey: env.apiKey,\n ingestUrl: `${env.apiUrl}${API_PATHS.INGEST}`,\n environment: env.nodeEnvironment,\n runtime: inferRuntime({ nextRuntime: env.nextRuntime }),\n buildId: env.release.sourceId,\n releaseId: env.release.destinationId,\n };\n}\n"],"mappings":";;;;AAeA,SAAgB,8BAAoD;CAClE,MAAM,MAAM,kBAAkB;AAE9B,KAAI,IAAI,QAAQ,aAAa,KAC3B,OAAM,IAAI,MACR,mHAED;AAGH,QAAO;EACL,QAAQ,IAAI;EACZ,WAAW,GAAG,IAAI,SAAS,UAAU;EACrC,aAAa,IAAI;EACjB,SAAS,aAAa,EAAE,aAAa,IAAI,aAAa,CAAC;EACvD,SAAS,IAAI,QAAQ;EACrB,WAAW,IAAI,QAAQ;EACxB"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { SessionId } from "@interfere/types/data/session";
|
|
2
|
-
import { SessionSource } from "@interfere/types/sdk/envelope";
|
|
3
|
-
|
|
4
|
-
//#region src/internal/server/session.d.ts
|
|
5
|
-
declare const SESSION_HEADER = "x-interfere-session";
|
|
6
|
-
declare function resolveSession(headers: Headers): {
|
|
7
|
-
readonly id: SessionId | null;
|
|
8
|
-
readonly source?: SessionSource;
|
|
9
|
-
};
|
|
10
|
-
//#endregion
|
|
11
|
-
export { SESSION_HEADER, resolveSession };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.d.mts","names":[],"sources":["../../../src/internal/server/session.ts"],"mappings":";;;;cAIa,cAAA;AAAA,iBAEG,cAAA,CAAe,OAAA,EAAS,OAAA;EAAA,SAC7B,EAAA,EAAI,SAAA;EAAA,SACJ,MAAA,GAAS,aAAA;AAAA"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { sessionIdSchema } from "@interfere/types/data/session";
|
|
2
|
-
//#region src/internal/server/session.ts
|
|
3
|
-
const SESSION_HEADER = "x-interfere-session";
|
|
4
|
-
function resolveSession(headers) {
|
|
5
|
-
const sessionId = headers.get(SESSION_HEADER);
|
|
6
|
-
if (sessionId === null) return { id: null };
|
|
7
|
-
const parsed = sessionIdSchema.safeParse(sessionId);
|
|
8
|
-
if (!parsed.success) return { id: null };
|
|
9
|
-
return {
|
|
10
|
-
id: parsed.data,
|
|
11
|
-
source: "header"
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
//#endregion
|
|
15
|
-
export { SESSION_HEADER, resolveSession };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"session.mjs","names":[],"sources":["../../../src/internal/server/session.ts"],"sourcesContent":["import type { SessionId } from \"@interfere/types/data/session\";\nimport { sessionIdSchema } from \"@interfere/types/data/session\";\nimport type { SessionSource } from \"@interfere/types/sdk/envelope\";\n\nexport const SESSION_HEADER = \"x-interfere-session\";\n\nexport function resolveSession(headers: Headers): {\n readonly id: SessionId | null;\n readonly source?: SessionSource;\n} {\n const sessionId = headers.get(SESSION_HEADER);\n if (sessionId === null) {\n return { id: null };\n }\n\n const parsed = sessionIdSchema.safeParse(sessionId);\n if (!parsed.success) {\n return { id: null };\n }\n\n return {\n id: parsed.data,\n source: \"header\",\n };\n}\n"],"mappings":";;AAIA,MAAa,iBAAiB;AAE9B,SAAgB,eAAe,SAG7B;CACA,MAAM,YAAY,QAAQ,IAAI,eAAe;AAC7C,KAAI,cAAc,KAChB,QAAO,EAAE,IAAI,MAAM;CAGrB,MAAM,SAAS,gBAAgB,UAAU,UAAU;AACnD,KAAI,CAAC,OAAO,QACV,QAAO,EAAE,IAAI,MAAM;AAGrB,QAAO;EACL,IAAI,OAAO;EACX,QAAQ;EACT"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { ServerCaptureRuntime } from "./runtime.mjs";
|
|
2
|
-
import { Envelope } from "@interfere/types/sdk/envelope";
|
|
3
|
-
|
|
4
|
-
//#region src/internal/server/transport.d.ts
|
|
5
|
-
interface SendEnvelopeInput {
|
|
6
|
-
readonly envelope: Envelope<"error">;
|
|
7
|
-
readonly runtime: ServerCaptureRuntime;
|
|
8
|
-
readonly traceparent?: string;
|
|
9
|
-
}
|
|
10
|
-
declare function sendEnvelope(input: SendEnvelopeInput): Promise<void>;
|
|
11
|
-
//#endregion
|
|
12
|
-
export { SendEnvelopeInput, sendEnvelope };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transport.d.mts","names":[],"sources":["../../../src/internal/server/transport.ts"],"mappings":";;;;UAIiB,iBAAA;EAAA,SACN,QAAA,EAAU,QAAA;EAAA,SACV,OAAA,EAAS,oBAAA;EAAA,SACT,WAAA;AAAA;AAAA,iBAGW,YAAA,CAAa,KAAA,EAAO,iBAAA,GAAoB,OAAA"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
//#region src/internal/server/transport.ts
|
|
2
|
-
async function sendEnvelope(input) {
|
|
3
|
-
const { envelope, runtime, traceparent } = input;
|
|
4
|
-
if (runtime.apiKey === null) return;
|
|
5
|
-
await fetch(runtime.ingestUrl, {
|
|
6
|
-
method: "POST",
|
|
7
|
-
headers: {
|
|
8
|
-
"content-type": "application/json",
|
|
9
|
-
"x-api-key": runtime.apiKey,
|
|
10
|
-
...traceparent ? { traceparent } : {}
|
|
11
|
-
},
|
|
12
|
-
body: JSON.stringify([envelope]),
|
|
13
|
-
keepalive: true
|
|
14
|
-
});
|
|
15
|
-
}
|
|
16
|
-
//#endregion
|
|
17
|
-
export { sendEnvelope };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"transport.mjs","names":[],"sources":["../../../src/internal/server/transport.ts"],"sourcesContent":["import type { Envelope } from \"@interfere/types/sdk/envelope\";\n\nimport type { ServerCaptureRuntime } from \"./runtime.js\";\n\nexport interface SendEnvelopeInput {\n readonly envelope: Envelope<\"error\">;\n readonly runtime: ServerCaptureRuntime;\n readonly traceparent?: string;\n}\n\nexport async function sendEnvelope(input: SendEnvelopeInput): Promise<void> {\n const { envelope, runtime, traceparent } = input;\n\n if (runtime.apiKey === null) {\n return;\n }\n\n await fetch(runtime.ingestUrl, {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"x-api-key\": runtime.apiKey,\n ...(traceparent ? { traceparent } : {}),\n },\n body: JSON.stringify([envelope]),\n keepalive: true,\n });\n}\n"],"mappings":";AAUA,eAAsB,aAAa,OAAyC;CAC1E,MAAM,EAAE,UAAU,SAAS,gBAAgB;AAE3C,KAAI,QAAQ,WAAW,KACrB;AAGF,OAAM,MAAM,QAAQ,WAAW;EAC7B,QAAQ;EACR,SAAS;GACP,gBAAgB;GAChB,aAAa,QAAQ;GACrB,GAAI,cAAc,EAAE,aAAa,GAAG,EAAE;GACvC;EACD,MAAM,KAAK,UAAU,CAAC,SAAS,CAAC;EAChC,WAAW;EACZ,CAAC"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { NextjsContext } from "@interfere/types/sdk/plugins/context/next";
|
|
2
|
-
import { ErrorMechanism } from "@interfere/types/sdk/plugins/payload/errors";
|
|
3
|
-
|
|
4
|
-
//#region src/internal/server/types.d.ts
|
|
5
|
-
type OnRequestErrorContext = Omit<NextjsContext, "errorDigest" | "requestMethod" | "requestPath" | "runtime">;
|
|
6
|
-
interface CaptureErrorContext {
|
|
7
|
-
readonly mechanism?: ErrorMechanism;
|
|
8
|
-
readonly nextjs?: Omit<NextjsContext, "runtime">;
|
|
9
|
-
readonly traceparent?: string;
|
|
10
|
-
}
|
|
11
|
-
interface NormalizedRequest {
|
|
12
|
-
readonly headers: Headers;
|
|
13
|
-
readonly method: string;
|
|
14
|
-
readonly path: string;
|
|
15
|
-
}
|
|
16
|
-
//#endregion
|
|
17
|
-
export { CaptureErrorContext, NormalizedRequest, OnRequestErrorContext };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.mts","names":[],"sources":["../../../src/internal/server/types.ts"],"mappings":";;;;KAGY,qBAAA,GAAwB,IAAA,CAClC,aAAA;AAAA,UAIe,mBAAA;EAAA,SACN,SAAA,GAAY,cAAA;EAAA,SACZ,MAAA,GAAS,IAAA,CAAK,aAAA;EAAA,SACd,WAAA;AAAA;AAAA,UAGM,iBAAA;EAAA,SACN,OAAA,EAAS,OAAA;EAAA,SACT,MAAA;EAAA,SACA,IAAA;AAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/dist/provider.d.mts
DELETED
package/dist/provider.mjs
DELETED
package/dist/route-handler.d.mts
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
//#region src/route-handler.d.ts
|
|
2
|
-
declare function GET(request: Request): Response;
|
|
3
|
-
declare function POST(request: Request): Promise<Response>;
|
|
4
|
-
declare function PUT(request: Request): Promise<Response>;
|
|
5
|
-
declare function OPTIONS(): Response;
|
|
6
|
-
//#endregion
|
|
7
|
-
export { GET, OPTIONS, POST, PUT };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"route-handler.d.mts","names":[],"sources":["../src/route-handler.ts"],"mappings":";iBAIgB,GAAA,CAAI,OAAA,EAAS,OAAA,GAAU,QAAA;AAAA,iBAIvB,IAAA,CAAK,OAAA,EAAS,OAAA,GAAU,OAAA,CAAQ,QAAA;AAAA,iBAIhC,GAAA,CAAI,OAAA,EAAS,OAAA,GAAU,OAAA,CAAQ,QAAA;AAAA,iBAI/B,OAAA,CAAA,GAAW,QAAA"}
|
package/dist/route-handler.mjs
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { handleOptions } from "./internal/route/cors.mjs";
|
|
2
|
-
import { handleGet } from "./internal/route/handle-get.mjs";
|
|
3
|
-
import { handlePost } from "./internal/route/handle-post.mjs";
|
|
4
|
-
//#region src/route-handler.ts
|
|
5
|
-
function GET(request) {
|
|
6
|
-
return handleGet(request);
|
|
7
|
-
}
|
|
8
|
-
function POST(request) {
|
|
9
|
-
return handlePost(request);
|
|
10
|
-
}
|
|
11
|
-
function PUT(request) {
|
|
12
|
-
return handlePost(request);
|
|
13
|
-
}
|
|
14
|
-
function OPTIONS() {
|
|
15
|
-
return handleOptions();
|
|
16
|
-
}
|
|
17
|
-
//#endregion
|
|
18
|
-
export { GET, OPTIONS, POST, PUT };
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"route-handler.mjs","names":[],"sources":["../src/route-handler.ts"],"sourcesContent":["import { handleOptions } from \"./internal/route/cors.js\";\nimport { handleGet } from \"./internal/route/handle-get.js\";\nimport { handlePost } from \"./internal/route/handle-post.js\";\n\nexport function GET(request: Request): Response {\n return handleGet(request);\n}\n\nexport function POST(request: Request): Promise<Response> {\n return handlePost(request);\n}\n\nexport function PUT(request: Request): Promise<Response> {\n return handlePost(request);\n}\n\nexport function OPTIONS(): Response {\n return handleOptions();\n}\n"],"mappings":";;;;AAIA,SAAgB,IAAI,SAA4B;AAC9C,QAAO,UAAU,QAAQ;;AAG3B,SAAgB,KAAK,SAAqC;AACxD,QAAO,WAAW,QAAQ;;AAG5B,SAAgB,IAAI,SAAqC;AACvD,QAAO,WAAW,QAAQ;;AAG5B,SAAgB,UAAoB;AAClC,QAAO,eAAe"}
|
package/dist/server.d.mts
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { CaptureErrorContext, OnRequestErrorContext } from "./internal/server/types.mjs";
|
|
2
|
-
import { captureOnRequestError, captureServerError } from "./internal/server/capture.mjs";
|
|
3
|
-
|
|
4
|
-
//#region src/server.d.ts
|
|
5
|
-
declare const captureError: typeof captureServerError;
|
|
6
|
-
declare const onRequestError: typeof captureOnRequestError;
|
|
7
|
-
//#endregion
|
|
8
|
-
export { type CaptureErrorContext, type OnRequestErrorContext, captureError, onRequestError };
|
package/dist/server.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.mts","names":[],"sources":["../src/server.ts"],"mappings":";;;;cAUa,YAAA,SAAY,kBAAA;AAAA,cACZ,cAAA,SAAc,qBAAA"}
|
package/dist/server.mjs
DELETED
package/dist/server.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"server.mjs","names":[],"sources":["../src/server.ts"],"sourcesContent":["import {\n captureOnRequestError,\n captureServerError,\n} from \"./internal/server/capture.js\";\n\nexport type {\n CaptureErrorContext,\n OnRequestErrorContext,\n} from \"./internal/server/types.js\";\n\nexport const captureError = captureServerError;\nexport const onRequestError = captureOnRequestError;\n"],"mappings":";;AAUA,MAAa,eAAe;AAC5B,MAAa,iBAAiB"}
|