velocious 1.0.121 → 1.0.123
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/src/configuration-types.d.ts +9 -0
- package/build/src/configuration-types.d.ts.map +1 -1
- package/build/src/configuration-types.js +5 -1
- package/build/src/database/migration/index.d.ts +8 -5
- package/build/src/database/migration/index.d.ts.map +1 -1
- package/build/src/database/migration/index.js +7 -6
- package/build/src/database/migrator.d.ts +3 -9
- package/build/src/database/migrator.d.ts.map +1 -1
- package/build/src/database/migrator.js +15 -17
- package/build/src/logger.d.ts +15 -3
- package/build/src/logger.d.ts.map +1 -1
- package/build/src/logger.js +7 -4
- package/package.json +1 -1
|
@@ -20,6 +20,10 @@
|
|
|
20
20
|
* @property {boolean} [options.encrypt]
|
|
21
21
|
* @property {boolean} [options.trustServerCertificate]
|
|
22
22
|
* @property {string} [password]
|
|
23
|
+
* @property {object} [pool]
|
|
24
|
+
* @property {number} [pool.max]
|
|
25
|
+
* @property {number} [pool.min]
|
|
26
|
+
* @property {number} [pool.idleTimeoutMillis]
|
|
23
27
|
* @property {string} [server]
|
|
24
28
|
* @property {string} [user]
|
|
25
29
|
*/
|
|
@@ -85,6 +89,11 @@ export type SqlConfig = {
|
|
|
85
89
|
trustServerCertificate?: boolean;
|
|
86
90
|
};
|
|
87
91
|
password?: string;
|
|
92
|
+
pool?: {
|
|
93
|
+
max?: number;
|
|
94
|
+
min?: number;
|
|
95
|
+
idleTimeoutMillis?: number;
|
|
96
|
+
};
|
|
88
97
|
server?: string;
|
|
89
98
|
user?: string;
|
|
90
99
|
};
|
|
@@ -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
|
|
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;;GAEG;AAEH;;;;;;;;;;;;;;GAcG;AAEH,yBAAyB;uBApEZ,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,MAAM;kBACN,MAAM;eACN,MAAM;;kCAIP,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;sBAChD,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"}
|
|
@@ -21,6 +21,10 @@
|
|
|
21
21
|
* @property {boolean} [options.encrypt]
|
|
22
22
|
* @property {boolean} [options.trustServerCertificate]
|
|
23
23
|
* @property {string} [password]
|
|
24
|
+
* @property {object} [pool]
|
|
25
|
+
* @property {number} [pool.max]
|
|
26
|
+
* @property {number} [pool.min]
|
|
27
|
+
* @property {number} [pool.idleTimeoutMillis]
|
|
24
28
|
* @property {string} [server]
|
|
25
29
|
* @property {string} [user]
|
|
26
30
|
*/
|
|
@@ -62,4 +66,4 @@
|
|
|
62
66
|
* @property {string} [testing]
|
|
63
67
|
*/
|
|
64
68
|
export const nothing = {};
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlndXJhdGlvbi10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWd1cmF0aW9uLXR5cGVzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWjs7R0FFRztBQUVIOztHQUVHO0FBRUg7Ozs7Ozs7O0dBUUc7QUFFSDs7Ozs7Ozs7Ozs7OztHQWFHO0FBRUg7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtCRztBQUVIOztHQUVHO0FBRUg7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFFSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbi8qKlxuICogQG1vZHVsZSB0eXBlc1xuICovXG5cbi8qKlxuICogQHR5cGVkZWYge2Z1bmN0aW9uKHtyZXF1ZXN0OiBpbXBvcnQoXCIuL2h0dHAtc2VydmVyL2NsaWVudC9yZXF1ZXN0LmpzXCIpLmRlZmF1bHQsIHJlc3BvbnNlOiBpbXBvcnQoXCIuL2h0dHAtc2VydmVyL2NsaWVudC9yZXNwb25zZS5qc1wiKS5kZWZhdWx0fSk6IFByb21pc2U8dm9pZD59IENvcnNUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7KGlkOiBzdHJpbmcpID0+IHtkZWZhdWx0OiB0eXBlb2YgaW1wb3J0KFwiLi9pbml0aWFsaXplci5qc1wiKS5kZWZhdWx0fX0gSW5pdGlhbGl6ZXJzUmVxdWlyZUNvbnRleHRUeXBlXG4gKiBAdHlwZWRlZiB7SW5pdGlhbGl6ZXJzUmVxdWlyZUNvbnRleHRUeXBlICYge1xuICogICBrZXlzOiAoKSA9PiBzdHJpbmdbXSxcbiAqICAgaWQ6IHN0cmluZ1xuICogfX0gV2VicGFja1JlcXVpcmVDb250ZXh0XG4gKiBAdHlwZWRlZiB7e3JlcXVpcmVDb250ZXh0OiBXZWJwYWNrUmVxdWlyZUNvbnRleHR9fSBJbml0aWFsaXplcnNFeHBvcnRUeXBlXG4gKiBAdHlwZWRlZiB7ZnVuY3Rpb24oe2NvbmZpZ3VyYXRpb246IGltcG9ydChcIi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0fSkgOiBQcm9taXNlPEluaXRpYWxpemVyc0V4cG9ydFR5cGU+fSBJbml0aWFsaXplcnNUeXBlXG4gKi9cblxuLyoqXG4gKiBAdHlwZWRlZiB7b2JqZWN0fSBTcWxDb25maWdcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGF0YWJhc2VdXG4gKiBAcHJvcGVydHkge29iamVjdH0gW29wdGlvbnNdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFtvcHRpb25zLmVuY3J5cHRdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFtvcHRpb25zLnRydXN0U2VydmVyQ2VydGlmaWNhdGVdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3Bhc3N3b3JkXVxuICogQHByb3BlcnR5IHtvYmplY3R9IFtwb29sXVxuICogQHByb3BlcnR5IHtudW1iZXJ9IFtwb29sLm1heF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbcG9vbC5taW5dXG4gKiBAcHJvcGVydHkge251bWJlcn0gW3Bvb2wuaWRsZVRpbWVvdXRNaWxsaXNdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3NlcnZlcl1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbdXNlcl1cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IERhdGFiYXNlQ29uZmlndXJhdGlvblR5cGVcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZGF0YWJhc2VdXG4gKiBAcHJvcGVydHkge3R5cGVvZiBpbXBvcnQoXCIuL2RhdGFiYXNlL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0fSBbZHJpdmVyXVxuICogQHByb3BlcnR5IHt0eXBlb2YgaW1wb3J0KFwiLi9kYXRhYmFzZS9wb29sL2Jhc2UuanNcIikuZGVmYXVsdH0gW3Bvb2xUeXBlXVxuICogQHByb3BlcnR5IHtmdW5jdGlvbigpIDogdm9pZH0gW2dldENvbm5lY3Rpb25dXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2hvc3RdXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IFttaWdyYXRpb25zXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtwYXNzd29yZF1cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBbcG9ydF1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbbmFtZV1cbiAqIEBwcm9wZXJ0eSB7b2JqZWN0fSBbcmVjb3JkXVxuICogQHByb3BlcnR5IHtib29sZWFufSBbcmVjb3JkLnRyYW5zYWN0aW9uc11cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gW3Jlc2V0XVxuICogQHByb3BlcnR5IHtTcWxDb25maWd9IFtzcWxDb25maWddXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3R5cGVdXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW3VzZURhdGFiYXNlXVxuICogQHByb3BlcnR5IHtzdHJpbmd9IFt1c2VybmFtZV1cbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtSZWNvcmQ8c3RyaW5nLCBzdHJpbmdbXT59IExvY2FsZUZhbGxiYWNrc1R5cGVcbiAqL1xuXG4vKipcbiAqIEB0eXBlZGVmIHtvYmplY3R9IENvbmZpZ3VyYXRpb25BcmdzVHlwZVxuICogQHByb3BlcnR5IHtDb3JzVHlwZX0gW2NvcnNdXG4gKiBAcHJvcGVydHkge3tba2V5OiBzdHJpbmddOiB7W2tleTogc3RyaW5nXTogRGF0YWJhc2VDb25maWd1cmF0aW9uVHlwZX19fSBkYXRhYmFzZVxuICogQHByb3BlcnR5IHtib29sZWFufSBbZGVidWddXG4gKiBAcHJvcGVydHkge3N0cmluZ30gW2RpcmVjdG9yeV1cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBbZW52aXJvbm1lbnRdXG4gKiBAcHJvcGVydHkge2ltcG9ydChcIi4vZW52aXJvbm1lbnQtaGFuZGxlcnMvYmFzZS5qc1wiKS5kZWZhdWx0fSBlbnZpcm9ubWVudEhhbmRsZXJcbiAqIEBwcm9wZXJ0eSB7ZnVuY3Rpb24oe2NvbmZpZ3VyYXRpb246IGltcG9ydChcIi4vY29uZmlndXJhdGlvbi5qc1wiKS5kZWZhdWx0LCB0eXBlOiBzdHJpbmd9KSA6IHZvaWR9IGluaXRpYWxpemVNb2RlbHNcbiAqIEBwcm9wZXJ0eSB7SW5pdGlhbGl6ZXJzVHlwZX0gW2luaXRpYWxpemVyc11cbiAqIEBwcm9wZXJ0eSB7c3RyaW5nIHwgZnVuY3Rpb24oKSA6IHN0cmluZ30gbG9jYWxlXG4gKiBAcHJvcGVydHkge3N0cmluZ1tdfSBsb2NhbGVzXG4gKiBAcHJvcGVydHkge0xvY2FsZUZhbGxiYWNrc1R5cGV9IGxvY2FsZUZhbGxiYWNrc1xuICogQHByb3BlcnR5IHtzdHJpbmd9IFt0ZXN0aW5nXVxuICovXG5cbmV4cG9ydCBjb25zdCBub3RoaW5nID0ge31cbiJdfQ==
|
|
@@ -141,11 +141,14 @@ export default class VelociousDatabaseMigration {
|
|
|
141
141
|
tableExists(tableName: string): Promise<boolean>;
|
|
142
142
|
}
|
|
143
143
|
export type AddColumnArgsType = {
|
|
144
|
-
default
|
|
145
|
-
foreignKey
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
144
|
+
default?: any;
|
|
145
|
+
foreignKey?: object;
|
|
146
|
+
index?: boolean | {
|
|
147
|
+
unique: boolean;
|
|
148
|
+
};
|
|
149
|
+
null?: boolean;
|
|
150
|
+
primaryKey?: boolean;
|
|
151
|
+
unique?: boolean;
|
|
149
152
|
};
|
|
150
153
|
export class NotImplementedError extends Error {
|
|
151
154
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/migration/index.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/migration/index.js"],"names":[],"mappings":"AAmBA;IACE;;;OAGG;IACH,wCAHW,MAAM,EAAE,GACN,IAAI,CAIhB;IAED,sCAAsC;IACtC,iCADc,MAAM,EAAE,GAAG,SAAS,CAGjC;IAED;;;;;OAKG;IACH,uDAJG;QAAuD,aAAa,EAA5D,OAAO,wBAAwB,EAAE,OAAO;QAC3B,kBAAkB,EAA/B,MAAM;QACqC,EAAE,EAA7C,OAAO,oBAAoB,EAAE,OAAO;KAC9C,EAQA;IAHC,wDAAkC;IAClC,4BAA6C;IAC7C,0CAAa;IAGf,iCAIC;IAED,sDAAsD;IACtD,aADc,OAAO,oBAAoB,EAAE,OAAO,CACnB;IAC/B,mDAAwC;IAExC,wBAEC;IAED,oBAEC;IAED,sBAEC;IAED;;;OAGG;IACH,aAHW,MAAM,GACJ,OAAO,CAAC,OAAO,oBAAoB,EAAE,eAAe,CAAC,CAIjE;IAED;;;;;;OAMG;IACH,qBANW,MAAM,cACN,MAAM,cACN,MAAM,SACN,iBAAiB,GACf,OAAO,CAAC,IAAI,CAAC,CAezB;IAED;;;;OAIG;IACH,wBAJW,MAAM,cACN,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAazB;IAED;;;;;OAKG;IACH;;;;;OAKG;IACH,oBALW,MAAM,WACN,KAAK,CAAC,MAAM,GAAG,OAAO,+BAA+B,EAAE,OAAO,CAAC;sBAN5D,OAAO;eACP,MAAM;iBACN,OAAO;QAMR,OAAO,CAAC,IAAI,CAAC,CAezB;IAED;;;;OAIG;IACH,yBAJW,MAAM,iBACN,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAkBzB;IAED;;;;;;;;OAQG;IACH,wBARW,MAAM,iBACN,MAAM,QAEd;QAAsB,UAAU,EAAxB,OAAO;QACM,IAAI,EAAjB,MAAM;QACQ,MAAM,EAApB,OAAO;KACf,GAAU,OAAO,CAAC,IAAI,CAAC,CAczB;IAED;;;;OAIG;IACH,2BAJW,MAAM,iBACN,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAMzB;IAED;;;;;OAKG;IACH,4BALW,MAAM,cACN,MAAM,YACN,OAAO,GACL,OAAO,CAAC,IAAI,CAAC,CAYzB;IAED;;;;OAIG;IACH,wBAJW,MAAM,cACN,MAAM,GACJ,OAAO,CAAC,OAAO,CAAC,CAc5B;;;;;;;IAeE,uBACQ,MAAM,gCAJW,IAAI,GAMnB,OAAO,CAAC,IAAI,CAAC,CACzB;;;;;;;;IAEE,uBACQ,MAAM;aAbH;sBALA,GAAG;mBACH,MAAM;YAIkB,KAAK;qCAGf,IAAI,GAanB,OAAO,CAAC,IAAI,CAAC,CACzB;IAuDD;;;OAGG;IACH,qBAHW,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;;;OAKG;IACH,wBALW,MAAM,iBACN,MAAM,iBACN,MAAM,GACJ,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,uBAHW,MAAM,GACJ,OAAO,CAAC,OAAO,CAAC,CAM5B;CACF;;cArVa,GAAG;iBACH,MAAM;YACN,OAAO,GAAG;QAAC,MAAM,EAAE,OAAO,CAAA;KAAC;WAC3B,OAAO;iBACP,OAAO;aACP,OAAO;;AAMrB;CAA0C"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
// @ts-check
|
|
2
2
|
/**
|
|
3
3
|
* @typedef {object} AddColumnArgsType
|
|
4
|
-
* @property {any} default
|
|
5
|
-
* @property {object} foreignKey
|
|
6
|
-
* @property {boolean}
|
|
7
|
-
* @property {boolean}
|
|
8
|
-
* @property {boolean}
|
|
4
|
+
* @property {any} [default]
|
|
5
|
+
* @property {object} [foreignKey]
|
|
6
|
+
* @property {boolean | {unique: boolean}} [index]
|
|
7
|
+
* @property {boolean} [null]
|
|
8
|
+
* @property {boolean} [primaryKey]
|
|
9
|
+
* @property {boolean} [unique]
|
|
9
10
|
*/
|
|
10
11
|
import * as inflection from "inflection";
|
|
11
12
|
import restArgsError from "../../utils/rest-args-error.js";
|
|
@@ -284,4 +285,4 @@ export default class VelociousDatabaseMigration {
|
|
|
284
285
|
return exists;
|
|
285
286
|
}
|
|
286
287
|
}
|
|
287
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/migration/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} AddColumnArgsType\n * @property {any} default\n * @property {object} foreignKey\n * @property {boolean} nullable\n * @property {boolean} primaryKey\n * @property {boolean} unique\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableData from \"../table-data/index.js\"\nclass NotImplementedError extends Error {}\n\nexport {NotImplementedError}\n\nexport default class VelociousDatabaseMigration {\n  /**\n   * @param {string[]} databaseIdentifiers\n   * @returns {void}\n   */\n  static onDatabases(databaseIdentifiers) {\n    this._databaseIdentifiers = databaseIdentifiers\n  }\n\n  /** @returns {string[] | undefined} */\n  static getDatabaseIdentifiers() {\n    return this._databaseIdentifiers\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @param {string} args.databaseIdentifier\n   * @param {import(\"../drivers/base.js\").default} args.db\n   */\n  constructor({configuration, databaseIdentifier = \"default\", db}) {\n    if (!databaseIdentifier) throw new Error(\"No database identifier given\")\n    if (!db) throw new Error(\"No 'db' given\")\n\n    this.configuration = configuration\n    this._databaseIdentifier = databaseIdentifier\n    this._db = db\n  }\n\n  _getDatabaseIdentifier() {\n    if (!this._databaseIdentifier) throw new Error(\"No database identifier set\")\n\n    return this._databaseIdentifier\n  }\n\n  /** @returns {import(\"../drivers/base.js\").default} */\n  getDriver() { return this._db }\n  connection() { return this.getDriver() }\n\n  async change() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  async up() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  async down() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<import(\"../drivers/base.js\").QueryResultType>}\n   */\n  async execute(sql) {\n    return await this.connection().query(sql)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} columnType\n   * @param {AddColumnArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async addColumn(tableName, columnName, columnType, args) {\n    if (!columnType) throw new Error(\"No column type given\")\n\n    const tableColumnArgs = Object.assign({isNewColumn: true, type: columnType}, args)\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(columnName, tableColumnArgs)\n\n    const sqls = await this.getDriver().alterTableSQLs(tableData)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @returns {Promise<void>}\n   */\n  async removeColumn(tableName, columnName) {\n    const tableColumnArgs = Object.assign({dropColumn: true})\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(columnName, tableColumnArgs)\n\n    const sqls = await this.getDriver().alterTableSQLs(tableData)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @typedef {object} AddIndexArgsType\n   * @property {boolean} [ifNotExists]\n   * @property {string} [name]\n   * @property {boolean} [unique]\n   */\n  /**\n   * @param {string} tableName\n   * @param {Array<string | import(\"../table-data/table-column.js\").default>} columns\n   * @param {AddIndexArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async addIndex(tableName, columns, args) {\n    const createIndexArgs = Object.assign(\n      {\n        columns,\n        tableName\n      },\n      args\n    )\n    const sqls = await this.getDriver().createIndexSQLs(createIndexArgs)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @returns {Promise<void>}\n   */\n  async addForeignKey(tableName, referenceName) {\n    const referenceNameUnderscore = inflection.underscore(referenceName)\n    const tableNameUnderscore = inflection.underscore(tableName)\n    const columnName = `${referenceNameUnderscore}_id`\n    const foreignKeyName = `fk_${tableName}_${referenceName}`\n\n    await this.getDriver().addForeignKey(\n      tableName,\n      columnName,\n      tableNameUnderscore,\n      \"id\",\n      {\n        isNewForeignKey: true,\n        name: foreignKeyName\n      }\n    )\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @param {object} args\n   * @param {boolean} args.foreignKey\n   * @param {string} args.type\n   * @param {boolean} args.unique\n   * @returns {Promise<void>}\n   */\n  async addReference(tableName, referenceName, args) {\n    const {foreignKey, type, unique, ...restArgs} = args\n    const columnName = `${inflection.underscore(referenceName)}_id`\n\n    restArgsError(restArgs)\n\n    await this.addColumn(tableName, columnName, type || \"integer\")\n    await this.addIndex(tableName, [columnName], {unique: unique})\n\n    if (foreignKey) {\n      await this.addForeignKey(tableName, referenceName)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @returns {Promise<void>}\n   */\n  async removeReference(tableName, referenceName) {\n    const columnName = `${inflection.underscore(referenceName)}_id`\n\n    this.removeColumn(tableName, columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {boolean} nullable\n   * @returns {Promise<void>}\n   */\n  async changeColumnNull(tableName, columnName, nullable) {\n    const table = await this.getDriver().getTableByName(tableName)\n\n    if (!table) throw new Error(`Table ${tableName} does not exist`)\n\n    const column = await table.getColumnByName(columnName)\n\n    if (!column) throw new Error(`Column ${columnName} does not exist in table ${tableName}`)\n\n    await column.changeNullable(nullable)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @returns {Promise<boolean>}\n   */\n  async columnExists(tableName, columnName) {\n    const table = await this.getDriver().getTableByName(tableName)\n\n    if (table) {\n      const column = await table.getColumnByName(columnName)\n\n      if (column) {\n        return true\n      }\n    }\n\n    return Boolean(false)\n  }\n\n  /**\n   * @typedef {object} CreateTableIdArgsType\n   * @property {any} [default]\n   * @property {string} [type]\n   */\n  /**\n   * @typedef {object} CreateTableArgsType\n   * @property {CreateTableIdArgsType | false} [id]\n   */\n  /**\n   * @typedef {(TableData) => void} CreateTableCallbackType\n   */\n  /**\n   * @overload\n   * @param {string} tableName\n   * @param {CreateTableCallbackType} callback\n   * @returns {Promise<void>}\n   */\n  /**\n   * @overload\n   * @param {string} tableName\n   * @param {CreateTableArgsType} args\n   * @param {CreateTableCallbackType} callback\n   * @returns {Promise<void>}\n   */\n  /**\n   * @param {string} tableName\n   * @param {CreateTableArgsType | CreateTableCallbackType} arg1\n   * @param {CreateTableCallbackType | undefined} [arg2]\n   * @returns {Promise<void>}\n   */\n  async createTable(tableName, arg1, arg2) {\n    let args\n    let callback\n\n    if (typeof arg1 == \"function\") {\n      args = {}\n      callback = arg1\n    } else {\n      args = arg1\n      callback = arg2\n    }\n\n    const {id = {}, ...restArgs} = args\n    const databaseIdentifier = this._getDatabaseIdentifier()\n    const databasePool = this.configuration.getDatabasePool(databaseIdentifier)\n    let idDefault, idType, restArgsId\n\n    if (id !== false) {\n      ({default: idDefault, type: idType, ...restArgsId} = id)\n\n      restArgsError(restArgsId)\n    }\n\n    if (!idType) {\n      idType = databasePool.primaryKeyType()\n    }\n\n    const tableData = new TableData(tableName)\n\n    restArgsError(restArgs)\n\n    if (!(idType in tableData)) throw new Error(`Unsupported primary key type: ${idType}`)\n\n    if (id !== false) {\n      tableData.addColumn(\"id\", {autoIncrement: true, default: idDefault, null: false, primaryKey: true, type: idType})\n    }\n\n    if (callback) {\n      callback(tableData)\n    }\n\n    const sqls = await this.getDriver().createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this._db.query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<void>}\n   */\n  async dropTable(tableName) {\n    await this.getDriver().dropTable(tableName)\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    await this.getDriver().renameColumn(tableName, oldColumnName, newColumnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>}\n   */\n  async tableExists(tableName) {\n    const exists = await this.getDriver().tableExists(tableName)\n\n    return exists\n  }\n}\n"]}
|
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/migration/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} AddColumnArgsType\n * @property {any} [default]\n * @property {object} [foreignKey]\n * @property {boolean | {unique: boolean}} [index]\n * @property {boolean} [null]\n * @property {boolean} [primaryKey]\n * @property {boolean} [unique]\n */\n\nimport * as inflection from \"inflection\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\nimport TableData from \"../table-data/index.js\"\nclass NotImplementedError extends Error {}\n\nexport {NotImplementedError}\n\nexport default class VelociousDatabaseMigration {\n  /**\n   * @param {string[]} databaseIdentifiers\n   * @returns {void}\n   */\n  static onDatabases(databaseIdentifiers) {\n    this._databaseIdentifiers = databaseIdentifiers\n  }\n\n  /** @returns {string[] | undefined} */\n  static getDatabaseIdentifiers() {\n    return this._databaseIdentifiers\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @param {string} args.databaseIdentifier\n   * @param {import(\"../drivers/base.js\").default} args.db\n   */\n  constructor({configuration, databaseIdentifier = \"default\", db}) {\n    if (!databaseIdentifier) throw new Error(\"No database identifier given\")\n    if (!db) throw new Error(\"No 'db' given\")\n\n    this.configuration = configuration\n    this._databaseIdentifier = databaseIdentifier\n    this._db = db\n  }\n\n  _getDatabaseIdentifier() {\n    if (!this._databaseIdentifier) throw new Error(\"No database identifier set\")\n\n    return this._databaseIdentifier\n  }\n\n  /** @returns {import(\"../drivers/base.js\").default} */\n  getDriver() { return this._db }\n  connection() { return this.getDriver() }\n\n  async change() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  async up() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  async down() {\n    throw new NotImplementedError(\"'change' not implemented\")\n  }\n\n  /**\n   * @param {string} sql\n   * @returns {Promise<import(\"../drivers/base.js\").QueryResultType>}\n   */\n  async execute(sql) {\n    return await this.connection().query(sql)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {string} columnType\n   * @param {AddColumnArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async addColumn(tableName, columnName, columnType, args) {\n    if (!columnType) throw new Error(\"No column type given\")\n\n    const tableColumnArgs = Object.assign({isNewColumn: true, type: columnType}, args)\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(columnName, tableColumnArgs)\n\n    const sqls = await this.getDriver().alterTableSQLs(tableData)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @returns {Promise<void>}\n   */\n  async removeColumn(tableName, columnName) {\n    const tableColumnArgs = Object.assign({dropColumn: true})\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(columnName, tableColumnArgs)\n\n    const sqls = await this.getDriver().alterTableSQLs(tableData)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @typedef {object} AddIndexArgsType\n   * @property {boolean} [ifNotExists]\n   * @property {string} [name]\n   * @property {boolean} [unique]\n   */\n  /**\n   * @param {string} tableName\n   * @param {Array<string | import(\"../table-data/table-column.js\").default>} columns\n   * @param {AddIndexArgsType} [args]\n   * @returns {Promise<void>}\n   */\n  async addIndex(tableName, columns, args) {\n    const createIndexArgs = Object.assign(\n      {\n        columns,\n        tableName\n      },\n      args\n    )\n    const sqls = await this.getDriver().createIndexSQLs(createIndexArgs)\n\n    for (const sql of sqls) {\n      await this.getDriver().query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @returns {Promise<void>}\n   */\n  async addForeignKey(tableName, referenceName) {\n    const referenceNameUnderscore = inflection.underscore(referenceName)\n    const tableNameUnderscore = inflection.underscore(tableName)\n    const columnName = `${referenceNameUnderscore}_id`\n    const foreignKeyName = `fk_${tableName}_${referenceName}`\n\n    await this.getDriver().addForeignKey(\n      tableName,\n      columnName,\n      tableNameUnderscore,\n      \"id\",\n      {\n        isNewForeignKey: true,\n        name: foreignKeyName\n      }\n    )\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @param {object} args\n   * @param {boolean} args.foreignKey\n   * @param {string} args.type\n   * @param {boolean} args.unique\n   * @returns {Promise<void>}\n   */\n  async addReference(tableName, referenceName, args) {\n    const {foreignKey, type, unique, ...restArgs} = args\n    const columnName = `${inflection.underscore(referenceName)}_id`\n\n    restArgsError(restArgs)\n\n    await this.addColumn(tableName, columnName, type || \"integer\")\n    await this.addIndex(tableName, [columnName], {unique: unique})\n\n    if (foreignKey) {\n      await this.addForeignKey(tableName, referenceName)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} referenceName\n   * @returns {Promise<void>}\n   */\n  async removeReference(tableName, referenceName) {\n    const columnName = `${inflection.underscore(referenceName)}_id`\n\n    this.removeColumn(tableName, columnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @param {boolean} nullable\n   * @returns {Promise<void>}\n   */\n  async changeColumnNull(tableName, columnName, nullable) {\n    const table = await this.getDriver().getTableByName(tableName)\n\n    if (!table) throw new Error(`Table ${tableName} does not exist`)\n\n    const column = await table.getColumnByName(columnName)\n\n    if (!column) throw new Error(`Column ${columnName} does not exist in table ${tableName}`)\n\n    await column.changeNullable(nullable)\n  }\n\n  /**\n   * @param {string} tableName\n   * @param {string} columnName\n   * @returns {Promise<boolean>}\n   */\n  async columnExists(tableName, columnName) {\n    const table = await this.getDriver().getTableByName(tableName)\n\n    if (table) {\n      const column = await table.getColumnByName(columnName)\n\n      if (column) {\n        return true\n      }\n    }\n\n    return Boolean(false)\n  }\n\n  /**\n   * @typedef {object} CreateTableIdArgsType\n   * @property {any} [default]\n   * @property {string} [type]\n   */\n  /**\n   * @typedef {object} CreateTableArgsType\n   * @property {CreateTableIdArgsType | false} [id]\n   */\n  /**\n   * @typedef {(TableData) => void} CreateTableCallbackType\n   */\n  /**\n   * @overload\n   * @param {string} tableName\n   * @param {CreateTableCallbackType} callback\n   * @returns {Promise<void>}\n   */\n  /**\n   * @overload\n   * @param {string} tableName\n   * @param {CreateTableArgsType} args\n   * @param {CreateTableCallbackType} callback\n   * @returns {Promise<void>}\n   */\n  /**\n   * @param {string} tableName\n   * @param {CreateTableArgsType | CreateTableCallbackType} arg1\n   * @param {CreateTableCallbackType | undefined} [arg2]\n   * @returns {Promise<void>}\n   */\n  async createTable(tableName, arg1, arg2) {\n    let args\n    let callback\n\n    if (typeof arg1 == \"function\") {\n      args = {}\n      callback = arg1\n    } else {\n      args = arg1\n      callback = arg2\n    }\n\n    const {id = {}, ...restArgs} = args\n    const databaseIdentifier = this._getDatabaseIdentifier()\n    const databasePool = this.configuration.getDatabasePool(databaseIdentifier)\n    let idDefault, idType, restArgsId\n\n    if (id !== false) {\n      ({default: idDefault, type: idType, ...restArgsId} = id)\n\n      restArgsError(restArgsId)\n    }\n\n    if (!idType) {\n      idType = databasePool.primaryKeyType()\n    }\n\n    const tableData = new TableData(tableName)\n\n    restArgsError(restArgs)\n\n    if (!(idType in tableData)) throw new Error(`Unsupported primary key type: ${idType}`)\n\n    if (id !== false) {\n      tableData.addColumn(\"id\", {autoIncrement: true, default: idDefault, null: false, primaryKey: true, type: idType})\n    }\n\n    if (callback) {\n      callback(tableData)\n    }\n\n    const sqls = await this.getDriver().createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this._db.query(sql)\n    }\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<void>}\n   */\n  async dropTable(tableName) {\n    await this.getDriver().dropTable(tableName)\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    await this.getDriver().renameColumn(tableName, oldColumnName, newColumnName)\n  }\n\n  /**\n   * @param {string} tableName\n   * @returns {Promise<boolean>}\n   */\n  async tableExists(tableName) {\n    const exists = await this.getDriver().tableExists(tableName)\n\n    return exists\n  }\n}\n"]}
|
|
@@ -10,13 +10,9 @@ export default class VelociousDatabaseMigrator {
|
|
|
10
10
|
migrationsVersions: Record<string, Record<string, boolean>>;
|
|
11
11
|
configuration: import("../configuration.js").default;
|
|
12
12
|
logger: Logger;
|
|
13
|
-
/**
|
|
14
|
-
* @returns {Promise<void>}
|
|
15
|
-
*/
|
|
13
|
+
/** @returns {Promise<void>} */
|
|
16
14
|
prepare(): Promise<void>;
|
|
17
|
-
/**
|
|
18
|
-
* @returns {Promise<void>}
|
|
19
|
-
*/
|
|
15
|
+
/** @returns {Promise<void>} */
|
|
20
16
|
createMigrationsTable(): Promise<void>;
|
|
21
17
|
dropDatabase(): Promise<void>;
|
|
22
18
|
/**
|
|
@@ -35,9 +31,7 @@ export default class VelociousDatabaseMigrator {
|
|
|
35
31
|
* @returns {Promise<void>}
|
|
36
32
|
*/
|
|
37
33
|
migrateFilesFromRequireContext(requireContext: import("./migrator/types.js").RequireMigrationContextType): Promise<void>;
|
|
38
|
-
/**
|
|
39
|
-
* @returns {Promise<void>}
|
|
40
|
-
*/
|
|
34
|
+
/** @returns {Promise<void>} */
|
|
41
35
|
loadMigrationsVersions(): Promise<void>;
|
|
42
36
|
/**
|
|
43
37
|
* @param {import("./drivers/base.js").default} db
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"AASA;IAIE;;;OAGG;IACH,4CAFG;QAAoD,aAAa,EAAzD,OAAO,qBAAqB,EAAE,OAAO;KAC/C,EAQA;IAdD,sDAAsD;IACtD,oBADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAC3B;IAWrB,qDAAkC;IAClC,eAA8C;
|
|
1
|
+
{"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"AASA;IAIE;;;OAGG;IACH,4CAFG;QAAoD,aAAa,EAAzD,OAAO,qBAAqB,EAAE,OAAO;KAC/C,EAQA;IAdD,sDAAsD;IACtD,oBADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAC3B;IAWrB,qDAAkC;IAClC,eAA8C;IAIhD,+BAA+B;IAC/B,WADc,OAAO,CAAC,IAAI,CAAC,CAI1B;IAED,+BAA+B;IAC/B,yBADc,OAAO,CAAC,IAAI,CAAC,CA+B1B;IAED,8BAEC;IAED;;;;OAIG;IACH,qCAJW,MAAM,WACN,MAAM,GACJ,OAAO,CAWnB;IAED;;;OAGG;IACH,oBAHW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,iBAqBlE;IAED;;;OAGG;IACH,+CAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CA2CzB;IAED,+BAA+B;IAC/B,0BADc,OAAO,CAAC,IAAI,CAAC,CA8B1B;IAED;;;OAGG;IACH,yBAHW,OAAO,mBAAmB,EAAE,OAAO,GACjC,OAAO,CAAC,OAAO,CAAC,CAQ5B;IAED;;;OAGG;IACH,sCAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CAkCzB;IAED;;OAEG;IACH,SAFa,OAAO,CAAC,IAAI,CAAC,CAoCzB;IAED;;;;OAIG;IACH,gBAJW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,GACtD,OAAO,CAAC,IAAI,CAAC,CAyBzB;IAED;;OAEG;IACH,2BAFa,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAiBvC;IAED;;;;;OAKG;IACH,6DAJG;QAAgE,SAAS,EAAjE,OAAO,qBAAqB,EAAE,mBAAmB;QACQ,gBAAgB,EAAzE,OAAO,qBAAqB,EAAE,oBAAoB;QACpC,SAAS,GAAvB,MAAM;KAAkB,iBAiGlC;CACF;uBA3aoB,cAAc"}
|
|
@@ -19,16 +19,12 @@ export default class VelociousDatabaseMigrator {
|
|
|
19
19
|
this.configuration = configuration;
|
|
20
20
|
this.logger = new Logger(this, { debug: false });
|
|
21
21
|
}
|
|
22
|
-
/**
|
|
23
|
-
* @returns {Promise<void>}
|
|
24
|
-
*/
|
|
22
|
+
/** @returns {Promise<void>} */
|
|
25
23
|
async prepare() {
|
|
26
24
|
await this.createMigrationsTable();
|
|
27
25
|
await this.loadMigrationsVersions();
|
|
28
26
|
}
|
|
29
|
-
/**
|
|
30
|
-
* @returns {Promise<void>}
|
|
31
|
-
*/
|
|
27
|
+
/** @returns {Promise<void>} */
|
|
32
28
|
async createMigrationsTable() {
|
|
33
29
|
const dbs = await this.configuration.getCurrentConnections();
|
|
34
30
|
for (const dbIdentifier in dbs) {
|
|
@@ -38,15 +34,19 @@ export default class VelociousDatabaseMigrator {
|
|
|
38
34
|
this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping creating migrations table for it`);
|
|
39
35
|
continue;
|
|
40
36
|
}
|
|
41
|
-
|
|
37
|
+
const exists = await this.migrationsTableExist(db);
|
|
38
|
+
if (exists) {
|
|
42
39
|
this.logger.debug(`${dbIdentifier} migrations table already exists - skipping`);
|
|
43
|
-
continue;
|
|
44
40
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
await db.
|
|
41
|
+
else {
|
|
42
|
+
this.logger.debug("New TableData for schema_migrations");
|
|
43
|
+
const schemaMigrationsTable = new TableData("schema_migrations", { ifNotExists: true });
|
|
44
|
+
schemaMigrationsTable.string("version", { null: false, primaryKey: true });
|
|
45
|
+
const createSchemaMigrationsTableSqls = await db.createTableSql(schemaMigrationsTable);
|
|
46
|
+
for (const createSchemaMigrationsTableSql of createSchemaMigrationsTableSqls) {
|
|
47
|
+
this.logger.debug(`Creating migrations table with SQL`, createSchemaMigrationsTableSql);
|
|
48
|
+
await db.query(createSchemaMigrationsTableSql);
|
|
49
|
+
}
|
|
50
50
|
}
|
|
51
51
|
}
|
|
52
52
|
}
|
|
@@ -129,9 +129,7 @@ export default class VelociousDatabaseMigrator {
|
|
|
129
129
|
}
|
|
130
130
|
});
|
|
131
131
|
}
|
|
132
|
-
/**
|
|
133
|
-
* @returns {Promise<void>}
|
|
134
|
-
*/
|
|
132
|
+
/** @returns {Promise<void>} */
|
|
135
133
|
async loadMigrationsVersions() {
|
|
136
134
|
this.migrationsVersions = {};
|
|
137
135
|
const dbs = await this.configuration.getCurrentConnections();
|
|
@@ -375,4 +373,4 @@ export default class VelociousDatabaseMigrator {
|
|
|
375
373
|
}
|
|
376
374
|
}
|
|
377
375
|
}
|
|
378
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport {Logger} from \"../logger.js\"\nimport {NotImplementedError} from \"./migration/index.js\"\nimport restArgsError from \"../utils/rest-args-error.js\"\nimport TableData from \"./table-data/index.js\"\n\nexport default class VelociousDatabaseMigrator {\n  /** @type {Record<string, Record<string, boolean>>} */\n  migrationsVersions = {}\n\n  /**\n   * @param {object} args\n   * @param {import(\"../configuration.js\").default} args.configuration\n   */\n  constructor({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(\"configuration argument is required\")\n\n    this.configuration = configuration\n    this.logger = new Logger(this, {debug: false})\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async prepare() {\n    await this.createMigrationsTable()\n    await this.loadMigrationsVersions()\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async createMigrationsTable() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping creating migrations table for it`)\n        continue\n      }\n\n      if (await this.migrationsTableExist(db)) {\n        this.logger.debug(`${dbIdentifier} migrations table already exists - skipping`)\n        continue\n      }\n\n      const schemaMigrationsTable = new TableData(\"schema_migrations\", {ifNotExists: true})\n\n      schemaMigrationsTable.string(\"version\", {null: false, primaryKey: true})\n\n      const createSchemaMigrationsTableSqls = await db.createTableSql(schemaMigrationsTable)\n\n      for (const createSchemaMigrationsTableSql of createSchemaMigrationsTableSqls) {\n        await db.query(createSchemaMigrationsTableSql)\n      }\n    }\n  }\n\n  async dropDatabase() {\n    throw new Error(\"Not implemented yet\")\n  }\n\n  /**\n   * @param {string} dbIdentifier\n   * @param {number} version\n   * @returns {boolean}\n   */\n  hasRunMigrationVersion(dbIdentifier, version) {\n    if (!this.migrationsVersions) throw new Error(\"Migrations versions hasn't been loaded yet\")\n    if (!this.migrationsVersions[dbIdentifier]) throw new Error(`Migrations versions hasn't been loaded yet for db: ${dbIdentifier}`)\n\n    if (version in this.migrationsVersions[dbIdentifier]) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback\n   */\n  async migrateFiles(files, importCallback) {\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => {\n            if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n            const migrationImport = await importCallback(migration.fullPath)\n\n            if (!migrationImport) {\n              throw new Error(`Migration file must export migration class: ${migration.fullPath}`)\n            }\n\n            return migrationImport\n          }\n        })\n      }\n    })\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async migrateFilesFromRequireContext(requireContext) {\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of requireContext.keys()) {\n      // \"13,14\" because somes \"require-context\"-npm-module deletes first character!?\n      const match = file.match(/(\\d{13,14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      // Fix require-context-npm-module deletes first character\n      let fileName = file\n      let dateNumber = match[1]\n\n      if (dateNumber.length == 13) {\n        dateNumber = `2${dateNumber}`\n        fileName = `2${fileName}`\n      }\n\n      // Parse regex\n      const date = parseInt(dateNumber)\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file: fileName,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => requireContext(migration.file).default\n        })\n      }\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async loadMigrationsVersions() {\n    this.migrationsVersions = {}\n\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping loading migrations versions for it`)\n        continue\n      }\n\n      if (!await this.migrationsTableExist(db)) {\n        this.logger.log(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`)\n        continue\n      }\n\n      const rows = await db.select(\"schema_migrations\")\n\n      this.migrationsVersions[dbIdentifier] = {}\n\n      for (const row of rows) {\n        const version = digg(row, \"version\")\n\n        this.migrationsVersions[dbIdentifier][version] = true\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"./drivers/base.js\").default} db\n   * @returns {Promise<boolean>}\n   */\n  async migrationsTableExist(db) {\n    const schemaTable = await db.getTableByName(\"schema_migrations\", {throwError: false})\n\n    if (!schemaTable) return false\n\n    return true\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async executeRequireContext(requireContext) {\n    const migrationFiles = requireContext.keys()\n\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of migrationFiles) {\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName)\n\n      const migrationObject = /** @type {import(\"./migrator/types.js\").MigrationObjectType} */ ({\n        file,\n        date,\n        migrationClassName\n      })\n\n      files.push(migrationObject)\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    for (const migration of files) {\n      await this.runMigrationFile({\n        migration,\n        requireMigration: async () => requireContext(migration.file).default\n      })\n    }\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reset() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n\n      await db.withDisabledForeignKeys(async () => {\n        while (true) {\n          const errors = []\n          let anyTableDropped = false\n\n          try {\n            for (const table of await db.getTables()) {\n              this.logger.log(`Dropping table ${table.getName()}`)\n\n              try {\n                await db.dropTable(table.getName(), {cascade: true})\n                anyTableDropped = true\n              } catch (error) {\n                errors.push(error)\n              }\n            }\n\n            break\n          } catch (error) { // eslint-disable-line no-unused-vars\n            if (errors.length > 0 && anyTableDropped) {\n              // Retry\n            } else {\n              throw errors[0]\n            }\n          }\n        }\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback Function to import a file\n   * @returns {Promise<void>}\n   */\n  async rollback(files, importCallback) {\n    const latestMigrationVersion = await this._latestMigrationVersion()\n\n    if (!latestMigrationVersion) {\n      throw new Error(\"No migrations have been run yet\")\n    }\n\n    const latestMigrationVersionNumber = parseInt(latestMigrationVersion)\n    const migration = files.find((file) => file.date == latestMigrationVersionNumber)\n\n    if (!migration) {\n      throw new Error(`Migration file for version ${latestMigrationVersionNumber} not found`)\n    }\n\n    await this.runMigrationFile({\n      migration,\n      requireMigration: async () => {\n        if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n        return await importCallback(migration.fullPath)\n      },\n      direction: \"down\"\n    })\n  }\n\n  /**\n   * @returns {Promise<string | undefined>} The latest migration version\n   */\n  async _latestMigrationVersion() {\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    /** @type {string | undefined} */\n    let highestVersion\n\n    for (const dbIdentifier in this.migrationsVersions) {\n      for (const migrationVersion in this.migrationsVersions[dbIdentifier]) {\n        if (!highestVersion || migrationVersion > highestVersion) {\n          highestVersion = migrationVersion\n        }\n      }\n    }\n\n    return highestVersion\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"./migrator/types.js\").MigrationObjectType} args.migration\n   * @param {import(\"./migrator/types.js\").RequireMigrationType} args.requireMigration\n   * @param {string} [args.direction]\n   */\n  async runMigrationFile({migration, requireMigration, direction = \"up\"}) {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n    if (!this.configuration.isDatabasePoolInitialized()) await this.configuration.initializeDatabasePool()\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    const dbs = await this.configuration.getCurrentConnections()\n    const migrationClass = await requireMigration()\n\n    if (!migrationClass || typeof migrationClass !== \"function\") {\n      throw new Error(`Migration ${migration.file} must export a default migration class. Type: ${typeof migrationClass}`)\n    }\n\n    const migrationDatabaseIdentifiers = migrationClass.getDatabaseIdentifiers() || [\"default\"]\n\n    for (const dbIdentifier in dbs) {\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping migration ${digg(migration, \"date\")}`)\n        continue\n      }\n\n      if (!migrationDatabaseIdentifiers.includes(dbIdentifier)) {\n        this.logger.debug(`${dbIdentifier} shouldn't run migration ${migration.file}`, {migrationDatabaseIdentifiers})\n        continue\n      }\n\n      if (direction == \"up\") {\n        if (this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} has already run migration ${migration.file}`)\n          continue\n        }\n      } else if (direction == \"down\") {\n        if (!this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} hasn't run migration ${migration.file}`)\n          continue\n        }\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n\n      this.logger.debug(`Running migration on ${dbIdentifier}: ${migration.file}`, {migrationDatabaseIdentifiers})\n\n      const db = dbs[dbIdentifier]\n      const MigrationClass = migrationClass\n      const migrationInstance = new MigrationClass({\n        configuration: this.configuration,\n        databaseIdentifier: dbIdentifier,\n        db\n      })\n      const dateString = `${digg(migration, \"date\")}`\n\n      if (direction == \"up\") {\n        try {\n          await migrationInstance.change()\n        } catch (changeError) {\n          if (changeError instanceof NotImplementedError) {\n            try {\n              await migrationInstance.up()\n            } catch (upError) {\n              if (upError instanceof NotImplementedError) {\n                throw new Error(`'change' or 'up' didn't exist on migration: ${migration.file}`)\n              } else {\n                throw upError\n              }\n            }\n          } else {\n            throw changeError\n          }\n        }\n\n        const existingSchemaMigrations = await db.newQuery()\n          .from(\"schema_migrations\")\n          .where({version: dateString})\n          .results()\n\n        if (existingSchemaMigrations.length == 0) {\n          await db.insert({tableName: \"schema_migrations\", data: {version: dateString}})\n        }\n      } else if (direction == \"down\") {\n        try {\n          await migrationInstance.down()\n        } catch (downError) {\n          if (downError instanceof NotImplementedError) {\n            throw new Error(`'down' didn't exist on migration: ${migration.file} or migrating down with a change method isn't currently supported`)\n          } else {\n            throw downError\n          }\n        }\n\n        await db.delete({tableName: \"schema_migrations\", conditions: {version: dateString}})\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n    }\n  }\n}\n"]}
|
|
376
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport {Logger} from \"../logger.js\"\nimport {NotImplementedError} from \"./migration/index.js\"\nimport restArgsError from \"../utils/rest-args-error.js\"\nimport TableData from \"./table-data/index.js\"\n\nexport default class VelociousDatabaseMigrator {\n  /** @type {Record<string, Record<string, boolean>>} */\n  migrationsVersions = {}\n\n  /**\n   * @param {object} args\n   * @param {import(\"../configuration.js\").default} args.configuration\n   */\n  constructor({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(\"configuration argument is required\")\n\n    this.configuration = configuration\n    this.logger = new Logger(this, {debug: false})\n  }\n\n\n  /** @returns {Promise<void>} */\n  async prepare() {\n    await this.createMigrationsTable()\n    await this.loadMigrationsVersions()\n  }\n\n  /** @returns {Promise<void>} */\n  async createMigrationsTable() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping creating migrations table for it`)\n        continue\n      }\n\n      const exists = await this.migrationsTableExist(db)\n\n      if (exists) {\n        this.logger.debug(`${dbIdentifier} migrations table already exists - skipping`)\n      } else {\n        this.logger.debug(\"New TableData for schema_migrations\")\n        const schemaMigrationsTable = new TableData(\"schema_migrations\", {ifNotExists: true})\n\n        schemaMigrationsTable.string(\"version\", {null: false, primaryKey: true})\n\n        const createSchemaMigrationsTableSqls = await db.createTableSql(schemaMigrationsTable)\n\n        for (const createSchemaMigrationsTableSql of createSchemaMigrationsTableSqls) {\n          this.logger.debug(`Creating migrations table with SQL`, createSchemaMigrationsTableSql)\n          await db.query(createSchemaMigrationsTableSql)\n        }\n      }\n    }\n  }\n\n  async dropDatabase() {\n    throw new Error(\"Not implemented yet\")\n  }\n\n  /**\n   * @param {string} dbIdentifier\n   * @param {number} version\n   * @returns {boolean}\n   */\n  hasRunMigrationVersion(dbIdentifier, version) {\n    if (!this.migrationsVersions) throw new Error(\"Migrations versions hasn't been loaded yet\")\n    if (!this.migrationsVersions[dbIdentifier]) throw new Error(`Migrations versions hasn't been loaded yet for db: ${dbIdentifier}`)\n\n    if (version in this.migrationsVersions[dbIdentifier]) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback\n   */\n  async migrateFiles(files, importCallback) {\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => {\n            if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n            const migrationImport = await importCallback(migration.fullPath)\n\n            if (!migrationImport) {\n              throw new Error(`Migration file must export migration class: ${migration.fullPath}`)\n            }\n\n            return migrationImport\n          }\n        })\n      }\n    })\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async migrateFilesFromRequireContext(requireContext) {\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of requireContext.keys()) {\n      // \"13,14\" because somes \"require-context\"-npm-module deletes first character!?\n      const match = file.match(/(\\d{13,14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      // Fix require-context-npm-module deletes first character\n      let fileName = file\n      let dateNumber = match[1]\n\n      if (dateNumber.length == 13) {\n        dateNumber = `2${dateNumber}`\n        fileName = `2${fileName}`\n      }\n\n      // Parse regex\n      const date = parseInt(dateNumber)\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file: fileName,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => requireContext(migration.file).default\n        })\n      }\n    })\n  }\n\n  /** @returns {Promise<void>} */\n  async loadMigrationsVersions() {\n    this.migrationsVersions = {}\n\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping loading migrations versions for it`)\n        continue\n      }\n\n      if (!await this.migrationsTableExist(db)) {\n        this.logger.log(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`)\n        continue\n      }\n\n      const rows = await db.select(\"schema_migrations\")\n\n      this.migrationsVersions[dbIdentifier] = {}\n\n      for (const row of rows) {\n        const version = digg(row, \"version\")\n\n        this.migrationsVersions[dbIdentifier][version] = true\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"./drivers/base.js\").default} db\n   * @returns {Promise<boolean>}\n   */\n  async migrationsTableExist(db) {\n    const schemaTable = await db.getTableByName(\"schema_migrations\", {throwError: false})\n\n    if (!schemaTable) return false\n\n    return true\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async executeRequireContext(requireContext) {\n    const migrationFiles = requireContext.keys()\n\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of migrationFiles) {\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName)\n\n      const migrationObject = /** @type {import(\"./migrator/types.js\").MigrationObjectType} */ ({\n        file,\n        date,\n        migrationClassName\n      })\n\n      files.push(migrationObject)\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    for (const migration of files) {\n      await this.runMigrationFile({\n        migration,\n        requireMigration: async () => requireContext(migration.file).default\n      })\n    }\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reset() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n\n      await db.withDisabledForeignKeys(async () => {\n        while (true) {\n          const errors = []\n          let anyTableDropped = false\n\n          try {\n            for (const table of await db.getTables()) {\n              this.logger.log(`Dropping table ${table.getName()}`)\n\n              try {\n                await db.dropTable(table.getName(), {cascade: true})\n                anyTableDropped = true\n              } catch (error) {\n                errors.push(error)\n              }\n            }\n\n            break\n          } catch (error) { // eslint-disable-line no-unused-vars\n            if (errors.length > 0 && anyTableDropped) {\n              // Retry\n            } else {\n              throw errors[0]\n            }\n          }\n        }\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback Function to import a file\n   * @returns {Promise<void>}\n   */\n  async rollback(files, importCallback) {\n    const latestMigrationVersion = await this._latestMigrationVersion()\n\n    if (!latestMigrationVersion) {\n      throw new Error(\"No migrations have been run yet\")\n    }\n\n    const latestMigrationVersionNumber = parseInt(latestMigrationVersion)\n    const migration = files.find((file) => file.date == latestMigrationVersionNumber)\n\n    if (!migration) {\n      throw new Error(`Migration file for version ${latestMigrationVersionNumber} not found`)\n    }\n\n    await this.runMigrationFile({\n      migration,\n      requireMigration: async () => {\n        if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n        return await importCallback(migration.fullPath)\n      },\n      direction: \"down\"\n    })\n  }\n\n  /**\n   * @returns {Promise<string | undefined>} The latest migration version\n   */\n  async _latestMigrationVersion() {\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    /** @type {string | undefined} */\n    let highestVersion\n\n    for (const dbIdentifier in this.migrationsVersions) {\n      for (const migrationVersion in this.migrationsVersions[dbIdentifier]) {\n        if (!highestVersion || migrationVersion > highestVersion) {\n          highestVersion = migrationVersion\n        }\n      }\n    }\n\n    return highestVersion\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"./migrator/types.js\").MigrationObjectType} args.migration\n   * @param {import(\"./migrator/types.js\").RequireMigrationType} args.requireMigration\n   * @param {string} [args.direction]\n   */\n  async runMigrationFile({migration, requireMigration, direction = \"up\"}) {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n    if (!this.configuration.isDatabasePoolInitialized()) await this.configuration.initializeDatabasePool()\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    const dbs = await this.configuration.getCurrentConnections()\n    const migrationClass = await requireMigration()\n\n    if (!migrationClass || typeof migrationClass !== \"function\") {\n      throw new Error(`Migration ${migration.file} must export a default migration class. Type: ${typeof migrationClass}`)\n    }\n\n    const migrationDatabaseIdentifiers = migrationClass.getDatabaseIdentifiers() || [\"default\"]\n\n    for (const dbIdentifier in dbs) {\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping migration ${digg(migration, \"date\")}`)\n        continue\n      }\n\n      if (!migrationDatabaseIdentifiers.includes(dbIdentifier)) {\n        this.logger.debug(`${dbIdentifier} shouldn't run migration ${migration.file}`, {migrationDatabaseIdentifiers})\n        continue\n      }\n\n      if (direction == \"up\") {\n        if (this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} has already run migration ${migration.file}`)\n          continue\n        }\n      } else if (direction == \"down\") {\n        if (!this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} hasn't run migration ${migration.file}`)\n          continue\n        }\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n\n      this.logger.debug(`Running migration on ${dbIdentifier}: ${migration.file}`, {migrationDatabaseIdentifiers})\n\n      const db = dbs[dbIdentifier]\n      const MigrationClass = migrationClass\n      const migrationInstance = new MigrationClass({\n        configuration: this.configuration,\n        databaseIdentifier: dbIdentifier,\n        db\n      })\n      const dateString = `${digg(migration, \"date\")}`\n\n      if (direction == \"up\") {\n        try {\n          await migrationInstance.change()\n        } catch (changeError) {\n          if (changeError instanceof NotImplementedError) {\n            try {\n              await migrationInstance.up()\n            } catch (upError) {\n              if (upError instanceof NotImplementedError) {\n                throw new Error(`'change' or 'up' didn't exist on migration: ${migration.file}`)\n              } else {\n                throw upError\n              }\n            }\n          } else {\n            throw changeError\n          }\n        }\n\n        const existingSchemaMigrations = await db.newQuery()\n          .from(\"schema_migrations\")\n          .where({version: dateString})\n          .results()\n\n        if (existingSchemaMigrations.length == 0) {\n          await db.insert({tableName: \"schema_migrations\", data: {version: dateString}})\n        }\n      } else if (direction == \"down\") {\n        try {\n          await migrationInstance.down()\n        } catch (downError) {\n          if (downError instanceof NotImplementedError) {\n            throw new Error(`'down' didn't exist on migration: ${migration.file} or migrating down with a change method isn't currently supported`)\n          } else {\n            throw downError\n          }\n        }\n\n        await db.delete({tableName: \"schema_migrations\", conditions: {version: dateString}})\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n    }\n  }\n}\n"]}
|
package/build/src/logger.d.ts
CHANGED
|
@@ -25,9 +25,21 @@ export class Logger {
|
|
|
25
25
|
*/
|
|
26
26
|
getConfiguration(): import("./configuration.js").default;
|
|
27
27
|
_configuration: any;
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
28
|
+
/**
|
|
29
|
+
* @param {any[]} messages
|
|
30
|
+
* @returns {Promise<void>}
|
|
31
|
+
*/
|
|
32
|
+
debug(...messages: any[]): Promise<void>;
|
|
33
|
+
/**
|
|
34
|
+
* @param {any[]} messages
|
|
35
|
+
* @returns {Promise<void>}
|
|
36
|
+
*/
|
|
37
|
+
log(...messages: any[]): Promise<void>;
|
|
38
|
+
/**
|
|
39
|
+
* @param {any[]} messages
|
|
40
|
+
* @returns {Promise<void>}
|
|
41
|
+
*/
|
|
42
|
+
error(...messages: any[]): Promise<void>;
|
|
31
43
|
/**
|
|
32
44
|
* @param {boolean} newValue
|
|
33
45
|
* @returns {void}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"AAqKA;;;GAGG;AACH,uCAHW,GAAG,eACA,UAAU,CAAC,OAAO,kBAAkB,CAAC,EAAA,iBASlD;AA9HD;;;GAGG;AACH,iDAHW,CAAG,GAAG,IAAC,MAAa,KAAK,CAAC,GAAG,CAAC,CAAA,GAAA,GAC5B,KAAK,CAAC,GAAG,CAAC,CAQtB;AA2BD;IACE;;;;OAIG;IACH,oBAJW,GAAG,2BAEX;QAAsB,KAAK,EAAnB,OAAO;KACjB,EAgBA;IAZC,gBAAmB;IAGjB,cAAsB;IAEtB,aAAqB;IASzB;;OAEG;IACH,oBAFa,OAAO,oBAAoB,EAAE,OAAO,CAQhD;IAJG,oBAA4E;IAMhF;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAMzB;IAED;;;OAGG;IACH,iBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,GAAG,EAAE,GACH,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;OAGG;IACH,mBAHW,OAAO,GACL,IAAI,CAIhB;IAGS,cAAU,UAAU,CAAC,OAAO,kBAAkB,CAAC,GAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CAK5E"}
|
package/build/src/logger.js
CHANGED
|
@@ -107,7 +107,8 @@ class Logger {
|
|
|
107
107
|
return this._configuration;
|
|
108
108
|
}
|
|
109
109
|
/**
|
|
110
|
-
* @
|
|
110
|
+
* @param {any[]} messages
|
|
111
|
+
* @returns {Promise<void>}
|
|
111
112
|
*/
|
|
112
113
|
async debug(...messages) {
|
|
113
114
|
if (this._debug || this.getConfiguration()?.debug) {
|
|
@@ -115,13 +116,15 @@ class Logger {
|
|
|
115
116
|
}
|
|
116
117
|
}
|
|
117
118
|
/**
|
|
118
|
-
* @
|
|
119
|
+
* @param {any[]} messages
|
|
120
|
+
* @returns {Promise<void>}
|
|
119
121
|
*/
|
|
120
122
|
async log(...messages) {
|
|
121
123
|
await consoleLog(messagesToMessage(this._subject, ...functionOrMessages(...messages)));
|
|
122
124
|
}
|
|
123
125
|
/**
|
|
124
|
-
* @
|
|
126
|
+
* @param {any[]} messages
|
|
127
|
+
* @returns {Promise<void>}
|
|
125
128
|
*/
|
|
126
129
|
async error(...messages) {
|
|
127
130
|
await consoleError(messagesToMessage(this._subject, ...functionOrMessages(...messages)));
|
|
@@ -152,4 +155,4 @@ export default async function logger(object, ...messages) {
|
|
|
152
155
|
await consoleLog(messagesToMessage(className, ...functionOrMessages(...messages)));
|
|
153
156
|
}
|
|
154
157
|
}
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,aAAa,MAAM,oBAAoB,CAAA;AAC9C,OAAO,aAAa,MAAM,4BAA4B,CAAA;AAEtD;;;GAGG;AACH,SAAS,UAAU,CAAC,OAAO;IACzB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACpB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,YAAY,CAAC,OAAO;IAC3B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACtB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,WAAW,CAAC,OAAO;IAC1B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACrB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,kBAAkB,CAAC,GAAG,QAAQ;IACrC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,QAAQ,CAAC,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC;QAC9D,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAA;IAC1B,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC;AAED;;;;GAIG;AACH,SAAS,iBAAiB,CAAC,GAAG,QAAQ;IACpC,IAAI,OAAO,GAAG,EAAE,CAAA;IAEhB,KAAK,MAAM,gBAAgB,IAAI,QAAQ,EAAE,CAAC;QACxC,MAAM,WAAW,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAA;QAE9C,IAAI,OAAO,gBAAgB,IAAI,QAAQ,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAChE,OAAO,IAAI,GAAG,CAAA;QAChB,CAAC;QAED,IAAI,OAAO,WAAW,IAAI,QAAQ,EAAE,CAAC;YACnC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,WAAW,CAAA;QACxB,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAA;AAChB,CAAC;AAED,MAAM,MAAM;IACV;;;;OAIG;IACH,YAAY,MAAM,EAAE,EAAC,KAAK,EAAE,GAAG,QAAQ,EAAC,GAAG,EAAC,KAAK,EAAE,KAAK,EAAC;QACvD,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QAEnB,IAAI,OAAO,MAAM,IAAI,QAAQ,EAAE,CAAC;YAC9B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAA;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;YACrB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAA;QACzC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;QACrC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,aAAa,CAAC,OAAO,EAAE,CAAA;QAC9E,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG,QAAQ;QACrB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,CAAC;YAClD,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAA;QAC7B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,GAAG,CAAC,GAAG,QAAQ;QACnB,MAAM,UAAU,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACxF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG,QAAQ;QACrB,MAAM,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC1F,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,QAAQ;QACf,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAA;IACxB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,IAAI,CAAC,GAAG,QAAQ;QACpB,MAAM,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACzF,CAAC;CACF;AAED,OAAO,EAAC,MAAM,EAAC,CAAA;AAEf;;;GAGG;AACH,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,MAAM,CAAC,MAAM,EAAE,GAAG,QAAQ;IACtD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAA;IACzC,MAAM,aAAa,GAAG,MAAM,CAAC,aAAa,IAAI,aAAa,CAAC,OAAO,EAAE,CAAA;IAErE,IAAI,aAAa,CAAC,KAAK,EAAE,CAAC;QACxB,MAAM,UAAU,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACpF,CAAC;AACH,CAAC","sourcesContent":["// @ts-check\n\nimport Configuration from \"./configuration.js\"\nimport restArgsError from \"./utils/rest-args-error.js\"\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleLog(message) {\n  return new Promise((resolve) => {\n    if (process.stdout) {\n      process.stdout.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.log(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleError(message) {\n  return new Promise((resolve) => {\n    if (process.stderr) {\n      process.stderr.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.error(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleWarn(message) {\n  return new Promise((resolve) => {\n    if (process.stderr) {\n      process.stderr.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.warn(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {...any|function() : Array<any>} messages\n * @returns {Array<any>} - Either the function result or the messages\n */\nfunction functionOrMessages(...messages) {\n  if (messages.length === 1 && typeof messages[0] == \"function\") {\n    messages = messages[0]()\n  }\n\n  return messages\n}\n\n/**\n * Converts multiple message parts into a single string.\n * @param {...any} messages - Parts to combine into a message\n * @returns {string}\n */\nfunction messagesToMessage(...messages) {\n  let message = \"\"\n\n  for (const messagePartIndex in messages) {\n    const messagePart = messages[messagePartIndex]\n\n    if (typeof messagePartIndex == \"number\" && messagePartIndex > 0) {\n      message += \" \"\n    }\n\n    if (typeof messagePart == \"object\") {\n      message += JSON.stringify(messagePart)\n    } else {\n      message += messagePart\n    }\n  }\n\n  return message\n}\n\nclass Logger {\n  /**\n   * @param {any} object\n   * @param {object} args\n   * @param {boolean} args.debug\n   */\n  constructor(object, {debug, ...restArgs} = {debug: false}) {\n    restArgsError(restArgs)\n\n    this._debug = debug\n\n    if (typeof object == \"string\") {\n      this._subject = object\n    } else {\n      this._object = object\n      this._subject = object.constructor.name\n    }\n\n    if (!this._subject) {\n      throw new Error(`No subject given`)\n    }\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default}\n   */\n  getConfiguration() {\n    if (!this._configuration) {\n      this._configuration = this._object?.configuration || Configuration.current()\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async debug(...messages) {\n    if (this._debug || this.getConfiguration()?.debug) {\n      await this.log(...messages)\n    }\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async log(...messages) {\n    await consoleLog(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async error(...messages) {\n    await consoleError(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n\n  /**\n   * @param {boolean} newValue\n   * @returns {void}\n   */\n  setDebug(newValue) {\n    this._debug = newValue\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async warn(...messages) {\n    await consoleWarn(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n}\n\nexport {Logger}\n\n/**\n * @param {any} object\n * @param {...Parameters<typeof functionOrMessages>} messages - forwarded args\n */\nexport default async function logger(object, ...messages) {\n  const className = object.constructor.name\n  const configuration = object.configuration || Configuration.current()\n\n  if (configuration.debug) {\n    await consoleLog(messagesToMessage(className, ...functionOrMessages(...messages)))\n  }\n}\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/logger.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,aAAa,MAAM,oBAAoB,CAAA;AAC9C,OAAO,aAAa,MAAM,4BAA4B,CAAA;AAEtD;;;GAGG;AACH,SAAS,UAAU,CAAC,OAAO;IACzB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YACpB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,YAAY,CAAC,OAAO;IAC3B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACtB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,WAAW,CAAC,OAAO;IAC1B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,OAAO,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAAA;QAC/D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACrB,OAAO,EAAE,CAAA;QACX,CAAC;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,kBAAkB,CAAC,GAAG,QAAQ;IACrC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,QAAQ,CAAC,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC;QAC9D,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAA;IAC1B,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC;AAED;;;;GAIG;AACH,SAAS,iBAAiB,CAAC,GAAG,QAAQ;IACpC,IAAI,OAAO,GAAG,EAAE,CAAA;IAEhB,KAAK,MAAM,gBAAgB,IAAI,QAAQ,EAAE,CAAC;QACxC,MAAM,WAAW,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAA;QAE9C,IAAI,OAAO,gBAAgB,IAAI,QAAQ,IAAI,gBAAgB,GAAG,CAAC,EAAE,CAAC;YAChE,OAAO,IAAI,GAAG,CAAA;QAChB,CAAC;QAED,IAAI,OAAO,WAAW,IAAI,QAAQ,EAAE,CAAC;YACnC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,WAAW,CAAA;QACxB,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAA;AAChB,CAAC;AAED,MAAM,MAAM;IACV;;;;OAIG;IACH,YAAY,MAAM,EAAE,EAAC,KAAK,EAAE,GAAG,QAAQ,EAAC,GAAG,EAAC,KAAK,EAAE,KAAK,EAAC;QACvD,aAAa,CAAC,QAAQ,CAAC,CAAA;QAEvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QAEnB,IAAI,OAAO,MAAM,IAAI,QAAQ,EAAE,CAAC;YAC9B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAA;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;YACrB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAA;QACzC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;QACrC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,aAAa,CAAC,OAAO,EAAE,CAAA;QAC9E,CAAC;QAED,OAAO,IAAI,CAAC,cAAc,CAAA;IAC5B,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG,QAAQ;QACrB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,KAAK,EAAE,CAAC;YAClD,MAAM,IAAI,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAA;QAC7B,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,GAAG,CAAC,GAAG,QAAQ;QACnB,MAAM,UAAU,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACxF,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG,QAAQ;QACrB,MAAM,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC1F,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,QAAQ;QACf,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAA;IACxB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,IAAI,CAAC,GAAG,QAAQ;QACpB,MAAM,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACzF,CAAC;CACF;AAED,OAAO,EAAC,MAAM,EAAC,CAAA;AAEf;;;GAGG;AACH,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,MAAM,CAAC,MAAM,EAAE,GAAG,QAAQ;IACtD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAA;IACzC,MAAM,aAAa,GAAG,MAAM,CAAC,aAAa,IAAI,aAAa,CAAC,OAAO,EAAE,CAAA;IAErE,IAAI,aAAa,CAAC,KAAK,EAAE,CAAC;QACxB,MAAM,UAAU,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,kBAAkB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACpF,CAAC;AACH,CAAC","sourcesContent":["// @ts-check\n\nimport Configuration from \"./configuration.js\"\nimport restArgsError from \"./utils/rest-args-error.js\"\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleLog(message) {\n  return new Promise((resolve) => {\n    if (process.stdout) {\n      process.stdout.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.log(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleError(message) {\n  return new Promise((resolve) => {\n    if (process.stderr) {\n      process.stderr.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.error(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {string} message\n * @returns {Promise<void>}\n */\nfunction consoleWarn(message) {\n  return new Promise((resolve) => {\n    if (process.stderr) {\n      process.stderr.write(`${message}\\n`, \"utf8\", () => resolve())\n    } else {\n      console.warn(message)\n      resolve()\n    }\n  })\n}\n\n/**\n * @param {...any|function() : Array<any>} messages\n * @returns {Array<any>} - Either the function result or the messages\n */\nfunction functionOrMessages(...messages) {\n  if (messages.length === 1 && typeof messages[0] == \"function\") {\n    messages = messages[0]()\n  }\n\n  return messages\n}\n\n/**\n * Converts multiple message parts into a single string.\n * @param {...any} messages - Parts to combine into a message\n * @returns {string}\n */\nfunction messagesToMessage(...messages) {\n  let message = \"\"\n\n  for (const messagePartIndex in messages) {\n    const messagePart = messages[messagePartIndex]\n\n    if (typeof messagePartIndex == \"number\" && messagePartIndex > 0) {\n      message += \" \"\n    }\n\n    if (typeof messagePart == \"object\") {\n      message += JSON.stringify(messagePart)\n    } else {\n      message += messagePart\n    }\n  }\n\n  return message\n}\n\nclass Logger {\n  /**\n   * @param {any} object\n   * @param {object} args\n   * @param {boolean} args.debug\n   */\n  constructor(object, {debug, ...restArgs} = {debug: false}) {\n    restArgsError(restArgs)\n\n    this._debug = debug\n\n    if (typeof object == \"string\") {\n      this._subject = object\n    } else {\n      this._object = object\n      this._subject = object.constructor.name\n    }\n\n    if (!this._subject) {\n      throw new Error(`No subject given`)\n    }\n  }\n\n  /**\n   * @returns {import(\"./configuration.js\").default}\n   */\n  getConfiguration() {\n    if (!this._configuration) {\n      this._configuration = this._object?.configuration || Configuration.current()\n    }\n\n    return this._configuration\n  }\n\n  /**\n   * @param {any[]} messages\n   * @returns {Promise<void>}\n   */\n  async debug(...messages) {\n    if (this._debug || this.getConfiguration()?.debug) {\n      await this.log(...messages)\n    }\n  }\n\n  /**\n   * @param {any[]} messages\n   * @returns {Promise<void>}\n   */\n  async log(...messages) {\n    await consoleLog(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n\n  /**\n   * @param {any[]} messages\n   * @returns {Promise<void>}\n   */\n  async error(...messages) {\n    await consoleError(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n\n  /**\n   * @param {boolean} newValue\n   * @returns {void}\n   */\n  setDebug(newValue) {\n    this._debug = newValue\n  }\n\n  /**\n   * @type {(...args: Parameters<typeof functionOrMessages>) => Promise<void>}\n   */\n  async warn(...messages) {\n    await consoleWarn(messagesToMessage(this._subject, ...functionOrMessages(...messages)))\n  }\n}\n\nexport {Logger}\n\n/**\n * @param {any} object\n * @param {...Parameters<typeof functionOrMessages>} messages - forwarded args\n */\nexport default async function logger(object, ...messages) {\n  const className = object.constructor.name\n  const configuration = object.configuration || Configuration.current()\n\n  if (configuration.debug) {\n    await consoleLog(messagesToMessage(className, ...functionOrMessages(...messages)))\n  }\n}\n"]}
|