@strapi/upgrade 0.0.0-experimental.a407f3bc8fb79a53cf7975140864526b6ddbac4b → 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011

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.
@@ -1 +0,0 @@
1
- {"version":3,"file":"codemod-runner-84t8FGQa.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/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_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 });\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"],"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_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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"}