@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.
Files changed (140) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/README.md +280 -10
  3. package/cde-config.json +86 -0
  4. package/lib/constants/index.cjs +2 -1
  5. package/lib/constants/index.cjs.map +1 -1
  6. package/lib/constants/index.d.ts +1 -0
  7. package/lib/constants/index.mjs +2 -1
  8. package/lib/constants/index.mjs.map +1 -1
  9. package/lib/generators/add-backend/files/CHANGELOG.md +0 -0
  10. package/lib/generators/add-backend/files/Dockerfile +1 -1
  11. package/lib/generators/add-backend/files/__tests__/test.ts.template +3 -2
  12. package/lib/generators/add-backend/files/package.json +2 -48
  13. package/lib/generators/add-backend/generator.cjs +21 -17
  14. package/lib/generators/add-backend/generator.cjs.map +1 -1
  15. package/lib/generators/add-backend/generator.d.ts +1 -0
  16. package/lib/generators/add-backend/generator.mjs +21 -17
  17. package/lib/generators/add-backend/generator.mjs.map +1 -1
  18. package/lib/generators/add-browser-package/files/package.json +1 -1
  19. package/lib/generators/add-browser-package/generator.cjs +14 -16
  20. package/lib/generators/add-browser-package/generator.cjs.map +1 -1
  21. package/lib/generators/add-browser-package/generator.d.ts +1 -0
  22. package/lib/generators/add-browser-package/generator.mjs +14 -16
  23. package/lib/generators/add-browser-package/generator.mjs.map +1 -1
  24. package/lib/generators/add-client-package/files/package.json +2 -3
  25. package/lib/generators/add-client-package/generator.cjs +14 -16
  26. package/lib/generators/add-client-package/generator.cjs.map +1 -1
  27. package/lib/generators/add-client-package/generator.d.ts +1 -0
  28. package/lib/generators/add-client-package/generator.mjs +14 -16
  29. package/lib/generators/add-client-package/generator.mjs.map +1 -1
  30. package/lib/generators/add-core-package/files/package.json +2 -3
  31. package/lib/generators/add-core-package/generator.cjs +14 -16
  32. package/lib/generators/add-core-package/generator.cjs.map +1 -1
  33. package/lib/generators/add-core-package/generator.d.ts +1 -0
  34. package/lib/generators/add-core-package/generator.mjs +14 -16
  35. package/lib/generators/add-core-package/generator.mjs.map +1 -1
  36. package/lib/generators/add-frontend/frameworks/chakraui/entry.client.tsx.template +30 -24
  37. package/lib/generators/add-frontend/frameworks/chakraui/entry.server.tsx.template +5 -8
  38. package/lib/generators/add-frontend/frameworks/chakraui/root.tsx.template +3 -3
  39. package/lib/generators/add-frontend/frameworks/tailwindui/entry.client.tsx.template +90 -0
  40. package/lib/generators/add-frontend/frameworks/tailwindui/entry.server.tsx.template +238 -0
  41. package/lib/generators/add-frontend/frameworks/tailwindui/root.tsx.template +117 -0
  42. package/lib/generators/add-frontend/frameworks/tailwindui/tailwind.css +3 -0
  43. package/lib/generators/add-frontend/generator.cjs +60 -42
  44. package/lib/generators/add-frontend/generator.cjs.map +1 -1
  45. package/lib/generators/add-frontend/generator.d.ts +1 -0
  46. package/lib/generators/add-frontend/generator.mjs +60 -42
  47. package/lib/generators/add-frontend/generator.mjs.map +1 -1
  48. package/lib/generators/add-frontend/schema.json +1 -1
  49. package/lib/generators/add-frontend/templates/package.json +18 -77
  50. package/lib/generators/add-frontend/templates/postcss.config.js +6 -0
  51. package/lib/generators/add-frontend/templates/tailwind.config.ts.template +12 -0
  52. package/lib/generators/add-fullstack/files/Jenkinsfile +3 -6
  53. package/lib/generators/add-fullstack/files/jest-mongodb-config.js +3 -2
  54. package/lib/generators/add-fullstack/files/jest.config.base.js +43 -4
  55. package/lib/generators/add-fullstack/files/jest.config.base.mjs +99 -0
  56. package/lib/generators/add-fullstack/files/jest.config.mongodb.mjs +3 -0
  57. package/lib/generators/add-fullstack/files/lint-staged.config.js +4 -1
  58. package/lib/generators/add-fullstack/files/nx.json +18 -13
  59. package/lib/generators/add-fullstack/files/package.json +12 -24
  60. package/lib/generators/add-fullstack/files/tools/cli/helpers/util.js +1 -1
  61. package/lib/generators/add-fullstack/files/tools/deploy-cli/updateLernaVersion.js +1 -1
  62. package/lib/generators/add-fullstack/files/tools/deploy-cli/updateYamlSettings.js +14 -15
  63. package/lib/generators/add-fullstack/files/tools/prettier.config.js +8 -0
  64. package/lib/generators/add-fullstack/files/tools/rollup/rollupPluginGenerateJson.mjs +48 -0
  65. package/lib/generators/add-fullstack/files/tools/rollup/rollupPluginModifyLibFiles.mjs +410 -0
  66. package/lib/generators/add-fullstack/files/tools/runLint.mjs +15 -0
  67. package/lib/generators/add-fullstack/files/tools/sortPackageJson.mjs +8 -2
  68. package/lib/generators/add-fullstack/files/tools/update-dependencies.mjs +95 -0
  69. package/lib/generators/add-fullstack/files/tools/update-dependency-link.mjs +138 -0
  70. package/lib/generators/add-fullstack/files/tools/update-dependency-version.js +104 -89
  71. package/lib/generators/add-fullstack/files/tools/updateUtils.mjs +77 -0
  72. package/lib/generators/add-fullstack/generator.cjs +71 -13
  73. package/lib/generators/add-fullstack/generator.cjs.map +1 -1
  74. package/lib/generators/add-fullstack/generator.mjs +71 -13
  75. package/lib/generators/add-fullstack/generator.mjs.map +1 -1
  76. package/lib/generators/add-fullstack/schema.json +9 -0
  77. package/lib/generators/add-fullstack/updates/index.d.ts +2 -0
  78. package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.cjs +36 -0
  79. package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.cjs.map +1 -0
  80. package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.d.ts +1 -0
  81. package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.mjs +36 -0
  82. package/lib/generators/add-fullstack/updates/jenkinsfileUpdate.mjs.map +1 -0
  83. package/lib/generators/add-fullstack/updates/packageJsonUpdate.cjs +8 -0
  84. package/lib/generators/add-fullstack/updates/packageJsonUpdate.cjs.map +1 -0
  85. package/lib/generators/add-fullstack/updates/packageJsonUpdate.d.ts +2 -0
  86. package/lib/generators/add-fullstack/updates/packageJsonUpdate.mjs +8 -0
  87. package/lib/generators/add-fullstack/updates/packageJsonUpdate.mjs.map +1 -0
  88. package/lib/generators/add-moleculer/files/package.json +3 -3
  89. package/lib/generators/add-moleculer/generator.cjs +14 -16
  90. package/lib/generators/add-moleculer/generator.cjs.map +1 -1
  91. package/lib/generators/add-moleculer/generator.d.ts +1 -0
  92. package/lib/generators/add-moleculer/generator.mjs +14 -16
  93. package/lib/generators/add-moleculer/generator.mjs.map +1 -1
  94. package/lib/generators/add-server-package/files/package.json +2 -2
  95. package/lib/generators/add-server-package/generator.cjs +14 -16
  96. package/lib/generators/add-server-package/generator.cjs.map +1 -1
  97. package/lib/generators/add-server-package/generator.d.ts +1 -0
  98. package/lib/generators/add-server-package/generator.mjs +14 -16
  99. package/lib/generators/add-server-package/generator.mjs.map +1 -1
  100. package/lib/index.cjs +1 -1
  101. package/lib/index.mjs +1 -1
  102. package/package.json +3 -2
  103. package/src/constants/index.ts +2 -1
  104. package/src/generators/add-backend/generator.ts +8 -4
  105. package/src/generators/add-browser-package/generator.ts +7 -6
  106. package/src/generators/add-client-package/generator.ts +7 -6
  107. package/src/generators/add-core-package/generator.ts +7 -6
  108. package/src/generators/add-frontend/frameworks/tailwindui/entry.client.tsx.template +90 -0
  109. package/src/generators/add-frontend/frameworks/tailwindui/entry.server.tsx.template +238 -0
  110. package/src/generators/add-frontend/frameworks/tailwindui/root.tsx.template +117 -0
  111. package/src/generators/add-frontend/frameworks/tailwindui/tailwind.css +3 -0
  112. package/src/generators/add-frontend/generator.ts +24 -2
  113. package/src/generators/add-frontend/schema.json +1 -1
  114. package/src/generators/add-fullstack/files/jest-mongodb-config.js +3 -2
  115. package/src/generators/add-fullstack/files/jest.config copy.js +27 -0
  116. package/src/generators/add-fullstack/files/jest.config.base.js +43 -4
  117. package/src/generators/add-fullstack/files/jest.config.base.mjs +99 -0
  118. package/src/generators/add-fullstack/files/jest.config.mongodb.mjs +3 -0
  119. package/src/generators/add-fullstack/files/lint-staged.config.js +4 -1
  120. package/src/generators/add-fullstack/files/nx.json +18 -13
  121. package/src/generators/add-fullstack/files/tools/cli/helpers/util.js +1 -1
  122. package/src/generators/add-fullstack/files/tools/deploy-cli/updateLernaVersion.js +1 -1
  123. package/src/generators/add-fullstack/files/tools/html-plugin-template.ejs +28 -0
  124. package/src/generators/add-fullstack/files/tools/prettier.config.js +8 -0
  125. package/src/generators/add-fullstack/files/tools/rollup/rollupPluginGenerateJson.mjs +48 -0
  126. package/src/generators/add-fullstack/files/tools/rollup/rollupPluginModifyLibFiles.mjs +410 -0
  127. package/src/generators/add-fullstack/files/tools/runLint.mjs +15 -0
  128. package/src/generators/add-fullstack/files/tools/sortPackageJson.mjs +0 -1
  129. package/src/generators/add-fullstack/files/tools/update-dependencies.mjs +95 -0
  130. package/src/generators/add-fullstack/files/tools/update-dependency-link.mjs +138 -0
  131. package/src/generators/add-fullstack/files/tools/update-dependency-version.js +104 -89
  132. package/src/generators/add-fullstack/files/tools/updateUtils.mjs +77 -0
  133. package/src/generators/add-fullstack/generator.ts +83 -1
  134. package/src/generators/add-fullstack/schema.d.ts +1 -0
  135. package/src/generators/add-fullstack/schema.json +4 -0
  136. package/src/generators/add-moleculer/files/package.json +1 -1
  137. package/src/generators/add-moleculer/generator.ts +7 -6
  138. package/src/generators/add-server-package/generator.ts +7 -6
  139. package/lib/generators/add-fullstack/files/tools/update-dependency-link.js +0 -107
  140. 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].includes('link:')) {
47
+ if (dependencies[key].startsWith('link:')) {
29
48
  const relativeDepFolder = dependencies[key].split('link:')[1];
30
- console.log('--FOLDER ROAD', relativeDepFolder);
31
- const dependencyFolder = path.join(packageDir, relativeDepFolder);
49
+ const dependencyFolder = path.join(path.dirname(filePath), relativeDepFolder);
50
+
32
51
  try {
33
- fs.readdirSync(dependencyFolder);
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
- glob(`${dependencyFolder}/package.json`, { ignore: '**/node_modules/**' }, (err, files) => {
43
- if (err) return console.error(`Unable to scan directory: ${err}`);
44
- console.log(files);
45
- files.forEach((file) => {
46
- fs.readFile(file, 'utf-8', (err, data) => {
47
- if (err) return console.error(`Unable to scan directory: ${err}`);
48
- try {
49
- const objVersion = JSON.parse(data);
50
- const { version } = objVersion;
51
- dependencies[key] = `${version}`;
52
- const str = JSON.stringify(obj, null, 2);
53
- fs.writeFileSync(fileWrie, str, 'ascii');
54
- } catch (err) {
55
- console.error(`Failed at file: ${file}`)
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
- glob(
67
- './+(servers|portable-devices|packages|packages-modules)/**/package.json',
68
- { onlyFiles: false, ignore: '**/node_modules/**' },
69
- (err, files) => {
70
- if (err) return console.error(`Unable to scan directory: ${err}`);
71
- files.forEach((file) => {
72
- if (!file.includes('node_modules')) {
73
- fs.readFile(file, 'utf-8', (err, data) => {
74
- if (err) return console.error(`Unable to scan directory: ${err}`);
75
- try {
76
- const obj = JSON.parse(data);
77
- const { dependencies, peerDependencies, devDependencies } = obj;
78
- searchAndUpdate(dependencies, file, obj);
79
- searchAndUpdate(peerDependencies, file, obj);
80
- searchAndUpdate(devDependencies, file, obj);
81
- } catch (err) {
82
- console.error(`Errored at ${file}`);
83
- console.error(err);
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
- git.add('.')
89
- .then(() => {
90
- git.status()
91
- .then((status) => {
92
- console.log('POST GIT CHANGES', status);
93
- if (status.modified.length) {
94
- const fileArray = status.modified.filter((element) => element.includes('package.json'));
95
- const addArray = fileArray.map((element) => `./${element}`);
96
- git.add(addArray);
97
- git.commit('corrected packages version!');
98
- } else console.log('no change');
99
- })
100
- .catch((err) => {
101
- console.error(err);
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;
@@ -1,3 +1,4 @@
1
1
  export interface AddFullstackGeneratorSchema {
2
2
  name: string;
3
+ config?: string;
3
4
  }
@@ -8,6 +8,10 @@
8
8
  "type": "string",
9
9
  "description": "",
10
10
  "x-prompt": "What name would you like to use?"
11
+ },
12
+ "config": {
13
+ "type": "string",
14
+ "description": "The absolute path of config file"
11
15
  }
12
16
  },
13
17
  "required": ["name"]
@@ -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.3",
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
- // addProjectConfiguration(tree, options.name, {
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