arkos 1.0.16 → 1.0.18-beta
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/dist/cjs/modules/base/base.router.js +1 -2
- package/dist/cjs/modules/base/base.router.js.map +1 -1
- package/dist/cjs/modules/error-handler/error-handler.controller.js +19 -16
- package/dist/cjs/modules/error-handler/error-handler.controller.js.map +1 -1
- package/dist/cjs/utils/helpers/models.helpers.js +165 -159
- package/dist/cjs/utils/helpers/models.helpers.js.map +1 -1
- package/dist/es2020/modules/base/base.router.js +1 -2
- package/dist/es2020/modules/base/base.router.js.map +1 -1
- package/dist/es2020/modules/error-handler/error-handler.controller.js +19 -16
- package/dist/es2020/modules/error-handler/error-handler.controller.js.map +1 -1
- package/dist/es2020/utils/helpers/models.helpers.js +159 -154
- package/dist/es2020/utils/helpers/models.helpers.js.map +1 -1
- package/dist/types/utils/helpers/models.helpers.d.ts +54 -22
- package/package.json +1 -1
|
@@ -10,63 +10,102 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
10
10
|
import path from "path";
|
|
11
11
|
import fs from "fs";
|
|
12
12
|
import { camelCase, kebabCase, pascalCase, } from "../../utils/helpers/change-case.helpers";
|
|
13
|
-
import arkosEnv from "../arkos-env";
|
|
14
13
|
import { userFileExtension } from "./fs.helpers";
|
|
14
|
+
import { importModule } from "./global.helpers";
|
|
15
15
|
export let prismaModelsModules = {};
|
|
16
16
|
export function getModelModules(modelName) {
|
|
17
17
|
return prismaModelsModules[kebabCase(modelName)];
|
|
18
18
|
}
|
|
19
|
-
export function
|
|
19
|
+
export function getFileModelModulesFileStructure(modelName) {
|
|
20
|
+
const kebabModelName = kebabCase(modelName).toLowerCase();
|
|
21
|
+
const lowerModelName = kebabModelName.toLowerCase();
|
|
22
|
+
const isAuthModule = modelName.toLowerCase() === "auth";
|
|
23
|
+
return {
|
|
24
|
+
core: {
|
|
25
|
+
service: `${kebabModelName}.service.${userFileExtension}`,
|
|
26
|
+
controller: `${kebabModelName}.controller.${userFileExtension}`,
|
|
27
|
+
middlewares: `${kebabModelName}.middlewares.${userFileExtension}`,
|
|
28
|
+
authConfigs: `${kebabModelName}.auth-configs.${userFileExtension}`,
|
|
29
|
+
prismaQueryOptions: `${kebabModelName}.prisma-query-options.${userFileExtension}`,
|
|
30
|
+
router: `${kebabModelName}.router.${userFileExtension}`,
|
|
31
|
+
},
|
|
32
|
+
dtos: isAuthModule
|
|
33
|
+
? {
|
|
34
|
+
login: `login.dto.${userFileExtension}`,
|
|
35
|
+
signup: `signup.dto.${userFileExtension}`,
|
|
36
|
+
updateMe: `update-me.dto.${userFileExtension}`,
|
|
37
|
+
updatePassword: `update-password.dto.${userFileExtension}`,
|
|
38
|
+
}
|
|
39
|
+
: {
|
|
40
|
+
model: `${lowerModelName}.dto.${userFileExtension}`,
|
|
41
|
+
create: `create-${lowerModelName}.dto.${userFileExtension}`,
|
|
42
|
+
update: `update-${lowerModelName}.dto.${userFileExtension}`,
|
|
43
|
+
query: `query-${lowerModelName}.dto.${userFileExtension}`,
|
|
44
|
+
},
|
|
45
|
+
schemas: isAuthModule
|
|
46
|
+
? {
|
|
47
|
+
login: `login.schema.${userFileExtension}`,
|
|
48
|
+
signup: `signup.schema.${userFileExtension}`,
|
|
49
|
+
updateMe: `update-me.schema.${userFileExtension}`,
|
|
50
|
+
updatePassword: `update-password.schema.${userFileExtension}`,
|
|
51
|
+
}
|
|
52
|
+
: {
|
|
53
|
+
model: `${lowerModelName}.schema.${userFileExtension}`,
|
|
54
|
+
create: `create-${lowerModelName}.schema.${userFileExtension}`,
|
|
55
|
+
update: `update-${lowerModelName}.schema.${userFileExtension}`,
|
|
56
|
+
query: `query-${lowerModelName}.schema.${userFileExtension}`,
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
export function processSubdir(modelName, type, result) {
|
|
20
61
|
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
const
|
|
22
|
-
const
|
|
62
|
+
const moduleDir = path.resolve(process.cwd(), "src", "modules", kebabCase(modelName));
|
|
63
|
+
const subdir = path.join(moduleDir, type);
|
|
23
64
|
const pascalModelName = pascalCase(modelName);
|
|
24
|
-
const
|
|
65
|
+
const fileStructure = getFileModelModulesFileStructure(modelName);
|
|
25
66
|
const isAuthModule = modelName.toLowerCase() === "auth";
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
67
|
+
try {
|
|
68
|
+
yield fs.promises.access(subdir).catch(() => {
|
|
69
|
+
return;
|
|
70
|
+
});
|
|
71
|
+
yield Promise.all(Object.entries(fileStructure[type]).map((_a) => __awaiter(this, [_a], void 0, function* ([key, fileName]) {
|
|
72
|
+
const filePath = path.join(subdir, fileName);
|
|
73
|
+
try {
|
|
74
|
+
const module = yield import(filePath).catch(() => null);
|
|
75
|
+
if (module) {
|
|
76
|
+
if (isAuthModule) {
|
|
77
|
+
const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);
|
|
78
|
+
const expectedName = `${pascalKey}${type === "dtos" ? "Dto" : "Schema"}`;
|
|
79
|
+
result[type][key] = module.default;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
const expectedName = key === "model"
|
|
83
|
+
? `${pascalModelName}${type === "dtos" ? "Dto" : "Schema"}`
|
|
84
|
+
: `${key.charAt(0).toUpperCase() + key.slice(1)}${pascalModelName}${type === "dtos" ? "Dto" : "Schema"}`;
|
|
85
|
+
result[type][key] = module.default;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
41
88
|
}
|
|
42
|
-
|
|
43
|
-
model: `${lowerModelName}.dto.${userFileExtension}`,
|
|
44
|
-
create: `create-${lowerModelName}.dto.${userFileExtension}`,
|
|
45
|
-
update: `update-${lowerModelName}.dto.${userFileExtension}`,
|
|
46
|
-
query: `query-${lowerModelName}.dto.${userFileExtension}`,
|
|
47
|
-
},
|
|
48
|
-
schemas: isAuthModule
|
|
49
|
-
? {
|
|
50
|
-
login: `login.schema.${userFileExtension}`,
|
|
51
|
-
signup: `signup.schema.${userFileExtension}`,
|
|
52
|
-
updateMe: `update-me.schema.${userFileExtension}`,
|
|
53
|
-
updatePassword: `update-password.schema.${userFileExtension}`,
|
|
89
|
+
catch (error) {
|
|
54
90
|
}
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
91
|
+
})));
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
export function importPrismaModelModules(modelName) {
|
|
98
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
99
|
+
const moduleDir = path.resolve(process.cwd(), "src", "modules", modelName);
|
|
62
100
|
const result = {
|
|
63
101
|
dtos: {},
|
|
64
102
|
schemas: {},
|
|
65
103
|
};
|
|
104
|
+
const fileStructure = getFileModelModulesFileStructure(modelName);
|
|
66
105
|
yield Promise.all(Object.entries(fileStructure.core).map((_a) => __awaiter(this, [_a], void 0, function* ([key, fileName]) {
|
|
67
106
|
const filePath = path.join(moduleDir, fileName);
|
|
68
107
|
try {
|
|
69
|
-
const module = yield
|
|
108
|
+
const module = yield importModule(filePath).catch(() => null);
|
|
70
109
|
if (module) {
|
|
71
110
|
if (key === "middlewares")
|
|
72
111
|
result[key] = module;
|
|
@@ -74,48 +113,17 @@ export function importPrismaModelModules(modelName) {
|
|
|
74
113
|
result[key] = module.default || module;
|
|
75
114
|
}
|
|
76
115
|
}
|
|
77
|
-
catch (
|
|
78
|
-
}
|
|
116
|
+
catch (_b) { }
|
|
79
117
|
})));
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
return;
|
|
85
|
-
});
|
|
86
|
-
yield Promise.all(Object.entries(fileStructure[type]).map((_a) => __awaiter(this, [_a], void 0, function* ([key, fileName]) {
|
|
87
|
-
const filePath = path.join(subdir, fileName);
|
|
88
|
-
try {
|
|
89
|
-
const module = yield import(filePath).catch(() => null);
|
|
90
|
-
if (module) {
|
|
91
|
-
if (isAuthModule) {
|
|
92
|
-
const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);
|
|
93
|
-
const expectedName = `${pascalKey}${type === "dtos" ? "Dto" : "Schema"}`;
|
|
94
|
-
result[type][key] = module.default;
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
const expectedName = key === "model"
|
|
98
|
-
? `${pascalModelName}${type === "dtos" ? "Dto" : "Schema"}`
|
|
99
|
-
: `${key.charAt(0).toUpperCase() + key.slice(1)}${pascalModelName}${type === "dtos" ? "Dto" : "Schema"}`;
|
|
100
|
-
result[type][key] = module.default;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
catch (error) {
|
|
105
|
-
}
|
|
106
|
-
})));
|
|
107
|
-
}
|
|
108
|
-
catch (error) {
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
yield Promise.all([processSubdir("dtos"), processSubdir("schemas")]);
|
|
118
|
+
yield Promise.all([
|
|
119
|
+
processSubdir(modelName, "dtos", result),
|
|
120
|
+
processSubdir(modelName, "schemas", result),
|
|
121
|
+
]);
|
|
112
122
|
prismaModelsModules[modelName] = result;
|
|
113
123
|
return result;
|
|
114
124
|
});
|
|
115
125
|
}
|
|
116
|
-
const
|
|
117
|
-
const prismaModelRelationFields = {};
|
|
118
|
-
const prismaContent = [];
|
|
126
|
+
export const prismaModelRelationFields = {};
|
|
119
127
|
export function getAllPrismaFiles(dirPath, fileList = []) {
|
|
120
128
|
const files = fs.readdirSync(dirPath);
|
|
121
129
|
files === null || files === void 0 ? void 0 : files.forEach((file) => {
|
|
@@ -130,93 +138,90 @@ export function getAllPrismaFiles(dirPath, fileList = []) {
|
|
|
130
138
|
});
|
|
131
139
|
return fileList;
|
|
132
140
|
}
|
|
133
|
-
const files = getAllPrismaFiles("./prisma");
|
|
134
|
-
for (const file of files) {
|
|
135
|
-
const content = fs.readFileSync(file, "utf-8");
|
|
136
|
-
prismaContent.push(content);
|
|
137
|
-
}
|
|
138
141
|
const modelRegex = /model\s+(\w+)\s*{/g;
|
|
139
|
-
const models = [];
|
|
142
|
+
export const models = [];
|
|
140
143
|
export const prismaModelsUniqueFields = [];
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
return modelName;
|
|
145
|
-
});
|
|
146
|
-
for (const model of models) {
|
|
147
|
-
const modelName = pascalCase(model);
|
|
148
|
-
let modelFile;
|
|
144
|
+
export function initializePrismaModels(testName) {
|
|
145
|
+
const prismaContent = [];
|
|
146
|
+
const files = getAllPrismaFiles("./prisma");
|
|
149
147
|
for (const file of files) {
|
|
150
|
-
const
|
|
151
|
-
|
|
152
|
-
if (stats.isFile()) {
|
|
153
|
-
const content = fs.readFileSync(filePath, "utf-8");
|
|
148
|
+
const content = fs.readFileSync(file, "utf-8");
|
|
149
|
+
if (!prismaContent.includes(content))
|
|
154
150
|
prismaContent.push(content);
|
|
155
|
-
if (content.includes(`model ${modelName} {`)) {
|
|
156
|
-
modelFile = file;
|
|
157
|
-
break;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
151
|
}
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
const
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
...(prismaModelsUniqueFields[model] || []),
|
|
184
|
-
{ name: fieldName, type, isUnique },
|
|
185
|
-
];
|
|
186
|
-
const cleanType = type === null || type === void 0 ? void 0 : type.replace("[]", "").replace("?", "");
|
|
187
|
-
if (trimmedLine.includes("@relation") ||
|
|
188
|
-
trimmedLine.match(/\s+\w+(\[\])?(\s+@|$)/) ||
|
|
189
|
-
models.includes(camelCase(cleanType || ""))) {
|
|
190
|
-
const modelStart = content.indexOf(`enum ${cleanType} {`);
|
|
191
|
-
if (!cleanType ||
|
|
192
|
-
modelStart >= 0 ||
|
|
193
|
-
cleanType === "String" ||
|
|
194
|
-
cleanType === "Int" ||
|
|
195
|
-
cleanType === "Float" ||
|
|
196
|
-
cleanType === "Boolean" ||
|
|
197
|
-
cleanType === "DateTime" ||
|
|
198
|
-
cleanType === "Bytes" ||
|
|
199
|
-
cleanType === "Decimal" ||
|
|
200
|
-
cleanType === "BigInt" ||
|
|
201
|
-
cleanType === "Json") {
|
|
152
|
+
const content = prismaContent
|
|
153
|
+
.join("\n")
|
|
154
|
+
.replace(modelRegex, (_, modelName) => {
|
|
155
|
+
if (!models.includes(modelName))
|
|
156
|
+
models.push(camelCase(modelName.trim()));
|
|
157
|
+
return `model ${modelName} {`;
|
|
158
|
+
});
|
|
159
|
+
for (const model of models) {
|
|
160
|
+
const modelName = pascalCase(model);
|
|
161
|
+
const modelStart = content.indexOf(`model ${modelName} {`);
|
|
162
|
+
const modelEnd = content.indexOf("}", modelStart);
|
|
163
|
+
const modelDefinition = content.slice(modelStart, modelEnd);
|
|
164
|
+
const relations = {
|
|
165
|
+
singular: [],
|
|
166
|
+
list: [],
|
|
167
|
+
};
|
|
168
|
+
const lines = modelDefinition.split("\n");
|
|
169
|
+
for (const line of lines) {
|
|
170
|
+
const trimmedLine = line.trim();
|
|
171
|
+
if (!trimmedLine ||
|
|
172
|
+
trimmedLine.startsWith("model") ||
|
|
173
|
+
trimmedLine.startsWith("//"))
|
|
202
174
|
continue;
|
|
175
|
+
const [fieldName, type] = trimmedLine.split(/\s+/);
|
|
176
|
+
const isUnique = trimmedLine.includes("@unique");
|
|
177
|
+
if (isUnique) {
|
|
178
|
+
const existingFields = prismaModelsUniqueFields[model] || [];
|
|
179
|
+
const alreadyExists = existingFields.some((field) => field.name === fieldName &&
|
|
180
|
+
field.type === type &&
|
|
181
|
+
field.isUnique === isUnique);
|
|
182
|
+
if (!alreadyExists) {
|
|
183
|
+
prismaModelsUniqueFields[model] = [
|
|
184
|
+
...existingFields,
|
|
185
|
+
{ name: fieldName, type, isUnique },
|
|
186
|
+
];
|
|
187
|
+
}
|
|
203
188
|
}
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
189
|
+
const cleanType = type === null || type === void 0 ? void 0 : type.replace("[]", "").replace("?", "");
|
|
190
|
+
if (trimmedLine.includes("@relation") ||
|
|
191
|
+
trimmedLine.match(/\s+\w+(\[\])?(\s+@|$)/) ||
|
|
192
|
+
models.includes(camelCase(cleanType || ""))) {
|
|
193
|
+
const modelStart = content.indexOf(`enum ${cleanType} {`);
|
|
194
|
+
if (!cleanType ||
|
|
195
|
+
modelStart >= 0 ||
|
|
196
|
+
cleanType === "String" ||
|
|
197
|
+
cleanType === "Int" ||
|
|
198
|
+
cleanType === "Float" ||
|
|
199
|
+
cleanType === "Boolean" ||
|
|
200
|
+
cleanType === "DateTime" ||
|
|
201
|
+
cleanType === "Bytes" ||
|
|
202
|
+
cleanType === "Decimal" ||
|
|
203
|
+
cleanType === "BigInt" ||
|
|
204
|
+
cleanType === "Json") {
|
|
205
|
+
continue;
|
|
206
|
+
}
|
|
207
|
+
if (!(type === null || type === void 0 ? void 0 : type.includes("[]"))) {
|
|
208
|
+
relations.singular.push({
|
|
209
|
+
name: fieldName,
|
|
210
|
+
type: cleanType,
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
relations.list.push({
|
|
215
|
+
name: fieldName,
|
|
216
|
+
type: cleanType,
|
|
217
|
+
});
|
|
218
|
+
}
|
|
215
219
|
}
|
|
220
|
+
prismaModelRelationFields[modelName] = relations;
|
|
216
221
|
}
|
|
217
|
-
prismaModelRelationFields[modelName] = relations;
|
|
218
222
|
}
|
|
219
223
|
}
|
|
224
|
+
initializePrismaModels();
|
|
220
225
|
export function getPrismaModelRelations(modelName) {
|
|
221
226
|
modelName = pascalCase(modelName);
|
|
222
227
|
if (!(modelName in prismaModelRelationFields))
|
|
@@ -229,5 +234,5 @@ function getModels() {
|
|
|
229
234
|
function getModelUniqueFields(modelName) {
|
|
230
235
|
return prismaModelsUniqueFields[modelName];
|
|
231
236
|
}
|
|
232
|
-
export {
|
|
237
|
+
export { getModels, getModelUniqueFields };
|
|
233
238
|
//# sourceMappingURL=models.helpers.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.helpers.js","sourceRoot":"","sources":["../../../../src/utils/helpers/models.helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import path from \"path\";\nimport fs from \"fs\";\nimport {\n camelCase,\n kebabCase,\n pascalCase,\n} from \"../../utils/helpers/change-case.helpers\";\nimport arkosEnv from \"../arkos-env\";\nimport { userFileExtension } from \"./fs.helpers\";\n\nexport let prismaModelsModules: Record<\n string,\n Awaited<ReturnType<typeof importPrismaModelModules>>\n> = {};\n\nexport function getModelModules(modelName: string) {\n return prismaModelsModules[kebabCase(modelName)];\n}\n\n// /**\n// * Dynamically imports model-specific modules like middlewares, auth configurations,\n// * prisma query options, and DTOs for a given model.\n// *\n// * @param {string} modelName - The name of the model (e.g., \"User\", \"Post\").\n// * @returns {Promise<Object>} An object containing the imported modules: `middlewares`, `authConfigs`, `prismaQueryOptions`, and `dtos`.\n// */\n// export async function importPrismaModelModules(modelName: string) {\n// const kebabModelName = kebabCase(modelName);\n// const lowerModelName = modelName.toLowerCase();\n\n// const moduleDir = path.resolve(process.cwd(), \"src\", \"modules\", modelName);\n// const dtosDir = path.join(moduleDir, \"dtos\");\n// const schemasDir = path.join(moduleDir, \"schemas\");\n\n// const middlewaresFile = path.join(\n// moduleDir,\n// `${kebabModelName}.middlewares.${userFileExtension}`\n// );\n// const authConfigsFile = path.join(\n// moduleDir,\n// `${kebabModelName}.auth-configs.${userFileExtension}`\n// );\n// const prismaQueryOptionsFile = path.join(\n// moduleDir,\n// `${kebabModelName}.prisma-query-options.${userFileExtension}`\n// );\n\n// // Define DTO file paths\n// const modelDtoFile = path.join(\n// dtosDir,\n// `${lowerModelName}.dto.${userFileExtension}`\n// );\n// const createDtoFile = path.join(\n// dtosDir,\n// `create-${lowerModelName}.dto.${userFileExtension}`\n// );\n// const updateDtoFile = path.join(\n// dtosDir,\n// `update-${lowerModelName}.dto.${userFileExtension}`\n// );\n// const queryDtoFile = path.join(\n// dtosDir,\n// `query-${lowerModelName}.dto.${userFileExtension}`\n// );\n\n// const modelSchemaFile = path.join(\n// schemasDir,\n// `${lowerModelName}.schema.${userFileExtension}`\n// );\n// const createSchemaFile = path.join(\n// schemasDir,\n// `create-${lowerModelName}.schema.${userFileExtension}`\n// );\n// const updateSchemaFile = path.join(\n// schemasDir,\n// `update-${lowerModelName}.schema.${userFileExtension}`\n// );\n// const querySchemaFile = path.join(\n// schemasDir,\n// `query-${lowerModelName}.schema.${userFileExtension}`\n// );\n\n// const result: {\n// middlewares?: any;\n// authConfigs?: any;\n// prismaQueryOptions?: any;\n// dtos: {\n// create?: any;\n// update?: any;\n// query?: any;\n// model?: any;\n// };\n// schemas: {\n// create?: any;\n// update?: any;\n// query?: any;\n// model?: any;\n// };\n// } = {\n// dtos: {},\n// schemas: {},\n// };\n\n// try {\n// if (fs.existsSync(middlewaresFile)) {\n// const middlewareModule = await import(middlewaresFile);\n// result.middlewares = middlewareModule;\n// }\n// } catch (error) {\n// console.error(\n// `Error importing middlewares for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(authConfigsFile)) {\n// const authConfigsModule = await import(authConfigsFile);\n// result.authConfigs = authConfigsModule.default || authConfigsModule;\n// }\n// } catch (error) {\n// console.error(\n// `Error importing auth configs for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(prismaQueryOptionsFile)) {\n// const prismaQueryOptionsModule = await import(prismaQueryOptionsFile);\n// result.prismaQueryOptions =\n// prismaQueryOptionsModule.default || prismaQueryOptionsModule;\n// }\n// } catch (error) {\n// console.error(\n// `Error importing prisma query options for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// // Import DTOs\n// const pascalModelName = pascalCase(modelName);\n// try {\n// if (fs.existsSync(modelDtoFile)) {\n// const modelDtoModule = await import(modelDtoFile);\n// result.dtos.model =\n// modelDtoModule.default || modelDtoModule[`${pascalModelName}Dto`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing model main DTO for model \"${modelName} ${pascalModelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(createDtoFile)) {\n// const createDtoModule = await import(createDtoFile);\n// result.dtos.create =\n// createDtoModule.default ||\n// createDtoModule[`Create${pascalModelName}Dto`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing create DTO for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(updateDtoFile)) {\n// const updateDtoModule = await import(updateDtoFile);\n// result.dtos.update =\n// updateDtoModule.default ||\n// updateDtoModule[`Update${pascalModelName}Dto`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing update DTO for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(queryDtoFile)) {\n// const queryDtoModule = await import(queryDtoFile);\n// result.dtos.query =\n// queryDtoModule.default || queryDtoModule[`Query${pascalModelName}Dto`];\n// }\n// } catch (error) {\n// console.error(`Error importing query DTO for model \"${modelName}\":`, error);\n// }\n\n// try {\n// if (fs.existsSync(modelSchemaFile)) {\n// const modelSchemaModule = await import(modelSchemaFile);\n// result.dtos.model =\n// modelSchemaModule.default ||\n// modelSchemaModule[`${pascalModelName}Schema`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing create Schema for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(createSchemaFile)) {\n// const createSchemaModule = await import(createSchemaFile);\n// result.dtos.create =\n// createSchemaModule.default ||\n// createSchemaModule[`Create${pascalModelName}Schema`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing create Schema for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(updateSchemaFile)) {\n// const updateSchemaModule = await import(updateSchemaFile);\n// result.dtos.update =\n// updateSchemaModule.default ||\n// updateSchemaModule[`Update${pascalModelName}Schema`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing update Schema for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// try {\n// if (fs.existsSync(querySchemaFile)) {\n// const querySchemaModule = await import(querySchemaFile);\n// result.dtos.query =\n// querySchemaModule.default ||\n// querySchemaModule[`Query${pascalModelName}Schema`];\n// }\n// } catch (error) {\n// console.error(\n// `Error importing query Schema for model \"${modelName}\":`,\n// error\n// );\n// }\n\n// prismaModelsModules[modelName] = result;\n\n// return result;\n// }\n\n/**\n * Dynamically imports model-specific modules for a given model with optimized file handling.\n * Includes special handling for the Auth module.\n *\n * @param {string} modelName - The name of the model (e.g., \"User\", \"Post\", \"Auth\").\n * @returns {Promise<Object>} An object containing the imported modules\n */\nexport async function importPrismaModelModules(modelName: string) {\n const kebabModelName = kebabCase(modelName).toLowerCase();\n const lowerModelName = kebabModelName.toLowerCase();\n const pascalModelName = pascalCase(modelName);\n\n const moduleDir = path.resolve(process.cwd(), \"src\", \"modules\", modelName);\n\n // Define special auth module structure if needed\n const isAuthModule = modelName.toLowerCase() === \"auth\";\n\n // Define the structure of files to import\n const fileStructure = {\n core: {\n service: `${kebabModelName}.service.${userFileExtension}`,\n controller: `${kebabModelName}.controller.${userFileExtension}`,\n middlewares: `${kebabModelName}.middlewares.${userFileExtension}`,\n authConfigs: `${kebabModelName}.auth-configs.${userFileExtension}`,\n prismaQueryOptions: `${kebabModelName}.prisma-query-options.${userFileExtension}`,\n router: `${kebabModelName}.router.${userFileExtension}`,\n },\n dtos: isAuthModule\n ? {\n login: `login.dto.${userFileExtension}`,\n signup: `signup.dto.${userFileExtension}`,\n updateMe: `update-me.dto.${userFileExtension}`,\n updatePassword: `update-password.dto.${userFileExtension}`,\n }\n : {\n model: `${lowerModelName}.dto.${userFileExtension}`,\n create: `create-${lowerModelName}.dto.${userFileExtension}`,\n update: `update-${lowerModelName}.dto.${userFileExtension}`,\n query: `query-${lowerModelName}.dto.${userFileExtension}`,\n },\n schemas: isAuthModule\n ? {\n login: `login.schema.${userFileExtension}`,\n signup: `signup.schema.${userFileExtension}`,\n updateMe: `update-me.schema.${userFileExtension}`,\n updatePassword: `update-password.schema.${userFileExtension}`,\n }\n : {\n model: `${lowerModelName}.schema.${userFileExtension}`,\n create: `create-${lowerModelName}.schema.${userFileExtension}`,\n update: `update-${lowerModelName}.schema.${userFileExtension}`,\n query: `query-${lowerModelName}.schema.${userFileExtension}`,\n },\n };\n\n // Initialize result object\n const result: {\n service?: any;\n controller?: any;\n middlewares?: any;\n authConfigs?: any;\n prismaQueryOptions?: any;\n router?: any;\n dtos: Record<string, any>;\n schemas: Record<string, any>;\n } = {\n dtos: {},\n schemas: {},\n };\n\n // Batch process core files\n await Promise.all(\n Object.entries(fileStructure.core).map(async ([key, fileName]) => {\n const filePath = path.join(moduleDir, fileName);\n try {\n const module = await import(filePath).catch(() => null);\n if (module) {\n // For middlewares, keep the entire module\n if (key === \"middlewares\") result[key] = module;\n // For all other core files, prefer default export\n else result[key as keyof typeof result] = module.default || module;\n }\n } catch (error) {\n // Silent fail - file might not exist\n }\n })\n );\n\n // Process DTOs and schemas in parallel\n const processSubdir = async (type: \"dtos\" | \"schemas\") => {\n const subdir = path.join(moduleDir, type);\n\n // Skip if directory doesn't exist\n try {\n await fs.promises.access(subdir).catch(() => {\n return; // Directory doesn't exist\n });\n\n await Promise.all(\n Object.entries(fileStructure[type]).map(async ([key, fileName]) => {\n const filePath = path.join(subdir, fileName);\n try {\n const module = await import(filePath).catch(() => null);\n if (module) {\n if (isAuthModule) {\n // Auth module uses different naming conventions\n const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);\n const expectedName = `${pascalKey}${\n type === \"dtos\" ? \"Dto\" : \"Schema\"\n }`;\n result[type][key] = module.default;\n } else {\n // Standard modules\n const expectedName =\n key === \"model\"\n ? `${pascalModelName}${type === \"dtos\" ? \"Dto\" : \"Schema\"}`\n : `${\n key.charAt(0).toUpperCase() + key.slice(1)\n }${pascalModelName}${type === \"dtos\" ? \"Dto\" : \"Schema\"}`;\n\n result[type][key] = module.default;\n }\n }\n } catch (error) {\n // Silent fail - file might not exist\n }\n })\n );\n } catch (error) {\n // Directory doesn't exist, continue silently\n }\n };\n\n // Process both subdirectories in parallel\n await Promise.all([processSubdir(\"dtos\"), processSubdir(\"schemas\")]);\n\n // Cache the result\n prismaModelsModules[modelName] = result;\n\n return result;\n}\n\nexport type ModelFieldDefition = {\n name: string;\n type: string;\n isUnique: boolean;\n};\n\n/**\n * Represents the structure of relation fields for Prisma models.\n * It includes both singular (one-to-one) and list (one-to-many) relationships.\n *\n * @typedef {Object} RelationFields\n * @property {Array<{name: string, type: string}>} singular - List of singular relationships.\n * @property {Array<{name: string, type: string}>} list - List of list relationships.\n */\nexport type RelationFields = {\n singular: Omit<ModelFieldDefition, \"isUnique\">[];\n list: Omit<ModelFieldDefition, \"isUnique\">[];\n};\n\nconst schemaFolderPath =\n process.env.PRISMA_SCHEMA_PATH || arkosEnv.PRISMA_SCHEMA_PATH;\n\n/**\n * Reads the Prisma schema files and extracts all model definitions,\n * identifying their relations (one-to-one and one-to-many).\n */\nconst prismaModelRelationFields: Record<string, RelationFields> = {};\n\nconst prismaContent: string[] = [];\n\nexport function getAllPrismaFiles(dirPath: string, fileList: string[] = []) {\n const files = fs.readdirSync(dirPath);\n\n files?.forEach((file) => {\n const filePath = path.join(dirPath, file);\n const stat = fs.statSync(filePath);\n\n // Skip migrations folder\n if (stat.isDirectory() && file !== \"migrations\") {\n fileList = getAllPrismaFiles(filePath, fileList);\n } else if (stat.isFile() && file.endsWith(\".prisma\")) {\n fileList.push(filePath);\n }\n });\n\n return fileList;\n}\n\n// const prismaRootDir = \"\"; // Adjust this path if needed\nconst files = getAllPrismaFiles(\"./prisma\");\n\nfor (const file of files) {\n const content = fs.readFileSync(file, \"utf-8\");\n\n prismaContent.push(content);\n}\n\nconst modelRegex = /model\\s+(\\w+)\\s*{/g;\nconst models: string[] = [];\nexport const prismaModelsUniqueFields: Record<string, ModelFieldDefition[]> =\n [] as any;\n\nprismaContent.join(\"\\n\").replace(modelRegex, (_, modelName) => {\n if (!models.includes(modelName)) models.push(camelCase(modelName.trim()));\n return modelName;\n});\n\nfor (const model of models) {\n const modelName = pascalCase(model);\n\n let modelFile;\n for (const file of files) {\n const filePath = path.join(file);\n const stats = fs.statSync(filePath);\n\n if (stats.isFile()) {\n const content = fs.readFileSync(filePath, \"utf-8\");\n prismaContent.push(content);\n if (content.includes(`model ${modelName} {`)) {\n modelFile = file;\n break;\n }\n }\n }\n\n if (!modelFile) {\n throw new Error(`Model ${modelName} not found`);\n }\n\n const content = fs.readFileSync(path.join(modelFile), \"utf-8\");\n\n const modelStart = content.indexOf(`model ${modelName} {`);\n const modelEnd = content.indexOf(\"}\", modelStart);\n const modelDefinition = content.slice(modelStart, modelEnd);\n\n const relations: RelationFields = {\n singular: [],\n list: [],\n };\n const lines = modelDefinition.split(\"\\n\");\n\n for (const line of lines) {\n const trimmedLine = line.trim();\n\n if (\n !trimmedLine ||\n trimmedLine.startsWith(\"model\") ||\n trimmedLine.startsWith(\"//\")\n )\n continue;\n\n const [fieldName, type] = trimmedLine.split(/\\s+/);\n const isUnique = trimmedLine.includes(\"@unique\");\n\n if (isUnique)\n prismaModelsUniqueFields[model] = [\n ...(prismaModelsUniqueFields[model] || []),\n { name: fieldName, type, isUnique },\n ];\n\n const cleanType = type?.replace(\"[]\", \"\").replace(\"?\", \"\");\n\n if (\n trimmedLine.includes(\"@relation\") ||\n trimmedLine.match(/\\s+\\w+(\\[\\])?(\\s+@|$)/) ||\n models.includes(camelCase(cleanType || \"\"))\n ) {\n const modelStart = content.indexOf(`enum ${cleanType} {`);\n\n if (\n !cleanType ||\n modelStart >= 0 ||\n cleanType === \"String\" ||\n cleanType === \"Int\" ||\n cleanType === \"Float\" ||\n cleanType === \"Boolean\" ||\n cleanType === \"DateTime\" ||\n cleanType === \"Bytes\" ||\n cleanType === \"Decimal\" ||\n cleanType === \"BigInt\" ||\n cleanType === \"Json\"\n ) {\n continue;\n }\n\n if (!type?.includes(\"[]\")) {\n relations.singular.push({\n name: fieldName,\n type: cleanType,\n });\n } else {\n relations.list.push({\n name: fieldName,\n type: cleanType,\n });\n }\n }\n\n prismaModelRelationFields[modelName] = relations;\n }\n}\n\n/**\n * Retrieves the relations for a given Prisma model.\n *\n * @param {string} modelName - The name of the model (e.g., \"User\").\n * @returns {RelationFields|undefined} The relation fields for the model, or `undefined` if no relations are found.\n */\nexport function getPrismaModelRelations(modelName: string) {\n modelName = pascalCase(modelName);\n\n if (!(modelName in prismaModelRelationFields)) return;\n return prismaModelRelationFields[modelName];\n}\n\n/**\n * Retrieves all the model names from the Prisma schema.\n *\n * @returns {string[]} An array of model names (e.g., [\"User\", \"Post\"]).\n */\nfunction getModels() {\n return models;\n}\n\n/** Retuns a given model unique fields\n * @param {string} modelName - The name of model in PascalCase\n * @returns {string[]} An array of all unique fields,\n */\nfunction getModelUniqueFields(modelName: string) {\n return prismaModelsUniqueFields[modelName];\n}\n\nexport { models, getModels, getModelUniqueFields, prismaModelRelationFields };\n"]}
|
|
1
|
+
{"version":3,"file":"models.helpers.js","sourceRoot":"","sources":["../../../../src/utils/helpers/models.helpers.ts"],"names":[],"mappings":"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","sourcesContent":["import path from \"path\";\nimport fs from \"fs\";\nimport {\n camelCase,\n kebabCase,\n pascalCase,\n} from \"../../utils/helpers/change-case.helpers\";\nimport { userFileExtension } from \"./fs.helpers\";\nimport { importModule } from \"./global.helpers\";\n\nexport let prismaModelsModules: Record<\n string,\n Awaited<ReturnType<typeof importPrismaModelModules>>\n> = {};\n\nexport function getModelModules(modelName: string) {\n return prismaModelsModules[kebabCase(modelName)];\n}\n\nexport function getFileModelModulesFileStructure(modelName: string) {\n const kebabModelName = kebabCase(modelName).toLowerCase();\n const lowerModelName = kebabModelName.toLowerCase();\n const isAuthModule = modelName.toLowerCase() === \"auth\";\n\n return {\n core: {\n service: `${kebabModelName}.service.${userFileExtension}`,\n controller: `${kebabModelName}.controller.${userFileExtension}`,\n middlewares: `${kebabModelName}.middlewares.${userFileExtension}`,\n authConfigs: `${kebabModelName}.auth-configs.${userFileExtension}`,\n prismaQueryOptions: `${kebabModelName}.prisma-query-options.${userFileExtension}`,\n router: `${kebabModelName}.router.${userFileExtension}`,\n },\n dtos: isAuthModule\n ? {\n login: `login.dto.${userFileExtension}`,\n signup: `signup.dto.${userFileExtension}`,\n updateMe: `update-me.dto.${userFileExtension}`,\n updatePassword: `update-password.dto.${userFileExtension}`,\n }\n : {\n model: `${lowerModelName}.dto.${userFileExtension}`,\n create: `create-${lowerModelName}.dto.${userFileExtension}`,\n update: `update-${lowerModelName}.dto.${userFileExtension}`,\n query: `query-${lowerModelName}.dto.${userFileExtension}`,\n },\n schemas: isAuthModule\n ? {\n login: `login.schema.${userFileExtension}`,\n signup: `signup.schema.${userFileExtension}`,\n updateMe: `update-me.schema.${userFileExtension}`,\n updatePassword: `update-password.schema.${userFileExtension}`,\n }\n : {\n model: `${lowerModelName}.schema.${userFileExtension}`,\n create: `create-${lowerModelName}.schema.${userFileExtension}`,\n update: `update-${lowerModelName}.schema.${userFileExtension}`,\n query: `query-${lowerModelName}.schema.${userFileExtension}`,\n },\n };\n}\n\nexport async function processSubdir(\n modelName: string,\n type: \"dtos\" | \"schemas\",\n result: Record<string, any>\n) {\n const moduleDir = path.resolve(\n process.cwd(),\n \"src\",\n \"modules\",\n kebabCase(modelName)\n );\n\n const subdir = path.join(moduleDir, type);\n const pascalModelName = pascalCase(modelName);\n const fileStructure = getFileModelModulesFileStructure(modelName);\n const isAuthModule = modelName.toLowerCase() === \"auth\";\n\n // Skip if directory doesn't exist\n try {\n await fs.promises.access(subdir).catch(() => {\n return; // Directory doesn't exist\n });\n\n await Promise.all(\n Object.entries(fileStructure[type]).map(async ([key, fileName]) => {\n const filePath = path.join(subdir, fileName);\n try {\n const module = await import(filePath).catch(() => null);\n if (module) {\n if (isAuthModule) {\n // Auth module uses different naming conventions\n const pascalKey = key.charAt(0).toUpperCase() + key.slice(1);\n const expectedName = `${pascalKey}${\n type === \"dtos\" ? \"Dto\" : \"Schema\"\n }`;\n result[type][key] = module.default;\n } else {\n // Standard modules\n const expectedName =\n key === \"model\"\n ? `${pascalModelName}${type === \"dtos\" ? \"Dto\" : \"Schema\"}`\n : `${\n key.charAt(0).toUpperCase() + key.slice(1)\n }${pascalModelName}${type === \"dtos\" ? \"Dto\" : \"Schema\"}`;\n\n result[type][key] = module.default;\n }\n }\n } catch (error) {\n // Silent fail - file might not exist\n }\n })\n );\n } catch (error) {\n // Directory doesn't exist, continue silently\n }\n}\n\n/**\n * Dynamically imports model-specific modules for a given model with optimized file handling.\n * Includes special handling for the Auth module.\n *\n * @param {string} modelName - The name of the model (e.g., \"User\", \"Post\", \"Auth\").\n * @returns {Promise<Object>} An object containing the imported modules\n */\nexport async function importPrismaModelModules(\n modelName: string\n): Promise<Record<string, any>> {\n const moduleDir = path.resolve(process.cwd(), \"src\", \"modules\", modelName);\n\n const result: {\n service?: any;\n controller?: any;\n middlewares?: any;\n authConfigs?: any;\n prismaQueryOptions?: any;\n router?: any;\n dtos: Record<string, any>;\n schemas: Record<string, any>;\n } = {\n dtos: {},\n schemas: {},\n };\n\n const fileStructure = getFileModelModulesFileStructure(modelName);\n // Batch process core files\n await Promise.all(\n Object.entries(fileStructure.core).map(async ([key, fileName]) => {\n const filePath = path.join(moduleDir, fileName);\n try {\n const module = await importModule(filePath).catch(() => null);\n if (module) {\n if (key === \"middlewares\") result[key] = module;\n else result[key as keyof typeof result] = module.default || module;\n }\n } catch {}\n })\n );\n\n await Promise.all([\n processSubdir(modelName, \"dtos\", result),\n processSubdir(modelName, \"schemas\", result),\n ]);\n\n // Cache the result\n prismaModelsModules[modelName] = result;\n\n return result;\n}\n\nexport type ModelFieldDefition = {\n name: string;\n type: string;\n isUnique: boolean;\n};\n\n/**\n * Represents the structure of relation fields for Prisma models.\n * It includes both singular (one-to-one) and list (one-to-many) relationships.\n *\n * @typedef {Object} RelationFields\n * @property {Array<{name: string, type: string}>} singular - List of singular relationships.\n * @property {Array<{name: string, type: string}>} list - List of list relationships.\n */\nexport type RelationFields = {\n singular: Omit<ModelFieldDefition, \"isUnique\">[];\n list: Omit<ModelFieldDefition, \"isUnique\">[];\n};\n\n/**\n * Reads the Prisma schema files and extracts all model definitions,\n * identifying their relations (one-to-one and one-to-many).\n */\nexport const prismaModelRelationFields: Record<string, RelationFields> = {};\n\nexport function getAllPrismaFiles(dirPath: string, fileList: string[] = []) {\n const files = fs.readdirSync(dirPath);\n\n files?.forEach((file) => {\n const filePath = path.join(dirPath, file);\n const stat = fs.statSync(filePath);\n\n // Skip migrations folder\n if (stat.isDirectory() && file !== \"migrations\") {\n fileList = getAllPrismaFiles(filePath, fileList);\n } else if (stat.isFile() && file.endsWith(\".prisma\")) {\n fileList.push(filePath);\n }\n });\n\n return fileList;\n}\n\nconst modelRegex = /model\\s+(\\w+)\\s*{/g;\nexport const models: string[] = [];\nexport const prismaModelsUniqueFields: Record<string, ModelFieldDefition[]> =\n [] as any;\n\nexport function initializePrismaModels(testName?: string) {\n const prismaContent: string[] = [];\n\n const files = getAllPrismaFiles(\"./prisma\");\n\n for (const file of files) {\n const content = fs.readFileSync(file, \"utf-8\");\n\n if (!prismaContent.includes(content)) prismaContent.push(content);\n }\n\n const content = prismaContent\n .join(\"\\n\")\n .replace(modelRegex, (_, modelName) => {\n if (!models.includes(modelName)) models.push(camelCase(modelName.trim()));\n return `model ${modelName} {`;\n });\n\n for (const model of models) {\n const modelName = pascalCase(model);\n\n // let modelFile;\n // for (const file of files) {\n // const filePath = path.join(file);\n // const stats = fs.statSync(filePath);\n\n // if (stats.isFile()) {\n // const content = fs.readFileSync(filePath, \"utf-8\");\n // prismaContent.push(content);\n // if (content.includes(`model ${modelName} {`)) {\n // modelFile = file;\n // break;\n // }\n // }\n // }\n\n // if (!modelFile) {\n // return;\n // }\n\n // const content = fs.readFileSync(path.join(modelFile), \"utf-8\");\n const modelStart = content.indexOf(`model ${modelName} {`);\n const modelEnd = content.indexOf(\"}\", modelStart);\n const modelDefinition = content.slice(modelStart, modelEnd);\n\n const relations: RelationFields = {\n singular: [],\n list: [],\n };\n const lines = modelDefinition.split(\"\\n\");\n\n for (const line of lines) {\n const trimmedLine = line.trim();\n\n if (\n !trimmedLine ||\n trimmedLine.startsWith(\"model\") ||\n trimmedLine.startsWith(\"//\")\n )\n continue;\n\n const [fieldName, type] = trimmedLine.split(/\\s+/);\n const isUnique = trimmedLine.includes(\"@unique\");\n\n if (isUnique) {\n const existingFields = prismaModelsUniqueFields[model] || [];\n\n const alreadyExists = existingFields.some(\n (field) =>\n field.name === fieldName &&\n field.type === type &&\n field.isUnique === isUnique\n );\n\n if (!alreadyExists) {\n prismaModelsUniqueFields[model] = [\n ...existingFields,\n { name: fieldName, type, isUnique },\n ];\n }\n }\n\n const cleanType = type?.replace(\"[]\", \"\").replace(\"?\", \"\");\n\n if (\n trimmedLine.includes(\"@relation\") ||\n trimmedLine.match(/\\s+\\w+(\\[\\])?(\\s+@|$)/) ||\n models.includes(camelCase(cleanType || \"\"))\n ) {\n const modelStart = content.indexOf(`enum ${cleanType} {`);\n\n if (\n !cleanType ||\n modelStart >= 0 ||\n cleanType === \"String\" ||\n cleanType === \"Int\" ||\n cleanType === \"Float\" ||\n cleanType === \"Boolean\" ||\n cleanType === \"DateTime\" ||\n cleanType === \"Bytes\" ||\n cleanType === \"Decimal\" ||\n cleanType === \"BigInt\" ||\n cleanType === \"Json\"\n ) {\n continue;\n }\n\n if (!type?.includes(\"[]\")) {\n relations.singular.push({\n name: fieldName,\n type: cleanType,\n });\n } else {\n relations.list.push({\n name: fieldName,\n type: cleanType,\n });\n }\n }\n\n prismaModelRelationFields[modelName] = relations;\n }\n }\n}\n\ninitializePrismaModels();\n\n/**\n * Retrieves the relations for a given Prisma model.\n *\n * @param {string} modelName - The name of the model (e.g., \"User\").\n * @returns {RelationFields|undefined} The relation fields for the model, or `undefined` if no relations are found.\n */\nexport function getPrismaModelRelations(modelName: string) {\n modelName = pascalCase(modelName);\n\n if (!(modelName in prismaModelRelationFields)) return;\n return prismaModelRelationFields[modelName];\n}\n\n/**\n * Retrieves all the model names from the Prisma schema.\n *\n * @returns {string[]} An array of model names (e.g., [\"User\", \"Post\"]).\n */\nfunction getModels() {\n return models;\n}\n\n/** Retuns a given model unique fields\n * @param {string} modelName - The name of model in PascalCase\n * @returns {string[]} An array of all unique fields,\n */\nfunction getModelUniqueFields(modelName: string) {\n return prismaModelsUniqueFields[modelName];\n}\n\nexport { getModels, getModelUniqueFields };\n"]}
|
|
@@ -1,24 +1,55 @@
|
|
|
1
1
|
export declare let prismaModelsModules: Record<string, Awaited<ReturnType<typeof importPrismaModelModules>>>;
|
|
2
|
-
export declare function getModelModules(modelName: string):
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
2
|
+
export declare function getModelModules(modelName: string): Record<string, any>;
|
|
3
|
+
export declare function getFileModelModulesFileStructure(modelName: string): {
|
|
4
|
+
core: {
|
|
5
|
+
service: string;
|
|
6
|
+
controller: string;
|
|
7
|
+
middlewares: string;
|
|
8
|
+
authConfigs: string;
|
|
9
|
+
prismaQueryOptions: string;
|
|
10
|
+
router: string;
|
|
11
|
+
};
|
|
12
|
+
dtos: {
|
|
13
|
+
login: string;
|
|
14
|
+
signup: string;
|
|
15
|
+
updateMe: string;
|
|
16
|
+
updatePassword: string;
|
|
17
|
+
model?: undefined;
|
|
18
|
+
create?: undefined;
|
|
19
|
+
update?: undefined;
|
|
20
|
+
query?: undefined;
|
|
21
|
+
} | {
|
|
22
|
+
model: string;
|
|
23
|
+
create: string;
|
|
24
|
+
update: string;
|
|
25
|
+
query: string;
|
|
26
|
+
login?: undefined;
|
|
27
|
+
signup?: undefined;
|
|
28
|
+
updateMe?: undefined;
|
|
29
|
+
updatePassword?: undefined;
|
|
30
|
+
};
|
|
31
|
+
schemas: {
|
|
32
|
+
login: string;
|
|
33
|
+
signup: string;
|
|
34
|
+
updateMe: string;
|
|
35
|
+
updatePassword: string;
|
|
36
|
+
model?: undefined;
|
|
37
|
+
create?: undefined;
|
|
38
|
+
update?: undefined;
|
|
39
|
+
query?: undefined;
|
|
40
|
+
} | {
|
|
41
|
+
model: string;
|
|
42
|
+
create: string;
|
|
43
|
+
update: string;
|
|
44
|
+
query: string;
|
|
45
|
+
login?: undefined;
|
|
46
|
+
signup?: undefined;
|
|
47
|
+
updateMe?: undefined;
|
|
48
|
+
updatePassword?: undefined;
|
|
49
|
+
};
|
|
11
50
|
};
|
|
12
|
-
export declare function
|
|
13
|
-
|
|
14
|
-
controller?: any;
|
|
15
|
-
middlewares?: any;
|
|
16
|
-
authConfigs?: any;
|
|
17
|
-
prismaQueryOptions?: any;
|
|
18
|
-
router?: any;
|
|
19
|
-
dtos: Record<string, any>;
|
|
20
|
-
schemas: Record<string, any>;
|
|
21
|
-
}>;
|
|
51
|
+
export declare function processSubdir(modelName: string, type: "dtos" | "schemas", result: Record<string, any>): Promise<void>;
|
|
52
|
+
export declare function importPrismaModelModules(modelName: string): Promise<Record<string, any>>;
|
|
22
53
|
export type ModelFieldDefition = {
|
|
23
54
|
name: string;
|
|
24
55
|
type: string;
|
|
@@ -28,11 +59,12 @@ export type RelationFields = {
|
|
|
28
59
|
singular: Omit<ModelFieldDefition, "isUnique">[];
|
|
29
60
|
list: Omit<ModelFieldDefition, "isUnique">[];
|
|
30
61
|
};
|
|
31
|
-
declare const prismaModelRelationFields: Record<string, RelationFields>;
|
|
62
|
+
export declare const prismaModelRelationFields: Record<string, RelationFields>;
|
|
32
63
|
export declare function getAllPrismaFiles(dirPath: string, fileList?: string[]): string[];
|
|
33
|
-
declare const models: string[];
|
|
64
|
+
export declare const models: string[];
|
|
34
65
|
export declare const prismaModelsUniqueFields: Record<string, ModelFieldDefition[]>;
|
|
66
|
+
export declare function initializePrismaModels(testName?: string): void;
|
|
35
67
|
export declare function getPrismaModelRelations(modelName: string): RelationFields | undefined;
|
|
36
68
|
declare function getModels(): string[];
|
|
37
69
|
declare function getModelUniqueFields(modelName: string): ModelFieldDefition[];
|
|
38
|
-
export {
|
|
70
|
+
export { getModels, getModelUniqueFields };
|