velocious 1.0.173 → 1.0.175

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/build/src/application.d.ts.map +1 -1
  2. package/build/src/application.js +2 -1
  3. package/build/src/configuration-types.d.ts +5 -0
  4. package/build/src/configuration-types.d.ts.map +1 -1
  5. package/build/src/configuration-types.js +2 -1
  6. package/build/src/configuration.d.ts +12 -1
  7. package/build/src/configuration.d.ts.map +1 -1
  8. package/build/src/configuration.js +60 -5
  9. package/build/src/database/drivers/base.d.ts +10 -0
  10. package/build/src/database/drivers/base.d.ts.map +1 -1
  11. package/build/src/database/drivers/base.js +15 -1
  12. package/build/src/database/drivers/mssql/index.d.ts +1 -2
  13. package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
  14. package/build/src/database/drivers/mssql/index.js +26 -12
  15. package/build/src/database/drivers/mysql/index.d.ts +0 -4
  16. package/build/src/database/drivers/mysql/index.d.ts.map +1 -1
  17. package/build/src/database/drivers/mysql/index.js +9 -8
  18. package/build/src/database/drivers/pgsql/index.d.ts +0 -2
  19. package/build/src/database/drivers/pgsql/index.d.ts.map +1 -1
  20. package/build/src/database/drivers/pgsql/index.js +5 -2
  21. package/build/src/database/drivers/sqlite/index.d.ts +0 -1
  22. package/build/src/database/drivers/sqlite/index.d.ts.map +1 -1
  23. package/build/src/database/drivers/sqlite/index.native.d.ts +0 -2
  24. package/build/src/database/drivers/sqlite/index.native.d.ts.map +1 -1
  25. package/build/src/database/drivers/sqlite/index.web.d.ts +0 -1
  26. package/build/src/database/drivers/sqlite/index.web.d.ts.map +1 -1
  27. package/build/src/database/pool/async-tracked-multi-connection.d.ts.map +1 -1
  28. package/build/src/database/pool/async-tracked-multi-connection.js +26 -1
  29. package/build/src/database/pool/base.d.ts +10 -0
  30. package/build/src/database/pool/base.d.ts.map +1 -1
  31. package/build/src/database/pool/base.js +11 -1
  32. package/build/src/database/pool/single-multi-use.d.ts.map +1 -1
  33. package/build/src/database/pool/single-multi-use.js +17 -1
  34. package/build/src/environment-handlers/node/cli/commands/generate/base-models.d.ts.map +1 -1
  35. package/build/src/environment-handlers/node/cli/commands/generate/base-models.js +179 -177
  36. package/build/src/environment-handlers/node.d.ts.map +1 -1
  37. package/build/src/environment-handlers/node.js +3 -1
  38. package/build/src/http-server/client/request-runner.d.ts.map +1 -1
  39. package/build/src/http-server/client/request-runner.js +52 -2
  40. package/build/src/http-server/client/response.d.ts +16 -0
  41. package/build/src/http-server/client/response.d.ts.map +1 -1
  42. package/build/src/http-server/client/response.js +31 -1
  43. package/build/src/http-server/client/websocket-session.d.ts +1 -0
  44. package/build/src/http-server/client/websocket-session.d.ts.map +1 -1
  45. package/build/src/http-server/client/websocket-session.js +12 -3
  46. package/build/src/http-server/index.d.ts.map +1 -1
  47. package/build/src/http-server/index.js +8 -3
  48. package/build/src/http-server/worker-handler/index.d.ts +11 -0
  49. package/build/src/http-server/worker-handler/index.d.ts.map +1 -1
  50. package/build/src/http-server/worker-handler/index.js +41 -2
  51. package/build/src/http-server/worker-handler/worker-thread.d.ts.map +1 -1
  52. package/build/src/http-server/worker-handler/worker-thread.js +8 -1
  53. package/build/src/testing/format-value.d.ts.map +1 -1
  54. package/build/src/testing/format-value.js +7 -1
  55. package/build/src/testing/test.d.ts.map +1 -1
  56. package/build/src/testing/test.js +31 -1
  57. package/package.json +1 -1
@@ -15,217 +15,219 @@ export default class DbGenerateModel extends BaseCommand {
15
15
  if (!await fileExists(baseModelsDir)) {
16
16
  await fs.mkdir(baseModelsDir, { recursive: true });
17
17
  }
18
- for (const modelClassName in modelClasses) {
19
- const modelClass = modelClasses[modelClassName];
20
- const modelName = inflection.dasherize(modelClassName);
21
- const modelNameCamelized = inflection.camelize(modelName.replaceAll("-", "_"));
22
- const modelBaseFileName = `${inflection.dasherize(inflection.underscore(modelName))}.js`;
23
- const modelPath = `${baseModelsDir}/${modelBaseFileName}`;
24
- console.log(`create src/model-bases/${modelBaseFileName}`);
25
- const sourceModelFullFilePath = `${modelsDir}/${modelBaseFileName}`;
26
- let sourceModelFilePath;
27
- if (await fileExists(sourceModelFullFilePath)) {
28
- sourceModelFilePath = `../models/${modelBaseFileName}`;
29
- }
30
- else {
31
- sourceModelFilePath = "velocious/build/src/database/record/index.js";
32
- }
33
- let fileContent = "";
34
- let velociousPath;
35
- if (devMode) {
36
- velociousPath = "../../../../src";
37
- }
38
- else {
39
- velociousPath = "velocious/build/src";
40
- }
41
- fileContent += `import DatabaseRecord from "${velociousPath}/database/record/index.js"\n\n`;
42
- const hasManyRelationFilePath = `${velociousPath}/database/record/instance-relationships/has-many.js`;
43
- fileContent += `export default class ${modelNameCamelized}Base extends DatabaseRecord {\n`;
44
- // --- getModelClass() override (fixes polymorphic typing in JS/JSDoc) ---
45
- if (await fileExists(sourceModelFullFilePath)) {
46
- // Model file exists (e.g. src/models/ticket.js) → return typeof Ticket
47
- fileContent += " /**\n";
48
- fileContent += ` * @returns {typeof import("${sourceModelFilePath}").default}\n`;
49
- fileContent += " */\n";
50
- fileContent += " // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\n";
51
- fileContent += ` getModelClass() { return /** @type {typeof import("${sourceModelFilePath}").default} */ (this.constructor) }\n\n`;
52
- }
53
- else {
54
- // No model file yet → fall back to typeof TicketBase
55
- fileContent += " /**\n";
56
- fileContent += ` * @returns {typeof ${modelNameCamelized}Base}\n`;
57
- fileContent += " */\n";
58
- fileContent += " // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\n";
59
- fileContent += ` getModelClass() { return /** @type {typeof ${modelNameCamelized}Base} */ (this.constructor) }\n\n`;
60
- }
61
- const columns = await modelClass._getTable().getColumns();
62
- let methodsCount = 0;
63
- for (const column of columns) {
64
- const camelizedColumnName = inflection.camelize(column.getName(), true);
65
- const camelizedColumnNameBigFirst = inflection.camelize(column.getName());
66
- const jsdocType = this.jsDocTypeFromColumn(column);
67
- if (methodsCount > 0) {
68
- fileContent += "\n";
18
+ await this.getConfiguration().ensureConnections(async () => {
19
+ for (const modelClassName in modelClasses) {
20
+ const modelClass = modelClasses[modelClassName];
21
+ const modelName = inflection.dasherize(modelClassName);
22
+ const modelNameCamelized = inflection.camelize(modelName.replaceAll("-", "_"));
23
+ const modelBaseFileName = `${inflection.dasherize(inflection.underscore(modelName))}.js`;
24
+ const modelPath = `${baseModelsDir}/${modelBaseFileName}`;
25
+ console.log(`create src/model-bases/${modelBaseFileName}`);
26
+ const sourceModelFullFilePath = `${modelsDir}/${modelBaseFileName}`;
27
+ let sourceModelFilePath;
28
+ if (await fileExists(sourceModelFullFilePath)) {
29
+ sourceModelFilePath = `../models/${modelBaseFileName}`;
30
+ }
31
+ else {
32
+ sourceModelFilePath = "velocious/build/src/database/record/index.js";
69
33
  }
70
- if (jsdocType) {
34
+ let fileContent = "";
35
+ let velociousPath;
36
+ if (devMode) {
37
+ velociousPath = "../../../../src";
38
+ }
39
+ else {
40
+ velociousPath = "velocious/build/src";
41
+ }
42
+ fileContent += `import DatabaseRecord from "${velociousPath}/database/record/index.js"\n\n`;
43
+ const hasManyRelationFilePath = `${velociousPath}/database/record/instance-relationships/has-many.js`;
44
+ fileContent += `export default class ${modelNameCamelized}Base extends DatabaseRecord {\n`;
45
+ // --- getModelClass() override (fixes polymorphic typing in JS/JSDoc) ---
46
+ if (await fileExists(sourceModelFullFilePath)) {
47
+ // Model file exists (e.g. src/models/ticket.js) → return typeof Ticket
71
48
  fileContent += " /**\n";
72
- fileContent += ` * @returns {${jsdocType}${column.getNull() ? " | null" : ""}}\n`;
49
+ fileContent += ` * @returns {typeof import("${sourceModelFilePath}").default}\n`;
73
50
  fileContent += " */\n";
51
+ fileContent += " // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\n";
52
+ fileContent += ` getModelClass() { return /** @type {typeof import("${sourceModelFilePath}").default} */ (this.constructor) }\n\n`;
74
53
  }
75
- fileContent += ` ${camelizedColumnName}() { return this.readAttribute("${camelizedColumnName}") }\n\n`;
76
- const setterJsdocType = this.jsDocSetterTypeFromColumn(column);
77
- if (setterJsdocType) {
54
+ else {
55
+ // No model file yet → fall back to typeof TicketBase
78
56
  fileContent += " /**\n";
79
- fileContent += ` * @param {${setterJsdocType}${column.getNull() ? " | null" : ""}} newValue\n`;
80
- fileContent += " * @returns {void}\n";
57
+ fileContent += ` * @returns {typeof ${modelNameCamelized}Base}\n`;
81
58
  fileContent += " */\n";
59
+ fileContent += " // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\n";
60
+ fileContent += ` getModelClass() { return /** @type {typeof ${modelNameCamelized}Base} */ (this.constructor) }\n\n`;
82
61
  }
83
- fileContent += ` set${camelizedColumnNameBigFirst}(newValue) { return this._setColumnAttribute("${camelizedColumnName}", newValue) }\n\n`;
84
- fileContent += " /**\n";
85
- fileContent += " * @returns {boolean}\n";
86
- fileContent += " */\n";
87
- fileContent += ` has${camelizedColumnNameBigFirst}() { return this._hasAttribute(this.${camelizedColumnName}()) }\n`;
88
- methodsCount++;
89
- }
90
- if (modelClass._translations) {
91
- const TranslationClass = modelClass.getTranslationClass();
92
- const translationColumns = TranslationClass.getColumns();
93
- for (const name in modelClass._translations) {
94
- const nameUnderscore = inflection.underscore(name);
95
- const column = translationColumns.find((translationColumn) => translationColumn.getName() === nameUnderscore);
96
- let translationJsdocType;
97
- if (column) {
98
- translationJsdocType = this.jsDocTypeFromColumn(column);
62
+ const columns = await modelClass._getTable().getColumns();
63
+ let methodsCount = 0;
64
+ for (const column of columns) {
65
+ const camelizedColumnName = inflection.camelize(column.getName(), true);
66
+ const camelizedColumnNameBigFirst = inflection.camelize(column.getName());
67
+ const jsdocType = this.jsDocTypeFromColumn(column);
68
+ if (methodsCount > 0) {
69
+ fileContent += "\n";
99
70
  }
100
- if (translationJsdocType) {
101
- fileContent += `\n`;
71
+ if (jsdocType) {
102
72
  fileContent += " /**\n";
103
- fileContent += ` * @returns {${translationJsdocType}${column.getNull() ? " | null" : ""}}\n`;
73
+ fileContent += ` * @returns {${jsdocType}${column.getNull() ? " | null" : ""}}\n`;
104
74
  fileContent += " */\n";
105
75
  }
106
- fileContent += ` ${name}() { return this._getTranslatedAttributeWithFallback("${name}", this._getConfiguration().getLocale()) ?? null }\n`;
107
- methodsCount++;
108
- const hasName = `has${inflection.camelize(name)}`;
109
- fileContent += `\n`;
76
+ fileContent += ` ${camelizedColumnName}() { return this.readAttribute("${camelizedColumnName}") }\n\n`;
77
+ const setterJsdocType = this.jsDocSetterTypeFromColumn(column);
78
+ if (setterJsdocType) {
79
+ fileContent += " /**\n";
80
+ fileContent += ` * @param {${setterJsdocType}${column.getNull() ? " | null" : ""}} newValue\n`;
81
+ fileContent += " * @returns {void}\n";
82
+ fileContent += " */\n";
83
+ }
84
+ fileContent += ` set${camelizedColumnNameBigFirst}(newValue) { return this._setColumnAttribute("${camelizedColumnName}", newValue) }\n\n`;
110
85
  fileContent += " /**\n";
111
- fileContent += ` * @abstract\n`;
112
- fileContent += ` * @returns {boolean}\n`;
86
+ fileContent += " * @returns {boolean}\n";
113
87
  fileContent += " */\n";
114
- fileContent += ` ${hasName}() { throw new Error("${hasName} not implemented") }\n`;
88
+ fileContent += ` has${camelizedColumnNameBigFirst}() { return this._hasAttribute(this.${camelizedColumnName}()) }\n`;
115
89
  methodsCount++;
116
- for (const locale of this.getConfiguration().getLocales()) {
117
- const localeMethodName = `${name}${inflection.camelize(locale)}`;
90
+ }
91
+ if (modelClass._translations) {
92
+ const TranslationClass = modelClass.getTranslationClass();
93
+ const translationColumns = TranslationClass.getColumns();
94
+ for (const name in modelClass._translations) {
95
+ const nameUnderscore = inflection.underscore(name);
96
+ const column = translationColumns.find((translationColumn) => translationColumn.getName() === nameUnderscore);
97
+ let translationJsdocType;
98
+ if (column) {
99
+ translationJsdocType = this.jsDocTypeFromColumn(column);
100
+ }
118
101
  if (translationJsdocType) {
119
102
  fileContent += `\n`;
120
103
  fileContent += " /**\n";
121
104
  fileContent += ` * @returns {${translationJsdocType}${column.getNull() ? " | null" : ""}}\n`;
122
105
  fileContent += " */\n";
123
106
  }
124
- fileContent += ` ${localeMethodName}() { return this._getTranslatedAttributeWithFallback("${name}", "${locale}") ?? null }\n`;
107
+ fileContent += ` ${name}() { return this._getTranslatedAttributeWithFallback("${name}", this._getConfiguration().getLocale()) ?? null }\n`;
125
108
  methodsCount++;
126
- const localeHasName = `has${inflection.camelize(localeMethodName)}`;
109
+ const hasName = `has${inflection.camelize(name)}`;
127
110
  fileContent += `\n`;
128
111
  fileContent += " /**\n";
129
112
  fileContent += ` * @abstract\n`;
130
113
  fileContent += ` * @returns {boolean}\n`;
131
114
  fileContent += " */\n";
132
- fileContent += ` ${localeHasName}() { throw new Error("${localeHasName} not implemented") }\n`;
115
+ fileContent += ` ${hasName}() { throw new Error("${hasName} not implemented") }\n`;
133
116
  methodsCount++;
117
+ for (const locale of this.getConfiguration().getLocales()) {
118
+ const localeMethodName = `${name}${inflection.camelize(locale)}`;
119
+ if (translationJsdocType) {
120
+ fileContent += `\n`;
121
+ fileContent += " /**\n";
122
+ fileContent += ` * @returns {${translationJsdocType}${column.getNull() ? " | null" : ""}}\n`;
123
+ fileContent += " */\n";
124
+ }
125
+ fileContent += ` ${localeMethodName}() { return this._getTranslatedAttributeWithFallback("${name}", "${locale}") ?? null }\n`;
126
+ methodsCount++;
127
+ const localeHasName = `has${inflection.camelize(localeMethodName)}`;
128
+ fileContent += `\n`;
129
+ fileContent += " /**\n";
130
+ fileContent += ` * @abstract\n`;
131
+ fileContent += ` * @returns {boolean}\n`;
132
+ fileContent += " */\n";
133
+ fileContent += ` ${localeHasName}() { throw new Error("${localeHasName} not implemented") }\n`;
134
+ methodsCount++;
135
+ }
134
136
  }
135
137
  }
136
- }
137
- for (const relationship of modelClass.getRelationships()) {
138
- let baseFilePath, baseFullFilePath, fileName, fullFilePath;
139
- if (relationship.getPolymorphic()) {
140
- fileName = "velocious/build/src/database/record/index.js";
141
- }
142
- else {
143
- fileName = inflection.dasherize(inflection.underscore(relationship.getTargetModelClass().name));
144
- fullFilePath = `src/models/${fileName}.js`;
145
- baseFilePath = `../model-bases/${fileName}.js`;
146
- baseFullFilePath = `src/model-bases/${fileName}.js`;
147
- }
148
- if (methodsCount > 0) {
149
- fileContent += "\n";
150
- }
151
- if (relationship.getType() == "belongsTo" || relationship.getType() == "hasOne") {
152
- let modelFilePath;
153
- if (fullFilePath && await fileExists(fullFilePath)) {
154
- modelFilePath = `../models/${fileName}.js`;
155
- }
156
- else if (baseFullFilePath && await fileExists(baseFullFilePath)) {
157
- modelFilePath = baseFilePath;
138
+ for (const relationship of modelClass.getRelationships()) {
139
+ let baseFilePath, baseFullFilePath, fileName, fullFilePath;
140
+ if (relationship.getPolymorphic()) {
141
+ fileName = "velocious/build/src/database/record/index.js";
158
142
  }
159
143
  else {
160
- modelFilePath = "velocious/build/src/database/record/index.js";
144
+ fileName = inflection.dasherize(inflection.underscore(relationship.getTargetModelClass().name));
145
+ fullFilePath = `src/models/${fileName}.js`;
146
+ baseFilePath = `../model-bases/${fileName}.js`;
147
+ baseFullFilePath = `src/model-bases/${fileName}.js`;
161
148
  }
162
- fileContent += " /**\n";
163
- fileContent += ` * @returns {import("${modelFilePath}").default}\n`;
164
- fileContent += " */\n";
165
- fileContent += ` ${relationship.getRelationshipName()}() { return /** @type {import("${modelFilePath}").default} */ (this.getRelationshipByName("${relationship.getRelationshipName()}").loaded()) }\n`;
166
- fileContent += "\n";
167
- fileContent += " /**\n";
168
- fileContent += " * @abstract\n";
169
- fileContent += " * @param {Record<string, any>} [attributes]\n";
170
- fileContent += ` * @returns {import("${modelFilePath}").default}\n`;
171
- fileContent += " */\n";
172
- fileContent += ` build${inflection.camelize(relationship.getRelationshipName())}(attributes) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
173
- fileContent += "\n";
174
- fileContent += " /**\n";
175
- fileContent += " * @abstract\n";
176
- fileContent += " * @returns {Promise<void>}\n";
177
- fileContent += " */\n";
178
- fileContent += ` load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error("Not implemented") }\n`;
179
- fileContent += "\n";
180
- fileContent += " /**\n";
181
- fileContent += " * @abstract\n";
182
- fileContent += ` * @param {import("${modelFilePath}").default} newModel\n`;
183
- fileContent += ` * @returns {void}\n`;
184
- fileContent += " */\n";
185
- fileContent += ` set${inflection.camelize(relationship.getRelationshipName())}(newModel) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
186
- }
187
- else if (relationship.getType() == "hasMany") {
188
- let recordImport;
189
- if (fullFilePath && await fileExists(fullFilePath)) {
190
- recordImport = `../models/${fileName}.js`;
149
+ if (methodsCount > 0) {
150
+ fileContent += "\n";
191
151
  }
192
- else if (baseFullFilePath && await fileExists(baseFullFilePath)) {
193
- recordImport = `../model-bases/${fileName}.js`;
152
+ if (relationship.getType() == "belongsTo" || relationship.getType() == "hasOne") {
153
+ let modelFilePath;
154
+ if (fullFilePath && await fileExists(fullFilePath)) {
155
+ modelFilePath = `../models/${fileName}.js`;
156
+ }
157
+ else if (baseFullFilePath && await fileExists(baseFullFilePath)) {
158
+ modelFilePath = baseFilePath;
159
+ }
160
+ else {
161
+ modelFilePath = "velocious/build/src/database/record/index.js";
162
+ }
163
+ fileContent += " /**\n";
164
+ fileContent += ` * @returns {import("${modelFilePath}").default}\n`;
165
+ fileContent += " */\n";
166
+ fileContent += ` ${relationship.getRelationshipName()}() { return /** @type {import("${modelFilePath}").default} */ (this.getRelationshipByName("${relationship.getRelationshipName()}").loaded()) }\n`;
167
+ fileContent += "\n";
168
+ fileContent += " /**\n";
169
+ fileContent += " * @abstract\n";
170
+ fileContent += " * @param {Record<string, any>} [attributes]\n";
171
+ fileContent += ` * @returns {import("${modelFilePath}").default}\n`;
172
+ fileContent += " */\n";
173
+ fileContent += ` build${inflection.camelize(relationship.getRelationshipName())}(attributes) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
174
+ fileContent += "\n";
175
+ fileContent += " /**\n";
176
+ fileContent += " * @abstract\n";
177
+ fileContent += " * @returns {Promise<void>}\n";
178
+ fileContent += " */\n";
179
+ fileContent += ` load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error("Not implemented") }\n`;
180
+ fileContent += "\n";
181
+ fileContent += " /**\n";
182
+ fileContent += " * @abstract\n";
183
+ fileContent += ` * @param {import("${modelFilePath}").default} newModel\n`;
184
+ fileContent += ` * @returns {void}\n`;
185
+ fileContent += " */\n";
186
+ fileContent += ` set${inflection.camelize(relationship.getRelationshipName())}(newModel) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
187
+ }
188
+ else if (relationship.getType() == "hasMany") {
189
+ let recordImport;
190
+ if (fullFilePath && await fileExists(fullFilePath)) {
191
+ recordImport = `../models/${fileName}.js`;
192
+ }
193
+ else if (baseFullFilePath && await fileExists(baseFullFilePath)) {
194
+ recordImport = `../model-bases/${fileName}.js`;
195
+ }
196
+ else {
197
+ recordImport = `${velociousPath}/database/record/index.js`;
198
+ }
199
+ fileContent += " /**\n";
200
+ fileContent += ` * @returns {import("${hasManyRelationFilePath}").default<typeof import("${sourceModelFilePath}").default, typeof import("${recordImport}").default>}\n`;
201
+ fileContent += " */\n";
202
+ fileContent += ` ${relationship.getRelationshipName()}() { return /** @type {import("${hasManyRelationFilePath}").default<typeof import("${sourceModelFilePath}").default, typeof import("${recordImport}").default>} */ (this.getRelationshipByName("${relationship.getRelationshipName()}")) }\n`;
203
+ fileContent += "\n";
204
+ fileContent += " /**\n";
205
+ fileContent += ` * @returns {Array<import("${recordImport}").default>}\n`;
206
+ fileContent += " */\n";
207
+ fileContent += ` ${relationship.getRelationshipName()}Loaded() { return /** @type {Array<import("${recordImport}").default>} */ (this.getRelationshipByName("${relationship.getRelationshipName()}").loaded()) }\n`;
208
+ fileContent += "\n";
209
+ fileContent += " /**\n";
210
+ fileContent += " * @abstract\n";
211
+ fileContent += " * @returns {Promise<void>}\n";
212
+ fileContent += " */\n";
213
+ fileContent += ` load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error("Not implemented") }\n`;
214
+ fileContent += "\n";
215
+ fileContent += " /**\n";
216
+ fileContent += " * @abstract\n";
217
+ fileContent += ` * @param {Array<import("${recordImport}").default>} newModels\n`;
218
+ fileContent += " * @returns {void}\n";
219
+ fileContent += " */\n";
220
+ fileContent += ` set${inflection.camelize(relationship.getRelationshipName())}(newModels) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
194
221
  }
195
222
  else {
196
- recordImport = `${velociousPath}/database/record/index.js`;
223
+ throw new Error(`Unknown relationship type: ${relationship.getType()}`);
197
224
  }
198
- fileContent += " /**\n";
199
- fileContent += ` * @returns {import("${hasManyRelationFilePath}").default<typeof import("${sourceModelFilePath}").default, typeof import("${recordImport}").default>}\n`;
200
- fileContent += " */\n";
201
- fileContent += ` ${relationship.getRelationshipName()}() { return /** @type {import("${hasManyRelationFilePath}").default<typeof import("${sourceModelFilePath}").default, typeof import("${recordImport}").default>} */ (this.getRelationshipByName("${relationship.getRelationshipName()}")) }\n`;
202
- fileContent += "\n";
203
- fileContent += " /**\n";
204
- fileContent += ` * @returns {Array<import("${recordImport}").default>}\n`;
205
- fileContent += " */\n";
206
- fileContent += ` ${relationship.getRelationshipName()}Loaded() { return /** @type {Array<import("${recordImport}").default>} */ (this.getRelationshipByName("${relationship.getRelationshipName()}").loaded()) }\n`;
207
- fileContent += "\n";
208
- fileContent += " /**\n";
209
- fileContent += " * @abstract\n";
210
- fileContent += " * @returns {Promise<void>}\n";
211
- fileContent += " */\n";
212
- fileContent += ` load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error("Not implemented") }\n`;
213
- fileContent += "\n";
214
- fileContent += " /**\n";
215
- fileContent += " * @abstract\n";
216
- fileContent += ` * @param {Array<import("${recordImport}").default>} newModels\n`;
217
- fileContent += " * @returns {void}\n";
218
- fileContent += " */\n";
219
- fileContent += ` set${inflection.camelize(relationship.getRelationshipName())}(newModels) { throw new Error("Not implemented") } // eslint-disable-line no-unused-vars\n`;
220
- }
221
- else {
222
- throw new Error(`Unknown relationship type: ${relationship.getType()}`);
225
+ methodsCount++;
223
226
  }
224
- methodsCount++;
227
+ fileContent += "}\n";
228
+ await fs.writeFile(modelPath, fileContent);
225
229
  }
226
- fileContent += "}\n";
227
- await fs.writeFile(modelPath, fileContent);
228
- }
230
+ });
229
231
  }
230
232
  /**
231
233
  * @param {import("../../../../../database/drivers/base-column.js").default} column - Column.
@@ -239,13 +241,13 @@ export default class DbGenerateModel extends BaseCommand {
239
241
  else if (type == "json") {
240
242
  return "Record<string, any>";
241
243
  }
242
- else if (["blob", "char", "nvarchar", "varchar", "text", "longtext", "uuid"].includes(type)) {
244
+ else if (["blob", "char", "nvarchar", "varchar", "text", "longtext", "uuid", "character varying"].includes(type)) {
243
245
  return "string";
244
246
  }
245
247
  else if (["bit", "bigint", "float", "int", "integer", "smallint", "tinyint"].includes(type)) {
246
248
  return "number";
247
249
  }
248
- else if (["date", "datetime"].includes(type)) {
250
+ else if (["date", "datetime", "timestamp without time zone"].includes(type)) {
249
251
  return "Date";
250
252
  }
251
253
  else {
@@ -258,10 +260,10 @@ export default class DbGenerateModel extends BaseCommand {
258
260
  */
259
261
  jsDocSetterTypeFromColumn(column) {
260
262
  const type = column.getType();
261
- if (["date", "datetime"].includes(type)) {
263
+ if (["date", "datetime", "timestamp without time zone"].includes(type)) {
262
264
  return "Date | string";
263
265
  }
264
266
  return this.jsDocTypeFromColumn(column);
265
267
  }
266
268
  }
267
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-models.js","sourceRoot":"","sources":["../../../../../../../src/environment-handlers/node/cli/commands/generate/base-models.js"],"names":[],"mappings":"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","sourcesContent":["import BaseCommand from \"../../../../../cli/base-command.js\"\nimport fileExists from \"../../../../../utils/file-exists.js\"\nimport fs from \"fs/promises\"\nimport * as inflection from \"inflection\"\n\nexport default class DbGenerateModel extends BaseCommand {\n  async execute() {\n    await this.getConfiguration().initializeModels()\n\n    const modelsDir = `${process.cwd()}/src/models`\n    const baseModelsDir = `${process.cwd()}/src/model-bases`\n    const modelClasses = this.getConfiguration().getModelClasses()\n    let devMode = false\n\n    if (baseModelsDir.includes(\"/spec/dummy/src/model-bases\")) {\n      devMode = true\n    }\n\n    if (!await fileExists(baseModelsDir)) {\n      await fs.mkdir(baseModelsDir, {recursive: true})\n    }\n\n    for (const modelClassName in modelClasses) {\n      const modelClass = modelClasses[modelClassName]\n      const modelName = inflection.dasherize(modelClassName)\n      const modelNameCamelized = inflection.camelize(modelName.replaceAll(\"-\", \"_\"))\n      const modelBaseFileName = `${inflection.dasherize(inflection.underscore(modelName))}.js`\n      const modelPath = `${baseModelsDir}/${modelBaseFileName}`\n\n      console.log(`create src/model-bases/${modelBaseFileName}`)\n\n      const sourceModelFullFilePath = `${modelsDir}/${modelBaseFileName}`\n      let sourceModelFilePath\n\n      if (await fileExists(sourceModelFullFilePath)) {\n        sourceModelFilePath = `../models/${modelBaseFileName}`\n      } else {\n        sourceModelFilePath = \"velocious/build/src/database/record/index.js\"\n      }\n\n      let fileContent = \"\"\n      let velociousPath\n\n      if (devMode) {\n        velociousPath = \"../../../../src\"\n      } else {\n        velociousPath = \"velocious/build/src\"\n      }\n\n      fileContent += `import DatabaseRecord from \"${velociousPath}/database/record/index.js\"\\n\\n`\n\n      const hasManyRelationFilePath = `${velociousPath}/database/record/instance-relationships/has-many.js`\n\n      fileContent += `export default class ${modelNameCamelized}Base extends DatabaseRecord {\\n`\n\n      // --- getModelClass() override (fixes polymorphic typing in JS/JSDoc) ---\n      if (await fileExists(sourceModelFullFilePath)) {\n        // Model file exists (e.g. src/models/ticket.js) → return typeof Ticket\n        fileContent += \"  /**\\n\"\n        fileContent += `   * @returns {typeof import(\"${sourceModelFilePath}\").default}\\n`\n        fileContent += \"   */\\n\"\n        fileContent += \"  // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\\n\"\n        fileContent += `  getModelClass() { return /** @type {typeof import(\"${sourceModelFilePath}\").default} */ (this.constructor) }\\n\\n`\n      } else {\n        // No model file yet → fall back to typeof TicketBase\n        fileContent += \"  /**\\n\"\n        fileContent += `   * @returns {typeof ${modelNameCamelized}Base}\\n`\n        fileContent += \"   */\\n\"\n        fileContent += \"  // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\\n\"\n        fileContent += `  getModelClass() { return /** @type {typeof ${modelNameCamelized}Base} */ (this.constructor) }\\n\\n`\n      }\n\n      const columns = await modelClass._getTable().getColumns()\n      let methodsCount = 0\n\n      for (const column of columns) {\n        const camelizedColumnName = inflection.camelize(column.getName(), true)\n        const camelizedColumnNameBigFirst = inflection.camelize(column.getName())\n        const jsdocType = this.jsDocTypeFromColumn(column)\n\n        if (methodsCount > 0) {\n          fileContent += \"\\n\"\n        }\n\n        if (jsdocType) {\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {${jsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n          fileContent += \"   */\\n\"\n        }\n\n        fileContent += `  ${camelizedColumnName}() { return this.readAttribute(\"${camelizedColumnName}\") }\\n\\n`\n\n        const setterJsdocType = this.jsDocSetterTypeFromColumn(column)\n\n        if (setterJsdocType) {\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @param {${setterJsdocType}${column.getNull() ? \" | null\" : \"\"}} newValue\\n`\n          fileContent += \"   * @returns {void}\\n\"\n          fileContent += \"   */\\n\"\n        }\n\n        fileContent += `  set${camelizedColumnNameBigFirst}(newValue) { return this._setColumnAttribute(\"${camelizedColumnName}\", newValue) }\\n\\n`\n\n        fileContent += \"  /**\\n\"\n        fileContent += \"   * @returns {boolean}\\n\"\n        fileContent += \"   */\\n\"\n        fileContent += `  has${camelizedColumnNameBigFirst}() { return this._hasAttribute(this.${camelizedColumnName}()) }\\n`\n\n        methodsCount++\n      }\n\n      if (modelClass._translations) {\n        const TranslationClass = modelClass.getTranslationClass()\n        const translationColumns = TranslationClass.getColumns()\n\n        for (const name in modelClass._translations) {\n          const nameUnderscore = inflection.underscore(name)\n          const column = translationColumns.find((translationColumn) => translationColumn.getName() === nameUnderscore)\n          let translationJsdocType\n\n          if (column) {\n            translationJsdocType = this.jsDocTypeFromColumn(column)\n          }\n\n          if (translationJsdocType) {\n            fileContent += `\\n`\n            fileContent += \"  /**\\n\"\n            fileContent += `   * @returns {${translationJsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n            fileContent += \"   */\\n\"\n          }\n\n          fileContent += `  ${name}() { return this._getTranslatedAttributeWithFallback(\"${name}\", this._getConfiguration().getLocale()) ?? null }\\n`\n          methodsCount++\n\n          const hasName = `has${inflection.camelize(name)}`\n\n          fileContent += `\\n`\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @abstract\\n`\n          fileContent += `   * @returns {boolean}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${hasName}() { throw new Error(\"${hasName} not implemented\") }\\n`\n          methodsCount++\n\n          for (const locale of this.getConfiguration().getLocales()) {\n            const localeMethodName = `${name}${inflection.camelize(locale)}`\n\n            if (translationJsdocType) {\n              fileContent += `\\n`\n              fileContent += \"  /**\\n\"\n              fileContent += `   * @returns {${translationJsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n              fileContent += \"   */\\n\"\n            }\n\n            fileContent += `  ${localeMethodName}() { return this._getTranslatedAttributeWithFallback(\"${name}\", \"${locale}\") ?? null }\\n`\n            methodsCount++\n\n            const localeHasName = `has${inflection.camelize(localeMethodName)}`\n\n            fileContent += `\\n`\n            fileContent += \"  /**\\n\"\n            fileContent += `   * @abstract\\n`\n            fileContent += `   * @returns {boolean}\\n`\n            fileContent += \"   */\\n\"\n            fileContent += `  ${localeHasName}() { throw new Error(\"${localeHasName} not implemented\") }\\n`\n            methodsCount++\n          }\n        }\n      }\n\n      for (const relationship of modelClass.getRelationships()) {\n        let baseFilePath, baseFullFilePath, fileName, fullFilePath\n\n        if (relationship.getPolymorphic()) {\n          fileName = \"velocious/build/src/database/record/index.js\"\n        } else {\n          fileName = inflection.dasherize(inflection.underscore(relationship.getTargetModelClass().name))\n          fullFilePath = `src/models/${fileName}.js`\n          baseFilePath = `../model-bases/${fileName}.js`\n          baseFullFilePath = `src/model-bases/${fileName}.js`\n        }\n\n        if (methodsCount > 0) {\n          fileContent += \"\\n\"\n        }\n\n        if (relationship.getType() == \"belongsTo\" || relationship.getType() == \"hasOne\") {\n          let modelFilePath\n\n          if (fullFilePath && await fileExists(fullFilePath)) {\n            modelFilePath = `../models/${fileName}.js`\n          } else if (baseFullFilePath && await fileExists(baseFullFilePath)) {\n            modelFilePath = baseFilePath\n          } else {\n            modelFilePath = \"velocious/build/src/database/record/index.js\"\n          }\n\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {import(\"${modelFilePath}\").default}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}() { return /** @type {import(\"${modelFilePath}\").default} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\").loaded()) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @param {Record<string, any>} [attributes]\\n\"\n          fileContent += `   * @returns {import(\"${modelFilePath}\").default}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  build${inflection.camelize(relationship.getRelationshipName())}(attributes) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @returns {Promise<void>}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error(\"Not implemented\") }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += `   * @param {import(\"${modelFilePath}\").default} newModel\\n`\n          fileContent += `   * @returns {void}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  set${inflection.camelize(relationship.getRelationshipName())}(newModel) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n        } else if (relationship.getType() == \"hasMany\") {\n          let recordImport\n\n          if (fullFilePath && await fileExists(fullFilePath)) {\n            recordImport = `../models/${fileName}.js`\n          } else if (baseFullFilePath && await fileExists(baseFullFilePath)) {\n            recordImport = `../model-bases/${fileName}.js`\n          } else {\n            recordImport = `${velociousPath}/database/record/index.js`\n          }\n\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {import(\"${hasManyRelationFilePath}\").default<typeof import(\"${sourceModelFilePath}\").default, typeof import(\"${recordImport}\").default>}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}() { return /** @type {import(\"${hasManyRelationFilePath}\").default<typeof import(\"${sourceModelFilePath}\").default, typeof import(\"${recordImport}\").default>} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\")) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {Array<import(\"${recordImport}\").default>}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}Loaded() { return /** @type {Array<import(\"${recordImport}\").default>} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\").loaded()) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @returns {Promise<void>}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error(\"Not implemented\") }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += `   * @param {Array<import(\"${recordImport}\").default>} newModels\\n`\n          fileContent += \"   * @returns {void}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  set${inflection.camelize(relationship.getRelationshipName())}(newModels) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n        } else {\n          throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n        }\n\n        methodsCount++\n      }\n\n      fileContent += \"}\\n\"\n\n      await fs.writeFile(modelPath, fileContent)\n    }\n  }\n\n  /**\n   * @param {import(\"../../../../../database/drivers/base-column.js\").default} column - Column.\n   * @returns {string | undefined} - The js doc type from column.\n   */\n  jsDocTypeFromColumn(column) {\n    const type = column.getType()\n\n    if (type == \"boolean\") {\n      return \"boolean\"\n    } else if (type == \"json\") {\n      return \"Record<string, any>\"\n    } else if ([\"blob\", \"char\", \"nvarchar\", \"varchar\", \"text\", \"longtext\", \"uuid\"].includes(type)) {\n      return \"string\"\n    } else if ([\"bit\", \"bigint\", \"float\", \"int\", \"integer\", \"smallint\", \"tinyint\"].includes(type)) {\n      return \"number\"\n    } else if ([\"date\", \"datetime\"].includes(type)) {\n      return \"Date\"\n    } else {\n      console.error(`Unknown column type: ${type}`)\n    }\n  }\n\n  /**\n   * @param {import(\"../../../../../database/drivers/base-column.js\").default} column - Column.\n   * @returns {string | undefined} - The js doc setter type from column.\n   */\n  jsDocSetterTypeFromColumn(column) {\n    const type = column.getType()\n\n    if ([\"date\", \"datetime\"].includes(type)) {\n      return \"Date | string\"\n    }\n\n    return this.jsDocTypeFromColumn(column)\n  }\n}\n"]}
269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-models.js","sourceRoot":"","sources":["../../../../../../../src/environment-handlers/node/cli/commands/generate/base-models.js"],"names":[],"mappings":"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","sourcesContent":["import BaseCommand from \"../../../../../cli/base-command.js\"\nimport fileExists from \"../../../../../utils/file-exists.js\"\nimport fs from \"fs/promises\"\nimport * as inflection from \"inflection\"\n\nexport default class DbGenerateModel extends BaseCommand {\n  async execute() {\n    await this.getConfiguration().initializeModels()\n\n    const modelsDir = `${process.cwd()}/src/models`\n    const baseModelsDir = `${process.cwd()}/src/model-bases`\n    const modelClasses = this.getConfiguration().getModelClasses()\n    let devMode = false\n\n    if (baseModelsDir.includes(\"/spec/dummy/src/model-bases\")) {\n      devMode = true\n    }\n\n    if (!await fileExists(baseModelsDir)) {\n      await fs.mkdir(baseModelsDir, {recursive: true})\n    }\n\n    await this.getConfiguration().ensureConnections(async () => {\n      for (const modelClassName in modelClasses) {\n        const modelClass = modelClasses[modelClassName]\n        const modelName = inflection.dasherize(modelClassName)\n        const modelNameCamelized = inflection.camelize(modelName.replaceAll(\"-\", \"_\"))\n        const modelBaseFileName = `${inflection.dasherize(inflection.underscore(modelName))}.js`\n        const modelPath = `${baseModelsDir}/${modelBaseFileName}`\n\n        console.log(`create src/model-bases/${modelBaseFileName}`)\n\n        const sourceModelFullFilePath = `${modelsDir}/${modelBaseFileName}`\n        let sourceModelFilePath\n\n        if (await fileExists(sourceModelFullFilePath)) {\n          sourceModelFilePath = `../models/${modelBaseFileName}`\n        } else {\n          sourceModelFilePath = \"velocious/build/src/database/record/index.js\"\n        }\n\n        let fileContent = \"\"\n        let velociousPath\n\n        if (devMode) {\n          velociousPath = \"../../../../src\"\n        } else {\n          velociousPath = \"velocious/build/src\"\n        }\n\n        fileContent += `import DatabaseRecord from \"${velociousPath}/database/record/index.js\"\\n\\n`\n\n        const hasManyRelationFilePath = `${velociousPath}/database/record/instance-relationships/has-many.js`\n\n        fileContent += `export default class ${modelNameCamelized}Base extends DatabaseRecord {\\n`\n\n      // --- getModelClass() override (fixes polymorphic typing in JS/JSDoc) ---\n      if (await fileExists(sourceModelFullFilePath)) {\n        // Model file exists (e.g. src/models/ticket.js) → return typeof Ticket\n        fileContent += \"  /**\\n\"\n        fileContent += `   * @returns {typeof import(\"${sourceModelFilePath}\").default}\\n`\n        fileContent += \"   */\\n\"\n        fileContent += \"  // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\\n\"\n        fileContent += `  getModelClass() { return /** @type {typeof import(\"${sourceModelFilePath}\").default} */ (this.constructor) }\\n\\n`\n      } else {\n        // No model file yet → fall back to typeof TicketBase\n        fileContent += \"  /**\\n\"\n        fileContent += `   * @returns {typeof ${modelNameCamelized}Base}\\n`\n        fileContent += \"   */\\n\"\n        fileContent += \"  // @ts-ignore - override narrows return type for better IntelliSense in generated model bases\\n\"\n        fileContent += `  getModelClass() { return /** @type {typeof ${modelNameCamelized}Base} */ (this.constructor) }\\n\\n`\n      }\n\n      const columns = await modelClass._getTable().getColumns()\n      let methodsCount = 0\n\n      for (const column of columns) {\n        const camelizedColumnName = inflection.camelize(column.getName(), true)\n        const camelizedColumnNameBigFirst = inflection.camelize(column.getName())\n        const jsdocType = this.jsDocTypeFromColumn(column)\n\n        if (methodsCount > 0) {\n          fileContent += \"\\n\"\n        }\n\n        if (jsdocType) {\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {${jsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n          fileContent += \"   */\\n\"\n        }\n\n        fileContent += `  ${camelizedColumnName}() { return this.readAttribute(\"${camelizedColumnName}\") }\\n\\n`\n\n        const setterJsdocType = this.jsDocSetterTypeFromColumn(column)\n\n        if (setterJsdocType) {\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @param {${setterJsdocType}${column.getNull() ? \" | null\" : \"\"}} newValue\\n`\n          fileContent += \"   * @returns {void}\\n\"\n          fileContent += \"   */\\n\"\n        }\n\n        fileContent += `  set${camelizedColumnNameBigFirst}(newValue) { return this._setColumnAttribute(\"${camelizedColumnName}\", newValue) }\\n\\n`\n\n        fileContent += \"  /**\\n\"\n        fileContent += \"   * @returns {boolean}\\n\"\n        fileContent += \"   */\\n\"\n        fileContent += `  has${camelizedColumnNameBigFirst}() { return this._hasAttribute(this.${camelizedColumnName}()) }\\n`\n\n        methodsCount++\n      }\n\n      if (modelClass._translations) {\n        const TranslationClass = modelClass.getTranslationClass()\n        const translationColumns = TranslationClass.getColumns()\n\n        for (const name in modelClass._translations) {\n          const nameUnderscore = inflection.underscore(name)\n          const column = translationColumns.find((translationColumn) => translationColumn.getName() === nameUnderscore)\n          let translationJsdocType\n\n          if (column) {\n            translationJsdocType = this.jsDocTypeFromColumn(column)\n          }\n\n          if (translationJsdocType) {\n            fileContent += `\\n`\n            fileContent += \"  /**\\n\"\n            fileContent += `   * @returns {${translationJsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n            fileContent += \"   */\\n\"\n          }\n\n          fileContent += `  ${name}() { return this._getTranslatedAttributeWithFallback(\"${name}\", this._getConfiguration().getLocale()) ?? null }\\n`\n          methodsCount++\n\n          const hasName = `has${inflection.camelize(name)}`\n\n          fileContent += `\\n`\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @abstract\\n`\n          fileContent += `   * @returns {boolean}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${hasName}() { throw new Error(\"${hasName} not implemented\") }\\n`\n          methodsCount++\n\n          for (const locale of this.getConfiguration().getLocales()) {\n            const localeMethodName = `${name}${inflection.camelize(locale)}`\n\n            if (translationJsdocType) {\n              fileContent += `\\n`\n              fileContent += \"  /**\\n\"\n              fileContent += `   * @returns {${translationJsdocType}${column.getNull() ? \" | null\" : \"\"}}\\n`\n              fileContent += \"   */\\n\"\n            }\n\n            fileContent += `  ${localeMethodName}() { return this._getTranslatedAttributeWithFallback(\"${name}\", \"${locale}\") ?? null }\\n`\n            methodsCount++\n\n            const localeHasName = `has${inflection.camelize(localeMethodName)}`\n\n            fileContent += `\\n`\n            fileContent += \"  /**\\n\"\n            fileContent += `   * @abstract\\n`\n            fileContent += `   * @returns {boolean}\\n`\n            fileContent += \"   */\\n\"\n            fileContent += `  ${localeHasName}() { throw new Error(\"${localeHasName} not implemented\") }\\n`\n            methodsCount++\n          }\n        }\n      }\n\n      for (const relationship of modelClass.getRelationships()) {\n        let baseFilePath, baseFullFilePath, fileName, fullFilePath\n\n        if (relationship.getPolymorphic()) {\n          fileName = \"velocious/build/src/database/record/index.js\"\n        } else {\n          fileName = inflection.dasherize(inflection.underscore(relationship.getTargetModelClass().name))\n          fullFilePath = `src/models/${fileName}.js`\n          baseFilePath = `../model-bases/${fileName}.js`\n          baseFullFilePath = `src/model-bases/${fileName}.js`\n        }\n\n        if (methodsCount > 0) {\n          fileContent += \"\\n\"\n        }\n\n        if (relationship.getType() == \"belongsTo\" || relationship.getType() == \"hasOne\") {\n          let modelFilePath\n\n          if (fullFilePath && await fileExists(fullFilePath)) {\n            modelFilePath = `../models/${fileName}.js`\n          } else if (baseFullFilePath && await fileExists(baseFullFilePath)) {\n            modelFilePath = baseFilePath\n          } else {\n            modelFilePath = \"velocious/build/src/database/record/index.js\"\n          }\n\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {import(\"${modelFilePath}\").default}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}() { return /** @type {import(\"${modelFilePath}\").default} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\").loaded()) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @param {Record<string, any>} [attributes]\\n\"\n          fileContent += `   * @returns {import(\"${modelFilePath}\").default}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  build${inflection.camelize(relationship.getRelationshipName())}(attributes) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @returns {Promise<void>}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error(\"Not implemented\") }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += `   * @param {import(\"${modelFilePath}\").default} newModel\\n`\n          fileContent += `   * @returns {void}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  set${inflection.camelize(relationship.getRelationshipName())}(newModel) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n        } else if (relationship.getType() == \"hasMany\") {\n          let recordImport\n\n          if (fullFilePath && await fileExists(fullFilePath)) {\n            recordImport = `../models/${fileName}.js`\n          } else if (baseFullFilePath && await fileExists(baseFullFilePath)) {\n            recordImport = `../model-bases/${fileName}.js`\n          } else {\n            recordImport = `${velociousPath}/database/record/index.js`\n          }\n\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {import(\"${hasManyRelationFilePath}\").default<typeof import(\"${sourceModelFilePath}\").default, typeof import(\"${recordImport}\").default>}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}() { return /** @type {import(\"${hasManyRelationFilePath}\").default<typeof import(\"${sourceModelFilePath}\").default, typeof import(\"${recordImport}\").default>} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\")) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += `   * @returns {Array<import(\"${recordImport}\").default>}\\n`\n          fileContent += \"   */\\n\"\n          fileContent += `  ${relationship.getRelationshipName()}Loaded() { return /** @type {Array<import(\"${recordImport}\").default>} */ (this.getRelationshipByName(\"${relationship.getRelationshipName()}\").loaded()) }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += \"   * @returns {Promise<void>}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  load${inflection.camelize(relationship.getRelationshipName())}() { throw new Error(\"Not implemented\") }\\n`\n\n          fileContent += \"\\n\"\n          fileContent += \"  /**\\n\"\n          fileContent += \"   * @abstract\\n\"\n          fileContent += `   * @param {Array<import(\"${recordImport}\").default>} newModels\\n`\n          fileContent += \"   * @returns {void}\\n\"\n          fileContent += \"   */\\n\"\n          fileContent += `  set${inflection.camelize(relationship.getRelationshipName())}(newModels) { throw new Error(\"Not implemented\") } // eslint-disable-line no-unused-vars\\n`\n        } else {\n          throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n        }\n\n        methodsCount++\n      }\n\n      fileContent += \"}\\n\"\n\n        await fs.writeFile(modelPath, fileContent)\n      }\n    })\n  }\n\n  /**\n   * @param {import(\"../../../../../database/drivers/base-column.js\").default} column - Column.\n   * @returns {string | undefined} - The js doc type from column.\n   */\n  jsDocTypeFromColumn(column) {\n    const type = column.getType()\n\n    if (type == \"boolean\") {\n      return \"boolean\"\n    } else if (type == \"json\") {\n      return \"Record<string, any>\"\n    } else if ([\"blob\", \"char\", \"nvarchar\", \"varchar\", \"text\", \"longtext\", \"uuid\", \"character varying\"].includes(type)) {\n      return \"string\"\n    } else if ([\"bit\", \"bigint\", \"float\", \"int\", \"integer\", \"smallint\", \"tinyint\"].includes(type)) {\n      return \"number\"\n    } else if ([\"date\", \"datetime\", \"timestamp without time zone\"].includes(type)) {\n      return \"Date\"\n    } else {\n      console.error(`Unknown column type: ${type}`)\n    }\n  }\n\n  /**\n   * @param {import(\"../../../../../database/drivers/base-column.js\").default} column - Column.\n   * @returns {string | undefined} - The js doc setter type from column.\n   */\n  jsDocSetterTypeFromColumn(column) {\n    const type = column.getType()\n\n    if ([\"date\", \"datetime\", \"timestamp without time zone\"].includes(type)) {\n      return \"Date | string\"\n    }\n\n    return this.jsDocTypeFromColumn(column)\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/environment-handlers/node.js"],"names":[],"mappings":"AAkBA,uDAAuD;AAEvD;IACE,sFAAsF;IACtF,4BADW,OAAO,kBAAkB,EAAE,iBAAiB,CAAC,aAAa,CAAC,GAAG,SAAS,CACU;IAE5F,sEAAsE;IACtE,qBADW,OAAO,WAAW,EAAE,qBAAqB,EAAE,GAAG,SAAS,CACnC;IA0D/B;;;SAyBC;IAyIG,uBAA6D;IAmEjE;;;OAGG;IACH,2BAHW,MAAM,GACJ,OAAO,CAAC,OAAO,gCAAgC,EAAE,OAAO,CAAC,CAUrE;IAED,+BAKC;IAwBD;;;;OAIG;IACH,mCAHG;QAA4E,GAAG,EAAvE,MAAM,CAAC,MAAM,EAAE,OAAO,6BAA6B,EAAE,OAAO,CAAC;KACrE,GAAU,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAkB3C;CACF;4BAvWa;IAAC,aAAa,EAAE,MAAM,CAAA;CAAC;iBAhBpB,WAAW"}
1
+ {"version":3,"file":"node.d.ts","sourceRoot":"","sources":["../../../src/environment-handlers/node.js"],"names":[],"mappings":"AAkBA,uDAAuD;AAEvD;IACE,sFAAsF;IACtF,4BADW,OAAO,kBAAkB,EAAE,iBAAiB,CAAC,aAAa,CAAC,GAAG,SAAS,CACU;IAE5F,sEAAsE;IACtE,qBADW,OAAO,WAAW,EAAE,qBAAqB,EAAE,GAAG,SAAS,CACnC;IA0D/B;;;SAyBC;IAyIG,uBAA6D;IAqEjE;;;OAGG;IACH,2BAHW,MAAM,GACJ,OAAO,CAAC,OAAO,gCAAgC,EAAE,OAAO,CAAC,CAUrE;IAED,+BAKC;IAwBD;;;;OAIG;IACH,mCAHG;QAA4E,GAAG,EAAvE,MAAM,CAAC,MAAM,EAAE,OAAO,6BAA6B,EAAE,OAAO,CAAC;KACrE,GAAU,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAkB3C;CACF;4BAzWa;IAAC,aAAa,EAAE,MAAM,CAAA;CAAC;iBAhBpB,WAAW"}