@dbos-inc/dbos-sdk 0.7.18-preview

Sign up to get free protection for your applications and to get access to all the features.
Files changed (203) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +30 -0
  3. package/dbos-config.schema.json +121 -0
  4. package/dbos-test-config.yaml +16 -0
  5. package/dist/schemas/system_db_schema.d.ts +34 -0
  6. package/dist/schemas/system_db_schema.d.ts.map +1 -0
  7. package/dist/schemas/system_db_schema.js +75 -0
  8. package/dist/schemas/system_db_schema.js.map +1 -0
  9. package/dist/schemas/user_db_schema.d.ts +11 -0
  10. package/dist/schemas/user_db_schema.d.ts.map +1 -0
  11. package/dist/schemas/user_db_schema.js +16 -0
  12. package/dist/schemas/user_db_schema.js.map +1 -0
  13. package/dist/src/cloud-cli/applications/configure.d.ts +2 -0
  14. package/dist/src/cloud-cli/applications/configure.d.ts.map +1 -0
  15. package/dist/src/cloud-cli/applications/configure.js +57 -0
  16. package/dist/src/cloud-cli/applications/configure.js.map +1 -0
  17. package/dist/src/cloud-cli/applications/delete-app.d.ts +2 -0
  18. package/dist/src/cloud-cli/applications/delete-app.d.ts.map +1 -0
  19. package/dist/src/cloud-cli/applications/delete-app.js +36 -0
  20. package/dist/src/cloud-cli/applications/delete-app.js.map +1 -0
  21. package/dist/src/cloud-cli/applications/deploy-app-code.d.ts +2 -0
  22. package/dist/src/cloud-cli/applications/deploy-app-code.d.ts.map +1 -0
  23. package/dist/src/cloud-cli/applications/deploy-app-code.js +64 -0
  24. package/dist/src/cloud-cli/applications/deploy-app-code.js.map +1 -0
  25. package/dist/src/cloud-cli/applications/get-app-logs.d.ts +2 -0
  26. package/dist/src/cloud-cli/applications/get-app-logs.d.ts.map +1 -0
  27. package/dist/src/cloud-cli/applications/get-app-logs.js +37 -0
  28. package/dist/src/cloud-cli/applications/get-app-logs.js.map +1 -0
  29. package/dist/src/cloud-cli/applications/index.d.ts +8 -0
  30. package/dist/src/cloud-cli/applications/index.d.ts.map +1 -0
  31. package/dist/src/cloud-cli/applications/index.js +18 -0
  32. package/dist/src/cloud-cli/applications/index.js.map +1 -0
  33. package/dist/src/cloud-cli/applications/list-apps.d.ts +2 -0
  34. package/dist/src/cloud-cli/applications/list-apps.d.ts.map +1 -0
  35. package/dist/src/cloud-cli/applications/list-apps.js +45 -0
  36. package/dist/src/cloud-cli/applications/list-apps.js.map +1 -0
  37. package/dist/src/cloud-cli/applications/register-app.d.ts +2 -0
  38. package/dist/src/cloud-cli/applications/register-app.d.ts.map +1 -0
  39. package/dist/src/cloud-cli/applications/register-app.js +41 -0
  40. package/dist/src/cloud-cli/applications/register-app.js.map +1 -0
  41. package/dist/src/cloud-cli/applications/types.d.ts +7 -0
  42. package/dist/src/cloud-cli/applications/types.d.ts.map +1 -0
  43. package/dist/src/cloud-cli/applications/types.js +3 -0
  44. package/dist/src/cloud-cli/applications/types.js.map +1 -0
  45. package/dist/src/cloud-cli/applications/update-app.d.ts +2 -0
  46. package/dist/src/cloud-cli/applications/update-app.d.ts.map +1 -0
  47. package/dist/src/cloud-cli/applications/update-app.js +42 -0
  48. package/dist/src/cloud-cli/applications/update-app.js.map +1 -0
  49. package/dist/src/cloud-cli/cli.d.ts +3 -0
  50. package/dist/src/cloud-cli/cli.d.ts.map +1 -0
  51. package/dist/src/cloud-cli/cli.js +148 -0
  52. package/dist/src/cloud-cli/cli.js.map +1 -0
  53. package/dist/src/cloud-cli/login.d.ts +7 -0
  54. package/dist/src/cloud-cli/login.d.ts.map +1 -0
  55. package/dist/src/cloud-cli/login.js +40 -0
  56. package/dist/src/cloud-cli/login.js.map +1 -0
  57. package/dist/src/cloud-cli/register.d.ts +2 -0
  58. package/dist/src/cloud-cli/register.d.ts.map +1 -0
  59. package/dist/src/cloud-cli/register.js +35 -0
  60. package/dist/src/cloud-cli/register.js.map +1 -0
  61. package/dist/src/cloud-cli/userdb.d.ts +4 -0
  62. package/dist/src/cloud-cli/userdb.d.ts.map +1 -0
  63. package/dist/src/cloud-cli/userdb.js +149 -0
  64. package/dist/src/cloud-cli/userdb.js.map +1 -0
  65. package/dist/src/cloud-cli/utils.d.ts +3 -0
  66. package/dist/src/cloud-cli/utils.d.ts.map +1 -0
  67. package/dist/src/cloud-cli/utils.js +17 -0
  68. package/dist/src/cloud-cli/utils.js.map +1 -0
  69. package/dist/src/communicator.d.ts +24 -0
  70. package/dist/src/communicator.d.ts.map +1 -0
  71. package/dist/src/communicator.js +26 -0
  72. package/dist/src/communicator.js.map +1 -0
  73. package/dist/src/context.d.ts +60 -0
  74. package/dist/src/context.d.ts.map +1 -0
  75. package/dist/src/context.js +94 -0
  76. package/dist/src/context.js.map +1 -0
  77. package/dist/src/data_validation.d.ts +3 -0
  78. package/dist/src/data_validation.d.ts.map +1 -0
  79. package/dist/src/data_validation.js +168 -0
  80. package/dist/src/data_validation.js.map +1 -0
  81. package/dist/src/dbos-executor.d.ts +79 -0
  82. package/dist/src/dbos-executor.d.ts.map +1 -0
  83. package/dist/src/dbos-executor.js +408 -0
  84. package/dist/src/dbos-executor.js.map +1 -0
  85. package/dist/src/dbos-runtime/TypeParser.d.ts +33 -0
  86. package/dist/src/dbos-runtime/TypeParser.d.ts.map +1 -0
  87. package/dist/src/dbos-runtime/TypeParser.js +104 -0
  88. package/dist/src/dbos-runtime/TypeParser.js.map +1 -0
  89. package/dist/src/dbos-runtime/applicationVersion.d.ts +3 -0
  90. package/dist/src/dbos-runtime/applicationVersion.d.ts.map +1 -0
  91. package/dist/src/dbos-runtime/applicationVersion.js +13 -0
  92. package/dist/src/dbos-runtime/applicationVersion.js.map +1 -0
  93. package/dist/src/dbos-runtime/cli.d.ts +8 -0
  94. package/dist/src/dbos-runtime/cli.d.ts.map +1 -0
  95. package/dist/src/dbos-runtime/cli.js +52 -0
  96. package/dist/src/dbos-runtime/cli.js.map +1 -0
  97. package/dist/src/dbos-runtime/config.d.ts +28 -0
  98. package/dist/src/dbos-runtime/config.d.ts.map +1 -0
  99. package/dist/src/dbos-runtime/config.js +111 -0
  100. package/dist/src/dbos-runtime/config.js.map +1 -0
  101. package/dist/src/dbos-runtime/init.d.ts +7 -0
  102. package/dist/src/dbos-runtime/init.d.ts.map +1 -0
  103. package/dist/src/dbos-runtime/init.js +51 -0
  104. package/dist/src/dbos-runtime/init.js.map +1 -0
  105. package/dist/src/dbos-runtime/openApi.d.ts +35 -0
  106. package/dist/src/dbos-runtime/openApi.d.ts.map +1 -0
  107. package/dist/src/dbos-runtime/openApi.js +595 -0
  108. package/dist/src/dbos-runtime/openApi.js.map +1 -0
  109. package/dist/src/dbos-runtime/runtime.d.ts +28 -0
  110. package/dist/src/dbos-runtime/runtime.d.ts.map +1 -0
  111. package/dist/src/dbos-runtime/runtime.js +96 -0
  112. package/dist/src/dbos-runtime/runtime.js.map +1 -0
  113. package/dist/src/dbos-runtime/tsDiagUtil.d.ts +16 -0
  114. package/dist/src/dbos-runtime/tsDiagUtil.d.ts.map +1 -0
  115. package/dist/src/dbos-runtime/tsDiagUtil.js +72 -0
  116. package/dist/src/dbos-runtime/tsDiagUtil.js.map +1 -0
  117. package/dist/src/decorators.d.ts +118 -0
  118. package/dist/src/decorators.d.ts.map +1 -0
  119. package/dist/src/decorators.js +467 -0
  120. package/dist/src/decorators.js.map +1 -0
  121. package/dist/src/error.d.ts +44 -0
  122. package/dist/src/error.d.ts.map +1 -0
  123. package/dist/src/error.js +164 -0
  124. package/dist/src/error.js.map +1 -0
  125. package/dist/src/httpServer/handler.d.ts +62 -0
  126. package/dist/src/httpServer/handler.d.ts.map +1 -0
  127. package/dist/src/httpServer/handler.js +168 -0
  128. package/dist/src/httpServer/handler.js.map +1 -0
  129. package/dist/src/httpServer/middleware.d.ts +56 -0
  130. package/dist/src/httpServer/middleware.d.ts.map +1 -0
  131. package/dist/src/httpServer/middleware.js +57 -0
  132. package/dist/src/httpServer/middleware.js.map +1 -0
  133. package/dist/src/httpServer/server.d.ts +40 -0
  134. package/dist/src/httpServer/server.d.ts.map +1 -0
  135. package/dist/src/httpServer/server.js +231 -0
  136. package/dist/src/httpServer/server.js.map +1 -0
  137. package/dist/src/index.d.ts +12 -0
  138. package/dist/src/index.d.ts.map +1 -0
  139. package/dist/src/index.js +75 -0
  140. package/dist/src/index.js.map +1 -0
  141. package/dist/src/provenance/provenance_daemon.d.ts +34 -0
  142. package/dist/src/provenance/provenance_daemon.d.ts.map +1 -0
  143. package/dist/src/provenance/provenance_daemon.js +86 -0
  144. package/dist/src/provenance/provenance_daemon.js.map +1 -0
  145. package/dist/src/system_database.d.ts +69 -0
  146. package/dist/src/system_database.d.ts.map +1 -0
  147. package/dist/src/system_database.js +384 -0
  148. package/dist/src/system_database.js.map +1 -0
  149. package/dist/src/telemetry/collector.d.ts +17 -0
  150. package/dist/src/telemetry/collector.d.ts.map +1 -0
  151. package/dist/src/telemetry/collector.js +77 -0
  152. package/dist/src/telemetry/collector.js.map +1 -0
  153. package/dist/src/telemetry/exporters.d.ts +29 -0
  154. package/dist/src/telemetry/exporters.d.ts.map +1 -0
  155. package/dist/src/telemetry/exporters.js +186 -0
  156. package/dist/src/telemetry/exporters.js.map +1 -0
  157. package/dist/src/telemetry/index.d.ts +7 -0
  158. package/dist/src/telemetry/index.d.ts.map +1 -0
  159. package/dist/src/telemetry/index.js +3 -0
  160. package/dist/src/telemetry/index.js.map +1 -0
  161. package/dist/src/telemetry/logs.d.ts +25 -0
  162. package/dist/src/telemetry/logs.d.ts.map +1 -0
  163. package/dist/src/telemetry/logs.js +91 -0
  164. package/dist/src/telemetry/logs.js.map +1 -0
  165. package/dist/src/telemetry/signals.d.ts +30 -0
  166. package/dist/src/telemetry/signals.d.ts.map +1 -0
  167. package/dist/src/telemetry/signals.js +11 -0
  168. package/dist/src/telemetry/signals.js.map +1 -0
  169. package/dist/src/telemetry/traces.d.ts +17 -0
  170. package/dist/src/telemetry/traces.d.ts.map +1 -0
  171. package/dist/src/telemetry/traces.js +76 -0
  172. package/dist/src/telemetry/traces.js.map +1 -0
  173. package/dist/src/testing/testing_runtime.d.ts +76 -0
  174. package/dist/src/testing/testing_runtime.d.ts.map +1 -0
  175. package/dist/src/testing/testing_runtime.js +147 -0
  176. package/dist/src/testing/testing_runtime.js.map +1 -0
  177. package/dist/src/transaction.d.ts +28 -0
  178. package/dist/src/transaction.d.ts.map +1 -0
  179. package/dist/src/transaction.js +27 -0
  180. package/dist/src/transaction.js.map +1 -0
  181. package/dist/src/user_database.d.ts +132 -0
  182. package/dist/src/user_database.d.ts.map +1 -0
  183. package/dist/src/user_database.js +324 -0
  184. package/dist/src/user_database.js.map +1 -0
  185. package/dist/src/utils.d.ts +6 -0
  186. package/dist/src/utils.d.ts.map +1 -0
  187. package/dist/src/utils.js +35 -0
  188. package/dist/src/utils.js.map +1 -0
  189. package/dist/src/workflow.d.ts +179 -0
  190. package/dist/src/workflow.d.ts.map +1 -0
  191. package/dist/src/workflow.js +446 -0
  192. package/dist/src/workflow.js.map +1 -0
  193. package/examples/hello/README.md +41 -0
  194. package/examples/hello/dbos-config.yaml +15 -0
  195. package/examples/hello/jest.config.js +8 -0
  196. package/examples/hello/knexfile.ts +23 -0
  197. package/examples/hello/migrations/create_dbos_hello_tables.ts +12 -0
  198. package/examples/hello/package.json +21 -0
  199. package/examples/hello/src/operations.test.ts +38 -0
  200. package/examples/hello/src/operations.ts +21 -0
  201. package/examples/hello/start_postgres_docker.sh +23 -0
  202. package/examples/hello/tsconfig.json +24 -0
  203. package/package.json +78 -0
@@ -0,0 +1,186 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PostgresExporter = exports.POSTGRES_EXPORTER = exports.JaegerExporter = exports.JAEGER_EXPORTER = void 0;
4
+ const pg_1 = require("pg");
5
+ const lodash_1 = require("lodash");
6
+ const decorators_1 = require("./../decorators");
7
+ const error_1 = require("./../error");
8
+ const exporter_trace_otlp_http_1 = require("@opentelemetry/exporter-trace-otlp-http");
9
+ const core_1 = require("@opentelemetry/core");
10
+ const traces_1 = require("./traces");
11
+ exports.JAEGER_EXPORTER = "JaegerExporter";
12
+ class JaegerExporter {
13
+ exporter;
14
+ constructor(endpoint = "http://localhost:4318/v1/traces") {
15
+ this.exporter = new exporter_trace_otlp_http_1.OTLPTraceExporter({
16
+ url: endpoint,
17
+ });
18
+ }
19
+ async export(rawSignals) {
20
+ // Note: it is not compatible with provenance signal.
21
+ const signals = rawSignals;
22
+ return await new Promise((resolve) => {
23
+ const exportSpans = [];
24
+ signals.forEach((signal) => {
25
+ if (signal.traceSpan) {
26
+ exportSpans.push(signal.traceSpan);
27
+ }
28
+ });
29
+ this.exporter.export(exportSpans, (results) => {
30
+ if (results.code !== core_1.ExportResultCode.SUCCESS) {
31
+ console.warn(`Jaeger export failed`);
32
+ }
33
+ });
34
+ resolve();
35
+ });
36
+ }
37
+ }
38
+ exports.JaegerExporter = JaegerExporter;
39
+ exports.POSTGRES_EXPORTER = "PostgresExporter";
40
+ class PostgresExporter {
41
+ poolConfig;
42
+ observabilityDBName;
43
+ pgClient;
44
+ constructor(poolConfig, observabilityDBName = "dbos_observability") {
45
+ this.poolConfig = poolConfig;
46
+ this.observabilityDBName = observabilityDBName;
47
+ const pgClientConfig = { ...poolConfig };
48
+ pgClientConfig.database = this.observabilityDBName;
49
+ this.pgClient = new pg_1.Client(pgClientConfig);
50
+ }
51
+ static getPGDataType(t) {
52
+ if (t.dataType === "double") {
53
+ return "double precision"; // aka "float8"
54
+ }
55
+ return t.formatAsString();
56
+ }
57
+ async init(registeredOperations = []) {
58
+ const pgSystemClient = new pg_1.Client(this.poolConfig);
59
+ await pgSystemClient.connect();
60
+ // First check if the log database exists using pgSystemClient.
61
+ const dbExists = await pgSystemClient.query(`SELECT FROM pg_database WHERE datname = '${this.observabilityDBName}'`);
62
+ if (dbExists.rows.length === 0) {
63
+ // Create the logs backend database
64
+ await pgSystemClient.query(`CREATE DATABASE ${this.observabilityDBName}`);
65
+ }
66
+ await pgSystemClient.end();
67
+ // Connect the exporter client
68
+ await this.pgClient.connect();
69
+ // Configure tables for registered workflows
70
+ for (const registeredOperation of registeredOperations) {
71
+ const tableName = `signal_${registeredOperation.name}`;
72
+ let createSignalTableQuery = `CREATE TABLE IF NOT EXISTS ${tableName} (
73
+ workflow_uuid TEXT NOT NULL,
74
+ function_name TEXT NOT NULL,
75
+ run_as TEXT NOT NULL,
76
+ timestamp BIGINT NOT NULL,
77
+ transaction_id TEXT DEFAULT NULL,
78
+ trace_id TEXT DEFAULT NULL,
79
+ trace_span JSONB DEFAULT NULL,\n`;
80
+ for (const arg of registeredOperation.args) {
81
+ if (arg.logMask === decorators_1.LogMasks.SKIP) {
82
+ continue;
83
+ }
84
+ else if (arg.logMask === decorators_1.LogMasks.HASH) {
85
+ const row = `${arg.name} VARCHAR(64) DEFAULT NULL,\n`;
86
+ createSignalTableQuery = createSignalTableQuery.concat(row);
87
+ }
88
+ else {
89
+ const row = `${arg.name} ${PostgresExporter.getPGDataType(arg.dataType)} DEFAULT NULL,\n`;
90
+ createSignalTableQuery = createSignalTableQuery.concat(row);
91
+ }
92
+ }
93
+ // Trim last comma and line feed
94
+ createSignalTableQuery = createSignalTableQuery.slice(0, -2).concat("\n);");
95
+ await this.pgClient.query(createSignalTableQuery);
96
+ // Create a table for provenance logs.
97
+ // TODO: create a secondary index.
98
+ }
99
+ await this.pgClient.query(`CREATE TABLE IF NOT EXISTS provenance_logs (
100
+ transaction_id TEXT NOT NULL,
101
+ kind TEXT,
102
+ schema_name TEXT,
103
+ table_name TEXT,
104
+ columnnames TEXT,
105
+ columntypes TEXT,
106
+ columnvalues TEXT
107
+ );`);
108
+ }
109
+ async destroy() {
110
+ await this.pgClient.end();
111
+ }
112
+ process(signals) {
113
+ const groupByFunctionName = new Map(Object.entries((0, lodash_1.groupBy)(signals, ({ operationName }) => operationName)));
114
+ const queries = [];
115
+ for (const [operationName, signals] of groupByFunctionName) {
116
+ const tableName = `signal_${operationName}`;
117
+ const query = `
118
+ INSERT INTO ${tableName}
119
+ SELECT * FROM jsonb_to_recordset($1::jsonb) AS tmp (workflow_uuid text, function_name text, run_as text, timestamp bigint, transaction_id text, trace_id text, trace_span json)
120
+ `;
121
+ const values = JSON.stringify(signals.map((signal) => {
122
+ return {
123
+ workflow_uuid: signal.workflowUUID,
124
+ function_name: signal.operationName,
125
+ run_as: signal.runAs,
126
+ timestamp: signal.timestamp,
127
+ transaction_id: signal.transactionID,
128
+ trace_id: signal.traceID,
129
+ trace_span: signal.traceSpan ? (0, traces_1.spanToString)(signal.traceSpan) : null,
130
+ };
131
+ }));
132
+ queries.push({
133
+ name: `insert-${tableName}`,
134
+ text: query,
135
+ values: [values],
136
+ });
137
+ }
138
+ return queries;
139
+ }
140
+ processProvenance(signals) {
141
+ const query = `
142
+ INSERT INTO provenance_logs
143
+ SELECT * FROM jsonb_to_recordset($1::jsonb) AS tmp (
144
+ transaction_id text, kind text, schema_name text, table_name text,
145
+ columnnames text, columntypes text, columnvalues text);
146
+ `;
147
+ const values = JSON.stringify(signals.map((signal) => {
148
+ return {
149
+ transaction_id: signal.provTransactionID,
150
+ kind: signal.kind,
151
+ schema_name: signal.schema,
152
+ table_name: signal.table,
153
+ columnnames: signal.columnnames,
154
+ columntypes: signal.columntypes,
155
+ columnvalues: signal.columnvalues
156
+ };
157
+ }));
158
+ return { name: `insert-provenance-log`, text: query, values: [values] };
159
+ }
160
+ async export(signals) {
161
+ const results = [];
162
+ // Find all telemetry signals and process.
163
+ const telemetrySignals = signals.filter(obj => obj.workflowUUID !== undefined);
164
+ if (telemetrySignals.length > 0) {
165
+ const queries = this.process(telemetrySignals);
166
+ for (const query of queries) {
167
+ results.push(this.pgClient.query(query));
168
+ }
169
+ }
170
+ // Find all provenance signals and process.
171
+ const provenanceSignals = signals.filter((obj) => obj.provTransactionID !== undefined);
172
+ if (provenanceSignals.length > 0) {
173
+ const provQuery = this.processProvenance(provenanceSignals);
174
+ results.push(this.pgClient.query(provQuery));
175
+ }
176
+ try {
177
+ // We do await here so we can catch and format PostgresExporter specific errors
178
+ return await Promise.all(results);
179
+ }
180
+ catch (err) {
181
+ throw new error_1.DBOSPostgresExporterError(err);
182
+ }
183
+ }
184
+ }
185
+ exports.PostgresExporter = PostgresExporter;
186
+ //# sourceMappingURL=exporters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exporters.js","sourceRoot":"","sources":["../../../src/telemetry/exporters.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { LoggerConfig } from "./logs";
2
+ import { TracerConfig } from "./traces";
3
+ export interface TelemetryConfig {
4
+ logs?: LoggerConfig;
5
+ traces?: TracerConfig;
6
+ }
7
+ //# 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,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,MAAM,WAAW,eAAe;IAC9B,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,MAAM,CAAC,EAAE,YAAY,CAAC;CACvB"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/telemetry/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,25 @@
1
+ import { Logger as IWinstonLogger } from "winston";
2
+ import { DBOSContext } from "../context";
3
+ export interface LoggerConfig {
4
+ logLevel?: string;
5
+ silent?: boolean;
6
+ addContextMetadata?: boolean;
7
+ }
8
+ export interface WinstonLogger extends IWinstonLogger {
9
+ addContextMetadata: boolean;
10
+ }
11
+ export declare class Logger {
12
+ private readonly globalLogger;
13
+ private readonly ctx;
14
+ readonly metadata: object;
15
+ constructor(globalLogger: WinstonLogger, ctx: DBOSContext);
16
+ info(message: string): void;
17
+ debug(message: string): void;
18
+ warn(message: string): void;
19
+ emerg(message: string): void;
20
+ alert(message: string): void;
21
+ crit(message: string): void;
22
+ error(inputError: any): void;
23
+ }
24
+ export declare function createGlobalLogger(config?: LoggerConfig): WinstonLogger;
25
+ //# 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;AAErF,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAGD,MAAM,WAAW,aAAc,SAAQ,cAAc;IACnD,kBAAkB,EAAE,OAAO,CAAC;CAC7B;AAKD,qBAAa,MAAM;IAGL,OAAO,CAAC,QAAQ,CAAC,YAAY;IAAiB,OAAO,CAAC,QAAQ,CAAC,GAAG;IAD9E,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAM;gBACF,YAAY,EAAE,aAAa,EAAmB,GAAG,EAAE,WAAW;IAW3F,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI3B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI3B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI5B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAI5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAM3B,KAAK,CAAC,UAAU,EAAE,GAAG,GAAG,IAAI;CAY7B;AAED,wBAAgB,kBAAkB,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,aAAa,CAYvE"}
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createGlobalLogger = exports.Logger = void 0;
4
+ const winston_1 = require("winston");
5
+ const applicationVersion_1 = require("../dbos-runtime/applicationVersion");
6
+ /* This is a wrapper around a global Winston logger. It holds a reference to the global logger.
7
+ * This class is expected to be instantiated by new DBOSContext such that they can share context information.
8
+ **/
9
+ class Logger {
10
+ globalLogger;
11
+ ctx;
12
+ // Eventually this object will implement one of our TelemetrySignal interface
13
+ metadata = {};
14
+ constructor(globalLogger, ctx) {
15
+ this.globalLogger = globalLogger;
16
+ this.ctx = ctx;
17
+ if (this.globalLogger.addContextMetadata) {
18
+ this.metadata = {
19
+ workflowUUID: this.ctx.workflowUUID,
20
+ authenticatedUser: this.ctx.authenticatedUser,
21
+ traceId: this.ctx.span.spanContext().traceId,
22
+ spanId: this.ctx.span.spanContext().spanId,
23
+ };
24
+ }
25
+ }
26
+ info(message) {
27
+ this.globalLogger.info(message, this.metadata);
28
+ }
29
+ debug(message) {
30
+ this.globalLogger.debug(message, this.metadata);
31
+ }
32
+ warn(message) {
33
+ this.globalLogger.warn(message, this.metadata);
34
+ }
35
+ emerg(message) {
36
+ this.globalLogger.emerg(message, this.metadata);
37
+ }
38
+ alert(message) {
39
+ this.globalLogger.alert(message, this.metadata);
40
+ }
41
+ crit(message) {
42
+ this.globalLogger.crit(message, this.metadata);
43
+ }
44
+ // We give users the same interface (message: string argument) but create an error to get a stack trace
45
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
46
+ error(inputError) {
47
+ if (inputError instanceof Error) {
48
+ this.globalLogger.error(inputError.message, { ...this.metadata, stack: inputError.stack, cause: inputError.cause });
49
+ }
50
+ else if (typeof inputError === "string") {
51
+ const e = new Error();
52
+ this.globalLogger.error(inputError, { ...this.metadata, stack: e.stack });
53
+ }
54
+ else {
55
+ // If this is neither a string nor an error, we just log it as is an ommit the context
56
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
57
+ this.globalLogger.error(inputError.toString());
58
+ }
59
+ }
60
+ }
61
+ exports.Logger = Logger;
62
+ function createGlobalLogger(config) {
63
+ const logger = (0, winston_1.createLogger)({
64
+ format: consoleFormat,
65
+ transports: [
66
+ new winston_1.transports.Console({
67
+ level: config?.logLevel || "info",
68
+ }),
69
+ ],
70
+ silent: config?.silent || false,
71
+ });
72
+ logger.addContextMetadata = config?.addContextMetadata || false;
73
+ return logger;
74
+ }
75
+ exports.createGlobalLogger = createGlobalLogger;
76
+ const consoleFormat = winston_1.format.combine(winston_1.format.errors({ stack: true }), winston_1.format.timestamp(), winston_1.format.colorize(),
77
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
78
+ winston_1.format.printf((info) => {
79
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
80
+ const { timestamp, level, message, stack, ...args } = info;
81
+ const applicationVersion = (0, applicationVersion_1.getApplicationVersion)();
82
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-assignment
83
+ const ts = timestamp.slice(0, 19).replace("T", " ");
84
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-assignment
85
+ const formattedStack = stack?.split("\n").slice(1).join("\n");
86
+ const messageString = typeof message === "string" ? message : JSON.stringify(message);
87
+ const versionString = applicationVersion ? ` [version ${applicationVersion}]` : "";
88
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
89
+ return `${ts}${versionString} [${level}]: ${messageString} ${Object.keys(args).length ? "\n" + JSON.stringify(args, null, 2) : ""} ${stack ? "\n" + formattedStack : ""}`;
90
+ }));
91
+ //# 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,30 @@
1
+ import { ReadableSpan } from "@opentelemetry/sdk-trace-base";
2
+ import { ValuesOf } from "../utils";
3
+ export type DBOSSignal = TelemetrySignal | ProvenanceSignal;
4
+ export declare const LogSeverity: {
5
+ readonly Debug: "DEBUG";
6
+ readonly Info: "INFO";
7
+ readonly Warn: "WARN";
8
+ readonly Error: "ERROR";
9
+ readonly Log: "LOG";
10
+ };
11
+ export type LogSeverity = ValuesOf<typeof LogSeverity>;
12
+ export interface TelemetrySignal {
13
+ workflowUUID: string;
14
+ operationName: string;
15
+ runAs: string;
16
+ timestamp: number;
17
+ transactionID?: string;
18
+ traceID?: string;
19
+ traceSpan?: ReadableSpan;
20
+ }
21
+ export interface ProvenanceSignal {
22
+ provTransactionID: string;
23
+ kind: string;
24
+ schema: string;
25
+ table: string;
26
+ columnnames: string[];
27
+ columntypes: string[];
28
+ columnvalues: string[];
29
+ }
30
+ //# sourceMappingURL=signals.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signals.d.ts","sourceRoot":"","sources":["../../../src/telemetry/signals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AAEpC,MAAM,MAAM,UAAU,GAAG,eAAe,GAAG,gBAAgB,CAAC;AAE5D,eAAO,MAAM,WAAW;;;;;;CAMd,CAAC;AACX,MAAM,MAAM,WAAW,GAAG,QAAQ,CAAC,OAAO,WAAW,CAAC,CAAC;AAEvD,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,YAAY,CAAC;CAC1B;AAED,MAAM,WAAW,gBAAgB;IAC/B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,YAAY,EAAE,MAAM,EAAE,CAAC;CACxB"}
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LogSeverity = void 0;
4
+ exports.LogSeverity = {
5
+ Debug: "DEBUG",
6
+ Info: "INFO",
7
+ Warn: "WARN",
8
+ Error: "ERROR",
9
+ Log: "LOG",
10
+ };
11
+ //# sourceMappingURL=signals.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signals.js","sourceRoot":"","sources":["../../../src/telemetry/signals.ts"],"names":[],"mappings":";;;AAKa,QAAA,WAAW,GAAG;IACzB,KAAK,EAAE,OAAO;IACd,IAAI,EAAE,MAAM;IACZ,IAAI,EAAE,MAAM;IACZ,KAAK,EAAE,OAAO;IACd,GAAG,EAAE,KAAK;CACF,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { ReadableSpan, Span } from "@opentelemetry/sdk-trace-base";
2
+ import { Attributes, SpanContext } from "@opentelemetry/api";
3
+ import { TelemetryCollector } from "./collector";
4
+ export interface TracerConfig {
5
+ enabled?: boolean;
6
+ endpoint?: string;
7
+ }
8
+ export declare function spanToString(span: ReadableSpan): string;
9
+ export declare class Tracer {
10
+ private readonly telemetryCollector;
11
+ private readonly tracer;
12
+ constructor(telemetryCollector: TelemetryCollector);
13
+ startSpanWithContext(spanContext: SpanContext, name: string, attributes?: Attributes): Span;
14
+ startSpan(name: string, attributes?: Attributes, parentSpan?: Span): Span;
15
+ endSpan(span: Span): void;
16
+ }
17
+ //# 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,EAAuB,YAAY,EAAE,IAAI,EAAE,MAAM,+BAA+B,CAAC;AAExF,OAAsB,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAG5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGjD,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,YAAY,GAAG,MAAM,CAevD;AAED,qBAAa,MAAM;IAEL,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IAD/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAsB;gBAChB,kBAAkB,EAAE,kBAAkB;IASnE,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;CAoBnB"}
@@ -0,0 +1,76 @@
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 = exports.spanToString = 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 core_1 = require("@opentelemetry/core");
11
+ const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
12
+ function spanToString(span) {
13
+ return JSON.stringify({
14
+ name: span.name,
15
+ kind: span.kind,
16
+ traceId: span.spanContext().traceId,
17
+ spanId: span.spanContext().spanId,
18
+ traceFlags: span.spanContext().traceFlags,
19
+ traceState: span.spanContext().traceState?.serialize(),
20
+ parentSpanId: span.parentSpanId,
21
+ start: (0, core_1.hrTimeToMicroseconds)(span.startTime),
22
+ duration: (0, core_1.hrTimeToMicroseconds)(span.duration),
23
+ attributes: span.attributes,
24
+ status: span.status,
25
+ events: span.events,
26
+ });
27
+ }
28
+ exports.spanToString = spanToString;
29
+ class Tracer {
30
+ telemetryCollector;
31
+ tracer;
32
+ constructor(telemetryCollector) {
33
+ this.telemetryCollector = telemetryCollector;
34
+ this.tracer = new sdk_trace_base_1.BasicTracerProvider({
35
+ resource: new resources_1.Resource({
36
+ [semantic_conventions_1.SemanticResourceAttributes.SERVICE_NAME]: "dbos",
37
+ }),
38
+ });
39
+ this.tracer.register();
40
+ }
41
+ startSpanWithContext(spanContext, name, attributes) {
42
+ const tracer = api_1.default.trace.getTracer("dbos-tracer");
43
+ const ctx = api_1.default.trace.setSpanContext(api_1.default.context.active(), spanContext);
44
+ return tracer.startSpan(name, { startTime: Date.now(), attributes: attributes }, ctx);
45
+ }
46
+ startSpan(name, attributes, parentSpan) {
47
+ const tracer = api_1.default.trace.getTracer("dbos-tracer");
48
+ if (parentSpan) {
49
+ const ctx = api_1.default.trace.setSpan(api_1.default.context.active(), parentSpan);
50
+ return tracer.startSpan(name, { startTime: Date.now(), attributes: attributes }, ctx);
51
+ }
52
+ else {
53
+ return tracer.startSpan(name, { attributes: attributes });
54
+ }
55
+ }
56
+ endSpan(span) {
57
+ span.end(Date.now());
58
+ const workflowUUID = span.attributes.workflowUUID;
59
+ const operationName = span.attributes.operationName;
60
+ const runAs = span.attributes.runAs;
61
+ const transactionID = span.attributes.transaction_id;
62
+ const traceID = span.spanContext().traceId;
63
+ const signal = {
64
+ workflowUUID,
65
+ operationName,
66
+ runAs,
67
+ timestamp: Date.now(),
68
+ traceID,
69
+ transactionID: transactionID,
70
+ traceSpan: span,
71
+ };
72
+ this.telemetryCollector.push(signal);
73
+ }
74
+ }
75
+ exports.Tracer = Tracer;
76
+ //# sourceMappingURL=traces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"traces.js","sourceRoot":"","sources":["../../../src/telemetry/traces.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,76 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { IncomingMessage } from "http";
4
+ import { HTTPRequest } from "../context";
5
+ import { InvokeFuncs } from "../httpServer/handler";
6
+ import { DBOSExecutor, DBOSConfig } from "../dbos-executor";
7
+ import { WorkflowHandle } from "../workflow";
8
+ import { Http2ServerRequest, Http2ServerResponse } from "http2";
9
+ import { ServerResponse } from "http";
10
+ import { SystemDatabase } from "../system_database";
11
+ /**
12
+ * Create a testing runtime. Warn: this function will drop the existing system DB and create a clean new one. Don't run tests against your production database!
13
+ */
14
+ export declare function createTestingRuntime(userClasses: object[], configFilePath?: string): Promise<TestingRuntime>;
15
+ export interface WorkflowInvokeParams {
16
+ readonly authenticatedUser?: string;
17
+ readonly authenticatedRoles?: string[];
18
+ readonly request?: HTTPRequest;
19
+ }
20
+ export interface TestingRuntime {
21
+ invoke<T extends object>(targetClass: T, workflowUUID?: string, params?: WorkflowInvokeParams): InvokeFuncs<T>;
22
+ retrieveWorkflow<R>(workflowUUID: string): WorkflowHandle<R>;
23
+ send<T extends NonNullable<any>>(destinationUUID: string, message: T, topic?: string, idempotencyKey?: string): Promise<void>;
24
+ getEvent<T extends NonNullable<any>>(workflowUUID: string, key: string, timeoutSeconds?: number): Promise<T | null>;
25
+ getHandlersCallback(): (req: IncomingMessage | Http2ServerRequest, res: ServerResponse | Http2ServerResponse) => Promise<void>;
26
+ getConfig<T>(key: string): T | undefined;
27
+ getConfig<T>(key: string, defaultValue: T): T;
28
+ queryUserDB<R>(sql: string, ...params: any[]): Promise<R[]>;
29
+ createUserSchema(): Promise<void>;
30
+ dropUserSchema(): Promise<void>;
31
+ destroy(): Promise<void>;
32
+ }
33
+ /**
34
+ * For internal unit tests which allows us to provide different system DB and control its behavior.
35
+ */
36
+ export declare function createInternalTestRuntime(userClasses: object[], testConfig: DBOSConfig, systemDB?: SystemDatabase): Promise<TestingRuntime>;
37
+ /**
38
+ * This class provides a runtime to test Opeorn functions in unit tests.
39
+ */
40
+ export declare class TestingRuntimeImpl implements TestingRuntime {
41
+ #private;
42
+ /**
43
+ * Initialize the testing runtime by loading user functions specified in classes and using the specified config.
44
+ * This should be the first function call before any subsequent calls.
45
+ */
46
+ init(userClasses: object[], testConfig?: DBOSConfig, systemDB?: SystemDatabase): Promise<void>;
47
+ /**
48
+ * Release resources after tests.
49
+ */
50
+ destroy(): Promise<void>;
51
+ /**
52
+ * Get Application Configuration.
53
+ */
54
+ getConfig<T>(key: string): T | undefined;
55
+ getConfig<T>(key: string, defaultValue: T): T;
56
+ /**
57
+ * Generate a proxy object for the provided class that wraps direct calls (i.e. OpClass.someMethod(param))
58
+ * to invoke workflows, transactions, and communicators;
59
+ */
60
+ invoke<T extends object>(object: T, workflowUUID?: string, params?: WorkflowInvokeParams): InvokeFuncs<T>;
61
+ /**
62
+ * Return a request handler callback for node's native http/http2 server, which includes all registered HTTP endpoints.
63
+ */
64
+ getHandlersCallback(): (req: IncomingMessage | Http2ServerRequest, res: Http2ServerResponse | ServerResponse<IncomingMessage>) => Promise<void>;
65
+ send<T extends NonNullable<any>>(destinationUUID: string, message: T, topic?: string, idempotencyKey?: string): Promise<void>;
66
+ getEvent<T extends NonNullable<any>>(workflowUUID: string, key: string, timeoutSeconds?: number): Promise<T | null>;
67
+ retrieveWorkflow<R>(workflowUUID: string): WorkflowHandle<R>;
68
+ queryUserDB<R>(sql: string, ...params: any[]): Promise<R[]>;
69
+ createUserSchema(): Promise<void>;
70
+ dropUserSchema(): Promise<void>;
71
+ /**
72
+ * For internal tests use only -- return the workflow executor object.
73
+ */
74
+ getDBOSExec(): DBOSExecutor;
75
+ }
76
+ //# sourceMappingURL=testing_runtime.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"testing_runtime.d.ts","sourceRoot":"","sources":["../../../src/testing/testing_runtime.ts"],"names":[],"mappings":"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"}