velocious 1.0.145 → 1.0.146

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.
@@ -38,6 +38,7 @@
38
38
  * @property {string} [password]
39
39
  * @property {number} [port]
40
40
  * @property {string} [name]
41
+ * @property {boolean} [readOnly]
41
42
  * @property {object} [record]
42
43
  * @property {boolean} [record.transactions]
43
44
  * @property {boolean} [reset]
@@ -117,6 +118,7 @@ export type DatabaseConfigurationType = {
117
118
  password?: string;
118
119
  port?: number;
119
120
  name?: string;
121
+ readOnly?: boolean;
120
122
  record?: {
121
123
  transactions?: boolean;
122
124
  };
@@ -1 +1 @@
1
- {"version":3,"file":"configuration-types.d.ts","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"AAEA;;GAEG;AAEH;;GAEG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;;;;;GAaG;AAEH;;;;;;;;;;;;;;;;;;GAkBG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;;;;;;;;;;;;;;GAeG;AAEH,yBAAyB;uBA/EZ,CAAS,IAA0H,EAA1H;IAAC,OAAO,EAAE,OAAO,iCAAiC,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,OAAO,kCAAkC,EAAE,OAAO,CAAA;CAAC,KAAG,OAAO,CAAC,IAAI,CAAC;6CAInJ,CAAC,EAAE,EAAE,MAAM,KAAK;IAAC,OAAO,EAAE,cAAc,kBAAkB,EAAE,OAAO,CAAA;CAAC;oCACpE,8BAA8B,GAAG;IACzC,IAAI,EAAE,MAAM,MAAM,EAAE,CAAC;IACrB,EAAE,EAAE,MAAM,CAAA;CACX;qCACS;IAAC,cAAc,EAAE,qBAAqB,CAAA;CAAC;+BACvC,CAAS,IAAqD,EAArD;IAAC,aAAa,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAA;CAAC,KAAI,OAAO,CAAC,sBAAsB,CAAC;;eAKhG,MAAM;cAEjB;QAA6B,OAAO,GAAzB,OAAO;QACW,sBAAsB,GAAxC,OAAO;KAClB;eAAW,MAAM;WAEjB;QAAyB,GAAG,GAAjB,MAAM;QACQ,GAAG,GAAjB,MAAM;QACQ,iBAAiB,GAA/B,MAAM;KACjB;aAAW,MAAM;WACN,MAAM;;;eAKN,MAAM;aACN,cAAc,4BAA4B,EAAE,OAAO;eACnD,cAAc,yBAAyB,EAAE,OAAO;oBAChD,MAAa,IAAI;WACjB,MAAM;iBACN,OAAO;eACP,MAAM;WACN,MAAM;WACN,MAAM;aAEjB;QAA4B,YAAY,GAA7B,OAAO;KAClB;YAAW,OAAO;gBACP,SAAS;WACT,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,QAAQ;kBACtC,MAAM;eACN,MAAM;;;;;;cAKN,OAAO;;;;WACP,OAAO;;;;gBACP,MAAM;;;;eACN,MAAM;;;;aACN,KAAK,CAAC,iBAAiB,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;;;;oBAC9D,OAAO;;kCAIR,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;;WAKvB,QAAQ;cACR;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG;YAAC,CAAC,GAAG,EAAE,MAAM,GAAG,yBAAyB,CAAA;SAAC,CAAA;KAAC;YAC3D,OAAO;gBACP,MAAM;kBACN,MAAM;wBACN,OAAO,gCAAgC,EAAE,OAAO;cAChD,oBAAoB;sBACpB,CAAS,IAAmE,EAAnE;QAAC,aAAa,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,KAAI,IAAI;mBACpF,gBAAgB;YAChB,MAAM,IAAG,MAAa,MAAM,CAAA;aAC5B,MAAM,EAAE;qBACR,mBAAmB;cACnB,MAAM"}
1
+ {"version":3,"file":"configuration-types.d.ts","sourceRoot":"","sources":["../../src/configuration-types.js"],"names":[],"mappings":"AAEA;;GAEG;AAEH;;GAEG;AAEH;;;;;;;;GAQG;AAEH;;;;;;;;;;;;;GAaG;AAEH;;;;;;;;;;;;;;;;;;;GAmBG;AAEH;;;;;;;;GAQG;AAEH;;GAEG;AAEH;;;;;;;;;;;;;;;GAeG;AAEH,yBAAyB;uBAhFZ,CAAS,IAA0H,EAA1H;IAAC,OAAO,EAAE,OAAO,iCAAiC,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,OAAO,kCAAkC,EAAE,OAAO,CAAA;CAAC,KAAG,OAAO,CAAC,IAAI,CAAC;6CAInJ,CAAC,EAAE,EAAE,MAAM,KAAK;IAAC,OAAO,EAAE,cAAc,kBAAkB,EAAE,OAAO,CAAA;CAAC;oCACpE,8BAA8B,GAAG;IACzC,IAAI,EAAE,MAAM,MAAM,EAAE,CAAC;IACrB,EAAE,EAAE,MAAM,CAAA;CACX;qCACS;IAAC,cAAc,EAAE,qBAAqB,CAAA;CAAC;+BACvC,CAAS,IAAqD,EAArD;IAAC,aAAa,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAA;CAAC,KAAI,OAAO,CAAC,sBAAsB,CAAC;;eAKhG,MAAM;cAEjB;QAA6B,OAAO,GAAzB,OAAO;QACW,sBAAsB,GAAxC,OAAO;KAClB;eAAW,MAAM;WAEjB;QAAyB,GAAG,GAAjB,MAAM;QACQ,GAAG,GAAjB,MAAM;QACQ,iBAAiB,GAA/B,MAAM;KACjB;aAAW,MAAM;WACN,MAAM;;;eAKN,MAAM;aACN,cAAc,4BAA4B,EAAE,OAAO;eACnD,cAAc,yBAAyB,EAAE,OAAO;oBAChD,MAAa,IAAI;WACjB,MAAM;iBACN,OAAO;eACP,MAAM;WACN,MAAM;WACN,MAAM;eACN,OAAO;aAElB;QAA4B,YAAY,GAA7B,OAAO;KAClB;YAAW,OAAO;gBACP,SAAS;WACT,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,QAAQ;kBACtC,MAAM;eACN,MAAM;;;;;;cAKN,OAAO;;;;WACP,OAAO;;;;gBACP,MAAM;;;;eACN,MAAM;;;;aACN,KAAK,CAAC,iBAAiB,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;;;;oBAC9D,OAAO;;kCAIR,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;;WAKvB,QAAQ;cACR;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG;YAAC,CAAC,GAAG,EAAE,MAAM,GAAG,yBAAyB,CAAA;SAAC,CAAA;KAAC;YAC3D,OAAO;gBACP,MAAM;kBACN,MAAM;wBACN,OAAO,gCAAgC,EAAE,OAAO;cAChD,oBAAoB;sBACpB,CAAS,IAAmE,EAAnE;QAAC,aAAa,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,KAAI,IAAI;mBACpF,gBAAgB;YAChB,MAAM,IAAG,MAAa,MAAM,CAAA;aAC5B,MAAM,EAAE;qBACR,mBAAmB;cACnB,MAAM"}
@@ -39,6 +39,7 @@
39
39
  * @property {string} [password]
40
40
  * @property {number} [port]
41
41
  * @property {string} [name]
42
+ * @property {boolean} [readOnly]
42
43
  * @property {object} [record]
43
44
  * @property {boolean} [record.transactions]
44
45
  * @property {boolean} [reset]
@@ -76,4 +77,4 @@
76
77
  * @property {string} [testing]
77
78
  */
78
79
  export const nothing = {};
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWd1cmF0aW9uLXR5cGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWjs7R0FFRztBQUVIOztHQUVHO0FBRUg7Ozs7Ozs7O0dBUUc7QUFFSDs7Ozs7Ozs7Ozs7OztHQWFHO0FBRUg7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtCRztBQUVIOzs7Ozs7OztHQVFHO0FBRUg7O0dBRUc7QUFFSDs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFFSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbi8qKlxuICogQG1vZHVsZSB0eXBlc1xuICovXG5cbi8qKlxuICogQHR5cGVkZWYge2Z1bmN0aW9uKHtyZXF1ZXN0OiBpbXBvcnQoXCIuL2h0dHAtc2VydmVyL2NsaWVudC9yZXF1ZXN0LmpzXCIpLmRlZmF1bHQsIHJlc3BvbnNlOiBpbXBvcnQoXCIuL2h0dHAtc2VydmVyL2NsaWVudC9yZXNwb25zZS5qc1wiKS5kZWZhdWx0fSk6IFByb21pc2U8dm9pZD59IENvcnNUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7KGlkOiBzdHJpbmcpID0+IHtkZWZhdWx0OiB0eXBlb2YgaW1wb3J0KFwiLi9pbml0aWFsaXplci5qc1wiKS5kZWZhdWx0fX0gSW5pdGlhbGl6ZXJzUmVxdWlyZUNvbnRleHRUeXBlXG4gKiBAdHlwZWRlZiB7SW5pdGlhbGl6ZXJzUmVxdWlyZUNvbnRleHRUeXBlICYge1xuICogICBrZXlzOiAoKSA9PiBzdHJpbmdbXSxcbiAqICAgaWQ6IHN0cmluZ1xuICogfX0gV2VicGFja1JlcXVpcmVDb250ZXh0XG4gKiBAdHlwZWRlZiB7e3JlcXVpcmVDb250ZXh0OiBXZWJwYWNrUmVxdWlyZUNvbnRleHR9fSBJbml0aWFsaXplcnNFeHBvcnRUeXBlXG4gKiBAdHlwZWRlZiB7ZnVuY3Rpb24oe2NvbmZpZ3VyYXRpb246IGltcG9ydChcIi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0fSkgOiBQcm9taXNlPEluaXRpYWxpemVyc0V4cG9ydFR5cGU+fSBJbml0aWFsaXplcnNUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBTcWxDb25maWdcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGF0YWJhc2VdXG4gKiBAcHJvcGVydHkge29iamVjdH0gW29wdGlvbnNdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFtvcHRpb25zLmVuY3J5cHRdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFtvcHRpb25zLnRydXN0U2VydmVyQ2VydGlmaWNhdGVdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3Bhc3N3b3JkXVxuICogQHByb3BlcnR5IHtvYmplY3R9IFtwb29sXVxuICogQHByb3BlcnR5IHtudW1iZXJ9IFtwb29sLm1heF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbcG9vbC5taW5dXG4gKiBAcHJvcGVydHkge251bWJlcn0gW3Bvb2wuaWRsZVRpbWVvdXRNaWxsaXNdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3NlcnZlcl1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdXNlcl1cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IERhdGFiYXNlQ29uZmlndXJhdGlvblR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGF0YWJhc2VdXG4gKiBAcHJvcGVydHkge3R5cGVvZiBpbXBvcnQoXCIuL2RhdGFiYXNlL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0fSBbZHJpdmVyXVxuICogQHByb3BlcnR5IHt0eXBlb2YgaW1wb3J0KFwiLi9kYXRhYmFzZS9wb29sL2Jhc2UuanNcIikuZGVmYXVsdH0gW3Bvb2xUeXBlXVxuICogQHByb3BlcnR5IHtmdW5jdGlvbigpIDogdm9pZH0gW2dldENvbm5lY3Rpb25dXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2hvc3RdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFttaWdyYXRpb25zXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtwYXNzd29yZF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbcG9ydF1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbbmFtZV1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbcmVjb3JkXVxuICogQHByb3BlcnR5IHtib29sZWFufSBbcmVjb3JkLnRyYW5zYWN0aW9uc11cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW3Jlc2V0XVxuICogQHByb3BlcnR5IHtTcWxDb25maWd9IFtzcWxDb25maWddXG4gKiBAcHJvcGVydHkge1wibXNzcWxcIiB8IFwibXlzcWxcIiB8IFwicGdzcWxcIiB8IFwic3FsaXRlXCJ9IFt0eXBlXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFt1c2VEYXRhYmFzZV1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdXNlcm5hbWVdXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBMb2dnaW5nQ29uZmlndXJhdGlvblxuICogQHByb3BlcnR5IHtib29sZWFufSBbY29uc29sZV0gLSBFbmFibGUvZGlzYWJsZSBjb25zb2xlIGxvZ2dpbmcgZm9yIHJlcXVlc3QgbG9nZ2luZy4gRGVmYXVsdHMgdG8gdHJ1ZSBvdXRzaWRlIG9mIFwidGVzdFwiIGFuZCBmb3IgSFRUUCBzZXJ2ZXIgbG9ncy5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2ZpbGVdIC0gRW5hYmxlL2Rpc2FibGUgd3JpdGluZyBsb2dzIHRvIGEgZmlsZS4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGlyZWN0b3J5XSAtIERpcmVjdG9yeSB3aGVyZSBsb2cgZmlsZXMgYXJlIHN0b3JlZC4gRGVmYXVsdHMgdG8gXCI8cHJvamVjdD4vbG9nXCIuXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2ZpbGVQYXRoXSAtIEV4cGxpY2l0IHBhdGggZm9yIHRoZSBsb2cgZmlsZS4gRGVmYXVsdHMgdG8gXCI8ZGlyZWN0b3J5Pi88ZW52aXJvbm1lbnQ+LmxvZ1wiLlxuICogQHByb3BlcnR5IHtBcnJheTxcImRlYnVnLWxvdy1sZXZlbFwiIHwgXCJkZWJ1Z1wiIHwgXCJpbmZvXCIgfCBcIndhcm5cIiB8IFwiZXJyb3JcIj59IFtsZXZlbHNdIC0gT3ZlcnJpZGUgd2hpY2ggbG9nIGxldmVscyBhcmUgZW1pdHRlZC5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlYnVnTG93TGV2ZWxdIC0gQ29udmVuaWVuY2UgZmxhZyB0byBpbmNsdWRlIHZlcnkgbG93LWxldmVsIGRlYnVnIGxvZ3MuXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7UmVjb3JkPHN0cmluZywgc3RyaW5nW10+fSBMb2NhbGVGYWxsYmFja3NUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBDb25maWd1cmF0aW9uQXJnc1R5cGVcbiAqIEBwcm9wZXJ0eSB7Q29yc1R5cGV9IFtjb3JzXVxuICogQHByb3BlcnR5IHt7W2tleTogc3RyaW5nXToge1trZXk6IHN0cmluZ106IERhdGFiYXNlQ29uZmlndXJhdGlvblR5cGV9fX0gZGF0YWJhc2VcbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlYnVnXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtkaXJlY3RvcnldXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2Vudmlyb25tZW50XVxuICogQHByb3BlcnR5IHtpbXBvcnQoXCIuL2Vudmlyb25tZW50LWhhbmRsZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gZW52aXJvbm1lbnRIYW5kbGVyXG4gKiBAcHJvcGVydHkge0xvZ2dpbmdDb25maWd1cmF0aW9ufSBbbG9nZ2luZ11cbiAqIEBwcm9wZXJ0eSB7ZnVuY3Rpb24oe2NvbmZpZ3VyYXRpb246IGltcG9ydChcIi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0LCB0eXBlOiBzdHJpbmd9KSA6IHZvaWR9IGluaXRpYWxpemVNb2RlbHNcbiAqIEBwcm9wZXJ0eSB7SW5pdGlhbGl6ZXJzVHlwZX0gW2luaXRpYWxpemVyc11cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nIHwgZnVuY3Rpb24oKSA6IHN0cmluZ30gbG9jYWxlXG4gKiBAcHJvcGVydHkge3N0cmluZ1tdfSBsb2NhbGVzXG4gKiBAcHJvcGVydHkge0xvY2FsZUZhbGxiYWNrc1R5cGV9IGxvY2FsZUZhbGxiYWNrc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IFt0ZXN0aW5nXVxuICovXG5cbmV4cG9ydCBjb25zdCBub3RoaW5nID0ge31cbiJdfQ==
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWd1cmF0aW9uLXR5cGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWjs7R0FFRztBQUVIOztHQUVHO0FBRUg7Ozs7Ozs7O0dBUUc7QUFFSDs7Ozs7Ozs7Ozs7OztHQWFHO0FBRUg7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQkc7QUFFSDs7Ozs7Ozs7R0FRRztBQUVIOztHQUVHO0FBRUg7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBRUgsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLEVBQUUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8vIEB0cy1jaGVja1xuXG4vKipcbiAqIEBtb2R1bGUgdHlwZXNcbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtmdW5jdGlvbih7cmVxdWVzdDogaW1wb3J0KFwiLi9odHRwLXNlcnZlci9jbGllbnQvcmVxdWVzdC5qc1wiKS5kZWZhdWx0LCByZXNwb25zZTogaW1wb3J0KFwiLi9odHRwLXNlcnZlci9jbGllbnQvcmVzcG9uc2UuanNcIikuZGVmYXVsdH0pOiBQcm9taXNlPHZvaWQ+fSBDb3JzVHlwZVxuICovXG5cbi8qKlxuICogQHR5cGVkZWYgeyhpZDogc3RyaW5nKSA9PiB7ZGVmYXVsdDogdHlwZW9mIGltcG9ydChcIi4vaW5pdGlhbGl6ZXIuanNcIikuZGVmYXVsdH19IEluaXRpYWxpemVyc1JlcXVpcmVDb250ZXh0VHlwZVxuICogQHR5cGVkZWYge0luaXRpYWxpemVyc1JlcXVpcmVDb250ZXh0VHlwZSAmIHtcbiAqICAga2V5czogKCkgPT4gc3RyaW5nW10sXG4gKiAgIGlkOiBzdHJpbmdcbiAqIH19IFdlYnBhY2tSZXF1aXJlQ29udGV4dFxuICogQHR5cGVkZWYge3tyZXF1aXJlQ29udGV4dDogV2VicGFja1JlcXVpcmVDb250ZXh0fX0gSW5pdGlhbGl6ZXJzRXhwb3J0VHlwZVxuICogQHR5cGVkZWYge2Z1bmN0aW9uKHtjb25maWd1cmF0aW9uOiBpbXBvcnQoXCIuL2NvbmZpZ3VyYXRpb24uanNcIikuZGVmYXVsdH0pIDogUHJvbWlzZTxJbml0aWFsaXplcnNFeHBvcnRUeXBlPn0gSW5pdGlhbGl6ZXJzVHlwZVxuICovXG5cbi8qKlxuICogQHR5cGVkZWYge29iamVjdH0gU3FsQ29uZmlnXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2RhdGFiYXNlXVxuICogQHByb3BlcnR5IHtvYmplY3R9IFtvcHRpb25zXVxuICogQHByb3BlcnR5IHtib29sZWFufSBbb3B0aW9ucy5lbmNyeXB0XVxuICogQHByb3BlcnR5IHtib29sZWFufSBbb3B0aW9ucy50cnVzdFNlcnZlckNlcnRpZmljYXRlXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtwYXNzd29yZF1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbcG9vbF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbcG9vbC5tYXhdXG4gKiBAcHJvcGVydHkge251bWJlcn0gW3Bvb2wubWluXVxuICogQHByb3BlcnR5IHtudW1iZXJ9IFtwb29sLmlkbGVUaW1lb3V0TWlsbGlzXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtzZXJ2ZXJdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3VzZXJdXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBEYXRhYmFzZUNvbmZpZ3VyYXRpb25UeXBlXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2RhdGFiYXNlXVxuICogQHByb3BlcnR5IHt0eXBlb2YgaW1wb3J0KFwiLi9kYXRhYmFzZS9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gW2RyaXZlcl1cbiAqIEBwcm9wZXJ0eSB7dHlwZW9mIGltcG9ydChcIi4vZGF0YWJhc2UvcG9vbC9iYXNlLmpzXCIpLmRlZmF1bHR9IFtwb29sVHlwZV1cbiAqIEBwcm9wZXJ0eSB7ZnVuY3Rpb24oKSA6IHZvaWR9IFtnZXRDb25uZWN0aW9uXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtob3N0XVxuICogQHByb3BlcnR5IHtib29sZWFufSBbbWlncmF0aW9uc11cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbcGFzc3dvcmRdXG4gKiBAcHJvcGVydHkge251bWJlcn0gW3BvcnRdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW25hbWVdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFtyZWFkT25seV1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbcmVjb3JkXVxuICogQHByb3BlcnR5IHtib29sZWFufSBbcmVjb3JkLnRyYW5zYWN0aW9uc11cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW3Jlc2V0XVxuICogQHByb3BlcnR5IHtTcWxDb25maWd9IFtzcWxDb25maWddXG4gKiBAcHJvcGVydHkge1wibXNzcWxcIiB8IFwibXlzcWxcIiB8IFwicGdzcWxcIiB8IFwic3FsaXRlXCJ9IFt0eXBlXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFt1c2VEYXRhYmFzZV1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdXNlcm5hbWVdXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBMb2dnaW5nQ29uZmlndXJhdGlvblxuICogQHByb3BlcnR5IHtib29sZWFufSBbY29uc29sZV0gLSBFbmFibGUvZGlzYWJsZSBjb25zb2xlIGxvZ2dpbmcgZm9yIHJlcXVlc3QgbG9nZ2luZy4gRGVmYXVsdHMgdG8gdHJ1ZSBvdXRzaWRlIG9mIFwidGVzdFwiIGFuZCBmb3IgSFRUUCBzZXJ2ZXIgbG9ncy5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2ZpbGVdIC0gRW5hYmxlL2Rpc2FibGUgd3JpdGluZyBsb2dzIHRvIGEgZmlsZS4gRGVmYXVsdHMgdG8gdHJ1ZS5cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGlyZWN0b3J5XSAtIERpcmVjdG9yeSB3aGVyZSBsb2cgZmlsZXMgYXJlIHN0b3JlZC4gRGVmYXVsdHMgdG8gXCI8cHJvamVjdD4vbG9nXCIuXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2ZpbGVQYXRoXSAtIEV4cGxpY2l0IHBhdGggZm9yIHRoZSBsb2cgZmlsZS4gRGVmYXVsdHMgdG8gXCI8ZGlyZWN0b3J5Pi88ZW52aXJvbm1lbnQ+LmxvZ1wiLlxuICogQHByb3BlcnR5IHtBcnJheTxcImRlYnVnLWxvdy1sZXZlbFwiIHwgXCJkZWJ1Z1wiIHwgXCJpbmZvXCIgfCBcIndhcm5cIiB8IFwiZXJyb3JcIj59IFtsZXZlbHNdIC0gT3ZlcnJpZGUgd2hpY2ggbG9nIGxldmVscyBhcmUgZW1pdHRlZC5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlYnVnTG93TGV2ZWxdIC0gQ29udmVuaWVuY2UgZmxhZyB0byBpbmNsdWRlIHZlcnkgbG93LWxldmVsIGRlYnVnIGxvZ3MuXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7UmVjb3JkPHN0cmluZywgc3RyaW5nW10+fSBMb2NhbGVGYWxsYmFja3NUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBDb25maWd1cmF0aW9uQXJnc1R5cGVcbiAqIEBwcm9wZXJ0eSB7Q29yc1R5cGV9IFtjb3JzXVxuICogQHByb3BlcnR5IHt7W2tleTogc3RyaW5nXToge1trZXk6IHN0cmluZ106IERhdGFiYXNlQ29uZmlndXJhdGlvblR5cGV9fX0gZGF0YWJhc2VcbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW2RlYnVnXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtkaXJlY3RvcnldXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2Vudmlyb25tZW50XVxuICogQHByb3BlcnR5IHtpbXBvcnQoXCIuL2Vudmlyb25tZW50LWhhbmRsZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gZW52aXJvbm1lbnRIYW5kbGVyXG4gKiBAcHJvcGVydHkge0xvZ2dpbmdDb25maWd1cmF0aW9ufSBbbG9nZ2luZ11cbiAqIEBwcm9wZXJ0eSB7ZnVuY3Rpb24oe2NvbmZpZ3VyYXRpb246IGltcG9ydChcIi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0LCB0eXBlOiBzdHJpbmd9KSA6IHZvaWR9IGluaXRpYWxpemVNb2RlbHNcbiAqIEBwcm9wZXJ0eSB7SW5pdGlhbGl6ZXJzVHlwZX0gW2luaXRpYWxpemVyc11cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nIHwgZnVuY3Rpb24oKSA6IHN0cmluZ30gbG9jYWxlXG4gKiBAcHJvcGVydHkge3N0cmluZ1tdfSBsb2NhbGVzXG4gKiBAcHJvcGVydHkge0xvY2FsZUZhbGxiYWNrc1R5cGV9IGxvY2FsZUZhbGxiYWNrc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IFt0ZXN0aW5nXVxuICovXG5cbmV4cG9ydCBjb25zdCBub3RoaW5nID0ge31cbiJdfQ==
@@ -259,6 +259,18 @@ export default class VelociousDatabaseDriversBase {
259
259
  * @returns {boolean}
260
260
  */
261
261
  retryableDatabaseError(_error: Error): boolean;
262
+ /**
263
+ * @param {string} sql
264
+ * @returns {void}
265
+ */
266
+ _assertWritableQuery(sql: string): void;
267
+ /**
268
+ * @param {string} sql
269
+ * @returns {boolean}
270
+ */
271
+ _sqlLooksLikeWrite(sql: string): boolean;
272
+ /** @returns {boolean} */
273
+ isReadOnly(): boolean;
262
274
  /**
263
275
  * @returns {Promise<void>}
264
276
  */
@@ -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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"}
@@ -482,6 +482,7 @@ export default class VelociousDatabaseDriversBase {
482
482
  * @returns {Promise<QueryResultType>}
483
483
  */
484
484
  async query(sql) {
485
+ this._assertWritableQuery(sql);
485
486
  let tries = 0;
486
487
  while (tries < 5) {
487
488
  tries++;
@@ -522,6 +523,57 @@ export default class VelociousDatabaseDriversBase {
522
523
  retryableDatabaseError(_error) {
523
524
  return false;
524
525
  }
526
+ /**
527
+ * @param {string} sql
528
+ * @returns {void}
529
+ */
530
+ _assertWritableQuery(sql) {
531
+ if (!this.isReadOnly())
532
+ return;
533
+ if (!this._sqlLooksLikeWrite(sql))
534
+ return;
535
+ throw new Error("Database is read-only");
536
+ }
537
+ /**
538
+ * @param {string} sql
539
+ * @returns {boolean}
540
+ */
541
+ _sqlLooksLikeWrite(sql) {
542
+ const normalized = sql.trim().toLowerCase();
543
+ if (!normalized)
544
+ return false;
545
+ if (normalized.startsWith("select") ||
546
+ normalized.startsWith("show") ||
547
+ normalized.startsWith("pragma") ||
548
+ normalized.startsWith("explain") ||
549
+ normalized.startsWith("describe")) {
550
+ return false;
551
+ }
552
+ if (normalized.startsWith("with")) {
553
+ const withMatch = normalized.match(/^\s*with[\s\S]+?\)\s*(select|insert|update|delete|merge|replace)\b/);
554
+ if (withMatch) {
555
+ return withMatch[1] !== "select";
556
+ }
557
+ return false;
558
+ }
559
+ const keywordMatch = normalized.match(/^\s*(\w+)/);
560
+ const keyword = keywordMatch ? keywordMatch[1] : "";
561
+ return [
562
+ "insert",
563
+ "update",
564
+ "delete",
565
+ "create",
566
+ "alter",
567
+ "drop",
568
+ "truncate",
569
+ "merge",
570
+ "replace"
571
+ ].includes(keyword);
572
+ }
573
+ /** @returns {boolean} */
574
+ isReadOnly() {
575
+ return Boolean(this.getArgs().readOnly);
576
+ }
525
577
  /**
526
578
  * @returns {Promise<void>}
527
579
  */
@@ -695,4 +747,4 @@ export default class VelociousDatabaseDriversBase {
695
747
  }
696
748
  }
697
749
  }
698
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns\n * @property {boolean} [ifNotExists]\n * @property {string} [name]\n * @property {boolean} [unique]\n * @property {string} tableName\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade]\n * @property {boolean} [ifExists]\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName\n * @property {{[key: string]: any}} conditions\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns]\n * @property {{[key: string]: any}} [data]\n * @property {boolean} [multiple]\n * @property {string[]} [returnLastInsertedColumnNames]\n * @property {Array<Array<any>>} [rows]\n * @property {string} tableName\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions\n * @property {object} data\n * @property {string} tableName\n */\n\nimport {Logger} from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/src/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config\n   * @param {import(\"../../configuration.js\").default} configuration\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} referencedTableName\n   * @param {string} referencedColumnName\n   * @param {object} args\n   * @returns {Promise<void>}\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} _tableData\n   * @returns {Promise<string[]>}\n   */\n  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName\n   * @param {object} [args]\n   * @param {boolean} [args.ifNotExists]\n   * @returns {string[]}\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData\n   * @returns {Promise<string[]>}\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<void>}\n   */\n  async createTable(tableData) {\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<string[]>}\n   */\n  async createTableSql(tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async delete(args) {\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args\n   * @returns {string}\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async dropTable(tableName, args) {\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<string[]>}\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value\n   * @returns {any}\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType}\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined}\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>}\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>}\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name\n   * @param {object} [args]\n   * @param {boolean} args.throwError\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>}\n   */\n  async getTableByName(name, args) {\n    const tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\n  }\n\n  /**\n   * @param {string} name\n   * @returns {Promise<import(\"./base-table.js\").default>}\n   */\n  async getTableByNameOrFail(name) {\n    return await this.getTableByName(name, {throwError: true})\n  }\n\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async insert(args) {\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>}\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args\n   * @returns {string}\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>}\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any}\n   */\n  _convertValue(value) {\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default}\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value\n   * @returns {number | string}\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {string}\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @returns {Query}\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<QueryResultType>}\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq\n   * @returns {void}\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>}\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback\n   * @returns {Promise<any>}\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    let transactionStarted = false\n    let savePointStarted = false\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  async query(sql) {\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query\n   * @returns {string}\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error\n   * @returns {boolean}\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return false\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string}\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} oldColumnName\n   * @param {string} newColumnName\n   * @returns {Promise<void>}\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async truncateAllTables() {\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async update(args) {\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args\n   * @returns {string}\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback\n   * @returns {Promise<any>}\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n}\n"]}
750
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns\n * @property {boolean} [ifNotExists]\n * @property {string} [name]\n * @property {boolean} [unique]\n * @property {string} tableName\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade]\n * @property {boolean} [ifExists]\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName\n * @property {{[key: string]: any}} conditions\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns]\n * @property {{[key: string]: any}} [data]\n * @property {boolean} [multiple]\n * @property {string[]} [returnLastInsertedColumnNames]\n * @property {Array<Array<any>>} [rows]\n * @property {string} tableName\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions\n * @property {object} data\n * @property {string} tableName\n */\n\nimport {Logger} from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/src/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config\n   * @param {import(\"../../configuration.js\").default} configuration\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} referencedTableName\n   * @param {string} referencedColumnName\n   * @param {object} args\n   * @returns {Promise<void>}\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} _tableData\n   * @returns {Promise<string[]>}\n   */\n  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName\n   * @param {object} [args]\n   * @param {boolean} [args.ifNotExists]\n   * @returns {string[]}\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData\n   * @returns {Promise<string[]>}\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<void>}\n   */\n  async createTable(tableData) {\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../table-data/index.js\").default} tableData\n   * @returns {Promise<string[]>}\n   */\n  async createTableSql(tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async delete(args) {\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args\n   * @returns {string}\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async dropTable(tableName, args) {\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {DropTableSqlArgsType} [args]\n   * @returns {Promise<string[]>}\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value\n   * @returns {any}\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType}\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined}\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>}\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>}\n   */\n  async structureSql() {\n    return null\n  }\n\n  /**\n   * @param {string} name\n   * @param {object} [args]\n   * @param {boolean} args.throwError\n   * @returns {Promise<import(\"./base-table.js\").default | undefined>}\n   */\n  async getTableByName(name, args) {\n    const tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\n  }\n\n  /**\n   * @param {string} name\n   * @returns {Promise<import(\"./base-table.js\").default>}\n   */\n  async getTableByNameOrFail(name) {\n    return await this.getTableByName(name, {throwError: true})\n  }\n\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async insert(args) {\n    const sql = this.insertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>}\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args\n   * @returns {string}\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>}\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any}\n   */\n  _convertValue(value) {\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default}\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value\n   * @returns {number | string}\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName\n   * @returns {string}\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {string}\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @returns {Query}\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<QueryResultType>}\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq\n   * @returns {void}\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean}\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>}\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback\n   * @returns {Promise<any>}\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    let transactionStarted = false\n    let savePointStarted = false\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql\n   * @returns {Promise<QueryResultType>}\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query\n   * @returns {string}\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error\n   * @returns {boolean}\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return false\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {void}\n   */\n  _assertWritableQuery(sql) {\n    if (!this.isReadOnly()) return\n    if (!this._sqlLooksLikeWrite(sql)) return\n\n    throw new Error(\"Database is read-only\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {boolean}\n   */\n  _sqlLooksLikeWrite(sql) {\n    const normalized = sql.trim().toLowerCase()\n\n    if (!normalized) return false\n\n    if (\n      normalized.startsWith(\"select\") ||\n      normalized.startsWith(\"show\") ||\n      normalized.startsWith(\"pragma\") ||\n      normalized.startsWith(\"explain\") ||\n      normalized.startsWith(\"describe\")\n    ) {\n      return false\n    }\n\n    if (normalized.startsWith(\"with\")) {\n      const withMatch = normalized.match(/^\\s*with[\\s\\S]+?\\)\\s*(select|insert|update|delete|merge|replace)\\b/)\n\n      if (withMatch) {\n        return withMatch[1] !== \"select\"\n      }\n\n      return false\n    }\n\n    const keywordMatch = normalized.match(/^\\s*(\\w+)/)\n    const keyword = keywordMatch ? keywordMatch[1] : \"\"\n\n    return [\n      \"insert\",\n      \"update\",\n      \"delete\",\n      \"create\",\n      \"alter\",\n      \"drop\",\n      \"truncate\",\n      \"merge\",\n      \"replace\"\n    ].includes(keyword)\n  }\n\n  /** @returns {boolean} */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string}\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} oldColumnName\n   * @param {string} newColumnName\n   * @returns {Promise<void>}\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName\n   * @returns {Promise<void>}\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async truncateAllTables() {\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args\n   * @returns {Promise<void>}\n   */\n  async update(args) {\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args\n   * @returns {string}\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>}\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback\n   * @returns {Promise<any>}\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n}\n"]}
@@ -141,6 +141,8 @@ declare class VelociousDatabaseRecord {
141
141
  * @returns {import("../drivers/base-column.js").default[]}
142
142
  */
143
143
  static getColumns(): import("../drivers/base-column.js").default[];
144
+ /** @returns {Record<string, import("../drivers/base-column.js").default>} */
145
+ static getColumnsHash(): Record<string, import("../drivers/base-column.js").default>;
144
146
  /**
145
147
  * @param {string} name
146
148
  * @returns {string | undefined}
@@ -471,6 +473,11 @@ declare class VelociousDatabaseRecord {
471
473
  * @returns {Record<string, any>}
472
474
  */
473
475
  attributes(): Record<string, any>;
476
+ /**
477
+ * Returns column-name keyed data (original attributes from database plus changes)
478
+ * @returns {Record<string, any>}
479
+ */
480
+ rawAttributes(): Record<string, any>;
474
481
  /**
475
482
  * @returns {import("../drivers/base.js").default}
476
483
  */
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/record/index.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/record/index.js"],"names":[],"mappings":"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"}
@@ -552,6 +552,17 @@ class VelociousDatabaseRecord {
552
552
  throw new Error(`${this.name} hasn't been initialized yet`);
553
553
  return this._columns;
554
554
  }
555
+ /** @returns {Record<string, import("../drivers/base-column.js").default>} */
556
+ static getColumnsHash() {
557
+ if (!this._columnsAsHash) {
558
+ /** @type {Record<string, import("../drivers/base-column.js").default>} */
559
+ this._columnsAsHash = {};
560
+ for (const column of this.getColumns()) {
561
+ this._columnsAsHash[column.getName()] = column;
562
+ }
563
+ }
564
+ return this._columnsAsHash;
565
+ }
555
566
  /**
556
567
  * @param {string} name
557
568
  * @returns {string | undefined}
@@ -1171,6 +1182,20 @@ class VelociousDatabaseRecord {
1171
1182
  * @returns {Record<string, any>}
1172
1183
  */
1173
1184
  attributes() {
1185
+ const data = this.rawAttributes();
1186
+ const columnNameToAttributeName = this.getModelClass().getColumnNameToAttributeNameMap();
1187
+ const attributes = {};
1188
+ for (const columnName in data) {
1189
+ const attributeName = columnNameToAttributeName[columnName] || columnName;
1190
+ attributes[attributeName] = this.readAttribute(attributeName);
1191
+ }
1192
+ return attributes;
1193
+ }
1194
+ /**
1195
+ * Returns column-name keyed data (original attributes from database plus changes)
1196
+ * @returns {Record<string, any>}
1197
+ */
1198
+ rawAttributes() {
1174
1199
  return Object.assign({}, this._attributes, this._changes);
1175
1200
  }
1176
1201
  /**
@@ -1300,7 +1325,7 @@ class VelociousDatabaseRecord {
1300
1325
  * @param {string} attributeName The name of the column to read. This is the column name, not the attribute name.
1301
1326
  */
1302
1327
  readColumn(attributeName) {
1303
- const column = this.getModelClass().getColumns().find((column) => column.getName() == attributeName);
1328
+ const column = this.getModelClass().getColumnsHash()[attributeName];
1304
1329
  let result;
1305
1330
  if (attributeName in this._changes) {
1306
1331
  result = this._changes[attributeName];
@@ -1346,7 +1371,7 @@ class VelociousDatabaseRecord {
1346
1371
  }
1347
1372
  const createdAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == "created_at");
1348
1373
  const updatedAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == "updated_at");
1349
- const data = Object.assign({}, this._belongsToChanges(), this.attributes());
1374
+ const data = Object.assign({}, this._belongsToChanges(), this.rawAttributes());
1350
1375
  const primaryKey = this.getModelClass().primaryKey();
1351
1376
  const primaryKeyColumn = this.getModelClass().getColumns().find((column) => column.getName() == primaryKey);
1352
1377
  const primaryKeyType = primaryKeyColumn?.getType()?.toLowerCase();
@@ -1448,7 +1473,7 @@ class VelociousDatabaseRecord {
1448
1473
  const reloadedModel = await query.first();
1449
1474
  if (!reloadedModel)
1450
1475
  throw new Error(`${this.constructor.name}#${id} couldn't be reloaded - record didn't exist`);
1451
- this._attributes = reloadedModel.attributes();
1476
+ this._attributes = reloadedModel.rawAttributes();
1452
1477
  this._changes = {};
1453
1478
  }
1454
1479
  /**
@@ -1513,4 +1538,4 @@ VelociousDatabaseRecord.registerValidatorType("presence", ValidatorsPresence);
1513
1538
  VelociousDatabaseRecord.registerValidatorType("uniqueness", ValidatorsUniqueness);
1514
1539
  export { ValidationError };
1515
1540
  export default VelociousDatabaseRecord;
1516
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/record/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{type: string, message: string}} ValidationErrorObjectType\n */\n\nimport BelongsToInstanceRelationship from \"./instance-relationships/belongs-to.js\"\nimport BelongsToRelationship from \"./relationships/belongs-to.js\"\nimport Configuration from \"../../configuration.js\"\nimport FromTable from \"../query/from-table.js\"\nimport Handler from \"../handler.js\"\nimport HasManyInstanceRelationship from \"./instance-relationships/has-many.js\"\nimport HasManyRelationship from \"./relationships/has-many.js\"\nimport HasOneInstanceRelationship from \"./instance-relationships/has-one.js\"\nimport HasOneRelationship from \"./relationships/has-one.js\"\nimport * as inflection from \"inflection\"\nimport ModelClassQuery from \"../query/model-class-query.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport singularizeModelName from \"../../utils/singularize-model-name.js\"\nimport ValidatorsPresence from \"./validators/presence.js\"\nimport ValidatorsUniqueness from \"./validators/uniqueness.js\"\nimport UUID from \"pure-uuid\"\n\nclass ValidationError extends Error {\n  /**\n   * @returns {VelociousDatabaseRecord}\n   */\n  getModel() {\n    if (!this._model) throw new Error(\"Model hasn't been set\")\n\n    return this._model\n  }\n\n  /**\n   * @param {VelociousDatabaseRecord} model\n   * @returns {void}\n   */\n  setModel(model) {\n    this._model = model\n  }\n\n  /** @returns {Record<string, ValidationErrorObjectType[]>} */\n  getValidationErrors() {\n    if (!this._validationErrors) throw new Error(\"Validation errors hasn't been set\")\n\n    return this._validationErrors\n  }\n\n  /** @param {Record<string, ValidationErrorObjectType[]>} validationErrors */\n  setValidationErrors(validationErrors) {\n    this._validationErrors = validationErrors\n  }\n}\n\nclass VelociousDatabaseRecord {\n  static getAttributeNameToColumnNameMap() {\n    if (!this._attributeNameToColumnName) {\n      /** @type {Record<string, string>} */\n      this._attributeNameToColumnName = {}\n    }\n\n    return this._attributeNameToColumnName\n  }\n\n  static getColumnNameToAttributeNameMap() {\n    if (!this._columnNameToAttributeName) {\n      /** @type {Record<string, string>} */\n      this._columnNameToAttributeName = {}\n    }\n\n    return this._columnNameToAttributeName\n  }\n\n  static getTranslationsMap() {\n    if (!this._translations) {\n      /** @type {Record<string, object>} */\n      this._translations = {}\n    }\n\n    return this._translations\n  }\n\n  static getValidatorsMap() {\n    if (!this._validators) {\n      /** @type {Record<string, import(\"./validators/base.js\").default[]>} */\n      this._validators = {}\n    }\n\n    return this._validators\n  }\n\n  static getValidatorTypesMap() {\n    if (!this._validatorTypes) {\n      /** @type {Record<string, typeof import(\"./validators/base.js\").default>} */\n      this._validatorTypes = {}\n    }\n\n    return this._validatorTypes\n  }\n\n  /** @type {Record<string, any>} */\n  _attributes = {}\n\n  /** @type {Record<string, any>} */\n  _changes = {}\n\n  /** @type {Record<string, import(\"../drivers/base-column.js\").default>} */\n  _columnsAsHash = {}\n\n  /** @type {import(\"../drivers/base.js\").default | undefined} */\n  __connection = undefined\n\n  /** @type {Record<string, import(\"./instance-relationships/base.js\").default>} */\n  _instanceRelationships = {}\n\n  /** @type {string | undefined} */\n  __tableName = undefined\n\n  /** @type {Record<string, ValidationErrorObjectType[]>} */\n  _validationErrors = {}\n\n  static validatorTypes() {\n    return this.getValidatorTypesMap()\n  }\n\n  /**\n   * @param {string} name\n   * @param {typeof import(\"./validators/base.js\").default} validatorClass\n   */\n  static registerValidatorType(name, validatorClass) {\n    this.validatorTypes()[name] = validatorClass\n  }\n\n  /**\n   * @param {string} validatorName\n   * @returns {typeof import(\"./validators/base.js\").default}\n   */\n  static getValidatorType(validatorName) {\n    if (!(validatorName in this.validatorTypes())) throw new Error(`Validator type ${validatorName} not found`)\n\n    return this.validatorTypes()[validatorName]\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {boolean}\n   */\n  static _relationshipExists(relationshipName) {\n    if (relationshipName in this.getRelationshipsMap()) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @typedef {object} RelationshipDataArgumentType\n   * @property {string} [className]\n   * @property {typeof VelociousDatabaseRecord} [klass]\n   * @property {string} [type]\n   */\n  /**\n   * @param {string} relationshipName\n   * @param {RelationshipDataArgumentType} data\n   */\n  static _defineRelationship(relationshipName, data) {\n    if (!relationshipName) throw new Error(`Invalid relationship name given: ${relationshipName}`)\n    if (this._relationshipExists(relationshipName)) throw new Error(`Relationship ${relationshipName} already exists`)\n\n    const actualData = Object.assign(\n      {\n        modelClass: this,\n        relationshipName,\n        type: \"hasMany\"\n      },\n      data\n    )\n\n    if (!actualData.className && !actualData.klass) {\n      actualData.className = singularizeModelName(relationshipName)\n    }\n\n    let relationship\n\n    if (actualData.type == \"belongsTo\") {\n      relationship = new BelongsToRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        const relationship = this.getRelationshipByName(relationshipName)\n\n        return relationship.loaded()\n      }\n\n      this.prototype[`build${inflection.camelize(relationshipName)}`] = function(attributes) {\n        const instanceRelationship = this.getRelationshipByName(relationshipName)\n        const record = instanceRelationship.build(attributes)\n        const inverseOf = instanceRelationship.getRelationship().getInverseOf()\n\n        if (inverseOf) {\n          const inverseInstanceRelationship = record.getRelationshipByName(inverseOf)\n\n          inverseInstanceRelationship.setAutoSave(false)\n\n          if (inverseInstanceRelationship.getType() == \"hasOne\") {\n            inverseInstanceRelationship.setLoaded(this)\n          } else if (inverseInstanceRelationship.getType() == \"hasMany\") {\n            inverseInstanceRelationship.addToLoaded(this)\n          } else {\n            throw new Error(`Unknown relationship type: ${inverseInstanceRelationship.getType()}`)\n          }\n        }\n\n        return record\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n\n      this.prototype[`set${inflection.camelize(relationshipName)}`] = function(model) {\n        const relationship = this.getRelationshipByName(relationshipName)\n\n        relationship.setLoaded(model)\n        relationship.setDirty(true)\n      }\n    } else if (actualData.type == \"hasMany\") {\n      relationship = new HasManyRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        return /** @type {import(\"./instance-relationships/has-many.js\").default} */ (this.getRelationshipByName(relationshipName))\n      }\n\n      this.prototype[`${relationshipName}Loaded`] = function() {\n        return this.getRelationshipByName(relationshipName).loaded()\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n    } else if (actualData.type == \"hasOne\") {\n      relationship = new HasOneRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        return this.getRelationshipByName(relationshipName).loaded()\n      }\n\n      this.prototype[`build${inflection.camelize(relationshipName)}`] = function(attributes) {\n        const instanceRelationship = this.getRelationshipByName(relationshipName)\n        const record = instanceRelationship.build(attributes)\n        const inverseOf = instanceRelationship.getRelationship().getInverseOf()\n\n        if (inverseOf) {\n          const inverseInstanceRelationship = record.getRelationshipByName(inverseOf)\n\n          inverseInstanceRelationship.setAutoSave(false)\n          inverseInstanceRelationship.setLoaded(this)\n        }\n\n        return record\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n    } else {\n      throw new Error(`Unknown relationship type: ${actualData.type}`)\n    }\n\n    this.getRelationshipsMap()[relationshipName] = relationship\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {import(\"./relationships/base.js\").default}\n   */\n  static getRelationshipByName(relationshipName) {\n    const relationship = this.getRelationshipsMap()[relationshipName]\n\n    if (!relationship) throw new Error(`No relationship in ${this.name} called \"${relationshipName}\" in list: ${Object.keys(this.getRelationshipsMap()).join(\", \")}`)\n\n    return relationship\n  }\n\n  /**\n   * @returns {Array<import(\"./relationships/base.js\").default>}\n   */\n  static getRelationships() {\n    return Object.values(this.getRelationshipsMap())\n  }\n\n  static getRelationshipsMap() {\n    if (!this._relationships) {\n      /** @type {Record<string, import(\"./relationships/base.js\").default>} */\n      this._relationships = {}\n    }\n\n    return this._relationships\n  }\n\n  /**\n   * @returns {Array<string>}\n   */\n  static getRelationshipNames() {\n    return this.getRelationships().map((relationship) => relationship.getRelationshipName())\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {import(\"./instance-relationships/base.js\").default}\n   */\n  getRelationshipByName(relationshipName) {\n    if (!(relationshipName in this._instanceRelationships)) {\n      const modelClassRelationship = this.getModelClass().getRelationshipByName(relationshipName)\n      const relationshipType = modelClassRelationship.getType()\n      let instanceRelationship\n\n      if (relationshipType == \"belongsTo\") {\n        instanceRelationship = new BelongsToInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else if (relationshipType == \"hasMany\") {\n        instanceRelationship = new HasManyInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else if (relationshipType == \"hasOne\") {\n        instanceRelationship = new HasOneInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else {\n        throw new Error(`Unknown relationship type: ${relationshipType}`)\n      }\n\n      this._instanceRelationships[relationshipName] = instanceRelationship\n    }\n\n    return this._instanceRelationships[relationshipName]\n  }\n\n  /**\n   * Adds a belongs-to-relationship to the model.\n   * @param {string} relationshipName The name of the relationship.\n   * @param {object} [options] The options for the relationship.\n   */\n  static belongsTo(relationshipName, options) {\n    this._defineRelationship(relationshipName, Object.assign({type: \"belongsTo\"}, options))\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  static connection() {\n    const databasePool = this._getConfiguration().getDatabasePool(this.getDatabaseIdentifier())\n    const connection = databasePool.getCurrentConnection()\n\n    if (!connection) throw new Error(\"No connection?\")\n\n    return connection\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {Record<string, any>} [attributes]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async create(attributes) {\n    const record = /** @type {InstanceType<MC>} */ (new this(attributes))\n\n    await record.save()\n\n    return record\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  static _getConfiguration() {\n    if (!this._configuration) {\n      this._configuration = Configuration.current()\n\n      if (!this._configuration) {\n        throw new Error(\"Configuration hasn't been set (model class probably hasn't been initialized)\")\n      }\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  _getConfiguration() {\n    return this.getModelClass()._getConfiguration()\n  }\n\n  /**\n   * Adds a has-many-relationship to the model class.\n   * @param {string} relationshipName The name of the relationship (e.g. \"posts\")\n   * @param {object} options The options for the relationship (e.g. {className: \"Post\"})\n   * @returns {void}\n   */\n  static hasMany(relationshipName, options = {}) {\n    return this._defineRelationship(relationshipName, Object.assign({type: \"hasMany\"}, options))\n  }\n\n  /**\n   * Adds a has-one-relationship to the model class.\n   * @param {string} relationshipName The name of the relationship (e.g. \"post\")\n   * @param {object} options The options for the relationship (e.g. {className: \"Post\"})\n   * @returns {void}\n   */\n  static hasOne(relationshipName, options = {}) {\n    return this._defineRelationship(relationshipName, Object.assign({type: \"hasOne\"}, options))\n  }\n\n  /**\n   * @param {string} attributeName\n   * @returns {string}\n   */\n  static humanAttributeName(attributeName) {\n    const modelNameKey = inflection.underscore(this.constructor.name)\n\n    return this._getConfiguration().getTranslator()(`velocious.database.record.attributes.${modelNameKey}.${attributeName}`, {defaultValue: inflection.camelize(attributeName)})\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getDatabaseType() {\n    if (!this._databaseType) throw new Error(\"Database type hasn't been set\")\n\n    return this._databaseType\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @returns {Promise<void>}\n   */\n  static async initializeRecord({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(`No configuration given for ${this.name}`)\n\n    this._configuration = configuration\n    this._configuration.registerModelClass(this)\n    this._databaseType = this.connection().getType()\n\n    this._table = await this.connection().getTableByName(this.tableName())\n    this._columns = await this._getTable().getColumns()\n\n    /** @type {Record<string, import(\"../drivers/base-column.js\").default>} */\n    this._columnsAsHash = {}\n\n    const columnNameToAttributeName = this.getColumnNameToAttributeNameMap()\n    const attributeNameToColumnName = this.getAttributeNameToColumnNameMap()\n\n    for (const column of this._columns) {\n      this._columnsAsHash[column.getName()] = column\n\n      const camelizedColumnName = inflection.camelize(column.getName(), true)\n      const camelizedColumnNameBigFirst = inflection.camelize(column.getName())\n\n      attributeNameToColumnName[camelizedColumnName] = column.getName()\n      columnNameToAttributeName[column.getName()] = camelizedColumnName\n\n      this.prototype[camelizedColumnName] = function() {\n        return this.readAttribute(camelizedColumnName)\n      }\n\n      this.prototype[`set${camelizedColumnNameBigFirst}`] = function(newValue) {\n        return this._setColumnAttribute(camelizedColumnName, newValue)\n      }\n\n      this.prototype[`has${camelizedColumnNameBigFirst}`] = function() {\n        let value = this[camelizedColumnName]()\n\n        return this._hasAttribute(value)\n      }\n    }\n\n    await this._defineTranslationMethods()\n    this._initialized = true\n  }\n\n  /**\n   * @param {any} value\n   * @returns {boolean}\n   */\n  _hasAttribute(value) {\n    if (typeof value == \"string\") {\n      value = value.trim()\n    }\n\n    if (value) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  static isInitialized() {\n    if (this._initialized) return true\n\n    return false\n  }\n\n  static async _defineTranslationMethods() {\n    if (this._translations) {\n      const locales = this._getConfiguration().getLocales()\n\n      if (!locales) throw new Error(\"Locales hasn't been set in the configuration\")\n\n      await this.getTranslationClass().initializeRecord({configuration: this._getConfiguration()})\n\n      for (const name in this._translations) {\n        const nameCamelized = inflection.camelize(name)\n        const setterMethodName = `set${nameCamelized}`\n\n        this.prototype[name] = function getTranslatedAttribute() {\n          const locale = this._getConfiguration().getLocale()\n\n          return this._getTranslatedAttributeWithFallback(name, locale)\n        }\n\n        this.prototype[`has${nameCamelized}`] = function hasTranslatedAttribute() {\n          const candidate = this[name]\n\n          if (typeof candidate == \"function\") {\n            const value = candidate.bind(this)()\n\n            return this._hasAttribute(value)\n          } else {\n            throw new Error(`Expected candidate to be a function but it was: ${typeof candidate}`)\n          }\n        }\n\n        this.prototype[setterMethodName] = function setTranslatedAttribute(newValue) {\n          const locale = this._getConfiguration().getLocale()\n\n          return this._setTranslatedAttribute(name, locale, newValue)\n        }\n\n        for (const locale of locales) {\n          const localeCamelized = inflection.camelize(locale)\n          const getterMethodNameLocalized = `${name}${localeCamelized}`\n          const setterMethodNameLocalized = `${setterMethodName}${localeCamelized}`\n          const hasMethodNameLocalized = `has${inflection.camelize(name)}${localeCamelized}`\n\n          this.prototype[getterMethodNameLocalized] = function getTranslatedAttributeWithLocale() {\n            return this._getTranslatedAttribute(name, locale)\n          }\n\n          this.prototype[setterMethodNameLocalized] = function setTranslatedAttributeWithLocale(newValue) {\n            return this._setTranslatedAttribute(name, locale, newValue)\n          }\n\n          this.prototype[hasMethodNameLocalized] = function hasTranslatedAttribute() {\n            const candidate = this[getterMethodNameLocalized]\n\n            if (typeof candidate == \"function\") {\n              const value = candidate.bind(this)()\n\n              return this._hasAttribute(value)\n            } else {\n              throw new Error(`Expected candidate to be a function but it was: ${typeof candidate}`)\n            }\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getDatabaseIdentifier() {\n    return this._databaseIdentifier || \"default\"\n  }\n\n  /**\n   * @param {string} databaseIdentifier\n   * @returns {void}\n   */\n  static setDatabaseIdentifier(databaseIdentifier) {\n    this._databaseIdentifier = databaseIdentifier\n  }\n\n  /**\n   * @param {string} name\n   * @returns {*}\n   */\n  getAttribute(name) {\n    const columnName = inflection.underscore(name)\n\n    if (!this.isNewRecord() && !(columnName in this._attributes)) {\n      throw new Error(`${this.constructor.name}#${name} attribute hasn't been loaded yet in ${Object.keys(this._attributes).join(\", \")}`)\n    }\n\n    return this._attributes[columnName]\n  }\n\n  /**\n   * @abstract\n   * @returns {typeof VelociousDatabaseRecord}\n   */\n  getModelClass() {\n    const modelClass = /** @type {typeof VelociousDatabaseRecord} */ (this.constructor)\n\n    return modelClass\n  }\n\n  /**\n   * @param {string} name\n   * @param {*} newValue\n   * @returns {void}\n   */\n  setAttribute(name, newValue) {\n    const setterName = `set${inflection.camelize(name)}`\n\n    if (!this.getModelClass().isInitialized()) throw new Error(`${this.constructor.name} model isn't initialized yet`)\n    if (!(setterName in this)) throw new Error(`No such setter method: ${this.constructor.name}#${setterName}`)\n\n    this[setterName](newValue)\n  }\n\n  /**\n   * @param {string} name\n   * @param {any} newValue\n   */\n  _setColumnAttribute(name, newValue) {\n    if (!this.getModelClass()._attributeNameToColumnName) throw new Error(\"No attribute-to-column mapping. Has record been initialized?\")\n\n    const columnName = this.getModelClass().getAttributeNameToColumnNameMap()[name]\n\n    if (!columnName) throw new Error(`Couldn't figure out column name for attribute: ${name}`)\n\n    let normalizedValue = newValue\n    const columnType = this.getModelClass().getColumnTypeByName(columnName)\n\n    if (columnType && this.getModelClass()._isDateLikeType(columnType)) {\n      normalizedValue = this._normalizeDateValue(newValue)\n    }\n\n    if (this._attributes[columnName] != normalizedValue) {\n      this._changes[columnName] = normalizedValue\n    }\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any}\n   */\n  _normalizeDateValue(value) {\n    if (typeof value != \"string\") return value\n\n    const isoDateTimeRegex = /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d{1,3})?(?:Z|[+-]\\d{2}:\\d{2})$/\n\n    if (!isoDateTimeRegex.test(value)) return value\n\n    const timestamp = Date.parse(value)\n\n    if (Number.isNaN(timestamp)) return value\n\n    return new Date(timestamp)\n  }\n\n  /**\n   * @returns {import(\"../drivers/base-column.js\").default[]}\n   */\n  static getColumns() {\n    if (!this._columns) throw new Error(`${this.name} hasn't been initialized yet`)\n\n    return this._columns\n  }\n\n  /**\n   * @param {string} name\n   * @returns {string | undefined}\n   */\n  static getColumnTypeByName(name) {\n    if (!this._columnTypeByName) {\n      this._columnTypeByName = {}\n\n      for (const column of this.getColumns()) {\n        this._columnTypeByName[column.getName()] = column.getType()\n      }\n    }\n\n    return this._columnTypeByName[name]\n  }\n\n  /**\n   * @param {string} type\n   * @returns {boolean}\n   */\n  static _isDateLikeType(type) {\n    const normalizedType = type.toLowerCase()\n\n    return normalizedType == \"date\" ||\n      normalizedType == \"datetime\" ||\n      normalizedType == \"timestamp\" ||\n      normalizedType == \"timestamptz\" ||\n      normalizedType.startsWith(\"timestamp \")\n  }\n\n  /**\n   * @returns {Array<string>}\n   */\n  static getColumnNames() {\n    if (!this._columnNames) {\n      this._columnNames = this.getColumns().map((column) => column.getName())\n    }\n\n    return this._columnNames\n  }\n\n  /**\n   * @returns {import(\"../drivers/base-table.js\").default}\n   */\n  static _getTable() {\n    if (!this._table) throw new Error(`${this.name} hasn't been initialized yet`)\n\n    return this._table\n  }\n\n  /**\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>}\n   */\n  static async insertMultiple(columns, rows) {\n    return await this.connection().insertMultiple(this.tableName(), columns, rows)\n  }\n\n  /**\n   * @returns {Promise<number>}\n   */\n  static async nextPrimaryKey() {\n    const primaryKey = this.primaryKey()\n    const tableName = this.tableName()\n    const connection = this.connection()\n    const newestRecord = await this.order(`${connection.quoteTable(tableName)}.${connection.quoteColumn(primaryKey)}`).last()\n\n    if (newestRecord) {\n      const id = newestRecord.id()\n\n      if (typeof id == \"number\") {\n        return id + 1\n      } else {\n        throw new Error(\"ID from newest record wasn't a number\")\n      }\n    } else {\n      return 1\n    }\n  }\n\n  /**\n   * @param {string} primaryKey\n   * @returns {void}\n   */\n  static setPrimaryKey(primaryKey) {\n    this._primaryKey = primaryKey\n  }\n\n  /**\n   * @returns {string}\n   */\n  static primaryKey() {\n    if (this._primaryKey) return this._primaryKey\n\n    return \"id\"\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async save() {\n    const isNewRecord = this.isNewRecord()\n    let result\n\n    await this._getConfiguration().ensureConnections(async () => {\n      await this._runValidations()\n\n      await this.getModelClass().transaction(async () => {\n        // If any belongs-to-relationships was saved, then updated-at should still be set on this record.\n        const {savedCount} = await this._autoSaveBelongsToRelationships()\n\n        if (this.isPersisted()) {\n          // If any has-many-relationships will be saved, then updated-at should still be set on this record.\n          const autoSaveHasManyrelationships = this._autoSaveHasManyAndHasOneRelationshipsToSave()\n\n          if (this._hasChanges() || savedCount > 0 || autoSaveHasManyrelationships.length > 0) {\n            result = await this._updateRecordWithChanges()\n          }\n        } else {\n          result = await this._createNewRecord()\n        }\n\n        await this._autoSaveHasManyAndHasOneRelationships({isNewRecord})\n      })\n    })\n\n    return result\n  }\n\n  async _autoSaveBelongsToRelationships() {\n    let savedCount = 0\n\n    for (const relationshipName in this._instanceRelationships) {\n      const instanceRelationship = this._instanceRelationships[relationshipName]\n\n      if (instanceRelationship.getType() != \"belongsTo\") {\n        continue\n      }\n\n      if (instanceRelationship.getAutoSave() === false) {\n        continue\n      }\n\n      const model = instanceRelationship.loaded()\n\n      if (model) {\n        if (model instanceof VelociousDatabaseRecord) {\n          if (model.isChanged()) {\n            await model.save()\n\n            const foreignKey = instanceRelationship.getForeignKey()\n\n            this.setAttribute(foreignKey, model.id())\n\n            instanceRelationship.setPreloaded(true)\n            instanceRelationship.setDirty(false)\n\n            savedCount++\n          }\n        } else {\n          throw new Error(`Expected a record but got: ${typeof model}`)\n        }\n      }\n    }\n\n    return {savedCount}\n  }\n\n  _autoSaveHasManyAndHasOneRelationshipsToSave() {\n    const relationships = []\n\n    for (const relationshipName in this._instanceRelationships) {\n      const instanceRelationship = this._instanceRelationships[relationshipName]\n\n      if (instanceRelationship.getType() != \"hasMany\" && instanceRelationship.getType() != \"hasOne\") {\n        continue\n      }\n\n      if (instanceRelationship.getAutoSave() === false) {\n        continue\n      }\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let loaded\n\n      const hasManyOrOneLoaded = instanceRelationship.getLoadedOrUndefined()\n\n      if (hasManyOrOneLoaded) {\n        if (Array.isArray(hasManyOrOneLoaded)) {\n          loaded = hasManyOrOneLoaded\n        } else if (hasManyOrOneLoaded instanceof VelociousDatabaseRecord) {\n          loaded = [hasManyOrOneLoaded]\n        } else {\n          throw new Error(`Expected hasOneLoaded to be a record but it wasn't: ${typeof hasManyOrOneLoaded}`)\n        }\n      } else {\n        continue\n      }\n\n      let useRelationship = false\n\n      if (loaded) {\n        for (const model of loaded) {\n          const foreignKey = instanceRelationship.getForeignKey()\n\n          model.setAttribute(foreignKey, this.id())\n\n          if (model.isChanged()) {\n            useRelationship = true\n            continue\n          }\n        }\n      }\n\n      if (useRelationship) relationships.push(instanceRelationship)\n    }\n\n    return relationships\n  }\n\n  /**\n   * @param {object} args\n   * @param {boolean} args.isNewRecord\n   */\n  async _autoSaveHasManyAndHasOneRelationships({isNewRecord}) {\n    for (const instanceRelationship of this._autoSaveHasManyAndHasOneRelationshipsToSave()) {\n      let hasManyOrOneLoaded = instanceRelationship.getLoadedOrUndefined()\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let loaded\n\n      if (hasManyOrOneLoaded === undefined) {\n        loaded = []\n      } else if (hasManyOrOneLoaded instanceof VelociousDatabaseRecord) {\n        loaded = [hasManyOrOneLoaded]\n      } else if (Array.isArray(hasManyOrOneLoaded)) {\n        loaded = hasManyOrOneLoaded\n      } else {\n        throw new Error(`Unexpected type for hasManyOrOneLoaded: ${typeof hasManyOrOneLoaded}`)\n      }\n\n      for (const model of loaded) {\n        const foreignKey = instanceRelationship.getForeignKey()\n\n        model.setAttribute(foreignKey, this.id())\n\n        if (model.isChanged()) {\n          await model.save()\n        }\n      }\n\n      if (isNewRecord) {\n        instanceRelationship.setPreloaded(true)\n      }\n    }\n  }\n\n  /**\n   * @returns {string}\n   */\n  static tableName() {\n    if (!this._tableName) this._tableName = inflection.underscore(inflection.pluralize(this.name))\n\n    return this._tableName\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {void}\n   */\n  static setTableName(tableName) {\n    this._tableName = tableName\n  }\n\n  /**\n   * @param {function() : Promise<void>} callback\n   * @returns {Promise<*>}\n   */\n  static async transaction(callback) {\n    const useTransactions = this.connection().getArgs().record?.transactions\n\n    if (useTransactions !== false) {\n      return await this.connection().transaction(callback)\n    } else {\n      return await callback()\n    }\n  }\n\n  /**\n   * @param {...string} names\n   * @returns {void}\n   */\n  static translates(...names) {\n    const translations = this.getTranslationsMap()\n\n    for (const name of names) {\n      if (name in translations) throw new Error(`Translation already exists: ${name}`)\n\n      translations[name] = {}\n\n      if (!this._relationshipExists(\"translations\")) {\n        this._defineRelationship(\"translations\", {klass: this.getTranslationClass(), type: \"hasMany\"})\n      }\n    }\n  }\n\n  /**\n   * @returns {typeof VelociousDatabaseRecord}\n   */\n  static getTranslationClass() {\n    if (this._translationClass) return this._translationClass\n    if (this.tableName().endsWith(\"_translations\")) throw new Error(\"Trying to define a translations class for a translation class\")\n\n    const className = `${this.name}Translation`\n    const TranslationClass = class Translation extends VelociousDatabaseRecord {}\n    const belongsTo = singularizeModelName(inflection.camelize(this.tableName(), true))\n\n    Object.defineProperty(TranslationClass, \"name\", {value: className})\n    TranslationClass.setTableName(this.getTranslationsTableName())\n    TranslationClass.belongsTo(belongsTo)\n\n    this._translationClass = TranslationClass\n\n    return this._translationClass\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getTranslationsTableName() {\n    const tableNameParts = this.tableName().split(\"_\")\n\n    tableNameParts[tableNameParts.length - 1] = inflection.singularize(tableNameParts[tableNameParts.length - 1])\n\n    return `${tableNameParts.join(\"_\")}_translations`\n  }\n\n  /**\n   * @returns {Promise<boolean>}\n   */\n  static async hasTranslationsTable() {\n    try {\n      await this.connection().getTableByName(this.getTranslationsTableName())\n\n      return true\n    } catch {\n      return false\n    }\n  }\n\n  /**\n   * Adds a validation to an attribute.\n   * @param {string} attributeName The name of the attribute to validate.\n   * @param {Record<string, boolean | Record<string, any>>} validators The validators to add. Key is the validator name, value is the validator arguments.\n   */\n  static async validates(attributeName, validators) {\n    for (const validatorName in validators) {\n      /** @type {Record<string, any>} */\n      let validatorArgs\n\n      /** @type {boolean} */\n      let useValidator = true\n\n      const validatorArgsCandidate = validators[validatorName]\n\n      if (typeof validatorArgsCandidate == \"boolean\") {\n        validatorArgs = {}\n        useValidator\n\n        if (!validatorArgsCandidate) {\n          useValidator = false\n        }\n      } else {\n        validatorArgs = validatorArgsCandidate\n      }\n\n      if (!useValidator) {\n        continue\n      }\n\n      const ValidatorClass = this.getValidatorType(validatorName)\n      const validator = new ValidatorClass({attributeName, args: validatorArgs})\n\n      if (!this._validators) this._validators = {}\n      if (!(attributeName in this._validators)) this._validators[attributeName] = []\n\n      this._validators[attributeName].push(validator)\n    }\n  }\n\n  /**\n   * @abstract\n   * @returns {TranslationBase[]}\n   */\n  translationsLoaded() {\n    throw new Error(\"'translationsLoaded' not implemented\")\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @returns {*}\n   */\n  _getTranslatedAttribute(name, locale) {\n    const translation = this.translationsLoaded().find((translation) => translation.locale() == locale)\n\n    if (translation) {\n      /** @type {Record<string, unknown>} */\n      // @ts-expect-error\n      const dict = translation\n\n      const attributeMethod = /** @type {function() : any | undefined} */ (dict[name])\n\n      if (typeof attributeMethod == \"function\") {\n        return attributeMethod.bind(translation)()\n      } else {\n        throw new Error(`No such translated method: ${name} (${typeof attributeMethod})`)\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @returns {*}\n   */\n  _getTranslatedAttributeWithFallback(name, locale) {\n    let localesInOrder\n    const fallbacks = this._getConfiguration().getLocaleFallbacks()\n\n    if (fallbacks && locale in fallbacks) {\n      localesInOrder = fallbacks[locale]\n    } else {\n      localesInOrder = [locale]\n    }\n\n    for (const fallbackLocale of localesInOrder) {\n      const result = this._getTranslatedAttribute(name, fallbackLocale)\n\n      if (result && result.trim() != \"\") {\n        return result\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @param {*} newValue\n   * @returns {void}\n   */\n  _setTranslatedAttribute(name, locale, newValue) {\n    /** @type {VelociousDatabaseRecord | TranslationBase | undefined} */\n    let translation\n\n    translation = this.translationsLoaded()?.find((translation) => translation.locale() == locale)\n\n    if (!translation) {\n      const instanceRelationship = this.getRelationshipByName(\"translations\")\n\n      translation = instanceRelationship.build({locale})\n    }\n\n    /** @type {Record<string, any>} */\n    const assignments = {}\n\n    assignments[name] = newValue\n\n    translation.assign(assignments)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {ModelClassQuery<MC>}\n   */\n  static _newQuery() {\n    const handler = new Handler()\n    const query = new ModelClassQuery({\n      driver: () => this.connection(),\n      handler,\n      modelClass: this\n    })\n\n    return query.from(new FromTable(this.tableName()))\n  }\n\n  /** @returns {string} */\n  static orderableColumn() {\n    // FIXME: Allow to change to 'created_at' if using UUID?\n\n    return this.primaryKey()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {ModelClassQuery<MC>}\n   */\n  static all() {\n    return this._newQuery()\n  }\n\n  /** @returns {Promise<number>} */\n  static async count() {\n    return await this._newQuery().count()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string} group\n   * @returns {ModelClassQuery<MC>}\n   */\n  static group(group) {\n    return this._newQuery().group(group)\n  }\n\n  static async destroyAll() {\n    return await this._newQuery().destroyAll()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {...string|string[]} columns\n   * @returns {Promise<any[]>}\n   */\n  static async pluck(...columns) {\n    return await this._newQuery().pluck(...columns)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {number|string} recordId\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async find(recordId) {\n    return await this._newQuery().find(recordId)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @returns {Promise<InstanceType<MC> | null>}\n   */\n  static async findBy(conditions) {\n    return await this._newQuery().findBy(conditions)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findByOrFail(conditions) {\n    return await this._newQuery().findByOrFail(conditions)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @param {function() : void} [callback]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findOrCreateBy(conditions, callback) {\n    return await this._newQuery().findOrCreateBy(conditions, callback)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {Record<string, any>} conditions\n   * @param {function(InstanceType<MC>) : void} [callback]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findOrInitializeBy(conditions, callback) {\n    return await this._newQuery().findOrInitializeBy(conditions, callback)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async first() {\n    return await this._newQuery().first()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string|{[key: string]: any}} join\n   * @returns {ModelClassQuery<MC>}\n   */\n  static joins(join) {\n    return this._newQuery().joins(join)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async last() {\n    return await this._newQuery().last()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {number} value\n   * @returns {ModelClassQuery<MC>}\n   */\n  static limit(value) {\n    return this._newQuery().limit(value)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string | number} order\n   * @returns {ModelClassQuery<MC>}\n   */\n  static order(order) {\n    return this._newQuery().order(order)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {boolean} [value]\n   * @returns {ModelClassQuery<MC>}\n   */\n  static distinct(value = true) {\n    return this._newQuery().distinct(value)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").NestedPreloadRecord} preload\n   */\n  static preload(preload) {\n    const query = /** @type {ModelClassQuery<MC>} */ (this._newQuery().preload(preload))\n\n    return query\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").SelectArgumentType} select\n   * @returns {ModelClassQuery<MC>}\n   */\n  static select(select) {\n    return this._newQuery().select(select)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>[]>}\n   */\n  static async toArray() {\n    return await this._newQuery().toArray()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").WhereArgumentType} where\n   * @returns {ModelClassQuery<MC>}\n   */\n  static where(where) {\n    return this._newQuery().where(where)\n  }\n\n  /**\n   * @param {Record<string, any>} changes\n   */\n  constructor(changes = {}) {\n    this._attributes = {}\n    this._changes = {}\n    this._isNewRecord = true\n\n    for (const key in changes) {\n      this.setAttribute(key, changes[key])\n    }\n  }\n\n  /**\n   * @param {object} attributes\n   * @returns {void}\n   */\n  loadExistingRecord(attributes) {\n    this._attributes = attributes\n    this._isNewRecord = false\n  }\n\n  /**\n   * Assigns the given attributes to the record.\n   * @param {Record<string, any>} attributesToAssign\n   * @returns {void}\n   */\n  assign(attributesToAssign) {\n    for (const attributeToAssign in attributesToAssign) {\n      this.setAttribute(attributeToAssign, attributesToAssign[attributeToAssign])\n    }\n  }\n\n  /**\n   * Returns a the current attributes of the record (original attributes from database plus changes)\n   * @returns {Record<string, any>}\n   */\n  attributes() {\n    return Object.assign({}, this._attributes, this._changes)\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  _connection() {\n    if (this.__connection) return this.__connection\n\n    return this.getModelClass().connection()\n  }\n\n  /**\n   * Destroys the record in the database and all of its dependent records.\n   * @returns {Promise<void>}\n   */\n  async destroy() {\n    for (const relationship of this.getModelClass().getRelationships()) {\n      if (relationship.getDependent() != \"destroy\") {\n        continue\n      }\n\n      const instanceRelationship = this.getRelationshipByName(relationship.getRelationshipName())\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let models\n\n      if (instanceRelationship.getType() == \"belongsTo\") {\n        if (!instanceRelationship.isLoaded()) {\n          await instanceRelationship.load()\n        }\n\n        const model = instanceRelationship.loaded()\n\n        if (model instanceof VelociousDatabaseRecord) {\n          models = [model]\n        } else {\n          throw new Error(`Unexpected loaded type: ${typeof model}`)\n        }\n      } else if (instanceRelationship.getType() == \"hasMany\") {\n        if (!instanceRelationship.isLoaded()) {\n          await instanceRelationship.load()\n        }\n\n        const loadedModels = instanceRelationship.loaded()\n\n        if (Array.isArray(loadedModels)) {\n          models = loadedModels\n        } else {\n          throw new Error(`Unexpected loaded type: ${typeof loadedModels}`)\n        }\n      } else {\n        throw new Error(`Unhandled relationship type: ${instanceRelationship.getType()}`)\n      }\n\n      for (const model of models) {\n        if (model.isPersisted()) {\n          await model.destroy()\n        }\n      }\n    }\n\n    /** @type {Record<string, any>} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = this.id()\n\n    const sql = this._connection().deleteSql({\n      conditions,\n      tableName: this._tableName()\n    })\n\n    await this._connection().query(sql)\n  }\n\n  /** @returns {boolean} */\n  _hasChanges() { return Object.keys(this._changes).length > 0 }\n\n  /**\n   * Returns true if the model has been changed since it was loaded from the database.\n   * @returns {boolean}\n   */\n  isChanged() {\n    if (this.isNewRecord() || this._hasChanges()){\n      return true\n    }\n\n    // Check if a loaded sub-model of a relationship is changed and should be saved along with this model.\n    if (this._instanceRelationships) {\n      for (const instanceRelationshipName in this._instanceRelationships) {\n        const instanceRelationship = this._instanceRelationships[instanceRelationshipName]\n        let loaded = instanceRelationship._loaded\n\n        if (instanceRelationship.getAutoSave() === false) {\n          continue\n        }\n\n        if (!loaded) continue\n        if (!Array.isArray(loaded)) loaded = [loaded]\n\n        for (const model of loaded) {\n          if (model.isChanged()) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  /** Returns the changes that have been made to this record since it was loaded from the database. */\n  changes() {\n    /** @type {Record<string, any[]>} */\n    const changes = {}\n\n    for (const changeKey in this._changes) {\n      const changeValue = this._changes[changeKey]\n\n      changes[changeKey] = [this._attributes[changeKey], changeValue]\n    }\n\n    return changes\n  }\n\n  /**\n   * @returns {string}\n   */\n  _tableName() {\n    if (this.__tableName) return this.__tableName\n\n    return this.getModelClass().tableName()\n  }\n\n  /**\n   * Reads an attribute value from the record.\n   * @param {string} attributeName The name of the attribute to read. This is the attribute name, not the column name.\n   * @returns {any}\n   */\n  readAttribute(attributeName) {\n    const columnName = this.getModelClass().getAttributeNameToColumnNameMap()[attributeName]\n\n    if (!columnName) throw new Error(`Couldn't figure out column name for attribute: ${attributeName} from these mappings: ${Object.keys(this.getModelClass().getAttributeNameToColumnNameMap()).join(\", \")}`)\n\n    return this.readColumn(columnName)\n  }\n\n  /**\n   * Reads a column value from the record.\n   * @param {string} attributeName The name of the column to read. This is the column name, not the attribute name.\n   */\n  readColumn(attributeName) {\n    const column = this.getModelClass().getColumns().find((column) => column.getName() == attributeName)\n    let result\n\n    if (attributeName in this._changes) {\n      result = this._changes[attributeName]\n    } else if (attributeName in this._attributes) {\n      result = this._attributes[attributeName]\n    } else if (this.isPersisted()) {\n      throw new Error(`No such attribute or not selected ${this.constructor.name}#${attributeName}`)\n    }\n\n    if (column && this.getModelClass().getDatabaseType() == \"sqlite\") {\n      if (result && (column.getType() == \"date\" || column.getType() == \"datetime\")) {\n        result = new Date(Date.parse(result))\n      }\n    }\n\n    return result\n  }\n\n  _belongsToChanges() {\n    /** @type {Record<string, any>} */\n    const belongsToChanges = {}\n\n    if (this._instanceRelationships) {\n      for (const relationshipName in this._instanceRelationships) {\n        const relationship = this._instanceRelationships[relationshipName]\n\n        if (relationship.getType() == \"belongsTo\" && relationship.getDirty()) {\n          const model = relationship.loaded()\n\n          if (model) {\n            if (model instanceof VelociousDatabaseRecord) {\n              belongsToChanges[relationship.getForeignKey()] = model?.id()\n            } else {\n              throw new Error(`Unexpected model type: ${typeof model}`)\n            }\n          }\n        }\n      }\n    }\n\n    return belongsToChanges\n  }\n\n  /** @returns {Promise<void>} */\n  async _createNewRecord() {\n    if (!this.getModelClass().connection()[\"insertSql\"]) {\n      throw new Error(`No insertSql on ${this.getModelClass().connection().constructor.name}`)\n    }\n\n    const createdAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"created_at\")\n    const updatedAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"updated_at\")\n    const data = Object.assign({}, this._belongsToChanges(), this.attributes())\n    const primaryKey = this.getModelClass().primaryKey()\n    const primaryKeyColumn = this.getModelClass().getColumns().find((column) => column.getName() == primaryKey)\n    const primaryKeyType = primaryKeyColumn?.getType()?.toLowerCase()\n    const driverSupportsDefaultUUID = typeof this._connection().supportsDefaultPrimaryKeyUUID == \"function\" && this._connection().supportsDefaultPrimaryKeyUUID()\n    const isUUIDPrimaryKey = primaryKeyType?.includes(\"uuid\")\n    const shouldAssignUUIDPrimaryKey = isUUIDPrimaryKey && !driverSupportsDefaultUUID\n    const currentDate = new Date()\n\n    if (createdAtColumn) data.created_at = currentDate\n    if (updatedAtColumn) data.updated_at = currentDate\n\n    const columnNames = this.getModelClass().getColumnNames()\n    const hasUserProvidedPrimaryKey = data[primaryKey] !== undefined && data[primaryKey] !== null && data[primaryKey] !== \"\"\n\n    if (shouldAssignUUIDPrimaryKey && !hasUserProvidedPrimaryKey) {\n      data[primaryKey] = new UUID(4).format()\n    }\n\n    const sql = this._connection().insertSql({\n      returnLastInsertedColumnNames: columnNames,\n      tableName: this._tableName(),\n      data\n    })\n    const insertResult = await this._connection().query(sql)\n\n    if (Array.isArray(insertResult) && insertResult[0] && insertResult[0][primaryKey]) {\n      this._attributes = insertResult[0]\n      this._changes = {}\n    } else if (primaryKeyType == \"uuid\" && data[primaryKey] !== undefined) {\n      this._attributes = Object.assign({}, data)\n      this._changes = {}\n    } else {\n      const id = await this._connection().lastInsertID()\n\n      await this._reloadWithId(id)\n    }\n\n    this.setIsNewRecord(false)\n\n    // Mark all relationships as preloaded, since we don't expect anything to have magically appeared since we created the record.\n    for (const relationship of this.getModelClass().getRelationships()) {\n      const instanceRelationship = this.getRelationshipByName(relationship.getRelationshipName())\n\n      if (instanceRelationship.getType() == \"hasMany\" && instanceRelationship.getLoadedOrUndefined() === null) {\n        instanceRelationship.setLoaded([])\n      }\n\n      instanceRelationship.setPreloaded(true)\n    }\n  }\n\n  /** @returns {Promise<void>} */\n  async _updateRecordWithChanges() {\n    /** @type {Record<string, any>} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = this.id()\n\n    const changes = Object.assign({}, this._belongsToChanges(), this._changes)\n    const updatedAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"updated_at\")\n    const currentDate = new Date()\n\n    if (updatedAtColumn) changes.updated_at = currentDate\n\n    if (Object.keys(changes).length > 0) {\n      const sql = this._connection().updateSql({\n        tableName: this._tableName(),\n        data: changes,\n        conditions\n      })\n      await this._connection().query(sql)\n      await this._reloadWithId(this.id())\n    }\n  }\n\n  /** @returns {number|string} */\n  id() {\n    if (!this.getModelClass()._columnNameToAttributeName) {\n      throw new Error(`Column names mapping hasn't been set on ${this.constructor.name}. Has the model been initialized?`)\n    }\n\n    const primaryKey = this.getModelClass().primaryKey()\n    const attributeName = this.getModelClass().getColumnNameToAttributeNameMap()[primaryKey]\n\n    if (attributeName === undefined) {\n      throw new Error(`Primary key ${primaryKey} doesn't exist in columns: ${Object.keys(this.getModelClass().getColumnNameToAttributeNameMap()).join(\", \")}`)\n    }\n\n    return this.readAttribute(attributeName)\n  }\n\n  /** @returns {boolean} */\n  isPersisted() { return !this._isNewRecord }\n\n  /** @returns {boolean} */\n  isNewRecord() { return this._isNewRecord }\n\n  /**\n   * @param {boolean} newIsNewRecord\n   * @returns {void}\n   */\n  setIsNewRecord(newIsNewRecord) {\n    this._isNewRecord = newIsNewRecord\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @param {string | number} id\n   * @returns {Promise<void>}\n   */\n  async _reloadWithId(id) {\n    const primaryKey = this.getModelClass().primaryKey()\n\n    /** @type {Record<string, any>} */\n    const whereObject = {}\n\n    whereObject[primaryKey] = id\n\n    const query = /** @type {import(\"../query/model-class-query.js\").default<MC>} */ (this.getModelClass().where(whereObject))\n    const reloadedModel = await query.first()\n\n    if (!reloadedModel) throw new Error(`${this.constructor.name}#${id} couldn't be reloaded - record didn't exist`)\n\n    this._attributes = reloadedModel.attributes()\n    this._changes = {}\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reload() {\n    await this._reloadWithId(this.readAttribute(\"id\"))\n  }\n\n  async _runValidations() {\n    /** @type {Record<string, {type: string, message: string}>} */\n    this._validationErrors = {}\n\n    const validators = this.getModelClass()._validators\n\n    if (validators) {\n      for (const attributeName in validators) {\n        const attributeValidators = validators[attributeName]\n\n        for (const validator of attributeValidators) {\n          await validator.validate({model: this, attributeName})\n        }\n      }\n    }\n\n    if (Object.keys(this._validationErrors).length > 0) {\n      const validationError = new ValidationError(this.fullErrorMessages().join(\". \"))\n\n      validationError.setValidationErrors(this._validationErrors)\n      validationError.setModel(this)\n\n      throw validationError\n    }\n  }\n\n  /** @returns {string[]} */\n  fullErrorMessages() {\n    /** @type {string[]} */\n    const validationErrorMessages = []\n\n    if (this._validationErrors) {\n      for (const attributeName in this._validationErrors) {\n        for (const validationError of this._validationErrors[attributeName]) {\n          const message = `${this.getModelClass().humanAttributeName(attributeName)} ${validationError.message}`\n\n          validationErrorMessages.push(message)\n        }\n      }\n    }\n\n    return validationErrorMessages\n  }\n\n  /**\n   * Assigns the attributes to the record and saves it.\n   * @param {object} attributesToAssign - The attributes to assign to the record.\n   */\n  async update(attributesToAssign) {\n    if (attributesToAssign) this.assign(attributesToAssign)\n\n    await this.save()\n  }\n}\n\nclass TranslationBase extends VelociousDatabaseRecord {\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  locale() {\n    throw new Error(\"'locale' not implemented\")\n  }\n}\n\nVelociousDatabaseRecord.registerValidatorType(\"presence\", ValidatorsPresence)\nVelociousDatabaseRecord.registerValidatorType(\"uniqueness\", ValidatorsUniqueness)\n\nexport {ValidationError}\nexport default VelociousDatabaseRecord\n"]}
1541
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/record/index.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ;;GAEG;AAEH,OAAO,6BAA6B,MAAM,wCAAwC,CAAA;AAClF,OAAO,qBAAqB,MAAM,+BAA+B,CAAA;AACjE,OAAO,aAAa,MAAM,wBAAwB,CAAA;AAClD,OAAO,SAAS,MAAM,wBAAwB,CAAA;AAC9C,OAAO,OAAO,MAAM,eAAe,CAAA;AACnC,OAAO,2BAA2B,MAAM,sCAAsC,CAAA;AAC9E,OAAO,mBAAmB,MAAM,6BAA6B,CAAA;AAC7D,OAAO,0BAA0B,MAAM,qCAAqC,CAAA;AAC5E,OAAO,kBAAkB,MAAM,4BAA4B,CAAA;AAC3D,OAAO,KAAK,UAAU,MAAM,YAAY,CAAA;AACxC,OAAO,eAAe,MAAM,+BAA+B,CAAA;AAC3D,OAAO,aAAa,MAAM,gCAAgC,CAAA;AAC1D,OAAO,oBAAoB,MAAM,uCAAuC,CAAA;AACxE,OAAO,kBAAkB,MAAM,0BAA0B,CAAA;AACzD,OAAO,oBAAoB,MAAM,4BAA4B,CAAA;AAC7D,OAAO,IAAI,MAAM,WAAW,CAAA;AAE5B,MAAM,eAAgB,SAAQ,KAAK;IACjC;;OAEG;IACH,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAE1D,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,KAAK;QACZ,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;IACrB,CAAC;IAED,6DAA6D;IAC7D,mBAAmB;QACjB,IAAI,CAAC,IAAI,CAAC,iBAAiB;YAAE,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;QAEjF,OAAO,IAAI,CAAC,iBAAiB,CAAA;IAC/B,CAAC;IAED,4EAA4E;IAC5E,mBAAmB,CAAC,gBAAgB;QAClC,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAA;IAC3C,CAAC;CACF;AAED,MAAM,uBAAuB;IAC3B,MAAM,CAAC,+BAA+B;QACpC,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE,CAAC;YACrC,qCAAqC;YACrC,IAAI,CAAC,0BAA0B,GAAG,EAAE,CAAA;QACtC,CAAC;QAED,OAAO,IAAI,CAAC,0BAA0B,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,+BAA+B;QACpC,IAAI,CAAC,IAAI,CAAC,0BAA0B,EAAE,CAAC;YACrC,qCAAqC;YACrC,IAAI,CAAC,0BAA0B,GAAG,EAAE,CAAA;QACtC,CAAC;QAED,OAAO,IAAI,CAAC,0BAA0B,CAAA;IACxC,CAAC;IAED,MAAM,CAAC,kBAAkB;QACvB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,qCAAqC;YACrC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAA;QACzB,CAAC;QAED,OAAO,IAAI,CAAC,aAAa,CAAA;IAC3B,CAAC;IAED,MAAM,CAAC,gBAAgB;QACrB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,uEAAuE;YACvE,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;QACvB,CAAC;QAED,OAAO,IAAI,CAAC,WAAW,CAAA;IACzB,CAAC;IAED,MAAM,CAAC,oBAAoB;QACzB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YAC1B,4EAA4E;YAC5E,IAAI,CAAC,eAAe,GAAG,EAAE,CAAA;QAC3B,CAAC;QAED,OAAO,IAAI,CAAC,eAAe,CAAA;IAC7B,CAAC;IAED,kCAAkC;IAClC,WAAW,GAAG,EAAE,CAAA;IAEhB,kCAAkC;IAClC,QAAQ,GAAG,EAAE,CAAA;IAEb,0EAA0E;IAC1E,cAAc,GAAG,EAAE,CAAA;IAEnB,+DAA+D;IAC/D,YAAY,GAAG,SAAS,CAAA;IAExB,iFAAiF;IACjF,sBAAsB,GAAG,EAAE,CAAA;IAE3B,iCAAiC;IACjC,WAAW,GAAG,SAAS,CAAA;IAEvB,0DAA0D;IAC1D,iBAAiB,GAAG,EAAE,CAAA;IAEtB,MAAM,CAAC,cAAc;QACnB,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAA;IACpC,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,qBAAqB,CAAC,IAAI,EAAE,cAAc;QAC/C,IAAI,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,GAAG,cAAc,CAAA;IAC9C,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,gBAAgB,CAAC,aAAa;QACnC,IAAI,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,aAAa,YAAY,CAAC,CAAA;QAE3G,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,aAAa,CAAC,CAAA;IAC7C,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,mBAAmB,CAAC,gBAAgB;QACzC,IAAI,gBAAgB,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC;YACnD,OAAO,IAAI,CAAA;QACb,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;;;OAKG;IACH;;;OAGG;IACH,MAAM,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,IAAI;QAC/C,IAAI,CAAC,gBAAgB;YAAE,MAAM,IAAI,KAAK,CAAC,oCAAoC,gBAAgB,EAAE,CAAC,CAAA;QAC9F,IAAI,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,gBAAgB,iBAAiB,CAAC,CAAA;QAElH,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAC9B;YACE,UAAU,EAAE,IAAI;YAChB,gBAAgB;YAChB,IAAI,EAAE,SAAS;SAChB,EACD,IAAI,CACL,CAAA;QAED,IAAI,CAAC,UAAU,CAAC,SAAS,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YAC/C,UAAU,CAAC,SAAS,GAAG,oBAAoB,CAAC,gBAAgB,CAAC,CAAA;QAC/D,CAAC;QAED,IAAI,YAAY,CAAA;QAEhB,IAAI,UAAU,CAAC,IAAI,IAAI,WAAW,EAAE,CAAC;YACnC,YAAY,GAAG,IAAI,qBAAqB,CAAC,UAAU,CAAC,CAAA;YAEpD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,GAAG;gBACjC,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;gBAEjE,OAAO,YAAY,CAAC,MAAM,EAAE,CAAA;YAC9B,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,QAAQ,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,UAAS,UAAU;gBACnF,MAAM,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;gBACzE,MAAM,MAAM,GAAG,oBAAoB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;gBACrD,MAAM,SAAS,GAAG,oBAAoB,CAAC,eAAe,EAAE,CAAC,YAAY,EAAE,CAAA;gBAEvE,IAAI,SAAS,EAAE,CAAC;oBACd,MAAM,2BAA2B,GAAG,MAAM,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAA;oBAE3E,2BAA2B,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;oBAE9C,IAAI,2BAA2B,CAAC,OAAO,EAAE,IAAI,QAAQ,EAAE,CAAC;wBACtD,2BAA2B,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;oBAC7C,CAAC;yBAAM,IAAI,2BAA2B,CAAC,OAAO,EAAE,IAAI,SAAS,EAAE,CAAC;wBAC9D,2BAA2B,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;oBAC/C,CAAC;yBAAM,CAAC;wBACN,MAAM,IAAI,KAAK,CAAC,8BAA8B,2BAA2B,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;oBACxF,CAAC;gBACH,CAAC;gBAED,OAAO,MAAM,CAAA;YACf,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,OAAO,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,KAAK;gBACpE,MAAM,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,IAAI,EAAE,CAAA;YAC3D,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,MAAM,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,UAAS,KAAK;gBAC5E,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;gBAEjE,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;gBAC7B,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YAC7B,CAAC,CAAA;QACH,CAAC;aAAM,IAAI,UAAU,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YACxC,YAAY,GAAG,IAAI,mBAAmB,CAAC,UAAU,CAAC,CAAA;YAElD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,GAAG;gBACjC,OAAO,qEAAqE,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,CAAA;YAC7H,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,GAAG,gBAAgB,QAAQ,CAAC,GAAG;gBAC5C,OAAO,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,MAAM,EAAE,CAAA;YAC9D,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,OAAO,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,KAAK;gBACpE,MAAM,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,IAAI,EAAE,CAAA;YAC3D,CAAC,CAAA;QACH,CAAC;aAAM,IAAI,UAAU,CAAC,IAAI,IAAI,QAAQ,EAAE,CAAC;YACvC,YAAY,GAAG,IAAI,kBAAkB,CAAC,UAAU,CAAC,CAAA;YAEjD,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,GAAG;gBACjC,OAAO,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,MAAM,EAAE,CAAA;YAC9D,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,QAAQ,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,UAAS,UAAU;gBACnF,MAAM,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;gBACzE,MAAM,MAAM,GAAG,oBAAoB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;gBACrD,MAAM,SAAS,GAAG,oBAAoB,CAAC,eAAe,EAAE,CAAC,YAAY,EAAE,CAAA;gBAEvE,IAAI,SAAS,EAAE,CAAC;oBACd,MAAM,2BAA2B,GAAG,MAAM,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAA;oBAE3E,2BAA2B,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;oBAC9C,2BAA2B,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;gBAC7C,CAAC;gBAED,OAAO,MAAM,CAAA;YACf,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,OAAO,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,KAAK;gBACpE,MAAM,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,IAAI,EAAE,CAAA;YAC3D,CAAC,CAAA;QACH,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,8BAA8B,UAAU,CAAC,IAAI,EAAE,CAAC,CAAA;QAClE,CAAC;QAED,IAAI,CAAC,mBAAmB,EAAE,CAAC,gBAAgB,CAAC,GAAG,YAAY,CAAA;IAC7D,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,qBAAqB,CAAC,gBAAgB;QAC3C,MAAM,YAAY,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC,gBAAgB,CAAC,CAAA;QAEjE,IAAI,CAAC,YAAY;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,IAAI,CAAC,IAAI,YAAY,gBAAgB,cAAc,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAEjK,OAAO,YAAY,CAAA;IACrB,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,gBAAgB;QACrB,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAA;IAClD,CAAC;IAED,MAAM,CAAC,mBAAmB;QACxB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,wEAAwE;YACxE,IAAI,CAAC,cAAc,GAAG,EAAE,CAAA;QAC1B,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,oBAAoB;QACzB,OAAO,IAAI,CAAC,gBAAgB,EAAE,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,mBAAmB,EAAE,CAAC,CAAA;IAC1F,CAAC;IAED;;;OAGG;IACH,qBAAqB,CAAC,gBAAgB;QACpC,IAAI,CAAC,CAAC,gBAAgB,IAAI,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC;YACvD,MAAM,sBAAsB,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;YAC3F,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,OAAO,EAAE,CAAA;YACzD,IAAI,oBAAoB,CAAA;YAExB,IAAI,gBAAgB,IAAI,WAAW,EAAE,CAAC;gBACpC,oBAAoB,GAAG,IAAI,6BAA6B,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,sBAAsB,EAAC,CAAC,CAAA;YAC/G,CAAC;iBAAM,IAAI,gBAAgB,IAAI,SAAS,EAAE,CAAC;gBACzC,oBAAoB,GAAG,IAAI,2BAA2B,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,sBAAsB,EAAC,CAAC,CAAA;YAC7G,CAAC;iBAAM,IAAI,gBAAgB,IAAI,QAAQ,EAAE,CAAC;gBACxC,oBAAoB,GAAG,IAAI,0BAA0B,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,YAAY,EAAE,sBAAsB,EAAC,CAAC,CAAA;YAC5G,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,8BAA8B,gBAAgB,EAAE,CAAC,CAAA;YACnE,CAAC;YAED,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,GAAG,oBAAoB,CAAA;QACtE,CAAC;QAED,OAAO,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAA;IACtD,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,SAAS,CAAC,gBAAgB,EAAE,OAAO;QACxC,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,EAAC,IAAI,EAAE,WAAW,EAAC,EAAE,OAAO,CAAC,CAAC,CAAA;IACzF,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU;QACf,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAA;QAC3F,MAAM,UAAU,GAAG,YAAY,CAAC,oBAAoB,EAAE,CAAA;QAEtD,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAA;QAElD,OAAO,UAAU,CAAA;IACnB,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU;QAC5B,MAAM,MAAM,GAAG,+BAA+B,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAA;QAErE,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;QAEnB,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,iBAAiB;QACtB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC,OAAO,EAAE,CAAA;YAE7C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACzB,MAAM,IAAI,KAAK,CAAC,8EAA8E,CAAC,CAAA;YACjG,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,iBAAiB;QACf,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC,iBAAiB,EAAE,CAAA;IACjD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,OAAO,CAAC,gBAAgB,EAAE,OAAO,GAAG,EAAE;QAC3C,OAAO,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,EAAC,IAAI,EAAE,SAAS,EAAC,EAAE,OAAO,CAAC,CAAC,CAAA;IAC9F,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,OAAO,GAAG,EAAE;QAC1C,OAAO,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,MAAM,CAAC,MAAM,CAAC,EAAC,IAAI,EAAE,QAAQ,EAAC,EAAE,OAAO,CAAC,CAAC,CAAA;IAC7F,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,kBAAkB,CAAC,aAAa;QACrC,MAAM,YAAY,GAAG,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAEjE,OAAO,IAAI,CAAC,iBAAiB,EAAE,CAAC,aAAa,EAAE,CAAC,wCAAwC,YAAY,IAAI,aAAa,EAAE,EAAE,EAAC,YAAY,EAAE,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAC,CAAC,CAAA;IAC9K,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,eAAe;QACpB,IAAI,CAAC,IAAI,CAAC,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;QAEzE,OAAO,IAAI,CAAC,aAAa,CAAA;IAC3B,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAC,aAAa,EAAE,GAAG,QAAQ,EAAC;QACxD,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvB,IAAI,CAAC,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,8BAA8B,IAAI,CAAC,IAAI,EAAE,CAAC,CAAA;QAE9E,IAAI,CAAC,cAAc,GAAG,aAAa,CAAA;QACnC,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE,CAAA;QAEhD,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QACtE,IAAI,CAAC,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,UAAU,EAAE,CAAA;QAEnD,0EAA0E;QAC1E,IAAI,CAAC,cAAc,GAAG,EAAE,CAAA;QAExB,MAAM,yBAAyB,GAAG,IAAI,CAAC,+BAA+B,EAAE,CAAA;QACxE,MAAM,yBAAyB,GAAG,IAAI,CAAC,+BAA+B,EAAE,CAAA;QAExE,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,MAAM,CAAA;YAE9C,MAAM,mBAAmB,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,CAAA;YACvE,MAAM,2BAA2B,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAA;YAEzE,yBAAyB,CAAC,mBAAmB,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;YACjE,yBAAyB,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,mBAAmB,CAAA;YAEjE,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,GAAG;gBACpC,OAAO,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAA;YAChD,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,MAAM,2BAA2B,EAAE,CAAC,GAAG,UAAS,QAAQ;gBACrE,OAAO,IAAI,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,QAAQ,CAAC,CAAA;YAChE,CAAC,CAAA;YAED,IAAI,CAAC,SAAS,CAAC,MAAM,2BAA2B,EAAE,CAAC,GAAG;gBACpD,IAAI,KAAK,GAAG,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAA;gBAEvC,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;YAClC,CAAC,CAAA;QACH,CAAC;QAED,MAAM,IAAI,CAAC,yBAAyB,EAAE,CAAA;QACtC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;IAC1B,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,KAAK;QACjB,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,KAAK,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;QACtB,CAAC;QAED,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,IAAI,CAAA;QACb,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,aAAa;QAClB,IAAI,IAAI,CAAC,YAAY;YAAE,OAAO,IAAI,CAAA;QAElC,OAAO,KAAK,CAAA;IACd,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,yBAAyB;QACpC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,UAAU,EAAE,CAAA;YAErD,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAA;YAE7E,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC,gBAAgB,CAAC,EAAC,aAAa,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAC,CAAC,CAAA;YAE5F,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtC,MAAM,aAAa,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;gBAC/C,MAAM,gBAAgB,GAAG,MAAM,aAAa,EAAE,CAAA;gBAE9C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,SAAS,sBAAsB;oBACpD,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,SAAS,EAAE,CAAA;oBAEnD,OAAO,IAAI,CAAC,mCAAmC,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;gBAC/D,CAAC,CAAA;gBAED,IAAI,CAAC,SAAS,CAAC,MAAM,aAAa,EAAE,CAAC,GAAG,SAAS,sBAAsB;oBACrE,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAA;oBAE5B,IAAI,OAAO,SAAS,IAAI,UAAU,EAAE,CAAC;wBACnC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAA;wBAEpC,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;oBAClC,CAAC;yBAAM,CAAC;wBACN,MAAM,IAAI,KAAK,CAAC,mDAAmD,OAAO,SAAS,EAAE,CAAC,CAAA;oBACxF,CAAC;gBACH,CAAC,CAAA;gBAED,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC,GAAG,SAAS,sBAAsB,CAAC,QAAQ;oBACzE,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,SAAS,EAAE,CAAA;oBAEnD,OAAO,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAA;gBAC7D,CAAC,CAAA;gBAED,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;oBAC7B,MAAM,eAAe,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;oBACnD,MAAM,yBAAyB,GAAG,GAAG,IAAI,GAAG,eAAe,EAAE,CAAA;oBAC7D,MAAM,yBAAyB,GAAG,GAAG,gBAAgB,GAAG,eAAe,EAAE,CAAA;oBACzE,MAAM,sBAAsB,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,eAAe,EAAE,CAAA;oBAElF,IAAI,CAAC,SAAS,CAAC,yBAAyB,CAAC,GAAG,SAAS,gCAAgC;wBACnF,OAAO,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;oBACnD,CAAC,CAAA;oBAED,IAAI,CAAC,SAAS,CAAC,yBAAyB,CAAC,GAAG,SAAS,gCAAgC,CAAC,QAAQ;wBAC5F,OAAO,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAA;oBAC7D,CAAC,CAAA;oBAED,IAAI,CAAC,SAAS,CAAC,sBAAsB,CAAC,GAAG,SAAS,sBAAsB;wBACtE,MAAM,SAAS,GAAG,IAAI,CAAC,yBAAyB,CAAC,CAAA;wBAEjD,IAAI,OAAO,SAAS,IAAI,UAAU,EAAE,CAAC;4BACnC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAA;4BAEpC,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;wBAClC,CAAC;6BAAM,CAAC;4BACN,MAAM,IAAI,KAAK,CAAC,mDAAmD,OAAO,SAAS,EAAE,CAAC,CAAA;wBACxF,CAAC;oBACH,CAAC,CAAA;gBACH,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,qBAAqB;QAC1B,OAAO,IAAI,CAAC,mBAAmB,IAAI,SAAS,CAAA;IAC9C,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,qBAAqB,CAAC,kBAAkB;QAC7C,IAAI,CAAC,mBAAmB,GAAG,kBAAkB,CAAA;IAC/C,CAAC;IAED;;;OAGG;IACH,YAAY,CAAC,IAAI;QACf,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QAE9C,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;YAC7D,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,IAAI,wCAAwC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACrI,CAAC;QAED,OAAO,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAA;IACrC,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,MAAM,UAAU,GAAG,6CAA6C,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QAEnF,OAAO,UAAU,CAAA;IACnB,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAC,IAAI,EAAE,QAAQ;QACzB,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAA;QAEpD,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,aAAa,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,8BAA8B,CAAC,CAAA;QAClH,IAAI,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,UAAU,EAAE,CAAC,CAAA;QAE3G,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAA;IAC5B,CAAC;IAED;;;OAGG;IACH,mBAAmB,CAAC,IAAI,EAAE,QAAQ;QAChC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,0BAA0B;YAAE,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAA;QAErI,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAC,IAAI,CAAC,CAAA;QAE/E,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,kDAAkD,IAAI,EAAE,CAAC,CAAA;QAE1F,IAAI,eAAe,GAAG,QAAQ,CAAA;QAC9B,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAA;QAEvE,IAAI,UAAU,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,eAAe,CAAC,UAAU,CAAC,EAAE,CAAC;YACnE,eAAe,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAA;QACtD,CAAC;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,eAAe,EAAE,CAAC;YACpD,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,eAAe,CAAA;QAC7C,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,mBAAmB,CAAC,KAAK;QACvB,IAAI,OAAO,KAAK,IAAI,QAAQ;YAAE,OAAO,KAAK,CAAA;QAE1C,MAAM,gBAAgB,GAAG,0EAA0E,CAAA;QAEnG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC;YAAE,OAAO,KAAK,CAAA;QAE/C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QAEnC,IAAI,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC;YAAE,OAAO,KAAK,CAAA;QAEzC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU;QACf,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,8BAA8B,CAAC,CAAA;QAE/E,OAAO,IAAI,CAAC,QAAQ,CAAA;IACtB,CAAC;IAED,6EAA6E;IAC7E,MAAM,CAAC,cAAc;QACnB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,0EAA0E;YAC1E,IAAI,CAAC,cAAc,GAAG,EAAE,CAAA;YAExB,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;gBACvC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,MAAM,CAAA;YAChD,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAA;IAC5B,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,mBAAmB,CAAC,IAAI;QAC7B,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC5B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAA;YAE3B,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;gBACvC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,CAAA;YAC7D,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,eAAe,CAAC,IAAI;QACzB,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,EAAE,CAAA;QAEzC,OAAO,cAAc,IAAI,MAAM;YAC7B,cAAc,IAAI,UAAU;YAC5B,cAAc,IAAI,WAAW;YAC7B,cAAc,IAAI,aAAa;YAC/B,cAAc,CAAC,UAAU,CAAC,YAAY,CAAC,CAAA;IAC3C,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,cAAc;QACnB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAA;QACzE,CAAC;QAED,OAAO,IAAI,CAAC,YAAY,CAAA;IAC1B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,SAAS;QACd,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,8BAA8B,CAAC,CAAA;QAE7E,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,EAAE,IAAI;QACvC,OAAO,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;IAChF,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,KAAK,CAAC,cAAc;QACzB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QACpC,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAClC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QACpC,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAA;QAEzH,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,EAAE,GAAG,YAAY,CAAC,EAAE,EAAE,CAAA;YAE5B,IAAI,OAAO,EAAE,IAAI,QAAQ,EAAE,CAAC;gBAC1B,OAAO,EAAE,GAAG,CAAC,CAAA;YACf,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAA;YAC1D,CAAC;QACH,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,CAAA;QACV,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,aAAa,CAAC,UAAU;QAC7B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAA;IAC/B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU;QACf,IAAI,IAAI,CAAC,WAAW;YAAE,OAAO,IAAI,CAAC,WAAW,CAAA;QAE7C,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,IAAI;QACR,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,EAAE,CAAA;QACtC,IAAI,MAAM,CAAA;QAEV,MAAM,IAAI,CAAC,iBAAiB,EAAE,CAAC,iBAAiB,CAAC,KAAK,IAAI,EAAE;YAC1D,MAAM,IAAI,CAAC,eAAe,EAAE,CAAA;YAE5B,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE;gBAChD,iGAAiG;gBACjG,MAAM,EAAC,UAAU,EAAC,GAAG,MAAM,IAAI,CAAC,+BAA+B,EAAE,CAAA;gBAEjE,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;oBACvB,mGAAmG;oBACnG,MAAM,4BAA4B,GAAG,IAAI,CAAC,4CAA4C,EAAE,CAAA;oBAExF,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,UAAU,GAAG,CAAC,IAAI,4BAA4B,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;wBACpF,MAAM,GAAG,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAA;oBAChD,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,GAAG,MAAM,IAAI,CAAC,gBAAgB,EAAE,CAAA;gBACxC,CAAC;gBAED,MAAM,IAAI,CAAC,sCAAsC,CAAC,EAAC,WAAW,EAAC,CAAC,CAAA;YAClE,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QAEF,OAAO,MAAM,CAAA;IACf,CAAC;IAED,KAAK,CAAC,+BAA+B;QACnC,IAAI,UAAU,GAAG,CAAC,CAAA;QAElB,KAAK,MAAM,gBAAgB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC3D,MAAM,oBAAoB,GAAG,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAA;YAE1E,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,WAAW,EAAE,CAAC;gBAClD,SAAQ;YACV,CAAC;YAED,IAAI,oBAAoB,CAAC,WAAW,EAAE,KAAK,KAAK,EAAE,CAAC;gBACjD,SAAQ;YACV,CAAC;YAED,MAAM,KAAK,GAAG,oBAAoB,CAAC,MAAM,EAAE,CAAA;YAE3C,IAAI,KAAK,EAAE,CAAC;gBACV,IAAI,KAAK,YAAY,uBAAuB,EAAE,CAAC;oBAC7C,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;wBACtB,MAAM,KAAK,CAAC,IAAI,EAAE,CAAA;wBAElB,MAAM,UAAU,GAAG,oBAAoB,CAAC,aAAa,EAAE,CAAA;wBAEvD,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAA;wBAEzC,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;wBACvC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;wBAEpC,UAAU,EAAE,CAAA;oBACd,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,8BAA8B,OAAO,KAAK,EAAE,CAAC,CAAA;gBAC/D,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,EAAC,UAAU,EAAC,CAAA;IACrB,CAAC;IAED,4CAA4C;QAC1C,MAAM,aAAa,GAAG,EAAE,CAAA;QAExB,KAAK,MAAM,gBAAgB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAC3D,MAAM,oBAAoB,GAAG,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAA;YAE1E,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,SAAS,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,QAAQ,EAAE,CAAC;gBAC9F,SAAQ;YACV,CAAC;YAED,IAAI,oBAAoB,CAAC,WAAW,EAAE,KAAK,KAAK,EAAE,CAAC;gBACjD,SAAQ;YACV,CAAC;YAED,wCAAwC;YACxC,IAAI,MAAM,CAAA;YAEV,MAAM,kBAAkB,GAAG,oBAAoB,CAAC,oBAAoB,EAAE,CAAA;YAEtE,IAAI,kBAAkB,EAAE,CAAC;gBACvB,IAAI,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,CAAC;oBACtC,MAAM,GAAG,kBAAkB,CAAA;gBAC7B,CAAC;qBAAM,IAAI,kBAAkB,YAAY,uBAAuB,EAAE,CAAC;oBACjE,MAAM,GAAG,CAAC,kBAAkB,CAAC,CAAA;gBAC/B,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,uDAAuD,OAAO,kBAAkB,EAAE,CAAC,CAAA;gBACrG,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,SAAQ;YACV,CAAC;YAED,IAAI,eAAe,GAAG,KAAK,CAAA;YAE3B,IAAI,MAAM,EAAE,CAAC;gBACX,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,MAAM,UAAU,GAAG,oBAAoB,CAAC,aAAa,EAAE,CAAA;oBAEvD,KAAK,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;oBAEzC,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;wBACtB,eAAe,GAAG,IAAI,CAAA;wBACtB,SAAQ;oBACV,CAAC;gBACH,CAAC;YACH,CAAC;YAED,IAAI,eAAe;gBAAE,aAAa,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAA;QAC/D,CAAC;QAED,OAAO,aAAa,CAAA;IACtB,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,sCAAsC,CAAC,EAAC,WAAW,EAAC;QACxD,KAAK,MAAM,oBAAoB,IAAI,IAAI,CAAC,4CAA4C,EAAE,EAAE,CAAC;YACvF,IAAI,kBAAkB,GAAG,oBAAoB,CAAC,oBAAoB,EAAE,CAAA;YAEpE,wCAAwC;YACxC,IAAI,MAAM,CAAA;YAEV,IAAI,kBAAkB,KAAK,SAAS,EAAE,CAAC;gBACrC,MAAM,GAAG,EAAE,CAAA;YACb,CAAC;iBAAM,IAAI,kBAAkB,YAAY,uBAAuB,EAAE,CAAC;gBACjE,MAAM,GAAG,CAAC,kBAAkB,CAAC,CAAA;YAC/B,CAAC;iBAAM,IAAI,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,CAAC;gBAC7C,MAAM,GAAG,kBAAkB,CAAA;YAC7B,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,2CAA2C,OAAO,kBAAkB,EAAE,CAAC,CAAA;YACzF,CAAC;YAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC3B,MAAM,UAAU,GAAG,oBAAoB,CAAC,aAAa,EAAE,CAAA;gBAEvD,KAAK,CAAC,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;gBAEzC,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;oBACtB,MAAM,KAAK,CAAC,IAAI,EAAE,CAAA;gBACpB,CAAC;YACH,CAAC;YAED,IAAI,WAAW,EAAE,CAAC;gBAChB,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,SAAS;QACd,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;QAE9F,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,YAAY,CAAC,SAAS;QAC3B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAA;IAC7B,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,QAAQ;QAC/B,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,YAAY,CAAA;QAExE,IAAI,eAAe,KAAK,KAAK,EAAE,CAAC;YAC9B,OAAO,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAA;QACtD,CAAC;aAAM,CAAC;YACN,OAAO,MAAM,QAAQ,EAAE,CAAA;QACzB,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,UAAU,CAAC,GAAG,KAAK;QACxB,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAE9C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,IAAI,YAAY;gBAAE,MAAM,IAAI,KAAK,CAAC,+BAA+B,IAAI,EAAE,CAAC,CAAA;YAEhF,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,CAAA;YAEvB,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC,EAAE,CAAC;gBAC9C,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,EAAC,KAAK,EAAE,IAAI,CAAC,mBAAmB,EAAE,EAAE,IAAI,EAAE,SAAS,EAAC,CAAC,CAAA;YAChG,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,mBAAmB;QACxB,IAAI,IAAI,CAAC,iBAAiB;YAAE,OAAO,IAAI,CAAC,iBAAiB,CAAA;QACzD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,+DAA+D,CAAC,CAAA;QAEhI,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,IAAI,aAAa,CAAA;QAC3C,MAAM,gBAAgB,GAAG,MAAM,WAAY,SAAQ,uBAAuB;SAAG,CAAA;QAC7E,MAAM,SAAS,GAAG,oBAAoB,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,IAAI,CAAC,CAAC,CAAA;QAEnF,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,MAAM,EAAE,EAAC,KAAK,EAAE,SAAS,EAAC,CAAC,CAAA;QACnE,gBAAgB,CAAC,YAAY,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,CAAA;QAC9D,gBAAgB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAA;QAErC,IAAI,CAAC,iBAAiB,GAAG,gBAAgB,CAAA;QAEzC,OAAO,IAAI,CAAC,iBAAiB,CAAA;IAC/B,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,wBAAwB;QAC7B,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAElD,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAA;QAE7G,OAAO,GAAG,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAA;IACnD,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,KAAK,CAAC,oBAAoB;QAC/B,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,CAAA;YAEvE,OAAO,IAAI,CAAA;QACb,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAA;QACd,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,aAAa,EAAE,UAAU;QAC9C,KAAK,MAAM,aAAa,IAAI,UAAU,EAAE,CAAC;YACvC,kCAAkC;YAClC,IAAI,aAAa,CAAA;YAEjB,sBAAsB;YACtB,IAAI,YAAY,GAAG,IAAI,CAAA;YAEvB,MAAM,sBAAsB,GAAG,UAAU,CAAC,aAAa,CAAC,CAAA;YAExD,IAAI,OAAO,sBAAsB,IAAI,SAAS,EAAE,CAAC;gBAC/C,aAAa,GAAG,EAAE,CAAA;gBAClB,YAAY,CAAA;gBAEZ,IAAI,CAAC,sBAAsB,EAAE,CAAC;oBAC5B,YAAY,GAAG,KAAK,CAAA;gBACtB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,aAAa,GAAG,sBAAsB,CAAA;YACxC,CAAC;YAED,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,SAAQ;YACV,CAAC;YAED,MAAM,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAA;YAC3D,MAAM,SAAS,GAAG,IAAI,cAAc,CAAC,EAAC,aAAa,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAA;YAE1E,IAAI,CAAC,IAAI,CAAC,WAAW;gBAAE,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;YAC5C,IAAI,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC;gBAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,GAAG,EAAE,CAAA;YAE9E,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACjD,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,kBAAkB;QAChB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAA;IACzD,CAAC;IAED;;;;OAIG;IACH,uBAAuB,CAAC,IAAI,EAAE,MAAM;QAClC,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,MAAM,CAAC,CAAA;QAEnG,IAAI,WAAW,EAAE,CAAC;YAChB,sCAAsC;YACtC,mBAAmB;YACnB,MAAM,IAAI,GAAG,WAAW,CAAA;YAExB,MAAM,eAAe,GAAG,2CAA2C,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YAEhF,IAAI,OAAO,eAAe,IAAI,UAAU,EAAE,CAAC;gBACzC,OAAO,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAA;YAC5C,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,8BAA8B,IAAI,KAAK,OAAO,eAAe,GAAG,CAAC,CAAA;YACnF,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,mCAAmC,CAAC,IAAI,EAAE,MAAM;QAC9C,IAAI,cAAc,CAAA;QAClB,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC,kBAAkB,EAAE,CAAA;QAE/D,IAAI,SAAS,IAAI,MAAM,IAAI,SAAS,EAAE,CAAC;YACrC,cAAc,GAAG,SAAS,CAAC,MAAM,CAAC,CAAA;QACpC,CAAC;aAAM,CAAC;YACN,cAAc,GAAG,CAAC,MAAM,CAAC,CAAA;QAC3B,CAAC;QAED,KAAK,MAAM,cAAc,IAAI,cAAc,EAAE,CAAC;YAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,cAAc,CAAC,CAAA;YAEjE,IAAI,MAAM,IAAI,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;gBAClC,OAAO,MAAM,CAAA;YACf,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ;QAC5C,oEAAoE;QACpE,IAAI,WAAW,CAAA;QAEf,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE,EAAE,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,MAAM,CAAC,CAAA;QAE9F,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAA;YAEvE,WAAW,GAAG,oBAAoB,CAAC,KAAK,CAAC,EAAC,MAAM,EAAC,CAAC,CAAA;QACpD,CAAC;QAED,kCAAkC;QAClC,MAAM,WAAW,GAAG,EAAE,CAAA;QAEtB,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAA;QAE5B,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;IACjC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,SAAS;QACd,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAA;QAC7B,MAAM,KAAK,GAAG,IAAI,eAAe,CAAC;YAChC,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE;YAC/B,OAAO;YACP,UAAU,EAAE,IAAI;SACjB,CAAC,CAAA;QAEF,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA;IACpD,CAAC;IAED,wBAAwB;IACxB,MAAM,CAAC,eAAe;QACpB,wDAAwD;QAExD,OAAO,IAAI,CAAC,UAAU,EAAE,CAAA;IAC1B,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,GAAG;QACR,OAAO,IAAI,CAAC,SAAS,EAAE,CAAA;IACzB,CAAC;IAED,iCAAiC;IACjC,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,CAAA;IACvC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACtC,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,UAAU;QACrB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,UAAU,EAAE,CAAA;IAC5C,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,OAAO;QAC3B,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC,CAAA;IACjD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ;QACxB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAC9C,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU;QAC5B,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;IAClD,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,UAAU;QAClC,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA;IACxD,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,EAAE,QAAQ;QAC9C,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,cAAc,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IACpE,CAAC;IAED;;;;;;OAMG;IACH,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAAC,UAAU,EAAE,QAAQ;QAClD,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,kBAAkB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;IACxE,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,CAAA;IACvC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,IAAI;QACf,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,IAAI;QACf,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,CAAA;IACtC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACtC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACtC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI;QAC1B,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;IACzC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,OAAO,CAAC,OAAO;QACpB,MAAM,KAAK,GAAG,kCAAkC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAA;QAEpF,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,MAAM;QAClB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACxC,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,KAAK,CAAC,OAAO;QAClB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAA;IACzC,CAAC;IAED;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK;QAChB,OAAO,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IACtC,CAAC;IAED;;OAEG;IACH,YAAY,OAAO,GAAG,EAAE;QACtB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAA;QACrB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QAClB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;QAExB,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;QACtC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,UAAU;QAC3B,IAAI,CAAC,WAAW,GAAG,UAAU,CAAA;QAC7B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAA;IAC3B,CAAC;IAED;;;;OAIG;IACH,MAAM,CAAC,kBAAkB;QACvB,KAAK,MAAM,iBAAiB,IAAI,kBAAkB,EAAE,CAAC;YACnD,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,kBAAkB,CAAC,iBAAiB,CAAC,CAAC,CAAA;QAC7E,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,UAAU;QACR,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;QACjC,MAAM,yBAAyB,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAA;QACxF,MAAM,UAAU,GAAG,EAAE,CAAA;QAErB,KAAK,MAAM,UAAU,IAAI,IAAI,EAAE,CAAC;YAC9B,MAAM,aAAa,GAAG,yBAAyB,CAAC,UAAU,CAAC,IAAI,UAAU,CAAA;YAEzE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAA;QAC/D,CAAC;QAED,OAAO,UAAU,CAAA;IACnB,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;IAC3D,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,YAAY;YAAE,OAAO,IAAI,CAAC,YAAY,CAAA;QAE/C,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAA;IAC1C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,OAAO;QACX,KAAK,MAAM,YAAY,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,gBAAgB,EAAE,EAAE,CAAC;YACnE,IAAI,YAAY,CAAC,YAAY,EAAE,IAAI,SAAS,EAAE,CAAC;gBAC7C,SAAQ;YACV,CAAC;YAED,MAAM,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,mBAAmB,EAAE,CAAC,CAAA;YAE3F,wCAAwC;YACxC,IAAI,MAAM,CAAA;YAEV,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,WAAW,EAAE,CAAC;gBAClD,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,EAAE,CAAC;oBACrC,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAA;gBACnC,CAAC;gBAED,MAAM,KAAK,GAAG,oBAAoB,CAAC,MAAM,EAAE,CAAA;gBAE3C,IAAI,KAAK,YAAY,uBAAuB,EAAE,CAAC;oBAC7C,MAAM,GAAG,CAAC,KAAK,CAAC,CAAA;gBAClB,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,2BAA2B,OAAO,KAAK,EAAE,CAAC,CAAA;gBAC5D,CAAC;YACH,CAAC;iBAAM,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,SAAS,EAAE,CAAC;gBACvD,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,EAAE,CAAC;oBACrC,MAAM,oBAAoB,CAAC,IAAI,EAAE,CAAA;gBACnC,CAAC;gBAED,MAAM,YAAY,GAAG,oBAAoB,CAAC,MAAM,EAAE,CAAA;gBAElD,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC;oBAChC,MAAM,GAAG,YAAY,CAAA;gBACvB,CAAC;qBAAM,CAAC;oBACN,MAAM,IAAI,KAAK,CAAC,2BAA2B,OAAO,YAAY,EAAE,CAAC,CAAA;gBACnE,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,gCAAgC,oBAAoB,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;YACnF,CAAC;YAED,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBAC3B,IAAI,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;oBACxB,MAAM,KAAK,CAAC,OAAO,EAAE,CAAA;gBACvB,CAAC;YACH,CAAC;QACH,CAAC;QAED,kCAAkC;QAClC,MAAM,UAAU,GAAG,EAAE,CAAA;QAErB,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;QAEzD,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC;YACvC,UAAU;YACV,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;SAC7B,CAAC,CAAA;QAEF,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACrC,CAAC;IAED,yBAAyB;IACzB,WAAW,KAAK,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAA,CAAC,CAAC;IAE9D;;;OAGG;IACH,SAAS;QACP,IAAI,IAAI,CAAC,WAAW,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE,EAAC,CAAC;YAC5C,OAAO,IAAI,CAAA;QACb,CAAC;QAED,sGAAsG;QACtG,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,KAAK,MAAM,wBAAwB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,sBAAsB,CAAC,wBAAwB,CAAC,CAAA;gBAClF,IAAI,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAA;gBAEzC,IAAI,oBAAoB,CAAC,WAAW,EAAE,KAAK,KAAK,EAAE,CAAC;oBACjD,SAAQ;gBACV,CAAC;gBAED,IAAI,CAAC,MAAM;oBAAE,SAAQ;gBACrB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;oBAAE,MAAM,GAAG,CAAC,MAAM,CAAC,CAAA;gBAE7C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;wBACtB,OAAO,IAAI,CAAA;oBACb,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED,oGAAoG;IACpG,OAAO;QACL,oCAAoC;QACpC,MAAM,OAAO,GAAG,EAAE,CAAA;QAElB,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACtC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAA;YAE5C,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,WAAW,CAAC,CAAA;QACjE,CAAC;QAED,OAAO,OAAO,CAAA;IAChB,CAAC;IAED;;OAEG;IACH,UAAU;QACR,IAAI,IAAI,CAAC,WAAW;YAAE,OAAO,IAAI,CAAC,WAAW,CAAA;QAE7C,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAA;IACzC,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,aAAa;QACzB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAC,aAAa,CAAC,CAAA;QAExF,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,kDAAkD,aAAa,yBAAyB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAE1M,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAA;IACpC,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,aAAa;QACtB,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,cAAc,EAAE,CAAC,aAAa,CAAC,CAAA;QACnE,IAAI,MAAM,CAAA;QAEV,IAAI,aAAa,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAA;QACvC,CAAC;aAAM,IAAI,aAAa,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YAC7C,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAA;QAC1C,CAAC;aAAM,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,qCAAqC,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,aAAa,EAAE,CAAC,CAAA;QAChG,CAAC;QAED,IAAI,MAAM,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,eAAe,EAAE,IAAI,QAAQ,EAAE,CAAC;YACjE,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,MAAM,IAAI,MAAM,CAAC,OAAO,EAAE,IAAI,UAAU,CAAC,EAAE,CAAC;gBAC7E,MAAM,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAA;YACvC,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED,iBAAiB;QACf,kCAAkC;QAClC,MAAM,gBAAgB,GAAG,EAAE,CAAA;QAE3B,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,KAAK,MAAM,gBAAgB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;gBAC3D,MAAM,YAAY,GAAG,IAAI,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAA;gBAElE,IAAI,YAAY,CAAC,OAAO,EAAE,IAAI,WAAW,IAAI,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC;oBACrE,MAAM,KAAK,GAAG,YAAY,CAAC,MAAM,EAAE,CAAA;oBAEnC,IAAI,KAAK,EAAE,CAAC;wBACV,IAAI,KAAK,YAAY,uBAAuB,EAAE,CAAC;4BAC7C,gBAAgB,CAAC,YAAY,CAAC,aAAa,EAAE,CAAC,GAAG,KAAK,EAAE,EAAE,EAAE,CAAA;wBAC9D,CAAC;6BAAM,CAAC;4BACN,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,KAAK,EAAE,CAAC,CAAA;wBAC3D,CAAC;oBACH,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,gBAAgB,CAAA;IACzB,CAAC;IAED,+BAA+B;IAC/B,KAAK,CAAC,gBAAgB;QACpB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC;YACpD,MAAM,IAAI,KAAK,CAAC,mBAAmB,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAA;QAC1F,CAAC;QAED,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,YAAY,CAAC,CAAA;QAC5G,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,YAAY,CAAC,CAAA;QAC5G,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAA;QAC9E,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAA;QACpD,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,UAAU,CAAC,CAAA;QAC3G,MAAM,cAAc,GAAG,gBAAgB,EAAE,OAAO,EAAE,EAAE,WAAW,EAAE,CAAA;QACjE,MAAM,yBAAyB,GAAG,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,6BAA6B,IAAI,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,6BAA6B,EAAE,CAAA;QAC7J,MAAM,gBAAgB,GAAG,cAAc,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAA;QACzD,MAAM,0BAA0B,GAAG,gBAAgB,IAAI,CAAC,yBAAyB,CAAA;QACjF,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAA;QAE9B,IAAI,eAAe;YAAE,IAAI,CAAC,UAAU,GAAG,WAAW,CAAA;QAClD,IAAI,eAAe;YAAE,IAAI,CAAC,UAAU,GAAG,WAAW,CAAA;QAElD,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,cAAc,EAAE,CAAA;QACzD,MAAM,yBAAyB,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAA;QAExH,IAAI,0BAA0B,IAAI,CAAC,yBAAyB,EAAE,CAAC;YAC7D,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAA;QACzC,CAAC;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC;YACvC,6BAA6B,EAAE,WAAW;YAC1C,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;YAC5B,IAAI;SACL,CAAC,CAAA;QACF,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAExD,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC;YAClF,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,CAAA;YAClC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QACpB,CAAC;aAAM,IAAI,cAAc,IAAI,MAAM,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,SAAS,EAAE,CAAC;YACtE,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,CAAA;YAC1C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;QACpB,CAAC;aAAM,CAAC;YACN,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,YAAY,EAAE,CAAA;YAElD,MAAM,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,CAAA;QAC9B,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;QAE1B,8HAA8H;QAC9H,KAAK,MAAM,YAAY,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,gBAAgB,EAAE,EAAE,CAAC;YACnE,MAAM,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,mBAAmB,EAAE,CAAC,CAAA;YAE3F,IAAI,oBAAoB,CAAC,OAAO,EAAE,IAAI,SAAS,IAAI,oBAAoB,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE,CAAC;gBACxG,oBAAoB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;YACpC,CAAC;YAED,oBAAoB,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;QACzC,CAAC;IACH,CAAC;IAED,+BAA+B;IAC/B,KAAK,CAAC,wBAAwB;QAC5B,kCAAkC;QAClC,MAAM,UAAU,GAAG,EAAE,CAAA;QAErB,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;QAEzD,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC1E,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,YAAY,CAAC,CAAA;QAC5G,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAA;QAE9B,IAAI,eAAe;YAAE,OAAO,CAAC,UAAU,GAAG,WAAW,CAAA;QAErD,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC;gBACvC,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;gBAC5B,IAAI,EAAE,OAAO;gBACb,UAAU;aACX,CAAC,CAAA;YACF,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;QACrC,CAAC;IACH,CAAC;IAED,+BAA+B;IAC/B,EAAE;QACA,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,0BAA0B,EAAE,CAAC;YACrD,MAAM,IAAI,KAAK,CAAC,2CAA2C,IAAI,CAAC,WAAW,CAAC,IAAI,mCAAmC,CAAC,CAAA;QACtH,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAA;QACpD,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAC,UAAU,CAAC,CAAA;QAExF,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,eAAe,UAAU,8BAA8B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,+BAA+B,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC1J,CAAC;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAA;IAC1C,CAAC;IAED,yBAAyB;IACzB,WAAW,KAAK,OAAO,CAAC,IAAI,CAAC,YAAY,CAAA,CAAC,CAAC;IAE3C,yBAAyB;IACzB,WAAW,KAAK,OAAO,IAAI,CAAC,YAAY,CAAA,CAAC,CAAC;IAE1C;;;OAGG;IACH,cAAc,CAAC,cAAc;QAC3B,IAAI,CAAC,YAAY,GAAG,cAAc,CAAA;IACpC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,aAAa,CAAC,EAAE;QACpB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAA;QAEpD,kCAAkC;QAClC,MAAM,WAAW,GAAG,EAAE,CAAA;QAEtB,WAAW,CAAC,UAAU,CAAC,GAAG,EAAE,CAAA;QAE5B,MAAM,KAAK,GAAG,kEAAkE,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAA;QAC1H,MAAM,aAAa,GAAG,MAAM,KAAK,CAAC,KAAK,EAAE,CAAA;QAEzC,IAAI,CAAC,aAAa;YAAE,MAAM,IAAI,KAAK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,EAAE,6CAA6C,CAAC,CAAA;QAEhH,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC,aAAa,EAAE,CAAA;QAChD,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,MAAM;QACV,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAA;IACpD,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,8DAA8D;QAC9D,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAA;QAE3B,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,WAAW,CAAA;QAEnD,IAAI,UAAU,EAAE,CAAC;YACf,KAAK,MAAM,aAAa,IAAI,UAAU,EAAE,CAAC;gBACvC,MAAM,mBAAmB,GAAG,UAAU,CAAC,aAAa,CAAC,CAAA;gBAErD,KAAK,MAAM,SAAS,IAAI,mBAAmB,EAAE,CAAC;oBAC5C,MAAM,SAAS,CAAC,QAAQ,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,aAAa,EAAC,CAAC,CAAA;gBACxD,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACnD,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAA;YAEhF,eAAe,CAAC,mBAAmB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;YAC3D,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;YAE9B,MAAM,eAAe,CAAA;QACvB,CAAC;IACH,CAAC;IAED,0BAA0B;IAC1B,iBAAiB;QACf,uBAAuB;QACvB,MAAM,uBAAuB,GAAG,EAAE,CAAA;QAElC,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,KAAK,MAAM,aAAa,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBACnD,KAAK,MAAM,eAAe,IAAI,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,EAAE,CAAC;oBACpE,MAAM,OAAO,GAAG,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,kBAAkB,CAAC,aAAa,CAAC,IAAI,eAAe,CAAC,OAAO,EAAE,CAAA;oBAEtG,uBAAuB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;gBACvC,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,uBAAuB,CAAA;IAChC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,kBAAkB;QAC7B,IAAI,kBAAkB;YAAE,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAA;QAEvD,MAAM,IAAI,CAAC,IAAI,EAAE,CAAA;IACnB,CAAC;CACF;AAED,MAAM,eAAgB,SAAQ,uBAAuB;IACnD;;;OAGG;IACH,MAAM;QACJ,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;IAC7C,CAAC;CACF;AAED,uBAAuB,CAAC,qBAAqB,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAA;AAC7E,uBAAuB,CAAC,qBAAqB,CAAC,YAAY,EAAE,oBAAoB,CAAC,CAAA;AAEjF,OAAO,EAAC,eAAe,EAAC,CAAA;AACxB,eAAe,uBAAuB,CAAA","sourcesContent":["// @ts-check\n\n/**\n * @typedef {{type: string, message: string}} ValidationErrorObjectType\n */\n\nimport BelongsToInstanceRelationship from \"./instance-relationships/belongs-to.js\"\nimport BelongsToRelationship from \"./relationships/belongs-to.js\"\nimport Configuration from \"../../configuration.js\"\nimport FromTable from \"../query/from-table.js\"\nimport Handler from \"../handler.js\"\nimport HasManyInstanceRelationship from \"./instance-relationships/has-many.js\"\nimport HasManyRelationship from \"./relationships/has-many.js\"\nimport HasOneInstanceRelationship from \"./instance-relationships/has-one.js\"\nimport HasOneRelationship from \"./relationships/has-one.js\"\nimport * as inflection from \"inflection\"\nimport ModelClassQuery from \"../query/model-class-query.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport singularizeModelName from \"../../utils/singularize-model-name.js\"\nimport ValidatorsPresence from \"./validators/presence.js\"\nimport ValidatorsUniqueness from \"./validators/uniqueness.js\"\nimport UUID from \"pure-uuid\"\n\nclass ValidationError extends Error {\n  /**\n   * @returns {VelociousDatabaseRecord}\n   */\n  getModel() {\n    if (!this._model) throw new Error(\"Model hasn't been set\")\n\n    return this._model\n  }\n\n  /**\n   * @param {VelociousDatabaseRecord} model\n   * @returns {void}\n   */\n  setModel(model) {\n    this._model = model\n  }\n\n  /** @returns {Record<string, ValidationErrorObjectType[]>} */\n  getValidationErrors() {\n    if (!this._validationErrors) throw new Error(\"Validation errors hasn't been set\")\n\n    return this._validationErrors\n  }\n\n  /** @param {Record<string, ValidationErrorObjectType[]>} validationErrors */\n  setValidationErrors(validationErrors) {\n    this._validationErrors = validationErrors\n  }\n}\n\nclass VelociousDatabaseRecord {\n  static getAttributeNameToColumnNameMap() {\n    if (!this._attributeNameToColumnName) {\n      /** @type {Record<string, string>} */\n      this._attributeNameToColumnName = {}\n    }\n\n    return this._attributeNameToColumnName\n  }\n\n  static getColumnNameToAttributeNameMap() {\n    if (!this._columnNameToAttributeName) {\n      /** @type {Record<string, string>} */\n      this._columnNameToAttributeName = {}\n    }\n\n    return this._columnNameToAttributeName\n  }\n\n  static getTranslationsMap() {\n    if (!this._translations) {\n      /** @type {Record<string, object>} */\n      this._translations = {}\n    }\n\n    return this._translations\n  }\n\n  static getValidatorsMap() {\n    if (!this._validators) {\n      /** @type {Record<string, import(\"./validators/base.js\").default[]>} */\n      this._validators = {}\n    }\n\n    return this._validators\n  }\n\n  static getValidatorTypesMap() {\n    if (!this._validatorTypes) {\n      /** @type {Record<string, typeof import(\"./validators/base.js\").default>} */\n      this._validatorTypes = {}\n    }\n\n    return this._validatorTypes\n  }\n\n  /** @type {Record<string, any>} */\n  _attributes = {}\n\n  /** @type {Record<string, any>} */\n  _changes = {}\n\n  /** @type {Record<string, import(\"../drivers/base-column.js\").default>} */\n  _columnsAsHash = {}\n\n  /** @type {import(\"../drivers/base.js\").default | undefined} */\n  __connection = undefined\n\n  /** @type {Record<string, import(\"./instance-relationships/base.js\").default>} */\n  _instanceRelationships = {}\n\n  /** @type {string | undefined} */\n  __tableName = undefined\n\n  /** @type {Record<string, ValidationErrorObjectType[]>} */\n  _validationErrors = {}\n\n  static validatorTypes() {\n    return this.getValidatorTypesMap()\n  }\n\n  /**\n   * @param {string} name\n   * @param {typeof import(\"./validators/base.js\").default} validatorClass\n   */\n  static registerValidatorType(name, validatorClass) {\n    this.validatorTypes()[name] = validatorClass\n  }\n\n  /**\n   * @param {string} validatorName\n   * @returns {typeof import(\"./validators/base.js\").default}\n   */\n  static getValidatorType(validatorName) {\n    if (!(validatorName in this.validatorTypes())) throw new Error(`Validator type ${validatorName} not found`)\n\n    return this.validatorTypes()[validatorName]\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {boolean}\n   */\n  static _relationshipExists(relationshipName) {\n    if (relationshipName in this.getRelationshipsMap()) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @typedef {object} RelationshipDataArgumentType\n   * @property {string} [className]\n   * @property {typeof VelociousDatabaseRecord} [klass]\n   * @property {string} [type]\n   */\n  /**\n   * @param {string} relationshipName\n   * @param {RelationshipDataArgumentType} data\n   */\n  static _defineRelationship(relationshipName, data) {\n    if (!relationshipName) throw new Error(`Invalid relationship name given: ${relationshipName}`)\n    if (this._relationshipExists(relationshipName)) throw new Error(`Relationship ${relationshipName} already exists`)\n\n    const actualData = Object.assign(\n      {\n        modelClass: this,\n        relationshipName,\n        type: \"hasMany\"\n      },\n      data\n    )\n\n    if (!actualData.className && !actualData.klass) {\n      actualData.className = singularizeModelName(relationshipName)\n    }\n\n    let relationship\n\n    if (actualData.type == \"belongsTo\") {\n      relationship = new BelongsToRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        const relationship = this.getRelationshipByName(relationshipName)\n\n        return relationship.loaded()\n      }\n\n      this.prototype[`build${inflection.camelize(relationshipName)}`] = function(attributes) {\n        const instanceRelationship = this.getRelationshipByName(relationshipName)\n        const record = instanceRelationship.build(attributes)\n        const inverseOf = instanceRelationship.getRelationship().getInverseOf()\n\n        if (inverseOf) {\n          const inverseInstanceRelationship = record.getRelationshipByName(inverseOf)\n\n          inverseInstanceRelationship.setAutoSave(false)\n\n          if (inverseInstanceRelationship.getType() == \"hasOne\") {\n            inverseInstanceRelationship.setLoaded(this)\n          } else if (inverseInstanceRelationship.getType() == \"hasMany\") {\n            inverseInstanceRelationship.addToLoaded(this)\n          } else {\n            throw new Error(`Unknown relationship type: ${inverseInstanceRelationship.getType()}`)\n          }\n        }\n\n        return record\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n\n      this.prototype[`set${inflection.camelize(relationshipName)}`] = function(model) {\n        const relationship = this.getRelationshipByName(relationshipName)\n\n        relationship.setLoaded(model)\n        relationship.setDirty(true)\n      }\n    } else if (actualData.type == \"hasMany\") {\n      relationship = new HasManyRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        return /** @type {import(\"./instance-relationships/has-many.js\").default} */ (this.getRelationshipByName(relationshipName))\n      }\n\n      this.prototype[`${relationshipName}Loaded`] = function() {\n        return this.getRelationshipByName(relationshipName).loaded()\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n    } else if (actualData.type == \"hasOne\") {\n      relationship = new HasOneRelationship(actualData)\n\n      this.prototype[relationshipName] = function() {\n        return this.getRelationshipByName(relationshipName).loaded()\n      }\n\n      this.prototype[`build${inflection.camelize(relationshipName)}`] = function(attributes) {\n        const instanceRelationship = this.getRelationshipByName(relationshipName)\n        const record = instanceRelationship.build(attributes)\n        const inverseOf = instanceRelationship.getRelationship().getInverseOf()\n\n        if (inverseOf) {\n          const inverseInstanceRelationship = record.getRelationshipByName(inverseOf)\n\n          inverseInstanceRelationship.setAutoSave(false)\n          inverseInstanceRelationship.setLoaded(this)\n        }\n\n        return record\n      }\n\n      this.prototype[`load${inflection.camelize(relationshipName)}`] = async function() {\n        await this.getRelationshipByName(relationshipName).load()\n      }\n    } else {\n      throw new Error(`Unknown relationship type: ${actualData.type}`)\n    }\n\n    this.getRelationshipsMap()[relationshipName] = relationship\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {import(\"./relationships/base.js\").default}\n   */\n  static getRelationshipByName(relationshipName) {\n    const relationship = this.getRelationshipsMap()[relationshipName]\n\n    if (!relationship) throw new Error(`No relationship in ${this.name} called \"${relationshipName}\" in list: ${Object.keys(this.getRelationshipsMap()).join(\", \")}`)\n\n    return relationship\n  }\n\n  /**\n   * @returns {Array<import(\"./relationships/base.js\").default>}\n   */\n  static getRelationships() {\n    return Object.values(this.getRelationshipsMap())\n  }\n\n  static getRelationshipsMap() {\n    if (!this._relationships) {\n      /** @type {Record<string, import(\"./relationships/base.js\").default>} */\n      this._relationships = {}\n    }\n\n    return this._relationships\n  }\n\n  /**\n   * @returns {Array<string>}\n   */\n  static getRelationshipNames() {\n    return this.getRelationships().map((relationship) => relationship.getRelationshipName())\n  }\n\n  /**\n   * @param {string} relationshipName\n   * @returns {import(\"./instance-relationships/base.js\").default}\n   */\n  getRelationshipByName(relationshipName) {\n    if (!(relationshipName in this._instanceRelationships)) {\n      const modelClassRelationship = this.getModelClass().getRelationshipByName(relationshipName)\n      const relationshipType = modelClassRelationship.getType()\n      let instanceRelationship\n\n      if (relationshipType == \"belongsTo\") {\n        instanceRelationship = new BelongsToInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else if (relationshipType == \"hasMany\") {\n        instanceRelationship = new HasManyInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else if (relationshipType == \"hasOne\") {\n        instanceRelationship = new HasOneInstanceRelationship({model: this, relationship: modelClassRelationship})\n      } else {\n        throw new Error(`Unknown relationship type: ${relationshipType}`)\n      }\n\n      this._instanceRelationships[relationshipName] = instanceRelationship\n    }\n\n    return this._instanceRelationships[relationshipName]\n  }\n\n  /**\n   * Adds a belongs-to-relationship to the model.\n   * @param {string} relationshipName The name of the relationship.\n   * @param {object} [options] The options for the relationship.\n   */\n  static belongsTo(relationshipName, options) {\n    this._defineRelationship(relationshipName, Object.assign({type: \"belongsTo\"}, options))\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  static connection() {\n    const databasePool = this._getConfiguration().getDatabasePool(this.getDatabaseIdentifier())\n    const connection = databasePool.getCurrentConnection()\n\n    if (!connection) throw new Error(\"No connection?\")\n\n    return connection\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {Record<string, any>} [attributes]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async create(attributes) {\n    const record = /** @type {InstanceType<MC>} */ (new this(attributes))\n\n    await record.save()\n\n    return record\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  static _getConfiguration() {\n    if (!this._configuration) {\n      this._configuration = Configuration.current()\n\n      if (!this._configuration) {\n        throw new Error(\"Configuration hasn't been set (model class probably hasn't been initialized)\")\n      }\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default}\n   */\n  _getConfiguration() {\n    return this.getModelClass()._getConfiguration()\n  }\n\n  /**\n   * Adds a has-many-relationship to the model class.\n   * @param {string} relationshipName The name of the relationship (e.g. \"posts\")\n   * @param {object} options The options for the relationship (e.g. {className: \"Post\"})\n   * @returns {void}\n   */\n  static hasMany(relationshipName, options = {}) {\n    return this._defineRelationship(relationshipName, Object.assign({type: \"hasMany\"}, options))\n  }\n\n  /**\n   * Adds a has-one-relationship to the model class.\n   * @param {string} relationshipName The name of the relationship (e.g. \"post\")\n   * @param {object} options The options for the relationship (e.g. {className: \"Post\"})\n   * @returns {void}\n   */\n  static hasOne(relationshipName, options = {}) {\n    return this._defineRelationship(relationshipName, Object.assign({type: \"hasOne\"}, options))\n  }\n\n  /**\n   * @param {string} attributeName\n   * @returns {string}\n   */\n  static humanAttributeName(attributeName) {\n    const modelNameKey = inflection.underscore(this.constructor.name)\n\n    return this._getConfiguration().getTranslator()(`velocious.database.record.attributes.${modelNameKey}.${attributeName}`, {defaultValue: inflection.camelize(attributeName)})\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getDatabaseType() {\n    if (!this._databaseType) throw new Error(\"Database type hasn't been set\")\n\n    return this._databaseType\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @returns {Promise<void>}\n   */\n  static async initializeRecord({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(`No configuration given for ${this.name}`)\n\n    this._configuration = configuration\n    this._configuration.registerModelClass(this)\n    this._databaseType = this.connection().getType()\n\n    this._table = await this.connection().getTableByName(this.tableName())\n    this._columns = await this._getTable().getColumns()\n\n    /** @type {Record<string, import(\"../drivers/base-column.js\").default>} */\n    this._columnsAsHash = {}\n\n    const columnNameToAttributeName = this.getColumnNameToAttributeNameMap()\n    const attributeNameToColumnName = this.getAttributeNameToColumnNameMap()\n\n    for (const column of this._columns) {\n      this._columnsAsHash[column.getName()] = column\n\n      const camelizedColumnName = inflection.camelize(column.getName(), true)\n      const camelizedColumnNameBigFirst = inflection.camelize(column.getName())\n\n      attributeNameToColumnName[camelizedColumnName] = column.getName()\n      columnNameToAttributeName[column.getName()] = camelizedColumnName\n\n      this.prototype[camelizedColumnName] = function() {\n        return this.readAttribute(camelizedColumnName)\n      }\n\n      this.prototype[`set${camelizedColumnNameBigFirst}`] = function(newValue) {\n        return this._setColumnAttribute(camelizedColumnName, newValue)\n      }\n\n      this.prototype[`has${camelizedColumnNameBigFirst}`] = function() {\n        let value = this[camelizedColumnName]()\n\n        return this._hasAttribute(value)\n      }\n    }\n\n    await this._defineTranslationMethods()\n    this._initialized = true\n  }\n\n  /**\n   * @param {any} value\n   * @returns {boolean}\n   */\n  _hasAttribute(value) {\n    if (typeof value == \"string\") {\n      value = value.trim()\n    }\n\n    if (value) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @returns {boolean}\n   */\n  static isInitialized() {\n    if (this._initialized) return true\n\n    return false\n  }\n\n  static async _defineTranslationMethods() {\n    if (this._translations) {\n      const locales = this._getConfiguration().getLocales()\n\n      if (!locales) throw new Error(\"Locales hasn't been set in the configuration\")\n\n      await this.getTranslationClass().initializeRecord({configuration: this._getConfiguration()})\n\n      for (const name in this._translations) {\n        const nameCamelized = inflection.camelize(name)\n        const setterMethodName = `set${nameCamelized}`\n\n        this.prototype[name] = function getTranslatedAttribute() {\n          const locale = this._getConfiguration().getLocale()\n\n          return this._getTranslatedAttributeWithFallback(name, locale)\n        }\n\n        this.prototype[`has${nameCamelized}`] = function hasTranslatedAttribute() {\n          const candidate = this[name]\n\n          if (typeof candidate == \"function\") {\n            const value = candidate.bind(this)()\n\n            return this._hasAttribute(value)\n          } else {\n            throw new Error(`Expected candidate to be a function but it was: ${typeof candidate}`)\n          }\n        }\n\n        this.prototype[setterMethodName] = function setTranslatedAttribute(newValue) {\n          const locale = this._getConfiguration().getLocale()\n\n          return this._setTranslatedAttribute(name, locale, newValue)\n        }\n\n        for (const locale of locales) {\n          const localeCamelized = inflection.camelize(locale)\n          const getterMethodNameLocalized = `${name}${localeCamelized}`\n          const setterMethodNameLocalized = `${setterMethodName}${localeCamelized}`\n          const hasMethodNameLocalized = `has${inflection.camelize(name)}${localeCamelized}`\n\n          this.prototype[getterMethodNameLocalized] = function getTranslatedAttributeWithLocale() {\n            return this._getTranslatedAttribute(name, locale)\n          }\n\n          this.prototype[setterMethodNameLocalized] = function setTranslatedAttributeWithLocale(newValue) {\n            return this._setTranslatedAttribute(name, locale, newValue)\n          }\n\n          this.prototype[hasMethodNameLocalized] = function hasTranslatedAttribute() {\n            const candidate = this[getterMethodNameLocalized]\n\n            if (typeof candidate == \"function\") {\n              const value = candidate.bind(this)()\n\n              return this._hasAttribute(value)\n            } else {\n              throw new Error(`Expected candidate to be a function but it was: ${typeof candidate}`)\n            }\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getDatabaseIdentifier() {\n    return this._databaseIdentifier || \"default\"\n  }\n\n  /**\n   * @param {string} databaseIdentifier\n   * @returns {void}\n   */\n  static setDatabaseIdentifier(databaseIdentifier) {\n    this._databaseIdentifier = databaseIdentifier\n  }\n\n  /**\n   * @param {string} name\n   * @returns {*}\n   */\n  getAttribute(name) {\n    const columnName = inflection.underscore(name)\n\n    if (!this.isNewRecord() && !(columnName in this._attributes)) {\n      throw new Error(`${this.constructor.name}#${name} attribute hasn't been loaded yet in ${Object.keys(this._attributes).join(\", \")}`)\n    }\n\n    return this._attributes[columnName]\n  }\n\n  /**\n   * @abstract\n   * @returns {typeof VelociousDatabaseRecord}\n   */\n  getModelClass() {\n    const modelClass = /** @type {typeof VelociousDatabaseRecord} */ (this.constructor)\n\n    return modelClass\n  }\n\n  /**\n   * @param {string} name\n   * @param {*} newValue\n   * @returns {void}\n   */\n  setAttribute(name, newValue) {\n    const setterName = `set${inflection.camelize(name)}`\n\n    if (!this.getModelClass().isInitialized()) throw new Error(`${this.constructor.name} model isn't initialized yet`)\n    if (!(setterName in this)) throw new Error(`No such setter method: ${this.constructor.name}#${setterName}`)\n\n    this[setterName](newValue)\n  }\n\n  /**\n   * @param {string} name\n   * @param {any} newValue\n   */\n  _setColumnAttribute(name, newValue) {\n    if (!this.getModelClass()._attributeNameToColumnName) throw new Error(\"No attribute-to-column mapping. Has record been initialized?\")\n\n    const columnName = this.getModelClass().getAttributeNameToColumnNameMap()[name]\n\n    if (!columnName) throw new Error(`Couldn't figure out column name for attribute: ${name}`)\n\n    let normalizedValue = newValue\n    const columnType = this.getModelClass().getColumnTypeByName(columnName)\n\n    if (columnType && this.getModelClass()._isDateLikeType(columnType)) {\n      normalizedValue = this._normalizeDateValue(newValue)\n    }\n\n    if (this._attributes[columnName] != normalizedValue) {\n      this._changes[columnName] = normalizedValue\n    }\n  }\n\n  /**\n   * @param {any} value\n   * @returns {any}\n   */\n  _normalizeDateValue(value) {\n    if (typeof value != \"string\") return value\n\n    const isoDateTimeRegex = /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(?:\\.\\d{1,3})?(?:Z|[+-]\\d{2}:\\d{2})$/\n\n    if (!isoDateTimeRegex.test(value)) return value\n\n    const timestamp = Date.parse(value)\n\n    if (Number.isNaN(timestamp)) return value\n\n    return new Date(timestamp)\n  }\n\n  /**\n   * @returns {import(\"../drivers/base-column.js\").default[]}\n   */\n  static getColumns() {\n    if (!this._columns) throw new Error(`${this.name} hasn't been initialized yet`)\n\n    return this._columns\n  }\n\n  /** @returns {Record<string, import(\"../drivers/base-column.js\").default>} */\n  static getColumnsHash() {\n    if (!this._columnsAsHash) {\n      /** @type {Record<string, import(\"../drivers/base-column.js\").default>} */\n      this._columnsAsHash = {}\n\n      for (const column of this.getColumns()) {\n        this._columnsAsHash[column.getName()] = column\n      }\n    }\n\n    return this._columnsAsHash\n  }\n\n  /**\n   * @param {string} name\n   * @returns {string | undefined}\n   */\n  static getColumnTypeByName(name) {\n    if (!this._columnTypeByName) {\n      this._columnTypeByName = {}\n\n      for (const column of this.getColumns()) {\n        this._columnTypeByName[column.getName()] = column.getType()\n      }\n    }\n\n    return this._columnTypeByName[name]\n  }\n\n  /**\n   * @param {string} type\n   * @returns {boolean}\n   */\n  static _isDateLikeType(type) {\n    const normalizedType = type.toLowerCase()\n\n    return normalizedType == \"date\" ||\n      normalizedType == \"datetime\" ||\n      normalizedType == \"timestamp\" ||\n      normalizedType == \"timestamptz\" ||\n      normalizedType.startsWith(\"timestamp \")\n  }\n\n  /**\n   * @returns {Array<string>}\n   */\n  static getColumnNames() {\n    if (!this._columnNames) {\n      this._columnNames = this.getColumns().map((column) => column.getName())\n    }\n\n    return this._columnNames\n  }\n\n  /**\n   * @returns {import(\"../drivers/base-table.js\").default}\n   */\n  static _getTable() {\n    if (!this._table) throw new Error(`${this.name} hasn't been initialized yet`)\n\n    return this._table\n  }\n\n  /**\n   * @param {Array<string>} columns\n   * @param {Array<Array<string>>} rows\n   * @returns {Promise<void>}\n   */\n  static async insertMultiple(columns, rows) {\n    return await this.connection().insertMultiple(this.tableName(), columns, rows)\n  }\n\n  /**\n   * @returns {Promise<number>}\n   */\n  static async nextPrimaryKey() {\n    const primaryKey = this.primaryKey()\n    const tableName = this.tableName()\n    const connection = this.connection()\n    const newestRecord = await this.order(`${connection.quoteTable(tableName)}.${connection.quoteColumn(primaryKey)}`).last()\n\n    if (newestRecord) {\n      const id = newestRecord.id()\n\n      if (typeof id == \"number\") {\n        return id + 1\n      } else {\n        throw new Error(\"ID from newest record wasn't a number\")\n      }\n    } else {\n      return 1\n    }\n  }\n\n  /**\n   * @param {string} primaryKey\n   * @returns {void}\n   */\n  static setPrimaryKey(primaryKey) {\n    this._primaryKey = primaryKey\n  }\n\n  /**\n   * @returns {string}\n   */\n  static primaryKey() {\n    if (this._primaryKey) return this._primaryKey\n\n    return \"id\"\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async save() {\n    const isNewRecord = this.isNewRecord()\n    let result\n\n    await this._getConfiguration().ensureConnections(async () => {\n      await this._runValidations()\n\n      await this.getModelClass().transaction(async () => {\n        // If any belongs-to-relationships was saved, then updated-at should still be set on this record.\n        const {savedCount} = await this._autoSaveBelongsToRelationships()\n\n        if (this.isPersisted()) {\n          // If any has-many-relationships will be saved, then updated-at should still be set on this record.\n          const autoSaveHasManyrelationships = this._autoSaveHasManyAndHasOneRelationshipsToSave()\n\n          if (this._hasChanges() || savedCount > 0 || autoSaveHasManyrelationships.length > 0) {\n            result = await this._updateRecordWithChanges()\n          }\n        } else {\n          result = await this._createNewRecord()\n        }\n\n        await this._autoSaveHasManyAndHasOneRelationships({isNewRecord})\n      })\n    })\n\n    return result\n  }\n\n  async _autoSaveBelongsToRelationships() {\n    let savedCount = 0\n\n    for (const relationshipName in this._instanceRelationships) {\n      const instanceRelationship = this._instanceRelationships[relationshipName]\n\n      if (instanceRelationship.getType() != \"belongsTo\") {\n        continue\n      }\n\n      if (instanceRelationship.getAutoSave() === false) {\n        continue\n      }\n\n      const model = instanceRelationship.loaded()\n\n      if (model) {\n        if (model instanceof VelociousDatabaseRecord) {\n          if (model.isChanged()) {\n            await model.save()\n\n            const foreignKey = instanceRelationship.getForeignKey()\n\n            this.setAttribute(foreignKey, model.id())\n\n            instanceRelationship.setPreloaded(true)\n            instanceRelationship.setDirty(false)\n\n            savedCount++\n          }\n        } else {\n          throw new Error(`Expected a record but got: ${typeof model}`)\n        }\n      }\n    }\n\n    return {savedCount}\n  }\n\n  _autoSaveHasManyAndHasOneRelationshipsToSave() {\n    const relationships = []\n\n    for (const relationshipName in this._instanceRelationships) {\n      const instanceRelationship = this._instanceRelationships[relationshipName]\n\n      if (instanceRelationship.getType() != \"hasMany\" && instanceRelationship.getType() != \"hasOne\") {\n        continue\n      }\n\n      if (instanceRelationship.getAutoSave() === false) {\n        continue\n      }\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let loaded\n\n      const hasManyOrOneLoaded = instanceRelationship.getLoadedOrUndefined()\n\n      if (hasManyOrOneLoaded) {\n        if (Array.isArray(hasManyOrOneLoaded)) {\n          loaded = hasManyOrOneLoaded\n        } else if (hasManyOrOneLoaded instanceof VelociousDatabaseRecord) {\n          loaded = [hasManyOrOneLoaded]\n        } else {\n          throw new Error(`Expected hasOneLoaded to be a record but it wasn't: ${typeof hasManyOrOneLoaded}`)\n        }\n      } else {\n        continue\n      }\n\n      let useRelationship = false\n\n      if (loaded) {\n        for (const model of loaded) {\n          const foreignKey = instanceRelationship.getForeignKey()\n\n          model.setAttribute(foreignKey, this.id())\n\n          if (model.isChanged()) {\n            useRelationship = true\n            continue\n          }\n        }\n      }\n\n      if (useRelationship) relationships.push(instanceRelationship)\n    }\n\n    return relationships\n  }\n\n  /**\n   * @param {object} args\n   * @param {boolean} args.isNewRecord\n   */\n  async _autoSaveHasManyAndHasOneRelationships({isNewRecord}) {\n    for (const instanceRelationship of this._autoSaveHasManyAndHasOneRelationshipsToSave()) {\n      let hasManyOrOneLoaded = instanceRelationship.getLoadedOrUndefined()\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let loaded\n\n      if (hasManyOrOneLoaded === undefined) {\n        loaded = []\n      } else if (hasManyOrOneLoaded instanceof VelociousDatabaseRecord) {\n        loaded = [hasManyOrOneLoaded]\n      } else if (Array.isArray(hasManyOrOneLoaded)) {\n        loaded = hasManyOrOneLoaded\n      } else {\n        throw new Error(`Unexpected type for hasManyOrOneLoaded: ${typeof hasManyOrOneLoaded}`)\n      }\n\n      for (const model of loaded) {\n        const foreignKey = instanceRelationship.getForeignKey()\n\n        model.setAttribute(foreignKey, this.id())\n\n        if (model.isChanged()) {\n          await model.save()\n        }\n      }\n\n      if (isNewRecord) {\n        instanceRelationship.setPreloaded(true)\n      }\n    }\n  }\n\n  /**\n   * @returns {string}\n   */\n  static tableName() {\n    if (!this._tableName) this._tableName = inflection.underscore(inflection.pluralize(this.name))\n\n    return this._tableName\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {void}\n   */\n  static setTableName(tableName) {\n    this._tableName = tableName\n  }\n\n  /**\n   * @param {function() : Promise<void>} callback\n   * @returns {Promise<*>}\n   */\n  static async transaction(callback) {\n    const useTransactions = this.connection().getArgs().record?.transactions\n\n    if (useTransactions !== false) {\n      return await this.connection().transaction(callback)\n    } else {\n      return await callback()\n    }\n  }\n\n  /**\n   * @param {...string} names\n   * @returns {void}\n   */\n  static translates(...names) {\n    const translations = this.getTranslationsMap()\n\n    for (const name of names) {\n      if (name in translations) throw new Error(`Translation already exists: ${name}`)\n\n      translations[name] = {}\n\n      if (!this._relationshipExists(\"translations\")) {\n        this._defineRelationship(\"translations\", {klass: this.getTranslationClass(), type: \"hasMany\"})\n      }\n    }\n  }\n\n  /**\n   * @returns {typeof VelociousDatabaseRecord}\n   */\n  static getTranslationClass() {\n    if (this._translationClass) return this._translationClass\n    if (this.tableName().endsWith(\"_translations\")) throw new Error(\"Trying to define a translations class for a translation class\")\n\n    const className = `${this.name}Translation`\n    const TranslationClass = class Translation extends VelociousDatabaseRecord {}\n    const belongsTo = singularizeModelName(inflection.camelize(this.tableName(), true))\n\n    Object.defineProperty(TranslationClass, \"name\", {value: className})\n    TranslationClass.setTableName(this.getTranslationsTableName())\n    TranslationClass.belongsTo(belongsTo)\n\n    this._translationClass = TranslationClass\n\n    return this._translationClass\n  }\n\n  /**\n   * @returns {string}\n   */\n  static getTranslationsTableName() {\n    const tableNameParts = this.tableName().split(\"_\")\n\n    tableNameParts[tableNameParts.length - 1] = inflection.singularize(tableNameParts[tableNameParts.length - 1])\n\n    return `${tableNameParts.join(\"_\")}_translations`\n  }\n\n  /**\n   * @returns {Promise<boolean>}\n   */\n  static async hasTranslationsTable() {\n    try {\n      await this.connection().getTableByName(this.getTranslationsTableName())\n\n      return true\n    } catch {\n      return false\n    }\n  }\n\n  /**\n   * Adds a validation to an attribute.\n   * @param {string} attributeName The name of the attribute to validate.\n   * @param {Record<string, boolean | Record<string, any>>} validators The validators to add. Key is the validator name, value is the validator arguments.\n   */\n  static async validates(attributeName, validators) {\n    for (const validatorName in validators) {\n      /** @type {Record<string, any>} */\n      let validatorArgs\n\n      /** @type {boolean} */\n      let useValidator = true\n\n      const validatorArgsCandidate = validators[validatorName]\n\n      if (typeof validatorArgsCandidate == \"boolean\") {\n        validatorArgs = {}\n        useValidator\n\n        if (!validatorArgsCandidate) {\n          useValidator = false\n        }\n      } else {\n        validatorArgs = validatorArgsCandidate\n      }\n\n      if (!useValidator) {\n        continue\n      }\n\n      const ValidatorClass = this.getValidatorType(validatorName)\n      const validator = new ValidatorClass({attributeName, args: validatorArgs})\n\n      if (!this._validators) this._validators = {}\n      if (!(attributeName in this._validators)) this._validators[attributeName] = []\n\n      this._validators[attributeName].push(validator)\n    }\n  }\n\n  /**\n   * @abstract\n   * @returns {TranslationBase[]}\n   */\n  translationsLoaded() {\n    throw new Error(\"'translationsLoaded' not implemented\")\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @returns {*}\n   */\n  _getTranslatedAttribute(name, locale) {\n    const translation = this.translationsLoaded().find((translation) => translation.locale() == locale)\n\n    if (translation) {\n      /** @type {Record<string, unknown>} */\n      // @ts-expect-error\n      const dict = translation\n\n      const attributeMethod = /** @type {function() : any | undefined} */ (dict[name])\n\n      if (typeof attributeMethod == \"function\") {\n        return attributeMethod.bind(translation)()\n      } else {\n        throw new Error(`No such translated method: ${name} (${typeof attributeMethod})`)\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @returns {*}\n   */\n  _getTranslatedAttributeWithFallback(name, locale) {\n    let localesInOrder\n    const fallbacks = this._getConfiguration().getLocaleFallbacks()\n\n    if (fallbacks && locale in fallbacks) {\n      localesInOrder = fallbacks[locale]\n    } else {\n      localesInOrder = [locale]\n    }\n\n    for (const fallbackLocale of localesInOrder) {\n      const result = this._getTranslatedAttribute(name, fallbackLocale)\n\n      if (result && result.trim() != \"\") {\n        return result\n      }\n    }\n  }\n\n  /**\n   * @param {string} name\n   * @param {string} locale\n   * @param {*} newValue\n   * @returns {void}\n   */\n  _setTranslatedAttribute(name, locale, newValue) {\n    /** @type {VelociousDatabaseRecord | TranslationBase | undefined} */\n    let translation\n\n    translation = this.translationsLoaded()?.find((translation) => translation.locale() == locale)\n\n    if (!translation) {\n      const instanceRelationship = this.getRelationshipByName(\"translations\")\n\n      translation = instanceRelationship.build({locale})\n    }\n\n    /** @type {Record<string, any>} */\n    const assignments = {}\n\n    assignments[name] = newValue\n\n    translation.assign(assignments)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {ModelClassQuery<MC>}\n   */\n  static _newQuery() {\n    const handler = new Handler()\n    const query = new ModelClassQuery({\n      driver: () => this.connection(),\n      handler,\n      modelClass: this\n    })\n\n    return query.from(new FromTable(this.tableName()))\n  }\n\n  /** @returns {string} */\n  static orderableColumn() {\n    // FIXME: Allow to change to 'created_at' if using UUID?\n\n    return this.primaryKey()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {ModelClassQuery<MC>}\n   */\n  static all() {\n    return this._newQuery()\n  }\n\n  /** @returns {Promise<number>} */\n  static async count() {\n    return await this._newQuery().count()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string} group\n   * @returns {ModelClassQuery<MC>}\n   */\n  static group(group) {\n    return this._newQuery().group(group)\n  }\n\n  static async destroyAll() {\n    return await this._newQuery().destroyAll()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {...string|string[]} columns\n   * @returns {Promise<any[]>}\n   */\n  static async pluck(...columns) {\n    return await this._newQuery().pluck(...columns)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {number|string} recordId\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async find(recordId) {\n    return await this._newQuery().find(recordId)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @returns {Promise<InstanceType<MC> | null>}\n   */\n  static async findBy(conditions) {\n    return await this._newQuery().findBy(conditions)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findByOrFail(conditions) {\n    return await this._newQuery().findByOrFail(conditions)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {{[key: string]: any}} conditions\n   * @param {function() : void} [callback]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findOrCreateBy(conditions, callback) {\n    return await this._newQuery().findOrCreateBy(conditions, callback)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {Record<string, any>} conditions\n   * @param {function(InstanceType<MC>) : void} [callback]\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async findOrInitializeBy(conditions, callback) {\n    return await this._newQuery().findOrInitializeBy(conditions, callback)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async first() {\n    return await this._newQuery().first()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string|{[key: string]: any}} join\n   * @returns {ModelClassQuery<MC>}\n   */\n  static joins(join) {\n    return this._newQuery().joins(join)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>>}\n   */\n  static async last() {\n    return await this._newQuery().last()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {number} value\n   * @returns {ModelClassQuery<MC>}\n   */\n  static limit(value) {\n    return this._newQuery().limit(value)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {string | number} order\n   * @returns {ModelClassQuery<MC>}\n   */\n  static order(order) {\n    return this._newQuery().order(order)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {boolean} [value]\n   * @returns {ModelClassQuery<MC>}\n   */\n  static distinct(value = true) {\n    return this._newQuery().distinct(value)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").NestedPreloadRecord} preload\n   */\n  static preload(preload) {\n    const query = /** @type {ModelClassQuery<MC>} */ (this._newQuery().preload(preload))\n\n    return query\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").SelectArgumentType} select\n   * @returns {ModelClassQuery<MC>}\n   */\n  static select(select) {\n    return this._newQuery().select(select)\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @returns {Promise<InstanceType<MC>[]>}\n   */\n  static async toArray() {\n    return await this._newQuery().toArray()\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @this {MC}\n   * @param {import(\"../query/index.js\").WhereArgumentType} where\n   * @returns {ModelClassQuery<MC>}\n   */\n  static where(where) {\n    return this._newQuery().where(where)\n  }\n\n  /**\n   * @param {Record<string, any>} changes\n   */\n  constructor(changes = {}) {\n    this._attributes = {}\n    this._changes = {}\n    this._isNewRecord = true\n\n    for (const key in changes) {\n      this.setAttribute(key, changes[key])\n    }\n  }\n\n  /**\n   * @param {object} attributes\n   * @returns {void}\n   */\n  loadExistingRecord(attributes) {\n    this._attributes = attributes\n    this._isNewRecord = false\n  }\n\n  /**\n   * Assigns the given attributes to the record.\n   * @param {Record<string, any>} attributesToAssign\n   * @returns {void}\n   */\n  assign(attributesToAssign) {\n    for (const attributeToAssign in attributesToAssign) {\n      this.setAttribute(attributeToAssign, attributesToAssign[attributeToAssign])\n    }\n  }\n\n  /**\n   * Returns a the current attributes of the record (original attributes from database plus changes)\n   * @returns {Record<string, any>}\n   */\n  attributes() {\n    const data = this.rawAttributes()\n    const columnNameToAttributeName = this.getModelClass().getColumnNameToAttributeNameMap()\n    const attributes = {}\n\n    for (const columnName in data) {\n      const attributeName = columnNameToAttributeName[columnName] || columnName\n\n      attributes[attributeName] = this.readAttribute(attributeName)\n    }\n\n    return attributes\n  }\n\n  /**\n   * Returns column-name keyed data (original attributes from database plus changes)\n   * @returns {Record<string, any>}\n   */\n  rawAttributes() {\n    return Object.assign({}, this._attributes, this._changes)\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  _connection() {\n    if (this.__connection) return this.__connection\n\n    return this.getModelClass().connection()\n  }\n\n  /**\n   * Destroys the record in the database and all of its dependent records.\n   * @returns {Promise<void>}\n   */\n  async destroy() {\n    for (const relationship of this.getModelClass().getRelationships()) {\n      if (relationship.getDependent() != \"destroy\") {\n        continue\n      }\n\n      const instanceRelationship = this.getRelationshipByName(relationship.getRelationshipName())\n\n      /** @type {VelociousDatabaseRecord[]} */\n      let models\n\n      if (instanceRelationship.getType() == \"belongsTo\") {\n        if (!instanceRelationship.isLoaded()) {\n          await instanceRelationship.load()\n        }\n\n        const model = instanceRelationship.loaded()\n\n        if (model instanceof VelociousDatabaseRecord) {\n          models = [model]\n        } else {\n          throw new Error(`Unexpected loaded type: ${typeof model}`)\n        }\n      } else if (instanceRelationship.getType() == \"hasMany\") {\n        if (!instanceRelationship.isLoaded()) {\n          await instanceRelationship.load()\n        }\n\n        const loadedModels = instanceRelationship.loaded()\n\n        if (Array.isArray(loadedModels)) {\n          models = loadedModels\n        } else {\n          throw new Error(`Unexpected loaded type: ${typeof loadedModels}`)\n        }\n      } else {\n        throw new Error(`Unhandled relationship type: ${instanceRelationship.getType()}`)\n      }\n\n      for (const model of models) {\n        if (model.isPersisted()) {\n          await model.destroy()\n        }\n      }\n    }\n\n    /** @type {Record<string, any>} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = this.id()\n\n    const sql = this._connection().deleteSql({\n      conditions,\n      tableName: this._tableName()\n    })\n\n    await this._connection().query(sql)\n  }\n\n  /** @returns {boolean} */\n  _hasChanges() { return Object.keys(this._changes).length > 0 }\n\n  /**\n   * Returns true if the model has been changed since it was loaded from the database.\n   * @returns {boolean}\n   */\n  isChanged() {\n    if (this.isNewRecord() || this._hasChanges()){\n      return true\n    }\n\n    // Check if a loaded sub-model of a relationship is changed and should be saved along with this model.\n    if (this._instanceRelationships) {\n      for (const instanceRelationshipName in this._instanceRelationships) {\n        const instanceRelationship = this._instanceRelationships[instanceRelationshipName]\n        let loaded = instanceRelationship._loaded\n\n        if (instanceRelationship.getAutoSave() === false) {\n          continue\n        }\n\n        if (!loaded) continue\n        if (!Array.isArray(loaded)) loaded = [loaded]\n\n        for (const model of loaded) {\n          if (model.isChanged()) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  /** Returns the changes that have been made to this record since it was loaded from the database. */\n  changes() {\n    /** @type {Record<string, any[]>} */\n    const changes = {}\n\n    for (const changeKey in this._changes) {\n      const changeValue = this._changes[changeKey]\n\n      changes[changeKey] = [this._attributes[changeKey], changeValue]\n    }\n\n    return changes\n  }\n\n  /**\n   * @returns {string}\n   */\n  _tableName() {\n    if (this.__tableName) return this.__tableName\n\n    return this.getModelClass().tableName()\n  }\n\n  /**\n   * Reads an attribute value from the record.\n   * @param {string} attributeName The name of the attribute to read. This is the attribute name, not the column name.\n   * @returns {any}\n   */\n  readAttribute(attributeName) {\n    const columnName = this.getModelClass().getAttributeNameToColumnNameMap()[attributeName]\n\n    if (!columnName) throw new Error(`Couldn't figure out column name for attribute: ${attributeName} from these mappings: ${Object.keys(this.getModelClass().getAttributeNameToColumnNameMap()).join(\", \")}`)\n\n    return this.readColumn(columnName)\n  }\n\n  /**\n   * Reads a column value from the record.\n   * @param {string} attributeName The name of the column to read. This is the column name, not the attribute name.\n   */\n  readColumn(attributeName) {\n    const column = this.getModelClass().getColumnsHash()[attributeName]\n    let result\n\n    if (attributeName in this._changes) {\n      result = this._changes[attributeName]\n    } else if (attributeName in this._attributes) {\n      result = this._attributes[attributeName]\n    } else if (this.isPersisted()) {\n      throw new Error(`No such attribute or not selected ${this.constructor.name}#${attributeName}`)\n    }\n\n    if (column && this.getModelClass().getDatabaseType() == \"sqlite\") {\n      if (result && (column.getType() == \"date\" || column.getType() == \"datetime\")) {\n        result = new Date(Date.parse(result))\n      }\n    }\n\n    return result\n  }\n\n  _belongsToChanges() {\n    /** @type {Record<string, any>} */\n    const belongsToChanges = {}\n\n    if (this._instanceRelationships) {\n      for (const relationshipName in this._instanceRelationships) {\n        const relationship = this._instanceRelationships[relationshipName]\n\n        if (relationship.getType() == \"belongsTo\" && relationship.getDirty()) {\n          const model = relationship.loaded()\n\n          if (model) {\n            if (model instanceof VelociousDatabaseRecord) {\n              belongsToChanges[relationship.getForeignKey()] = model?.id()\n            } else {\n              throw new Error(`Unexpected model type: ${typeof model}`)\n            }\n          }\n        }\n      }\n    }\n\n    return belongsToChanges\n  }\n\n  /** @returns {Promise<void>} */\n  async _createNewRecord() {\n    if (!this.getModelClass().connection()[\"insertSql\"]) {\n      throw new Error(`No insertSql on ${this.getModelClass().connection().constructor.name}`)\n    }\n\n    const createdAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"created_at\")\n    const updatedAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"updated_at\")\n    const data = Object.assign({}, this._belongsToChanges(), this.rawAttributes())\n    const primaryKey = this.getModelClass().primaryKey()\n    const primaryKeyColumn = this.getModelClass().getColumns().find((column) => column.getName() == primaryKey)\n    const primaryKeyType = primaryKeyColumn?.getType()?.toLowerCase()\n    const driverSupportsDefaultUUID = typeof this._connection().supportsDefaultPrimaryKeyUUID == \"function\" && this._connection().supportsDefaultPrimaryKeyUUID()\n    const isUUIDPrimaryKey = primaryKeyType?.includes(\"uuid\")\n    const shouldAssignUUIDPrimaryKey = isUUIDPrimaryKey && !driverSupportsDefaultUUID\n    const currentDate = new Date()\n\n    if (createdAtColumn) data.created_at = currentDate\n    if (updatedAtColumn) data.updated_at = currentDate\n\n    const columnNames = this.getModelClass().getColumnNames()\n    const hasUserProvidedPrimaryKey = data[primaryKey] !== undefined && data[primaryKey] !== null && data[primaryKey] !== \"\"\n\n    if (shouldAssignUUIDPrimaryKey && !hasUserProvidedPrimaryKey) {\n      data[primaryKey] = new UUID(4).format()\n    }\n\n    const sql = this._connection().insertSql({\n      returnLastInsertedColumnNames: columnNames,\n      tableName: this._tableName(),\n      data\n    })\n    const insertResult = await this._connection().query(sql)\n\n    if (Array.isArray(insertResult) && insertResult[0] && insertResult[0][primaryKey]) {\n      this._attributes = insertResult[0]\n      this._changes = {}\n    } else if (primaryKeyType == \"uuid\" && data[primaryKey] !== undefined) {\n      this._attributes = Object.assign({}, data)\n      this._changes = {}\n    } else {\n      const id = await this._connection().lastInsertID()\n\n      await this._reloadWithId(id)\n    }\n\n    this.setIsNewRecord(false)\n\n    // Mark all relationships as preloaded, since we don't expect anything to have magically appeared since we created the record.\n    for (const relationship of this.getModelClass().getRelationships()) {\n      const instanceRelationship = this.getRelationshipByName(relationship.getRelationshipName())\n\n      if (instanceRelationship.getType() == \"hasMany\" && instanceRelationship.getLoadedOrUndefined() === null) {\n        instanceRelationship.setLoaded([])\n      }\n\n      instanceRelationship.setPreloaded(true)\n    }\n  }\n\n  /** @returns {Promise<void>} */\n  async _updateRecordWithChanges() {\n    /** @type {Record<string, any>} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = this.id()\n\n    const changes = Object.assign({}, this._belongsToChanges(), this._changes)\n    const updatedAtColumn = this.getModelClass().getColumns().find((column) => column.getName() == \"updated_at\")\n    const currentDate = new Date()\n\n    if (updatedAtColumn) changes.updated_at = currentDate\n\n    if (Object.keys(changes).length > 0) {\n      const sql = this._connection().updateSql({\n        tableName: this._tableName(),\n        data: changes,\n        conditions\n      })\n      await this._connection().query(sql)\n      await this._reloadWithId(this.id())\n    }\n  }\n\n  /** @returns {number|string} */\n  id() {\n    if (!this.getModelClass()._columnNameToAttributeName) {\n      throw new Error(`Column names mapping hasn't been set on ${this.constructor.name}. Has the model been initialized?`)\n    }\n\n    const primaryKey = this.getModelClass().primaryKey()\n    const attributeName = this.getModelClass().getColumnNameToAttributeNameMap()[primaryKey]\n\n    if (attributeName === undefined) {\n      throw new Error(`Primary key ${primaryKey} doesn't exist in columns: ${Object.keys(this.getModelClass().getColumnNameToAttributeNameMap()).join(\", \")}`)\n    }\n\n    return this.readAttribute(attributeName)\n  }\n\n  /** @returns {boolean} */\n  isPersisted() { return !this._isNewRecord }\n\n  /** @returns {boolean} */\n  isNewRecord() { return this._isNewRecord }\n\n  /**\n   * @param {boolean} newIsNewRecord\n   * @returns {void}\n   */\n  setIsNewRecord(newIsNewRecord) {\n    this._isNewRecord = newIsNewRecord\n  }\n\n  /**\n   * @template {typeof VelociousDatabaseRecord} MC\n   * @param {string | number} id\n   * @returns {Promise<void>}\n   */\n  async _reloadWithId(id) {\n    const primaryKey = this.getModelClass().primaryKey()\n\n    /** @type {Record<string, any>} */\n    const whereObject = {}\n\n    whereObject[primaryKey] = id\n\n    const query = /** @type {import(\"../query/model-class-query.js\").default<MC>} */ (this.getModelClass().where(whereObject))\n    const reloadedModel = await query.first()\n\n    if (!reloadedModel) throw new Error(`${this.constructor.name}#${id} couldn't be reloaded - record didn't exist`)\n\n    this._attributes = reloadedModel.rawAttributes()\n    this._changes = {}\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reload() {\n    await this._reloadWithId(this.readAttribute(\"id\"))\n  }\n\n  async _runValidations() {\n    /** @type {Record<string, {type: string, message: string}>} */\n    this._validationErrors = {}\n\n    const validators = this.getModelClass()._validators\n\n    if (validators) {\n      for (const attributeName in validators) {\n        const attributeValidators = validators[attributeName]\n\n        for (const validator of attributeValidators) {\n          await validator.validate({model: this, attributeName})\n        }\n      }\n    }\n\n    if (Object.keys(this._validationErrors).length > 0) {\n      const validationError = new ValidationError(this.fullErrorMessages().join(\". \"))\n\n      validationError.setValidationErrors(this._validationErrors)\n      validationError.setModel(this)\n\n      throw validationError\n    }\n  }\n\n  /** @returns {string[]} */\n  fullErrorMessages() {\n    /** @type {string[]} */\n    const validationErrorMessages = []\n\n    if (this._validationErrors) {\n      for (const attributeName in this._validationErrors) {\n        for (const validationError of this._validationErrors[attributeName]) {\n          const message = `${this.getModelClass().humanAttributeName(attributeName)} ${validationError.message}`\n\n          validationErrorMessages.push(message)\n        }\n      }\n    }\n\n    return validationErrorMessages\n  }\n\n  /**\n   * Assigns the attributes to the record and saves it.\n   * @param {object} attributesToAssign - The attributes to assign to the record.\n   */\n  async update(attributesToAssign) {\n    if (attributesToAssign) this.assign(attributesToAssign)\n\n    await this.save()\n  }\n}\n\nclass TranslationBase extends VelociousDatabaseRecord {\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  locale() {\n    throw new Error(\"'locale' not implemented\")\n  }\n}\n\nVelociousDatabaseRecord.registerValidatorType(\"presence\", ValidatorsPresence)\nVelociousDatabaseRecord.registerValidatorType(\"uniqueness\", ValidatorsUniqueness)\n\nexport {ValidationError}\nexport default VelociousDatabaseRecord\n"]}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "velocious": "build/bin/velocious.js"
4
4
  },
5
5
  "name": "velocious",
6
- "version": "1.0.145",
6
+ "version": "1.0.146",
7
7
  "main": "build/index.js",
8
8
  "types": "build/index.d.ts",
9
9
  "files": [