@strapi/upgrade 0.0.0-experimental.e3e48deb89bd0a1b6cc69b698696566fa7854a95 → 0.0.0-experimental.e576af447d9f97e89e24c6daa32d8f714376cd5f

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (101) hide show
  1. package/LICENSE +19 -4
  2. package/README.md +1 -1
  3. package/dist/chunks/logger-DGi224NW.js +1649 -0
  4. package/dist/chunks/logger-DGi224NW.js.map +1 -0
  5. package/dist/chunks/logger-np_r7rTc.mjs +1599 -0
  6. package/dist/chunks/logger-np_r7rTc.mjs.map +1 -0
  7. package/dist/cli.js +212 -6
  8. package/dist/cli.js.map +1 -1
  9. package/dist/cli.mjs +211 -0
  10. package/dist/cli.mjs.map +1 -0
  11. package/dist/index.js +133 -1172
  12. package/dist/index.js.map +1 -1
  13. package/dist/index.mjs +131 -1165
  14. package/dist/index.mjs.map +1 -1
  15. package/dist/modules/codemod/codemod.d.ts +4 -2
  16. package/dist/modules/codemod/codemod.d.ts.map +1 -1
  17. package/dist/modules/codemod/types.d.ts +8 -1
  18. package/dist/modules/codemod/types.d.ts.map +1 -1
  19. package/dist/modules/codemod-repository/repository.d.ts +6 -5
  20. package/dist/modules/codemod-repository/repository.d.ts.map +1 -1
  21. package/dist/modules/codemod-repository/types.d.ts +7 -3
  22. package/dist/modules/codemod-repository/types.d.ts.map +1 -1
  23. package/dist/modules/codemod-runner/codemod-runner.d.ts +3 -0
  24. package/dist/modules/codemod-runner/codemod-runner.d.ts.map +1 -1
  25. package/dist/modules/codemod-runner/index.d.ts +1 -0
  26. package/dist/modules/codemod-runner/index.d.ts.map +1 -1
  27. package/dist/modules/codemod-runner/types.d.ts +1 -0
  28. package/dist/modules/codemod-runner/types.d.ts.map +1 -1
  29. package/dist/modules/error/utils.d.ts +8 -0
  30. package/dist/modules/error/utils.d.ts.map +1 -1
  31. package/dist/modules/file-scanner/scanner.d.ts.map +1 -1
  32. package/dist/modules/format/formats.d.ts +6 -0
  33. package/dist/modules/format/formats.d.ts.map +1 -1
  34. package/dist/modules/project/constants.d.ts +6 -3
  35. package/dist/modules/project/constants.d.ts.map +1 -1
  36. package/dist/modules/project/index.d.ts +2 -0
  37. package/dist/modules/project/index.d.ts.map +1 -1
  38. package/dist/modules/project/project.d.ts +27 -5
  39. package/dist/modules/project/project.d.ts.map +1 -1
  40. package/dist/modules/project/types.d.ts +3 -10
  41. package/dist/modules/project/types.d.ts.map +1 -1
  42. package/dist/modules/project/utils.d.ts +6 -0
  43. package/dist/modules/project/utils.d.ts.map +1 -0
  44. package/dist/modules/report/report.d.ts.map +1 -1
  45. package/dist/modules/requirement/types.d.ts +2 -2
  46. package/dist/modules/requirement/types.d.ts.map +1 -1
  47. package/dist/modules/runner/json/transform.d.ts.map +1 -1
  48. package/dist/modules/upgrader/types.d.ts +6 -0
  49. package/dist/modules/upgrader/types.d.ts.map +1 -1
  50. package/dist/modules/upgrader/upgrader.d.ts +7 -3
  51. package/dist/modules/upgrader/upgrader.d.ts.map +1 -1
  52. package/dist/modules/version/range.d.ts +2 -0
  53. package/dist/modules/version/range.d.ts.map +1 -1
  54. package/dist/modules/version/types.d.ts +2 -1
  55. package/dist/modules/version/types.d.ts.map +1 -1
  56. package/dist/tasks/codemods/index.d.ts +2 -1
  57. package/dist/tasks/codemods/index.d.ts.map +1 -1
  58. package/dist/tasks/codemods/list-codemods.d.ts +3 -0
  59. package/dist/tasks/codemods/list-codemods.d.ts.map +1 -0
  60. package/dist/tasks/codemods/run-codemods.d.ts +3 -0
  61. package/dist/tasks/codemods/run-codemods.d.ts.map +1 -0
  62. package/dist/tasks/codemods/types.d.ts +9 -3
  63. package/dist/tasks/codemods/types.d.ts.map +1 -1
  64. package/dist/tasks/codemods/utils.d.ts +6 -0
  65. package/dist/tasks/codemods/utils.d.ts.map +1 -0
  66. package/dist/tasks/index.d.ts +1 -1
  67. package/dist/tasks/index.d.ts.map +1 -1
  68. package/dist/tasks/upgrade/prompts/index.d.ts +2 -0
  69. package/dist/tasks/upgrade/prompts/index.d.ts.map +1 -0
  70. package/dist/tasks/upgrade/prompts/latest.d.ts +9 -0
  71. package/dist/tasks/upgrade/prompts/latest.d.ts.map +1 -0
  72. package/dist/tasks/upgrade/requirements/major.d.ts.map +1 -1
  73. package/dist/tasks/upgrade/upgrade.d.ts.map +1 -1
  74. package/package.json +16 -15
  75. package/resources/codemods/5.0.0/comment-out-lifecycle-files.code.ts +63 -0
  76. package/resources/codemods/5.0.0/dependency-remove-strapi-plugin-i18n.json.ts +31 -0
  77. package/resources/codemods/5.0.0/dependency-upgrade-react-and-react-dom.json.ts +67 -0
  78. package/resources/codemods/5.0.0/dependency-upgrade-react-router-dom.json.ts +59 -0
  79. package/resources/codemods/5.0.0/dependency-upgrade-styled-components.json.ts +49 -0
  80. package/resources/codemods/5.0.0/deprecate-helper-plugin.code.ts +192 -0
  81. package/resources/codemods/5.0.0/entity-service-document-service.code.ts +437 -0
  82. package/resources/codemods/5.0.0/s3-keys-wrapped-in-credentials.code.ts +1 -1
  83. package/resources/codemods/5.0.0/sqlite3-to-better-sqlite3.json.ts +5 -3
  84. package/resources/codemods/5.0.0/strapi-public-interface.code.ts +126 -0
  85. package/resources/codemods/5.0.0/use-uid-for-config-namespace.code.ts +1 -1
  86. package/resources/codemods/5.0.0/utils-public-interface.code.ts +320 -0
  87. package/resources/codemods/5.1.0/dependency-better-sqlite3.json.ts +48 -0
  88. package/resources/examples/console.log-to-console.info.code.ts +1 -1
  89. package/resources/examples/disable-jsx-buttons.code.ts +42 -0
  90. package/resources/utils/change-import.ts +118 -0
  91. package/resources/utils/replace-jsx.ts +49 -0
  92. package/dist/_chunks/codemod-runner-B5OeSMTQ.js +0 -730
  93. package/dist/_chunks/codemod-runner-B5OeSMTQ.js.map +0 -1
  94. package/dist/_chunks/codemods-10ZKewQx.js +0 -108
  95. package/dist/_chunks/codemods-10ZKewQx.js.map +0 -1
  96. package/dist/_chunks/index-uxCwtuH1.js +0 -103
  97. package/dist/_chunks/index-uxCwtuH1.js.map +0 -1
  98. package/dist/_chunks/upgrade-A4T1OWs5.js +0 -357
  99. package/dist/_chunks/upgrade-A4T1OWs5.js.map +0 -1
  100. package/dist/tasks/codemods/codemods.d.ts +0 -3
  101. package/dist/tasks/codemods/codemods.d.ts.map +0 -1
package/dist/cli.mjs ADDED
@@ -0,0 +1,211 @@
1
+ import os from 'os';
2
+ import chalk from 'chalk';
3
+ import { Option, InvalidArgumentError, program } from 'commander';
4
+ import prompts from 'prompts';
5
+ import { I as AbortedError, q as isValidStringifiedRange, s as rangeFactory, X as ReleaseType, k as isLiteralSemVer, y as semVerFactory, o as isValidSemVer, W as loggerFactory, V as upgrade$1, T as runCodemods$1, S as listCodemods$1 } from './chunks/logger-np_r7rTc.mjs';
6
+ import 'semver';
7
+ import 'cli-table3';
8
+ import 'node:path';
9
+ import 'node:assert';
10
+ import 'fs-extra';
11
+ import 'fast-glob';
12
+ import 'jscodeshift/src/Runner';
13
+ import 'lodash/fp';
14
+ import 'esbuild-register/dist/node';
15
+ import '@strapi/utils';
16
+ import 'simple-git';
17
+
18
+ const handleError = (err, isSilent)=>{
19
+ // If the upgrade process has been aborted, exit silently
20
+ if (err instanceof AbortedError) {
21
+ process.exit(0);
22
+ }
23
+ if (!isSilent) {
24
+ console.error(chalk.red(`[ERROR]\t[${new Date().toISOString()}]`), err instanceof Error ? err.message : err);
25
+ }
26
+ process.exit(1);
27
+ };
28
+
29
+ const projectPathOption = new Option('-p, --project-path <project-path>', 'Root path to the Strapi application or plugin');
30
+ const dryOption = new Option('-n, --dry', 'Simulate the upgrade without updating any files').default(false);
31
+ const debugOption = new Option('-d, --debug', 'Get more logs in debug mode').default(false);
32
+ const silentOption = new Option('-s, --silent', "Don't log anything").default(false);
33
+ const autoConfirmOption = new Option('-y, --yes', 'Automatically answer "yes" to any prompts that the CLI might print on the command line.').default(false);
34
+ const rangeOption = new Option('-r, --range <range>', 'Use a custom semver range for the codemods execution.').argParser((range)=>{
35
+ if (!isValidStringifiedRange(range)) {
36
+ throw new InvalidArgumentError('Expected a valid semver range');
37
+ }
38
+ return rangeFactory(range);
39
+ });
40
+
41
+ const upgrade = async (options)=>{
42
+ try {
43
+ const { silent, debug, yes } = options;
44
+ const logger = loggerFactory({
45
+ silent,
46
+ debug
47
+ });
48
+ logger.warn("Please make sure you've created a backup of your codebase and files before upgrading");
49
+ const confirm = async (message)=>{
50
+ if (yes) {
51
+ return true;
52
+ }
53
+ const { confirm } = await prompts({
54
+ name: 'confirm',
55
+ type: 'confirm',
56
+ message
57
+ });
58
+ // If confirm is undefined (Ctrl + C), default to false
59
+ return confirm ?? false;
60
+ };
61
+ await upgrade$1({
62
+ logger,
63
+ confirm,
64
+ dry: options.dry,
65
+ cwd: options.projectPath,
66
+ target: options.target,
67
+ codemodsTarget: options.codemodsTarget
68
+ });
69
+ } catch (err) {
70
+ handleError(err, options.silent);
71
+ }
72
+ };
73
+ /**
74
+ * Registers upgrade related codemods.
75
+ */ const register$1 = (program)=>{
76
+ const addReleaseUpgradeCommand = (releaseType, description)=>{
77
+ program.command(releaseType).description(description).addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).addOption(autoConfirmOption).action(async (options)=>{
78
+ return upgrade({
79
+ ...options,
80
+ target: releaseType
81
+ });
82
+ });
83
+ };
84
+ // upgrade latest
85
+ addReleaseUpgradeCommand(ReleaseType.Latest, 'Upgrade to the latest available version of Strapi');
86
+ // upgrade major
87
+ addReleaseUpgradeCommand(ReleaseType.Major, 'Upgrade to the next available major version of Strapi');
88
+ // upgrade minor
89
+ addReleaseUpgradeCommand(ReleaseType.Minor, 'Upgrade to the latest minor and patch version of Strapi for the current major');
90
+ // upgrade patch
91
+ addReleaseUpgradeCommand(ReleaseType.Patch, 'Upgrade to latest patch version of Strapi for the current major and minor');
92
+ // upgrade to <target>
93
+ program.command('to <target>', {
94
+ hidden: true
95
+ }).description('Upgrade to the specified version of Strapi').addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).addOption(autoConfirmOption).addOption(new Option('-c, --codemods-target <codemodsTarget>', 'Use a custom target for the codemods execution. Useful when targeting pre-releases').argParser((codemodsTarget)=>{
96
+ if (!isLiteralSemVer(codemodsTarget)) {
97
+ throw new InvalidArgumentError(`Expected a version with the following format: "<number>.<number>.<number>"`);
98
+ }
99
+ return semVerFactory(codemodsTarget);
100
+ })).action(async (target, options)=>{
101
+ if (!isValidSemVer(target)) {
102
+ console.error(`Invalid target supplied, expected a valid semver but got "${target}"`);
103
+ process.exit(1);
104
+ }
105
+ return upgrade({
106
+ ...options,
107
+ target: semVerFactory(target)
108
+ });
109
+ });
110
+ };
111
+
112
+ const DEFAULT_TARGET = ReleaseType.Major;
113
+ const runCodemods = async (options)=>{
114
+ const { silent, debug } = options;
115
+ const logger = loggerFactory({
116
+ silent,
117
+ debug
118
+ });
119
+ logger.warn("Please make sure you've created a backup of your codebase and files before running the codemods");
120
+ const confirm = async (message)=>{
121
+ const { confirm } = await prompts({
122
+ name: 'confirm',
123
+ type: 'confirm',
124
+ message
125
+ });
126
+ // If confirm is undefined (Ctrl + C), default to false
127
+ return confirm ?? false;
128
+ };
129
+ const selectCodemods = async (codemods)=>{
130
+ const selectableCodemods = codemods.map(({ version, codemods })=>codemods.map((codemod)=>({
131
+ title: `(${version}) ${codemod.format()}`,
132
+ value: codemod,
133
+ selected: true
134
+ }))).flat();
135
+ if (selectableCodemods.length === 0) {
136
+ logger.info('No codemods to run');
137
+ return [];
138
+ }
139
+ const { selectedCodemods } = await prompts({
140
+ type: 'autocompleteMultiselect',
141
+ name: 'selectedCodemods',
142
+ message: 'Choose the codemods you would like to run:',
143
+ choices: selectableCodemods
144
+ });
145
+ if (!selectedCodemods || selectedCodemods.length === 0) {
146
+ logger.info('No codemods selected');
147
+ return [];
148
+ }
149
+ return selectedCodemods.map((codemod)=>({
150
+ version: codemod.version,
151
+ codemods: [
152
+ codemod
153
+ ]
154
+ }));
155
+ };
156
+ return runCodemods$1({
157
+ logger,
158
+ confirm,
159
+ selectCodemods,
160
+ dry: options.dry,
161
+ cwd: options.projectPath,
162
+ target: options.range ?? DEFAULT_TARGET,
163
+ uid: options.uid
164
+ }).catch((err)=>handleError(err, options.silent));
165
+ };
166
+ const listCodemods = async (options)=>{
167
+ const { silent, debug } = options;
168
+ const logger = loggerFactory({
169
+ silent,
170
+ debug
171
+ });
172
+ return listCodemods$1({
173
+ cwd: options.projectPath,
174
+ target: options.range ?? DEFAULT_TARGET,
175
+ logger
176
+ }).catch((err)=>handleError(err, options.silent));
177
+ };
178
+ /**
179
+ * Registers codemods related commands.
180
+ */ const register = (program)=>{
181
+ const codemodsCommand = program.command('codemods');
182
+ // upgrade codemods run [options] [uid]
183
+ codemodsCommand.command('run [uid]').description(`
184
+ Executes a set of codemods on the current project.
185
+
186
+ If the optional UID argument is provided, the command specifically runs the codemod associated with that UID.
187
+ Without the UID, the command produces a list of all available codemods for your project.
188
+
189
+ By default, when executed on a Strapi application project, it offers codemods matching the current major version of the app.
190
+ When executed on a Strapi plugin project, it shows every codemods.
191
+ `).addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).addOption(rangeOption).action(async (uid, options)=>{
192
+ return runCodemods({
193
+ ...options,
194
+ uid
195
+ });
196
+ });
197
+ // upgrade codemods ls [options]
198
+ codemodsCommand.command('ls').description(`List available codemods`).addOption(projectPathOption).addOption(debugOption).addOption(silentOption).addOption(rangeOption).action(async (options)=>{
199
+ return listCodemods(options);
200
+ });
201
+ };
202
+
203
+ var version = "0.0.0-experimental.e576af447d9f97e89e24c6daa32d8f714376cd5f";
204
+
205
+ register$1(program);
206
+ register(program);
207
+ program.usage('<command> [options]').on('command:*', ([invalidCmd])=>{
208
+ console.error(chalk.red(`[ERROR] Invalid command: ${invalidCmd}.${os.EOL} See --help for a list of available commands.`));
209
+ process.exit(1);
210
+ }).helpOption('-h, --help', 'Print command line options').addHelpCommand('help [command]', 'Print options for a specific command').version(version).parse(process.argv);
211
+ //# sourceMappingURL=cli.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.mjs","sources":["../src/cli/errors.ts","../src/cli/options.ts","../src/cli/commands/upgrade.ts","../src/cli/commands/codemods.ts","../src/cli/index.ts"],"sourcesContent":["import chalk from 'chalk';\n\nimport { AbortedError } from '../modules/error';\n\nexport const handleError = (err: unknown, isSilent: boolean) => {\n // If the upgrade process has been aborted, exit silently\n if (err instanceof AbortedError) {\n process.exit(0);\n }\n\n if (!isSilent) {\n console.error(\n chalk.red(`[ERROR]\\t[${new Date().toISOString()}]`),\n err instanceof Error ? err.message : err\n );\n }\n\n process.exit(1);\n};\n","import { InvalidArgumentError, Option } from 'commander';\nimport { isValidStringifiedRange, rangeFactory } from '../modules/version';\n\nexport const projectPathOption = new Option(\n '-p, --project-path <project-path>',\n 'Root path to the Strapi application or plugin'\n);\n\nexport const dryOption = new Option(\n '-n, --dry',\n 'Simulate the upgrade without updating any files'\n).default(false);\n\nexport const debugOption = new Option('-d, --debug', 'Get more logs in debug mode').default(false);\n\nexport const silentOption = new Option('-s, --silent', \"Don't log anything\").default(false);\n\nexport const autoConfirmOption = new Option(\n '-y, --yes',\n 'Automatically answer \"yes\" to any prompts that the CLI might print on the command line.'\n).default(false);\n\nexport const rangeOption = new Option(\n '-r, --range <range>',\n 'Use a custom semver range for the codemods execution.'\n).argParser((range) => {\n if (!isValidStringifiedRange(range)) {\n throw new InvalidArgumentError('Expected a valid semver range');\n }\n\n return rangeFactory(range);\n});\n","import prompts from 'prompts';\nimport { InvalidArgumentError, Option } from 'commander';\n\nimport type { Command } from 'commander';\n\nimport { loggerFactory } from '../../modules/logger';\nimport { Version, isLiteralSemVer, isValidSemVer, semVerFactory } from '../../modules/version';\nimport { handleError } from '../errors';\nimport * as tasks from '../../tasks';\nimport {\n autoConfirmOption,\n debugOption,\n dryOption,\n projectPathOption,\n silentOption,\n} from '../options';\n\nimport type { CLIUpgradeOptions, CLIUpgradeToOptions, UpgradeCommand } from '../types';\n\nexport const upgrade: UpgradeCommand = async (options) => {\n try {\n const { silent, debug, yes } = options;\n const logger = loggerFactory({ silent, debug });\n\n logger.warn(\n \"Please make sure you've created a backup of your codebase and files before upgrading\"\n );\n\n const confirm = async (message: string) => {\n if (yes) {\n return true;\n }\n\n const { confirm } = await prompts({\n name: 'confirm',\n type: 'confirm',\n message,\n });\n\n // If confirm is undefined (Ctrl + C), default to false\n return confirm ?? false;\n };\n\n await tasks.upgrade({\n logger,\n confirm,\n dry: options.dry,\n cwd: options.projectPath,\n target: options.target,\n codemodsTarget: options.codemodsTarget,\n });\n } catch (err) {\n handleError(err, options.silent);\n }\n};\n\n/**\n * Registers upgrade related codemods.\n */\nexport const register = (program: Command) => {\n const addReleaseUpgradeCommand = (releaseType: Version.ReleaseType, description: string) => {\n program\n .command(releaseType)\n .description(description)\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(autoConfirmOption)\n .action(async (options: CLIUpgradeOptions) => {\n return upgrade({ ...options, target: releaseType });\n });\n };\n\n // upgrade latest\n addReleaseUpgradeCommand(\n Version.ReleaseType.Latest,\n 'Upgrade to the latest available version of Strapi'\n );\n\n // upgrade major\n addReleaseUpgradeCommand(\n Version.ReleaseType.Major,\n 'Upgrade to the next available major version of Strapi'\n );\n\n // upgrade minor\n addReleaseUpgradeCommand(\n Version.ReleaseType.Minor,\n 'Upgrade to the latest minor and patch version of Strapi for the current major'\n );\n\n // upgrade patch\n addReleaseUpgradeCommand(\n Version.ReleaseType.Patch,\n 'Upgrade to latest patch version of Strapi for the current major and minor'\n );\n\n // upgrade to <target>\n program\n .command('to <target>', { hidden: true })\n .description('Upgrade to the specified version of Strapi')\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(autoConfirmOption)\n .addOption(\n new Option(\n '-c, --codemods-target <codemodsTarget>',\n 'Use a custom target for the codemods execution. Useful when targeting pre-releases'\n ).argParser((codemodsTarget) => {\n if (!isLiteralSemVer(codemodsTarget)) {\n throw new InvalidArgumentError(\n `Expected a version with the following format: \"<number>.<number>.<number>\"`\n );\n }\n\n return semVerFactory(codemodsTarget);\n })\n )\n .action(async (target: string, options: CLIUpgradeToOptions) => {\n if (!isValidSemVer(target)) {\n console.error(`Invalid target supplied, expected a valid semver but got \"${target}\"`);\n process.exit(1);\n }\n\n return upgrade({ ...options, target: semVerFactory(target) });\n });\n};\n","import prompts from 'prompts';\n\nimport type { Command } from 'commander';\nimport { loggerFactory } from '../../modules/logger';\nimport { Version } from '../../modules/version';\nimport { handleError } from '../errors';\nimport * as tasks from '../../tasks';\nimport { debugOption, dryOption, projectPathOption, rangeOption, silentOption } from '../options';\n\nimport type {\n CLIListCodemodsOptions,\n CLIRunCodemodsOptions,\n ListCodemodsCommand,\n RunCodemodsCommand,\n} from '../types';\nimport type { Codemod } from '../../modules/codemod';\n\nconst DEFAULT_TARGET = Version.ReleaseType.Major;\n\nexport const runCodemods: RunCodemodsCommand = async (options) => {\n const { silent, debug } = options;\n const logger = loggerFactory({ silent, debug });\n\n logger.warn(\n \"Please make sure you've created a backup of your codebase and files before running the codemods\"\n );\n\n const confirm = async (message: string) => {\n const { confirm } = await prompts({\n name: 'confirm',\n type: 'confirm',\n message,\n });\n\n // If confirm is undefined (Ctrl + C), default to false\n return confirm ?? false;\n };\n\n const selectCodemods = async (codemods: Codemod.VersionedCollection[]) => {\n const selectableCodemods = codemods\n .map(({ version, codemods }) =>\n codemods.map((codemod) => ({\n title: `(${version}) ${codemod.format()}`,\n value: codemod,\n selected: true,\n }))\n )\n .flat();\n\n if (selectableCodemods.length === 0) {\n logger.info('No codemods to run');\n return [];\n }\n\n const { selectedCodemods }: { selectedCodemods: Codemod.Codemod[] } = await prompts({\n type: 'autocompleteMultiselect',\n name: 'selectedCodemods',\n message: 'Choose the codemods you would like to run:',\n choices: selectableCodemods,\n });\n\n if (!selectedCodemods || selectedCodemods.length === 0) {\n logger.info('No codemods selected');\n return [];\n }\n\n return selectedCodemods.map<Codemod.VersionedCollection>((codemod) => ({\n version: codemod.version,\n codemods: [codemod],\n }));\n };\n\n return tasks\n .runCodemods({\n logger,\n confirm,\n selectCodemods,\n dry: options.dry,\n cwd: options.projectPath,\n target: options.range ?? DEFAULT_TARGET,\n uid: options.uid,\n })\n .catch((err) => handleError(err, options.silent));\n};\n\nexport const listCodemods: ListCodemodsCommand = async (options) => {\n const { silent, debug } = options;\n const logger = loggerFactory({ silent, debug });\n\n return tasks\n .listCodemods({\n cwd: options.projectPath,\n target: options.range ?? DEFAULT_TARGET,\n logger,\n })\n .catch((err) => handleError(err, options.silent));\n};\n\n/**\n * Registers codemods related commands.\n */\nexport const register = (program: Command) => {\n const codemodsCommand = program.command('codemods');\n\n // upgrade codemods run [options] [uid]\n codemodsCommand\n .command('run [uid]')\n .description(\n `\nExecutes a set of codemods on the current project.\n\nIf the optional UID argument is provided, the command specifically runs the codemod associated with that UID.\nWithout the UID, the command produces a list of all available codemods for your project.\n\nBy default, when executed on a Strapi application project, it offers codemods matching the current major version of the app.\nWhen executed on a Strapi plugin project, it shows every codemods.\n`\n )\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(rangeOption)\n .action(async (uid: string | undefined, options: CLIRunCodemodsOptions) => {\n return runCodemods({ ...options, uid });\n });\n\n // upgrade codemods ls [options]\n codemodsCommand\n .command('ls')\n .description(`List available codemods`)\n .addOption(projectPathOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(rangeOption)\n .action(async (options: CLIListCodemodsOptions) => {\n return listCodemods(options);\n });\n};\n","import os from 'os';\nimport chalk from 'chalk';\nimport { program } from 'commander';\n\nimport { register as registerUpgradeCommands } from './commands/upgrade';\nimport { register as registerCodemodsCommands } from './commands/codemods';\n\nimport { version as packageJSONVersion } from '../../package.json';\n\nregisterUpgradeCommands(program);\nregisterCodemodsCommands(program);\n\nprogram\n .usage('<command> [options]')\n .on('command:*', ([invalidCmd]) => {\n console.error(\n chalk.red(\n `[ERROR] Invalid command: ${invalidCmd}.${os.EOL} See --help for a list of available commands.`\n )\n );\n\n process.exit(1);\n })\n .helpOption('-h, --help', 'Print command line options')\n .addHelpCommand('help [command]', 'Print options for a specific command')\n .version(packageJSONVersion)\n .parse(process.argv);\n"],"names":["handleError","err","isSilent","AbortedError","process","exit","console","error","chalk","red","Date","toISOString","Error","message","projectPathOption","Option","dryOption","default","debugOption","silentOption","autoConfirmOption","rangeOption","argParser","range","isValidStringifiedRange","InvalidArgumentError","rangeFactory","upgrade","options","silent","debug","yes","logger","loggerFactory","warn","confirm","prompts","name","type","tasks","dry","cwd","projectPath","target","codemodsTarget","register","program","addReleaseUpgradeCommand","releaseType","description","command","addOption","action","Version","Latest","Major","Minor","Patch","hidden","isLiteralSemVer","semVerFactory","isValidSemVer","DEFAULT_TARGET","runCodemods","selectCodemods","codemods","selectableCodemods","map","version","codemod","title","format","value","selected","flat","length","info","selectedCodemods","choices","uid","catch","listCodemods","codemodsCommand","registerUpgradeCommands","registerCodemodsCommands","usage","on","invalidCmd","os","EOL","helpOption","addHelpCommand","packageJSONVersion","parse","argv"],"mappings":"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"}