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