velocious 1.0.300 → 1.0.301

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.
Files changed (59) hide show
  1. package/build/src/configuration-types.d.ts +1 -1
  2. package/build/src/configuration.d.ts +1 -1
  3. package/build/src/database/drivers/base.d.ts +29 -0
  4. package/build/src/database/drivers/base.d.ts.map +1 -1
  5. package/build/src/database/drivers/base.js +25 -1
  6. package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
  7. package/build/src/database/drivers/mssql/index.js +10 -1
  8. package/build/src/database/drivers/mssql/sql/upsert.d.ts +5 -0
  9. package/build/src/database/drivers/mssql/sql/upsert.d.ts.map +1 -0
  10. package/build/src/database/drivers/mssql/sql/upsert.js +19 -0
  11. package/build/src/database/drivers/mysql/index.d.ts.map +1 -1
  12. package/build/src/database/drivers/mysql/index.js +10 -1
  13. package/build/src/database/drivers/mysql/sql/upsert.d.ts +5 -0
  14. package/build/src/database/drivers/mysql/sql/upsert.d.ts.map +1 -0
  15. package/build/src/database/drivers/mysql/sql/upsert.js +11 -0
  16. package/build/src/database/drivers/pgsql/index.d.ts.map +1 -1
  17. package/build/src/database/drivers/pgsql/index.js +10 -1
  18. package/build/src/database/drivers/pgsql/sql/upsert.d.ts +5 -0
  19. package/build/src/database/drivers/pgsql/sql/upsert.d.ts.map +1 -0
  20. package/build/src/database/drivers/pgsql/sql/upsert.js +12 -0
  21. package/build/src/database/drivers/sqlite/base.d.ts.map +1 -1
  22. package/build/src/database/drivers/sqlite/base.js +7 -1
  23. package/build/src/database/drivers/sqlite/sql/upsert.d.ts +5 -0
  24. package/build/src/database/drivers/sqlite/sql/upsert.d.ts.map +1 -0
  25. package/build/src/database/drivers/sqlite/sql/upsert.js +12 -0
  26. package/build/src/database/query/upsert-base.d.ts +59 -0
  27. package/build/src/database/query/upsert-base.d.ts.map +1 -0
  28. package/build/src/database/query/upsert-base.js +87 -0
  29. package/build/src/frontend-model-controller.d.ts.map +1 -1
  30. package/build/src/frontend-model-controller.js +4 -2
  31. package/build/src/frontend-models/websocket-channel.d.ts +9 -1
  32. package/build/src/frontend-models/websocket-channel.d.ts.map +1 -1
  33. package/build/src/frontend-models/websocket-channel.js +17 -3
  34. package/build/src/http-client/websocket-client.d.ts +8 -6
  35. package/build/src/http-client/websocket-client.d.ts.map +1 -1
  36. package/build/src/http-client/websocket-client.js +17 -8
  37. package/build/src/http-server/client/websocket-session.d.ts +62 -5
  38. package/build/src/http-server/client/websocket-session.d.ts.map +1 -1
  39. package/build/src/http-server/client/websocket-session.js +129 -14
  40. package/build/src/http-server/websocket-channel.d.ts +18 -3
  41. package/build/src/http-server/websocket-channel.d.ts.map +1 -1
  42. package/build/src/http-server/websocket-channel.js +18 -6
  43. package/build/src/http-server/websocket-event-log-store.d.ts +198 -0
  44. package/build/src/http-server/websocket-event-log-store.d.ts.map +1 -0
  45. package/build/src/http-server/websocket-event-log-store.js +308 -0
  46. package/build/src/http-server/websocket-events-host.d.ts +14 -0
  47. package/build/src/http-server/websocket-events-host.d.ts.map +1 -1
  48. package/build/src/http-server/websocket-events-host.js +38 -4
  49. package/build/src/http-server/worker-handler/in-process.d.ts +5 -1
  50. package/build/src/http-server/worker-handler/in-process.d.ts.map +1 -1
  51. package/build/src/http-server/worker-handler/in-process.js +10 -3
  52. package/build/src/http-server/worker-handler/index.d.ts +5 -1
  53. package/build/src/http-server/worker-handler/index.d.ts.map +1 -1
  54. package/build/src/http-server/worker-handler/index.js +5 -3
  55. package/build/src/http-server/worker-handler/worker-thread.d.ts +9 -1
  56. package/build/src/http-server/worker-handler/worker-thread.d.ts.map +1 -1
  57. package/build/src/http-server/worker-handler/worker-thread.js +16 -6
  58. package/build/tsconfig.tsbuildinfo +1 -1
  59. package/package.json +1 -1
@@ -474,7 +474,7 @@ export type DatabaseConfigurationType = {
474
474
  /**
475
475
  * - Database type identifier.
476
476
  */
477
- type?: "mysql" | "pgsql" | "mssql" | "sqlite" | undefined;
477
+ type?: "sqlite" | "pgsql" | "mysql" | "mssql" | undefined;
478
478
  /**
479
479
  * - Database to switch to after connecting.
480
480
  */
@@ -81,7 +81,7 @@ export default class VelociousConfiguration {
81
81
  * @returns {typeof import("./database/pool/base.js").default} - The database pool type.
82
82
  */
83
83
  getDatabasePoolType(identifier?: string): typeof import("./database/pool/base.js").default;
84
- getDatabaseType(identifier?: string): "mysql" | "pgsql" | "mssql" | "sqlite";
84
+ getDatabaseType(identifier?: string): "sqlite" | "pgsql" | "mysql" | "mssql";
85
85
  /**
86
86
  * @returns {string} - The directory.
87
87
  */
@@ -169,6 +169,11 @@ export default class VelociousDatabaseDriversBase {
169
169
  * @returns {string} - SQL string.
170
170
  */
171
171
  insertSql(args: InsertSqlArgsType): string;
172
+ /**
173
+ * @param {UpsertSqlArgsType} args - Options object.
174
+ * @returns {Promise<void>} - Resolves when complete.
175
+ */
176
+ upsert(args: UpsertSqlArgsType): Promise<void>;
172
177
  /**
173
178
  * @abstract
174
179
  * @returns {Promise<number>} - Resolves with the last insert id.
@@ -376,6 +381,12 @@ export default class VelociousDatabaseDriversBase {
376
381
  * @returns {string} - SQL string.
377
382
  */
378
383
  updateSql(args: UpdateSqlArgsType): string;
384
+ /**
385
+ * @abstract
386
+ * @param {UpsertSqlArgsType} args - Options object.
387
+ * @returns {string} - SQL string.
388
+ */
389
+ upsertSql(args: UpsertSqlArgsType): string;
379
390
  /**
380
391
  * @abstract
381
392
  * @returns {Promise<void>} - Resolves when complete.
@@ -498,6 +509,24 @@ export type UpdateSqlArgsType = {
498
509
  */
499
510
  tableName: string;
500
511
  };
512
+ export type UpsertSqlArgsType = {
513
+ /**
514
+ * - Columns that define a conflict.
515
+ */
516
+ conflictColumns: string[];
517
+ /**
518
+ * - Column/value pairs to insert.
519
+ */
520
+ data: object;
521
+ /**
522
+ * - Table name to upsert into.
523
+ */
524
+ tableName: string;
525
+ /**
526
+ * - Columns to update on conflict.
527
+ */
528
+ updateColumns: string[];
529
+ };
501
530
  import Mutex from "epic-locks/build/mutex.js";
502
531
  import Logger from "../../logger.js";
503
532
  import Query from "../query/index.js";
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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"}
@@ -43,6 +43,13 @@
43
43
  * @property {object} data - Column/value pairs to update.
44
44
  * @property {string} tableName - Table name to update.
45
45
  */
46
+ /**
47
+ * @typedef {object}UpsertSqlArgsType
48
+ * @property {string[]} conflictColumns - Columns that define a conflict.
49
+ * @property {object} data - Column/value pairs to insert.
50
+ * @property {string} tableName - Table name to upsert into.
51
+ * @property {string[]} updateColumns - Columns to update on conflict.
52
+ */
46
53
  import Logger from "../../logger.js";
47
54
  import Query from "../query/index.js";
48
55
  import Handler from "../handler.js";
@@ -321,6 +328,15 @@ export default class VelociousDatabaseDriversBase {
321
328
  insertSql(args) {
322
329
  throw new Error("'insertSql' not implemented");
323
330
  }
331
+ /**
332
+ * @param {UpsertSqlArgsType} args - Options object.
333
+ * @returns {Promise<void>} - Resolves when complete.
334
+ */
335
+ async upsert(args) {
336
+ this._assertNotReadOnly();
337
+ const sql = this.upsertSql(args);
338
+ await this.query(sql);
339
+ }
324
340
  /**
325
341
  * @abstract
326
342
  * @returns {Promise<number>} - Resolves with the last insert id.
@@ -834,6 +850,14 @@ export default class VelociousDatabaseDriversBase {
834
850
  updateSql(args) {
835
851
  throw new Error("'disableForeignKeys' not implemented");
836
852
  }
853
+ /**
854
+ * @abstract
855
+ * @param {UpsertSqlArgsType} args - Options object.
856
+ * @returns {string} - SQL string.
857
+ */
858
+ upsertSql(args) {
859
+ throw new Error("'upsertSql' not implemented");
860
+ }
837
861
  /**
838
862
  * @abstract
839
863
  * @returns {Promise<void>} - Resolves when complete.
@@ -862,4 +886,4 @@ export default class VelociousDatabaseDriversBase {
862
886
  }
863
887
  }
864
888
  }
865
- //# 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;;;;;;GAMG;AACH;;;;;GAKG;AAEH,OAAO,MAAM,MAAM,iBAAiB,CAAA;AACpC,OAAO,KAAK,MAAM,mBAAmB,CAAA;AACrC,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,KAAK,MAAM,2BAA2B,CAAA;AAC7C,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;IACjB,uDAAuD;IACvD,0BAA0B,CAAA;IAE1B;;;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,0BAA0B,GAAG,EAAE,CAAA;QACpC,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,mBAAmB;IACrB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,UAAU;QACd,mBAAmB;IACrB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS;QACb,MAAM,IAAI,CAAC,KAAK,EAAE,CAAA;QAClB,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;IACtB,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAA;QACnE,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;;OAIG;IACH,yBAAyB,CAAC,IAAI,EAAE,UAAU;QACxC,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,cAAc,EAAE,CAAA;QAC5D,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAA;QAC3B,MAAM,YAAY,GAAG,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,IAAI,IAAI,IAAI,EAAE,WAAW,IAAI,SAAS,CAAA;QAEnF,OAAO,uCAAuC,IAAI,SAAS,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,WAAW,eAAe,YAAY,GAAG,CAAA;IAC7I,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,oBAAoB,CAAC,IAAI;QAC7B,OAAO,gDAAgD,CAAC,CAAC,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,EAAC,UAAU,EAAE,IAAI,EAAC,CAAC,CAAC,CAAA;IAC/G,CAAC;IAED;;;OAGG;IACH,OAAO;QACL,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAA;IAC3C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,IAAI;QACf,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;QAEhC,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI;QAC3C,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAEzB,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,EAAC,OAAO,EAAE,SAAS,EAAE,IAAI,EAAC,CAAC,CAAA;QAEtD,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;;;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,OAAO,KAAK,KAAK,SAAS,EAAE,CAAC;YAC/B,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACtB,CAAC;QAED,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;;;OAGG;IAEH;;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,gDAAgD;QAChD,MAAM,aAAa,GAAG,EAAE,CAAA;QACxB,IAAI,kBAAkB,GAAG,KAAK,CAAA;QAC9B,IAAI,gBAAgB,GAAG,KAAK,CAAA;QAE5B,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;QAEnD,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;YAED,MAAM,IAAI,CAAC,+BAA+B,EAAE,CAAA;QAC9C,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,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,CAAA;YAErC,MAAM,KAAK,CAAA;QACb,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,QAAQ;QACxB,MAAM,YAAY,GAAG,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,0BAA0B,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAEhG,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,MAAM,QAAQ,EAAE,CAAA;YAChB,OAAM;QACR,CAAC;QAED,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAC7B,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,+BAA+B;QACnC,MAAM,kBAAkB,GAAG,IAAI,CAAC,0BAA0B,CAAC,GAAG,EAAE,CAAA;QAEhE,IAAI,CAAC,kBAAkB,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC;YAAE,OAAM;QAElE,MAAM,WAAW,GAAG,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,0BAA0B,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAE/F,IAAI,WAAW,EAAE,CAAC;YAChB,WAAW,CAAC,IAAI,CAAC,GAAG,kBAAkB,CAAC,CAAA;YACvC,OAAM;QACR,CAAC;QAED,KAAK,MAAM,QAAQ,IAAI,kBAAkB,EAAE,CAAC;YAC1C,MAAM,QAAQ,EAAE,CAAA;QAClB,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG;QACb,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAA;QAE9B,IAAI,KAAK,GAAG,CAAC,CAAA;QACb,MAAM,QAAQ,GAAG,CAAC,CAAA;QAElB,OAAO,KAAK,GAAG,QAAQ,EAAE,CAAC;YACxB,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,CAAC,CAAC,KAAK,YAAY,KAAK,CAAC;oBAAE,MAAM,KAAK,CAAA;gBAE1C,MAAM,SAAS,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAA;gBAEpD,IAAI,KAAK,GAAG,QAAQ,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;oBACxC,IAAI,SAAS,CAAC,SAAS,EAAE,CAAC;wBACxB,IAAI,IAAI,CAAC,kBAAkB,GAAG,CAAC,EAAE,CAAC;4BAChC,MAAM,IAAI,KAAK,CAAC,mDAAmD,IAAI,CAAC,kBAAkB,sBAAsB,KAAK,CAAC,OAAO,EAAE,EAAE,EAAC,KAAK,EAAE,KAAK,EAAC,CAAC,CAAA;wBAClJ,CAAC;wBAED,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;oBACxB,CAAC;oBAED,MAAM,MAAM,GAAG,OAAO,SAAS,CAAC,MAAM,KAAK,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAA;oBAEjH,IAAI,MAAM,GAAG,CAAC;wBAAE,MAAM,IAAI,CAAC,MAAM,CAAC,CAAA;oBAClC,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,EAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAC,CAAA;IACzC,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;;OAEG;IACH,kBAAkB;QAChB,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAC1C,CAAC;IACH,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,+CAA+C;IAC/C,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,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 - Columns to include in the index.\n * @property {boolean} [ifNotExists] - Skip creation if the index already exists.\n * @property {string} [name] - Explicit index name to use.\n * @property {boolean} [unique] - Whether the index should enforce uniqueness.\n * @property {string} tableName - Name of the table to add the index to.\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade] - Whether dependent objects should be dropped too.\n * @property {boolean} [ifExists] - Skip dropping if the table does not exist.\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName - Table name to delete from.\n * @property {{[key: string]: any}} conditions - Conditions used to build the delete WHERE clause.\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns] - Column names for `rows` inserts.\n * @property {{[key: string]: any}} [data] - Column/value pairs for a single-row insert.\n * @property {boolean} [multiple] - Whether this insert should be treated as multi-row.\n * @property {string[]} [returnLastInsertedColumnNames] - Column names to return after insert.\n * @property {Array<Array<any>>} [rows] - Row values for a multi-row insert.\n * @property {string} tableName - Table name to insert into.\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object} RetryableDatabaseErrorResult\n * @property {boolean} retry - Whether the error should be retried.\n * @property {boolean} reconnect - Whether to reconnect before retrying.\n * @property {number} [maxTries] - Override the max retry attempts.\n * @property {number} [waitMs] - Wait time before retrying in milliseconds.\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions - Conditions used to build the update WHERE clause.\n * @property {object} data - Column/value pairs to update.\n * @property {string} tableName - Table name to update.\n */\n\nimport Logger from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/build/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  /** @type {Array<Array<() => void | Promise<void>>>} */\n  _afterCommitCallbackFrames\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config - Configuration object.\n   * @param {import(\"../../configuration.js\").default} configuration - Configuration instance.\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._afterCommitCallbackFrames = []\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} columnName - Column name.\n   * @param {string} referencedTableName - Referenced table name.\n   * @param {string} referencedColumnName - Referenced column name.\n   * @param {object} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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>} - Resolves when complete.\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * Optional close hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async close() {\n    // No-op by default\n  }\n\n  /**\n   * Optional disconnect hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async disconnect() {\n    // No-op by default\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async reconnect() {\n    await this.close()\n    await this.connect()\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @returns {string[]} - SQL statements.\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 - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Table data.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {string} - SQL 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 - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Value to use.\n   * @returns {any} - The escape.\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} - The args.\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default} - The configuration.\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} - The id seq.\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>} - Resolves with the tables.\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} args.throwError - Whether throw error.\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>} - Resolves with the table by name.\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) {\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n\n    return table\n  }\n\n  /**\n   * @param {string} name - Table name.\n   * @param {string[]} tableNames - Available table names.\n   * @returns {string} - Error message.\n   */\n  _missingTableErrorMessage(name, tableNames) {\n    const environment = this.getConfiguration().getEnvironment()\n    const args = this.getArgs()\n    const databaseName = args?.database || args?.name || args?.useDatabase || \"unknown\"\n\n    return `Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")} (environment: ${environment}, database: ${databaseName})`\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @returns {Promise<import(\"./base-table.js\").default>} - Resolves with the table by name or fail.\n   */\n  async getTableByNameOrFail(name) {\n    return /** @type {import(\"./base-table.js\").default} */ (await this.getTableByName(name, {throwError: true}))\n  }\n\n  /**\n   * @abstract\n   * @returns {string} - The type.\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insert(args) {\n    this._assertNotReadOnly()\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n\n    const sql = this.insertSql({columns, tableName, rows})\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL 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>} - Resolves with the last insert id.\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The convert value.\n   */\n  _convertValue(value) {\n    if (typeof value === \"boolean\") {\n      return value ? 1 : 0\n    }\n\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} - The options options.\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {number | string} - The quote.\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 - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote index.\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @param {any} value - Value from database.\n   * @returns {any} - Normalized value.\n   */\n\n  /**\n   * @returns {Query} - The new 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 - Table name.\n   * @returns {Promise<QueryResultType>} - Resolves with the select.\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 - New id seq.\n   * @returns {void} - No return value.\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether set auto increment when primary key.\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean} - Whether supports default primary key uuid.\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<boolean>} - Resolves with Whether table exists.\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 - Callback function.\n   * @returns {Promise<any>} - Resolves with the transaction.\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    /** @type {Array<() => void | Promise<void>>} */\n    const callbackFrame = []\n    let transactionStarted = false\n    let savePointStarted = false\n\n    this._afterCommitCallbackFrames.push(callbackFrame)\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\n      await this._commitAfterCommitCallbackFrame()\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      this._afterCommitCallbackFrames.pop()\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * Runs a callback after the surrounding transaction commits.\n   * If no transaction is active, the callback runs immediately.\n   * @param {() => void | Promise<void>} callback - Callback.\n   * @returns {Promise<void>} - Resolves when the callback has been registered or run.\n   */\n  async afterCommit(callback) {\n    const currentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (!currentFrame) {\n      await callback()\n      return\n    }\n\n    currentFrame.push(callback)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * Merges committed callbacks into the parent transaction frame or runs them when the outermost commit completes.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitAfterCommitCallbackFrame() {\n    const committedCallbacks = this._afterCommitCallbackFrames.pop()\n\n    if (!committedCallbacks || committedCallbacks.length === 0) return\n\n    const parentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (parentFrame) {\n      parentFrame.push(...committedCallbacks)\n      return\n    }\n\n    for (const callback of committedCallbacks) {\n      await callback()\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n    const maxTries = 5\n\n    while (tries < maxTries) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (!(error instanceof Error)) throw error\n\n        const retryInfo = this.retryableDatabaseError(error)\n\n        if (tries < maxTries && retryInfo.retry) {\n          if (retryInfo.reconnect) {\n            if (this._transactionsCount > 0) {\n              throw new Error(`Cannot reconnect while a transaction is active (${this._transactionsCount}). Original error: ${error.message}`, {cause: error})\n            }\n\n            await this.reconnect()\n          }\n\n          const waitMs = typeof retryInfo.waitMs === \"number\" && Number.isFinite(retryInfo.waitMs) ? retryInfo.waitMs : 100\n\n          if (waitMs > 0) await wait(waitMs)\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 - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query actual.\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 - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error - Error instance.\n   * @returns {RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return {retry: false, reconnect: false}\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {void} - No return value.\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} - No return value.\n   */\n  _assertNotReadOnly() {\n    if (this.isReadOnly()) {\n      throw new Error(\"Database is read-only\")\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {boolean} - SQL representation.\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} - Whether read only.  */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string} - The generate save point name.\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {string} - SQL 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>} - Resolves when complete.\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the with disabled foreign keys.\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"]}
889
+ //# 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 - Columns to include in the index.\n * @property {boolean} [ifNotExists] - Skip creation if the index already exists.\n * @property {string} [name] - Explicit index name to use.\n * @property {boolean} [unique] - Whether the index should enforce uniqueness.\n * @property {string} tableName - Name of the table to add the index to.\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade] - Whether dependent objects should be dropped too.\n * @property {boolean} [ifExists] - Skip dropping if the table does not exist.\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName - Table name to delete from.\n * @property {{[key: string]: any}} conditions - Conditions used to build the delete WHERE clause.\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns] - Column names for `rows` inserts.\n * @property {{[key: string]: any}} [data] - Column/value pairs for a single-row insert.\n * @property {boolean} [multiple] - Whether this insert should be treated as multi-row.\n * @property {string[]} [returnLastInsertedColumnNames] - Column names to return after insert.\n * @property {Array<Array<any>>} [rows] - Row values for a multi-row insert.\n * @property {string} tableName - Table name to insert into.\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object} RetryableDatabaseErrorResult\n * @property {boolean} retry - Whether the error should be retried.\n * @property {boolean} reconnect - Whether to reconnect before retrying.\n * @property {number} [maxTries] - Override the max retry attempts.\n * @property {number} [waitMs] - Wait time before retrying in milliseconds.\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions - Conditions used to build the update WHERE clause.\n * @property {object} data - Column/value pairs to update.\n * @property {string} tableName - Table name to update.\n */\n/**\n * @typedef {object}UpsertSqlArgsType\n * @property {string[]} conflictColumns - Columns that define a conflict.\n * @property {object} data - Column/value pairs to insert.\n * @property {string} tableName - Table name to upsert into.\n * @property {string[]} updateColumns - Columns to update on conflict.\n */\n\nimport Logger from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/build/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  /** @type {Array<Array<() => void | Promise<void>>>} */\n  _afterCommitCallbackFrames\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config - Configuration object.\n   * @param {import(\"../../configuration.js\").default} configuration - Configuration instance.\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._afterCommitCallbackFrames = []\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} columnName - Column name.\n   * @param {string} referencedTableName - Referenced table name.\n   * @param {string} referencedColumnName - Referenced column name.\n   * @param {object} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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>} - Resolves when complete.\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * Optional close hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async close() {\n    // No-op by default\n  }\n\n  /**\n   * Optional disconnect hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async disconnect() {\n    // No-op by default\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async reconnect() {\n    await this.close()\n    await this.connect()\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @returns {string[]} - SQL statements.\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 - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Table data.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {string} - SQL 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 - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\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 - Value to use.\n   * @returns {any} - The escape.\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} - The args.\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default} - The configuration.\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} - The id seq.\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>} - Resolves with the tables.\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} args.throwError - Whether throw error.\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>} - Resolves with the table by name.\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) {\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n\n    return table\n  }\n\n  /**\n   * @param {string} name - Table name.\n   * @param {string[]} tableNames - Available table names.\n   * @returns {string} - Error message.\n   */\n  _missingTableErrorMessage(name, tableNames) {\n    const environment = this.getConfiguration().getEnvironment()\n    const args = this.getArgs()\n    const databaseName = args?.database || args?.name || args?.useDatabase || \"unknown\"\n\n    return `Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")} (environment: ${environment}, database: ${databaseName})`\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @returns {Promise<import(\"./base-table.js\").default>} - Resolves with the table by name or fail.\n   */\n  async getTableByNameOrFail(name) {\n    return /** @type {import(\"./base-table.js\").default} */ (await this.getTableByName(name, {throwError: true}))\n  }\n\n  /**\n   * @abstract\n   * @returns {string} - The type.\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insert(args) {\n    this._assertNotReadOnly()\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n\n    const sql = this.insertSql({columns, tableName, rows})\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async upsert(args) {\n    this._assertNotReadOnly()\n    const sql = this.upsertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>} - Resolves with the last insert id.\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The convert value.\n   */\n  _convertValue(value) {\n    if (typeof value === \"boolean\") {\n      return value ? 1 : 0\n    }\n\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} - The options options.\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {number | string} - The quote.\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 - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote index.\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @param {any} value - Value from database.\n   * @returns {any} - Normalized value.\n   */\n\n  /**\n   * @returns {Query} - The new 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 - Table name.\n   * @returns {Promise<QueryResultType>} - Resolves with the select.\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 - New id seq.\n   * @returns {void} - No return value.\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether set auto increment when primary key.\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean} - Whether supports default primary key uuid.\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<boolean>} - Resolves with Whether table exists.\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 - Callback function.\n   * @returns {Promise<any>} - Resolves with the transaction.\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    /** @type {Array<() => void | Promise<void>>} */\n    const callbackFrame = []\n    let transactionStarted = false\n    let savePointStarted = false\n\n    this._afterCommitCallbackFrames.push(callbackFrame)\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\n      await this._commitAfterCommitCallbackFrame()\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      this._afterCommitCallbackFrames.pop()\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * Runs a callback after the surrounding transaction commits.\n   * If no transaction is active, the callback runs immediately.\n   * @param {() => void | Promise<void>} callback - Callback.\n   * @returns {Promise<void>} - Resolves when the callback has been registered or run.\n   */\n  async afterCommit(callback) {\n    const currentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (!currentFrame) {\n      await callback()\n      return\n    }\n\n    currentFrame.push(callback)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * Merges committed callbacks into the parent transaction frame or runs them when the outermost commit completes.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitAfterCommitCallbackFrame() {\n    const committedCallbacks = this._afterCommitCallbackFrames.pop()\n\n    if (!committedCallbacks || committedCallbacks.length === 0) return\n\n    const parentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (parentFrame) {\n      parentFrame.push(...committedCallbacks)\n      return\n    }\n\n    for (const callback of committedCallbacks) {\n      await callback()\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n    const maxTries = 5\n\n    while (tries < maxTries) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (!(error instanceof Error)) throw error\n\n        const retryInfo = this.retryableDatabaseError(error)\n\n        if (tries < maxTries && retryInfo.retry) {\n          if (retryInfo.reconnect) {\n            if (this._transactionsCount > 0) {\n              throw new Error(`Cannot reconnect while a transaction is active (${this._transactionsCount}). Original error: ${error.message}`, {cause: error})\n            }\n\n            await this.reconnect()\n          }\n\n          const waitMs = typeof retryInfo.waitMs === \"number\" && Number.isFinite(retryInfo.waitMs) ? retryInfo.waitMs : 100\n\n          if (waitMs > 0) await wait(waitMs)\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 - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query actual.\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 - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error - Error instance.\n   * @returns {RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return {retry: false, reconnect: false}\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {void} - No return value.\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} - No return value.\n   */\n  _assertNotReadOnly() {\n    if (this.isReadOnly()) {\n      throw new Error(\"Database is read-only\")\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {boolean} - SQL representation.\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} - Whether read only.  */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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>} - Resolves when complete.\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string} - The generate save point name.\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\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 - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'upsertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the with disabled foreign keys.\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"]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"AAsBA;IAUM,6CAAqD;IAavD,0DAA+B;IAwDjC;;OAEG;IACH,mBAFa,OAAO,CAAC,MAAM,CAAC,CAM3B;IA2BD;;OAEG;IACH,kBAFa,MAAM,CAEiB;IA6CpC;;;OAGG;IACH,cAHW,OAAO,GACL,MAAM,CAUlB;IAED;;;OAGG;IACH,aAHW,OAAO,GACL,MAAM,GAAG,MAAM,CAS3B;IA2FD,6BAOC;IAIqB,8BAA2C;CAgFlE;iBAnYgB,YAAY;kBAUX,OAAO;oBADL,cAAc"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"AAuBA;IAUM,6CAAqD;IAavD,0DAA+B;IAwDjC;;OAEG;IACH,mBAFa,OAAO,CAAC,MAAM,CAAC,CAM3B;IA2BD;;OAEG;IACH,kBAFa,MAAM,CAEiB;IA6CpC;;;OAGG;IACH,cAHW,OAAO,GACL,MAAM,CAUlB;IAED;;;OAGG;IACH,aAHW,OAAO,GACL,MAAM,GAAG,MAAM,CAS3B;IA2FD,6BAOC;IAIqB,8BAA2C;CA0FlE;iBA9YgB,YAAY;kBAUX,OAAO;oBADL,cAAc"}
@@ -16,6 +16,7 @@ import QueryParser from "./query-parser.js";
16
16
  import Table from "./table.js";
17
17
  import StructureSql from "./structure-sql.js";
18
18
  import timeout from "awaitery/build/timeout.js";
19
+ import Upsert from "./sql/upsert.js";
19
20
  import Update from "./sql/update.js";
20
21
  import UUID from "pure-uuid";
21
22
  export default class VelociousDatabaseDriversMssql extends Base {
@@ -327,6 +328,14 @@ export default class VelociousDatabaseDriversMssql extends Base {
327
328
  const update = new Update({ conditions, data, driver: this, tableName });
328
329
  return update.toSql();
329
330
  }
331
+ /**
332
+ * @param {import("../base.js").UpsertSqlArgsType} args - Options object.
333
+ * @returns {string} - SQL string.
334
+ */
335
+ upsertSql(args) {
336
+ const upsert = new Upsert({ ...args, driver: this });
337
+ return upsert.toSql();
338
+ }
330
339
  /**
331
340
  * @returns {Promise<string | null>} - Resolves with SQL string.
332
341
  */
@@ -334,4 +343,4 @@ export default class VelociousDatabaseDriversMssql extends Base {
334
343
  return await new StructureSql({ driver: this }).toSql();
335
344
  }
336
345
  }
337
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTable from \"./sql/alter-table.js\"\nimport Base from \"../base.js\"\nimport CreateDatabase from \"./sql/create-database.js\"\nimport CreateIndex from \"./sql/create-index.js\"\nimport CreateTable from \"./sql/create-table.js\"\nimport Delete from \"./sql/delete.js\"\nimport DropTable from \"./sql/drop-table.js\"\nimport {digg} from \"diggerize\"\nimport escapeString from \"sql-escape-string\"\nimport Insert from \"./sql/insert.js\"\nimport Options from \"./options.js\"\nimport mssql from \"mssql\"\nimport net from \"node:net\"\nimport QueryParser from \"./query-parser.js\"\nimport Table from \"./table.js\"\nimport StructureSql from \"./structure-sql.js\"\nimport timeout from \"awaitery/build/timeout.js\"\nimport Update from \"./sql/update.js\"\nimport UUID from \"pure-uuid\"\n\nexport default class VelociousDatabaseDriversMssql extends Base{\n  async connect() {\n    const args = this.getArgs()\n    const sqlConfig = digg(args, \"sqlConfig\")\n\n    try {\n      if (sqlConfig?.server && !sqlConfig.options?.serverName && net.isIP(sqlConfig.server)) {\n        sqlConfig.options = Object.assign({}, sqlConfig.options, {serverName: \"\"})\n      }\n\n      this.connection = new mssql.ConnectionPool(sqlConfig)\n      await this.connection.connect()\n    } catch (error) {\n      // Re-throw to fix unuseable stack trace.\n      throw new Error(`Couldn't connect to database: ${error instanceof Error ? error.message : error}`, {cause: error})\n    }\n  }\n\n  async close() {\n    if (!this.connection) return\n\n    const connection = this.connection\n    this.connection = undefined\n    this._currentTransaction = null\n    this._transactionsCount = 0\n\n    try {\n      await timeout({timeout: 2000}, () => connection.close())\n    } catch (error) {\n      this.logger.warn(\"Failed to close MSSQL connection cleanly\", {error})\n    }\n  }\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async alterTableSQLs(tableData) {\n    const alterArgs = {tableData, driver: this}\n    const alterTable = new AlterTable(alterArgs)\n\n    return await alterTable.toSQLs()\n  }\n\n  /**\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @returns {string[]} - SQL statements.\n   */\n  createDatabaseSql(databaseName, args) {\n    const createArgs = Object.assign({databaseName, driver: this}, args)\n    const createDatabase = new CreateDatabase(createArgs)\n\n    return createDatabase.toSql()\n  }\n\n  /**\n   * @param {import(\"../base.js\").CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) {\n    const createArgs = Object.assign({driver: this}, indexData)\n    const createIndex = new CreateIndex(createArgs)\n\n    return await createIndex.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createTableSql(tableData) {\n    const createArgs = {tableData, driver: this, indexInCreateTable: false}\n    const createTable = new CreateTable(createArgs)\n\n    return await createTable.toSql()\n  }\n\n  /**\n   * @returns {Promise<string>} - Resolves with the current database.\n   */\n  async currentDatabase() {\n    const rows = await this.query(\"SELECT DB_NAME() AS db_name\")\n\n    return digg(rows, 0, \"db_name\")\n  }\n\n  async disableForeignKeys() {\n    await this.query(\"EXEC sp_MSforeachtable \\\"ALTER TABLE ? NOCHECK CONSTRAINT all\\\"\")\n  }\n\n  async enableForeignKeys() {\n    await this.query(\"EXEC sp_MSforeachtable @command1=\\\"print '?'\\\", @command2=\\\"ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all\\\"\")\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {import(\"../base.js\").DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args = {}) {\n    const dropArgs = Object.assign({tableName, driver: this}, args)\n    const dropTable = new DropTable(dropArgs)\n\n    return await dropTable.toSQLs()\n  }\n\n  /**\n   * @returns {string} - The type.\n   */\n  getType() { return \"mssql\" }\n\n  /**\n   * @returns {string} - The primary key type.\n   */\n  primaryKeyType() { return \"bigint\" }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {Promise<import(\"../base.js\").QueryResultType>} - Resolves with the query actual.\n   */\n  async _queryActual(sql) {\n    let result\n    let tries = 0\n\n    while (true) {\n      tries++\n\n      try {\n        const request = this._currentTransaction\n          ? new mssql.Request(this._currentTransaction)\n          : new mssql.Request(this.connection)\n        result = await request.query(sql)\n        break\n      } catch (error) {\n        if (error instanceof Error && error.message == \"No connection is specified for that request.\" && tries <= 3) {\n          this.logger.warn(\"Reconnecting to database\")\n          await this.connect()\n          // Retry\n        } else if (error instanceof Error) {\n          // Re-throw error because the stack-trace is broken and can't be used for app-development.\n          throw new Error(`Query failed '${error.message}': ${sql}`, {cause: error})\n        } else {\n          throw new Error(`Query failed '${error}': ${sql}`, {cause: error})\n        }\n      }\n    }\n\n    return Array.isArray(result.recordsets) ? result.recordsets[0] || [] : []\n  }\n\n  /**\n   * @param {import(\"../../query/index.js\").default} query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(query) { return new QueryParser({query}).toSql() }\n\n  shouldSetAutoIncrementWhenPrimaryKey() { return true }\n  supportsDefaultPrimaryKeyUUID() { return true }\n\n  /**\n   * @param {unknown} value - Value to use.\n   * @returns {string} - The escape.\n   */\n  escape(value) {\n    value = this._convertValue(value)\n    const stringValue = typeof value == \"string\" ? value : `${value}`\n\n    const resultWithQuotes = escapeString(stringValue, null)\n    const result = resultWithQuotes.substring(1, resultWithQuotes.length - 1)\n\n    return result\n  }\n\n  /**\n   * @param {unknown} value - Value to use.\n   * @returns {string | number} - The quoted value.\n   */\n  quote(value) {\n    value = this._convertValue(value)\n\n    if (typeof value == \"number\") return value\n    const stringValue = typeof value == \"string\" ? value : String(value)\n\n    return escapeString(stringValue, null)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) { return this.options().quoteColumnName(columnName) }\n\n  /**\n   * @param {string} string - String.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(string) { return this.options().quoteTableName(string) }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    await this.query(`EXEC sp_rename ${this.quote(`${tableName}.${oldColumnName}`)}, ${this.quote(newColumnName)}, 'COLUMN'`)\n  }\n\n  /**\n   * @param {import(\"../base.js\").DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql({tableName, conditions}) {\n    const deleteInstruction = new Delete({conditions, driver: this, tableName})\n\n    return deleteInstruction.toSql()\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../base.js\").InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) {\n    const insertArgs = Object.assign({driver: this}, args)\n    const insert = new Insert(insertArgs)\n\n    return insert.toSql()\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"../base-table.js\").default>>} - Resolves with the tables.\n   */\n  async getTables() {\n    const schema = this.getArgs()?.schema || this.getArgs()?.sqlConfig?.options?.schema\n    const schemaClause = schema\n      ? ` AND [TABLE_SCHEMA] = ${this.quote(schema)}`\n      : \" AND [TABLE_SCHEMA] = SCHEMA_NAME()\"\n    const result = await this.query(`SELECT [TABLE_NAME] FROM [INFORMATION_SCHEMA].[TABLES] WHERE [TABLE_CATALOG] = DB_NAME()${schemaClause}`)\n    const tables = []\n\n    for (const row of result) {\n      const table = new Table(this, /** @type {Record<string, string>} */ (row))\n\n      tables.push(table)\n    }\n\n    return tables\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} args.throwError - Whether throw error.\n   * @returns {Promise<import(\"../base-table.js\").default | undefined>} - Resolves with the table by name.\n   */\n  async getTableByName(name, args) {\n    const schema = this.getArgs()?.schema || this.getArgs()?.sqlConfig?.options?.schema\n    const schemaClause = schema\n      ? ` AND [TABLE_SCHEMA] = ${this.quote(schema)}`\n      : \" AND [TABLE_SCHEMA] = SCHEMA_NAME()\"\n    const result = await this.query(`SELECT [TABLE_NAME] FROM [INFORMATION_SCHEMA].[TABLES] WHERE [TABLE_CATALOG] = DB_NAME()${schemaClause} AND [TABLE_NAME] = ${this.quote(name)}`)\n\n    if (result[0]) {\n      return new Table(this, /** @type {Record<string, string>} */ (result[0]))\n    }\n\n    if (args?.throwError !== false) {\n      const tables = await this.getTables()\n      const tableNames = tables.map((table) => table.getName())\n\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n  }\n\n  async lastInsertID() {\n    const result = await this.query(\"SELECT SCOPE_IDENTITY() AS last_insert_id\")\n    const lastInsertID = digg(result, 0, \"last_insert_id\")\n\n    if (lastInsertID === null) throw new Error(\"Couldn't get the last inserted ID\")\n\n    return lastInsertID\n  }\n\n  /** @returns {Options} - The options options.  */\n  options() {\n    if (!this._options) this._options = new Options({driver: this})\n\n    return this._options\n  }\n\n  async _startTransactionAction() {\n    if (this._currentTransaction) throw new Error(\"A transaction is already running\")\n    if (!this.connection) await this.connect()\n\n    this._currentTransaction = new mssql.Transaction(this.connection)\n\n    try {\n      await this._currentTransaction.begin()\n    } catch (error) {\n      this._currentTransaction = null\n      throw error\n    }\n  }\n\n  async _commitTransactionAction() {\n    if (!this._currentTransaction) throw new Error(\"A transaction isn't running\")\n\n    await this._currentTransaction.commit()\n    this._currentTransaction = null\n  }\n\n  async _rollbackTransactionAction() {\n    if (this._currentTransaction) {\n      await this._currentTransaction.rollback()\n\n      this._currentTransaction = null\n    } else {\n      this.logger.debug(\"A transaction isn't running - ignoring because that can happen if something else has failed in the db\")\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVE TRANSACTION [${savePointName}]`)\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _releaseSavePointAction(savePointName) { // eslint-disable-line no-unused-vars\n    // Do nothing in MS-SQL.\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TRANSACTION [${savePointName}]`)\n  }\n\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`.substring(0, 32)\n  }\n\n  /**\n   * @param {import(\"../base.js\").UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql({conditions, data, tableName}) {\n    const update = new Update({conditions, data, driver: this, tableName})\n\n    return update.toSql()\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return await new StructureSql({driver: this}).toSql()\n  }\n}\n"]}
346
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTable from \"./sql/alter-table.js\"\nimport Base from \"../base.js\"\nimport CreateDatabase from \"./sql/create-database.js\"\nimport CreateIndex from \"./sql/create-index.js\"\nimport CreateTable from \"./sql/create-table.js\"\nimport Delete from \"./sql/delete.js\"\nimport DropTable from \"./sql/drop-table.js\"\nimport {digg} from \"diggerize\"\nimport escapeString from \"sql-escape-string\"\nimport Insert from \"./sql/insert.js\"\nimport Options from \"./options.js\"\nimport mssql from \"mssql\"\nimport net from \"node:net\"\nimport QueryParser from \"./query-parser.js\"\nimport Table from \"./table.js\"\nimport StructureSql from \"./structure-sql.js\"\nimport timeout from \"awaitery/build/timeout.js\"\nimport Upsert from \"./sql/upsert.js\"\nimport Update from \"./sql/update.js\"\nimport UUID from \"pure-uuid\"\n\nexport default class VelociousDatabaseDriversMssql extends Base{\n  async connect() {\n    const args = this.getArgs()\n    const sqlConfig = digg(args, \"sqlConfig\")\n\n    try {\n      if (sqlConfig?.server && !sqlConfig.options?.serverName && net.isIP(sqlConfig.server)) {\n        sqlConfig.options = Object.assign({}, sqlConfig.options, {serverName: \"\"})\n      }\n\n      this.connection = new mssql.ConnectionPool(sqlConfig)\n      await this.connection.connect()\n    } catch (error) {\n      // Re-throw to fix unuseable stack trace.\n      throw new Error(`Couldn't connect to database: ${error instanceof Error ? error.message : error}`, {cause: error})\n    }\n  }\n\n  async close() {\n    if (!this.connection) return\n\n    const connection = this.connection\n    this.connection = undefined\n    this._currentTransaction = null\n    this._transactionsCount = 0\n\n    try {\n      await timeout({timeout: 2000}, () => connection.close())\n    } catch (error) {\n      this.logger.warn(\"Failed to close MSSQL connection cleanly\", {error})\n    }\n  }\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async alterTableSQLs(tableData) {\n    const alterArgs = {tableData, driver: this}\n    const alterTable = new AlterTable(alterArgs)\n\n    return await alterTable.toSQLs()\n  }\n\n  /**\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @returns {string[]} - SQL statements.\n   */\n  createDatabaseSql(databaseName, args) {\n    const createArgs = Object.assign({databaseName, driver: this}, args)\n    const createDatabase = new CreateDatabase(createArgs)\n\n    return createDatabase.toSql()\n  }\n\n  /**\n   * @param {import(\"../base.js\").CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) {\n    const createArgs = Object.assign({driver: this}, indexData)\n    const createIndex = new CreateIndex(createArgs)\n\n    return await createIndex.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createTableSql(tableData) {\n    const createArgs = {tableData, driver: this, indexInCreateTable: false}\n    const createTable = new CreateTable(createArgs)\n\n    return await createTable.toSql()\n  }\n\n  /**\n   * @returns {Promise<string>} - Resolves with the current database.\n   */\n  async currentDatabase() {\n    const rows = await this.query(\"SELECT DB_NAME() AS db_name\")\n\n    return digg(rows, 0, \"db_name\")\n  }\n\n  async disableForeignKeys() {\n    await this.query(\"EXEC sp_MSforeachtable \\\"ALTER TABLE ? NOCHECK CONSTRAINT all\\\"\")\n  }\n\n  async enableForeignKeys() {\n    await this.query(\"EXEC sp_MSforeachtable @command1=\\\"print '?'\\\", @command2=\\\"ALTER TABLE ? WITH CHECK CHECK CONSTRAINT all\\\"\")\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {import(\"../base.js\").DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args = {}) {\n    const dropArgs = Object.assign({tableName, driver: this}, args)\n    const dropTable = new DropTable(dropArgs)\n\n    return await dropTable.toSQLs()\n  }\n\n  /**\n   * @returns {string} - The type.\n   */\n  getType() { return \"mssql\" }\n\n  /**\n   * @returns {string} - The primary key type.\n   */\n  primaryKeyType() { return \"bigint\" }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {Promise<import(\"../base.js\").QueryResultType>} - Resolves with the query actual.\n   */\n  async _queryActual(sql) {\n    let result\n    let tries = 0\n\n    while (true) {\n      tries++\n\n      try {\n        const request = this._currentTransaction\n          ? new mssql.Request(this._currentTransaction)\n          : new mssql.Request(this.connection)\n        result = await request.query(sql)\n        break\n      } catch (error) {\n        if (error instanceof Error && error.message == \"No connection is specified for that request.\" && tries <= 3) {\n          this.logger.warn(\"Reconnecting to database\")\n          await this.connect()\n          // Retry\n        } else if (error instanceof Error) {\n          // Re-throw error because the stack-trace is broken and can't be used for app-development.\n          throw new Error(`Query failed '${error.message}': ${sql}`, {cause: error})\n        } else {\n          throw new Error(`Query failed '${error}': ${sql}`, {cause: error})\n        }\n      }\n    }\n\n    return Array.isArray(result.recordsets) ? result.recordsets[0] || [] : []\n  }\n\n  /**\n   * @param {import(\"../../query/index.js\").default} query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(query) { return new QueryParser({query}).toSql() }\n\n  shouldSetAutoIncrementWhenPrimaryKey() { return true }\n  supportsDefaultPrimaryKeyUUID() { return true }\n\n  /**\n   * @param {unknown} value - Value to use.\n   * @returns {string} - The escape.\n   */\n  escape(value) {\n    value = this._convertValue(value)\n    const stringValue = typeof value == \"string\" ? value : `${value}`\n\n    const resultWithQuotes = escapeString(stringValue, null)\n    const result = resultWithQuotes.substring(1, resultWithQuotes.length - 1)\n\n    return result\n  }\n\n  /**\n   * @param {unknown} value - Value to use.\n   * @returns {string | number} - The quoted value.\n   */\n  quote(value) {\n    value = this._convertValue(value)\n\n    if (typeof value == \"number\") return value\n    const stringValue = typeof value == \"string\" ? value : String(value)\n\n    return escapeString(stringValue, null)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) { return this.options().quoteColumnName(columnName) }\n\n  /**\n   * @param {string} string - String.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(string) { return this.options().quoteTableName(string) }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    await this.query(`EXEC sp_rename ${this.quote(`${tableName}.${oldColumnName}`)}, ${this.quote(newColumnName)}, 'COLUMN'`)\n  }\n\n  /**\n   * @param {import(\"../base.js\").DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql({tableName, conditions}) {\n    const deleteInstruction = new Delete({conditions, driver: this, tableName})\n\n    return deleteInstruction.toSql()\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../base.js\").InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) {\n    const insertArgs = Object.assign({driver: this}, args)\n    const insert = new Insert(insertArgs)\n\n    return insert.toSql()\n  }\n\n  /**\n   * @returns {Promise<Array<import(\"../base-table.js\").default>>} - Resolves with the tables.\n   */\n  async getTables() {\n    const schema = this.getArgs()?.schema || this.getArgs()?.sqlConfig?.options?.schema\n    const schemaClause = schema\n      ? ` AND [TABLE_SCHEMA] = ${this.quote(schema)}`\n      : \" AND [TABLE_SCHEMA] = SCHEMA_NAME()\"\n    const result = await this.query(`SELECT [TABLE_NAME] FROM [INFORMATION_SCHEMA].[TABLES] WHERE [TABLE_CATALOG] = DB_NAME()${schemaClause}`)\n    const tables = []\n\n    for (const row of result) {\n      const table = new Table(this, /** @type {Record<string, string>} */ (row))\n\n      tables.push(table)\n    }\n\n    return tables\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} args.throwError - Whether throw error.\n   * @returns {Promise<import(\"../base-table.js\").default | undefined>} - Resolves with the table by name.\n   */\n  async getTableByName(name, args) {\n    const schema = this.getArgs()?.schema || this.getArgs()?.sqlConfig?.options?.schema\n    const schemaClause = schema\n      ? ` AND [TABLE_SCHEMA] = ${this.quote(schema)}`\n      : \" AND [TABLE_SCHEMA] = SCHEMA_NAME()\"\n    const result = await this.query(`SELECT [TABLE_NAME] FROM [INFORMATION_SCHEMA].[TABLES] WHERE [TABLE_CATALOG] = DB_NAME()${schemaClause} AND [TABLE_NAME] = ${this.quote(name)}`)\n\n    if (result[0]) {\n      return new Table(this, /** @type {Record<string, string>} */ (result[0]))\n    }\n\n    if (args?.throwError !== false) {\n      const tables = await this.getTables()\n      const tableNames = tables.map((table) => table.getName())\n\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n  }\n\n  async lastInsertID() {\n    const result = await this.query(\"SELECT SCOPE_IDENTITY() AS last_insert_id\")\n    const lastInsertID = digg(result, 0, \"last_insert_id\")\n\n    if (lastInsertID === null) throw new Error(\"Couldn't get the last inserted ID\")\n\n    return lastInsertID\n  }\n\n  /** @returns {Options} - The options options.  */\n  options() {\n    if (!this._options) this._options = new Options({driver: this})\n\n    return this._options\n  }\n\n  async _startTransactionAction() {\n    if (this._currentTransaction) throw new Error(\"A transaction is already running\")\n    if (!this.connection) await this.connect()\n\n    this._currentTransaction = new mssql.Transaction(this.connection)\n\n    try {\n      await this._currentTransaction.begin()\n    } catch (error) {\n      this._currentTransaction = null\n      throw error\n    }\n  }\n\n  async _commitTransactionAction() {\n    if (!this._currentTransaction) throw new Error(\"A transaction isn't running\")\n\n    await this._currentTransaction.commit()\n    this._currentTransaction = null\n  }\n\n  async _rollbackTransactionAction() {\n    if (this._currentTransaction) {\n      await this._currentTransaction.rollback()\n\n      this._currentTransaction = null\n    } else {\n      this.logger.debug(\"A transaction isn't running - ignoring because that can happen if something else has failed in the db\")\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVE TRANSACTION [${savePointName}]`)\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _releaseSavePointAction(savePointName) { // eslint-disable-line no-unused-vars\n    // Do nothing in MS-SQL.\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TRANSACTION [${savePointName}]`)\n  }\n\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`.substring(0, 32)\n  }\n\n  /**\n   * @param {import(\"../base.js\").UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql({conditions, data, tableName}) {\n    const update = new Update({conditions, data, driver: this, tableName})\n\n    return update.toSql()\n  }\n\n  /**\n   * @param {import(\"../base.js\").UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) {\n    const upsert = new Upsert({...args, driver: this})\n\n    return upsert.toSql()\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return await new StructureSql({driver: this}).toSql()\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ export default class VelociousDatabaseConnectionDriversMssqlSqlUpsert extends UpsertBase {
2
+ toSql(): string;
3
+ }
4
+ import UpsertBase from "../../../query/upsert-base.js";
5
+ //# sourceMappingURL=upsert.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upsert.d.ts","sourceRoot":"","sources":["../../../../../../src/database/drivers/mssql/sql/upsert.js"],"names":[],"mappings":"AAIA;IACE,gBAcC;CACF;uBAlBsB,+BAA+B"}