@strapi/upgrade 5.0.0-beta.1 → 5.0.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/dist/cli.js +1452 -5
  2. package/dist/cli.js.map +1 -1
  3. package/dist/index.js +228 -92
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.mjs +229 -93
  6. package/dist/index.mjs.map +1 -1
  7. package/dist/modules/codemod/codemod.d.ts +4 -2
  8. package/dist/modules/codemod/codemod.d.ts.map +1 -1
  9. package/dist/modules/codemod/types.d.ts +8 -1
  10. package/dist/modules/codemod/types.d.ts.map +1 -1
  11. package/dist/modules/codemod-repository/constants.d.ts.map +1 -1
  12. package/dist/modules/codemod-repository/repository.d.ts +5 -5
  13. package/dist/modules/codemod-repository/repository.d.ts.map +1 -1
  14. package/dist/modules/codemod-repository/types.d.ts +7 -3
  15. package/dist/modules/codemod-repository/types.d.ts.map +1 -1
  16. package/dist/modules/codemod-runner/codemod-runner.d.ts +6 -3
  17. package/dist/modules/codemod-runner/codemod-runner.d.ts.map +1 -1
  18. package/dist/modules/codemod-runner/index.d.ts +1 -0
  19. package/dist/modules/codemod-runner/index.d.ts.map +1 -1
  20. package/dist/modules/codemod-runner/types.d.ts +1 -0
  21. package/dist/modules/codemod-runner/types.d.ts.map +1 -1
  22. package/dist/modules/format/formats.d.ts +5 -0
  23. package/dist/modules/format/formats.d.ts.map +1 -1
  24. package/dist/modules/project/project.d.ts +1 -1
  25. package/dist/modules/project/project.d.ts.map +1 -1
  26. package/dist/modules/project/types.d.ts +1 -0
  27. package/dist/modules/project/types.d.ts.map +1 -1
  28. package/dist/modules/project/utils.d.ts +1 -1
  29. package/dist/modules/project/utils.d.ts.map +1 -1
  30. package/dist/modules/upgrader/upgrader.d.ts.map +1 -1
  31. package/dist/modules/version/range.d.ts +2 -0
  32. package/dist/modules/version/range.d.ts.map +1 -1
  33. package/dist/tasks/codemods/index.d.ts +2 -1
  34. package/dist/tasks/codemods/index.d.ts.map +1 -1
  35. package/dist/tasks/codemods/list-codemods.d.ts +3 -0
  36. package/dist/tasks/codemods/list-codemods.d.ts.map +1 -0
  37. package/dist/tasks/codemods/run-codemods.d.ts +3 -0
  38. package/dist/tasks/codemods/run-codemods.d.ts.map +1 -0
  39. package/dist/tasks/codemods/types.d.ts +9 -3
  40. package/dist/tasks/codemods/types.d.ts.map +1 -1
  41. package/dist/tasks/codemods/utils.d.ts +6 -0
  42. package/dist/tasks/codemods/utils.d.ts.map +1 -0
  43. package/dist/tasks/index.d.ts +1 -1
  44. package/dist/tasks/index.d.ts.map +1 -1
  45. package/package.json +7 -7
  46. package/resources/codemods/5.0.0/entity-service-document-service.code.ts +374 -0
  47. package/resources/codemods/5.0.0/strapi-public-interface.code.ts +126 -0
  48. package/resources/codemods/5.0.0/utils-public-interface.code.ts +320 -0
  49. package/dist/_chunks/codemod-runner-aVWS9EOj.js +0 -798
  50. package/dist/_chunks/codemod-runner-aVWS9EOj.js.map +0 -1
  51. package/dist/_chunks/codemods-FxCTNGki.js +0 -105
  52. package/dist/_chunks/codemods-FxCTNGki.js.map +0 -1
  53. package/dist/_chunks/index-qYtax-pz.js +0 -103
  54. package/dist/_chunks/index-qYtax-pz.js.map +0 -1
  55. package/dist/_chunks/upgrade-_IPNaAR-.js +0 -361
  56. package/dist/_chunks/upgrade-_IPNaAR-.js.map +0 -1
  57. package/dist/tasks/codemods/codemods.d.ts +0 -3
  58. package/dist/tasks/codemods/codemods.d.ts.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"codemod-runner-aVWS9EOj.js","sources":["../../src/modules/version/range.ts","../../src/modules/logger/logger.ts","../../src/cli/errors.ts","../../src/modules/requirement/requirement.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/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"],"sourcesContent":["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 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 chalk from 'chalk';\n\nexport const handleError = (err: unknown, isSilent: boolean) => {\n if (!isSilent) {\n console.error(\n chalk.red(`[ERROR]\\t[${new Date().toISOString()}]`),\n err instanceof Error ? err.message : err\n );\n }\n\n process.exit(1);\n};\n","import 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 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","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"],"names":["semver","Version.ReleaseType","isSemverInstance","isSemVerReleaseType","chalk","simpleGit","cloneDeep","path","get","has","merge","set","omit","fse","glob","jscodeshift","register","module","assert","isEqual","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","version","constants.STRAPI_DEPENDENCY_NAME","isValidSemVer","isLiteralSemVer","semVerFactory","CliTable3","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","f.highlight","codemods","f.version","f.reports"],"mappings":"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"}
@@ -1,105 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const prompts = require("prompts");
4
- const codemodRunner = require("./codemod-runner-aVWS9EOj.js");
5
- require("semver");
6
- const index = require("./index-qYtax-pz.js");
7
- const path = require("node:path");
8
- require("chalk");
9
- require("@strapi/utils");
10
- require("lodash/fp");
11
- require("fs-extra");
12
- require("node:assert");
13
- require("glob");
14
- require("jscodeshift/src/Runner");
15
- require("esbuild-register/dist/node");
16
- require("cli-table3");
17
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
18
- const prompts__default = /* @__PURE__ */ _interopDefault(prompts);
19
- const path__default = /* @__PURE__ */ _interopDefault(path);
20
- const codemods$1 = async (options) => {
21
- const timer = codemodRunner.timerFactory();
22
- const { logger } = options;
23
- const cwd = path__default.default.resolve(options.cwd ?? process.cwd());
24
- const project = codemodRunner.projectFactory(cwd);
25
- const range = codemodRunner.isAppProject(project) ? getRangeFromTarget(project.strapiVersion, options.target) : void 0;
26
- const codemodRunner$1 = codemodRunner.codemodRunnerFactory(project, range).dry(options.dry ?? false).onSelectCodemods(options.selectCodemods ?? null).setLogger(logger);
27
- const executionReport = await codemodRunner$1.run();
28
- if (!executionReport.success) {
29
- throw executionReport.error;
30
- }
31
- timer.stop();
32
- logger.info(`Completed in ${timer.elapsedMs}`);
33
- };
34
- const getRangeFromTarget = (currentVersion, target) => {
35
- if (index.isSemverInstance(target)) {
36
- return codemodRunner.rangeFactory(target);
37
- }
38
- const { major, minor, patch } = currentVersion;
39
- switch (target) {
40
- case index.ReleaseType.Major:
41
- return codemodRunner.rangeFactory(`${major}`);
42
- case index.ReleaseType.Minor:
43
- return codemodRunner.rangeFactory(`${major}.${minor}`);
44
- case index.ReleaseType.Patch:
45
- return codemodRunner.rangeFactory(`${major}.${minor}.${patch}`);
46
- default:
47
- throw new Error(`Invalid target set: ${target}`);
48
- }
49
- };
50
- const codemods = async (options) => {
51
- try {
52
- const { silent, debug } = options;
53
- const logger = codemodRunner.loggerFactory({ silent, debug });
54
- logger.warn(
55
- "Please make sure you've created a backup of your codebase and files before running the codemods"
56
- );
57
- const confirm = async (message) => {
58
- const { confirm: confirm2 } = await prompts__default.default({
59
- name: "confirm",
60
- type: "confirm",
61
- message
62
- });
63
- return confirm2 ?? false;
64
- };
65
- const selectCodemods = async (codemods2) => {
66
- const selectableCodemods = codemods2.map(
67
- ({ version, codemods: codemods3 }) => codemods3.map((codemod) => ({
68
- title: `(${version}) ${codemod.format()}`,
69
- value: codemod,
70
- selected: true
71
- }))
72
- ).flat();
73
- if (selectableCodemods.length === 0) {
74
- logger.info("No codemods to run");
75
- return [];
76
- }
77
- const { selectedCodemods } = await prompts__default.default({
78
- type: "autocompleteMultiselect",
79
- name: "selectedCodemods",
80
- message: "Choose the codemods you would like to run:",
81
- choices: selectableCodemods
82
- });
83
- if (!selectedCodemods || selectedCodemods.length === 0) {
84
- logger.info("No codemods selected");
85
- return [];
86
- }
87
- return selectedCodemods.map((codemod) => ({
88
- version: codemod.version,
89
- codemods: [codemod]
90
- }));
91
- };
92
- await codemods$1({
93
- logger,
94
- confirm,
95
- selectCodemods,
96
- dry: options.dry,
97
- cwd: options.projectPath,
98
- target: index.ReleaseType.Major
99
- });
100
- } catch (err) {
101
- codemodRunner.handleError(err, options.silent);
102
- }
103
- };
104
- exports.codemods = codemods;
105
- //# sourceMappingURL=codemods-FxCTNGki.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"codemods-FxCTNGki.js","sources":["../../src/tasks/codemods/codemods.ts","../../src/cli/commands/codemods.ts"],"sourcesContent":["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 prompts from 'prompts';\nimport { loggerFactory } from '../../modules/logger';\nimport { Version } from '../../modules/version';\nimport { handleError } from '../errors';\nimport * as tasks from '../../tasks';\n\nimport type { CodemodsCommand } from '../types';\nimport type { Codemod } from '../../modules/codemod';\n\nexport const codemods: CodemodsCommand = async (options) => {\n try {\n const { silent, debug } = options;\n const logger = loggerFactory({ silent, debug });\n\n logger.warn(\n \"Please make sure you've created a backup of your codebase and files before running the codemods\"\n );\n\n const confirm = async (message: string) => {\n const { confirm } = await prompts({\n name: 'confirm',\n type: 'confirm',\n message,\n });\n\n // If confirm is undefined (Ctrl + C), default to false\n return confirm ?? false;\n };\n\n const selectCodemods = async (codemods: Codemod.VersionedCollection[]) => {\n const selectableCodemods = codemods\n .map(({ version, codemods }) =>\n codemods.map((codemod) => ({\n title: `(${version}) ${codemod.format()}`,\n value: codemod,\n selected: true,\n }))\n )\n .flat();\n\n if (selectableCodemods.length === 0) {\n logger.info('No codemods to run');\n return [];\n }\n\n const { selectedCodemods }: { selectedCodemods: Codemod.Codemod[] } = await prompts({\n type: 'autocompleteMultiselect',\n name: 'selectedCodemods',\n message: 'Choose the codemods you would like to run:',\n choices: selectableCodemods,\n });\n\n if (!selectedCodemods || selectedCodemods.length === 0) {\n logger.info('No codemods selected');\n return [];\n }\n\n return selectedCodemods.map<Codemod.VersionedCollection>((codemod) => ({\n version: codemod.version,\n codemods: [codemod],\n }));\n };\n\n await tasks.codemods({\n logger,\n confirm,\n selectCodemods,\n dry: options.dry,\n cwd: options.projectPath,\n target: Version.ReleaseType.Major,\n });\n } catch (err) {\n handleError(err, options.silent);\n }\n};\n"],"names":["codemods","timerFactory","path","projectFactory","isAppProject","codemodRunner","codemodRunnerFactory","isSemverInstance","rangeFactory","Version.ReleaseType","loggerFactory","confirm","prompts","tasks.codemods","handleError"],"mappings":"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"}
@@ -1,103 +0,0 @@
1
- "use strict";
2
- const os = require("os");
3
- const chalk = require("chalk");
4
- const commander = require("commander");
5
- const semver = require("semver");
6
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
- const os__default = /* @__PURE__ */ _interopDefault(os);
8
- const chalk__default = /* @__PURE__ */ _interopDefault(chalk);
9
- const semver__default = /* @__PURE__ */ _interopDefault(semver);
10
- const version = "5.0.0-beta.1";
11
- var ReleaseType = /* @__PURE__ */ ((ReleaseType2) => {
12
- ReleaseType2["Major"] = "major";
13
- ReleaseType2["Minor"] = "minor";
14
- ReleaseType2["Patch"] = "patch";
15
- return ReleaseType2;
16
- })(ReleaseType || {});
17
- const semVerFactory = (version2) => {
18
- return new semver__default.default.SemVer(version2);
19
- };
20
- const isLiteralSemVer = (str) => {
21
- const tokens = str.split(".");
22
- return tokens.length === 3 && tokens.every((token) => !Number.isNaN(+token) && Number.isInteger(+token));
23
- };
24
- const isValidSemVer = (str) => semver__default.default.valid(str) !== null;
25
- const isSemverInstance = (value) => {
26
- return value instanceof semver__default.default.SemVer;
27
- };
28
- const isSemVerReleaseType = (str) => {
29
- return Object.values(ReleaseType).includes(str);
30
- };
31
- const projectPathOption = new commander.Option(
32
- "-p, --project-path <project-path>",
33
- "Path to the Strapi project"
34
- );
35
- const dryOption = new commander.Option(
36
- "-n, --dry",
37
- "Simulate the upgrade without updating any files"
38
- ).default(false);
39
- const debugOption = new commander.Option("-d, --debug", "Get more logs in debug mode").default(false);
40
- const silentOption = new commander.Option("-s, --silent", "Don't log anything").default(false);
41
- const automaticConfirmationOption = new commander.Option(
42
- "-y, --yes",
43
- 'Automatically answer "yes" to any prompts that the CLI might print on the command line.'
44
- ).default(false);
45
- const addReleaseUpgradeCommand = (releaseType, description) => {
46
- commander.program.command(releaseType).description(description).addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).addOption(automaticConfirmationOption).action(async (options) => {
47
- const { upgrade } = await Promise.resolve().then(() => require("./upgrade-_IPNaAR-.js"));
48
- return upgrade({ ...options, target: releaseType });
49
- });
50
- };
51
- addReleaseUpgradeCommand(
52
- ReleaseType.Major,
53
- "Upgrade to the next available major version of Strapi"
54
- );
55
- addReleaseUpgradeCommand(
56
- ReleaseType.Minor,
57
- "Upgrade to the latest minor and patch version of Strapi for the current major"
58
- );
59
- addReleaseUpgradeCommand(
60
- ReleaseType.Patch,
61
- "Upgrade to latest patch version of Strapi for the current major and minor"
62
- );
63
- commander.program.command("codemods").description(
64
- "Run a set of available codemods for the selected target version without updating the Strapi dependencies"
65
- ).addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).action(async (options) => {
66
- const { codemods } = await Promise.resolve().then(() => require("./codemods-FxCTNGki.js"));
67
- return codemods(options);
68
- });
69
- commander.program.command("to <target>", { hidden: true }).description("Upgrade to the specified version of Strapi").addOption(projectPathOption).addOption(dryOption).addOption(debugOption).addOption(silentOption).addOption(automaticConfirmationOption).addOption(
70
- new commander.Option(
71
- "-c, --codemods-target <codemodsTarget>",
72
- "Use a custom target for the codemods execution. Useful when targeting pre-releases"
73
- ).argParser((codemodsTarget) => {
74
- if (!isLiteralSemVer(codemodsTarget)) {
75
- throw new commander.InvalidArgumentError(
76
- `Expected a version with the following format: "<number>.<number>.<number>"`
77
- );
78
- }
79
- return semVerFactory(codemodsTarget);
80
- })
81
- ).action(async (target, options) => {
82
- if (!isValidSemVer(target)) {
83
- console.error(`Invalid target supplied, expected a valid semver but got "${target}"`);
84
- process.exit(1);
85
- }
86
- const { upgrade } = await Promise.resolve().then(() => require("./upgrade-_IPNaAR-.js"));
87
- return upgrade({ ...options, target: semVerFactory(target) });
88
- });
89
- commander.program.usage("<command> [options]").on("command:*", ([invalidCmd]) => {
90
- console.error(
91
- chalk__default.default.red(
92
- `[ERROR] Invalid command: ${invalidCmd}.${os__default.default.EOL} See --help for a list of available commands.`
93
- )
94
- );
95
- process.exit(1);
96
- }).helpOption("-h, --help", "Print command line options").addHelpCommand("help [command]", "Print options for a specific command").version(version).parse(process.argv);
97
- exports.ReleaseType = ReleaseType;
98
- exports.isLiteralSemVer = isLiteralSemVer;
99
- exports.isSemVerReleaseType = isSemVerReleaseType;
100
- exports.isSemverInstance = isSemverInstance;
101
- exports.isValidSemVer = isValidSemVer;
102
- exports.semVerFactory = semVerFactory;
103
- //# sourceMappingURL=index-qYtax-pz.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index-qYtax-pz.js","sources":["../../src/modules/version/types.ts","../../src/modules/version/semver.ts","../../src/cli/index.ts"],"sourcesContent":["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 os from 'os';\nimport chalk from 'chalk';\nimport { InvalidArgumentError, Option, program } from 'commander';\n\nimport { version as packageJSONVersion } from '../../package.json';\nimport { isLiteralSemVer, isValidSemVer, semVerFactory, Version } from '../modules/version';\n\nimport type { CLICodemodsOptions, CLIUpgradeOptions, CLIUpgradeToOptions } from './types';\n\nconst projectPathOption = new Option(\n '-p, --project-path <project-path>',\n 'Path to the Strapi project'\n);\n\nconst dryOption = new Option(\n '-n, --dry',\n 'Simulate the upgrade without updating any files'\n).default(false);\n\nconst debugOption = new Option('-d, --debug', 'Get more logs in debug mode').default(false);\n\nconst silentOption = new Option('-s, --silent', \"Don't log anything\").default(false);\n\nconst automaticConfirmationOption = new Option(\n '-y, --yes',\n 'Automatically answer \"yes\" to any prompts that the CLI might print on the command line.'\n).default(false);\n\nconst addReleaseUpgradeCommand = (releaseType: Version.ReleaseType, description: string) => {\n program\n .command(releaseType)\n .description(description)\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(automaticConfirmationOption)\n .action(async (options: CLIUpgradeOptions) => {\n const { upgrade } = await import('./commands/upgrade.js');\n\n return upgrade({ ...options, target: releaseType });\n });\n};\n\naddReleaseUpgradeCommand(\n Version.ReleaseType.Major,\n 'Upgrade to the next available major version of Strapi'\n);\n\naddReleaseUpgradeCommand(\n Version.ReleaseType.Minor,\n 'Upgrade to the latest minor and patch version of Strapi for the current major'\n);\n\naddReleaseUpgradeCommand(\n Version.ReleaseType.Patch,\n 'Upgrade to latest patch version of Strapi for the current major and minor'\n);\n\nprogram\n .command('codemods')\n .description(\n 'Run a set of available codemods for the selected target version without updating the Strapi dependencies'\n )\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .action(async (options: CLICodemodsOptions) => {\n const { codemods } = await import('./commands/codemods.js');\n return codemods(options);\n });\n\n// Defines the 'to' command to upgrade to a specific Strapi version,\n// with various options including custom codemod target.\n// This command is meant for internal use for now (and is thus hidden)\nprogram\n .command('to <target>', { hidden: true })\n .description('Upgrade to the specified version of Strapi')\n .addOption(projectPathOption)\n .addOption(dryOption)\n .addOption(debugOption)\n .addOption(silentOption)\n .addOption(automaticConfirmationOption)\n .addOption(\n new Option(\n '-c, --codemods-target <codemodsTarget>',\n 'Use a custom target for the codemods execution. Useful when targeting pre-releases'\n ).argParser((codemodsTarget) => {\n if (!isLiteralSemVer(codemodsTarget)) {\n throw new InvalidArgumentError(\n `Expected a version with the following format: \"<number>.<number>.<number>\"`\n );\n }\n\n return semVerFactory(codemodsTarget);\n })\n )\n .action(async (target: string, options: CLIUpgradeToOptions) => {\n if (!isValidSemVer(target)) {\n console.error(`Invalid target supplied, expected a valid semver but got \"${target}\"`);\n process.exit(1);\n }\n\n const { upgrade } = await import('./commands/upgrade.js');\n\n return upgrade({ ...options, target: semVerFactory(target) });\n });\n\nprogram\n .usage('<command> [options]')\n .on('command:*', ([invalidCmd]) => {\n console.error(\n chalk.red(\n `[ERROR] Invalid command: ${invalidCmd}.${os.EOL} See --help for a list of available commands.`\n )\n );\n\n process.exit(1);\n })\n .helpOption('-h, --help', 'Print command line options')\n .addHelpCommand('help [command]', 'Print options for a specific command')\n .version(packageJSONVersion)\n .parse(process.argv);\n"],"names":["ReleaseType","version","semver","Version.ReleaseType","Option","program","InvalidArgumentError","chalk","os","packageJSONVersion"],"mappings":";;;;;;;;;;AAWY,IAAA,gCAAAA,iBAAL;AACLA,eAAA,OAAQ,IAAA;AACRA,eAAA,OAAQ,IAAA;AACRA,eAAA,OAAQ,IAAA;AAHEA,SAAAA;AAAA,GAAA,eAAA,CAAA,CAAA;ACPC,MAAA,gBAAgB,CAACC,aAAoC;AACzD,SAAA,IAAIC,gBAAO,QAAA,OAAOD,QAAO;AAClC;AAEa,MAAA,kBAAkB,CAAC,QAA8C;AACtE,QAAA,SAAS,IAAI,MAAM,GAAG;AAE5B,SACE,OAAO,WAAW,KAClB,OAAO,MAAM,CAAC,UAAU,CAAC,OAAO,MAAM,CAAC,KAAK,KAAK,OAAO,UAAU,CAAC,KAAK,CAAC;AAE7E;AAEO,MAAM,gBAAgB,CAAC,QAAgBC,gBAAAA,QAAO,MAAM,GAAG,MAAM;AAEvD,MAAA,mBAAmB,CAAC,UAA2C;AAC1E,SAAO,iBAAiBA,gBAAO,QAAA;AACjC;AAEa,MAAA,sBAAsB,CAAC,QAA4C;AAC9E,SAAO,OAAO,OAAOC,WAAmB,EAAE,SAAS,GAA0B;AAC/E;AChBA,MAAM,oBAAoB,IAAIC,UAAA;AAAA,EAC5B;AAAA,EACA;AACF;AAEA,MAAM,YAAY,IAAIA,UAAA;AAAA,EACpB;AAAA,EACA;AACF,EAAE,QAAQ,KAAK;AAEf,MAAM,cAAc,IAAIA,UAAAA,OAAO,eAAe,6BAA6B,EAAE,QAAQ,KAAK;AAE1F,MAAM,eAAe,IAAIA,UAAAA,OAAO,gBAAgB,oBAAoB,EAAE,QAAQ,KAAK;AAEnF,MAAM,8BAA8B,IAAIA,UAAA;AAAA,EACtC;AAAA,EACA;AACF,EAAE,QAAQ,KAAK;AAEf,MAAM,2BAA2B,CAAC,aAAkC,gBAAwB;AAEvFC,oBAAA,QAAQ,WAAW,EACnB,YAAY,WAAW,EACvB,UAAU,iBAAiB,EAC3B,UAAU,SAAS,EACnB,UAAU,WAAW,EACrB,UAAU,YAAY,EACtB,UAAU,2BAA2B,EACrC,OAAO,OAAO,YAA+B;AAC5C,UAAM,EAAE,QAAA,IAAY,MAAM,QAAA,QAAA,EAAA,KAAA,MAAA,QAAO,uBAAuB,CAAA;AAExD,WAAO,QAAQ,EAAE,GAAG,SAAS,QAAQ,YAAa,CAAA;AAAA,EAAA,CACnD;AACL;AAEA;AAAA,EACEF,YAAoB;AAAA,EACpB;AACF;AAEA;AAAA,EACEA,YAAoB;AAAA,EACpB;AACF;AAEA;AAAA,EACEA,YAAoB;AAAA,EACpB;AACF;AAEAE,UAAAA,QACG,QAAQ,UAAU,EAClB;AAAA,EACC;AACF,EACC,UAAU,iBAAiB,EAC3B,UAAU,SAAS,EACnB,UAAU,WAAW,EACrB,UAAU,YAAY,EACtB,OAAO,OAAO,YAAgC;AAC7C,QAAM,EAAE,SAAA,IAAa,MAAM,QAAA,QAAA,EAAA,KAAA,MAAA,QAAO,wBAAwB,CAAA;AAC1D,SAAO,SAAS,OAAO;AACzB,CAAC;AAKHA,UAAAA,QACG,QAAQ,eAAe,EAAE,QAAQ,MAAM,EACvC,YAAY,4CAA4C,EACxD,UAAU,iBAAiB,EAC3B,UAAU,SAAS,EACnB,UAAU,WAAW,EACrB,UAAU,YAAY,EACtB,UAAU,2BAA2B,EACrC;AAAA,EACC,IAAID,UAAA;AAAA,IACF;AAAA,IACA;AAAA,EAAA,EACA,UAAU,CAAC,mBAAmB;AAC1B,QAAA,CAAC,gBAAgB,cAAc,GAAG;AACpC,YAAM,IAAIE,UAAA;AAAA,QACR;AAAA,MAAA;AAAA,IAEJ;AAEA,WAAO,cAAc,cAAc;AAAA,EAAA,CACpC;AACH,EACC,OAAO,OAAO,QAAgB,YAAiC;AAC1D,MAAA,CAAC,cAAc,MAAM,GAAG;AAClB,YAAA,MAAM,6DAA6D,MAAM,GAAG;AACpF,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,QAAM,EAAE,QAAA,IAAY,MAAM,QAAA,QAAA,EAAA,KAAA,MAAA,QAAO,uBAAuB,CAAA;AAEjD,SAAA,QAAQ,EAAE,GAAG,SAAS,QAAQ,cAAc,MAAM,GAAG;AAC9D,CAAC;AAEHD,UAAAA,QACG,MAAM,qBAAqB,EAC3B,GAAG,aAAa,CAAC,CAAC,UAAU,MAAM;AACzB,UAAA;AAAA,IACNE,eAAAA,QAAM;AAAA,MACJ,4BAA4B,UAAU,IAAIC,YAAAA,QAAG,GAAG;AAAA,IAClD;AAAA,EAAA;AAGF,UAAQ,KAAK,CAAC;AAChB,CAAC,EACA,WAAW,cAAc,4BAA4B,EACrD,eAAe,kBAAkB,sCAAsC,EACvE,QAAQC,OAAkB,EAC1B,MAAM,QAAQ,IAAI;;;;;;;"}