@riddance/host 0.0.9 → 0.0.11
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/context.d.ts +0 -7
- package/context.js +1 -19
- package/host/context.d.ts +0 -1
- package/host/context.js +5 -17
- package/host/emitter.js +47 -60
- package/host/http.js +8 -2
- package/host/logging.js +69 -83
- package/host/reflect.js +1 -1
- package/host/registry.js +1 -1
- package/http.js +1 -1
- package/package.json +38 -38
package/context.d.ts
CHANGED
|
@@ -81,13 +81,6 @@ export interface Context {
|
|
|
81
81
|
export declare function httpRequestHeaders(context: Context): {
|
|
82
82
|
[key: string]: string;
|
|
83
83
|
};
|
|
84
|
-
export declare function throwOnNotOK<T extends {
|
|
85
|
-
ok?: boolean;
|
|
86
|
-
status?: number;
|
|
87
|
-
text?: () => Promise<string>;
|
|
88
|
-
}>(response: T, message: string, data?: {
|
|
89
|
-
[key: string]: unknown;
|
|
90
|
-
}): Promise<T>;
|
|
91
84
|
export declare function measure<T>(logger: {
|
|
92
85
|
trace: (message: string, _: undefined, f: object) => void;
|
|
93
86
|
}, name: string, fn: () => Promise<T> | T, fields?: object): Promise<T>;
|
package/context.js
CHANGED
|
@@ -34,24 +34,6 @@ export function httpRequestHeaders(context) {
|
|
|
34
34
|
}
|
|
35
35
|
return headers;
|
|
36
36
|
}
|
|
37
|
-
export async function throwOnNotOK(response, message, data) {
|
|
38
|
-
if (response.ok === false) {
|
|
39
|
-
throw Object.assign(new Error(message), {
|
|
40
|
-
response: {
|
|
41
|
-
status: response.status,
|
|
42
|
-
body: limitSize(await response.text?.()),
|
|
43
|
-
},
|
|
44
|
-
...data,
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
return response;
|
|
48
|
-
}
|
|
49
|
-
function limitSize(text) {
|
|
50
|
-
if ((text?.length ?? 0) > 2048) {
|
|
51
|
-
return text?.substring(0, 2048);
|
|
52
|
-
}
|
|
53
|
-
return text;
|
|
54
|
-
}
|
|
55
37
|
export async function measure(logger, name, fn, fields) {
|
|
56
38
|
const start = performance.now();
|
|
57
39
|
try {
|
|
@@ -67,4 +49,4 @@ export async function measure(logger, name, fn, fields) {
|
|
|
67
49
|
});
|
|
68
50
|
}
|
|
69
51
|
}
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import { performance } from 'perf_hooks'\r\nimport { highPrecisionISODate } from './host/logging.js'\r\n\r\nexport interface Environment {\r\n    readonly [key: string]: string\r\n}\r\n\r\nexport interface Logger {\r\n    enrich(fields: object): Logger\r\n    trace(message: string, error?: unknown, fields?: object): void\r\n    debug(message: string, error?: unknown, fields?: object): void\r\n    info(message: string, error?: unknown, fields?: object): void\r\n    warn(message: string, error?: unknown, fields?: object): void\r\n    error(message: string, error?: unknown, fields?: object): void\r\n    fatal(message: string, error?: unknown, fields?: object): void\r\n}\r\n\r\nexport interface AbortSignal {\r\n    aborted: boolean\r\n\r\n    addEventListener: (\r\n        type: 'abort',\r\n        listener: (this: AbortSignal, event: unknown) => unknown,\r\n        options?: { capture?: boolean; once?: boolean; passive?: boolean },\r\n    ) => void\r\n\r\n    removeEventListener: (\r\n        type: 'abort',\r\n        listener: (this: AbortSignal, event: unknown) => unknown,\r\n        options?: { capture?: boolean },\r\n    ) => void\r\n}\r\n\r\nexport type MutableJson =\r\n    | null\r\n    | boolean\r\n    | number\r\n    | string\r\n    | MutableJson[]\r\n    | { [key: string]: MutableJson }\r\nexport type Json =\r\n    | null\r\n    | boolean\r\n    | number\r\n    | string\r\n    | readonly Json[]\r\n    | { readonly [key: string]: Json }\r\n\r\n/*@__INLINE__*/\r\nexport function objectSpreadable(json?: Json): { readonly [key: string]: Json } {\r\n    if (!json) {\r\n        return {}\r\n    }\r\n    return json as unknown as { readonly [key: string]: Json }\r\n}\r\n\r\n/*@__INLINE__*/\r\nexport function arraySpreadable(json?: Json): readonly Json[] {\r\n    if (!Array.isArray(json)) {\r\n        return []\r\n    }\r\n    return json as readonly Json[]\r\n}\r\n\r\nexport interface HandlerConfiguration {\r\n    /**\r\n     * An indication of CPU usage of the handler.\r\n     * @default 'low'\r\n     */\r\n    readonly compute?: 'high' | 'low'\r\n    /**\r\n     * An indication of memory usage of the handler.\r\n     * @default 'low'\r\n     */\r\n    readonly memory?: 'high' | 'low'\r\n    /**\r\n     * A boolean indicating whether to enrich the log with the body of events, requests or responses. Set to false if the body is large or contain very sensitive data.\r\n     * @default false\r\n     */\r\n    readonly excludeBodyFromLogs?: boolean\r\n    /**\r\n     * The level below which log entries will be discarded.\r\n     * @default 'trace'\r\n     */\r\n    readonly minimumLogLevel?: 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal'\r\n    /**\r\n     * The number of seconds the function is expected to finish executing in.\r\n     */\r\n    readonly timeout?: number\r\n}\r\n\r\nexport interface Context {\r\n    readonly env: Environment\r\n    readonly log: Logger\r\n    readonly signal: AbortSignal\r\n    now(): Date\r\n\r\n    readonly operationId?: string\r\n    readonly client?: {\r\n        readonly id?: string\r\n        readonly ip?: string\r\n        readonly port?: number\r\n        readonly userAgent?: string\r\n    }\r\n    readonly meta?: {\r\n        readonly packageName: string\r\n        readonly fileName: string\r\n        readonly revision?: string\r\n    }\r\n\r\n    emit(topic: string, type: string, subject: string, data?: Json, messageId?: string): void\r\n    eventBarrier(): Promise<void>\r\n\r\n    onSuccess(fn: () => Promise<void> | void): void\r\n}\r\n\r\nexport function httpRequestHeaders(context: Context) {\r\n    const headers: { [key: string]: string } = {\r\n        'user-agent': `${context.meta?.packageName ?? '?'}/${context.meta?.revision ?? '?'}`,\r\n    }\r\n    if (context.operationId) {\r\n        headers['x-request-id'] = context.operationId\r\n    }\r\n    if (context.client) {\r\n        if (context.client.id) {\r\n            headers['x-client-id'] = context.client.id\r\n        }\r\n        if (context.client.ip || context.client.port) {\r\n            headers['x-forwarded-for'] = `${context.client.ip ?? ''}:${context.client.port ?? ''}`\r\n        }\r\n        if (context.client.userAgent) {\r\n            headers['x-forwarded-for-user-agent'] = context.client.userAgent\r\n        }\r\n    }\r\n    return headers\r\n}\r\n\r\nexport async function throwOnNotOK<\r\n    T extends { ok?: boolean; status?: number; text?: () => Promise<string> },\r\n>(response: T, message: string, data?: { [key: string]: unknown }) {\r\n    if (response.ok === false) {\r\n        throw Object.assign(new Error(message), {\r\n            response: {\r\n                status: response.status,\r\n                body: limitSize(await response.text?.()),\r\n            },\r\n            ...data,\r\n        })\r\n    }\r\n    return response\r\n}\r\n\r\nfunction limitSize(text: string | undefined) {\r\n    if ((text?.length ?? 0) > 2048) {\r\n        return text?.substring(0, 2048)\r\n    }\r\n    return text\r\n}\r\n\r\nexport async function measure<T>(\r\n    logger: { trace: (message: string, _: undefined, f: object) => void },\r\n    name: string,\r\n    fn: () => Promise<T> | T,\r\n    fields?: object,\r\n) {\r\n    const start = performance.now()\r\n    try {\r\n        return await fn()\r\n    } finally {\r\n        const end = performance.now()\r\n        logger.trace(`Measurement of ${name} time`, undefined, {\r\n            start: highPrecisionISODate(start),\r\n            end: highPrecisionISODate(end),\r\n            duration: (Math.round(end * 10000) - Math.round(start * 10000)) / 10000,\r\n            ...fields,\r\n        })\r\n    }\r\n}\r\n"]}
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AACxC,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AA+CxD,eAAe;AACf,MAAM,UAAU,gBAAgB,CAAC,IAAW;IACxC,IAAI,CAAC,IAAI,EAAE;QACP,OAAO,EAAE,CAAA;KACZ;IACD,OAAO,IAAmD,CAAA;AAC9D,CAAC;AAED,eAAe;AACf,MAAM,UAAU,eAAe,CAAC,IAAW;IACvC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QACtB,OAAO,EAAE,CAAA;KACZ;IACD,OAAO,IAAuB,CAAA;AAClC,CAAC;AAsDD,MAAM,UAAU,kBAAkB,CAAC,OAAgB;IAC/C,MAAM,OAAO,GAA8B;QACvC,YAAY,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,WAAW,IAAI,GAAG,IAAI,OAAO,CAAC,IAAI,EAAE,QAAQ,IAAI,GAAG,EAAE;KACvF,CAAA;IACD,IAAI,OAAO,CAAC,WAAW,EAAE;QACrB,OAAO,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,WAAW,CAAA;KAChD;IACD,IAAI,OAAO,CAAC,MAAM,EAAE;QAChB,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE;YACnB,OAAO,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,CAAA;SAC7C;QACD,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE;YAC1C,OAAO,CAAC,iBAAiB,CAAC,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,IAAI,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,EAAE,CAAA;SACzF;QACD,IAAI,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE;YAC1B,OAAO,CAAC,4BAA4B,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,SAAS,CAAA;SACnE;KACJ;IACD,OAAO,OAAO,CAAA;AAClB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CACzB,MAAqE,EACrE,IAAY,EACZ,EAAwB,EACxB,MAAe;IAEf,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;IAC/B,IAAI;QACA,OAAO,MAAM,EAAE,EAAE,CAAA;KACpB;YAAS;QACN,MAAM,GAAG,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;QAC7B,MAAM,CAAC,KAAK,CAAC,kBAAkB,IAAI,OAAO,EAAE,SAAS,EAAE;YACnD,KAAK,EAAE,oBAAoB,CAAC,KAAK,CAAC;YAClC,GAAG,EAAE,oBAAoB,CAAC,GAAG,CAAC;YAC9B,QAAQ,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC,GAAG,KAAK;YACvE,GAAG,MAAM;SACZ,CAAC,CAAA;KACL;AACL,CAAC","sourcesContent":["import { performance } from 'perf_hooks'\nimport { highPrecisionISODate } from './host/logging.js'\n\nexport interface Environment {\n    readonly [key: string]: string\n}\n\nexport interface Logger {\n    enrich(fields: object): Logger\n    trace(message: string, error?: unknown, fields?: object): void\n    debug(message: string, error?: unknown, fields?: object): void\n    info(message: string, error?: unknown, fields?: object): void\n    warn(message: string, error?: unknown, fields?: object): void\n    error(message: string, error?: unknown, fields?: object): void\n    fatal(message: string, error?: unknown, fields?: object): void\n}\n\nexport interface AbortSignal {\n    aborted: boolean\n\n    addEventListener: (\n        type: 'abort',\n        listener: (this: AbortSignal, event: unknown) => unknown,\n        options?: { capture?: boolean; once?: boolean; passive?: boolean },\n    ) => void\n\n    removeEventListener: (\n        type: 'abort',\n        listener: (this: AbortSignal, event: unknown) => unknown,\n        options?: { capture?: boolean },\n    ) => void\n}\n\nexport type MutableJson =\n    | null\n    | boolean\n    | number\n    | string\n    | MutableJson[]\n    | { [key: string]: MutableJson }\nexport type Json =\n    | null\n    | boolean\n    | number\n    | string\n    | readonly Json[]\n    | { readonly [key: string]: Json }\n\n/*@__INLINE__*/\nexport function objectSpreadable(json?: Json): { readonly [key: string]: Json } {\n    if (!json) {\n        return {}\n    }\n    return json as unknown as { readonly [key: string]: Json }\n}\n\n/*@__INLINE__*/\nexport function arraySpreadable(json?: Json): readonly Json[] {\n    if (!Array.isArray(json)) {\n        return []\n    }\n    return json as readonly Json[]\n}\n\nexport interface HandlerConfiguration {\n    /**\n     * An indication of CPU usage of the handler.\n     * @default 'low'\n     */\n    readonly compute?: 'high' | 'low'\n    /**\n     * An indication of memory usage of the handler.\n     * @default 'low'\n     */\n    readonly memory?: 'high' | 'low'\n    /**\n     * A boolean indicating whether to enrich the log with the body of events, requests or responses. Set to false if the body is large or contain very sensitive data.\n     * @default false\n     */\n    readonly excludeBodyFromLogs?: boolean\n    /**\n     * The level below which log entries will be discarded.\n     * @default 'trace'\n     */\n    readonly minimumLogLevel?: 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal'\n    /**\n     * The number of seconds the function is expected to finish executing in.\n     */\n    readonly timeout?: number\n}\n\nexport interface Context {\n    readonly env: Environment\n    readonly log: Logger\n    readonly signal: AbortSignal\n    now(): Date\n\n    readonly operationId?: string\n    readonly client?: {\n        readonly id?: string\n        readonly ip?: string\n        readonly port?: number\n        readonly userAgent?: string\n    }\n    readonly meta?: {\n        readonly packageName: string\n        readonly fileName: string\n        readonly revision?: string\n    }\n\n    emit(topic: string, type: string, subject: string, data?: Json, messageId?: string): void\n    eventBarrier(): Promise<void>\n\n    onSuccess(fn: () => Promise<void> | void): void\n}\n\nexport function httpRequestHeaders(context: Context) {\n    const headers: { [key: string]: string } = {\n        'user-agent': `${context.meta?.packageName ?? '?'}/${context.meta?.revision ?? '?'}`,\n    }\n    if (context.operationId) {\n        headers['x-request-id'] = context.operationId\n    }\n    if (context.client) {\n        if (context.client.id) {\n            headers['x-client-id'] = context.client.id\n        }\n        if (context.client.ip || context.client.port) {\n            headers['x-forwarded-for'] = `${context.client.ip ?? ''}:${context.client.port ?? ''}`\n        }\n        if (context.client.userAgent) {\n            headers['x-forwarded-for-user-agent'] = context.client.userAgent\n        }\n    }\n    return headers\n}\n\nexport async function measure<T>(\n    logger: { trace: (message: string, _: undefined, f: object) => void },\n    name: string,\n    fn: () => Promise<T> | T,\n    fields?: object,\n) {\n    const start = performance.now()\n    try {\n        return await fn()\n    } finally {\n        const end = performance.now()\n        logger.trace(`Measurement of ${name} time`, undefined, {\n            start: highPrecisionISODate(start),\n            end: highPrecisionISODate(end),\n            duration: (Math.round(end * 10000) - Math.round(start * 10000)) / 10000,\n            ...fields,\n        })\n    }\n}\n"]}
|
package/host/context.d.ts
CHANGED
package/host/context.js
CHANGED
|
@@ -1,32 +1,20 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _LogMulticaster_transports;
|
|
13
1
|
import { EventEmitter } from './emitter.js';
|
|
14
2
|
import { makeLogger } from './logging.js';
|
|
15
3
|
class LogMulticaster {
|
|
4
|
+
#transports;
|
|
5
|
+
publishRate;
|
|
16
6
|
constructor(transports) {
|
|
17
|
-
|
|
18
|
-
__classPrivateFieldSet(this, _LogMulticaster_transports, transports, "f");
|
|
7
|
+
this.#transports = transports;
|
|
19
8
|
this.publishRate = transports.map(t => t.publishRate).sort()[0] ?? Number.MAX_SAFE_INTEGER;
|
|
20
9
|
}
|
|
21
10
|
sendEntries(entries, signal) {
|
|
22
|
-
const promises =
|
|
11
|
+
const promises = this.#transports.map(t => t.sendEntries(entries, signal)).filter(p => !!p);
|
|
23
12
|
if (promises.length === 0) {
|
|
24
13
|
return;
|
|
25
14
|
}
|
|
26
15
|
return Promise.all(promises);
|
|
27
16
|
}
|
|
28
17
|
}
|
|
29
|
-
_LogMulticaster_transports = new WeakMap();
|
|
30
18
|
export function createContext(clientInfo, loggers, eventTransport, timeouts, outerController, meta, environment, now) {
|
|
31
19
|
const timeout = (timeouts.cap
|
|
32
20
|
? Math.min(meta?.config?.timeout ?? timeouts.default, timeouts.cap)
|
|
@@ -99,4 +87,4 @@ process.on('uncaughtException', err => {
|
|
|
99
87
|
process.on('unhandledRejection', reason => {
|
|
100
88
|
globalLogger?.fatal('Unhandled rejection.', reason, undefined);
|
|
101
89
|
});
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbortSignal, Context, Environment, Json, Logger } from '../context.js'\r\nimport { EventEmitter } from './emitter.js'\r\nimport { makeLogger } from './logging.js'\r\nimport { Metadata } from './registry.js'\r\n\r\nexport interface ClientInfo {\r\n    readonly operationId?: string\r\n    readonly clientId?: string\r\n    readonly clientIp?: string\r\n    readonly clientPort?: number\r\n    readonly userAgent?: string\r\n}\r\n\r\nexport interface EventMetadata {\r\n    topic: string\r\n    type: string\r\n    subject: string\r\n    id?: string\r\n}\r\n\r\nexport interface BufferedEvent {\r\n    eventTime: Date\r\n    meta: Omit<EventMetadata, 'topic'>\r\n    ids: ClientInfo\r\n    json?: string\r\n}\r\n\r\nexport interface EventTransport {\r\n    readonly publishRate: number\r\n    sendEvents(topic: string, events: BufferedEvent[], signal: AbortSignal): Promise<void>\r\n}\r\n\r\nexport type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal'\r\n\r\nexport interface LogEntry {\r\n    readonly level: LogLevel\r\n    readonly timestamp: number\r\n    readonly message: string\r\n    readonly error: unknown\r\n    readonly json: string\r\n}\r\n\r\nexport interface LogTransport {\r\n    readonly publishRate?: number\r\n    sendEntries(entries: LogEntry[], signal: AbortSignal): Promise<void> | undefined\r\n}\r\n\r\nclass LogMulticaster implements LogTransport {\r\n    #transports: LogTransport[]\r\n    readonly publishRate: number\r\n\r\n    constructor(transports: LogTransport[]) {\r\n        this.#transports = transports\r\n        this.publishRate = transports.map(t => t.publishRate).sort()[0] ?? Number.MAX_SAFE_INTEGER\r\n    }\r\n\r\n    sendEntries(entries: LogEntry[], signal: AbortSignal) {\r\n        const promises = this.#transports.map(t => t.sendEntries(entries, signal)).filter(p => !!p)\r\n        if (promises.length === 0) {\r\n            return\r\n        }\r\n        return Promise.all(promises) as unknown as Promise<void>\r\n    }\r\n}\r\n\r\nexport interface RootLogger extends Logger {\r\n    enrichReserved(fields: object): RootLogger\r\n    flush(): Promise<void>\r\n}\r\n\r\nexport function createContext(\r\n    clientInfo: ClientInfo,\r\n    loggers: LogTransport[],\r\n    eventTransport: EventTransport,\r\n    timeouts: { default: number; cap?: number },\r\n    outerController: AbortController,\r\n    meta?: Metadata,\r\n    environment?: Environment | undefined,\r\n    now?: (() => Date) | undefined,\r\n): {\r\n    log: RootLogger\r\n    context: Omit<Context, 'log'>\r\n    success: () => Promise<unknown>\r\n    flush: () => Promise<void>\r\n} {\r\n    const timeout =\r\n        (timeouts.cap\r\n            ? Math.min(meta?.config?.timeout ?? timeouts.default, timeouts.cap)\r\n            : meta?.config?.timeout ?? timeouts.default) * 1000\r\n    const innerController = new AbortController()\r\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n    const logTransport = loggers.length === 1 ? loggers[0]! : new LogMulticaster(loggers)\r\n    const logger = makeLogger(\r\n        logTransport,\r\n        meta?.config?.minimumLogLevel,\r\n        outerController.signal as AbortSignal,\r\n    ).enrichReserved({\r\n        operationId: clientInfo.operationId,\r\n        client: {\r\n            id: clientInfo.clientId,\r\n            ip: clientInfo.clientIp,\r\n            port: clientInfo.clientPort,\r\n            userAgent: clientInfo.userAgent,\r\n        },\r\n    })\r\n    globalLogger = logger\r\n    const emitter = new EventEmitter(\r\n        eventTransport,\r\n        logger,\r\n        clientInfo,\r\n        timeout,\r\n        outerController.signal as AbortSignal,\r\n    )\r\n    const successHandlers: (() => Promise<void> | void)[] = []\r\n    const ctx = {\r\n        env: environment ?? (process.env as Environment),\r\n        signal: innerController.signal as AbortSignal,\r\n        now: now ?? (() => new Date()),\r\n        operationId: clientInfo.operationId,\r\n        client: {\r\n            id: clientInfo.clientId,\r\n            ip: clientInfo.clientIp,\r\n            port: clientInfo.clientPort,\r\n            userAgent: clientInfo.userAgent,\r\n        },\r\n        meta: meta\r\n            ? {\r\n                  packageName: meta.packageName,\r\n                  fileName: meta.fileName,\r\n                  revision: meta.revision,\r\n              }\r\n            : undefined,\r\n        emit: (topic: string, type: string, subject: string, data?: Json, messageId?: string) =>\r\n            emitter.emit({ topic, type, subject, id: messageId }, data),\r\n        eventBarrier: () => emitter.flush(),\r\n        onSuccess: (fn: () => Promise<void> | void) => successHandlers.push(fn),\r\n    }\r\n    const timeoutHandle = setTimeout(() => {\r\n        logger.error('Timeout.', undefined, undefined)\r\n        innerController.abort()\r\n        // eslint-disable-next-line no-void\r\n        void logger.flush()\r\n        // eslint-disable-next-line no-void\r\n        void emitter.flush()\r\n    }, timeout)\r\n    const flushHandle = setTimeout(() => {\r\n        logger.error('Aborting flush.', undefined, undefined)\r\n        outerController.abort()\r\n    }, timeout + 15000)\r\n    return {\r\n        log: logger,\r\n        context: ctx,\r\n        success: () => Promise.all(successHandlers.map(fn => fn())),\r\n        flush: async () => {\r\n            clearTimeout(timeoutHandle)\r\n            await emitter.flush()\r\n            await logger.flush()\r\n            clearTimeout(flushHandle)\r\n        },\r\n    }\r\n}\r\n\r\nlet globalLogger: Logger | undefined\r\n\r\nprocess.on('uncaughtException', err => {\r\n    globalLogger?.fatal('Uncaught exception.', err, undefined)\r\n})\r\nprocess.on('unhandledRejection', reason => {\r\n    globalLogger?.fatal('Unhandled rejection.', reason, undefined)\r\n})\r\n"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context.js","sourceRoot":"","sources":["context.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbortSignal, Context, Environment, Json, Logger } from '../context.js'\nimport { EventEmitter } from './emitter.js'\nimport { makeLogger } from './logging.js'\nimport { Metadata } from './registry.js'\n\nexport interface ClientInfo {\n    readonly operationId?: string\n    readonly clientId?: string\n    readonly clientIp?: string\n    readonly clientPort?: number\n    readonly userAgent?: string\n}\n\nexport interface EventMetadata {\n    topic: string\n    type: string\n    subject: string\n    id?: string\n}\n\nexport interface BufferedEvent {\n    eventTime: Date\n    meta: Omit<EventMetadata, 'topic'>\n    ids: ClientInfo\n    json?: string\n}\n\nexport interface EventTransport {\n    readonly publishRate: number\n    sendEvents(topic: string, events: BufferedEvent[], signal: AbortSignal): Promise<void>\n}\n\nexport type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal'\n\nexport interface LogEntry {\n    readonly level: LogLevel\n    readonly timestamp: number\n    readonly message: string\n    readonly error: unknown\n    readonly json: string\n}\n\nexport interface LogTransport {\n    readonly publishRate?: number\n    sendEntries(entries: LogEntry[], signal: AbortSignal): Promise<void> | undefined\n}\n\nclass LogMulticaster implements LogTransport {\n    #transports: LogTransport[]\n    readonly publishRate: number\n\n    constructor(transports: LogTransport[]) {\n        this.#transports = transports\n        this.publishRate = transports.map(t => t.publishRate).sort()[0] ?? Number.MAX_SAFE_INTEGER\n    }\n\n    sendEntries(entries: LogEntry[], signal: AbortSignal) {\n        const promises = this.#transports.map(t => t.sendEntries(entries, signal)).filter(p => !!p)\n        if (promises.length === 0) {\n            return\n        }\n        return Promise.all(promises) as unknown as Promise<void>\n    }\n}\n\nexport interface RootLogger extends Logger {\n    enrichReserved(fields: object): RootLogger\n    flush(): Promise<void>\n}\n\nexport function createContext(\n    clientInfo: ClientInfo,\n    loggers: LogTransport[],\n    eventTransport: EventTransport,\n    timeouts: { default: number; cap?: number },\n    outerController: AbortController,\n    meta?: Metadata,\n    environment?: Environment | undefined,\n    now?: (() => Date) | undefined,\n): {\n    log: RootLogger\n    context: Omit<Context, 'log'>\n    success: () => Promise<unknown>\n    flush: () => Promise<void>\n} {\n    const timeout =\n        (timeouts.cap\n            ? Math.min(meta?.config?.timeout ?? timeouts.default, timeouts.cap)\n            : meta?.config?.timeout ?? timeouts.default) * 1000\n    const innerController = new AbortController()\n    // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n    const logTransport = loggers.length === 1 ? loggers[0]! : new LogMulticaster(loggers)\n    const logger = makeLogger(\n        logTransport,\n        meta?.config?.minimumLogLevel,\n        outerController.signal as AbortSignal,\n    ).enrichReserved({\n        operationId: clientInfo.operationId,\n        client: {\n            id: clientInfo.clientId,\n            ip: clientInfo.clientIp,\n            port: clientInfo.clientPort,\n            userAgent: clientInfo.userAgent,\n        },\n    })\n    globalLogger = logger\n    const emitter = new EventEmitter(\n        eventTransport,\n        logger,\n        clientInfo,\n        timeout,\n        outerController.signal as AbortSignal,\n    )\n    const successHandlers: (() => Promise<void> | void)[] = []\n    const ctx = {\n        env: environment ?? (process.env as Environment),\n        signal: innerController.signal as AbortSignal,\n        now: now ?? (() => new Date()),\n        operationId: clientInfo.operationId,\n        client: {\n            id: clientInfo.clientId,\n            ip: clientInfo.clientIp,\n            port: clientInfo.clientPort,\n            userAgent: clientInfo.userAgent,\n        },\n        meta: meta\n            ? {\n                  packageName: meta.packageName,\n                  fileName: meta.fileName,\n                  revision: meta.revision,\n              }\n            : undefined,\n        emit: (topic: string, type: string, subject: string, data?: Json, messageId?: string) =>\n            emitter.emit({ topic, type, subject, id: messageId }, data),\n        eventBarrier: () => emitter.flush(),\n        onSuccess: (fn: () => Promise<void> | void) => successHandlers.push(fn),\n    }\n    const timeoutHandle = setTimeout(() => {\n        logger.error('Timeout.', undefined, undefined)\n        innerController.abort()\n        // eslint-disable-next-line no-void\n        void logger.flush()\n        // eslint-disable-next-line no-void\n        void emitter.flush()\n    }, timeout)\n    const flushHandle = setTimeout(() => {\n        logger.error('Aborting flush.', undefined, undefined)\n        outerController.abort()\n    }, timeout + 15000)\n    return {\n        log: logger,\n        context: ctx,\n        success: () => Promise.all(successHandlers.map(fn => fn())),\n        flush: async () => {\n            clearTimeout(timeoutHandle)\n            await emitter.flush()\n            await logger.flush()\n            clearTimeout(flushHandle)\n        },\n    }\n}\n\nlet globalLogger: Logger | undefined\n\nprocess.on('uncaughtException', err => {\n    globalLogger?.fatal('Uncaught exception.', err, undefined)\n})\nprocess.on('unhandledRejection', reason => {\n    globalLogger?.fatal('Unhandled rejection.', reason, undefined)\n})\n"]}
|
package/host/emitter.js
CHANGED
|
@@ -1,81 +1,68 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _EventEmitter_instances, _EventEmitter_transport, _EventEmitter_logger, _EventEmitter_ids, _EventEmitter_emitted, _EventEmitter_size, _EventEmitter_flusher, _EventEmitter_deadline, _EventEmitter_buffered, _EventEmitter_signal, _EventEmitter_startFlush, _EventEmitter_flushEvents;
|
|
13
1
|
export class EventEmitter {
|
|
2
|
+
#transport;
|
|
3
|
+
#logger;
|
|
4
|
+
#ids;
|
|
5
|
+
#emitted = {};
|
|
6
|
+
#size = 0;
|
|
7
|
+
#flusher;
|
|
8
|
+
#deadline;
|
|
9
|
+
#buffered;
|
|
10
|
+
#signal;
|
|
14
11
|
constructor(transport, logger, ids, timeout, signal) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
_EventEmitter_flusher.set(this, void 0);
|
|
22
|
-
_EventEmitter_deadline.set(this, void 0);
|
|
23
|
-
_EventEmitter_buffered.set(this, void 0);
|
|
24
|
-
_EventEmitter_signal.set(this, void 0);
|
|
25
|
-
__classPrivateFieldSet(this, _EventEmitter_transport, transport, "f");
|
|
26
|
-
__classPrivateFieldSet(this, _EventEmitter_logger, logger, "f");
|
|
27
|
-
__classPrivateFieldSet(this, _EventEmitter_ids, ids, "f");
|
|
28
|
-
__classPrivateFieldSet(this, _EventEmitter_deadline, new Date().getTime() + timeout, "f");
|
|
29
|
-
__classPrivateFieldSet(this, _EventEmitter_buffered, 0, "f");
|
|
30
|
-
__classPrivateFieldSet(this, _EventEmitter_signal, signal, "f");
|
|
12
|
+
this.#transport = transport;
|
|
13
|
+
this.#logger = logger;
|
|
14
|
+
this.#ids = ids;
|
|
15
|
+
this.#deadline = new Date().getTime() + timeout;
|
|
16
|
+
this.#buffered = 0;
|
|
17
|
+
this.#signal = signal;
|
|
31
18
|
}
|
|
32
19
|
emit(meta, data) {
|
|
33
|
-
var _a;
|
|
34
20
|
const eventTime = new Date();
|
|
35
|
-
const timeLeft =
|
|
36
|
-
if (
|
|
21
|
+
const timeLeft = this.#deadline - new Date().getTime();
|
|
22
|
+
if (this.#buffered / this.#transport.publishRate > timeLeft) {
|
|
37
23
|
throw new Error('Event overflow.');
|
|
38
24
|
}
|
|
39
25
|
const event = data === undefined
|
|
40
|
-
? { meta, ids:
|
|
41
|
-
: { meta, ids:
|
|
42
|
-
const events =
|
|
26
|
+
? { meta, ids: this.#ids, eventTime }
|
|
27
|
+
: { meta, ids: this.#ids, eventTime, json: JSON.stringify(data) };
|
|
28
|
+
const events = this.#emitted[meta.topic];
|
|
43
29
|
if (!events) {
|
|
44
|
-
|
|
30
|
+
this.#emitted[meta.topic] = [event];
|
|
45
31
|
}
|
|
46
32
|
else {
|
|
47
33
|
events.push(event);
|
|
48
|
-
if (events.length > 64 ||
|
|
34
|
+
if (events.length > 64 || this.#size > 64000) {
|
|
49
35
|
// eslint-disable-next-line no-void
|
|
50
36
|
void this.flush();
|
|
51
37
|
}
|
|
52
38
|
}
|
|
53
|
-
|
|
54
|
-
|
|
39
|
+
++this.#buffered;
|
|
40
|
+
this.#size += event.json?.length ?? 0;
|
|
55
41
|
}
|
|
56
42
|
async flush() {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
return await
|
|
43
|
+
this.#startFlush(this.#emitted);
|
|
44
|
+
this.#emitted = {};
|
|
45
|
+
this.#size = 0;
|
|
46
|
+
return await this.#flusher;
|
|
61
47
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
__classPrivateFieldSet(this, _EventEmitter_flusher, __classPrivateFieldGet(this, _EventEmitter_flusher, "f").then(() => __classPrivateFieldGet(this, _EventEmitter_instances, "m", _EventEmitter_flushEvents).call(this, emitted)), "f");
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
__classPrivateFieldSet(this, _EventEmitter_flusher, __classPrivateFieldGet(this, _EventEmitter_instances, "m", _EventEmitter_flushEvents).call(this, emitted), "f");
|
|
69
|
-
}
|
|
70
|
-
}, _EventEmitter_flushEvents = async function _EventEmitter_flushEvents(emitted) {
|
|
71
|
-
await Promise.all(Object.entries(emitted).map(async ([topic, events]) => {
|
|
72
|
-
try {
|
|
73
|
-
await __classPrivateFieldGet(this, _EventEmitter_transport, "f").sendEvents(topic, events, __classPrivateFieldGet(this, _EventEmitter_signal, "f"));
|
|
48
|
+
#startFlush(emitted) {
|
|
49
|
+
if (this.#flusher) {
|
|
50
|
+
this.#flusher = this.#flusher.then(() => this.#flushEvents(emitted));
|
|
74
51
|
}
|
|
75
|
-
|
|
76
|
-
|
|
52
|
+
else {
|
|
53
|
+
this.#flusher = this.#flushEvents(emitted);
|
|
77
54
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
55
|
+
}
|
|
56
|
+
async #flushEvents(emitted) {
|
|
57
|
+
await Promise.all(Object.entries(emitted).map(async ([topic, events]) => {
|
|
58
|
+
try {
|
|
59
|
+
await this.#transport.sendEvents(topic, events, this.#signal);
|
|
60
|
+
}
|
|
61
|
+
catch (e) {
|
|
62
|
+
this.#logger.fatal('Error sending events.', e, { events });
|
|
63
|
+
}
|
|
64
|
+
this.#buffered -= events.length;
|
|
65
|
+
}));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1pdHRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImVtaXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxPQUFPLFlBQVk7SUFDWixVQUFVLENBQWdCO0lBQzFCLE9BQU8sQ0FBUTtJQUNmLElBQUksQ0FBWTtJQUN6QixRQUFRLEdBQWUsRUFBRSxDQUFBO0lBQ3pCLEtBQUssR0FBRyxDQUFDLENBQUE7SUFDVCxRQUFRLENBQWdCO0lBQ2YsU0FBUyxDQUFRO0lBQzFCLFNBQVMsQ0FBUTtJQUNSLE9BQU8sQ0FBYTtJQUU3QixZQUNJLFNBQXlCLEVBQ3pCLE1BQWMsRUFDZCxHQUF1RixFQUN2RixPQUFlLEVBQ2YsTUFBbUI7UUFFbkIsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQUE7UUFDM0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUE7UUFDckIsSUFBSSxDQUFDLElBQUksR0FBRyxHQUFHLENBQUE7UUFDZixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsT0FBTyxDQUFBO1FBQy9DLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFBO1FBQ2xCLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFBO0lBQ3pCLENBQUM7SUFFRCxJQUFJLENBQUMsSUFBbUIsRUFBRSxJQUFXO1FBQ2pDLE1BQU0sU0FBUyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUE7UUFDNUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBQ3RELElBQUksSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsR0FBRyxRQUFRLEVBQUU7WUFDekQsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1NBQ3JDO1FBQ0QsTUFBTSxLQUFLLEdBQ1AsSUFBSSxLQUFLLFNBQVM7WUFDZCxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsU0FBUyxFQUFFO1lBQ3JDLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQTtRQUN6RSxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN4QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQTtTQUN0QzthQUFNO1lBQ0gsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtZQUNsQixJQUFJLE1BQU0sQ0FBQyxNQUFNLEdBQUcsRUFBRSxJQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxFQUFFO2dCQUMxQyxtQ0FBbUM7Z0JBQ25DLEtBQUssSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFBO2FBQ3BCO1NBQ0o7UUFDRCxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUE7UUFDaEIsSUFBSSxDQUFDLEtBQUssSUFBSSxLQUFLLENBQUMsSUFBSSxFQUFFLE1BQU0sSUFBSSxDQUFDLENBQUE7SUFDekMsQ0FBQztJQUVELEtBQUssQ0FBQyxLQUFLO1FBQ1AsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDL0IsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUE7UUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUE7UUFDZCxPQUFPLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQTtJQUM5QixDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQW1CO1FBQzNCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFBO1NBQ3ZFO2FBQU07WUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUE7U0FDN0M7SUFDTCxDQUFDO0lBRUQsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFtQjtRQUNsQyxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQ2IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxFQUFFLEVBQUU7WUFDbEQsSUFBSTtnQkFDQSxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO2FBQ2hFO1lBQUMsT0FBTyxDQUFDLEVBQUU7Z0JBQ1IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQTthQUM3RDtZQUNELElBQUksQ0FBQyxTQUFTLElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQTtRQUNuQyxDQUFDLENBQUMsQ0FDTCxDQUFBO0lBQ0wsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWJvcnRTaWduYWwsIEpzb24sIExvZ2dlciB9IGZyb20gJy4uL2NvbnRleHQuanMnXG5pbXBvcnQgeyBCdWZmZXJlZEV2ZW50LCBDbGllbnRJbmZvLCBFdmVudE1ldGFkYXRhLCBFdmVudFRyYW5zcG9ydCB9IGZyb20gJy4vY29udGV4dC5qcydcblxuaW50ZXJmYWNlIEVtaXRCdWZmZXIge1xuICAgIFt0b3BpYzogc3RyaW5nXTogQnVmZmVyZWRFdmVudFtdXG59XG5cbmV4cG9ydCBjbGFzcyBFdmVudEVtaXR0ZXIge1xuICAgIHJlYWRvbmx5ICN0cmFuc3BvcnQ6IEV2ZW50VHJhbnNwb3J0XG4gICAgcmVhZG9ubHkgI2xvZ2dlcjogTG9nZ2VyXG4gICAgcmVhZG9ubHkgI2lkczogQ2xpZW50SW5mb1xuICAgICNlbWl0dGVkOiBFbWl0QnVmZmVyID0ge31cbiAgICAjc2l6ZSA9IDBcbiAgICAjZmx1c2hlcj86IFByb21pc2U8dm9pZD5cbiAgICByZWFkb25seSAjZGVhZGxpbmU6IG51bWJlclxuICAgICNidWZmZXJlZDogbnVtYmVyXG4gICAgcmVhZG9ubHkgI3NpZ25hbDogQWJvcnRTaWduYWxcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICB0cmFuc3BvcnQ6IEV2ZW50VHJhbnNwb3J0LFxuICAgICAgICBsb2dnZXI6IExvZ2dlcixcbiAgICAgICAgaWRzOiB7IG9wZXJhdGlvbklkPzogc3RyaW5nOyBjbGllbnRJZD86IHN0cmluZzsgY2xpZW50SXA/OiBzdHJpbmc7IHVzZXJBZ2VudD86IHN0cmluZyB9LFxuICAgICAgICB0aW1lb3V0OiBudW1iZXIsXG4gICAgICAgIHNpZ25hbDogQWJvcnRTaWduYWwsXG4gICAgKSB7XG4gICAgICAgIHRoaXMuI3RyYW5zcG9ydCA9IHRyYW5zcG9ydFxuICAgICAgICB0aGlzLiNsb2dnZXIgPSBsb2dnZXJcbiAgICAgICAgdGhpcy4jaWRzID0gaWRzXG4gICAgICAgIHRoaXMuI2RlYWRsaW5lID0gbmV3IERhdGUoKS5nZXRUaW1lKCkgKyB0aW1lb3V0XG4gICAgICAgIHRoaXMuI2J1ZmZlcmVkID0gMFxuICAgICAgICB0aGlzLiNzaWduYWwgPSBzaWduYWxcbiAgICB9XG5cbiAgICBlbWl0KG1ldGE6IEV2ZW50TWV0YWRhdGEsIGRhdGE/OiBKc29uKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGV2ZW50VGltZSA9IG5ldyBEYXRlKClcbiAgICAgICAgY29uc3QgdGltZUxlZnQgPSB0aGlzLiNkZWFkbGluZSAtIG5ldyBEYXRlKCkuZ2V0VGltZSgpXG4gICAgICAgIGlmICh0aGlzLiNidWZmZXJlZCAvIHRoaXMuI3RyYW5zcG9ydC5wdWJsaXNoUmF0ZSA+IHRpbWVMZWZ0KSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0V2ZW50IG92ZXJmbG93LicpXG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgZXZlbnQgPVxuICAgICAgICAgICAgZGF0YSA9PT0gdW5kZWZpbmVkXG4gICAgICAgICAgICAgICAgPyB7IG1ldGEsIGlkczogdGhpcy4jaWRzLCBldmVudFRpbWUgfVxuICAgICAgICAgICAgICAgIDogeyBtZXRhLCBpZHM6IHRoaXMuI2lkcywgZXZlbnRUaW1lLCBqc29uOiBKU09OLnN0cmluZ2lmeShkYXRhKSB9XG4gICAgICAgIGNvbnN0IGV2ZW50cyA9IHRoaXMuI2VtaXR0ZWRbbWV0YS50b3BpY11cbiAgICAgICAgaWYgKCFldmVudHMpIHtcbiAgICAgICAgICAgIHRoaXMuI2VtaXR0ZWRbbWV0YS50b3BpY10gPSBbZXZlbnRdXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBldmVudHMucHVzaChldmVudClcbiAgICAgICAgICAgIGlmIChldmVudHMubGVuZ3RoID4gNjQgfHwgdGhpcy4jc2l6ZSA+IDY0MDAwKSB7XG4gICAgICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXZvaWRcbiAgICAgICAgICAgICAgICB2b2lkIHRoaXMuZmx1c2goKVxuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgICsrdGhpcy4jYnVmZmVyZWRcbiAgICAgICAgdGhpcy4jc2l6ZSArPSBldmVudC5qc29uPy5sZW5ndGggPz8gMFxuICAgIH1cblxuICAgIGFzeW5jIGZsdXNoKCk6IFByb21pc2U8dm9pZD4ge1xuICAgICAgICB0aGlzLiNzdGFydEZsdXNoKHRoaXMuI2VtaXR0ZWQpXG4gICAgICAgIHRoaXMuI2VtaXR0ZWQgPSB7fVxuICAgICAgICB0aGlzLiNzaXplID0gMFxuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy4jZmx1c2hlclxuICAgIH1cblxuICAgICNzdGFydEZsdXNoKGVtaXR0ZWQ6IEVtaXRCdWZmZXIpIHtcbiAgICAgICAgaWYgKHRoaXMuI2ZsdXNoZXIpIHtcbiAgICAgICAgICAgIHRoaXMuI2ZsdXNoZXIgPSB0aGlzLiNmbHVzaGVyLnRoZW4oKCkgPT4gdGhpcy4jZmx1c2hFdmVudHMoZW1pdHRlZCkpXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLiNmbHVzaGVyID0gdGhpcy4jZmx1c2hFdmVudHMoZW1pdHRlZClcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGFzeW5jICNmbHVzaEV2ZW50cyhlbWl0dGVkOiBFbWl0QnVmZmVyKSB7XG4gICAgICAgIGF3YWl0IFByb21pc2UuYWxsKFxuICAgICAgICAgICAgT2JqZWN0LmVudHJpZXMoZW1pdHRlZCkubWFwKGFzeW5jIChbdG9waWMsIGV2ZW50c10pID0+IHtcbiAgICAgICAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgICAgICAgICBhd2FpdCB0aGlzLiN0cmFuc3BvcnQuc2VuZEV2ZW50cyh0b3BpYywgZXZlbnRzLCB0aGlzLiNzaWduYWwpXG4gICAgICAgICAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLiNsb2dnZXIuZmF0YWwoJ0Vycm9yIHNlbmRpbmcgZXZlbnRzLicsIGUsIHsgZXZlbnRzIH0pXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIHRoaXMuI2J1ZmZlcmVkIC09IGV2ZW50cy5sZW5ndGhcbiAgICAgICAgICAgIH0pLFxuICAgICAgICApXG4gICAgfVxufVxuIl19
|
package/host/http.js
CHANGED
|
@@ -44,7 +44,13 @@ export async function executeRequest(log, context, handler, options, success) {
|
|
|
44
44
|
...response.headers,
|
|
45
45
|
};
|
|
46
46
|
}
|
|
47
|
-
log = log.enrichReserved({
|
|
47
|
+
log = log.enrichReserved({
|
|
48
|
+
response: {
|
|
49
|
+
status: response.status,
|
|
50
|
+
headers: response.headers,
|
|
51
|
+
body: response.logBody,
|
|
52
|
+
},
|
|
53
|
+
});
|
|
48
54
|
if (response.status < 300) {
|
|
49
55
|
log.debug('Request END');
|
|
50
56
|
await success();
|
|
@@ -202,4 +208,4 @@ export function clientFromHeaders(headers) {
|
|
|
202
208
|
userAgent: headers['x-forwarded-for-user-agent'] ?? headers['user-agent'],
|
|
203
209
|
};
|
|
204
210
|
}
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http.js","sourceRoot":"","sources":["http.ts"],"names":[],"mappings":"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","sourcesContent":["import { parse, UrlWithParsedQuery } from 'node:url'\r\nimport { Context, measure } from '../context.js'\r\nimport type { Json, ResponseHeaders, Result } from '../http.js'\r\nimport { ClientInfo, RootLogger } from './context.js'\r\nimport type { HttpHandler } from './registry.js'\r\n\r\nexport interface Response {\r\n    headers: { readonly [key: string]: string }\r\n    status: number\r\n    body?: string | Buffer\r\n}\r\n\r\ntype RequestOptions = BodylessRequestOptions | StringRequestOptions | JsonRequestOptions\r\n\r\ninterface BodylessRequestOptions {\r\n    uri: string\r\n    headers?: { readonly [key: string]: string }\r\n}\r\n\r\ninterface StringRequestOptions extends BodylessRequestOptions {\r\n    body: string\r\n}\r\n\r\ninterface JsonRequestOptions extends BodylessRequestOptions {\r\n    json: Json\r\n}\r\n\r\nexport async function executeRequest(\r\n    log: RootLogger,\r\n    context: Omit<Context, 'log'>,\r\n    handler: HttpHandler,\r\n    options: RequestOptions,\r\n    success: () => Promise<unknown>,\r\n): Promise<Response> {\r\n    const isShallow =\r\n        context.env.SHALLOW_KEY && options.headers?.['x-shallow'] === context.env.SHALLOW_KEY\r\n    const includeBodyInLogs = !handler.config?.excludeBodyFromLogs\r\n    const logRequest = includeBodyInLogs\r\n        ? { method: handler.method, ...options }\r\n        : withoutRequestBody({ method: handler.method, ...options })\r\n    log = log.enrichReserved({ meta: context.meta, request: logRequest })\r\n    if (isShallow) {\r\n        log.trace('Shallow request')\r\n        return {\r\n            headers: {},\r\n            status: 204,\r\n        }\r\n    }\r\n    log.trace('Request BEGIN')\r\n    try {\r\n        let parsedUrl: UrlWithParsedQuery & { pathStepAt: (index: number) => string }\r\n        let pathSteps: string[]\r\n        const req = {\r\n            rawUrl: options.uri,\r\n            get url() {\r\n                return (parsedUrl ??= {\r\n                    ...parse(this.rawUrl, true),\r\n                    pathStepAt: (index: number) => {\r\n                        const steps = (pathSteps ??= parsedUrl.pathname?.split('/') ?? [])\r\n                        const step = steps[index + 1]\r\n                        if (!step) {\r\n                            throw new RangeError(`Path does not have a step at index ${index}.`)\r\n                        }\r\n                        return step\r\n                    },\r\n                })\r\n            },\r\n            body: requestBody(options),\r\n            headers: options.headers ?? {},\r\n        }\r\n\r\n        const result = await measure(log, 'execution', () =>\r\n            handler.entry({ ...context, log }, req),\r\n        )\r\n\r\n        const response = resultToResponse(result, includeBodyInLogs)\r\n\r\n        if (context.signal.aborted) {\r\n            response.headers = {\r\n                'x-timeout': '1',\r\n                ...response.headers,\r\n            }\r\n        }\r\n\r\n        log = log.enrichReserved({ request: logRequest })\r\n        if (response.status < 300) {\r\n            log.debug('Request END')\r\n            await success()\r\n        } else {\r\n            log.warn('Request END')\r\n        }\r\n        return response\r\n    } catch (e) {\r\n        try {\r\n            const response = errorToResponse(e)\r\n            log = log.enrichReserved({ response })\r\n            log.error('Request END', e)\r\n            return response\r\n        } catch (convertError) {\r\n            log.error('Could not convert exception to error response.', convertError)\r\n            return {\r\n                headers: {},\r\n                status: 500,\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\nfunction resultToResponse(result: Result, withLogBody: boolean): Response & { logBody?: unknown } {\r\n    if (!result) {\r\n        return {\r\n            headers: {},\r\n            status: 204,\r\n        }\r\n    } else if (typeof result === 'string') {\r\n        const logBody = withLogBody ? result : undefined\r\n        return {\r\n            headers: {\r\n                'content-type': 'text/plain',\r\n            },\r\n            status: 200,\r\n            body: result,\r\n            logBody,\r\n        }\r\n    } else {\r\n        if (result.body === undefined) {\r\n            return {\r\n                headers: result.headers ?? {},\r\n                status: result.status ?? 200,\r\n            }\r\n        } else if (typeof result.body === 'string') {\r\n            const logBody = withLogBody ? result.body : undefined\r\n            return {\r\n                headers: withContentType(result.headers, 'text/plain'),\r\n                status: result.status ?? 200,\r\n                body: result.body,\r\n                logBody,\r\n            }\r\n        } else if (Buffer.isBuffer(result.body)) {\r\n            const logBody = withLogBody ? result.body.toString('base64') : undefined\r\n            return {\r\n                headers: withContentType(result.headers, 'application/octet-stream'),\r\n                status: result.status ?? 200,\r\n                body: result.body,\r\n                logBody,\r\n            }\r\n        } else {\r\n            const logBody = withLogBody ? result.body : undefined\r\n            return {\r\n                headers: withContentType(result.headers, 'application/json'),\r\n                status: result.status ?? 200,\r\n                body: JSON.stringify(result.body),\r\n                logBody,\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\nfunction withoutRequestBody(options: RequestOptions & { method: string }) {\r\n    if (hasJsonBody(options)) {\r\n        const { json, ...bodyless } = options\r\n        return bodyless\r\n    }\r\n    if (hasStringBody(options)) {\r\n        const { body, ...bodyless } = options\r\n        return bodyless\r\n    }\r\n    return options\r\n}\r\n\r\nfunction requestBody(options: RequestOptions): Json | string | undefined {\r\n    if (hasJsonBody(options)) {\r\n        return options.json\r\n    }\r\n    if (hasStringBody(options)) {\r\n        return options.body\r\n    }\r\n    return undefined\r\n}\r\n\r\nfunction hasJsonBody(options: RequestOptions): options is JsonRequestOptions {\r\n    return (options as { json?: unknown }).json !== undefined\r\n}\r\n\r\nfunction hasStringBody(options: RequestOptions): options is StringRequestOptions {\r\n    return (options as { body?: unknown }).body !== undefined\r\n}\r\n\r\nfunction withContentType(headers: ResponseHeaders | undefined, contentType: string) {\r\n    if (!headers) {\r\n        return {\r\n            'content-type': contentType,\r\n        }\r\n    }\r\n    if (!headers['content-type']) {\r\n        headers['content-type'] = contentType\r\n    }\r\n    return headers\r\n}\r\n\r\nfunction errorToResponse(e: unknown): Response {\r\n    const { body, statusCode: status } = e as { body?: unknown; statusCode?: number }\r\n    if (typeof body === 'string') {\r\n        return {\r\n            headers: {\r\n                'content-type': 'text/plain',\r\n            },\r\n            status: status ?? 500,\r\n            body,\r\n        }\r\n    } else if (typeof body === 'object') {\r\n        return {\r\n            headers: {\r\n                'content-type': 'application/json',\r\n            },\r\n            status: status ?? 500,\r\n            body: JSON.stringify(body),\r\n        }\r\n    } else {\r\n        return {\r\n            headers: {},\r\n            status: status ?? 500,\r\n        }\r\n    }\r\n}\r\n\r\nexport function clientFromHeaders(\r\n    headers: { readonly [key: string]: string } | undefined,\r\n): ClientInfo {\r\n    if (!headers) {\r\n        return {}\r\n    }\r\n    return {\r\n        operationId: headers['x-request-id'] ?? headers['request-id'],\r\n        clientId:\r\n            headers['x-client-id'] ??\r\n            headers['x-installation-id'] ??\r\n            headers['client-id'] ??\r\n            headers['installation-id'],\r\n        clientIp: headers['x-forwarded-for'],\r\n        userAgent: headers['x-forwarded-for-user-agent'] ?? headers['user-agent'],\r\n    }\r\n}\r\n"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http.js","sourceRoot":"","sources":["http.ts"],"names":[],"mappings":"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","sourcesContent":["import { parse, UrlWithParsedQuery } from 'node:url'\nimport { Context, measure } from '../context.js'\nimport type { Json, ResponseHeaders, Result } from '../http.js'\nimport { ClientInfo, RootLogger } from './context.js'\nimport type { HttpHandler } from './registry.js'\n\nexport interface Response {\n    headers: { readonly [key: string]: string }\n    status: number\n    body?: string | Buffer\n}\n\ntype RequestOptions = BodylessRequestOptions | StringRequestOptions | JsonRequestOptions\n\ninterface BodylessRequestOptions {\n    uri: string\n    headers?: { readonly [key: string]: string }\n}\n\ninterface StringRequestOptions extends BodylessRequestOptions {\n    body: string\n}\n\ninterface JsonRequestOptions extends BodylessRequestOptions {\n    json: Json\n}\n\nexport async function executeRequest(\n    log: RootLogger,\n    context: Omit<Context, 'log'>,\n    handler: HttpHandler,\n    options: RequestOptions,\n    success: () => Promise<unknown>,\n): Promise<Response> {\n    const isShallow =\n        context.env.SHALLOW_KEY && options.headers?.['x-shallow'] === context.env.SHALLOW_KEY\n    const includeBodyInLogs = !handler.config?.excludeBodyFromLogs\n    const logRequest = includeBodyInLogs\n        ? { method: handler.method, ...options }\n        : withoutRequestBody({ method: handler.method, ...options })\n    log = log.enrichReserved({ meta: context.meta, request: logRequest })\n    if (isShallow) {\n        log.trace('Shallow request')\n        return {\n            headers: {},\n            status: 204,\n        }\n    }\n    log.trace('Request BEGIN')\n    try {\n        let parsedUrl: UrlWithParsedQuery & { pathStepAt: (index: number) => string }\n        let pathSteps: string[]\n        const req = {\n            rawUrl: options.uri,\n            get url() {\n                return (parsedUrl ??= {\n                    ...parse(this.rawUrl, true),\n                    pathStepAt: (index: number) => {\n                        const steps = (pathSteps ??= parsedUrl.pathname?.split('/') ?? [])\n                        const step = steps[index + 1]\n                        if (!step) {\n                            throw new RangeError(`Path does not have a step at index ${index}.`)\n                        }\n                        return step\n                    },\n                })\n            },\n            body: requestBody(options),\n            headers: options.headers ?? {},\n        }\n\n        const result = await measure(log, 'execution', () =>\n            handler.entry({ ...context, log }, req),\n        )\n\n        const response = resultToResponse(result, includeBodyInLogs)\n\n        if (context.signal.aborted) {\n            response.headers = {\n                'x-timeout': '1',\n                ...response.headers,\n            }\n        }\n\n        log = log.enrichReserved({\n            response: {\n                status: response.status,\n                headers: response.headers,\n                body: response.logBody,\n            },\n        })\n        if (response.status < 300) {\n            log.debug('Request END')\n            await success()\n        } else {\n            log.warn('Request END')\n        }\n        return response\n    } catch (e) {\n        try {\n            const response = errorToResponse(e)\n            log = log.enrichReserved({ response })\n            log.error('Request END', e)\n            return response\n        } catch (convertError) {\n            log.error('Could not convert exception to error response.', convertError)\n            return {\n                headers: {},\n                status: 500,\n            }\n        }\n    }\n}\n\nfunction resultToResponse(result: Result, withLogBody: boolean): Response & { logBody?: unknown } {\n    if (!result) {\n        return {\n            headers: {},\n            status: 204,\n        }\n    } else if (typeof result === 'string') {\n        const logBody = withLogBody ? result : undefined\n        return {\n            headers: {\n                'content-type': 'text/plain',\n            },\n            status: 200,\n            body: result,\n            logBody,\n        }\n    } else {\n        if (result.body === undefined) {\n            return {\n                headers: result.headers ?? {},\n                status: result.status ?? 200,\n            }\n        } else if (typeof result.body === 'string') {\n            const logBody = withLogBody ? result.body : undefined\n            return {\n                headers: withContentType(result.headers, 'text/plain'),\n                status: result.status ?? 200,\n                body: result.body,\n                logBody,\n            }\n        } else if (Buffer.isBuffer(result.body)) {\n            const logBody = withLogBody ? result.body.toString('base64') : undefined\n            return {\n                headers: withContentType(result.headers, 'application/octet-stream'),\n                status: result.status ?? 200,\n                body: result.body,\n                logBody,\n            }\n        } else {\n            const logBody = withLogBody ? result.body : undefined\n            return {\n                headers: withContentType(result.headers, 'application/json'),\n                status: result.status ?? 200,\n                body: JSON.stringify(result.body),\n                logBody,\n            }\n        }\n    }\n}\n\nfunction withoutRequestBody(options: RequestOptions & { method: string }) {\n    if (hasJsonBody(options)) {\n        const { json, ...bodyless } = options\n        return bodyless\n    }\n    if (hasStringBody(options)) {\n        const { body, ...bodyless } = options\n        return bodyless\n    }\n    return options\n}\n\nfunction requestBody(options: RequestOptions): Json | string | undefined {\n    if (hasJsonBody(options)) {\n        return options.json\n    }\n    if (hasStringBody(options)) {\n        return options.body\n    }\n    return undefined\n}\n\nfunction hasJsonBody(options: RequestOptions): options is JsonRequestOptions {\n    return (options as { json?: unknown }).json !== undefined\n}\n\nfunction hasStringBody(options: RequestOptions): options is StringRequestOptions {\n    return (options as { body?: unknown }).body !== undefined\n}\n\nfunction withContentType(headers: ResponseHeaders | undefined, contentType: string) {\n    if (!headers) {\n        return {\n            'content-type': contentType,\n        }\n    }\n    if (!headers['content-type']) {\n        headers['content-type'] = contentType\n    }\n    return headers\n}\n\nfunction errorToResponse(e: unknown): Response {\n    const { body, statusCode: status } = e as { body?: unknown; statusCode?: number }\n    if (typeof body === 'string') {\n        return {\n            headers: {\n                'content-type': 'text/plain',\n            },\n            status: status ?? 500,\n            body,\n        }\n    } else if (typeof body === 'object') {\n        return {\n            headers: {\n                'content-type': 'application/json',\n            },\n            status: status ?? 500,\n            body: JSON.stringify(body),\n        }\n    } else {\n        return {\n            headers: {},\n            status: status ?? 500,\n        }\n    }\n}\n\nexport function clientFromHeaders(\n    headers: { readonly [key: string]: string } | undefined,\n): ClientInfo {\n    if (!headers) {\n        return {}\n    }\n    return {\n        operationId: headers['x-request-id'] ?? headers['request-id'],\n        clientId:\n            headers['x-client-id'] ??\n            headers['x-installation-id'] ??\n            headers['client-id'] ??\n            headers['installation-id'],\n        clientIp: headers['x-forwarded-for'],\n        userAgent: headers['x-forwarded-for-user-agent'] ?? headers['user-agent'],\n    }\n}\n"]}
|
package/host/logging.js
CHANGED
|
@@ -1,15 +1,3 @@
|
|
|
1
|
-
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _LogBuffer_instances, _LogBuffer_transport, _LogBuffer_entries, _LogBuffer_size, _LogBuffer_flusher, _LogBuffer_signal, _LogBuffer_asyncTransport, _LogBuffer_timeout, _LogBuffer_startFlush, _EnrichingLogger_buffer, _EnrichingLogger_reservedEnrichment, _EnrichingLogger_customEnrichment, _EnrichingLogger_level;
|
|
13
1
|
import { performance } from 'perf_hooks';
|
|
14
2
|
export function makeLogger(transport, minimumLogLevel, signal) {
|
|
15
3
|
return new EnrichingLogger(new LogBuffer(transport, signal), minimumLogLevel
|
|
@@ -24,17 +12,16 @@ export function highPrecisionISODate(performanceNow) {
|
|
|
24
12
|
'Z');
|
|
25
13
|
}
|
|
26
14
|
class LogBuffer {
|
|
15
|
+
#transport;
|
|
16
|
+
#entries = [];
|
|
17
|
+
#size = 0;
|
|
18
|
+
#flusher;
|
|
19
|
+
#signal;
|
|
20
|
+
#asyncTransport;
|
|
21
|
+
#timeout;
|
|
27
22
|
constructor(transport, signal) {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
_LogBuffer_entries.set(this, []);
|
|
31
|
-
_LogBuffer_size.set(this, 0);
|
|
32
|
-
_LogBuffer_flusher.set(this, void 0);
|
|
33
|
-
_LogBuffer_signal.set(this, void 0);
|
|
34
|
-
_LogBuffer_asyncTransport.set(this, void 0);
|
|
35
|
-
_LogBuffer_timeout.set(this, void 0);
|
|
36
|
-
__classPrivateFieldSet(this, _LogBuffer_transport, transport, "f");
|
|
37
|
-
__classPrivateFieldSet(this, _LogBuffer_signal, signal, "f");
|
|
23
|
+
this.#transport = transport;
|
|
24
|
+
this.#signal = signal;
|
|
38
25
|
}
|
|
39
26
|
collect(level, numericLogLevel, message, error, fields, reservedEnrichment, customEnrichment) {
|
|
40
27
|
const offset = performance.now();
|
|
@@ -52,134 +39,133 @@ class LogBuffer {
|
|
|
52
39
|
: fields,
|
|
53
40
|
}),
|
|
54
41
|
});
|
|
55
|
-
|
|
42
|
+
this.#entries.push({
|
|
56
43
|
timestamp: offset,
|
|
57
44
|
level,
|
|
58
45
|
message,
|
|
59
46
|
error,
|
|
60
47
|
json,
|
|
61
48
|
});
|
|
62
|
-
|
|
63
|
-
if (
|
|
49
|
+
this.#size += json.length;
|
|
50
|
+
if (this.#asyncTransport === false) {
|
|
64
51
|
// eslint-disable-next-line no-void
|
|
65
|
-
void
|
|
66
|
-
|
|
67
|
-
|
|
52
|
+
void this.#transport.sendEntries(this.#entries, this.#signal);
|
|
53
|
+
this.#entries = [];
|
|
54
|
+
this.#size = 0;
|
|
68
55
|
}
|
|
69
|
-
else if (
|
|
70
|
-
|
|
56
|
+
else if (this.#asyncTransport === undefined) {
|
|
57
|
+
this.#asyncTransport = true;
|
|
71
58
|
setImmediate(() => {
|
|
72
|
-
if (
|
|
59
|
+
if (this.#flusher) {
|
|
73
60
|
return;
|
|
74
61
|
}
|
|
75
|
-
const sendResult =
|
|
76
|
-
|
|
77
|
-
|
|
62
|
+
const sendResult = this.#transport.sendEntries(this.#entries, this.#signal);
|
|
63
|
+
this.#entries = [];
|
|
64
|
+
this.#size = 0;
|
|
78
65
|
if (sendResult) {
|
|
79
|
-
|
|
66
|
+
this.#flusher = sendResult;
|
|
80
67
|
}
|
|
81
68
|
else {
|
|
82
|
-
|
|
69
|
+
this.#asyncTransport = false;
|
|
83
70
|
}
|
|
84
71
|
});
|
|
85
72
|
}
|
|
86
73
|
else {
|
|
87
|
-
if (numericLogLevel < 2 ||
|
|
74
|
+
if (numericLogLevel < 2 || this.#entries.length > 8 || this.#size > 64000) {
|
|
88
75
|
// eslint-disable-next-line no-void
|
|
89
76
|
void this.flush();
|
|
90
77
|
}
|
|
91
78
|
else {
|
|
92
|
-
|
|
79
|
+
this.#timeout = setTimeout(() => {
|
|
93
80
|
// eslint-disable-next-line no-void
|
|
94
81
|
void this.flush();
|
|
95
|
-
|
|
96
|
-
}, 2000)
|
|
82
|
+
this.#timeout = undefined;
|
|
83
|
+
}, 2000);
|
|
97
84
|
}
|
|
98
85
|
}
|
|
99
86
|
}
|
|
100
87
|
async flush() {
|
|
101
|
-
if (
|
|
88
|
+
if (this.#entries.length === 0) {
|
|
102
89
|
return;
|
|
103
90
|
}
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
if (
|
|
108
|
-
clearTimeout(
|
|
109
|
-
|
|
91
|
+
this.#startFlush(this.#entries);
|
|
92
|
+
this.#entries = [];
|
|
93
|
+
this.#size = 0;
|
|
94
|
+
if (this.#timeout) {
|
|
95
|
+
clearTimeout(this.#timeout);
|
|
96
|
+
this.#timeout = undefined;
|
|
110
97
|
}
|
|
111
|
-
return await
|
|
98
|
+
return await this.#flusher;
|
|
112
99
|
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
100
|
+
#startFlush(entries) {
|
|
101
|
+
if (this.#flusher) {
|
|
102
|
+
this.#flusher = this.#flusher.then(() => this.#transport.sendEntries(entries, this.#signal));
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
this.#flusher = this.#transport.sendEntries(entries, this.#signal);
|
|
106
|
+
}
|
|
120
107
|
}
|
|
121
|
-
}
|
|
108
|
+
}
|
|
122
109
|
class EnrichingLogger {
|
|
110
|
+
#buffer;
|
|
111
|
+
#reservedEnrichment;
|
|
112
|
+
#customEnrichment;
|
|
113
|
+
#level;
|
|
123
114
|
constructor(buffer, level, reservedEnrichment, customEnrichment) {
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
__classPrivateFieldSet(this, _EnrichingLogger_buffer, buffer, "f");
|
|
129
|
-
__classPrivateFieldSet(this, _EnrichingLogger_level, level, "f");
|
|
130
|
-
__classPrivateFieldSet(this, _EnrichingLogger_reservedEnrichment, reservedEnrichment, "f");
|
|
131
|
-
__classPrivateFieldSet(this, _EnrichingLogger_customEnrichment, customEnrichment, "f");
|
|
115
|
+
this.#buffer = buffer;
|
|
116
|
+
this.#level = level;
|
|
117
|
+
this.#reservedEnrichment = reservedEnrichment;
|
|
118
|
+
this.#customEnrichment = customEnrichment;
|
|
132
119
|
}
|
|
133
120
|
enrich(fields) {
|
|
134
|
-
return new EnrichingLogger(
|
|
135
|
-
...(
|
|
121
|
+
return new EnrichingLogger(this.#buffer, this.#level, this.#reservedEnrichment, {
|
|
122
|
+
...(this.#customEnrichment ?? {}),
|
|
136
123
|
...fields,
|
|
137
124
|
});
|
|
138
125
|
}
|
|
139
126
|
flush() {
|
|
140
|
-
return
|
|
127
|
+
return this.#buffer.flush();
|
|
141
128
|
}
|
|
142
129
|
enrichReserved(fields) {
|
|
143
|
-
return new EnrichingLogger(
|
|
144
|
-
...(
|
|
130
|
+
return new EnrichingLogger(this.#buffer, this.#level, {
|
|
131
|
+
...(this.#reservedEnrichment ?? {}),
|
|
145
132
|
...fields,
|
|
146
|
-
},
|
|
133
|
+
}, this.#customEnrichment);
|
|
147
134
|
}
|
|
148
135
|
trace(message, error, fields) {
|
|
149
|
-
if (
|
|
136
|
+
if (this.#level < 5) {
|
|
150
137
|
return;
|
|
151
138
|
}
|
|
152
|
-
|
|
139
|
+
this.#buffer.collect('trace', 5, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
153
140
|
}
|
|
154
141
|
debug(message, error, fields) {
|
|
155
|
-
if (
|
|
142
|
+
if (this.#level < 4) {
|
|
156
143
|
return;
|
|
157
144
|
}
|
|
158
|
-
|
|
145
|
+
this.#buffer.collect('debug', 4, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
159
146
|
}
|
|
160
147
|
info(message, error, fields) {
|
|
161
|
-
if (
|
|
148
|
+
if (this.#level < 3) {
|
|
162
149
|
return;
|
|
163
150
|
}
|
|
164
|
-
|
|
151
|
+
this.#buffer.collect('info', 3, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
165
152
|
}
|
|
166
153
|
warn(message, error, fields) {
|
|
167
|
-
if (
|
|
154
|
+
if (this.#level < 2) {
|
|
168
155
|
return;
|
|
169
156
|
}
|
|
170
|
-
|
|
157
|
+
this.#buffer.collect('warning', 2, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
171
158
|
}
|
|
172
159
|
error(message, error, fields) {
|
|
173
|
-
if (
|
|
160
|
+
if (this.#level < 1) {
|
|
174
161
|
return;
|
|
175
162
|
}
|
|
176
|
-
|
|
163
|
+
this.#buffer.collect('error', 1, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
177
164
|
}
|
|
178
165
|
fatal(message, error, fields) {
|
|
179
|
-
|
|
166
|
+
this.#buffer.collect('fatal', 0, message, error, fields, this.#reservedEnrichment, this.#customEnrichment);
|
|
180
167
|
}
|
|
181
168
|
}
|
|
182
|
-
_EnrichingLogger_buffer = new WeakMap(), _EnrichingLogger_reservedEnrichment = new WeakMap(), _EnrichingLogger_customEnrichment = new WeakMap(), _EnrichingLogger_level = new WeakMap();
|
|
183
169
|
function errorAsJson(error) {
|
|
184
170
|
if (error === undefined || error === null) {
|
|
185
171
|
return undefined;
|
|
@@ -202,4 +188,4 @@ function errorAsJson(error) {
|
|
|
202
188
|
name: typeof error,
|
|
203
189
|
};
|
|
204
190
|
}
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.js","sourceRoot":"","sources":["logging.ts"],"names":[],"mappings":"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","sourcesContent":["import { performance } from 'perf_hooks'\r\nimport { AbortSignal, Json, Logger } from '../context.js'\r\nimport { LogEntry, LogLevel, LogTransport, RootLogger } from './context.js'\r\n\r\nexport function makeLogger(\r\n    transport: LogTransport,\r\n    minimumLogLevel: LogLevel | undefined,\r\n    signal: AbortSignal,\r\n): RootLogger {\r\n    return new EnrichingLogger(\r\n        new LogBuffer(transport, signal),\r\n        minimumLogLevel\r\n            ? ['fatal', 'error', 'warning', 'info', 'debug', 'trace'].indexOf(minimumLogLevel)\r\n            : 5,\r\n        signal,\r\n    )\r\n}\r\n\r\nconst performanceTimeOrigin100ns = Math.round(performance.timeOrigin * 10000)\r\n\r\nexport function highPrecisionISODate(performanceNow: number) {\r\n    const now100ns = performanceTimeOrigin100ns + Math.round(performanceNow * 10000)\r\n    return (\r\n        new Date(now100ns / 10000).toISOString().substring(0, 20) +\r\n        (now100ns % 10000000).toString().padStart(7, '0') +\r\n        'Z'\r\n    )\r\n}\r\n\r\nclass LogBuffer {\r\n    readonly #transport: LogTransport\r\n    #entries: LogEntry[] = []\r\n    #size = 0\r\n    #flusher?: Promise<void> | undefined\r\n    readonly #signal: AbortSignal\r\n    #asyncTransport: boolean | undefined\r\n    #timeout: NodeJS.Timeout | undefined\r\n\r\n    constructor(transport: LogTransport, signal: AbortSignal) {\r\n        this.#transport = transport\r\n        this.#signal = signal\r\n    }\r\n\r\n    collect(\r\n        level: LogLevel,\r\n        numericLogLevel: number,\r\n        message: string,\r\n        error: unknown,\r\n        fields: object | undefined,\r\n        reservedEnrichment: object | undefined,\r\n        customEnrichment: object | undefined,\r\n    ) {\r\n        const offset = performance.now()\r\n        const json = JSON.stringify({\r\n            timestamp: highPrecisionISODate(offset),\r\n            level,\r\n            message,\r\n            error: errorAsJson(error),\r\n            ...reservedEnrichment,\r\n            ...((fields || customEnrichment) && {\r\n                fields: customEnrichment\r\n                    ? fields\r\n                        ? { ...customEnrichment, ...fields }\r\n                        : customEnrichment\r\n                    : fields,\r\n            }),\r\n        })\r\n        this.#entries.push({\r\n            timestamp: offset,\r\n            level,\r\n            message,\r\n            error,\r\n            json,\r\n        })\r\n        this.#size += json.length\r\n\r\n        if (this.#asyncTransport === false) {\r\n            // eslint-disable-next-line no-void\r\n            void this.#transport.sendEntries(this.#entries, this.#signal)\r\n            this.#entries = []\r\n            this.#size = 0\r\n        } else if (this.#asyncTransport === undefined) {\r\n            this.#asyncTransport = true\r\n            setImmediate(() => {\r\n                if (this.#flusher) {\r\n                    return\r\n                }\r\n                const sendResult = this.#transport.sendEntries(this.#entries, this.#signal)\r\n                this.#entries = []\r\n                this.#size = 0\r\n                if (sendResult) {\r\n                    this.#flusher = sendResult\r\n                } else {\r\n                    this.#asyncTransport = false\r\n                }\r\n            })\r\n        } else {\r\n            if (numericLogLevel < 2 || this.#entries.length > 8 || this.#size > 64000) {\r\n                // eslint-disable-next-line no-void\r\n                void this.flush()\r\n            } else {\r\n                this.#timeout = setTimeout(() => {\r\n                    // eslint-disable-next-line no-void\r\n                    void this.flush()\r\n                    this.#timeout = undefined\r\n                }, 2000)\r\n            }\r\n        }\r\n    }\r\n\r\n    async flush(): Promise<void> {\r\n        if (this.#entries.length === 0) {\r\n            return\r\n        }\r\n        this.#startFlush(this.#entries)\r\n        this.#entries = []\r\n        this.#size = 0\r\n        if (this.#timeout) {\r\n            clearTimeout(this.#timeout)\r\n            this.#timeout = undefined\r\n        }\r\n        return await this.#flusher\r\n    }\r\n\r\n    #startFlush(entries: LogEntry[]) {\r\n        if (this.#flusher) {\r\n            this.#flusher = this.#flusher.then(() =>\r\n                this.#transport.sendEntries(entries, this.#signal),\r\n            )\r\n        } else {\r\n            this.#flusher = this.#transport.sendEntries(entries, this.#signal)\r\n        }\r\n    }\r\n}\r\n\r\nclass EnrichingLogger implements Logger {\r\n    readonly #buffer: LogBuffer\r\n    readonly #reservedEnrichment?: object\r\n    readonly #customEnrichment?: object\r\n    readonly #level: number\r\n\r\n    constructor(\r\n        buffer: LogBuffer,\r\n        level: number,\r\n        reservedEnrichment?: object,\r\n        customEnrichment?: object,\r\n    ) {\r\n        this.#buffer = buffer\r\n        this.#level = level\r\n        this.#reservedEnrichment = reservedEnrichment\r\n        this.#customEnrichment = customEnrichment\r\n    }\r\n\r\n    enrich(fields: object): Logger {\r\n        return new EnrichingLogger(this.#buffer, this.#level, this.#reservedEnrichment, {\r\n            ...(this.#customEnrichment ?? {}),\r\n            ...fields,\r\n        })\r\n    }\r\n\r\n    flush() {\r\n        return this.#buffer.flush()\r\n    }\r\n\r\n    enrichReserved(fields: object): EnrichingLogger {\r\n        return new EnrichingLogger(\r\n            this.#buffer,\r\n            this.#level,\r\n            {\r\n                ...(this.#reservedEnrichment ?? {}),\r\n                ...fields,\r\n            },\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n\r\n    trace(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 5) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'trace',\r\n            5,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    debug(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 4) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'debug',\r\n            4,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    info(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 3) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'info',\r\n            3,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    warn(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 2) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'warning',\r\n            2,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    error(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 1) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'error',\r\n            1,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    fatal(message: string, error: unknown, fields: object | undefined): void {\r\n        this.#buffer.collect(\r\n            'fatal',\r\n            0,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n}\r\n\r\nfunction errorAsJson(error: unknown): Json | undefined {\r\n    if (error === undefined || error === null) {\r\n        return undefined\r\n    }\r\n    if (error instanceof Error) {\r\n        return {\r\n            message: error.message,\r\n            name: error.name,\r\n            stack: error.stack,\r\n            ...(error as unknown as { [key: string]: unknown }),\r\n        } as Json\r\n    }\r\n    if (error instanceof Object) {\r\n        return {\r\n            ...error,\r\n        } as Json\r\n    }\r\n    return {\r\n        message: (error as object | undefined)?.toString(),\r\n        name: typeof error,\r\n    } as Json\r\n}\r\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.js","sourceRoot":"","sources":["logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAIxC,MAAM,UAAU,UAAU,CACtB,SAAuB,EACvB,eAAqC,EACrC,MAAmB;IAEnB,OAAO,IAAI,eAAe,CACtB,IAAI,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC,EAChC,eAAe;QACX,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;QAClF,CAAC,CAAC,CAAC,EACP,MAAM,CACT,CAAA;AACL,CAAC;AAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,GAAG,KAAK,CAAC,CAAA;AAE7E,MAAM,UAAU,oBAAoB,CAAC,cAAsB;IACvD,MAAM,QAAQ,GAAG,0BAA0B,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,GAAG,KAAK,CAAC,CAAA;IAChF,OAAO,CACH,IAAI,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;QACzD,CAAC,QAAQ,GAAG,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;QACjD,GAAG,CACN,CAAA;AACL,CAAC;AAED,MAAM,SAAS;IACF,UAAU,CAAc;IACjC,QAAQ,GAAe,EAAE,CAAA;IACzB,KAAK,GAAG,CAAC,CAAA;IACT,QAAQ,CAA4B;IAC3B,OAAO,CAAa;IAC7B,eAAe,CAAqB;IACpC,QAAQ,CAA4B;IAEpC,YAAY,SAAuB,EAAE,MAAmB;QACpD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAA;QAC3B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;IACzB,CAAC;IAED,OAAO,CACH,KAAe,EACf,eAAuB,EACvB,OAAe,EACf,KAAc,EACd,MAA0B,EAC1B,kBAAsC,EACtC,gBAAoC;QAEpC,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE,CAAA;QAChC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;YACxB,SAAS,EAAE,oBAAoB,CAAC,MAAM,CAAC;YACvC,KAAK;YACL,OAAO;YACP,KAAK,EAAE,WAAW,CAAC,KAAK,CAAC;YACzB,GAAG,kBAAkB;YACrB,GAAG,CAAC,CAAC,MAAM,IAAI,gBAAgB,CAAC,IAAI;gBAChC,MAAM,EAAE,gBAAgB;oBACpB,CAAC,CAAC,MAAM;wBACJ,CAAC,CAAC,EAAE,GAAG,gBAAgB,EAAE,GAAG,MAAM,EAAE;wBACpC,CAAC,CAAC,gBAAgB;oBACtB,CAAC,CAAC,MAAM;aACf,CAAC;SACL,CAAC,CAAA;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACf,SAAS,EAAE,MAAM;YACjB,KAAK;YACL,OAAO;YACP,KAAK;YACL,IAAI;SACP,CAAC,CAAA;QACF,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,CAAA;QAEzB,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE;YAChC,mCAAmC;YACnC,KAAK,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;YAC7D,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;YAClB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAA;SACjB;aAAM,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS,EAAE;YAC3C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;YAC3B,YAAY,CAAC,GAAG,EAAE;gBACd,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACf,OAAM;iBACT;gBACD,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;gBAC3E,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;gBAClB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAA;gBACd,IAAI,UAAU,EAAE;oBACZ,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;iBAC7B;qBAAM;oBACH,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;iBAC/B;YACL,CAAC,CAAC,CAAA;SACL;aAAM;YACH,IAAI,eAAe,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,KAAK,EAAE;gBACvE,mCAAmC;gBACnC,KAAK,IAAI,CAAC,KAAK,EAAE,CAAA;aACpB;iBAAM;gBACH,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC,GAAG,EAAE;oBAC5B,mCAAmC;oBACnC,KAAK,IAAI,CAAC,KAAK,EAAE,CAAA;oBACjB,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAA;gBAC7B,CAAC,EAAE,IAAI,CAAC,CAAA;aACX;SACJ;IACL,CAAC;IAED,KAAK,CAAC,KAAK;QACP,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YAC5B,OAAM;SACT;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC/B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QAClB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAA;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;YAC3B,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAA;SAC5B;QACD,OAAO,MAAM,IAAI,CAAC,QAAQ,CAAA;IAC9B,CAAC;IAED,WAAW,CAAC,OAAmB;QAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CACpC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CACrD,CAAA;SACJ;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;SACrE;IACL,CAAC;CACJ;AAED,MAAM,eAAe;IACR,OAAO,CAAW;IAClB,mBAAmB,CAAS;IAC5B,iBAAiB,CAAS;IAC1B,MAAM,CAAQ;IAEvB,YACI,MAAiB,EACjB,KAAa,EACb,kBAA2B,EAC3B,gBAAyB;QAEzB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACnB,IAAI,CAAC,mBAAmB,GAAG,kBAAkB,CAAA;QAC7C,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAA;IAC7C,CAAC;IAED,MAAM,CAAC,MAAc;QACjB,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,mBAAmB,EAAE;YAC5E,GAAG,CAAC,IAAI,CAAC,iBAAiB,IAAI,EAAE,CAAC;YACjC,GAAG,MAAM;SACZ,CAAC,CAAA;IACN,CAAC;IAED,KAAK;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;IAC/B,CAAC;IAED,cAAc,CAAC,MAAc;QACzB,OAAO,IAAI,eAAe,CACtB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,MAAM,EACX;YACI,GAAG,CAAC,IAAI,CAAC,mBAAmB,IAAI,EAAE,CAAC;YACnC,GAAG,MAAM;SACZ,EACD,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC7D,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,OAAM;SACT;QACD,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,OAAO,EACP,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC7D,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,OAAM;SACT;QACD,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,OAAO,EACP,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IACD,IAAI,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC5D,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,OAAM;SACT;QACD,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,MAAM,EACN,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IACD,IAAI,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC5D,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,OAAM;SACT;QACD,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,SAAS,EACT,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC7D,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,OAAM;SACT;QACD,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,OAAO,EACP,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;IACD,KAAK,CAAC,OAAe,EAAE,KAAc,EAAE,MAA0B;QAC7D,IAAI,CAAC,OAAO,CAAC,OAAO,CAChB,OAAO,EACP,CAAC,EACD,OAAO,EACP,KAAK,EACL,MAAM,EACN,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,iBAAiB,CACzB,CAAA;IACL,CAAC;CACJ;AAED,SAAS,WAAW,CAAC,KAAc;IAC/B,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;QACvC,OAAO,SAAS,CAAA;KACnB;IACD,IAAI,KAAK,YAAY,KAAK,EAAE;QACxB,OAAO;YACH,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,GAAI,KAA+C;SAC9C,CAAA;KACZ;IACD,IAAI,KAAK,YAAY,MAAM,EAAE;QACzB,OAAO;YACH,GAAG,KAAK;SACH,CAAA;KACZ;IACD,OAAO;QACH,OAAO,EAAG,KAA4B,EAAE,QAAQ,EAAE;QAClD,IAAI,EAAE,OAAO,KAAK;KACb,CAAA;AACb,CAAC","sourcesContent":["import { performance } from 'perf_hooks'\nimport { AbortSignal, Json, Logger } from '../context.js'\nimport { LogEntry, LogLevel, LogTransport, RootLogger } from './context.js'\n\nexport function makeLogger(\n    transport: LogTransport,\n    minimumLogLevel: LogLevel | undefined,\n    signal: AbortSignal,\n): RootLogger {\n    return new EnrichingLogger(\n        new LogBuffer(transport, signal),\n        minimumLogLevel\n            ? ['fatal', 'error', 'warning', 'info', 'debug', 'trace'].indexOf(minimumLogLevel)\n            : 5,\n        signal,\n    )\n}\n\nconst performanceTimeOrigin100ns = Math.round(performance.timeOrigin * 10000)\n\nexport function highPrecisionISODate(performanceNow: number) {\n    const now100ns = performanceTimeOrigin100ns + Math.round(performanceNow * 10000)\n    return (\n        new Date(now100ns / 10000).toISOString().substring(0, 20) +\n        (now100ns % 10000000).toString().padStart(7, '0') +\n        'Z'\n    )\n}\n\nclass LogBuffer {\n    readonly #transport: LogTransport\n    #entries: LogEntry[] = []\n    #size = 0\n    #flusher?: Promise<void> | undefined\n    readonly #signal: AbortSignal\n    #asyncTransport: boolean | undefined\n    #timeout: NodeJS.Timeout | undefined\n\n    constructor(transport: LogTransport, signal: AbortSignal) {\n        this.#transport = transport\n        this.#signal = signal\n    }\n\n    collect(\n        level: LogLevel,\n        numericLogLevel: number,\n        message: string,\n        error: unknown,\n        fields: object | undefined,\n        reservedEnrichment: object | undefined,\n        customEnrichment: object | undefined,\n    ) {\n        const offset = performance.now()\n        const json = JSON.stringify({\n            timestamp: highPrecisionISODate(offset),\n            level,\n            message,\n            error: errorAsJson(error),\n            ...reservedEnrichment,\n            ...((fields || customEnrichment) && {\n                fields: customEnrichment\n                    ? fields\n                        ? { ...customEnrichment, ...fields }\n                        : customEnrichment\n                    : fields,\n            }),\n        })\n        this.#entries.push({\n            timestamp: offset,\n            level,\n            message,\n            error,\n            json,\n        })\n        this.#size += json.length\n\n        if (this.#asyncTransport === false) {\n            // eslint-disable-next-line no-void\n            void this.#transport.sendEntries(this.#entries, this.#signal)\n            this.#entries = []\n            this.#size = 0\n        } else if (this.#asyncTransport === undefined) {\n            this.#asyncTransport = true\n            setImmediate(() => {\n                if (this.#flusher) {\n                    return\n                }\n                const sendResult = this.#transport.sendEntries(this.#entries, this.#signal)\n                this.#entries = []\n                this.#size = 0\n                if (sendResult) {\n                    this.#flusher = sendResult\n                } else {\n                    this.#asyncTransport = false\n                }\n            })\n        } else {\n            if (numericLogLevel < 2 || this.#entries.length > 8 || this.#size > 64000) {\n                // eslint-disable-next-line no-void\n                void this.flush()\n            } else {\n                this.#timeout = setTimeout(() => {\n                    // eslint-disable-next-line no-void\n                    void this.flush()\n                    this.#timeout = undefined\n                }, 2000)\n            }\n        }\n    }\n\n    async flush(): Promise<void> {\n        if (this.#entries.length === 0) {\n            return\n        }\n        this.#startFlush(this.#entries)\n        this.#entries = []\n        this.#size = 0\n        if (this.#timeout) {\n            clearTimeout(this.#timeout)\n            this.#timeout = undefined\n        }\n        return await this.#flusher\n    }\n\n    #startFlush(entries: LogEntry[]) {\n        if (this.#flusher) {\n            this.#flusher = this.#flusher.then(() =>\n                this.#transport.sendEntries(entries, this.#signal),\n            )\n        } else {\n            this.#flusher = this.#transport.sendEntries(entries, this.#signal)\n        }\n    }\n}\n\nclass EnrichingLogger implements Logger {\n    readonly #buffer: LogBuffer\n    readonly #reservedEnrichment?: object\n    readonly #customEnrichment?: object\n    readonly #level: number\n\n    constructor(\n        buffer: LogBuffer,\n        level: number,\n        reservedEnrichment?: object,\n        customEnrichment?: object,\n    ) {\n        this.#buffer = buffer\n        this.#level = level\n        this.#reservedEnrichment = reservedEnrichment\n        this.#customEnrichment = customEnrichment\n    }\n\n    enrich(fields: object): Logger {\n        return new EnrichingLogger(this.#buffer, this.#level, this.#reservedEnrichment, {\n            ...(this.#customEnrichment ?? {}),\n            ...fields,\n        })\n    }\n\n    flush() {\n        return this.#buffer.flush()\n    }\n\n    enrichReserved(fields: object): EnrichingLogger {\n        return new EnrichingLogger(\n            this.#buffer,\n            this.#level,\n            {\n                ...(this.#reservedEnrichment ?? {}),\n                ...fields,\n            },\n            this.#customEnrichment,\n        )\n    }\n\n    trace(message: string, error: unknown, fields: object | undefined): void {\n        if (this.#level < 5) {\n            return\n        }\n        this.#buffer.collect(\n            'trace',\n            5,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n    debug(message: string, error: unknown, fields: object | undefined): void {\n        if (this.#level < 4) {\n            return\n        }\n        this.#buffer.collect(\n            'debug',\n            4,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n    info(message: string, error: unknown, fields: object | undefined): void {\n        if (this.#level < 3) {\n            return\n        }\n        this.#buffer.collect(\n            'info',\n            3,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n    warn(message: string, error: unknown, fields: object | undefined): void {\n        if (this.#level < 2) {\n            return\n        }\n        this.#buffer.collect(\n            'warning',\n            2,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n    error(message: string, error: unknown, fields: object | undefined): void {\n        if (this.#level < 1) {\n            return\n        }\n        this.#buffer.collect(\n            'error',\n            1,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n    fatal(message: string, error: unknown, fields: object | undefined): void {\n        this.#buffer.collect(\n            'fatal',\n            0,\n            message,\n            error,\n            fields,\n            this.#reservedEnrichment,\n            this.#customEnrichment,\n        )\n    }\n}\n\nfunction errorAsJson(error: unknown): Json | undefined {\n    if (error === undefined || error === null) {\n        return undefined\n    }\n    if (error instanceof Error) {\n        return {\n            message: error.message,\n            name: error.name,\n            stack: error.stack,\n            ...(error as unknown as { [key: string]: unknown }),\n        } as Json\n    }\n    if (error instanceof Object) {\n        return {\n            ...error,\n        } as Json\n    }\n    return {\n        message: (error as object | undefined)?.toString(),\n        name: typeof error,\n    } as Json\n}\n"]}
|
package/host/reflect.js
CHANGED
|
@@ -55,4 +55,4 @@ async function readConfig() {
|
|
|
55
55
|
const packageJson = JSON.parse(await readFile('package.json', 'utf-8'));
|
|
56
56
|
return packageJson;
|
|
57
57
|
}
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reflect.js","sourceRoot":"","sources":["reflect.ts"],"names":[],"mappings":"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","sourcesContent":["import { readdir, readFile } from 'node:fs/promises'\nimport { basename, extname, join, resolve } from 'node:path'\nimport { pathToFileURL } from 'node:url'\nimport { HttpHandlerConfiguration } from '../http.js'\nimport { PackageConfiguration } from './registry.js'\n\ntype CPU =\n    | 'arm'\n    | 'arm64'\n    | 'ia32'\n    | 'mips'\n    | 'mipsel'\n    | 'ppc'\n    | 'ppc64'\n    | 's390'\n    | 's390x'\n    | 'x32'\n    | 'x64'\ntype CpuConfig = CPU | `!${CPU}`\ntype OSConfig = NodeJS.Platform | `!${NodeJS.Platform}`\n\nexport interface PackageJsonConfiguration {\n    nodeVersion?: string\n    cpus?: CpuConfig[]\n    os?: OSConfig[]\n}\n\nexport interface Reflection {\n    name: string\n    http: {\n        name: string\n        method: string\n        pathPattern: string\n        pathRegExp: RegExp\n        config: HttpHandlerConfiguration & PackageJsonConfiguration\n    }[]\n}\n\nexport function resolveCpu(config: PackageJsonConfiguration, supported: CPU[]): CPU {\n    const resolved = resolveSupported(config.cpus, supported)\n    if (!resolved) {\n        // resolve<T>(config, supported) actually asserts config is (T | `!${T}`)[], but that's not supported yet.\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        throw new Error('Unsupported CPUs: ' + config.cpus!.join(', '))\n    }\n    return resolved\n}\n\nexport function resolveOS(\n    config: PackageJsonConfiguration,\n    supported: NodeJS.Platform[],\n): NodeJS.Platform {\n    const resolved = resolveSupported(config.os, supported)\n    if (!resolved) {\n        // resolve<T>(config, supported) actually asserts config is (T | `!${T}`)[], but that's not supported yet.\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        throw new Error('Unsupported operating systems: ' + config.os!.join(', '))\n    }\n    return resolved\n}\n\nfunction resolveSupported<T extends string>(\n    config: (T | `!${T}`)[] | undefined,\n    supported: T[],\n): T | undefined {\n    if (!config) {\n        return supported[0]\n    }\n    return supported.find(s => config.includes(s) && !config.includes(`!${s}`))\n}\n\nexport async function reflect(path: string): Promise<Reflection> {\n    const packageJson = await readConfig()\n    const absolutePath = resolve(process.cwd(), path)\n    const files = (await readdir(absolutePath)).filter(\n        file => extname(file) === '.ts' && !file.endsWith('.d.ts'),\n    )\n    const { getHandlers, setMeta } = (await import(\n        pathToFileURL(join(absolutePath, 'node_modules/@riddance/host/host/registry.js')).toString()\n    )) as {\n        getHandlers: (type: string) => {\n            name: string\n            meta?: { fileName: string }\n            config: HttpHandlerConfiguration\n            method: string\n            pathPattern: string\n            pathRegExp: RegExp\n        }[]\n        setMeta: (\n            packageName: string,\n            fileName: string,\n            rev: string | undefined,\n            cfg: PackageConfiguration | undefined,\n        ) => void\n    }\n\n    for (const file of files) {\n        const base = basename(file, '.ts')\n        setMeta(packageJson.name, base, undefined, packageJson.config)\n        await import(pathToFileURL(join(absolutePath, base + '.js')).toString())\n    }\n\n    return {\n        name: packageJson.name,\n        http: getHandlers('http').map(h => ({\n            config: {\n                ...h.config,\n                cpus: packageJson.cpu,\n                os: packageJson.os,\n                nodeVersion: packageJson.engines?.node,\n            },\n            name: h.meta?.fileName ?? '',\n            method: h.method,\n            pathPattern: h.pathPattern,\n            pathRegExp: h.pathRegExp,\n        })),\n    }\n}\n\nasync function readConfig() {\n    const packageJson = JSON.parse(await readFile('package.json', 'utf-8')) as {\n        name: string\n        engines?: { [engine: string]: string }\n        cpu?: CpuConfig[]\n        os?: OSConfig[]\n        config?: object\n    }\n    return packageJson\n}\n"]}
|
package/host/registry.js
CHANGED
|
@@ -58,4 +58,4 @@ export function registerHttpHandler(method, path, configOrHandler, fn) {
|
|
|
58
58
|
httpHostRegistry(getMetadata(), configOrHandler, method, path, fn);
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJyZWdpc3RyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQkEsTUFBTSxRQUFRLEdBQWlDLEVBQUUsQ0FBQTtBQUVqRCxTQUFTLFVBQVUsQ0FBQyxJQUF3QixFQUFFLE9BQW9CO0lBQzlELENBQUM7SUFBQSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7QUFDMUMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBd0I7SUFDaEQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQWtCLENBQUE7QUFDbEQsQ0FBQztBQVVELElBQUksZ0JBQTBCLENBQUE7QUFFOUIsU0FBUyxXQUFXLENBQUMsSUFBYztJQUMvQixnQkFBZ0IsR0FBRyxJQUFJLENBQUE7QUFDM0IsQ0FBQztBQUVELElBQUksUUFBOEIsQ0FBQTtBQUVsQyxNQUFNLFVBQVUsT0FBTyxDQUNuQixXQUFtQixFQUNuQixRQUFnQixFQUNoQixRQUE0QixFQUM1QixNQUF3QztJQUV4QyxRQUFRLEdBQUc7UUFDUCxXQUFXO1FBQ1gsUUFBUTtRQUNSLFFBQVE7UUFDUixNQUFNO0tBQ1QsQ0FBQTtBQUNMLENBQUM7QUFjRCxTQUFTLFdBQVc7SUFDaEIsT0FBTyxRQUFRLENBQUE7QUFDbkIsQ0FBQztBQUVELFNBQVMsWUFBWSxDQUFDLElBQVk7SUFDOUIsT0FBTyxJQUFJLE1BQU0sQ0FDYixDQUNJLEdBQUc7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLHNCQUFzQixFQUFFLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDO1FBQ3hFLFdBQVcsQ0FDZCxDQUFDLE9BQU8sQ0FBQywyQkFBMkIsRUFBRSxFQUFFLENBQUMsRUFDMUMsR0FBRyxDQUNOLENBQUE7QUFDTCxDQUFDO0FBRUQsU0FBUyxhQUFhLENBQ2xCLElBQXNDLEVBQ3RDLFFBQTBDO0lBRTFDLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRTtRQUNwQixPQUFPLFFBQVEsQ0FBQTtLQUNsQjtTQUFNLElBQUksUUFBUSxLQUFLLFNBQVMsRUFBRTtRQUMvQixPQUFPLElBQUksQ0FBQTtLQUNkO0lBQ0QsT0FBTyxFQUFFLEdBQUcsSUFBSSxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUE7QUFDbkMsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUNiLElBQTBCLEVBQzFCLEdBQXFDLEVBQ3JDLE1BQWMsRUFDZCxJQUFZLEVBQ1osS0FBYztJQUVkLFVBQVUsQ0FBQyxNQUFNLEVBQUU7UUFDZixJQUFJO1FBQ0osTUFBTSxFQUFFLGFBQWEsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLEdBQUcsQ0FBQztRQUN4QyxNQUFNO1FBQ04sV0FBVyxFQUFFLElBQUk7UUFDakIsVUFBVSxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUM7UUFDOUIsS0FBSztLQUNSLENBQUMsQ0FBQTtBQUNOLENBQUM7QUFFRCxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUE7QUFJckIsTUFBTSxVQUFVLG1CQUFtQixDQUMvQixNQUFjLEVBQ2QsSUFBWSxFQUNaLGVBQStDLEVBQy9DLEVBQVk7SUFFWixJQUFJLE9BQU8sZUFBZSxLQUFLLFVBQVUsRUFBRTtRQUN2QyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQTtLQUM1RTtTQUFNO1FBQ0gsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FBQTtTQUN4RDtRQUNELGdCQUFnQixDQUFDLFdBQVcsRUFBRSxFQUFFLGVBQWUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0tBQ3JFO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhbmRsZXJDb25maWd1cmF0aW9uIH0gZnJvbSAnLi4vY29udGV4dC5qcydcbmltcG9ydCB7IEhhbmRsZXIgfSBmcm9tICcuLi9odHRwLmpzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBIYW5kbGVyIHtcbiAgICBtZXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZFxuICAgIGNvbmZpZzogKFBhY2thZ2VDb25maWd1cmF0aW9uICYgSGFuZGxlckNvbmZpZ3VyYXRpb24pIHwgdW5kZWZpbmVkXG4gICAgbWV0aG9kOiBNZXRob2RcbiAgICBwYXRoUGF0dGVybjogc3RyaW5nXG4gICAgcGF0aFJlZ0V4cDogUmVnRXhwXG4gICAgZW50cnk6IEhhbmRsZXJcbn1cblxuaW50ZXJmYWNlIEhhbmRsZXJUeXBlcyB7XG4gICAgaHR0cDogSHR0cEhhbmRsZXJcbn1cblxuY29uc3QgaGFuZGxlcnM6IHsgW2tleTogc3RyaW5nXTogdW5rbm93bltdIH0gPSB7fVxuXG5mdW5jdGlvbiBhZGRIYW5kbGVyKHR5cGU6IGtleW9mIEhhbmRsZXJUeXBlcywgaGFuZGxlcjogSHR0cEhhbmRsZXIpIHtcbiAgICA7KGhhbmRsZXJzW3R5cGVdID8/PSBbXSkucHVzaChoYW5kbGVyKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SGFuZGxlcnModHlwZToga2V5b2YgSGFuZGxlclR5cGVzKSB7XG4gICAgcmV0dXJuIChoYW5kbGVyc1t0eXBlXSA/PyBbXSkgYXMgSHR0cEhhbmRsZXJbXVxufVxuXG50eXBlIEh0dHBIb3N0ID0gKFxuICAgIG1ldGE6IE1ldGFkYXRhIHwgdW5kZWZpbmVkLFxuICAgIGNvbmZpZzogSGFuZGxlckNvbmZpZ3VyYXRpb24gfCB1bmRlZmluZWQsXG4gICAgbWV0aG9kOiBNZXRob2QsXG4gICAgcGF0aDogc3RyaW5nLFxuICAgIGhhbmRsZXI6IEhhbmRsZXIsXG4pID0+IHZvaWRcblxubGV0IGh0dHBIb3N0UmVnaXN0cnk6IEh0dHBIb3N0XG5cbmZ1bmN0aW9uIHNldEh0dHBIb3N0KGhvc3Q6IEh0dHBIb3N0KSB7XG4gICAgaHR0cEhvc3RSZWdpc3RyeSA9IGhvc3Rcbn1cblxubGV0IG1ldGFkYXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZFxuXG5leHBvcnQgZnVuY3Rpb24gc2V0TWV0YShcbiAgICBwYWNrYWdlTmFtZTogc3RyaW5nLFxuICAgIGZpbGVOYW1lOiBzdHJpbmcsXG4gICAgcmV2aXNpb246IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBjb25maWc6IFBhY2thZ2VDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuKSB7XG4gICAgbWV0YWRhdGEgPSB7XG4gICAgICAgIHBhY2thZ2VOYW1lLFxuICAgICAgICBmaWxlTmFtZSxcbiAgICAgICAgcmV2aXNpb24sXG4gICAgICAgIGNvbmZpZyxcbiAgICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlXG5leHBvcnQgaW50ZXJmYWNlIFBhY2thZ2VDb25maWd1cmF0aW9uIGV4dGVuZHMgSGFuZGxlckNvbmZpZ3VyYXRpb24ge1xuICAgIC8vIFBsYWNlaG9sZGVyIGZvciBwYWNrYWdlLWxldmVsIGNvbmZpZ3VyYXRpb25zXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWV0YWRhdGEge1xuICAgIHBhY2thZ2VOYW1lOiBzdHJpbmdcbiAgICBmaWxlTmFtZTogc3RyaW5nXG4gICAgcmV2aXNpb246IHN0cmluZyB8IHVuZGVmaW5lZFxuICAgIGNvbmZpZz86IFBhY2thZ2VDb25maWd1cmF0aW9uXG59XG5cbmZ1bmN0aW9uIGdldE1ldGFkYXRhKCkge1xuICAgIHJldHVybiBtZXRhZGF0YVxufVxuXG5mdW5jdGlvbiBwYXRoVG9SZWdFeHAocGF0aDogc3RyaW5nKSB7XG4gICAgcmV0dXJuIG5ldyBSZWdFeHAoXG4gICAgICAgIChcbiAgICAgICAgICAgICdeJyArXG4gICAgICAgICAgICBwYXRoLnJlcGxhY2UoL1svXFxcXF4kKz8uKCl8W1xcXXt9XS9ndSwgJ1xcXFwkJicpLnJlcGxhY2VBbGwoJyonLCAnW14vXFxcXD9dKycpICtcbiAgICAgICAgICAgICcoXFxcXD8uKik/JCdcbiAgICAgICAgKS5yZXBsYWNlKCdbXi9cXFxcP10rW14vXFxcXD9dKyhcXFxcPy4qKT8kJywgJycpLFxuICAgICAgICAndScsXG4gICAgKVxufVxuXG5mdW5jdGlvbiBjb21iaW5lQ29uZmlnKFxuICAgIGJhc2U6IFBhY2thZ2VDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuICAgIG92ZXJyaWRlOiBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IHVuZGVmaW5lZCxcbik6IChQYWNrYWdlQ29uZmlndXJhdGlvbiAmIEhhbmRsZXJDb25maWd1cmF0aW9uKSB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKGJhc2UgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXR1cm4gb3ZlcnJpZGVcbiAgICB9IGVsc2UgaWYgKG92ZXJyaWRlID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuIGJhc2VcbiAgICB9XG4gICAgcmV0dXJuIHsgLi4uYmFzZSwgLi4ub3ZlcnJpZGUgfVxufVxuXG5mdW5jdGlvbiBodHRwSG9zdChcbiAgICBtZXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZCxcbiAgICBjZmc6IEhhbmRsZXJDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuICAgIG1ldGhvZDogTWV0aG9kLFxuICAgIHBhdGg6IHN0cmluZyxcbiAgICBlbnRyeTogSGFuZGxlcixcbikge1xuICAgIGFkZEhhbmRsZXIoJ2h0dHAnLCB7XG4gICAgICAgIG1ldGEsXG4gICAgICAgIGNvbmZpZzogY29tYmluZUNvbmZpZyhtZXRhPy5jb25maWcsIGNmZyksXG4gICAgICAgIG1ldGhvZCxcbiAgICAgICAgcGF0aFBhdHRlcm46IHBhdGgsXG4gICAgICAgIHBhdGhSZWdFeHA6IHBhdGhUb1JlZ0V4cChwYXRoKSxcbiAgICAgICAgZW50cnksXG4gICAgfSlcbn1cblxuc2V0SHR0cEhvc3QoaHR0cEhvc3QpXG5cbmV4cG9ydCB0eXBlIE1ldGhvZCA9ICdHRVQnIHwgJ1BPU1QnIHwgJ1BVVCcgfCAnUEFUQ0gnIHwgJ0RFTEVURSdcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVySHR0cEhhbmRsZXIoXG4gICAgbWV0aG9kOiBNZXRob2QsXG4gICAgcGF0aDogc3RyaW5nLFxuICAgIGNvbmZpZ09ySGFuZGxlcjogSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxuICAgIGZuPzogSGFuZGxlcixcbik6IHZvaWQge1xuICAgIGlmICh0eXBlb2YgY29uZmlnT3JIYW5kbGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIGh0dHBIb3N0UmVnaXN0cnkoZ2V0TWV0YWRhdGEoKSwgdW5kZWZpbmVkLCBtZXRob2QsIHBhdGgsIGNvbmZpZ09ySGFuZGxlcilcbiAgICB9IGVsc2Uge1xuICAgICAgICBpZiAoIWZuKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1BsZWFzZSBwcm92aWRlIGEgaGFuZGxlciBmdW5jdGlvbi4nKVxuICAgICAgICB9XG4gICAgICAgIGh0dHBIb3N0UmVnaXN0cnkoZ2V0TWV0YWRhdGEoKSwgY29uZmlnT3JIYW5kbGVyLCBtZXRob2QsIHBhdGgsIGZuKVxuICAgIH1cbn1cbiJdfQ==
|
package/http.js
CHANGED
|
@@ -15,4 +15,4 @@ export function patch(path, configOrHandler, fn) {
|
|
|
15
15
|
export function del(path, configOrHandler, fn) {
|
|
16
16
|
registerHttpHandler('DELETE', path, configOrHandler, fn);
|
|
17
17
|
}
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImh0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0JBQW9CLENBQUE7QUFFeEQsY0FBYyxjQUFjLENBQUE7QUFpQzVCLE1BQU0sVUFBVSxHQUFHLENBQ2YsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUN6RCxDQUFDO0FBR0QsTUFBTSxVQUFVLElBQUksQ0FDaEIsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUMxRCxDQUFDO0FBR0QsTUFBTSxVQUFVLEdBQUcsQ0FDZixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQ3pELENBQUM7QUFHRCxNQUFNLFVBQVUsS0FBSyxDQUNqQixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQzNELENBQUM7QUFHRCxNQUFNLFVBQVUsR0FBRyxDQUNmLElBQVksRUFDWixlQUFtRCxFQUNuRCxFQUFZO0lBRVosbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7QUFDNUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVXJsV2l0aFBhcnNlZFF1ZXJ5IH0gZnJvbSAnbm9kZTp1cmwnXG5pbXBvcnQgeyBDb250ZXh0LCBIYW5kbGVyQ29uZmlndXJhdGlvbiwgSnNvbiB9IGZyb20gJy4vY29udGV4dC5qcydcbmltcG9ydCB7IHJlZ2lzdGVySHR0cEhhbmRsZXIgfSBmcm9tICcuL2hvc3QvcmVnaXN0cnkuanMnXG5cbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC5qcydcblxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZUhlYWRlcnMge1xuICAgIFtrZXk6IHN0cmluZ106IHN0cmluZ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZ1bGxSZXN1bHQge1xuICAgIGhlYWRlcnM/OiBSZXNwb25zZUhlYWRlcnNcbiAgICBzdGF0dXM/OiBudW1iZXJcbiAgICBib2R5PzogdW5rbm93blxufVxuXG5leHBvcnQgdHlwZSBSZXN1bHQgPSB2b2lkIHwgc3RyaW5nIHwgRnVsbFJlc3VsdFxuXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBSZXF1ZXN0IHtcbiAgICByZWFkb25seSByYXdVcmw6IHN0cmluZ1xuICAgIHJlYWRvbmx5IHVybDogUmVhZG9ubHk8VXJsV2l0aFBhcnNlZFF1ZXJ5PiAmIHsgcGF0aFN0ZXBBdDogKGluZGV4OiBudW1iZXIpID0+IHN0cmluZyB9XG4gICAgcmVhZG9ubHkgaGVhZGVyczogUmVhZG9ubHk8UmVzcG9uc2VIZWFkZXJzPlxuICAgIHJlYWRvbmx5IGJvZHk/OiBKc29uIHwgc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIGV4dGVuZHMgSGFuZGxlckNvbmZpZ3VyYXRpb24ge1xuICAgIC8qKlxuICAgICAqIEEgc3RyaW5nIGlkZW50aWZ5aW5nIHdoaWNoIGRvbWFpbnMgY2FuIGFjY2VzcyB0aGUgZW5kcG9pbnQgY3Jvc3Mtb3JpZ2luLlxuICAgICAqIEBkZWZhdWx0IHVuZGVmaW5lZFxuICAgICAqL1xuICAgIHJlYWRvbmx5IGNvcnM/OiBzdHJpbmdcbn1cblxuZXhwb3J0IHR5cGUgSGFuZGxlciA9IChjb250ZXh0OiBDb250ZXh0LCByZXF1ZXN0OiBIdHRwUmVxdWVzdCkgPT4gUHJvbWlzZTxSZXN1bHQ+IHwgUmVzdWx0XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXQocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcbmV4cG9ydCBmdW5jdGlvbiBnZXQocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXG5leHBvcnQgZnVuY3Rpb24gZ2V0KFxuICAgIHBhdGg6IHN0cmluZyxcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXG4gICAgZm4/OiBIYW5kbGVyLFxuKTogdm9pZCB7XG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignR0VUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcbn1cbmV4cG9ydCBmdW5jdGlvbiBwb3N0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXG5leHBvcnQgZnVuY3Rpb24gcG9zdChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcbmV4cG9ydCBmdW5jdGlvbiBwb3N0KFxuICAgIHBhdGg6IHN0cmluZyxcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXG4gICAgZm4/OiBIYW5kbGVyLFxuKTogdm9pZCB7XG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUE9TVCcsIHBhdGgsIGNvbmZpZ09ySGFuZGxlciwgZm4pXG59XG5leHBvcnQgZnVuY3Rpb24gcHV0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXG5leHBvcnQgZnVuY3Rpb24gcHV0KHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxuZXhwb3J0IGZ1bmN0aW9uIHB1dChcbiAgICBwYXRoOiBzdHJpbmcsXG4gICAgY29uZmlnT3JIYW5kbGVyOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxuICAgIGZuPzogSGFuZGxlcixcbik6IHZvaWQge1xuICAgIHJlZ2lzdGVySHR0cEhhbmRsZXIoJ1BVVCcsIHBhdGgsIGNvbmZpZ09ySGFuZGxlciwgZm4pXG59XG5leHBvcnQgZnVuY3Rpb24gcGF0Y2gocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcbmV4cG9ydCBmdW5jdGlvbiBwYXRjaChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcbmV4cG9ydCBmdW5jdGlvbiBwYXRjaChcbiAgICBwYXRoOiBzdHJpbmcsXG4gICAgY29uZmlnT3JIYW5kbGVyOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxuICAgIGZuPzogSGFuZGxlcixcbik6IHZvaWQge1xuICAgIHJlZ2lzdGVySHR0cEhhbmRsZXIoJ1BBVENIJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcbn1cbmV4cG9ydCBmdW5jdGlvbiBkZWwocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcbmV4cG9ydCBmdW5jdGlvbiBkZWwocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXG5leHBvcnQgZnVuY3Rpb24gZGVsKFxuICAgIHBhdGg6IHN0cmluZyxcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXG4gICAgZm4/OiBIYW5kbGVyLFxuKTogdm9pZCB7XG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignREVMRVRFJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcbn1cbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@riddance/host",
|
|
3
|
+
"version": "0.0.11",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"license": "MIT",
|
|
6
|
+
"engines": {
|
|
7
|
+
"node": ">=16"
|
|
8
|
+
},
|
|
9
|
+
"keywords": [
|
|
10
|
+
"riddance",
|
|
11
|
+
"serverless",
|
|
12
|
+
"environment",
|
|
13
|
+
"devenv",
|
|
14
|
+
"opinionated"
|
|
15
|
+
],
|
|
16
|
+
"files": [
|
|
17
|
+
"*.js",
|
|
18
|
+
"*.d.ts",
|
|
19
|
+
"host/*.js",
|
|
20
|
+
"host/*.d.ts"
|
|
21
|
+
],
|
|
22
|
+
"exports": {
|
|
23
|
+
"./lib/context": "./context.js",
|
|
24
|
+
"./lib/http": "./http.js",
|
|
25
|
+
"./registry": "./host/registry.js",
|
|
26
|
+
"./reflect": "./host/reflect.js",
|
|
27
|
+
"./logging": "./host/logging.js",
|
|
28
|
+
"./context": "./host/context.js",
|
|
29
|
+
"./http": "./host/http.js"
|
|
30
|
+
},
|
|
31
|
+
"scripts": {
|
|
32
|
+
"prepack": "node node_modules/@riddance/env/bin/build.js",
|
|
33
|
+
"start": "watch"
|
|
34
|
+
},
|
|
35
|
+
"devDependencies": {
|
|
36
|
+
"@riddance/env": "0.2.4"
|
|
37
|
+
}
|
|
38
|
+
}
|