@riddance/host 0.0.7 → 0.0.8

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 CHANGED
@@ -21,10 +21,10 @@ export interface AbortSignal {
21
21
  capture?: boolean;
22
22
  }) => void;
23
23
  }
24
- export declare type MutableJson = null | boolean | number | string | MutableJson[] | {
24
+ export type MutableJson = null | boolean | number | string | MutableJson[] | {
25
25
  [key: string]: MutableJson;
26
26
  };
27
- export declare type Json = null | boolean | number | string | readonly Json[] | {
27
+ export type Json = null | boolean | number | string | readonly Json[] | {
28
28
  readonly [key: string]: Json;
29
29
  };
30
30
  export declare function objectSpreadable(json?: Json): {
package/context.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { performance } from 'perf_hooks';
2
- import { highPrecisionISODate } from './host/logging.js';
2
+ import { highPrecisionISODate } from './lib/logging.js';
3
3
  /*@__INLINE__*/
4
4
  export function objectSpreadable(json) {
5
5
  if (!json) {
@@ -67,4 +67,4 @@ export async function measure(logger, name, fn, fields) {
67
67
  });
68
68
  }
69
69
  }
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"]}
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 './lib/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"]}
package/http.d.ts CHANGED
@@ -10,7 +10,7 @@ export interface FullResult {
10
10
  status?: number;
11
11
  body?: unknown;
12
12
  }
13
- export declare type Result = void | string | FullResult;
13
+ export type Result = void | string | FullResult;
14
14
  export interface HttpRequest {
15
15
  readonly rawUrl: string;
16
16
  readonly url: Readonly<UrlWithParsedQuery> & {
@@ -26,7 +26,7 @@ export interface HttpHandlerConfiguration extends HandlerConfiguration {
26
26
  */
27
27
  readonly cors?: string;
28
28
  }
29
- export declare type Handler = (context: Context, request: HttpRequest) => Promise<Result> | Result;
29
+ export type Handler = (context: Context, request: HttpRequest) => Promise<Result> | Result;
30
30
  export declare function get(path: string, fn: Handler): void;
31
31
  export declare function get(path: string, config: HttpHandlerConfiguration, fn: Handler): void;
32
32
  export declare function post(path: string, fn: Handler): void;
package/http.js CHANGED
@@ -1,4 +1,4 @@
1
- import { registerHttpHandler } from './host/registry.js';
1
+ import { registerHttpHandler } from './lib/registry.js';
2
2
  export * from './context.js';
3
3
  export function get(path, configOrHandler, fn) {
4
4
  registerHttpHandler('GET', path, configOrHandler, fn);
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImh0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0JBQW9CLENBQUE7QUFFeEQsY0FBYyxjQUFjLENBQUE7QUFpQzVCLE1BQU0sVUFBVSxHQUFHLENBQ2YsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUN6RCxDQUFDO0FBR0QsTUFBTSxVQUFVLElBQUksQ0FDaEIsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUMxRCxDQUFDO0FBR0QsTUFBTSxVQUFVLEdBQUcsQ0FDZixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQ3pELENBQUM7QUFHRCxNQUFNLFVBQVUsS0FBSyxDQUNqQixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQzNELENBQUM7QUFHRCxNQUFNLFVBQVUsR0FBRyxDQUNmLElBQVksRUFDWixlQUFtRCxFQUNuRCxFQUFZO0lBRVosbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7QUFDNUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVXJsV2l0aFBhcnNlZFF1ZXJ5IH0gZnJvbSAnbm9kZTp1cmwnXHJcbmltcG9ydCB7IENvbnRleHQsIEhhbmRsZXJDb25maWd1cmF0aW9uLCBKc29uIH0gZnJvbSAnLi9jb250ZXh0LmpzJ1xyXG5pbXBvcnQgeyByZWdpc3Rlckh0dHBIYW5kbGVyIH0gZnJvbSAnLi9ob3N0L3JlZ2lzdHJ5LmpzJ1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LmpzJ1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25zZUhlYWRlcnMge1xyXG4gICAgW2tleTogc3RyaW5nXTogc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRnVsbFJlc3VsdCB7XHJcbiAgICBoZWFkZXJzPzogUmVzcG9uc2VIZWFkZXJzXHJcbiAgICBzdGF0dXM/OiBudW1iZXJcclxuICAgIGJvZHk/OiB1bmtub3duXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIFJlc3VsdCA9IHZvaWQgfCBzdHJpbmcgfCBGdWxsUmVzdWx0XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBSZXF1ZXN0IHtcclxuICAgIHJlYWRvbmx5IHJhd1VybDogc3RyaW5nXHJcbiAgICByZWFkb25seSB1cmw6IFJlYWRvbmx5PFVybFdpdGhQYXJzZWRRdWVyeT4gJiB7IHBhdGhTdGVwQXQ6IChpbmRleDogbnVtYmVyKSA9PiBzdHJpbmcgfVxyXG4gICAgcmVhZG9ubHkgaGVhZGVyczogUmVhZG9ubHk8UmVzcG9uc2VIZWFkZXJzPlxyXG4gICAgcmVhZG9ubHkgYm9keT86IEpzb24gfCBzdHJpbmdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24gZXh0ZW5kcyBIYW5kbGVyQ29uZmlndXJhdGlvbiB7XHJcbiAgICAvKipcclxuICAgICAqIEEgc3RyaW5nIGlkZW50aWZ5aW5nIHdoaWNoIGRvbWFpbnMgY2FuIGFjY2VzcyB0aGUgZW5kcG9pbnQgY3Jvc3Mtb3JpZ2luLlxyXG4gICAgICogQGRlZmF1bHQgdW5kZWZpbmVkXHJcbiAgICAgKi9cclxuICAgIHJlYWRvbmx5IGNvcnM/OiBzdHJpbmdcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgSGFuZGxlciA9IChjb250ZXh0OiBDb250ZXh0LCByZXF1ZXN0OiBIdHRwUmVxdWVzdCkgPT4gUHJvbWlzZTxSZXN1bHQ+IHwgUmVzdWx0XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZ2V0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXQocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXQoXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignR0VUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gcG9zdChwYXRoOiBzdHJpbmcsIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcG9zdChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIHBvc3QoXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUE9TVCcsIHBhdGgsIGNvbmZpZ09ySGFuZGxlciwgZm4pXHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIHB1dChwYXRoOiBzdHJpbmcsIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcHV0KHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcHV0KFxyXG4gICAgcGF0aDogc3RyaW5nLFxyXG4gICAgY29uZmlnT3JIYW5kbGVyOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxyXG4gICAgZm4/OiBIYW5kbGVyLFxyXG4pOiB2b2lkIHtcclxuICAgIHJlZ2lzdGVySHR0cEhhbmRsZXIoJ1BVVCcsIHBhdGgsIGNvbmZpZ09ySGFuZGxlciwgZm4pXHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIHBhdGNoKHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwYXRjaChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIHBhdGNoKFxyXG4gICAgcGF0aDogc3RyaW5nLFxyXG4gICAgY29uZmlnT3JIYW5kbGVyOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxyXG4gICAgZm4/OiBIYW5kbGVyLFxyXG4pOiB2b2lkIHtcclxuICAgIHJlZ2lzdGVySHR0cEhhbmRsZXIoJ1BBVENIJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gZGVsKHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBkZWwocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBkZWwoXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignREVMRVRFJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImh0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFFdkQsY0FBYyxjQUFjLENBQUE7QUFpQzVCLE1BQU0sVUFBVSxHQUFHLENBQ2YsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUN6RCxDQUFDO0FBR0QsTUFBTSxVQUFVLElBQUksQ0FDaEIsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUMxRCxDQUFDO0FBR0QsTUFBTSxVQUFVLEdBQUcsQ0FDZixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQ3pELENBQUM7QUFHRCxNQUFNLFVBQVUsS0FBSyxDQUNqQixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQzNELENBQUM7QUFHRCxNQUFNLFVBQVUsR0FBRyxDQUNmLElBQVksRUFDWixlQUFtRCxFQUNuRCxFQUFZO0lBRVosbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7QUFDNUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVXJsV2l0aFBhcnNlZFF1ZXJ5IH0gZnJvbSAnbm9kZTp1cmwnXHJcbmltcG9ydCB7IENvbnRleHQsIEhhbmRsZXJDb25maWd1cmF0aW9uLCBKc29uIH0gZnJvbSAnLi9jb250ZXh0LmpzJ1xyXG5pbXBvcnQgeyByZWdpc3Rlckh0dHBIYW5kbGVyIH0gZnJvbSAnLi9saWIvcmVnaXN0cnkuanMnXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbnRleHQuanMnXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFJlc3BvbnNlSGVhZGVycyB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBzdHJpbmdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGdWxsUmVzdWx0IHtcclxuICAgIGhlYWRlcnM/OiBSZXNwb25zZUhlYWRlcnNcclxuICAgIHN0YXR1cz86IG51bWJlclxyXG4gICAgYm9keT86IHVua25vd25cclxufVxyXG5cclxuZXhwb3J0IHR5cGUgUmVzdWx0ID0gdm9pZCB8IHN0cmluZyB8IEZ1bGxSZXN1bHRcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSHR0cFJlcXVlc3Qge1xyXG4gICAgcmVhZG9ubHkgcmF3VXJsOiBzdHJpbmdcclxuICAgIHJlYWRvbmx5IHVybDogUmVhZG9ubHk8VXJsV2l0aFBhcnNlZFF1ZXJ5PiAmIHsgcGF0aFN0ZXBBdDogKGluZGV4OiBudW1iZXIpID0+IHN0cmluZyB9XHJcbiAgICByZWFkb25seSBoZWFkZXJzOiBSZWFkb25seTxSZXNwb25zZUhlYWRlcnM+XHJcbiAgICByZWFkb25seSBib2R5PzogSnNvbiB8IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiBleHRlbmRzIEhhbmRsZXJDb25maWd1cmF0aW9uIHtcclxuICAgIC8qKlxyXG4gICAgICogQSBzdHJpbmcgaWRlbnRpZnlpbmcgd2hpY2ggZG9tYWlucyBjYW4gYWNjZXNzIHRoZSBlbmRwb2ludCBjcm9zcy1vcmlnaW4uXHJcbiAgICAgKiBAZGVmYXVsdCB1bmRlZmluZWRcclxuICAgICAqL1xyXG4gICAgcmVhZG9ubHkgY29ycz86IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBIYW5kbGVyID0gKGNvbnRleHQ6IENvbnRleHQsIHJlcXVlc3Q6IEh0dHBSZXF1ZXN0KSA9PiBQcm9taXNlPFJlc3VsdD4gfCBSZXN1bHRcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXQocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGdldChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGdldChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdHRVQnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBwb3N0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwb3N0KHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcG9zdChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdQT1NUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gcHV0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwdXQocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwdXQoXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUFVUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gcGF0Y2gocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIHBhdGNoKHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcGF0Y2goXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUEFUQ0gnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBkZWwocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGRlbChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGRlbChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdERUxFVEUnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbiJdfQ==
@@ -24,7 +24,7 @@ export interface EventTransport {
24
24
  readonly publishRate: number;
25
25
  sendEvents(topic: string, events: BufferedEvent[], signal: AbortSignal): Promise<void>;
26
26
  }
27
- export declare type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
27
+ export type LogLevel = 'trace' | 'debug' | 'info' | 'warning' | 'error' | 'fatal';
28
28
  export interface LogEntry {
29
29
  readonly level: LogLevel;
30
30
  readonly timestamp: number;
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
@@ -21,6 +21,6 @@ export interface Metadata {
21
21
  revision: string | undefined;
22
22
  config?: PackageConfiguration;
23
23
  }
24
- export declare type Method = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE';
24
+ export type Method = 'GET' | 'POST' | 'PUT' | 'PATCH' | 'DELETE';
25
25
  export declare function registerHttpHandler(method: Method, path: string, configOrHandler: HandlerConfiguration | Handler, fn?: Handler): void;
26
26
  export {};
File without changes
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@riddance/host",
3
- "version": "0.0.7",
3
+ "version": "0.0.8",
4
4
  "type": "module",
5
5
  "license": "MIT",
6
6
  "engines": {
@@ -16,20 +16,20 @@
16
16
  "files": [
17
17
  "*.js",
18
18
  "*.d.ts",
19
- "host/*.js",
20
- "host/*.d.ts"
19
+ "lib/*.js",
20
+ "lib/*.d.ts"
21
21
  ],
22
22
  "exports": {
23
23
  "./lib/context": "./context.js",
24
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"
25
+ "./registry": "./lib/registry.js",
26
+ "./reflect": "./lib/reflect.js",
27
+ "./logging": "./lib/logging.js",
28
+ "./context": "./lib/context.js",
29
+ "./http": "./lib/http.js"
30
30
  },
31
31
  "devDependencies": {
32
- "@riddance/env": "0.0.3"
32
+ "@riddance/env": "0.1.1"
33
33
  },
34
34
  "scripts": {
35
35
  "prepare": "tsc",