@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.
package/lib/logging.js DELETED
@@ -1,205 +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 _LogBuffer_instances, _LogBuffer_transport, _LogBuffer_entries, _LogBuffer_size, _LogBuffer_flusher, _LogBuffer_signal, _LogBuffer_asyncTransport, _LogBuffer_timeout, _LogBuffer_startFlush, _EnrichingLogger_buffer, _EnrichingLogger_reservedEnrichment, _EnrichingLogger_customEnrichment, _EnrichingLogger_level;
13
- import { performance } from 'perf_hooks';
14
- export function makeLogger(transport, minimumLogLevel, signal) {
15
- return new EnrichingLogger(new LogBuffer(transport, signal), minimumLogLevel
16
- ? ['fatal', 'error', 'warning', 'info', 'debug', 'trace'].indexOf(minimumLogLevel)
17
- : 5, signal);
18
- }
19
- const performanceTimeOrigin100ns = Math.round(performance.timeOrigin * 10000);
20
- export function highPrecisionISODate(performanceNow) {
21
- const now100ns = performanceTimeOrigin100ns + Math.round(performanceNow * 10000);
22
- return (new Date(now100ns / 10000).toISOString().substring(0, 20) +
23
- (now100ns % 10000000).toString().padStart(7, '0') +
24
- 'Z');
25
- }
26
- class LogBuffer {
27
- constructor(transport, signal) {
28
- _LogBuffer_instances.add(this);
29
- _LogBuffer_transport.set(this, void 0);
30
- _LogBuffer_entries.set(this, []);
31
- _LogBuffer_size.set(this, 0);
32
- _LogBuffer_flusher.set(this, void 0);
33
- _LogBuffer_signal.set(this, void 0);
34
- _LogBuffer_asyncTransport.set(this, void 0);
35
- _LogBuffer_timeout.set(this, void 0);
36
- __classPrivateFieldSet(this, _LogBuffer_transport, transport, "f");
37
- __classPrivateFieldSet(this, _LogBuffer_signal, signal, "f");
38
- }
39
- collect(level, numericLogLevel, message, error, fields, reservedEnrichment, customEnrichment) {
40
- const offset = performance.now();
41
- const json = JSON.stringify({
42
- timestamp: highPrecisionISODate(offset),
43
- level,
44
- message,
45
- error: errorAsJson(error),
46
- ...reservedEnrichment,
47
- ...((fields || customEnrichment) && {
48
- fields: customEnrichment
49
- ? fields
50
- ? { ...customEnrichment, ...fields }
51
- : customEnrichment
52
- : fields,
53
- }),
54
- });
55
- __classPrivateFieldGet(this, _LogBuffer_entries, "f").push({
56
- timestamp: offset,
57
- level,
58
- message,
59
- error,
60
- json,
61
- });
62
- __classPrivateFieldSet(this, _LogBuffer_size, __classPrivateFieldGet(this, _LogBuffer_size, "f") + json.length, "f");
63
- if (__classPrivateFieldGet(this, _LogBuffer_asyncTransport, "f") === false) {
64
- // eslint-disable-next-line no-void
65
- void __classPrivateFieldGet(this, _LogBuffer_transport, "f").sendEntries(__classPrivateFieldGet(this, _LogBuffer_entries, "f"), __classPrivateFieldGet(this, _LogBuffer_signal, "f"));
66
- __classPrivateFieldSet(this, _LogBuffer_entries, [], "f");
67
- __classPrivateFieldSet(this, _LogBuffer_size, 0, "f");
68
- }
69
- else if (__classPrivateFieldGet(this, _LogBuffer_asyncTransport, "f") === undefined) {
70
- __classPrivateFieldSet(this, _LogBuffer_asyncTransport, true, "f");
71
- setImmediate(() => {
72
- if (__classPrivateFieldGet(this, _LogBuffer_flusher, "f")) {
73
- return;
74
- }
75
- const sendResult = __classPrivateFieldGet(this, _LogBuffer_transport, "f").sendEntries(__classPrivateFieldGet(this, _LogBuffer_entries, "f"), __classPrivateFieldGet(this, _LogBuffer_signal, "f"));
76
- __classPrivateFieldSet(this, _LogBuffer_entries, [], "f");
77
- __classPrivateFieldSet(this, _LogBuffer_size, 0, "f");
78
- if (sendResult) {
79
- __classPrivateFieldSet(this, _LogBuffer_flusher, sendResult, "f");
80
- }
81
- else {
82
- __classPrivateFieldSet(this, _LogBuffer_asyncTransport, false, "f");
83
- }
84
- });
85
- }
86
- else {
87
- if (numericLogLevel < 2 || __classPrivateFieldGet(this, _LogBuffer_entries, "f").length > 8 || __classPrivateFieldGet(this, _LogBuffer_size, "f") > 64000) {
88
- // eslint-disable-next-line no-void
89
- void this.flush();
90
- }
91
- else {
92
- __classPrivateFieldSet(this, _LogBuffer_timeout, setTimeout(() => {
93
- // eslint-disable-next-line no-void
94
- void this.flush();
95
- __classPrivateFieldSet(this, _LogBuffer_timeout, undefined, "f");
96
- }, 2000), "f");
97
- }
98
- }
99
- }
100
- async flush() {
101
- if (__classPrivateFieldGet(this, _LogBuffer_entries, "f").length === 0) {
102
- return;
103
- }
104
- __classPrivateFieldGet(this, _LogBuffer_instances, "m", _LogBuffer_startFlush).call(this, __classPrivateFieldGet(this, _LogBuffer_entries, "f"));
105
- __classPrivateFieldSet(this, _LogBuffer_entries, [], "f");
106
- __classPrivateFieldSet(this, _LogBuffer_size, 0, "f");
107
- if (__classPrivateFieldGet(this, _LogBuffer_timeout, "f")) {
108
- clearTimeout(__classPrivateFieldGet(this, _LogBuffer_timeout, "f"));
109
- __classPrivateFieldSet(this, _LogBuffer_timeout, undefined, "f");
110
- }
111
- return await __classPrivateFieldGet(this, _LogBuffer_flusher, "f");
112
- }
113
- }
114
- _LogBuffer_transport = new WeakMap(), _LogBuffer_entries = new WeakMap(), _LogBuffer_size = new WeakMap(), _LogBuffer_flusher = new WeakMap(), _LogBuffer_signal = new WeakMap(), _LogBuffer_asyncTransport = new WeakMap(), _LogBuffer_timeout = new WeakMap(), _LogBuffer_instances = new WeakSet(), _LogBuffer_startFlush = function _LogBuffer_startFlush(entries) {
115
- if (__classPrivateFieldGet(this, _LogBuffer_flusher, "f")) {
116
- __classPrivateFieldSet(this, _LogBuffer_flusher, __classPrivateFieldGet(this, _LogBuffer_flusher, "f").then(() => __classPrivateFieldGet(this, _LogBuffer_transport, "f").sendEntries(entries, __classPrivateFieldGet(this, _LogBuffer_signal, "f"))), "f");
117
- }
118
- else {
119
- __classPrivateFieldSet(this, _LogBuffer_flusher, __classPrivateFieldGet(this, _LogBuffer_transport, "f").sendEntries(entries, __classPrivateFieldGet(this, _LogBuffer_signal, "f")), "f");
120
- }
121
- };
122
- class EnrichingLogger {
123
- constructor(buffer, level, reservedEnrichment, customEnrichment) {
124
- _EnrichingLogger_buffer.set(this, void 0);
125
- _EnrichingLogger_reservedEnrichment.set(this, void 0);
126
- _EnrichingLogger_customEnrichment.set(this, void 0);
127
- _EnrichingLogger_level.set(this, void 0);
128
- __classPrivateFieldSet(this, _EnrichingLogger_buffer, buffer, "f");
129
- __classPrivateFieldSet(this, _EnrichingLogger_level, level, "f");
130
- __classPrivateFieldSet(this, _EnrichingLogger_reservedEnrichment, reservedEnrichment, "f");
131
- __classPrivateFieldSet(this, _EnrichingLogger_customEnrichment, customEnrichment, "f");
132
- }
133
- enrich(fields) {
134
- return new EnrichingLogger(__classPrivateFieldGet(this, _EnrichingLogger_buffer, "f"), __classPrivateFieldGet(this, _EnrichingLogger_level, "f"), __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), {
135
- ...(__classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f") ?? {}),
136
- ...fields,
137
- });
138
- }
139
- flush() {
140
- return __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").flush();
141
- }
142
- enrichReserved(fields) {
143
- return new EnrichingLogger(__classPrivateFieldGet(this, _EnrichingLogger_buffer, "f"), __classPrivateFieldGet(this, _EnrichingLogger_level, "f"), {
144
- ...(__classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f") ?? {}),
145
- ...fields,
146
- }, __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
147
- }
148
- trace(message, error, fields) {
149
- if (__classPrivateFieldGet(this, _EnrichingLogger_level, "f") < 5) {
150
- return;
151
- }
152
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('trace', 5, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
153
- }
154
- debug(message, error, fields) {
155
- if (__classPrivateFieldGet(this, _EnrichingLogger_level, "f") < 4) {
156
- return;
157
- }
158
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('debug', 4, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
159
- }
160
- info(message, error, fields) {
161
- if (__classPrivateFieldGet(this, _EnrichingLogger_level, "f") < 3) {
162
- return;
163
- }
164
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('info', 3, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
165
- }
166
- warn(message, error, fields) {
167
- if (__classPrivateFieldGet(this, _EnrichingLogger_level, "f") < 2) {
168
- return;
169
- }
170
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('warning', 2, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
171
- }
172
- error(message, error, fields) {
173
- if (__classPrivateFieldGet(this, _EnrichingLogger_level, "f") < 1) {
174
- return;
175
- }
176
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('error', 1, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
177
- }
178
- fatal(message, error, fields) {
179
- __classPrivateFieldGet(this, _EnrichingLogger_buffer, "f").collect('fatal', 0, message, error, fields, __classPrivateFieldGet(this, _EnrichingLogger_reservedEnrichment, "f"), __classPrivateFieldGet(this, _EnrichingLogger_customEnrichment, "f"));
180
- }
181
- }
182
- _EnrichingLogger_buffer = new WeakMap(), _EnrichingLogger_reservedEnrichment = new WeakMap(), _EnrichingLogger_customEnrichment = new WeakMap(), _EnrichingLogger_level = new WeakMap();
183
- function errorAsJson(error) {
184
- if (error === undefined || error === null) {
185
- return undefined;
186
- }
187
- if (error instanceof Error) {
188
- return {
189
- message: error.message,
190
- name: error.name,
191
- stack: error.stack,
192
- ...error,
193
- };
194
- }
195
- if (error instanceof Object) {
196
- return {
197
- ...error,
198
- };
199
- }
200
- return {
201
- message: error?.toString(),
202
- name: typeof error,
203
- };
204
- }
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging.js","sourceRoot":"","sources":["logging.ts"],"names":[],"mappings":"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","sourcesContent":["import { performance } from 'perf_hooks'\r\nimport { AbortSignal, Json, Logger } from '../context.js'\r\nimport { LogEntry, LogLevel, LogTransport, RootLogger } from './context.js'\r\n\r\nexport function makeLogger(\r\n    transport: LogTransport,\r\n    minimumLogLevel: LogLevel | undefined,\r\n    signal: AbortSignal,\r\n): RootLogger {\r\n    return new EnrichingLogger(\r\n        new LogBuffer(transport, signal),\r\n        minimumLogLevel\r\n            ? ['fatal', 'error', 'warning', 'info', 'debug', 'trace'].indexOf(minimumLogLevel)\r\n            : 5,\r\n        signal,\r\n    )\r\n}\r\n\r\nconst performanceTimeOrigin100ns = Math.round(performance.timeOrigin * 10000)\r\n\r\nexport function highPrecisionISODate(performanceNow: number) {\r\n    const now100ns = performanceTimeOrigin100ns + Math.round(performanceNow * 10000)\r\n    return (\r\n        new Date(now100ns / 10000).toISOString().substring(0, 20) +\r\n        (now100ns % 10000000).toString().padStart(7, '0') +\r\n        'Z'\r\n    )\r\n}\r\n\r\nclass LogBuffer {\r\n    readonly #transport: LogTransport\r\n    #entries: LogEntry[] = []\r\n    #size = 0\r\n    #flusher?: Promise<void> | undefined\r\n    readonly #signal: AbortSignal\r\n    #asyncTransport: boolean | undefined\r\n    #timeout: NodeJS.Timeout | undefined\r\n\r\n    constructor(transport: LogTransport, signal: AbortSignal) {\r\n        this.#transport = transport\r\n        this.#signal = signal\r\n    }\r\n\r\n    collect(\r\n        level: LogLevel,\r\n        numericLogLevel: number,\r\n        message: string,\r\n        error: unknown,\r\n        fields: object | undefined,\r\n        reservedEnrichment: object | undefined,\r\n        customEnrichment: object | undefined,\r\n    ) {\r\n        const offset = performance.now()\r\n        const json = JSON.stringify({\r\n            timestamp: highPrecisionISODate(offset),\r\n            level,\r\n            message,\r\n            error: errorAsJson(error),\r\n            ...reservedEnrichment,\r\n            ...((fields || customEnrichment) && {\r\n                fields: customEnrichment\r\n                    ? fields\r\n                        ? { ...customEnrichment, ...fields }\r\n                        : customEnrichment\r\n                    : fields,\r\n            }),\r\n        })\r\n        this.#entries.push({\r\n            timestamp: offset,\r\n            level,\r\n            message,\r\n            error,\r\n            json,\r\n        })\r\n        this.#size += json.length\r\n\r\n        if (this.#asyncTransport === false) {\r\n            // eslint-disable-next-line no-void\r\n            void this.#transport.sendEntries(this.#entries, this.#signal)\r\n            this.#entries = []\r\n            this.#size = 0\r\n        } else if (this.#asyncTransport === undefined) {\r\n            this.#asyncTransport = true\r\n            setImmediate(() => {\r\n                if (this.#flusher) {\r\n                    return\r\n                }\r\n                const sendResult = this.#transport.sendEntries(this.#entries, this.#signal)\r\n                this.#entries = []\r\n                this.#size = 0\r\n                if (sendResult) {\r\n                    this.#flusher = sendResult\r\n                } else {\r\n                    this.#asyncTransport = false\r\n                }\r\n            })\r\n        } else {\r\n            if (numericLogLevel < 2 || this.#entries.length > 8 || this.#size > 64000) {\r\n                // eslint-disable-next-line no-void\r\n                void this.flush()\r\n            } else {\r\n                this.#timeout = setTimeout(() => {\r\n                    // eslint-disable-next-line no-void\r\n                    void this.flush()\r\n                    this.#timeout = undefined\r\n                }, 2000)\r\n            }\r\n        }\r\n    }\r\n\r\n    async flush(): Promise<void> {\r\n        if (this.#entries.length === 0) {\r\n            return\r\n        }\r\n        this.#startFlush(this.#entries)\r\n        this.#entries = []\r\n        this.#size = 0\r\n        if (this.#timeout) {\r\n            clearTimeout(this.#timeout)\r\n            this.#timeout = undefined\r\n        }\r\n        return await this.#flusher\r\n    }\r\n\r\n    #startFlush(entries: LogEntry[]) {\r\n        if (this.#flusher) {\r\n            this.#flusher = this.#flusher.then(() =>\r\n                this.#transport.sendEntries(entries, this.#signal),\r\n            )\r\n        } else {\r\n            this.#flusher = this.#transport.sendEntries(entries, this.#signal)\r\n        }\r\n    }\r\n}\r\n\r\nclass EnrichingLogger implements Logger {\r\n    readonly #buffer: LogBuffer\r\n    readonly #reservedEnrichment?: object\r\n    readonly #customEnrichment?: object\r\n    readonly #level: number\r\n\r\n    constructor(\r\n        buffer: LogBuffer,\r\n        level: number,\r\n        reservedEnrichment?: object,\r\n        customEnrichment?: object,\r\n    ) {\r\n        this.#buffer = buffer\r\n        this.#level = level\r\n        this.#reservedEnrichment = reservedEnrichment\r\n        this.#customEnrichment = customEnrichment\r\n    }\r\n\r\n    enrich(fields: object): Logger {\r\n        return new EnrichingLogger(this.#buffer, this.#level, this.#reservedEnrichment, {\r\n            ...(this.#customEnrichment ?? {}),\r\n            ...fields,\r\n        })\r\n    }\r\n\r\n    flush() {\r\n        return this.#buffer.flush()\r\n    }\r\n\r\n    enrichReserved(fields: object): EnrichingLogger {\r\n        return new EnrichingLogger(\r\n            this.#buffer,\r\n            this.#level,\r\n            {\r\n                ...(this.#reservedEnrichment ?? {}),\r\n                ...fields,\r\n            },\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n\r\n    trace(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 5) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'trace',\r\n            5,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    debug(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 4) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'debug',\r\n            4,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    info(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 3) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'info',\r\n            3,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    warn(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 2) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'warning',\r\n            2,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    error(message: string, error: unknown, fields: object | undefined): void {\r\n        if (this.#level < 1) {\r\n            return\r\n        }\r\n        this.#buffer.collect(\r\n            'error',\r\n            1,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n    fatal(message: string, error: unknown, fields: object | undefined): void {\r\n        this.#buffer.collect(\r\n            'fatal',\r\n            0,\r\n            message,\r\n            error,\r\n            fields,\r\n            this.#reservedEnrichment,\r\n            this.#customEnrichment,\r\n        )\r\n    }\r\n}\r\n\r\nfunction errorAsJson(error: unknown): Json | undefined {\r\n    if (error === undefined || error === null) {\r\n        return undefined\r\n    }\r\n    if (error instanceof Error) {\r\n        return {\r\n            message: error.message,\r\n            name: error.name,\r\n            stack: error.stack,\r\n            ...(error as unknown as { [key: string]: unknown }),\r\n        } as Json\r\n    }\r\n    if (error instanceof Object) {\r\n        return {\r\n            ...error,\r\n        } as Json\r\n    }\r\n    return {\r\n        message: (error as object | undefined)?.toString(),\r\n        name: typeof error,\r\n    } as Json\r\n}\r\n"]}
package/lib/registry.js DELETED
@@ -1,61 +0,0 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0cnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJyZWdpc3RyeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQkEsTUFBTSxRQUFRLEdBQWlDLEVBQUUsQ0FBQTtBQUVqRCxTQUFTLFVBQVUsQ0FBQyxJQUF3QixFQUFFLE9BQW9CO0lBQzlELENBQUM7SUFBQSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7QUFDMUMsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBd0I7SUFDaEQsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQWtCLENBQUE7QUFDbEQsQ0FBQztBQVVELElBQUksZ0JBQTBCLENBQUE7QUFFOUIsU0FBUyxXQUFXLENBQUMsSUFBYztJQUMvQixnQkFBZ0IsR0FBRyxJQUFJLENBQUE7QUFDM0IsQ0FBQztBQUVELElBQUksUUFBOEIsQ0FBQTtBQUVsQyxNQUFNLFVBQVUsT0FBTyxDQUNuQixXQUFtQixFQUNuQixRQUFnQixFQUNoQixRQUE0QixFQUM1QixNQUF3QztJQUV4QyxRQUFRLEdBQUc7UUFDUCxXQUFXO1FBQ1gsUUFBUTtRQUNSLFFBQVE7UUFDUixNQUFNO0tBQ1QsQ0FBQTtBQUNMLENBQUM7QUFjRCxTQUFTLFdBQVc7SUFDaEIsT0FBTyxRQUFRLENBQUE7QUFDbkIsQ0FBQztBQUVELFNBQVMsWUFBWSxDQUFDLElBQVk7SUFDOUIsT0FBTyxJQUFJLE1BQU0sQ0FDYixDQUNJLEdBQUc7UUFDSCxJQUFJLENBQUMsT0FBTyxDQUFDLHNCQUFzQixFQUFFLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsVUFBVSxDQUFDO1FBQ3hFLFdBQVcsQ0FDZCxDQUFDLE9BQU8sQ0FBQywyQkFBMkIsRUFBRSxFQUFFLENBQUMsRUFDMUMsR0FBRyxDQUNOLENBQUE7QUFDTCxDQUFDO0FBRUQsU0FBUyxhQUFhLENBQ2xCLElBQXNDLEVBQ3RDLFFBQTBDO0lBRTFDLElBQUksSUFBSSxLQUFLLFNBQVMsRUFBRTtRQUNwQixPQUFPLFFBQVEsQ0FBQTtLQUNsQjtTQUFNLElBQUksUUFBUSxLQUFLLFNBQVMsRUFBRTtRQUMvQixPQUFPLElBQUksQ0FBQTtLQUNkO0lBQ0QsT0FBTyxFQUFFLEdBQUcsSUFBSSxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUE7QUFDbkMsQ0FBQztBQUVELFNBQVMsUUFBUSxDQUNiLElBQTBCLEVBQzFCLEdBQXFDLEVBQ3JDLE1BQWMsRUFDZCxJQUFZLEVBQ1osS0FBYztJQUVkLFVBQVUsQ0FBQyxNQUFNLEVBQUU7UUFDZixJQUFJO1FBQ0osTUFBTSxFQUFFLGFBQWEsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLEdBQUcsQ0FBQztRQUN4QyxNQUFNO1FBQ04sV0FBVyxFQUFFLElBQUk7UUFDakIsVUFBVSxFQUFFLFlBQVksQ0FBQyxJQUFJLENBQUM7UUFDOUIsS0FBSztLQUNSLENBQUMsQ0FBQTtBQUNOLENBQUM7QUFFRCxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUE7QUFJckIsTUFBTSxVQUFVLG1CQUFtQixDQUMvQixNQUFjLEVBQ2QsSUFBWSxFQUNaLGVBQStDLEVBQy9DLEVBQVk7SUFFWixJQUFJLE9BQU8sZUFBZSxLQUFLLFVBQVUsRUFBRTtRQUN2QyxnQkFBZ0IsQ0FBQyxXQUFXLEVBQUUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxlQUFlLENBQUMsQ0FBQTtLQUM1RTtTQUFNO1FBQ0gsSUFBSSxDQUFDLEVBQUUsRUFBRTtZQUNMLE1BQU0sSUFBSSxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FBQTtTQUN4RDtRQUNELGdCQUFnQixDQUFDLFdBQVcsRUFBRSxFQUFFLGVBQWUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFBO0tBQ3JFO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhbmRsZXJDb25maWd1cmF0aW9uIH0gZnJvbSAnLi4vY29udGV4dC5qcydcclxuaW1wb3J0IHsgSGFuZGxlciB9IGZyb20gJy4uL2h0dHAuanMnXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEh0dHBIYW5kbGVyIHtcclxuICAgIG1ldGE6IE1ldGFkYXRhIHwgdW5kZWZpbmVkXHJcbiAgICBjb25maWc6IChQYWNrYWdlQ29uZmlndXJhdGlvbiAmIEhhbmRsZXJDb25maWd1cmF0aW9uKSB8IHVuZGVmaW5lZFxyXG4gICAgbWV0aG9kOiBNZXRob2RcclxuICAgIHBhdGhQYXR0ZXJuOiBzdHJpbmdcclxuICAgIHBhdGhSZWdFeHA6IFJlZ0V4cFxyXG4gICAgZW50cnk6IEhhbmRsZXJcclxufVxyXG5cclxuaW50ZXJmYWNlIEhhbmRsZXJUeXBlcyB7XHJcbiAgICBodHRwOiBIdHRwSGFuZGxlclxyXG59XHJcblxyXG5jb25zdCBoYW5kbGVyczogeyBba2V5OiBzdHJpbmddOiB1bmtub3duW10gfSA9IHt9XHJcblxyXG5mdW5jdGlvbiBhZGRIYW5kbGVyKHR5cGU6IGtleW9mIEhhbmRsZXJUeXBlcywgaGFuZGxlcjogSHR0cEhhbmRsZXIpIHtcclxuICAgIDsoaGFuZGxlcnNbdHlwZV0gPz89IFtdKS5wdXNoKGhhbmRsZXIpXHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRIYW5kbGVycyh0eXBlOiBrZXlvZiBIYW5kbGVyVHlwZXMpIHtcclxuICAgIHJldHVybiAoaGFuZGxlcnNbdHlwZV0gPz8gW10pIGFzIEh0dHBIYW5kbGVyW11cclxufVxyXG5cclxudHlwZSBIdHRwSG9zdCA9IChcclxuICAgIG1ldGE6IE1ldGFkYXRhIHwgdW5kZWZpbmVkLFxyXG4gICAgY29uZmlnOiBIYW5kbGVyQ29uZmlndXJhdGlvbiB8IHVuZGVmaW5lZCxcclxuICAgIG1ldGhvZDogTWV0aG9kLFxyXG4gICAgcGF0aDogc3RyaW5nLFxyXG4gICAgaGFuZGxlcjogSGFuZGxlcixcclxuKSA9PiB2b2lkXHJcblxyXG5sZXQgaHR0cEhvc3RSZWdpc3RyeTogSHR0cEhvc3RcclxuXHJcbmZ1bmN0aW9uIHNldEh0dHBIb3N0KGhvc3Q6IEh0dHBIb3N0KSB7XHJcbiAgICBodHRwSG9zdFJlZ2lzdHJ5ID0gaG9zdFxyXG59XHJcblxyXG5sZXQgbWV0YWRhdGE6IE1ldGFkYXRhIHwgdW5kZWZpbmVkXHJcblxyXG5leHBvcnQgZnVuY3Rpb24gc2V0TWV0YShcclxuICAgIHBhY2thZ2VOYW1lOiBzdHJpbmcsXHJcbiAgICBmaWxlTmFtZTogc3RyaW5nLFxyXG4gICAgcmV2aXNpb246IHN0cmluZyB8IHVuZGVmaW5lZCxcclxuICAgIGNvbmZpZzogUGFja2FnZUNvbmZpZ3VyYXRpb24gfCB1bmRlZmluZWQsXHJcbikge1xyXG4gICAgbWV0YWRhdGEgPSB7XHJcbiAgICAgICAgcGFja2FnZU5hbWUsXHJcbiAgICAgICAgZmlsZU5hbWUsXHJcbiAgICAgICAgcmV2aXNpb24sXHJcbiAgICAgICAgY29uZmlnLFxyXG4gICAgfVxyXG59XHJcblxyXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWVtcHR5LWludGVyZmFjZVxyXG5leHBvcnQgaW50ZXJmYWNlIFBhY2thZ2VDb25maWd1cmF0aW9uIGV4dGVuZHMgSGFuZGxlckNvbmZpZ3VyYXRpb24ge1xyXG4gICAgLy8gUGxhY2Vob2xkZXIgZm9yIHBhY2thZ2UtbGV2ZWwgY29uZmlndXJhdGlvbnNcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBNZXRhZGF0YSB7XHJcbiAgICBwYWNrYWdlTmFtZTogc3RyaW5nXHJcbiAgICBmaWxlTmFtZTogc3RyaW5nXHJcbiAgICByZXZpc2lvbjogc3RyaW5nIHwgdW5kZWZpbmVkXHJcbiAgICBjb25maWc/OiBQYWNrYWdlQ29uZmlndXJhdGlvblxyXG59XHJcblxyXG5mdW5jdGlvbiBnZXRNZXRhZGF0YSgpIHtcclxuICAgIHJldHVybiBtZXRhZGF0YVxyXG59XHJcblxyXG5mdW5jdGlvbiBwYXRoVG9SZWdFeHAocGF0aDogc3RyaW5nKSB7XHJcbiAgICByZXR1cm4gbmV3IFJlZ0V4cChcclxuICAgICAgICAoXHJcbiAgICAgICAgICAgICdeJyArXHJcbiAgICAgICAgICAgIHBhdGgucmVwbGFjZSgvWy9cXFxcXiQrPy4oKXxbXFxde31dL2d1LCAnXFxcXCQmJykucmVwbGFjZUFsbCgnKicsICdbXi9cXFxcP10rJykgK1xyXG4gICAgICAgICAgICAnKFxcXFw/LiopPyQnXHJcbiAgICAgICAgKS5yZXBsYWNlKCdbXi9cXFxcP10rW14vXFxcXD9dKyhcXFxcPy4qKT8kJywgJycpLFxyXG4gICAgICAgICd1JyxcclxuICAgIClcclxufVxyXG5cclxuZnVuY3Rpb24gY29tYmluZUNvbmZpZyhcclxuICAgIGJhc2U6IFBhY2thZ2VDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxyXG4gICAgb3ZlcnJpZGU6IEhhbmRsZXJDb25maWd1cmF0aW9uIHwgdW5kZWZpbmVkLFxyXG4pOiAoUGFja2FnZUNvbmZpZ3VyYXRpb24gJiBIYW5kbGVyQ29uZmlndXJhdGlvbikgfCB1bmRlZmluZWQge1xyXG4gICAgaWYgKGJhc2UgPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICAgIHJldHVybiBvdmVycmlkZVxyXG4gICAgfSBlbHNlIGlmIChvdmVycmlkZSA9PT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgICAgcmV0dXJuIGJhc2VcclxuICAgIH1cclxuICAgIHJldHVybiB7IC4uLmJhc2UsIC4uLm92ZXJyaWRlIH1cclxufVxyXG5cclxuZnVuY3Rpb24gaHR0cEhvc3QoXHJcbiAgICBtZXRhOiBNZXRhZGF0YSB8IHVuZGVmaW5lZCxcclxuICAgIGNmZzogSGFuZGxlckNvbmZpZ3VyYXRpb24gfCB1bmRlZmluZWQsXHJcbiAgICBtZXRob2Q6IE1ldGhvZCxcclxuICAgIHBhdGg6IHN0cmluZyxcclxuICAgIGVudHJ5OiBIYW5kbGVyLFxyXG4pIHtcclxuICAgIGFkZEhhbmRsZXIoJ2h0dHAnLCB7XHJcbiAgICAgICAgbWV0YSxcclxuICAgICAgICBjb25maWc6IGNvbWJpbmVDb25maWcobWV0YT8uY29uZmlnLCBjZmcpLFxyXG4gICAgICAgIG1ldGhvZCxcclxuICAgICAgICBwYXRoUGF0dGVybjogcGF0aCxcclxuICAgICAgICBwYXRoUmVnRXhwOiBwYXRoVG9SZWdFeHAocGF0aCksXHJcbiAgICAgICAgZW50cnksXHJcbiAgICB9KVxyXG59XHJcblxyXG5zZXRIdHRwSG9zdChodHRwSG9zdClcclxuXHJcbmV4cG9ydCB0eXBlIE1ldGhvZCA9ICdHRVQnIHwgJ1BPU1QnIHwgJ1BVVCcgfCAnUEFUQ0gnIHwgJ0RFTEVURSdcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiByZWdpc3Rlckh0dHBIYW5kbGVyKFxyXG4gICAgbWV0aG9kOiBNZXRob2QsXHJcbiAgICBwYXRoOiBzdHJpbmcsXHJcbiAgICBjb25maWdPckhhbmRsZXI6IEhhbmRsZXJDb25maWd1cmF0aW9uIHwgSGFuZGxlcixcclxuICAgIGZuPzogSGFuZGxlcixcclxuKTogdm9pZCB7XHJcbiAgICBpZiAodHlwZW9mIGNvbmZpZ09ySGFuZGxlciA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgIGh0dHBIb3N0UmVnaXN0cnkoZ2V0TWV0YWRhdGEoKSwgdW5kZWZpbmVkLCBtZXRob2QsIHBhdGgsIGNvbmZpZ09ySGFuZGxlcilcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgICAgaWYgKCFmbikge1xyXG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ1BsZWFzZSBwcm92aWRlIGEgaGFuZGxlciBmdW5jdGlvbi4nKVxyXG4gICAgICAgIH1cclxuICAgICAgICBodHRwSG9zdFJlZ2lzdHJ5KGdldE1ldGFkYXRhKCksIGNvbmZpZ09ySGFuZGxlciwgbWV0aG9kLCBwYXRoLCBmbilcclxuICAgIH1cclxufVxyXG4iXX0=