@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.
- package/cli.ts +177 -0
- package/dist/packages/dbos-cloud/applications/delete-app.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/delete-app.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/delete-app.js +42 -0
- package/dist/packages/dbos-cloud/applications/delete-app.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/deploy-app-code.js +145 -0
- package/dist/packages/dbos-cloud/applications/deploy-app-code.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/get-app-logs.js +42 -0
- package/dist/packages/dbos-cloud/applications/get-app-logs.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/index.d.ts +7 -0
- package/dist/packages/dbos-cloud/applications/index.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/index.js +16 -0
- package/dist/packages/dbos-cloud/applications/index.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/list-apps.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/list-apps.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/list-apps.js +45 -0
- package/dist/packages/dbos-cloud/applications/list-apps.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/register-app.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/register-app.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/register-app.js +48 -0
- package/dist/packages/dbos-cloud/applications/register-app.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/types.d.ts +9 -0
- package/dist/packages/dbos-cloud/applications/types.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/types.js +3 -0
- package/dist/packages/dbos-cloud/applications/types.js.map +1 -0
- package/dist/packages/dbos-cloud/applications/update-app.d.ts +2 -0
- package/dist/packages/dbos-cloud/applications/update-app.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/applications/update-app.js +49 -0
- package/dist/packages/dbos-cloud/applications/update-app.js.map +1 -0
- package/dist/packages/dbos-cloud/cli.d.ts +3 -0
- package/dist/packages/dbos-cloud/cli.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/cli.js +149 -0
- package/dist/packages/dbos-cloud/cli.js.map +1 -0
- package/dist/packages/dbos-cloud/cloudutils.d.ts +5 -0
- package/dist/packages/dbos-cloud/cloudutils.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/cloudutils.js +47 -0
- package/dist/packages/dbos-cloud/cloudutils.js.map +1 -0
- package/dist/packages/dbos-cloud/login.d.ts +9 -0
- package/dist/packages/dbos-cloud/login.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/login.js +102 -0
- package/dist/packages/dbos-cloud/login.js.map +1 -0
- package/dist/packages/dbos-cloud/register.d.ts +2 -0
- package/dist/packages/dbos-cloud/register.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/register.js +40 -0
- package/dist/packages/dbos-cloud/register.js.map +1 -0
- package/dist/packages/dbos-cloud/userdb.d.ts +13 -0
- package/dist/packages/dbos-cloud/userdb.d.ts.map +1 -0
- package/dist/packages/dbos-cloud/userdb.js +266 -0
- package/dist/packages/dbos-cloud/userdb.js.map +1 -0
- package/dist/schemas/system_db_schema.d.ts +34 -0
- package/dist/schemas/system_db_schema.d.ts.map +1 -0
- package/dist/schemas/system_db_schema.js +77 -0
- package/dist/schemas/system_db_schema.js.map +1 -0
- package/dist/schemas/user_db_schema.d.ts +11 -0
- package/dist/schemas/user_db_schema.d.ts.map +1 -0
- package/dist/schemas/user_db_schema.js +16 -0
- package/dist/schemas/user_db_schema.js.map +1 -0
- package/dist/src/communicator.d.ts +25 -0
- package/dist/src/communicator.d.ts.map +1 -0
- package/dist/src/communicator.js +26 -0
- package/dist/src/communicator.js.map +1 -0
- package/dist/src/context.d.ts +64 -0
- package/dist/src/context.d.ts.map +1 -0
- package/dist/src/context.js +96 -0
- package/dist/src/context.js.map +1 -0
- package/dist/src/data_validation.d.ts +3 -0
- package/dist/src/data_validation.d.ts.map +1 -0
- package/dist/src/data_validation.js +168 -0
- package/dist/src/data_validation.js.map +1 -0
- package/dist/src/dbos-executor.d.ts +102 -0
- package/dist/src/dbos-executor.d.ts.map +1 -0
- package/dist/src/dbos-executor.js +631 -0
- package/dist/src/dbos-executor.js.map +1 -0
- package/dist/src/dbos-runtime/applicationVersion.d.ts +3 -0
- package/dist/src/dbos-runtime/applicationVersion.d.ts.map +1 -0
- package/dist/src/dbos-runtime/applicationVersion.js +13 -0
- package/dist/src/dbos-runtime/applicationVersion.js.map +1 -0
- package/dist/src/dbos-runtime/cli.d.ts +8 -0
- package/dist/src/dbos-runtime/cli.d.ts.map +1 -0
- package/dist/src/dbos-runtime/cli.js +47 -0
- package/dist/src/dbos-runtime/cli.js.map +1 -0
- package/dist/src/dbos-runtime/config.d.ts +29 -0
- package/dist/src/dbos-runtime/config.d.ts.map +1 -0
- package/dist/src/dbos-runtime/config.js +111 -0
- package/dist/src/dbos-runtime/config.js.map +1 -0
- package/dist/src/dbos-runtime/debug.d.ts +4 -0
- package/dist/src/dbos-runtime/debug.d.ts.map +1 -0
- package/dist/src/dbos-runtime/debug.js +21 -0
- package/dist/src/dbos-runtime/debug.js.map +1 -0
- package/dist/src/dbos-runtime/init.d.ts +7 -0
- package/dist/src/dbos-runtime/init.d.ts.map +1 -0
- package/dist/src/dbos-runtime/init.js +51 -0
- package/dist/src/dbos-runtime/init.js.map +1 -0
- package/dist/src/dbos-runtime/runtime.d.ts +28 -0
- package/dist/src/dbos-runtime/runtime.d.ts.map +1 -0
- package/dist/src/dbos-runtime/runtime.js +95 -0
- package/dist/src/dbos-runtime/runtime.js.map +1 -0
- package/dist/src/debugger/debug_workflow.d.ts +38 -0
- package/dist/src/debugger/debug_workflow.d.ts.map +1 -0
- package/dist/src/debugger/debug_workflow.js +211 -0
- package/dist/src/debugger/debug_workflow.js.map +1 -0
- package/dist/src/decorators.d.ts +118 -0
- package/dist/src/decorators.d.ts.map +1 -0
- package/dist/src/decorators.js +467 -0
- package/dist/src/decorators.js.map +1 -0
- package/dist/src/error.d.ts +47 -0
- package/dist/src/error.d.ts.map +1 -0
- package/dist/src/error.js +171 -0
- package/dist/src/error.js.map +1 -0
- package/dist/src/httpServer/handler.d.ts +54 -0
- package/dist/src/httpServer/handler.d.ts.map +1 -0
- package/dist/src/httpServer/handler.js +175 -0
- package/dist/src/httpServer/handler.js.map +1 -0
- package/dist/src/httpServer/handlerTypes.d.ts +11 -0
- package/dist/src/httpServer/handlerTypes.d.ts.map +1 -0
- package/dist/src/httpServer/handlerTypes.js +19 -0
- package/dist/src/httpServer/handlerTypes.js.map +1 -0
- package/dist/src/httpServer/middleware.d.ts +56 -0
- package/dist/src/httpServer/middleware.d.ts.map +1 -0
- package/dist/src/httpServer/middleware.js +57 -0
- package/dist/src/httpServer/middleware.js.map +1 -0
- package/dist/src/httpServer/server.d.ts +45 -0
- package/dist/src/httpServer/server.d.ts.map +1 -0
- package/dist/src/httpServer/server.js +253 -0
- package/dist/src/httpServer/server.js.map +1 -0
- package/dist/src/system_database.d.ts +89 -0
- package/dist/src/system_database.d.ts.map +1 -0
- package/dist/src/system_database.js +447 -0
- package/dist/src/system_database.js.map +1 -0
- package/dist/src/telemetry/collector.d.ts +16 -0
- package/dist/src/telemetry/collector.d.ts.map +1 -0
- package/dist/src/telemetry/collector.js +65 -0
- package/dist/src/telemetry/collector.js.map +1 -0
- package/dist/src/telemetry/exporters.d.ts +15 -0
- package/dist/src/telemetry/exporters.d.ts.map +1 -0
- package/dist/src/telemetry/exporters.js +59 -0
- package/dist/src/telemetry/exporters.js.map +1 -0
- package/dist/src/telemetry/index.d.ts +11 -0
- package/dist/src/telemetry/index.d.ts.map +1 -0
- package/dist/src/telemetry/index.js +19 -0
- package/dist/src/telemetry/index.js.map +1 -0
- package/dist/src/telemetry/logs.d.ts +47 -0
- package/dist/src/telemetry/logs.d.ts.map +1 -0
- package/dist/src/telemetry/logs.js +195 -0
- package/dist/src/telemetry/logs.js.map +1 -0
- package/dist/src/telemetry/traces.d.ts +14 -0
- package/dist/src/telemetry/traces.d.ts.map +1 -0
- package/dist/src/telemetry/traces.js +52 -0
- package/dist/src/telemetry/traces.js.map +1 -0
- package/dist/src/transaction.d.ts +29 -0
- package/dist/src/transaction.d.ts.map +1 -0
- package/dist/src/transaction.js +27 -0
- package/dist/src/transaction.js.map +1 -0
- package/dist/src/user_database.d.ts +132 -0
- package/dist/src/user_database.d.ts.map +1 -0
- package/dist/src/user_database.js +332 -0
- package/dist/src/user_database.js.map +1 -0
- package/dist/src/utils.d.ts +6 -0
- package/dist/src/utils.d.ts.map +1 -0
- package/dist/src/utils.js +35 -0
- package/dist/src/utils.js.map +1 -0
- package/dist/src/workflow.d.ts +195 -0
- package/dist/src/workflow.d.ts.map +1 -0
- package/dist/src/workflow.js +498 -0
- package/dist/src/workflow.js.map +1 -0
- 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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"}
|