@dbos-inc/dbos-cloud 0.8.41-preview

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 (170) hide show
  1. package/cli.ts +177 -0
  2. package/dist/packages/dbos-cloud/applications/delete-app.d.ts +2 -0
  3. package/dist/packages/dbos-cloud/applications/delete-app.d.ts.map +1 -0
  4. package/dist/packages/dbos-cloud/applications/delete-app.js +42 -0
  5. package/dist/packages/dbos-cloud/applications/delete-app.js.map +1 -0
  6. package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts +2 -0
  7. package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts.map +1 -0
  8. package/dist/packages/dbos-cloud/applications/deploy-app-code.js +145 -0
  9. package/dist/packages/dbos-cloud/applications/deploy-app-code.js.map +1 -0
  10. package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts +2 -0
  11. package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts.map +1 -0
  12. package/dist/packages/dbos-cloud/applications/get-app-logs.js +42 -0
  13. package/dist/packages/dbos-cloud/applications/get-app-logs.js.map +1 -0
  14. package/dist/packages/dbos-cloud/applications/index.d.ts +7 -0
  15. package/dist/packages/dbos-cloud/applications/index.d.ts.map +1 -0
  16. package/dist/packages/dbos-cloud/applications/index.js +16 -0
  17. package/dist/packages/dbos-cloud/applications/index.js.map +1 -0
  18. package/dist/packages/dbos-cloud/applications/list-apps.d.ts +2 -0
  19. package/dist/packages/dbos-cloud/applications/list-apps.d.ts.map +1 -0
  20. package/dist/packages/dbos-cloud/applications/list-apps.js +45 -0
  21. package/dist/packages/dbos-cloud/applications/list-apps.js.map +1 -0
  22. package/dist/packages/dbos-cloud/applications/register-app.d.ts +2 -0
  23. package/dist/packages/dbos-cloud/applications/register-app.d.ts.map +1 -0
  24. package/dist/packages/dbos-cloud/applications/register-app.js +48 -0
  25. package/dist/packages/dbos-cloud/applications/register-app.js.map +1 -0
  26. package/dist/packages/dbos-cloud/applications/types.d.ts +9 -0
  27. package/dist/packages/dbos-cloud/applications/types.d.ts.map +1 -0
  28. package/dist/packages/dbos-cloud/applications/types.js +3 -0
  29. package/dist/packages/dbos-cloud/applications/types.js.map +1 -0
  30. package/dist/packages/dbos-cloud/applications/update-app.d.ts +2 -0
  31. package/dist/packages/dbos-cloud/applications/update-app.d.ts.map +1 -0
  32. package/dist/packages/dbos-cloud/applications/update-app.js +49 -0
  33. package/dist/packages/dbos-cloud/applications/update-app.js.map +1 -0
  34. package/dist/packages/dbos-cloud/cli.d.ts +3 -0
  35. package/dist/packages/dbos-cloud/cli.d.ts.map +1 -0
  36. package/dist/packages/dbos-cloud/cli.js +149 -0
  37. package/dist/packages/dbos-cloud/cli.js.map +1 -0
  38. package/dist/packages/dbos-cloud/cloudutils.d.ts +5 -0
  39. package/dist/packages/dbos-cloud/cloudutils.d.ts.map +1 -0
  40. package/dist/packages/dbos-cloud/cloudutils.js +47 -0
  41. package/dist/packages/dbos-cloud/cloudutils.js.map +1 -0
  42. package/dist/packages/dbos-cloud/login.d.ts +9 -0
  43. package/dist/packages/dbos-cloud/login.d.ts.map +1 -0
  44. package/dist/packages/dbos-cloud/login.js +102 -0
  45. package/dist/packages/dbos-cloud/login.js.map +1 -0
  46. package/dist/packages/dbos-cloud/register.d.ts +2 -0
  47. package/dist/packages/dbos-cloud/register.d.ts.map +1 -0
  48. package/dist/packages/dbos-cloud/register.js +40 -0
  49. package/dist/packages/dbos-cloud/register.js.map +1 -0
  50. package/dist/packages/dbos-cloud/userdb.d.ts +13 -0
  51. package/dist/packages/dbos-cloud/userdb.d.ts.map +1 -0
  52. package/dist/packages/dbos-cloud/userdb.js +266 -0
  53. package/dist/packages/dbos-cloud/userdb.js.map +1 -0
  54. package/dist/schemas/system_db_schema.d.ts +34 -0
  55. package/dist/schemas/system_db_schema.d.ts.map +1 -0
  56. package/dist/schemas/system_db_schema.js +77 -0
  57. package/dist/schemas/system_db_schema.js.map +1 -0
  58. package/dist/schemas/user_db_schema.d.ts +11 -0
  59. package/dist/schemas/user_db_schema.d.ts.map +1 -0
  60. package/dist/schemas/user_db_schema.js +16 -0
  61. package/dist/schemas/user_db_schema.js.map +1 -0
  62. package/dist/src/communicator.d.ts +25 -0
  63. package/dist/src/communicator.d.ts.map +1 -0
  64. package/dist/src/communicator.js +26 -0
  65. package/dist/src/communicator.js.map +1 -0
  66. package/dist/src/context.d.ts +64 -0
  67. package/dist/src/context.d.ts.map +1 -0
  68. package/dist/src/context.js +96 -0
  69. package/dist/src/context.js.map +1 -0
  70. package/dist/src/data_validation.d.ts +3 -0
  71. package/dist/src/data_validation.d.ts.map +1 -0
  72. package/dist/src/data_validation.js +168 -0
  73. package/dist/src/data_validation.js.map +1 -0
  74. package/dist/src/dbos-executor.d.ts +102 -0
  75. package/dist/src/dbos-executor.d.ts.map +1 -0
  76. package/dist/src/dbos-executor.js +631 -0
  77. package/dist/src/dbos-executor.js.map +1 -0
  78. package/dist/src/dbos-runtime/applicationVersion.d.ts +3 -0
  79. package/dist/src/dbos-runtime/applicationVersion.d.ts.map +1 -0
  80. package/dist/src/dbos-runtime/applicationVersion.js +13 -0
  81. package/dist/src/dbos-runtime/applicationVersion.js.map +1 -0
  82. package/dist/src/dbos-runtime/cli.d.ts +8 -0
  83. package/dist/src/dbos-runtime/cli.d.ts.map +1 -0
  84. package/dist/src/dbos-runtime/cli.js +47 -0
  85. package/dist/src/dbos-runtime/cli.js.map +1 -0
  86. package/dist/src/dbos-runtime/config.d.ts +29 -0
  87. package/dist/src/dbos-runtime/config.d.ts.map +1 -0
  88. package/dist/src/dbos-runtime/config.js +111 -0
  89. package/dist/src/dbos-runtime/config.js.map +1 -0
  90. package/dist/src/dbos-runtime/debug.d.ts +4 -0
  91. package/dist/src/dbos-runtime/debug.d.ts.map +1 -0
  92. package/dist/src/dbos-runtime/debug.js +21 -0
  93. package/dist/src/dbos-runtime/debug.js.map +1 -0
  94. package/dist/src/dbos-runtime/init.d.ts +7 -0
  95. package/dist/src/dbos-runtime/init.d.ts.map +1 -0
  96. package/dist/src/dbos-runtime/init.js +51 -0
  97. package/dist/src/dbos-runtime/init.js.map +1 -0
  98. package/dist/src/dbos-runtime/runtime.d.ts +28 -0
  99. package/dist/src/dbos-runtime/runtime.d.ts.map +1 -0
  100. package/dist/src/dbos-runtime/runtime.js +95 -0
  101. package/dist/src/dbos-runtime/runtime.js.map +1 -0
  102. package/dist/src/debugger/debug_workflow.d.ts +38 -0
  103. package/dist/src/debugger/debug_workflow.d.ts.map +1 -0
  104. package/dist/src/debugger/debug_workflow.js +211 -0
  105. package/dist/src/debugger/debug_workflow.js.map +1 -0
  106. package/dist/src/decorators.d.ts +118 -0
  107. package/dist/src/decorators.d.ts.map +1 -0
  108. package/dist/src/decorators.js +467 -0
  109. package/dist/src/decorators.js.map +1 -0
  110. package/dist/src/error.d.ts +47 -0
  111. package/dist/src/error.d.ts.map +1 -0
  112. package/dist/src/error.js +171 -0
  113. package/dist/src/error.js.map +1 -0
  114. package/dist/src/httpServer/handler.d.ts +54 -0
  115. package/dist/src/httpServer/handler.d.ts.map +1 -0
  116. package/dist/src/httpServer/handler.js +175 -0
  117. package/dist/src/httpServer/handler.js.map +1 -0
  118. package/dist/src/httpServer/handlerTypes.d.ts +11 -0
  119. package/dist/src/httpServer/handlerTypes.d.ts.map +1 -0
  120. package/dist/src/httpServer/handlerTypes.js +19 -0
  121. package/dist/src/httpServer/handlerTypes.js.map +1 -0
  122. package/dist/src/httpServer/middleware.d.ts +56 -0
  123. package/dist/src/httpServer/middleware.d.ts.map +1 -0
  124. package/dist/src/httpServer/middleware.js +57 -0
  125. package/dist/src/httpServer/middleware.js.map +1 -0
  126. package/dist/src/httpServer/server.d.ts +45 -0
  127. package/dist/src/httpServer/server.d.ts.map +1 -0
  128. package/dist/src/httpServer/server.js +253 -0
  129. package/dist/src/httpServer/server.js.map +1 -0
  130. package/dist/src/system_database.d.ts +89 -0
  131. package/dist/src/system_database.d.ts.map +1 -0
  132. package/dist/src/system_database.js +447 -0
  133. package/dist/src/system_database.js.map +1 -0
  134. package/dist/src/telemetry/collector.d.ts +16 -0
  135. package/dist/src/telemetry/collector.d.ts.map +1 -0
  136. package/dist/src/telemetry/collector.js +65 -0
  137. package/dist/src/telemetry/collector.js.map +1 -0
  138. package/dist/src/telemetry/exporters.d.ts +15 -0
  139. package/dist/src/telemetry/exporters.d.ts.map +1 -0
  140. package/dist/src/telemetry/exporters.js +59 -0
  141. package/dist/src/telemetry/exporters.js.map +1 -0
  142. package/dist/src/telemetry/index.d.ts +11 -0
  143. package/dist/src/telemetry/index.d.ts.map +1 -0
  144. package/dist/src/telemetry/index.js +19 -0
  145. package/dist/src/telemetry/index.js.map +1 -0
  146. package/dist/src/telemetry/logs.d.ts +47 -0
  147. package/dist/src/telemetry/logs.d.ts.map +1 -0
  148. package/dist/src/telemetry/logs.js +195 -0
  149. package/dist/src/telemetry/logs.js.map +1 -0
  150. package/dist/src/telemetry/traces.d.ts +14 -0
  151. package/dist/src/telemetry/traces.d.ts.map +1 -0
  152. package/dist/src/telemetry/traces.js +52 -0
  153. package/dist/src/telemetry/traces.js.map +1 -0
  154. package/dist/src/transaction.d.ts +29 -0
  155. package/dist/src/transaction.d.ts.map +1 -0
  156. package/dist/src/transaction.js +27 -0
  157. package/dist/src/transaction.js.map +1 -0
  158. package/dist/src/user_database.d.ts +132 -0
  159. package/dist/src/user_database.d.ts.map +1 -0
  160. package/dist/src/user_database.js +332 -0
  161. package/dist/src/user_database.js.map +1 -0
  162. package/dist/src/utils.d.ts +6 -0
  163. package/dist/src/utils.d.ts.map +1 -0
  164. package/dist/src/utils.js +35 -0
  165. package/dist/src/utils.js.map +1 -0
  166. package/dist/src/workflow.d.ts +195 -0
  167. package/dist/src/workflow.d.ts.map +1 -0
  168. package/dist/src/workflow.js +498 -0
  169. package/dist/src/workflow.js.map +1 -0
  170. package/package.json +50 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exporters.js","sourceRoot":"","sources":["../../../../../src/telemetry/exporters.ts"],"names":[],"mappings":";;;AACA,yBAAgD;AAChD,wFAA6E;AAC7E,sFAA0E;AAG1E,8CAAqE;AAWrE,MAAa,iBAAiB;IACX,cAAc,CAAqB;IACnC,YAAY,CAAmB;IAChD,YAAY,MAA0B;QACpC,IAAI,MAAM,CAAC,cAAc,EAAE,CAAC;YAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,6CAAiB,CAAC;gBAC1C,GAAG,EAAE,MAAM,CAAC,cAAc;aAC3B,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,8BAA8B,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;QACrE,CAAC;QACD,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,IAAI,0CAAe,CAAC;gBACtC,GAAG,EAAE,MAAM,CAAC,YAAY;aACzB,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,4BAA4B,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAA0B;QACrC,OAAO,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE;YACzC,2BAA2B;YAC3B,MAAM,WAAW,GAAmB,EAAE,CAAC;YACvC,MAAM,UAAU,GAAwB,EAAE,CAAC;YAC3C,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACzB,IAAI,IAAA,gBAAa,EAAC,MAAM,CAAC,EAAE,CAAC;oBAC1B,WAAW,CAAC,IAAI,CAAC,MAAsB,CAAC,CAAC;gBAC3C,CAAC;gBACD,IAAI,IAAA,cAAW,EAAC,MAAM,CAAC,EAAE,CAAC;oBACxB,UAAU,CAAC,IAAI,CAAC,MAA2B,CAAC,CAAC;gBAC/C,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;gBAClD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,OAAqB,EAAE,EAAE;oBAChE,IAAI,OAAO,CAAC,IAAI,KAAK,uBAAgB,CAAC,OAAO,EAAE,CAAC;wBAC9C,OAAO,CAAC,IAAI,CAAC,wBAAwB,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;wBACrD,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBACxB,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;YAED,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC/C,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,OAAqB,EAAE,EAAE;oBAC7D,IAAI,OAAO,CAAC,IAAI,KAAK,uBAAgB,CAAC,OAAO,EAAE,CAAC;wBAC9C,OAAO,CAAC,IAAI,CAAC,sBAAsB,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;wBACnD,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBACxB,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC;YAED,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AArDD,8CAqDC"}
@@ -0,0 +1,11 @@
1
+ import { LoggerConfig } from "./logs";
2
+ import { OTLPExporterConfig } from "./exporters";
3
+ import { Span } from "@opentelemetry/sdk-trace-base";
4
+ import { LogRecord } from "@opentelemetry/api-logs";
5
+ export declare function isTraceSignal(signal: any): signal is Span;
6
+ export declare function isLogSignal(signal: any): signal is LogRecord;
7
+ export interface TelemetryConfig {
8
+ logs?: LoggerConfig;
9
+ OTLPExporter?: OTLPExporterConfig;
10
+ }
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/telemetry/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAIpD,wBAAgB,aAAa,CAAC,MAAM,EAAE,GAAG,GAAG,MAAM,IAAI,IAAI,CAIzD;AAGD,wBAAgB,WAAW,CAAC,MAAM,EAAE,GAAG,GAAG,MAAM,IAAI,SAAS,CAI5D;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,YAAY,CAAC,EAAE,kBAAkB,CAAC;CACnC"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isLogSignal = exports.isTraceSignal = void 0;
4
+ // We could implement our own types and avoid having `any`, but this has likely little value
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ function isTraceSignal(signal) {
7
+ // Span is an interface that has a property 'kind'
8
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-return
9
+ return signal && 'kind' in signal;
10
+ }
11
+ exports.isTraceSignal = isTraceSignal;
12
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
13
+ function isLogSignal(signal) {
14
+ // LogRecord is an interface that has a property 'severityText' and 'severityNumber'
15
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-return
16
+ return signal && 'severityText' in signal && 'severityNumber' in signal;
17
+ }
18
+ exports.isLogSignal = isLogSignal;
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/telemetry/index.ts"],"names":[],"mappings":";;;AAKA,4FAA4F;AAC5F,8DAA8D;AAC9D,SAAgB,aAAa,CAAC,MAAW;IACvC,kDAAkD;IAClD,+DAA+D;IAC/D,OAAO,MAAM,IAAI,MAAM,IAAI,MAAM,CAAC;AACpC,CAAC;AAJD,sCAIC;AAED,8DAA8D;AAC9D,SAAgB,WAAW,CAAC,MAAW;IACrC,oFAAoF;IACpF,+DAA+D;IAC/D,OAAO,MAAM,IAAI,cAAc,IAAI,MAAM,IAAI,gBAAgB,IAAI,MAAM,CAAC;AAC1E,CAAC;AAJD,kCAIC"}
@@ -0,0 +1,47 @@
1
+ import { Logger as IWinstonLogger } from "winston";
2
+ import { DBOSContextImpl } from "../context";
3
+ import { Span } from "@opentelemetry/sdk-trace-base";
4
+ import { TelemetryCollector } from "./collector";
5
+ /*****************/
6
+ /*****************/
7
+ export interface LoggerConfig {
8
+ logLevel?: string;
9
+ silent?: boolean;
10
+ addContextMetadata?: boolean;
11
+ }
12
+ type ContextualMetadata = {
13
+ includeContextMetadata: boolean;
14
+ span: Span;
15
+ };
16
+ interface StackTrace {
17
+ stack?: string;
18
+ }
19
+ export interface IGlobalLogger extends IWinstonLogger {
20
+ readonly addContextMetadata: boolean;
21
+ readonly logger: IWinstonLogger;
22
+ readonly telemetryCollector: TelemetryCollector;
23
+ }
24
+ export declare class GlobalLogger {
25
+ private readonly telemetryCollector?;
26
+ private readonly logger;
27
+ readonly addContextMetadata: boolean;
28
+ constructor(telemetryCollector?: TelemetryCollector | undefined, config?: LoggerConfig);
29
+ info(logEntry: any, metadata?: ContextualMetadata): void;
30
+ debug(logEntry: any, metadata?: ContextualMetadata): void;
31
+ warn(logEntry: any, metadata?: ContextualMetadata): void;
32
+ error(inputError: any, metadata?: ContextualMetadata & StackTrace): void;
33
+ }
34
+ /******************/
35
+ /******************/
36
+ export declare class Logger {
37
+ private readonly globalLogger;
38
+ readonly ctx: DBOSContextImpl;
39
+ readonly metadata: ContextualMetadata;
40
+ constructor(globalLogger: GlobalLogger, ctx: DBOSContextImpl);
41
+ info(logEntry: any): void;
42
+ debug(logEntry: any): void;
43
+ warn(logEntry: any): void;
44
+ error(inputError: any): void;
45
+ }
46
+ export {};
47
+ //# sourceMappingURL=logs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../../../src/telemetry/logs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoC,MAAM,IAAI,cAAc,EAAE,MAAM,SAAS,CAAC;AAGrF,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAG7C,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AACrD,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,mBAAmB;AAEnB,mBAAmB;AAEnB,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAED,KAAK,kBAAkB,GAAG;IACxB,sBAAsB,EAAE,OAAO,CAAC;IAChC,IAAI,EAAE,IAAI,CAAC;CACZ,CAAC;AAEF,UAAU,UAAU;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAGD,MAAM,WAAW,aAAc,SAAQ,cAAc;IACnD,QAAQ,CAAC,kBAAkB,EAAE,OAAO,CAAC;IACrC,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,QAAQ,CAAC,kBAAkB,EAAE,kBAAkB,CAAC;CACjD;AAED,qBAAa,YAAY;IAKrB,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAC;IAJtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;IACxC,QAAQ,CAAC,kBAAkB,EAAE,OAAO,CAAC;gBAGlB,kBAAkB,CAAC,gCAAoB,EACxD,MAAM,CAAC,EAAE,YAAY;IAoBvB,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,kBAAkB,GAAG,IAAI;IASxD,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,kBAAkB,GAAG,IAAI;IASzD,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,kBAAkB,GAAG,IAAI;IAUxD,KAAK,CAAC,UAAU,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,kBAAkB,GAAG,UAAU,GAAG,IAAI;CAIzE;AAED,oBAAoB;AAEpB,oBAAoB;AAGpB,qBAAa,MAAM;IAGf,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,QAAQ,CAAC,GAAG,EAAE,eAAe;IAH/B,QAAQ,CAAC,QAAQ,EAAE,kBAAkB,CAAC;gBAEnB,YAAY,EAAE,YAAY,EAClC,GAAG,EAAE,eAAe;IAS/B,IAAI,CAAC,QAAQ,EAAE,GAAG,GAAG,IAAI;IASzB,KAAK,CAAC,QAAQ,EAAE,GAAG,GAAG,IAAI;IAS1B,IAAI,CAAC,QAAQ,EAAE,GAAG,GAAG,IAAI;IAUzB,KAAK,CAAC,UAAU,EAAE,GAAG,GAAG,IAAI;CAU7B"}
@@ -0,0 +1,195 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Logger = exports.GlobalLogger = void 0;
4
+ const winston_1 = require("winston");
5
+ const TransportStream = require("winston-transport");
6
+ const applicationVersion_1 = require("../dbos-runtime/applicationVersion");
7
+ const api_logs_1 = require("@opentelemetry/api-logs");
8
+ const sdk_logs_1 = require("@opentelemetry/sdk-logs");
9
+ class GlobalLogger {
10
+ telemetryCollector;
11
+ logger;
12
+ addContextMetadata;
13
+ constructor(telemetryCollector, config) {
14
+ this.telemetryCollector = telemetryCollector;
15
+ const winstonTransports = [];
16
+ winstonTransports.push(new winston_1.transports.Console({
17
+ format: consoleFormat,
18
+ level: config?.logLevel || "info",
19
+ silent: config?.silent || false,
20
+ }));
21
+ // Only enable the OTLP transport if we have a telemetry collector and an exporter
22
+ if (this.telemetryCollector?.exporter) {
23
+ winstonTransports.push(new OTLPLogQueueTransport(this.telemetryCollector));
24
+ }
25
+ this.logger = (0, winston_1.createLogger)({ transports: winstonTransports });
26
+ this.addContextMetadata = config?.addContextMetadata || false;
27
+ }
28
+ // We use this form of winston logging methods: `(message: string, ...meta: any[])`. See node_modules/winston/index.d.ts
29
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
30
+ info(logEntry, metadata) {
31
+ if (typeof logEntry === "string") {
32
+ this.logger.info(logEntry, metadata);
33
+ }
34
+ else {
35
+ this.logger.info(JSON.stringify(logEntry), metadata);
36
+ }
37
+ }
38
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
39
+ debug(logEntry, metadata) {
40
+ if (typeof logEntry === "string") {
41
+ this.logger.debug(logEntry, metadata);
42
+ }
43
+ else {
44
+ this.logger.debug(JSON.stringify(logEntry), metadata);
45
+ }
46
+ }
47
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
48
+ warn(logEntry, metadata) {
49
+ if (typeof logEntry === "string") {
50
+ this.logger.warn(logEntry, metadata);
51
+ }
52
+ else {
53
+ this.logger.warn(JSON.stringify(logEntry), metadata);
54
+ }
55
+ }
56
+ // metadata can have both ContextualMetadata and the error stack trace
57
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
58
+ error(inputError, metadata) {
59
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
60
+ this.logger.error(inputError, metadata);
61
+ }
62
+ }
63
+ exports.GlobalLogger = GlobalLogger;
64
+ /******************/
65
+ /* CONTEXT LOGGER */
66
+ /******************/
67
+ // Wrapper around our global logger. Expected to be instantiated by a new contexts so they can inject contextual metadata
68
+ class Logger {
69
+ globalLogger;
70
+ ctx;
71
+ metadata;
72
+ constructor(globalLogger, ctx) {
73
+ this.globalLogger = globalLogger;
74
+ this.ctx = ctx;
75
+ this.metadata = {
76
+ span: ctx.span,
77
+ includeContextMetadata: this.globalLogger.addContextMetadata,
78
+ };
79
+ }
80
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
81
+ info(logEntry) {
82
+ if (typeof logEntry === "string") {
83
+ this.globalLogger.info(logEntry, this.metadata);
84
+ }
85
+ else {
86
+ this.globalLogger.info(JSON.stringify(logEntry), this.metadata);
87
+ }
88
+ }
89
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
90
+ debug(logEntry) {
91
+ if (typeof logEntry === "string") {
92
+ this.globalLogger.debug(logEntry, this.metadata);
93
+ }
94
+ else {
95
+ this.globalLogger.debug(JSON.stringify(logEntry), this.metadata);
96
+ }
97
+ }
98
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
99
+ warn(logEntry) {
100
+ if (typeof logEntry === "string") {
101
+ this.globalLogger.warn(logEntry, this.metadata);
102
+ }
103
+ else {
104
+ this.globalLogger.warn(JSON.stringify(logEntry), this.metadata);
105
+ }
106
+ }
107
+ // We give users the same interface (message: string argument) but create an error to get a stack trace
108
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
109
+ error(inputError) {
110
+ if (inputError instanceof Error) {
111
+ this.globalLogger.error(inputError.message, { ...this.metadata, stack: inputError.stack });
112
+ }
113
+ else if (typeof inputError === "string") {
114
+ this.globalLogger.error(inputError, { ...this.metadata, stack: new Error().stack });
115
+ }
116
+ else {
117
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
118
+ this.globalLogger.error(JSON.stringify(inputError), { ...this.metadata, stack: new Error().stack });
119
+ }
120
+ }
121
+ }
122
+ exports.Logger = Logger;
123
+ /***********************/
124
+ /* FORMAT & TRANSPORTS */
125
+ /***********************/
126
+ const consoleFormat = winston_1.format.combine(winston_1.format.errors({ stack: true }), winston_1.format.timestamp(), winston_1.format.colorize(), winston_1.format.printf((info) => {
127
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
128
+ const { timestamp, level, message, stack } = info;
129
+ const applicationVersion = (0, applicationVersion_1.getApplicationVersion)();
130
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-assignment
131
+ const ts = timestamp.slice(0, 19).replace("T", " ");
132
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-assignment
133
+ const formattedStack = stack?.split("\n").slice(1).join("\n");
134
+ const messageString = typeof message === "string" ? message : JSON.stringify(message);
135
+ const fullMessageString = `${messageString}${info.includeContextMetadata ? ` ${JSON.stringify(info.span?.attributes)}` : ""}`;
136
+ const versionString = applicationVersion ? ` [version ${applicationVersion}]` : "";
137
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
138
+ return `${ts}${versionString} [${level}]: ${fullMessageString} ${stack ? "\n" + formattedStack : ""}`;
139
+ }));
140
+ class OTLPLogQueueTransport extends TransportStream {
141
+ telemetryCollector;
142
+ name = "OTLPLogQueueTransport";
143
+ otelLogger;
144
+ applicationID;
145
+ executorID;
146
+ constructor(telemetryCollector) {
147
+ super();
148
+ this.telemetryCollector = telemetryCollector;
149
+ // not sure if we need a more explicit name here
150
+ const loggerProvider = new sdk_logs_1.LoggerProvider();
151
+ this.otelLogger = loggerProvider.getLogger("default");
152
+ this.applicationID = process.env.DBOS__APPID || process.env.APPID || "APP_ID_NOT_DEFINED"; // TODO: Remove APPID
153
+ this.executorID = process.env.DBOS__VMID || process.env.VMID || "VM_ID_NOT_DEFINED"; // TODO: Remove VMID
154
+ const logRecordProcessor = {
155
+ forceFlush: async () => {
156
+ // no-op
157
+ },
158
+ onEmit(logRecord) {
159
+ telemetryCollector.push(logRecord);
160
+ },
161
+ shutdown: async () => {
162
+ // no-op
163
+ },
164
+ };
165
+ loggerProvider.addLogRecordProcessor(logRecordProcessor);
166
+ }
167
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
168
+ log(info, callback) {
169
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
170
+ const { level, message, stack, span } = info;
171
+ const levelToSeverityNumber = {
172
+ error: api_logs_1.SeverityNumber.ERROR,
173
+ warn: api_logs_1.SeverityNumber.WARN,
174
+ info: api_logs_1.SeverityNumber.INFO,
175
+ debug: api_logs_1.SeverityNumber.DEBUG,
176
+ };
177
+ // Ideally we want to give the spanContext to the logRecord,
178
+ // But there seems to some dependency bugs in opentelemetry-js
179
+ // (span.getValue(SPAN_KEY) undefined when we pass the context, as commented bellow)
180
+ // So for now we get the traceId and spanId directly from the context and pass them through the logRecord attributes
181
+ this.otelLogger.emit({
182
+ severityNumber: levelToSeverityNumber[level],
183
+ severityText: level,
184
+ body: message,
185
+ timestamp: new Date().getTime(), // So far I don't see a major difference between this and observedTimestamp
186
+ observedTimestamp: new Date().getTime(),
187
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
188
+ attributes: { ...span?.attributes, traceId: span?.spanContext()?.traceId, spanId: span?.spanContext()?.spanId, stack, applicationID: this.applicationID, executorID: this.executorID },
189
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
190
+ // context: span?.spanContext() || undefined,
191
+ });
192
+ callback();
193
+ }
194
+ }
195
+ //# sourceMappingURL=logs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../../../src/telemetry/logs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { Span } from "@opentelemetry/sdk-trace-base";
2
+ import { Attributes, SpanContext } from "@opentelemetry/api";
3
+ import { TelemetryCollector } from "./collector";
4
+ export declare class Tracer {
5
+ private readonly telemetryCollector;
6
+ private readonly tracer;
7
+ readonly applicationID: string;
8
+ readonly executorID: string;
9
+ constructor(telemetryCollector: TelemetryCollector);
10
+ startSpanWithContext(spanContext: SpanContext, name: string, attributes?: Attributes): Span;
11
+ startSpan(name: string, attributes?: Attributes, parentSpan?: Span): Span;
12
+ endSpan(span: Span): void;
13
+ }
14
+ //# sourceMappingURL=traces.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traces.d.ts","sourceRoot":"","sources":["../../../../../src/telemetry/traces.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqC,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAExF,OAAsB,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAE5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAEjD,qBAAa,MAAM;IAIL,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAH/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;IAC7C,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;gBACC,kBAAkB,EAAE,kBAAkB;IAWnE,oBAAoB,CAAC,WAAW,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,IAAI;IAM3F,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,IAAI,GAAG,IAAI;IAUzE,OAAO,CAAC,IAAI,EAAE,IAAI;CAQnB"}
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.Tracer = void 0;
7
+ const sdk_trace_base_1 = require("@opentelemetry/sdk-trace-base");
8
+ const resources_1 = require("@opentelemetry/resources");
9
+ const api_1 = __importDefault(require("@opentelemetry/api"));
10
+ const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
11
+ class Tracer {
12
+ telemetryCollector;
13
+ tracer;
14
+ applicationID;
15
+ executorID;
16
+ constructor(telemetryCollector) {
17
+ this.telemetryCollector = telemetryCollector;
18
+ this.tracer = new sdk_trace_base_1.BasicTracerProvider({
19
+ resource: new resources_1.Resource({
20
+ [semantic_conventions_1.SemanticResourceAttributes.SERVICE_NAME]: "dbos",
21
+ }),
22
+ });
23
+ this.tracer.register();
24
+ this.applicationID = process.env.DBOS__APPID || process.env.APPID || "APP_ID_NOT_DEFINED"; // TODO: Remove APPID
25
+ this.executorID = process.env.DBOS__VMID || process.env.VMID || "VM_ID_NOT_DEFINED"; // TODO: Remove VMID
26
+ }
27
+ startSpanWithContext(spanContext, name, attributes) {
28
+ const tracer = api_1.default.trace.getTracer("dbos-tracer");
29
+ const ctx = api_1.default.trace.setSpanContext(api_1.default.context.active(), spanContext);
30
+ return tracer.startSpan(name, { startTime: Date.now(), attributes: attributes }, ctx);
31
+ }
32
+ startSpan(name, attributes, parentSpan) {
33
+ const tracer = api_1.default.trace.getTracer("dbos-tracer");
34
+ if (parentSpan) {
35
+ const ctx = api_1.default.trace.setSpan(api_1.default.context.active(), parentSpan);
36
+ return tracer.startSpan(name, { startTime: Date.now(), attributes: attributes }, ctx);
37
+ }
38
+ else {
39
+ return tracer.startSpan(name, { attributes: attributes });
40
+ }
41
+ }
42
+ endSpan(span) {
43
+ span.end(Date.now());
44
+ span.attributes.applicationID = this.applicationID;
45
+ if (!("executorID" in span.attributes)) {
46
+ span.attributes.executorID = this.executorID;
47
+ }
48
+ this.telemetryCollector.push(span);
49
+ }
50
+ }
51
+ exports.Tracer = Tracer;
52
+ //# sourceMappingURL=traces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traces.js","sourceRoot":"","sources":["../../../../../src/telemetry/traces.ts"],"names":[],"mappings":";;;;;;AAAA,kEAAwF;AACxF,wDAAoD;AACpD,6DAA4E;AAC5E,8EAAiF;AAGjF,MAAa,MAAM;IAIY;IAHZ,MAAM,CAAsB;IACpC,aAAa,CAAS;IACtB,UAAU,CAAS;IAC5B,YAA6B,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACjE,IAAI,CAAC,MAAM,GAAG,IAAI,oCAAmB,CAAC;YACpC,QAAQ,EAAE,IAAI,oBAAQ,CAAC;gBACrB,CAAC,iDAA0B,CAAC,YAAY,CAAC,EAAE,MAAM;aAClD,CAAC;SACH,CAAC,CAAC;QACH,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QACvB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,GAAG,CAAC,WAAW,IAAK,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,oBAAoB,CAAC,CAAC,qBAAqB;QACjH,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,mBAAmB,CAAC,CAAC,oBAAoB;IAC3G,CAAC;IAED,oBAAoB,CAAC,WAAwB,EAAE,IAAY,EAAE,UAAuB;QAClF,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC5D,MAAM,GAAG,GAAG,aAAa,CAAC,KAAK,CAAC,cAAc,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,WAAW,CAAC,CAAC;QAC5F,OAAO,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,GAAG,CAAS,CAAC;IAChG,CAAC;IAED,SAAS,CAAC,IAAY,EAAE,UAAuB,EAAE,UAAiB;QAChE,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QAC5D,IAAI,UAAU,EAAE,CAAC;YACf,MAAM,GAAG,GAAG,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,UAAU,CAAC,CAAC;YACpF,OAAO,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,EAAE,GAAG,CAAS,CAAC;QAChG,CAAC;aAAM,CAAC;YACN,OAAO,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,CAAS,CAAC;QACpE,CAAC;IACH,CAAC;IAED,OAAO,CAAC,IAAU;QAChB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QACrB,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACnD,IAAK,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAoB,CAAC,CAAC;IACrD,CAAC;CACF;AAvCD,wBAuCC"}
@@ -0,0 +1,29 @@
1
+ import { UserDatabaseName, UserDatabaseClient } from "./user_database";
2
+ import { WorkflowContextImpl } from "./workflow";
3
+ import { Span } from "@opentelemetry/sdk-trace-base";
4
+ import { DBOSContext, DBOSContextImpl } from "./context";
5
+ import { ValuesOf } from "./utils";
6
+ import { GlobalLogger as Logger } from "./telemetry/logs";
7
+ import { WorkflowContextDebug } from "./debugger/debug_workflow";
8
+ export type Transaction<T extends any[], R> = (ctxt: TransactionContext<any>, ...args: T) => Promise<R>;
9
+ export interface TransactionConfig {
10
+ isolationLevel?: IsolationLevel;
11
+ readOnly?: boolean;
12
+ }
13
+ export declare const IsolationLevel: {
14
+ readonly ReadUncommitted: "READ UNCOMMITTED";
15
+ readonly ReadCommitted: "READ COMMITTED";
16
+ readonly RepeatableRead: "REPEATABLE READ";
17
+ readonly Serializable: "SERIALIZABLE";
18
+ };
19
+ export type IsolationLevel = ValuesOf<typeof IsolationLevel>;
20
+ export interface TransactionContext<T extends UserDatabaseClient> extends DBOSContext {
21
+ readonly client: T;
22
+ }
23
+ export declare class TransactionContextImpl<T extends UserDatabaseClient> extends DBOSContextImpl implements TransactionContext<T> {
24
+ readonly clientKind: UserDatabaseName;
25
+ readonly client: T;
26
+ readonly functionID: number;
27
+ constructor(clientKind: UserDatabaseName, client: T, workflowContext: WorkflowContextImpl | WorkflowContextDebug, span: Span, logger: Logger, functionID: number, operationName: string);
28
+ }
29
+ //# sourceMappingURL=transaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AACrD,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,YAAY,IAAI,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAGjE,MAAM,MAAM,WAAW,CAAC,CAAC,SAAS,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,kBAAkB,CAAC,GAAG,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AAExG,MAAM,WAAW,iBAAiB;IAChC,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,eAAO,MAAM,cAAc;;;;;CAKjB,CAAC;AACX,MAAM,MAAM,cAAc,GAAG,QAAQ,CAAC,OAAO,cAAc,CAAC,CAAC;AAE7D,MAAM,WAAW,kBAAkB,CAAC,CAAC,SAAS,kBAAkB,CAAE,SAAQ,WAAW;IACnF,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;CACpB;AAED,qBAAa,sBAAsB,CAAC,CAAC,SAAS,kBAAkB,CAAE,SAAQ,eAAgB,YAAW,kBAAkB,CAAC,CAAC,CAAC;IAEtH,QAAQ,CAAC,UAAU,EAAE,gBAAgB;IACrC,QAAQ,CAAC,MAAM,EAAE,CAAC;IAIlB,QAAQ,CAAC,UAAU,EAAE,MAAM;gBALlB,UAAU,EAAE,gBAAgB,EAC5B,MAAM,EAAE,CAAC,EAClB,eAAe,EAAE,mBAAmB,GAAG,oBAAoB,EAC3D,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,MAAM,EACL,UAAU,EAAE,MAAM,EAC3B,aAAa,EAAE,MAAM;CAQxB"}
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TransactionContextImpl = exports.IsolationLevel = void 0;
4
+ const context_1 = require("./context");
5
+ exports.IsolationLevel = {
6
+ ReadUncommitted: "READ UNCOMMITTED",
7
+ ReadCommitted: "READ COMMITTED",
8
+ RepeatableRead: "REPEATABLE READ",
9
+ Serializable: "SERIALIZABLE",
10
+ };
11
+ class TransactionContextImpl extends context_1.DBOSContextImpl {
12
+ clientKind;
13
+ client;
14
+ functionID;
15
+ constructor(clientKind, client, workflowContext, span, logger, functionID, operationName) {
16
+ super(operationName, span, logger, workflowContext);
17
+ this.clientKind = clientKind;
18
+ this.client = client;
19
+ this.functionID = functionID;
20
+ if (workflowContext.applicationConfig) {
21
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
22
+ this.applicationConfig = workflowContext.applicationConfig;
23
+ }
24
+ }
25
+ }
26
+ exports.TransactionContextImpl = TransactionContextImpl;
27
+ //# sourceMappingURL=transaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../../src/transaction.ts"],"names":[],"mappings":";;;AAIA,uCAAyD;AAa5C,QAAA,cAAc,GAAG;IAC5B,eAAe,EAAE,kBAAkB;IACnC,aAAa,EAAE,gBAAgB;IAC/B,cAAc,EAAE,iBAAiB;IACjC,YAAY,EAAE,cAAc;CACpB,CAAC;AAOX,MAAa,sBAAqD,SAAQ,yBAAe;IAE5E;IACA;IAIA;IANX,YACW,UAA4B,EAC5B,MAAS,EAClB,eAA2D,EAC3D,IAAU,EACV,MAAc,EACL,UAAkB,EAC3B,aAAqB;QAErB,KAAK,CAAC,aAAa,EAAE,IAAI,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC;QAR3C,eAAU,GAAV,UAAU,CAAkB;QAC5B,WAAM,GAAN,MAAM,CAAG;QAIT,eAAU,GAAV,UAAU,CAAQ;QAI3B,IAAI,eAAe,CAAC,iBAAiB,EAAE,CAAC;YACtC,mEAAmE;YACnE,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC,iBAAiB,CAAC;QAC7D,CAAC;IACH,CAAC;CACF;AAhBD,wDAgBC"}
@@ -0,0 +1,132 @@
1
+ import { Pool, PoolConfig, PoolClient } from "pg";
2
+ import { IsolationLevel, TransactionConfig } from "./transaction";
3
+ import { ValuesOf } from "./utils";
4
+ import { Knex } from "knex";
5
+ export interface UserDatabase {
6
+ init(debugMode?: boolean): Promise<void>;
7
+ destroy(): Promise<void>;
8
+ getName(): UserDatabaseName;
9
+ transaction<R, T extends unknown[]>(transactionFunction: UserDatabaseTransaction<R, T>, config: TransactionConfig, ...args: T): Promise<R>;
10
+ queryFunction<C extends UserDatabaseClient, R, T extends unknown[]>(queryFunction: UserDatabaseQuery<C, R, T>, ...params: T): Promise<R>;
11
+ query<R, T extends unknown[]>(sql: string, ...params: T): Promise<R[]>;
12
+ queryWithClient<R, T extends unknown[] = unknown[]>(client: UserDatabaseClient, sql: string, ...params: T): Promise<R[]>;
13
+ isRetriableTransactionError(error: unknown): boolean;
14
+ isKeyConflictError(error: unknown): boolean;
15
+ createSchema(): Promise<void>;
16
+ dropSchema(): Promise<void>;
17
+ }
18
+ type UserDatabaseQuery<C extends UserDatabaseClient, R, T extends unknown[]> = (ctxt: C, ...args: T) => Promise<R>;
19
+ type UserDatabaseTransaction<R, T extends unknown[]> = (ctxt: UserDatabaseClient, ...args: T) => Promise<R>;
20
+ export type UserDatabaseClient = PoolClient | PrismaClient | TypeORMEntityManager | Knex;
21
+ export declare const UserDatabaseName: {
22
+ readonly PGNODE: "pg-node";
23
+ readonly PRISMA: "prisma";
24
+ readonly TYPEORM: "typeorm";
25
+ readonly KNEX: "knex";
26
+ };
27
+ export type UserDatabaseName = ValuesOf<typeof UserDatabaseName>;
28
+ /**
29
+ * node-postgres user data access interface
30
+ */
31
+ export declare class PGNodeUserDatabase implements UserDatabase {
32
+ readonly poolConfig: PoolConfig;
33
+ readonly pool: Pool;
34
+ constructor(poolConfig: PoolConfig);
35
+ init(debugMode?: boolean): Promise<void>;
36
+ destroy(): Promise<void>;
37
+ getName(): "pg-node";
38
+ transaction<R, T extends unknown[]>(txn: UserDatabaseTransaction<R, T>, config: TransactionConfig, ...args: T): Promise<R>;
39
+ queryFunction<C extends UserDatabaseClient, R, T extends unknown[]>(func: UserDatabaseQuery<C, R, T>, ...args: T): Promise<R>;
40
+ query<R, T extends unknown[]>(sql: string, ...params: T): Promise<R[]>;
41
+ queryWithClient<R, T extends unknown[]>(client: UserDatabaseClient, sql: string, ...params: T): Promise<R[]>;
42
+ getPostgresErrorCode(error: unknown): string | null;
43
+ isRetriableTransactionError(error: unknown): boolean;
44
+ isKeyConflictError(error: unknown): boolean;
45
+ createSchema(): Promise<void>;
46
+ dropSchema(): Promise<void>;
47
+ }
48
+ /**
49
+ * Prisma user data access interface
50
+ */
51
+ export interface PrismaClient {
52
+ $queryRawUnsafe<R, T extends unknown[]>(query: string, ...params: T): Promise<R[]>;
53
+ $transaction<R>(fn: (prisma: unknown) => Promise<R>, options?: {
54
+ maxWait?: number;
55
+ timeout?: number;
56
+ isolationLevel?: unknown;
57
+ }): Promise<R>;
58
+ $disconnect(): Promise<void>;
59
+ }
60
+ export declare class PrismaUserDatabase implements UserDatabase {
61
+ readonly prisma: PrismaClient;
62
+ constructor(prisma: PrismaClient);
63
+ init(debugMode?: boolean): Promise<void>;
64
+ destroy(): Promise<void>;
65
+ getName(): "prisma";
66
+ transaction<R, T extends unknown[]>(transaction: UserDatabaseTransaction<R, T>, config: TransactionConfig, ...args: T): Promise<R>;
67
+ queryFunction<C extends UserDatabaseClient, R, T extends unknown[]>(func: UserDatabaseQuery<C, R, T>, ...args: T): Promise<R>;
68
+ query<R, T extends unknown[]>(sql: string, ...params: T): Promise<R[]>;
69
+ queryWithClient<R, T extends unknown[]>(client: UserDatabaseClient, sql: string, ...params: T): Promise<R[]>;
70
+ getPostgresErrorCode(error: unknown): string | null;
71
+ isRetriableTransactionError(error: unknown): boolean;
72
+ isKeyConflictError(error: unknown): boolean;
73
+ createSchema(): Promise<void>;
74
+ dropSchema(): Promise<void>;
75
+ }
76
+ export interface TypeORMDataSource {
77
+ readonly isInitialized: boolean;
78
+ readonly manager: TypeORMEntityManager;
79
+ initialize(): Promise<this>;
80
+ query<R = unknown>(query: string): Promise<R>;
81
+ destroy(): Promise<void>;
82
+ synchronize(): Promise<void>;
83
+ dropDatabase(): Promise<void>;
84
+ }
85
+ export interface TypeORMEntityManager {
86
+ query<R, T extends unknown[]>(query: string, parameters?: T): Promise<R>;
87
+ transaction<R>(isolationLevel: IsolationLevel, runinTransaction: (entityManager: TypeORMEntityManager) => Promise<R>): Promise<R>;
88
+ }
89
+ export interface QueryFailedError<T> {
90
+ driverError: T;
91
+ }
92
+ /**
93
+ * TypeORM user data access interface
94
+ */
95
+ export declare class TypeORMDatabase implements UserDatabase {
96
+ readonly ds: TypeORMDataSource;
97
+ readonly dataSource: TypeORMDataSource;
98
+ constructor(ds: TypeORMDataSource);
99
+ init(debugMode?: boolean): Promise<void>;
100
+ destroy(): Promise<void>;
101
+ getName(): "typeorm";
102
+ transaction<R, T extends unknown[]>(txn: UserDatabaseTransaction<R, T>, config: TransactionConfig, ...args: T): Promise<R>;
103
+ queryFunction<C extends UserDatabaseClient, R, T extends unknown[]>(func: UserDatabaseQuery<C, R, T>, ...args: T): Promise<R>;
104
+ query<R>(sql: string, ...params: unknown[]): Promise<R[]>;
105
+ queryWithClient<R, T extends unknown[]>(client: UserDatabaseClient, sql: string, ...params: T): Promise<R[]>;
106
+ getPostgresErrorCode(error: unknown): string | null;
107
+ isRetriableTransactionError(error: unknown): boolean;
108
+ isKeyConflictError(error: unknown): boolean;
109
+ createSchema(): Promise<void>;
110
+ dropSchema(): Promise<void>;
111
+ }
112
+ /**
113
+ * Knex user data access interface
114
+ */
115
+ export declare class KnexUserDatabase implements UserDatabase {
116
+ readonly knex: Knex;
117
+ constructor(knex: Knex);
118
+ init(debugMode?: boolean): Promise<void>;
119
+ destroy(): Promise<void>;
120
+ getName(): "knex";
121
+ transaction<R, T extends unknown[]>(transactionFunction: UserDatabaseTransaction<R, T>, config: TransactionConfig, ...args: T): Promise<R>;
122
+ queryFunction<C extends UserDatabaseClient, R, T extends unknown[]>(func: UserDatabaseQuery<C, R, T>, ...args: T): Promise<R>;
123
+ query<R, T extends unknown[]>(sql: string, ...params: T): Promise<R[]>;
124
+ queryWithClient<R, T extends unknown[]>(client: Knex, sql: string, ...uparams: T): Promise<R[]>;
125
+ getPostgresErrorCode(error: unknown): string | null;
126
+ isRetriableTransactionError(error: unknown): boolean;
127
+ isKeyConflictError(error: unknown): boolean;
128
+ createSchema(): Promise<void>;
129
+ dropSchema(): Promise<void>;
130
+ }
131
+ export {};
132
+ //# sourceMappingURL=user_database.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user_database.d.ts","sourceRoot":"","sources":["../../../../src/user_database.ts"],"names":[],"mappings":"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"}