@riddance/host 0.0.12 → 0.0.14

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/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright © 2022 The Riddance Authors (see git commits)
1
+ Copyright © 2022-2024 The Riddance Authors (see git commits)
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining a copy
4
4
  of this software and associated documentation files (the “Software”), to deal
package/context.d.ts CHANGED
@@ -1,86 +1,86 @@
1
- export type Environment = {
2
- readonly [key: string]: string;
3
- };
4
- export type Logger = {
5
- enrich(fields: object): Logger;
6
- trace(message: string, error?: unknown, fields?: object): void;
7
- debug(message: string, error?: unknown, fields?: object): void;
8
- info(message: string, error?: unknown, fields?: object): void;
9
- warn(message: string, error?: unknown, fields?: object): void;
10
- error(message: string, error?: unknown, fields?: object): void;
11
- fatal(message: string, error?: unknown, fields?: object): void;
12
- };
13
- export type AbortSignal = {
14
- aborted: boolean;
15
- addEventListener: (type: 'abort', listener: (this: AbortSignal, event: unknown) => unknown, options?: {
16
- capture?: boolean;
17
- once?: boolean;
18
- passive?: boolean;
19
- }) => void;
20
- removeEventListener: (type: 'abort', listener: (this: AbortSignal, event: unknown) => unknown, options?: {
21
- capture?: boolean;
22
- }) => void;
23
- };
24
- export type MutableJson = null | boolean | number | string | MutableJson[] | {
25
- [key: string]: MutableJson;
26
- };
27
- export type Json = null | boolean | number | string | readonly Json[] | {
28
- readonly [key: string]: Json;
29
- };
30
- export declare function objectSpreadable(json?: Json): {
31
- readonly [key: string]: Json;
32
- };
33
- export declare function arraySpreadable(json?: Json): readonly Json[];
34
- export type HandlerConfiguration = {
35
- /**
36
- * An indication of CPU usage of the handler.
37
- * @default 'low'
38
- */
39
- readonly compute?: 'high' | 'low';
40
- /**
41
- * An indication of memory usage of the handler.
42
- * @default 'low'
43
- */
44
- readonly memory?: 'high' | 'low';
45
- /**
46
- * 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.
47
- * @default false
48
- */
49
- readonly excludeBodyFromLogs?: boolean;
50
- /**
51
- * The level below which log entries will be discarded.
52
- * @default 'trace'
53
- */
54
- readonly minimumLogLevel?: 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
55
- /**
56
- * The number of seconds the function is expected to finish executing in.
57
- */
58
- readonly timeout?: number;
59
- };
60
- export type Context = {
61
- readonly env: Environment;
62
- readonly log: Logger;
63
- readonly signal: AbortSignal;
64
- now(): Date;
65
- readonly operationId?: string;
66
- readonly client?: {
67
- readonly id?: string;
68
- readonly ip?: string;
69
- readonly port?: number;
70
- readonly userAgent?: string;
71
- };
72
- readonly meta?: {
73
- readonly packageName: string;
74
- readonly fileName: string;
75
- readonly revision?: string;
76
- };
77
- emit(topic: string, type: string, subject: string, data?: Json, messageId?: string): void;
78
- eventBarrier(): Promise<void>;
79
- onSuccess(fn: () => Promise<void> | void): void;
80
- };
81
- export declare function httpRequestHeaders(context: Context): {
82
- [key: string]: string;
83
- };
84
- export declare function measure<T>(logger: {
85
- trace: (message: string, _: undefined, f: object) => void;
86
- }, name: string, fn: () => Promise<T> | T, fields?: object): Promise<T>;
1
+ export type Environment = {
2
+ readonly [key: string]: string;
3
+ };
4
+ export type Logger = {
5
+ enrich(fields: object): Logger;
6
+ trace(message: string, error?: unknown, fields?: object): void;
7
+ debug(message: string, error?: unknown, fields?: object): void;
8
+ info(message: string, error?: unknown, fields?: object): void;
9
+ warn(message: string, error?: unknown, fields?: object): void;
10
+ error(message: string, error?: unknown, fields?: object): void;
11
+ fatal(message: string, error?: unknown, fields?: object): void;
12
+ };
13
+ export type AbortSignal = {
14
+ aborted: boolean;
15
+ addEventListener: (type: 'abort', listener: (this: AbortSignal, event: unknown) => unknown, options?: {
16
+ capture?: boolean;
17
+ once?: boolean;
18
+ passive?: boolean;
19
+ }) => void;
20
+ removeEventListener: (type: 'abort', listener: (this: AbortSignal, event: unknown) => unknown, options?: {
21
+ capture?: boolean;
22
+ }) => void;
23
+ };
24
+ export type MutableJson = null | boolean | number | string | MutableJson[] | {
25
+ [key: string]: MutableJson;
26
+ };
27
+ export type Json = null | boolean | number | string | readonly Json[] | {
28
+ readonly [key: string]: Json;
29
+ };
30
+ export declare function objectSpreadable(json?: Json): {
31
+ readonly [key: string]: Json;
32
+ };
33
+ export declare function arraySpreadable(json?: Json): readonly Json[];
34
+ export type HandlerConfiguration = {
35
+ /**
36
+ * An indication of CPU usage of the handler.
37
+ * @default 'low'
38
+ */
39
+ readonly compute?: 'high' | 'low';
40
+ /**
41
+ * An indication of memory usage of the handler.
42
+ * @default 'low'
43
+ */
44
+ readonly memory?: 'high' | 'low';
45
+ /**
46
+ * 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.
47
+ * @default false
48
+ */
49
+ readonly excludeBodyFromLogs?: boolean;
50
+ /**
51
+ * The level below which log entries will be discarded.
52
+ * @default 'trace'
53
+ */
54
+ readonly minimumLogLevel?: 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
55
+ /**
56
+ * The number of seconds the function is expected to finish executing in.
57
+ */
58
+ readonly timeout?: number;
59
+ };
60
+ export type Context = {
61
+ readonly env: Environment;
62
+ readonly log: Logger;
63
+ readonly signal: AbortSignal;
64
+ now(): Date;
65
+ readonly operationId?: string;
66
+ readonly client?: {
67
+ readonly id?: string;
68
+ readonly ip?: string;
69
+ readonly port?: number;
70
+ readonly userAgent?: string;
71
+ };
72
+ readonly meta?: {
73
+ readonly packageName: string;
74
+ readonly fileName: string;
75
+ readonly revision?: string;
76
+ };
77
+ emit(topic: string, type: string, subject: string, data?: Json, messageId?: string): void;
78
+ eventBarrier(): Promise<void>;
79
+ onSuccess(fn: () => Promise<void> | void): void;
80
+ };
81
+ export declare function httpRequestHeaders(context: Context): {
82
+ [key: string]: string;
83
+ };
84
+ export declare function measure<T>(logger: {
85
+ trace: (message: string, _: undefined, f: object) => void;
86
+ }, name: string, fn: () => Promise<T> | T, fields?: object): Promise<T>;
package/context.js CHANGED
@@ -1,52 +1,52 @@
1
- import { performance } from 'perf_hooks';
2
- import { highPrecisionISODate } from './host/logging.js';
3
- /*@__INLINE__*/
4
- export function objectSpreadable(json) {
5
- if (!json) {
6
- return {};
7
- }
8
- return json;
9
- }
10
- /*@__INLINE__*/
11
- export function arraySpreadable(json) {
12
- if (!Array.isArray(json)) {
13
- return [];
14
- }
15
- return json;
16
- }
17
- export function httpRequestHeaders(context) {
18
- const headers = {
19
- 'user-agent': `${context.meta?.packageName ?? '?'}/${context.meta?.revision ?? '?'}`,
20
- };
21
- if (context.operationId) {
22
- headers['x-request-id'] = context.operationId;
23
- }
24
- if (context.client) {
25
- if (context.client.id) {
26
- headers['x-client-id'] = context.client.id;
27
- }
28
- if (context.client.ip || context.client.port) {
29
- headers['x-forwarded-for'] = `${context.client.ip ?? ''}:${context.client.port ?? ''}`;
30
- }
31
- if (context.client.userAgent) {
32
- headers['x-forwarded-for-user-agent'] = context.client.userAgent;
33
- }
34
- }
35
- return headers;
36
- }
37
- export async function measure(logger, name, fn, fields) {
38
- const start = performance.now();
39
- try {
40
- return await fn();
41
- }
42
- finally {
43
- const end = performance.now();
44
- logger.trace(`Measurement of ${name} time`, undefined, {
45
- start: highPrecisionISODate(start),
46
- end: highPrecisionISODate(end),
47
- duration: (Math.round(end * 10000) - Math.round(start * 10000)) / 10000,
48
- ...fields,
49
- });
50
- }
51
- }
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 type Environment = {\n    readonly [key: string]: string\n}\n\nexport type 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 type 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 type 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 type 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"]}
1
+ import { performance } from 'perf_hooks';
2
+ import { highPrecisionISODate } from './host/logging.js';
3
+ /*@__INLINE__*/
4
+ export function objectSpreadable(json) {
5
+ if (!json) {
6
+ return {};
7
+ }
8
+ return json;
9
+ }
10
+ /*@__INLINE__*/
11
+ export function arraySpreadable(json) {
12
+ if (!Array.isArray(json)) {
13
+ return [];
14
+ }
15
+ return json;
16
+ }
17
+ export function httpRequestHeaders(context) {
18
+ const headers = {
19
+ 'user-agent': `${context.meta?.packageName ?? '?'}/${context.meta?.revision ?? '?'}`,
20
+ };
21
+ if (context.operationId) {
22
+ headers['x-request-id'] = context.operationId;
23
+ }
24
+ if (context.client) {
25
+ if (context.client.id) {
26
+ headers['x-client-id'] = context.client.id;
27
+ }
28
+ if (!!context.client.ip || !!context.client.port) {
29
+ headers['x-forwarded-for'] = `${context.client.ip ?? ''}:${context.client.port ?? ''}`;
30
+ }
31
+ if (context.client.userAgent) {
32
+ headers['x-forwarded-for-user-agent'] = context.client.userAgent;
33
+ }
34
+ }
35
+ return headers;
36
+ }
37
+ export async function measure(logger, name, fn, fields) {
38
+ const start = performance.now();
39
+ try {
40
+ return await fn();
41
+ }
42
+ finally {
43
+ const end = performance.now();
44
+ logger.trace(`Measurement of ${name} time`, undefined, {
45
+ start: highPrecisionISODate(start),
46
+ end: highPrecisionISODate(end),
47
+ duration: (Math.round(end * 10000) - Math.round(start * 10000)) / 10000,
48
+ ...fields,
49
+ });
50
+ }
51
+ }
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,CAAC;QACR,OAAO,EAAE,CAAA;IACb,CAAC;IACD,OAAO,IAAmD,CAAA;AAC9D,CAAC;AAED,eAAe;AACf,MAAM,UAAU,eAAe,CAAC,IAAW;IACvC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QACvB,OAAO,EAAE,CAAA;IACb,CAAC;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,CAAC;QACtB,OAAO,CAAC,cAAc,CAAC,GAAG,OAAO,CAAC,WAAW,CAAA;IACjD,CAAC;IACD,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;QACjB,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;YACpB,OAAO,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,CAAA;QAC9C,CAAC;QACD,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAC/C,OAAO,CAAC,iBAAiB,CAAC,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,IAAI,OAAO,CAAC,MAAM,CAAC,IAAI,IAAI,EAAE,EAAE,CAAA;QAC1F,CAAC;QACD,IAAI,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YAC3B,OAAO,CAAC,4BAA4B,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,SAAS,CAAA;QACpE,CAAC;IACL,CAAC;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,CAAC;QACD,OAAO,MAAM,EAAE,EAAE,CAAA;IACrB,CAAC;YAAS,CAAC;QACP,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;IACN,CAAC;AACL,CAAC","sourcesContent":["import { performance } from 'perf_hooks'\nimport { highPrecisionISODate } from './host/logging.js'\n\nexport type Environment = {\n    readonly [key: string]: string\n}\n\nexport type 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 type 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 type 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 type 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
@@ -1,50 +1,51 @@
1
- import { AbortSignal, Context, Environment, Logger } from '../context.js';
2
- import { Metadata } from './registry.js';
3
- export type ClientInfo = {
4
- readonly operationId?: string;
5
- readonly clientId?: string;
6
- readonly clientIp?: string;
7
- readonly clientPort?: number;
8
- readonly userAgent?: string;
9
- };
10
- export type EventMetadata = {
11
- topic: string;
12
- type: string;
13
- subject: string;
14
- id?: string;
15
- };
16
- export type BufferedEvent = {
17
- eventTime: Date;
18
- meta: Omit<EventMetadata, 'topic'>;
19
- ids: ClientInfo;
20
- json?: string;
21
- };
22
- export type EventTransport = {
23
- readonly publishRate: number;
24
- sendEvents(topic: string, events: BufferedEvent[], signal: AbortSignal): Promise<void>;
25
- };
26
- export type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
27
- export type LogEntry = {
28
- readonly level: LogLevel;
29
- readonly timestamp: number;
30
- readonly message: string;
31
- readonly error: unknown;
32
- readonly json: string;
33
- };
34
- export type LogTransport = {
35
- readonly publishRate?: number;
36
- sendEntries(entries: LogEntry[], signal: AbortSignal): Promise<void> | undefined;
37
- };
38
- export type RootLogger = {
39
- enrichReserved(fields: object): RootLogger;
40
- flush(): Promise<void>;
41
- } & Logger;
42
- export declare function createContext(clientInfo: ClientInfo, loggers: LogTransport[], eventTransport: EventTransport, timeouts: {
43
- default: number;
44
- cap?: number;
45
- }, outerController: AbortController, meta?: Metadata, environment?: Environment | undefined, now?: (() => Date) | undefined): {
46
- log: RootLogger;
47
- context: Omit<Context, 'log'>;
48
- success: () => Promise<unknown>;
49
- flush: () => Promise<void>;
50
- };
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { AbortSignal, Context, Environment, Logger } from '../context.js';
3
+ import { FullConfiguration, Metadata } from './registry.js';
4
+ export type ClientInfo = {
5
+ readonly operationId?: string;
6
+ readonly clientId?: string;
7
+ readonly clientIp?: string;
8
+ readonly clientPort?: number;
9
+ readonly userAgent?: string;
10
+ };
11
+ export type EventMetadata = {
12
+ topic: string;
13
+ type: string;
14
+ subject: string;
15
+ id?: string;
16
+ };
17
+ export type BufferedEvent = {
18
+ eventTime: Date;
19
+ meta: Omit<EventMetadata, 'topic'>;
20
+ ids: ClientInfo;
21
+ json?: string;
22
+ };
23
+ export type EventTransport = {
24
+ readonly publishRate: number;
25
+ sendEvents(topic: string, events: BufferedEvent[], signal: AbortSignal): Promise<void>;
26
+ };
27
+ export type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
28
+ export type LogEntry = {
29
+ readonly level: LogLevel;
30
+ readonly timestamp: number;
31
+ readonly message: string;
32
+ readonly error: unknown;
33
+ readonly json: string;
34
+ };
35
+ export type LogTransport = {
36
+ readonly publishRate?: number;
37
+ sendEntries(entries: LogEntry[], signal: AbortSignal): Promise<void> | undefined;
38
+ };
39
+ export type RootLogger = {
40
+ enrichReserved(fields: object): RootLogger;
41
+ flush(): Promise<void>;
42
+ } & Logger;
43
+ export declare function createContext(clientInfo: ClientInfo, loggers: LogTransport[], eventTransport: EventTransport, timeouts: {
44
+ default: number;
45
+ cap?: number;
46
+ }, outerController: AbortController, config?: FullConfiguration, meta?: Metadata, environment?: Environment | undefined, now?: (() => Date) | undefined): {
47
+ log: RootLogger;
48
+ context: Omit<Context, 'log'>;
49
+ success: () => Promise<unknown>;
50
+ flush: () => Promise<void>;
51
+ };