@adviser/cement 0.2.28 → 0.2.29

Sign up to get free protection for your applications and to get access to all the features.
Files changed (319) hide show
  1. package/{base-sys-abstraction-C9WW3w57.d.cts → base-sys-abstraction-BkEiLHl0.d.ts} +8 -4
  2. package/{base-sys-abstraction-C9WW3w57.d.ts → base-sys-abstraction-Qj7pkY1N.d.cts} +8 -4
  3. package/{chunk-OXD3YZZ7.js → chunk-7KFVMTOS.js} +3 -47
  4. package/chunk-7KFVMTOS.js.map +1 -0
  5. package/{chunk-P5RXA4C4.js → chunk-GES3MUGV.js} +24 -27
  6. package/{chunk-LCPYQVWT.js.map → chunk-GES3MUGV.js.map} +1 -1
  7. package/{chunk-YDIUMYIE.js → chunk-Q65HLCNL.js} +8 -7
  8. package/chunk-Q65HLCNL.js.map +1 -0
  9. package/{chunk-DPIL5UIL.js → chunk-WMMUXBDX.js} +6 -2
  10. package/chunk-WMMUXBDX.js.map +1 -0
  11. package/{index-Dhb2fQiw.d.cts → index-Q3phXzYr.d.cts} +2 -21
  12. package/{index-CcsGcehs.d.ts → index-tIGZMHTc.d.ts} +2 -21
  13. package/index.cjs +264 -7343
  14. package/index.cjs.map +1 -1
  15. package/index.d.cts +72 -12
  16. package/index.d.ts +72 -12
  17. package/index.js +217 -7265
  18. package/index.js.map +1 -1
  19. package/node/index.cjs +220 -39
  20. package/node/index.cjs.map +1 -1
  21. package/node/index.d.cts +22 -4
  22. package/node/index.d.ts +22 -4
  23. package/node/index.js +201 -25
  24. package/node/index.js.map +1 -1
  25. package/package.json +23 -12
  26. package/src/LICENSE +201 -0
  27. package/src/README.md +39 -0
  28. package/src/base-sys-abstraction.test.ts +95 -0
  29. package/src/base-sys-abstraction.ts +242 -0
  30. package/src/bin2text.test.ts +59 -0
  31. package/src/bin2text.ts +47 -0
  32. package/src/crypto.test.ts +15 -0
  33. package/src/crypto.ts +125 -0
  34. package/src/file-service.ts +24 -0
  35. package/src/future.test.ts +32 -0
  36. package/src/future.ts +27 -0
  37. package/src/index.ts +22 -0
  38. package/src/jsr.json +20 -0
  39. package/src/log-level-impl.ts +87 -0
  40. package/src/log-writer-impl.ts +58 -0
  41. package/src/logger-impl.ts +498 -0
  42. package/src/logger.test.ts +1132 -0
  43. package/src/logger.ts +208 -0
  44. package/src/node/deno-file-service.ts +92 -0
  45. package/src/node/deno-sys-abstraction.ts +133 -0
  46. package/src/node/index.ts +4 -0
  47. package/src/node/mock-file-service.ts +45 -0
  48. package/src/node/node-file-service.ts +91 -0
  49. package/src/node/node-sys-abstraction.ts +121 -0
  50. package/src/option.ts +60 -0
  51. package/src/resolve-once.test.ts +321 -0
  52. package/src/resolve-once.ts +179 -0
  53. package/src/result.test.ts +102 -0
  54. package/src/result.ts +165 -0
  55. package/src/runtime.ts +36 -0
  56. package/src/sys-abstraction.ts +53 -0
  57. package/src/sys-env.test.ts +53 -0
  58. package/src/sys-env.ts +216 -0
  59. package/src/test/log-write-stream.ts +95 -0
  60. package/src/test/mock-logger.ts +40 -0
  61. package/src/time.ts +20 -0
  62. package/src/tracer.test.ts +314 -0
  63. package/src/tracer.ts +222 -0
  64. package/src/txt-en-decoder.ts +21 -0
  65. package/src/uri.test.ts +155 -0
  66. package/src/uri.ts +421 -0
  67. package/src/utils/console-write-stream.ts +72 -0
  68. package/src/utils/fanout-write-stream.ts +32 -0
  69. package/src/utils/index.ts +6 -0
  70. package/src/utils/rebuffer.ts +75 -0
  71. package/src/utils/stream-map.ts +67 -0
  72. package/src/utils/stream2string.ts +47 -0
  73. package/src/utils/string2stream.ts +14 -0
  74. package/src/version.ts +3 -0
  75. package/src/web/index.ts +1 -0
  76. package/src/web/web-sys-abstraction.ts +80 -0
  77. package/ts/base-sys-abstraction.d.ts +84 -0
  78. package/ts/base-sys-abstraction.d.ts.map +1 -0
  79. package/ts/base-sys-abstraction.js +178 -0
  80. package/ts/base-sys-abstraction.js.map +1 -0
  81. package/ts/base-sys-abstraction.test.d.ts +2 -0
  82. package/ts/base-sys-abstraction.test.d.ts.map +1 -0
  83. package/ts/base-sys-abstraction.test.js +82 -0
  84. package/ts/base-sys-abstraction.test.js.map +1 -0
  85. package/ts/bin2text.d.ts +3 -0
  86. package/ts/bin2text.d.ts.map +1 -0
  87. package/ts/bin2text.js +43 -0
  88. package/ts/bin2text.js.map +1 -0
  89. package/ts/bin2text.test.d.ts +2 -0
  90. package/ts/bin2text.test.d.ts.map +1 -0
  91. package/ts/bin2text.test.js +51 -0
  92. package/ts/bin2text.test.js.map +1 -0
  93. package/ts/crypto.d.ts +76 -0
  94. package/ts/crypto.d.ts.map +1 -0
  95. package/ts/crypto.js +22 -0
  96. package/ts/crypto.js.map +1 -0
  97. package/ts/crypto.test.d.ts +2 -0
  98. package/ts/crypto.test.d.ts.map +1 -0
  99. package/ts/crypto.test.js +14 -0
  100. package/ts/crypto.test.js.map +1 -0
  101. package/ts/file-service.d.ts +17 -0
  102. package/ts/file-service.d.ts.map +1 -0
  103. package/ts/file-service.js +2 -0
  104. package/ts/file-service.js.map +1 -0
  105. package/ts/future.d.ts +8 -0
  106. package/ts/future.d.ts.map +1 -0
  107. package/ts/future.js +38 -0
  108. package/ts/future.js.map +1 -0
  109. package/ts/future.test.d.ts +2 -0
  110. package/ts/future.test.d.ts.map +1 -0
  111. package/ts/future.test.js +28 -0
  112. package/ts/future.test.js.map +1 -0
  113. package/ts/index.d.ts +23 -0
  114. package/ts/index.d.ts.map +1 -0
  115. package/ts/index.js +23 -0
  116. package/ts/index.js.map +1 -0
  117. package/ts/log-level-impl.d.ts +14 -0
  118. package/ts/log-level-impl.d.ts.map +1 -0
  119. package/ts/log-level-impl.js +72 -0
  120. package/ts/log-level-impl.js.map +1 -0
  121. package/ts/log-writer-impl.d.ts +10 -0
  122. package/ts/log-writer-impl.d.ts.map +1 -0
  123. package/ts/log-writer-impl.js +45 -0
  124. package/ts/log-writer-impl.js.map +1 -0
  125. package/ts/logger-impl.d.ts +71 -0
  126. package/ts/logger-impl.d.ts.map +1 -0
  127. package/ts/logger-impl.js +412 -0
  128. package/ts/logger-impl.js.map +1 -0
  129. package/ts/logger.d.ts +84 -0
  130. package/ts/logger.d.ts.map +1 -0
  131. package/ts/logger.js +114 -0
  132. package/ts/logger.js.map +1 -0
  133. package/ts/logger.test.d.ts +2 -0
  134. package/ts/logger.test.d.ts.map +1 -0
  135. package/ts/logger.test.js +1023 -0
  136. package/ts/logger.test.js.map +1 -0
  137. package/ts/node/deno-file-service.d.ts +17 -0
  138. package/ts/node/deno-file-service.d.ts.map +1 -0
  139. package/ts/node/deno-file-service.js +65 -0
  140. package/ts/node/deno-file-service.js.map +1 -0
  141. package/ts/node/deno-sys-abstraction.d.ts +22 -0
  142. package/ts/node/deno-sys-abstraction.d.ts.map +1 -0
  143. package/ts/node/deno-sys-abstraction.js +101 -0
  144. package/ts/node/deno-sys-abstraction.js.map +1 -0
  145. package/ts/node/index.d.ts +5 -0
  146. package/ts/node/index.d.ts.map +1 -0
  147. package/ts/node/index.js +5 -0
  148. package/ts/node/index.js.map +1 -0
  149. package/ts/node/mock-file-service.d.ts +11 -0
  150. package/ts/node/mock-file-service.d.ts.map +1 -0
  151. package/ts/node/mock-file-service.js +34 -0
  152. package/ts/node/mock-file-service.js.map +1 -0
  153. package/ts/node/mock-file-service.test.d.ts +2 -0
  154. package/ts/node/mock-file-service.test.d.ts.map +1 -0
  155. package/ts/node/mock-file-service.test.js +31 -0
  156. package/ts/node/mock-file-service.test.js.map +1 -0
  157. package/ts/node/node-file-service.d.ts +16 -0
  158. package/ts/node/node-file-service.d.ts.map +1 -0
  159. package/ts/node/node-file-service.js +71 -0
  160. package/ts/node/node-file-service.js.map +1 -0
  161. package/ts/node/node-sys-abstraction.d.ts +22 -0
  162. package/ts/node/node-sys-abstraction.d.ts.map +1 -0
  163. package/ts/node/node-sys-abstraction.js +99 -0
  164. package/ts/node/node-sys-abstraction.js.map +1 -0
  165. package/ts/node/node-sys-abstraction.test.d.ts +2 -0
  166. package/ts/node/node-sys-abstraction.test.d.ts.map +1 -0
  167. package/ts/node/node-sys-abstraction.test.js +87 -0
  168. package/ts/node/node-sys-abstraction.test.js.map +1 -0
  169. package/ts/option.d.ts +25 -0
  170. package/ts/option.d.ts.map +1 -0
  171. package/ts/option.js +47 -0
  172. package/ts/option.js.map +1 -0
  173. package/ts/resolve-once.d.ts +46 -0
  174. package/ts/resolve-once.d.ts.map +1 -0
  175. package/ts/resolve-once.js +152 -0
  176. package/ts/resolve-once.js.map +1 -0
  177. package/ts/resolve-once.test.d.ts +2 -0
  178. package/ts/resolve-once.test.d.ts.map +1 -0
  179. package/ts/resolve-once.test.js +283 -0
  180. package/ts/resolve-once.test.js.map +1 -0
  181. package/ts/result.d.ts +34 -0
  182. package/ts/result.d.ts.map +1 -0
  183. package/ts/result.js +85 -0
  184. package/ts/result.js.map +1 -0
  185. package/ts/result.test.d.ts +2 -0
  186. package/ts/result.test.d.ts.map +1 -0
  187. package/ts/result.test.js +79 -0
  188. package/ts/result.test.js.map +1 -0
  189. package/ts/runtime.d.ts +8 -0
  190. package/ts/runtime.d.ts.map +1 -0
  191. package/ts/runtime.js +26 -0
  192. package/ts/runtime.js.map +1 -0
  193. package/ts/sys-abstraction.d.ts +36 -0
  194. package/ts/sys-abstraction.d.ts.map +1 -0
  195. package/ts/sys-abstraction.js +31 -0
  196. package/ts/sys-abstraction.js.map +1 -0
  197. package/ts/sys-env.d.ts +48 -0
  198. package/ts/sys-env.d.ts.map +1 -0
  199. package/ts/sys-env.js +176 -0
  200. package/ts/sys-env.js.map +1 -0
  201. package/ts/sys-env.test.d.ts +2 -0
  202. package/ts/sys-env.test.d.ts.map +1 -0
  203. package/ts/sys-env.test.js +51 -0
  204. package/ts/sys-env.test.js.map +1 -0
  205. package/ts/test/log-write-stream.d.ts +27 -0
  206. package/ts/test/log-write-stream.d.ts.map +1 -0
  207. package/ts/test/log-write-stream.js +74 -0
  208. package/ts/test/log-write-stream.js.map +1 -0
  209. package/ts/test/mock-logger.d.ts +14 -0
  210. package/ts/test/mock-logger.d.ts.map +1 -0
  211. package/ts/test/mock-logger.js +29 -0
  212. package/ts/test/mock-logger.js.map +1 -0
  213. package/ts/test/mock-logger.test.d.ts +2 -0
  214. package/ts/test/mock-logger.test.d.ts.map +1 -0
  215. package/ts/test/mock-logger.test.js +63 -0
  216. package/ts/test/mock-logger.test.js.map +1 -0
  217. package/ts/test/test-exit-handler.d.ts +2 -0
  218. package/ts/test/test-exit-handler.d.ts.map +1 -0
  219. package/ts/test/test-exit-handler.js +57 -0
  220. package/ts/test/test-exit-handler.js.map +1 -0
  221. package/ts/time.d.ts +13 -0
  222. package/ts/time.d.ts.map +1 -0
  223. package/ts/time.js +14 -0
  224. package/ts/time.js.map +1 -0
  225. package/ts/tracer.d.ts +59 -0
  226. package/ts/tracer.d.ts.map +1 -0
  227. package/ts/tracer.js +148 -0
  228. package/ts/tracer.js.map +1 -0
  229. package/ts/tracer.test.d.ts +2 -0
  230. package/ts/tracer.test.d.ts.map +1 -0
  231. package/ts/tracer.test.js +311 -0
  232. package/ts/tracer.test.js.map +1 -0
  233. package/ts/txt-en-decoder.d.ts +10 -0
  234. package/ts/txt-en-decoder.d.ts.map +1 -0
  235. package/ts/txt-en-decoder.js +15 -0
  236. package/ts/txt-en-decoder.js.map +1 -0
  237. package/ts/uri.d.ts +67 -0
  238. package/ts/uri.d.ts.map +1 -0
  239. package/ts/uri.js +283 -0
  240. package/ts/uri.js.map +1 -0
  241. package/ts/uri.test.d.ts +2 -0
  242. package/ts/uri.test.d.ts.map +1 -0
  243. package/ts/uri.test.js +119 -0
  244. package/ts/uri.test.js.map +1 -0
  245. package/ts/utils/console-write-stream.d.ts +21 -0
  246. package/ts/utils/console-write-stream.d.ts.map +1 -0
  247. package/ts/utils/console-write-stream.js +62 -0
  248. package/ts/utils/console-write-stream.js.map +1 -0
  249. package/ts/utils/fanout-write-stream.d.ts +12 -0
  250. package/ts/utils/fanout-write-stream.d.ts.map +1 -0
  251. package/ts/utils/fanout-write-stream.js +24 -0
  252. package/ts/utils/fanout-write-stream.js.map +1 -0
  253. package/ts/utils/index.d.ts +7 -0
  254. package/ts/utils/index.d.ts.map +1 -0
  255. package/ts/utils/index.js +7 -0
  256. package/ts/utils/index.js.map +1 -0
  257. package/ts/utils/rebuffer.d.ts +3 -0
  258. package/ts/utils/rebuffer.d.ts.map +1 -0
  259. package/ts/utils/rebuffer.js +60 -0
  260. package/ts/utils/rebuffer.js.map +1 -0
  261. package/ts/utils/rebuffer.test.d.ts +2 -0
  262. package/ts/utils/rebuffer.test.d.ts.map +1 -0
  263. package/ts/utils/rebuffer.test.js +77 -0
  264. package/ts/utils/rebuffer.test.js.map +1 -0
  265. package/ts/utils/stream-map.d.ts +9 -0
  266. package/ts/utils/stream-map.d.ts.map +1 -0
  267. package/ts/utils/stream-map.js +62 -0
  268. package/ts/utils/stream-map.js.map +1 -0
  269. package/ts/utils/stream-map.test.d.ts +2 -0
  270. package/ts/utils/stream-map.test.d.ts.map +1 -0
  271. package/ts/utils/stream-map.test.js +87 -0
  272. package/ts/utils/stream-map.test.js.map +1 -0
  273. package/ts/utils/stream-test-helper.d.ts +17 -0
  274. package/ts/utils/stream-test-helper.d.ts.map +1 -0
  275. package/ts/utils/stream-test-helper.js +37 -0
  276. package/ts/utils/stream-test-helper.js.map +1 -0
  277. package/ts/utils/stream2string.d.ts +3 -0
  278. package/ts/utils/stream2string.d.ts.map +1 -0
  279. package/ts/utils/stream2string.js +48 -0
  280. package/ts/utils/stream2string.js.map +1 -0
  281. package/ts/utils/stream2string.test.d.ts +2 -0
  282. package/ts/utils/stream2string.test.d.ts.map +1 -0
  283. package/ts/utils/stream2string.test.js +29 -0
  284. package/ts/utils/stream2string.test.js.map +1 -0
  285. package/ts/utils/string2stream.d.ts +4 -0
  286. package/ts/utils/string2stream.d.ts.map +1 -0
  287. package/ts/utils/string2stream.js +13 -0
  288. package/ts/utils/string2stream.js.map +1 -0
  289. package/ts/utils/string2stream.test.d.ts +2 -0
  290. package/ts/utils/string2stream.test.d.ts.map +1 -0
  291. package/ts/utils/string2stream.test.js +6 -0
  292. package/ts/utils/string2stream.test.js.map +1 -0
  293. package/ts/version.d.ts +2 -0
  294. package/ts/version.d.ts.map +1 -0
  295. package/ts/version.js +4 -0
  296. package/ts/version.js.map +1 -0
  297. package/ts/web/index.d.ts +2 -0
  298. package/ts/web/index.d.ts.map +1 -0
  299. package/ts/web/index.js +2 -0
  300. package/ts/web/index.js.map +1 -0
  301. package/ts/web/web-sys-abstraction.d.ts +4 -0
  302. package/ts/web/web-sys-abstraction.d.ts.map +1 -0
  303. package/ts/web/web-sys-abstraction.js +64 -0
  304. package/ts/web/web-sys-abstraction.js.map +1 -0
  305. package/utils/index.cjs +0 -42
  306. package/utils/index.cjs.map +1 -1
  307. package/utils/index.d.cts +1 -2
  308. package/utils/index.d.ts +1 -2
  309. package/utils/index.js +2 -7
  310. package/web/index.cjs +25 -7
  311. package/web/index.cjs.map +1 -1
  312. package/web/index.d.cts +2 -1
  313. package/web/index.d.ts +2 -1
  314. package/web/index.js +3 -3
  315. package/chunk-DPIL5UIL.js.map +0 -1
  316. package/chunk-LCPYQVWT.js +0 -21
  317. package/chunk-OXD3YZZ7.js.map +0 -1
  318. package/chunk-P5RXA4C4.js.map +0 -1
  319. package/chunk-YDIUMYIE.js.map +0 -1
package/ts/time.js ADDED
@@ -0,0 +1,14 @@
1
+ export class Time {
2
+ TimeSince(start) {
3
+ const now = this.Now();
4
+ return now.getTime() - start.getTime();
5
+ }
6
+ }
7
+ export var TimeUnits;
8
+ (function (TimeUnits) {
9
+ TimeUnits[TimeUnits["Microsecond"] = 1] = "Microsecond";
10
+ TimeUnits[TimeUnits["Second"] = 1000] = "Second";
11
+ TimeUnits[TimeUnits["Minute"] = 60000] = "Minute";
12
+ TimeUnits[TimeUnits["Hour"] = 3600000] = "Hour";
13
+ })(TimeUnits || (TimeUnits = {}));
14
+ //# sourceMappingURL=time.js.map
package/ts/time.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"time.js","sourceRoot":"","sources":["../../src/time.ts"],"names":[],"mappings":"AAAA,MAAM,OAAgB,IAAI;IAGxB,SAAS,CAAC,KAAW;QACnB,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,OAAO,GAAG,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC;IACzC,CAAC;CACF;AAID,MAAM,CAAN,IAAY,SAQX;AARD,WAAY,SAAS;IACnB,uDAAe,CAAA;IAEf,gDAA2B,CAAA;IAE3B,iDAAoB,CAAA;IAEpB,+CAAkB,CAAA;AACpB,CAAC,EARW,SAAS,KAAT,SAAS,QAQpB"}
package/ts/tracer.d.ts ADDED
@@ -0,0 +1,59 @@
1
+ import { Time } from "./time.js";
2
+ import { Logger } from "./logger.js";
3
+ export type TraceCtx = {
4
+ readonly spanId: string;
5
+ readonly time: Time;
6
+ readonly parent: TraceNode;
7
+ readonly metrics: Map<string, Metric<unknown>>;
8
+ readonly logger?: Logger;
9
+ } & Record<string, unknown>;
10
+ export type CleanCtx = {
11
+ readonly spanId: string;
12
+ } & Record<string, unknown>;
13
+ export type TraceCtxParam = {
14
+ readonly spanId: string;
15
+ } & Partial<{
16
+ readonly time: Time;
17
+ readonly parent: TraceNode;
18
+ readonly logger: Logger;
19
+ }> & Record<string, unknown>;
20
+ export declare class Metric<T> {
21
+ value?: T;
22
+ readonly path: string;
23
+ constructor(path: string);
24
+ set(value: T): void;
25
+ add<R extends number | ArrayLike<T>>(value: R): void;
26
+ }
27
+ export type MetricMap = Map<string, Metric<unknown>>;
28
+ export declare class Metrics {
29
+ readonly tracenode: TraceNode;
30
+ private readonly map;
31
+ readonly spanRefs: MetricMap;
32
+ constructor(tracenode: TraceNode);
33
+ toJSON(): Record<string, unknown>;
34
+ get<T>(ipath: string): Metric<T>;
35
+ }
36
+ export interface Invokaction {
37
+ readonly result: "success" | "error";
38
+ readonly start: number;
39
+ readonly end: number;
40
+ readonly metrics?: Metrics;
41
+ }
42
+ export type TraceNodeMap = Map<string, TraceNode>;
43
+ export declare class TraceNode {
44
+ readonly childs: TraceNodeMap;
45
+ readonly invokations: Invokaction[];
46
+ readonly spanId: string;
47
+ readonly ctx: TraceCtx;
48
+ readonly metrics: Metrics;
49
+ static root(time: Time, logger?: Logger): TraceNode;
50
+ constructor(ctx: TraceCtx);
51
+ getRootPath(rpath?: string[]): string;
52
+ invokes(): {
53
+ ctx: CleanCtx;
54
+ invokations: Invokaction[];
55
+ };
56
+ ctxWith(spanId: string, logger?: Logger): TraceCtxParam;
57
+ span<V extends (trace: TraceNode) => Promise<T> | T, T>(inSpanId: string | TraceCtxParam, fn: V): ReturnType<V>;
58
+ }
59
+ //# sourceMappingURL=tracer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracer.d.ts","sourceRoot":"","sources":["../../src/tracer.ts"],"names":[],"mappings":"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"}
package/ts/tracer.js ADDED
@@ -0,0 +1,148 @@
1
+ export class Metric {
2
+ constructor(path) {
3
+ this.path = path;
4
+ }
5
+ set(value) {
6
+ this.value = value;
7
+ }
8
+ add(value) {
9
+ if (typeof value === "number") {
10
+ if (this.value === undefined) {
11
+ this.value = 0;
12
+ }
13
+ this.value = (this.value + value);
14
+ }
15
+ else if (Array.isArray(value)) {
16
+ if (!Array.isArray(this.value)) {
17
+ this.value = [];
18
+ }
19
+ this.value.push(...value);
20
+ }
21
+ else {
22
+ throw new Error("add only support number or array");
23
+ }
24
+ }
25
+ }
26
+ export class Metrics {
27
+ constructor(tracenode) {
28
+ this.spanRefs = new Map();
29
+ this.tracenode = tracenode;
30
+ this.map = tracenode.ctx.metrics;
31
+ }
32
+ toJSON() {
33
+ const obj = {};
34
+ for (const [key, value] of this.map) {
35
+ obj[key] = value.value;
36
+ }
37
+ return obj;
38
+ }
39
+ get(ipath) {
40
+ const path = ipath.replace(/[/]+/g, "/").trim();
41
+ if (path.startsWith("/")) {
42
+ if (path.slice(1).length === 0) {
43
+ throw new Error(`Metrics path must contain value /:${path}`);
44
+ }
45
+ let metric = this.map.get(path);
46
+ if (!metric) {
47
+ metric = new Metric(path);
48
+ this.map.set(path, metric);
49
+ }
50
+ this.spanRefs.set(path, metric);
51
+ return metric;
52
+ }
53
+ else if (path.includes("/")) {
54
+ throw new Error(`Metrics path must start with /:${path}`);
55
+ }
56
+ const rootPath = this.tracenode.getRootPath();
57
+ return this.get(`${rootPath}/${path}`);
58
+ }
59
+ }
60
+ export class TraceNode {
61
+ static root(time, logger) {
62
+ return new TraceNode({
63
+ spanId: "root",
64
+ time,
65
+ logger,
66
+ metrics: new Map(),
67
+ parent: undefined,
68
+ });
69
+ }
70
+ constructor(ctx) {
71
+ this.childs = new Map();
72
+ this.invokations = [];
73
+ this.spanId = ctx.spanId;
74
+ this.ctx = ctx;
75
+ this.metrics = new Metrics(this);
76
+ }
77
+ getRootPath(rpath = []) {
78
+ if (!this.ctx.parent) {
79
+ return "/" + rpath.reverse().join("/");
80
+ }
81
+ return this.ctx.parent.getRootPath(rpath.concat(this.ctx.spanId));
82
+ }
83
+ invokes() {
84
+ const cleanCtx = Object.assign({}, this.ctx);
85
+ delete cleanCtx.parent;
86
+ delete cleanCtx.time;
87
+ delete cleanCtx.logger;
88
+ delete cleanCtx.metrics;
89
+ const spanRefs = this.metrics.toJSON.call({ map: this.metrics.spanRefs });
90
+ const metricsRefs = Object.keys(spanRefs).length > 0 ? { metricRefs: spanRefs } : {};
91
+ return Object.assign({ ctx: cleanCtx, invokations: this.invokations }, metricsRefs);
92
+ }
93
+ ctxWith(spanId, logger) {
94
+ const ctx = Object.assign(Object.assign({}, this.ctx), { spanId });
95
+ if (logger) {
96
+ ctx.logger = logger;
97
+ }
98
+ return ctx;
99
+ }
100
+ span(inSpanId, fn) {
101
+ let ctx;
102
+ if (typeof inSpanId === "string") {
103
+ ctx = Object.assign(Object.assign({}, this.ctx), { spanId: inSpanId, parent: this });
104
+ }
105
+ else {
106
+ ctx = Object.assign(Object.assign(Object.assign({}, this.ctx), inSpanId), { parent: this });
107
+ }
108
+ if (ctx.logger) {
109
+ ctx = Object.assign(Object.assign({}, ctx), ctx.logger.Attributes());
110
+ }
111
+ const spanId = ctx.spanId;
112
+ let spanTrace = this.childs.get(spanId);
113
+ if (!spanTrace) {
114
+ spanTrace = new TraceNode(ctx);
115
+ this.childs.set(spanId.toString(), spanTrace);
116
+ }
117
+ const invokation = {
118
+ start: this.ctx.time.Now().getTime(),
119
+ end: 0,
120
+ result: "success",
121
+ };
122
+ spanTrace.invokations.push(invokation);
123
+ try {
124
+ const possiblePromise = fn(spanTrace);
125
+ if (possiblePromise instanceof Promise) {
126
+ return possiblePromise
127
+ .then((v) => {
128
+ return v;
129
+ })
130
+ .catch((e) => {
131
+ invokation.result = "error";
132
+ throw e;
133
+ })
134
+ .finally(() => {
135
+ invokation.end = this.ctx.time.Now().getTime();
136
+ });
137
+ }
138
+ invokation.end = this.ctx.time.Now().getTime();
139
+ return possiblePromise;
140
+ }
141
+ catch (e) {
142
+ invokation.result = "error";
143
+ invokation.end = this.ctx.time.Now().getTime();
144
+ throw e;
145
+ }
146
+ }
147
+ }
148
+ //# sourceMappingURL=tracer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracer.js","sourceRoot":"","sources":["../../src/tracer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tracer.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracer.test.d.ts","sourceRoot":"","sources":["../../src/tracer.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,311 @@
1
+ import { WebSysAbstraction } from "./web/index.js";
2
+ import { TimeMode } from "./sys-abstraction.js";
3
+ import { TraceNode } from "./tracer.js";
4
+ import { MockLogger } from "./test/mock-logger.js";
5
+ describe("trace", () => {
6
+ let time;
7
+ let refTime;
8
+ let trace;
9
+ const logger = MockLogger().logger.With().Module("trace").Str("value", "important").Logger();
10
+ beforeEach(() => {
11
+ time = WebSysAbstraction({ TimeMode: TimeMode.STEP }).Time();
12
+ trace = TraceNode.root(time, logger);
13
+ refTime = WebSysAbstraction({ TimeMode: TimeMode.STEP }).Time();
14
+ });
15
+ it("a simple trace", () => {
16
+ var _a;
17
+ expect(trace.span("test", (trace) => {
18
+ const r1 = trace.span("test.1", () => {
19
+ return 1;
20
+ });
21
+ const r2 = trace.span("test.2", () => {
22
+ return 1;
23
+ });
24
+ return r1 + r2;
25
+ })).toBe(2);
26
+ const childs = Array.from(trace.childs.values());
27
+ expect(childs.map((v) => v.invokes())).toEqual([
28
+ {
29
+ ctx: {
30
+ module: "trace",
31
+ spanId: "test",
32
+ value: "important",
33
+ },
34
+ invokations: [
35
+ {
36
+ start: refTime.Now().getTime(),
37
+ result: "success",
38
+ end: refTime.Now(5).getTime(),
39
+ },
40
+ ],
41
+ },
42
+ ]);
43
+ const layered = Array.from(((_a = trace.childs.get("test")) === null || _a === void 0 ? void 0 : _a.childs.values()) || []);
44
+ refTime = WebSysAbstraction({ TimeMode: TimeMode.STEP }).Time();
45
+ expect(layered.map((v) => v.invokes())).toEqual([
46
+ {
47
+ ctx: {
48
+ module: "trace",
49
+ spanId: "test.1",
50
+ value: "important",
51
+ },
52
+ invokations: [
53
+ {
54
+ start: refTime.Now(2).getTime(),
55
+ result: "success",
56
+ end: refTime.Now().getTime(),
57
+ },
58
+ ],
59
+ },
60
+ {
61
+ ctx: {
62
+ module: "trace",
63
+ spanId: "test.2",
64
+ value: "important",
65
+ },
66
+ invokations: [
67
+ {
68
+ start: refTime.Now().getTime(),
69
+ result: "success",
70
+ end: refTime.Now(1).getTime(),
71
+ },
72
+ ],
73
+ },
74
+ ]);
75
+ });
76
+ it("a async simple trace", async () => {
77
+ var _a, _b;
78
+ const log = (_a = trace.ctx.logger) === null || _a === void 0 ? void 0 : _a.With().Str("value", "test").Logger();
79
+ const ret = await trace.span(trace.ctxWith("test", log), async (trace) => {
80
+ var _a;
81
+ const r1 = trace.span(trace.ctxWith("test.1"), () => 1);
82
+ const log2 = (_a = trace.ctx.logger) === null || _a === void 0 ? void 0 : _a.With().Module("xxx").Str("r2", "test.2").Logger();
83
+ const r2 = (await trace.span(trace.ctxWith("test.2", log2), async () => {
84
+ time.Now();
85
+ await new Promise((resolve) => setTimeout(() => {
86
+ time.Now();
87
+ time.Now();
88
+ resolve();
89
+ }, 100));
90
+ return 1;
91
+ }));
92
+ return r1 + r2;
93
+ });
94
+ expect(ret).toBe(2);
95
+ const childs = Array.from(trace.childs.values());
96
+ const exp = childs.map((v) => v.invokes());
97
+ expect(exp).toEqual([
98
+ {
99
+ ctx: {
100
+ module: "trace",
101
+ spanId: "test",
102
+ value: "test",
103
+ },
104
+ invokations: [
105
+ {
106
+ start: refTime.Now().getTime(),
107
+ result: "success",
108
+ end: refTime.Now(8).getTime(),
109
+ },
110
+ ],
111
+ },
112
+ ]);
113
+ const layered = Array.from(((_b = trace.childs.get("test")) === null || _b === void 0 ? void 0 : _b.childs.values()) || []);
114
+ expect(layered.map((v) => v.invokes())).toEqual([
115
+ {
116
+ ctx: {
117
+ module: "trace",
118
+ spanId: "test.1",
119
+ value: "test",
120
+ },
121
+ invokations: [
122
+ {
123
+ result: "success",
124
+ start: refTime.Now(-2).getTime(),
125
+ end: refTime.Now().getTime(),
126
+ },
127
+ ],
128
+ },
129
+ {
130
+ ctx: {
131
+ module: "xxx",
132
+ r2: "test.2",
133
+ spanId: "test.2",
134
+ value: "test",
135
+ },
136
+ invokations: [
137
+ {
138
+ start: refTime.Now().getTime(),
139
+ end: refTime.Now(4).getTime(),
140
+ result: "success",
141
+ },
142
+ ],
143
+ },
144
+ ]);
145
+ });
146
+ it("a async exception trace", async () => {
147
+ var _a;
148
+ const ret = await trace.span("test", async (trace) => {
149
+ let r1 = 0;
150
+ let r2 = 0;
151
+ for (let i = 0; i < 3; i++) {
152
+ try {
153
+ r1 += trace.span("test.1", (trace) => {
154
+ if (i % 2) {
155
+ throw new Error("test.1");
156
+ }
157
+ trace.metrics.get("i.1").add([i]);
158
+ return 1;
159
+ });
160
+ }
161
+ catch (e) {
162
+ if (i % 2) {
163
+ expect(e.message).toEqual("test.1");
164
+ }
165
+ else {
166
+ assert(false, "should not happen");
167
+ }
168
+ }
169
+ try {
170
+ r2 += await trace.span("test.2", async (trace) => {
171
+ time.Now();
172
+ await new Promise((resolve, reject) => setTimeout(() => {
173
+ time.Now();
174
+ time.Now();
175
+ if (i % 2) {
176
+ trace.metrics.get("i.2").add(i);
177
+ resolve();
178
+ }
179
+ else {
180
+ reject("test.2");
181
+ }
182
+ }, 10));
183
+ return 1;
184
+ });
185
+ }
186
+ catch (e) {
187
+ if (i % 2) {
188
+ assert(false, "should not happen");
189
+ }
190
+ else {
191
+ expect(e).toEqual("test.2");
192
+ }
193
+ }
194
+ }
195
+ return r1 + r2;
196
+ });
197
+ expect(ret).toBe(3);
198
+ expect(trace.metrics.toJSON()).toEqual({
199
+ "/test/test.1/i.1": [0, 2],
200
+ "/test/test.2/i.2": 1,
201
+ });
202
+ const childs = Array.from(trace.childs.values());
203
+ const exp = childs.map((v) => v.invokes());
204
+ expect(exp).toEqual([
205
+ {
206
+ ctx: {
207
+ module: "trace",
208
+ spanId: "test",
209
+ value: "important",
210
+ },
211
+ invokations: [
212
+ {
213
+ start: refTime.Now(1).getTime(),
214
+ end: refTime.Now(22).getTime(),
215
+ result: "success",
216
+ },
217
+ ],
218
+ },
219
+ ]);
220
+ const layered = Array.from(((_a = trace.childs.get("test")) === null || _a === void 0 ? void 0 : _a.childs.values()) || []);
221
+ expect(layered.map((v) => v.invokes())).toEqual([
222
+ {
223
+ ctx: {
224
+ module: "trace",
225
+ spanId: "test.1",
226
+ value: "important",
227
+ },
228
+ invokations: [
229
+ {
230
+ start: refTime.Now(-2).getTime(),
231
+ end: refTime.Now().getTime(),
232
+ result: "success",
233
+ },
234
+ {
235
+ start: refTime.Now(-9).getTime(),
236
+ end: refTime.Now().getTime(),
237
+ result: "error",
238
+ },
239
+ {
240
+ start: refTime.Now(-16).getTime(),
241
+ end: refTime.Now().getTime(),
242
+ result: "success",
243
+ },
244
+ ],
245
+ metricRefs: {
246
+ "/test/test.1/i.1": [0, 2],
247
+ },
248
+ },
249
+ {
250
+ ctx: {
251
+ module: "trace",
252
+ spanId: "test.2",
253
+ value: "important",
254
+ },
255
+ invokations: [
256
+ {
257
+ start: refTime.Now(-4).getTime(),
258
+ end: refTime.Now(4).getTime(),
259
+ result: "error",
260
+ },
261
+ {
262
+ start: refTime.Now(-11).getTime(),
263
+ end: refTime.Now(4).getTime(),
264
+ result: "success",
265
+ },
266
+ {
267
+ start: refTime.Now(-18).getTime(),
268
+ end: refTime.Now(4).getTime(),
269
+ result: "error",
270
+ },
271
+ ],
272
+ metricRefs: {
273
+ "/test/test.2/i.2": 1,
274
+ },
275
+ },
276
+ ]);
277
+ });
278
+ });
279
+ describe("metrics", () => {
280
+ let time;
281
+ let trace;
282
+ beforeEach(() => {
283
+ time = WebSysAbstraction({ TimeMode: TimeMode.STEP }).Time();
284
+ trace = TraceNode.root(time);
285
+ });
286
+ it("a simple metrics", () => {
287
+ ["/test", "test", "/test/wurst", "bla"].forEach((path) => {
288
+ const abs = path.startsWith("/") ? path : "/" + path;
289
+ expect(trace.metrics.get(path).path).toBe(abs);
290
+ expect(trace.metrics.get(path).value).toBeFalsy();
291
+ trace.metrics.get(path).add(4711);
292
+ expect(trace.metrics.get(path).value).toBe(4711);
293
+ trace.metrics.get(path).set(undefined);
294
+ });
295
+ });
296
+ it("create metrics path", () => {
297
+ trace.span("test", (trace) => {
298
+ trace.span("test.1", (trace) => {
299
+ trace.metrics.get("m1.1").add(1);
300
+ trace.metrics.get("/test/test.1/m1.1").add(1);
301
+ expect(trace.metrics.get("m1.1").path).toBe("/test/test.1/m1.1");
302
+ expect(trace.metrics.get("m1.1").value).toBe(2);
303
+ });
304
+ });
305
+ });
306
+ it("typed span promise or literal", async () => {
307
+ expect(trace.span("test", () => "1")).toBe("1");
308
+ expect(await trace.span("test", async () => 1)).toBe(1);
309
+ });
310
+ });
311
+ //# sourceMappingURL=tracer.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracer.test.js","sourceRoot":"","sources":["../../src/tracer.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ export interface TxtEnDecoder {
2
+ encode(str: string): Uint8Array;
3
+ decode(data: Uint8Array): string;
4
+ }
5
+ export declare class Utf8EnDecoder implements TxtEnDecoder {
6
+ encode(str: string): Uint8Array;
7
+ decode(data: Uint8Array): string;
8
+ }
9
+ export declare function Utf8EnDecoderSingleton(): TxtEnDecoder;
10
+ //# sourceMappingURL=txt-en-decoder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"txt-en-decoder.d.ts","sourceRoot":"","sources":["../../src/txt-en-decoder.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC;IAChC,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAAC;CAClC;AAKD,qBAAa,aAAc,YAAW,YAAY;IAChD,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU;IAG/B,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM;CAGjC;AAGD,wBAAgB,sBAAsB,IAAI,YAAY,CAErD"}
@@ -0,0 +1,15 @@
1
+ const encoder = new TextEncoder();
2
+ const decoder = new TextDecoder();
3
+ export class Utf8EnDecoder {
4
+ encode(str) {
5
+ return encoder.encode(str);
6
+ }
7
+ decode(data) {
8
+ return decoder.decode(data);
9
+ }
10
+ }
11
+ const utf8EnDecoder = new Utf8EnDecoder();
12
+ export function Utf8EnDecoderSingleton() {
13
+ return utf8EnDecoder;
14
+ }
15
+ //# sourceMappingURL=txt-en-decoder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"txt-en-decoder.js","sourceRoot":"","sources":["../../src/txt-en-decoder.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;AAClC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;AAElC,MAAM,OAAO,aAAa;IACxB,MAAM,CAAC,GAAW;QAChB,OAAO,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IACD,MAAM,CAAC,IAAgB;QACrB,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;CACF;AAED,MAAM,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC;AAC1C,MAAM,UAAU,sBAAsB;IACpC,OAAO,aAAa,CAAC;AACvB,CAAC"}