@strapi/upgrade 5.0.0-alpha.5 → 5.0.0-alpha.7
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/_chunks/{codemod-runner-CrDQxTWE.js → codemod-runner-Szbnr_ca.js} +88 -20
- package/dist/_chunks/codemod-runner-Szbnr_ca.js.map +1 -0
- package/dist/_chunks/{codemods-SNk0-R2U.js → codemods-kphfI74G.js} +4 -4
- package/dist/_chunks/{codemods-SNk0-R2U.js.map → codemods-kphfI74G.js.map} +1 -1
- package/dist/_chunks/{index-jxp8ewxV.js → index-_HkHk3z9.js} +5 -5
- package/dist/_chunks/{index-jxp8ewxV.js.map → index-_HkHk3z9.js.map} +1 -1
- package/dist/_chunks/{upgrade-cGHdihLS.js → upgrade-ETqxKahE.js} +10 -3
- package/dist/_chunks/upgrade-ETqxKahE.js.map +1 -0
- package/dist/cli.js +1 -1
- package/dist/index.js +112 -19
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +112 -19
- package/dist/index.mjs.map +1 -1
- package/dist/modules/codemod-repository/repository.d.ts +1 -0
- package/dist/modules/codemod-repository/repository.d.ts.map +1 -1
- package/dist/modules/codemod-runner/codemod-runner.d.ts +3 -3
- package/dist/modules/codemod-runner/codemod-runner.d.ts.map +1 -1
- package/dist/modules/project/constants.d.ts +2 -0
- 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 +12 -4
- package/dist/modules/project/project.d.ts.map +1 -1
- package/dist/modules/project/types.d.ts +0 -11
- 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/requirement/types.d.ts +2 -2
- package/dist/modules/requirement/types.d.ts.map +1 -1
- package/dist/modules/upgrader/upgrader.d.ts +3 -3
- package/dist/modules/upgrader/upgrader.d.ts.map +1 -1
- package/dist/tasks/codemods/codemods.d.ts.map +1 -1
- package/dist/tasks/upgrade/upgrade.d.ts.map +1 -1
- package/package.json +6 -6
- package/resources/codemods/5.0.0/dependency-remove-strapi-plugin-i18n.json.ts +31 -0
- package/resources/codemods/5.0.0/dependency-upgrade-react-router-dom.json.ts +59 -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 -2
- package/resources/codemods/5.0.0/use-uid-for-config-namespace.code.ts +1 -1
- package/resources/examples/console.log-to-console.info.code.ts +1 -1
- package/resources/examples/disable-jsx-buttons.code.ts +42 -0
- package/dist/_chunks/codemod-runner-CrDQxTWE.js.map +0 -1
- package/dist/_chunks/upgrade-cGHdihLS.js.map +0 -1
package/dist/index.mjs
CHANGED
|
@@ -366,7 +366,20 @@ const index$b = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.definePrope
|
|
|
366
366
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
367
367
|
const PROJECT_PACKAGE_JSON = "package.json";
|
|
368
368
|
const PROJECT_DEFAULT_ALLOWED_ROOT_PATHS = ["src", "config", "public"];
|
|
369
|
-
const
|
|
369
|
+
const PROJECT_DEFAULT_CODE_EXTENSIONS = [
|
|
370
|
+
// Source files
|
|
371
|
+
"js",
|
|
372
|
+
"mjs",
|
|
373
|
+
"ts",
|
|
374
|
+
// React files
|
|
375
|
+
"jsx",
|
|
376
|
+
"tsx"
|
|
377
|
+
];
|
|
378
|
+
const PROJECT_DEFAULT_JSON_EXTENSIONS = ["json"];
|
|
379
|
+
const PROJECT_DEFAULT_ALLOWED_EXTENSIONS = [
|
|
380
|
+
...PROJECT_DEFAULT_CODE_EXTENSIONS,
|
|
381
|
+
...PROJECT_DEFAULT_JSON_EXTENSIONS
|
|
382
|
+
];
|
|
370
383
|
const PROJECT_DEFAULT_PATTERNS = ["package.json"];
|
|
371
384
|
const SCOPED_STRAPI_PACKAGE_PREFIX = "@strapi/";
|
|
372
385
|
const STRAPI_DEPENDENCY_NAME = `${SCOPED_STRAPI_PACKAGE_PREFIX}strapi`;
|
|
@@ -374,6 +387,8 @@ const constants$3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineP
|
|
|
374
387
|
__proto__: null,
|
|
375
388
|
PROJECT_DEFAULT_ALLOWED_EXTENSIONS,
|
|
376
389
|
PROJECT_DEFAULT_ALLOWED_ROOT_PATHS,
|
|
390
|
+
PROJECT_DEFAULT_CODE_EXTENSIONS,
|
|
391
|
+
PROJECT_DEFAULT_JSON_EXTENSIONS,
|
|
377
392
|
PROJECT_DEFAULT_PATTERNS,
|
|
378
393
|
PROJECT_PACKAGE_JSON,
|
|
379
394
|
SCOPED_STRAPI_PACKAGE_PREFIX,
|
|
@@ -385,7 +400,6 @@ class Project {
|
|
|
385
400
|
files;
|
|
386
401
|
packageJSONPath;
|
|
387
402
|
packageJSON;
|
|
388
|
-
strapiVersion;
|
|
389
403
|
constructor(cwd) {
|
|
390
404
|
if (!fse.pathExistsSync(cwd)) {
|
|
391
405
|
throw new Error(`ENOENT: no such file or directory, access '${cwd}'`);
|
|
@@ -401,7 +415,6 @@ class Project {
|
|
|
401
415
|
}
|
|
402
416
|
refresh() {
|
|
403
417
|
this.refreshPackageJSON();
|
|
404
|
-
this.refreshStrapiVersion();
|
|
405
418
|
this.refreshProjectFiles();
|
|
406
419
|
return this;
|
|
407
420
|
}
|
|
@@ -419,17 +432,24 @@ class Project {
|
|
|
419
432
|
return reports2;
|
|
420
433
|
}
|
|
421
434
|
createProjectCodemodsRunners(dry = false) {
|
|
422
|
-
const
|
|
423
|
-
|
|
435
|
+
const jsonExtensions = PROJECT_DEFAULT_JSON_EXTENSIONS.map(
|
|
436
|
+
(ext) => `.${ext}`
|
|
437
|
+
);
|
|
438
|
+
const codeExtensions = PROJECT_DEFAULT_CODE_EXTENSIONS.map(
|
|
439
|
+
(ext) => `.${ext}`
|
|
440
|
+
);
|
|
441
|
+
const jsonFiles = this.getFilesByExtensions(jsonExtensions);
|
|
442
|
+
const codeFiles = this.getFilesByExtensions(codeExtensions);
|
|
424
443
|
const codeRunner = codeRunnerFactory(codeFiles, {
|
|
425
444
|
dry,
|
|
426
|
-
|
|
427
|
-
silent: true,
|
|
428
|
-
extensions: "js,ts",
|
|
445
|
+
parser: "ts",
|
|
429
446
|
runInBand: true,
|
|
430
|
-
verbose: 0,
|
|
431
447
|
babel: true,
|
|
432
|
-
|
|
448
|
+
extensions: PROJECT_DEFAULT_CODE_EXTENSIONS.join(","),
|
|
449
|
+
// Don't output any log coming from the runner
|
|
450
|
+
print: false,
|
|
451
|
+
silent: true,
|
|
452
|
+
verbose: 0
|
|
433
453
|
});
|
|
434
454
|
const jsonRunner = jsonRunnerFactory(jsonFiles, { dry, cwd: this.cwd });
|
|
435
455
|
return [codeRunner, jsonRunner];
|
|
@@ -457,6 +477,19 @@ class Project {
|
|
|
457
477
|
const scanner = fileScannerFactory(this.cwd);
|
|
458
478
|
this.files = scanner.scan(patterns);
|
|
459
479
|
}
|
|
480
|
+
}
|
|
481
|
+
class AppProject extends Project {
|
|
482
|
+
strapiVersion;
|
|
483
|
+
type = "app";
|
|
484
|
+
constructor(cwd) {
|
|
485
|
+
super(cwd);
|
|
486
|
+
this.refreshStrapiVersion();
|
|
487
|
+
}
|
|
488
|
+
refresh() {
|
|
489
|
+
super.refresh();
|
|
490
|
+
this.refreshStrapiVersion();
|
|
491
|
+
return this;
|
|
492
|
+
}
|
|
460
493
|
refreshStrapiVersion() {
|
|
461
494
|
this.strapiVersion = // First try to get the strapi version from the package.json dependencies
|
|
462
495
|
this.findStrapiVersionFromProjectPackageJSON() ?? // If the version found is not a valid SemVer, get the Strapi version from the installed package
|
|
@@ -502,10 +535,50 @@ const formatGlobCollectionPattern = (collection) => {
|
|
|
502
535
|
);
|
|
503
536
|
return collection.length === 1 ? collection[0] : `{${collection}}`;
|
|
504
537
|
};
|
|
505
|
-
|
|
538
|
+
class PluginProject extends Project {
|
|
539
|
+
type = "plugin";
|
|
540
|
+
}
|
|
541
|
+
const isPlugin = (cwd) => {
|
|
542
|
+
const packageJSONPath = path$1.join(cwd, PROJECT_PACKAGE_JSON);
|
|
543
|
+
try {
|
|
544
|
+
fse.accessSync(packageJSONPath);
|
|
545
|
+
} catch {
|
|
546
|
+
throw new Error(`Could not find a ${PROJECT_PACKAGE_JSON} file in ${cwd}`);
|
|
547
|
+
}
|
|
548
|
+
const packageJSONBuffer = fse.readFileSync(packageJSONPath);
|
|
549
|
+
const packageJSON = JSON.parse(packageJSONBuffer.toString());
|
|
550
|
+
return packageJSON?.strapi?.kind === "plugin";
|
|
551
|
+
};
|
|
552
|
+
const projectFactory = (cwd) => {
|
|
553
|
+
fse.accessSync(cwd);
|
|
554
|
+
if (isPlugin(cwd)) {
|
|
555
|
+
return new PluginProject(cwd);
|
|
556
|
+
}
|
|
557
|
+
return new AppProject(cwd);
|
|
558
|
+
};
|
|
559
|
+
const isPluginProject = (project) => {
|
|
560
|
+
return project instanceof PluginProject;
|
|
561
|
+
};
|
|
562
|
+
function assertPluginProject(project) {
|
|
563
|
+
if (!isPluginProject(project)) {
|
|
564
|
+
throw new Error("Project is not a plugin");
|
|
565
|
+
}
|
|
566
|
+
}
|
|
567
|
+
const isAppProject = (project) => {
|
|
568
|
+
return project instanceof AppProject;
|
|
569
|
+
};
|
|
570
|
+
function assertAppProject(project) {
|
|
571
|
+
if (!isAppProject(project)) {
|
|
572
|
+
throw new Error("Project is not an app");
|
|
573
|
+
}
|
|
574
|
+
}
|
|
506
575
|
const index$a = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
507
576
|
__proto__: null,
|
|
577
|
+
assertAppProject,
|
|
578
|
+
assertPluginProject,
|
|
508
579
|
constants: constants$3,
|
|
580
|
+
isAppProject,
|
|
581
|
+
isPluginProject,
|
|
509
582
|
projectFactory
|
|
510
583
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
511
584
|
class UnexpectedError extends Error {
|
|
@@ -652,6 +725,13 @@ class CodemodRepository {
|
|
|
652
725
|
const codemods2 = this.groups[literalVersion];
|
|
653
726
|
return codemods2 ?? [];
|
|
654
727
|
}
|
|
728
|
+
findAll() {
|
|
729
|
+
const entries = Object.entries(this.groups);
|
|
730
|
+
return entries.map(([version2, codemods2]) => ({
|
|
731
|
+
version: semVerFactory(version2),
|
|
732
|
+
codemods: codemods2
|
|
733
|
+
}));
|
|
734
|
+
}
|
|
655
735
|
refreshAvailableVersions() {
|
|
656
736
|
this.versions = fse.readdirSync(this.cwd).filter((filename) => fse.statSync(path$1.join(this.cwd, filename)).isDirectory()).filter((filename) => semver.valid(filename) !== null).map((version2) => semVerFactory(version2)).sort(semver.compare);
|
|
657
737
|
return this;
|
|
@@ -732,18 +812,24 @@ class CodemodRunner {
|
|
|
732
812
|
codemodsDirectory ?? INTERNAL_CODEMODS_DIRECTORY
|
|
733
813
|
);
|
|
734
814
|
repository.refresh();
|
|
735
|
-
const allVersionedCodemods = repository.findByRange(this.range);
|
|
815
|
+
const allVersionedCodemods = this.range ? repository.findByRange(this.range) : repository.findAll();
|
|
736
816
|
const versionedCodemods = this.selectCodemodsCallback ? await this.selectCodemodsCallback(allVersionedCodemods) : allVersionedCodemods;
|
|
737
817
|
const hasCodemodsToRun = versionedCodemods.length > 0;
|
|
738
818
|
if (!hasCodemodsToRun) {
|
|
739
|
-
|
|
819
|
+
if (this.range) {
|
|
820
|
+
this.logger?.debug(`Found no codemods to run for ${versionRange(this.range)}`);
|
|
821
|
+
} else {
|
|
822
|
+
this.logger?.debug(`Found no codemods to run`);
|
|
823
|
+
}
|
|
740
824
|
return successReport$1();
|
|
741
825
|
}
|
|
742
|
-
this.
|
|
743
|
-
|
|
744
|
-
versionedCodemods.length
|
|
745
|
-
)
|
|
746
|
-
|
|
826
|
+
if (this.range) {
|
|
827
|
+
this.logger?.debug(
|
|
828
|
+
`Found codemods for ${highlight(versionedCodemods.length)} version(s) using ${this.range}`
|
|
829
|
+
);
|
|
830
|
+
} else {
|
|
831
|
+
this.logger?.debug(`Found codemods for ${highlight(versionedCodemods.length)} version(s)`);
|
|
832
|
+
}
|
|
747
833
|
versionedCodemods.forEach(
|
|
748
834
|
({ version: version$1, codemods: codemods22 }) => this.logger?.debug(`- ${version(version$1)} (${codemods22.length})`)
|
|
749
835
|
);
|
|
@@ -851,6 +937,8 @@ class Upgrader {
|
|
|
851
937
|
});
|
|
852
938
|
this.logger?.info(upgradeStep("Applying the latest code modifications", [2, 4]));
|
|
853
939
|
await this.runCodemods(codemodsRange);
|
|
940
|
+
this.logger?.debug("Refreshing project information...");
|
|
941
|
+
this.project.refresh();
|
|
854
942
|
this.logger?.info(upgradeStep("Upgrading Strapi dependencies", [3, 4]));
|
|
855
943
|
await this.updateDependencies();
|
|
856
944
|
this.logger?.info(upgradeStep("Installing dependencies", [4, 4]));
|
|
@@ -1028,6 +1116,11 @@ const upgrade = async (options) => {
|
|
|
1028
1116
|
const { logger, codemodsTarget } = options;
|
|
1029
1117
|
const cwd = path$1.resolve(options.cwd ?? process.cwd());
|
|
1030
1118
|
const project = projectFactory(cwd);
|
|
1119
|
+
if (!isAppProject(project)) {
|
|
1120
|
+
throw new Error(
|
|
1121
|
+
`The "${options.target}" upgrade can only be run on a Strapi project; for plugins, please use "codemods".`
|
|
1122
|
+
);
|
|
1123
|
+
}
|
|
1031
1124
|
const npmPackage = npmPackageFactory(STRAPI_PACKAGE_NAME);
|
|
1032
1125
|
await npmPackage.refresh();
|
|
1033
1126
|
const upgrader = upgraderFactory(project, options.target, npmPackage).dry(options.dry ?? false).onConfirm(options.confirm ?? null).setLogger(logger);
|
|
@@ -1050,7 +1143,7 @@ const codemods = async (options) => {
|
|
|
1050
1143
|
const { logger } = options;
|
|
1051
1144
|
const cwd = path$1.resolve(options.cwd ?? process.cwd());
|
|
1052
1145
|
const project = projectFactory(cwd);
|
|
1053
|
-
const range = getRangeFromTarget(project.strapiVersion, options.target);
|
|
1146
|
+
const range = isAppProject(project) ? getRangeFromTarget(project.strapiVersion, options.target) : void 0;
|
|
1054
1147
|
const codemodRunner = codemodRunnerFactory(project, range).dry(options.dry ?? false).onSelectCodemods(options.selectCodemods ?? null).setLogger(logger);
|
|
1055
1148
|
const executionReport = await codemodRunner.run();
|
|
1056
1149
|
if (!executionReport.success) {
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../src/modules/requirement/requirement.ts","../src/tasks/upgrade/requirements/major.ts","../src/tasks/upgrade/requirements/common.ts","../src/modules/timer/timer.ts","../src/modules/timer/constants.ts","../src/modules/json/transform-api.ts","../src/modules/json/file.ts","../src/modules/version/types.ts","../src/modules/version/semver.ts","../src/modules/version/range.ts","../src/modules/file-scanner/scanner.ts","../src/modules/runner/runner.ts","../src/modules/runner/code/code.ts","../src/modules/runner/json/transform.ts","../src/modules/runner/json/json.ts","../src/modules/project/constants.ts","../src/modules/project/project.ts","../src/modules/error/utils.ts","../src/modules/format/formats.ts","../src/modules/codemod/constants.ts","../src/modules/codemod/codemod.ts","../src/modules/codemod-repository/repository.ts","../src/modules/codemod-repository/constants.ts","../src/modules/codemod-runner/codemod-runner.ts","../src/modules/upgrader/upgrader.ts","../src/modules/upgrader/constants.ts","../src/modules/npm/constants.ts","../src/modules/npm/package.ts","../src/tasks/upgrade/upgrade.ts","../src/tasks/codemods/codemods.ts","../src/modules/logger/logger.ts","../src/modules/report/report.ts"],"sourcesContent":["import type {\n Requirement as RequirementInterface,\n RequirementTestCallback,\n TestContext,\n TestResult,\n} from './types';\n\nexport class Requirement implements RequirementInterface {\n readonly isRequired: boolean;\n\n readonly name: string;\n\n readonly testCallback: RequirementTestCallback | null;\n\n children: RequirementInterface[];\n\n constructor(name: string, testCallback: RequirementTestCallback | null, isRequired?: boolean) {\n this.name = name;\n this.testCallback = testCallback;\n this.isRequired = isRequired ?? true;\n this.children = [];\n }\n\n setChildren(children: RequirementInterface[]) {\n this.children = children;\n return this;\n }\n\n addChild(child: RequirementInterface) {\n this.children.push(child);\n return this;\n }\n\n asOptional() {\n const newInstance = requirementFactory(this.name, this.testCallback, false);\n\n newInstance.setChildren(this.children);\n\n return newInstance;\n }\n\n asRequired() {\n const newInstance = requirementFactory(this.name, this.testCallback, true);\n\n newInstance.setChildren(this.children);\n\n return newInstance;\n }\n\n async test(context: TestContext) {\n try {\n await this.testCallback?.(context);\n return ok();\n } catch (e) {\n if (e instanceof Error) {\n return errored(e);\n }\n\n if (typeof e === 'string') {\n return errored(new Error(e));\n }\n\n return errored(new Error('Unknown error'));\n }\n }\n}\n\nconst ok = (): TestResult => ({ pass: true, error: null });\n\nconst errored = (error: Error): TestResult => ({ pass: false, error });\n\nexport const requirementFactory = (\n name: string,\n testCallback: RequirementTestCallback | null,\n isRequired?: boolean\n) => new Requirement(name, testCallback, isRequired);\n","import { requirementFactory } from '../../../modules/requirement';\n\nexport const REQUIRE_AVAILABLE_NEXT_MAJOR = requirementFactory(\n 'REQUIRE_AVAILABLE_NEXT_MAJOR',\n (context) => {\n const { project, target } = context;\n\n const currentMajor = project.strapiVersion.major;\n const targetedMajor = target.major;\n\n if (targetedMajor === currentMajor) {\n throw new Error(`You're already on the latest major version (v${currentMajor})`);\n }\n }\n);\n\nexport const REQUIRE_LATEST_FOR_CURRENT_MAJOR = requirementFactory(\n 'REQUIRE_LATEST_FOR_CURRENT_MAJOR',\n (context) => {\n const { project, target, npmVersionsMatches } = context;\n\n if (npmVersionsMatches.length !== 1) {\n const invalidVersions = npmVersionsMatches.slice(0, -1);\n const invalidVersionsAsSemVer = invalidVersions.map((v) => v.version);\n const nbInvalidVersions = npmVersionsMatches.length;\n const currentMajor = project.strapiVersion.major;\n\n throw new Error(\n `Doing a major upgrade requires to be on the latest v${currentMajor} version, but found ${nbInvalidVersions} versions between the current one and ${target}: ${invalidVersionsAsSemVer}`\n );\n }\n }\n);\n","import simpleGit from 'simple-git';\n\nimport { requirementFactory } from '../../../modules/requirement';\n\nexport const REQUIRE_GIT_CLEAN_REPOSITORY = requirementFactory(\n 'REQUIRE_GIT_CLEAN_REPOSITORY',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n const status = await git.status();\n\n if (!status.isClean()) {\n throw new Error(\n 'Repository is not clean. Please commit or stash any changes before upgrading'\n );\n }\n }\n);\n\nexport const REQUIRE_GIT_REPOSITORY = requirementFactory(\n 'REQUIRE_GIT_REPOSITORY',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n const isRepo = await git.checkIsRepo();\n\n if (!isRepo) {\n throw new Error('Not a git repository (or any of the parent directories)');\n }\n }\n).addChild(REQUIRE_GIT_CLEAN_REPOSITORY.asOptional());\n\nexport const REQUIRE_GIT_INSTALLED = requirementFactory(\n 'REQUIRE_GIT_INSTALLED',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n try {\n await git.version();\n } catch {\n throw new Error('Git is not installed');\n }\n }\n).addChild(REQUIRE_GIT_REPOSITORY.asOptional());\n\nexport const REQUIRE_GIT = requirementFactory('REQUIRE_GIT', null).addChild(\n REQUIRE_GIT_INSTALLED.asOptional()\n);\n","import type { Timer as TimerInterface, TimeInterval } from './types';\n\nexport class Timer implements TimerInterface {\n private interval!: TimeInterval;\n\n constructor() {\n this.reset();\n }\n\n get elapsedMs() {\n const { start, end } = this.interval;\n\n return end ? end - start : Date.now() - start;\n }\n\n get end() {\n return this.interval.end;\n }\n\n get start() {\n return this.interval.start;\n }\n\n stop() {\n this.interval.end = Date.now();\n\n return this.elapsedMs;\n }\n\n reset() {\n this.interval = { start: Date.now(), end: null };\n\n return this;\n }\n}\n\nexport const timerFactory = () => new Timer();\n","export const ONE_SECOND_MS = 1000;\n","import { cloneDeep, get, has, set, merge, omit } from 'lodash/fp';\n\nimport type { Utils } from '@strapi/types';\n\nimport type { JSONTransformAPI as JSONTransformAPIInterface } from './types';\n\nexport class JSONTransformAPI implements JSONTransformAPIInterface {\n private json: Utils.JSONObject;\n\n constructor(json: Utils.JSONObject) {\n this.json = cloneDeep(json);\n }\n\n get<T extends Utils.JSONValue>(path: string): T | undefined;\n get<T extends Utils.JSONValue>(path: string, defaultValue: T): T;\n get<T extends Utils.JSONValue>(path?: string, defaultValue?: T) {\n if (!path) {\n return this.root() as T;\n }\n\n return cloneDeep(get(path, this.json) ?? defaultValue) as T;\n }\n\n has(path: string) {\n return has(path, this.json);\n }\n\n merge(other: Utils.JSONObject) {\n this.json = merge(other, this.json);\n\n return this;\n }\n\n root(): Utils.JSONObject {\n return cloneDeep(this.json);\n }\n\n set(path: string, value: Utils.JSONValue) {\n this.json = set(path, value, this.json);\n\n return this;\n }\n\n remove(path: string) {\n this.json = omit(path, this.json);\n return this;\n }\n}\n\nexport const createJSONTransformAPI = (object: Utils.JSONObject) => new JSONTransformAPI(object);\n","import fse from 'fs-extra';\n\nimport type { Utils } from '@strapi/types';\n\nexport const readJSON = async (path: string): Promise<Utils.JSONValue> => {\n const buffer = await fse.readFile(path);\n\n return JSON.parse(buffer.toString());\n};\n\nexport const saveJSON = async (path: string, json: Utils.JSONValue): Promise<void> => {\n const jsonAsString = `${JSON.stringify(json, null, 2)}\\n`;\n\n await fse.writeFile(path, jsonAsString);\n};\n","export type Version = number;\n\nexport type LiteralVersion =\n | `${Version}`\n | `${Version}.${Version}`\n | `${Version}.${Version}.${Version}`;\n\nexport type LiteralSemVer = `${Version}.${Version}.${Version}`;\n\nexport type { SemVer, Range } from 'semver';\n\nexport enum ReleaseType {\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n}\n","import semver from 'semver';\n\nimport * as Version from './types';\n\nexport const semVerFactory = (version: string): Version.SemVer => {\n return new semver.SemVer(version);\n};\n\nexport const isLiteralSemVer = (str: string): str is Version.LiteralSemVer => {\n const tokens = str.split('.');\n\n return (\n tokens.length === 3 &&\n tokens.every((token) => !Number.isNaN(+token) && Number.isInteger(+token))\n );\n};\n\nexport const isValidSemVer = (str: string) => semver.valid(str) !== null;\n\nexport const isSemverInstance = (value: unknown): value is semver.SemVer => {\n return value instanceof semver.SemVer;\n};\n\nexport const isSemVerReleaseType = (str: string): str is Version.ReleaseType => {\n return Object.values(Version.ReleaseType).includes(str as Version.ReleaseType);\n};\n","import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType } from './semver';\n\nexport const rangeFactory = (range: string): Version.Range => {\n return new semver.Range(range);\n};\n\nexport const rangeFromReleaseType = (current: Version.SemVer, identifier: Version.ReleaseType) => {\n switch (identifier) {\n case Version.ReleaseType.Major: {\n // semver.inc(_, 'major') will target <major + 1>.0.0 which is what we want\n // e.g. for 4.15.4, it'll return 5.0.0\n const nextMajor = semver.inc(current, 'major') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <=${nextMajor}`);\n }\n case Version.ReleaseType.Patch: {\n // This will return the minor for the next minor\n // e.g. for 4.15.4, it'll return 4.16.0\n const minor = semver.inc(current, 'minor') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <${minor}`);\n }\n case Version.ReleaseType.Minor: {\n // This will return the major for the next major\n // e.g. for 4.15.4, it'll return 5.0.0\n const major = semver.inc(current, 'major') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <${major}`);\n }\n default: {\n throw new Error('Not implemented');\n }\n }\n};\n\nexport const rangeFromVersions = (\n currentVersion: Version.SemVer,\n target: Version.ReleaseType | Version.SemVer\n) => {\n if (isSemverInstance(target)) {\n return rangeFactory(`>${currentVersion.raw} <=${target.raw}`);\n }\n\n if (isSemVerReleaseType(target)) {\n return rangeFromReleaseType(currentVersion, target);\n }\n\n throw new Error(`Invalid target set: ${target}`); // TODO: better errors\n};\n","import path from 'node:path';\nimport { glob } from 'glob';\n\nimport type { FileScanner as FileScannerInterface } from './types';\n\nexport class FileScanner implements FileScannerInterface {\n public cwd: string;\n\n constructor(cwd: string) {\n this.cwd = cwd;\n }\n\n scan(patterns: string[]) {\n const filenames = glob.sync(patterns, { cwd: this.cwd });\n\n // Resolve the full paths for every filename\n return filenames.map((filename) => path.join(this.cwd, filename));\n }\n}\n\nexport const fileScannerFactory = (cwd: string) => new FileScanner(cwd);\n","import type { Codemod } from '../codemod';\n\nimport type { Runner as RunnerInterface, RunnerConfiguration, RunnerFunction } from './types';\n\nexport abstract class AbstractRunner<TConfig extends RunnerConfiguration>\n implements RunnerInterface<TConfig>\n{\n abstract runner: RunnerFunction<TConfig>;\n\n paths: string[];\n\n configuration: TConfig;\n\n constructor(paths: string[], configuration: TConfig) {\n this.paths = paths;\n this.configuration = configuration;\n }\n\n async run(codemod: Codemod.Codemod, configuration?: TConfig) {\n const isValidCodemod = this.valid(codemod);\n\n if (!isValidCodemod) {\n throw new Error(`Invalid codemod provided to the runner: ${codemod.filename}`);\n }\n\n const runConfiguration: TConfig = { ...this.configuration, ...configuration };\n\n return this.runner(codemod.path, this.paths, runConfiguration);\n }\n\n abstract valid(codemod: Codemod.Codemod): boolean;\n}\n","import { run as jscodeshift } from 'jscodeshift/src/Runner';\n\nimport { AbstractRunner } from '../runner';\n\nimport type { Codemod } from '../../codemod';\nimport type { CodeRunnerConfiguration } from './types';\n\nexport class CodeRunner extends AbstractRunner<CodeRunnerConfiguration> {\n runner = jscodeshift;\n\n valid(codemod: Codemod.Codemod): boolean {\n return codemod.kind === 'code';\n }\n}\n\nexport const codeRunnerFactory = (paths: string[], configuration: CodeRunnerConfiguration) => {\n return new CodeRunner(paths, configuration);\n};\n","/* eslint-disable @typescript-eslint/no-var-requires */\n\nimport assert from 'node:assert';\nimport { isEqual } from 'lodash/fp';\nimport { register } from 'esbuild-register/dist/node';\n\nimport { createJSONTransformAPI, readJSON, saveJSON } from '../../json';\n\nimport type { Report } from '../../report';\n\nimport type { JSONRunnerConfiguration, JSONSourceFile, JSONTransformParams } from './types';\n\nexport const transformJSON = async (\n codemodPath: string,\n paths: string[],\n config: JSONRunnerConfiguration\n): Promise<Report.Report> => {\n const { dry } = config;\n const startTime = process.hrtime();\n\n const report: Report.Report = {\n ok: 0,\n nochange: 0,\n skip: 0,\n error: 0,\n timeElapsed: '',\n stats: {},\n };\n\n const esbuildOptions = { extensions: ['.js', '.mjs', '.ts'] };\n const { unregister } = register(esbuildOptions);\n\n const module = require(codemodPath);\n\n unregister();\n\n const codemod = typeof module.default === 'function' ? module.default : module;\n\n assert(typeof codemod === 'function', `Codemod must be a function. Found ${typeof codemod}`);\n\n for (const path of paths) {\n try {\n const json = await readJSON(path);\n\n // Make sure the JSON value is a JSON object\n assert(typeof json === 'object' && !Array.isArray(json) && json !== null);\n\n // TODO: Optimize the API to limit parse/stringify operations\n const file: JSONSourceFile = { path, json };\n const params: JSONTransformParams = { cwd: config.cwd, json: createJSONTransformAPI };\n\n const out = await codemod(file, params);\n\n if (out === undefined) {\n report.error += 1;\n }\n // If the json object has modifications\n else if (!isEqual(json, out)) {\n if (!dry) {\n await saveJSON(path, out);\n }\n report.ok += 1;\n }\n // No changes\n else {\n report.nochange += 1;\n }\n } catch {\n report.error += 1;\n }\n }\n\n const endTime = process.hrtime(startTime);\n report.timeElapsed = (endTime[0] + endTime[1] / 1e9).toFixed(3);\n\n return report;\n};\n","import { AbstractRunner } from '../runner';\n\nimport { transformJSON } from './transform';\n\nimport type { Codemod } from '../../codemod';\nimport type { JSONRunnerConfiguration } from './types';\n\nexport class JSONRunner extends AbstractRunner<JSONRunnerConfiguration> {\n runner = transformJSON;\n\n valid(codemod: Codemod.Codemod): boolean {\n return codemod.kind === 'json';\n }\n}\n\nexport const jsonRunnerFactory = (paths: string[], configuration: JSONRunnerConfiguration) => {\n return new JSONRunner(paths, configuration);\n};\n","export const PROJECT_PACKAGE_JSON = 'package.json';\n\nexport const PROJECT_DEFAULT_ALLOWED_ROOT_PATHS = ['src', 'config', 'public'];\n\nexport const PROJECT_DEFAULT_ALLOWED_EXTENSIONS = ['js', 'ts', 'json'];\n\nexport const PROJECT_DEFAULT_PATTERNS = ['package.json'];\n\nexport const SCOPED_STRAPI_PACKAGE_PREFIX = '@strapi/';\n\nexport const STRAPI_DEPENDENCY_NAME = `${SCOPED_STRAPI_PACKAGE_PREFIX}strapi`;\n","import path from 'node:path';\nimport assert from 'node:assert';\nimport fse from 'fs-extra';\nimport semver from 'semver';\n\nimport { semVerFactory, isLiteralSemVer, isValidSemVer } from '../version';\nimport { fileScannerFactory } from '../file-scanner';\nimport { codeRunnerFactory } from '../runner/code';\nimport { jsonRunnerFactory } from '../runner/json';\nimport * as constants from './constants';\n\nimport type { Version } from '../version';\nimport type { Codemod } from '../codemod';\nimport type { Report } from '../report';\nimport type {\n Project as ProjectInterface,\n FileExtension,\n MinimalPackageJSON,\n RunCodemodsOptions,\n} from './types';\n\nexport class Project implements ProjectInterface {\n public cwd: string;\n\n // The following properties are assigned during the .refresh() call in the constructor.\n\n public files!: string[];\n\n public packageJSONPath!: string;\n\n public packageJSON!: MinimalPackageJSON;\n\n public strapiVersion!: Version.SemVer;\n\n constructor(cwd: string) {\n if (!fse.pathExistsSync(cwd)) {\n throw new Error(`ENOENT: no such file or directory, access '${cwd}'`);\n }\n\n this.cwd = cwd;\n\n this.refresh();\n }\n\n getFilesByExtensions(extensions: FileExtension[]) {\n return this.files.filter((filePath) => {\n const fileExtension = path.extname(filePath) as FileExtension;\n\n return extensions.includes(fileExtension);\n });\n }\n\n refresh() {\n this.refreshPackageJSON();\n this.refreshStrapiVersion();\n this.refreshProjectFiles();\n\n return this;\n }\n\n async runCodemods(codemods: Codemod.List, options: RunCodemodsOptions) {\n const runners = this.createProjectCodemodsRunners(options.dry);\n const reports: Report.CodemodReport[] = [];\n\n for (const codemod of codemods) {\n for (const runner of runners) {\n if (runner.valid(codemod)) {\n const report = await runner.run(codemod);\n reports.push({ codemod, report });\n }\n }\n }\n\n return reports;\n }\n\n private createProjectCodemodsRunners(dry: boolean = false) {\n const jsonFiles = this.getFilesByExtensions(['.json']);\n const codeFiles = this.getFilesByExtensions(['.js', '.ts', '.mjs']);\n\n const codeRunner = codeRunnerFactory(codeFiles, {\n dry,\n print: false,\n silent: true,\n extensions: 'js,ts',\n runInBand: true,\n verbose: 0,\n babel: true,\n parser: 'ts',\n });\n const jsonRunner = jsonRunnerFactory(jsonFiles, { dry, cwd: this.cwd });\n\n return [codeRunner, jsonRunner] as const;\n }\n\n private refreshPackageJSON(): void {\n const packageJSONPath = path.join(this.cwd, constants.PROJECT_PACKAGE_JSON);\n\n try {\n fse.accessSync(packageJSONPath);\n } catch {\n throw new Error(`Could not find a ${constants.PROJECT_PACKAGE_JSON} file in ${this.cwd}`);\n }\n\n const packageJSONBuffer = fse.readFileSync(packageJSONPath);\n\n this.packageJSONPath = packageJSONPath;\n this.packageJSON = JSON.parse(packageJSONBuffer.toString());\n }\n\n private refreshProjectFiles(): void {\n const allowedRootPaths = formatGlobCollectionPattern(\n constants.PROJECT_DEFAULT_ALLOWED_ROOT_PATHS\n );\n\n const allowedExtensions = formatGlobCollectionPattern(\n constants.PROJECT_DEFAULT_ALLOWED_EXTENSIONS\n );\n\n const projectFilesPattern = `./${allowedRootPaths}/**/*.${allowedExtensions}`;\n\n const patterns = [projectFilesPattern, ...constants.PROJECT_DEFAULT_PATTERNS];\n const scanner = fileScannerFactory(this.cwd);\n\n this.files = scanner.scan(patterns);\n }\n\n private refreshStrapiVersion(): void {\n this.strapiVersion =\n // First try to get the strapi version from the package.json dependencies\n this.findStrapiVersionFromProjectPackageJSON() ??\n // If the version found is not a valid SemVer, get the Strapi version from the installed package\n this.findLocallyInstalledStrapiVersion();\n }\n\n private findStrapiVersionFromProjectPackageJSON(): Version.SemVer | undefined {\n const projectName = this.packageJSON.name;\n const version = this.packageJSON.dependencies?.[constants.STRAPI_DEPENDENCY_NAME];\n\n if (version === undefined) {\n throw new Error(\n `No version of ${constants.STRAPI_DEPENDENCY_NAME} was found in ${projectName}. Are you in a valid Strapi project?`\n );\n }\n\n const isValidSemVer = isLiteralSemVer(version) && semver.valid(version) === version;\n\n // We return undefined only if a strapi/strapi version is found, but it's not semver compliant\n return isValidSemVer ? semVerFactory(version) : undefined;\n }\n\n private findLocallyInstalledStrapiVersion(): Version.SemVer {\n const packageSearchText = `${constants.STRAPI_DEPENDENCY_NAME}/package.json`;\n\n let strapiPackageJSONPath: string;\n let strapiPackageJSON: MinimalPackageJSON;\n\n try {\n strapiPackageJSONPath = require.resolve(packageSearchText, { paths: [this.cwd] });\n strapiPackageJSON = require(strapiPackageJSONPath);\n\n assert(typeof strapiPackageJSON === 'object');\n } catch {\n throw new Error(\n `Cannot resolve module \"${constants.STRAPI_DEPENDENCY_NAME}\" from paths [${this.cwd}]`\n );\n }\n\n const strapiVersion = strapiPackageJSON.version;\n\n if (!isValidSemVer(strapiVersion)) {\n throw new Error(\n `Invalid ${constants.STRAPI_DEPENDENCY_NAME} version found in ${strapiPackageJSONPath} (${strapiVersion})`\n );\n }\n\n return semVerFactory(strapiVersion);\n }\n}\n\nconst formatGlobCollectionPattern = (collection: string[]): string => {\n assert(\n collection.length > 0,\n 'Invalid pattern provided, the given collection needs at least 1 element'\n );\n\n return collection.length === 1 ? collection[0] : `{${collection}}`;\n};\n\nexport const projectFactory = (cwd: string) => new Project(cwd);\n","export class UnexpectedError extends Error {\n constructor() {\n super('Unexpected Error');\n }\n}\n\nexport const unknownToError = (e: unknown): Error => {\n if (e instanceof Error) {\n return e;\n }\n\n if (typeof e === 'string') {\n return new Error(e);\n }\n\n return new UnexpectedError();\n};\n","import CliTable3 from 'cli-table3';\nimport chalk from 'chalk';\n\nimport { constants as timerConstants } from '../timer';\n\nimport type { Version } from '../version';\nimport type { Report } from '../report';\n\nexport const path = (path: string) => chalk.blue(path);\n\nexport const version = (version: Version.LiteralVersion | Version.SemVer) => {\n return chalk.italic.yellow(`v${version}`);\n};\n\nexport const versionRange = (range: Version.Range) => chalk.italic.yellow(range);\n\nexport const transform = (transformFilePath: string) => chalk.cyan(transformFilePath);\n\nexport const highlight = (arg: unknown) => chalk.bold.underline(arg);\n\nexport const upgradeStep = (text: string, step: [current: number, total: number]) => {\n return chalk.bold(`(${step[0]}/${step[1]}) ${text}...`);\n};\n\nexport const reports = (reports: Report.CodemodReport[]) => {\n const rows = reports.map(({ codemod, report }, i) => {\n const fIndex = chalk.grey(i);\n const fVersion = chalk.magenta(codemod.version);\n const fKind = chalk.yellow(codemod.kind);\n const fFormattedTransformPath = chalk.cyan(codemod.format());\n const fTimeElapsed =\n i === 0\n ? `${report.timeElapsed}s ${chalk.dim.italic('(cold start)')}`\n : `${report.timeElapsed}s`;\n const fAffected = report.ok > 0 ? chalk.green(report.ok) : chalk.grey(0);\n const fUnchanged = report.ok === 0 ? chalk.red(report.nochange) : chalk.grey(report.nochange);\n\n return [fIndex, fVersion, fKind, fFormattedTransformPath, fAffected, fUnchanged, fTimeElapsed];\n });\n\n const table = new CliTable3({\n style: { compact: true },\n head: [\n chalk.bold.grey('N°'),\n chalk.bold.magenta('Version'),\n chalk.bold.yellow('Kind'),\n chalk.bold.cyan('Name'),\n chalk.bold.green('Affected'),\n chalk.bold.red('Unchanged'),\n chalk.bold.blue('Duration'),\n ],\n });\n\n table.push(...rows);\n\n return table.toString();\n};\n\nexport const durationMs = (elapsedMs: number) => {\n const elapsedSeconds = (elapsedMs / timerConstants.ONE_SECOND_MS).toFixed(3);\n\n return `${elapsedSeconds}s`;\n};\n","export const CODEMOD_CODE_SUFFIX = 'code';\n\nexport const CODEMOD_JSON_SUFFIX = 'json';\n\nexport const CODEMOD_ALLOWED_SUFFIXES = [CODEMOD_CODE_SUFFIX, CODEMOD_JSON_SUFFIX];\n\nexport const CODEMOD_EXTENSION = 'ts';\n\nexport const CODEMOD_FILE_REGEXP = new RegExp(\n `^.+[.](${CODEMOD_ALLOWED_SUFFIXES.join('|')})[.]${CODEMOD_EXTENSION}$`\n);\n","import path from 'node:path';\n\nimport * as constants from './constants';\n\nimport type { Codemod as CodemodInterface, Kind } from './types';\nimport type { Version } from '../version';\n\ntype CreateCodemodPayload = Pick<\n CodemodInterface,\n 'kind' | 'version' | 'baseDirectory' | 'filename'\n>;\n\nexport class Codemod implements CodemodInterface {\n kind: Kind;\n\n version: Version.SemVer;\n\n baseDirectory: string;\n\n filename: string;\n\n path: string;\n\n constructor(options: CreateCodemodPayload) {\n this.kind = options.kind;\n this.version = options.version;\n this.baseDirectory = options.baseDirectory;\n this.filename = options.filename;\n\n this.path = path.join(this.baseDirectory, this.version.raw, this.filename);\n }\n\n format() {\n return this.filename\n .replace(`.${constants.CODEMOD_CODE_SUFFIX}.${constants.CODEMOD_EXTENSION}`, '')\n .replace(`.${constants.CODEMOD_JSON_SUFFIX}.${constants.CODEMOD_EXTENSION}`, '')\n .replaceAll('-', ' ');\n }\n}\n\nexport const codemodFactory = (options: CreateCodemodPayload) => new Codemod(options);\n","import assert from 'node:assert';\nimport fse from 'fs-extra';\nimport semver from 'semver';\nimport path from 'node:path';\n\nimport { codemodFactory, constants } from '../codemod';\nimport { semVerFactory } from '../version';\n\nimport type { Codemod } from '../codemod';\nimport type { Version } from '../version';\n\nimport type { CodemodRepository as CodemodRepositoryInterface } from './types';\n\nexport class CodemodRepository implements CodemodRepositoryInterface {\n private groups: Record<Version.LiteralSemVer, Codemod.Codemod[]>;\n\n private versions: Version.SemVer[];\n\n public cwd: string;\n\n constructor(cwd: string) {\n assert(fse.existsSync(cwd), `Invalid codemods directory provided \"${cwd}\"`);\n\n this.cwd = cwd;\n\n this.groups = {};\n this.versions = [];\n }\n\n refresh() {\n this.refreshAvailableVersions();\n this.refreshAvailableFiles();\n\n return this;\n }\n\n count(version: Version.SemVer) {\n return this.findByVersion(version).length;\n }\n\n countRange(range: Version.Range) {\n return this.findByRange(range).length;\n }\n\n exists(version: Version.SemVer) {\n return version.raw in this.groups;\n }\n\n findByRange(range: Version.Range) {\n const entries = Object.entries(this.groups) as Array<[Version.LiteralSemVer, Codemod.List]>;\n\n return entries\n .filter(([version]) => range.test(version))\n .map<Codemod.VersionedCollection>(([version, codemods]) => ({\n version: semVerFactory(version),\n codemods,\n }));\n }\n\n findByVersion(version: Version.SemVer) {\n const literalVersion = version.raw as Version.LiteralSemVer;\n const codemods = this.groups[literalVersion];\n\n return codemods ?? [];\n }\n\n private refreshAvailableVersions() {\n this.versions = fse\n .readdirSync(this.cwd) // Only keep root directories\n .filter((filename) => fse.statSync(path.join(this.cwd, filename)).isDirectory())\n // Paths should be valid semver\n .filter((filename): filename is Version.LiteralSemVer => semver.valid(filename) !== null)\n // Transform files names to SemVer instances\n .map<Version.SemVer>((version) => semVerFactory(version))\n // Sort versions in ascending order\n .sort(semver.compare);\n\n return this;\n }\n\n private refreshAvailableFiles() {\n this.groups = {};\n\n for (const version of this.versions) {\n this.refreshAvailableFilesForVersion(version);\n }\n }\n\n private refreshAvailableFilesForVersion(version: Version.SemVer) {\n const literalVersion = version.raw as Version.LiteralSemVer;\n const versionDirectory = path.join(this.cwd, literalVersion);\n\n // Ignore obsolete versions\n if (!fse.existsSync(versionDirectory)) {\n return;\n }\n\n this.groups[literalVersion] = fse\n .readdirSync(versionDirectory)\n // Make sure the filenames are valid codemod files\n .filter((filename) => fse.statSync(path.join(versionDirectory, filename)).isFile())\n .filter((filename) => constants.CODEMOD_FILE_REGEXP.test(filename))\n // Transform the filenames into Codemod instances\n .map((filename) => {\n const kind = parseCodemodKindFromFilename(filename);\n const baseDirectory = this.cwd;\n\n return codemodFactory({ kind, baseDirectory, version, filename });\n });\n }\n}\n\nexport const parseCodemodKindFromFilename = (filename: string): Codemod.Kind => {\n const kind = filename.split('.').at(-2) as Codemod.Kind | undefined;\n\n assert(kind !== undefined);\n assert(constants.CODEMOD_ALLOWED_SUFFIXES.includes(kind));\n\n return kind;\n};\n\nexport const codemodRepositoryFactory = (cwd: string) => new CodemodRepository(cwd);\n","import path from 'node:path';\n\nexport const INTERNAL_CODEMODS_DIRECTORY = path.join(\n __dirname,\n '..',\n '..',\n 'resources',\n 'codemods'\n);\n","import {\n codemodRepositoryFactory,\n constants as codemodRepositoryConstants,\n} from '../codemod-repository';\nimport { unknownToError } from '../error';\nimport * as f from '../format';\n\nimport type { Logger } from '../logger';\nimport type { Project } from '../project';\nimport type { UpgradeReport } from '../upgrader';\nimport type { CodemodRunnerInterface, CodemodRunnerReport, SelectCodemodsCallback } from './types';\nimport type { Version } from '../version';\n\nexport class CodemodRunner implements CodemodRunnerInterface {\n private readonly project: Project;\n\n private range: Version.Range;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private selectCodemodsCallback: SelectCodemodsCallback | null;\n\n constructor(project: Project, range: Version.Range) {\n this.project = project;\n this.range = range;\n\n this.isDry = false;\n\n this.logger = null;\n this.selectCodemodsCallback = null;\n }\n\n setRange(range: Version.Range) {\n this.range = range;\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onSelectCodemods(callback: SelectCodemodsCallback | null) {\n this.selectCodemodsCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n async run(codemodsDirectory?: string): Promise<CodemodRunnerReport> {\n const repository = codemodRepositoryFactory(\n codemodsDirectory ?? codemodRepositoryConstants.INTERNAL_CODEMODS_DIRECTORY\n );\n\n // Make sure we have access to the latest snapshots of codemods on the system\n repository.refresh();\n\n const allVersionedCodemods = repository.findByRange(this.range);\n\n // If a selection callback is set, use it, else keep every codemods\n const versionedCodemods = this.selectCodemodsCallback\n ? await this.selectCodemodsCallback(allVersionedCodemods)\n : allVersionedCodemods;\n\n const hasCodemodsToRun = versionedCodemods.length > 0;\n\n if (!hasCodemodsToRun) {\n this.logger?.debug(`Found no codemods to run for ${f.versionRange(this.range)}`);\n return successReport();\n }\n\n this.logger?.debug(\n `Found codemods for ${f.highlight(\n versionedCodemods.length\n )} version(s) using ${f.versionRange(this.range)}`\n );\n versionedCodemods.forEach(({ version, codemods }) =>\n this.logger?.debug(`- ${f.version(version)} (${codemods.length})`)\n );\n\n // Flatten the collection to a single list of codemods, the original list should already be sorted\n const codemods = versionedCodemods.map(({ codemods }) => codemods).flat();\n\n try {\n const reports = await this.project.runCodemods(codemods, { dry: this.isDry });\n this.logger?.raw(f.reports(reports));\n } catch (e: unknown) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n}\n\nexport const codemodRunnerFactory = (project: Project, range: Version.Range) => {\n return new CodemodRunner(project, range);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n","import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { Project } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: Project;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: Project, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.1\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n this.logger?.info(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug(`Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`);\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug(`Skipping dependencies installation (${chalk.italic('dry mode')}`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n codemodRunner.dry(this.isDry);\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: Project,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion | undefined => {\n // Semver\n if (isSemverInstance(target)) {\n return npmPackage.findVersion(target);\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n return npmVersionsMatches.at(-1);\n }\n\n return undefined;\n};\n\nexport const upgraderFactory = (\n project: Project,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const targetedNPMVersion = resolveNPMTarget(project, target, npmPackage);\n if (!targetedNPMVersion) {\n throw new Error(`Couldn't find a matching version in the NPM registry for \"${target}\"`);\n }\n\n const semverTarget = semVerFactory(targetedNPMVersion.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already on ${f.version(semverTarget)}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n","export const STRAPI_PACKAGE_NAME = '@strapi/strapi';\n","export const NPM_REGISTRY_URL = 'https://registry.npmjs.org';\n","import assert from 'node:assert';\nimport semver from 'semver';\n\nimport * as constants from './constants';\nimport { isLiteralSemVer } from '../version';\n\nimport type { Package as PackageInterface, NPMPackage, NPMPackageVersion } from './types';\nimport type { Version } from '../version';\n\nexport class Package implements PackageInterface {\n name: string;\n\n packageURL: string;\n\n private npmPackage: NPMPackage | null;\n\n constructor(name: string) {\n this.name = name;\n this.packageURL = `${constants.NPM_REGISTRY_URL}/${name}`;\n this.npmPackage = null;\n }\n\n get isLoaded() {\n return this.npmPackage !== null;\n }\n\n private assertPackageIsLoaded(npmPackage: NPMPackage | null): asserts npmPackage is NPMPackage {\n assert(this.isLoaded, 'The package is not loaded yet');\n }\n\n getVersionsDict() {\n this.assertPackageIsLoaded(this.npmPackage);\n\n return this.npmPackage.versions;\n }\n\n getVersionsAsList() {\n this.assertPackageIsLoaded(this.npmPackage);\n\n return Object.values(this.npmPackage.versions);\n }\n\n findVersionsInRange(range: Version.Range) {\n const versions = this.getVersionsAsList();\n\n return (\n versions\n // Only select versions matching the upgrade range\n .filter((v) => range.test(v.version))\n // Only select supported version format (x.x.x)\n .filter((v) => isLiteralSemVer(v.version))\n // Sort in ascending order\n .sort((v1, v2) => semver.compare(v1.version, v2.version))\n );\n }\n\n findVersion(version: Version.SemVer): NPMPackageVersion | undefined {\n const versions = this.getVersionsAsList();\n\n return versions.find((npmVersion) => semver.eq(npmVersion.version, version));\n }\n\n async refresh() {\n const response = await fetch(this.packageURL);\n\n // TODO: Use a validation library to make sure the response structure is correct\n assert(response.ok, `Request failed for ${this.packageURL}`);\n\n this.npmPackage = await response.json();\n\n return this;\n }\n\n versionExists(version: Version.SemVer) {\n return this.findVersion(version) !== undefined;\n }\n}\n\nexport const npmPackageFactory = (name: string) => new Package(name);\n","import path from 'node:path';\n\nimport * as requirements from './requirements';\nimport { timerFactory } from '../../modules/timer';\nimport { upgraderFactory, constants as upgraderConstants } from '../../modules/upgrader';\nimport { npmPackageFactory } from '../../modules/npm';\nimport { projectFactory } from '../../modules/project';\nimport * as f from '../../modules/format';\nimport { Version } from '../../modules/version';\n\nimport type { UpgradeOptions } from './types';\n\nexport const upgrade = async (options: UpgradeOptions) => {\n const timer = timerFactory();\n const { logger, codemodsTarget } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = path.resolve(options.cwd ?? process.cwd());\n\n const project = projectFactory(cwd);\n const npmPackage = npmPackageFactory(upgraderConstants.STRAPI_PACKAGE_NAME);\n // Load all versions from the registry\n await npmPackage.refresh();\n\n const upgrader = upgraderFactory(project, options.target, npmPackage)\n .dry(options.dry ?? false)\n .onConfirm(options.confirm ?? null)\n .setLogger(logger);\n\n // Manually override the target version for codemods if it's explicitly provided\n if (codemodsTarget !== undefined) {\n upgrader.overrideCodemodsTarget(codemodsTarget);\n }\n\n // We're not adding the same requirements (e.g. \"REQUIRE_LATEST_FOR_CURRENT_MAJOR\") when manually targeting a\n // major upgrade (using a semver) as it's implied that the user knows what they're doing\n if (options.target === Version.ReleaseType.Major) {\n upgrader\n .addRequirement(requirements.major.REQUIRE_AVAILABLE_NEXT_MAJOR)\n .addRequirement(requirements.major.REQUIRE_LATEST_FOR_CURRENT_MAJOR);\n }\n\n // Make sure the git repository is in an optimal state before running the upgrade\n // Mainly used to ease rollbacks in case the upgrade is corrupted\n upgrader.addRequirement(requirements.common.REQUIRE_GIT.asOptional());\n\n // Actually run the upgrade process once configured\n // The response contains information about the final status (success/error)\n const upgradeReport = await upgrader.upgrade();\n\n if (!upgradeReport.success) {\n throw upgradeReport.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${f.durationMs(timer.elapsedMs)}`);\n};\n","import path from 'node:path';\n\nimport { timerFactory } from '../../modules/timer';\nimport { projectFactory } from '../../modules/project';\nimport type { RunCodemodsOptions } from './types';\nimport { codemodRunnerFactory } from '../../modules/codemod-runner';\nimport { Version, isSemverInstance, rangeFactory } from '../../modules/version';\n\nexport const codemods = async (options: RunCodemodsOptions) => {\n const timer = timerFactory();\n const { logger } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = path.resolve(options.cwd ?? process.cwd());\n\n const project = projectFactory(cwd);\n const range = getRangeFromTarget(project.strapiVersion, options.target);\n const codemodRunner = codemodRunnerFactory(project, range)\n .dry(options.dry ?? false)\n .onSelectCodemods(options.selectCodemods ?? null)\n .setLogger(logger);\n\n const executionReport = await codemodRunner.run();\n\n if (!executionReport.success) {\n throw executionReport.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${timer.elapsedMs}`);\n};\n\nconst getRangeFromTarget = (\n currentVersion: Version.SemVer,\n target: Version.ReleaseType | Version.LiteralSemVer\n) => {\n if (isSemverInstance(target)) {\n return rangeFactory(target);\n }\n\n const { major, minor, patch } = currentVersion;\n\n switch (target) {\n case Version.ReleaseType.Major:\n return rangeFactory(`${major}`);\n case Version.ReleaseType.Minor:\n return rangeFactory(`${major}.${minor}`);\n case Version.ReleaseType.Patch:\n return rangeFactory(`${major}.${minor}.${patch}`);\n default:\n throw new Error(`Invalid target set: ${target}`);\n }\n};\n","import chalk from 'chalk';\n\nimport type { Logger as LoggerInterface, LoggerOptions } from './types';\n\nexport class Logger implements LoggerInterface {\n isDebug: boolean;\n\n isSilent: boolean;\n\n private nbErrorsCalls: number;\n\n private nbWarningsCalls: number;\n\n constructor(options: LoggerOptions = {}) {\n // Set verbosity options\n this.isDebug = options.debug ?? false;\n this.isSilent = options.silent ?? false;\n\n // Initialize counters\n this.nbErrorsCalls = 0;\n this.nbWarningsCalls = 0;\n }\n\n private get isNotSilent(): boolean {\n return !this.isSilent;\n }\n\n get errors(): number {\n return this.nbErrorsCalls;\n }\n\n get warnings(): number {\n return this.nbWarningsCalls;\n }\n\n get stdout(): (NodeJS.WriteStream & { fd: 1 }) | undefined {\n return this.isSilent ? undefined : process.stdout;\n }\n\n get stderr(): (NodeJS.WriteStream & { fd: 2 }) | undefined {\n return this.isSilent ? undefined : process.stderr;\n }\n\n setDebug(debug: boolean): this {\n this.isDebug = debug;\n return this;\n }\n\n setSilent(silent: boolean): this {\n this.isSilent = silent;\n return this;\n }\n\n debug(...args: unknown[]): this {\n const isDebugEnabled = this.isNotSilent && this.isDebug;\n\n if (isDebugEnabled) {\n console.log(chalk.cyan(`[DEBUG]\\t[${nowAsISO()}]`), ...args);\n }\n\n return this;\n }\n\n error(...args: unknown[]): this {\n this.nbErrorsCalls += 1;\n\n if (this.isNotSilent) {\n console.error(chalk.red(`[ERROR]\\t[${nowAsISO()}]`), ...args);\n }\n\n return this;\n }\n\n info(...args: unknown[]): this {\n if (this.isNotSilent) {\n console.info(chalk.blue(`[INFO]\\t[${new Date().toISOString()}]`), ...args);\n }\n\n return this;\n }\n\n raw(...args: unknown[]): this {\n if (this.isNotSilent) {\n console.log(...args);\n }\n\n return this;\n }\n\n warn(...args: unknown[]): this {\n this.nbWarningsCalls += 1;\n\n if (this.isNotSilent) {\n console.warn(chalk.yellow(`[WARN]\\t[${new Date().toISOString()}]`), ...args);\n }\n\n return this;\n }\n}\n\nconst nowAsISO = () => new Date().toISOString();\n\nexport const loggerFactory = (options: LoggerOptions = {}) => new Logger(options);\n","import type { Codemod } from '../codemod';\n\nimport type { CodemodReport, Report } from './types';\n\nexport const codemodReportFactory = (codemod: Codemod.Codemod, report: Report): CodemodReport => ({\n codemod,\n report,\n});\n\nexport const reportFactory = (report: Report): Report => ({ ...report });\n"],"names":["path","ReleaseType","version","Version.ReleaseType","jscodeshift","codemods","reports","constants.PROJECT_PACKAGE_JSON","constants.PROJECT_DEFAULT_ALLOWED_ROOT_PATHS","constants.PROJECT_DEFAULT_ALLOWED_EXTENSIONS","constants.PROJECT_DEFAULT_PATTERNS","constants.STRAPI_DEPENDENCY_NAME","isValidSemVer","timerConstants.ONE_SECOND_MS","constants.CODEMOD_CODE_SUFFIX","constants.CODEMOD_EXTENSION","constants.CODEMOD_JSON_SUFFIX","constants.CODEMOD_FILE_REGEXP","constants.CODEMOD_ALLOWED_SUFFIXES","codemodRepositoryConstants.INTERNAL_CODEMODS_DIRECTORY","f.versionRange","successReport","f.highlight","f.version","f.reports","erroredReport","f.upgradeStep","projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX","constants.NPM_REGISTRY_URL","upgraderConstants.STRAPI_PACKAGE_NAME","requirements.major.REQUIRE_AVAILABLE_NEXT_MAJOR","requirements.major.REQUIRE_LATEST_FOR_CURRENT_MAJOR","requirements.common.REQUIRE_GIT","f.durationMs"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../src/modules/requirement/requirement.ts","../src/tasks/upgrade/requirements/major.ts","../src/tasks/upgrade/requirements/common.ts","../src/modules/timer/timer.ts","../src/modules/timer/constants.ts","../src/modules/json/transform-api.ts","../src/modules/json/file.ts","../src/modules/version/types.ts","../src/modules/version/semver.ts","../src/modules/version/range.ts","../src/modules/file-scanner/scanner.ts","../src/modules/runner/runner.ts","../src/modules/runner/code/code.ts","../src/modules/runner/json/transform.ts","../src/modules/runner/json/json.ts","../src/modules/project/constants.ts","../src/modules/project/project.ts","../src/modules/project/utils.ts","../src/modules/error/utils.ts","../src/modules/format/formats.ts","../src/modules/codemod/constants.ts","../src/modules/codemod/codemod.ts","../src/modules/codemod-repository/repository.ts","../src/modules/codemod-repository/constants.ts","../src/modules/codemod-runner/codemod-runner.ts","../src/modules/upgrader/upgrader.ts","../src/modules/upgrader/constants.ts","../src/modules/npm/constants.ts","../src/modules/npm/package.ts","../src/tasks/upgrade/upgrade.ts","../src/tasks/codemods/codemods.ts","../src/modules/logger/logger.ts","../src/modules/report/report.ts"],"sourcesContent":["import type {\n Requirement as RequirementInterface,\n RequirementTestCallback,\n TestContext,\n TestResult,\n} from './types';\n\nexport class Requirement implements RequirementInterface {\n readonly isRequired: boolean;\n\n readonly name: string;\n\n readonly testCallback: RequirementTestCallback | null;\n\n children: RequirementInterface[];\n\n constructor(name: string, testCallback: RequirementTestCallback | null, isRequired?: boolean) {\n this.name = name;\n this.testCallback = testCallback;\n this.isRequired = isRequired ?? true;\n this.children = [];\n }\n\n setChildren(children: RequirementInterface[]) {\n this.children = children;\n return this;\n }\n\n addChild(child: RequirementInterface) {\n this.children.push(child);\n return this;\n }\n\n asOptional() {\n const newInstance = requirementFactory(this.name, this.testCallback, false);\n\n newInstance.setChildren(this.children);\n\n return newInstance;\n }\n\n asRequired() {\n const newInstance = requirementFactory(this.name, this.testCallback, true);\n\n newInstance.setChildren(this.children);\n\n return newInstance;\n }\n\n async test(context: TestContext) {\n try {\n await this.testCallback?.(context);\n return ok();\n } catch (e) {\n if (e instanceof Error) {\n return errored(e);\n }\n\n if (typeof e === 'string') {\n return errored(new Error(e));\n }\n\n return errored(new Error('Unknown error'));\n }\n }\n}\n\nconst ok = (): TestResult => ({ pass: true, error: null });\n\nconst errored = (error: Error): TestResult => ({ pass: false, error });\n\nexport const requirementFactory = (\n name: string,\n testCallback: RequirementTestCallback | null,\n isRequired?: boolean\n) => new Requirement(name, testCallback, isRequired);\n","import { requirementFactory } from '../../../modules/requirement';\n\nexport const REQUIRE_AVAILABLE_NEXT_MAJOR = requirementFactory(\n 'REQUIRE_AVAILABLE_NEXT_MAJOR',\n (context) => {\n const { project, target } = context;\n\n const currentMajor = project.strapiVersion.major;\n const targetedMajor = target.major;\n\n if (targetedMajor === currentMajor) {\n throw new Error(`You're already on the latest major version (v${currentMajor})`);\n }\n }\n);\n\nexport const REQUIRE_LATEST_FOR_CURRENT_MAJOR = requirementFactory(\n 'REQUIRE_LATEST_FOR_CURRENT_MAJOR',\n (context) => {\n const { project, target, npmVersionsMatches } = context;\n\n if (npmVersionsMatches.length !== 1) {\n const invalidVersions = npmVersionsMatches.slice(0, -1);\n const invalidVersionsAsSemVer = invalidVersions.map((v) => v.version);\n const nbInvalidVersions = npmVersionsMatches.length;\n const currentMajor = project.strapiVersion.major;\n\n throw new Error(\n `Doing a major upgrade requires to be on the latest v${currentMajor} version, but found ${nbInvalidVersions} versions between the current one and ${target}: ${invalidVersionsAsSemVer}`\n );\n }\n }\n);\n","import simpleGit from 'simple-git';\n\nimport { requirementFactory } from '../../../modules/requirement';\n\nexport const REQUIRE_GIT_CLEAN_REPOSITORY = requirementFactory(\n 'REQUIRE_GIT_CLEAN_REPOSITORY',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n const status = await git.status();\n\n if (!status.isClean()) {\n throw new Error(\n 'Repository is not clean. Please commit or stash any changes before upgrading'\n );\n }\n }\n);\n\nexport const REQUIRE_GIT_REPOSITORY = requirementFactory(\n 'REQUIRE_GIT_REPOSITORY',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n const isRepo = await git.checkIsRepo();\n\n if (!isRepo) {\n throw new Error('Not a git repository (or any of the parent directories)');\n }\n }\n).addChild(REQUIRE_GIT_CLEAN_REPOSITORY.asOptional());\n\nexport const REQUIRE_GIT_INSTALLED = requirementFactory(\n 'REQUIRE_GIT_INSTALLED',\n async (context) => {\n const git = simpleGit({ baseDir: context.project.cwd });\n\n try {\n await git.version();\n } catch {\n throw new Error('Git is not installed');\n }\n }\n).addChild(REQUIRE_GIT_REPOSITORY.asOptional());\n\nexport const REQUIRE_GIT = requirementFactory('REQUIRE_GIT', null).addChild(\n REQUIRE_GIT_INSTALLED.asOptional()\n);\n","import type { Timer as TimerInterface, TimeInterval } from './types';\n\nexport class Timer implements TimerInterface {\n private interval!: TimeInterval;\n\n constructor() {\n this.reset();\n }\n\n get elapsedMs() {\n const { start, end } = this.interval;\n\n return end ? end - start : Date.now() - start;\n }\n\n get end() {\n return this.interval.end;\n }\n\n get start() {\n return this.interval.start;\n }\n\n stop() {\n this.interval.end = Date.now();\n\n return this.elapsedMs;\n }\n\n reset() {\n this.interval = { start: Date.now(), end: null };\n\n return this;\n }\n}\n\nexport const timerFactory = () => new Timer();\n","export const ONE_SECOND_MS = 1000;\n","import { cloneDeep, get, has, set, merge, omit } from 'lodash/fp';\n\nimport type { Utils } from '@strapi/types';\n\nimport type { JSONTransformAPI as JSONTransformAPIInterface } from './types';\n\nexport class JSONTransformAPI implements JSONTransformAPIInterface {\n private json: Utils.JSONObject;\n\n constructor(json: Utils.JSONObject) {\n this.json = cloneDeep(json);\n }\n\n get<T extends Utils.JSONValue>(path: string): T | undefined;\n get<T extends Utils.JSONValue>(path: string, defaultValue: T): T;\n get<T extends Utils.JSONValue>(path?: string, defaultValue?: T) {\n if (!path) {\n return this.root() as T;\n }\n\n return cloneDeep(get(path, this.json) ?? defaultValue) as T;\n }\n\n has(path: string) {\n return has(path, this.json);\n }\n\n merge(other: Utils.JSONObject) {\n this.json = merge(other, this.json);\n\n return this;\n }\n\n root(): Utils.JSONObject {\n return cloneDeep(this.json);\n }\n\n set(path: string, value: Utils.JSONValue) {\n this.json = set(path, value, this.json);\n\n return this;\n }\n\n remove(path: string) {\n this.json = omit(path, this.json);\n return this;\n }\n}\n\nexport const createJSONTransformAPI = (object: Utils.JSONObject) => new JSONTransformAPI(object);\n","import fse from 'fs-extra';\n\nimport type { Utils } from '@strapi/types';\n\nexport const readJSON = async (path: string): Promise<Utils.JSONValue> => {\n const buffer = await fse.readFile(path);\n\n return JSON.parse(buffer.toString());\n};\n\nexport const saveJSON = async (path: string, json: Utils.JSONValue): Promise<void> => {\n const jsonAsString = `${JSON.stringify(json, null, 2)}\\n`;\n\n await fse.writeFile(path, jsonAsString);\n};\n","export type Version = number;\n\nexport type LiteralVersion =\n | `${Version}`\n | `${Version}.${Version}`\n | `${Version}.${Version}.${Version}`;\n\nexport type LiteralSemVer = `${Version}.${Version}.${Version}`;\n\nexport type { SemVer, Range } from 'semver';\n\nexport enum ReleaseType {\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n}\n","import semver from 'semver';\n\nimport * as Version from './types';\n\nexport const semVerFactory = (version: string): Version.SemVer => {\n return new semver.SemVer(version);\n};\n\nexport const isLiteralSemVer = (str: string): str is Version.LiteralSemVer => {\n const tokens = str.split('.');\n\n return (\n tokens.length === 3 &&\n tokens.every((token) => !Number.isNaN(+token) && Number.isInteger(+token))\n );\n};\n\nexport const isValidSemVer = (str: string) => semver.valid(str) !== null;\n\nexport const isSemverInstance = (value: unknown): value is semver.SemVer => {\n return value instanceof semver.SemVer;\n};\n\nexport const isSemVerReleaseType = (str: string): str is Version.ReleaseType => {\n return Object.values(Version.ReleaseType).includes(str as Version.ReleaseType);\n};\n","import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType } from './semver';\n\nexport const rangeFactory = (range: string): Version.Range => {\n return new semver.Range(range);\n};\n\nexport const rangeFromReleaseType = (current: Version.SemVer, identifier: Version.ReleaseType) => {\n switch (identifier) {\n case Version.ReleaseType.Major: {\n // semver.inc(_, 'major') will target <major + 1>.0.0 which is what we want\n // e.g. for 4.15.4, it'll return 5.0.0\n const nextMajor = semver.inc(current, 'major') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <=${nextMajor}`);\n }\n case Version.ReleaseType.Patch: {\n // This will return the minor for the next minor\n // e.g. for 4.15.4, it'll return 4.16.0\n const minor = semver.inc(current, 'minor') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <${minor}`);\n }\n case Version.ReleaseType.Minor: {\n // This will return the major for the next major\n // e.g. for 4.15.4, it'll return 5.0.0\n const major = semver.inc(current, 'major') as Version.LiteralSemVer;\n return rangeFactory(`>${current.raw} <${major}`);\n }\n default: {\n throw new Error('Not implemented');\n }\n }\n};\n\nexport const rangeFromVersions = (\n currentVersion: Version.SemVer,\n target: Version.ReleaseType | Version.SemVer\n) => {\n if (isSemverInstance(target)) {\n return rangeFactory(`>${currentVersion.raw} <=${target.raw}`);\n }\n\n if (isSemVerReleaseType(target)) {\n return rangeFromReleaseType(currentVersion, target);\n }\n\n throw new Error(`Invalid target set: ${target}`); // TODO: better errors\n};\n","import path from 'node:path';\nimport { glob } from 'glob';\n\nimport type { FileScanner as FileScannerInterface } from './types';\n\nexport class FileScanner implements FileScannerInterface {\n public cwd: string;\n\n constructor(cwd: string) {\n this.cwd = cwd;\n }\n\n scan(patterns: string[]) {\n const filenames = glob.sync(patterns, { cwd: this.cwd });\n\n // Resolve the full paths for every filename\n return filenames.map((filename) => path.join(this.cwd, filename));\n }\n}\n\nexport const fileScannerFactory = (cwd: string) => new FileScanner(cwd);\n","import type { Codemod } from '../codemod';\n\nimport type { Runner as RunnerInterface, RunnerConfiguration, RunnerFunction } from './types';\n\nexport abstract class AbstractRunner<TConfig extends RunnerConfiguration>\n implements RunnerInterface<TConfig>\n{\n abstract runner: RunnerFunction<TConfig>;\n\n paths: string[];\n\n configuration: TConfig;\n\n constructor(paths: string[], configuration: TConfig) {\n this.paths = paths;\n this.configuration = configuration;\n }\n\n async run(codemod: Codemod.Codemod, configuration?: TConfig) {\n const isValidCodemod = this.valid(codemod);\n\n if (!isValidCodemod) {\n throw new Error(`Invalid codemod provided to the runner: ${codemod.filename}`);\n }\n\n const runConfiguration: TConfig = { ...this.configuration, ...configuration };\n\n return this.runner(codemod.path, this.paths, runConfiguration);\n }\n\n abstract valid(codemod: Codemod.Codemod): boolean;\n}\n","import { run as jscodeshift } from 'jscodeshift/src/Runner';\n\nimport { AbstractRunner } from '../runner';\n\nimport type { Codemod } from '../../codemod';\nimport type { CodeRunnerConfiguration } from './types';\n\nexport class CodeRunner extends AbstractRunner<CodeRunnerConfiguration> {\n runner = jscodeshift;\n\n valid(codemod: Codemod.Codemod): boolean {\n return codemod.kind === 'code';\n }\n}\n\nexport const codeRunnerFactory = (paths: string[], configuration: CodeRunnerConfiguration) => {\n return new CodeRunner(paths, configuration);\n};\n","/* eslint-disable @typescript-eslint/no-var-requires */\n\nimport assert from 'node:assert';\nimport { isEqual } from 'lodash/fp';\nimport { register } from 'esbuild-register/dist/node';\n\nimport { createJSONTransformAPI, readJSON, saveJSON } from '../../json';\n\nimport type { Report } from '../../report';\n\nimport type { JSONRunnerConfiguration, JSONSourceFile, JSONTransformParams } from './types';\n\nexport const transformJSON = async (\n codemodPath: string,\n paths: string[],\n config: JSONRunnerConfiguration\n): Promise<Report.Report> => {\n const { dry } = config;\n const startTime = process.hrtime();\n\n const report: Report.Report = {\n ok: 0,\n nochange: 0,\n skip: 0,\n error: 0,\n timeElapsed: '',\n stats: {},\n };\n\n const esbuildOptions = { extensions: ['.js', '.mjs', '.ts'] };\n const { unregister } = register(esbuildOptions);\n\n const module = require(codemodPath);\n\n unregister();\n\n const codemod = typeof module.default === 'function' ? module.default : module;\n\n assert(typeof codemod === 'function', `Codemod must be a function. Found ${typeof codemod}`);\n\n for (const path of paths) {\n try {\n const json = await readJSON(path);\n\n // Make sure the JSON value is a JSON object\n assert(typeof json === 'object' && !Array.isArray(json) && json !== null);\n\n // TODO: Optimize the API to limit parse/stringify operations\n const file: JSONSourceFile = { path, json };\n const params: JSONTransformParams = { cwd: config.cwd, json: createJSONTransformAPI };\n\n const out = await codemod(file, params);\n\n if (out === undefined) {\n report.error += 1;\n }\n // If the json object has modifications\n else if (!isEqual(json, out)) {\n if (!dry) {\n await saveJSON(path, out);\n }\n report.ok += 1;\n }\n // No changes\n else {\n report.nochange += 1;\n }\n } catch {\n report.error += 1;\n }\n }\n\n const endTime = process.hrtime(startTime);\n report.timeElapsed = (endTime[0] + endTime[1] / 1e9).toFixed(3);\n\n return report;\n};\n","import { AbstractRunner } from '../runner';\n\nimport { transformJSON } from './transform';\n\nimport type { Codemod } from '../../codemod';\nimport type { JSONRunnerConfiguration } from './types';\n\nexport class JSONRunner extends AbstractRunner<JSONRunnerConfiguration> {\n runner = transformJSON;\n\n valid(codemod: Codemod.Codemod): boolean {\n return codemod.kind === 'json';\n }\n}\n\nexport const jsonRunnerFactory = (paths: string[], configuration: JSONRunnerConfiguration) => {\n return new JSONRunner(paths, configuration);\n};\n","export const PROJECT_PACKAGE_JSON = 'package.json';\n\nexport const PROJECT_DEFAULT_ALLOWED_ROOT_PATHS = ['src', 'config', 'public'];\n\nexport const PROJECT_DEFAULT_CODE_EXTENSIONS = [\n // Source files\n 'js',\n 'mjs',\n 'ts',\n // React files\n 'jsx',\n 'tsx',\n];\n\nexport const PROJECT_DEFAULT_JSON_EXTENSIONS = ['json'];\n\nexport const PROJECT_DEFAULT_ALLOWED_EXTENSIONS = [\n ...PROJECT_DEFAULT_CODE_EXTENSIONS,\n ...PROJECT_DEFAULT_JSON_EXTENSIONS,\n];\n\nexport const PROJECT_DEFAULT_PATTERNS = ['package.json'];\n\nexport const SCOPED_STRAPI_PACKAGE_PREFIX = '@strapi/';\n\nexport const STRAPI_DEPENDENCY_NAME = `${SCOPED_STRAPI_PACKAGE_PREFIX}strapi`;\n","import path from 'node:path';\nimport assert from 'node:assert';\nimport fse from 'fs-extra';\nimport semver from 'semver';\n\nimport { semVerFactory, isLiteralSemVer, isValidSemVer } from '../version';\nimport { fileScannerFactory } from '../file-scanner';\nimport { codeRunnerFactory } from '../runner/code';\nimport { jsonRunnerFactory } from '../runner/json';\nimport * as constants from './constants';\n\nimport type { Version } from '../version';\nimport type { Codemod } from '../codemod';\nimport type { Report } from '../report';\nimport type { FileExtension, MinimalPackageJSON, RunCodemodsOptions } from './types';\n\nexport class Project {\n public cwd: string;\n\n // The following properties are assigned during the .refresh() call in the constructor.\n\n public files!: string[];\n\n public packageJSONPath!: string;\n\n public packageJSON!: MinimalPackageJSON;\n\n constructor(cwd: string) {\n if (!fse.pathExistsSync(cwd)) {\n throw new Error(`ENOENT: no such file or directory, access '${cwd}'`);\n }\n\n this.cwd = cwd;\n\n this.refresh();\n }\n\n getFilesByExtensions(extensions: FileExtension[]) {\n return this.files.filter((filePath) => {\n const fileExtension = path.extname(filePath) as FileExtension;\n\n return extensions.includes(fileExtension);\n });\n }\n\n refresh() {\n this.refreshPackageJSON();\n this.refreshProjectFiles();\n\n return this;\n }\n\n async runCodemods(codemods: Codemod.List, options: RunCodemodsOptions) {\n const runners = this.createProjectCodemodsRunners(options.dry);\n const reports: Report.CodemodReport[] = [];\n\n for (const codemod of codemods) {\n for (const runner of runners) {\n if (runner.valid(codemod)) {\n const report = await runner.run(codemod);\n reports.push({ codemod, report });\n }\n }\n }\n\n return reports;\n }\n\n private createProjectCodemodsRunners(dry: boolean = false) {\n const jsonExtensions = constants.PROJECT_DEFAULT_JSON_EXTENSIONS.map<FileExtension>(\n (ext) => `.${ext}`\n );\n const codeExtensions = constants.PROJECT_DEFAULT_CODE_EXTENSIONS.map<FileExtension>(\n (ext) => `.${ext}`\n );\n\n const jsonFiles = this.getFilesByExtensions(jsonExtensions);\n const codeFiles = this.getFilesByExtensions(codeExtensions);\n\n const codeRunner = codeRunnerFactory(codeFiles, {\n dry,\n parser: 'ts',\n runInBand: true,\n babel: true,\n extensions: constants.PROJECT_DEFAULT_CODE_EXTENSIONS.join(','),\n // Don't output any log coming from the runner\n print: false,\n silent: true,\n verbose: 0,\n });\n const jsonRunner = jsonRunnerFactory(jsonFiles, { dry, cwd: this.cwd });\n\n return [codeRunner, jsonRunner] as const;\n }\n\n private refreshPackageJSON(): void {\n const packageJSONPath = path.join(this.cwd, constants.PROJECT_PACKAGE_JSON);\n\n try {\n fse.accessSync(packageJSONPath);\n } catch {\n throw new Error(`Could not find a ${constants.PROJECT_PACKAGE_JSON} file in ${this.cwd}`);\n }\n\n const packageJSONBuffer = fse.readFileSync(packageJSONPath);\n\n this.packageJSONPath = packageJSONPath;\n this.packageJSON = JSON.parse(packageJSONBuffer.toString());\n }\n\n private refreshProjectFiles(): void {\n const allowedRootPaths = formatGlobCollectionPattern(\n constants.PROJECT_DEFAULT_ALLOWED_ROOT_PATHS\n );\n\n const allowedExtensions = formatGlobCollectionPattern(\n constants.PROJECT_DEFAULT_ALLOWED_EXTENSIONS\n );\n\n const projectFilesPattern = `./${allowedRootPaths}/**/*.${allowedExtensions}`;\n\n const patterns = [projectFilesPattern, ...constants.PROJECT_DEFAULT_PATTERNS];\n const scanner = fileScannerFactory(this.cwd);\n\n this.files = scanner.scan(patterns);\n }\n}\n\nexport class AppProject extends Project {\n public strapiVersion!: Version.SemVer;\n\n readonly type = 'app' as const;\n\n constructor(cwd: string) {\n super(cwd);\n this.refreshStrapiVersion();\n }\n\n refresh() {\n super.refresh();\n this.refreshStrapiVersion();\n return this;\n }\n\n private refreshStrapiVersion(): void {\n this.strapiVersion =\n // First try to get the strapi version from the package.json dependencies\n this.findStrapiVersionFromProjectPackageJSON() ??\n // If the version found is not a valid SemVer, get the Strapi version from the installed package\n this.findLocallyInstalledStrapiVersion();\n }\n\n private findStrapiVersionFromProjectPackageJSON(): Version.SemVer | undefined {\n const projectName = this.packageJSON.name;\n const version = this.packageJSON.dependencies?.[constants.STRAPI_DEPENDENCY_NAME];\n\n if (version === undefined) {\n throw new Error(\n `No version of ${constants.STRAPI_DEPENDENCY_NAME} was found in ${projectName}. Are you in a valid Strapi project?`\n );\n }\n\n const isValidSemVer = isLiteralSemVer(version) && semver.valid(version) === version;\n\n // We return undefined only if a strapi/strapi version is found, but it's not semver compliant\n return isValidSemVer ? semVerFactory(version) : undefined;\n }\n\n private findLocallyInstalledStrapiVersion(): Version.SemVer {\n const packageSearchText = `${constants.STRAPI_DEPENDENCY_NAME}/package.json`;\n\n let strapiPackageJSONPath: string;\n let strapiPackageJSON: MinimalPackageJSON;\n\n try {\n strapiPackageJSONPath = require.resolve(packageSearchText, { paths: [this.cwd] });\n strapiPackageJSON = require(strapiPackageJSONPath);\n\n assert(typeof strapiPackageJSON === 'object');\n } catch {\n throw new Error(\n `Cannot resolve module \"${constants.STRAPI_DEPENDENCY_NAME}\" from paths [${this.cwd}]`\n );\n }\n\n const strapiVersion = strapiPackageJSON.version;\n\n if (!isValidSemVer(strapiVersion)) {\n throw new Error(\n `Invalid ${constants.STRAPI_DEPENDENCY_NAME} version found in ${strapiPackageJSONPath} (${strapiVersion})`\n );\n }\n\n return semVerFactory(strapiVersion);\n }\n}\n\nconst formatGlobCollectionPattern = (collection: string[]): string => {\n assert(\n collection.length > 0,\n 'Invalid pattern provided, the given collection needs at least 1 element'\n );\n\n return collection.length === 1 ? collection[0] : `{${collection}}`;\n};\n\nexport class PluginProject extends Project {\n readonly type = 'plugin' as const;\n}\n\nconst isPlugin = (cwd: string) => {\n const packageJSONPath = path.join(cwd, constants.PROJECT_PACKAGE_JSON);\n\n try {\n fse.accessSync(packageJSONPath);\n } catch {\n throw new Error(`Could not find a ${constants.PROJECT_PACKAGE_JSON} file in ${cwd}`);\n }\n\n const packageJSONBuffer = fse.readFileSync(packageJSONPath);\n\n const packageJSON = JSON.parse(packageJSONBuffer.toString());\n\n return packageJSON?.strapi?.kind === 'plugin';\n};\n\n// TODO: make this async so we can use async file methods\nexport const projectFactory = (cwd: string) => {\n fse.accessSync(cwd);\n\n if (isPlugin(cwd)) {\n return new PluginProject(cwd);\n }\n\n return new AppProject(cwd);\n};\n","import { AppProject, PluginProject } from './project';\n\nexport const isPluginProject = (project: unknown): project is PluginProject => {\n return project instanceof PluginProject;\n};\n\nexport function assertPluginProject(project: unknown): asserts project is PluginProject {\n if (!isPluginProject(project)) {\n throw new Error('Project is not a plugin');\n }\n}\n\nexport const isAppProject = (project: unknown): project is AppProject => {\n return project instanceof AppProject;\n};\n\nexport function assertAppProject(project: unknown): asserts project is AppProject {\n if (!isAppProject(project)) {\n throw new Error('Project is not an app');\n }\n}\n","export class UnexpectedError extends Error {\n constructor() {\n super('Unexpected Error');\n }\n}\n\nexport const unknownToError = (e: unknown): Error => {\n if (e instanceof Error) {\n return e;\n }\n\n if (typeof e === 'string') {\n return new Error(e);\n }\n\n return new UnexpectedError();\n};\n","import CliTable3 from 'cli-table3';\nimport chalk from 'chalk';\n\nimport { constants as timerConstants } from '../timer';\n\nimport type { Version } from '../version';\nimport type { Report } from '../report';\n\nexport const path = (path: string) => chalk.blue(path);\n\nexport const version = (version: Version.LiteralVersion | Version.SemVer) => {\n return chalk.italic.yellow(`v${version}`);\n};\n\nexport const versionRange = (range: Version.Range) => chalk.italic.yellow(range);\n\nexport const transform = (transformFilePath: string) => chalk.cyan(transformFilePath);\n\nexport const highlight = (arg: unknown) => chalk.bold.underline(arg);\n\nexport const upgradeStep = (text: string, step: [current: number, total: number]) => {\n return chalk.bold(`(${step[0]}/${step[1]}) ${text}...`);\n};\n\nexport const reports = (reports: Report.CodemodReport[]) => {\n const rows = reports.map(({ codemod, report }, i) => {\n const fIndex = chalk.grey(i);\n const fVersion = chalk.magenta(codemod.version);\n const fKind = chalk.yellow(codemod.kind);\n const fFormattedTransformPath = chalk.cyan(codemod.format());\n const fTimeElapsed =\n i === 0\n ? `${report.timeElapsed}s ${chalk.dim.italic('(cold start)')}`\n : `${report.timeElapsed}s`;\n const fAffected = report.ok > 0 ? chalk.green(report.ok) : chalk.grey(0);\n const fUnchanged = report.ok === 0 ? chalk.red(report.nochange) : chalk.grey(report.nochange);\n\n return [fIndex, fVersion, fKind, fFormattedTransformPath, fAffected, fUnchanged, fTimeElapsed];\n });\n\n const table = new CliTable3({\n style: { compact: true },\n head: [\n chalk.bold.grey('N°'),\n chalk.bold.magenta('Version'),\n chalk.bold.yellow('Kind'),\n chalk.bold.cyan('Name'),\n chalk.bold.green('Affected'),\n chalk.bold.red('Unchanged'),\n chalk.bold.blue('Duration'),\n ],\n });\n\n table.push(...rows);\n\n return table.toString();\n};\n\nexport const durationMs = (elapsedMs: number) => {\n const elapsedSeconds = (elapsedMs / timerConstants.ONE_SECOND_MS).toFixed(3);\n\n return `${elapsedSeconds}s`;\n};\n","export const CODEMOD_CODE_SUFFIX = 'code';\n\nexport const CODEMOD_JSON_SUFFIX = 'json';\n\nexport const CODEMOD_ALLOWED_SUFFIXES = [CODEMOD_CODE_SUFFIX, CODEMOD_JSON_SUFFIX];\n\nexport const CODEMOD_EXTENSION = 'ts';\n\nexport const CODEMOD_FILE_REGEXP = new RegExp(\n `^.+[.](${CODEMOD_ALLOWED_SUFFIXES.join('|')})[.]${CODEMOD_EXTENSION}$`\n);\n","import path from 'node:path';\n\nimport * as constants from './constants';\n\nimport type { Codemod as CodemodInterface, Kind } from './types';\nimport type { Version } from '../version';\n\ntype CreateCodemodPayload = Pick<\n CodemodInterface,\n 'kind' | 'version' | 'baseDirectory' | 'filename'\n>;\n\nexport class Codemod implements CodemodInterface {\n kind: Kind;\n\n version: Version.SemVer;\n\n baseDirectory: string;\n\n filename: string;\n\n path: string;\n\n constructor(options: CreateCodemodPayload) {\n this.kind = options.kind;\n this.version = options.version;\n this.baseDirectory = options.baseDirectory;\n this.filename = options.filename;\n\n this.path = path.join(this.baseDirectory, this.version.raw, this.filename);\n }\n\n format() {\n return this.filename\n .replace(`.${constants.CODEMOD_CODE_SUFFIX}.${constants.CODEMOD_EXTENSION}`, '')\n .replace(`.${constants.CODEMOD_JSON_SUFFIX}.${constants.CODEMOD_EXTENSION}`, '')\n .replaceAll('-', ' ');\n }\n}\n\nexport const codemodFactory = (options: CreateCodemodPayload) => new Codemod(options);\n","import assert from 'node:assert';\nimport fse from 'fs-extra';\nimport semver from 'semver';\nimport path from 'node:path';\n\nimport { codemodFactory, constants } from '../codemod';\nimport { semVerFactory } from '../version';\n\nimport type { Codemod } from '../codemod';\nimport type { Version } from '../version';\n\nimport type { CodemodRepository as CodemodRepositoryInterface } from './types';\n\nexport class CodemodRepository implements CodemodRepositoryInterface {\n private groups: Record<Version.LiteralSemVer, Codemod.Codemod[]>;\n\n private versions: Version.SemVer[];\n\n public cwd: string;\n\n constructor(cwd: string) {\n assert(fse.existsSync(cwd), `Invalid codemods directory provided \"${cwd}\"`);\n\n this.cwd = cwd;\n\n this.groups = {};\n this.versions = [];\n }\n\n refresh() {\n this.refreshAvailableVersions();\n this.refreshAvailableFiles();\n\n return this;\n }\n\n count(version: Version.SemVer) {\n return this.findByVersion(version).length;\n }\n\n countRange(range: Version.Range) {\n return this.findByRange(range).length;\n }\n\n exists(version: Version.SemVer) {\n return version.raw in this.groups;\n }\n\n findByRange(range: Version.Range) {\n const entries = Object.entries(this.groups) as Array<[Version.LiteralSemVer, Codemod.List]>;\n\n return entries\n .filter(([version]) => range.test(version))\n .map<Codemod.VersionedCollection>(([version, codemods]) => ({\n version: semVerFactory(version),\n codemods,\n }));\n }\n\n findByVersion(version: Version.SemVer) {\n const literalVersion = version.raw as Version.LiteralSemVer;\n const codemods = this.groups[literalVersion];\n\n return codemods ?? [];\n }\n\n findAll() {\n const entries = Object.entries(this.groups);\n\n return entries.map<Codemod.VersionedCollection>(([version, codemods]) => ({\n version: semVerFactory(version),\n codemods,\n }));\n }\n\n private refreshAvailableVersions() {\n this.versions = fse\n .readdirSync(this.cwd) // Only keep root directories\n .filter((filename) => fse.statSync(path.join(this.cwd, filename)).isDirectory())\n // Paths should be valid semver\n .filter((filename): filename is Version.LiteralSemVer => semver.valid(filename) !== null)\n // Transform files names to SemVer instances\n .map<Version.SemVer>((version) => semVerFactory(version))\n // Sort versions in ascending order\n .sort(semver.compare);\n\n return this;\n }\n\n private refreshAvailableFiles() {\n this.groups = {};\n\n for (const version of this.versions) {\n this.refreshAvailableFilesForVersion(version);\n }\n }\n\n private refreshAvailableFilesForVersion(version: Version.SemVer) {\n const literalVersion = version.raw as Version.LiteralSemVer;\n const versionDirectory = path.join(this.cwd, literalVersion);\n\n // Ignore obsolete versions\n if (!fse.existsSync(versionDirectory)) {\n return;\n }\n\n this.groups[literalVersion] = fse\n .readdirSync(versionDirectory)\n // Make sure the filenames are valid codemod files\n .filter((filename) => fse.statSync(path.join(versionDirectory, filename)).isFile())\n .filter((filename) => constants.CODEMOD_FILE_REGEXP.test(filename))\n // Transform the filenames into Codemod instances\n .map((filename) => {\n const kind = parseCodemodKindFromFilename(filename);\n const baseDirectory = this.cwd;\n\n return codemodFactory({ kind, baseDirectory, version, filename });\n });\n }\n}\n\nexport const parseCodemodKindFromFilename = (filename: string): Codemod.Kind => {\n const kind = filename.split('.').at(-2) as Codemod.Kind | undefined;\n\n assert(kind !== undefined);\n assert(constants.CODEMOD_ALLOWED_SUFFIXES.includes(kind));\n\n return kind;\n};\n\nexport const codemodRepositoryFactory = (cwd: string) => new CodemodRepository(cwd);\n","import path from 'node:path';\n\nexport const INTERNAL_CODEMODS_DIRECTORY = path.join(\n __dirname,\n '..',\n '..',\n 'resources',\n 'codemods'\n);\n","import {\n codemodRepositoryFactory,\n constants as codemodRepositoryConstants,\n} from '../codemod-repository';\nimport { unknownToError } from '../error';\nimport * as f from '../format';\n\nimport type { Logger } from '../logger';\nimport type { Project } from '../project';\nimport type { UpgradeReport } from '../upgrader';\nimport type { CodemodRunnerInterface, CodemodRunnerReport, SelectCodemodsCallback } from './types';\nimport type { Version } from '../version';\n\nexport class CodemodRunner implements CodemodRunnerInterface {\n private readonly project: Project;\n\n private range?: Version.Range;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private selectCodemodsCallback: SelectCodemodsCallback | null;\n\n constructor(project: Project, range?: Version.Range) {\n this.project = project;\n this.range = range;\n\n this.isDry = false;\n\n this.logger = null;\n this.selectCodemodsCallback = null;\n }\n\n setRange(range: Version.Range) {\n this.range = range;\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onSelectCodemods(callback: SelectCodemodsCallback | null) {\n this.selectCodemodsCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n async run(codemodsDirectory?: string): Promise<CodemodRunnerReport> {\n const repository = codemodRepositoryFactory(\n codemodsDirectory ?? codemodRepositoryConstants.INTERNAL_CODEMODS_DIRECTORY\n );\n\n // Make sure we have access to the latest snapshots of codemods on the system\n repository.refresh();\n\n const allVersionedCodemods = this.range\n ? repository.findByRange(this.range)\n : repository.findAll();\n\n // If a selection callback is set, use it, else keep every codemods\n const versionedCodemods = this.selectCodemodsCallback\n ? await this.selectCodemodsCallback(allVersionedCodemods)\n : allVersionedCodemods;\n\n const hasCodemodsToRun = versionedCodemods.length > 0;\n\n if (!hasCodemodsToRun) {\n if (this.range) {\n this.logger?.debug(`Found no codemods to run for ${f.versionRange(this.range)}`);\n } else {\n this.logger?.debug(`Found no codemods to run`);\n }\n return successReport();\n }\n\n if (this.range) {\n this.logger?.debug(\n `Found codemods for ${f.highlight(versionedCodemods.length)} version(s) using ${this.range}`\n );\n } else {\n this.logger?.debug(`Found codemods for ${f.highlight(versionedCodemods.length)} version(s)`);\n }\n\n versionedCodemods.forEach(({ version, codemods }) =>\n this.logger?.debug(`- ${f.version(version)} (${codemods.length})`)\n );\n\n // Flatten the collection to a single list of codemods, the original list should already be sorted\n const codemods = versionedCodemods.map(({ codemods }) => codemods).flat();\n\n try {\n const reports = await this.project.runCodemods(codemods, { dry: this.isDry });\n this.logger?.raw(f.reports(reports));\n } catch (e: unknown) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n}\n\nexport const codemodRunnerFactory = (project: Project, range?: Version.Range) => {\n return new CodemodRunner(project, range);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n","import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { AppProject } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: AppProject;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: AppProject, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.1\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n // We need to refresh the project files to make sure we have\n // the latest version of each file (including package.json) for the next steps\n this.logger?.debug('Refreshing project information...');\n this.project.refresh();\n\n this.logger?.info(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug(`Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`);\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug(`Skipping dependencies installation (${chalk.italic('dry mode')}`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n codemodRunner.dry(this.isDry);\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion | undefined => {\n // Semver\n if (isSemverInstance(target)) {\n return npmPackage.findVersion(target);\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n return npmVersionsMatches.at(-1);\n }\n\n return undefined;\n};\n\nexport const upgraderFactory = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const targetedNPMVersion = resolveNPMTarget(project, target, npmPackage);\n if (!targetedNPMVersion) {\n throw new Error(`Couldn't find a matching version in the NPM registry for \"${target}\"`);\n }\n\n const semverTarget = semVerFactory(targetedNPMVersion.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already on ${f.version(semverTarget)}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n","export const STRAPI_PACKAGE_NAME = '@strapi/strapi';\n","export const NPM_REGISTRY_URL = 'https://registry.npmjs.org';\n","import assert from 'node:assert';\nimport semver from 'semver';\n\nimport * as constants from './constants';\nimport { isLiteralSemVer } from '../version';\n\nimport type { Package as PackageInterface, NPMPackage, NPMPackageVersion } from './types';\nimport type { Version } from '../version';\n\nexport class Package implements PackageInterface {\n name: string;\n\n packageURL: string;\n\n private npmPackage: NPMPackage | null;\n\n constructor(name: string) {\n this.name = name;\n this.packageURL = `${constants.NPM_REGISTRY_URL}/${name}`;\n this.npmPackage = null;\n }\n\n get isLoaded() {\n return this.npmPackage !== null;\n }\n\n private assertPackageIsLoaded(npmPackage: NPMPackage | null): asserts npmPackage is NPMPackage {\n assert(this.isLoaded, 'The package is not loaded yet');\n }\n\n getVersionsDict() {\n this.assertPackageIsLoaded(this.npmPackage);\n\n return this.npmPackage.versions;\n }\n\n getVersionsAsList() {\n this.assertPackageIsLoaded(this.npmPackage);\n\n return Object.values(this.npmPackage.versions);\n }\n\n findVersionsInRange(range: Version.Range) {\n const versions = this.getVersionsAsList();\n\n return (\n versions\n // Only select versions matching the upgrade range\n .filter((v) => range.test(v.version))\n // Only select supported version format (x.x.x)\n .filter((v) => isLiteralSemVer(v.version))\n // Sort in ascending order\n .sort((v1, v2) => semver.compare(v1.version, v2.version))\n );\n }\n\n findVersion(version: Version.SemVer): NPMPackageVersion | undefined {\n const versions = this.getVersionsAsList();\n\n return versions.find((npmVersion) => semver.eq(npmVersion.version, version));\n }\n\n async refresh() {\n const response = await fetch(this.packageURL);\n\n // TODO: Use a validation library to make sure the response structure is correct\n assert(response.ok, `Request failed for ${this.packageURL}`);\n\n this.npmPackage = await response.json();\n\n return this;\n }\n\n versionExists(version: Version.SemVer) {\n return this.findVersion(version) !== undefined;\n }\n}\n\nexport const npmPackageFactory = (name: string) => new Package(name);\n","import path from 'node:path';\n\nimport * as requirements from './requirements';\nimport { timerFactory } from '../../modules/timer';\nimport { upgraderFactory, constants as upgraderConstants } from '../../modules/upgrader';\nimport { npmPackageFactory } from '../../modules/npm';\nimport { projectFactory, isAppProject } from '../../modules/project';\nimport * as f from '../../modules/format';\nimport { Version } from '../../modules/version';\n\nimport type { UpgradeOptions } from './types';\n\nexport const upgrade = async (options: UpgradeOptions) => {\n const timer = timerFactory();\n const { logger, codemodsTarget } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = path.resolve(options.cwd ?? process.cwd());\n\n const project = projectFactory(cwd);\n\n if (!isAppProject(project)) {\n throw new Error(\n `The \"${options.target}\" upgrade can only be run on a Strapi project; for plugins, please use \"codemods\".`\n );\n }\n const npmPackage = npmPackageFactory(upgraderConstants.STRAPI_PACKAGE_NAME);\n // Load all versions from the registry\n await npmPackage.refresh();\n\n const upgrader = upgraderFactory(project, options.target, npmPackage)\n .dry(options.dry ?? false)\n .onConfirm(options.confirm ?? null)\n .setLogger(logger);\n\n // Manually override the target version for codemods if it's explicitly provided\n if (codemodsTarget !== undefined) {\n upgrader.overrideCodemodsTarget(codemodsTarget);\n }\n\n // We're not adding the same requirements (e.g. \"REQUIRE_LATEST_FOR_CURRENT_MAJOR\") when manually targeting a\n // major upgrade (using a semver) as it's implied that the user knows what they're doing\n if (options.target === Version.ReleaseType.Major) {\n upgrader\n .addRequirement(requirements.major.REQUIRE_AVAILABLE_NEXT_MAJOR)\n .addRequirement(requirements.major.REQUIRE_LATEST_FOR_CURRENT_MAJOR);\n }\n\n // Make sure the git repository is in an optimal state before running the upgrade\n // Mainly used to ease rollbacks in case the upgrade is corrupted\n upgrader.addRequirement(requirements.common.REQUIRE_GIT.asOptional());\n\n // Actually run the upgrade process once configured\n // The response contains information about the final status (success/error)\n const upgradeReport = await upgrader.upgrade();\n\n if (!upgradeReport.success) {\n throw upgradeReport.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${f.durationMs(timer.elapsedMs)}`);\n};\n","import path from 'node:path';\n\nimport { timerFactory } from '../../modules/timer';\nimport { isAppProject, projectFactory } from '../../modules/project';\nimport { codemodRunnerFactory } from '../../modules/codemod-runner';\nimport { Version, isSemverInstance, rangeFactory } from '../../modules/version';\n\nimport type { RunCodemodsOptions } from './types';\n\nexport const codemods = async (options: RunCodemodsOptions) => {\n const timer = timerFactory();\n const { logger } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = path.resolve(options.cwd ?? process.cwd());\n\n const project = projectFactory(cwd);\n const range = isAppProject(project)\n ? getRangeFromTarget(project.strapiVersion, options.target)\n : undefined;\n\n const codemodRunner = codemodRunnerFactory(project, range)\n .dry(options.dry ?? false)\n .onSelectCodemods(options.selectCodemods ?? null)\n .setLogger(logger);\n\n const executionReport = await codemodRunner.run();\n\n if (!executionReport.success) {\n throw executionReport.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${timer.elapsedMs}`);\n};\n\nconst getRangeFromTarget = (\n currentVersion: Version.SemVer,\n target: Version.ReleaseType | Version.LiteralSemVer\n) => {\n if (isSemverInstance(target)) {\n return rangeFactory(target);\n }\n\n const { major, minor, patch } = currentVersion;\n\n switch (target) {\n case Version.ReleaseType.Major:\n return rangeFactory(`${major}`);\n case Version.ReleaseType.Minor:\n return rangeFactory(`${major}.${minor}`);\n case Version.ReleaseType.Patch:\n return rangeFactory(`${major}.${minor}.${patch}`);\n default:\n throw new Error(`Invalid target set: ${target}`);\n }\n};\n","import chalk from 'chalk';\n\nimport type { Logger as LoggerInterface, LoggerOptions } from './types';\n\nexport class Logger implements LoggerInterface {\n isDebug: boolean;\n\n isSilent: boolean;\n\n private nbErrorsCalls: number;\n\n private nbWarningsCalls: number;\n\n constructor(options: LoggerOptions = {}) {\n // Set verbosity options\n this.isDebug = options.debug ?? false;\n this.isSilent = options.silent ?? false;\n\n // Initialize counters\n this.nbErrorsCalls = 0;\n this.nbWarningsCalls = 0;\n }\n\n private get isNotSilent(): boolean {\n return !this.isSilent;\n }\n\n get errors(): number {\n return this.nbErrorsCalls;\n }\n\n get warnings(): number {\n return this.nbWarningsCalls;\n }\n\n get stdout(): (NodeJS.WriteStream & { fd: 1 }) | undefined {\n return this.isSilent ? undefined : process.stdout;\n }\n\n get stderr(): (NodeJS.WriteStream & { fd: 2 }) | undefined {\n return this.isSilent ? undefined : process.stderr;\n }\n\n setDebug(debug: boolean): this {\n this.isDebug = debug;\n return this;\n }\n\n setSilent(silent: boolean): this {\n this.isSilent = silent;\n return this;\n }\n\n debug(...args: unknown[]): this {\n const isDebugEnabled = this.isNotSilent && this.isDebug;\n\n if (isDebugEnabled) {\n console.log(chalk.cyan(`[DEBUG]\\t[${nowAsISO()}]`), ...args);\n }\n\n return this;\n }\n\n error(...args: unknown[]): this {\n this.nbErrorsCalls += 1;\n\n if (this.isNotSilent) {\n console.error(chalk.red(`[ERROR]\\t[${nowAsISO()}]`), ...args);\n }\n\n return this;\n }\n\n info(...args: unknown[]): this {\n if (this.isNotSilent) {\n console.info(chalk.blue(`[INFO]\\t[${new Date().toISOString()}]`), ...args);\n }\n\n return this;\n }\n\n raw(...args: unknown[]): this {\n if (this.isNotSilent) {\n console.log(...args);\n }\n\n return this;\n }\n\n warn(...args: unknown[]): this {\n this.nbWarningsCalls += 1;\n\n if (this.isNotSilent) {\n console.warn(chalk.yellow(`[WARN]\\t[${new Date().toISOString()}]`), ...args);\n }\n\n return this;\n }\n}\n\nconst nowAsISO = () => new Date().toISOString();\n\nexport const loggerFactory = (options: LoggerOptions = {}) => new Logger(options);\n","import type { Codemod } from '../codemod';\n\nimport type { CodemodReport, Report } from './types';\n\nexport const codemodReportFactory = (codemod: Codemod.Codemod, report: Report): CodemodReport => ({\n codemod,\n report,\n});\n\nexport const reportFactory = (report: Report): Report => ({ ...report });\n"],"names":["path","ReleaseType","version","Version.ReleaseType","jscodeshift","codemods","reports","constants.PROJECT_DEFAULT_JSON_EXTENSIONS","constants.PROJECT_DEFAULT_CODE_EXTENSIONS","constants.PROJECT_PACKAGE_JSON","constants.PROJECT_DEFAULT_ALLOWED_ROOT_PATHS","constants.PROJECT_DEFAULT_ALLOWED_EXTENSIONS","constants.PROJECT_DEFAULT_PATTERNS","constants.STRAPI_DEPENDENCY_NAME","isValidSemVer","timerConstants.ONE_SECOND_MS","constants.CODEMOD_CODE_SUFFIX","constants.CODEMOD_EXTENSION","constants.CODEMOD_JSON_SUFFIX","constants.CODEMOD_FILE_REGEXP","constants.CODEMOD_ALLOWED_SUFFIXES","codemodRepositoryConstants.INTERNAL_CODEMODS_DIRECTORY","f.versionRange","successReport","f.highlight","f.version","f.reports","erroredReport","f.upgradeStep","projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX","constants.NPM_REGISTRY_URL","upgraderConstants.STRAPI_PACKAGE_NAME","requirements.major.REQUIRE_AVAILABLE_NEXT_MAJOR","requirements.major.REQUIRE_LATEST_FOR_CURRENT_MAJOR","requirements.common.REQUIRE_GIT","f.durationMs"],"mappings":"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"}
|