@lukaskj/ts-utils 1.2.0 → 1.2.2

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.
Files changed (37) hide show
  1. package/dist/cjs/cache/index.cjs +182 -0
  2. package/dist/cjs/colors/index.cjs +115 -0
  3. package/dist/cjs/index.cjs +270 -0
  4. package/dist/cjs/neverthrow/index.cjs +69 -0
  5. package/dist/esm/cache/index.mjs +137 -0
  6. package/dist/esm/colors/index.mjs +72 -0
  7. package/dist/esm/index.mjs +217 -0
  8. package/dist/esm/neverthrow/index.mjs +24 -0
  9. package/package.json +20 -36
  10. package/dist/cache/index.cjs +0 -182
  11. package/dist/cache/index.mjs +0 -137
  12. package/dist/colors/index.cjs +0 -115
  13. package/dist/colors/index.mjs +0 -72
  14. package/dist/index.cjs +0 -270
  15. package/dist/index.mjs +0 -217
  16. package/dist/neverthrow/index.cjs +0 -69
  17. package/dist/neverthrow/index.mjs +0 -24
  18. /package/dist/{cache → types/cache}/cacheService.d.ts +0 -0
  19. /package/dist/{cache → types/cache}/constants.d.ts +0 -0
  20. /package/dist/{cache → types/cache}/index.d.ts +0 -0
  21. /package/dist/{cache → types/cache}/internal/types.d.ts +0 -0
  22. /package/dist/{cache → types/cache}/types.d.ts +0 -0
  23. /package/dist/{colors → types/colors}/index.d.ts +0 -0
  24. /package/dist/{index.d.ts → types/index.d.ts} +0 -0
  25. /package/dist/{neverthrow → types/neverthrow}/index.d.ts +0 -0
  26. /package/dist/{neverthrow → types/neverthrow}/tryCatch.d.ts +0 -0
  27. /package/dist/{types.d.ts → types/types.d.ts} +0 -0
  28. /package/dist/{utils → types/utils}/chunksToLines.d.ts +0 -0
  29. /package/dist/{utils → types/utils}/isCallable.d.ts +0 -0
  30. /package/dist/{utils → types/utils}/isNullOrUndefined.d.ts +0 -0
  31. /package/dist/{utils → types/utils}/isObject.d.ts +0 -0
  32. /package/dist/{utils → types/utils}/isPrimitive.d.ts +0 -0
  33. /package/dist/{utils → types/utils}/isPromise.d.ts +0 -0
  34. /package/dist/{utils → types/utils}/jsonParser.d.ts +0 -0
  35. /package/dist/{utils → types/utils}/randomString.d.ts +0 -0
  36. /package/dist/{utils → types/utils}/readStdinAsync.d.ts +0 -0
  37. /package/dist/{utils → types/utils}/sleep.d.ts +0 -0
@@ -0,0 +1,182 @@
1
+ var __create = Object.create;
2
+ var __getProtoOf = Object.getPrototypeOf;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __toESM = (mod, isNodeMode, target) => {
8
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
9
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
10
+ for (let key of __getOwnPropNames(mod))
11
+ if (!__hasOwnProp.call(to, key))
12
+ __defProp(to, key, {
13
+ get: () => mod[key],
14
+ enumerable: true
15
+ });
16
+ return to;
17
+ };
18
+ var __moduleCache = /* @__PURE__ */ new WeakMap;
19
+ var __toCommonJS = (from) => {
20
+ var entry = __moduleCache.get(from), desc;
21
+ if (entry)
22
+ return entry;
23
+ entry = __defProp({}, "__esModule", { value: true });
24
+ if (from && typeof from === "object" || typeof from === "function")
25
+ __getOwnPropNames(from).map((key) => !__hasOwnProp.call(entry, key) && __defProp(entry, key, {
26
+ get: () => from[key],
27
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
28
+ }));
29
+ __moduleCache.set(from, entry);
30
+ return entry;
31
+ };
32
+ var __export = (target, all) => {
33
+ for (var name in all)
34
+ __defProp(target, name, {
35
+ get: all[name],
36
+ enumerable: true,
37
+ configurable: true,
38
+ set: (newValue) => all[name] = () => newValue
39
+ });
40
+ };
41
+
42
+ // src/cache/index.ts
43
+ var exports_cache = {};
44
+ __export(exports_cache, {
45
+ Cache: () => Cache,
46
+ CACHE_TTL_NEVER_EXPIRE: () => CACHE_TTL_NEVER_EXPIRE
47
+ });
48
+ module.exports = __toCommonJS(exports_cache);
49
+
50
+ // src/cache/cacheService.ts
51
+ var import_types = require("node:util/types");
52
+
53
+ // src/utils/isCallable.ts
54
+ function isCallable(value) {
55
+ return typeof value === "function";
56
+ }
57
+
58
+ // src/cache/cacheService.ts
59
+ var defaultCacheOptions = {
60
+ expirationThresholdMs: 0,
61
+ ttlMs: 60 * 60 * 1000
62
+ };
63
+
64
+ class Cache {
65
+ inMemoryCache = new Map;
66
+ options;
67
+ adapter;
68
+ constructor(adapter, defaultOptions) {
69
+ const options = adapter && !("getValue" in adapter) ? adapter : defaultOptions;
70
+ if (adapter && "getValue" in adapter && "setValue" in adapter) {
71
+ this.adapter = adapter;
72
+ }
73
+ this.options = {
74
+ ...defaultCacheOptions,
75
+ ...options
76
+ };
77
+ }
78
+ async getFromAdapter(cacheKey) {
79
+ if (!this.adapter) {
80
+ return;
81
+ }
82
+ return this.adapter.getValue(cacheKey);
83
+ }
84
+ async saveToAdapter(cacheKey, value) {
85
+ if (!this.adapter) {
86
+ return;
87
+ }
88
+ return this.adapter.setValue(cacheKey, value);
89
+ }
90
+ async get(cacheKey, valueLoader, options = {}) {
91
+ const mergedOptions = this.mergeOptions(options);
92
+ const cachedValue = this.tryGetFromMemory(cacheKey);
93
+ if (cachedValue !== undefined) {
94
+ return cachedValue;
95
+ }
96
+ const freshValue = await this.tryGetFromValueLoader(valueLoader);
97
+ if (freshValue !== undefined) {
98
+ await this.cacheValue(cacheKey, freshValue, mergedOptions);
99
+ return freshValue;
100
+ }
101
+ const adapterValue = await this.tryGetFromAdapter(cacheKey);
102
+ if (adapterValue !== undefined) {
103
+ await this.cacheValue(cacheKey, adapterValue, mergedOptions);
104
+ return adapterValue;
105
+ }
106
+ }
107
+ mergeOptions(options) {
108
+ return {
109
+ ttlMs: this.options.ttlMs,
110
+ expirationThresholdMs: this.options.expirationThresholdMs,
111
+ ...options
112
+ };
113
+ }
114
+ tryGetFromMemory(cacheKey) {
115
+ const cached = this.inMemoryCache.get(cacheKey);
116
+ if (cached && !this.isExpired(cached.metadata)) {
117
+ return cached.data;
118
+ }
119
+ return;
120
+ }
121
+ async tryGetFromAdapter(cacheKey) {
122
+ const cached = await this.getFromAdapter(cacheKey);
123
+ if (cached && !this.isExpired(cached.metadata)) {
124
+ this.inMemoryCache.set(cacheKey, cached);
125
+ return cached.data;
126
+ }
127
+ return;
128
+ }
129
+ async tryGetFromValueLoader(valueLoader) {
130
+ if (valueLoader === undefined) {
131
+ return;
132
+ }
133
+ if (isCallable(valueLoader)) {
134
+ return await valueLoader();
135
+ }
136
+ if (import_types.isPromise(valueLoader)) {
137
+ return await valueLoader;
138
+ }
139
+ return valueLoader;
140
+ }
141
+ async cacheValue(cacheKey, value, options) {
142
+ const cacheData = this.createCacheEntry(value, options);
143
+ await this.saveToAdapter(cacheKey, cacheData);
144
+ this.inMemoryCache.set(cacheKey, cacheData);
145
+ }
146
+ createCacheEntry(value, options) {
147
+ const now = Date.now();
148
+ let expiresAt;
149
+ if (options.ttlMs < 0) {
150
+ expiresAt = -1;
151
+ } else {
152
+ expiresAt = now + options.ttlMs - options.expirationThresholdMs;
153
+ }
154
+ return {
155
+ data: value,
156
+ metadata: {
157
+ createdAt: now,
158
+ ttlMs: options.ttlMs,
159
+ expirationThresholdMs: options.expirationThresholdMs,
160
+ expiresAt
161
+ }
162
+ };
163
+ }
164
+ isExpired(metadata) {
165
+ if (!metadata) {
166
+ return true;
167
+ }
168
+ if (metadata.expiresAt < 0) {
169
+ return false;
170
+ }
171
+ const expirationTime = metadata.expiresAt ?? (metadata.createdAt && metadata.ttlMs ? metadata.createdAt + metadata.ttlMs : undefined);
172
+ if (expirationTime === undefined) {
173
+ return true;
174
+ }
175
+ return Date.now() >= expirationTime;
176
+ }
177
+ }
178
+ // src/cache/constants.ts
179
+ var CACHE_TTL_NEVER_EXPIRE = -1;
180
+
181
+ //# debugId=3EEB577CB85A3AEE64756E2164756E21
182
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NhY2hlL2NhY2hlU2VydmljZS50cyIsICIuLi8uLi9zcmMvdXRpbHMvaXNDYWxsYWJsZS50cyIsICIuLi8uLi9zcmMvY2FjaGUvY29uc3RhbnRzLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWwogICAgImltcG9ydCB7IGlzUHJvbWlzZSB9IGZyb20gXCJub2RlOnV0aWwvdHlwZXNcIjtcbmltcG9ydCB7IGlzQ2FsbGFibGUgfSBmcm9tIFwiLi4vdXRpbHMvaXNDYWxsYWJsZS50c1wiO1xuaW1wb3J0IHR5cGUgeyBDYWNoZU1ldGFkYXRhT3B0aW9ucywgQ2FjaGVPcHRpb25zLCBDYWNoZVdpdGhNZXRhZGF0YSwgVmFsdWVMb2FkZXIgfSBmcm9tIFwiLi9pbnRlcm5hbC90eXBlcy50c1wiO1xuaW1wb3J0IHR5cGUgeyBDYWNoZU1ldGFkYXRhLCBJQ2FjaGVBZGFwdGVyIH0gZnJvbSBcIi4vdHlwZXMudHNcIjtcblxuY29uc3QgZGVmYXVsdENhY2hlT3B0aW9uczogQ2FjaGVPcHRpb25zID0ge1xuICBleHBpcmF0aW9uVGhyZXNob2xkTXM6IDAsXG4gIHR0bE1zOiA2MCAqIDYwICogMTAwMCxcbn07XG5cbmV4cG9ydCBjbGFzcyBDYWNoZTxUQWRhcHRlciBleHRlbmRzIElDYWNoZUFkYXB0ZXIgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ+IHtcbiAgcHJpdmF0ZSBpbk1lbW9yeUNhY2hlOiBNYXA8c3RyaW5nLCBDYWNoZVdpdGhNZXRhZGF0YT4gPSBuZXcgTWFwKCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgb3B0aW9uczogQ2FjaGVPcHRpb25zO1xuICBwcml2YXRlIHJlYWRvbmx5IGFkYXB0ZXI/OiBUQWRhcHRlcjtcblxuICBjb25zdHJ1Y3RvcihkZWZhdWx0T3B0aW9ucz86IFBhcnRpYWw8Q2FjaGVPcHRpb25zPik7XG4gIGNvbnN0cnVjdG9yKGFkYXB0ZXI/OiBUQWRhcHRlciwgZGVmYXVsdE9wdGlvbnM/OiBQYXJ0aWFsPENhY2hlT3B0aW9ucz4pO1xuICBjb25zdHJ1Y3RvcihhZGFwdGVyPzogVEFkYXB0ZXIgfCBQYXJ0aWFsPENhY2hlT3B0aW9ucz4sIGRlZmF1bHRPcHRpb25zPzogUGFydGlhbDxDYWNoZU9wdGlvbnM+KSB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IGFkYXB0ZXIgJiYgIShcImdldFZhbHVlXCIgaW4gYWRhcHRlcikgPyAoYWRhcHRlciBhcyBQYXJ0aWFsPENhY2hlT3B0aW9ucz4pIDogZGVmYXVsdE9wdGlvbnM7XG4gICAgaWYgKGFkYXB0ZXIgJiYgXCJnZXRWYWx1ZVwiIGluIGFkYXB0ZXIgJiYgXCJzZXRWYWx1ZVwiIGluIGFkYXB0ZXIpIHtcbiAgICAgIHRoaXMuYWRhcHRlciA9IGFkYXB0ZXIgYXMgVEFkYXB0ZXI7XG4gICAgfVxuXG4gICAgdGhpcy5vcHRpb25zID0ge1xuICAgICAgLi4uZGVmYXVsdENhY2hlT3B0aW9ucyxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgZ2V0RnJvbUFkYXB0ZXI8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFByb21pc2U8VCB8IHVuZGVmaW5lZD4ge1xuICAgIGlmICghdGhpcy5hZGFwdGVyKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmFkYXB0ZXIuZ2V0VmFsdWUoY2FjaGVLZXkpO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBzYXZlVG9BZGFwdGVyPFQ+KGNhY2hlS2V5OiBzdHJpbmcsIHZhbHVlOiBUKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgaWYgKCF0aGlzLmFkYXB0ZXIpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5hZGFwdGVyLnNldFZhbHVlPFQ+KGNhY2hlS2V5LCB2YWx1ZSk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0PFQ+KFxuICAgIGNhY2hlS2V5OiBzdHJpbmcsXG4gICAgdmFsdWVMb2FkZXI/OiBWYWx1ZUxvYWRlcjxUPixcbiAgICBvcHRpb25zOiBQYXJ0aWFsPENhY2hlTWV0YWRhdGFPcHRpb25zPiA9IHt9LFxuICApOiBQcm9taXNlPFQgfCB1bmRlZmluZWQ+IHtcbiAgICBjb25zdCBtZXJnZWRPcHRpb25zID0gdGhpcy5tZXJnZU9wdGlvbnMob3B0aW9ucyk7XG5cbiAgICAvLyBUcnkgaW4tbWVtb3J5IGNhY2hlIGZpcnN0XG4gICAgY29uc3QgY2FjaGVkVmFsdWUgPSB0aGlzLnRyeUdldEZyb21NZW1vcnk8VD4oY2FjaGVLZXkpO1xuICAgIGlmIChjYWNoZWRWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gY2FjaGVkVmFsdWU7XG4gICAgfVxuXG4gICAgLy8gTG9hZCBmcmVzaCB2YWx1ZSBmcm9tIGxvYWRlciBmdW5jdGlvbiBmaXJzdFxuICAgIGNvbnN0IGZyZXNoVmFsdWUgPSBhd2FpdCB0aGlzLnRyeUdldEZyb21WYWx1ZUxvYWRlcih2YWx1ZUxvYWRlcik7XG4gICAgaWYgKGZyZXNoVmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgICAgYXdhaXQgdGhpcy5jYWNoZVZhbHVlKGNhY2hlS2V5LCBmcmVzaFZhbHVlLCBtZXJnZWRPcHRpb25zKTtcblxuICAgICAgcmV0dXJuIGZyZXNoVmFsdWU7XG4gICAgfVxuXG4gICAgLy8gVHJ5IGFkYXB0ZXIgY2FjaGUgc2Vjb25kXG4gICAgY29uc3QgYWRhcHRlclZhbHVlID0gYXdhaXQgdGhpcy50cnlHZXRGcm9tQWRhcHRlcjxUPihjYWNoZUtleSk7XG4gICAgaWYgKGFkYXB0ZXJWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBhd2FpdCB0aGlzLmNhY2hlVmFsdWUoY2FjaGVLZXksIGFkYXB0ZXJWYWx1ZSwgbWVyZ2VkT3B0aW9ucyk7XG5cbiAgICAgIHJldHVybiBhZGFwdGVyVmFsdWU7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBtZXJnZU9wdGlvbnMob3B0aW9uczogUGFydGlhbDxDYWNoZU1ldGFkYXRhT3B0aW9ucz4pOiBDYWNoZU1ldGFkYXRhT3B0aW9ucyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR0bE1zOiB0aGlzLm9wdGlvbnMudHRsTXMsXG4gICAgICBleHBpcmF0aW9uVGhyZXNob2xkTXM6IHRoaXMub3B0aW9ucy5leHBpcmF0aW9uVGhyZXNob2xkTXMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIHRyeUdldEZyb21NZW1vcnk8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFQgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IGNhY2hlZCA9IHRoaXMuaW5NZW1vcnlDYWNoZS5nZXQoY2FjaGVLZXkpO1xuXG4gICAgaWYgKGNhY2hlZCAmJiAhdGhpcy5pc0V4cGlyZWQoY2FjaGVkLm1ldGFkYXRhKSkge1xuICAgICAgcmV0dXJuIGNhY2hlZC5kYXRhIGFzIFQ7XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgdHJ5R2V0RnJvbUFkYXB0ZXI8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFByb21pc2U8VCB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IGNhY2hlZCA9IGF3YWl0IHRoaXMuZ2V0RnJvbUFkYXB0ZXI8Q2FjaGVXaXRoTWV0YWRhdGE8VD4+KGNhY2hlS2V5KTtcblxuICAgIGlmIChjYWNoZWQgJiYgIXRoaXMuaXNFeHBpcmVkKGNhY2hlZC5tZXRhZGF0YSkpIHtcbiAgICAgIHRoaXMuaW5NZW1vcnlDYWNoZS5zZXQoY2FjaGVLZXksIGNhY2hlZCk7XG4gICAgICByZXR1cm4gY2FjaGVkLmRhdGE7XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgdHJ5R2V0RnJvbVZhbHVlTG9hZGVyPFQ+KHZhbHVlTG9hZGVyPzogVmFsdWVMb2FkZXI8VD4pOiBQcm9taXNlPFQgfCB1bmRlZmluZWQ+IHtcbiAgICBpZiAodmFsdWVMb2FkZXIgPT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBpZiAoaXNDYWxsYWJsZSh2YWx1ZUxvYWRlcikpIHtcbiAgICAgIHJldHVybiBhd2FpdCB2YWx1ZUxvYWRlcigpO1xuICAgIH1cblxuICAgIGlmIChpc1Byb21pc2UodmFsdWVMb2FkZXIpKSB7XG4gICAgICByZXR1cm4gYXdhaXQgdmFsdWVMb2FkZXI7XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlTG9hZGVyO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBjYWNoZVZhbHVlPFQ+KGNhY2hlS2V5OiBzdHJpbmcsIHZhbHVlOiBULCBvcHRpb25zOiBDYWNoZU1ldGFkYXRhT3B0aW9ucyk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGNhY2hlRGF0YSA9IHRoaXMuY3JlYXRlQ2FjaGVFbnRyeSh2YWx1ZSwgb3B0aW9ucyk7XG5cbiAgICBhd2FpdCB0aGlzLnNhdmVUb0FkYXB0ZXIoY2FjaGVLZXksIGNhY2hlRGF0YSk7XG4gICAgdGhpcy5pbk1lbW9yeUNhY2hlLnNldChjYWNoZUtleSwgY2FjaGVEYXRhKTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlQ2FjaGVFbnRyeTxUPih2YWx1ZTogVCwgb3B0aW9uczogQ2FjaGVNZXRhZGF0YU9wdGlvbnMpOiBDYWNoZVdpdGhNZXRhZGF0YTxUPiB7XG4gICAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgICBsZXQgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgaWYgKG9wdGlvbnMudHRsTXMgPCAwKSB7XG4gICAgICBleHBpcmVzQXQgPSAtMTtcbiAgICB9IGVsc2Uge1xuICAgICAgZXhwaXJlc0F0ID0gbm93ICsgb3B0aW9ucy50dGxNcyAtIG9wdGlvbnMuZXhwaXJhdGlvblRocmVzaG9sZE1zO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBkYXRhOiB2YWx1ZSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIGNyZWF0ZWRBdDogbm93LFxuICAgICAgICB0dGxNczogb3B0aW9ucy50dGxNcyxcbiAgICAgICAgZXhwaXJhdGlvblRocmVzaG9sZE1zOiBvcHRpb25zLmV4cGlyYXRpb25UaHJlc2hvbGRNcyxcbiAgICAgICAgZXhwaXJlc0F0LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcHJpdmF0ZSBpc0V4cGlyZWQobWV0YWRhdGE/OiBDYWNoZU1ldGFkYXRhKTogYm9vbGVhbiB7XG4gICAgaWYgKCFtZXRhZGF0YSkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgaWYgKG1ldGFkYXRhLmV4cGlyZXNBdCA8IDApIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBjb25zdCBleHBpcmF0aW9uVGltZSA9XG4gICAgICBtZXRhZGF0YS5leHBpcmVzQXQgPz8gKG1ldGFkYXRhLmNyZWF0ZWRBdCAmJiBtZXRhZGF0YS50dGxNcyA/IG1ldGFkYXRhLmNyZWF0ZWRBdCArIG1ldGFkYXRhLnR0bE1zIDogdW5kZWZpbmVkKTtcblxuICAgIGlmIChleHBpcmF0aW9uVGltZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICByZXR1cm4gRGF0ZS5ub3coKSA+PSBleHBpcmF0aW9uVGltZTtcbiAgfVxufVxuIiwKICAgICJleHBvcnQgZnVuY3Rpb24gaXNDYWxsYWJsZSh2YWx1ZTogYW55KTogdmFsdWUgaXMgQ2FsbGFibGVGdW5jdGlvbiB7XG4gIHJldHVybiB0eXBlb2YgdmFsdWUgPT09IFwiZnVuY3Rpb25cIjtcbn1cbiIsCiAgICAiZXhwb3J0IGNvbnN0IENBQ0hFX1RUTF9ORVZFUl9FWFBJUkUgPSAtMTtcbiIKICBdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQTBCLElBQTFCOzs7QUNBTyxTQUFTLFVBQVUsQ0FBQyxPQUF1QztBQUFBLEVBQ2hFLE9BQU8sT0FBTyxVQUFVO0FBQUE7OztBREkxQixJQUFNLHNCQUFvQztBQUFBLEVBQ3hDLHVC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QUFpQixPQUFPLE9BQU87QUFBQSxJQUV0RCxNQUFNLEtBQUssY0FBYyxVQUFVLFNBQVM7QUFBQSxJQUM1QyxLQUFLLGNBQWMsSUFBSSxVQUFVLFNBQVM7QUFBQTtBQUFBLEVBR3BDLGdCQUFtQixDQUFDLE9BQVUsU0FBcUQ7QUFBQSxJQUN6RixNQUFNLE1BQU0sS0FBSyxJQUFJO0FBQUEsSUFDckIsSUFBSTtBQUFBLElBQ0osSUFBSSxRQUFRLFFBQVEsR0FBRztBQUFBLE1BQ3JCLFlBQVk7QUFBQSxJQUNkLEVBQU87QUFBQSxNQUNMLFlBQVksTUFBTSxRQUFRLFFBQVEsUUFBUTtBQUFBO0FBQUEsSUFHNUMsT0FBTztBQUFBLE1BQ0wsTUFBTTtBQUFBLE1BQ04sVUFBVTtBQUFBLFFBQ1IsV0FBVztBQUFBLFFBQ1gsT0FBTyxRQUFRO0FBQUEsUUFDZix1QkFBdUIsUUFBUTtBQUFBLFFBQy9CO0FBQUEsTUFDRjtBQUFBLElBQ0Y7QUFBQTtBQUFBLEVBR00sU0FBUyxDQUFDLFVBQW1DO0FBQUEsSUFDbkQsSUFBSSxDQUFDLFVBQVU7QUFBQSxNQUNiLE9BQU87QUFBQSxJQUNUO0FBQUEsSUFFQSxJQUFJLFNBQVMsWUFBWSxHQUFHO0FBQUEsTUFDMUIsT0FBTztBQUFBLElBQ1Q7QUFBQSxJQUVBLE1BQU0saUJBQ0osU0FBUyxjQUFjLFNBQVMsYUFBYSxTQUFTLFFBQVEsU0FBUyxZQUFZLFNBQVMsUUFBUTtBQUFBLElBRXRHLElBQUksbUJBQW1CLFdBQVc7QUFBQSxNQUNoQyxPQUFPO0FBQUEsSUFDVDtBQUFBLElBRUEsT0FBTyxLQUFLLElBQUksS0FBSztBQUFBO0FBRXpCOztBRXJLTyxJQUFNLHlCQUF5QjsiLAogICJkZWJ1Z0lkIjogIjNFRUI1NzdDQjg1QTNBRUU2NDc1NkUyMTY0NzU2RTIxIiwKICAibmFtZXMiOiBbXQp9
@@ -0,0 +1,115 @@
1
+ var __create = Object.create;
2
+ var __getProtoOf = Object.getPrototypeOf;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __toESM = (mod, isNodeMode, target) => {
8
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
9
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
10
+ for (let key of __getOwnPropNames(mod))
11
+ if (!__hasOwnProp.call(to, key))
12
+ __defProp(to, key, {
13
+ get: () => mod[key],
14
+ enumerable: true
15
+ });
16
+ return to;
17
+ };
18
+ var __moduleCache = /* @__PURE__ */ new WeakMap;
19
+ var __toCommonJS = (from) => {
20
+ var entry = __moduleCache.get(from), desc;
21
+ if (entry)
22
+ return entry;
23
+ entry = __defProp({}, "__esModule", { value: true });
24
+ if (from && typeof from === "object" || typeof from === "function")
25
+ __getOwnPropNames(from).map((key) => !__hasOwnProp.call(entry, key) && __defProp(entry, key, {
26
+ get: () => from[key],
27
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
28
+ }));
29
+ __moduleCache.set(from, entry);
30
+ return entry;
31
+ };
32
+ var __export = (target, all) => {
33
+ for (var name in all)
34
+ __defProp(target, name, {
35
+ get: all[name],
36
+ enumerable: true,
37
+ configurable: true,
38
+ set: (newValue) => all[name] = () => newValue
39
+ });
40
+ };
41
+
42
+ // src/colors/index.ts
43
+ var exports_colors = {};
44
+ __export(exports_colors, {
45
+ default: () => colors_default
46
+ });
47
+ module.exports = __toCommonJS(exports_colors);
48
+ var __reset = "\x1B[0m";
49
+ var COLORS_MAP;
50
+ ((COLORS_MAP2) => {
51
+ COLORS_MAP2["black"] = "\x1B[0;30m";
52
+ COLORS_MAP2["red"] = "\x1B[0;31m";
53
+ COLORS_MAP2["green"] = "\x1B[0;32m";
54
+ COLORS_MAP2["yellow"] = "\x1B[0;33m";
55
+ COLORS_MAP2["blue"] = "\x1B[0;34m";
56
+ COLORS_MAP2["purple"] = "\x1B[0;35m";
57
+ COLORS_MAP2["magenta"] = "\x1B[0;35m";
58
+ COLORS_MAP2["cyan"] = "\x1B[0;36m";
59
+ COLORS_MAP2["white"] = "\x1B[0;37m";
60
+ COLORS_MAP2["blackBright"] = "\x1B[0;90m";
61
+ COLORS_MAP2["redBright"] = "\x1B[0;91m";
62
+ COLORS_MAP2["greenBright"] = "\x1B[0;92m";
63
+ COLORS_MAP2["yellowBright"] = "\x1B[0;93m";
64
+ COLORS_MAP2["blueBright"] = "\x1B[0;94m";
65
+ COLORS_MAP2["purpleBright"] = "\x1B[0;95m";
66
+ COLORS_MAP2["magentaBright"] = "\x1B[0;95m";
67
+ COLORS_MAP2["cyanBright"] = "\x1B[0;96m";
68
+ COLORS_MAP2["whiteBright"] = "\x1B[0;97m";
69
+ COLORS_MAP2["redBold"] = "\x1B[1;31m";
70
+ COLORS_MAP2["greenBold"] = "\x1B[1;32m";
71
+ COLORS_MAP2["yellowBold"] = "\x1B[1;33m";
72
+ COLORS_MAP2["blueBold"] = "\x1B[1;34m";
73
+ COLORS_MAP2["purpleBold"] = "\x1B[1;35m";
74
+ COLORS_MAP2["magentaBold"] = "\x1B[1;35m";
75
+ COLORS_MAP2["cyanBold"] = "\x1B[1;36m";
76
+ COLORS_MAP2["whiteBold"] = "\x1B[1;37m";
77
+ COLORS_MAP2["blackUnderline"] = "\x1B[4;30m";
78
+ COLORS_MAP2["redUnderline"] = "\x1B[4;31m";
79
+ COLORS_MAP2["greenUnderline"] = "\x1B[4;32m";
80
+ COLORS_MAP2["yellowUnderline"] = "\x1B[4;33m";
81
+ COLORS_MAP2["blueUnderline"] = "\x1B[4;34m";
82
+ COLORS_MAP2["purpleUnderline"] = "\x1B[4;35m";
83
+ COLORS_MAP2["magentaUnderline"] = "\x1B[4;35m";
84
+ COLORS_MAP2["cyanUnderline"] = "\x1B[4;36m";
85
+ COLORS_MAP2["whiteUnderline"] = "\x1B[4;37m";
86
+ COLORS_MAP2["bgBlack"] = "\x1B[40m";
87
+ COLORS_MAP2["bgRed"] = "\x1B[41m";
88
+ COLORS_MAP2["bgGreen"] = "\x1B[42m";
89
+ COLORS_MAP2["bgYellow"] = "\x1B[43m";
90
+ COLORS_MAP2["bgBlue"] = "\x1B[44m";
91
+ COLORS_MAP2["bgPurple"] = "\x1B[45m";
92
+ COLORS_MAP2["bgMagenta"] = "\x1B[45m";
93
+ COLORS_MAP2["bgCyan"] = "\x1B[46m";
94
+ COLORS_MAP2["bgWhite"] = "\x1B[47m";
95
+ COLORS_MAP2["bgBlackBright"] = "\x1B[100m";
96
+ COLORS_MAP2["bgRedBright"] = "\x1B[101m";
97
+ COLORS_MAP2["bgGreenBright"] = "\x1B[102m";
98
+ COLORS_MAP2["bgYellowBright"] = "\x1B[103m";
99
+ COLORS_MAP2["bgBlueBright"] = "\x1B[104m";
100
+ COLORS_MAP2["bgPurpleBright"] = "\x1B[105m";
101
+ COLORS_MAP2["bgMagentaBright"] = "\x1B[105m";
102
+ COLORS_MAP2["bgCyanBright"] = "\x1B[106m";
103
+ COLORS_MAP2["bgWhiteBright"] = "\x1B[107m";
104
+ })(COLORS_MAP ||= {});
105
+ function wrap(color) {
106
+ return (data) => `${color}${data}${__reset}`;
107
+ }
108
+ var colors = {};
109
+ for (const [colorName, colorValue] of Object.entries(COLORS_MAP)) {
110
+ colors[colorName] = wrap(colorValue);
111
+ }
112
+ var colors_default = colors;
113
+
114
+ //# debugId=34FC3A7A08D5655564756E2164756E21
115
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NvbG9ycy9pbmRleC50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsKICAgICIvLyBodHRwczovL2dpc3QuZ2l0aHViLmNvbS9KQmxvbmQvMmZlYTQzYTMwNDliMzgyODdlNWU5Y2VmYzg3YjIxMjRcblxuY29uc3QgX19yZXNldCA9IFwiXFx4MWJbMG1cIjtcblxuZW51bSBDT0xPUlNfTUFQIHtcbiAgYmxhY2sgPSBcIlxceDFiWzA7MzBtXCIsXG4gIHJlZCA9IFwiXFx4MWJbMDszMW1cIixcbiAgZ3JlZW4gPSBcIlxceDFiWzA7MzJtXCIsXG4gIHllbGxvdyA9IFwiXFx4MWJbMDszM21cIixcbiAgYmx1ZSA9IFwiXFx4MWJbMDszNG1cIixcbiAgcHVycGxlID0gXCJcXHgxYlswOzM1bVwiLFxuICBtYWdlbnRhID0gXCJcXHgxYlswOzM1bVwiLFxuICBjeWFuID0gXCJcXHgxYlswOzM2bVwiLFxuICB3aGl0ZSA9IFwiXFx4MWJbMDszN21cIixcblxuICBibGFja0JyaWdodCA9IFwiXFx4MWJbMDs5MG1cIixcbiAgcmVkQnJpZ2h0ID0gXCJcXHgxYlswOzkxbVwiLFxuICBncmVlbkJyaWdodCA9IFwiXFx4MWJbMDs5Mm1cIixcbiAgeWVsbG93QnJpZ2h0ID0gXCJcXHgxYlswOzkzbVwiLFxuICBibHVlQnJpZ2h0ID0gXCJcXHgxYlswOzk0bVwiLFxuICBwdXJwbGVCcmlnaHQgPSBcIlxceDFiWzA7OTVtXCIsXG4gIG1hZ2VudGFCcmlnaHQgPSBcIlxceDFiWzA7OTVtXCIsXG4gIGN5YW5CcmlnaHQgPSBcIlxceDFiWzA7OTZtXCIsXG4gIHdoaXRlQnJpZ2h0ID0gXCJcXHgxYlswOzk3bVwiLFxuXG4gIHJlZEJvbGQgPSBcIlxceDFiWzE7MzFtXCIsXG4gIGdyZWVuQm9sZCA9IFwiXFx4MWJbMTszMm1cIixcbiAgeWVsbG93Qm9sZCA9IFwiXFx4MWJbMTszM21cIixcbiAgYmx1ZUJvbGQgPSBcIlxceDFiWzE7MzRtXCIsXG4gIHB1cnBsZUJvbGQgPSBcIlxceDFiWzE7MzVtXCIsXG4gIG1hZ2VudGFCb2xkID0gXCJcXHgxYlsxOzM1bVwiLFxuICBjeWFuQm9sZCA9IFwiXFx4MWJbMTszNm1cIixcbiAgd2hpdGVCb2xkID0gXCJcXHgxYlsxOzM3bVwiLFxuXG4gIGJsYWNrVW5kZXJsaW5lID0gXCJcXHgxYls0OzMwbVwiLFxuICByZWRVbmRlcmxpbmUgPSBcIlxceDFiWzQ7MzFtXCIsXG4gIGdyZWVuVW5kZXJsaW5lID0gXCJcXHgxYls0OzMybVwiLFxuICB5ZWxsb3dVbmRlcmxpbmUgPSBcIlxceDFiWzQ7MzNtXCIsXG4gIGJsdWVVbmRlcmxpbmUgPSBcIlxceDFiWzQ7MzRtXCIsXG4gIHB1cnBsZVVuZGVybGluZSA9IFwiXFx4MWJbNDszNW1cIixcbiAgbWFnZW50YVVuZGVybGluZSA9IFwiXFx4MWJbNDszNW1cIixcbiAgY3lhblVuZGVybGluZSA9IFwiXFx4MWJbNDszNm1cIixcbiAgd2hpdGVVbmRlcmxpbmUgPSBcIlxceDFiWzQ7MzdtXCIsXG5cbiAgYmdCbGFjayA9IFwiXFx4MWJbNDBtXCIsXG4gIGJnUmVkID0gXCJcXHgxYls0MW1cIixcbiAgYmdHcmVlbiA9IFwiXFx4MWJbNDJtXCIsXG4gIGJnWWVsbG93ID0gXCJcXHgxYls0M21cIixcbiAgYmdCbHVlID0gXCJcXHgxYls0NG1cIixcbiAgYmdQdXJwbGUgPSBcIlxceDFiWzQ1bVwiLFxuICBiZ01hZ2VudGEgPSBcIlxceDFiWzQ1bVwiLFxuICBiZ0N5YW4gPSBcIlxceDFiWzQ2bVwiLFxuICBiZ1doaXRlID0gXCJcXHgxYls0N21cIixcblxuICBiZ0JsYWNrQnJpZ2h0ID0gXCJcXHgxYlsxMDBtXCIsXG4gIGJnUmVkQnJpZ2h0ID0gXCJcXHgxYlsxMDFtXCIsXG4gIGJnR3JlZW5CcmlnaHQgPSBcIlxceDFiWzEwMm1cIixcbiAgYmdZZWxsb3dCcmlnaHQgPSBcIlxceDFiWzEwM21cIixcbiAgYmdCbHVlQnJpZ2h0ID0gXCJcXHgxYlsxMDRtXCIsXG4gIGJnUHVycGxlQnJpZ2h0ID0gXCJcXHgxYlsxMDVtXCIsXG4gIGJnTWFnZW50YUJyaWdodCA9IFwiXFx4MWJbMTA1bVwiLFxuICBiZ0N5YW5CcmlnaHQgPSBcIlxceDFiWzEwNm1cIixcbiAgYmdXaGl0ZUJyaWdodCA9IFwiXFx4MWJbMTA3bVwiLFxufVxuXG5mdW5jdGlvbiB3cmFwKGNvbG9yOiBzdHJpbmcpIHtcbiAgcmV0dXJuIChkYXRhOiB1bmtub3duKSA9PiBgJHtjb2xvcn0ke2RhdGF9JHtfX3Jlc2V0fWA7XG59XG5cbmNvbnN0IGNvbG9yczogUmVjb3JkPGtleW9mIHR5cGVvZiBDT0xPUlNfTUFQLCBSZXR1cm5UeXBlPHR5cGVvZiB3cmFwPj4gPSB7fSBhcyBhbnk7XG5cbmZvciAoY29uc3QgW2NvbG9yTmFtZSwgY29sb3JWYWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoQ09MT1JTX01BUCkpIHtcbiAgY29sb3JzW2NvbG9yTmFtZSBhcyBrZXlvZiB0eXBlb2YgQ09MT1JTX01BUF0gPSB3cmFwKGNvbG9yVmFsdWUpO1xufVxuXG5leHBvcnQgZGVmYXVsdCBjb2xvcnM7XG4iCiAgXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLElBQU0sVUFBVTtBQUVoQixJQUFLO0FBQUEsQ0FBTCxDQUFLLGdCQUFMO0FBQUEsRUFDRSx1QkFBUTtBQUFBLEVBQ1IscUJBQU07QUFBQSxFQUNOLHVCQUFRO0FBQUEsRUFDUix3QkFBUztBQUFBLEVBQ1Qsc0JBQU87QUFBQSxFQUNQLHdCQUFTO0FBQUEsRUFDVCx5QkFBVTtBQUFBLEVBQ1Ysc0JBQU87QUFBQSxFQUNQLHVCQUFRO0FBQUEsRUFFUiw2QkFBYztBQUFBLEVBQ2QsMkJBQVk7QUFBQSxFQUNaLDZCQUFjO0FBQUEsRUFDZCw4QkFBZTtBQUFBLEVBQ2YsNEJBQWE7QUFBQSxFQUNiLDhCQUFlO0FBQUEsRUFDZiwrQkFBZ0I7QUFBQSxFQUNoQiw0QkFBYTtBQUFBLEVBQ2IsNkJBQWM7QUFBQSxFQUVkLHlCQUFVO0FBQUEsRUFDViwyQkFBWTtBQUFBLEVBQ1osNEJBQWE7QUFBQSxFQUNiLDBCQUFXO0FBQUEsRUFDWCw0QkFBYTtBQUFBLEVBQ2IsNkJBQWM7QUFBQSxFQUNkLDBCQUFXO0FBQUEsRUFDWCwyQkFBWTtBQUFBLEVBRVosZ0NBQWlCO0FBQUEsRUFDakIsOEJBQWU7QUFBQSxFQUNmLGdDQUFpQjtBQUFBLEVBQ2pCLGlDQUFrQjtBQUFBLEVBQ2xCLCtCQUFnQjtBQUFBLEVBQ2hCLGlDQUFrQjtBQUFBLEVBQ2xCLGtDQUFtQjtBQUFBLEVBQ25CLCtCQUFnQjtBQUFBLEVBQ2hCLGdDQUFpQjtBQUFBLEVBRWpCLHlCQUFVO0FBQUEsRUFDVix1QkFBUTtBQUFBLEVBQ1IseUJBQVU7QUFBQSxFQUNWLDBCQUFXO0FBQUEsRUFDWCx3QkFBUztBQUFBLEVBQ1QsMEJBQVc7QUFBQSxFQUNYLDJCQUFZO0FBQUEsRUFDWix3QkFBUztBQUFBLEVBQ1QseUJBQVU7QUFBQSxFQUVWLCtCQUFnQjtBQUFBLEVBQ2hCLDZCQUFjO0FBQUEsRUFDZCwrQkFBZ0I7QUFBQSxFQUNoQixnQ0FBaUI7QUFBQSxFQUNqQiw4QkFBZTtBQUFBLEVBQ2YsZ0NBQWlCO0FBQUEsRUFDakIsaUNBQWtCO0FBQUEsRUFDbEIsOEJBQWU7QUFBQSxFQUNmLCtCQUFnQjtBQUFBLEdBMURiO0FBNkRMLFNBQVMsSUFBSSxDQUFDLE9BQWU7QUFBQSxFQUMzQixPQUFPLENBQUMsU0FBa0IsR0FBRyxRQUFRLE9BQU87QUFBQTtBQUc5QyxJQUFNLFNBQW1FLENBQUM7QUFFMUUsWUFBWSxXQUFXLGVBQWUsT0FBTyxRQUFRLFVBQVUsR0FBRztBQUFBLEVBQ2hFLE9BQU8sYUFBd0MsS0FBSyxVQUFVO0FBQ2hFO0FBRUEsSUFBZTsiLAogICJkZWJ1Z0lkIjogIjM0RkMzQTdBMDhENTY1NTU2NDc1NkUyMTY0NzU2RTIxIiwKICAibmFtZXMiOiBbXQp9
@@ -0,0 +1,270 @@
1
+ var __create = Object.create;
2
+ var __getProtoOf = Object.getPrototypeOf;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __toESM = (mod, isNodeMode, target) => {
8
+ target = mod != null ? __create(__getProtoOf(mod)) : {};
9
+ const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target;
10
+ for (let key of __getOwnPropNames(mod))
11
+ if (!__hasOwnProp.call(to, key))
12
+ __defProp(to, key, {
13
+ get: () => mod[key],
14
+ enumerable: true
15
+ });
16
+ return to;
17
+ };
18
+ var __moduleCache = /* @__PURE__ */ new WeakMap;
19
+ var __toCommonJS = (from) => {
20
+ var entry = __moduleCache.get(from), desc;
21
+ if (entry)
22
+ return entry;
23
+ entry = __defProp({}, "__esModule", { value: true });
24
+ if (from && typeof from === "object" || typeof from === "function")
25
+ __getOwnPropNames(from).map((key) => !__hasOwnProp.call(entry, key) && __defProp(entry, key, {
26
+ get: () => from[key],
27
+ enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
28
+ }));
29
+ __moduleCache.set(from, entry);
30
+ return entry;
31
+ };
32
+ var __export = (target, all) => {
33
+ for (var name in all)
34
+ __defProp(target, name, {
35
+ get: all[name],
36
+ enumerable: true,
37
+ configurable: true,
38
+ set: (newValue) => all[name] = () => newValue
39
+ });
40
+ };
41
+
42
+ // src/cache/index.ts
43
+ var exports_cache = {};
44
+ __export(exports_cache, {
45
+ Cache: () => Cache,
46
+ CACHE_TTL_NEVER_EXPIRE: () => CACHE_TTL_NEVER_EXPIRE
47
+ });
48
+ module.exports = __toCommonJS(exports_cache);
49
+
50
+ // src/cache/cacheService.ts
51
+ var import_types = require("node:util/types");
52
+
53
+ // src/utils/isCallable.ts
54
+ function isCallable(value) {
55
+ return typeof value === "function";
56
+ }
57
+
58
+ // src/cache/cacheService.ts
59
+ var defaultCacheOptions = {
60
+ expirationThresholdMs: 0,
61
+ ttlMs: 60 * 60 * 1000
62
+ };
63
+
64
+ class Cache {
65
+ inMemoryCache = new Map;
66
+ options;
67
+ adapter;
68
+ constructor(adapter, defaultOptions) {
69
+ const options = adapter && !("getValue" in adapter) ? adapter : defaultOptions;
70
+ if (adapter && "getValue" in adapter && "setValue" in adapter) {
71
+ this.adapter = adapter;
72
+ }
73
+ this.options = {
74
+ ...defaultCacheOptions,
75
+ ...options
76
+ };
77
+ }
78
+ async getFromAdapter(cacheKey) {
79
+ if (!this.adapter) {
80
+ return;
81
+ }
82
+ return this.adapter.getValue(cacheKey);
83
+ }
84
+ async saveToAdapter(cacheKey, value) {
85
+ if (!this.adapter) {
86
+ return;
87
+ }
88
+ return this.adapter.setValue(cacheKey, value);
89
+ }
90
+ async get(cacheKey, valueLoader, options = {}) {
91
+ const mergedOptions = this.mergeOptions(options);
92
+ const cachedValue = this.tryGetFromMemory(cacheKey);
93
+ if (cachedValue !== undefined) {
94
+ return cachedValue;
95
+ }
96
+ const freshValue = await this.tryGetFromValueLoader(valueLoader);
97
+ if (freshValue !== undefined) {
98
+ await this.cacheValue(cacheKey, freshValue, mergedOptions);
99
+ return freshValue;
100
+ }
101
+ const adapterValue = await this.tryGetFromAdapter(cacheKey);
102
+ if (adapterValue !== undefined) {
103
+ await this.cacheValue(cacheKey, adapterValue, mergedOptions);
104
+ return adapterValue;
105
+ }
106
+ }
107
+ mergeOptions(options) {
108
+ return {
109
+ ttlMs: this.options.ttlMs,
110
+ expirationThresholdMs: this.options.expirationThresholdMs,
111
+ ...options
112
+ };
113
+ }
114
+ tryGetFromMemory(cacheKey) {
115
+ const cached = this.inMemoryCache.get(cacheKey);
116
+ if (cached && !this.isExpired(cached.metadata)) {
117
+ return cached.data;
118
+ }
119
+ return;
120
+ }
121
+ async tryGetFromAdapter(cacheKey) {
122
+ const cached = await this.getFromAdapter(cacheKey);
123
+ if (cached && !this.isExpired(cached.metadata)) {
124
+ this.inMemoryCache.set(cacheKey, cached);
125
+ return cached.data;
126
+ }
127
+ return;
128
+ }
129
+ async tryGetFromValueLoader(valueLoader) {
130
+ if (valueLoader === undefined) {
131
+ return;
132
+ }
133
+ if (isCallable(valueLoader)) {
134
+ return await valueLoader();
135
+ }
136
+ if (import_types.isPromise(valueLoader)) {
137
+ return await valueLoader;
138
+ }
139
+ return valueLoader;
140
+ }
141
+ async cacheValue(cacheKey, value, options) {
142
+ const cacheData = this.createCacheEntry(value, options);
143
+ await this.saveToAdapter(cacheKey, cacheData);
144
+ this.inMemoryCache.set(cacheKey, cacheData);
145
+ }
146
+ createCacheEntry(value, options) {
147
+ const now = Date.now();
148
+ let expiresAt;
149
+ if (options.ttlMs < 0) {
150
+ expiresAt = -1;
151
+ } else {
152
+ expiresAt = now + options.ttlMs - options.expirationThresholdMs;
153
+ }
154
+ return {
155
+ data: value,
156
+ metadata: {
157
+ createdAt: now,
158
+ ttlMs: options.ttlMs,
159
+ expirationThresholdMs: options.expirationThresholdMs,
160
+ expiresAt
161
+ }
162
+ };
163
+ }
164
+ isExpired(metadata) {
165
+ if (!metadata) {
166
+ return true;
167
+ }
168
+ if (metadata.expiresAt < 0) {
169
+ return false;
170
+ }
171
+ const expirationTime = metadata.expiresAt ?? (metadata.createdAt && metadata.ttlMs ? metadata.createdAt + metadata.ttlMs : undefined);
172
+ if (expirationTime === undefined) {
173
+ return true;
174
+ }
175
+ return Date.now() >= expirationTime;
176
+ }
177
+ }
178
+ // src/cache/constants.ts
179
+ var CACHE_TTL_NEVER_EXPIRE = -1;
180
+ // src/index.ts
181
+ var exports_src = {};
182
+ __export(exports_src, {
183
+ tryCatchAsync: () => tryCatchAsync,
184
+ tryCatch: () => tryCatch,
185
+ streamToLines: () => streamToLines,
186
+ sleep: () => sleep,
187
+ randomString: () => randomString,
188
+ jsonParser: () => jsonParser,
189
+ isPrimitive: () => isPrimitive,
190
+ isObject: () => isObject,
191
+ isNullOrUndefined: () => isNullOrUndefined,
192
+ isNullOrEmptyOrUndefined: () => isNullOrEmptyOrUndefined,
193
+ chunksToLines: () => chunksToLines,
194
+ Cache: () => Cache,
195
+ CACHE_TTL_NEVER_EXPIRE: () => CACHE_TTL_NEVER_EXPIRE
196
+ });
197
+ module.exports = __toCommonJS(exports_src);
198
+
199
+ // src/utils/chunksToLines.ts
200
+ async function* streamToLines(chunks) {
201
+ let previous = "";
202
+ for await (const chunk of chunks) {
203
+ previous += chunk;
204
+ let eolIndex;
205
+ while ((eolIndex = previous.indexOf(`
206
+ `)) >= 0) {
207
+ const line = previous.slice(0, eolIndex + 1);
208
+ yield line?.trim() ?? "";
209
+ previous = previous.slice(eolIndex + 1);
210
+ }
211
+ }
212
+ if (previous.length > 0) {
213
+ yield previous;
214
+ }
215
+ }
216
+ var chunksToLines = streamToLines;
217
+ // src/utils/isNullOrUndefined.ts
218
+ var isNullOrUndefined = (value) => value === null || value === undefined;
219
+ function isNullOrEmptyOrUndefined(value) {
220
+ return value === undefined || value === null || value === "" || value.toString().trim() === "";
221
+ }
222
+ // src/utils/isObject.ts
223
+ function isObject(input) {
224
+ return Object.prototype.toString.apply(input) === "[object Object]";
225
+ }
226
+ // src/utils/isPrimitive.ts
227
+ function isPrimitive(value) {
228
+ return typeof value !== "object" && typeof value !== "function" || value === null || value instanceof Date;
229
+ }
230
+ // src/utils/jsonParser.ts
231
+ var import_secure_json_parse = __toESM(require("secure-json-parse"));
232
+ function jsonParser(input) {
233
+ try {
234
+ return { value: import_secure_json_parse.default.parse(input, { protoAction: "remove" }) };
235
+ } catch (err) {
236
+ return { err };
237
+ }
238
+ }
239
+ // src/utils/randomString.ts
240
+ function randomString(length = 6) {
241
+ let result = "";
242
+ const characters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
243
+ const charactersLength = characters.length;
244
+ for (let i = 0;i < length; i++) {
245
+ result += characters.charAt(Math.floor(Math.random() * charactersLength));
246
+ }
247
+ return result;
248
+ }
249
+ // src/utils/sleep.ts
250
+ var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
251
+ // src/neverthrow/tryCatch.ts
252
+ function tryCatch(fn) {
253
+ try {
254
+ const data = fn();
255
+ return [data, undefined];
256
+ } catch (error) {
257
+ return [undefined, error];
258
+ }
259
+ }
260
+ async function tryCatchAsync(promise) {
261
+ try {
262
+ const data = await promise;
263
+ return [data, undefined];
264
+ } catch (error) {
265
+ return [undefined, error];
266
+ }
267
+ }
268
+
269
+ //# debugId=C7BA7063207A301864756E2164756E21
270
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL2NhY2hlL2NhY2hlU2VydmljZS50cyIsICIuLi8uLi9zcmMvdXRpbHMvaXNDYWxsYWJsZS50cyIsICIuLi8uLi9zcmMvY2FjaGUvY29uc3RhbnRzLnRzIiwgIi4uLy4uL3NyYy91dGlscy9jaHVua3NUb0xpbmVzLnRzIiwgIi4uLy4uL3NyYy91dGlscy9pc051bGxPclVuZGVmaW5lZC50cyIsICIuLi8uLi9zcmMvdXRpbHMvaXNPYmplY3QudHMiLCAiLi4vLi4vc3JjL3V0aWxzL2lzUHJpbWl0aXZlLnRzIiwgIi4uLy4uL3NyYy91dGlscy9qc29uUGFyc2VyLnRzIiwgIi4uLy4uL3NyYy91dGlscy9yYW5kb21TdHJpbmcudHMiLCAiLi4vLi4vc3JjL3V0aWxzL3NsZWVwLnRzIiwgIi4uLy4uL3NyYy9uZXZlcnRocm93L3RyeUNhdGNoLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWwogICAgImltcG9ydCB7IGlzUHJvbWlzZSB9IGZyb20gXCJub2RlOnV0aWwvdHlwZXNcIjtcbmltcG9ydCB7IGlzQ2FsbGFibGUgfSBmcm9tIFwiLi4vdXRpbHMvaXNDYWxsYWJsZS50c1wiO1xuaW1wb3J0IHR5cGUgeyBDYWNoZU1ldGFkYXRhT3B0aW9ucywgQ2FjaGVPcHRpb25zLCBDYWNoZVdpdGhNZXRhZGF0YSwgVmFsdWVMb2FkZXIgfSBmcm9tIFwiLi9pbnRlcm5hbC90eXBlcy50c1wiO1xuaW1wb3J0IHR5cGUgeyBDYWNoZU1ldGFkYXRhLCBJQ2FjaGVBZGFwdGVyIH0gZnJvbSBcIi4vdHlwZXMudHNcIjtcblxuY29uc3QgZGVmYXVsdENhY2hlT3B0aW9uczogQ2FjaGVPcHRpb25zID0ge1xuICBleHBpcmF0aW9uVGhyZXNob2xkTXM6IDAsXG4gIHR0bE1zOiA2MCAqIDYwICogMTAwMCxcbn07XG5cbmV4cG9ydCBjbGFzcyBDYWNoZTxUQWRhcHRlciBleHRlbmRzIElDYWNoZUFkYXB0ZXIgfCB1bmRlZmluZWQgPSB1bmRlZmluZWQ+IHtcbiAgcHJpdmF0ZSBpbk1lbW9yeUNhY2hlOiBNYXA8c3RyaW5nLCBDYWNoZVdpdGhNZXRhZGF0YT4gPSBuZXcgTWFwKCk7XG4gIHByaXZhdGUgcmVhZG9ubHkgb3B0aW9uczogQ2FjaGVPcHRpb25zO1xuICBwcml2YXRlIHJlYWRvbmx5IGFkYXB0ZXI/OiBUQWRhcHRlcjtcblxuICBjb25zdHJ1Y3RvcihkZWZhdWx0T3B0aW9ucz86IFBhcnRpYWw8Q2FjaGVPcHRpb25zPik7XG4gIGNvbnN0cnVjdG9yKGFkYXB0ZXI/OiBUQWRhcHRlciwgZGVmYXVsdE9wdGlvbnM/OiBQYXJ0aWFsPENhY2hlT3B0aW9ucz4pO1xuICBjb25zdHJ1Y3RvcihhZGFwdGVyPzogVEFkYXB0ZXIgfCBQYXJ0aWFsPENhY2hlT3B0aW9ucz4sIGRlZmF1bHRPcHRpb25zPzogUGFydGlhbDxDYWNoZU9wdGlvbnM+KSB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IGFkYXB0ZXIgJiYgIShcImdldFZhbHVlXCIgaW4gYWRhcHRlcikgPyAoYWRhcHRlciBhcyBQYXJ0aWFsPENhY2hlT3B0aW9ucz4pIDogZGVmYXVsdE9wdGlvbnM7XG4gICAgaWYgKGFkYXB0ZXIgJiYgXCJnZXRWYWx1ZVwiIGluIGFkYXB0ZXIgJiYgXCJzZXRWYWx1ZVwiIGluIGFkYXB0ZXIpIHtcbiAgICAgIHRoaXMuYWRhcHRlciA9IGFkYXB0ZXIgYXMgVEFkYXB0ZXI7XG4gICAgfVxuXG4gICAgdGhpcy5vcHRpb25zID0ge1xuICAgICAgLi4uZGVmYXVsdENhY2hlT3B0aW9ucyxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgZ2V0RnJvbUFkYXB0ZXI8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFByb21pc2U8VCB8IHVuZGVmaW5lZD4ge1xuICAgIGlmICghdGhpcy5hZGFwdGVyKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmFkYXB0ZXIuZ2V0VmFsdWUoY2FjaGVLZXkpO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBzYXZlVG9BZGFwdGVyPFQ+KGNhY2hlS2V5OiBzdHJpbmcsIHZhbHVlOiBUKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgaWYgKCF0aGlzLmFkYXB0ZXIpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy5hZGFwdGVyLnNldFZhbHVlPFQ+KGNhY2hlS2V5LCB2YWx1ZSk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0PFQ+KFxuICAgIGNhY2hlS2V5OiBzdHJpbmcsXG4gICAgdmFsdWVMb2FkZXI/OiBWYWx1ZUxvYWRlcjxUPixcbiAgICBvcHRpb25zOiBQYXJ0aWFsPENhY2hlTWV0YWRhdGFPcHRpb25zPiA9IHt9LFxuICApOiBQcm9taXNlPFQgfCB1bmRlZmluZWQ+IHtcbiAgICBjb25zdCBtZXJnZWRPcHRpb25zID0gdGhpcy5tZXJnZU9wdGlvbnMob3B0aW9ucyk7XG5cbiAgICAvLyBUcnkgaW4tbWVtb3J5IGNhY2hlIGZpcnN0XG4gICAgY29uc3QgY2FjaGVkVmFsdWUgPSB0aGlzLnRyeUdldEZyb21NZW1vcnk8VD4oY2FjaGVLZXkpO1xuICAgIGlmIChjYWNoZWRWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gY2FjaGVkVmFsdWU7XG4gICAgfVxuXG4gICAgLy8gTG9hZCBmcmVzaCB2YWx1ZSBmcm9tIGxvYWRlciBmdW5jdGlvbiBmaXJzdFxuICAgIGNvbnN0IGZyZXNoVmFsdWUgPSBhd2FpdCB0aGlzLnRyeUdldEZyb21WYWx1ZUxvYWRlcih2YWx1ZUxvYWRlcik7XG4gICAgaWYgKGZyZXNoVmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgICAgYXdhaXQgdGhpcy5jYWNoZVZhbHVlKGNhY2hlS2V5LCBmcmVzaFZhbHVlLCBtZXJnZWRPcHRpb25zKTtcblxuICAgICAgcmV0dXJuIGZyZXNoVmFsdWU7XG4gICAgfVxuXG4gICAgLy8gVHJ5IGFkYXB0ZXIgY2FjaGUgc2Vjb25kXG4gICAgY29uc3QgYWRhcHRlclZhbHVlID0gYXdhaXQgdGhpcy50cnlHZXRGcm9tQWRhcHRlcjxUPihjYWNoZUtleSk7XG4gICAgaWYgKGFkYXB0ZXJWYWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICBhd2FpdCB0aGlzLmNhY2hlVmFsdWUoY2FjaGVLZXksIGFkYXB0ZXJWYWx1ZSwgbWVyZ2VkT3B0aW9ucyk7XG5cbiAgICAgIHJldHVybiBhZGFwdGVyVmFsdWU7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBtZXJnZU9wdGlvbnMob3B0aW9uczogUGFydGlhbDxDYWNoZU1ldGFkYXRhT3B0aW9ucz4pOiBDYWNoZU1ldGFkYXRhT3B0aW9ucyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR0bE1zOiB0aGlzLm9wdGlvbnMudHRsTXMsXG4gICAgICBleHBpcmF0aW9uVGhyZXNob2xkTXM6IHRoaXMub3B0aW9ucy5leHBpcmF0aW9uVGhyZXNob2xkTXMsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIHRyeUdldEZyb21NZW1vcnk8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFQgfCB1bmRlZmluZWQge1xuICAgIGNvbnN0IGNhY2hlZCA9IHRoaXMuaW5NZW1vcnlDYWNoZS5nZXQoY2FjaGVLZXkpO1xuXG4gICAgaWYgKGNhY2hlZCAmJiAhdGhpcy5pc0V4cGlyZWQoY2FjaGVkLm1ldGFkYXRhKSkge1xuICAgICAgcmV0dXJuIGNhY2hlZC5kYXRhIGFzIFQ7XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgdHJ5R2V0RnJvbUFkYXB0ZXI8VD4oY2FjaGVLZXk6IHN0cmluZyk6IFByb21pc2U8VCB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IGNhY2hlZCA9IGF3YWl0IHRoaXMuZ2V0RnJvbUFkYXB0ZXI8Q2FjaGVXaXRoTWV0YWRhdGE8VD4+KGNhY2hlS2V5KTtcblxuICAgIGlmIChjYWNoZWQgJiYgIXRoaXMuaXNFeHBpcmVkKGNhY2hlZC5tZXRhZGF0YSkpIHtcbiAgICAgIHRoaXMuaW5NZW1vcnlDYWNoZS5zZXQoY2FjaGVLZXksIGNhY2hlZCk7XG4gICAgICByZXR1cm4gY2FjaGVkLmRhdGE7XG4gICAgfVxuXG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgdHJ5R2V0RnJvbVZhbHVlTG9hZGVyPFQ+KHZhbHVlTG9hZGVyPzogVmFsdWVMb2FkZXI8VD4pOiBQcm9taXNlPFQgfCB1bmRlZmluZWQ+IHtcbiAgICBpZiAodmFsdWVMb2FkZXIgPT09IHVuZGVmaW5lZCkge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBpZiAoaXNDYWxsYWJsZSh2YWx1ZUxvYWRlcikpIHtcbiAgICAgIHJldHVybiBhd2FpdCB2YWx1ZUxvYWRlcigpO1xuICAgIH1cblxuICAgIGlmIChpc1Byb21pc2UodmFsdWVMb2FkZXIpKSB7XG4gICAgICByZXR1cm4gYXdhaXQgdmFsdWVMb2FkZXI7XG4gICAgfVxuXG4gICAgcmV0dXJuIHZhbHVlTG9hZGVyO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBjYWNoZVZhbHVlPFQ+KGNhY2hlS2V5OiBzdHJpbmcsIHZhbHVlOiBULCBvcHRpb25zOiBDYWNoZU1ldGFkYXRhT3B0aW9ucyk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGNhY2hlRGF0YSA9IHRoaXMuY3JlYXRlQ2FjaGVFbnRyeSh2YWx1ZSwgb3B0aW9ucyk7XG5cbiAgICBhd2FpdCB0aGlzLnNhdmVUb0FkYXB0ZXIoY2FjaGVLZXksIGNhY2hlRGF0YSk7XG4gICAgdGhpcy5pbk1lbW9yeUNhY2hlLnNldChjYWNoZUtleSwgY2FjaGVEYXRhKTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlQ2FjaGVFbnRyeTxUPih2YWx1ZTogVCwgb3B0aW9uczogQ2FjaGVNZXRhZGF0YU9wdGlvbnMpOiBDYWNoZVdpdGhNZXRhZGF0YTxUPiB7XG4gICAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgICBsZXQgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgaWYgKG9wdGlvbnMudHRsTXMgPCAwKSB7XG4gICAgICBleHBpcmVzQXQgPSAtMTtcbiAgICB9IGVsc2Uge1xuICAgICAgZXhwaXJlc0F0ID0gbm93ICsgb3B0aW9ucy50dGxNcyAtIG9wdGlvbnMuZXhwaXJhdGlvblRocmVzaG9sZE1zO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICBkYXRhOiB2YWx1ZSxcbiAgICAgIG1ldGFkYXRhOiB7XG4gICAgICAgIGNyZWF0ZWRBdDogbm93LFxuICAgICAgICB0dGxNczogb3B0aW9ucy50dGxNcyxcbiAgICAgICAgZXhwaXJhdGlvblRocmVzaG9sZE1zOiBvcHRpb25zLmV4cGlyYXRpb25UaHJlc2hvbGRNcyxcbiAgICAgICAgZXhwaXJlc0F0LFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcHJpdmF0ZSBpc0V4cGlyZWQobWV0YWRhdGE/OiBDYWNoZU1ldGFkYXRhKTogYm9vbGVhbiB7XG4gICAgaWYgKCFtZXRhZGF0YSkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgaWYgKG1ldGFkYXRhLmV4cGlyZXNBdCA8IDApIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBjb25zdCBleHBpcmF0aW9uVGltZSA9XG4gICAgICBtZXRhZGF0YS5leHBpcmVzQXQgPz8gKG1ldGFkYXRhLmNyZWF0ZWRBdCAmJiBtZXRhZGF0YS50dGxNcyA/IG1ldGFkYXRhLmNyZWF0ZWRBdCArIG1ldGFkYXRhLnR0bE1zIDogdW5kZWZpbmVkKTtcblxuICAgIGlmIChleHBpcmF0aW9uVGltZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICByZXR1cm4gRGF0ZS5ub3coKSA+PSBleHBpcmF0aW9uVGltZTtcbiAgfVxufVxuIiwKICAgICJleHBvcnQgZnVuY3Rpb24gaXNDYWxsYWJsZSh2YWx1ZTogYW55KTogdmFsdWUgaXMgQ2FsbGFibGVGdW5jdGlvbiB7XG4gIHJldHVybiB0eXBlb2YgdmFsdWUgPT09IFwiZnVuY3Rpb25cIjtcbn1cbiIsCiAgICAiZXhwb3J0IGNvbnN0IENBQ0hFX1RUTF9ORVZFUl9FWFBJUkUgPSAtMTtcbiIsCiAgICAiLyoqXG4gKiBDb252ZXJ0cyBhbiBhc3luYyBpdGVyYWJsZSBvZiBzdHJpbmcgb3IgVWludDhBcnJheSBjaHVua3MgaW50byBhbiBhc3luYyBpdGVyYWJsZSBvZiBsaW5lcy5cbiAqIEhhbmRsZXMgY2FzZXMgd2hlcmUgbGluZXMgbWF5IGJlIHNwbGl0IGFjcm9zcyBtdWx0aXBsZSBjaHVua3MuXG4gKiBVc2FnZTpcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBwaXBlbGluZSB9IGZyb20gXCJub2RlOnN0cmVhbS9wcm9taXNlc1wiO1xuICogaW1wb3J0IHsgY3JlYXRlUmVhZFN0cmVhbSB9IGZyb20gXCJub2RlOmZzXCI7XG4gKiBpbXBvcnQgeyBzdHJlYW1Ub0xpbmVzIH0gZnJvbSBcIkBsdWthc2tqL3RzLXV0aWxzXCI7XG4gKlxuICogYXN5bmMgZnVuY3Rpb24gcHJvY2Vzc0xpbmUoY2h1bms6IEFzeW5jSXRlcmFibGU8c3RyaW5nPikge1xuICogICBmb3IgYXdhaXQgKGNvbnN0IGxpbmUgb2YgY2h1bmspIHtcbiAqICAgICBjb25zb2xlLmxvZyhsaW5lKTtcbiAqICAgICB5aWVsZCBsaW5lO1xuICogICB9XG4gKiB9XG4gKiBjb25zdCByZWFkU3RyZWFtID0gY3JlYXRlUmVhZFN0cmVhbShcInBhdGgvdG8vZmlsZS50eHRcIiwgeyBlbmNvZGluZzogXCJ1dGYtOFwiIH0pO1xuICogYXdhaXQgcGlwZWxpbmUocmVhZFN0cmVhbSwgc3RyZWFtVG9MaW5lcywgcHJvY2Vzcy5zdGRvdXQpLmNhdGNoKChlcnIpID0+IHtcbiAqICAgY29uc29sZS5lcnJvcihlcnIpO1xuICogICBwcm9jZXNzLmV4aXQoMSk7XG4gKiB9KTtcbiAqIGBgYFxuICogQHBhcmFtIGNodW5rc1xuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24qIHN0cmVhbVRvTGluZXMoY2h1bmtzOiBBc3luY0l0ZXJhYmxlPHN0cmluZyB8IFVpbnQ4QXJyYXk+KSB7XG4gIGxldCBwcmV2aW91cyA9IFwiXCI7XG5cbiAgZm9yIGF3YWl0IChjb25zdCBjaHVuayBvZiBjaHVua3MpIHtcbiAgICBwcmV2aW91cyArPSBjaHVuaztcbiAgICBsZXQgZW9sSW5kZXg6IG51bWJlcjtcblxuICAgIC8vIGJpb21lLWlnbm9yZSBsaW50L3N1c3BpY2lvdXMvbm9Bc3NpZ25JbkV4cHJlc3Npb25zOiBcImV4cGxhbmF0aW9uXCJcbiAgICB3aGlsZSAoKGVvbEluZGV4ID0gcHJldmlvdXMuaW5kZXhPZihcIlxcblwiKSkgPj0gMCkge1xuICAgICAgLy8gdGhpcyBsaW5lIGluY2x1ZGVzIHRoZSBFT0xcbiAgICAgIGNvbnN0IGxpbmUgPSBwcmV2aW91cy5zbGljZSgwLCBlb2xJbmRleCArIDEpO1xuICAgICAgeWllbGQgbGluZT8udHJpbSgpID8/IFwiXCI7XG4gICAgICBwcmV2aW91cyA9IHByZXZpb3VzLnNsaWNlKGVvbEluZGV4ICsgMSk7XG4gICAgfVxuICB9XG5cbiAgaWYgKHByZXZpb3VzLmxlbmd0aCA+IDApIHtcbiAgICB5aWVsZCBwcmV2aW91cztcbiAgfVxufVxuXG4vKipcbiAqIEBkZXByZWNhdGVkIHVzZSBzdHJlYW1Ub0xpbmVzXG4gKi9cbmV4cG9ydCBjb25zdCBjaHVua3NUb0xpbmVzID0gc3RyZWFtVG9MaW5lcztcbiIsCiAgICAiZXhwb3J0IGNvbnN0IGlzTnVsbE9yVW5kZWZpbmVkID0gKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBudWxsIHwgdW5kZWZpbmVkID0+IHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSB1bmRlZmluZWQ7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc051bGxPckVtcHR5T3JVbmRlZmluZWQodmFsdWU/OiBhbnkgfCBudWxsKTogdmFsdWUgaXMgbnVsbCB8IHVuZGVmaW5lZCB7XG4gIHJldHVybiB2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlID09PSBudWxsIHx8IHZhbHVlID09PSBcIlwiIHx8IHZhbHVlLnRvU3RyaW5nKCkudHJpbSgpID09PSBcIlwiO1xufVxuIiwKICAgICIvKipcbiAqIFR5cGUgZ3VhcmQgdGhhdCBjaGVja3MgaWYgdGhlIGlucHV0IGlzIGEgcGxhaW4gSmF2YVNjcmlwdCBvYmplY3QuXG4gKiBAcGFyYW0ge2FueX0gaW5wdXQgLSBUaGUgdmFsdWUgdG8gY2hlY2tcbiAqIEByZXR1cm5zIHtib29sZWFufSBUcnVlIGlmIHRoZSBpbnB1dCBpcyBhIHBsYWluIG9iamVjdCwgZmFsc2Ugb3RoZXJ3aXNlXG4gKiBAdHlwZVBhcmFtIHtSZWNvcmQ8c3RyaW5nLCBhbnk+fSBUeXBlIGd1YXJkIG5hcnJvd3MgdGhlIGlucHV0IHR5cGUgdG8gYSBzdHJpbmcta2V5ZWQgb2JqZWN0XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc09iamVjdChpbnB1dDogYW55KTogaW5wdXQgaXMgUmVjb3JkPHN0cmluZywgYW55PiB7XG4gIHJldHVybiBPYmplY3QucHJvdG90eXBlLnRvU3RyaW5nLmFwcGx5KGlucHV0KSA9PT0gXCJbb2JqZWN0IE9iamVjdF1cIjtcbn1cbiIsCiAgICAiZXhwb3J0IGZ1bmN0aW9uIGlzUHJpbWl0aXZlKHZhbHVlOiB1bmtub3duKTogYm9vbGVhbiB7XG4gIHJldHVybiAodHlwZW9mIHZhbHVlICE9PSBcIm9iamVjdFwiICYmIHR5cGVvZiB2YWx1ZSAhPT0gXCJmdW5jdGlvblwiKSB8fCB2YWx1ZSA9PT0gbnVsbCB8fCB2YWx1ZSBpbnN0YW5jZW9mIERhdGU7XG59XG4iLAogICAgImltcG9ydCBzanMgZnJvbSBcInNlY3VyZS1qc29uLXBhcnNlXCI7XG5cbi8qKlxuICogU2FmZWx5IHBhcnNlcyBKU09OIGlucHV0IHVzaW5nIHNlY3VyZS1qc29uLXBhcnNlIHdpdGggcHJvdG90eXBlIHBvbGx1dGlvbiBwcm90ZWN0aW9uLlxuICogQHBhcmFtIHthbnl9IGlucHV0IC0gVGhlIGlucHV0IHRvIGJlIHBhcnNlZCBhcyBKU09OXG4gKiBAcmV0dXJucyB7eyB2YWx1ZT86IGFueSwgZXJyPzogRXJyb3IgfX0gQW4gb2JqZWN0IGNvbnRhaW5pbmcgZWl0aGVyIHRoZSBwYXJzZWQgdmFsdWUgb3IgYW4gZXJyb3IgaWYgcGFyc2luZyBmYWlsZWRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGpzb25QYXJzZXIoaW5wdXQ6IGFueSkge1xuICB0cnkge1xuICAgIHJldHVybiB7IHZhbHVlOiBzanMucGFyc2UoaW5wdXQsIHsgcHJvdG9BY3Rpb246IFwicmVtb3ZlXCIgfSkgfTtcbiAgfSBjYXRjaCAoZXJyKSB7XG4gICAgcmV0dXJuIHsgZXJyIH07XG4gIH1cbn1cbiIsCiAgICAiZXhwb3J0IGZ1bmN0aW9uIHJhbmRvbVN0cmluZyhsZW5ndGg6IG51bWJlciA9IDYpOiBzdHJpbmcge1xuICBsZXQgcmVzdWx0ID0gXCJcIjtcbiAgY29uc3QgY2hhcmFjdGVycyA9IFwiQUJDREVGR0hJSktMTU5PUFFSU1RVVldYWVphYmNkZWZnaGlqa2xtbm9wcXJzdHV2d3h5ejAxMjM0NTY3ODlcIjtcbiAgY29uc3QgY2hhcmFjdGVyc0xlbmd0aCA9IGNoYXJhY3RlcnMubGVuZ3RoO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGxlbmd0aDsgaSsrKSB7XG4gICAgcmVzdWx0ICs9IGNoYXJhY3RlcnMuY2hhckF0KE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIGNoYXJhY3RlcnNMZW5ndGgpKTtcbiAgfVxuICByZXR1cm4gcmVzdWx0O1xufVxuIiwKICAgICJleHBvcnQgY29uc3Qgc2xlZXAgPSAobXM6IG51bWJlcikgPT4gbmV3IFByb21pc2UoKHJlc29sdmUpID0+IHNldFRpbWVvdXQocmVzb2x2ZSwgbXMpKTtcbiIsCiAgICAiLy8gaHR0cHM6Ly9naXN0LmdpdGh1Yi5jb20vdDNkb3RnZy9hNDg2YzRhZTY2ZDMyYmYxN2MwOWM3MzYwOWRhY2M1YlxuLy8gVHlwZXMgZm9yIHRoZSByZXN1bHQgb2JqZWN0IHdpdGggZGlzY3JpbWluYXRlZCB1bmlvblxuLy8gdHlwZSBTdWNjZXNzPFQ+ID0ge1xuLy8gICBkYXRhOiBUO1xuLy8gICBlcnJvcjogbnVsbDtcbi8vIH07XG5cbi8vIHR5cGUgRmFpbHVyZTxFPiA9IHtcbi8vICAgZGF0YTogbnVsbDtcbi8vICAgZXJyb3I6IEU7XG4vLyB9O1xuXG4vLyBleHBvcnQgdHlwZSBSZXN1bHQ8VCwgRSA9IEVycm9yPiA9IFN1Y2Nlc3M8VD4gfCBGYWlsdXJlPEU+O1xuXG5leHBvcnQgdHlwZSBSZXN1bHQ8VCwgRT4gPSBbdW5kZWZpbmVkLCBFXSB8IFtULCB1bmRlZmluZWRdO1xuZXhwb3J0IHR5cGUgUHJvbWlzZVJlc3VsdDxULCBFPiA9IFByb21pc2U8UmVzdWx0PFQsIEU+PjtcblxuLyoqXG4gKiBXcmFwcyBhIHN5bmNocm9ub3VzIGZ1bmN0aW9uIGluIGEgdHJ5LWNhdGNoIGJsb2NrIGFuZCByZXR1cm5zIGEgUmVzdWx0IHR1cGxlIGNvbnRhaW5pbmcgZWl0aGVyIHRoZSByZXR1cm5lZCB2YWx1ZSBvciB0aGUgY2F1Z2h0IGVycm9yXG4gKlxuICogQHRlbXBsYXRlIFQgLSBUaGUgdHlwZSBvZiB0aGUgc3VjY2Vzc2Z1bCByZXN1bHQgdmFsdWVcbiAqIEB0ZW1wbGF0ZSBFIC0gVGhlIHR5cGUgb2YgdGhlIGVycm9yIHZhbHVlLCBtdXN0IGV4dGVuZCBFcnJvclxuICogQHBhcmFtIHsoKSA9PiBUfSBmbiAtIFRoZSBmdW5jdGlvbiB0byBiZSBleGVjdXRlZFxuICogQHJldHVybnMge1Jlc3VsdDxULCBFPn0gQSB0dXBsZSBjb250YWluaW5nIGVpdGhlciBbZGF0YSwgdW5kZWZpbmVkXSBvciBbdW5kZWZpbmVkLCBlcnJvcl1cbiAqXG4gKiBAZXhhbXBsZVxuICogY29uc3QgW2RhdGEsIGVycm9yXSA9IHRyeUNhdGNoKCgpID0+IHNvbWVSaXNreU9wZXJhdGlvbigpKTtcbiAqIGlmIChlcnJvcikge1xuICogICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAqIH0gZWxzZSB7XG4gKiAgIGNvbnNvbGUubG9nKGRhdGEpO1xuICogfVxuICovXG5leHBvcnQgZnVuY3Rpb24gdHJ5Q2F0Y2g8VCwgRSBleHRlbmRzIEVycm9yPihmbjogKCkgPT4gVCk6IFJlc3VsdDxULCBFPiB7XG4gIHRyeSB7XG4gICAgY29uc3QgZGF0YSA9IGZuKCk7XG4gICAgcmV0dXJuIFtkYXRhIGFzIFQsIHVuZGVmaW5lZF07XG4gIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgcmV0dXJuIFt1bmRlZmluZWQsIGVycm9yIGFzIEVdO1xuICB9XG59XG5cbi8qKlxuICogV3JhcHMgYSBQcm9taXNlIGluIGEgdHJ5LWNhdGNoIGJsb2NrIGFuZCByZXR1cm5zIGEgUmVzdWx0IG9iamVjdCBjb250YWluaW5nIGVpdGhlciB0aGUgcmVzb2x2ZWQgZGF0YSBvciB0aGUgY2F1Z2h0IGVycm9yXG4gKlxuICogQHRlbXBsYXRlIFQgLSBUaGUgdHlwZSBvZiB0aGUgc3VjY2Vzc2Z1bCByZXN1bHQgdmFsdWVcbiAqIEB0ZW1wbGF0ZSBFIC0gVGhlIHR5cGUgb2YgdGhlIGVycm9yIHZhbHVlLCBkZWZhdWx0cyB0byBFcnJvclxuICogQHBhcmFtIHtQcm9taXNlPFQ+fSBwcm9taXNlIC0gVGhlIHByb21pc2UgdG8gYmUgZXhlY3V0ZWRcbiAqIEByZXR1cm5zIHtQcm9taXNlPFJlc3VsdDxULCBFPj59IEEgUHJvbWlzZSB0aGF0IHJlc29sdmVzIHRvIGEgUmVzdWx0IG9iamVjdCBjb250YWluaW5nIGVpdGhlciB0aGUgZGF0YSBvciBlcnJvclxuICpcbiAqIEBleGFtcGxlXG4gKiBjb25zdCB7ZGF0YSwgZXJyb3J9ID0gYXdhaXQgdHJ5Q2F0Y2hBc3luYyhzb21lUHJvbWlzZSk7XG4gKiBpZiAoZXJyb3IpIHtcbiAqICAgY29uc29sZS5lcnJvcihyZXN1bHQuZXJyb3IpO1xuICogfSBlbHNlIHtcbiAqICAgY29uc29sZS5sb2coZGF0YSk7XG4gKiB9XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiB0cnlDYXRjaEFzeW5jPFQsIEUgZXh0ZW5kcyBFcnJvcj4ocHJvbWlzZTogUHJvbWlzZTxUPik6IFByb21pc2VSZXN1bHQ8VCwgRT4ge1xuICB0cnkge1xuICAgIGNvbnN0IGRhdGEgPSBhd2FpdCBwcm9taXNlO1xuICAgIHJldHVybiBbZGF0YSBhcyBULCB1bmRlZmluZWRdO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIHJldHVybiBbdW5kZWZpbmVkLCBlcnJvciBhcyBFXTtcbiAgfVxufVxuIgogIF0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBMEIsSUFBMUI7OztBQ0FPLFNBQVMsVUFBVSxDQUFDLE9BQXVDO0FBQUEsRUFDaEUsT0FBTyxPQUFPLFVBQVU7QUFBQTs7O0FESTFCLElBQU0sc0JBQW9DO0FBQUEsRUFDeEMsdUJBQXVCO0FBQUEsRUFDdkIsT0FBTyxLQUFLLEtBQUs7QUFDbkI7QUFBQTtBQUVPLE1BQU0sTUFBOEQ7QUFBQSxFQUNqRSxnQkFBZ0QsSUFBSTtBQUFBLEVBQzNDO0FBQUEsRUFDQTtBQUFBLEVBSWpCLFdBQVcsQ0FBQyxTQUE0QyxnQkFBd0M7QUFBQSxJQUM5RixNQUFNLFVBQVUsV0FBVyxFQUFFLGNBQWMsV0FBWSxVQUFvQztBQUFBLElBQzNGLElBQUksV0FBVyxjQUFjLFdBQVcsY0FBYyxTQUFTO0FBQUEsTUFDN0QsS0FBSyxVQUFVO0FBQUEsSUFDakI7QUFBQSxJQUVBLEtBQUssVUFBVTtBQUFBLFNBQ1Y7QUFBQSxTQUNBO0FBQUEsSUFDTDtBQUFBO0FBQUEsT0FHWSxlQUFpQixDQUFDLFVBQTBDO0FBQUEsSUFDeEUsSUFBSSxDQUFDLEtBQUssU0FBUztBQUFBLE1BQ2pCO0FBQUEsSUFDRjtBQUFBLElBRUEsT0FBTyxLQUFLLFFBQVEsU0FBUyxRQUFRO0FBQUE7QUFBQSxPQUd6QixjQUFnQixDQUFDLFVBQWtCLE9BQXlCO0FBQUEsSUFDeEUsSUFBSSxDQUFDLEtBQUssU0FBUztBQUFBLE1BQ2pCO0FBQUEsSUFDRjtBQUFBLElBRUEsT0FBTyxLQUFL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