@gadmin2n/cli 0.0.160 → 0.0.162

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.
@@ -98,7 +98,10 @@ class PrismaAction extends abstract_action_1.AbstractAction {
98
98
  const verbose = !!((_b = options.find((option) => option.name === 'verbose')) === null || _b === void 0 ? void 0 : _b.value);
99
99
  // 分发过程按类别记账,收尾统一打摘要 / --verbose 打完整清单
100
100
  const stats = {
101
- serverModulesIndex: [],
101
+ serverGeneratedIndex: [],
102
+ serverGenerated: [],
103
+ serverGeneratedUnchanged: [],
104
+ serverGeneratedOrphans: [],
102
105
  serverModulesNew: [],
103
106
  serverModulesSkipped: [],
104
107
  routesNew: [],
@@ -109,16 +112,16 @@ class PrismaAction extends abstract_action_1.AbstractAction {
109
112
  };
110
113
  // 构建合并的 schema(两种模式都需要重建 schema.prisma)
111
114
  this.buildMergedSchema();
112
- // Staging 目录:generator 全量写入到 node_modules/.cache/*,CLI 再增量分发。
115
+ // Staging 目录:generator 全量写入到 .gadmin/generated/*,CLI 再增量分发。
113
116
  // 不放在 src/ 下,避免任何 watcher 感知到中间态的进出。
114
117
  // 用绝对路径以便 (a) 在 shell.cd('server/') 之后仍指向正确位置;
115
118
  // (b) 通过 env 传给 generator 子进程时无歧义。
116
119
  const cwd = process.cwd();
117
- const WEB_STAGING = (0, path_1.resolve)(cwd, 'web/node_modules/.cache/gadmin-web');
118
- const SERVER_STAGING = (0, path_1.resolve)(cwd, 'server/node_modules/.cache/gadmin-server');
120
+ const WEB_STAGING = (0, path_1.resolve)(cwd, '.gadmin/generated/web');
121
+ const SERVER_STAGING = (0, path_1.resolve)(cwd, '.gadmin/generated/server');
119
122
  const WEB_ROUTES_DIR = (0, path_1.resolve)(cwd, 'web/src/routes');
120
123
  // 每轮清空对应 staging,让「本轮 staging = 本轮完整产物」这个不变量成立,
121
- // 后续孤儿清理直接依赖它。父目录(如 web/node_modules/.cache/)不存在时先创建,
124
+ // 后续孤儿清理直接依赖它。父目录(如 .gadmin/generated/)不存在时先创建,
122
125
  // 避免 generator 首次运行时因缺目录报错。
123
126
  fs.rmSync(WEB_STAGING, { recursive: true, force: true });
124
127
  fs.mkdirSync(WEB_STAGING, { recursive: true });
@@ -144,7 +147,8 @@ class PrismaAction extends abstract_action_1.AbstractAction {
144
147
  // SERVER_STAGING/
145
148
  // modules.index.ts → diff-copy 到 server/src/generated/modules.index.ts
146
149
  // {model}/dto/{model}.form.validator.ts → diff-copy 到 web/src/generated/props/{model}/form.validator.ts(跨端)
147
- // {model}/**(其余) 首次落地到 server/src/modules/{model}/**
150
+ // {model}/dto/**(其余), {model}/entities/** diff-copy server/src/generated/{model}/**(权威、可被覆盖)
151
+ // {model}/**(其余:controller/service/module/spec) → 首次落地到 server/src/modules/{model}/**(保护用户编辑)
148
152
  // 收集 server staging 里的 model 列表:凡有 dto/{name}.form.validator.ts 的一级子目录即视为 model
149
153
  const stagingModels = fs.existsSync(SERVER_STAGING)
150
154
  ? fs
@@ -154,32 +158,55 @@ class PrismaAction extends abstract_action_1.AbstractAction {
154
158
  .filter((name) => fs.existsSync((0, path_1.join)(SERVER_STAGING, name, 'dto', `${name}.form.validator.ts`)))
155
159
  : [];
156
160
  // ============ 阶段 1:server 集中写入 ============
161
+ const serverGeneratedKeep = new Set();
157
162
  if (fs.existsSync(SERVER_STAGING)) {
158
- // 1.1 modules.index.ts —— 顶层入口
163
+ // 1.1 modules.index.ts —— 顶层入口(放在 generated 下的顶级文件)
159
164
  const modulesIndexSrc = (0, path_1.join)(SERVER_STAGING, 'modules.index.ts');
160
165
  if (fs.existsSync(modulesIndexSrc)) {
161
- const rel = 'server/src/generated/modules.index.ts';
162
- if ((0, sync_fs_1.copyFileIfChanged)(modulesIndexSrc, rel)) {
163
- stats.serverModulesIndex.push(rel);
166
+ const rel = 'modules.index.ts';
167
+ const dest = (0, path_1.join)('server/src/generated', rel);
168
+ if ((0, sync_fs_1.copyFileIfChanged)(modulesIndexSrc, dest)) {
169
+ stats.serverGeneratedIndex.push(dest);
164
170
  }
171
+ serverGeneratedKeep.add(rel);
165
172
  }
166
- // 1.2 逐 model 首次落地到 server/src/modules/{model}(跳过 form.validator,它归 web 阶段)
173
+ // 1.2 逐 model 分发。dto/entities generated(覆盖,权威),其余 → modules(首次落地)
167
174
  for (const modelName of stagingModels) {
168
175
  const modelStaging = (0, path_1.join)(SERVER_STAGING, modelName);
169
176
  const validatorInStaging = (0, path_1.join)('dto', `${modelName}.form.validator.ts`);
170
177
  for (const rel of (0, sync_fs_1.listFilesRecursive)(modelStaging)) {
171
178
  if (rel === validatorInStaging)
172
- continue;
173
- const dest = (0, path_1.join)('server/src/modules', modelName, rel);
174
- if (fs.existsSync(dest)) {
175
- stats.serverModulesSkipped.push(dest);
176
- continue;
179
+ continue; // 归 web 阶段处理
180
+ const isDto = rel.startsWith('dto' + path_1.sep) || rel.startsWith('dto/');
181
+ const isEntity = rel.startsWith('entities' + path_1.sep) ||
182
+ rel.startsWith('entities/');
183
+ if (isDto || isEntity) {
184
+ // 权威、每次覆盖到 server/src/generated/{model}/(controller 从这里 import)
185
+ const relInGenerated = (0, path_1.join)(modelName, rel);
186
+ const dest = (0, path_1.join)('server/src/generated', relInGenerated);
187
+ if ((0, sync_fs_1.copyFileIfChanged)((0, path_1.join)(modelStaging, rel), dest)) {
188
+ stats.serverGenerated.push(dest);
189
+ }
190
+ else {
191
+ stats.serverGeneratedUnchanged.push(dest);
192
+ }
193
+ serverGeneratedKeep.add(relInGenerated);
194
+ }
195
+ else {
196
+ // controller/service/module/spec —— 首次落地到 server/src/modules/{model}/
197
+ const dest = (0, path_1.join)('server/src/modules', modelName, rel);
198
+ if (fs.existsSync(dest)) {
199
+ stats.serverModulesSkipped.push(dest);
200
+ continue;
201
+ }
202
+ fs.mkdirSync((0, path_1.dirname)(dest), { recursive: true });
203
+ fs.copyFileSync((0, path_1.join)(modelStaging, rel), dest);
204
+ stats.serverModulesNew.push(dest);
177
205
  }
178
- fs.mkdirSync((0, path_1.dirname)(dest), { recursive: true });
179
- fs.copyFileSync((0, path_1.join)(modelStaging, rel), dest);
180
- stats.serverModulesNew.push(dest);
181
206
  }
182
207
  }
208
+ // 1.3 孤儿清理:删除 server/src/generated 下所有本轮未产出的文件(例如被删除的 model)
209
+ stats.serverGeneratedOrphans = (0, sync_fs_1.pruneOrphans)('server/src/generated', serverGeneratedKeep).map((r) => (0, path_1.join)('server/src/generated', r));
183
210
  }
184
211
  // ============ 阶段 2:web 集中写入 ============
185
212
  const webKeep = new Set();
@@ -258,14 +285,18 @@ class PrismaAction extends abstract_action_1.AbstractAction {
258
285
  });
259
286
  }
260
287
  printReport(stats, verbose) {
261
- const serverWritten = stats.serverModulesIndex.length + stats.serverModulesNew.length;
288
+ const serverWritten = stats.serverGeneratedIndex.length +
289
+ stats.serverGenerated.length +
290
+ stats.serverModulesNew.length;
262
291
  const webWritten = stats.generated.length + stats.routesNew.length;
263
292
  console.log('');
264
293
  console.log(chalk.bold('gadmin2 g prisma:'));
265
294
  console.log(` ${chalk.cyan('server')}: ${serverWritten} written` +
266
- ` (index=${stats.serverModulesIndex.length},` +
295
+ ` (index=${stats.serverGeneratedIndex.length},` +
296
+ ` generated=${stats.serverGenerated.length},` +
267
297
  ` modules-new=${stats.serverModulesNew.length}),` +
268
- ` ${stats.serverModulesSkipped.length} skipped`);
298
+ ` ${stats.serverGeneratedUnchanged.length + stats.serverModulesSkipped.length} unchanged,` +
299
+ ` ${stats.serverGeneratedOrphans.length} orphan removed`);
269
300
  console.log(` ${chalk.cyan('web')}: ${webWritten} written` +
270
301
  ` (routes-new=${stats.routesNew.length},` +
271
302
  ` generated=${stats.generated.length}),` +
@@ -282,7 +313,10 @@ class PrismaAction extends abstract_action_1.AbstractAction {
282
313
  for (const p of list)
283
314
  console.log(' ' + color(p));
284
315
  };
285
- printGroup('server modules.index (diff-write)', stats.serverModulesIndex, chalk.green);
316
+ printGroup('server generated modules.index (diff-write)', stats.serverGeneratedIndex, chalk.green);
317
+ printGroup('server generated (written)', stats.serverGenerated, chalk.green);
318
+ printGroup('server generated (unchanged)', stats.serverGeneratedUnchanged, chalk.gray);
319
+ printGroup('server generated orphans removed', stats.serverGeneratedOrphans, chalk.red);
286
320
  printGroup('server modules (new)', stats.serverModulesNew, chalk.green);
287
321
  printGroup('server modules (skipped, exists)', stats.serverModulesSkipped, chalk.gray);
288
322
  printGroup('web routes (new)', stats.routesNew, chalk.green);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gadmin2n/cli",
3
- "version": "0.0.160",
3
+ "version": "0.0.162",
4
4
  "description": "Gadmin - modern, fast, powerful node.js web framework (@cli)",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -47,7 +47,7 @@
47
47
  "@angular-devkit/core": "13.3.2",
48
48
  "@angular-devkit/schematics": "13.3.2",
49
49
  "@angular-devkit/schematics-cli": "13.3.2",
50
- "@gadmin2n/schematics": "^0.0.128",
50
+ "@gadmin2n/schematics": "^0.0.130",
51
51
  "abc": "^0.6.1",
52
52
  "chalk": "3.0.0",
53
53
  "chokidar": "3.5.3",