@common-stack/generate-plugin 5.0.6-alpha.5 → 5.0.6-alpha.8
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/CHANGELOG.md +8 -0
- package/README.md +280 -10
- package/cde-config.json +86 -0
- package/lib/constants/index.cjs +2 -1
- package/lib/constants/index.cjs.map +1 -1
- package/lib/constants/index.d.ts +1 -0
- package/lib/constants/index.mjs +2 -1
- package/lib/constants/index.mjs.map +1 -1
- package/lib/generators/add-backend/files/CHANGELOG.md +0 -0
- package/lib/generators/add-backend/files/Dockerfile +1 -1
- package/lib/generators/add-backend/files/__tests__/test.ts.template +3 -2
- package/lib/generators/add-backend/files/package.json +2 -48
- package/lib/generators/add-backend/generator.cjs +21 -17
- package/lib/generators/add-backend/generator.cjs.map +1 -1
- package/lib/generators/add-backend/generator.d.ts +1 -0
- package/lib/generators/add-backend/generator.mjs +21 -17
- package/lib/generators/add-backend/generator.mjs.map +1 -1
- package/lib/generators/add-browser-package/files/package.json +1 -1
- package/lib/generators/add-browser-package/generator.cjs +14 -16
- package/lib/generators/add-browser-package/generator.cjs.map +1 -1
- package/lib/generators/add-browser-package/generator.d.ts +1 -0
- package/lib/generators/add-browser-package/generator.mjs +14 -16
- package/lib/generators/add-browser-package/generator.mjs.map +1 -1
- package/lib/generators/add-client-package/files/package.json +2 -3
- package/lib/generators/add-client-package/generator.cjs +14 -16
- package/lib/generators/add-client-package/generator.cjs.map +1 -1
- package/lib/generators/add-client-package/generator.d.ts +1 -0
- package/lib/generators/add-client-package/generator.mjs +14 -16
- package/lib/generators/add-client-package/generator.mjs.map +1 -1
- package/lib/generators/add-core-package/files/package.json +2 -3
- package/lib/generators/add-core-package/generator.cjs +14 -16
- package/lib/generators/add-core-package/generator.cjs.map +1 -1
- package/lib/generators/add-core-package/generator.d.ts +1 -0
- package/lib/generators/add-core-package/generator.mjs +14 -16
- package/lib/generators/add-core-package/generator.mjs.map +1 -1
- package/lib/generators/add-frontend/frameworks/chakraui/entry.client.tsx.template +30 -24
- package/lib/generators/add-frontend/frameworks/chakraui/entry.server.tsx.template +5 -8
- package/lib/generators/add-frontend/frameworks/chakraui/root.tsx.template +3 -3
- package/lib/generators/add-frontend/frameworks/tailwindui/entry.client.tsx.template +90 -0
- package/lib/generators/add-frontend/frameworks/tailwindui/entry.server.tsx.template +238 -0
- package/lib/generators/add-frontend/frameworks/tailwindui/root.tsx.template +117 -0
- package/lib/generators/add-frontend/frameworks/tailwindui/tailwind.css +3 -0
- package/lib/generators/add-frontend/generator.cjs +60 -42
- package/lib/generators/add-frontend/generator.cjs.map +1 -1
- package/lib/generators/add-frontend/generator.d.ts +1 -0
- package/lib/generators/add-frontend/generator.mjs +60 -42
- package/lib/generators/add-frontend/generator.mjs.map +1 -1
- package/lib/generators/add-frontend/schema.json +1 -1
- package/lib/generators/add-frontend/templates/package.json +18 -77
- package/lib/generators/add-frontend/templates/postcss.config.js +6 -0
- package/lib/generators/add-frontend/templates/tailwind.config.ts.template +12 -0
- package/lib/generators/add-fullstack/files/Jenkinsfile +3 -6
- package/lib/generators/add-fullstack/files/jest-mongodb-config.js +3 -2
- package/lib/generators/add-fullstack/files/jest.config.base.js +43 -4
- package/lib/generators/add-fullstack/files/jest.config.base.mjs +99 -0
- package/lib/generators/add-fullstack/files/jest.config.mongodb.mjs +3 -0
- package/lib/generators/add-fullstack/files/lint-staged.config.js +4 -1
- package/lib/generators/add-fullstack/files/nx.json +18 -13
- package/lib/generators/add-fullstack/files/package.json +12 -24
- package/lib/generators/add-fullstack/files/tools/cli/helpers/util.js +1 -1
- package/lib/generators/add-fullstack/files/tools/deploy-cli/updateLernaVersion.js +1 -1
- package/lib/generators/add-fullstack/files/tools/deploy-cli/updateYamlSettings.js +14 -15
- package/lib/generators/add-fullstack/files/tools/prettier.config.js +8 -0
- package/lib/generators/add-fullstack/files/tools/rollup/rollupPluginGenerateJson.mjs +48 -0
- package/lib/generators/add-fullstack/files/tools/rollup/rollupPluginModifyLibFiles.mjs +410 -0
- package/lib/generators/add-fullstack/files/tools/runLint.mjs +15 -0
- package/lib/generators/add-fullstack/files/tools/sortPackageJson.mjs +8 -2
- package/lib/generators/add-fullstack/files/tools/update-dependencies.mjs +95 -0
- package/lib/generators/add-fullstack/files/tools/update-dependency-link.mjs +138 -0
- package/lib/generators/add-fullstack/files/tools/update-dependency-version.js +104 -89
- package/lib/generators/add-fullstack/files/tools/updateUtils.mjs +77 -0
- package/lib/generators/add-fullstack/generator.cjs +71 -13
- package/lib/generators/add-fullstack/generator.cjs.map +1 -1
- package/lib/generators/add-fullstack/generator.mjs +71 -13
- package/lib/generators/add-fullstack/generator.mjs.map +1 -1
- package/lib/generators/add-fullstack/schema.json +9 -0
- package/lib/generators/add-fullstack/updates/index.d.ts +2 -0
- package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.cjs +36 -0
- package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.cjs.map +1 -0
- package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.d.ts +1 -0
- package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.mjs +36 -0
- package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.mjs.map +1 -0
- package/lib/generators/add-fullstack/updates/packageJsonUpdate.cjs +8 -0
- package/lib/generators/add-fullstack/updates/packageJsonUpdate.cjs.map +1 -0
- package/lib/generators/add-fullstack/updates/packageJsonUpdate.d.ts +2 -0
- package/lib/generators/add-fullstack/updates/packageJsonUpdate.mjs +8 -0
- package/lib/generators/add-fullstack/updates/packageJsonUpdate.mjs.map +1 -0
- package/lib/generators/add-moleculer/files/package.json +3 -3
- package/lib/generators/add-moleculer/generator.cjs +14 -16
- package/lib/generators/add-moleculer/generator.cjs.map +1 -1
- package/lib/generators/add-moleculer/generator.d.ts +1 -0
- package/lib/generators/add-moleculer/generator.mjs +14 -16
- package/lib/generators/add-moleculer/generator.mjs.map +1 -1
- package/lib/generators/add-server-package/files/package.json +2 -2
- package/lib/generators/add-server-package/generator.cjs +14 -16
- package/lib/generators/add-server-package/generator.cjs.map +1 -1
- package/lib/generators/add-server-package/generator.d.ts +1 -0
- package/lib/generators/add-server-package/generator.mjs +14 -16
- package/lib/generators/add-server-package/generator.mjs.map +1 -1
- package/lib/index.cjs +1 -1
- package/lib/index.mjs +1 -1
- package/package.json +3 -2
- package/src/constants/index.ts +2 -1
- package/src/generators/add-backend/generator.ts +8 -4
- package/src/generators/add-browser-package/generator.ts +7 -6
- package/src/generators/add-client-package/generator.ts +7 -6
- package/src/generators/add-core-package/generator.ts +7 -6
- package/src/generators/add-frontend/frameworks/tailwindui/entry.client.tsx.template +90 -0
- package/src/generators/add-frontend/frameworks/tailwindui/entry.server.tsx.template +238 -0
- package/src/generators/add-frontend/frameworks/tailwindui/root.tsx.template +117 -0
- package/src/generators/add-frontend/frameworks/tailwindui/tailwind.css +3 -0
- package/src/generators/add-frontend/generator.ts +24 -2
- package/src/generators/add-frontend/schema.json +1 -1
- package/src/generators/add-fullstack/files/jest-mongodb-config.js +3 -2
- package/src/generators/add-fullstack/files/jest.config copy.js +27 -0
- package/src/generators/add-fullstack/files/jest.config.base.js +43 -4
- package/src/generators/add-fullstack/files/jest.config.base.mjs +99 -0
- package/src/generators/add-fullstack/files/jest.config.mongodb.mjs +3 -0
- package/src/generators/add-fullstack/files/lint-staged.config.js +4 -1
- package/src/generators/add-fullstack/files/nx.json +18 -13
- package/src/generators/add-fullstack/files/tools/cli/helpers/util.js +1 -1
- package/src/generators/add-fullstack/files/tools/deploy-cli/updateLernaVersion.js +1 -1
- package/src/generators/add-fullstack/files/tools/html-plugin-template.ejs +28 -0
- package/src/generators/add-fullstack/files/tools/prettier.config.js +8 -0
- package/src/generators/add-fullstack/files/tools/rollup/rollupPluginGenerateJson.mjs +48 -0
- package/src/generators/add-fullstack/files/tools/rollup/rollupPluginModifyLibFiles.mjs +410 -0
- package/src/generators/add-fullstack/files/tools/runLint.mjs +15 -0
- package/src/generators/add-fullstack/files/tools/sortPackageJson.mjs +0 -1
- package/src/generators/add-fullstack/files/tools/update-dependencies.mjs +95 -0
- package/src/generators/add-fullstack/files/tools/update-dependency-link.mjs +138 -0
- package/src/generators/add-fullstack/files/tools/update-dependency-version.js +104 -89
- package/src/generators/add-fullstack/files/tools/updateUtils.mjs +77 -0
- package/src/generators/add-fullstack/generator.ts +83 -1
- package/src/generators/add-fullstack/schema.d.ts +1 -0
- package/src/generators/add-fullstack/schema.json +4 -0
- package/src/generators/add-moleculer/files/package.json +1 -1
- package/src/generators/add-moleculer/generator.ts +7 -6
- package/src/generators/add-server-package/generator.ts +7 -6
- package/lib/generators/add-fullstack/files/tools/update-dependency-link.js +0 -107
- package/src/generators/add-fullstack/files/tools/update-dependency-link.js +0 -107
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { exec } from 'child_process';
|
|
2
|
+
import { resolve } from 'path';
|
|
3
|
+
import { readFile, writeFile } from 'fs/promises';
|
|
4
|
+
import { fileURLToPath } from 'url';
|
|
5
|
+
import { runLintStaged } from './runLint.mjs'; // Assuming updateLint.mjs exports this function
|
|
6
|
+
|
|
7
|
+
const __dirname = fileURLToPath(new URL('.', import.meta.url));
|
|
8
|
+
|
|
9
|
+
// Constants for JSON formatting
|
|
10
|
+
const JSON_SPACING = 4;
|
|
11
|
+
const ADD_END_NEWLINE = true; // Set to true to add a newline at the end of the file
|
|
12
|
+
|
|
13
|
+
// Paths to package.json files
|
|
14
|
+
const backendPackagePath = resolve(__dirname, '../servers/backend-server/package.json');
|
|
15
|
+
const frontendPackagePath = resolve(__dirname, '../servers/frontend-server/package.json');
|
|
16
|
+
|
|
17
|
+
// Packages to check
|
|
18
|
+
const packagesToCheck = [
|
|
19
|
+
'@common-stack/server-stack',
|
|
20
|
+
'@common-stack/frontend-stack-react'
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
// Function to update dependencies
|
|
24
|
+
const updateDependencies = async (targetPackagePath, sourcePackagePath) => {
|
|
25
|
+
const targetPackageJson = JSON.parse(await readFile(targetPackagePath, 'utf-8'));
|
|
26
|
+
const sourcePackageJson = JSON.parse(await readFile(sourcePackagePath, 'utf-8'));
|
|
27
|
+
|
|
28
|
+
const mergeDependencies = (targetDeps = {}, sourceDeps = {}) => ({
|
|
29
|
+
...targetDeps,
|
|
30
|
+
...sourceDeps
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
// Merge dependencies only
|
|
34
|
+
targetPackageJson.dependencies = mergeDependencies(
|
|
35
|
+
targetPackageJson.dependencies,
|
|
36
|
+
sourcePackageJson.dependencies
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
// Format the JSON string with the specified spacing
|
|
40
|
+
let jsonString = JSON.stringify(targetPackageJson, null, JSON_SPACING);
|
|
41
|
+
|
|
42
|
+
// Optionally add a newline at the end
|
|
43
|
+
if (ADD_END_NEWLINE) {
|
|
44
|
+
jsonString += '\n';
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// Write the formatted JSON back to disk
|
|
48
|
+
await writeFile(targetPackagePath, jsonString, 'utf-8');
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
// Function to run `ncu`, update dependencies, and then run linting
|
|
52
|
+
export const runUpdateDependencies = async () => {
|
|
53
|
+
// Run `ncu` command to update the dependencies from the root level
|
|
54
|
+
await new Promise((resolve, reject) => {
|
|
55
|
+
exec('ncu -u -t minor "@common-stack*" && lerna exec "ncu -u -t minor /@common-stack*/"', { cwd: resolve(__dirname, '..') }, (err, stdout, stderr) => {
|
|
56
|
+
if (err) {
|
|
57
|
+
console.error(`Error running ncu and lerna: ${stderr}`);
|
|
58
|
+
return reject(err);
|
|
59
|
+
}
|
|
60
|
+
console.log(stdout);
|
|
61
|
+
resolve();
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
// Check for changes in the specified packages
|
|
66
|
+
for (const packageName of packagesToCheck) {
|
|
67
|
+
const packagePath = resolve(__dirname, `../node_modules/${packageName}/package.json`);
|
|
68
|
+
try {
|
|
69
|
+
await updateDependencies(
|
|
70
|
+
packageName.includes('server-stack') ? backendPackagePath : frontendPackagePath,
|
|
71
|
+
packagePath
|
|
72
|
+
);
|
|
73
|
+
} catch (error) {
|
|
74
|
+
console.warn(`Package ${packageName} not found or failed to update:`, error);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
console.log('Dependencies from @common-stack packages have been updated.');
|
|
79
|
+
|
|
80
|
+
// Run linting to apply Prettier
|
|
81
|
+
try {
|
|
82
|
+
await runLintStaged();
|
|
83
|
+
console.log('Prettier formatting applied.');
|
|
84
|
+
} catch (err) {
|
|
85
|
+
console.error('Failed to run Prettier:', err);
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
// Execute the function if this file is run directly
|
|
90
|
+
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
91
|
+
runUpdateDependencies().catch(err => {
|
|
92
|
+
console.error('Failed to update dependencies:', err);
|
|
93
|
+
process.exit(1);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import glob from 'glob';
|
|
2
|
+
import { resolve, dirname, relative } from 'path';
|
|
3
|
+
import { readFileSync, writeFileSync } from 'fs';
|
|
4
|
+
import simpleGit from 'simple-git';
|
|
5
|
+
import { runLintStaged } from './runLint.mjs';
|
|
6
|
+
import { fileURLToPath } from 'url';
|
|
7
|
+
|
|
8
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
9
|
+
const __dirname = dirname(__filename);
|
|
10
|
+
|
|
11
|
+
// matching prettier format
|
|
12
|
+
const JSON_SPACING = 4;
|
|
13
|
+
const ADD_END_NEWLINE = true; // Set to true to add a newline at the end of the file
|
|
14
|
+
|
|
15
|
+
const git = simpleGit();
|
|
16
|
+
|
|
17
|
+
const monorepoRoot = resolve(__dirname, '..');
|
|
18
|
+
|
|
19
|
+
const findPackageJsonFiles = () => {
|
|
20
|
+
return new Promise((resolve, reject) => {
|
|
21
|
+
glob(
|
|
22
|
+
`${monorepoRoot}/+(servers|portable-devices|packages|packages-modules)/**/package.json`,
|
|
23
|
+
{ onlyFiles: true, ignore: '**/node_modules/**' },
|
|
24
|
+
(err, files) => {
|
|
25
|
+
if (err) reject(`Unable to scan directory: ${err}`);
|
|
26
|
+
resolve(files);
|
|
27
|
+
},
|
|
28
|
+
);
|
|
29
|
+
});
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const buildPackageMap = async () => {
|
|
33
|
+
const packageJsonFiles = await findPackageJsonFiles();
|
|
34
|
+
const packageMap = new Map();
|
|
35
|
+
|
|
36
|
+
packageJsonFiles.forEach((file) => {
|
|
37
|
+
const packageJson = JSON.parse(readFileSync(file, 'utf8'));
|
|
38
|
+
if (packageJson.name) {
|
|
39
|
+
packageMap.set(packageJson.name, {
|
|
40
|
+
path: dirname(file),
|
|
41
|
+
version: packageJson.version,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
return packageMap;
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
const searchAndUpdate = (dependencies, filePath, obj, packageMap) => {
|
|
50
|
+
let modified = false;
|
|
51
|
+
|
|
52
|
+
for (const key in dependencies) {
|
|
53
|
+
if (packageMap.has(key)) {
|
|
54
|
+
const targetDir = packageMap.get(key).path;
|
|
55
|
+
const relativePath = `link:${relative(dirname(filePath), targetDir)}`;
|
|
56
|
+
|
|
57
|
+
if (dependencies[key] !== relativePath) {
|
|
58
|
+
dependencies[key] = relativePath;
|
|
59
|
+
modified = true;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
if (modified) {
|
|
65
|
+
// Write the updated package.json back to disk with or without a newline at the end
|
|
66
|
+
let formattedJson = JSON.stringify(obj, null, JSON_SPACING);
|
|
67
|
+
if (ADD_END_NEWLINE) {
|
|
68
|
+
formattedJson += '\n';
|
|
69
|
+
}
|
|
70
|
+
writeFileSync(filePath, formattedJson, 'utf8');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return modified;
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
const updateDependencies = async () => {
|
|
77
|
+
const packageMap = await buildPackageMap();
|
|
78
|
+
const packageJsonFiles = await findPackageJsonFiles();
|
|
79
|
+
const modifiedFiles = [];
|
|
80
|
+
|
|
81
|
+
packageJsonFiles.forEach((file) => {
|
|
82
|
+
if (!file.includes('node_modules')) {
|
|
83
|
+
try {
|
|
84
|
+
const data = readFileSync(file, 'utf8');
|
|
85
|
+
const obj = JSON.parse(data);
|
|
86
|
+
const { dependencies, peerDependencies, devDependencies } = obj;
|
|
87
|
+
|
|
88
|
+
let modified = false;
|
|
89
|
+
modified = searchAndUpdate(dependencies, file, obj, packageMap) || modified;
|
|
90
|
+
modified = searchAndUpdate(peerDependencies, file, obj, packageMap) || modified;
|
|
91
|
+
modified = searchAndUpdate(devDependencies, file, obj, packageMap) || modified;
|
|
92
|
+
|
|
93
|
+
if (modified) {
|
|
94
|
+
console.log('--PUSHING FILE=---', file);
|
|
95
|
+
modifiedFiles.push(file);
|
|
96
|
+
}
|
|
97
|
+
} catch (err) {
|
|
98
|
+
console.error(`Unable to read file ${file}: ${err.message}`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
return modifiedFiles;
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
updateDependencies()
|
|
107
|
+
.then((modifiedFiles) => {
|
|
108
|
+
const addArray = modifiedFiles.map((file) => `./${relative(monorepoRoot, file)}`);
|
|
109
|
+
console.log('-- Modified Files --', modifiedFiles, addArray);
|
|
110
|
+
if (addArray.length === 0) {
|
|
111
|
+
console.log('No files to stage.');
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
return git.add(addArray).then(() => git.status()); // Stage files and then check status
|
|
115
|
+
})
|
|
116
|
+
.then((status) => {
|
|
117
|
+
if (status && status.modified.length) {
|
|
118
|
+
const fileArray = status.modified.filter((element) => element.includes('package.json'));
|
|
119
|
+
const addArray = fileArray.map((element) => `./${element}`);
|
|
120
|
+
return git
|
|
121
|
+
.add(addArray)
|
|
122
|
+
.then(runLintStaged)
|
|
123
|
+
.then(() => git.status()); // Run lint-staged after adding
|
|
124
|
+
} else {
|
|
125
|
+
console.log('No changes to lint or commit.');
|
|
126
|
+
return null;
|
|
127
|
+
}
|
|
128
|
+
})
|
|
129
|
+
.then((status) => {
|
|
130
|
+
if (status && status.modified.length > 0) {
|
|
131
|
+
return git.commit('Updated packages to use correct versions and linked dependencies');
|
|
132
|
+
} else {
|
|
133
|
+
console.log('No changes after linting. Nothing to commit.');
|
|
134
|
+
}
|
|
135
|
+
})
|
|
136
|
+
.catch((err) => {
|
|
137
|
+
console.error(err);
|
|
138
|
+
});
|
|
@@ -1,106 +1,121 @@
|
|
|
1
|
-
/* eslint-disable jest/require-hook */
|
|
2
|
-
/* eslint-disable no-loop-func */
|
|
3
|
-
/* eslint-disable no-undef */
|
|
4
|
-
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
5
|
-
/* eslint-disable @typescript-eslint/no-floating-promises */
|
|
6
|
-
/* eslint-disable no-restricted-syntax */
|
|
7
|
-
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
|
8
|
-
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
|
9
|
-
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
|
10
|
-
/* eslint-disable @typescript-eslint/no-shadow */
|
|
11
|
-
/* eslint-disable no-console */
|
|
12
|
-
/* eslint-disable @typescript-eslint/restrict-template-expressions */
|
|
13
|
-
/* eslint-disable consistent-return */
|
|
14
|
-
const glob = require('glob');
|
|
15
1
|
const path = require('path');
|
|
16
2
|
const fs = require('fs');
|
|
17
|
-
|
|
18
|
-
const SERVER_FOLDER = './servers';
|
|
19
3
|
const simpleGit = require('simple-git');
|
|
4
|
+
const glob = require('glob');
|
|
20
5
|
|
|
21
6
|
const git = simpleGit();
|
|
7
|
+
const monorepoRoot = path.resolve(__dirname, '..');
|
|
8
|
+
|
|
9
|
+
// matching prettier format
|
|
10
|
+
const JSON_SPACING = 4;
|
|
11
|
+
const ADD_END_NEWLINE = true; // Set to true to add a newline at the end of the file
|
|
12
|
+
|
|
13
|
+
const findPackageJsonFiles = () => {
|
|
14
|
+
return new Promise((resolve, reject) => {
|
|
15
|
+
glob(
|
|
16
|
+
`${monorepoRoot}/+(servers|portable-devices|packages|packages-modules)/**/package.json`,
|
|
17
|
+
{ onlyFiles: true, ignore: '**/node_modules/**' },
|
|
18
|
+
(err, files) => {
|
|
19
|
+
if (err) reject(`Unable to scan directory: ${err}`);
|
|
20
|
+
resolve(files);
|
|
21
|
+
},
|
|
22
|
+
);
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const buildPackageMap = async () => {
|
|
27
|
+
const packageJsonFiles = await findPackageJsonFiles();
|
|
28
|
+
const packageMap = new Map();
|
|
29
|
+
|
|
30
|
+
packageJsonFiles.forEach((file) => {
|
|
31
|
+
const packageJson = JSON.parse(fs.readFileSync(file, 'utf8'));
|
|
32
|
+
if (packageJson.name) {
|
|
33
|
+
packageMap.set(packageJson.name, {
|
|
34
|
+
path: path.dirname(file),
|
|
35
|
+
version: packageJson.version,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
return packageMap;
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const searchAndUpdate = (dependencies, filePath, obj, packageMap) => {
|
|
44
|
+
let modified = false;
|
|
22
45
|
|
|
23
|
-
const searchAndUpdate = (dependencies, filePath, obj) => {
|
|
24
|
-
const fileWrie = filePath;
|
|
25
|
-
const packageDir = path.dirname(filePath);
|
|
26
|
-
console.log('---PACKAGE DIR', packageDir);
|
|
27
46
|
for (const key in dependencies) {
|
|
28
|
-
if (dependencies[key].
|
|
47
|
+
if (dependencies[key].startsWith('link:')) {
|
|
29
48
|
const relativeDepFolder = dependencies[key].split('link:')[1];
|
|
30
|
-
|
|
31
|
-
|
|
49
|
+
const dependencyFolder = path.join(path.dirname(filePath), relativeDepFolder);
|
|
50
|
+
|
|
32
51
|
try {
|
|
33
|
-
|
|
52
|
+
const packageJsonPath = path.join(dependencyFolder, 'package.json');
|
|
53
|
+
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
|
|
54
|
+
if (dependencies[key] !== packageJson.version) {
|
|
55
|
+
dependencies[key] = packageJson.version;
|
|
56
|
+
modified = true;
|
|
57
|
+
}
|
|
34
58
|
} catch (err) {
|
|
35
|
-
|
|
36
|
-
console.log(`--- err ${err.message}`);
|
|
37
|
-
console.log(
|
|
38
|
-
`err Search for dependency of ${filePath} with package path ${relativeDepFolder} not found`,
|
|
39
|
-
);
|
|
59
|
+
console.error(`Error updating ${key} in ${filePath}: ${err.message}`);
|
|
40
60
|
throw err;
|
|
41
61
|
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
throw (err);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
+
} else if (packageMap.has(key)) {
|
|
63
|
+
const version = packageMap.get(key).version;
|
|
64
|
+
if (dependencies[key] !== version) {
|
|
65
|
+
dependencies[key] = version;
|
|
66
|
+
modified = true;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if (modified) {
|
|
72
|
+
// Write the updated package.json back to disk with or without a newline at the end
|
|
73
|
+
let formattedJson = JSON.stringify(obj, null, JSON_SPACING);
|
|
74
|
+
if (ADD_END_NEWLINE) {
|
|
75
|
+
formattedJson += '\n';
|
|
62
76
|
}
|
|
77
|
+
fs.writeFileSync(filePath, formattedJson, 'utf8');
|
|
63
78
|
}
|
|
79
|
+
|
|
80
|
+
return modified;
|
|
64
81
|
};
|
|
65
82
|
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
}
|
|
83
|
+
const updateDependencies = async () => {
|
|
84
|
+
const packageMap = await buildPackageMap();
|
|
85
|
+
const packageJsonFiles = await findPackageJsonFiles();
|
|
86
|
+
const modifiedFiles = [];
|
|
87
|
+
|
|
88
|
+
packageJsonFiles.forEach((file) => {
|
|
89
|
+
if (!file.includes('node_modules')) {
|
|
90
|
+
try {
|
|
91
|
+
const data = fs.readFileSync(file, 'utf8');
|
|
92
|
+
const obj = JSON.parse(data);
|
|
93
|
+
const { dependencies, peerDependencies, devDependencies } = obj;
|
|
94
|
+
|
|
95
|
+
let modified = false;
|
|
96
|
+
modified = searchAndUpdate(dependencies, file, obj, packageMap) || modified;
|
|
97
|
+
modified = searchAndUpdate(peerDependencies, file, obj, packageMap) || modified;
|
|
98
|
+
modified = searchAndUpdate(devDependencies, file, obj, packageMap) || modified;
|
|
99
|
+
|
|
100
|
+
if (modified) {
|
|
101
|
+
modifiedFiles.push(file);
|
|
102
|
+
}
|
|
103
|
+
} catch (err) {
|
|
104
|
+
console.error(`Unable to read file ${file}: ${err.message}`);
|
|
86
105
|
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
})
|
|
104
|
-
.catch((err) => console.error(err));
|
|
105
|
-
},
|
|
106
|
-
);
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
if (modifiedFiles.length > 0) {
|
|
110
|
+
await git.add(modifiedFiles);
|
|
111
|
+
await git.commit('Updated packages to use correct versions and linked dependencies');
|
|
112
|
+
} else {
|
|
113
|
+
console.log('No changes detected');
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
updateDependencies()
|
|
118
|
+
.then(() => {
|
|
119
|
+
console.log('Dependencies updated successfully.');
|
|
120
|
+
})
|
|
121
|
+
.catch((err) => console.error(`Error in updateDependencies: ${err.message}`));
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { resolve, dirname, join } from 'path';
|
|
2
|
+
import { readFileSync, writeFileSync } from 'fs';
|
|
3
|
+
import glob from 'glob';
|
|
4
|
+
|
|
5
|
+
export const JSON_SPACING = 4;
|
|
6
|
+
export const ADD_END_NEWLINE = true; // Set to true to add a newline at the end of the file
|
|
7
|
+
|
|
8
|
+
export const monorepoRoot = resolve(dirname(import.meta.url), '..');
|
|
9
|
+
|
|
10
|
+
export const findPackageJsonFiles = () => {
|
|
11
|
+
return new Promise((resolve, reject) => {
|
|
12
|
+
glob(
|
|
13
|
+
`${monorepoRoot}/+(servers|portable-devices|packages|packages-modules)/**/package.json`,
|
|
14
|
+
{ onlyFiles: true, ignore: '**/node_modules/**' },
|
|
15
|
+
(err, files) => {
|
|
16
|
+
if (err) reject(`Unable to scan directory: ${err}`);
|
|
17
|
+
resolve(files);
|
|
18
|
+
},
|
|
19
|
+
);
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
export const buildPackageMap = async () => {
|
|
24
|
+
const packageJsonFiles = await findPackageJsonFiles();
|
|
25
|
+
const packageMap = new Map();
|
|
26
|
+
|
|
27
|
+
packageJsonFiles.forEach((file) => {
|
|
28
|
+
const packageJson = JSON.parse(readFileSync(file, 'utf8'));
|
|
29
|
+
if (packageJson.name) {
|
|
30
|
+
packageMap.set(packageJson.name, {
|
|
31
|
+
path: dirname(file),
|
|
32
|
+
version: packageJson.version,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
return packageMap;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export const searchAndUpdate = (dependencies, filePath, obj, packageMap) => {
|
|
41
|
+
let modified = false;
|
|
42
|
+
|
|
43
|
+
for (const key in dependencies) {
|
|
44
|
+
if (dependencies[key].startsWith('link:')) {
|
|
45
|
+
const relativeDepFolder = dependencies[key].split('link:')[1];
|
|
46
|
+
const dependencyFolder = join(dirname(filePath), relativeDepFolder);
|
|
47
|
+
|
|
48
|
+
try {
|
|
49
|
+
const packageJsonPath = join(dependencyFolder, 'package.json');
|
|
50
|
+
const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));
|
|
51
|
+
if (dependencies[key] !== packageJson.version) {
|
|
52
|
+
dependencies[key] = packageJson.version;
|
|
53
|
+
modified = true;
|
|
54
|
+
}
|
|
55
|
+
} catch (err) {
|
|
56
|
+
console.error(`Error updating ${key} in ${filePath}: ${err.message}`);
|
|
57
|
+
throw err;
|
|
58
|
+
}
|
|
59
|
+
} else if (packageMap.has(key)) {
|
|
60
|
+
const version = packageMap.get(key).version;
|
|
61
|
+
if (dependencies[key] !== version) {
|
|
62
|
+
dependencies[key] = version;
|
|
63
|
+
modified = true;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
if (modified) {
|
|
69
|
+
let formattedJson = JSON.stringify(obj, null, JSON_SPACING);
|
|
70
|
+
if (ADD_END_NEWLINE) {
|
|
71
|
+
formattedJson += '\n';
|
|
72
|
+
}
|
|
73
|
+
writeFileSync(filePath, formattedJson, 'utf8');
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
return modified;
|
|
77
|
+
};
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
import { addProjectConfiguration, formatFiles, generateFiles, Tree, updateJson } from '@nx/devkit';
|
|
2
2
|
import * as path from 'path';
|
|
3
|
+
import fs from 'fs';
|
|
3
4
|
import { AddFullstackGeneratorSchema } from './schema';
|
|
4
|
-
import { getValid } from '../../utils';
|
|
5
|
+
import { getValid, isValid } from '../../utils';
|
|
6
|
+
import {
|
|
7
|
+
generateBackend,
|
|
8
|
+
generateFrontend,
|
|
9
|
+
generateMoleculer,
|
|
10
|
+
generateBrowserPackage,
|
|
11
|
+
generateClientPackage,
|
|
12
|
+
generateCorePackage,
|
|
13
|
+
generateServerPackage,
|
|
14
|
+
} from '../../index';
|
|
5
15
|
|
|
6
16
|
export async function addFullstackGenerator(tree: Tree, options: AddFullstackGeneratorSchema) {
|
|
7
17
|
const projectRoot = getValid(options.name) ?? 'fullstack-pro';
|
|
@@ -17,6 +27,78 @@ export async function addFullstackGenerator(tree: Tree, options: AddFullstackGen
|
|
|
17
27
|
return packageJson;
|
|
18
28
|
});
|
|
19
29
|
await formatFiles(tree);
|
|
30
|
+
|
|
31
|
+
if (isValid(options.config)) {
|
|
32
|
+
const configPath = getValid(options.config);
|
|
33
|
+
if (fs.existsSync(configPath)) {
|
|
34
|
+
try {
|
|
35
|
+
const content = String(fs.readFileSync(configPath));
|
|
36
|
+
const configs = JSON.parse(content);
|
|
37
|
+
configs.parent = projectRoot;
|
|
38
|
+
|
|
39
|
+
await processConfigs(tree, configs);
|
|
40
|
+
} catch(error) {
|
|
41
|
+
console.error('Error while reading config.', error);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const processConfigs = async (tree: Tree, configs: any) => {
|
|
48
|
+
if (configs.servers) {
|
|
49
|
+
await generateServers(tree, configs.parent, configs.servers);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
if (configs.packages && configs.packages.modules) {
|
|
53
|
+
await generatePackages(tree, configs.parent, configs.packages.modules);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
const generateServers = async (tree: Tree, parent: string, servers: any) => {
|
|
58
|
+
for (const [serverName, serverConfig] of Object.entries(servers)) {
|
|
59
|
+
const configs: any = serverConfig;
|
|
60
|
+
configs.name = serverName;
|
|
61
|
+
configs.directory = `${parent}/servers`;
|
|
62
|
+
|
|
63
|
+
switch(configs?.type) {
|
|
64
|
+
case 'frontend':
|
|
65
|
+
await generateFrontend(tree, configs);
|
|
66
|
+
break;
|
|
67
|
+
case 'backend':
|
|
68
|
+
await generateBackend(tree, configs);
|
|
69
|
+
break;
|
|
70
|
+
case 'moleculer':
|
|
71
|
+
await generateMoleculer(tree, configs);
|
|
72
|
+
break;
|
|
73
|
+
default:
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const generatePackages = async (tree: Tree, parent: string, packages: any) => {
|
|
80
|
+
for (const [packageName, packageConfig] of Object.entries(packages)) {
|
|
81
|
+
const configs: any = packageConfig;
|
|
82
|
+
configs.name = packageName;
|
|
83
|
+
configs.directory = `${parent}/packages`;
|
|
84
|
+
|
|
85
|
+
switch((packageConfig as any)?.type) {
|
|
86
|
+
case 'packages-core':
|
|
87
|
+
await generateCorePackage(tree, configs);
|
|
88
|
+
break;
|
|
89
|
+
case 'packages-browser':
|
|
90
|
+
await generateBrowserPackage(tree, configs);
|
|
91
|
+
break;
|
|
92
|
+
case 'packages-client':
|
|
93
|
+
await generateClientPackage(tree, configs);
|
|
94
|
+
break;
|
|
95
|
+
case 'packages-server':
|
|
96
|
+
await generateServerPackage(tree, configs);
|
|
97
|
+
break;
|
|
98
|
+
default:
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
20
102
|
}
|
|
21
103
|
|
|
22
104
|
export default addFullstackGenerator;
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
"@common-stack/client-core": "5.0.6-alpha.3",
|
|
32
32
|
"@common-stack/core": "5.0.6-alpha.3",
|
|
33
33
|
"@common-stack/server-core": "5.0.6-alpha.3",
|
|
34
|
-
"@common-stack/server-stack": "5.0.6-alpha.
|
|
34
|
+
"@common-stack/server-stack": "5.0.6-alpha.7",
|
|
35
35
|
"@common-stack/store-mongo": "5.0.6-alpha.3",
|
|
36
36
|
"@container-stack/mailing-api": "5.2.1-alpha.1",
|
|
37
37
|
"app-root-path": "^3.0.0",
|
|
@@ -4,19 +4,20 @@ import { AddMoleculerGeneratorSchema } from './schema';
|
|
|
4
4
|
import { isValid, getValid } from '../../utils';
|
|
5
5
|
|
|
6
6
|
export async function addMoleculerGenerator(tree: Tree, options: AddMoleculerGeneratorSchema) {
|
|
7
|
+
const configs: any = {...options};
|
|
8
|
+
return await generateMoleculer(tree, configs);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export const generateMoleculer = async (tree: Tree, options: any) => {
|
|
7
12
|
const projectName = getValid(options.name) ?? 'moleculer-server';
|
|
8
13
|
const projectRoot = isValid(options.directory) ? `${getValid(options.directory)}/${projectName}` : projectName;
|
|
9
|
-
|
|
10
|
-
// root: projectRoot,
|
|
11
|
-
// projectType: 'library',
|
|
12
|
-
// sourceRoot: `${projectRoot}/src`,
|
|
13
|
-
// targets: {},
|
|
14
|
-
// });
|
|
14
|
+
|
|
15
15
|
generateFiles(tree, path.join(__dirname, 'files'), projectRoot, options);
|
|
16
16
|
updateJson(tree, `${projectRoot}/package.json`, (packageJson) => {
|
|
17
17
|
packageJson['name'] = options.name;
|
|
18
18
|
return packageJson;
|
|
19
19
|
});
|
|
20
|
+
|
|
20
21
|
await formatFiles(tree);
|
|
21
22
|
}
|
|
22
23
|
|