@dbos-inc/dbos-sdk 0.8.45-preview → 0.8.45-preview.g56ba028de5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (51) hide show
  1. package/dist/packages/dbos-cloud/cli.js +12 -0
  2. package/dist/packages/dbos-cloud/cli.js.map +1 -1
  3. package/dist/packages/dbos-cloud/userdb.d.ts +2 -0
  4. package/dist/packages/dbos-cloud/userdb.d.ts.map +1 -1
  5. package/dist/packages/dbos-cloud/userdb.js +173 -1
  6. package/dist/packages/dbos-cloud/userdb.js.map +1 -1
  7. package/dist/src/dbos-runtime/cli.d.ts.map +1 -1
  8. package/dist/src/dbos-runtime/cli.js +0 -14
  9. package/dist/src/dbos-runtime/cli.js.map +1 -1
  10. package/dist/src/system_database.d.ts +0 -2
  11. package/dist/src/system_database.d.ts.map +1 -1
  12. package/dist/src/system_database.js +11 -26
  13. package/dist/src/system_database.js.map +1 -1
  14. package/dist/src/utils.d.ts +0 -1
  15. package/dist/src/utils.d.ts.map +1 -1
  16. package/dist/src/utils.js +1 -26
  17. package/dist/src/utils.js.map +1 -1
  18. package/dist/tsconfig.build.tsbuildinfo +1 -1
  19. package/examples/hello/start_postgres_docker.sh +1 -1
  20. package/package.json +1 -1
  21. package/packages/dbos-cloud/dist/packages/dbos-cloud/cli.js +12 -0
  22. package/packages/dbos-cloud/dist/packages/dbos-cloud/cli.js.map +1 -1
  23. package/packages/dbos-cloud/dist/packages/dbos-cloud/userdb.d.ts +2 -0
  24. package/packages/dbos-cloud/dist/packages/dbos-cloud/userdb.d.ts.map +1 -1
  25. package/packages/dbos-cloud/dist/packages/dbos-cloud/userdb.js +173 -1
  26. package/packages/dbos-cloud/dist/packages/dbos-cloud/userdb.js.map +1 -1
  27. package/packages/dbos-cloud/dist/src/dbos-runtime/cli.d.ts.map +1 -1
  28. package/packages/dbos-cloud/dist/src/dbos-runtime/cli.js +0 -14
  29. package/packages/dbos-cloud/dist/src/dbos-runtime/cli.js.map +1 -1
  30. package/packages/dbos-cloud/dist/src/system_database.d.ts +0 -2
  31. package/packages/dbos-cloud/dist/src/system_database.d.ts.map +1 -1
  32. package/packages/dbos-cloud/dist/src/system_database.js +11 -26
  33. package/packages/dbos-cloud/dist/src/system_database.js.map +1 -1
  34. package/packages/dbos-cloud/dist/src/utils.d.ts +0 -1
  35. package/packages/dbos-cloud/dist/src/utils.d.ts.map +1 -1
  36. package/packages/dbos-cloud/dist/src/utils.js +1 -26
  37. package/packages/dbos-cloud/dist/src/utils.js.map +1 -1
  38. package/packages/dbos-cloud/package.json +1 -1
  39. package/packages/dbos-openapi/package.json +1 -1
  40. package/dist/src/dbos-runtime/migrate.d.ts +0 -3
  41. package/dist/src/dbos-runtime/migrate.d.ts.map +0 -1
  42. package/dist/src/dbos-runtime/migrate.js +0 -175
  43. package/dist/src/dbos-runtime/migrate.js.map +0 -1
  44. package/migrations/20240123182943_schema.js +0 -8
  45. package/migrations/20240123183021_tables.js +0 -48
  46. package/migrations/20240123183025_indexes.js +0 -14
  47. package/migrations/20240123183030_triggers.js +0 -39
  48. package/packages/dbos-cloud/dist/src/dbos-runtime/migrate.d.ts +0 -3
  49. package/packages/dbos-cloud/dist/src/dbos-runtime/migrate.d.ts.map +0 -1
  50. package/packages/dbos-cloud/dist/src/dbos-runtime/migrate.js +0 -175
  51. package/packages/dbos-cloud/dist/src/dbos-runtime/migrate.js.map +0 -1
@@ -1,3 +0,0 @@
1
- export declare function migrate(): Promise<number>;
2
- export declare function rollbackMigration(): number;
3
- //# sourceMappingURL=migrate.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../../../src/dbos-runtime/migrate.ts"],"names":[],"mappings":"AASA,wBAAsB,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAiF/C;AAED,wBAAgB,iBAAiB,IAAI,MAAM,CA4B1C"}
@@ -1,175 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.rollbackMigration = exports.migrate = void 0;
4
- const child_process_1 = require("child_process");
5
- const logs_1 = require("../telemetry/logs");
6
- const user_database_1 = require("../user_database");
7
- const config_1 = require("./config");
8
- const utils_1 = require("../utils");
9
- const pg_1 = require("pg");
10
- const user_db_schema_1 = require("../../schemas/user_db_schema");
11
- const system_database_1 = require("../system_database");
12
- async function migrate() {
13
- const logger = new logs_1.GlobalLogger();
14
- // Read the configuration YAML file
15
- const configFile = (0, config_1.loadConfigFile)(config_1.dbosConfigFilePath);
16
- if (!configFile) {
17
- logger.error(`Failed to parse ${config_1.dbosConfigFilePath}`);
18
- return 1;
19
- }
20
- const userDBName = configFile.database.user_database;
21
- logger.info(`Creating database ${userDBName} if it does not already exist`);
22
- const createDB = `createdb -h ${configFile.database.hostname} -p ${configFile.database.port} ${userDBName} -U ${configFile.database.username} -ew ${userDBName}`;
23
- try {
24
- process.env.PGPASSWORD = configFile.database.password;
25
- const createDBOutput = (0, child_process_1.execSync)(createDB, { env: process.env }).toString();
26
- if (createDBOutput.includes(`database "${userDBName}" already exists`)) {
27
- logger.info(`Database ${userDBName} already exists`);
28
- }
29
- else {
30
- logger.info(createDBOutput);
31
- }
32
- }
33
- catch (e) {
34
- if (e instanceof Error) {
35
- if (e.message.includes(`database "${userDBName}" already exists`)) {
36
- logger.info(`Database ${userDBName} already exists`);
37
- }
38
- else {
39
- logger.error(`Error creating database: ${e.message}`);
40
- return 1;
41
- }
42
- }
43
- else {
44
- logger.error(e);
45
- return 1;
46
- }
47
- }
48
- const dbType = configFile.database.user_dbclient || user_database_1.UserDatabaseName.KNEX;
49
- const migrationScript = `node_modules/.bin/${dbType}`;
50
- const migrationCommands = configFile.database.migrate;
51
- try {
52
- migrationCommands?.forEach((cmd) => {
53
- const command = `node ${migrationScript} ${cmd}`;
54
- logger.info(`Executing migration command: ${command}`);
55
- const migrateCommandOutput = (0, child_process_1.execSync)(command).toString();
56
- logger.info(migrateCommandOutput);
57
- });
58
- }
59
- catch (e) {
60
- logger.error("Error running migration");
61
- if (e instanceof Error) {
62
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
63
- const stderr = e.stderr;
64
- if (stderr && Buffer.isBuffer(stderr) && stderr.length > 0) {
65
- logger.error(`Standard Error: ${stderr.toString().trim()}`);
66
- }
67
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
68
- const stdout = e.stdout;
69
- if (stdout && Buffer.isBuffer(stdout) && stdout.length > 0) {
70
- logger.error(`Standard Output: ${stdout.toString().trim()}`);
71
- }
72
- if (e.message) {
73
- logger.error(e.message);
74
- }
75
- }
76
- else {
77
- logger.error(e);
78
- }
79
- return 1;
80
- }
81
- logger.info("Creating DBOS tables and system database.");
82
- try {
83
- await createDBOSTables(configFile);
84
- }
85
- catch (e) {
86
- if (e instanceof Error) {
87
- logger.error(`Error creating DBOS system database: ${e.message}`);
88
- }
89
- else {
90
- logger.error(e);
91
- }
92
- return 1;
93
- }
94
- return 0;
95
- }
96
- exports.migrate = migrate;
97
- function rollbackMigration() {
98
- const logger = new logs_1.GlobalLogger();
99
- // read the yaml file
100
- const configFile = (0, config_1.loadConfigFile)(config_1.dbosConfigFilePath);
101
- if (!configFile) {
102
- logger.error(`failed to parse ${config_1.dbosConfigFilePath}`);
103
- return 1;
104
- }
105
- let dbType = configFile.database.user_dbclient;
106
- if (dbType == undefined) {
107
- dbType = "knex";
108
- }
109
- const rollbackcommands = configFile.database.rollback;
110
- try {
111
- rollbackcommands?.forEach((cmd) => {
112
- const command = "npx " + dbType + " " + cmd;
113
- logger.info("Executing " + command);
114
- (0, child_process_1.execSync)(command);
115
- });
116
- }
117
- catch (e) {
118
- logger.error("Error rolling back migration. ");
119
- return 1;
120
- }
121
- return 0;
122
- }
123
- exports.rollbackMigration = rollbackMigration;
124
- // Create DBOS system DB and tables.
125
- // TODO: replace this with knex to manage schema.
126
- async function createDBOSTables(configFile) {
127
- const logger = new logs_1.GlobalLogger();
128
- const userPoolConfig = {
129
- host: configFile.database.hostname,
130
- port: configFile.database.port,
131
- user: configFile.database.username,
132
- password: configFile.database.password,
133
- connectionTimeoutMillis: configFile.database.connectionTimeoutMillis || 3000,
134
- database: configFile.database.user_database,
135
- };
136
- if (configFile.database.ssl_ca) {
137
- userPoolConfig.ssl = { ca: [(0, utils_1.readFileSync)(configFile.database.ssl_ca)], rejectUnauthorized: true };
138
- }
139
- const systemPoolConfig = { ...userPoolConfig };
140
- systemPoolConfig.database = `${userPoolConfig.database}_dbos_sys`;
141
- const pgUserClient = new pg_1.Client(userPoolConfig);
142
- await pgUserClient.connect();
143
- // Create DBOS table/schema in user DB.
144
- const schemaExists = await pgUserClient.query(`SELECT EXISTS (SELECT FROM information_schema.schemata WHERE schema_name = 'dbos')`);
145
- if (!schemaExists.rows[0].exists) {
146
- await pgUserClient.query(user_db_schema_1.createUserDBSchema);
147
- await pgUserClient.query(user_db_schema_1.userDBSchema);
148
- }
149
- // Create the DBOS system database.
150
- const dbExists = await pgUserClient.query(`SELECT EXISTS (SELECT FROM pg_database WHERE datname = '${systemPoolConfig.database}')`);
151
- if (!dbExists.rows[0].exists) {
152
- await pgUserClient.query(`CREATE DATABASE ${systemPoolConfig.database}`);
153
- }
154
- // Load the DBOS system schema.
155
- const pgSystemClient = new pg_1.Client(systemPoolConfig);
156
- await pgSystemClient.connect();
157
- try {
158
- await (0, system_database_1.migrateSystemDatabase)(systemPoolConfig);
159
- }
160
- catch (e) {
161
- const tableExists = await pgSystemClient.query(`SELECT EXISTS (SELECT FROM information_schema.tables WHERE table_schema = 'dbos' AND table_name = 'operation_outputs')`);
162
- if (tableExists.rows[0].exists) {
163
- // If the table has been created by someone else. Ignore the error.
164
- logger.warn(`System tables creation failed, may conflict with concurrent tasks: ${e.message}`);
165
- }
166
- else {
167
- throw e;
168
- }
169
- }
170
- finally {
171
- await pgSystemClient.end();
172
- await pgUserClient.end();
173
- }
174
- }
175
- //# sourceMappingURL=migrate.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../../src/dbos-runtime/migrate.ts"],"names":[],"mappings":"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"}
@@ -1,8 +0,0 @@
1
- exports.up = function(knex) {
2
- return knex.raw('CREATE SCHEMA IF NOT EXISTS dbos');
3
- };
4
-
5
- exports.down = function(knex) {
6
- return knex.raw('DROP SCHEMA IF EXISTS dbos');
7
- };
8
-
@@ -1,48 +0,0 @@
1
- exports.up = function(knex) {
2
- return knex.schema.withSchema('dbos')
3
- .createTable('operation_outputs', function(table) {
4
- table.text('workflow_uuid').notNullable();
5
- table.integer('function_id').notNullable();
6
- table.text('output');
7
- table.text('error');
8
- table.primary(['workflow_uuid', 'function_id']);
9
- })
10
- .createTable('workflow_inputs', function(table) {
11
- table.text('workflow_uuid').primary().notNullable();
12
- table.text('inputs').notNullable();
13
- })
14
- .createTable('workflow_status', function(table) {
15
- table.text('workflow_uuid').primary();
16
- table.text('status');
17
- table.text('name');
18
- table.text('authenticated_user');
19
- table.text('assumed_role');
20
- table.text('authenticated_roles');
21
- table.text('request');
22
- table.text('output');
23
- table.text('error');
24
- table.text('executor_id');
25
- })
26
- .createTable('notifications', function(table) {
27
- table.text('destination_uuid').notNullable();
28
- table.text('topic');
29
- table.text('message').notNullable();
30
- table.bigInteger('created_at_epoch_ms').notNullable().defaultTo(knex.raw('(EXTRACT(EPOCH FROM now())*1000)::bigint'));
31
- })
32
- .createTable('workflow_events', function(table) {
33
- table.text('workflow_uuid').notNullable();
34
- table.text('key').notNullable();
35
- table.text('value').notNullable();
36
- table.primary(['workflow_uuid', 'key']);
37
- });
38
- };
39
-
40
- exports.down = function(knex) {
41
- return knex.schema.withSchema('dbos')
42
- .dropTableIfExists('operation_outputs')
43
- .dropTableIfExists('workflow_inputs')
44
- .dropTableIfExists('workflow_status')
45
- .dropTableIfExists('notifications')
46
- .dropTableIfExists('workflow_events');
47
- };
48
-
@@ -1,14 +0,0 @@
1
- exports.up = function(knex) {
2
- return knex.schema.withSchema('dbos')
3
- .table('notifications', function(table) {
4
- table.index(['destination_uuid', 'topic'], 'idx_workflow_topic');
5
- });
6
- };
7
-
8
- exports.down = function(knex) {
9
- return knex.schema.withSchema('dbos')
10
- .table('notifications', function(table) {
11
- table.dropIndex(['destination_uuid', 'topic'], 'idx_workflow_topic');
12
- });
13
- };
14
-
@@ -1,39 +0,0 @@
1
- exports.up = function(knex) {
2
- return knex.raw(`
3
- CREATE OR REPLACE FUNCTION dbos.notifications_function() RETURNS TRIGGER AS $$
4
- DECLARE
5
- payload text := NEW.destination_uuid || '::' || NEW.topic;
6
- BEGIN
7
- PERFORM pg_notify('dbos_notifications_channel', payload);
8
- RETURN NEW;
9
- END;
10
- $$ LANGUAGE plpgsql;
11
-
12
- CREATE TRIGGER dbos_notifications_trigger
13
- AFTER INSERT ON dbos.notifications
14
- FOR EACH ROW EXECUTE FUNCTION dbos.notifications_function();
15
-
16
- CREATE OR REPLACE FUNCTION dbos.workflow_events_function() RETURNS TRIGGER AS $$
17
- DECLARE
18
- payload text := NEW.workflow_uuid || '::' || NEW.key;
19
- BEGIN
20
- PERFORM pg_notify('dbos_workflow_events_channel', payload);
21
- RETURN NEW;
22
- END;
23
- $$ LANGUAGE plpgsql;
24
-
25
- CREATE TRIGGER dbos_workflow_events_trigger
26
- AFTER INSERT ON dbos.workflow_events
27
- FOR EACH ROW EXECUTE FUNCTION dbos.workflow_events_function();
28
- `);
29
- };
30
-
31
- exports.down = function(knex) {
32
- return knex.raw(`
33
- DROP TRIGGER IF EXISTS dbos_notifications_trigger ON dbos.notifications;
34
- DROP FUNCTION IF EXISTS dbos.notifications_function;
35
- DROP TRIGGER IF EXISTS dbos_workflow_events_trigger ON dbos.workflow_events;
36
- DROP FUNCTION IF EXISTS dbos.workflow_events_function;
37
- `);
38
- };
39
-
@@ -1,3 +0,0 @@
1
- export declare function migrate(): Promise<number>;
2
- export declare function rollbackMigration(): number;
3
- //# sourceMappingURL=migrate.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"migrate.d.ts","sourceRoot":"","sources":["../../../../../src/dbos-runtime/migrate.ts"],"names":[],"mappings":"AASA,wBAAsB,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAiF/C;AAED,wBAAgB,iBAAiB,IAAI,MAAM,CA4B1C"}
@@ -1,175 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.rollbackMigration = exports.migrate = void 0;
4
- const child_process_1 = require("child_process");
5
- const logs_1 = require("../telemetry/logs");
6
- const user_database_1 = require("../user_database");
7
- const config_1 = require("./config");
8
- const utils_1 = require("../utils");
9
- const pg_1 = require("pg");
10
- const user_db_schema_1 = require("../../schemas/user_db_schema");
11
- const system_database_1 = require("../system_database");
12
- async function migrate() {
13
- const logger = new logs_1.GlobalLogger();
14
- // Read the configuration YAML file
15
- const configFile = (0, config_1.loadConfigFile)(config_1.dbosConfigFilePath);
16
- if (!configFile) {
17
- logger.error(`Failed to parse ${config_1.dbosConfigFilePath}`);
18
- return 1;
19
- }
20
- const userDBName = configFile.database.user_database;
21
- logger.info(`Creating database ${userDBName} if it does not already exist`);
22
- const createDB = `createdb -h ${configFile.database.hostname} -p ${configFile.database.port} ${userDBName} -U ${configFile.database.username} -ew ${userDBName}`;
23
- try {
24
- process.env.PGPASSWORD = configFile.database.password;
25
- const createDBOutput = (0, child_process_1.execSync)(createDB, { env: process.env }).toString();
26
- if (createDBOutput.includes(`database "${userDBName}" already exists`)) {
27
- logger.info(`Database ${userDBName} already exists`);
28
- }
29
- else {
30
- logger.info(createDBOutput);
31
- }
32
- }
33
- catch (e) {
34
- if (e instanceof Error) {
35
- if (e.message.includes(`database "${userDBName}" already exists`)) {
36
- logger.info(`Database ${userDBName} already exists`);
37
- }
38
- else {
39
- logger.error(`Error creating database: ${e.message}`);
40
- return 1;
41
- }
42
- }
43
- else {
44
- logger.error(e);
45
- return 1;
46
- }
47
- }
48
- const dbType = configFile.database.user_dbclient || user_database_1.UserDatabaseName.KNEX;
49
- const migrationScript = `node_modules/.bin/${dbType}`;
50
- const migrationCommands = configFile.database.migrate;
51
- try {
52
- migrationCommands?.forEach((cmd) => {
53
- const command = `node ${migrationScript} ${cmd}`;
54
- logger.info(`Executing migration command: ${command}`);
55
- const migrateCommandOutput = (0, child_process_1.execSync)(command).toString();
56
- logger.info(migrateCommandOutput);
57
- });
58
- }
59
- catch (e) {
60
- logger.error("Error running migration");
61
- if (e instanceof Error) {
62
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
63
- const stderr = e.stderr;
64
- if (stderr && Buffer.isBuffer(stderr) && stderr.length > 0) {
65
- logger.error(`Standard Error: ${stderr.toString().trim()}`);
66
- }
67
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-explicit-any
68
- const stdout = e.stdout;
69
- if (stdout && Buffer.isBuffer(stdout) && stdout.length > 0) {
70
- logger.error(`Standard Output: ${stdout.toString().trim()}`);
71
- }
72
- if (e.message) {
73
- logger.error(e.message);
74
- }
75
- }
76
- else {
77
- logger.error(e);
78
- }
79
- return 1;
80
- }
81
- logger.info("Creating DBOS tables and system database.");
82
- try {
83
- await createDBOSTables(configFile);
84
- }
85
- catch (e) {
86
- if (e instanceof Error) {
87
- logger.error(`Error creating DBOS system database: ${e.message}`);
88
- }
89
- else {
90
- logger.error(e);
91
- }
92
- return 1;
93
- }
94
- return 0;
95
- }
96
- exports.migrate = migrate;
97
- function rollbackMigration() {
98
- const logger = new logs_1.GlobalLogger();
99
- // read the yaml file
100
- const configFile = (0, config_1.loadConfigFile)(config_1.dbosConfigFilePath);
101
- if (!configFile) {
102
- logger.error(`failed to parse ${config_1.dbosConfigFilePath}`);
103
- return 1;
104
- }
105
- let dbType = configFile.database.user_dbclient;
106
- if (dbType == undefined) {
107
- dbType = "knex";
108
- }
109
- const rollbackcommands = configFile.database.rollback;
110
- try {
111
- rollbackcommands?.forEach((cmd) => {
112
- const command = "npx " + dbType + " " + cmd;
113
- logger.info("Executing " + command);
114
- (0, child_process_1.execSync)(command);
115
- });
116
- }
117
- catch (e) {
118
- logger.error("Error rolling back migration. ");
119
- return 1;
120
- }
121
- return 0;
122
- }
123
- exports.rollbackMigration = rollbackMigration;
124
- // Create DBOS system DB and tables.
125
- // TODO: replace this with knex to manage schema.
126
- async function createDBOSTables(configFile) {
127
- const logger = new logs_1.GlobalLogger();
128
- const userPoolConfig = {
129
- host: configFile.database.hostname,
130
- port: configFile.database.port,
131
- user: configFile.database.username,
132
- password: configFile.database.password,
133
- connectionTimeoutMillis: configFile.database.connectionTimeoutMillis || 3000,
134
- database: configFile.database.user_database,
135
- };
136
- if (configFile.database.ssl_ca) {
137
- userPoolConfig.ssl = { ca: [(0, utils_1.readFileSync)(configFile.database.ssl_ca)], rejectUnauthorized: true };
138
- }
139
- const systemPoolConfig = { ...userPoolConfig };
140
- systemPoolConfig.database = `${userPoolConfig.database}_dbos_sys`;
141
- const pgUserClient = new pg_1.Client(userPoolConfig);
142
- await pgUserClient.connect();
143
- // Create DBOS table/schema in user DB.
144
- const schemaExists = await pgUserClient.query(`SELECT EXISTS (SELECT FROM information_schema.schemata WHERE schema_name = 'dbos')`);
145
- if (!schemaExists.rows[0].exists) {
146
- await pgUserClient.query(user_db_schema_1.createUserDBSchema);
147
- await pgUserClient.query(user_db_schema_1.userDBSchema);
148
- }
149
- // Create the DBOS system database.
150
- const dbExists = await pgUserClient.query(`SELECT EXISTS (SELECT FROM pg_database WHERE datname = '${systemPoolConfig.database}')`);
151
- if (!dbExists.rows[0].exists) {
152
- await pgUserClient.query(`CREATE DATABASE ${systemPoolConfig.database}`);
153
- }
154
- // Load the DBOS system schema.
155
- const pgSystemClient = new pg_1.Client(systemPoolConfig);
156
- await pgSystemClient.connect();
157
- try {
158
- await (0, system_database_1.migrateSystemDatabase)(systemPoolConfig);
159
- }
160
- catch (e) {
161
- const tableExists = await pgSystemClient.query(`SELECT EXISTS (SELECT FROM information_schema.tables WHERE table_schema = 'dbos' AND table_name = 'operation_outputs')`);
162
- if (tableExists.rows[0].exists) {
163
- // If the table has been created by someone else. Ignore the error.
164
- logger.warn(`System tables creation failed, may conflict with concurrent tasks: ${e.message}`);
165
- }
166
- else {
167
- throw e;
168
- }
169
- }
170
- finally {
171
- await pgSystemClient.end();
172
- await pgUserClient.end();
173
- }
174
- }
175
- //# sourceMappingURL=migrate.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"migrate.js","sourceRoot":"","sources":["../../../../../src/dbos-runtime/migrate.ts"],"names":[],"mappings":"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"}