@decaf-ts/utils 0.1.6 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/slogans.json +802 -0
- package/dist/utils.cjs +4471 -0
- package/dist/utils.esm.cjs +4424 -0
- package/lib/bin/build-scripts.cjs +11 -0
- package/lib/bin/tag-release.cjs +1 -2
- package/lib/bin/update-scripts.cjs +1 -2
- package/lib/bin/update-scripts.d.ts +1 -0
- package/lib/cli/command.cjs +1 -2
- package/lib/cli/commands/build-scripts.cjs +270 -0
- package/lib/cli/commands/build-scripts.d.ts +50 -0
- package/lib/cli/commands/index.cjs +2 -2
- package/{dist/types → lib}/cli/commands/index.d.ts +1 -0
- package/lib/cli/commands/tag-release.cjs +1 -2
- package/lib/cli/commands/update-scripts.cjs +6 -3
- package/lib/cli/constants.cjs +1 -2
- package/lib/cli/index.cjs +1 -2
- package/lib/cli/types.cjs +1 -2
- package/lib/esm/assets/slogans.json +801 -801
- package/lib/esm/bin/build-scripts.d.ts +1 -0
- package/lib/esm/bin/build-scripts.js +9 -0
- package/lib/esm/bin/tag-release.d.ts +1 -0
- package/lib/esm/bin/tag-release.js +1 -2
- package/lib/esm/bin/update-scripts.d.ts +1 -0
- package/lib/esm/bin/update-scripts.js +1 -2
- package/lib/esm/cli/command.d.ts +110 -0
- package/lib/esm/cli/command.js +1 -2
- package/lib/esm/cli/commands/build-scripts.d.ts +50 -0
- package/lib/esm/cli/commands/build-scripts.js +263 -0
- package/lib/esm/cli/commands/index.d.ts +3 -0
- package/lib/esm/cli/commands/index.js +2 -2
- package/lib/esm/cli/commands/tag-release.d.ts +105 -0
- package/lib/esm/cli/commands/tag-release.js +1 -2
- package/lib/esm/cli/commands/update-scripts.d.ts +211 -0
- package/lib/esm/cli/commands/update-scripts.js +6 -3
- package/lib/esm/cli/constants.d.ts +73 -0
- package/lib/esm/cli/constants.js +1 -2
- package/lib/esm/cli/index.d.ts +4 -0
- package/lib/esm/cli/index.js +1 -2
- package/lib/esm/cli/types.d.ts +28 -0
- package/lib/esm/cli/types.js +1 -2
- package/{dist/types → lib/esm}/index.d.ts +2 -2
- package/lib/esm/index.js +3 -4
- package/lib/esm/input/index.js +1 -2
- package/{dist/types → lib/esm}/input/input.d.ts +3 -3
- package/lib/esm/input/input.js +1 -2
- package/lib/esm/input/types.js +1 -2
- package/lib/esm/output/common.js +1 -2
- package/lib/esm/output/index.js +1 -2
- package/lib/esm/output/logging.js +1 -2
- package/lib/esm/output/types.js +1 -2
- package/lib/esm/utils/accumulator.js +1 -2
- package/lib/esm/utils/constants.js +1 -2
- package/lib/esm/utils/environment.js +1 -2
- package/{dist/types → lib/esm}/utils/fs.d.ts +16 -0
- package/lib/esm/utils/fs.js +115 -2
- package/lib/esm/utils/http.js +1 -2
- package/lib/esm/utils/index.js +1 -2
- package/lib/esm/utils/md.js +1 -2
- package/lib/esm/utils/tests.js +1 -2
- package/lib/esm/utils/text.js +1 -2
- package/lib/esm/utils/timeout.js +1 -2
- package/lib/esm/utils/types.js +1 -2
- package/lib/esm/utils/utils.js +1 -2
- package/lib/esm/utils/web.js +1 -2
- package/lib/esm/writers/OutputWriter.js +1 -2
- package/lib/esm/writers/RegexpOutputWriter.js +1 -2
- package/lib/esm/writers/StandardOutputWriter.js +2 -4
- package/lib/esm/writers/index.js +1 -2
- package/lib/esm/writers/types.js +1 -2
- package/lib/index.cjs +3 -4
- package/lib/index.d.ts +39 -0
- package/lib/input/index.cjs +1 -2
- package/lib/input/index.d.ts +2 -0
- package/lib/input/input.cjs +1 -2
- package/lib/input/input.d.ts +472 -0
- package/lib/input/types.cjs +1 -2
- package/lib/input/types.d.ts +76 -0
- package/lib/output/common.cjs +1 -2
- package/lib/output/common.d.ts +51 -0
- package/lib/output/index.cjs +1 -2
- package/lib/output/index.d.ts +3 -0
- package/lib/output/logging.cjs +1 -2
- package/lib/output/logging.d.ts +177 -0
- package/lib/output/types.cjs +1 -2
- package/lib/output/types.d.ts +203 -0
- package/lib/utils/accumulator.cjs +1 -2
- package/lib/utils/accumulator.d.ts +105 -0
- package/lib/utils/constants.cjs +1 -2
- package/lib/utils/constants.d.ts +136 -0
- package/lib/utils/environment.cjs +1 -2
- package/lib/utils/environment.d.ts +57 -0
- package/lib/utils/fs.cjs +119 -2
- package/lib/utils/fs.d.ts +149 -0
- package/lib/utils/http.cjs +1 -2
- package/lib/utils/http.d.ts +41 -0
- package/lib/utils/index.cjs +1 -2
- package/lib/utils/index.d.ts +7 -0
- package/lib/utils/md.cjs +1 -2
- package/lib/utils/md.d.ts +156 -0
- package/lib/utils/tests.cjs +1 -2
- package/lib/utils/tests.d.ts +170 -0
- package/lib/utils/text.cjs +1 -2
- package/lib/utils/text.d.ts +106 -0
- package/lib/utils/timeout.cjs +1 -2
- package/lib/utils/timeout.d.ts +1 -0
- package/lib/utils/types.cjs +1 -2
- package/lib/utils/types.d.ts +81 -0
- package/lib/utils/utils.cjs +1 -2
- package/lib/utils/utils.d.ts +91 -0
- package/lib/utils/web.cjs +1 -2
- package/lib/utils/web.d.ts +7 -0
- package/lib/writers/OutputWriter.cjs +1 -2
- package/lib/writers/OutputWriter.d.ts +49 -0
- package/lib/writers/RegexpOutputWriter.cjs +1 -2
- package/lib/writers/RegexpOutputWriter.d.ts +69 -0
- package/lib/writers/StandardOutputWriter.cjs +2 -4
- package/lib/writers/StandardOutputWriter.d.ts +91 -0
- package/lib/writers/index.cjs +1 -2
- package/lib/writers/index.d.ts +4 -0
- package/lib/writers/types.cjs +1 -2
- package/lib/writers/types.d.ts +29 -0
- package/package.json +24 -30
- package/dist/esm/utils.js +0 -1
- package/dist/utils.js +0 -1
- /package/{dist/types/bin/tag-release.d.ts → lib/bin/build-scripts.d.ts} +0 -0
- /package/{dist/types/bin/update-scripts.d.ts → lib/bin/tag-release.d.ts} +0 -0
- /package/{dist/types → lib}/cli/command.d.ts +0 -0
- /package/{dist/types → lib}/cli/commands/tag-release.d.ts +0 -0
- /package/{dist/types → lib}/cli/commands/update-scripts.d.ts +0 -0
- /package/{dist/types → lib}/cli/constants.d.ts +0 -0
- /package/{dist/types → lib}/cli/index.d.ts +0 -0
- /package/{dist/types → lib}/cli/types.d.ts +0 -0
- /package/{dist/types → lib/esm}/input/index.d.ts +0 -0
- /package/{dist/types → lib/esm}/input/types.d.ts +0 -0
- /package/{dist/types → lib/esm}/output/common.d.ts +0 -0
- /package/{dist/types → lib/esm}/output/index.d.ts +0 -0
- /package/{dist/types → lib/esm}/output/logging.d.ts +0 -0
- /package/{dist/types → lib/esm}/output/types.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/accumulator.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/constants.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/environment.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/http.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/index.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/md.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/tests.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/text.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/timeout.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/types.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/utils.d.ts +0 -0
- /package/{dist/types → lib/esm}/utils/web.d.ts +0 -0
- /package/{dist/types → lib/esm}/writers/OutputWriter.d.ts +0 -0
- /package/{dist/types → lib/esm}/writers/RegexpOutputWriter.d.ts +0 -0
- /package/{dist/types → lib/esm}/writers/StandardOutputWriter.d.ts +0 -0
- /package/{dist/types → lib/esm}/writers/index.d.ts +0 -0
- /package/{dist/types → lib/esm}/writers/types.d.ts +0 -0
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { Command } from "../command";
|
|
2
|
+
import { LoggingConfig } from "../../output";
|
|
3
|
+
import { DefaultCommandValues } from "../index";
|
|
4
|
+
declare const options: {
|
|
5
|
+
ci: {
|
|
6
|
+
type: string;
|
|
7
|
+
default: boolean;
|
|
8
|
+
};
|
|
9
|
+
message: {
|
|
10
|
+
type: string;
|
|
11
|
+
short: string;
|
|
12
|
+
};
|
|
13
|
+
tag: {
|
|
14
|
+
type: string;
|
|
15
|
+
short: string;
|
|
16
|
+
default: undefined;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* @class ReleaseScript
|
|
21
|
+
* @extends {Command}
|
|
22
|
+
* @cavegory scripts
|
|
23
|
+
* @description A command-line script for managing releases and version updates.
|
|
24
|
+
* @summary This script automates the process of creating and pushing new releases. It handles version updates,
|
|
25
|
+
* commit messages, and optionally publishes to NPM. The script supports semantic versioning and can work in both CI and non-CI environments.
|
|
26
|
+
*
|
|
27
|
+
* @param {Object} options - Configuration options for the script
|
|
28
|
+
* @param {boolean} options.ci - Whether the script is running in a CI environment (default: true)
|
|
29
|
+
* @param {string} options.message - The release message (short: 'm')
|
|
30
|
+
* @param {string} options.tag - The version tag to use (short: 't', default: undefined)
|
|
31
|
+
*/
|
|
32
|
+
export declare class ReleaseScript extends Command<typeof options, void> {
|
|
33
|
+
constructor();
|
|
34
|
+
/**
|
|
35
|
+
* @description Prepares the version for the release.
|
|
36
|
+
* @summary This method validates the provided tag or prompts the user for a new one if not provided or invalid.
|
|
37
|
+
* It also displays the latest git tags for reference.
|
|
38
|
+
* @param {string} tag - The version tag to prepare
|
|
39
|
+
* @returns {Promise<string>} The prepared version tag
|
|
40
|
+
*
|
|
41
|
+
* @mermaid
|
|
42
|
+
* sequenceDiagram
|
|
43
|
+
* participant R as ReleaseScript
|
|
44
|
+
* participant T as TestVersion
|
|
45
|
+
* participant U as UserInput
|
|
46
|
+
* participant G as Git
|
|
47
|
+
* R->>T: testVersion(tag)
|
|
48
|
+
* alt tag is valid
|
|
49
|
+
* T-->>R: return tag
|
|
50
|
+
* else tag is invalid or not provided
|
|
51
|
+
* R->>G: List latest git tags
|
|
52
|
+
* R->>U: Prompt for new tag
|
|
53
|
+
* U-->>R: return new tag
|
|
54
|
+
* end
|
|
55
|
+
*/
|
|
56
|
+
prepareVersion(tag?: string): Promise<string>;
|
|
57
|
+
/**
|
|
58
|
+
* @description Tests if the provided version is valid.
|
|
59
|
+
* @summary This method checks if the version is a valid semantic version or a predefined update type (PATCH, MINOR, MAJOR).
|
|
60
|
+
* @param {string} version - The version to test
|
|
61
|
+
* @returns {string | undefined} The validated version or undefined if invalid
|
|
62
|
+
*/
|
|
63
|
+
testVersion(version: string): string | undefined;
|
|
64
|
+
/**
|
|
65
|
+
* @description Prepares the release message.
|
|
66
|
+
* @summary This method either returns the provided message or prompts the user for a new one if not provided.
|
|
67
|
+
* @param {string} [message] - The release message
|
|
68
|
+
* @returns {Promise<string>} The prepared release message
|
|
69
|
+
*/
|
|
70
|
+
prepareMessage(message?: string): Promise<string>;
|
|
71
|
+
/**
|
|
72
|
+
* @description Runs the release script.
|
|
73
|
+
* @summary This method orchestrates the entire release process, including version preparation, message creation,
|
|
74
|
+
* git operations, and npm publishing (if not in CI environment).
|
|
75
|
+
* @param {ParseArgsResult} args - The parsed command-line arguments
|
|
76
|
+
* @returns {Promise<void>}
|
|
77
|
+
*
|
|
78
|
+
* @mermaid
|
|
79
|
+
* sequenceDiagram
|
|
80
|
+
* participant R as ReleaseScript
|
|
81
|
+
* participant V as PrepareVersion
|
|
82
|
+
* participant M as PrepareMessage
|
|
83
|
+
* participant N as NPM
|
|
84
|
+
* participant G as Git
|
|
85
|
+
* participant U as UserInput
|
|
86
|
+
* R->>V: prepareVersion(tag)
|
|
87
|
+
* R->>M: prepareMessage(message)
|
|
88
|
+
* R->>N: Run prepare-release script
|
|
89
|
+
* R->>G: Check git status
|
|
90
|
+
* alt changes exist
|
|
91
|
+
* R->>U: Ask for confirmation
|
|
92
|
+
* U-->>R: Confirm
|
|
93
|
+
* R->>G: Add and commit changes
|
|
94
|
+
* end
|
|
95
|
+
* R->>N: Update npm version
|
|
96
|
+
* R->>G: Push changes and tags
|
|
97
|
+
* alt not CI environment
|
|
98
|
+
* R->>N: Publish to npm
|
|
99
|
+
* end
|
|
100
|
+
*/
|
|
101
|
+
run(args: LoggingConfig & typeof DefaultCommandValues & {
|
|
102
|
+
[k in keyof typeof options]: unknown;
|
|
103
|
+
}): Promise<void>;
|
|
104
|
+
}
|
|
105
|
+
export {};
|
|
@@ -160,5 +160,4 @@ export class ReleaseScript extends Command {
|
|
|
160
160
|
}
|
|
161
161
|
}
|
|
162
162
|
}
|
|
163
|
-
|
|
164
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/cli/commands/tag-release.ts"],"names":[],"mappings":"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","file":"cli/commands/tag-release.js","sourcesContent":["import { runCommand } from \"../../utils/utils\";\nimport { NoCIFLag, SemVersion, SemVersionRegex } from \"../../utils/constants\";\nimport { UserInput } from \"../../input/input\";\nimport { Command } from \"../command\";\nimport { LoggingConfig } from \"../../output\";\nimport { DefaultCommandValues } from \"../index\";\n\nconst options = {\n  ci: {\n    type: \"boolean\",\n    default: true,\n  },\n  message: {\n    type: \"string\",\n    short: \"m\",\n  },\n  tag: {\n    type: \"string\",\n    short: \"t\",\n    default: undefined,\n  },\n};\n\n/**\n * @class ReleaseScript\n * @extends {Command}\n * @cavegory scripts\n * @description A command-line script for managing releases and version updates.\n * @summary This script automates the process of creating and pushing new releases. It handles version updates,\n * commit messages, and optionally publishes to NPM. The script supports semantic versioning and can work in both CI and non-CI environments.\n *\n * @param {Object} options - Configuration options for the script\n * @param {boolean} options.ci - Whether the script is running in a CI environment (default: true)\n * @param {string} options.message - The release message (short: 'm')\n * @param {string} options.tag - The version tag to use (short: 't', default: undefined)\n */\nexport class ReleaseScript extends Command<typeof options, void> {\n  constructor() {\n    super(\"ReleaseScript\", options);\n  }\n\n  /**\n   * @description Prepares the version for the release.\n   * @summary This method validates the provided tag or prompts the user for a new one if not provided or invalid.\n   * It also displays the latest git tags for reference.\n   * @param {string} tag - The version tag to prepare\n   * @returns {Promise<string>} The prepared version tag\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant T as TestVersion\n   *   participant U as UserInput\n   *   participant G as Git\n   *   R->>T: testVersion(tag)\n   *   alt tag is valid\n   *     T-->>R: return tag\n   *   else tag is invalid or not provided\n   *     R->>G: List latest git tags\n   *     R->>U: Prompt for new tag\n   *     U-->>R: return new tag\n   *   end\n   */\n  async prepareVersion(tag?: string): Promise<string> {\n    const log = this.log.for(this.prepareVersion);\n    tag = this.testVersion((tag as string) || \"\");\n    if (!tag) {\n      log.verbose(\"No release message provided. Prompting for one:\");\n      log.info(`Listing latest git tags:`);\n      await runCommand(\"git tag --sort=-taggerdate | head -n 5\").promise;\n      return await UserInput.insistForText(\n        \"tag\",\n        \"Enter the new tag number (accepts v*.*.*[-...])\",\n        (val) =>\n          !!val.toString().match(/^v[0-9]+\\.[0-9]+.[0-9]+(-[0-9a-zA-Z-]+)?$/)\n      );\n    }\n    return tag;\n  }\n\n  /**\n   * @description Tests if the provided version is valid.\n   * @summary This method checks if the version is a valid semantic version or a predefined update type (PATCH, MINOR, MAJOR).\n   * @param {string} version - The version to test\n   * @returns {string | undefined} The validated version or undefined if invalid\n   */\n  testVersion(version: string): string | undefined {\n    const log = this.log.for(this.testVersion);\n    version = version.trim().toLowerCase();\n    switch (version) {\n      case SemVersion.PATCH:\n      case SemVersion.MINOR:\n      case SemVersion.MAJOR:\n        log.verbose(`Using provided SemVer update: ${version}`, 1);\n        return version;\n      default:\n        log.verbose(\n          `Testing provided version for SemVer compatibility: ${version}`,\n          1\n        );\n        if (!new RegExp(SemVersionRegex).test(version)) {\n          log.debug(`Invalid version number: ${version}`);\n          return undefined;\n        }\n        log.verbose(`version approved: ${version}`, 1);\n        return version;\n    }\n  }\n\n  /**\n   * @description Prepares the release message.\n   * @summary This method either returns the provided message or prompts the user for a new one if not provided.\n   * @param {string} [message] - The release message\n   * @returns {Promise<string>} The prepared release message\n   */\n  async prepareMessage(message?: string) {\n    const log = this.log.for(this.prepareMessage);\n    if (!message) {\n      log.verbose(\"No release message provided. Prompting for one\");\n      return await UserInput.insistForText(\n        \"message\",\n        \"What should be the release message/ticket?\",\n        (val) => !!val && val.toString().length > 5\n      );\n    }\n    return message;\n  }\n\n  /**\n   * @description Runs the release script.\n   * @summary This method orchestrates the entire release process, including version preparation, message creation,\n   * git operations, and npm publishing (if not in CI environment).\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant V as PrepareVersion\n   *   participant M as PrepareMessage\n   *   participant N as NPM\n   *   participant G as Git\n   *   participant U as UserInput\n   *   R->>V: prepareVersion(tag)\n   *   R->>M: prepareMessage(message)\n   *   R->>N: Run prepare-release script\n   *   R->>G: Check git status\n   *   alt changes exist\n   *     R->>U: Ask for confirmation\n   *     U-->>R: Confirm\n   *     R->>G: Add and commit changes\n   *   end\n   *   R->>N: Update npm version\n   *   R->>G: Push changes and tags\n   *   alt not CI environment\n   *     R->>N: Publish to npm\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<void> {\n    let result: any;\n    const { ci } = args;\n    let { tag, message } = args;\n    tag = await this.prepareVersion(tag as string);\n    message = await this.prepareMessage(message as string);\n    result = await runCommand(`npm run prepare-release -- ${tag} ${message}`, {\n      cwd: process.cwd(),\n    }).promise;\n    result = await runCommand(\"git status --porcelain\").promise;\n    await result;\n    if (\n      result.logs.length &&\n      (await UserInput.askConfirmation(\n        \"git-changes\",\n        \"Do you want to push the changes to the remote repository?\",\n        true\n      ))\n    ) {\n      await runCommand(\"git add .\").promise;\n      await runCommand(\n        `git commit -m \"${tag} - ${message} - after release preparation${ci ? \"\" : NoCIFLag}\"`\n      ).promise;\n    }\n    await runCommand(\n      `npm version \"${tag}\" -m \"${message}${ci ? \"\" : NoCIFLag}\"`\n    ).promise;\n    await runCommand(\"git push --follow-tags\").promise;\n    if (!ci) {\n      await runCommand(\"NPM_TOKEN=$(cat .npmtoken) npm publish --access public\")\n        .promise;\n    }\n  }\n}\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tag-release.js","sourceRoot":"","sources":["../../../../src/cli/commands/tag-release.ts"],"names":[],"mappings":"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","sourcesContent":["import { runCommand } from \"../../utils/utils\";\nimport { NoCIFLag, SemVersion, SemVersionRegex } from \"../../utils/constants\";\nimport { UserInput } from \"../../input/input\";\nimport { Command } from \"../command\";\nimport { LoggingConfig } from \"../../output\";\nimport { DefaultCommandValues } from \"../index\";\n\nconst options = {\n  ci: {\n    type: \"boolean\",\n    default: true,\n  },\n  message: {\n    type: \"string\",\n    short: \"m\",\n  },\n  tag: {\n    type: \"string\",\n    short: \"t\",\n    default: undefined,\n  },\n};\n\n/**\n * @class ReleaseScript\n * @extends {Command}\n * @cavegory scripts\n * @description A command-line script for managing releases and version updates.\n * @summary This script automates the process of creating and pushing new releases. It handles version updates,\n * commit messages, and optionally publishes to NPM. The script supports semantic versioning and can work in both CI and non-CI environments.\n *\n * @param {Object} options - Configuration options for the script\n * @param {boolean} options.ci - Whether the script is running in a CI environment (default: true)\n * @param {string} options.message - The release message (short: 'm')\n * @param {string} options.tag - The version tag to use (short: 't', default: undefined)\n */\nexport class ReleaseScript extends Command<typeof options, void> {\n  constructor() {\n    super(\"ReleaseScript\", options);\n  }\n\n  /**\n   * @description Prepares the version for the release.\n   * @summary This method validates the provided tag or prompts the user for a new one if not provided or invalid.\n   * It also displays the latest git tags for reference.\n   * @param {string} tag - The version tag to prepare\n   * @returns {Promise<string>} The prepared version tag\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant T as TestVersion\n   *   participant U as UserInput\n   *   participant G as Git\n   *   R->>T: testVersion(tag)\n   *   alt tag is valid\n   *     T-->>R: return tag\n   *   else tag is invalid or not provided\n   *     R->>G: List latest git tags\n   *     R->>U: Prompt for new tag\n   *     U-->>R: return new tag\n   *   end\n   */\n  async prepareVersion(tag?: string): Promise<string> {\n    const log = this.log.for(this.prepareVersion);\n    tag = this.testVersion((tag as string) || \"\");\n    if (!tag) {\n      log.verbose(\"No release message provided. Prompting for one:\");\n      log.info(`Listing latest git tags:`);\n      await runCommand(\"git tag --sort=-taggerdate | head -n 5\").promise;\n      return await UserInput.insistForText(\n        \"tag\",\n        \"Enter the new tag number (accepts v*.*.*[-...])\",\n        (val) =>\n          !!val.toString().match(/^v[0-9]+\\.[0-9]+.[0-9]+(-[0-9a-zA-Z-]+)?$/)\n      );\n    }\n    return tag;\n  }\n\n  /**\n   * @description Tests if the provided version is valid.\n   * @summary This method checks if the version is a valid semantic version or a predefined update type (PATCH, MINOR, MAJOR).\n   * @param {string} version - The version to test\n   * @returns {string | undefined} The validated version or undefined if invalid\n   */\n  testVersion(version: string): string | undefined {\n    const log = this.log.for(this.testVersion);\n    version = version.trim().toLowerCase();\n    switch (version) {\n      case SemVersion.PATCH:\n      case SemVersion.MINOR:\n      case SemVersion.MAJOR:\n        log.verbose(`Using provided SemVer update: ${version}`, 1);\n        return version;\n      default:\n        log.verbose(\n          `Testing provided version for SemVer compatibility: ${version}`,\n          1\n        );\n        if (!new RegExp(SemVersionRegex).test(version)) {\n          log.debug(`Invalid version number: ${version}`);\n          return undefined;\n        }\n        log.verbose(`version approved: ${version}`, 1);\n        return version;\n    }\n  }\n\n  /**\n   * @description Prepares the release message.\n   * @summary This method either returns the provided message or prompts the user for a new one if not provided.\n   * @param {string} [message] - The release message\n   * @returns {Promise<string>} The prepared release message\n   */\n  async prepareMessage(message?: string) {\n    const log = this.log.for(this.prepareMessage);\n    if (!message) {\n      log.verbose(\"No release message provided. Prompting for one\");\n      return await UserInput.insistForText(\n        \"message\",\n        \"What should be the release message/ticket?\",\n        (val) => !!val && val.toString().length > 5\n      );\n    }\n    return message;\n  }\n\n  /**\n   * @description Runs the release script.\n   * @summary This method orchestrates the entire release process, including version preparation, message creation,\n   * git operations, and npm publishing (if not in CI environment).\n   * @param {ParseArgsResult} args - The parsed command-line arguments\n   * @returns {Promise<void>}\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant R as ReleaseScript\n   *   participant V as PrepareVersion\n   *   participant M as PrepareMessage\n   *   participant N as NPM\n   *   participant G as Git\n   *   participant U as UserInput\n   *   R->>V: prepareVersion(tag)\n   *   R->>M: prepareMessage(message)\n   *   R->>N: Run prepare-release script\n   *   R->>G: Check git status\n   *   alt changes exist\n   *     R->>U: Ask for confirmation\n   *     U-->>R: Confirm\n   *     R->>G: Add and commit changes\n   *   end\n   *   R->>N: Update npm version\n   *   R->>G: Push changes and tags\n   *   alt not CI environment\n   *     R->>N: Publish to npm\n   *   end\n   */\n  async run(\n    args: LoggingConfig &\n      typeof DefaultCommandValues & { [k in keyof typeof options]: unknown }\n  ): Promise<void> {\n    let result: any;\n    const { ci } = args;\n    let { tag, message } = args;\n    tag = await this.prepareVersion(tag as string);\n    message = await this.prepareMessage(message as string);\n    result = await runCommand(`npm run prepare-release -- ${tag} ${message}`, {\n      cwd: process.cwd(),\n    }).promise;\n    result = await runCommand(\"git status --porcelain\").promise;\n    await result;\n    if (\n      result.logs.length &&\n      (await UserInput.askConfirmation(\n        \"git-changes\",\n        \"Do you want to push the changes to the remote repository?\",\n        true\n      ))\n    ) {\n      await runCommand(\"git add .\").promise;\n      await runCommand(\n        `git commit -m \"${tag} - ${message} - after release preparation${ci ? \"\" : NoCIFLag}\"`\n      ).promise;\n    }\n    await runCommand(\n      `npm version \"${tag}\" -m \"${message}${ci ? \"\" : NoCIFLag}\"`\n    ).promise;\n    await runCommand(\"git push --follow-tags\").promise;\n    if (!ci) {\n      await runCommand(\"NPM_TOKEN=$(cat .npmtoken) npm publish --access public\")\n        .promise;\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
import { Command } from "../command";
|
|
2
|
+
import { CommandOptions } from "../types";
|
|
3
|
+
import { LoggingConfig } from "../../output";
|
|
4
|
+
import { DefaultCommandValues } from "../index";
|
|
5
|
+
declare const options: {
|
|
6
|
+
templates: string[];
|
|
7
|
+
workflows: string[];
|
|
8
|
+
ide: string[];
|
|
9
|
+
docs: string[];
|
|
10
|
+
styles: string[];
|
|
11
|
+
scripts: string[];
|
|
12
|
+
tests: string[];
|
|
13
|
+
typescript: string[];
|
|
14
|
+
docker: string[];
|
|
15
|
+
automation: string[];
|
|
16
|
+
};
|
|
17
|
+
declare const argzz: {
|
|
18
|
+
boot: {
|
|
19
|
+
type: string;
|
|
20
|
+
};
|
|
21
|
+
org: {
|
|
22
|
+
type: string;
|
|
23
|
+
short: string;
|
|
24
|
+
};
|
|
25
|
+
name: {
|
|
26
|
+
type: string;
|
|
27
|
+
short: string;
|
|
28
|
+
default: undefined;
|
|
29
|
+
};
|
|
30
|
+
author: {
|
|
31
|
+
type: string;
|
|
32
|
+
short: string;
|
|
33
|
+
default: undefined;
|
|
34
|
+
};
|
|
35
|
+
all: {
|
|
36
|
+
type: string;
|
|
37
|
+
};
|
|
38
|
+
license: {
|
|
39
|
+
type: string;
|
|
40
|
+
message: string;
|
|
41
|
+
};
|
|
42
|
+
scripts: {
|
|
43
|
+
type: string;
|
|
44
|
+
};
|
|
45
|
+
styles: {
|
|
46
|
+
type: string;
|
|
47
|
+
};
|
|
48
|
+
docs: {
|
|
49
|
+
type: string;
|
|
50
|
+
};
|
|
51
|
+
ide: {
|
|
52
|
+
type: string;
|
|
53
|
+
};
|
|
54
|
+
workflows: {
|
|
55
|
+
type: string;
|
|
56
|
+
};
|
|
57
|
+
templates: {
|
|
58
|
+
type: string;
|
|
59
|
+
};
|
|
60
|
+
typescript: {
|
|
61
|
+
type: string;
|
|
62
|
+
};
|
|
63
|
+
docker: {
|
|
64
|
+
type: string;
|
|
65
|
+
};
|
|
66
|
+
pkg: {
|
|
67
|
+
type: string;
|
|
68
|
+
};
|
|
69
|
+
dependencies: {
|
|
70
|
+
type: string;
|
|
71
|
+
};
|
|
72
|
+
tests: {
|
|
73
|
+
type: string;
|
|
74
|
+
};
|
|
75
|
+
automation: {
|
|
76
|
+
type: string;
|
|
77
|
+
};
|
|
78
|
+
};
|
|
79
|
+
/**
|
|
80
|
+
* @class TemplateSync
|
|
81
|
+
* @extends {Command}
|
|
82
|
+
* @category scripts
|
|
83
|
+
* @description A command-line tool for synchronizing project templates and configurations.
|
|
84
|
+
* @summary This class provides functionality to download and update various project files and configurations from a remote repository.
|
|
85
|
+
* It supports updating licenses, IDE configurations, scripts, styles, documentation, workflows, and templates.
|
|
86
|
+
*
|
|
87
|
+
* @param {CommandOptions} args - The command options for TemplateSync
|
|
88
|
+
*/
|
|
89
|
+
export declare class TemplateSync extends Command<CommandOptions<typeof argzz>, void> {
|
|
90
|
+
private replacements;
|
|
91
|
+
constructor();
|
|
92
|
+
private loadValuesFromPackage;
|
|
93
|
+
/**
|
|
94
|
+
* @description Downloads files for a specific option category.
|
|
95
|
+
* @summary This method downloads all files associated with a given option key from the remote repository.
|
|
96
|
+
* @param {string} key - The key representing the option category to download
|
|
97
|
+
* @returns {Promise<void>}
|
|
98
|
+
* @throws {Error} If the specified option key is not found
|
|
99
|
+
*/
|
|
100
|
+
downloadOption(key: keyof typeof options): Promise<void>;
|
|
101
|
+
/**
|
|
102
|
+
* @description Downloads and sets up the specified license.
|
|
103
|
+
* @summary This method downloads the chosen license file, saves it to the project, and updates the package.json license field.
|
|
104
|
+
* @param {"MIT" | "GPL" | "Apache" | "LGPL" | "AGPL"} license - The license to download and set up
|
|
105
|
+
* @returns {Promise<void>}
|
|
106
|
+
*/
|
|
107
|
+
getLicense(license: "MIT" | "GPL" | "Apache" | "LGPL" | "AGPL"): Promise<void>;
|
|
108
|
+
/**
|
|
109
|
+
* @description Downloads IDE configuration files.
|
|
110
|
+
* @returns {Promise<void>}
|
|
111
|
+
*/
|
|
112
|
+
getIde(): Promise<void>;
|
|
113
|
+
/**
|
|
114
|
+
* @description Update npm scripts
|
|
115
|
+
* @returns {Promise<void>}
|
|
116
|
+
*/
|
|
117
|
+
getScripts(): Promise<void>;
|
|
118
|
+
/**
|
|
119
|
+
* @description Downloads style configuration files.
|
|
120
|
+
* @returns {Promise<void>}
|
|
121
|
+
*/
|
|
122
|
+
getStyles: () => Promise<void>;
|
|
123
|
+
/**
|
|
124
|
+
* @description Downloads template files.
|
|
125
|
+
* @returns {Promise<void>}
|
|
126
|
+
*/
|
|
127
|
+
getTemplates: () => Promise<void>;
|
|
128
|
+
/**
|
|
129
|
+
* @description Downloads workflow configuration files.
|
|
130
|
+
* @returns {Promise<void>}
|
|
131
|
+
*/
|
|
132
|
+
getWorkflows: () => Promise<void>;
|
|
133
|
+
/**
|
|
134
|
+
* @description Downloads documentation files.
|
|
135
|
+
* @returns {Promise<void>}
|
|
136
|
+
*/
|
|
137
|
+
getDocs: () => Promise<void>;
|
|
138
|
+
/**
|
|
139
|
+
* @description Downloads typescript config files.
|
|
140
|
+
* @returns {Promise<void>}
|
|
141
|
+
*/
|
|
142
|
+
getTypescript: () => Promise<void>;
|
|
143
|
+
/**
|
|
144
|
+
* @description Downloads automation documentation files.
|
|
145
|
+
* @returns {Promise<void>}
|
|
146
|
+
*/
|
|
147
|
+
getAutomation: () => Promise<void>;
|
|
148
|
+
/**
|
|
149
|
+
* @description Downloads automation documentation files.
|
|
150
|
+
* @returns {Promise<void>}
|
|
151
|
+
*/
|
|
152
|
+
getTests: () => Promise<void>;
|
|
153
|
+
/**
|
|
154
|
+
* @description Downloads docker image files.
|
|
155
|
+
* @returns {Promise<void>}
|
|
156
|
+
*/
|
|
157
|
+
getDocker: () => Promise<void>;
|
|
158
|
+
initPackage(pkgName: string, author: string, license: string): Promise<void>;
|
|
159
|
+
updatePackageScrips(): Promise<void>;
|
|
160
|
+
createTokenFiles(): Promise<void>;
|
|
161
|
+
getOrg(): Promise<string>;
|
|
162
|
+
auditFix(): Promise<string>;
|
|
163
|
+
patchFiles(): void;
|
|
164
|
+
updateDependencies(): Promise<void>;
|
|
165
|
+
/**
|
|
166
|
+
* @description Runs the template synchronization process.
|
|
167
|
+
* @summary This method orchestrates the downloading of various project components based on the provided arguments.
|
|
168
|
+
* @param {ParseArgsResult} args - The parsed command-line arguments
|
|
169
|
+
* @returns {Promise<void>}
|
|
170
|
+
*
|
|
171
|
+
* @mermaid
|
|
172
|
+
* sequenceDiagram
|
|
173
|
+
* participant T as TemplateSync
|
|
174
|
+
* participant L as getLicense
|
|
175
|
+
* participant I as getIde
|
|
176
|
+
* participant S as getScripts
|
|
177
|
+
* participant St as getStyles
|
|
178
|
+
* participant D as getDocs
|
|
179
|
+
* participant W as getWorkflows
|
|
180
|
+
* participant Te as getTemplates
|
|
181
|
+
* T->>T: Parse arguments
|
|
182
|
+
* alt all flag is true
|
|
183
|
+
* T->>T: Set all component flags to true
|
|
184
|
+
* end
|
|
185
|
+
* alt license is specified
|
|
186
|
+
* T->>L: getLicense(license)
|
|
187
|
+
* end
|
|
188
|
+
* alt ide flag is true
|
|
189
|
+
* T->>I: getIde()
|
|
190
|
+
* end
|
|
191
|
+
* alt scripts flag is true
|
|
192
|
+
* T->>S: getScripts()
|
|
193
|
+
* end
|
|
194
|
+
* alt styles flag is true
|
|
195
|
+
* T->>St: getStyles()
|
|
196
|
+
* end
|
|
197
|
+
* alt docs flag is true
|
|
198
|
+
* T->>D: getDocs()
|
|
199
|
+
* end
|
|
200
|
+
* alt workflows flag is true
|
|
201
|
+
* T->>W: getWorkflows()
|
|
202
|
+
* end
|
|
203
|
+
* alt templates flag is true
|
|
204
|
+
* T->>Te: getTemplates()
|
|
205
|
+
* end
|
|
206
|
+
*/
|
|
207
|
+
run(args: LoggingConfig & typeof DefaultCommandValues & {
|
|
208
|
+
[k in keyof typeof argzz]: unknown;
|
|
209
|
+
}): Promise<void>;
|
|
210
|
+
}
|
|
211
|
+
export {};
|
|
@@ -45,7 +45,11 @@ const options = {
|
|
|
45
45
|
"workdocs/readme-md.json",
|
|
46
46
|
],
|
|
47
47
|
styles: [".prettierrc", "eslint.config.js"],
|
|
48
|
-
scripts: [
|
|
48
|
+
scripts: [
|
|
49
|
+
"bin/update-scripts.cjs",
|
|
50
|
+
"bin/tag-release.cjs",
|
|
51
|
+
"bin/build-scripts.cjs",
|
|
52
|
+
],
|
|
49
53
|
tests: ["jest.config.ts", "workdocs/reports/jest.coverage.config.ts"],
|
|
50
54
|
typescript: ["tsconfig.json"],
|
|
51
55
|
docker: ["Dockerfile"],
|
|
@@ -500,5 +504,4 @@ export class TemplateSync extends Command {
|
|
|
500
504
|
await this.updateDependencies();
|
|
501
505
|
}
|
|
502
506
|
}
|
|
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"]}
|
|
507
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"update-scripts.js","sourceRoot":"","sources":["../../../../src/cli/commands/update-scripts.ts"],"names":[],"mappings":"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","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: [\n    \"bin/update-scripts.cjs\",\n    \"bin/tag-release.cjs\",\n    \"bin/build-scripts.cjs\",\n  ],\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"]}
|