@modern-js/server-generator 2.4.16 → 2.4.18
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/index.js +0 -4
- package/package.json +8 -8
- package/src/index.ts +199 -0
package/dist/index.js
CHANGED
|
@@ -85064,7 +85064,6 @@ var require_downloadPackage = __commonJSMin((exports) => {
|
|
|
85064
85064
|
if (response.status !== 200) {
|
|
85065
85065
|
throw new Error(`download tar package get bad status code: ${response.status}`);
|
|
85066
85066
|
}
|
|
85067
|
-
const contentLength = Number(response.headers["content-length"]);
|
|
85068
85067
|
const randomId = Math.floor(Math.random() * 1e4);
|
|
85069
85068
|
const tempTgzFilePath = `${_os.default.tmpdir()}/temp-${randomId}.tgz`;
|
|
85070
85069
|
const dest = _utils.fs.createWriteStream(tempTgzFilePath);
|
|
@@ -85077,9 +85076,6 @@ var require_downloadPackage = __commonJSMin((exports) => {
|
|
|
85077
85076
|
resolve();
|
|
85078
85077
|
});
|
|
85079
85078
|
});
|
|
85080
|
-
if ((await _utils.fs.stat(tempTgzFilePath)).size !== contentLength) {
|
|
85081
|
-
throw new Error("download tar package get bad content length");
|
|
85082
|
-
}
|
|
85083
85079
|
await new Promise((resolve, reject) => {
|
|
85084
85080
|
_utils.fs.createReadStream(tempTgzFilePath).pipe(_tar.default.x({
|
|
85085
85081
|
strip: 1,
|
package/package.json
CHANGED
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
"modern",
|
|
12
12
|
"modern.js"
|
|
13
13
|
],
|
|
14
|
-
"version": "2.4.
|
|
14
|
+
"version": "2.4.18",
|
|
15
15
|
"jsnext:source": "./src/index.ts",
|
|
16
16
|
"types": "./src/index.ts",
|
|
17
17
|
"main": "./dist/index.js",
|
|
@@ -21,17 +21,17 @@
|
|
|
21
21
|
],
|
|
22
22
|
"devDependencies": {
|
|
23
23
|
"@babel/runtime": "^7.18.0",
|
|
24
|
-
"@modern-js/codesmith": "1.6.
|
|
25
|
-
"@modern-js/codesmith-api-app": "1.6.
|
|
26
|
-
"@modern-js/codesmith-api-json": "1.6.
|
|
24
|
+
"@modern-js/codesmith": "1.6.4",
|
|
25
|
+
"@modern-js/codesmith-api-app": "1.6.4",
|
|
26
|
+
"@modern-js/codesmith-api-json": "1.6.4",
|
|
27
27
|
"@types/jest": "^27",
|
|
28
28
|
"@types/node": "^14",
|
|
29
29
|
"jest": "^27",
|
|
30
30
|
"typescript": "^4",
|
|
31
|
-
"@modern-js/generator-common": "2.4.
|
|
32
|
-
"@modern-js/generator-utils": "2.4.
|
|
33
|
-
"@scripts/build": "1.22.
|
|
34
|
-
"@scripts/jest-config": "1.22.
|
|
31
|
+
"@modern-js/generator-common": "2.4.18",
|
|
32
|
+
"@modern-js/generator-utils": "2.4.18",
|
|
33
|
+
"@scripts/build": "1.22.7",
|
|
34
|
+
"@scripts/jest-config": "1.22.7"
|
|
35
35
|
},
|
|
36
36
|
"sideEffects": false,
|
|
37
37
|
"modernConfig": {
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import {
|
|
3
|
+
fs,
|
|
4
|
+
getModernPluginVersion,
|
|
5
|
+
getPackageVersion,
|
|
6
|
+
isTsProject,
|
|
7
|
+
readTsConfigByFile,
|
|
8
|
+
} from '@modern-js/generator-utils';
|
|
9
|
+
import { GeneratorContext, GeneratorCore } from '@modern-js/codesmith';
|
|
10
|
+
import { AppAPI } from '@modern-js/codesmith-api-app';
|
|
11
|
+
import { JsonAPI } from '@modern-js/codesmith-api-json';
|
|
12
|
+
import {
|
|
13
|
+
Framework,
|
|
14
|
+
FrameworkAppendTypeContent,
|
|
15
|
+
i18n,
|
|
16
|
+
Language,
|
|
17
|
+
ServerSchema,
|
|
18
|
+
Solution,
|
|
19
|
+
} from '@modern-js/generator-common';
|
|
20
|
+
|
|
21
|
+
function isEmptyServerDir(serverDir: string) {
|
|
22
|
+
const files = fs.readdirSync(serverDir);
|
|
23
|
+
if (files.length === 0) {
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
return files.every(file => {
|
|
27
|
+
if (fs.statSync(path.join(serverDir, file)).isDirectory()) {
|
|
28
|
+
const childFiles = fs.readdirSync(path.join(serverDir, file));
|
|
29
|
+
return childFiles.length === 0;
|
|
30
|
+
}
|
|
31
|
+
return false;
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const handleTemplateFile = async (
|
|
36
|
+
context: GeneratorContext,
|
|
37
|
+
generator: GeneratorCore,
|
|
38
|
+
appApi: AppAPI,
|
|
39
|
+
) => {
|
|
40
|
+
const jsonAPI = new JsonAPI(generator);
|
|
41
|
+
const ans = await appApi.getInputBySchema(ServerSchema, context.config);
|
|
42
|
+
|
|
43
|
+
const appDir = context.materials.default.basePath;
|
|
44
|
+
const serverDir = path.join(appDir, 'server');
|
|
45
|
+
|
|
46
|
+
if (fs.existsSync(serverDir) && !isEmptyServerDir(serverDir)) {
|
|
47
|
+
const files = fs.readdirSync('server');
|
|
48
|
+
if (files.length > 0) {
|
|
49
|
+
generator.logger.warn("'server' is already exist");
|
|
50
|
+
// eslint-disable-next-line no-process-exit
|
|
51
|
+
process.exit(1);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const { framework } = ans;
|
|
56
|
+
|
|
57
|
+
const language = isTsProject(appDir) ? Language.TS : Language.JS;
|
|
58
|
+
|
|
59
|
+
if (language === Language.JS && framework === Framework.Nest) {
|
|
60
|
+
generator.logger.warn('nest not support js project');
|
|
61
|
+
// eslint-disable-next-line no-process-exit
|
|
62
|
+
process.exit(1);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
let updateInfo = {};
|
|
66
|
+
|
|
67
|
+
if (framework === Framework.Express || framework === Framework.Koa) {
|
|
68
|
+
updateInfo = {
|
|
69
|
+
[`devDependencies.@types/${
|
|
70
|
+
framework as string
|
|
71
|
+
}`]: `^${await getPackageVersion(`@types/${framework as string}`)}`,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (framework === Framework.Nest) {
|
|
76
|
+
updateInfo = {
|
|
77
|
+
'dependencies.@nestjs/core': `^${await getPackageVersion(
|
|
78
|
+
'@nestjs/core',
|
|
79
|
+
)}`,
|
|
80
|
+
'dependencies.@nestjs/common': `^${await getPackageVersion(
|
|
81
|
+
'@nestjs/common',
|
|
82
|
+
)}`,
|
|
83
|
+
'dependencies.express': `^${await getPackageVersion('express')}`,
|
|
84
|
+
'devDependencies.@types/express': `^${await getPackageVersion(
|
|
85
|
+
'@types/express',
|
|
86
|
+
)}`,
|
|
87
|
+
};
|
|
88
|
+
} else {
|
|
89
|
+
updateInfo = {
|
|
90
|
+
...updateInfo,
|
|
91
|
+
[`dependencies.${framework as string}`]: `^${await getPackageVersion(
|
|
92
|
+
framework as string,
|
|
93
|
+
)}`,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
const getServerPluginVersion = (packageName: string) => {
|
|
98
|
+
return getModernPluginVersion(Solution.MWA, packageName, {
|
|
99
|
+
registry: context.config.registry,
|
|
100
|
+
distTag: context.config.distTag,
|
|
101
|
+
});
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
await jsonAPI.update(
|
|
105
|
+
context.materials.default.get(path.join(appDir, 'package.json')),
|
|
106
|
+
{
|
|
107
|
+
query: {},
|
|
108
|
+
update: {
|
|
109
|
+
$set: {
|
|
110
|
+
'dependencies.@modern-js/plugin-server': `${await getServerPluginVersion(
|
|
111
|
+
'@modern-js/plugin-server',
|
|
112
|
+
)}`,
|
|
113
|
+
[`dependencies.@modern-js/plugin-${
|
|
114
|
+
framework as string
|
|
115
|
+
}`]: `${await getServerPluginVersion(
|
|
116
|
+
`@modern-js/plugin-${framework as string}`,
|
|
117
|
+
)}`,
|
|
118
|
+
...updateInfo,
|
|
119
|
+
},
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
);
|
|
123
|
+
|
|
124
|
+
await appApi.forgeTemplate(
|
|
125
|
+
`templates/base-template/${language}/**/*`,
|
|
126
|
+
undefined,
|
|
127
|
+
resourceKey =>
|
|
128
|
+
resourceKey
|
|
129
|
+
.replace(`templates/base-template/${language}/`, '')
|
|
130
|
+
.replace('.handlebars', ''),
|
|
131
|
+
);
|
|
132
|
+
|
|
133
|
+
if (language === Language.TS) {
|
|
134
|
+
const tsconfigJSON = readTsConfigByFile(path.join(appDir, 'tsconfig.json'));
|
|
135
|
+
|
|
136
|
+
if (!(tsconfigJSON.include || []).includes('server')) {
|
|
137
|
+
await jsonAPI.update(
|
|
138
|
+
context.materials.default.get(path.join(appDir, 'tsconfig.json')),
|
|
139
|
+
{
|
|
140
|
+
query: {},
|
|
141
|
+
update: {
|
|
142
|
+
$set: {
|
|
143
|
+
include: [...(tsconfigJSON.include || []), 'server'],
|
|
144
|
+
},
|
|
145
|
+
},
|
|
146
|
+
},
|
|
147
|
+
);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
await appApi.forgeTemplate(
|
|
152
|
+
`templates/${framework as string}/**/*`,
|
|
153
|
+
resourceKey => resourceKey.includes(language),
|
|
154
|
+
resourceKey =>
|
|
155
|
+
resourceKey
|
|
156
|
+
.replace(`templates/${framework as string}/`, 'server/')
|
|
157
|
+
.replace('.handlebars', ''),
|
|
158
|
+
);
|
|
159
|
+
|
|
160
|
+
const appendTypeContent = FrameworkAppendTypeContent[framework as Framework];
|
|
161
|
+
|
|
162
|
+
if (appendTypeContent && language === Language.TS) {
|
|
163
|
+
const typePath = path.join(appDir, 'src', 'modern-app-env.d.ts');
|
|
164
|
+
if (fs.existsSync(typePath)) {
|
|
165
|
+
const npmrc = fs.readFileSync(typePath, 'utf-8');
|
|
166
|
+
if (!npmrc.includes(appendTypeContent)) {
|
|
167
|
+
fs.writeFileSync(typePath, `${npmrc}${appendTypeContent}\n`, 'utf-8');
|
|
168
|
+
}
|
|
169
|
+
} else {
|
|
170
|
+
fs.ensureFileSync(typePath);
|
|
171
|
+
fs.writeFileSync(typePath, appendTypeContent, 'utf-8');
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
|
|
176
|
+
export default async (context: GeneratorContext, generator: GeneratorCore) => {
|
|
177
|
+
const appApi = new AppAPI(context, generator);
|
|
178
|
+
|
|
179
|
+
const { locale } = context.config;
|
|
180
|
+
i18n.changeLanguage({ locale });
|
|
181
|
+
appApi.i18n.changeLanguage({ locale });
|
|
182
|
+
|
|
183
|
+
if (!(await appApi.checkEnvironment())) {
|
|
184
|
+
// eslint-disable-next-line no-process-exit
|
|
185
|
+
process.exit(1);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
generator.logger.debug(`start run @modern-js/server-generator`);
|
|
189
|
+
generator.logger.debug(`context=${JSON.stringify(context)}`);
|
|
190
|
+
generator.logger.debug(`context.data=${JSON.stringify(context.data)}`);
|
|
191
|
+
|
|
192
|
+
await handleTemplateFile(context, generator, appApi);
|
|
193
|
+
|
|
194
|
+
await appApi.runInstall(undefined, { ignoreScripts: true });
|
|
195
|
+
|
|
196
|
+
appApi.showSuccessInfo();
|
|
197
|
+
|
|
198
|
+
generator.logger.debug(`forge @modern-js/server-generator succeed `);
|
|
199
|
+
};
|