@dbos-inc/node-pg-datasource 3.0.7-preview → 3.0.8-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/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +75 -48
- package/dist/index.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/index.ts +105 -75
- package/package.json +6 -5
- package/tests/config.test.ts +1 -1
- package/tests/datasource.test.ts +179 -58
- package/tests/test-helpers.ts +3 -2
package/dist/index.d.ts
CHANGED
|
@@ -3,12 +3,12 @@ import { type ClientBase, type ClientConfig, type PoolConfig } from 'pg';
|
|
|
3
3
|
export { NodePostgresTransactionOptions };
|
|
4
4
|
export declare class NodePostgresDataSource implements DBOSDataSource<NodePostgresTransactionOptions> {
|
|
5
5
|
#private;
|
|
6
|
+
readonly name: string;
|
|
6
7
|
static get client(): ClientBase;
|
|
7
8
|
static initializeInternalSchema(config: ClientConfig): Promise<void>;
|
|
8
|
-
readonly name: string;
|
|
9
9
|
constructor(name: string, config: PoolConfig);
|
|
10
10
|
runTransaction<T>(callback: () => Promise<T>, funcName: string, config?: NodePostgresTransactionOptions): Promise<T>;
|
|
11
|
-
registerTransaction<This, Args extends unknown[], Return>(func: (this: This, ...args: Args) => Promise<Return>,
|
|
12
|
-
transaction(config?: NodePostgresTransactionOptions): <This, Args extends unknown[], Return>(_target: object, propertyKey:
|
|
11
|
+
registerTransaction<This, Args extends unknown[], Return>(func: (this: This, ...args: Args) => Promise<Return>, config?: NodePostgresTransactionOptions, name?: string): (this: This, ...args: Args) => Promise<Return>;
|
|
12
|
+
transaction(config?: NodePostgresTransactionOptions): <This, Args extends unknown[], Return>(_target: object, propertyKey: PropertyKey, descriptor: TypedPropertyDescriptor<(this: This, ...args: Args) => Promise<Return>>) => TypedPropertyDescriptor<(this: This, ...args: Args) => Promise<Return>>;
|
|
13
13
|
}
|
|
14
14
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAGA,OAAO,EAQL,mBAAmB,IAAI,8BAA8B,EACrD,cAAc,EAEf,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAU,KAAK,UAAU,EAAE,KAAK,YAAY,EAAQ,KAAK,UAAU,EAAE,MAAM,IAAI,CAAC;AAQvF,OAAO,EAAE,8BAA8B,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAGA,OAAO,EAQL,mBAAmB,IAAI,8BAA8B,EACrD,cAAc,EAEf,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAU,KAAK,UAAU,EAAE,KAAK,YAAY,EAAQ,KAAK,UAAU,EAAE,MAAM,IAAI,CAAC;AAQvF,OAAO,EAAE,8BAA8B,EAAE,CAAC;AAwL1C,qBAAa,sBAAuB,YAAW,cAAc,CAAC,8BAA8B,CAAC;;IA0BzF,QAAQ,CAAC,IAAI,EAAE,MAAM;IAzBvB,MAAM,KAAK,MAAM,IAAI,UAAU,CAS9B;WAEY,wBAAwB,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;gBAc/D,IAAI,EAAE,MAAM,EACrB,MAAM,EAAE,UAAU;IAMd,cAAc,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,8BAA8B;IAI7G,mBAAmB,CAAC,IAAI,EAAE,IAAI,SAAS,OAAO,EAAE,EAAE,MAAM,EACtD,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC,MAAM,CAAC,EACpD,MAAM,CAAC,EAAE,8BAA8B,EACvC,IAAI,CAAC,EAAE,MAAM,GACZ,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,IAAI,KAAK,OAAO,CAAC,MAAM,CAAC;IAIjD,WAAW,CAAC,MAAM,CAAC,EAAE,8BAA8B,mDAItC,MAAM,eACF,WAAW,cACZ,wBAAwB,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,EAAE,IAAI,KAAK,QAAQ,MAAM,CAAC,CAAC,oCAAxC,IAAI,WAAW,IAAI,KAAK,QAAQ,MAAM,CAAC;CAWvF"}
|
package/dist/index.js
CHANGED
|
@@ -8,32 +8,64 @@ const pg_1 = require("pg");
|
|
|
8
8
|
const node_async_hooks_1 = require("node:async_hooks");
|
|
9
9
|
const superjson_1 = require("superjson");
|
|
10
10
|
const asyncLocalCtx = new node_async_hooks_1.AsyncLocalStorage();
|
|
11
|
-
class
|
|
11
|
+
class NodePostgresTransactionHandler {
|
|
12
12
|
name;
|
|
13
|
+
config;
|
|
13
14
|
dsType = 'NodePostgresDataSource';
|
|
14
|
-
#
|
|
15
|
+
#poolField;
|
|
15
16
|
constructor(name, config) {
|
|
16
17
|
this.name = name;
|
|
17
|
-
this
|
|
18
|
+
this.config = config;
|
|
18
19
|
}
|
|
19
|
-
initialize() {
|
|
20
|
-
|
|
20
|
+
async initialize() {
|
|
21
|
+
const pool = this.#poolField;
|
|
22
|
+
this.#poolField = new pg_1.Pool(this.config);
|
|
23
|
+
await pool?.end();
|
|
21
24
|
}
|
|
22
|
-
destroy() {
|
|
23
|
-
|
|
25
|
+
async destroy() {
|
|
26
|
+
const pool = this.#poolField;
|
|
27
|
+
this.#poolField = undefined;
|
|
28
|
+
await pool?.end();
|
|
24
29
|
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
return
|
|
30
|
+
get #pool() {
|
|
31
|
+
if (!this.#poolField) {
|
|
32
|
+
throw new Error(`DataSource ${this.name} is not initialized.`);
|
|
33
|
+
}
|
|
34
|
+
return this.#poolField;
|
|
35
|
+
}
|
|
36
|
+
async #checkExecution(workflowID, stepID) {
|
|
37
|
+
const { rows } = await this.#pool.query(
|
|
38
|
+
/*sql*/
|
|
39
|
+
`SELECT output, error FROM dbos.transaction_completion
|
|
40
|
+
WHERE workflow_id = $1 AND function_num = $2`, [workflowID, stepID]);
|
|
41
|
+
if (rows.length === 0) {
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
const { output, error } = rows[0];
|
|
45
|
+
return error !== null ? { error } : { output };
|
|
30
46
|
}
|
|
31
|
-
static async #recordOutput(client, workflowID,
|
|
47
|
+
static async #recordOutput(client, workflowID, stepID, output) {
|
|
32
48
|
try {
|
|
33
49
|
await client.query(
|
|
34
50
|
/*sql*/
|
|
35
51
|
`INSERT INTO dbos.transaction_completion (workflow_id, function_num, output)
|
|
36
|
-
VALUES ($1, $2, $3)`, [workflowID,
|
|
52
|
+
VALUES ($1, $2, $3)`, [workflowID, stepID, output]);
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
if ((0, datasource_1.isPGKeyConflictError)(error)) {
|
|
56
|
+
throw new dbos_sdk_1.DBOSWorkflowConflictError(workflowID);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
throw error;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async #recordError(workflowID, stepID, error) {
|
|
64
|
+
try {
|
|
65
|
+
await this.#pool.query(
|
|
66
|
+
/*sql*/
|
|
67
|
+
`INSERT INTO dbos.transaction_completion (workflow_id, function_num, error)
|
|
68
|
+
VALUES ($1, $2, $3)`, [workflowID, stepID, error]);
|
|
37
69
|
}
|
|
38
70
|
catch (error) {
|
|
39
71
|
if ((0, datasource_1.isPGKeyConflictError)(error)) {
|
|
@@ -65,57 +97,52 @@ class NodePGDSTH {
|
|
|
65
97
|
}
|
|
66
98
|
async invokeTransactionFunction(config, target, func, ...args) {
|
|
67
99
|
const workflowID = dbos_sdk_1.DBOS.workflowID;
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
const functionNum = dbos_sdk_1.DBOS.stepID;
|
|
72
|
-
if (functionNum === undefined) {
|
|
73
|
-
throw new Error('Function Number is not set.');
|
|
100
|
+
const stepID = dbos_sdk_1.DBOS.stepID;
|
|
101
|
+
if (workflowID !== undefined && stepID === undefined) {
|
|
102
|
+
throw new Error('DBOS.stepID is undefined inside a workflow.');
|
|
74
103
|
}
|
|
75
104
|
const readOnly = config?.readOnly ?? false;
|
|
105
|
+
const saveResults = !readOnly && workflowID !== undefined;
|
|
106
|
+
// Retry loop if appropriate
|
|
76
107
|
let retryWaitMS = 1;
|
|
77
108
|
const backoffFactor = 1.5;
|
|
78
|
-
const maxRetryWaitMS = 2000;
|
|
109
|
+
const maxRetryWaitMS = 2000; // Maximum wait 2 seconds.
|
|
79
110
|
while (true) {
|
|
111
|
+
// Check to see if this tx has already been executed
|
|
112
|
+
const previousResult = saveResults ? await this.#checkExecution(workflowID, stepID) : undefined;
|
|
113
|
+
if (previousResult) {
|
|
114
|
+
dbos_sdk_1.DBOS.span?.setAttribute('cached', true);
|
|
115
|
+
if ('error' in previousResult) {
|
|
116
|
+
throw superjson_1.SuperJSON.parse(previousResult.error);
|
|
117
|
+
}
|
|
118
|
+
return (previousResult.output ? superjson_1.SuperJSON.parse(previousResult.output) : null);
|
|
119
|
+
}
|
|
80
120
|
try {
|
|
81
121
|
const result = await this.#transaction(async (client) => {
|
|
82
|
-
// Check to see if this tx has already been executed
|
|
83
|
-
const previousResult = readOnly || !workflowID ? undefined : await NodePGDSTH.#checkExecution(client, workflowID, functionNum);
|
|
84
|
-
if (previousResult) {
|
|
85
|
-
return (previousResult.output ? superjson_1.SuperJSON.parse(previousResult.output) : null);
|
|
86
|
-
}
|
|
87
122
|
// execute user's transaction function
|
|
88
123
|
const result = await asyncLocalCtx.run({ client }, async () => {
|
|
89
124
|
return (await func.call(target, ...args));
|
|
90
125
|
});
|
|
91
126
|
// save the output of read/write transactions
|
|
92
|
-
if (
|
|
93
|
-
await
|
|
94
|
-
// Note, existing code wraps #recordOutput call in a try/catch block that
|
|
95
|
-
// converts DB error with code 25P02 to DBOSFailedSqlTransactionError.
|
|
96
|
-
// However, existing code doesn't make any logic decisions based on that error type.
|
|
97
|
-
// DBOSFailedSqlTransactionError does stored WF ID and function name, so I assume that info is logged out somewhere
|
|
127
|
+
if (saveResults) {
|
|
128
|
+
await NodePostgresTransactionHandler.#recordOutput(client, workflowID, stepID, superjson_1.SuperJSON.stringify(result));
|
|
98
129
|
}
|
|
99
130
|
return result;
|
|
100
|
-
},
|
|
101
|
-
// TODO: span.setStatus({ code: SpanStatusCode.OK });
|
|
102
|
-
// TODO: this.tracer.endSpan(span);
|
|
131
|
+
}, config);
|
|
103
132
|
return result;
|
|
104
133
|
}
|
|
105
134
|
catch (error) {
|
|
106
135
|
if ((0, datasource_1.isPGRetriableTransactionError)(error)) {
|
|
107
|
-
|
|
136
|
+
dbos_sdk_1.DBOS.span?.addEvent('TXN SERIALIZATION FAILURE', { retryWaitMillis: retryWaitMS }, performance.now());
|
|
108
137
|
await new Promise((resolve) => setTimeout(resolve, retryWaitMS));
|
|
109
138
|
retryWaitMS = Math.min(retryWaitMS * backoffFactor, maxRetryWaitMS);
|
|
110
139
|
continue;
|
|
111
140
|
}
|
|
112
141
|
else {
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
// However, I'm concerned that we have a dueling execution hole where one tx fails while another succeeds.
|
|
118
|
-
// This implies that we can end up in a situation where the step output records an error but the txOutput table records success.
|
|
142
|
+
if (saveResults) {
|
|
143
|
+
const message = superjson_1.SuperJSON.stringify(error);
|
|
144
|
+
await this.#recordError(workflowID, stepID, message);
|
|
145
|
+
}
|
|
119
146
|
throw error;
|
|
120
147
|
}
|
|
121
148
|
}
|
|
@@ -123,13 +150,14 @@ class NodePGDSTH {
|
|
|
123
150
|
}
|
|
124
151
|
}
|
|
125
152
|
class NodePostgresDataSource {
|
|
153
|
+
name;
|
|
126
154
|
static get client() {
|
|
127
155
|
if (!dbos_sdk_1.DBOS.isInTransaction()) {
|
|
128
156
|
throw new Error('invalid use of NodePostgresDataSource.client outside of a DBOS transaction.');
|
|
129
157
|
}
|
|
130
158
|
const ctx = asyncLocalCtx.getStore();
|
|
131
159
|
if (!ctx) {
|
|
132
|
-
throw new Error('
|
|
160
|
+
throw new Error('invalid use of NodePostgresDataSource.client outside of a DBOS transaction.');
|
|
133
161
|
}
|
|
134
162
|
return ctx.client;
|
|
135
163
|
}
|
|
@@ -144,18 +172,17 @@ class NodePostgresDataSource {
|
|
|
144
172
|
await client.end();
|
|
145
173
|
}
|
|
146
174
|
}
|
|
147
|
-
name;
|
|
148
175
|
#provider;
|
|
149
176
|
constructor(name, config) {
|
|
150
177
|
this.name = name;
|
|
151
|
-
this.#provider = new
|
|
178
|
+
this.#provider = new NodePostgresTransactionHandler(name, config);
|
|
152
179
|
(0, datasource_1.registerDataSource)(this.#provider);
|
|
153
180
|
}
|
|
154
181
|
async runTransaction(callback, funcName, config) {
|
|
155
182
|
return await (0, datasource_1.runTransaction)(callback, funcName, { dsName: this.name, config });
|
|
156
183
|
}
|
|
157
|
-
registerTransaction(func,
|
|
158
|
-
return (0, datasource_1.registerTransaction)(this.name, func, { name }, config);
|
|
184
|
+
registerTransaction(func, config, name) {
|
|
185
|
+
return (0, datasource_1.registerTransaction)(this.name, func, { name: name ?? func.name }, config);
|
|
159
186
|
}
|
|
160
187
|
transaction(config) {
|
|
161
188
|
// eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
@@ -164,7 +191,7 @@ class NodePostgresDataSource {
|
|
|
164
191
|
if (!descriptor.value) {
|
|
165
192
|
throw Error('Use of decorator when original method is undefined');
|
|
166
193
|
}
|
|
167
|
-
descriptor.value = ds.registerTransaction(descriptor.value,
|
|
194
|
+
descriptor.value = ds.registerTransaction(descriptor.value, config, String(propertyKey));
|
|
168
195
|
return descriptor;
|
|
169
196
|
};
|
|
170
197
|
}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";AAAA,gDAAgD;;;AAEhD,iDAAqE;AACrE,8DAWuC;AACvC,2BAAuF;AACvF,uDAAqD;AACrD,yCAAsC;AAQtC,MAAM,aAAa,GAAG,IAAI,oCAAiB,EAAiC,CAAC;AAE7E,MAAM,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"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"}
|