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.
- package/build/src/application.d.ts.map +1 -1
- package/build/src/application.js +2 -1
- package/build/src/configuration-types.d.ts +5 -0
- package/build/src/configuration-types.d.ts.map +1 -1
- package/build/src/configuration-types.js +2 -1
- package/build/src/configuration.d.ts +12 -1
- package/build/src/configuration.d.ts.map +1 -1
- package/build/src/configuration.js +60 -5
- package/build/src/database/drivers/base.d.ts +10 -0
- package/build/src/database/drivers/base.d.ts.map +1 -1
- package/build/src/database/drivers/base.js +15 -1
- package/build/src/database/drivers/mssql/index.d.ts +1 -2
- package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
- package/build/src/database/drivers/mssql/index.js +26 -12
- package/build/src/database/drivers/mysql/index.d.ts +0 -4
- package/build/src/database/drivers/mysql/index.d.ts.map +1 -1
- package/build/src/database/drivers/mysql/index.js +9 -8
- package/build/src/database/drivers/pgsql/index.d.ts +0 -2
- package/build/src/database/drivers/pgsql/index.d.ts.map +1 -1
- package/build/src/database/drivers/pgsql/index.js +5 -2
- package/build/src/database/drivers/sqlite/index.d.ts +0 -1
- package/build/src/database/drivers/sqlite/index.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/index.native.d.ts +0 -2
- package/build/src/database/drivers/sqlite/index.native.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/index.web.d.ts +0 -1
- package/build/src/database/drivers/sqlite/index.web.d.ts.map +1 -1
- package/build/src/database/pool/async-tracked-multi-connection.d.ts.map +1 -1
- package/build/src/database/pool/async-tracked-multi-connection.js +26 -1
- package/build/src/database/pool/base.d.ts +10 -0
- package/build/src/database/pool/base.d.ts.map +1 -1
- package/build/src/database/pool/base.js +11 -1
- package/build/src/database/pool/single-multi-use.d.ts.map +1 -1
- package/build/src/database/pool/single-multi-use.js +17 -1
- package/build/src/environment-handlers/node/cli/commands/generate/base-models.d.ts.map +1 -1
- package/build/src/environment-handlers/node/cli/commands/generate/base-models.js +179 -177
- package/build/src/environment-handlers/node.d.ts.map +1 -1
- package/build/src/environment-handlers/node.js +3 -1
- package/build/src/http-server/client/request-runner.d.ts.map +1 -1
- package/build/src/http-server/client/request-runner.js +52 -2
- package/build/src/http-server/client/response.d.ts +16 -0
- package/build/src/http-server/client/response.d.ts.map +1 -1
- package/build/src/http-server/client/response.js +31 -1
- package/build/src/http-server/client/websocket-session.d.ts +1 -0
- package/build/src/http-server/client/websocket-session.d.ts.map +1 -1
- package/build/src/http-server/client/websocket-session.js +12 -3
- package/build/src/http-server/index.d.ts.map +1 -1
- package/build/src/http-server/index.js +8 -3
- package/build/src/http-server/worker-handler/index.d.ts +11 -0
- package/build/src/http-server/worker-handler/index.d.ts.map +1 -1
- package/build/src/http-server/worker-handler/index.js +41 -2
- package/build/src/http-server/worker-handler/worker-thread.d.ts.map +1 -1
- package/build/src/http-server/worker-handler/worker-thread.js +8 -1
- package/build/src/testing/format-value.d.ts.map +1 -1
- package/build/src/testing/format-value.js +7 -1
- package/build/src/testing/test.d.ts.map +1 -1
- package/build/src/testing/test.js +31 -1
- 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
|
-
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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
|
-
|
|
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 {${
|
|
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
|
-
|
|
76
|
-
|
|
77
|
-
if (setterJsdocType) {
|
|
54
|
+
else {
|
|
55
|
+
// No model file yet → fall back to typeof TicketBase
|
|
78
56
|
fileContent += " /**\n";
|
|
79
|
-
fileContent += ` * @
|
|
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
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
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 (
|
|
101
|
-
fileContent += `\n`;
|
|
71
|
+
if (jsdocType) {
|
|
102
72
|
fileContent += " /**\n";
|
|
103
|
-
fileContent += ` * @returns {${
|
|
73
|
+
fileContent += ` * @returns {${jsdocType}${column.getNull() ? " | null" : ""}}\n`;
|
|
104
74
|
fileContent += " */\n";
|
|
105
75
|
}
|
|
106
|
-
fileContent += ` ${
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
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 +=
|
|
112
|
-
fileContent += ` * @returns {boolean}\n`;
|
|
86
|
+
fileContent += " * @returns {boolean}\n";
|
|
113
87
|
fileContent += " */\n";
|
|
114
|
-
fileContent += ` ${
|
|
88
|
+
fileContent += ` has${camelizedColumnNameBigFirst}() { return this._hasAttribute(this.${camelizedColumnName}()) }\n`;
|
|
115
89
|
methodsCount++;
|
|
116
|
-
|
|
117
|
-
|
|
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 += ` ${
|
|
107
|
+
fileContent += ` ${name}() { return this._getTranslatedAttributeWithFallback("${name}", this._getConfiguration().getLocale()) ?? null }\n`;
|
|
125
108
|
methodsCount++;
|
|
126
|
-
const
|
|
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 += ` ${
|
|
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
|
-
|
|
138
|
-
|
|
139
|
-
|
|
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
|
-
|
|
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
|
-
|
|
163
|
-
|
|
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
|
-
|
|
193
|
-
|
|
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
|
-
|
|
223
|
+
throw new Error(`Unknown relationship type: ${relationship.getType()}`);
|
|
197
224
|
}
|
|
198
|
-
|
|
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
|
-
|
|
227
|
+
fileContent += "}\n";
|
|
228
|
+
await fs.writeFile(modelPath, fileContent);
|
|
225
229
|
}
|
|
226
|
-
|
|
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;
|
|
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"}
|