@decaf-ts/utils 0.1.6

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 (112) hide show
  1. package/LICENSE.md +157 -0
  2. package/README.md +95 -0
  3. package/dist/esm/utils.js +1 -0
  4. package/dist/types/bin/tag-release.d.ts +1 -0
  5. package/dist/types/bin/update-scripts.d.ts +1 -0
  6. package/dist/types/cli/command.d.ts +110 -0
  7. package/dist/types/cli/commands/index.d.ts +2 -0
  8. package/dist/types/cli/commands/tag-release.d.ts +105 -0
  9. package/dist/types/cli/commands/update-scripts.d.ts +211 -0
  10. package/dist/types/cli/constants.d.ts +73 -0
  11. package/dist/types/cli/index.d.ts +4 -0
  12. package/dist/types/cli/types.d.ts +28 -0
  13. package/dist/types/index.d.ts +39 -0
  14. package/dist/types/input/index.d.ts +2 -0
  15. package/dist/types/input/input.d.ts +472 -0
  16. package/dist/types/input/types.d.ts +76 -0
  17. package/dist/types/output/common.d.ts +51 -0
  18. package/dist/types/output/index.d.ts +3 -0
  19. package/dist/types/output/logging.d.ts +177 -0
  20. package/dist/types/output/types.d.ts +203 -0
  21. package/dist/types/utils/accumulator.d.ts +105 -0
  22. package/dist/types/utils/constants.d.ts +136 -0
  23. package/dist/types/utils/environment.d.ts +57 -0
  24. package/dist/types/utils/fs.d.ts +133 -0
  25. package/dist/types/utils/http.d.ts +41 -0
  26. package/dist/types/utils/index.d.ts +7 -0
  27. package/dist/types/utils/md.d.ts +156 -0
  28. package/dist/types/utils/tests.d.ts +170 -0
  29. package/dist/types/utils/text.d.ts +106 -0
  30. package/dist/types/utils/timeout.d.ts +1 -0
  31. package/dist/types/utils/types.d.ts +81 -0
  32. package/dist/types/utils/utils.d.ts +91 -0
  33. package/dist/types/utils/web.d.ts +7 -0
  34. package/dist/types/writers/OutputWriter.d.ts +49 -0
  35. package/dist/types/writers/RegexpOutputWriter.d.ts +69 -0
  36. package/dist/types/writers/StandardOutputWriter.d.ts +91 -0
  37. package/dist/types/writers/index.d.ts +4 -0
  38. package/dist/types/writers/types.d.ts +29 -0
  39. package/dist/utils.js +1 -0
  40. package/lib/assets/slogans.json +802 -0
  41. package/lib/bin/tag-release.cjs +12 -0
  42. package/lib/bin/update-scripts.cjs +12 -0
  43. package/lib/cli/command.cjs +153 -0
  44. package/lib/cli/commands/index.cjs +20 -0
  45. package/lib/cli/commands/tag-release.cjs +168 -0
  46. package/lib/cli/commands/update-scripts.cjs +511 -0
  47. package/lib/cli/constants.cjs +80 -0
  48. package/lib/cli/index.cjs +22 -0
  49. package/lib/cli/types.cjs +4 -0
  50. package/lib/esm/assets/slogans.json +802 -0
  51. package/lib/esm/bin/tag-release.js +10 -0
  52. package/lib/esm/bin/update-scripts.js +10 -0
  53. package/lib/esm/cli/command.js +149 -0
  54. package/lib/esm/cli/commands/index.js +4 -0
  55. package/lib/esm/cli/commands/tag-release.js +164 -0
  56. package/lib/esm/cli/commands/update-scripts.js +504 -0
  57. package/lib/esm/cli/constants.js +77 -0
  58. package/lib/esm/cli/index.js +6 -0
  59. package/lib/esm/cli/types.js +3 -0
  60. package/lib/esm/index.js +41 -0
  61. package/lib/esm/input/index.js +4 -0
  62. package/lib/esm/input/input.js +570 -0
  63. package/lib/esm/input/types.js +3 -0
  64. package/lib/esm/output/common.js +93 -0
  65. package/lib/esm/output/index.js +5 -0
  66. package/lib/esm/output/logging.js +350 -0
  67. package/lib/esm/output/types.js +3 -0
  68. package/lib/esm/utils/accumulator.js +145 -0
  69. package/lib/esm/utils/constants.js +176 -0
  70. package/lib/esm/utils/environment.js +91 -0
  71. package/lib/esm/utils/fs.js +271 -0
  72. package/lib/esm/utils/http.js +70 -0
  73. package/lib/esm/utils/index.js +9 -0
  74. package/lib/esm/utils/md.js +3 -0
  75. package/lib/esm/utils/tests.js +223 -0
  76. package/lib/esm/utils/text.js +142 -0
  77. package/lib/esm/utils/timeout.js +5 -0
  78. package/lib/esm/utils/types.js +3 -0
  79. package/lib/esm/utils/utils.js +220 -0
  80. package/lib/esm/utils/web.js +12 -0
  81. package/lib/esm/writers/OutputWriter.js +3 -0
  82. package/lib/esm/writers/RegexpOutputWriter.js +98 -0
  83. package/lib/esm/writers/StandardOutputWriter.js +127 -0
  84. package/lib/esm/writers/index.js +6 -0
  85. package/lib/esm/writers/types.js +3 -0
  86. package/lib/index.cjs +58 -0
  87. package/lib/input/index.cjs +20 -0
  88. package/lib/input/input.cjs +577 -0
  89. package/lib/input/types.cjs +4 -0
  90. package/lib/output/common.cjs +100 -0
  91. package/lib/output/index.cjs +21 -0
  92. package/lib/output/logging.cjs +355 -0
  93. package/lib/output/types.cjs +4 -0
  94. package/lib/utils/accumulator.cjs +149 -0
  95. package/lib/utils/constants.cjs +179 -0
  96. package/lib/utils/environment.cjs +95 -0
  97. package/lib/utils/fs.cjs +288 -0
  98. package/lib/utils/http.cjs +77 -0
  99. package/lib/utils/index.cjs +25 -0
  100. package/lib/utils/md.cjs +4 -0
  101. package/lib/utils/tests.cjs +263 -0
  102. package/lib/utils/text.cjs +153 -0
  103. package/lib/utils/timeout.cjs +8 -0
  104. package/lib/utils/types.cjs +4 -0
  105. package/lib/utils/utils.cjs +226 -0
  106. package/lib/utils/web.cjs +15 -0
  107. package/lib/writers/OutputWriter.cjs +4 -0
  108. package/lib/writers/RegexpOutputWriter.cjs +102 -0
  109. package/lib/writers/StandardOutputWriter.cjs +131 -0
  110. package/lib/writers/index.cjs +22 -0
  111. package/lib/writers/types.cjs +4 -0
  112. package/package.json +121 -0
@@ -0,0 +1,511 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TemplateSync = void 0;
7
+ const path_1 = __importDefault(require("path"));
8
+ const command_1 = require("../command.cjs");
9
+ const utils_1 = require("../../utils/index.cjs");
10
+ const input_1 = require("../../input/index.cjs");
11
+ const fs_1 = __importDefault(require("fs"));
12
+ const baseUrl = "https://raw.githubusercontent.com/decaf-ts/ts-workspace/master";
13
+ const options = {
14
+ templates: [
15
+ ".github/ISSUE_TEMPLATE/bug_report.md",
16
+ ".github/ISSUE_TEMPLATE/feature_request.md",
17
+ ".github/FUNDING.yml",
18
+ ],
19
+ workflows: [
20
+ ".github/workflows/codeql-analysis.yml",
21
+ ".github/workflows/jest-coverage.yaml",
22
+ ".github/workflows/nodejs-build-prod.yaml",
23
+ ".github/workflows/pages.yaml",
24
+ ".github/workflows/publish-on-release.yaml",
25
+ ".github/workflows/release-on-tag.yaml",
26
+ ".github/workflows/snyk-analysis.yaml",
27
+ ],
28
+ ide: [
29
+ ".idea/runConfigurations/All Tests.run.xml",
30
+ ".idea/runConfigurations/build.run.xml",
31
+ ".idea/runConfigurations/build_prod.run.xml",
32
+ ".idea/runConfigurations/coverage.run.xml",
33
+ ".idea/runConfigurations/docs.run.xml",
34
+ ".idea/runConfigurations/drawings.run.xml",
35
+ ".idea/runConfigurations/flash-forward.run.xml",
36
+ ".idea/runConfigurations/Integration_Tests.run.xml",
37
+ ".idea/runConfigurations/Bundling_Tests.run.xml",
38
+ ".idea/runConfigurations/lint-fix.run.xml",
39
+ ".idea/runConfigurations/release.run.xml",
40
+ ".idea/runConfigurations/test_circular.run.xml",
41
+ ".idea/runConfigurations/uml.run.xml",
42
+ ".idea/runConfigurations/Unit Tests.run.xml",
43
+ ".idea/runConfigurations/update-scripts.run.xml",
44
+ ],
45
+ docs: [
46
+ "workdocs/tutorials/Contributing.md",
47
+ "workdocs/tutorials/Documentation.md",
48
+ "workdocs/tutorials/For Developers.md",
49
+ "workdocs/2-Badges.md",
50
+ "workdocs/jsdocs.json",
51
+ "workdocs/readme-md.json",
52
+ ],
53
+ styles: [".prettierrc", "eslint.config.js"],
54
+ scripts: ["bin/update-scripts.cjs", "bin/tag-release.cjs"],
55
+ tests: ["jest.config.ts", "workdocs/reports/jest.coverage.config.ts"],
56
+ typescript: ["tsconfig.json"],
57
+ docker: ["Dockerfile"],
58
+ automation: [
59
+ "workdocs/confluence/Continuous Integration-Deployment/GitHub.md",
60
+ "workdocs/confluence/Continuous Integration-Deployment/Jira.md",
61
+ "workdocs/confluence/Continuous Integration-Deployment/Teams.md",
62
+ ],
63
+ };
64
+ const argzz = {
65
+ // init attributes
66
+ boot: {
67
+ type: "boolean",
68
+ },
69
+ org: {
70
+ type: "string",
71
+ short: "o",
72
+ },
73
+ name: {
74
+ type: "string",
75
+ short: "n",
76
+ default: undefined,
77
+ },
78
+ author: {
79
+ type: "string",
80
+ short: "a",
81
+ default: undefined,
82
+ },
83
+ // update attributes
84
+ all: {
85
+ type: "boolean",
86
+ },
87
+ license: {
88
+ type: "string",
89
+ message: "Pick the license",
90
+ },
91
+ scripts: {
92
+ type: "boolean",
93
+ },
94
+ styles: {
95
+ type: "boolean",
96
+ },
97
+ docs: {
98
+ type: "boolean",
99
+ },
100
+ ide: {
101
+ type: "boolean",
102
+ },
103
+ workflows: {
104
+ type: "boolean",
105
+ },
106
+ templates: {
107
+ type: "boolean",
108
+ },
109
+ typescript: {
110
+ type: "boolean",
111
+ },
112
+ docker: {
113
+ type: "boolean",
114
+ },
115
+ pkg: {
116
+ type: "boolean",
117
+ },
118
+ dependencies: {
119
+ type: "boolean",
120
+ },
121
+ tests: {
122
+ type: "boolean",
123
+ },
124
+ automation: {
125
+ type: "boolean",
126
+ },
127
+ };
128
+ /**
129
+ * @class TemplateSync
130
+ * @extends {Command}
131
+ * @category scripts
132
+ * @description A command-line tool for synchronizing project templates and configurations.
133
+ * @summary This class provides functionality to download and update various project files and configurations from a remote repository.
134
+ * It supports updating licenses, IDE configurations, scripts, styles, documentation, workflows, and templates.
135
+ *
136
+ * @param {CommandOptions} args - The command options for TemplateSync
137
+ */
138
+ class TemplateSync extends command_1.Command {
139
+ constructor() {
140
+ super("TemplateSync", argzz);
141
+ this.replacements = {};
142
+ /**
143
+ * @description Downloads style configuration files.
144
+ * @returns {Promise<void>}
145
+ */
146
+ this.getStyles = () => this.downloadOption("styles");
147
+ /**
148
+ * @description Downloads template files.
149
+ * @returns {Promise<void>}
150
+ */
151
+ this.getTemplates = () => this.downloadOption("templates");
152
+ /**
153
+ * @description Downloads workflow configuration files.
154
+ * @returns {Promise<void>}
155
+ */
156
+ this.getWorkflows = () => this.downloadOption("workflows");
157
+ /**
158
+ * @description Downloads documentation files.
159
+ * @returns {Promise<void>}
160
+ */
161
+ this.getDocs = () => this.downloadOption("docs");
162
+ /**
163
+ * @description Downloads typescript config files.
164
+ * @returns {Promise<void>}
165
+ */
166
+ this.getTypescript = () => this.downloadOption("typescript");
167
+ /**
168
+ * @description Downloads automation documentation files.
169
+ * @returns {Promise<void>}
170
+ */
171
+ this.getAutomation = () => this.downloadOption("automation");
172
+ /**
173
+ * @description Downloads automation documentation files.
174
+ * @returns {Promise<void>}
175
+ */
176
+ this.getTests = () => this.downloadOption("tests");
177
+ /**
178
+ * @description Downloads docker image files.
179
+ * @returns {Promise<void>}
180
+ */
181
+ this.getDocker = () => this.downloadOption("docker");
182
+ }
183
+ loadValuesFromPackage() {
184
+ const p = process.cwd();
185
+ const author = (0, utils_1.getPackage)(p, "author");
186
+ const scopedName = (0, utils_1.getPackage)(p, "name");
187
+ let name = scopedName;
188
+ let org;
189
+ if (name.startsWith("@")) {
190
+ const split = name.split("/");
191
+ name = split[1];
192
+ org = split[0].replace("@", "");
193
+ }
194
+ ["Tiago Venceslau", "TiagoVenceslau", "${author}"].forEach((el) => (this.replacements[el] = author));
195
+ ["TS-Workspace", "ts-workspace", "${name}"].forEach((el) => (this.replacements[el] = name));
196
+ ["decaf-ts", "${org}"].forEach((el) => (this.replacements[el] = org || '""'));
197
+ this.replacements["${org_or_owner}"] = org || name;
198
+ }
199
+ /**
200
+ * @description Downloads files for a specific option category.
201
+ * @summary This method downloads all files associated with a given option key from the remote repository.
202
+ * @param {string} key - The key representing the option category to download
203
+ * @returns {Promise<void>}
204
+ * @throws {Error} If the specified option key is not found
205
+ */
206
+ async downloadOption(key) {
207
+ if (!(key in options)) {
208
+ throw new Error(`Option "${key}" not found in options`);
209
+ }
210
+ const files = options[key];
211
+ for (const file of files) {
212
+ this.log.info(`Downloading ${file}`);
213
+ let data = await utils_1.HttpClient.downloadFile(`${baseUrl}/${file}`);
214
+ data = (0, utils_1.patchString)(data, this.replacements);
215
+ (0, utils_1.writeFile)(path_1.default.join(process.cwd(), file), data);
216
+ }
217
+ }
218
+ /**
219
+ * @description Downloads and sets up the specified license.
220
+ * @summary This method downloads the chosen license file, saves it to the project, and updates the package.json license field.
221
+ * @param {"MIT" | "GPL" | "Apache" | "LGPL" | "AGPL"} license - The license to download and set up
222
+ * @returns {Promise<void>}
223
+ */
224
+ async getLicense(license) {
225
+ this.log.info(`Downloading ${license} license`);
226
+ const url = `${baseUrl}/workdocs/licenses/${license}.md`;
227
+ let data = await utils_1.HttpClient.downloadFile(url);
228
+ data = (0, utils_1.patchString)(data, this.replacements);
229
+ (0, utils_1.writeFile)(path_1.default.join(process.cwd(), "LICENSE.md"), data);
230
+ (0, utils_1.setPackageAttribute)("license", license);
231
+ }
232
+ /**
233
+ * @description Downloads IDE configuration files.
234
+ * @returns {Promise<void>}
235
+ */
236
+ async getIde() {
237
+ fs_1.default.mkdirSync(path_1.default.join(process.cwd(), ".idea", "runConfigurations"), {
238
+ recursive: true,
239
+ });
240
+ await this.downloadOption("ide");
241
+ }
242
+ /**
243
+ * @description Update npm scripts
244
+ * @returns {Promise<void>}
245
+ */
246
+ async getScripts() {
247
+ await this.downloadOption("scripts");
248
+ this.log.info("please re-run the command");
249
+ process.exit(0);
250
+ }
251
+ async initPackage(pkgName, author, license) {
252
+ try {
253
+ const pkg = (0, utils_1.getPackage)();
254
+ delete pkg[utils_1.SetupScriptKey];
255
+ pkg.name = pkgName;
256
+ pkg.version = "0.0.1";
257
+ pkg.author = author;
258
+ pkg.license = license;
259
+ fs_1.default.writeFileSync("package.json", JSON.stringify(pkg, null, 2));
260
+ }
261
+ catch (e) {
262
+ throw new Error(`Error fixing package.json: ${e}`);
263
+ }
264
+ }
265
+ async updatePackageScrips() {
266
+ try {
267
+ const originalPkg = JSON.parse(await utils_1.HttpClient.downloadFile(`${baseUrl}/package.json`));
268
+ const { scripts } = originalPkg;
269
+ const pkg = (0, utils_1.getPackage)();
270
+ Object.keys(pkg.scripts).forEach((key) => {
271
+ if (key in scripts) {
272
+ const replaced = (0, utils_1.patchString)(scripts[key], this.replacements);
273
+ if (replaced !== scripts[key]) {
274
+ pkg.scripts[key] = replaced;
275
+ }
276
+ }
277
+ });
278
+ pkg["exports"]["require"] = originalPkg["exports"]["require"];
279
+ pkg["exports"]["import"] = originalPkg["exports"]["import"];
280
+ pkg["types"] = originalPkg["types"];
281
+ fs_1.default.writeFileSync("package.json", JSON.stringify(pkg, null, 2));
282
+ }
283
+ catch (e) {
284
+ throw new Error(`Error fixing package.json scripts: ${e}`);
285
+ }
286
+ }
287
+ async createTokenFiles() {
288
+ const log = this.log.for(this.createTokenFiles);
289
+ const gitToken = await input_1.UserInput.insistForText("token", "please input your github token", (res) => {
290
+ return !!res.match(/^ghp_[0-9a-zA-Z]{36}$/g);
291
+ });
292
+ Object.values(utils_1.Tokens).forEach((token) => {
293
+ try {
294
+ let status;
295
+ try {
296
+ status = fs_1.default.existsSync(token);
297
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
298
+ }
299
+ catch (e) {
300
+ log.info(`Token file ${token} not found. Creating a new one...`);
301
+ fs_1.default.writeFileSync(token, token === ".token" ? gitToken : "");
302
+ return;
303
+ }
304
+ if (!status) {
305
+ fs_1.default.writeFileSync(token, token === ".token" ? gitToken : "");
306
+ }
307
+ }
308
+ catch (e) {
309
+ throw new Error(`Error creating token file ${token}: ${e}`);
310
+ }
311
+ });
312
+ }
313
+ async getOrg() {
314
+ const org = await input_1.UserInput.askText("Organization", "Enter the organization name (will be used to scope your npm project. leave blank to create a unscoped project):");
315
+ const confirmation = await input_1.UserInput.askConfirmation("Confirm organization", "Is this organization correct?", true);
316
+ if (!confirmation)
317
+ return this.getOrg();
318
+ return org;
319
+ }
320
+ async auditFix() {
321
+ return await (0, utils_1.runCommand)("npm audit fix --force").promise;
322
+ }
323
+ patchFiles() {
324
+ const files = [
325
+ ...fs_1.default
326
+ .readdirSync(path_1.default.join(process.cwd(), "src"), {
327
+ recursive: true,
328
+ withFileTypes: true,
329
+ })
330
+ .filter((entry) => entry.isFile())
331
+ .map((entry) => path_1.default.join(entry.parentPath, entry.name)),
332
+ ...fs_1.default
333
+ .readdirSync(path_1.default.join(process.cwd(), "workdocs"), {
334
+ recursive: true,
335
+ withFileTypes: true,
336
+ })
337
+ .filter((entry) => entry.isFile() && entry.name.endsWith(".md"))
338
+ .map((entry) => path_1.default.join(entry.parentPath, entry.name)),
339
+ path_1.default.join(process.cwd(), ".gitlab-ci.yml"),
340
+ path_1.default.join(process.cwd(), "workdocs", "jsdocs.json"),
341
+ ];
342
+ for (const file of files) {
343
+ (0, utils_1.patchFile)(file, this.replacements);
344
+ }
345
+ }
346
+ async updateDependencies() {
347
+ try {
348
+ const originalPkg = JSON.parse(await utils_1.HttpClient.downloadFile(`${baseUrl}/package.json`));
349
+ const { devDependencies } = originalPkg;
350
+ const pkg = (0, utils_1.getPackage)();
351
+ Object.keys(pkg.scripts).forEach((key) => {
352
+ if (key in devDependencies) {
353
+ const replaced = devDependencies[key];
354
+ if (replaced !== devDependencies[key]) {
355
+ pkg["devDependencies"] =
356
+ pkg["devDependencies"] || {};
357
+ pkg["devDependencies"][key] = replaced;
358
+ }
359
+ }
360
+ });
361
+ fs_1.default.writeFileSync("package.json", JSON.stringify(pkg, null, 2));
362
+ await (0, utils_1.runCommand)("npm install").promise;
363
+ }
364
+ catch (e) {
365
+ throw new Error(`Error fixing package.json dependencies: ${e}`);
366
+ }
367
+ }
368
+ /**
369
+ * @description Runs the template synchronization process.
370
+ * @summary This method orchestrates the downloading of various project components based on the provided arguments.
371
+ * @param {ParseArgsResult} args - The parsed command-line arguments
372
+ * @returns {Promise<void>}
373
+ *
374
+ * @mermaid
375
+ * sequenceDiagram
376
+ * participant T as TemplateSync
377
+ * participant L as getLicense
378
+ * participant I as getIde
379
+ * participant S as getScripts
380
+ * participant St as getStyles
381
+ * participant D as getDocs
382
+ * participant W as getWorkflows
383
+ * participant Te as getTemplates
384
+ * T->>T: Parse arguments
385
+ * alt all flag is true
386
+ * T->>T: Set all component flags to true
387
+ * end
388
+ * alt license is specified
389
+ * T->>L: getLicense(license)
390
+ * end
391
+ * alt ide flag is true
392
+ * T->>I: getIde()
393
+ * end
394
+ * alt scripts flag is true
395
+ * T->>S: getScripts()
396
+ * end
397
+ * alt styles flag is true
398
+ * T->>St: getStyles()
399
+ * end
400
+ * alt docs flag is true
401
+ * T->>D: getDocs()
402
+ * end
403
+ * alt workflows flag is true
404
+ * T->>W: getWorkflows()
405
+ * end
406
+ * alt templates flag is true
407
+ * T->>Te: getTemplates()
408
+ * end
409
+ */
410
+ async run(args) {
411
+ let { license } = args;
412
+ const { boot } = args;
413
+ let { all, scripts, styles, docs, ide, workflows, templates, docker, typescript, dependencies, tests, automation, pkg, } = args;
414
+ if (scripts ||
415
+ styles ||
416
+ docs ||
417
+ ide ||
418
+ workflows ||
419
+ templates ||
420
+ docker ||
421
+ typescript ||
422
+ automation ||
423
+ dependencies ||
424
+ tests ||
425
+ pkg)
426
+ all = false;
427
+ if (boot) {
428
+ const org = await this.getOrg();
429
+ const name = await input_1.UserInput.insistForText("Project name", "Enter the project name:", (res) => res.length > 1);
430
+ const author = await input_1.UserInput.insistForText("Author", "Enter the author name:", (res) => res.length > 1);
431
+ const pkgName = org ? `@${org}/${name}` : name;
432
+ await this.initPackage(pkgName, author, license);
433
+ await this.createTokenFiles();
434
+ await this.auditFix();
435
+ this.patchFiles();
436
+ }
437
+ if (all) {
438
+ scripts = false;
439
+ styles = true;
440
+ docs = true;
441
+ ide = true;
442
+ workflows = true;
443
+ templates = true;
444
+ docker = true;
445
+ typescript = true;
446
+ pkg = true;
447
+ dependencies = true;
448
+ tests = true;
449
+ automation = false;
450
+ }
451
+ if (typeof scripts === "undefined")
452
+ scripts = await input_1.UserInput.askConfirmation("scripts", "Do you want to get scripts?", true);
453
+ if (scripts)
454
+ await this.getScripts();
455
+ this.loadValuesFromPackage();
456
+ if (!all && typeof license === "undefined") {
457
+ const confirmation = await input_1.UserInput.askConfirmation("license", "Do you want to set a license?", true);
458
+ if (confirmation)
459
+ license = await input_1.UserInput.insistForText("license", "Enter the desired License (MIT|GPL|Apache|LGPL|AGPL):", (val) => !!val && !!val.match(/^(MIT|GPL|Apache|LGPL|AGPL)$/g));
460
+ }
461
+ if (typeof license !== "undefined")
462
+ await this.getLicense(license);
463
+ if (typeof ide === "undefined")
464
+ ide = await input_1.UserInput.askConfirmation("ide", "Do you want to get ide configs?", true);
465
+ if (ide)
466
+ await this.getIde();
467
+ if (typeof typescript === "undefined")
468
+ typescript = await input_1.UserInput.askConfirmation("typescript", "Do you want to get typescript configs?", true);
469
+ if (typescript)
470
+ await this.getTypescript();
471
+ if (typeof docker === "undefined")
472
+ docker = await input_1.UserInput.askConfirmation("docker", "Do you want to get docker configs?", true);
473
+ if (docker)
474
+ await this.getDocker();
475
+ if (typeof automation === "undefined")
476
+ automation = await input_1.UserInput.askConfirmation("automation", "Do you want to get automation configs?", true);
477
+ if (automation)
478
+ await this.getAutomation();
479
+ if (typeof styles === "undefined")
480
+ styles = await input_1.UserInput.askConfirmation("styles", "Do you want to get styles?", true);
481
+ if (styles)
482
+ await this.getStyles();
483
+ if (typeof docs === "undefined")
484
+ docs = await input_1.UserInput.askConfirmation("docs", "Do you want to get docs?", true);
485
+ if (docs)
486
+ await this.getDocs();
487
+ if (typeof workflows === "undefined")
488
+ workflows = await input_1.UserInput.askConfirmation("workflows", "Do you want to get workflows?", true);
489
+ if (workflows)
490
+ await this.getWorkflows();
491
+ if (typeof templates === "undefined")
492
+ templates = await input_1.UserInput.askConfirmation("templates", "Do you want to get templates?", true);
493
+ if (templates)
494
+ await this.getTemplates();
495
+ if (typeof pkg === "undefined")
496
+ pkg = await input_1.UserInput.askConfirmation("pkg", "Do you want to update your package.json scripts?", true);
497
+ if (pkg)
498
+ await this.updatePackageScrips();
499
+ if (typeof tests === "undefined")
500
+ tests = await input_1.UserInput.askConfirmation("pkg", "Do you want to update your test configs?", true);
501
+ if (tests)
502
+ await this.getTests();
503
+ if (typeof dependencies === "undefined")
504
+ dependencies = await input_1.UserInput.askConfirmation("pkg", "Do you want to update dev dependencies?", true);
505
+ if (dependencies)
506
+ await this.updateDependencies();
507
+ }
508
+ }
509
+ exports.TemplateSync = TemplateSync;
510
+
511
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/cli/commands/update-scripts.ts"],"names":[],"mappings":"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","file":"cli/commands/update-scripts.js","sourcesContent":["import path from \"path\";\nimport { Command } from \"../command\";\nimport { CommandOptions } from \"../types\";\nimport {\n  getPackage,\n  HttpClient,\n  patchFile,\n  patchString,\n  runCommand,\n  setPackageAttribute,\n  SetupScriptKey,\n  Tokens,\n  writeFile,\n} from \"../../utils\";\nimport { LoggingConfig } from \"../../output\";\nimport { DefaultCommandValues } from \"../index\";\nimport { UserInput } from \"../../input\";\nimport fs from \"fs\";\n\nconst baseUrl =\n  \"https://raw.githubusercontent.com/decaf-ts/ts-workspace/master\";\n\nconst options = {\n  templates: [\n    \".github/ISSUE_TEMPLATE/bug_report.md\",\n    \".github/ISSUE_TEMPLATE/feature_request.md\",\n    \".github/FUNDING.yml\",\n  ],\n  workflows: [\n    \".github/workflows/codeql-analysis.yml\",\n    \".github/workflows/jest-coverage.yaml\",\n    \".github/workflows/nodejs-build-prod.yaml\",\n    \".github/workflows/pages.yaml\",\n    \".github/workflows/publish-on-release.yaml\",\n    \".github/workflows/release-on-tag.yaml\",\n    \".github/workflows/snyk-analysis.yaml\",\n  ],\n  ide: [\n    \".idea/runConfigurations/All Tests.run.xml\",\n    \".idea/runConfigurations/build.run.xml\",\n    \".idea/runConfigurations/build_prod.run.xml\",\n    \".idea/runConfigurations/coverage.run.xml\",\n    \".idea/runConfigurations/docs.run.xml\",\n    \".idea/runConfigurations/drawings.run.xml\",\n    \".idea/runConfigurations/flash-forward.run.xml\",\n    \".idea/runConfigurations/Integration_Tests.run.xml\",\n    \".idea/runConfigurations/Bundling_Tests.run.xml\",\n    \".idea/runConfigurations/lint-fix.run.xml\",\n    \".idea/runConfigurations/release.run.xml\",\n    \".idea/runConfigurations/test_circular.run.xml\",\n    \".idea/runConfigurations/uml.run.xml\",\n    \".idea/runConfigurations/Unit Tests.run.xml\",\n    \".idea/runConfigurations/update-scripts.run.xml\",\n  ],\n  docs: [\n    \"workdocs/tutorials/Contributing.md\",\n    \"workdocs/tutorials/Documentation.md\",\n    \"workdocs/tutorials/For Developers.md\",\n    \"workdocs/2-Badges.md\",\n    \"workdocs/jsdocs.json\",\n    \"workdocs/readme-md.json\",\n  ],\n  styles: [\".prettierrc\", \"eslint.config.js\"],\n  scripts: [\"bin/update-scripts.cjs\", \"bin/tag-release.cjs\"],\n  tests: [\"jest.config.ts\", \"workdocs/reports/jest.coverage.config.ts\"],\n  typescript: [\"tsconfig.json\"],\n  docker: [\"Dockerfile\"],\n  automation: [\n    \"workdocs/confluence/Continuous Integration-Deployment/GitHub.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Jira.md\",\n    \"workdocs/confluence/Continuous Integration-Deployment/Teams.md\",\n  ],\n};\n\nconst argzz = {\n  // init attributes\n  boot: {\n    type: \"boolean\",\n  },\n  org: {\n    type: \"string\",\n    short: \"o\",\n  },\n  name: {\n    type: \"string\",\n    short: \"n\",\n    default: undefined,\n  },\n  author: {\n    type: \"string\",\n    short: \"a\",\n    default: undefined,\n  },\n  // update attributes\n  all: {\n    type: \"boolean\",\n  },\n  license: {\n    type: \"string\",\n    message: \"Pick the license\",\n  },\n  scripts: {\n    type: \"boolean\",\n  },\n  styles: {\n    type: \"boolean\",\n  },\n  docs: {\n    type: \"boolean\",\n  },\n  ide: {\n    type: \"boolean\",\n  },\n  workflows: {\n    type: \"boolean\",\n  },\n  templates: {\n    type: \"boolean\",\n  },\n  typescript: {\n    type: \"boolean\",\n  },\n  docker: {\n    type: \"boolean\",\n  },\n  pkg: {\n    type: \"boolean\",\n  },\n  dependencies: {\n    type: \"boolean\",\n  },\n  tests: {\n    type: \"boolean\",\n  },\n  automation: {\n    type: \"boolean\",\n  },\n};\n\n/**\n * @class TemplateSync\n * @extends {Command}\n * @category scripts\n * @description A command-line tool for synchronizing project templates and configurations.\n * @summary This class provides functionality to download and update various project files and configurations from a remote repository.\n * It supports updating licenses, IDE configurations, scripts, styles, documentation, workflows, and templates.\n *\n * @param {CommandOptions} args - The command options for TemplateSync\n */\nexport class TemplateSync extends Command<CommandOptions<typeof argzz>, void> {\n  private replacements: Record<string, string | number> = {};\n\n  constructor() {\n    super(\"TemplateSync\", argzz);\n  }\n\n  private loadValuesFromPackage() {\n    const p = process.cwd();\n    const author = getPackage(p, \"author\") as string;\n    const scopedName = getPackage(p, \"name\");\n    let name: string = scopedName as string;\n    let org: string | undefined;\n    if (name.startsWith(\"@\")) {\n      const split = name.split(\"/\");\n      name = split[1];\n      org = split[0].replace(\"@\", \"\");\n    }\n    [\"Tiago Venceslau\", \"TiagoVenceslau\", \"${author}\"].forEach(\n      (el) => (this.replacements[el] = author)\n    );\n    [\"TS-Workspace\", \"ts-workspace\", \"${name}\"].forEach(\n      (el) => (this.replacements[el] = name)\n    );\n    [\"decaf-ts\", \"${org}\"].forEach(\n      (el) => (this.replacements[el] = (org as string) || '\"\"')\n    );\n    this.replacements[\"${org_or_owner}\"] = org || name;\n  }\n\n  /**\n   * @description Downloads files for a specific option category.\n   * @summary This method downloads all files associated with a given option key from the remote repository.\n   * @param {string} key - The key representing the option category to download\n   * @returns {Promise<void>}\n   * @throws {Error} If the specified option key is not found\n   */\n  async downloadOption(key: keyof typeof options): Promise<void> {\n    if (!(key in options)) {\n      throw new Error(`Option \"${key}\" not found in options`);\n    }\n    const files = options[key as keyof typeof options];\n\n    for (const file of files) {\n      this.log.info(`Downloading ${file}`);\n\n      let data = await HttpClient.downloadFile(`${baseUrl}/${file}`);\n      data = patchString(data, this.replacements);\n      writeFile(path.join(process.cwd(), file), data);\n    }\n  }\n\n  /**\n   * @description Downloads and sets up the specified license.\n   * @summary This method downloads the chosen license file, saves it to the project, and updates the package.json license field.\n   * @param {\"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"} license - The license to download and set up\n   * @returns {Promise<void>}\n   */\n  async getLicense(license: \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\") {\n    this.log.info(`Downloading ${license} license`);\n    const url = `${baseUrl}/workdocs/licenses/${license}.md`;\n    let data = await HttpClient.downloadFile(url);\n    data = patchString(data, this.replacements);\n    writeFile(path.join(process.cwd(), \"LICENSE.md\"), data);\n    setPackageAttribute(\"license\", license);\n  }\n\n  /**\n   * @description Downloads IDE configuration files.\n   * @returns {Promise<void>}\n   */\n  async getIde() {\n    fs.mkdirSync(path.join(process.cwd(), \".idea\", \"runConfigurations\"), {\n      recursive: true,\n    });\n    await this.downloadOption(\"ide\");\n  }\n\n  /**\n   * @description Update npm scripts\n   * @returns {Promise<void>}\n   */\n  async getScripts() {\n    await this.downloadOption(\"scripts\");\n    this.log.info(\"please re-run the command\");\n    process.exit(0);\n  }\n\n  /**\n   * @description Downloads style configuration files.\n   * @returns {Promise<void>}\n   */\n  getStyles = () => this.downloadOption(\"styles\");\n\n  /**\n   * @description Downloads template files.\n   * @returns {Promise<void>}\n   */\n  getTemplates = () => this.downloadOption(\"templates\");\n\n  /**\n   * @description Downloads workflow configuration files.\n   * @returns {Promise<void>}\n   */\n  getWorkflows = () => this.downloadOption(\"workflows\");\n\n  /**\n   * @description Downloads documentation files.\n   * @returns {Promise<void>}\n   */\n  getDocs = () => this.downloadOption(\"docs\");\n\n  /**\n   * @description Downloads typescript config files.\n   * @returns {Promise<void>}\n   */\n  getTypescript = () => this.downloadOption(\"typescript\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getAutomation = () => this.downloadOption(\"automation\");\n\n  /**\n   * @description Downloads automation documentation files.\n   * @returns {Promise<void>}\n   */\n  getTests = () => this.downloadOption(\"tests\");\n\n  /**\n   * @description Downloads docker image files.\n   * @returns {Promise<void>}\n   */\n  getDocker = () => this.downloadOption(\"docker\");\n\n  async initPackage(pkgName: string, author: string, license: string) {\n    try {\n      const pkg = getPackage() as Record<string, unknown>;\n      delete pkg[SetupScriptKey];\n      pkg.name = pkgName;\n      pkg.version = \"0.0.1\";\n      pkg.author = author;\n      pkg.license = license;\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json: ${e}`);\n    }\n  }\n\n  async updatePackageScrips() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { scripts } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in scripts) {\n          const replaced = patchString(scripts[key], this.replacements);\n          if (replaced !== scripts[key]) {\n            pkg.scripts[key] = replaced;\n          }\n        }\n      });\n\n      pkg[\"exports\"][\"require\"] = originalPkg[\"exports\"][\"require\"];\n      pkg[\"exports\"][\"import\"] = originalPkg[\"exports\"][\"import\"];\n      pkg[\"types\"] = originalPkg[\"types\"];\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json scripts: ${e}`);\n    }\n  }\n\n  async createTokenFiles() {\n    const log = this.log.for(this.createTokenFiles);\n    const gitToken = await UserInput.insistForText(\n      \"token\",\n      \"please input your github token\",\n      (res: string) => {\n        return !!res.match(/^ghp_[0-9a-zA-Z]{36}$/g);\n      }\n    );\n    Object.values(Tokens).forEach((token) => {\n      try {\n        let status;\n        try {\n          status = fs.existsSync(token);\n          // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        } catch (e: unknown) {\n          log.info(`Token file ${token} not found. Creating a new one...`);\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n          return;\n        }\n        if (!status) {\n          fs.writeFileSync(token, token === \".token\" ? gitToken : \"\");\n        }\n      } catch (e: unknown) {\n        throw new Error(`Error creating token file ${token}: ${e}`);\n      }\n    });\n  }\n\n  async getOrg(): Promise<string> {\n    const org = await UserInput.askText(\n      \"Organization\",\n      \"Enter the organization name (will be used to scope your npm project. leave blank to create a unscoped project):\"\n    );\n    const confirmation = await UserInput.askConfirmation(\n      \"Confirm organization\",\n      \"Is this organization correct?\",\n      true\n    );\n    if (!confirmation) return this.getOrg();\n\n    return org;\n  }\n\n  async auditFix() {\n    return await runCommand(\"npm audit fix --force\").promise;\n  }\n\n  patchFiles() {\n    const files = [\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"src\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile())\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      ...fs\n        .readdirSync(path.join(process.cwd(), \"workdocs\"), {\n          recursive: true,\n          withFileTypes: true,\n        })\n        .filter((entry) => entry.isFile() && entry.name.endsWith(\".md\"))\n        .map((entry) => path.join(entry.parentPath, entry.name)),\n      path.join(process.cwd(), \".gitlab-ci.yml\"),\n      path.join(process.cwd(), \"workdocs\", \"jsdocs.json\"),\n    ];\n\n    for (const file of files) {\n      patchFile(file as string, this.replacements);\n    }\n  }\n\n  async updateDependencies() {\n    try {\n      const originalPkg = JSON.parse(\n        await HttpClient.downloadFile(`${baseUrl}/package.json`)\n      );\n      const { devDependencies } = originalPkg;\n\n      const pkg: typeof originalPkg = getPackage() as {\n        scripts: Record<string, string>;\n      };\n      Object.keys(pkg.scripts).forEach((key) => {\n        if (key in devDependencies) {\n          const replaced = devDependencies[key];\n          if (replaced !== devDependencies[key]) {\n            (pkg as any)[\"devDependencies\"] =\n              (pkg as any)[\"devDependencies\"] || {};\n            (pkg as any)[\"devDependencies\"][key] = replaced;\n          }\n        }\n      });\n\n      fs.writeFileSync(\"package.json\", JSON.stringify(pkg, null, 2));\n      await runCommand(\"npm install\").promise;\n    } catch (e: unknown) {\n      throw new Error(`Error fixing package.json dependencies: ${e}`);\n    }\n  }\n\n  /**\n   * @description Runs the template synchronization process.\n   * @summary This method orchestrates the downloading of various project components based on the provided arguments.\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant T as TemplateSync\n   *   participant L as getLicense\n   *   participant I as getIde\n   *   participant S as getScripts\n   *   participant St as getStyles\n   *   participant D as getDocs\n   *   participant W as getWorkflows\n   *   participant Te as getTemplates\n   *   T->>T: Parse arguments\n   *   alt all flag is true\n   *     T->>T: Set all component flags to true\n   *   end\n   *   alt license is specified\n   *     T->>L: getLicense(license)\n   *   end\n   *   alt ide flag is true\n   *     T->>I: getIde()\n   *   end\n   *   alt scripts flag is true\n   *     T->>S: getScripts()\n   *   end\n   *   alt styles flag is true\n   *     T->>St: getStyles()\n   *   end\n   *   alt docs flag is true\n   *     T->>D: getDocs()\n   *   end\n   *   alt workflows flag is true\n   *     T->>W: getWorkflows()\n   *   end\n   *   alt templates flag is true\n   *     T->>Te: getTemplates()\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof argzz]: unknown }\n  ) {\n    let { license } = args;\n    const { boot } = args;\n    let {\n      all,\n      scripts,\n      styles,\n      docs,\n      ide,\n      workflows,\n      templates,\n      docker,\n      typescript,\n      dependencies,\n      tests,\n      automation,\n      pkg,\n    } = args;\n    if (\n      scripts ||\n      styles ||\n      docs ||\n      ide ||\n      workflows ||\n      templates ||\n      docker ||\n      typescript ||\n      automation ||\n      dependencies ||\n      tests ||\n      pkg\n    )\n      all = false;\n\n    if (boot) {\n      const org = await this.getOrg();\n      const name = await UserInput.insistForText(\n        \"Project name\",\n        \"Enter the project name:\",\n        (res: string) => res.length > 1\n      );\n      const author = await UserInput.insistForText(\n        \"Author\",\n        \"Enter the author name:\",\n        (res: string) => res.length > 1\n      );\n      const pkgName = org ? `@${org}/${name}` : name;\n\n      await this.initPackage(pkgName, author, license as string);\n      await this.createTokenFiles();\n      await this.auditFix();\n      this.patchFiles();\n    }\n\n    if (all) {\n      scripts = false;\n      styles = true;\n      docs = true;\n      ide = true;\n      workflows = true;\n      templates = true;\n      docker = true;\n      typescript = true;\n      pkg = true;\n      dependencies = true;\n      tests = true;\n      automation = false;\n    }\n\n    if (typeof scripts === \"undefined\")\n      scripts = await UserInput.askConfirmation(\n        \"scripts\",\n        \"Do you want to get scripts?\",\n        true\n      );\n\n    if (scripts) await this.getScripts();\n\n    this.loadValuesFromPackage();\n    if (!all && typeof license === \"undefined\") {\n      const confirmation = await UserInput.askConfirmation(\n        \"license\",\n        \"Do you want to set a license?\",\n        true\n      );\n      if (confirmation)\n        license = await UserInput.insistForText(\n          \"license\",\n          \"Enter the desired License (MIT|GPL|Apache|LGPL|AGPL):\",\n          (val) => !!val && !!val.match(/^(MIT|GPL|Apache|LGPL|AGPL)$/g)\n        );\n    }\n    if (typeof license !== \"undefined\")\n      await this.getLicense(\n        license as \"MIT\" | \"GPL\" | \"Apache\" | \"LGPL\" | \"AGPL\"\n      );\n\n    if (typeof ide === \"undefined\")\n      ide = await UserInput.askConfirmation(\n        \"ide\",\n        \"Do you want to get ide configs?\",\n        true\n      );\n\n    if (ide) await this.getIde();\n\n    if (typeof typescript === \"undefined\")\n      typescript = await UserInput.askConfirmation(\n        \"typescript\",\n        \"Do you want to get typescript configs?\",\n        true\n      );\n    if (typescript) await this.getTypescript();\n\n    if (typeof docker === \"undefined\")\n      docker = await UserInput.askConfirmation(\n        \"docker\",\n        \"Do you want to get docker configs?\",\n        true\n      );\n\n    if (docker) await this.getDocker();\n    if (typeof automation === \"undefined\")\n      automation = await UserInput.askConfirmation(\n        \"automation\",\n        \"Do you want to get automation configs?\",\n        true\n      );\n    if (automation) await this.getAutomation();\n\n    if (typeof styles === \"undefined\")\n      styles = await UserInput.askConfirmation(\n        \"styles\",\n        \"Do you want to get styles?\",\n        true\n      );\n    if (styles) await this.getStyles();\n\n    if (typeof docs === \"undefined\")\n      docs = await UserInput.askConfirmation(\n        \"docs\",\n        \"Do you want to get docs?\",\n        true\n      );\n    if (docs) await this.getDocs();\n    if (typeof workflows === \"undefined\")\n      workflows = await UserInput.askConfirmation(\n        \"workflows\",\n        \"Do you want to get workflows?\",\n        true\n      );\n    if (workflows) await this.getWorkflows();\n    if (typeof templates === \"undefined\")\n      templates = await UserInput.askConfirmation(\n        \"templates\",\n        \"Do you want to get templates?\",\n        true\n      );\n    if (templates) await this.getTemplates();\n    if (typeof pkg === \"undefined\")\n      pkg = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your package.json scripts?\",\n        true\n      );\n    if (pkg) await this.updatePackageScrips();\n\n    if (typeof tests === \"undefined\")\n      tests = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update your test configs?\",\n        true\n      );\n    if (tests) await this.getTests();\n\n    if (typeof dependencies === \"undefined\")\n      dependencies = await UserInput.askConfirmation(\n        \"pkg\",\n        \"Do you want to update dev dependencies?\",\n        true\n      );\n    if (dependencies) await this.updateDependencies();\n  }\n}\n"]}