@riddance/host 0.0.8 → 0.0.10

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.
@@ -1,8 +1,8 @@
1
1
  /// <reference types="node" resolution-mode="require"/>
2
2
  import { HttpHandlerConfiguration } from '../http.js';
3
- declare type CPU = 'arm' | 'arm64' | 'ia32' | 'mips' | 'mipsel' | 'ppc' | 'ppc64' | 's390' | 's390x' | 'x32' | 'x64';
4
- declare type CpuConfig = CPU | `!${CPU}`;
5
- declare type OSConfig = NodeJS.Platform | `!${NodeJS.Platform}`;
3
+ type CPU = 'arm' | 'arm64' | 'ia32' | 'mips' | 'mipsel' | 'ppc' | 'ppc64' | 's390' | 's390x' | 'x32' | 'x64';
4
+ type CpuConfig = CPU | `!${CPU}`;
5
+ type OSConfig = NodeJS.Platform | `!${NodeJS.Platform}`;
6
6
  export interface PackageJsonConfiguration {
7
7
  nodeVersion?: string;
8
8
  cpus?: CpuConfig[];
@@ -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,{"version":3,"file":"reflect.js","sourceRoot":"","sources":["reflect.ts"],"names":[],"mappings":"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","sourcesContent":["import { readdir, readFile } from 'node:fs/promises'\r\nimport { basename, extname, join, resolve } from 'node:path'\r\nimport { pathToFileURL } from 'node:url'\r\nimport { HttpHandlerConfiguration } from '../http.js'\r\nimport { PackageConfiguration } from './registry.js'\r\n\r\ntype CPU =\r\n    | 'arm'\r\n    | 'arm64'\r\n    | 'ia32'\r\n    | 'mips'\r\n    | 'mipsel'\r\n    | 'ppc'\r\n    | 'ppc64'\r\n    | 's390'\r\n    | 's390x'\r\n    | 'x32'\r\n    | 'x64'\r\ntype CpuConfig = CPU | `!${CPU}`\r\ntype OSConfig = NodeJS.Platform | `!${NodeJS.Platform}`\r\n\r\nexport interface PackageJsonConfiguration {\r\n    nodeVersion?: string\r\n    cpus?: CpuConfig[]\r\n    os?: OSConfig[]\r\n}\r\n\r\nexport interface Reflection {\r\n    name: string\r\n    http: {\r\n        name: string\r\n        method: string\r\n        pathPattern: string\r\n        pathRegExp: RegExp\r\n        config: HttpHandlerConfiguration & PackageJsonConfiguration\r\n    }[]\r\n}\r\n\r\nexport function resolveCpu(config: PackageJsonConfiguration, supported: CPU[]): CPU {\r\n    const resolved = resolveSupported(config.cpus, supported)\r\n    if (!resolved) {\r\n        // resolve<T>(config, supported) actually asserts config is (T | `!${T}`)[], but that's not supported yet.\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        throw new Error('Unsupported CPUs: ' + config.cpus!.join(', '))\r\n    }\r\n    return resolved\r\n}\r\n\r\nexport function resolveOS(\r\n    config: PackageJsonConfiguration,\r\n    supported: NodeJS.Platform[],\r\n): NodeJS.Platform {\r\n    const resolved = resolveSupported(config.os, supported)\r\n    if (!resolved) {\r\n        // resolve<T>(config, supported) actually asserts config is (T | `!${T}`)[], but that's not supported yet.\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        throw new Error('Unsupported operating systems: ' + config.os!.join(', '))\r\n    }\r\n    return resolved\r\n}\r\n\r\nfunction resolveSupported<T extends string>(\r\n    config: (T | `!${T}`)[] | undefined,\r\n    supported: T[],\r\n): T | undefined {\r\n    if (!config) {\r\n        return supported[0]\r\n    }\r\n    return supported.find(s => config.includes(s) && !config.includes(`!${s}`))\r\n}\r\n\r\nexport async function reflect(path: string): Promise<Reflection> {\r\n    const packageJson = await readConfig()\r\n    const absolutePath = resolve(process.cwd(), path)\r\n    const files = (await readdir(absolutePath)).filter(\r\n        file => extname(file) === '.ts' && !file.endsWith('.d.ts'),\r\n    )\r\n    const { getHandlers, setMeta } = (await import(\r\n        pathToFileURL(join(absolutePath, 'node_modules/@riddance/host/host/registry.js')).toString()\r\n    )) as {\r\n        getHandlers: (type: string) => {\r\n            name: string\r\n            meta?: { fileName: string }\r\n            config: HttpHandlerConfiguration\r\n            method: string\r\n            pathPattern: string\r\n            pathRegExp: RegExp\r\n        }[]\r\n        setMeta: (\r\n            packageName: string,\r\n            fileName: string,\r\n            rev: string | undefined,\r\n            cfg: PackageConfiguration | undefined,\r\n        ) => void\r\n    }\r\n\r\n    for (const file of files) {\r\n        const base = basename(file, '.ts')\r\n        setMeta(packageJson.name, base, undefined, packageJson.config)\r\n        await import(pathToFileURL(join(absolutePath, base + '.js')).toString())\r\n    }\r\n\r\n    return {\r\n        name: packageJson.name,\r\n        http: getHandlers('http').map(h => ({\r\n            config: {\r\n                ...h.config,\r\n                cpus: packageJson.cpu,\r\n                os: packageJson.os,\r\n                nodeVersion: packageJson.engines?.node,\r\n            },\r\n            name: h.meta?.fileName ?? '',\r\n            method: h.method,\r\n            pathPattern: h.pathPattern,\r\n            pathRegExp: h.pathRegExp,\r\n        })),\r\n    }\r\n}\r\n\r\nasync function readConfig() {\r\n    const packageJson = JSON.parse(await readFile('package.json', 'utf-8')) as {\r\n        name: string\r\n        engines?: { [engine: string]: string }\r\n        cpu?: CpuConfig[]\r\n        os?: OSConfig[]\r\n        config?: object\r\n    }\r\n    return packageJson\r\n}\r\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reflect.js","sourceRoot":"","sources":["reflect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AACpD,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAoCxC,MAAM,UAAU,UAAU,CAAC,MAAgC,EAAE,SAAgB;IACzE,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;IACzD,IAAI,CAAC,QAAQ,EAAE;QACX,0GAA0G;QAC1G,oEAAoE;QACpE,MAAM,IAAI,KAAK,CAAC,oBAAoB,GAAG,MAAM,CAAC,IAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;KAClE;IACD,OAAO,QAAQ,CAAA;AACnB,CAAC;AAED,MAAM,UAAU,SAAS,CACrB,MAAgC,EAChC,SAA4B;IAE5B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;IACvD,IAAI,CAAC,QAAQ,EAAE;QACX,0GAA0G;QAC1G,oEAAoE;QACpE,MAAM,IAAI,KAAK,CAAC,iCAAiC,GAAG,MAAM,CAAC,EAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;KAC7E;IACD,OAAO,QAAQ,CAAA;AACnB,CAAC;AAED,SAAS,gBAAgB,CACrB,MAAmC,EACnC,SAAc;IAEd,IAAI,CAAC,MAAM,EAAE;QACT,OAAO,SAAS,CAAC,CAAC,CAAC,CAAA;KACtB;IACD,OAAO,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;AAC/E,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,IAAY;IACtC,MAAM,WAAW,GAAG,MAAM,UAAU,EAAE,CAAA;IACtC,MAAM,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,CAAA;IACjD,MAAM,KAAK,GAAG,CAAC,MAAM,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAC9C,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAC7D,CAAA;IACD,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,GAAG,CAAC,MAAM,MAAM,CAC1C,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,8CAA8C,CAAC,CAAC,CAAC,QAAQ,EAAE,CAC/F,CAeA,CAAA;IAED,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACtB,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;QAClC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;QAC9D,MAAM,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAA;KAC3E;IAED,OAAO;QACH,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAChC,MAAM,EAAE;gBACJ,GAAG,CAAC,CAAC,MAAM;gBACX,IAAI,EAAE,WAAW,CAAC,GAAG;gBACrB,EAAE,EAAE,WAAW,CAAC,EAAE;gBAClB,WAAW,EAAE,WAAW,CAAC,OAAO,EAAE,IAAI;aACzC;YACD,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,QAAQ,IAAI,EAAE;YAC5B,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,WAAW,EAAE,CAAC,CAAC,WAAW;YAC1B,UAAU,EAAE,CAAC,CAAC,UAAU;SAC3B,CAAC,CAAC;KACN,CAAA;AACL,CAAC;AAED,KAAK,UAAU,UAAU;IACrB,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,QAAQ,CAAC,cAAc,EAAE,OAAO,CAAC,CAMrE,CAAA;IACD,OAAO,WAAW,CAAA;AACtB,CAAC","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"]}
File without changes
@@ -0,0 +1,61 @@
1
+ const handlers = {};
2
+ function addHandler(type, handler) {
3
+ ;
4
+ (handlers[type] ??= []).push(handler);
5
+ }
6
+ export function getHandlers(type) {
7
+ return (handlers[type] ?? []);
8
+ }
9
+ let httpHostRegistry;
10
+ function setHttpHost(host) {
11
+ httpHostRegistry = host;
12
+ }
13
+ let metadata;
14
+ export function setMeta(packageName, fileName, revision, config) {
15
+ metadata = {
16
+ packageName,
17
+ fileName,
18
+ revision,
19
+ config,
20
+ };
21
+ }
22
+ function getMetadata() {
23
+ return metadata;
24
+ }
25
+ function pathToRegExp(path) {
26
+ return new RegExp(('^' +
27
+ path.replace(/[/\\^$+?.()|[\]{}]/gu, '\\$&').replaceAll('*', '[^/\\?]+') +
28
+ '(\\?.*)?$').replace('[^/\\?]+[^/\\?]+(\\?.*)?$', ''), 'u');
29
+ }
30
+ function combineConfig(base, override) {
31
+ if (base === undefined) {
32
+ return override;
33
+ }
34
+ else if (override === undefined) {
35
+ return base;
36
+ }
37
+ return { ...base, ...override };
38
+ }
39
+ function httpHost(meta, cfg, method, path, entry) {
40
+ addHandler('http', {
41
+ meta,
42
+ config: combineConfig(meta?.config, cfg),
43
+ method,
44
+ pathPattern: path,
45
+ pathRegExp: pathToRegExp(path),
46
+ entry,
47
+ });
48
+ }
49
+ setHttpHost(httpHost);
50
+ export function registerHttpHandler(method, path, configOrHandler, fn) {
51
+ if (typeof configOrHandler === 'function') {
52
+ httpHostRegistry(getMetadata(), undefined, method, path, configOrHandler);
53
+ }
54
+ else {
55
+ if (!fn) {
56
+ throw new Error('Please provide a handler function.');
57
+ }
58
+ httpHostRegistry(getMetadata(), configOrHandler, method, path, fn);
59
+ }
60
+ }
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJyZWdpc3RyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQkEsTUFBTSxRQUFRLEdBQWlDLEVBQUUsQ0FBQTtBQUVqRCxTQUFTLFVBQVUsQ0FBQyxJQUF3QixFQUFFLE9BQW9CO0lBQzlELENBQUM7SUFBQSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7QUFDMUMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBd0I7SUFDaEQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQWtCLENBQUE7QUFDbEQsQ0FBQztBQVVELElBQUksZ0JBQTBCLENBQUE7QUFFOUIsU0FBUyxXQUFXLENBQUMsSUFBYztJQUMvQixnQkFBZ0IsR0FBRyxJQUFJLENBQUE7QUFDM0IsQ0FBQztBQUVELElBQUksUUFBOEIsQ0FBQTtBQUVsQyxNQUFNLFVBQVUsT0FBTyxDQUNuQixXQUFtQixFQUNuQixRQUFnQixFQUNoQixRQUE0QixFQUM1QixNQUF3QztJQUV4QyxRQUFRLEdBQUc7UUFDUCxXQUFXO1FBQ1gsUUFBUTtRQUNSLFFBQVE7UUFDUixNQUFNO0tBQ1QsQ0FBQTtBQUNMLENBQUM7QUFjRCxTQUFTLFdBQVc7SUFDaEIsT0FBTyxRQUFRLENBQUE7QUFDbkIsQ0FBQztBQUVELFNBQVMsWUFBWSxDQUFDLElBQVk7SUFDOUIsT0FBTyxJQUFJLE1BQU0sQ0FDYixDQUNJLEdBQUc7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLHNCQUFzQixFQUFFLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDO1FBQ3hFLFdBQVcsQ0FDZCxDQUFDLE9BQU8sQ0FBQywyQkFBMkIsRUFBRSxFQUFFLENBQUMsRUFDMUMsR0FBRyxDQUNOLENBQUE7QUFDTCxDQUFDO0FBRUQsU0FBUyxhQUFhLENBQ2xCLElBQXNDLEVBQ3RDLFFBQTBDO0lBRTFDLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRTtRQUNwQixPQUFPLFFBQVEsQ0FBQTtLQUNsQjtTQUFNLElBQUksUUFBUSxLQUFLLFNBQVMsRUFBRTtRQUMvQixPQUFPLElBQUksQ0FBQTtLQUNkO0lBQ0QsT0FBTyxFQUFFLEdBQUcsSUFBSSxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUE7QUFDbkMsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUNiLElBQTBCLEVBQzFCLEdBQXFDLEVBQ3JDLE1BQWMsRUFDZCxJQUFZLEVBQ1osS0FBYztJQUVkLFVBQVUsQ0FBQyxNQUFNLEVBQUU7UUFDZixJQUFJO1FBQ0osTUFBTSxFQUFFLGFBQWEsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLEdBQUcsQ0FBQztRQUN4QyxNQUFNO1FBQ04sV0FBVyxFQUFFLElBQUk7UUFDakIsVUFBVSxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUM7UUFDOUIsS0FBSztLQUNSLENBQUMsQ0FBQTtBQUNOLENBQUM7QUFFRCxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUE7QUFJckIsTUFBTSxVQUFVLG1CQUFtQixDQUMvQixNQUFjLEVBQ2QsSUFBWSxFQUNaLGVBQStDLEVBQy9DLEVBQVk7SUFFWixJQUFJLE9BQU8sZUFBZSxLQUFLLFVBQVUsRUFBRTtRQUN2QyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQTtLQUM1RTtTQUFNO1FBQ0gsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FBQTtTQUN4RDtRQUNELGdCQUFnQixDQUFDLFdBQVcsRUFBRSxFQUFFLGVBQWUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0tBQ3JFO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhbmRsZXJDb25maWd1cmF0aW9uIH0gZnJvbSAnLi4vY29udGV4dC5qcydcbmltcG9ydCB7IEhhbmRsZXIgfSBmcm9tICcuLi9odHRwLmpzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBIYW5kbGVyIHtcbiAgICBtZXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZFxuICAgIGNvbmZpZzogKFBhY2thZ2VDb25maWd1cmF0aW9uICYgSGFuZGxlckNvbmZpZ3VyYXRpb24pIHwgdW5kZWZpbmVkXG4gICAgbWV0aG9kOiBNZXRob2RcbiAgICBwYXRoUGF0dGVybjogc3RyaW5nXG4gICAgcGF0aFJlZ0V4cDogUmVnRXhwXG4gICAgZW50cnk6IEhhbmRsZXJcbn1cblxuaW50ZXJmYWNlIEhhbmRsZXJUeXBlcyB7XG4gICAgaHR0cDogSHR0cEhhbmRsZXJcbn1cblxuY29uc3QgaGFuZGxlcnM6IHsgW2tleTogc3RyaW5nXTogdW5rbm93bltdIH0gPSB7fVxuXG5mdW5jdGlvbiBhZGRIYW5kbGVyKHR5cGU6IGtleW9mIEhhbmRsZXJUeXBlcywgaGFuZGxlcjogSHR0cEhhbmRsZXIpIHtcbiAgICA7KGhhbmRsZXJzW3R5cGVdID8/PSBbXSkucHVzaChoYW5kbGVyKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0SGFuZGxlcnModHlwZToga2V5b2YgSGFuZGxlclR5cGVzKSB7XG4gICAgcmV0dXJuIChoYW5kbGVyc1t0eXBlXSA/PyBbXSkgYXMgSHR0cEhhbmRsZXJbXVxufVxuXG50eXBlIEh0dHBIb3N0ID0gKFxuICAgIG1ldGE6IE1ldGFkYXRhIHwgdW5kZWZpbmVkLFxuICAgIGNvbmZpZzogSGFuZGxlckNvbmZpZ3VyYXRpb24gfCB1bmRlZmluZWQsXG4gICAgbWV0aG9kOiBNZXRob2QsXG4gICAgcGF0aDogc3RyaW5nLFxuICAgIGhhbmRsZXI6IEhhbmRsZXIsXG4pID0+IHZvaWRcblxubGV0IGh0dHBIb3N0UmVnaXN0cnk6IEh0dHBIb3N0XG5cbmZ1bmN0aW9uIHNldEh0dHBIb3N0KGhvc3Q6IEh0dHBIb3N0KSB7XG4gICAgaHR0cEhvc3RSZWdpc3RyeSA9IGhvc3Rcbn1cblxubGV0IG1ldGFkYXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZFxuXG5leHBvcnQgZnVuY3Rpb24gc2V0TWV0YShcbiAgICBwYWNrYWdlTmFtZTogc3RyaW5nLFxuICAgIGZpbGVOYW1lOiBzdHJpbmcsXG4gICAgcmV2aXNpb246IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICBjb25maWc6IFBhY2thZ2VDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuKSB7XG4gICAgbWV0YWRhdGEgPSB7XG4gICAgICAgIHBhY2thZ2VOYW1lLFxuICAgICAgICBmaWxlTmFtZSxcbiAgICAgICAgcmV2aXNpb24sXG4gICAgICAgIGNvbmZpZyxcbiAgICB9XG59XG5cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlXG5leHBvcnQgaW50ZXJmYWNlIFBhY2thZ2VDb25maWd1cmF0aW9uIGV4dGVuZHMgSGFuZGxlckNvbmZpZ3VyYXRpb24ge1xuICAgIC8vIFBsYWNlaG9sZGVyIGZvciBwYWNrYWdlLWxldmVsIGNvbmZpZ3VyYXRpb25zXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWV0YWRhdGEge1xuICAgIHBhY2thZ2VOYW1lOiBzdHJpbmdcbiAgICBmaWxlTmFtZTogc3RyaW5nXG4gICAgcmV2aXNpb246IHN0cmluZyB8IHVuZGVmaW5lZFxuICAgIGNvbmZpZz86IFBhY2thZ2VDb25maWd1cmF0aW9uXG59XG5cbmZ1bmN0aW9uIGdldE1ldGFkYXRhKCkge1xuICAgIHJldHVybiBtZXRhZGF0YVxufVxuXG5mdW5jdGlvbiBwYXRoVG9SZWdFeHAocGF0aDogc3RyaW5nKSB7XG4gICAgcmV0dXJuIG5ldyBSZWdFeHAoXG4gICAgICAgIChcbiAgICAgICAgICAgICdeJyArXG4gICAgICAgICAgICBwYXRoLnJlcGxhY2UoL1svXFxcXF4kKz8uKCl8W1xcXXt9XS9ndSwgJ1xcXFwkJicpLnJlcGxhY2VBbGwoJyonLCAnW14vXFxcXD9dKycpICtcbiAgICAgICAgICAgICcoXFxcXD8uKik/JCdcbiAgICAgICAgKS5yZXBsYWNlKCdbXi9cXFxcP10rW14vXFxcXD9dKyhcXFxcPy4qKT8kJywgJycpLFxuICAgICAgICAndScsXG4gICAgKVxufVxuXG5mdW5jdGlvbiBjb21iaW5lQ29uZmlnKFxuICAgIGJhc2U6IFBhY2thZ2VDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuICAgIG92ZXJyaWRlOiBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IHVuZGVmaW5lZCxcbik6IChQYWNrYWdlQ29uZmlndXJhdGlvbiAmIEhhbmRsZXJDb25maWd1cmF0aW9uKSB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKGJhc2UgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICByZXR1cm4gb3ZlcnJpZGVcbiAgICB9IGVsc2UgaWYgKG92ZXJyaWRlID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgcmV0dXJuIGJhc2VcbiAgICB9XG4gICAgcmV0dXJuIHsgLi4uYmFzZSwgLi4ub3ZlcnJpZGUgfVxufVxuXG5mdW5jdGlvbiBodHRwSG9zdChcbiAgICBtZXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZCxcbiAgICBjZmc6IEhhbmRsZXJDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxuICAgIG1ldGhvZDogTWV0aG9kLFxuICAgIHBhdGg6IHN0cmluZyxcbiAgICBlbnRyeTogSGFuZGxlcixcbikge1xuICAgIGFkZEhhbmRsZXIoJ2h0dHAnLCB7XG4gICAgICAgIG1ldGEsXG4gICAgICAgIGNvbmZpZzogY29tYmluZUNvbmZpZyhtZXRhPy5jb25maWcsIGNmZyksXG4gICAgICAgIG1ldGhvZCxcbiAgICAgICAgcGF0aFBhdHRlcm46IHBhdGgsXG4gICAgICAgIHBhdGhSZWdFeHA6IHBhdGhUb1JlZ0V4cChwYXRoKSxcbiAgICAgICAgZW50cnksXG4gICAgfSlcbn1cblxuc2V0SHR0cEhvc3QoaHR0cEhvc3QpXG5cbmV4cG9ydCB0eXBlIE1ldGhvZCA9ICdHRVQnIHwgJ1BPU1QnIHwgJ1BVVCcgfCAnUEFUQ0gnIHwgJ0RFTEVURSdcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVySHR0cEhhbmRsZXIoXG4gICAgbWV0aG9kOiBNZXRob2QsXG4gICAgcGF0aDogc3RyaW5nLFxuICAgIGNvbmZpZ09ySGFuZGxlcjogSGFuZGxlckNvbmZpZ3VyYXRpb24gfCBIYW5kbGVyLFxuICAgIGZuPzogSGFuZGxlcixcbik6IHZvaWQge1xuICAgIGlmICh0eXBlb2YgY29uZmlnT3JIYW5kbGVyID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgIGh0dHBIb3N0UmVnaXN0cnkoZ2V0TWV0YWRhdGEoKSwgdW5kZWZpbmVkLCBtZXRob2QsIHBhdGgsIGNvbmZpZ09ySGFuZGxlcilcbiAgICB9IGVsc2Uge1xuICAgICAgICBpZiAoIWZuKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1BsZWFzZSBwcm92aWRlIGEgaGFuZGxlciBmdW5jdGlvbi4nKVxuICAgICAgICB9XG4gICAgICAgIGh0dHBIb3N0UmVnaXN0cnkoZ2V0TWV0YWRhdGEoKSwgY29uZmlnT3JIYW5kbGVyLCBtZXRob2QsIHBhdGgsIGZuKVxuICAgIH1cbn1cbiJdfQ==
package/http.js CHANGED
@@ -1,4 +1,4 @@
1
- import { registerHttpHandler } from './lib/registry.js';
1
+ import { registerHttpHandler } from './host/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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImh0dHAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFFdkQsY0FBYyxjQUFjLENBQUE7QUFpQzVCLE1BQU0sVUFBVSxHQUFHLENBQ2YsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUN6RCxDQUFDO0FBR0QsTUFBTSxVQUFVLElBQUksQ0FDaEIsSUFBWSxFQUNaLGVBQW1ELEVBQ25ELEVBQVk7SUFFWixtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxFQUFFLENBQUMsQ0FBQTtBQUMxRCxDQUFDO0FBR0QsTUFBTSxVQUFVLEdBQUcsQ0FDZixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQ3pELENBQUM7QUFHRCxNQUFNLFVBQVUsS0FBSyxDQUNqQixJQUFZLEVBQ1osZUFBbUQsRUFDbkQsRUFBWTtJQUVaLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0FBQzNELENBQUM7QUFHRCxNQUFNLFVBQVUsR0FBRyxDQUNmLElBQVksRUFDWixlQUFtRCxFQUNuRCxFQUFZO0lBRVosbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUE7QUFDNUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVXJsV2l0aFBhcnNlZFF1ZXJ5IH0gZnJvbSAnbm9kZTp1cmwnXHJcbmltcG9ydCB7IENvbnRleHQsIEhhbmRsZXJDb25maWd1cmF0aW9uLCBKc29uIH0gZnJvbSAnLi9jb250ZXh0LmpzJ1xyXG5pbXBvcnQgeyByZWdpc3Rlckh0dHBIYW5kbGVyIH0gZnJvbSAnLi9saWIvcmVnaXN0cnkuanMnXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbnRleHQuanMnXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFJlc3BvbnNlSGVhZGVycyB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBzdHJpbmdcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGdWxsUmVzdWx0IHtcclxuICAgIGhlYWRlcnM/OiBSZXNwb25zZUhlYWRlcnNcclxuICAgIHN0YXR1cz86IG51bWJlclxyXG4gICAgYm9keT86IHVua25vd25cclxufVxyXG5cclxuZXhwb3J0IHR5cGUgUmVzdWx0ID0gdm9pZCB8IHN0cmluZyB8IEZ1bGxSZXN1bHRcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgSHR0cFJlcXVlc3Qge1xyXG4gICAgcmVhZG9ubHkgcmF3VXJsOiBzdHJpbmdcclxuICAgIHJlYWRvbmx5IHVybDogUmVhZG9ubHk8VXJsV2l0aFBhcnNlZFF1ZXJ5PiAmIHsgcGF0aFN0ZXBBdDogKGluZGV4OiBudW1iZXIpID0+IHN0cmluZyB9XHJcbiAgICByZWFkb25seSBoZWFkZXJzOiBSZWFkb25seTxSZXNwb25zZUhlYWRlcnM+XHJcbiAgICByZWFkb25seSBib2R5PzogSnNvbiB8IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiBleHRlbmRzIEhhbmRsZXJDb25maWd1cmF0aW9uIHtcclxuICAgIC8qKlxyXG4gICAgICogQSBzdHJpbmcgaWRlbnRpZnlpbmcgd2hpY2ggZG9tYWlucyBjYW4gYWNjZXNzIHRoZSBlbmRwb2ludCBjcm9zcy1vcmlnaW4uXHJcbiAgICAgKiBAZGVmYXVsdCB1bmRlZmluZWRcclxuICAgICAqL1xyXG4gICAgcmVhZG9ubHkgY29ycz86IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBIYW5kbGVyID0gKGNvbnRleHQ6IENvbnRleHQsIHJlcXVlc3Q6IEh0dHBSZXF1ZXN0KSA9PiBQcm9taXNlPFJlc3VsdD4gfCBSZXN1bHRcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXQocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGdldChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGdldChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdHRVQnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBwb3N0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwb3N0KHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcG9zdChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdQT1NUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gcHV0KHBhdGg6IHN0cmluZywgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwdXQocGF0aDogc3RyaW5nLCBjb25maWc6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiwgZm46IEhhbmRsZXIpOiB2b2lkXHJcbmV4cG9ydCBmdW5jdGlvbiBwdXQoXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUFVUJywgcGF0aCwgY29uZmlnT3JIYW5kbGVyLCBmbilcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gcGF0Y2gocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIHBhdGNoKHBhdGg6IHN0cmluZywgY29uZmlnOiBIdHRwSGFuZGxlckNvbmZpZ3VyYXRpb24sIGZuOiBIYW5kbGVyKTogdm9pZFxyXG5leHBvcnQgZnVuY3Rpb24gcGF0Y2goXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEh0dHBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IEhhbmRsZXIsXHJcbiAgICBmbj86IEhhbmRsZXIsXHJcbik6IHZvaWQge1xyXG4gICAgcmVnaXN0ZXJIdHRwSGFuZGxlcignUEFUQ0gnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBkZWwocGF0aDogc3RyaW5nLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGRlbChwYXRoOiBzdHJpbmcsIGNvbmZpZzogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uLCBmbjogSGFuZGxlcik6IHZvaWRcclxuZXhwb3J0IGZ1bmN0aW9uIGRlbChcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGNvbmZpZ09ySGFuZGxlcjogSHR0cEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICByZWdpc3Rlckh0dHBIYW5kbGVyKCdERUxFVEUnLCBwYXRoLCBjb25maWdPckhhbmRsZXIsIGZuKVxyXG59XHJcbiJdfQ==
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
1
  {
2
- "name": "@riddance/host",
3
- "version": "0.0.8",
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
- "lib/*.js",
20
- "lib/*.d.ts"
21
- ],
22
- "exports": {
23
- "./lib/context": "./context.js",
24
- "./lib/http": "./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
- },
31
- "devDependencies": {
32
- "@riddance/env": "0.1.1"
33
- },
34
- "scripts": {
35
- "prepare": "tsc",
36
- "watch": "watch"
37
- }
2
+ "name": "@riddance/host",
3
+ "version": "0.0.10",
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
38
  }
package/lib/context.js DELETED
@@ -1,102 +0,0 @@
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
- import { EventEmitter } from './emitter.js';
14
- import { makeLogger } from './logging.js';
15
- class LogMulticaster {
16
- constructor(transports) {
17
- _LogMulticaster_transports.set(this, void 0);
18
- __classPrivateFieldSet(this, _LogMulticaster_transports, transports, "f");
19
- this.publishRate = transports.map(t => t.publishRate).sort()[0] ?? Number.MAX_SAFE_INTEGER;
20
- }
21
- sendEntries(entries, signal) {
22
- const promises = __classPrivateFieldGet(this, _LogMulticaster_transports, "f").map(t => t.sendEntries(entries, signal)).filter(p => !!p);
23
- if (promises.length === 0) {
24
- return;
25
- }
26
- return Promise.all(promises);
27
- }
28
- }
29
- _LogMulticaster_transports = new WeakMap();
30
- export function createContext(clientInfo, loggers, eventTransport, timeouts, outerController, meta, environment, now) {
31
- const timeout = (timeouts.cap
32
- ? Math.min(meta?.config?.timeout ?? timeouts.default, timeouts.cap)
33
- : meta?.config?.timeout ?? timeouts.default) * 1000;
34
- const innerController = new AbortController();
35
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
36
- const logTransport = loggers.length === 1 ? loggers[0] : new LogMulticaster(loggers);
37
- const logger = makeLogger(logTransport, meta?.config?.minimumLogLevel, outerController.signal).enrichReserved({
38
- operationId: clientInfo.operationId,
39
- client: {
40
- id: clientInfo.clientId,
41
- ip: clientInfo.clientIp,
42
- port: clientInfo.clientPort,
43
- userAgent: clientInfo.userAgent,
44
- },
45
- });
46
- globalLogger = logger;
47
- const emitter = new EventEmitter(eventTransport, logger, clientInfo, timeout, outerController.signal);
48
- const successHandlers = [];
49
- const ctx = {
50
- env: environment ?? process.env,
51
- signal: innerController.signal,
52
- now: now ?? (() => new Date()),
53
- operationId: clientInfo.operationId,
54
- client: {
55
- id: clientInfo.clientId,
56
- ip: clientInfo.clientIp,
57
- port: clientInfo.clientPort,
58
- userAgent: clientInfo.userAgent,
59
- },
60
- meta: meta
61
- ? {
62
- packageName: meta.packageName,
63
- fileName: meta.fileName,
64
- revision: meta.revision,
65
- }
66
- : undefined,
67
- emit: (topic, type, subject, data, messageId) => emitter.emit({ topic, type, subject, id: messageId }, data),
68
- eventBarrier: () => emitter.flush(),
69
- onSuccess: (fn) => successHandlers.push(fn),
70
- };
71
- const timeoutHandle = setTimeout(() => {
72
- logger.error('Timeout.', undefined, undefined);
73
- innerController.abort();
74
- // eslint-disable-next-line no-void
75
- void logger.flush();
76
- // eslint-disable-next-line no-void
77
- void emitter.flush();
78
- }, timeout);
79
- const flushHandle = setTimeout(() => {
80
- logger.error('Aborting flush.', undefined, undefined);
81
- outerController.abort();
82
- }, timeout + 15000);
83
- return {
84
- log: logger,
85
- context: ctx,
86
- success: () => Promise.all(successHandlers.map(fn => fn())),
87
- flush: async () => {
88
- clearTimeout(timeoutHandle);
89
- await emitter.flush();
90
- await logger.flush();
91
- clearTimeout(flushHandle);
92
- },
93
- };
94
- }
95
- let globalLogger;
96
- process.on('uncaughtException', err => {
97
- globalLogger?.fatal('Uncaught exception.', err, undefined);
98
- });
99
- process.on('unhandledRejection', reason => {
100
- globalLogger?.fatal('Unhandled rejection.', reason, undefined);
101
- });
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"]}
package/lib/emitter.js DELETED
@@ -1,81 +0,0 @@
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
- export class EventEmitter {
14
- constructor(transport, logger, ids, timeout, signal) {
15
- _EventEmitter_instances.add(this);
16
- _EventEmitter_transport.set(this, void 0);
17
- _EventEmitter_logger.set(this, void 0);
18
- _EventEmitter_ids.set(this, void 0);
19
- _EventEmitter_emitted.set(this, {});
20
- _EventEmitter_size.set(this, 0);
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");
31
- }
32
- emit(meta, data) {
33
- var _a;
34
- const eventTime = new Date();
35
- const timeLeft = __classPrivateFieldGet(this, _EventEmitter_deadline, "f") - new Date().getTime();
36
- if (__classPrivateFieldGet(this, _EventEmitter_buffered, "f") / __classPrivateFieldGet(this, _EventEmitter_transport, "f").publishRate > timeLeft) {
37
- throw new Error('Event overflow.');
38
- }
39
- const event = data === undefined
40
- ? { meta, ids: __classPrivateFieldGet(this, _EventEmitter_ids, "f"), eventTime }
41
- : { meta, ids: __classPrivateFieldGet(this, _EventEmitter_ids, "f"), eventTime, json: JSON.stringify(data) };
42
- const events = __classPrivateFieldGet(this, _EventEmitter_emitted, "f")[meta.topic];
43
- if (!events) {
44
- __classPrivateFieldGet(this, _EventEmitter_emitted, "f")[meta.topic] = [event];
45
- }
46
- else {
47
- events.push(event);
48
- if (events.length > 64 || __classPrivateFieldGet(this, _EventEmitter_size, "f") > 64000) {
49
- // eslint-disable-next-line no-void
50
- void this.flush();
51
- }
52
- }
53
- __classPrivateFieldSet(this, _EventEmitter_buffered, (_a = __classPrivateFieldGet(this, _EventEmitter_buffered, "f"), ++_a), "f");
54
- __classPrivateFieldSet(this, _EventEmitter_size, __classPrivateFieldGet(this, _EventEmitter_size, "f") + (event.json?.length ?? 0), "f");
55
- }
56
- async flush() {
57
- __classPrivateFieldGet(this, _EventEmitter_instances, "m", _EventEmitter_startFlush).call(this, __classPrivateFieldGet(this, _EventEmitter_emitted, "f"));
58
- __classPrivateFieldSet(this, _EventEmitter_emitted, {}, "f");
59
- __classPrivateFieldSet(this, _EventEmitter_size, 0, "f");
60
- return await __classPrivateFieldGet(this, _EventEmitter_flusher, "f");
61
- }
62
- }
63
- _EventEmitter_transport = new WeakMap(), _EventEmitter_logger = new WeakMap(), _EventEmitter_ids = new WeakMap(), _EventEmitter_emitted = new WeakMap(), _EventEmitter_size = new WeakMap(), _EventEmitter_flusher = new WeakMap(), _EventEmitter_deadline = new WeakMap(), _EventEmitter_buffered = new WeakMap(), _EventEmitter_signal = new WeakMap(), _EventEmitter_instances = new WeakSet(), _EventEmitter_startFlush = function _EventEmitter_startFlush(emitted) {
64
- if (__classPrivateFieldGet(this, _EventEmitter_flusher, "f")) {
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"));
74
- }
75
- catch (e) {
76
- __classPrivateFieldGet(this, _EventEmitter_logger, "f").fatal('Error sending events.', e, { events });
77
- }
78
- __classPrivateFieldSet(this, _EventEmitter_buffered, __classPrivateFieldGet(this, _EventEmitter_buffered, "f") - events.length, "f");
79
- }));
80
- };
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1pdHRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImVtaXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBT0EsTUFBTSxPQUFPLFlBQVk7SUFXckIsWUFDSSxTQUF5QixFQUN6QixNQUFjLEVBQ2QsR0FBdUYsRUFDdkYsT0FBZSxFQUNmLE1BQW1COztRQWZ2QiwwQ0FBbUM7UUFDbkMsdUNBQXdCO1FBQ3hCLG9DQUF5QjtRQUN6QixnQ0FBdUIsRUFBRSxFQUFBO1FBQ3pCLDZCQUFRLENBQUMsRUFBQTtRQUNULHdDQUF3QjtRQUN4Qix5Q0FBMEI7UUFDMUIseUNBQWlCO1FBQ2pCLHVDQUE2QjtRQVN6Qix1QkFBQSxJQUFJLDJCQUFjLFNBQVMsTUFBQSxDQUFBO1FBQzNCLHVCQUFBLElBQUksd0JBQVcsTUFBTSxNQUFBLENBQUE7UUFDckIsdUJBQUEsSUFBSSxxQkFBUSxHQUFHLE1BQUEsQ0FBQTtRQUNmLHVCQUFBLElBQUksMEJBQWEsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyxPQUFPLE1BQUEsQ0FBQTtRQUMvQyx1QkFBQSxJQUFJLDBCQUFhLENBQUMsTUFBQSxDQUFBO1FBQ2xCLHVCQUFBLElBQUksd0JBQVcsTUFBTSxNQUFBLENBQUE7SUFDekIsQ0FBQztJQUVELElBQUksQ0FBQyxJQUFtQixFQUFFLElBQVc7O1FBQ2pDLE1BQU0sU0FBUyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUE7UUFDNUIsTUFBTSxRQUFRLEdBQUcsdUJBQUEsSUFBSSw4QkFBVSxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDdEQsSUFBSSx1QkFBQSxJQUFJLDhCQUFVLEdBQUcsdUJBQUEsSUFBSSwrQkFBVyxDQUFDLFdBQVcsR0FBRyxRQUFRLEVBQUU7WUFDekQsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFBO1NBQ3JDO1FBQ0QsTUFBTSxLQUFLLEdBQ1AsSUFBSSxLQUFLLFNBQVM7WUFDZCxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLHVCQUFBLElBQUkseUJBQUssRUFBRSxTQUFTLEVBQUU7WUFDckMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSx1QkFBQSxJQUFJLHlCQUFLLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUE7UUFDekUsTUFBTSxNQUFNLEdBQUcsdUJBQUEsSUFBSSw2QkFBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUN4QyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ1QsdUJBQUEsSUFBSSw2QkFBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFBO1NBQ3RDO2FBQU07WUFDSCxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFBO1lBQ2xCLElBQUksTUFBTSxDQUFDLE1BQU0sR0FBRyxFQUFFLElBQUksdUJBQUEsSUFBSSwwQkFBTSxHQUFHLEtBQUssRUFBRTtnQkFDMUMsbUNBQW1DO2dCQUNuQyxLQUFLLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQTthQUNwQjtTQUNKO1FBQ0QscURBQUEsQ0FBRSw4REFBYyxFQUFoQixJQUFnQixDQUFBLE1BQUEsQ0FBQTtRQUNoQiwwR0FBYyxLQUFLLENBQUMsSUFBSSxFQUFFLE1BQU0sSUFBSSxDQUFDLE9BQUEsQ0FBQTtJQUN6QyxDQUFDO0lBRUQsS0FBSyxDQUFDLEtBQUs7UUFDUCx1QkFBQSxJQUFJLHlEQUFZLE1BQWhCLElBQUksRUFBYSx1QkFBQSxJQUFJLDZCQUFTLENBQUMsQ0FBQTtRQUMvQix1QkFBQSxJQUFJLHlCQUFZLEVBQUUsTUFBQSxDQUFBO1FBQ2xCLHVCQUFBLElBQUksc0JBQVMsQ0FBQyxNQUFBLENBQUE7UUFDZCxPQUFPLE1BQU0sdUJBQUEsSUFBSSw2QkFBUyxDQUFBO0lBQzlCLENBQUM7Q0FzQko7Z2NBcEJlLE9BQW1CO0lBQzNCLElBQUksdUJBQUEsSUFBSSw2QkFBUyxFQUFFO1FBQ2YsdUJBQUEsSUFBSSx5QkFBWSx1QkFBQSxJQUFJLDZCQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUFBLElBQUksMERBQWEsTUFBakIsSUFBSSxFQUFjLE9BQU8sQ0FBQyxDQUFDLE1BQUEsQ0FBQTtLQUN2RTtTQUFNO1FBQ0gsdUJBQUEsSUFBSSx5QkFBWSx1QkFBQSxJQUFJLDBEQUFhLE1BQWpCLElBQUksRUFBYyxPQUFPLENBQUMsTUFBQSxDQUFBO0tBQzdDO0FBQ0wsQ0FBQyw4QkFFRCxLQUFLLG9DQUFjLE9BQW1CO0lBQ2xDLE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FDYixNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLEVBQUUsRUFBRTtRQUNsRCxJQUFJO1lBQ0EsTUFBTSx1QkFBQSxJQUFJLCtCQUFXLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsdUJBQUEsSUFBSSw0QkFBUSxDQUFDLENBQUE7U0FDaEU7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNSLHVCQUFBLElBQUksNEJBQVEsQ0FBQyxLQUFLLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxFQUFFLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQTtTQUM3RDtRQUNELGlIQUFrQixNQUFNLENBQUMsTUFBTSxNQUFBLENBQUE7SUFDbkMsQ0FBQyxDQUFDLENBQ0wsQ0FBQTtBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYm9ydFNpZ25hbCwgSnNvbiwgTG9nZ2VyIH0gZnJvbSAnLi4vY29udGV4dC5qcydcclxuaW1wb3J0IHsgQnVmZmVyZWRFdmVudCwgQ2xpZW50SW5mbywgRXZlbnRNZXRhZGF0YSwgRXZlbnRUcmFuc3BvcnQgfSBmcm9tICcuL2NvbnRleHQuanMnXHJcblxyXG5pbnRlcmZhY2UgRW1pdEJ1ZmZlciB7XHJcbiAgICBbdG9waWM6IHN0cmluZ106IEJ1ZmZlcmVkRXZlbnRbXVxyXG59XHJcblxyXG5leHBvcnQgY2xhc3MgRXZlbnRFbWl0dGVyIHtcclxuICAgIHJlYWRvbmx5ICN0cmFuc3BvcnQ6IEV2ZW50VHJhbnNwb3J0XHJcbiAgICByZWFkb25seSAjbG9nZ2VyOiBMb2dnZXJcclxuICAgIHJlYWRvbmx5ICNpZHM6IENsaWVudEluZm9cclxuICAgICNlbWl0dGVkOiBFbWl0QnVmZmVyID0ge31cclxuICAgICNzaXplID0gMFxyXG4gICAgI2ZsdXNoZXI/OiBQcm9taXNlPHZvaWQ+XHJcbiAgICByZWFkb25seSAjZGVhZGxpbmU6IG51bWJlclxyXG4gICAgI2J1ZmZlcmVkOiBudW1iZXJcclxuICAgIHJlYWRvbmx5ICNzaWduYWw6IEFib3J0U2lnbmFsXHJcblxyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgdHJhbnNwb3J0OiBFdmVudFRyYW5zcG9ydCxcclxuICAgICAgICBsb2dnZXI6IExvZ2dlcixcclxuICAgICAgICBpZHM6IHsgb3BlcmF0aW9uSWQ/OiBzdHJpbmc7IGNsaWVudElkPzogc3RyaW5nOyBjbGllbnRJcD86IHN0cmluZzsgdXNlckFnZW50Pzogc3RyaW5nIH0sXHJcbiAgICAgICAgdGltZW91dDogbnVtYmVyLFxyXG4gICAgICAgIHNpZ25hbDogQWJvcnRTaWduYWwsXHJcbiAgICApIHtcclxuICAgICAgICB0aGlzLiN0cmFuc3BvcnQgPSB0cmFuc3BvcnRcclxuICAgICAgICB0aGlzLiNsb2dnZXIgPSBsb2dnZXJcclxuICAgICAgICB0aGlzLiNpZHMgPSBpZHNcclxuICAgICAgICB0aGlzLiNkZWFkbGluZSA9IG5ldyBEYXRlKCkuZ2V0VGltZSgpICsgdGltZW91dFxyXG4gICAgICAgIHRoaXMuI2J1ZmZlcmVkID0gMFxyXG4gICAgICAgIHRoaXMuI3NpZ25hbCA9IHNpZ25hbFxyXG4gICAgfVxyXG5cclxuICAgIGVtaXQobWV0YTogRXZlbnRNZXRhZGF0YSwgZGF0YT86IEpzb24pOiB2b2lkIHtcclxuICAgICAgICBjb25zdCBldmVudFRpbWUgPSBuZXcgRGF0ZSgpXHJcbiAgICAgICAgY29uc3QgdGltZUxlZnQgPSB0aGlzLiNkZWFkbGluZSAtIG5ldyBEYXRlKCkuZ2V0VGltZSgpXHJcbiAgICAgICAgaWYgKHRoaXMuI2J1ZmZlcmVkIC8gdGhpcy4jdHJhbnNwb3J0LnB1Ymxpc2hSYXRlID4gdGltZUxlZnQpIHtcclxuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdFdmVudCBvdmVyZmxvdy4nKVxyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zdCBldmVudCA9XHJcbiAgICAgICAgICAgIGRhdGEgPT09IHVuZGVmaW5lZFxyXG4gICAgICAgICAgICAgICAgPyB7IG1ldGEsIGlkczogdGhpcy4jaWRzLCBldmVudFRpbWUgfVxyXG4gICAgICAgICAgICAgICAgOiB7IG1ldGEsIGlkczogdGhpcy4jaWRzLCBldmVudFRpbWUsIGpzb246IEpTT04uc3RyaW5naWZ5KGRhdGEpIH1cclxuICAgICAgICBjb25zdCBldmVudHMgPSB0aGlzLiNlbWl0dGVkW21ldGEudG9waWNdXHJcbiAgICAgICAgaWYgKCFldmVudHMpIHtcclxuICAgICAgICAgICAgdGhpcy4jZW1pdHRlZFttZXRhLnRvcGljXSA9IFtldmVudF1cclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICBldmVudHMucHVzaChldmVudClcclxuICAgICAgICAgICAgaWYgKGV2ZW50cy5sZW5ndGggPiA2NCB8fCB0aGlzLiNzaXplID4gNjQwMDApIHtcclxuICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby12b2lkXHJcbiAgICAgICAgICAgICAgICB2b2lkIHRoaXMuZmx1c2goKVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgICsrdGhpcy4jYnVmZmVyZWRcclxuICAgICAgICB0aGlzLiNzaXplICs9IGV2ZW50Lmpzb24/Lmxlbmd0aCA/PyAwXHJcbiAgICB9XHJcblxyXG4gICAgYXN5bmMgZmx1c2goKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICAgICAgdGhpcy4jc3RhcnRGbHVzaCh0aGlzLiNlbWl0dGVkKVxyXG4gICAgICAgIHRoaXMuI2VtaXR0ZWQgPSB7fVxyXG4gICAgICAgIHRoaXMuI3NpemUgPSAwXHJcbiAgICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuI2ZsdXNoZXJcclxuICAgIH1cclxuXHJcbiAgICAjc3RhcnRGbHVzaChlbWl0dGVkOiBFbWl0QnVmZmVyKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuI2ZsdXNoZXIpIHtcclxuICAgICAgICAgICAgdGhpcy4jZmx1c2hlciA9IHRoaXMuI2ZsdXNoZXIudGhlbigoKSA9PiB0aGlzLiNmbHVzaEV2ZW50cyhlbWl0dGVkKSlcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICB0aGlzLiNmbHVzaGVyID0gdGhpcy4jZmx1c2hFdmVudHMoZW1pdHRlZClcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgYXN5bmMgI2ZsdXNoRXZlbnRzKGVtaXR0ZWQ6IEVtaXRCdWZmZXIpIHtcclxuICAgICAgICBhd2FpdCBQcm9taXNlLmFsbChcclxuICAgICAgICAgICAgT2JqZWN0LmVudHJpZXMoZW1pdHRlZCkubWFwKGFzeW5jIChbdG9waWMsIGV2ZW50c10pID0+IHtcclxuICAgICAgICAgICAgICAgIHRyeSB7XHJcbiAgICAgICAgICAgICAgICAgICAgYXdhaXQgdGhpcy4jdHJhbnNwb3J0LnNlbmRFdmVudHModG9waWMsIGV2ZW50cywgdGhpcy4jc2lnbmFsKVxyXG4gICAgICAgICAgICAgICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHRoaXMuI2xvZ2dlci5mYXRhbCgnRXJyb3Igc2VuZGluZyBldmVudHMuJywgZSwgeyBldmVudHMgfSlcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHRoaXMuI2J1ZmZlcmVkIC09IGV2ZW50cy5sZW5ndGhcclxuICAgICAgICAgICAgfSksXHJcbiAgICAgICAgKVxyXG4gICAgfVxyXG59XHJcbiJdfQ==