velocious 1.0.146 → 1.0.147
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/build/src/application.d.ts +8 -8
- package/build/src/application.d.ts.map +1 -1
- package/build/src/application.js +9 -9
- package/build/src/cli/base-command.d.ts +5 -5
- package/build/src/cli/base-command.d.ts.map +1 -1
- package/build/src/cli/base-command.js +6 -6
- package/build/src/cli/browser-cli.d.ts +2 -2
- package/build/src/cli/browser-cli.js +3 -3
- package/build/src/cli/commands/db/create.d.ts +3 -3
- package/build/src/cli/commands/db/create.js +4 -4
- package/build/src/cli/index.d.ts +1 -1
- package/build/src/cli/index.d.ts.map +1 -1
- package/build/src/cli/index.js +2 -2
- package/build/src/configuration-resolver.d.ts +1 -1
- package/build/src/configuration-resolver.js +2 -2
- package/build/src/configuration.d.ts +34 -34
- package/build/src/configuration.d.ts.map +1 -1
- package/build/src/configuration.js +35 -35
- package/build/src/controller.d.ts +13 -13
- package/build/src/controller.d.ts.map +1 -1
- package/build/src/controller.js +14 -14
- package/build/src/database/drivers/base-column.d.ts +13 -13
- package/build/src/database/drivers/base-column.js +14 -14
- package/build/src/database/drivers/base-columns-index.d.ts +8 -8
- package/build/src/database/drivers/base-columns-index.js +9 -9
- package/build/src/database/drivers/base-foreign-key.d.ts +9 -9
- package/build/src/database/drivers/base-foreign-key.js +10 -10
- package/build/src/database/drivers/base-table.d.ts +11 -11
- package/build/src/database/drivers/base-table.d.ts.map +1 -1
- package/build/src/database/drivers/base-table.js +13 -12
- package/build/src/database/drivers/base.d.ts +69 -65
- package/build/src/database/drivers/base.d.ts.map +1 -1
- package/build/src/database/drivers/base.js +83 -66
- package/build/src/database/drivers/mssql/index.d.ts +5 -5
- package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
- package/build/src/database/drivers/mssql/index.js +26 -25
- package/build/src/database/drivers/mssql/options.js +6 -6
- package/build/src/database/drivers/mssql/structure-sql.d.ts +2 -2
- package/build/src/database/drivers/mssql/structure-sql.js +3 -3
- package/build/src/database/drivers/mssql/table.d.ts.map +1 -1
- package/build/src/database/drivers/mssql/table.js +3 -2
- package/build/src/database/drivers/mysql/index.d.ts +5 -5
- package/build/src/database/drivers/mysql/index.js +27 -27
- package/build/src/database/drivers/mysql/options.js +2 -2
- package/build/src/database/drivers/mysql/query.d.ts +2 -1
- package/build/src/database/drivers/mysql/query.d.ts.map +1 -1
- package/build/src/database/drivers/mysql/query.js +2 -1
- package/build/src/database/drivers/mysql/structure-sql.d.ts +3 -3
- package/build/src/database/drivers/mysql/structure-sql.js +4 -4
- package/build/src/database/drivers/pgsql/index.d.ts +1 -1
- package/build/src/database/drivers/pgsql/index.js +14 -14
- package/build/src/database/drivers/pgsql/options.d.ts +1 -1
- package/build/src/database/drivers/pgsql/options.js +2 -2
- package/build/src/database/drivers/pgsql/structure-sql.d.ts +2 -2
- package/build/src/database/drivers/pgsql/structure-sql.js +3 -3
- package/build/src/database/drivers/sqlite/base.d.ts +4 -4
- package/build/src/database/drivers/sqlite/base.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/base.js +24 -21
- package/build/src/database/drivers/sqlite/connection-sql-js.d.ts +1 -1
- package/build/src/database/drivers/sqlite/connection-sql-js.js +2 -2
- package/build/src/database/drivers/sqlite/index.js +2 -2
- package/build/src/database/drivers/sqlite/index.web.d.ts +1 -1
- package/build/src/database/drivers/sqlite/index.web.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/index.web.js +3 -3
- package/build/src/database/drivers/sqlite/options.d.ts +1 -1
- package/build/src/database/drivers/sqlite/options.js +2 -2
- package/build/src/database/drivers/sqlite/query.d.ts +1 -1
- package/build/src/database/drivers/sqlite/query.js +2 -2
- package/build/src/database/drivers/sqlite/query.web.d.ts +1 -1
- package/build/src/database/drivers/sqlite/query.web.js +2 -2
- package/build/src/database/drivers/sqlite/sql/alter-table.js +2 -2
- package/build/src/database/drivers/sqlite/structure-sql.d.ts +1 -1
- package/build/src/database/drivers/sqlite/structure-sql.js +2 -2
- package/build/src/database/drivers/sqlite/table.d.ts +4 -1
- package/build/src/database/drivers/sqlite/table.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/table.js +6 -3
- package/build/src/database/drivers/structure-sql/utils.d.ts +2 -2
- package/build/src/database/drivers/structure-sql/utils.js +3 -3
- package/build/src/database/handler.d.ts +1 -1
- package/build/src/database/handler.js +2 -2
- package/build/src/database/initializer-from-require-context.d.ts +1 -1
- package/build/src/database/initializer-from-require-context.js +2 -2
- package/build/src/database/migration/index.d.ts +17 -17
- package/build/src/database/migration/index.d.ts.map +1 -1
- package/build/src/database/migration/index.js +19 -19
- package/build/src/database/migrator/files-finder.d.ts +1 -1
- package/build/src/database/migrator/files-finder.js +2 -2
- package/build/src/database/migrator.d.ts +10 -10
- package/build/src/database/migrator.d.ts.map +1 -1
- package/build/src/database/migrator.js +11 -11
- package/build/src/database/pool/async-tracked-multi-connection.d.ts +4 -4
- package/build/src/database/pool/async-tracked-multi-connection.js +9 -9
- package/build/src/database/pool/base-methods-forward.d.ts +1 -1
- package/build/src/database/pool/base-methods-forward.js +2 -2
- package/build/src/database/pool/base.d.ts +11 -11
- package/build/src/database/pool/base.js +12 -12
- package/build/src/database/pool/single-multi-use.js +4 -4
- package/build/src/database/query/alter-table-base.js +2 -2
- package/build/src/database/query/base.d.ts +2 -2
- package/build/src/database/query/base.js +3 -3
- package/build/src/database/query/create-database-base.d.ts +1 -1
- package/build/src/database/query/create-database-base.js +2 -2
- package/build/src/database/query/create-index-base.js +2 -2
- package/build/src/database/query/create-table-base.d.ts +1 -1
- package/build/src/database/query/create-table-base.js +2 -2
- package/build/src/database/query/drop-table-base.js +2 -2
- package/build/src/database/query/from-base.d.ts +3 -3
- package/build/src/database/query/from-base.js +4 -4
- package/build/src/database/query/index.d.ts +18 -18
- package/build/src/database/query/index.d.ts.map +1 -1
- package/build/src/database/query/index.js +19 -19
- package/build/src/database/query/insert-base.d.ts +2 -1
- package/build/src/database/query/insert-base.d.ts.map +1 -1
- package/build/src/database/query/insert-base.js +3 -2
- package/build/src/database/query/join-base.d.ts +2 -2
- package/build/src/database/query/join-base.js +3 -3
- package/build/src/database/query/join-object.d.ts +1 -1
- package/build/src/database/query/join-object.js +2 -2
- package/build/src/database/query/model-class-query.d.ts +14 -14
- package/build/src/database/query/model-class-query.d.ts.map +1 -1
- package/build/src/database/query/model-class-query.js +15 -15
- package/build/src/database/query/order-base.d.ts +2 -2
- package/build/src/database/query/order-base.js +3 -3
- package/build/src/database/query/select-base.d.ts +2 -2
- package/build/src/database/query/select-base.js +3 -3
- package/build/src/database/query/update-base.d.ts +1 -1
- package/build/src/database/query/update-base.js +2 -2
- package/build/src/database/query/where-base.d.ts +3 -3
- package/build/src/database/query/where-base.js +4 -4
- package/build/src/database/query/where-hash.d.ts +1 -0
- package/build/src/database/query/where-hash.d.ts.map +1 -1
- package/build/src/database/query/where-hash.js +5 -1
- package/build/src/database/query-parser/from-parser.d.ts +1 -1
- package/build/src/database/query-parser/from-parser.d.ts.map +1 -1
- package/build/src/database/query-parser/from-parser.js +2 -2
- package/build/src/database/query-parser/group-parser.d.ts +1 -1
- package/build/src/database/query-parser/group-parser.js +2 -2
- package/build/src/database/query-parser/options.d.ts +6 -6
- package/build/src/database/query-parser/options.js +7 -7
- package/build/src/database/record/index.d.ts +94 -89
- package/build/src/database/record/index.d.ts.map +1 -1
- package/build/src/database/record/index.js +95 -90
- package/build/src/database/record/instance-relationships/base.d.ts +7 -7
- package/build/src/database/record/instance-relationships/base.d.ts.map +1 -1
- package/build/src/database/record/instance-relationships/base.js +8 -8
- package/build/src/database/record/instance-relationships/belongs-to.d.ts +1 -1
- package/build/src/database/record/instance-relationships/belongs-to.js +2 -2
- package/build/src/database/record/instance-relationships/has-many.d.ts +7 -7
- package/build/src/database/record/instance-relationships/has-many.d.ts.map +1 -1
- package/build/src/database/record/instance-relationships/has-many.js +9 -9
- package/build/src/database/record/instance-relationships/has-one.d.ts +1 -1
- package/build/src/database/record/instance-relationships/has-one.js +2 -2
- package/build/src/database/record/relationships/base.d.ts +3 -3
- package/build/src/database/record/relationships/base.d.ts.map +1 -1
- package/build/src/database/record/relationships/base.js +4 -4
- package/build/src/database/record/relationships/belongs-to.js +3 -3
- package/build/src/database/record/relationships/has-many.js +3 -3
- package/build/src/database/record/relationships/has-one.js +3 -3
- package/build/src/database/record/validators/base.d.ts +1 -1
- package/build/src/database/record/validators/base.js +2 -2
- package/build/src/database/record/validators/uniqueness.js +2 -2
- package/build/src/database/table-data/index.d.ts +19 -19
- package/build/src/database/table-data/index.js +20 -20
- package/build/src/database/table-data/table-column.d.ts +23 -23
- package/build/src/database/table-data/table-column.js +24 -24
- package/build/src/database/table-data/table-foreign-key.d.ts +7 -7
- package/build/src/database/table-data/table-foreign-key.js +8 -8
- package/build/src/database/table-data/table-index.d.ts +3 -3
- package/build/src/database/table-data/table-index.js +4 -4
- package/build/src/database/use-database.d.ts +1 -1
- package/build/src/database/use-database.js +2 -2
- package/build/src/environment-handlers/base.d.ts +24 -24
- package/build/src/environment-handlers/base.js +25 -25
- package/build/src/environment-handlers/browser.d.ts +4 -4
- package/build/src/environment-handlers/browser.js +9 -9
- package/build/src/environment-handlers/node/cli/commands/destroy/migration.d.ts +1 -1
- package/build/src/environment-handlers/node/cli/commands/destroy/migration.js +2 -2
- package/build/src/environment-handlers/node/cli/commands/generate/base-models.d.ts +2 -2
- package/build/src/environment-handlers/node/cli/commands/generate/base-models.js +3 -3
- package/build/src/environment-handlers/node/cli/commands/generate/migration.d.ts +1 -1
- package/build/src/environment-handlers/node/cli/commands/generate/migration.js +2 -2
- package/build/src/environment-handlers/node/cli/commands/generate/model.d.ts +1 -1
- package/build/src/environment-handlers/node/cli/commands/generate/model.js +2 -2
- package/build/src/environment-handlers/node/cli/commands/init.d.ts +1 -1
- package/build/src/environment-handlers/node/cli/commands/init.js +2 -2
- package/build/src/environment-handlers/node/cli/commands/routes.d.ts +2 -2
- package/build/src/environment-handlers/node/cli/commands/routes.js +3 -3
- package/build/src/environment-handlers/node.d.ts +9 -9
- package/build/src/environment-handlers/node.js +21 -21
- package/build/src/error-logger.d.ts +1 -0
- package/build/src/error-logger.d.ts.map +1 -1
- package/build/src/error-logger.js +3 -2
- package/build/src/http-client/index.d.ts +1 -1
- package/build/src/http-client/index.js +2 -2
- package/build/src/http-client/request.d.ts +6 -0
- package/build/src/http-client/request.d.ts.map +1 -1
- package/build/src/http-client/request.js +7 -1
- package/build/src/http-client/response.d.ts +2 -2
- package/build/src/http-client/response.js +3 -3
- package/build/src/http-client/websocket-client.d.ts +7 -7
- package/build/src/http-client/websocket-client.d.ts.map +1 -1
- package/build/src/http-client/websocket-client.js +8 -8
- package/build/src/http-server/client/index.d.ts +5 -5
- package/build/src/http-server/client/index.d.ts.map +1 -1
- package/build/src/http-server/client/index.js +6 -6
- package/build/src/http-server/client/params-to-object.d.ts +3 -3
- package/build/src/http-server/client/params-to-object.d.ts.map +1 -1
- package/build/src/http-server/client/params-to-object.js +4 -4
- package/build/src/http-server/client/request-buffer/form-data-part.d.ts +2 -2
- package/build/src/http-server/client/request-buffer/form-data-part.js +3 -3
- package/build/src/http-server/client/request-buffer/index.d.ts +10 -10
- package/build/src/http-server/client/request-buffer/index.js +11 -11
- package/build/src/http-server/client/request-parser.d.ts +14 -14
- package/build/src/http-server/client/request-parser.d.ts.map +1 -1
- package/build/src/http-server/client/request-parser.js +15 -15
- package/build/src/http-server/client/request.d.ts +2 -2
- package/build/src/http-server/client/request.js +3 -3
- package/build/src/http-server/client/response.d.ts +8 -8
- package/build/src/http-server/client/response.js +9 -9
- package/build/src/http-server/client/uploaded-file/memory-uploaded-file.js +2 -2
- package/build/src/http-server/client/uploaded-file/temporary-uploaded-file.js +2 -2
- package/build/src/http-server/client/uploaded-file/uploaded-file.d.ts +1 -1
- package/build/src/http-server/client/uploaded-file/uploaded-file.js +2 -2
- package/build/src/http-server/client/websocket-session.d.ts +10 -10
- package/build/src/http-server/client/websocket-session.js +11 -11
- package/build/src/http-server/index.d.ts +12 -12
- package/build/src/http-server/index.d.ts.map +1 -1
- package/build/src/http-server/index.js +13 -13
- package/build/src/http-server/server-client.d.ts +6 -6
- package/build/src/http-server/server-client.d.ts.map +1 -1
- package/build/src/http-server/server-client.js +7 -7
- package/build/src/http-server/websocket-events-host.d.ts +2 -2
- package/build/src/http-server/websocket-events-host.js +3 -3
- package/build/src/http-server/websocket-events.d.ts +1 -1
- package/build/src/http-server/websocket-events.js +2 -2
- package/build/src/http-server/worker-handler/index.d.ts +4 -4
- package/build/src/http-server/worker-handler/index.js +5 -5
- package/build/src/http-server/worker-handler/worker-thread.d.ts +2 -2
- package/build/src/http-server/worker-handler/worker-thread.js +3 -3
- package/build/src/initializer.d.ts +3 -3
- package/build/src/initializer.js +4 -4
- package/build/src/logger.d.ts +9 -9
- package/build/src/logger.js +17 -17
- package/build/src/routes/app-routes.d.ts +1 -1
- package/build/src/routes/app-routes.js +2 -2
- package/build/src/routes/base-route.d.ts +6 -6
- package/build/src/routes/base-route.d.ts.map +1 -1
- package/build/src/routes/base-route.js +7 -7
- package/build/src/routes/basic-route.d.ts +1 -1
- package/build/src/routes/basic-route.js +5 -5
- package/build/src/routes/get-route.js +2 -2
- package/build/src/routes/index.d.ts +1 -1
- package/build/src/routes/index.js +2 -2
- package/build/src/routes/namespace-route.js +2 -2
- package/build/src/routes/post-route.js +2 -2
- package/build/src/routes/resolver.d.ts +4 -4
- package/build/src/routes/resolver.d.ts.map +1 -1
- package/build/src/routes/resolver.js +9 -6
- package/build/src/routes/resource-route.js +2 -2
- package/build/src/testing/format-value.d.ts +2 -2
- package/build/src/testing/format-value.js +5 -5
- package/build/src/testing/request-client.d.ts +6 -6
- package/build/src/testing/request-client.d.ts.map +1 -1
- package/build/src/testing/request-client.js +7 -7
- package/build/src/testing/test-files-finder.d.ts +8 -7
- package/build/src/testing/test-files-finder.d.ts.map +1 -1
- package/build/src/testing/test-files-finder.js +8 -7
- package/build/src/testing/test-runner.d.ts +14 -14
- package/build/src/testing/test-runner.js +15 -15
- package/build/src/testing/test.d.ts +26 -26
- package/build/src/testing/test.js +27 -27
- package/build/src/utils/backtrace-cleaner.d.ts +2 -2
- package/build/src/utils/backtrace-cleaner.js +3 -3
- package/build/src/utils/ensure-error.d.ts +1 -1
- package/build/src/utils/ensure-error.js +2 -2
- package/build/src/utils/file-exists.d.ts +1 -1
- package/build/src/utils/file-exists.js +2 -2
- package/build/src/utils/nest-callbacks.d.ts +1 -1
- package/build/src/utils/nest-callbacks.js +2 -2
- package/build/src/utils/rest-args-error.d.ts +1 -1
- package/build/src/utils/rest-args-error.js +2 -2
- package/build/src/utils/singularize-model-name.d.ts +1 -1
- package/build/src/utils/singularize-model-name.js +2 -2
- package/build/src/utils/with-tracked-stack-async-hooks.d.ts +1 -1
- package/build/src/utils/with-tracked-stack-async-hooks.js +2 -2
- package/build/src/utils/with-tracked-stack.d.ts +1 -1
- package/build/src/utils/with-tracked-stack.js +2 -2
- package/package.json +1 -1
|
@@ -67,9 +67,10 @@ export default class VelociousDatabaseDriversBase {
|
|
|
67
67
|
* @param {string} referencedTableName
|
|
68
68
|
* @param {string} referencedColumnName
|
|
69
69
|
* @param {object} args
|
|
70
|
-
* @returns {Promise<void>}
|
|
70
|
+
* @returns {Promise<void>} - Result.
|
|
71
71
|
*/
|
|
72
72
|
async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {
|
|
73
|
+
this._assertNotReadOnly();
|
|
73
74
|
const tableForeignKeyArgs = Object.assign({
|
|
74
75
|
columnName,
|
|
75
76
|
tableName,
|
|
@@ -87,14 +88,14 @@ export default class VelociousDatabaseDriversBase {
|
|
|
87
88
|
/**
|
|
88
89
|
* @abstract
|
|
89
90
|
* @param {import("../table-data/index.js").default} _tableData
|
|
90
|
-
* @returns {Promise<string[]>}
|
|
91
|
+
* @returns {Promise<string[]>} - Result.
|
|
91
92
|
*/
|
|
92
93
|
alterTableSQLs(_tableData) {
|
|
93
94
|
throw new Error("alterTableSQLs not implemented");
|
|
94
95
|
}
|
|
95
96
|
/**
|
|
96
97
|
* @abstract
|
|
97
|
-
* @returns {Promise<void>}
|
|
98
|
+
* @returns {Promise<void>} - Result.
|
|
98
99
|
*/
|
|
99
100
|
connect() {
|
|
100
101
|
throw new Error("'connect' not implemented");
|
|
@@ -104,22 +105,23 @@ export default class VelociousDatabaseDriversBase {
|
|
|
104
105
|
* @param {string} databaseName
|
|
105
106
|
* @param {object} [args]
|
|
106
107
|
* @param {boolean} [args.ifNotExists]
|
|
107
|
-
* @returns {string[]}
|
|
108
|
+
* @returns {string[]} - Result.
|
|
108
109
|
*/
|
|
109
110
|
createDatabaseSql(databaseName, args) { throw new Error("'createDatabaseSql' not implemented"); } // eslint-disable-line no-unused-vars
|
|
110
111
|
/**
|
|
111
112
|
* @abstract
|
|
112
113
|
* @param {CreateIndexSqlArgs} indexData
|
|
113
|
-
* @returns {Promise<string[]>}
|
|
114
|
+
* @returns {Promise<string[]>} - Result.
|
|
114
115
|
*/
|
|
115
116
|
async createIndexSQLs(indexData) {
|
|
116
117
|
throw new Error("'createIndexSQLs' not implemented");
|
|
117
118
|
}
|
|
118
119
|
/**
|
|
119
120
|
* @param {import("../table-data/index.js").default} tableData
|
|
120
|
-
* @returns {Promise<void>}
|
|
121
|
+
* @returns {Promise<void>} - Result.
|
|
121
122
|
*/
|
|
122
123
|
async createTable(tableData) {
|
|
124
|
+
this._assertNotReadOnly();
|
|
123
125
|
const sqls = await this.createTableSql(tableData);
|
|
124
126
|
for (const sql of sqls) {
|
|
125
127
|
await this.query(sql);
|
|
@@ -128,23 +130,24 @@ export default class VelociousDatabaseDriversBase {
|
|
|
128
130
|
/**
|
|
129
131
|
* @abstract
|
|
130
132
|
* @param {import("../table-data/index.js").default} tableData
|
|
131
|
-
* @returns {Promise<string[]>}
|
|
133
|
+
* @returns {Promise<string[]>} - Result.
|
|
132
134
|
*/
|
|
133
135
|
async createTableSql(tableData) {
|
|
134
136
|
throw new Error("'createTableSql' not implemented");
|
|
135
137
|
}
|
|
136
138
|
/**
|
|
137
139
|
* @param {DeleteSqlArgsType} args
|
|
138
|
-
* @returns {Promise<void>}
|
|
140
|
+
* @returns {Promise<void>} - Result.
|
|
139
141
|
*/
|
|
140
142
|
async delete(args) {
|
|
143
|
+
this._assertNotReadOnly();
|
|
141
144
|
const sql = this.deleteSql(args);
|
|
142
145
|
await this.query(sql);
|
|
143
146
|
}
|
|
144
147
|
/**
|
|
145
148
|
* @abstract
|
|
146
149
|
* @param {DeleteSqlArgsType} args
|
|
147
|
-
* @returns {string}
|
|
150
|
+
* @returns {string} - Result.
|
|
148
151
|
*/
|
|
149
152
|
deleteSql(args) {
|
|
150
153
|
throw new Error(`'deleteSql' not implemented`);
|
|
@@ -152,9 +155,10 @@ export default class VelociousDatabaseDriversBase {
|
|
|
152
155
|
/**
|
|
153
156
|
* @param {string} tableName
|
|
154
157
|
* @param {DropTableSqlArgsType} [args]
|
|
155
|
-
* @returns {Promise<void>}
|
|
158
|
+
* @returns {Promise<void>} - Result.
|
|
156
159
|
*/
|
|
157
160
|
async dropTable(tableName, args) {
|
|
161
|
+
this._assertNotReadOnly();
|
|
158
162
|
const sqls = await this.dropTableSQLs(tableName, args);
|
|
159
163
|
for (const sql of sqls) {
|
|
160
164
|
await this.query(sql);
|
|
@@ -164,7 +168,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
164
168
|
* @abstract
|
|
165
169
|
* @param {string} tableName
|
|
166
170
|
* @param {DropTableSqlArgsType} [args]
|
|
167
|
-
* @returns {Promise<string[]>}
|
|
171
|
+
* @returns {Promise<string[]>} - Result.
|
|
168
172
|
*/
|
|
169
173
|
async dropTableSQLs(tableName, args) {
|
|
170
174
|
throw new Error("dropTableSQLs not implemented");
|
|
@@ -172,19 +176,19 @@ export default class VelociousDatabaseDriversBase {
|
|
|
172
176
|
/**
|
|
173
177
|
* @abstract
|
|
174
178
|
* @param {any} value
|
|
175
|
-
* @returns {any}
|
|
179
|
+
* @returns {any} - Result.
|
|
176
180
|
*/
|
|
177
181
|
escape(value) {
|
|
178
182
|
throw new Error("'escape' not implemented");
|
|
179
183
|
}
|
|
180
184
|
/**
|
|
181
|
-
* @returns {import("../../configuration-types.js").DatabaseConfigurationType}
|
|
185
|
+
* @returns {import("../../configuration-types.js").DatabaseConfigurationType} - Result.
|
|
182
186
|
*/
|
|
183
187
|
getArgs() {
|
|
184
188
|
return this._args;
|
|
185
189
|
}
|
|
186
190
|
/**
|
|
187
|
-
* @returns {import("../../configuration.js").default}
|
|
191
|
+
* @returns {import("../../configuration.js").default} - Result.
|
|
188
192
|
*/
|
|
189
193
|
getConfiguration() {
|
|
190
194
|
if (!this.configuration)
|
|
@@ -192,20 +196,20 @@ export default class VelociousDatabaseDriversBase {
|
|
|
192
196
|
return this.configuration;
|
|
193
197
|
}
|
|
194
198
|
/**
|
|
195
|
-
* @returns {number | undefined}
|
|
199
|
+
* @returns {number | undefined} - Result.
|
|
196
200
|
*/
|
|
197
201
|
getIdSeq() {
|
|
198
202
|
return this.idSeq;
|
|
199
203
|
}
|
|
200
204
|
/**
|
|
201
205
|
* @abstract
|
|
202
|
-
* @returns {Promise<Array<import("./base-table.js").default>>}
|
|
206
|
+
* @returns {Promise<Array<import("./base-table.js").default>>} - Result.
|
|
203
207
|
*/
|
|
204
208
|
getTables() {
|
|
205
209
|
throw new Error(`${this.constructor.name}#getTables not implemented`);
|
|
206
210
|
}
|
|
207
211
|
/**
|
|
208
|
-
* @returns {Promise<string | null>}
|
|
212
|
+
* @returns {Promise<string | null>} - Result.
|
|
209
213
|
*/
|
|
210
214
|
async structureSql() {
|
|
211
215
|
return null;
|
|
@@ -214,7 +218,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
214
218
|
* @param {string} name
|
|
215
219
|
* @param {object} [args]
|
|
216
220
|
* @param {boolean} args.throwError
|
|
217
|
-
* @returns {Promise<import("./base-table.js").default | undefined>}
|
|
221
|
+
* @returns {Promise<import("./base-table.js").default | undefined>} - Result.
|
|
218
222
|
*/
|
|
219
223
|
async getTableByName(name, args) {
|
|
220
224
|
const tables = await this.getTables();
|
|
@@ -234,23 +238,24 @@ export default class VelociousDatabaseDriversBase {
|
|
|
234
238
|
}
|
|
235
239
|
/**
|
|
236
240
|
* @param {string} name
|
|
237
|
-
* @returns {Promise<import("./base-table.js").default>}
|
|
241
|
+
* @returns {Promise<import("./base-table.js").default>} - Result.
|
|
238
242
|
*/
|
|
239
243
|
async getTableByNameOrFail(name) {
|
|
240
244
|
return await this.getTableByName(name, { throwError: true });
|
|
241
245
|
}
|
|
242
246
|
/**
|
|
243
247
|
* @abstract
|
|
244
|
-
* @returns {string}
|
|
248
|
+
* @returns {string} - Result.
|
|
245
249
|
*/
|
|
246
250
|
getType() {
|
|
247
251
|
throw new Error("'type' not implemented");
|
|
248
252
|
}
|
|
249
253
|
/**
|
|
250
254
|
* @param {InsertSqlArgsType} args
|
|
251
|
-
* @returns {Promise<void>}
|
|
255
|
+
* @returns {Promise<void>} - Result.
|
|
252
256
|
*/
|
|
253
257
|
async insert(args) {
|
|
258
|
+
this._assertNotReadOnly();
|
|
254
259
|
const sql = this.insertSql(args);
|
|
255
260
|
await this.query(sql);
|
|
256
261
|
}
|
|
@@ -259,7 +264,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
259
264
|
* @param {string} tableName
|
|
260
265
|
* @param {Array<string>} columns
|
|
261
266
|
* @param {Array<Array<string>>} rows
|
|
262
|
-
* @returns {Promise<void>}
|
|
267
|
+
* @returns {Promise<void>} - Result.
|
|
263
268
|
*/
|
|
264
269
|
async insertMultiple(tableName, columns, rows) {
|
|
265
270
|
throw new Error("'insertMultiple' not implemented");
|
|
@@ -267,21 +272,21 @@ export default class VelociousDatabaseDriversBase {
|
|
|
267
272
|
/**
|
|
268
273
|
* @abstract
|
|
269
274
|
* @param {InsertSqlArgsType} args
|
|
270
|
-
* @returns {string}
|
|
275
|
+
* @returns {string} - Result.
|
|
271
276
|
*/
|
|
272
277
|
insertSql(args) {
|
|
273
278
|
throw new Error("'insertSql' not implemented");
|
|
274
279
|
}
|
|
275
280
|
/**
|
|
276
281
|
* @abstract
|
|
277
|
-
* @returns {Promise<number>}
|
|
282
|
+
* @returns {Promise<number>} - Result.
|
|
278
283
|
*/
|
|
279
284
|
lastInsertID() {
|
|
280
285
|
throw new Error(`${this.constructor.name}#lastInsertID not implemented`);
|
|
281
286
|
}
|
|
282
287
|
/**
|
|
283
288
|
* @param {any} value
|
|
284
|
-
* @returns {any}
|
|
289
|
+
* @returns {any} - Result.
|
|
285
290
|
*/
|
|
286
291
|
_convertValue(value) {
|
|
287
292
|
if (value instanceof Date) {
|
|
@@ -291,14 +296,14 @@ export default class VelociousDatabaseDriversBase {
|
|
|
291
296
|
}
|
|
292
297
|
/**
|
|
293
298
|
* @abstract
|
|
294
|
-
* @returns {import("../query-parser/options.js").default}
|
|
299
|
+
* @returns {import("../query-parser/options.js").default} - Result.
|
|
295
300
|
*/
|
|
296
301
|
options() {
|
|
297
302
|
throw new Error("'options' not implemented.");
|
|
298
303
|
}
|
|
299
304
|
/**
|
|
300
305
|
* @param {any} value
|
|
301
|
-
* @returns {number | string}
|
|
306
|
+
* @returns {number | string} - Result.
|
|
302
307
|
*/
|
|
303
308
|
quote(value) {
|
|
304
309
|
if (typeof value == "number")
|
|
@@ -309,27 +314,27 @@ export default class VelociousDatabaseDriversBase {
|
|
|
309
314
|
}
|
|
310
315
|
/**
|
|
311
316
|
* @param {string} columnName
|
|
312
|
-
* @returns {string}
|
|
317
|
+
* @returns {string} - Result.
|
|
313
318
|
*/
|
|
314
319
|
quoteColumn(columnName) {
|
|
315
320
|
return this.options().quoteColumnName(columnName);
|
|
316
321
|
}
|
|
317
322
|
/**
|
|
318
323
|
* @param {string} columnName
|
|
319
|
-
* @returns {string}
|
|
324
|
+
* @returns {string} - Result.
|
|
320
325
|
*/
|
|
321
326
|
quoteIndex(columnName) {
|
|
322
327
|
return this.options().quoteIndexName(columnName);
|
|
323
328
|
}
|
|
324
329
|
/**
|
|
325
330
|
* @param {string} tableName
|
|
326
|
-
* @returns {string}
|
|
331
|
+
* @returns {string} - Result.
|
|
327
332
|
*/
|
|
328
333
|
quoteTable(tableName) {
|
|
329
334
|
return this.options().quoteTableName(tableName);
|
|
330
335
|
}
|
|
331
336
|
/**
|
|
332
|
-
* @returns {Query}
|
|
337
|
+
* @returns {Query} - Result.
|
|
333
338
|
*/
|
|
334
339
|
newQuery() {
|
|
335
340
|
const handler = new Handler();
|
|
@@ -340,7 +345,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
340
345
|
}
|
|
341
346
|
/**
|
|
342
347
|
* @param {string} tableName
|
|
343
|
-
* @returns {Promise<QueryResultType>}
|
|
348
|
+
* @returns {Promise<QueryResultType>} - Result.
|
|
344
349
|
*/
|
|
345
350
|
async select(tableName) {
|
|
346
351
|
const query = this.newQuery();
|
|
@@ -351,30 +356,30 @@ export default class VelociousDatabaseDriversBase {
|
|
|
351
356
|
}
|
|
352
357
|
/**
|
|
353
358
|
* @param {number | undefined} newIdSeq
|
|
354
|
-
* @returns {void}
|
|
359
|
+
* @returns {void} - Result.
|
|
355
360
|
*/
|
|
356
361
|
setIdSeq(newIdSeq) {
|
|
357
362
|
this.idSeq = newIdSeq;
|
|
358
363
|
}
|
|
359
364
|
/**
|
|
360
365
|
* @abstract
|
|
361
|
-
* @returns {boolean}
|
|
366
|
+
* @returns {boolean} - Result.
|
|
362
367
|
*/
|
|
363
368
|
shouldSetAutoIncrementWhenPrimaryKey() {
|
|
364
369
|
throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`);
|
|
365
370
|
}
|
|
366
371
|
/**
|
|
367
|
-
* @returns {boolean}
|
|
372
|
+
* @returns {boolean} - Result.
|
|
368
373
|
*/
|
|
369
374
|
supportsDefaultPrimaryKeyUUID() { return false; }
|
|
370
375
|
/**
|
|
371
376
|
* @abstract
|
|
372
|
-
* @returns {boolean}
|
|
377
|
+
* @returns {boolean} - Result.
|
|
373
378
|
*/
|
|
374
379
|
supportsInsertIntoReturning() { return false; }
|
|
375
380
|
/**
|
|
376
381
|
* @param {string} tableName
|
|
377
|
-
* @returns {Promise<boolean>}
|
|
382
|
+
* @returns {Promise<boolean>} - Result.
|
|
378
383
|
*/
|
|
379
384
|
async tableExists(tableName) {
|
|
380
385
|
const tables = await this.getTables();
|
|
@@ -385,9 +390,10 @@ export default class VelociousDatabaseDriversBase {
|
|
|
385
390
|
}
|
|
386
391
|
/**
|
|
387
392
|
* @param {() => Promise<void>} callback
|
|
388
|
-
* @returns {Promise<any>}
|
|
393
|
+
* @returns {Promise<any>} - Result.
|
|
389
394
|
*/
|
|
390
395
|
async transaction(callback) {
|
|
396
|
+
this._assertNotReadOnly();
|
|
391
397
|
const savePointName = this.generateSavePointName();
|
|
392
398
|
let transactionStarted = false;
|
|
393
399
|
let savePointStarted = false;
|
|
@@ -448,7 +454,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
448
454
|
return result;
|
|
449
455
|
}
|
|
450
456
|
/**
|
|
451
|
-
* @returns {Promise<void>}
|
|
457
|
+
* @returns {Promise<void>} - Result.
|
|
452
458
|
*/
|
|
453
459
|
async startTransaction() {
|
|
454
460
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -457,13 +463,13 @@ export default class VelociousDatabaseDriversBase {
|
|
|
457
463
|
});
|
|
458
464
|
}
|
|
459
465
|
/**
|
|
460
|
-
* @returns {Promise<void>}
|
|
466
|
+
* @returns {Promise<void>} - Result.
|
|
461
467
|
*/
|
|
462
468
|
async _startTransactionAction() {
|
|
463
469
|
await this.query("BEGIN TRANSACTION");
|
|
464
470
|
}
|
|
465
471
|
/**
|
|
466
|
-
* @returns {Promise<void>}
|
|
472
|
+
* @returns {Promise<void>} - Result.
|
|
467
473
|
*/
|
|
468
474
|
async commitTransaction() {
|
|
469
475
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -472,14 +478,14 @@ export default class VelociousDatabaseDriversBase {
|
|
|
472
478
|
});
|
|
473
479
|
}
|
|
474
480
|
/**
|
|
475
|
-
* @returns {Promise<void>}
|
|
481
|
+
* @returns {Promise<void>} - Result.
|
|
476
482
|
*/
|
|
477
483
|
async _commitTransactionAction() {
|
|
478
484
|
await this.query("COMMIT");
|
|
479
485
|
}
|
|
480
486
|
/**
|
|
481
487
|
* @param {string} sql
|
|
482
|
-
* @returns {Promise<QueryResultType>}
|
|
488
|
+
* @returns {Promise<QueryResultType>} - Result.
|
|
483
489
|
*/
|
|
484
490
|
async query(sql) {
|
|
485
491
|
this._assertWritableQuery(sql);
|
|
@@ -505,7 +511,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
505
511
|
/**
|
|
506
512
|
* @abstract
|
|
507
513
|
* @param {string} sql
|
|
508
|
-
* @returns {Promise<QueryResultType>}
|
|
514
|
+
* @returns {Promise<QueryResultType>} - Result.
|
|
509
515
|
*/
|
|
510
516
|
_queryActual(sql) {
|
|
511
517
|
throw new Error(`queryActual not implemented`);
|
|
@@ -513,19 +519,19 @@ export default class VelociousDatabaseDriversBase {
|
|
|
513
519
|
/**
|
|
514
520
|
* @abstract
|
|
515
521
|
* @param {Query} _query
|
|
516
|
-
* @returns {string}
|
|
522
|
+
* @returns {string} - Result.
|
|
517
523
|
*/
|
|
518
524
|
queryToSql(_query) { throw new Error("queryToSql not implemented"); } // eslint-disable-line no-unused-vars
|
|
519
525
|
/**
|
|
520
526
|
* @param {Error} _error
|
|
521
|
-
* @returns {boolean}
|
|
527
|
+
* @returns {boolean} - Result.
|
|
522
528
|
*/
|
|
523
529
|
retryableDatabaseError(_error) {
|
|
524
530
|
return false;
|
|
525
531
|
}
|
|
526
532
|
/**
|
|
527
533
|
* @param {string} sql
|
|
528
|
-
* @returns {void}
|
|
534
|
+
* @returns {void} - Result.
|
|
529
535
|
*/
|
|
530
536
|
_assertWritableQuery(sql) {
|
|
531
537
|
if (!this.isReadOnly())
|
|
@@ -534,9 +540,17 @@ export default class VelociousDatabaseDriversBase {
|
|
|
534
540
|
return;
|
|
535
541
|
throw new Error("Database is read-only");
|
|
536
542
|
}
|
|
543
|
+
/**
|
|
544
|
+
* @returns {void} - Result.
|
|
545
|
+
*/
|
|
546
|
+
_assertNotReadOnly() {
|
|
547
|
+
if (this.isReadOnly()) {
|
|
548
|
+
throw new Error("Database is read-only");
|
|
549
|
+
}
|
|
550
|
+
}
|
|
537
551
|
/**
|
|
538
552
|
* @param {string} sql
|
|
539
|
-
* @returns {boolean}
|
|
553
|
+
* @returns {boolean} - Result.
|
|
540
554
|
*/
|
|
541
555
|
_sqlLooksLikeWrite(sql) {
|
|
542
556
|
const normalized = sql.trim().toLowerCase();
|
|
@@ -570,12 +584,12 @@ export default class VelociousDatabaseDriversBase {
|
|
|
570
584
|
"replace"
|
|
571
585
|
].includes(keyword);
|
|
572
586
|
}
|
|
573
|
-
/** @returns {boolean} */
|
|
587
|
+
/** @returns {boolean} - Result. */
|
|
574
588
|
isReadOnly() {
|
|
575
589
|
return Boolean(this.getArgs().readOnly);
|
|
576
590
|
}
|
|
577
591
|
/**
|
|
578
|
-
* @returns {Promise<void>}
|
|
592
|
+
* @returns {Promise<void>} - Result.
|
|
579
593
|
*/
|
|
580
594
|
async rollbackTransaction() {
|
|
581
595
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -584,20 +598,20 @@ export default class VelociousDatabaseDriversBase {
|
|
|
584
598
|
});
|
|
585
599
|
}
|
|
586
600
|
/**
|
|
587
|
-
* @returns {Promise<void>}
|
|
601
|
+
* @returns {Promise<void>} - Result.
|
|
588
602
|
*/
|
|
589
603
|
async _rollbackTransactionAction() {
|
|
590
604
|
await this.query("ROLLBACK");
|
|
591
605
|
}
|
|
592
606
|
/**
|
|
593
|
-
* @returns {string}
|
|
607
|
+
* @returns {string} - Result.
|
|
594
608
|
*/
|
|
595
609
|
generateSavePointName() {
|
|
596
610
|
return `sp${new UUID(4).format().replaceAll("-", "")}`;
|
|
597
611
|
}
|
|
598
612
|
/**
|
|
599
613
|
* @param {string} savePointName
|
|
600
|
-
* @returns {Promise<void>}
|
|
614
|
+
* @returns {Promise<void>} - Result.
|
|
601
615
|
*/
|
|
602
616
|
async startSavePoint(savePointName) {
|
|
603
617
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -606,7 +620,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
606
620
|
}
|
|
607
621
|
/**
|
|
608
622
|
* @param {string} savePointName
|
|
609
|
-
* @returns {Promise<void>}
|
|
623
|
+
* @returns {Promise<void>} - Result.
|
|
610
624
|
*/
|
|
611
625
|
async _startSavePointAction(savePointName) {
|
|
612
626
|
await this.query(`SAVEPOINT ${savePointName}`);
|
|
@@ -615,9 +629,10 @@ export default class VelociousDatabaseDriversBase {
|
|
|
615
629
|
* @param {string} tableName
|
|
616
630
|
* @param {string} oldColumnName
|
|
617
631
|
* @param {string} newColumnName
|
|
618
|
-
* @returns {Promise<void>}
|
|
632
|
+
* @returns {Promise<void>} - Result.
|
|
619
633
|
*/
|
|
620
634
|
async renameColumn(tableName, oldColumnName, newColumnName) {
|
|
635
|
+
this._assertNotReadOnly();
|
|
621
636
|
const tableColumn = new TableColumn(oldColumnName);
|
|
622
637
|
tableColumn.setNewName(newColumnName);
|
|
623
638
|
const tableData = new TableData(tableName);
|
|
@@ -629,7 +644,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
629
644
|
}
|
|
630
645
|
/**
|
|
631
646
|
* @param {string} savePointName
|
|
632
|
-
* @returns {Promise<void>}
|
|
647
|
+
* @returns {Promise<void>} - Result.
|
|
633
648
|
*/
|
|
634
649
|
async releaseSavePoint(savePointName) {
|
|
635
650
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -638,7 +653,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
638
653
|
}
|
|
639
654
|
/**
|
|
640
655
|
* @param {string} savePointName
|
|
641
|
-
* @returns {Promise<void>}
|
|
656
|
+
* @returns {Promise<void>} - Result.
|
|
642
657
|
*/
|
|
643
658
|
async _releaseSavePointAction(savePointName) {
|
|
644
659
|
try {
|
|
@@ -656,7 +671,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
656
671
|
}
|
|
657
672
|
/**
|
|
658
673
|
* @param {string} savePointName
|
|
659
|
-
* @returns {Promise<void>}
|
|
674
|
+
* @returns {Promise<void>} - Result.
|
|
660
675
|
*/
|
|
661
676
|
async rollbackSavePoint(savePointName) {
|
|
662
677
|
await this._transactionsActionsMutex.sync(async () => {
|
|
@@ -665,15 +680,16 @@ export default class VelociousDatabaseDriversBase {
|
|
|
665
680
|
}
|
|
666
681
|
/**
|
|
667
682
|
* @param {string} savePointName
|
|
668
|
-
* @returns {Promise<void>}
|
|
683
|
+
* @returns {Promise<void>} - Result.
|
|
669
684
|
*/
|
|
670
685
|
async _rollbackSavePointAction(savePointName) {
|
|
671
686
|
await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`);
|
|
672
687
|
}
|
|
673
688
|
/**
|
|
674
|
-
* @returns {Promise<void>}
|
|
689
|
+
* @returns {Promise<void>} - Result.
|
|
675
690
|
*/
|
|
676
691
|
async truncateAllTables() {
|
|
692
|
+
this._assertNotReadOnly();
|
|
677
693
|
await this.withDisabledForeignKeys(async () => {
|
|
678
694
|
let tries = 0;
|
|
679
695
|
while (tries <= 5) {
|
|
@@ -705,37 +721,38 @@ export default class VelociousDatabaseDriversBase {
|
|
|
705
721
|
}
|
|
706
722
|
/**
|
|
707
723
|
* @param {UpdateSqlArgsType} args
|
|
708
|
-
* @returns {Promise<void>}
|
|
724
|
+
* @returns {Promise<void>} - Result.
|
|
709
725
|
*/
|
|
710
726
|
async update(args) {
|
|
727
|
+
this._assertNotReadOnly();
|
|
711
728
|
const sql = this.updateSql(args);
|
|
712
729
|
await this.query(sql);
|
|
713
730
|
}
|
|
714
731
|
/**
|
|
715
732
|
* @abstract
|
|
716
733
|
* @param {UpdateSqlArgsType} args
|
|
717
|
-
* @returns {string}
|
|
734
|
+
* @returns {string} - Result.
|
|
718
735
|
*/
|
|
719
736
|
updateSql(args) {
|
|
720
737
|
throw new Error("'disableForeignKeys' not implemented");
|
|
721
738
|
}
|
|
722
739
|
/**
|
|
723
740
|
* @abstract
|
|
724
|
-
* @returns {Promise<void>}
|
|
741
|
+
* @returns {Promise<void>} - Result.
|
|
725
742
|
*/
|
|
726
743
|
disableForeignKeys() {
|
|
727
744
|
throw new Error("'disableForeignKeys' not implemented");
|
|
728
745
|
}
|
|
729
746
|
/**
|
|
730
747
|
* @abstract
|
|
731
|
-
* @returns {Promise<void>}
|
|
748
|
+
* @returns {Promise<void>} - Result.
|
|
732
749
|
*/
|
|
733
750
|
enableForeignKeys() {
|
|
734
751
|
throw new Error("'enableForeignKeys' not implemented");
|
|
735
752
|
}
|
|
736
753
|
/**
|
|
737
754
|
* @param {function() : void} callback
|
|
738
|
-
* @returns {Promise<any>}
|
|
755
|
+
* @returns {Promise<any>} - Result.
|
|
739
756
|
*/
|
|
740
757
|
async withDisabledForeignKeys(callback) {
|
|
741
758
|
await this.disableForeignKeys();
|
|
@@ -747,4 +764,4 @@ export default class VelociousDatabaseDriversBase {
|
|
|
747
764
|
}
|
|
748
765
|
}
|
|
749
766
|
}
|
|
750
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ;;;;;;;GAOG;AACH;;;;GAIG;AACH;;;;GAIG;AACH;;;;;;;;GAQG;AACH;;;GAGG;AACH;;;;;GAKG;AAEH,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAA;AACtC,OAAO,KAAK,MAAM,mBAAmB,CAAA;AACrC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,KAAK,MAAM,yBAAyB,CAAA;AAC3C,OAAO,QAAQ,MAAM,UAAU,CAAA;AAC/B,OAAO,IAAI,MAAM,WAAW,CAAA;AAC5B,OAAO,SAAS,MAAM,wBAAwB,CAAA;AAC9C,OAAO,WAAW,MAAM,+BAA+B,CAAA;AACvD,OAAO,eAAe,MAAM,oCAAoC,CAAA;AAChE,OAAO,IAAI,MAAM,wBAAwB,CAAA;AAEzC,MAAM,CAAC,OAAO,OAAO,4BAA4B;IAC/C,iCAAiC;IACjC,KAAK,GAAG,SAAS,CAAA;IAEjB;;;OAGG;IACH,YAAY,MAAM,EAAE,aAAa;QAC/B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAA;QACnB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;QAClC,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,EAAE,CAAA,CAAC,sDAAsD;QAC/E,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAA;QAC9B,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAA;QAC3B,IAAI,CAAC,yBAAyB,GAAG,IAAI,KAAK,EAAE,CAAA;IAC9C,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,UAAU,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,IAAI;QACxF,MAAM,mBAAmB,GAAG,MAAM,CAAC,MAAM,CACvC;YACE,UAAU;YACV,SAAS;YACT,oBAAoB;YACpB,mBAAmB;SACpB,EACD,IAAI,CACL,CAAA;QACD,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,mBAAmB,CAAC,CAAA;QAChE,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,SAAS,CAAC,CAAA;QAE1C,SAAS,CAAC,aAAa,CAAC,eAAe,CAAC,CAAA;QAExC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;QAE3D,KAAK,MAAM,aAAa,IAAI,cAAc,EAAE,CAAC;YAC3C,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACjC,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,UAAU;QACvB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAA;IACnD,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;IAC9C,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CAAC,YAAY,EAAE,IAAI,IAAI,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA,CAAC,CAAC,CAAC,qCAAqC;IAEtI;;;;OAIG;IACH,KAAK,CAAC,eAAe,CAAC,SAAS;QAC7B,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;IACtD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,SAAS;QACzB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;QAEjD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS;QAC5B,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAA;IACrD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,IAAI;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;QAEhC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,IAAI;QACZ,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;IAChD,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI;QAC7B,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,CAAA;QAEtD,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACvB,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI;QACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;IAClD,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK;QACV,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;IAC7C,CAAC;IAED;;OAEG;IACH,OAAO;QACL,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;QAEhE,OAAO,IAAI,CAAC,aAAa,CAAA;IAC3B,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAED;;;OAGG;IACH,SAAS;QACP,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,4BAA4B,CAAC,CAAA;IACvE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,YAAY;QAChB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI;QAC7B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;QACrC,MAAM,UAAU,GAAG,EAAE,CAAA;QACrB,IAAI,KAAK,CAAA;QAET,KAAK,MAAM,SAAS,IAAI,MAAM,EAAE,CAAC;YAC/B,MAAM,aAAa,GAAG,SAAS,CAAC,OAAO,EAAE,CAAA;YAEzC,IAAI,aAAa,IAAI,IAAI,EAAE,CAAC;gBAC1B,KAAK,GAAG,SAAS,CAAA;gBACjB,MAAK;YACP,CAAC;YAED,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAChC,CAAC;QAED,IAAI,CAAC,KAAK,IAAI,IAAI,EAAE,UAAU,KAAK,KAAK;YAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,IAAI,SAAS,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAEtI,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,oBAAoB,CAAC,IAAI;QAC7B,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,EAAC,UAAU,EAAE,IAAI,EAAC,CAAC,CAAA;IAC5D,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAA;IAC3C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,IAAI;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;QAEhC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI;QAC3C,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAA;IACrD,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,IAAI;QACZ,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;IAChD,CAAC;IAED;;;OAGG;IACH,YAAY;QACV,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,+BAA+B,CAAC,CAAA;IAC1E,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,KAAK;QACjB,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;YAC1B,OAAO,QAAQ,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;QACpC,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;IAC/C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,OAAO,KAAK,IAAI,QAAQ;YAAE,OAAO,KAAK,CAAA;QAE1C,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QACvC,MAAM,MAAM,GAAG,IAAI,YAAY,GAAG,CAAA;QAElC,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,UAAU;QACpB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;IACnD,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,UAAU;QACnB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,cAAc,CAAC,UAAU,CAAC,CAAA;IAClD,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,SAAS;QAClB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;IACjD,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAA;QAE7B,OAAO,IAAI,KAAK,CAAC;YACf,MAAM,EAAE,IAAI;YACZ,OAAO;SACR,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,SAAS;QACpB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAA;QAE7B,MAAM,GAAG,GAAG,KAAK;aACd,IAAI,CAAC,SAAS,CAAC;aACf,KAAK,EAAE,CAAA;QAEV,OAAO,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IAC9B,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,QAAQ;QACf,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAA;IACvB,CAAC;IAED;;;OAGG;IACH,oCAAoC;QAClC,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAA;IAC3E,CAAC;IAED;;OAEG;IACH,6BAA6B,KAAK,OAAO,KAAK,CAAA,CAAC,CAAC;IAEhD;;;OAGG;IACH,2BAA2B,KAAK,OAAO,KAAK,CAAA,CAAC,CAAC;IAE9C;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,SAAS;QACzB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;QACrC,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,SAAS,CAAC,CAAA;QAElE,IAAI,KAAK;YAAE,OAAO,IAAI,CAAA;QAEtB,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,WAAW,CAAC,QAAQ;QACxB,MAAM,aAAa,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAA;QAClD,IAAI,kBAAkB,GAAG,KAAK,CAAA;QAC9B,IAAI,gBAAgB,GAAG,KAAK,CAAA;QAE5B,IAAI,IAAI,CAAC,kBAAkB,IAAI,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;YACtC,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAA;YAC7B,kBAAkB,GAAG,IAAI,CAAA;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,EAAE,aAAa,CAAC,CAAA;YACnD,MAAM,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAA;YACxC,gBAAgB,GAAG,IAAI,CAAA;QACzB,CAAC;QAED,IAAI,MAAM,CAAA;QAEV,IAAI,CAAC;YACH,MAAM,GAAG,MAAM,QAAQ,EAAE,CAAA;YAEzB,IAAI,gBAAgB,EAAE,CAAC;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,aAAa,CAAC,CAAA;gBACrD,MAAM,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAA;YAC5C,CAAC;YAED,IAAI,kBAAkB,EAAE,CAAC;gBACvB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAA;gBACvC,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAA;YAChC,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,KAAK,CAAC,OAAO,CAAC,CAAA;YACvD,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAA;YAC/C,CAAC;YAED,IAAI,qBAAqB,GAAG,KAAK,CAAA;YAEjC,IAAI,gBAAgB,EAAE,CAAC;gBACrB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oBAAoB,EAAE,aAAa,CAAC,CAAA;gBACtD,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAA;gBAC7C,CAAC;gBAAC,OAAO,cAAc,EAAE,CAAC;oBACxB,MAAM,OAAO,GAAG,cAAc,YAAY,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,cAAc,EAAE,CAAA;oBAE9F,gGAAgG;oBAChG,IAAI,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAC,EAAE,CAAC;wBAC9E,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,oEAAoE,CAAC,CAAA;wBACvF,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAA;wBAChC,qBAAqB,GAAG,IAAI,CAAA;oBAC9B,CAAC;yBAAM,CAAC;wBACN,MAAM,cAAc,CAAA;oBACtB,CAAC;gBACH,CAAC;YACH,CAAC;YAED,IAAI,kBAAkB,IAAI,CAAC,qBAAqB,EAAE,CAAC;gBACjD,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAA;gBACzC,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAA;YAClC,CAAC;YAED,MAAM,KAAK,CAAA;QACb,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,gBAAgB;QACpB,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,uBAAuB,EAAE,CAAA;YACpC,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAC3B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,uBAAuB;QAC3B,MAAM,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;IACvC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,iBAAiB;QACrB,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAA;YACrC,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAC3B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,wBAAwB;QAC5B,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;IAC5B,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG;QACb,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAA;QAE9B,IAAI,KAAK,GAAG,CAAC,CAAA;QAEb,OAAM,KAAK,GAAG,CAAC,EAAE,CAAC;YAChB,KAAK,EAAE,CAAA;YAEP,IAAI,CAAC;gBACH,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAA;YACrC,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,KAAK,YAAY,KAAK,IAAI,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,EAAE,CAAC;oBAC9E,MAAM,IAAI,CAAC,GAAG,CAAC,CAAA;oBACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAA;oBACtE,QAAQ;gBACV,CAAC;qBAAM,CAAC;oBACN,MAAM,KAAK,CAAA;gBACb,CAAC;YACH,CAAC;QACH,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAA;IACjD,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAC,GAAG;QACd,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;IAChD,CAAC;IAED;;;;OAIG;IACH,UAAU,CAAC,MAAM,IAAI,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA,CAAC,CAAC,CAAC,qCAAqC;IAE1G;;;OAGG;IACH,sBAAsB,CAAC,MAAM;QAC3B,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,GAAG;QACtB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAAE,OAAM;QAC9B,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC;YAAE,OAAM;QAEzC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;IAC1C,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,GAAG;QACpB,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;QAE3C,IAAI,CAAC,UAAU;YAAE,OAAO,KAAK,CAAA;QAE7B,IACE,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC;YAC/B,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC;YAC7B,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC;YAC/B,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC;YAChC,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,EACjC,CAAC;YACD,OAAO,KAAK,CAAA;QACd,CAAC;QAED,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,UAAU,CAAC,KAAK,CAAC,oEAAoE,CAAC,CAAA;YAExG,IAAI,SAAS,EAAE,CAAC;gBACd,OAAO,SAAS,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAA;YAClC,CAAC;YAED,OAAO,KAAK,CAAA;QACd,CAAC;QAED,MAAM,YAAY,GAAG,UAAU,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QAClD,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;QAEnD,OAAO;YACL,QAAQ;YACR,QAAQ;YACR,QAAQ;YACR,QAAQ;YACR,OAAO;YACP,MAAM;YACN,UAAU;YACV,OAAO;YACP,SAAS;SACV,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;IACrB,CAAC;IAED,yBAAyB;IACzB,UAAU;QACR,OAAO,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAA;IACzC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,mBAAmB;QACvB,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,0BAA0B,EAAE,CAAA;YACvC,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAC3B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,0BAA0B;QAC9B,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;IAC9B,CAAC;IAED;;OAEG;IACH,qBAAqB;QACnB,OAAO,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,CAAA;IACxD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,cAAc,CAAC,aAAa;QAChC,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,CAAA;QACjD,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,qBAAqB,CAAC,aAAa;QACvC,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,aAAa,EAAE,CAAC,CAAA;IAChD,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,aAAa;QACxD,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,aAAa,CAAC,CAAA;QAElD,WAAW,CAAC,UAAU,CAAC,aAAa,CAAC,CAAA;QAErC,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,SAAS,CAAC,CAAA;QAE1C,SAAS,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QAEhC,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;QAE3D,KAAK,MAAM,aAAa,IAAI,cAAc,EAAE,CAAC;YAC3C,MAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QACjC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,gBAAgB,CAAC,aAAa;QAClC,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,uBAAuB,CAAC,aAAa,CAAC,CAAA;QACnD,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,uBAAuB,CAAC,aAAa;QACzC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,KAAK,CAAC,qBAAqB,aAAa,EAAE,CAAC,CAAA;QACxD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,OAAO,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,CAAA;YAEnE,0EAA0E;YAC1E,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBACpG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0DAA0D,aAAa,EAAE,CAAC,CAAA;gBAC5F,OAAM;YACR,CAAC;YAED,MAAM,KAAK,CAAA;QACb,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,iBAAiB,CAAC,aAAa;QACnC,MAAM,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;YACnD,MAAM,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAA;QACpD,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,wBAAwB,CAAC,aAAa;QAC1C,MAAM,IAAI,CAAC,KAAK,CAAC,yBAAyB,aAAa,EAAE,CAAC,CAAA;IAC5D,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,iBAAiB;QACrB,MAAM,IAAI,CAAC,uBAAuB,CAAC,KAAK,IAAI,EAAE;YAC5C,IAAI,KAAK,GAAG,CAAC,CAAA;YAEb,OAAM,KAAK,IAAI,CAAC,EAAE,CAAC;gBACjB,KAAK,EAAE,CAAA;gBAEP,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;gBACrC,MAAM,cAAc,GAAG,EAAE,CAAA;gBAEzB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,IAAI,KAAK,CAAC,OAAO,EAAE,IAAI,mBAAmB,EAAE,CAAC;wBAC3C,IAAI,CAAC;4BACH,MAAM,KAAK,CAAC,QAAQ,CAAC,EAAC,OAAO,EAAE,IAAI,EAAC,CAAC,CAAA;wBACvC,CAAC;wBAAC,OAAO,KAAK,EAAE,CAAC;4BACf,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;4BACpB,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;wBAC5B,CAAC;oBACH,CAAC;gBACH,CAAC;gBAED,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oBAC/B,MAAK;gBACP,CAAC;qBAAM,IAAI,KAAK,IAAI,CAAC,EAAE,CAAC;oBACtB,QAAQ;gBACV,CAAC;qBAAM,CAAC;oBACN,MAAM,cAAc,CAAC,CAAC,CAAC,CAAA;gBACzB,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,IAAI;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;QAEhC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAED;;;;OAIG;IACH,SAAS,CAAC,IAAI;QACZ,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAA;IACzD,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAA;IACzD,CAAC;IAED;;;OAGG;IACH,iBAAiB;QACf,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA;IACxD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,uBAAuB,CAAC,QAAQ;QACpC,MAAM,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAE/B,IAAI,CAAC;YACH,OAAO,MAAM,QAAQ,EAAE,CAAA;QACzB,CAAC;gBAAS,CAAC;YACT,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAChC,CAAC;IACH,CAAC;CACF","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns\n * @property {boolean} [ifNotExists]\n * @property {string} [name]\n * @property {boolean} [unique]\n * @property {string} tableName\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade]\n * @property {boolean} [ifExists]\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName\n * @property {{[key: string]: any}} conditions\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns]\n * @property {{[key: string]: any}} [data]\n * @property {boolean} [multiple]\n * @property {string[]} [returnLastInsertedColumnNames]\n * @property {Array<Array<any>>} [rows]\n * @property {string} tableName\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions\n * @property {object} data\n * @property {string} tableName\n */\n\nimport {Logger} from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/src/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config\n   * @param {import(\"../../configuration.js\").default} configuration\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} referencedTableName\n   * @param {string} referencedColumnName\n   * @param {object} args\n   * @returns {Promise<void>}\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} _tableData\n   * @returns {Promise<string[]>}\n   */\n  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName\n   * @param {object} [args]\n   * @param {boolean} [args.ifNotExists]\n   * @returns {string[]}\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData\n   * @returns {Promise<string[]>}\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<void>}\n   */\n  async createTable(tableData) {\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<string[]>}\n   */\n  async createTableSql(tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async delete(args) {\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args\n   * @returns {string}\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async dropTable(tableName, args) {\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<string[]>}\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value\n   * @returns {any}\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType}\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined}\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>}\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>}\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name\n   * @param {object} [args]\n   * @param {boolean} args.throwError\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>}\n   */\n  async getTableByName(name, args) {\n    const tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\n  }\n\n  /**\n   * @param {string} name\n   * @returns {Promise<import(\"./base-table.js\").default>}\n   */\n  async getTableByNameOrFail(name) {\n    return await this.getTableByName(name, {throwError: true})\n  }\n\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async insert(args) {\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>}\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args\n   * @returns {string}\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>}\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any}\n   */\n  _convertValue(value) {\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default}\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value\n   * @returns {number | string}\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {string}\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @returns {Query}\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<QueryResultType>}\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq\n   * @returns {void}\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>}\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback\n   * @returns {Promise<any>}\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    let transactionStarted = false\n    let savePointStarted = false\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query\n   * @returns {string}\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error\n   * @returns {boolean}\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return false\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {void}\n   */\n  _assertWritableQuery(sql) {\n    if (!this.isReadOnly()) return\n    if (!this._sqlLooksLikeWrite(sql)) return\n\n    throw new Error(\"Database is read-only\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {boolean}\n   */\n  _sqlLooksLikeWrite(sql) {\n    const normalized = sql.trim().toLowerCase()\n\n    if (!normalized) return false\n\n    if (\n      normalized.startsWith(\"select\") ||\n      normalized.startsWith(\"show\") ||\n      normalized.startsWith(\"pragma\") ||\n      normalized.startsWith(\"explain\") ||\n      normalized.startsWith(\"describe\")\n    ) {\n      return false\n    }\n\n    if (normalized.startsWith(\"with\")) {\n      const withMatch = normalized.match(/^\\s*with[\\s\\S]+?\\)\\s*(select|insert|update|delete|merge|replace)\\b/)\n\n      if (withMatch) {\n        return withMatch[1] !== \"select\"\n      }\n\n      return false\n    }\n\n    const keywordMatch = normalized.match(/^\\s*(\\w+)/)\n    const keyword = keywordMatch ? keywordMatch[1] : \"\"\n\n    return [\n      \"insert\",\n      \"update\",\n      \"delete\",\n      \"create\",\n      \"alter\",\n      \"drop\",\n      \"truncate\",\n      \"merge\",\n      \"replace\"\n    ].includes(keyword)\n  }\n\n  /** @returns {boolean} */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string}\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} oldColumnName\n   * @param {string} newColumnName\n   * @returns {Promise<void>}\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async truncateAllTables() {\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async update(args) {\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args\n   * @returns {string}\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback\n   * @returns {Promise<any>}\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n}\n"]}
|
|
767
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns\n * @property {boolean} [ifNotExists]\n * @property {string} [name]\n * @property {boolean} [unique]\n * @property {string} tableName\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade]\n * @property {boolean} [ifExists]\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName\n * @property {{[key: string]: any}} conditions\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns]\n * @property {{[key: string]: any}} [data]\n * @property {boolean} [multiple]\n * @property {string[]} [returnLastInsertedColumnNames]\n * @property {Array<Array<any>>} [rows]\n * @property {string} tableName\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions\n * @property {object} data\n * @property {string} tableName\n */\n\nimport {Logger} from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/src/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config\n   * @param {import(\"../../configuration.js\").default} configuration\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} referencedTableName\n   * @param {string} referencedColumnName\n   * @param {object} args\n   * @returns {Promise<void>} - Result.\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    this._assertNotReadOnly()\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} _tableData\n   * @returns {Promise<string[]>} - Result.\n   */\n  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Result.\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName\n   * @param {object} [args]\n   * @param {boolean} [args.ifNotExists]\n   * @returns {string[]} - Result.\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData\n   * @returns {Promise<string[]>} - Result.\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<void>} - Result.\n   */\n  async createTable(tableData) {\n    this._assertNotReadOnly()\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<string[]>} - Result.\n   */\n  async createTableSql(tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args\n   * @returns {Promise<void>} - Result.\n   */\n  async delete(args) {\n    this._assertNotReadOnly()\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args\n   * @returns {string} - Result.\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<void>} - Result.\n   */\n  async dropTable(tableName, args) {\n    this._assertNotReadOnly()\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<string[]>} - Result.\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value\n   * @returns {any} - Result.\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType} - Result.\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default} - Result.\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined} - Result.\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>} - Result.\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Result.\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name\n   * @param {object} [args]\n   * @param {boolean} args.throwError\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>} - Result.\n   */\n  async getTableByName(name, args) {\n    const tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\n  }\n\n  /**\n   * @param {string} name\n   * @returns {Promise<import(\"./base-table.js\").default>} - Result.\n   */\n  async getTableByNameOrFail(name) {\n    return await this.getTableByName(name, {throwError: true})\n  }\n\n  /**\n   * @abstract\n   * @returns {string} - Result.\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args\n   * @returns {Promise<void>} - Result.\n   */\n  async insert(args) {\n    this._assertNotReadOnly()\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>} - Result.\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args\n   * @returns {string} - Result.\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>} - Result.\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any} - Result.\n   */\n  _convertValue(value) {\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default} - Result.\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value\n   * @returns {number | string} - Result.\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string} - Result.\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string} - Result.\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {string} - Result.\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @returns {Query} - Result.\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<QueryResultType>} - Result.\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq\n   * @returns {void} - Result.\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Result.\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean} - Result.\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Result.\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>} - Result.\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback\n   * @returns {Promise<any>} - Result.\n   */\n  async transaction(callback) {\n    this._assertNotReadOnly()\n    const savePointName = this.generateSavePointName()\n    let transactionStarted = false\n    let savePointStarted = false\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>} - Result.\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>} - Result.\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query\n   * @returns {string} - Result.\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error\n   * @returns {boolean} - Result.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return false\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {void} - Result.\n   */\n  _assertWritableQuery(sql) {\n    if (!this.isReadOnly()) return\n    if (!this._sqlLooksLikeWrite(sql)) return\n\n    throw new Error(\"Database is read-only\")\n  }\n\n  /**\n   * @returns {void} - Result.\n   */\n  _assertNotReadOnly() {\n    if (this.isReadOnly()) {\n      throw new Error(\"Database is read-only\")\n    }\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {boolean} - Result.\n   */\n  _sqlLooksLikeWrite(sql) {\n    const normalized = sql.trim().toLowerCase()\n\n    if (!normalized) return false\n\n    if (\n      normalized.startsWith(\"select\") ||\n      normalized.startsWith(\"show\") ||\n      normalized.startsWith(\"pragma\") ||\n      normalized.startsWith(\"explain\") ||\n      normalized.startsWith(\"describe\")\n    ) {\n      return false\n    }\n\n    if (normalized.startsWith(\"with\")) {\n      const withMatch = normalized.match(/^\\s*with[\\s\\S]+?\\)\\s*(select|insert|update|delete|merge|replace)\\b/)\n\n      if (withMatch) {\n        return withMatch[1] !== \"select\"\n      }\n\n      return false\n    }\n\n    const keywordMatch = normalized.match(/^\\s*(\\w+)/)\n    const keyword = keywordMatch ? keywordMatch[1] : \"\"\n\n    return [\n      \"insert\",\n      \"update\",\n      \"delete\",\n      \"create\",\n      \"alter\",\n      \"drop\",\n      \"truncate\",\n      \"merge\",\n      \"replace\"\n    ].includes(keyword)\n  }\n\n  /** @returns {boolean} - Result.  */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string} - Result.\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} oldColumnName\n   * @param {string} newColumnName\n   * @returns {Promise<void>} - Result.\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    this._assertNotReadOnly()\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>} - Result.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>} - Result.\n   */\n  async truncateAllTables() {\n    this._assertNotReadOnly()\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args\n   * @returns {Promise<void>} - Result.\n   */\n  async update(args) {\n    this._assertNotReadOnly()\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args\n   * @returns {string} - Result.\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Result.\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Result.\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback\n   * @returns {Promise<any>} - Result.\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n}\n"]}
|