@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.
- package/LICENSE +19 -4
- package/README.md +1 -1
- package/dist/chunks/logger-DGi224NW.js +1649 -0
- package/dist/chunks/logger-DGi224NW.js.map +1 -0
- package/dist/chunks/logger-np_r7rTc.mjs +1599 -0
- package/dist/chunks/logger-np_r7rTc.mjs.map +1 -0
- package/dist/cli.js +212 -6
- package/dist/cli.js.map +1 -1
- package/dist/cli.mjs +211 -0
- package/dist/cli.mjs.map +1 -0
- package/dist/index.js +133 -1172
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +131 -1165
- package/dist/index.mjs.map +1 -1
- package/dist/modules/codemod/codemod.d.ts +4 -2
- package/dist/modules/codemod/codemod.d.ts.map +1 -1
- package/dist/modules/codemod/types.d.ts +8 -1
- package/dist/modules/codemod/types.d.ts.map +1 -1
- package/dist/modules/codemod-repository/repository.d.ts +6 -5
- package/dist/modules/codemod-repository/repository.d.ts.map +1 -1
- package/dist/modules/codemod-repository/types.d.ts +7 -3
- package/dist/modules/codemod-repository/types.d.ts.map +1 -1
- package/dist/modules/codemod-runner/codemod-runner.d.ts +3 -0
- package/dist/modules/codemod-runner/codemod-runner.d.ts.map +1 -1
- package/dist/modules/codemod-runner/index.d.ts +1 -0
- package/dist/modules/codemod-runner/index.d.ts.map +1 -1
- package/dist/modules/codemod-runner/types.d.ts +1 -0
- package/dist/modules/codemod-runner/types.d.ts.map +1 -1
- package/dist/modules/error/utils.d.ts +8 -0
- package/dist/modules/error/utils.d.ts.map +1 -1
- package/dist/modules/file-scanner/scanner.d.ts.map +1 -1
- package/dist/modules/format/formats.d.ts +6 -0
- package/dist/modules/format/formats.d.ts.map +1 -1
- package/dist/modules/project/constants.d.ts +6 -3
- package/dist/modules/project/constants.d.ts.map +1 -1
- package/dist/modules/project/index.d.ts +2 -0
- package/dist/modules/project/index.d.ts.map +1 -1
- package/dist/modules/project/project.d.ts +27 -5
- package/dist/modules/project/project.d.ts.map +1 -1
- package/dist/modules/project/types.d.ts +3 -10
- package/dist/modules/project/types.d.ts.map +1 -1
- package/dist/modules/project/utils.d.ts +6 -0
- package/dist/modules/project/utils.d.ts.map +1 -0
- package/dist/modules/report/report.d.ts.map +1 -1
- package/dist/modules/requirement/types.d.ts +2 -2
- package/dist/modules/requirement/types.d.ts.map +1 -1
- package/dist/modules/runner/json/transform.d.ts.map +1 -1
- package/dist/modules/upgrader/types.d.ts +6 -0
- package/dist/modules/upgrader/types.d.ts.map +1 -1
- package/dist/modules/upgrader/upgrader.d.ts +7 -3
- package/dist/modules/upgrader/upgrader.d.ts.map +1 -1
- package/dist/modules/version/range.d.ts +2 -0
- package/dist/modules/version/range.d.ts.map +1 -1
- package/dist/modules/version/types.d.ts +2 -1
- package/dist/modules/version/types.d.ts.map +1 -1
- package/dist/tasks/codemods/index.d.ts +2 -1
- package/dist/tasks/codemods/index.d.ts.map +1 -1
- package/dist/tasks/codemods/list-codemods.d.ts +3 -0
- package/dist/tasks/codemods/list-codemods.d.ts.map +1 -0
- package/dist/tasks/codemods/run-codemods.d.ts +3 -0
- package/dist/tasks/codemods/run-codemods.d.ts.map +1 -0
- package/dist/tasks/codemods/types.d.ts +9 -3
- package/dist/tasks/codemods/types.d.ts.map +1 -1
- package/dist/tasks/codemods/utils.d.ts +6 -0
- package/dist/tasks/codemods/utils.d.ts.map +1 -0
- package/dist/tasks/index.d.ts +1 -1
- package/dist/tasks/index.d.ts.map +1 -1
- package/dist/tasks/upgrade/prompts/index.d.ts +2 -0
- package/dist/tasks/upgrade/prompts/index.d.ts.map +1 -0
- package/dist/tasks/upgrade/prompts/latest.d.ts +9 -0
- package/dist/tasks/upgrade/prompts/latest.d.ts.map +1 -0
- package/dist/tasks/upgrade/requirements/major.d.ts.map +1 -1
- package/dist/tasks/upgrade/upgrade.d.ts.map +1 -1
- package/package.json +16 -15
- package/resources/codemods/5.0.0/comment-out-lifecycle-files.code.ts +63 -0
- package/resources/codemods/5.0.0/dependency-remove-strapi-plugin-i18n.json.ts +31 -0
- package/resources/codemods/5.0.0/dependency-upgrade-react-and-react-dom.json.ts +67 -0
- package/resources/codemods/5.0.0/dependency-upgrade-react-router-dom.json.ts +59 -0
- package/resources/codemods/5.0.0/dependency-upgrade-styled-components.json.ts +49 -0
- package/resources/codemods/5.0.0/deprecate-helper-plugin.code.ts +192 -0
- package/resources/codemods/5.0.0/entity-service-document-service.code.ts +437 -0
- package/resources/codemods/5.0.0/s3-keys-wrapped-in-credentials.code.ts +1 -1
- package/resources/codemods/5.0.0/sqlite3-to-better-sqlite3.json.ts +5 -3
- package/resources/codemods/5.0.0/strapi-public-interface.code.ts +126 -0
- package/resources/codemods/5.0.0/use-uid-for-config-namespace.code.ts +1 -1
- package/resources/codemods/5.0.0/utils-public-interface.code.ts +320 -0
- package/resources/codemods/5.1.0/dependency-better-sqlite3.json.ts +48 -0
- package/resources/examples/console.log-to-console.info.code.ts +1 -1
- package/resources/examples/disable-jsx-buttons.code.ts +42 -0
- package/resources/utils/change-import.ts +118 -0
- package/resources/utils/replace-jsx.ts +49 -0
- package/dist/_chunks/codemod-runner-B5OeSMTQ.js +0 -730
- package/dist/_chunks/codemod-runner-B5OeSMTQ.js.map +0 -1
- package/dist/_chunks/codemods-10ZKewQx.js +0 -108
- package/dist/_chunks/codemods-10ZKewQx.js.map +0 -1
- package/dist/_chunks/index-uxCwtuH1.js +0 -103
- package/dist/_chunks/index-uxCwtuH1.js.map +0 -1
- package/dist/_chunks/upgrade-A4T1OWs5.js +0 -357
- package/dist/_chunks/upgrade-A4T1OWs5.js.map +0 -1
- package/dist/tasks/codemods/codemods.d.ts +0 -3
- 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
|
package/dist/cli.mjs.map
ADDED
|
@@ -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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"}
|