@pristine-ts/common 2.0.3 → 2.0.5

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 (149) hide show
  1. package/dist/lib/cjs/contexts/event-context.js +5 -5
  2. package/dist/lib/cjs/contexts/event-context.js.map +1 -1
  3. package/dist/lib/cjs/decorators/decorators.js +1 -0
  4. package/dist/lib/cjs/decorators/decorators.js.map +1 -1
  5. package/dist/lib/cjs/decorators/traced.decorator.js +101 -0
  6. package/dist/lib/cjs/decorators/traced.decorator.js.map +1 -0
  7. package/dist/lib/cjs/enums/enums.js +1 -0
  8. package/dist/lib/cjs/enums/enums.js.map +1 -1
  9. package/dist/lib/cjs/enums/span-keyname.enum.js +34 -0
  10. package/dist/lib/cjs/enums/span-keyname.enum.js.map +1 -0
  11. package/dist/lib/cjs/errors/bad-request.error.js +15 -0
  12. package/dist/lib/cjs/errors/bad-request.error.js.map +1 -0
  13. package/dist/lib/cjs/errors/config.error.js +20 -0
  14. package/dist/lib/cjs/errors/config.error.js.map +1 -0
  15. package/dist/lib/cjs/errors/conflict.error.js +15 -0
  16. package/dist/lib/cjs/errors/conflict.error.js.map +1 -0
  17. package/dist/lib/cjs/errors/errors.js +14 -1
  18. package/dist/lib/cjs/errors/errors.js.map +1 -1
  19. package/dist/lib/cjs/errors/exit-code.enum.js +50 -0
  20. package/dist/lib/cjs/errors/exit-code.enum.js.map +1 -0
  21. package/dist/lib/cjs/errors/forbidden.error.js +15 -0
  22. package/dist/lib/cjs/errors/forbidden.error.js.map +1 -0
  23. package/dist/lib/cjs/errors/internal.error.js +19 -0
  24. package/dist/lib/cjs/errors/internal.error.js.map +1 -0
  25. package/dist/lib/cjs/errors/not-found.error.js +15 -0
  26. package/dist/lib/cjs/errors/not-found.error.js.map +1 -0
  27. package/dist/lib/cjs/errors/pristine-error-code.enum.js +37 -0
  28. package/dist/lib/cjs/errors/pristine-error-code.enum.js.map +1 -0
  29. package/dist/lib/cjs/errors/pristine-error-kind.enum.js +29 -0
  30. package/dist/lib/cjs/errors/pristine-error-kind.enum.js.map +1 -0
  31. package/dist/lib/cjs/errors/pristine-error-options.interface.js +3 -0
  32. package/dist/lib/cjs/errors/pristine-error-options.interface.js.map +1 -0
  33. package/dist/lib/cjs/errors/pristine.error.js +109 -0
  34. package/dist/lib/cjs/errors/pristine.error.js.map +1 -0
  35. package/dist/lib/cjs/errors/unauthorized.error.js +15 -0
  36. package/dist/lib/cjs/errors/unauthorized.error.js.map +1 -0
  37. package/dist/lib/cjs/errors/usage.error.js +18 -0
  38. package/dist/lib/cjs/errors/usage.error.js.map +1 -0
  39. package/dist/lib/cjs/errors/validation.error.js +15 -0
  40. package/dist/lib/cjs/errors/validation.error.js.map +1 -0
  41. package/dist/lib/cjs/interfaces/interfaces.js +1 -0
  42. package/dist/lib/cjs/interfaces/interfaces.js.map +1 -1
  43. package/dist/lib/cjs/interfaces/tracing-manager.interface.js +3 -0
  44. package/dist/lib/cjs/interfaces/tracing-manager.interface.js.map +1 -0
  45. package/dist/lib/cjs/managers/event-context.manager.js +9 -0
  46. package/dist/lib/cjs/managers/event-context.manager.js.map +1 -1
  47. package/dist/lib/cjs/models/models.js +4 -0
  48. package/dist/lib/cjs/models/models.js.map +1 -1
  49. package/dist/lib/cjs/models/span-event.model.js +28 -0
  50. package/dist/lib/cjs/models/span-event.model.js.map +1 -0
  51. package/dist/lib/cjs/models/span-lifecycle-owner.interface.js +3 -0
  52. package/dist/lib/cjs/models/span-lifecycle-owner.interface.js.map +1 -0
  53. package/dist/lib/cjs/models/span.model.js +79 -0
  54. package/dist/lib/cjs/models/span.model.js.map +1 -0
  55. package/dist/lib/cjs/models/trace.model.js +46 -0
  56. package/dist/lib/cjs/models/trace.model.js.map +1 -0
  57. package/dist/lib/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  58. package/dist/lib/esm/contexts/event-context.js +5 -5
  59. package/dist/lib/esm/contexts/event-context.js.map +1 -1
  60. package/dist/lib/esm/decorators/decorators.js +1 -0
  61. package/dist/lib/esm/decorators/decorators.js.map +1 -1
  62. package/dist/lib/esm/decorators/traced.decorator.js +98 -0
  63. package/dist/lib/esm/decorators/traced.decorator.js.map +1 -0
  64. package/dist/lib/esm/enums/enums.js +1 -0
  65. package/dist/lib/esm/enums/enums.js.map +1 -1
  66. package/dist/lib/esm/enums/span-keyname.enum.js +31 -0
  67. package/dist/lib/esm/enums/span-keyname.enum.js.map +1 -0
  68. package/dist/lib/esm/errors/bad-request.error.js +11 -0
  69. package/dist/lib/esm/errors/bad-request.error.js.map +1 -0
  70. package/dist/lib/esm/errors/config.error.js +16 -0
  71. package/dist/lib/esm/errors/config.error.js.map +1 -0
  72. package/dist/lib/esm/errors/conflict.error.js +11 -0
  73. package/dist/lib/esm/errors/conflict.error.js.map +1 -0
  74. package/dist/lib/esm/errors/errors.js +14 -1
  75. package/dist/lib/esm/errors/errors.js.map +1 -1
  76. package/dist/lib/esm/errors/exit-code.enum.js +47 -0
  77. package/dist/lib/esm/errors/exit-code.enum.js.map +1 -0
  78. package/dist/lib/esm/errors/forbidden.error.js +11 -0
  79. package/dist/lib/esm/errors/forbidden.error.js.map +1 -0
  80. package/dist/lib/esm/errors/internal.error.js +15 -0
  81. package/dist/lib/esm/errors/internal.error.js.map +1 -0
  82. package/dist/lib/esm/errors/not-found.error.js +11 -0
  83. package/dist/lib/esm/errors/not-found.error.js.map +1 -0
  84. package/dist/lib/esm/errors/pristine-error-code.enum.js +34 -0
  85. package/dist/lib/esm/errors/pristine-error-code.enum.js.map +1 -0
  86. package/dist/lib/esm/errors/pristine-error-kind.enum.js +26 -0
  87. package/dist/lib/esm/errors/pristine-error-kind.enum.js.map +1 -0
  88. package/dist/lib/esm/errors/pristine-error-options.interface.js +2 -0
  89. package/dist/lib/esm/errors/pristine-error-options.interface.js.map +1 -0
  90. package/dist/lib/esm/errors/pristine.error.js +105 -0
  91. package/dist/lib/esm/errors/pristine.error.js.map +1 -0
  92. package/dist/lib/esm/errors/unauthorized.error.js +11 -0
  93. package/dist/lib/esm/errors/unauthorized.error.js.map +1 -0
  94. package/dist/lib/esm/errors/usage.error.js +14 -0
  95. package/dist/lib/esm/errors/usage.error.js.map +1 -0
  96. package/dist/lib/esm/errors/validation.error.js +11 -0
  97. package/dist/lib/esm/errors/validation.error.js.map +1 -0
  98. package/dist/lib/esm/interfaces/interfaces.js +1 -0
  99. package/dist/lib/esm/interfaces/interfaces.js.map +1 -1
  100. package/dist/lib/esm/interfaces/tracing-manager.interface.js +2 -0
  101. package/dist/lib/esm/interfaces/tracing-manager.interface.js.map +1 -0
  102. package/dist/lib/esm/managers/event-context.manager.js +9 -0
  103. package/dist/lib/esm/managers/event-context.manager.js.map +1 -1
  104. package/dist/lib/esm/models/models.js +4 -0
  105. package/dist/lib/esm/models/models.js.map +1 -1
  106. package/dist/lib/esm/models/span-event.model.js +24 -0
  107. package/dist/lib/esm/models/span-event.model.js.map +1 -0
  108. package/dist/lib/esm/models/span-lifecycle-owner.interface.js +2 -0
  109. package/dist/lib/esm/models/span-lifecycle-owner.interface.js.map +1 -0
  110. package/dist/lib/esm/models/span.model.js +75 -0
  111. package/dist/lib/esm/models/span.model.js.map +1 -0
  112. package/dist/lib/esm/models/trace.model.js +42 -0
  113. package/dist/lib/esm/models/trace.model.js.map +1 -0
  114. package/dist/lib/esm/tsconfig.tsbuildinfo +1 -1
  115. package/dist/types/contexts/event-context.d.ts +24 -9
  116. package/dist/types/decorators/decorators.d.ts +1 -0
  117. package/dist/types/decorators/traced.decorator.d.ts +40 -0
  118. package/dist/types/enums/enums.d.ts +1 -0
  119. package/dist/types/enums/span-keyname.enum.d.ts +29 -0
  120. package/dist/types/errors/bad-request.error.d.ts +8 -0
  121. package/dist/types/errors/config.error.d.ts +13 -0
  122. package/dist/types/errors/conflict.error.d.ts +8 -0
  123. package/dist/types/errors/errors.d.ts +14 -1
  124. package/dist/types/errors/exit-code.enum.d.ts +45 -0
  125. package/dist/types/errors/forbidden.error.d.ts +8 -0
  126. package/dist/types/errors/internal.error.d.ts +12 -0
  127. package/dist/types/errors/not-found.error.d.ts +8 -0
  128. package/dist/types/errors/pristine-error-code.enum.d.ts +32 -0
  129. package/dist/types/errors/pristine-error-kind.enum.d.ts +24 -0
  130. package/dist/types/errors/pristine-error-options.interface.d.ts +59 -0
  131. package/dist/types/errors/pristine.error.d.ts +78 -0
  132. package/dist/types/errors/unauthorized.error.d.ts +8 -0
  133. package/dist/types/errors/usage.error.d.ts +11 -0
  134. package/dist/types/errors/validation.error.d.ts +8 -0
  135. package/dist/types/interfaces/interfaces.d.ts +1 -0
  136. package/dist/types/interfaces/module.interface.d.ts +26 -0
  137. package/dist/types/interfaces/tracing-manager.interface.d.ts +78 -0
  138. package/dist/types/managers/event-context.manager.d.ts +4 -0
  139. package/dist/types/models/models.d.ts +4 -0
  140. package/dist/types/models/span-event.model.d.ts +30 -0
  141. package/dist/types/models/span-lifecycle-owner.interface.d.ts +11 -0
  142. package/dist/types/models/span.model.d.ts +82 -0
  143. package/dist/types/models/trace.model.d.ts +53 -0
  144. package/package.json +2 -2
  145. package/dist/lib/cjs/errors/loggable.error.js +0 -19
  146. package/dist/lib/cjs/errors/loggable.error.js.map +0 -1
  147. package/dist/lib/esm/errors/loggable.error.js +0 -15
  148. package/dist/lib/esm/errors/loggable.error.js.map +0 -1
  149. package/dist/types/errors/loggable.error.d.ts +0 -8
@@ -2,4 +2,5 @@ export * from "./http-method.enum";
2
2
  export * from "./internal-container-parameter.enum";
3
3
  export * from "./metadata.enum";
4
4
  export * from "./service-definition-tag.enum";
5
+ export * from "./span-keyname.enum";
5
6
  //# sourceMappingURL=enums.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"enums.js","sourceRoot":"","sources":["../../../../src/enums/enums.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,qCAAqC,CAAC;AACpD,cAAc,iBAAiB,CAAC;AAChC,cAAc,+BAA+B,CAAC"}
1
+ {"version":3,"file":"enums.js","sourceRoot":"","sources":["../../../../src/enums/enums.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,qCAAqC,CAAC;AACpD,cAAc,iBAAiB,CAAC;AAChC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qBAAqB,CAAC"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * This enum is for the different span names that are integrated in Pristine.
3
+ */
4
+ export var SpanKeynameEnum;
5
+ (function (SpanKeynameEnum) {
6
+ SpanKeynameEnum["ChildContainerCreation"] = "child.container.creation";
7
+ SpanKeynameEnum["ChildContainerRegistration"] = "child.container.registration";
8
+ SpanKeynameEnum["ConfigurationInitialization"] = "configuration.initialization";
9
+ SpanKeynameEnum["ErrorResponseInterceptors"] = "error.response.interceptors";
10
+ SpanKeynameEnum["EventDispatcherResolver"] = "event.dispatcher.resolver";
11
+ SpanKeynameEnum["EventExecution"] = "event.execution";
12
+ SpanKeynameEnum["EventInitialization"] = "event.initialization";
13
+ SpanKeynameEnum["EventPreMappingInterception"] = "event.pre-mapping.interception";
14
+ SpanKeynameEnum["EventPostMappingInterception"] = "event.post-mapping.interception";
15
+ SpanKeynameEnum["EventPreResponseMappingInterception"] = "event.pre-response-mapping.interception";
16
+ SpanKeynameEnum["EventPostResponseMappingInterception"] = "event.post-response-mapping.interception";
17
+ SpanKeynameEnum["EventMapping"] = "event.mapping";
18
+ SpanKeynameEnum["KernelInitialization"] = "kernel.initialization";
19
+ SpanKeynameEnum["ModuleInitialization"] = "module.initialization";
20
+ SpanKeynameEnum["ModuleInitializationImportModules"] = "module.initialization.import.modules";
21
+ SpanKeynameEnum["RequestExecution"] = "request.execution";
22
+ SpanKeynameEnum["RequestInterceptors"] = "request.interceptors";
23
+ SpanKeynameEnum["ResponseInterceptors"] = "response.interceptors";
24
+ SpanKeynameEnum["RootExecution"] = "root.execution";
25
+ SpanKeynameEnum["RouterControllerResolver"] = "router.controller.resolver";
26
+ SpanKeynameEnum["RouterFindMethodRouterNode"] = "router.find.method.router.node";
27
+ SpanKeynameEnum["RouterRequestAuthentication"] = "router.request.authentication";
28
+ SpanKeynameEnum["RouterRequestExecution"] = "router.request.execution";
29
+ SpanKeynameEnum["RouterSetup"] = "router.setup";
30
+ })(SpanKeynameEnum || (SpanKeynameEnum = {}));
31
+ //# sourceMappingURL=span-keyname.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"span-keyname.enum.js","sourceRoot":"","sources":["../../../../src/enums/span-keyname.enum.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,CAAN,IAAY,eAyBX;AAzBD,WAAY,eAAe;IACzB,sEAAmD,CAAA;IACnD,8EAA2D,CAAA;IAC3D,+EAA4D,CAAA;IAC5D,4EAAyD,CAAA;IACzD,wEAAqD,CAAA;IACrD,qDAAkC,CAAA;IAClC,+DAA4C,CAAA;IAC5C,iFAA8D,CAAA;IAC9D,mFAAgE,CAAA;IAChE,kGAA+E,CAAA;IAC/E,oGAAiF,CAAA;IACjF,iDAA8B,CAAA;IAC9B,iEAA8C,CAAA;IAC9C,iEAA8C,CAAA;IAC9C,6FAA0E,CAAA;IAC1E,yDAAsC,CAAA;IACtC,+DAA4C,CAAA;IAC5C,iEAA8C,CAAA;IAC9C,mDAAgC,CAAA;IAChC,0EAAuD,CAAA;IACvD,gFAA6D,CAAA;IAC7D,gFAA6D,CAAA;IAC7D,sEAAmD,CAAA;IACnD,+CAA4B,CAAA;AAC9B,CAAC,EAzBW,eAAe,KAAf,eAAe,QAyB1B"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 400. Caller sent malformed/invalid input. CLI exit `ExitCode.DataError` (65). */
6
+ export class BadRequestError extends PristineError {
7
+ constructor(message, options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.BadRequest, httpStatus: 400, exitCode: ExitCode.DataError, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=bad-request.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bad-request.error.js","sourceRoot":"","sources":["../../../../src/errors/bad-request.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,oFAAoF;AACpF,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAChD,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,UAAU,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,SAAS,EACjF,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,16 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /**
6
+ * Configuration loading / parsing / validation failure. No `httpStatus` — config errors
7
+ * shouldn't be exposed to HTTP callers, so the responder will treat them as 500 with
8
+ * sanitized message. CLI exit `ExitCode.Configuration` (78). Marked `SystemError` so the
9
+ * message isn't surfaced verbatim in production HTTP responses.
10
+ */
11
+ export class ConfigError extends PristineError {
12
+ constructor(message, options = {}) {
13
+ super(message, Object.assign({ code: PristineErrorCode.ConfigError, exitCode: ExitCode.Configuration, kind: PristineErrorKind.SystemError }, options));
14
+ }
15
+ }
16
+ //# sourceMappingURL=config.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.error.js","sourceRoot":"","sources":["../../../../src/errors/config.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D;;;;;GAKG;AACH,MAAM,OAAO,WAAY,SAAQ,aAAa;IAC5C,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,WAAW,EAAE,QAAQ,EAAE,QAAQ,CAAC,aAAa,EACrE,IAAI,EAAE,iBAAiB,CAAC,WAAW,IAChC,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 409. Operation conflicts with existing state (duplicate, version mismatch, etc.). */
6
+ export class ConflictError extends PristineError {
7
+ constructor(message, options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.Conflict, httpStatus: 409, exitCode: ExitCode.Error, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=conflict.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conflict.error.js","sourceRoot":"","sources":["../../../../src/errors/conflict.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,wFAAwF;AACxF,MAAM,OAAO,aAAc,SAAQ,aAAa;IAC9C,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,QAAQ,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,KAAK,EAC3E,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -1,2 +1,15 @@
1
- export * from "./loggable.error";
1
+ export * from "./bad-request.error";
2
+ export * from "./config.error";
3
+ export * from "./conflict.error";
4
+ export * from "./exit-code.enum";
5
+ export * from "./forbidden.error";
6
+ export * from "./internal.error";
7
+ export * from "./not-found.error";
8
+ export * from "./pristine-error-code.enum";
9
+ export * from "./pristine-error-kind.enum";
10
+ export * from "./pristine-error-options.interface";
11
+ export * from "./pristine.error";
12
+ export * from "./unauthorized.error";
13
+ export * from "./usage.error";
14
+ export * from "./validation.error";
2
15
  //# sourceMappingURL=errors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../../src/errors/errors.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC"}
1
+ {"version":3,"file":"errors.js","sourceRoot":"","sources":["../../../../src/errors/errors.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,4BAA4B,CAAC;AAC3C,cAAc,oCAAoC,CAAC;AACnD,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Standard process exit codes, drawn from BSD's `sysexits.h` conventions. Surfaced by
3
+ * `CliErrorReporter` and `PristineError.options.exitCode` so shell pipelines can branch on
4
+ * meaningful failure categories rather than the binary "0 or non-zero" distinction.
5
+ *
6
+ * **Use the enum for framework-standard codes.** Consumers can pass raw numbers for any
7
+ * custom exit code — `PristineErrorOptions.exitCode` is typed `ExitCode | number`.
8
+ *
9
+ * Note that exit codes ≥ 64 (`Usage` and above) follow the `sysexits.h` registered
10
+ * meanings; lower codes (1, etc.) are conventional but not standardized.
11
+ *
12
+ * ```ts
13
+ * throw new ConfigError("Missing DATABASE_URL", {
14
+ * exitCode: ExitCode.Configuration, // 78 — picked up by shells aware of sysexits.h
15
+ * });
16
+ *
17
+ * throw new UsageError("Unknown flag --foo", {
18
+ * exitCode: ExitCode.Usage, // 64
19
+ * });
20
+ * ```
21
+ */
22
+ export var ExitCode;
23
+ (function (ExitCode) {
24
+ /** Successful termination. */
25
+ ExitCode[ExitCode["Success"] = 0] = "Success";
26
+ /** Generic error. Default fallback for user-facing errors that don't specify a code. */
27
+ ExitCode[ExitCode["Error"] = 1] = "Error";
28
+ /** Command-line usage error (`EX_USAGE`). Bad flags, missing required args, unknown commands. */
29
+ ExitCode[ExitCode["Usage"] = 64] = "Usage";
30
+ /** Input data malformed (`EX_DATAERR`). Validation failed, body unparseable. */
31
+ ExitCode[ExitCode["DataError"] = 65] = "DataError";
32
+ /** Internal software error (`EX_SOFTWARE`). Default fallback for system errors. */
33
+ ExitCode[ExitCode["Software"] = 70] = "Software";
34
+ /** Can't create user output file (`EX_CANTCREAT`). */
35
+ ExitCode[ExitCode["Cantcreat"] = 73] = "Cantcreat";
36
+ /** Input/output error (`EX_IOERR`). */
37
+ ExitCode[ExitCode["IoError"] = 74] = "IoError";
38
+ /** Temporary failure, retry might succeed (`EX_TEMPFAIL`). */
39
+ ExitCode[ExitCode["Temporary"] = 75] = "Temporary";
40
+ /** Remote error in protocol (`EX_PROTOCOL`). */
41
+ ExitCode[ExitCode["Protocol"] = 76] = "Protocol";
42
+ /** Permission denied (`EX_NOPERM`). Authentication / authorization failures. */
43
+ ExitCode[ExitCode["NoPermission"] = 77] = "NoPermission";
44
+ /** Configuration error (`EX_CONFIG`). Missing or invalid config. */
45
+ ExitCode[ExitCode["Configuration"] = 78] = "Configuration";
46
+ })(ExitCode || (ExitCode = {}));
47
+ //# sourceMappingURL=exit-code.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exit-code.enum.js","sourceRoot":"","sources":["../../../../src/errors/exit-code.enum.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAN,IAAY,QAiCX;AAjCD,WAAY,QAAQ;IAClB,8BAA8B;IAC9B,6CAAmB,CAAA;IAEnB,wFAAwF;IACxF,yCAAmB,CAAA;IAEnB,iGAAiG;IACjG,0CAAoB,CAAA;IAEpB,gFAAgF;IAChF,kDAAoB,CAAA;IAEpB,mFAAmF;IACnF,gDAAoB,CAAA;IAEpB,sDAAsD;IACtD,kDAAoB,CAAA;IAEpB,uCAAuC;IACvC,8CAAoB,CAAA;IAEpB,8DAA8D;IAC9D,kDAAoB,CAAA;IAEpB,gDAAgD;IAChD,gDAAoB,CAAA;IAEpB,gFAAgF;IAChF,wDAAoB,CAAA;IAEpB,oEAAoE;IACpE,0DAAoB,CAAA;AACtB,CAAC,EAjCW,QAAQ,KAAR,QAAQ,QAiCnB"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 403. Caller is authenticated but lacks permission. CLI exit `ExitCode.NoPermission` (77). */
6
+ export class ForbiddenError extends PristineError {
7
+ constructor(message = "Forbidden", options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.Forbidden, httpStatus: 403, exitCode: ExitCode.NoPermission, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=forbidden.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"forbidden.error.js","sourceRoot":"","sources":["../../../../src/errors/forbidden.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,gGAAgG;AAChG,MAAM,OAAO,cAAe,SAAQ,aAAa;IAC/C,YAAY,UAAkB,WAAW,EAAE,UAA2B,EAAE;QACtE,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,SAAS,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,YAAY,EACnF,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,15 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /**
6
+ * Catch-all for framework/system bugs that shouldn't be exposed verbatim. 500.
7
+ * CLI exit `ExitCode.Software` (70). `SystemError` triggers message sanitization in
8
+ * production mode.
9
+ */
10
+ export class InternalError extends PristineError {
11
+ constructor(message = "Internal error", options = {}) {
12
+ super(message, Object.assign({ code: PristineErrorCode.InternalError, httpStatus: 500, exitCode: ExitCode.Software, kind: PristineErrorKind.SystemError }, options));
13
+ }
14
+ }
15
+ //# sourceMappingURL=internal.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"internal.error.js","sourceRoot":"","sources":["../../../../src/errors/internal.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D;;;;GAIG;AACH,MAAM,OAAO,aAAc,SAAQ,aAAa;IAC9C,YAAY,UAAkB,gBAAgB,EAAE,UAA2B,EAAE;QAC3E,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,aAAa,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,EACnF,IAAI,EAAE,iBAAiB,CAAC,WAAW,IAChC,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 404. Resource doesn't exist. CLI exit `ExitCode.Error` (1). */
6
+ export class NotFoundError extends PristineError {
7
+ constructor(message, options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.NotFound, httpStatus: 404, exitCode: ExitCode.Error, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=not-found.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"not-found.error.js","sourceRoot":"","sources":["../../../../src/errors/not-found.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,kEAAkE;AAClE,MAAM,OAAO,aAAc,SAAQ,aAAa;IAC9C,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,QAAQ,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,KAAK,EAC3E,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Standard error-code catalog used across the framework. Each value is a `SCREAMING_SNAKE_CASE`
3
+ * slug surfaced in the HTTP response body (`{"code": ...}`) and on CLI stderr (`✗ CODE: ...`).
4
+ *
5
+ * **Use the enum members for framework-standard cases.** Consumers can add their own
6
+ * domain-specific codes by passing a plain string — `PristineErrorOptions.code` is typed
7
+ * `PristineErrorCode | string` so both the enum and free-form strings get autocomplete-
8
+ * friendly type checking.
9
+ *
10
+ * ```ts
11
+ * throw new PristineError("Token expired", {
12
+ * code: "TOKEN_EXPIRED", // consumer-defined code
13
+ * httpStatus: 401,
14
+ * });
15
+ *
16
+ * throw new PristineError("Item missing", {
17
+ * code: PristineErrorCode.NotFound, // framework-standard code
18
+ * httpStatus: 404,
19
+ * });
20
+ * ```
21
+ */
22
+ export var PristineErrorCode;
23
+ (function (PristineErrorCode) {
24
+ PristineErrorCode["BadRequest"] = "BAD_REQUEST";
25
+ PristineErrorCode["Unauthorized"] = "UNAUTHORIZED";
26
+ PristineErrorCode["Forbidden"] = "FORBIDDEN";
27
+ PristineErrorCode["NotFound"] = "NOT_FOUND";
28
+ PristineErrorCode["Conflict"] = "CONFLICT";
29
+ PristineErrorCode["ValidationFailed"] = "VALIDATION_FAILED";
30
+ PristineErrorCode["ConfigError"] = "CONFIG_ERROR";
31
+ PristineErrorCode["UsageError"] = "USAGE_ERROR";
32
+ PristineErrorCode["InternalError"] = "INTERNAL_ERROR";
33
+ })(PristineErrorCode || (PristineErrorCode = {}));
34
+ //# sourceMappingURL=pristine-error-code.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pristine-error-code.enum.js","sourceRoot":"","sources":["../../../../src/errors/pristine-error-code.enum.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAN,IAAY,iBAUX;AAVD,WAAY,iBAAiB;IAC3B,+CAAiC,CAAA;IACjC,kDAAkC,CAAA;IAClC,4CAA+B,CAAA;IAC/B,2CAA+B,CAAA;IAC/B,0CAA8B,CAAA;IAC9B,2DAAuC,CAAA;IACvC,iDAAkC,CAAA;IAClC,+CAAiC,CAAA;IACjC,qDAAoC,CAAA;AACtC,CAAC,EAVW,iBAAiB,KAAjB,iBAAiB,QAU5B"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Categorizes a `PristineError` by who caused it. Replaces the older `expected: boolean`
3
+ * field, whose meaning ("expected by whom?") wasn't self-explanatory.
4
+ *
5
+ * The kind drives how the channel reporters render the error in production mode:
6
+ *
7
+ * - `UserError`: caller did something wrong. Message is safe to expose verbatim;
8
+ * structured details surface as-is. HTTP responses use the carried `httpStatus`
9
+ * (typically 4xx). CLI stderr shows the message and details.
10
+ *
11
+ * - `SystemError`: framework or downstream bug — not the caller's fault. In production
12
+ * mode the message is replaced with a generic "Internal Server Error" / "Internal Error"
13
+ * so internal details never leak to clients. Stack and cause chain are still logged
14
+ * internally via the LogHandler for operators. In development mode (`PRISTINE_ENV=dev`)
15
+ * the full message surfaces.
16
+ *
17
+ * Default is `UserError` — most thrown errors in framework and application code are caller-
18
+ * induced. `PristineError.from(unknown)` marks raw `Error` and non-Error throws as
19
+ * `SystemError` since they didn't opt into the typed contract.
20
+ */
21
+ export var PristineErrorKind;
22
+ (function (PristineErrorKind) {
23
+ PristineErrorKind["UserError"] = "user-error";
24
+ PristineErrorKind["SystemError"] = "system-error";
25
+ })(PristineErrorKind || (PristineErrorKind = {}));
26
+ //# sourceMappingURL=pristine-error-kind.enum.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pristine-error-kind.enum.js","sourceRoot":"","sources":["../../../../src/errors/pristine-error-kind.enum.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,6CAA0B,CAAA;IAC1B,iDAA4B,CAAA;AAC9B,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pristine-error-options.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pristine-error-options.interface.js","sourceRoot":"","sources":["../../../../src/errors/pristine-error-options.interface.ts"],"names":[],"mappings":""}
@@ -0,0 +1,105 @@
1
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
2
+ /**
3
+ * Single error base for the entire framework. Replaces the old `LoggableError` +
4
+ * `HttpError` + ad-hoc subclass hierarchy.
5
+ *
6
+ * **What it gives you**:
7
+ * - A structured `options` bag (`code`, `httpStatus`, `exitCode`, `details`, `cause`,
8
+ * `kind`) read by both the HTTP and CLI channel reporters.
9
+ * - Automatic `error.name = ClassName` for subclasses.
10
+ * - Automatic prototype-chain fix via `new.target.prototype` — subclasses never need to
11
+ * repeat the `Object.setPrototypeOf(this, FooError.prototype)` incantation, AND
12
+ * `instanceof` works correctly for direct/standard-library/custom subclasses at any
13
+ * depth (verified by spec).
14
+ * - Standard `Error.cause` propagation (Node 16.9+ native).
15
+ *
16
+ * **Subclass form** when a named class makes `instanceof` checks read better:
17
+ *
18
+ * ```ts
19
+ * export class TokenExpiredError extends UnauthorizedError {
20
+ * constructor(tokenId: string) {
21
+ * super("The token has expired", {
22
+ * code: "TOKEN_EXPIRED",
23
+ * details: { tokenId },
24
+ * });
25
+ * }
26
+ * }
27
+ * // ...
28
+ * try { ... }
29
+ * catch (e) { if (e instanceof TokenExpiredError) ... } // works.
30
+ * ```
31
+ *
32
+ * **Direct form** when the call site self-documents:
33
+ *
34
+ * ```ts
35
+ * throw new PristineError(`User '${id}' not found`, {
36
+ * code: PristineErrorCode.NotFound,
37
+ * httpStatus: 404,
38
+ * details: { resource: "User", id },
39
+ * });
40
+ * ```
41
+ *
42
+ * **Re-throw with enrichment** when catching, adding context, and re-throwing. Use the
43
+ * standard `cause` chain rather than mutating the original — this preserves the original
44
+ * error's identity for tooling that walks `error.cause`:
45
+ *
46
+ * ```ts
47
+ * try { await dispatcher.dispatch(event); }
48
+ * catch (cause) {
49
+ * throw new PristineError("Event dispatch failed", {
50
+ * code: "EVENT_DISPATCH_FAILED",
51
+ * kind: PristineErrorKind.SystemError,
52
+ * cause,
53
+ * details: { eventId: event.id },
54
+ * });
55
+ * }
56
+ * ```
57
+ */
58
+ export class PristineError extends Error {
59
+ constructor(message, options = {}) {
60
+ // Use the standard Error.cause slot so any tooling that knows the standard chain
61
+ // (debuggers, V8's default Error formatting, OpenTelemetry's exception recording)
62
+ // picks it up automatically. We don't need a custom `originalError` slot.
63
+ super(message, { cause: options.cause });
64
+ // `new.target` is the actual class being constructed (subclass or PristineError
65
+ // itself). Using it for both `name` and `setPrototypeOf` means subclasses never need
66
+ // to repeat the boilerplate, and `instanceof` works correctly at every depth.
67
+ this.name = new.target.name;
68
+ Object.setPrototypeOf(this, new.target.prototype);
69
+ // `kind: UserError` is the default — most thrown errors are caller-induced. System
70
+ // errors get marked explicitly via `kind: PristineErrorKind.SystemError` (or by
71
+ // `PristineError.from` for unknown throws).
72
+ this.options = Object.assign({ kind: PristineErrorKind.UserError }, options);
73
+ }
74
+ /**
75
+ * Normalizes any thrown value into a `PristineError`. The chokepoint that every channel
76
+ * reporter funnels through before rendering, so the reporters never need to handle
77
+ * unknown shapes.
78
+ *
79
+ * - `PristineError` instances pass through unchanged.
80
+ * - `Error` instances are wrapped with `kind: SystemError` and propagated as `cause` —
81
+ * the wrapper preserves the original message and stack for `mode === Development`
82
+ * rendering.
83
+ * - Anything else (strings, numbers, `throw {someObject}`) is coerced via `String(...)`
84
+ * into a message with `kind: SystemError`.
85
+ *
86
+ * The standard `Error.cause` chain is preserved: if the input has a `cause`, it stays
87
+ * on the wrapper (which itself has the input as its cause), so a debugger walking
88
+ * `error.cause.cause.cause` sees the full history.
89
+ */
90
+ static from(error) {
91
+ if (error instanceof PristineError) {
92
+ return error;
93
+ }
94
+ if (error instanceof Error) {
95
+ return new PristineError(error.message, {
96
+ cause: error,
97
+ kind: PristineErrorKind.SystemError,
98
+ });
99
+ }
100
+ return new PristineError(String(error), {
101
+ kind: PristineErrorKind.SystemError,
102
+ });
103
+ }
104
+ }
105
+ //# sourceMappingURL=pristine.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pristine.error.js","sourceRoot":"","sources":["../../../../src/errors/pristine.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAG7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuDG;AACH,MAAM,OAAO,aAAc,SAAQ,KAAK;IAGtC,YAAY,OAAe,EAAE,UAAgC,EAAE;QAC7D,iFAAiF;QACjF,kFAAkF;QAClF,0EAA0E;QAC1E,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;QAEzC,gFAAgF;QAChF,qFAAqF;QACrF,8EAA8E;QAC9E,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC5B,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAElD,mFAAmF;QACnF,gFAAgF;QAChF,4CAA4C;QAC5C,IAAI,CAAC,OAAO,mBAAK,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAAK,OAAO,CAAE,CAAC;IACnE,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACH,MAAM,CAAC,IAAI,CAAC,KAAc;QACxB,IAAI,KAAK,YAAY,aAAa,EAAE,CAAC;YACnC,OAAO,KAAK,CAAC;QACf,CAAC;QACD,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAC3B,OAAO,IAAI,aAAa,CAAC,KAAK,CAAC,OAAO,EAAE;gBACtC,KAAK,EAAE,KAAK;gBACZ,IAAI,EAAE,iBAAiB,CAAC,WAAW;aACpC,CAAC,CAAC;QACL,CAAC;QACD,OAAO,IAAI,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YACtC,IAAI,EAAE,iBAAiB,CAAC,WAAW;SACpC,CAAC,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 401. Caller is not authenticated. CLI exit `ExitCode.NoPermission` (77). */
6
+ export class UnauthorizedError extends PristineError {
7
+ constructor(message = "Unauthorized", options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.Unauthorized, httpStatus: 401, exitCode: ExitCode.NoPermission, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=unauthorized.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unauthorized.error.js","sourceRoot":"","sources":["../../../../src/errors/unauthorized.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,+EAA+E;AAC/E,MAAM,OAAO,iBAAkB,SAAQ,aAAa;IAClD,YAAY,UAAkB,cAAc,EAAE,UAA2B,EAAE;QACzE,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,YAAY,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,YAAY,EACtF,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,14 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /**
6
+ * CLI-only — bad command-line usage (wrong flag, missing required arg, unknown command).
7
+ * No `httpStatus`. CLI exit `ExitCode.Usage` (64).
8
+ */
9
+ export class UsageError extends PristineError {
10
+ constructor(message, options = {}) {
11
+ super(message, Object.assign({ code: PristineErrorCode.UsageError, exitCode: ExitCode.Usage, kind: PristineErrorKind.UserError }, options));
12
+ }
13
+ }
14
+ //# sourceMappingURL=usage.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usage.error.js","sourceRoot":"","sources":["../../../../src/errors/usage.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D;;;GAGG;AACH,MAAM,OAAO,UAAW,SAAQ,aAAa;IAC3C,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,UAAU,EAAE,QAAQ,EAAE,QAAQ,CAAC,KAAK,EAC5D,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import { ExitCode } from "./exit-code.enum";
2
+ import { PristineError } from "./pristine.error";
3
+ import { PristineErrorCode } from "./pristine-error-code.enum";
4
+ import { PristineErrorKind } from "./pristine-error-kind.enum";
5
+ /** 422. Input parsed but failed semantic validation. CLI exit `ExitCode.DataError` (65). */
6
+ export class ValidationError extends PristineError {
7
+ constructor(message, options = {}) {
8
+ super(message, Object.assign({ code: PristineErrorCode.ValidationFailed, httpStatus: 422, exitCode: ExitCode.DataError, kind: PristineErrorKind.UserError }, options));
9
+ }
10
+ }
11
+ //# sourceMappingURL=validation.error.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.error.js","sourceRoot":"","sources":["../../../../src/errors/validation.error.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4BAA4B,CAAC;AAK7D,4FAA4F;AAC5F,MAAM,OAAO,eAAgB,SAAQ,aAAa;IAChD,YAAY,OAAe,EAAE,UAA2B,EAAE;QACxD,KAAK,CAAC,OAAO,kBACX,IAAI,EAAE,iBAAiB,CAAC,gBAAgB,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,CAAC,SAAS,EACvF,IAAI,EAAE,iBAAiB,CAAC,SAAS,IAC9B,OAAO,EACV,CAAC;IACL,CAAC;CACF"}
@@ -9,5 +9,6 @@ export * from "./module-scoped-registration.interface";
9
9
  export * from "./resolver.interface";
10
10
  export * from "./tagged-registration.interface";
11
11
  export * from "./token-provider-registration.interface";
12
+ export * from "./tracing-manager.interface";
12
13
  export * from "./value-provider-registration.interface";
13
14
  //# sourceMappingURL=interfaces.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../../src/interfaces/interfaces.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,yCAAyC,CAAC;AACxD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wCAAwC,CAAC;AACvD,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,yCAAyC,CAAC;AACxD,cAAc,yCAAyC,CAAC"}
1
+ {"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../../src/interfaces/interfaces.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,yCAAyC,CAAC;AACxD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,4CAA4C,CAAC;AAC3D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wCAAwC,CAAC;AACvD,cAAc,sBAAsB,CAAC;AACrC,cAAc,iCAAiC,CAAC;AAChD,cAAc,yCAAyC,CAAC;AACxD,cAAc,6BAA6B,CAAC;AAC5C,cAAc,yCAAyC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tracing-manager.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tracing-manager.interface.js","sourceRoot":"","sources":["../../../../src/interfaces/tracing-manager.interface.ts"],"names":[],"mappings":""}
@@ -53,6 +53,11 @@ let EventContextManager = EventContextManager_1 = class EventContextManager {
53
53
  var _a;
54
54
  return (_a = this.current()) === null || _a === void 0 ? void 0 : _a.container;
55
55
  }
56
+ /** Convenience: the `TracingManager` that owns this event's trace, or `undefined`. */
57
+ tracingManager() {
58
+ var _a;
59
+ return (_a = this.current()) === null || _a === void 0 ? void 0 : _a.tracingManager;
60
+ }
56
61
  /**
57
62
  * Returns a wrapped version of `fn` that restores the current context on call. Use
58
63
  * when you need to spawn work that escapes the natural async chain (e.g. a callback
@@ -88,6 +93,10 @@ let EventContextManager = EventContextManager_1 = class EventContextManager {
88
93
  var _a;
89
94
  return (_a = EventContextManager_1.current()) === null || _a === void 0 ? void 0 : _a.container;
90
95
  }
96
+ static tracingManager() {
97
+ var _a;
98
+ return (_a = EventContextManager_1.current()) === null || _a === void 0 ? void 0 : _a.tracingManager;
99
+ }
91
100
  static bind(fn) {
92
101
  const ctx = EventContextManager_1.current();
93
102
  if (ctx === undefined)
@@ -1 +1 @@
1
- {"version":3,"file":"event-context.manager.js","sourceRoot":"","sources":["../../../../src/managers/event-context.manager.ts"],"names":[],"mappings":";;;;;;;AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAsB,UAAU,EAAC,MAAM,UAAU,CAAC;AAGzD;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEI,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAU9B,GAAG,CAAI,GAAiB,EAAE,EAAwB;QAChD,OAAO,qBAAmB,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED;iDAC6C;IAC7C,OAAO;QACL,OAAO,qBAAmB,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IAED,wEAAwE;IACxE,OAAO;;QACL,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IACjC,CAAC;IAED,wEAAwE;IACxE,OAAO;;QACL,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IACjC,CAAC;IAED,qEAAqE;IACrE,SAAS;;QACP,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,SAAS,CAAC;IACnC,CAAC;IAED;;;;;;;;OAQG;IACH,IAAI,CAAoC,EAAK;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC3B,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,qBAAmB,CAAC,GAAG,CAAC;QACpC,OAAO,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAM,CAAC;IACpE,CAAC;IAED,kFAAkF;IAClF,+EAA+E;IAC/E,+EAA+E;IAC/E,uBAAuB;IAEvB,MAAM,CAAC,OAAO;QACZ,OAAO,qBAAmB,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IAED,MAAM,CAAC,OAAO;;QACZ,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,OAAO;;QACZ,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,SAAS;;QACd,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,SAAS,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,IAAI,CAAoC,EAAK;QAClD,MAAM,GAAG,GAAG,qBAAmB,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,qBAAmB,CAAC,GAAG,CAAC;QACpC,OAAO,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAM,CAAC;IACpE,CAAC;;AA5EuB,uBAAG,GAAG,IAAI,iBAAiB,EAAgB,AAAxC,CAAyC;AADzD,mBAAmB;IAD/B,UAAU,EAAE;GACA,mBAAmB,CA8E/B"}
1
+ {"version":3,"file":"event-context.manager.js","sourceRoot":"","sources":["../../../../src/managers/event-context.manager.ts"],"names":[],"mappings":";;;;;;;AAAA,OAAO,EAAC,iBAAiB,EAAC,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAsB,UAAU,EAAC,MAAM,UAAU,CAAC;AAIzD;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEI,IAAM,mBAAmB,2BAAzB,MAAM,mBAAmB;IAU9B,GAAG,CAAI,GAAiB,EAAE,EAAwB;QAChD,OAAO,qBAAmB,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED;iDAC6C;IAC7C,OAAO;QACL,OAAO,qBAAmB,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IAED,wEAAwE;IACxE,OAAO;;QACL,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IACjC,CAAC;IAED,wEAAwE;IACxE,OAAO;;QACL,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IACjC,CAAC;IAED,qEAAqE;IACrE,SAAS;;QACP,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,SAAS,CAAC;IACnC,CAAC;IAED,sFAAsF;IACtF,cAAc;;QACZ,OAAO,MAAA,IAAI,CAAC,OAAO,EAAE,0CAAE,cAAc,CAAC;IACxC,CAAC;IAED;;;;;;;;OAQG;IACH,IAAI,CAAoC,EAAK;QAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC3B,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,qBAAmB,CAAC,GAAG,CAAC;QACpC,OAAO,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAM,CAAC;IACpE,CAAC;IAED,kFAAkF;IAClF,+EAA+E;IAC/E,+EAA+E;IAC/E,uBAAuB;IAEvB,MAAM,CAAC,OAAO;QACZ,OAAO,qBAAmB,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IAC5C,CAAC;IAED,MAAM,CAAC,OAAO;;QACZ,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,OAAO;;QACZ,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,OAAO,CAAC;IAChD,CAAC;IAED,MAAM,CAAC,SAAS;;QACd,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,SAAS,CAAC;IAClD,CAAC;IAED,MAAM,CAAC,cAAc;;QACnB,OAAO,MAAA,qBAAmB,CAAC,OAAO,EAAE,0CAAE,cAAc,CAAC;IACvD,CAAC;IAED,MAAM,CAAC,IAAI,CAAoC,EAAK;QAClD,MAAM,GAAG,GAAG,qBAAmB,CAAC,OAAO,EAAE,CAAC;QAC1C,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACjC,MAAM,GAAG,GAAG,qBAAmB,CAAC,GAAG,CAAC;QACpC,OAAO,CAAC,CAAC,GAAG,IAAW,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAM,CAAC;IACpE,CAAC;;AArFuB,uBAAG,GAAG,IAAI,iBAAiB,EAAgB,AAAxC,CAAyC;AADzD,mBAAmB;IAD/B,UAAU,EAAE;GACA,mBAAmB,CAuF/B"}
@@ -1,3 +1,7 @@
1
1
  export * from "./request";
2
2
  export * from "./response";
3
+ export * from "./span-event.model";
4
+ export * from "./span-lifecycle-owner.interface";
5
+ export * from "./span.model";
6
+ export * from "./trace.model";
3
7
  //# sourceMappingURL=models.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../src/models/models.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"models.js","sourceRoot":"","sources":["../../../../src/models/models.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,kCAAkC,CAAC;AACjD,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * A named, timestamped marker attached to a `Span`. Represents a noteworthy moment
3
+ * inside the span's lifetime that doesn't warrant a child span of its own — e.g.
4
+ * "validation passed", "rate limit check ok", "found 50 rows in DB".
5
+ *
6
+ * Modeled after OpenTelemetry's "span events" concept: a `Span` carries `events: SpanEvent[]`
7
+ * alongside its `children: Span[]`. Renderers (the console/file tracer output, etc.) interleave
8
+ * events with spans by timestamp to produce a chronological trail of what happened during the span.
9
+ *
10
+ * Use `TracingManager.addEventToCurrentSpan(message, attributes?)` to add one — it finds
11
+ * the most-recently-started in-progress span and attaches the event there.
12
+ */
13
+ export class SpanEvent {
14
+ constructor(message, attributes) {
15
+ this.message = message;
16
+ /**
17
+ * The timestamp in milliseconds at which the event was created. Used to interleave
18
+ * events with sibling spans when rendering a sorted trail.
19
+ */
20
+ this.timestamp = Date.now();
21
+ this.attributes = attributes;
22
+ }
23
+ }
24
+ //# sourceMappingURL=span-event.model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"span-event.model.js","sourceRoot":"","sources":["../../../../src/models/span-event.model.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AACH,MAAM,OAAO,SAAS;IAapB,YAA4B,OAAe,EAAE,UAAsC;QAAvD,YAAO,GAAP,OAAO,CAAQ;QAZ3C;;;WAGG;QACa,cAAS,GAAW,IAAI,CAAC,GAAG,EAAE,CAAC;QAS7C,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC/B,CAAC;CACF"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=span-lifecycle-owner.interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"span-lifecycle-owner.interface.js","sourceRoot":"","sources":["../../../../src/models/span-lifecycle-owner.interface.ts"],"names":[],"mappings":""}