@strapi/upgrade 5.29.0 → 5.30.1

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 (85) hide show
  1. package/dist/package.json.js +1 -1
  2. package/dist/package.json.mjs +1 -1
  3. package/dist/src/cli/commands/codemods.js.map +1 -1
  4. package/dist/src/cli/commands/codemods.mjs.map +1 -1
  5. package/dist/src/cli/options.js +0 -1
  6. package/dist/src/cli/options.js.map +1 -1
  7. package/dist/src/cli/options.mjs +0 -1
  8. package/dist/src/cli/options.mjs.map +1 -1
  9. package/dist/src/modules/codemod/codemod.js.map +1 -1
  10. package/dist/src/modules/codemod/codemod.mjs.map +1 -1
  11. package/dist/src/modules/codemod-repository/repository.js +0 -1
  12. package/dist/src/modules/codemod-repository/repository.js.map +1 -1
  13. package/dist/src/modules/codemod-repository/repository.mjs +0 -1
  14. package/dist/src/modules/codemod-repository/repository.mjs.map +1 -1
  15. package/dist/src/modules/codemod-runner/codemod-runner.js +0 -1
  16. package/dist/src/modules/codemod-runner/codemod-runner.js.map +1 -1
  17. package/dist/src/modules/codemod-runner/codemod-runner.mjs +0 -1
  18. package/dist/src/modules/codemod-runner/codemod-runner.mjs.map +1 -1
  19. package/dist/src/modules/error/utils.js.map +1 -1
  20. package/dist/src/modules/error/utils.mjs.map +1 -1
  21. package/dist/src/modules/file-scanner/scanner.js.map +1 -1
  22. package/dist/src/modules/file-scanner/scanner.mjs.map +1 -1
  23. package/dist/src/modules/format/formats.js.map +1 -1
  24. package/dist/src/modules/format/formats.mjs.map +1 -1
  25. package/dist/src/modules/json/file.js.map +1 -1
  26. package/dist/src/modules/json/file.mjs.map +1 -1
  27. package/dist/src/modules/json/transform-api.js.map +1 -1
  28. package/dist/src/modules/json/transform-api.mjs.map +1 -1
  29. package/dist/src/modules/logger/logger.js.map +1 -1
  30. package/dist/src/modules/logger/logger.mjs.map +1 -1
  31. package/dist/src/modules/npm/package.js +0 -1
  32. package/dist/src/modules/npm/package.js.map +1 -1
  33. package/dist/src/modules/npm/package.mjs +0 -1
  34. package/dist/src/modules/npm/package.mjs.map +1 -1
  35. package/dist/src/modules/project/constants.js.map +1 -1
  36. package/dist/src/modules/project/constants.mjs.map +1 -1
  37. package/dist/src/modules/project/project.js +2 -5
  38. package/dist/src/modules/project/project.js.map +1 -1
  39. package/dist/src/modules/project/project.mjs +2 -5
  40. package/dist/src/modules/project/project.mjs.map +1 -1
  41. package/dist/src/modules/requirement/requirement.js.map +1 -1
  42. package/dist/src/modules/requirement/requirement.mjs.map +1 -1
  43. package/dist/src/modules/runner/code/code.js +1 -2
  44. package/dist/src/modules/runner/code/code.js.map +1 -1
  45. package/dist/src/modules/runner/code/code.mjs +1 -2
  46. package/dist/src/modules/runner/code/code.mjs.map +1 -1
  47. package/dist/src/modules/runner/json/json.js +1 -2
  48. package/dist/src/modules/runner/json/json.js.map +1 -1
  49. package/dist/src/modules/runner/json/json.mjs +1 -2
  50. package/dist/src/modules/runner/json/json.mjs.map +1 -1
  51. package/dist/src/modules/runner/json/transform.js.map +1 -1
  52. package/dist/src/modules/runner/json/transform.mjs.map +1 -1
  53. package/dist/src/modules/runner/runner.js.map +1 -1
  54. package/dist/src/modules/runner/runner.mjs.map +1 -1
  55. package/dist/src/modules/timer/timer.js.map +1 -1
  56. package/dist/src/modules/timer/timer.mjs.map +1 -1
  57. package/dist/src/modules/upgrader/upgrader.js +0 -1
  58. package/dist/src/modules/upgrader/upgrader.js.map +1 -1
  59. package/dist/src/modules/upgrader/upgrader.mjs +0 -1
  60. package/dist/src/modules/upgrader/upgrader.mjs.map +1 -1
  61. package/dist/src/modules/version/range.js.map +1 -1
  62. package/dist/src/modules/version/range.mjs.map +1 -1
  63. package/dist/src/modules/version/types.js +5 -3
  64. package/dist/src/modules/version/types.js.map +1 -1
  65. package/dist/src/modules/version/types.mjs +3 -3
  66. package/dist/src/modules/version/types.mjs.map +1 -1
  67. package/dist/src/tasks/codemods/list-codemods.js.map +1 -1
  68. package/dist/src/tasks/codemods/list-codemods.mjs.map +1 -1
  69. package/dist/src/tasks/codemods/run-codemods.js.map +1 -1
  70. package/dist/src/tasks/codemods/run-codemods.mjs.map +1 -1
  71. package/dist/src/tasks/codemods/utils.js.map +1 -1
  72. package/dist/src/tasks/codemods/utils.mjs.map +1 -1
  73. package/dist/src/tasks/index.js +0 -1
  74. package/dist/src/tasks/index.js.map +1 -1
  75. package/dist/src/tasks/index.mjs +0 -1
  76. package/dist/src/tasks/index.mjs.map +1 -1
  77. package/dist/src/tasks/upgrade/prompts/latest.js.map +1 -1
  78. package/dist/src/tasks/upgrade/prompts/latest.mjs.map +1 -1
  79. package/dist/src/tasks/upgrade/requirements/major.js +0 -1
  80. package/dist/src/tasks/upgrade/requirements/major.js.map +1 -1
  81. package/dist/src/tasks/upgrade/requirements/major.mjs +0 -1
  82. package/dist/src/tasks/upgrade/requirements/major.mjs.map +1 -1
  83. package/dist/src/tasks/upgrade/upgrade.js.map +1 -1
  84. package/dist/src/tasks/upgrade/upgrade.mjs.map +1 -1
  85. package/package.json +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"json.js","sources":["../../../../../src/modules/runner/json/json.ts"],"sourcesContent":["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"],"names":["JSONRunner","AbstractRunner","valid","codemod","kind","runner","transformJSON","jsonRunnerFactory","paths","configuration"],"mappings":";;;;;AAOO,MAAMA,UAAmBC,SAAAA,qBAAAA,CAAAA;AAG9BC,IAAAA,KAAAA,CAAMC,OAAwB,EAAW;QACvC,OAAOA,OAAAA,CAAQC,IAAI,KAAK,MAAA;AAC1B;;;aAJAC,MAASC,GAAAA,uBAAAA;;AAKX;AAEO,MAAMC,iBAAoB,GAAA,CAACC,KAAiBC,EAAAA,aAAAA,GAAAA;IACjD,OAAO,IAAIT,WAAWQ,KAAOC,EAAAA,aAAAA,CAAAA;AAC/B;;;;;"}
1
+ {"version":3,"file":"json.js","sources":["../../../../../src/modules/runner/json/json.ts"],"sourcesContent":["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"],"names":["JSONRunner","AbstractRunner","valid","codemod","kind","runner","transformJSON","jsonRunnerFactory","paths","configuration"],"mappings":";;;;;AAOO,MAAMA,UAAmBC,SAAAA,qBAAAA,CAAAA;AAG9BC,IAAAA,KAAAA,CAAMC,OAAwB,EAAW;QACvC,OAAOA,OAAAA,CAAQC,IAAI,KAAK,MAAA;AAC1B;;AALK,QAAA,KAAA,CAAA,GAAA,IAAA,CAAA,EAAA,IAAA,CACLC,MAASC,GAAAA,uBAAAA;;AAKX;AAEO,MAAMC,iBAAoB,GAAA,CAACC,KAAiBC,EAAAA,aAAAA,GAAAA;IACjD,OAAO,IAAIT,WAAWQ,KAAOC,EAAAA,aAAAA,CAAAA;AAC/B;;;;;"}
@@ -6,8 +6,7 @@ class JSONRunner extends AbstractRunner {
6
6
  return codemod.kind === 'json';
7
7
  }
8
8
  constructor(...args){
9
- super(...args);
10
- this.runner = transformJSON;
9
+ super(...args), this.runner = transformJSON;
11
10
  }
12
11
  }
13
12
  const jsonRunnerFactory = (paths, configuration)=>{
@@ -1 +1 @@
1
- {"version":3,"file":"json.mjs","sources":["../../../../../src/modules/runner/json/json.ts"],"sourcesContent":["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"],"names":["JSONRunner","AbstractRunner","valid","codemod","kind","runner","transformJSON","jsonRunnerFactory","paths","configuration"],"mappings":";;;AAOO,MAAMA,UAAmBC,SAAAA,cAAAA,CAAAA;AAG9BC,IAAAA,KAAAA,CAAMC,OAAwB,EAAW;QACvC,OAAOA,OAAAA,CAAQC,IAAI,KAAK,MAAA;AAC1B;;;aAJAC,MAASC,GAAAA,aAAAA;;AAKX;AAEO,MAAMC,iBAAoB,GAAA,CAACC,KAAiBC,EAAAA,aAAAA,GAAAA;IACjD,OAAO,IAAIT,WAAWQ,KAAOC,EAAAA,aAAAA,CAAAA;AAC/B;;;;"}
1
+ {"version":3,"file":"json.mjs","sources":["../../../../../src/modules/runner/json/json.ts"],"sourcesContent":["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"],"names":["JSONRunner","AbstractRunner","valid","codemod","kind","runner","transformJSON","jsonRunnerFactory","paths","configuration"],"mappings":";;;AAOO,MAAMA,UAAmBC,SAAAA,cAAAA,CAAAA;AAG9BC,IAAAA,KAAAA,CAAMC,OAAwB,EAAW;QACvC,OAAOA,OAAAA,CAAQC,IAAI,KAAK,MAAA;AAC1B;;AALK,QAAA,KAAA,CAAA,GAAA,IAAA,CAAA,EAAA,IAAA,CACLC,MAASC,GAAAA,aAAAA;;AAKX;AAEO,MAAMC,iBAAoB,GAAA,CAACC,KAAiBC,EAAAA,aAAAA,GAAAA;IACjD,OAAO,IAAIT,WAAWQ,KAAOC,EAAAA,aAAAA,CAAAA;AAC/B;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"transform.js","sources":["../../../../../src/modules/runner/json/transform.ts"],"sourcesContent":["/* 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 /**\n * Why do we need to include node_modules (hookIgnoreNodeModules) and specify a matcher (hookMatcher) to esbuild?\n *\n * When using tools like npx or dlx, the execution context is different from when running the program in a local\n * project. npx and dlx run the commands in a temporary installation, which is isolated from local project files.\n *\n * When hookIgnoreNodeModules is not specified (or set to true), esbuild-register instructs\n * Pirates (https://github.com/danez/pirates) to not transpile any files that come from node_modules.\n *\n * Now, when using npx or dlx to run a script, its location can be seen as \"external\" because it's not part of\n * the temporary environment where npx or dlx execute. Therefore, it's considered to be part of node_modules.\n *\n * Due to this, if hookIgnoreNodeModules is set to true or left unspecified,\n * esbuild-register won't try to compile them upon require.\n *\n * hookMatcher is added to make sure we're not matching anything else than our codemod in external directories.\n */\n const esbuildOptions = {\n extensions: ['.js', '.mjs', '.ts'],\n hookIgnoreNodeModules: false,\n hookMatcher: isEqual(codemodPath),\n };\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"],"names":["transformJSON","codemodPath","paths","config","dry","startTime","process","hrtime","report","ok","nochange","skip","error","timeElapsed","stats","esbuildOptions","extensions","hookIgnoreNodeModules","hookMatcher","isEqual","unregister","register","module","require","codemod","default","assert","path","json","readJSON","Array","isArray","file","params","cwd","createJSONTransformAPI","out","undefined","saveJSON","endTime","toFixed"],"mappings":";;;;;;;;AAYaA,MAAAA,aAAAA,GAAgB,OAC3BC,WAAAA,EACAC,KACAC,EAAAA,MAAAA,GAAAA;IAEA,MAAM,EAAEC,GAAG,EAAE,GAAGD,MAAAA;IAChB,MAAME,SAAAA,GAAYC,QAAQC,MAAM,EAAA;AAEhC,IAAA,MAAMC,MAAwB,GAAA;QAC5BC,EAAI,EAAA,CAAA;QACJC,QAAU,EAAA,CAAA;QACVC,IAAM,EAAA,CAAA;QACNC,KAAO,EAAA,CAAA;QACPC,WAAa,EAAA,EAAA;AACbC,QAAAA,KAAAA,EAAO;AACT,KAAA;AAEA;;;;;;;;;;;;;;;;AAgBC,MACD,MAAMC,cAAiB,GAAA;QACrBC,UAAY,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA,MAAA;AAAQ,YAAA;AAAM,SAAA;QAClCC,qBAAuB,EAAA,KAAA;AACvBC,QAAAA,WAAAA,EAAaC,UAAQlB,CAAAA,WAAAA;AACvB,KAAA;AACA,IAAA,MAAM,EAAEmB,UAAU,EAAE,GAAGC,aAASN,CAAAA,cAAAA,CAAAA;AAEhC,IAAA,MAAMO,SAASC,OAAQtB,CAAAA,WAAAA,CAAAA;AAEvBmB,IAAAA,UAAAA,EAAAA;IAEA,MAAMI,OAAAA,GAAU,OAAOF,MAAOG,CAAAA,OAAO,KAAK,UAAaH,GAAAA,MAAAA,CAAOG,OAAO,GAAGH,MAAAA;IAExEI,MAAO,CAAA,OAAOF,YAAY,UAAY,EAAA,CAAC,kCAAkC,EAAE,OAAOA,QAAQ,CAAC,CAAA;IAE3F,KAAK,MAAMG,QAAQzB,KAAO,CAAA;QACxB,IAAI;YACF,MAAM0B,IAAAA,GAAO,MAAMC,aAASF,CAAAA,IAAAA,CAAAA;;YAG5BD,MAAO,CAAA,OAAOE,SAAS,QAAY,IAAA,CAACE,MAAMC,OAAO,CAACH,SAASA,IAAS,KAAA,IAAA,CAAA;;AAGpE,YAAA,MAAMI,MAAuB,GAAA;AAAEL,gBAAAA,IAAAA;AAAMC,gBAAAA;AAAK,aAAA;AAC1C,YAAA,MAAMK,MAA8B,GAAA;AAAEC,gBAAAA,GAAAA,EAAK/B,OAAO+B,GAAG;gBAAEN,IAAMO,EAAAA;AAAuB,aAAA;YAEpF,MAAMC,GAAAA,GAAM,MAAMZ,OAAAA,CAAQQ,MAAMC,EAAAA,MAAAA,CAAAA;AAEhC,YAAA,IAAIG,QAAQC,SAAW,EAAA;AACrB7B,gBAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB,aAAA,MAEK,IAAI,CAACO,UAAQS,CAAAA,IAAAA,EAAMQ,GAAM,CAAA,EAAA;AAC5B,gBAAA,IAAI,CAAChC,GAAK,EAAA;AACR,oBAAA,MAAMkC,cAASX,IAAMS,EAAAA,GAAAA,CAAAA;AACvB;AACA5B,gBAAAA,MAAAA,CAAOC,EAAE,IAAI,CAAA;aAGV,MAAA;AACHD,gBAAAA,MAAAA,CAAOE,QAAQ,IAAI,CAAA;AACrB;AACF,SAAA,CAAE,OAAM;AACNF,YAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB;AACF;IAEA,MAAM2B,OAAAA,GAAUjC,OAAQC,CAAAA,MAAM,CAACF,SAAAA,CAAAA;AAC/BG,IAAAA,MAAAA,CAAOK,WAAW,GAAG,CAAC0B,OAAO,CAAC,CAAA,CAAE,GAAGA,OAAO,CAAC,CAAE,CAAA,GAAG,GAAE,EAAGC,OAAO,CAAC,CAAA,CAAA;IAE7D,OAAOhC,MAAAA;AACT;;;;"}
1
+ {"version":3,"file":"transform.js","sources":["../../../../../src/modules/runner/json/transform.ts"],"sourcesContent":["/* 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 /**\n * Why do we need to include node_modules (hookIgnoreNodeModules) and specify a matcher (hookMatcher) to esbuild?\n *\n * When using tools like npx or dlx, the execution context is different from when running the program in a local\n * project. npx and dlx run the commands in a temporary installation, which is isolated from local project files.\n *\n * When hookIgnoreNodeModules is not specified (or set to true), esbuild-register instructs\n * Pirates (https://github.com/danez/pirates) to not transpile any files that come from node_modules.\n *\n * Now, when using npx or dlx to run a script, its location can be seen as \"external\" because it's not part of\n * the temporary environment where npx or dlx execute. Therefore, it's considered to be part of node_modules.\n *\n * Due to this, if hookIgnoreNodeModules is set to true or left unspecified,\n * esbuild-register won't try to compile them upon require.\n *\n * hookMatcher is added to make sure we're not matching anything else than our codemod in external directories.\n */\n const esbuildOptions = {\n extensions: ['.js', '.mjs', '.ts'],\n hookIgnoreNodeModules: false,\n hookMatcher: isEqual(codemodPath),\n };\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"],"names":["transformJSON","codemodPath","paths","config","dry","startTime","process","hrtime","report","ok","nochange","skip","error","timeElapsed","stats","esbuildOptions","extensions","hookIgnoreNodeModules","hookMatcher","isEqual","unregister","register","module","require","codemod","default","assert","path","json","readJSON","Array","isArray","file","params","cwd","createJSONTransformAPI","out","undefined","saveJSON","endTime","toFixed"],"mappings":";;;;;;;;AAYaA,MAAAA,aAAAA,GAAgB,OAC3BC,WAAAA,EACAC,KACAC,EAAAA,MAAAA,GAAAA;IAEA,MAAM,EAAEC,GAAG,EAAE,GAAGD,MAAAA;IAChB,MAAME,SAAAA,GAAYC,QAAQC,MAAM,EAAA;AAEhC,IAAA,MAAMC,MAAwB,GAAA;QAC5BC,EAAI,EAAA,CAAA;QACJC,QAAU,EAAA,CAAA;QACVC,IAAM,EAAA,CAAA;QACNC,KAAO,EAAA,CAAA;QACPC,WAAa,EAAA,EAAA;AACbC,QAAAA,KAAAA,EAAO;AACT,KAAA;AAEA;;;;;;;;;;;;;;;;AAgBC,MACD,MAAMC,cAAiB,GAAA;QACrBC,UAAY,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA,MAAA;AAAQ,YAAA;AAAM,SAAA;QAClCC,qBAAuB,EAAA,KAAA;AACvBC,QAAAA,WAAAA,EAAaC,UAAQlB,CAAAA,WAAAA;AACvB,KAAA;AACA,IAAA,MAAM,EAAEmB,UAAU,EAAE,GAAGC,aAASN,CAAAA,cAAAA,CAAAA;AAEhC,IAAA,MAAMO,SAASC,OAAQtB,CAAAA,WAAAA,CAAAA;AAEvBmB,IAAAA,UAAAA,EAAAA;IAEA,MAAMI,OAAAA,GAAU,OAAOF,MAAOG,CAAAA,OAAO,KAAK,UAAaH,GAAAA,MAAAA,CAAOG,OAAO,GAAGH,MAAAA;AAExEI,IAAAA,MAAAA,CAAO,OAAOF,OAAY,KAAA,UAAA,EAAY,CAAC,kCAAkC,EAAE,OAAOA,OAAS,CAAA,CAAA,CAAA;IAE3F,KAAK,MAAMG,QAAQzB,KAAO,CAAA;QACxB,IAAI;YACF,MAAM0B,IAAAA,GAAO,MAAMC,aAASF,CAAAA,IAAAA,CAAAA;;YAG5BD,MAAO,CAAA,OAAOE,SAAS,QAAY,IAAA,CAACE,MAAMC,OAAO,CAACH,SAASA,IAAS,KAAA,IAAA,CAAA;;AAGpE,YAAA,MAAMI,MAAuB,GAAA;AAAEL,gBAAAA,IAAAA;AAAMC,gBAAAA;AAAK,aAAA;AAC1C,YAAA,MAAMK,MAA8B,GAAA;AAAEC,gBAAAA,GAAAA,EAAK/B,OAAO+B,GAAG;gBAAEN,IAAMO,EAAAA;AAAuB,aAAA;YAEpF,MAAMC,GAAAA,GAAM,MAAMZ,OAAAA,CAAQQ,MAAMC,EAAAA,MAAAA,CAAAA;AAEhC,YAAA,IAAIG,QAAQC,SAAW,EAAA;AACrB7B,gBAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB,aAAA,MAEK,IAAI,CAACO,UAAQS,CAAAA,IAAAA,EAAMQ,GAAM,CAAA,EAAA;AAC5B,gBAAA,IAAI,CAAChC,GAAK,EAAA;AACR,oBAAA,MAAMkC,cAASX,IAAMS,EAAAA,GAAAA,CAAAA;AACvB;AACA5B,gBAAAA,MAAAA,CAAOC,EAAE,IAAI,CAAA;aAGV,MAAA;AACHD,gBAAAA,MAAAA,CAAOE,QAAQ,IAAI,CAAA;AACrB;AACF,SAAA,CAAE,OAAM;AACNF,YAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB;AACF;IAEA,MAAM2B,OAAAA,GAAUjC,OAAQC,CAAAA,MAAM,CAACF,SAAAA,CAAAA;AAC/BG,IAAAA,MAAAA,CAAOK,WAAW,GAAG,CAAC0B,OAAO,CAAC,CAAA,CAAE,GAAGA,OAAO,CAAC,CAAE,CAAA,GAAG,GAAE,EAAGC,OAAO,CAAC,CAAA,CAAA;IAE7D,OAAOhC,MAAAA;AACT;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"transform.mjs","sources":["../../../../../src/modules/runner/json/transform.ts"],"sourcesContent":["/* 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 /**\n * Why do we need to include node_modules (hookIgnoreNodeModules) and specify a matcher (hookMatcher) to esbuild?\n *\n * When using tools like npx or dlx, the execution context is different from when running the program in a local\n * project. npx and dlx run the commands in a temporary installation, which is isolated from local project files.\n *\n * When hookIgnoreNodeModules is not specified (or set to true), esbuild-register instructs\n * Pirates (https://github.com/danez/pirates) to not transpile any files that come from node_modules.\n *\n * Now, when using npx or dlx to run a script, its location can be seen as \"external\" because it's not part of\n * the temporary environment where npx or dlx execute. Therefore, it's considered to be part of node_modules.\n *\n * Due to this, if hookIgnoreNodeModules is set to true or left unspecified,\n * esbuild-register won't try to compile them upon require.\n *\n * hookMatcher is added to make sure we're not matching anything else than our codemod in external directories.\n */\n const esbuildOptions = {\n extensions: ['.js', '.mjs', '.ts'],\n hookIgnoreNodeModules: false,\n hookMatcher: isEqual(codemodPath),\n };\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"],"names":["transformJSON","codemodPath","paths","config","dry","startTime","process","hrtime","report","ok","nochange","skip","error","timeElapsed","stats","esbuildOptions","extensions","hookIgnoreNodeModules","hookMatcher","isEqual","unregister","register","module","require","codemod","default","assert","path","json","readJSON","Array","isArray","file","params","cwd","createJSONTransformAPI","out","undefined","saveJSON","endTime","toFixed"],"mappings":";;;;;;AAYaA,MAAAA,aAAAA,GAAgB,OAC3BC,WAAAA,EACAC,KACAC,EAAAA,MAAAA,GAAAA;IAEA,MAAM,EAAEC,GAAG,EAAE,GAAGD,MAAAA;IAChB,MAAME,SAAAA,GAAYC,QAAQC,MAAM,EAAA;AAEhC,IAAA,MAAMC,MAAwB,GAAA;QAC5BC,EAAI,EAAA,CAAA;QACJC,QAAU,EAAA,CAAA;QACVC,IAAM,EAAA,CAAA;QACNC,KAAO,EAAA,CAAA;QACPC,WAAa,EAAA,EAAA;AACbC,QAAAA,KAAAA,EAAO;AACT,KAAA;AAEA;;;;;;;;;;;;;;;;AAgBC,MACD,MAAMC,cAAiB,GAAA;QACrBC,UAAY,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA,MAAA;AAAQ,YAAA;AAAM,SAAA;QAClCC,qBAAuB,EAAA,KAAA;AACvBC,QAAAA,WAAAA,EAAaC,OAAQlB,CAAAA,WAAAA;AACvB,KAAA;AACA,IAAA,MAAM,EAAEmB,UAAU,EAAE,GAAGC,QAASN,CAAAA,cAAAA,CAAAA;AAEhC,IAAA,MAAMO,SAASC,OAAQtB,CAAAA,WAAAA,CAAAA;AAEvBmB,IAAAA,UAAAA,EAAAA;IAEA,MAAMI,OAAAA,GAAU,OAAOF,MAAOG,CAAAA,OAAO,KAAK,UAAaH,GAAAA,MAAAA,CAAOG,OAAO,GAAGH,MAAAA;IAExEI,MAAO,CAAA,OAAOF,YAAY,UAAY,EAAA,CAAC,kCAAkC,EAAE,OAAOA,QAAQ,CAAC,CAAA;IAE3F,KAAK,MAAMG,QAAQzB,KAAO,CAAA;QACxB,IAAI;YACF,MAAM0B,IAAAA,GAAO,MAAMC,QAASF,CAAAA,IAAAA,CAAAA;;YAG5BD,MAAO,CAAA,OAAOE,SAAS,QAAY,IAAA,CAACE,MAAMC,OAAO,CAACH,SAASA,IAAS,KAAA,IAAA,CAAA;;AAGpE,YAAA,MAAMI,IAAuB,GAAA;AAAEL,gBAAAA,IAAAA;AAAMC,gBAAAA;AAAK,aAAA;AAC1C,YAAA,MAAMK,MAA8B,GAAA;AAAEC,gBAAAA,GAAAA,EAAK/B,OAAO+B,GAAG;gBAAEN,IAAMO,EAAAA;AAAuB,aAAA;YAEpF,MAAMC,GAAAA,GAAM,MAAMZ,OAAAA,CAAQQ,IAAMC,EAAAA,MAAAA,CAAAA;AAEhC,YAAA,IAAIG,QAAQC,SAAW,EAAA;AACrB7B,gBAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB,aAAA,MAEK,IAAI,CAACO,OAAQS,CAAAA,IAAAA,EAAMQ,GAAM,CAAA,EAAA;AAC5B,gBAAA,IAAI,CAAChC,GAAK,EAAA;AACR,oBAAA,MAAMkC,SAASX,IAAMS,EAAAA,GAAAA,CAAAA;AACvB;AACA5B,gBAAAA,MAAAA,CAAOC,EAAE,IAAI,CAAA;aAGV,MAAA;AACHD,gBAAAA,MAAAA,CAAOE,QAAQ,IAAI,CAAA;AACrB;AACF,SAAA,CAAE,OAAM;AACNF,YAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB;AACF;IAEA,MAAM2B,OAAAA,GAAUjC,OAAQC,CAAAA,MAAM,CAACF,SAAAA,CAAAA;AAC/BG,IAAAA,MAAAA,CAAOK,WAAW,GAAG,CAAC0B,OAAO,CAAC,CAAA,CAAE,GAAGA,OAAO,CAAC,CAAE,CAAA,GAAG,GAAE,EAAGC,OAAO,CAAC,CAAA,CAAA;IAE7D,OAAOhC,MAAAA;AACT;;;;"}
1
+ {"version":3,"file":"transform.mjs","sources":["../../../../../src/modules/runner/json/transform.ts"],"sourcesContent":["/* 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 /**\n * Why do we need to include node_modules (hookIgnoreNodeModules) and specify a matcher (hookMatcher) to esbuild?\n *\n * When using tools like npx or dlx, the execution context is different from when running the program in a local\n * project. npx and dlx run the commands in a temporary installation, which is isolated from local project files.\n *\n * When hookIgnoreNodeModules is not specified (or set to true), esbuild-register instructs\n * Pirates (https://github.com/danez/pirates) to not transpile any files that come from node_modules.\n *\n * Now, when using npx or dlx to run a script, its location can be seen as \"external\" because it's not part of\n * the temporary environment where npx or dlx execute. Therefore, it's considered to be part of node_modules.\n *\n * Due to this, if hookIgnoreNodeModules is set to true or left unspecified,\n * esbuild-register won't try to compile them upon require.\n *\n * hookMatcher is added to make sure we're not matching anything else than our codemod in external directories.\n */\n const esbuildOptions = {\n extensions: ['.js', '.mjs', '.ts'],\n hookIgnoreNodeModules: false,\n hookMatcher: isEqual(codemodPath),\n };\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"],"names":["transformJSON","codemodPath","paths","config","dry","startTime","process","hrtime","report","ok","nochange","skip","error","timeElapsed","stats","esbuildOptions","extensions","hookIgnoreNodeModules","hookMatcher","isEqual","unregister","register","module","require","codemod","default","assert","path","json","readJSON","Array","isArray","file","params","cwd","createJSONTransformAPI","out","undefined","saveJSON","endTime","toFixed"],"mappings":";;;;;;AAYaA,MAAAA,aAAAA,GAAgB,OAC3BC,WAAAA,EACAC,KACAC,EAAAA,MAAAA,GAAAA;IAEA,MAAM,EAAEC,GAAG,EAAE,GAAGD,MAAAA;IAChB,MAAME,SAAAA,GAAYC,QAAQC,MAAM,EAAA;AAEhC,IAAA,MAAMC,MAAwB,GAAA;QAC5BC,EAAI,EAAA,CAAA;QACJC,QAAU,EAAA,CAAA;QACVC,IAAM,EAAA,CAAA;QACNC,KAAO,EAAA,CAAA;QACPC,WAAa,EAAA,EAAA;AACbC,QAAAA,KAAAA,EAAO;AACT,KAAA;AAEA;;;;;;;;;;;;;;;;AAgBC,MACD,MAAMC,cAAiB,GAAA;QACrBC,UAAY,EAAA;AAAC,YAAA,KAAA;AAAO,YAAA,MAAA;AAAQ,YAAA;AAAM,SAAA;QAClCC,qBAAuB,EAAA,KAAA;AACvBC,QAAAA,WAAAA,EAAaC,OAAQlB,CAAAA,WAAAA;AACvB,KAAA;AACA,IAAA,MAAM,EAAEmB,UAAU,EAAE,GAAGC,QAASN,CAAAA,cAAAA,CAAAA;AAEhC,IAAA,MAAMO,SAASC,OAAQtB,CAAAA,WAAAA,CAAAA;AAEvBmB,IAAAA,UAAAA,EAAAA;IAEA,MAAMI,OAAAA,GAAU,OAAOF,MAAOG,CAAAA,OAAO,KAAK,UAAaH,GAAAA,MAAAA,CAAOG,OAAO,GAAGH,MAAAA;AAExEI,IAAAA,MAAAA,CAAO,OAAOF,OAAY,KAAA,UAAA,EAAY,CAAC,kCAAkC,EAAE,OAAOA,OAAS,CAAA,CAAA,CAAA;IAE3F,KAAK,MAAMG,QAAQzB,KAAO,CAAA;QACxB,IAAI;YACF,MAAM0B,IAAAA,GAAO,MAAMC,QAASF,CAAAA,IAAAA,CAAAA;;YAG5BD,MAAO,CAAA,OAAOE,SAAS,QAAY,IAAA,CAACE,MAAMC,OAAO,CAACH,SAASA,IAAS,KAAA,IAAA,CAAA;;AAGpE,YAAA,MAAMI,IAAuB,GAAA;AAAEL,gBAAAA,IAAAA;AAAMC,gBAAAA;AAAK,aAAA;AAC1C,YAAA,MAAMK,MAA8B,GAAA;AAAEC,gBAAAA,GAAAA,EAAK/B,OAAO+B,GAAG;gBAAEN,IAAMO,EAAAA;AAAuB,aAAA;YAEpF,MAAMC,GAAAA,GAAM,MAAMZ,OAAAA,CAAQQ,IAAMC,EAAAA,MAAAA,CAAAA;AAEhC,YAAA,IAAIG,QAAQC,SAAW,EAAA;AACrB7B,gBAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB,aAAA,MAEK,IAAI,CAACO,OAAQS,CAAAA,IAAAA,EAAMQ,GAAM,CAAA,EAAA;AAC5B,gBAAA,IAAI,CAAChC,GAAK,EAAA;AACR,oBAAA,MAAMkC,SAASX,IAAMS,EAAAA,GAAAA,CAAAA;AACvB;AACA5B,gBAAAA,MAAAA,CAAOC,EAAE,IAAI,CAAA;aAGV,MAAA;AACHD,gBAAAA,MAAAA,CAAOE,QAAQ,IAAI,CAAA;AACrB;AACF,SAAA,CAAE,OAAM;AACNF,YAAAA,MAAAA,CAAOI,KAAK,IAAI,CAAA;AAClB;AACF;IAEA,MAAM2B,OAAAA,GAAUjC,OAAQC,CAAAA,MAAM,CAACF,SAAAA,CAAAA;AAC/BG,IAAAA,MAAAA,CAAOK,WAAW,GAAG,CAAC0B,OAAO,CAAC,CAAA,CAAE,GAAGA,OAAO,CAAC,CAAE,CAAA,GAAG,GAAE,EAAGC,OAAO,CAAC,CAAA,CAAA;IAE7D,OAAOhC,MAAAA;AACT;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"runner.js","sources":["../../../../src/modules/runner/runner.ts"],"sourcesContent":["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"],"names":["AbstractRunner","run","codemod","configuration","isValidCodemod","valid","Error","filename","runConfiguration","runner","path","paths","constructor"],"mappings":";;AAIO,MAAeA,cAAAA,CAAAA;AAcpB,IAAA,MAAMC,GAAIC,CAAAA,OAAwB,EAAEC,aAAuB,EAAE;AAC3D,QAAA,MAAMC,cAAiB,GAAA,IAAI,CAACC,KAAK,CAACH,OAAAA,CAAAA;AAElC,QAAA,IAAI,CAACE,cAAgB,EAAA;YACnB,MAAM,IAAIE,MAAM,CAAC,wCAAwC,EAAEJ,OAAQK,CAAAA,QAAQ,CAAC,CAAC,CAAA;AAC/E;AAEA,QAAA,MAAMC,gBAA4B,GAAA;YAAE,GAAG,IAAI,CAACL,aAAa;AAAE,YAAA,GAAGA;AAAc,SAAA;QAE5E,OAAO,IAAI,CAACM,MAAM,CAACP,OAAAA,CAAQQ,IAAI,EAAE,IAAI,CAACC,KAAK,EAAEH,gBAAAA,CAAAA;AAC/C;IAfAI,WAAYD,CAAAA,KAAe,EAAER,aAAsB,CAAE;QACnD,IAAI,CAACQ,KAAK,GAAGA,KAAAA;QACb,IAAI,CAACR,aAAa,GAAGA,aAAAA;AACvB;AAeF;;;;"}
1
+ {"version":3,"file":"runner.js","sources":["../../../../src/modules/runner/runner.ts"],"sourcesContent":["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"],"names":["AbstractRunner","run","codemod","configuration","isValidCodemod","valid","Error","filename","runConfiguration","runner","path","paths"],"mappings":";;AAIO,MAAeA,cAAAA,CAAAA;AAcpB,IAAA,MAAMC,GAAIC,CAAAA,OAAwB,EAAEC,aAAuB,EAAE;AAC3D,QAAA,MAAMC,cAAiB,GAAA,IAAI,CAACC,KAAK,CAACH,OAAAA,CAAAA;AAElC,QAAA,IAAI,CAACE,cAAgB,EAAA;AACnB,YAAA,MAAM,IAAIE,KAAM,CAAA,CAAC,wCAAwC,EAAEJ,OAAAA,CAAQK,QAAQ,CAAE,CAAA,CAAA;AAC/E;AAEA,QAAA,MAAMC,gBAA4B,GAAA;YAAE,GAAG,IAAI,CAACL,aAAa;AAAE,YAAA,GAAGA;AAAc,SAAA;QAE5E,OAAO,IAAI,CAACM,MAAM,CAACP,OAAAA,CAAQQ,IAAI,EAAE,IAAI,CAACC,KAAK,EAAEH,gBAAAA,CAAAA;AAC/C;IAfA,WAAYG,CAAAA,KAAe,EAAER,aAAsB,CAAE;QACnD,IAAI,CAACQ,KAAK,GAAGA,KAAAA;QACb,IAAI,CAACR,aAAa,GAAGA,aAAAA;AACvB;AAeF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"runner.mjs","sources":["../../../../src/modules/runner/runner.ts"],"sourcesContent":["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"],"names":["AbstractRunner","run","codemod","configuration","isValidCodemod","valid","Error","filename","runConfiguration","runner","path","paths","constructor"],"mappings":"AAIO,MAAeA,cAAAA,CAAAA;AAcpB,IAAA,MAAMC,GAAIC,CAAAA,OAAwB,EAAEC,aAAuB,EAAE;AAC3D,QAAA,MAAMC,cAAiB,GAAA,IAAI,CAACC,KAAK,CAACH,OAAAA,CAAAA;AAElC,QAAA,IAAI,CAACE,cAAgB,EAAA;YACnB,MAAM,IAAIE,MAAM,CAAC,wCAAwC,EAAEJ,OAAQK,CAAAA,QAAQ,CAAC,CAAC,CAAA;AAC/E;AAEA,QAAA,MAAMC,gBAA4B,GAAA;YAAE,GAAG,IAAI,CAACL,aAAa;AAAE,YAAA,GAAGA;AAAc,SAAA;QAE5E,OAAO,IAAI,CAACM,MAAM,CAACP,OAAAA,CAAQQ,IAAI,EAAE,IAAI,CAACC,KAAK,EAAEH,gBAAAA,CAAAA;AAC/C;IAfAI,WAAYD,CAAAA,KAAe,EAAER,aAAsB,CAAE;QACnD,IAAI,CAACQ,KAAK,GAAGA,KAAAA;QACb,IAAI,CAACR,aAAa,GAAGA,aAAAA;AACvB;AAeF;;;;"}
1
+ {"version":3,"file":"runner.mjs","sources":["../../../../src/modules/runner/runner.ts"],"sourcesContent":["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"],"names":["AbstractRunner","run","codemod","configuration","isValidCodemod","valid","Error","filename","runConfiguration","runner","path","paths"],"mappings":"AAIO,MAAeA,cAAAA,CAAAA;AAcpB,IAAA,MAAMC,GAAIC,CAAAA,OAAwB,EAAEC,aAAuB,EAAE;AAC3D,QAAA,MAAMC,cAAiB,GAAA,IAAI,CAACC,KAAK,CAACH,OAAAA,CAAAA;AAElC,QAAA,IAAI,CAACE,cAAgB,EAAA;AACnB,YAAA,MAAM,IAAIE,KAAM,CAAA,CAAC,wCAAwC,EAAEJ,OAAAA,CAAQK,QAAQ,CAAE,CAAA,CAAA;AAC/E;AAEA,QAAA,MAAMC,gBAA4B,GAAA;YAAE,GAAG,IAAI,CAACL,aAAa;AAAE,YAAA,GAAGA;AAAc,SAAA;QAE5E,OAAO,IAAI,CAACM,MAAM,CAACP,OAAAA,CAAQQ,IAAI,EAAE,IAAI,CAACC,KAAK,EAAEH,gBAAAA,CAAAA;AAC/C;IAfA,WAAYG,CAAAA,KAAe,EAAER,aAAsB,CAAE;QACnD,IAAI,CAACQ,KAAK,GAAGA,KAAAA;QACb,IAAI,CAACR,aAAa,GAAGA,aAAAA;AACvB;AAeF;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"timer.js","sources":["../../../../src/modules/timer/timer.ts"],"sourcesContent":["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"],"names":["Timer","elapsedMs","start","end","interval","Date","now","stop","reset","constructor","timerFactory"],"mappings":";;AAEO,MAAMA,KAAAA,CAAAA;AAOX,IAAA,IAAIC,SAAY,GAAA;QACd,MAAM,EAAEC,KAAK,EAAEC,GAAG,EAAE,GAAG,IAAI,CAACC,QAAQ;AAEpC,QAAA,OAAOD,GAAMA,GAAAA,GAAAA,GAAMD,KAAQG,GAAAA,IAAAA,CAAKC,GAAG,EAAKJ,GAAAA,KAAAA;AAC1C;AAEA,IAAA,IAAIC,GAAM,GAAA;AACR,QAAA,OAAO,IAAI,CAACC,QAAQ,CAACD,GAAG;AAC1B;AAEA,IAAA,IAAID,KAAQ,GAAA;AACV,QAAA,OAAO,IAAI,CAACE,QAAQ,CAACF,KAAK;AAC5B;IAEAK,IAAO,GAAA;AACL,QAAA,IAAI,CAACH,QAAQ,CAACD,GAAG,GAAGE,KAAKC,GAAG,EAAA;QAE5B,OAAO,IAAI,CAACL,SAAS;AACvB;IAEAO,KAAQ,GAAA;QACN,IAAI,CAACJ,QAAQ,GAAG;AAAEF,YAAAA,KAAAA,EAAOG,KAAKC,GAAG,EAAA;YAAIH,GAAK,EAAA;AAAK,SAAA;AAE/C,QAAA,OAAO,IAAI;AACb;IA5BAM,WAAc,EAAA;AACZ,QAAA,IAAI,CAACD,KAAK,EAAA;AACZ;AA2BF;AAEaE,MAAAA,YAAAA,GAAe,IAAM,IAAIV,KAAQ;;;;;"}
1
+ {"version":3,"file":"timer.js","sources":["../../../../src/modules/timer/timer.ts"],"sourcesContent":["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"],"names":["Timer","elapsedMs","start","end","interval","Date","now","stop","reset","timerFactory"],"mappings":";;AAEO,MAAMA,KAAAA,CAAAA;AAOX,IAAA,IAAIC,SAAY,GAAA;QACd,MAAM,EAAEC,KAAK,EAAEC,GAAG,EAAE,GAAG,IAAI,CAACC,QAAQ;AAEpC,QAAA,OAAOD,GAAMA,GAAAA,GAAAA,GAAMD,KAAQG,GAAAA,IAAAA,CAAKC,GAAG,EAAKJ,GAAAA,KAAAA;AAC1C;AAEA,IAAA,IAAIC,GAAM,GAAA;AACR,QAAA,OAAO,IAAI,CAACC,QAAQ,CAACD,GAAG;AAC1B;AAEA,IAAA,IAAID,KAAQ,GAAA;AACV,QAAA,OAAO,IAAI,CAACE,QAAQ,CAACF,KAAK;AAC5B;IAEAK,IAAO,GAAA;AACL,QAAA,IAAI,CAACH,QAAQ,CAACD,GAAG,GAAGE,KAAKC,GAAG,EAAA;QAE5B,OAAO,IAAI,CAACL,SAAS;AACvB;IAEAO,KAAQ,GAAA;QACN,IAAI,CAACJ,QAAQ,GAAG;AAAEF,YAAAA,KAAAA,EAAOG,KAAKC,GAAG,EAAA;YAAIH,GAAK,EAAA;AAAK,SAAA;AAE/C,QAAA,OAAO,IAAI;AACb;IA5BA,WAAc,EAAA;AACZ,QAAA,IAAI,CAACK,KAAK,EAAA;AACZ;AA2BF;AAEaC,MAAAA,YAAAA,GAAe,IAAM,IAAIT,KAAQ;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"timer.mjs","sources":["../../../../src/modules/timer/timer.ts"],"sourcesContent":["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"],"names":["Timer","elapsedMs","start","end","interval","Date","now","stop","reset","constructor","timerFactory"],"mappings":"AAEO,MAAMA,KAAAA,CAAAA;AAOX,IAAA,IAAIC,SAAY,GAAA;QACd,MAAM,EAAEC,KAAK,EAAEC,GAAG,EAAE,GAAG,IAAI,CAACC,QAAQ;AAEpC,QAAA,OAAOD,GAAMA,GAAAA,GAAAA,GAAMD,KAAQG,GAAAA,IAAAA,CAAKC,GAAG,EAAKJ,GAAAA,KAAAA;AAC1C;AAEA,IAAA,IAAIC,GAAM,GAAA;AACR,QAAA,OAAO,IAAI,CAACC,QAAQ,CAACD,GAAG;AAC1B;AAEA,IAAA,IAAID,KAAQ,GAAA;AACV,QAAA,OAAO,IAAI,CAACE,QAAQ,CAACF,KAAK;AAC5B;IAEAK,IAAO,GAAA;AACL,QAAA,IAAI,CAACH,QAAQ,CAACD,GAAG,GAAGE,KAAKC,GAAG,EAAA;QAE5B,OAAO,IAAI,CAACL,SAAS;AACvB;IAEAO,KAAQ,GAAA;QACN,IAAI,CAACJ,QAAQ,GAAG;AAAEF,YAAAA,KAAAA,EAAOG,KAAKC,GAAG,EAAA;YAAIH,GAAK,EAAA;AAAK,SAAA;AAE/C,QAAA,OAAO,IAAI;AACb;IA5BAM,WAAc,EAAA;AACZ,QAAA,IAAI,CAACD,KAAK,EAAA;AACZ;AA2BF;AAEaE,MAAAA,YAAAA,GAAe,IAAM,IAAIV,KAAQ;;;;"}
1
+ {"version":3,"file":"timer.mjs","sources":["../../../../src/modules/timer/timer.ts"],"sourcesContent":["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"],"names":["Timer","elapsedMs","start","end","interval","Date","now","stop","reset","timerFactory"],"mappings":"AAEO,MAAMA,KAAAA,CAAAA;AAOX,IAAA,IAAIC,SAAY,GAAA;QACd,MAAM,EAAEC,KAAK,EAAEC,GAAG,EAAE,GAAG,IAAI,CAACC,QAAQ;AAEpC,QAAA,OAAOD,GAAMA,GAAAA,GAAAA,GAAMD,KAAQG,GAAAA,IAAAA,CAAKC,GAAG,EAAKJ,GAAAA,KAAAA;AAC1C;AAEA,IAAA,IAAIC,GAAM,GAAA;AACR,QAAA,OAAO,IAAI,CAACC,QAAQ,CAACD,GAAG;AAC1B;AAEA,IAAA,IAAID,KAAQ,GAAA;AACV,QAAA,OAAO,IAAI,CAACE,QAAQ,CAACF,KAAK;AAC5B;IAEAK,IAAO,GAAA;AACL,QAAA,IAAI,CAACH,QAAQ,CAACD,GAAG,GAAGE,KAAKC,GAAG,EAAA;QAE5B,OAAO,IAAI,CAACL,SAAS;AACvB;IAEAO,KAAQ,GAAA;QACN,IAAI,CAACJ,QAAQ,GAAG;AAAEF,YAAAA,KAAAA,EAAOG,KAAKC,GAAG,EAAA;YAAIH,GAAK,EAAA;AAAK,SAAA;AAE/C,QAAA,OAAO,IAAI;AACb;IA5BA,WAAc,EAAA;AACZ,QAAA,IAAI,CAACK,KAAK,EAAA;AACZ;AA2BF;AAEaC,MAAAA,YAAAA,GAAe,IAAM,IAAIT,KAAQ;;;;"}
@@ -10,7 +10,6 @@ require('node:assert');
10
10
  require('fs-extra');
11
11
  var semver = require('../version/semver.js');
12
12
  var range = require('../version/range.js');
13
- require('../version/types.js');
14
13
  require('fast-glob');
15
14
  require('jscodeshift/src/Runner');
16
15
  require('lodash/fp');
@@ -1 +1 @@
1
- {"version":3,"file":"upgrader.js","sources":["../../../../src/modules/upgrader/upgrader.ts"],"sourcesContent":["import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { NPMCandidateNotFoundError, unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { AppProject } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: AppProject;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: AppProject, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n getNPMPackage(): NPM.Package {\n return this.npmPackage;\n }\n\n getProject(): AppProject {\n return this.project;\n }\n\n getTarget(): Version.SemVer {\n return semVerFactory(this.target.raw);\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.951\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug?.(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug?.(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug?.(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info?.(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn?.(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug?.(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info?.(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info?.(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n // We need to refresh the project files to make sure we have\n // the latest version of each file (including package.json) for the next steps\n this.logger?.debug?.('Refreshing project information...');\n this.project.refresh();\n\n this.logger?.info?.(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info?.(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n async confirm(message: string): Promise<boolean> {\n if (typeof this.confirmationCallback !== 'function') {\n return true;\n }\n\n return this.confirmationCallback(message);\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn?.(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug?.(\n `Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`\n );\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug?.(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug?.(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies installation (${chalk.italic('dry mode')})`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n\n codemodRunner.dry(this.isDry);\n\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion => {\n // Semver\n if (isSemverInstance(target)) {\n const version = npmPackage.findVersion(target);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(target);\n }\n\n return version;\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n const version = npmVersionsMatches.at(-1);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(range, `The project is already up-to-date (${target})`);\n }\n\n return version;\n }\n\n throw new NPMCandidateNotFoundError(target);\n};\n\nexport const upgraderFactory = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const npmTarget = resolveNPMTarget(project, target, npmPackage);\n const semverTarget = semVerFactory(npmTarget.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already using v${semverTarget}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n"],"names":["Upgrader","getNPMPackage","npmPackage","getProject","project","getTarget","semVerFactory","target","raw","setRequirements","requirements","setTarget","syncCodemodsTarget","codemodsTarget","major","minor","patch","logger","debug","f","overrideCodemodsTarget","setLogger","onConfirm","callback","confirmationCallback","dry","enabled","isDry","addRequirement","requirement","push","fRequired","isRequired","name","upgrade","info","strapiVersion","warn","range","rangeFromVersions","codemodsRange","npmVersionsMatches","findVersionsInRange","length","checkRequirements","runCodemods","refresh","updateDependencies","installDependencies","e","erroredReport","unknownToError","successReport","confirm","message","context","pass","error","test","onSuccessfulRequirement","onFailedRequirement","hasChildren","children","originalError","errorMessage","warningMessage","confirmationMessage","Error","response","packageJSON","packageJSONPath","json","createJSONTransformAPI","dependencies","get","strapiDependencies","getScopedStrapiDependencies","forEach","dependency","set","updatedPackageJSON","root","chalk","italic","saveJSON","version","Object","entries","isScopedStrapiPackage","startsWith","projectConstants","isOnCurrentStrapiVersion","isValidSemVer","projectPath","cwd","packageManagerName","packageManager","getPreferred","stdout","stderr","codemodRunner","codemodRunnerFactory","run","constructor","resolveNPMTarget","isSemverInstance","findVersion","NPMCandidateNotFoundError","isSemVerReleaseType","at","upgraderFactory","npmTarget","semverTarget","semver","eq","success"],"mappings":"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"}
1
+ {"version":3,"file":"upgrader.js","sources":["../../../../src/modules/upgrader/upgrader.ts"],"sourcesContent":["import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { NPMCandidateNotFoundError, unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { AppProject } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: AppProject;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: AppProject, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n getNPMPackage(): NPM.Package {\n return this.npmPackage;\n }\n\n getProject(): AppProject {\n return this.project;\n }\n\n getTarget(): Version.SemVer {\n return semVerFactory(this.target.raw);\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.951\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug?.(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug?.(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug?.(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info?.(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn?.(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug?.(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info?.(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info?.(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n // We need to refresh the project files to make sure we have\n // the latest version of each file (including package.json) for the next steps\n this.logger?.debug?.('Refreshing project information...');\n this.project.refresh();\n\n this.logger?.info?.(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info?.(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n async confirm(message: string): Promise<boolean> {\n if (typeof this.confirmationCallback !== 'function') {\n return true;\n }\n\n return this.confirmationCallback(message);\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn?.(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug?.(\n `Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`\n );\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug?.(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug?.(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies installation (${chalk.italic('dry mode')})`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n\n codemodRunner.dry(this.isDry);\n\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion => {\n // Semver\n if (isSemverInstance(target)) {\n const version = npmPackage.findVersion(target);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(target);\n }\n\n return version;\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n const version = npmVersionsMatches.at(-1);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(range, `The project is already up-to-date (${target})`);\n }\n\n return version;\n }\n\n throw new NPMCandidateNotFoundError(target);\n};\n\nexport const upgraderFactory = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const npmTarget = resolveNPMTarget(project, target, npmPackage);\n const semverTarget = semVerFactory(npmTarget.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already using v${semverTarget}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n"],"names":["Upgrader","getNPMPackage","npmPackage","getProject","project","getTarget","semVerFactory","target","raw","setRequirements","requirements","setTarget","syncCodemodsTarget","codemodsTarget","major","minor","patch","logger","debug","f","overrideCodemodsTarget","setLogger","onConfirm","callback","confirmationCallback","dry","enabled","isDry","addRequirement","requirement","push","fRequired","isRequired","name","upgrade","info","strapiVersion","warn","range","rangeFromVersions","codemodsRange","npmVersionsMatches","findVersionsInRange","length","checkRequirements","runCodemods","refresh","updateDependencies","installDependencies","e","erroredReport","unknownToError","successReport","confirm","message","context","pass","error","test","onSuccessfulRequirement","onFailedRequirement","hasChildren","children","originalError","errorMessage","warningMessage","confirmationMessage","Error","response","packageJSON","packageJSONPath","json","createJSONTransformAPI","dependencies","get","strapiDependencies","getScopedStrapiDependencies","forEach","dependency","set","updatedPackageJSON","root","chalk","italic","saveJSON","version","Object","entries","isScopedStrapiPackage","startsWith","projectConstants","isOnCurrentStrapiVersion","isValidSemVer","projectPath","cwd","packageManagerName","packageManager","getPreferred","stdout","stderr","codemodRunner","codemodRunnerFactory","run","resolveNPMTarget","isSemverInstance","findVersion","NPMCandidateNotFoundError","isSemVerReleaseType","at","upgraderFactory","npmTarget","semverTarget","semver","eq","success"],"mappings":"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"}
@@ -8,7 +8,6 @@ import 'node:assert';
8
8
  import 'fs-extra';
9
9
  import { semVerFactory, isValidSemVer, isSemverInstance, isSemVerReleaseType } from '../version/semver.mjs';
10
10
  import { rangeFromVersions } from '../version/range.mjs';
11
- import '../version/types.mjs';
12
11
  import 'fast-glob';
13
12
  import 'jscodeshift/src/Runner';
14
13
  import 'lodash/fp';
@@ -1 +1 @@
1
- {"version":3,"file":"upgrader.mjs","sources":["../../../../src/modules/upgrader/upgrader.ts"],"sourcesContent":["import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { NPMCandidateNotFoundError, unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { AppProject } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: AppProject;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: AppProject, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n getNPMPackage(): NPM.Package {\n return this.npmPackage;\n }\n\n getProject(): AppProject {\n return this.project;\n }\n\n getTarget(): Version.SemVer {\n return semVerFactory(this.target.raw);\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.951\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug?.(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug?.(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug?.(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info?.(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn?.(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug?.(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info?.(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info?.(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n // We need to refresh the project files to make sure we have\n // the latest version of each file (including package.json) for the next steps\n this.logger?.debug?.('Refreshing project information...');\n this.project.refresh();\n\n this.logger?.info?.(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info?.(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n async confirm(message: string): Promise<boolean> {\n if (typeof this.confirmationCallback !== 'function') {\n return true;\n }\n\n return this.confirmationCallback(message);\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn?.(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug?.(\n `Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`\n );\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug?.(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug?.(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies installation (${chalk.italic('dry mode')})`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n\n codemodRunner.dry(this.isDry);\n\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion => {\n // Semver\n if (isSemverInstance(target)) {\n const version = npmPackage.findVersion(target);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(target);\n }\n\n return version;\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n const version = npmVersionsMatches.at(-1);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(range, `The project is already up-to-date (${target})`);\n }\n\n return version;\n }\n\n throw new NPMCandidateNotFoundError(target);\n};\n\nexport const upgraderFactory = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const npmTarget = resolveNPMTarget(project, target, npmPackage);\n const semverTarget = semVerFactory(npmTarget.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already using v${semverTarget}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n"],"names":["Upgrader","getNPMPackage","npmPackage","getProject","project","getTarget","semVerFactory","target","raw","setRequirements","requirements","setTarget","syncCodemodsTarget","codemodsTarget","major","minor","patch","logger","debug","f","overrideCodemodsTarget","setLogger","onConfirm","callback","confirmationCallback","dry","enabled","isDry","addRequirement","requirement","push","fRequired","isRequired","name","upgrade","info","strapiVersion","warn","range","rangeFromVersions","codemodsRange","npmVersionsMatches","findVersionsInRange","length","checkRequirements","runCodemods","refresh","updateDependencies","installDependencies","e","erroredReport","unknownToError","successReport","confirm","message","context","pass","error","test","onSuccessfulRequirement","onFailedRequirement","hasChildren","children","originalError","errorMessage","warningMessage","confirmationMessage","Error","response","packageJSON","packageJSONPath","json","createJSONTransformAPI","dependencies","get","strapiDependencies","getScopedStrapiDependencies","forEach","dependency","set","updatedPackageJSON","root","chalk","italic","saveJSON","version","Object","entries","isScopedStrapiPackage","startsWith","projectConstants","isOnCurrentStrapiVersion","isValidSemVer","projectPath","cwd","packageManagerName","packageManager","getPreferred","stdout","stderr","codemodRunner","codemodRunnerFactory","run","constructor","resolveNPMTarget","isSemverInstance","findVersion","NPMCandidateNotFoundError","isSemVerReleaseType","at","upgraderFactory","npmTarget","semverTarget","semver","eq","success"],"mappings":";;;;;;;;;;;;;;;;;;;;AA2BO,MAAMA,QAAAA,CAAAA;IAgCXC,aAA6B,GAAA;QAC3B,OAAO,IAAI,CAACC,UAAU;AACxB;IAEAC,UAAyB,GAAA;QACvB,OAAO,IAAI,CAACC,OAAO;AACrB;IAEAC,SAA4B,GAAA;AAC1B,QAAA,OAAOC,aAAc,CAAA,IAAI,CAACC,MAAM,CAACC,GAAG,CAAA;AACtC;AAEAC,IAAAA,eAAAA,CAAgBC,YAAuC,EAAE;QACvD,IAAI,CAACA,YAAY,GAAGA,YAAAA;AACpB,QAAA,OAAO,IAAI;AACb;AAEAC,IAAAA,SAAAA,CAAUJ,MAAsB,EAAE;QAChC,IAAI,CAACA,MAAM,GAAGA,MAAAA;AACd,QAAA,OAAO,IAAI;AACb;IAEAK,kBAAqB,GAAA;;;;;;;;AAQnB,QAAA,IAAI,CAACC,cAAc,GAAGP,aAAAA,CACpB,CAAC,EAAE,IAAI,CAACC,MAAM,CAACO,KAAK,CAAC,CAAC,EAAE,IAAI,CAACP,MAAM,CAACQ,KAAK,CAAC,CAAC,EAAE,IAAI,CAACR,MAAM,CAACS,KAAK,CAAC,CAAC,CAAA;AAGlE,QAAA,IAAI,CAACC,MAAM,EAAEC,KAAAA,GACX,CAAC,kGAAkG,EAAEC,OAAS,CAC5G,IAAI,CAACN,cAAc,EACnB,CAAC,CAAA;AAGL,QAAA,OAAO,IAAI;AACb;AAEAO,IAAAA,sBAAAA,CAAuBb,MAAsB,EAAE;QAC7C,IAAI,CAACM,cAAc,GAAGN,MAAAA;QAEtB,IAAI,CAACU,MAAM,EAAEC,KACX,GAAA,CAAC,qEAAqE,EAAEC,OAAS,CAACZ,MAAAA,CAAAA,CAAQ,CAAC,CAAA;AAG7F,QAAA,OAAO,IAAI;AACb;AAEAc,IAAAA,SAAAA,CAAUJ,MAAc,EAAE;QACxB,IAAI,CAACA,MAAM,GAAGA,MAAAA;AACd,QAAA,OAAO,IAAI;AACb;AAEAK,IAAAA,SAAAA,CAAUC,QAAqC,EAAE;QAC/C,IAAI,CAACC,oBAAoB,GAAGD,QAAAA;AAC5B,QAAA,OAAO,IAAI;AACb;IAEAE,GAAIC,CAAAA,OAAAA,GAAmB,IAAI,EAAE;QAC3B,IAAI,CAACC,KAAK,GAAGD,OAAAA;AACb,QAAA,OAAO,IAAI;AACb;AAEAE,IAAAA,cAAAA,CAAeC,WAAoC,EAAE;AACnD,QAAA,IAAI,CAACnB,YAAY,CAACoB,IAAI,CAACD,WAAAA,CAAAA;AAEvB,QAAA,MAAME,SAAYF,GAAAA,WAAAA,CAAYG,UAAU,GAAG,YAAe,GAAA,YAAA;AAC1D,QAAA,IAAI,CAACf,MAAM,EAAEC,KACX,GAAA,CAAC,wCAAwC,EAAEC,SAAW,CAACU,YAAYI,IAAI,CAAA,CAAE,CAAC,EAAEF,UAAU,CAAC,CAAA;AAGzF,QAAA,OAAO,IAAI;AACb;AAEA,IAAA,MAAMG,OAAkC,GAAA;QACtC,IAAI,CAACjB,MAAM,EAAEkB,IACX,GAAA,CAAC,eAAe,EAAEhB,OAAS,CAAC,IAAI,CAACf,OAAO,CAACgC,aAAa,CAAE,CAAA,IAAI,EAAEjB,OAAS,CAAC,IAAI,CAACZ,MAAM,CAAA,CAAE,CAAC,CAAA;QAGxF,IAAI,IAAI,CAACoB,KAAK,EAAE;YACd,IAAI,CAACV,MAAM,EAAEoB,IACX,GAAA,gFAAA,CAAA;AAEJ;QAEA,MAAMC,KAAAA,GAAQC,iBAAkB,CAAA,IAAI,CAACnC,OAAO,CAACgC,aAAa,EAAE,IAAI,CAAC7B,MAAM,CAAA;QACvE,MAAMiC,aAAAA,GAAgBD,iBAAkB,CAAA,IAAI,CAACnC,OAAO,CAACgC,aAAa,EAAE,IAAI,CAACvB,cAAc,CAAA;AAEvF,QAAA,MAAM4B,qBAAqB,IAAI,CAACvC,UAAU,EAAEwC,mBAAAA,CAAoBJ,UAAU,EAAE;AAE5E,QAAA,IAAI,CAACrB,MAAM,EAAEC,QACX,CAAC,MAAM,EAAEC,SAAW,CAACsB,kBAAmBE,CAAAA,MAAM,EAAE,qBAAqB,EAAExB,YAAc,CAACmB,OAAO,CAAC,CAAA;QAGhG,IAAI;AACF,YAAA,IAAI,CAACrB,MAAM,EAAEkB,OAAOhB,WAAa,CAAC,sBAAwB,EAAA;AAAC,gBAAA,CAAA;AAAG,gBAAA;AAAE,aAAA,CAAA,CAAA;AAChE,YAAA,MAAM,IAAI,CAACyB,iBAAiB,CAAC,IAAI,CAAClC,YAAY,EAAE;AAC9C+B,gBAAAA,kBAAAA;gBACArC,OAAS,EAAA,IAAI,CAACA,OAAO;gBACrBG,MAAQ,EAAA,IAAI,CAACA;AACf,aAAA,CAAA;AAEA,YAAA,IAAI,CAACU,MAAM,EAAEkB,OAAOhB,WAAa,CAAC,wCAA0C,EAAA;AAAC,gBAAA,CAAA;AAAG,gBAAA;AAAE,aAAA,CAAA,CAAA;YAClF,MAAM,IAAI,CAAC0B,WAAW,CAACL,aAAAA,CAAAA;;;YAIvB,IAAI,CAACvB,MAAM,EAAEC,KAAQ,GAAA,mCAAA,CAAA;YACrB,IAAI,CAACd,OAAO,CAAC0C,OAAO,EAAA;AAEpB,YAAA,IAAI,CAAC7B,MAAM,EAAEkB,OAAOhB,WAAa,CAAC,+BAAiC,EAAA;AAAC,gBAAA,CAAA;AAAG,gBAAA;AAAE,aAAA,CAAA,CAAA;YACzE,MAAM,IAAI,CAAC4B,kBAAkB,EAAA;AAE7B,YAAA,IAAI,CAAC9B,MAAM,EAAEkB,OAAOhB,WAAa,CAAC,yBAA2B,EAAA;AAAC,gBAAA,CAAA;AAAG,gBAAA;AAAE,aAAA,CAAA,CAAA;YACnE,MAAM,IAAI,CAAC6B,mBAAmB,EAAA;AAChC,SAAA,CAAE,OAAOC,CAAG,EAAA;AACV,YAAA,OAAOC,cAAcC,cAAeF,CAAAA,CAAAA,CAAAA,CAAAA;AACtC;QAEA,OAAOG,aAAAA,EAAAA;AACT;IAEA,MAAMC,OAAAA,CAAQC,OAAe,EAAoB;AAC/C,QAAA,IAAI,OAAO,IAAI,CAAC9B,oBAAoB,KAAK,UAAY,EAAA;YACnD,OAAO,IAAA;AACT;QAEA,OAAO,IAAI,CAACA,oBAAoB,CAAC8B,OAAAA,CAAAA;AACnC;AAEA,IAAA,MAAcV,iBACZlC,CAAAA,YAAuC,EACvC6C,OAAgC,EAChC;QACA,KAAK,MAAM1B,eAAenB,YAAc,CAAA;YACtC,MAAM,EAAE8C,IAAI,EAAEC,KAAK,EAAE,GAAG,MAAM5B,WAAY6B,CAAAA,IAAI,CAACH,OAAAA,CAAAA;AAE/C,YAAA,IAAIC,IAAM,EAAA;AACR,gBAAA,MAAM,IAAI,CAACG,uBAAuB,CAAC9B,WAAa0B,EAAAA,OAAAA,CAAAA;aAC3C,MAAA;AACL,gBAAA,MAAM,IAAI,CAACK,mBAAmB,CAAC/B,WAAa4B,EAAAA,KAAAA,CAAAA;AAC9C;AACF;AACF;AAEA,IAAA,MAAcE,uBACZ9B,CAAAA,WAAoC,EACpC0B,OAAgC,EACjB;AACf,QAAA,MAAMM,WAAchC,GAAAA,WAAAA,CAAYiC,QAAQ,CAACnB,MAAM,GAAG,CAAA;AAElD,QAAA,IAAIkB,WAAa,EAAA;AACf,YAAA,MAAM,IAAI,CAACjB,iBAAiB,CAACf,WAAAA,CAAYiC,QAAQ,EAAEP,OAAAA,CAAAA;AACrD;AACF;AAEA,IAAA,MAAcK,mBACZ/B,CAAAA,WAAoC,EACpCkC,aAAoB,EACL;AACf,QAAA,MAAMC,eAAe,CAAC,oBAAoB,EAAED,aAAAA,CAAcT,OAAO,CAAC,EAAE,EAAEnC,SAAW,CAC/EU,WAAAA,CAAYI,IAAI,CAAA,CAChB,CAAC,CAAC;QACJ,MAAMgC,cAAAA,GAAiBF,cAAcT,OAAO;QAC5C,MAAMY,mBAAAA,GAAsB,CAAC,6BAA6B,EAAE/C,SAAW,CAACU,WAAYI,CAAAA,IAAI,CAAE,CAAA,GAAG,CAAC;QAE9F,MAAMwB,KAAAA,GAAQ,IAAIU,KAAMH,CAAAA,YAAAA,CAAAA;QAExB,IAAInC,WAAAA,CAAYG,UAAU,EAAE;YAC1B,MAAMyB,KAAAA;AACR;QAEA,IAAI,CAACxC,MAAM,EAAEoB,IAAO4B,GAAAA,cAAAA,CAAAA;AAEpB,QAAA,MAAMG,QAAW,GAAA,MAAM,IAAI,CAAC5C,oBAAoB,GAAG0C,mBAAAA,CAAAA;AAEnD,QAAA,IAAI,CAACE,QAAU,EAAA;YACb,MAAMX,KAAAA;AACR;AACF;AAEA,IAAA,MAAcV,kBAAoC,GAAA;QAChD,MAAM,EAAEsB,WAAW,EAAEC,eAAe,EAAE,GAAG,IAAI,CAAClE,OAAO;AAErD,QAAA,MAAMmE,OAAOC,sBAAuBH,CAAAA,WAAAA,CAAAA;AAEpC,QAAA,MAAMI,YAAeF,GAAAA,IAAAA,CAAKG,GAAG,CAAyB,gBAAgB,EAAC,CAAA;AACvE,QAAA,MAAMC,kBAAqB,GAAA,IAAI,CAACC,2BAA2B,CAACH,YAAAA,CAAAA;AAE5D,QAAA,IAAI,CAACxD,MAAM,EAAEC,KAAAA,GACX,CAAC,MAAM,EAAEC,SAAW,CAACwD,kBAAAA,CAAmBhC,MAAM,CAAA,CAAE,0BAA0B,CAAC,CAAA;AAE7EgC,QAAAA,kBAAAA,CAAmBE,OAAO,CAAC,CAACC,UAAAA,GAC1B,IAAI,CAAC7D,MAAM,EAAEC,KAAQ,GAAA,CAAC,EAAE,EAAE4D,UAAU,CAAC,CAAE,CAAA,CAAC,EAAE,EAAEA,UAAU,CAAC,CAAE,CAAA,CAAC,IAAI,EAAE,IAAI,CAACvE,MAAM,CAAC,CAAC,CAAC,CAAA,CAAA;QAGhF,IAAIoE,kBAAAA,CAAmBhC,MAAM,KAAK,CAAG,EAAA;AACnC,YAAA;AACF;AAEAgC,QAAAA,kBAAAA,CAAmBE,OAAO,CAAC,CAAC,CAAC5C,IAAK,CAAA,GAAKsC,KAAKQ,GAAG,CAAC,CAAC,aAAa,EAAE9C,KAAK,CAAC,EAAE,IAAI,CAAC1B,MAAM,CAACC,GAAG,CAAA,CAAA;QAEvF,MAAMwE,kBAAAA,GAAqBT,KAAKU,IAAI,EAAA;QAEpC,IAAI,IAAI,CAACtD,KAAK,EAAE;AACd,YAAA,IAAI,CAACV,MAAM,EAAEC,KAAAA,GAAQ,CAAC,8BAA8B,EAAEgE,KAAAA,CAAMC,MAAM,CAAC,UAAY,CAAA,CAAA,CAAC,CAAC,CAAA;AACjF,YAAA;AACF;AAEA,QAAA,MAAMC,SAASd,eAAiBU,EAAAA,kBAAAA,CAAAA;AAClC;AAEQJ,IAAAA,2BAAAA,CAA4BH,YAAoC,EAAuB;AAC7F,QAAA,MAAM,EAAErC,aAAa,EAAE,GAAG,IAAI,CAAChC,OAAO;AAEtC,QAAA,MAAMuE,qBAA0C,EAAE;;QAGlD,KAAK,MAAM,CAAC1C,IAAMoD,EAAAA,OAAAA,CAAQ,IAAIC,MAAOC,CAAAA,OAAO,CAACd,YAAe,CAAA,CAAA;AAC1D,YAAA,MAAMe,qBAAwBvD,GAAAA,IAAAA,CAAKwD,UAAU,CAACC,4BAA6C,CAAA;AAC3F,YAAA,MAAMC,wBAA2BC,GAAAA,aAAAA,CAAcP,OAAYA,CAAAA,IAAAA,OAAAA,KAAYjD,cAAc5B,GAAG;AAExF,YAAA,IAAIgF,yBAAyBG,wBAA0B,EAAA;AACrDhB,gBAAAA,kBAAAA,CAAmB7C,IAAI,CAAC;AAACG,oBAAAA,IAAAA;oBAAM3B,aAAc+E,CAAAA,OAAAA;AAAS,iBAAA,CAAA;AACxD;AACF;QAEA,OAAOV,kBAAAA;AACT;AAEA,IAAA,MAAc3B,mBAAqC,GAAA;AACjD,QAAA,MAAM6C,WAAc,GAAA,IAAI,CAACzF,OAAO,CAAC0F,GAAG;AAEpC,QAAA,MAAMC,kBAAqB,GAAA,MAAMC,cAAeC,CAAAA,YAAY,CAACJ,WAAAA,CAAAA;AAE7D,QAAA,IAAI,CAAC5E,MAAM,EAAEC,KAAAA,GAAQ,CAAC,MAAM,EAAEC,SAAW,CAAC4E,kBAAoB,CAAA,CAAA,mBAAmB,CAAC,CAAA;QAElF,IAAI,IAAI,CAACpE,KAAK,EAAE;AACd,YAAA,IAAI,CAACV,MAAM,EAAEC,KAAAA,GAAQ,CAAC,oCAAoC,EAAEgE,KAAAA,CAAMC,MAAM,CAAC,UAAY,CAAA,CAAA,CAAC,CAAC,CAAA;AACvF,YAAA;AACF;AAEA,QAAA,MAAMa,cAAehD,CAAAA,mBAAmB,CAAC6C,WAAAA,EAAaE,kBAAoB,EAAA;YACxEG,MAAQ,EAAA,IAAI,CAACjF,MAAM,EAAEiF,MAAAA;YACrBC,MAAQ,EAAA,IAAI,CAAClF,MAAM,EAAEkF;AACvB,SAAA,CAAA;AACF;IAEA,MAActD,WAAAA,CAAYP,KAAoB,EAAiB;AAC7D,QAAA,MAAM8D,aAAgBC,GAAAA,oBAAAA,CAAqB,IAAI,CAACjG,OAAO,EAAEkC,KAAAA,CAAAA;AAEzD8D,QAAAA,aAAAA,CAAc3E,GAAG,CAAC,IAAI,CAACE,KAAK,CAAA;QAE5B,IAAI,IAAI,CAACV,MAAM,EAAE;AACfmF,YAAAA,aAAAA,CAAc/E,SAAS,CAAC,IAAI,CAACJ,MAAM,CAAA;AACrC;AAEA,QAAA,MAAMmF,cAAcE,GAAG,EAAA;AACzB;AAtRAC,IAAAA,WAAAA,CAAYnG,OAAmB,EAAEG,MAAsB,EAAEL,UAAuB,CAAE;QAChF,IAAI,CAACE,OAAO,GAAGA,OAAAA;QACf,IAAI,CAACF,UAAU,GAAGA,UAAAA;QAElB,IAAI,CAACK,MAAM,GAAGA,MAAAA;AACd,QAAA,IAAI,CAACK,kBAAkB,EAAA;QAEvB,IAAI,CAACe,KAAK,GAAG,KAAA;QAEb,IAAI,CAACjB,YAAY,GAAG,EAAE;QAEtB,IAAI,CAACO,MAAM,GAAG,IAAA;QACd,IAAI,CAACO,oBAAoB,GAAG,IAAA;AAC9B;AA0QF;AAEA;;;;AAIC,IACD,MAAMgF,gBAAAA,GAAmB,CACvBpG,OAAAA,EACAG,MACAL,EAAAA,UAAAA,GAAAA;;AAGA,IAAA,IAAIuG,iBAAiBlG,MAAS,CAAA,EAAA;QAC5B,MAAM8E,OAAAA,GAAUnF,UAAWwG,CAAAA,WAAW,CAACnG,MAAAA,CAAAA;AAEvC,QAAA,IAAI,CAAC8E,OAAS,EAAA;AACZ,YAAA,MAAM,IAAIsB,yBAA0BpG,CAAAA,MAAAA,CAAAA;AACtC;QAEA,OAAO8E,OAAAA;AACT;;AAGA,IAAA,IAAIuB,oBAAoBrG,MAAS,CAAA,EAAA;AAC/B,QAAA,MAAM+B,KAAQC,GAAAA,iBAAAA,CAAkBnC,OAAQgC,CAAAA,aAAa,EAAE7B,MAAAA,CAAAA;QACvD,MAAMkC,kBAAAA,GAAqBvC,UAAWwC,CAAAA,mBAAmB,CAACJ,KAAAA,CAAAA;;AAG1D,QAAA,MAAM+C,OAAU5C,GAAAA,kBAAAA,CAAmBoE,EAAE,CAAC,CAAC,CAAA,CAAA;AAEvC,QAAA,IAAI,CAACxB,OAAS,EAAA;YACZ,MAAM,IAAIsB,0BAA0BrE,KAAO,EAAA,CAAC,mCAAmC,EAAE/B,MAAAA,CAAO,CAAC,CAAC,CAAA;AAC5F;QAEA,OAAO8E,OAAAA;AACT;AAEA,IAAA,MAAM,IAAIsB,yBAA0BpG,CAAAA,MAAAA,CAAAA;AACtC,CAAA;AAEauG,MAAAA,eAAAA,GAAkB,CAC7B1G,OAAAA,EACAG,MACAL,EAAAA,UAAAA,GAAAA;IAEA,MAAM6G,SAAAA,GAAYP,gBAAiBpG,CAAAA,OAAAA,EAASG,MAAQL,EAAAA,UAAAA,CAAAA;IACpD,MAAM8G,YAAAA,GAAe1G,aAAcyG,CAAAA,SAAAA,CAAU1B,OAAO,CAAA;AAEpD,IAAA,IAAI4B,OAAOC,EAAE,CAACF,YAAc5G,EAAAA,OAAAA,CAAQgC,aAAa,CAAG,EAAA;AAClD,QAAA,MAAM,IAAI+B,KAAM,CAAA,CAAC,8BAA8B,EAAE6C,aAAa,CAAC,CAAA;AACjE;IAEA,OAAO,IAAIhH,QAASI,CAAAA,OAAAA,EAAS4G,YAAc9G,EAAAA,UAAAA,CAAAA;AAC7C;AAEA,MAAMkD,aAAAA,GAAgB,KAAsB;QAAE+D,OAAS,EAAA,IAAA;QAAM1D,KAAO,EAAA;KAAK,CAAA;AACzE,MAAMP,aAAAA,GAAgB,CAACO,KAAAA,IAAiC;QAAE0D,OAAS,EAAA,KAAA;AAAO1D,QAAAA;KAAM,CAAA;;;;"}
1
+ {"version":3,"file":"upgrader.mjs","sources":["../../../../src/modules/upgrader/upgrader.ts"],"sourcesContent":["import chalk from 'chalk';\nimport semver from 'semver';\nimport { packageManager } from '@strapi/utils';\n\nimport { createJSONTransformAPI, saveJSON } from '../json';\nimport { constants as projectConstants } from '../project';\nimport {\n isSemverInstance,\n isSemVerReleaseType,\n isValidSemVer,\n rangeFromVersions,\n semVerFactory,\n} from '../version';\nimport { NPMCandidateNotFoundError, unknownToError } from '../error';\nimport * as f from '../format';\nimport { codemodRunnerFactory } from '../codemod-runner';\n\nimport type { Upgrader as UpgraderInterface, UpgradeReport } from './types';\nimport type { Version } from '../version';\nimport type { Logger } from '../logger';\nimport type { Requirement } from '../requirement';\nimport type { NPM } from '../npm';\nimport type { AppProject } from '../project';\nimport type { ConfirmationCallback } from '../common/types';\n\ntype DependenciesEntries = Array<[name: string, version: Version.SemVer]>;\n\nexport class Upgrader implements UpgraderInterface {\n private readonly project: AppProject;\n\n private readonly npmPackage: NPM.Package;\n\n private target: Version.SemVer;\n\n private codemodsTarget!: Version.SemVer;\n\n private isDry: boolean;\n\n private logger: Logger | null;\n\n private requirements: Requirement.Requirement[];\n\n private confirmationCallback: ConfirmationCallback | null;\n\n constructor(project: AppProject, target: Version.SemVer, npmPackage: NPM.Package) {\n this.project = project;\n this.npmPackage = npmPackage;\n\n this.target = target;\n this.syncCodemodsTarget();\n\n this.isDry = false;\n\n this.requirements = [];\n\n this.logger = null;\n this.confirmationCallback = null;\n }\n\n getNPMPackage(): NPM.Package {\n return this.npmPackage;\n }\n\n getProject(): AppProject {\n return this.project;\n }\n\n getTarget(): Version.SemVer {\n return semVerFactory(this.target.raw);\n }\n\n setRequirements(requirements: Requirement.Requirement[]) {\n this.requirements = requirements;\n return this;\n }\n\n setTarget(target: Version.SemVer) {\n this.target = target;\n return this;\n }\n\n syncCodemodsTarget() {\n // Extract the <major>.<minor>.<patch> version from the target and assign it to the codemods target\n //\n // This is useful when dealing with alphas, betas or release candidates:\n // e.g. \"5.0.0-beta.951\" becomes \"5.0.0\"\n //\n // For experimental versions (e.g. \"0.0.0-experimental.hex\"), it is necessary to\n // override the codemods target manually in order to run the appropriate ones.\n this.codemodsTarget = semVerFactory(\n `${this.target.major}.${this.target.minor}.${this.target.patch}`\n );\n\n this.logger?.debug?.(\n `The codemods target has been synced with the upgrade target. The codemod runner will now look for ${f.version(\n this.codemodsTarget\n )}`\n );\n\n return this;\n }\n\n overrideCodemodsTarget(target: Version.SemVer) {\n this.codemodsTarget = target;\n\n this.logger?.debug?.(\n `Overriding the codemods target. The codemod runner will now look for ${f.version(target)}`\n );\n\n return this;\n }\n\n setLogger(logger: Logger) {\n this.logger = logger;\n return this;\n }\n\n onConfirm(callback: ConfirmationCallback | null) {\n this.confirmationCallback = callback;\n return this;\n }\n\n dry(enabled: boolean = true) {\n this.isDry = enabled;\n return this;\n }\n\n addRequirement(requirement: Requirement.Requirement) {\n this.requirements.push(requirement);\n\n const fRequired = requirement.isRequired ? '(required)' : '(optional)';\n this.logger?.debug?.(\n `Added a new requirement to the upgrade: ${f.highlight(requirement.name)} ${fRequired}`\n );\n\n return this;\n }\n\n async upgrade(): Promise<UpgradeReport> {\n this.logger?.info?.(\n `Upgrading from ${f.version(this.project.strapiVersion)} to ${f.version(this.target)}`\n );\n\n if (this.isDry) {\n this.logger?.warn?.(\n 'Running the upgrade in dry mode. No files will be modified during the process.'\n );\n }\n\n const range = rangeFromVersions(this.project.strapiVersion, this.target);\n const codemodsRange = rangeFromVersions(this.project.strapiVersion, this.codemodsTarget);\n\n const npmVersionsMatches = this.npmPackage?.findVersionsInRange(range) ?? [];\n\n this.logger?.debug?.(\n `Found ${f.highlight(npmVersionsMatches.length)} versions satisfying ${f.versionRange(range)}`\n );\n\n try {\n this.logger?.info?.(f.upgradeStep('Checking requirement', [1, 4]));\n await this.checkRequirements(this.requirements, {\n npmVersionsMatches,\n project: this.project,\n target: this.target,\n });\n\n this.logger?.info?.(f.upgradeStep('Applying the latest code modifications', [2, 4]));\n await this.runCodemods(codemodsRange);\n\n // We need to refresh the project files to make sure we have\n // the latest version of each file (including package.json) for the next steps\n this.logger?.debug?.('Refreshing project information...');\n this.project.refresh();\n\n this.logger?.info?.(f.upgradeStep('Upgrading Strapi dependencies', [3, 4]));\n await this.updateDependencies();\n\n this.logger?.info?.(f.upgradeStep('Installing dependencies', [4, 4]));\n await this.installDependencies();\n } catch (e) {\n return erroredReport(unknownToError(e));\n }\n\n return successReport();\n }\n\n async confirm(message: string): Promise<boolean> {\n if (typeof this.confirmationCallback !== 'function') {\n return true;\n }\n\n return this.confirmationCallback(message);\n }\n\n private async checkRequirements(\n requirements: Requirement.Requirement[],\n context: Requirement.TestContext\n ) {\n for (const requirement of requirements) {\n const { pass, error } = await requirement.test(context);\n\n if (pass) {\n await this.onSuccessfulRequirement(requirement, context);\n } else {\n await this.onFailedRequirement(requirement, error);\n }\n }\n }\n\n private async onSuccessfulRequirement(\n requirement: Requirement.Requirement,\n context: Requirement.TestContext\n ): Promise<void> {\n const hasChildren = requirement.children.length > 0;\n\n if (hasChildren) {\n await this.checkRequirements(requirement.children, context);\n }\n }\n\n private async onFailedRequirement(\n requirement: Requirement.Requirement,\n originalError: Error\n ): Promise<void> {\n const errorMessage = `Requirement failed: ${originalError.message} (${f.highlight(\n requirement.name\n )})`;\n const warningMessage = originalError.message;\n const confirmationMessage = `Ignore optional requirement \"${f.highlight(requirement.name)}\" ?`;\n\n const error = new Error(errorMessage);\n\n if (requirement.isRequired) {\n throw error;\n }\n\n this.logger?.warn?.(warningMessage);\n\n const response = await this.confirmationCallback?.(confirmationMessage);\n\n if (!response) {\n throw error;\n }\n }\n\n private async updateDependencies(): Promise<void> {\n const { packageJSON, packageJSONPath } = this.project;\n\n const json = createJSONTransformAPI(packageJSON);\n\n const dependencies = json.get<Record<string, string>>('dependencies', {});\n const strapiDependencies = this.getScopedStrapiDependencies(dependencies);\n\n this.logger?.debug?.(\n `Found ${f.highlight(strapiDependencies.length)} dependency(ies) to update`\n );\n strapiDependencies.forEach((dependency) =>\n this.logger?.debug?.(`- ${dependency[0]} (${dependency[1]} -> ${this.target})`)\n );\n\n if (strapiDependencies.length === 0) {\n return;\n }\n\n strapiDependencies.forEach(([name]) => json.set(`dependencies.${name}`, this.target.raw));\n\n const updatedPackageJSON = json.root();\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies update (${chalk.italic('dry mode')})`);\n return;\n }\n\n await saveJSON(packageJSONPath, updatedPackageJSON);\n }\n\n private getScopedStrapiDependencies(dependencies: Record<string, string>): DependenciesEntries {\n const { strapiVersion } = this.project;\n\n const strapiDependencies: DependenciesEntries = [];\n\n // Find all @strapi/* packages matching the current Strapi version\n for (const [name, version] of Object.entries(dependencies)) {\n const isScopedStrapiPackage = name.startsWith(projectConstants.SCOPED_STRAPI_PACKAGE_PREFIX);\n const isOnCurrentStrapiVersion = isValidSemVer(version) && version === strapiVersion.raw;\n\n if (isScopedStrapiPackage && isOnCurrentStrapiVersion) {\n strapiDependencies.push([name, semVerFactory(version)]);\n }\n }\n\n return strapiDependencies;\n }\n\n private async installDependencies(): Promise<void> {\n const projectPath = this.project.cwd;\n\n const packageManagerName = await packageManager.getPreferred(projectPath);\n\n this.logger?.debug?.(`Using ${f.highlight(packageManagerName)} as package manager`);\n\n if (this.isDry) {\n this.logger?.debug?.(`Skipping dependencies installation (${chalk.italic('dry mode')})`);\n return;\n }\n\n await packageManager.installDependencies(projectPath, packageManagerName, {\n stdout: this.logger?.stdout,\n stderr: this.logger?.stderr,\n });\n }\n\n private async runCodemods(range: Version.Range): Promise<void> {\n const codemodRunner = codemodRunnerFactory(this.project, range);\n\n codemodRunner.dry(this.isDry);\n\n if (this.logger) {\n codemodRunner.setLogger(this.logger);\n }\n\n await codemodRunner.run();\n }\n}\n\n/**\n * Resolves the NPM target version based on the given project, target, and NPM package.\n * If target is a SemVer, it directly finds it. If it's a release type (major, minor, patch),\n * it calculates the range of versions for this release type and returns the latest version within this range.\n */\nconst resolveNPMTarget = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n): NPM.NPMPackageVersion => {\n // Semver\n if (isSemverInstance(target)) {\n const version = npmPackage.findVersion(target);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(target);\n }\n\n return version;\n }\n\n // Release Types\n if (isSemVerReleaseType(target)) {\n const range = rangeFromVersions(project.strapiVersion, target);\n const npmVersionsMatches = npmPackage.findVersionsInRange(range);\n\n // The targeted version is the latest one that matches the given range\n const version = npmVersionsMatches.at(-1);\n\n if (!version) {\n throw new NPMCandidateNotFoundError(range, `The project is already up-to-date (${target})`);\n }\n\n return version;\n }\n\n throw new NPMCandidateNotFoundError(target);\n};\n\nexport const upgraderFactory = (\n project: AppProject,\n target: Version.ReleaseType | Version.SemVer,\n npmPackage: NPM.Package\n) => {\n const npmTarget = resolveNPMTarget(project, target, npmPackage);\n const semverTarget = semVerFactory(npmTarget.version);\n\n if (semver.eq(semverTarget, project.strapiVersion)) {\n throw new Error(`The project is already using v${semverTarget}`);\n }\n\n return new Upgrader(project, semverTarget, npmPackage);\n};\n\nconst successReport = (): UpgradeReport => ({ success: true, error: null });\nconst erroredReport = (error: Error): UpgradeReport => ({ success: false, error });\n"],"names":["Upgrader","getNPMPackage","npmPackage","getProject","project","getTarget","semVerFactory","target","raw","setRequirements","requirements","setTarget","syncCodemodsTarget","codemodsTarget","major","minor","patch","logger","debug","f","overrideCodemodsTarget","setLogger","onConfirm","callback","confirmationCallback","dry","enabled","isDry","addRequirement","requirement","push","fRequired","isRequired","name","upgrade","info","strapiVersion","warn","range","rangeFromVersions","codemodsRange","npmVersionsMatches","findVersionsInRange","length","checkRequirements","runCodemods","refresh","updateDependencies","installDependencies","e","erroredReport","unknownToError","successReport","confirm","message","context","pass","error","test","onSuccessfulRequirement","onFailedRequirement","hasChildren","children","originalError","errorMessage","warningMessage","confirmationMessage","Error","response","packageJSON","packageJSONPath","json","createJSONTransformAPI","dependencies","get","strapiDependencies","getScopedStrapiDependencies","forEach","dependency","set","updatedPackageJSON","root","chalk","italic","saveJSON","version","Object","entries","isScopedStrapiPackage","startsWith","projectConstants","isOnCurrentStrapiVersion","isValidSemVer","projectPath","cwd","packageManagerName","packageManager","getPreferred","stdout","stderr","codemodRunner","codemodRunnerFactory","run","resolveNPMTarget","isSemverInstance","findVersion","NPMCandidateNotFoundError","isSemVerReleaseType","at","upgraderFactory","npmTarget","semverTarget","semver","eq","success"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"range.js","sources":["../../../../src/modules/version/range.ts"],"sourcesContent":["import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType, semVerFactory } 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.Latest: {\n // Match anything greater than the current version\n return rangeFactory(`>${current.raw}`);\n }\n case Version.ReleaseType.Major: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using only the major version as the upper limit allows any minor,\n // patch, or build version to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <=5\", allowing any version\n // greater than \"4.15.4\" but less than \"6.0.0-0\".\n return rangeFactory(`>${current.raw} <=${nextMajor.major}`);\n }\n case Version.ReleaseType.Minor: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using the <major>.<minor>.<patch> version as the upper limit allows any minor,\n // patch, or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <5.0.0\", allowing any version\n // greater than \"4.15.4\" but less than \"5.0.0\".\n return rangeFactory(`>${current.raw} <${nextMajor.raw}`);\n }\n case Version.ReleaseType.Patch: {\n // For example, 4.15.4 returns 4.16.0\n const nextMinor = semVerFactory(current.raw).inc('minor');\n\n // Using only the minor version as the upper limit allows any patch\n // or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // minor version would result in \"4.16.0\".\n // The generated rule is \">4.15.4 <4.16.0\", allowing any version\n // greater than \"4.15.4\" but less than \"4.16.0\".\n return rangeFactory(`>${current.raw} <${nextMinor.raw}`);\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\nexport const isValidStringifiedRange = (str: string) => semver.validRange(str) !== null;\n\nexport const isRangeInstance = (range: unknown): range is semver.Range => {\n return range instanceof semver.Range;\n};\n"],"names":["rangeFactory","range","semver","Range","rangeFromReleaseType","current","identifier","Version","Latest","raw","Major","nextMajor","semVerFactory","inc","major","Minor","Patch","nextMinor","Error","rangeFromVersions","currentVersion","target","isSemverInstance","isSemVerReleaseType","isValidStringifiedRange","str","validRange","isRangeInstance"],"mappings":";;;;;;AAKO,MAAMA,eAAe,CAACC,KAAAA,GAAAA;IAC3B,OAAO,IAAIC,MAAOC,CAAAA,KAAK,CAACF,KAAAA,CAAAA;AAC1B;AAEO,MAAMG,oBAAuB,GAAA,CAACC,OAAyBC,EAAAA,UAAAA,GAAAA;IAC5D,OAAQA,UAAAA;QACN,KAAKC,iBAAmB,CAACC,MAAM;AAAE,YAAA;;AAE/B,gBAAA,OAAOR,aAAa,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,CAAC,CAAA;AACvC;QACA,KAAKF,iBAAmB,CAACG,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYC,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,GAAG,EAAEE,SAAAA,CAAUG,KAAK,CAAC,CAAC,CAAA;AAC5D;QACA,KAAKP,iBAAmB,CAACQ,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMJ,YAAYC,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,EAAE,EAAEE,SAAAA,CAAUF,GAAG,CAAC,CAAC,CAAA;AACzD;QACA,KAAKF,iBAAmB,CAACS,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYL,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,EAAE,EAAEQ,SAAAA,CAAUR,GAAG,CAAC,CAAC,CAAA;AACzD;AACA,QAAA;AAAS,YAAA;AACP,gBAAA,MAAM,IAAIS,KAAM,CAAA,iBAAA,CAAA;AAClB;AACF;AACF;AAEO,MAAMC,iBAAoB,GAAA,CAC/BC,cACAC,EAAAA,MAAAA,GAAAA;AAEA,IAAA,IAAIC,0BAAiBD,MAAS,CAAA,EAAA;AAC5B,QAAA,OAAOrB,YAAa,CAAA,CAAC,CAAC,EAAEoB,cAAeX,CAAAA,GAAG,CAAC,GAAG,EAAEY,MAAAA,CAAOZ,GAAG,CAAC,CAAC,CAAA;AAC9D;AAEA,IAAA,IAAIc,6BAAoBF,MAAS,CAAA,EAAA;AAC/B,QAAA,OAAOjB,qBAAqBgB,cAAgBC,EAAAA,MAAAA,CAAAA;AAC9C;IAEA,MAAM,IAAIH,MAAM,CAAC,oBAAoB,EAAEG,MAAO,CAAA,CAAC;AACjD;AAEO,MAAMG,0BAA0B,CAACC,GAAAA,GAAgBvB,OAAOwB,UAAU,CAACD,SAAS;AAE5E,MAAME,kBAAkB,CAAC1B,KAAAA,GAAAA;IAC9B,OAAOA,KAAAA,YAAiBC,OAAOC,KAAK;AACtC;;;;;;;;"}
1
+ {"version":3,"file":"range.js","sources":["../../../../src/modules/version/range.ts"],"sourcesContent":["import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType, semVerFactory } 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.Latest: {\n // Match anything greater than the current version\n return rangeFactory(`>${current.raw}`);\n }\n case Version.ReleaseType.Major: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using only the major version as the upper limit allows any minor,\n // patch, or build version to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <=5\", allowing any version\n // greater than \"4.15.4\" but less than \"6.0.0-0\".\n return rangeFactory(`>${current.raw} <=${nextMajor.major}`);\n }\n case Version.ReleaseType.Minor: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using the <major>.<minor>.<patch> version as the upper limit allows any minor,\n // patch, or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <5.0.0\", allowing any version\n // greater than \"4.15.4\" but less than \"5.0.0\".\n return rangeFactory(`>${current.raw} <${nextMajor.raw}`);\n }\n case Version.ReleaseType.Patch: {\n // For example, 4.15.4 returns 4.16.0\n const nextMinor = semVerFactory(current.raw).inc('minor');\n\n // Using only the minor version as the upper limit allows any patch\n // or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // minor version would result in \"4.16.0\".\n // The generated rule is \">4.15.4 <4.16.0\", allowing any version\n // greater than \"4.15.4\" but less than \"4.16.0\".\n return rangeFactory(`>${current.raw} <${nextMinor.raw}`);\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\nexport const isValidStringifiedRange = (str: string) => semver.validRange(str) !== null;\n\nexport const isRangeInstance = (range: unknown): range is semver.Range => {\n return range instanceof semver.Range;\n};\n"],"names":["rangeFactory","range","semver","Range","rangeFromReleaseType","current","identifier","Version","Latest","raw","Major","nextMajor","semVerFactory","inc","major","Minor","Patch","nextMinor","Error","rangeFromVersions","currentVersion","target","isSemverInstance","isSemVerReleaseType","isValidStringifiedRange","str","validRange","isRangeInstance"],"mappings":";;;;;;AAKO,MAAMA,eAAe,CAACC,KAAAA,GAAAA;IAC3B,OAAO,IAAIC,MAAOC,CAAAA,KAAK,CAACF,KAAAA,CAAAA;AAC1B;AAEO,MAAMG,oBAAuB,GAAA,CAACC,OAAyBC,EAAAA,UAAAA,GAAAA;IAC5D,OAAQA,UAAAA;QACN,KAAKC,iBAAmB,CAACC,MAAM;AAAE,YAAA;;AAE/B,gBAAA,OAAOR,aAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAE,CAAA,CAAA;AACvC;QACA,KAAKF,iBAAmB,CAACG,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYC,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,GAAG,EAAEE,SAAUG,CAAAA,KAAK,CAAE,CAAA,CAAA;AAC5D;QACA,KAAKP,iBAAmB,CAACQ,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMJ,YAAYC,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,EAAE,EAAEE,SAAUF,CAAAA,GAAG,CAAE,CAAA,CAAA;AACzD;QACA,KAAKF,iBAAmB,CAACS,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYL,sBAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,EAAE,EAAEQ,SAAUR,CAAAA,GAAG,CAAE,CAAA,CAAA;AACzD;AACA,QAAA;AAAS,YAAA;AACP,gBAAA,MAAM,IAAIS,KAAM,CAAA,iBAAA,CAAA;AAClB;AACF;AACF;AAEO,MAAMC,iBAAoB,GAAA,CAC/BC,cACAC,EAAAA,MAAAA,GAAAA;AAEA,IAAA,IAAIC,0BAAiBD,MAAS,CAAA,EAAA;QAC5B,OAAOrB,YAAAA,CAAa,CAAC,CAAC,EAAEoB,cAAAA,CAAeX,GAAG,CAAC,GAAG,EAAEY,MAAOZ,CAAAA,GAAG,CAAE,CAAA,CAAA;AAC9D;AAEA,IAAA,IAAIc,6BAAoBF,MAAS,CAAA,EAAA;AAC/B,QAAA,OAAOjB,qBAAqBgB,cAAgBC,EAAAA,MAAAA,CAAAA;AAC9C;AAEA,IAAA,MAAM,IAAIH,KAAM,CAAA,CAAC,oBAAoB,EAAEG,MAAAA,CAAAA,CAAQ;AACjD;AAEO,MAAMG,0BAA0B,CAACC,GAAAA,GAAgBvB,OAAOwB,UAAU,CAACD,SAAS;AAE5E,MAAME,kBAAkB,CAAC1B,KAAAA,GAAAA;IAC9B,OAAOA,KAAAA,YAAiBC,OAAOC,KAAK;AACtC;;;;;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"range.mjs","sources":["../../../../src/modules/version/range.ts"],"sourcesContent":["import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType, semVerFactory } 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.Latest: {\n // Match anything greater than the current version\n return rangeFactory(`>${current.raw}`);\n }\n case Version.ReleaseType.Major: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using only the major version as the upper limit allows any minor,\n // patch, or build version to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <=5\", allowing any version\n // greater than \"4.15.4\" but less than \"6.0.0-0\".\n return rangeFactory(`>${current.raw} <=${nextMajor.major}`);\n }\n case Version.ReleaseType.Minor: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using the <major>.<minor>.<patch> version as the upper limit allows any minor,\n // patch, or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <5.0.0\", allowing any version\n // greater than \"4.15.4\" but less than \"5.0.0\".\n return rangeFactory(`>${current.raw} <${nextMajor.raw}`);\n }\n case Version.ReleaseType.Patch: {\n // For example, 4.15.4 returns 4.16.0\n const nextMinor = semVerFactory(current.raw).inc('minor');\n\n // Using only the minor version as the upper limit allows any patch\n // or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // minor version would result in \"4.16.0\".\n // The generated rule is \">4.15.4 <4.16.0\", allowing any version\n // greater than \"4.15.4\" but less than \"4.16.0\".\n return rangeFactory(`>${current.raw} <${nextMinor.raw}`);\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\nexport const isValidStringifiedRange = (str: string) => semver.validRange(str) !== null;\n\nexport const isRangeInstance = (range: unknown): range is semver.Range => {\n return range instanceof semver.Range;\n};\n"],"names":["rangeFactory","range","semver","Range","rangeFromReleaseType","current","identifier","Version","Latest","raw","Major","nextMajor","semVerFactory","inc","major","Minor","Patch","nextMinor","Error","rangeFromVersions","currentVersion","target","isSemverInstance","isSemVerReleaseType","isValidStringifiedRange","str","validRange","isRangeInstance"],"mappings":";;;;AAKO,MAAMA,eAAe,CAACC,KAAAA,GAAAA;IAC3B,OAAO,IAAIC,MAAOC,CAAAA,KAAK,CAACF,KAAAA,CAAAA;AAC1B;AAEO,MAAMG,oBAAuB,GAAA,CAACC,OAAyBC,EAAAA,UAAAA,GAAAA;IAC5D,OAAQA,UAAAA;QACN,KAAKC,WAAmB,CAACC,MAAM;AAAE,YAAA;;AAE/B,gBAAA,OAAOR,aAAa,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,CAAC,CAAA;AACvC;QACA,KAAKF,WAAmB,CAACG,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYC,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,GAAG,EAAEE,SAAAA,CAAUG,KAAK,CAAC,CAAC,CAAA;AAC5D;QACA,KAAKP,WAAmB,CAACQ,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMJ,YAAYC,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,EAAE,EAAEE,SAAAA,CAAUF,GAAG,CAAC,CAAC,CAAA;AACzD;QACA,KAAKF,WAAmB,CAACS,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYL,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;AASjD,gBAAA,OAAOb,YAAa,CAAA,CAAC,CAAC,EAAEK,OAAQI,CAAAA,GAAG,CAAC,EAAE,EAAEQ,SAAAA,CAAUR,GAAG,CAAC,CAAC,CAAA;AACzD;AACA,QAAA;AAAS,YAAA;AACP,gBAAA,MAAM,IAAIS,KAAM,CAAA,iBAAA,CAAA;AAClB;AACF;AACF;AAEO,MAAMC,iBAAoB,GAAA,CAC/BC,cACAC,EAAAA,MAAAA,GAAAA;AAEA,IAAA,IAAIC,iBAAiBD,MAAS,CAAA,EAAA;AAC5B,QAAA,OAAOrB,YAAa,CAAA,CAAC,CAAC,EAAEoB,cAAeX,CAAAA,GAAG,CAAC,GAAG,EAAEY,MAAAA,CAAOZ,GAAG,CAAC,CAAC,CAAA;AAC9D;AAEA,IAAA,IAAIc,oBAAoBF,MAAS,CAAA,EAAA;AAC/B,QAAA,OAAOjB,qBAAqBgB,cAAgBC,EAAAA,MAAAA,CAAAA;AAC9C;IAEA,MAAM,IAAIH,MAAM,CAAC,oBAAoB,EAAEG,MAAO,CAAA,CAAC;AACjD;AAEO,MAAMG,0BAA0B,CAACC,GAAAA,GAAgBvB,OAAOwB,UAAU,CAACD,SAAS;AAE5E,MAAME,kBAAkB,CAAC1B,KAAAA,GAAAA;IAC9B,OAAOA,KAAAA,YAAiBC,OAAOC,KAAK;AACtC;;;;"}
1
+ {"version":3,"file":"range.mjs","sources":["../../../../src/modules/version/range.ts"],"sourcesContent":["import semver from 'semver';\n\nimport * as Version from './types';\nimport { isSemverInstance, isSemVerReleaseType, semVerFactory } 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.Latest: {\n // Match anything greater than the current version\n return rangeFactory(`>${current.raw}`);\n }\n case Version.ReleaseType.Major: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using only the major version as the upper limit allows any minor,\n // patch, or build version to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <=5\", allowing any version\n // greater than \"4.15.4\" but less than \"6.0.0-0\".\n return rangeFactory(`>${current.raw} <=${nextMajor.major}`);\n }\n case Version.ReleaseType.Minor: {\n // For example, 4.15.4 returns 5.0.0\n const nextMajor = semVerFactory(current.raw).inc('major');\n\n // Using the <major>.<minor>.<patch> version as the upper limit allows any minor,\n // patch, or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // major version would result in \"5.0.0\".\n // The generated rule is \">4.15.4 <5.0.0\", allowing any version\n // greater than \"4.15.4\" but less than \"5.0.0\".\n return rangeFactory(`>${current.raw} <${nextMajor.raw}`);\n }\n case Version.ReleaseType.Patch: {\n // For example, 4.15.4 returns 4.16.0\n const nextMinor = semVerFactory(current.raw).inc('minor');\n\n // Using only the minor version as the upper limit allows any patch\n // or build versions to be taken in the range.\n //\n // For example, if the current version is \"4.15.4\", incrementing the\n // minor version would result in \"4.16.0\".\n // The generated rule is \">4.15.4 <4.16.0\", allowing any version\n // greater than \"4.15.4\" but less than \"4.16.0\".\n return rangeFactory(`>${current.raw} <${nextMinor.raw}`);\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\nexport const isValidStringifiedRange = (str: string) => semver.validRange(str) !== null;\n\nexport const isRangeInstance = (range: unknown): range is semver.Range => {\n return range instanceof semver.Range;\n};\n"],"names":["rangeFactory","range","semver","Range","rangeFromReleaseType","current","identifier","Version","Latest","raw","Major","nextMajor","semVerFactory","inc","major","Minor","Patch","nextMinor","Error","rangeFromVersions","currentVersion","target","isSemverInstance","isSemVerReleaseType","isValidStringifiedRange","str","validRange","isRangeInstance"],"mappings":";;;;AAKO,MAAMA,eAAe,CAACC,KAAAA,GAAAA;IAC3B,OAAO,IAAIC,MAAOC,CAAAA,KAAK,CAACF,KAAAA,CAAAA;AAC1B;AAEO,MAAMG,oBAAuB,GAAA,CAACC,OAAyBC,EAAAA,UAAAA,GAAAA;IAC5D,OAAQA,UAAAA;QACN,KAAKC,WAAmB,CAACC,MAAM;AAAE,YAAA;;AAE/B,gBAAA,OAAOR,aAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAE,CAAA,CAAA;AACvC;QACA,KAAKF,WAAmB,CAACG,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYC,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,GAAG,EAAEE,SAAUG,CAAAA,KAAK,CAAE,CAAA,CAAA;AAC5D;QACA,KAAKP,WAAmB,CAACQ,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMJ,YAAYC,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,EAAE,EAAEE,SAAUF,CAAAA,GAAG,CAAE,CAAA,CAAA;AACzD;QACA,KAAKF,WAAmB,CAACS,KAAK;AAAE,YAAA;;AAE9B,gBAAA,MAAMC,YAAYL,aAAcP,CAAAA,OAAAA,CAAQI,GAAG,CAAA,CAAEI,GAAG,CAAC,OAAA,CAAA;;;;;;;;gBASjD,OAAOb,YAAAA,CAAa,CAAC,CAAC,EAAEK,OAAAA,CAAQI,GAAG,CAAC,EAAE,EAAEQ,SAAUR,CAAAA,GAAG,CAAE,CAAA,CAAA;AACzD;AACA,QAAA;AAAS,YAAA;AACP,gBAAA,MAAM,IAAIS,KAAM,CAAA,iBAAA,CAAA;AAClB;AACF;AACF;AAEO,MAAMC,iBAAoB,GAAA,CAC/BC,cACAC,EAAAA,MAAAA,GAAAA;AAEA,IAAA,IAAIC,iBAAiBD,MAAS,CAAA,EAAA;QAC5B,OAAOrB,YAAAA,CAAa,CAAC,CAAC,EAAEoB,cAAAA,CAAeX,GAAG,CAAC,GAAG,EAAEY,MAAOZ,CAAAA,GAAG,CAAE,CAAA,CAAA;AAC9D;AAEA,IAAA,IAAIc,oBAAoBF,MAAS,CAAA,EAAA;AAC/B,QAAA,OAAOjB,qBAAqBgB,cAAgBC,EAAAA,MAAAA,CAAAA;AAC9C;AAEA,IAAA,MAAM,IAAIH,KAAM,CAAA,CAAC,oBAAoB,EAAEG,MAAAA,CAAAA,CAAQ;AACjD;AAEO,MAAMG,0BAA0B,CAACC,GAAAA,GAAgBvB,OAAOwB,UAAU,CAACD,SAAS;AAE5E,MAAME,kBAAkB,CAAC1B,KAAAA,GAAAA;IAC9B,OAAOA,KAAAA,YAAiBC,OAAOC,KAAK;AACtC;;;;"}
@@ -1,12 +1,14 @@
1
1
  'use strict';
2
2
 
3
- exports.ReleaseType = void 0;
4
- (function(ReleaseType) {
3
+ var ReleaseType = /*#__PURE__*/ function(ReleaseType) {
5
4
  // Classic
6
5
  ReleaseType["Major"] = "major";
7
6
  ReleaseType["Minor"] = "minor";
8
7
  ReleaseType["Patch"] = "patch";
9
8
  // Other
10
9
  ReleaseType["Latest"] = "latest";
11
- })(exports.ReleaseType || (exports.ReleaseType = {}));
10
+ return ReleaseType;
11
+ }({});
12
+
13
+ exports.ReleaseType = ReleaseType;
12
14
  //# sourceMappingURL=types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sources":["../../../../src/modules/version/types.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 // Classic\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n // Other\n Latest = 'latest',\n}\n"],"names":["ReleaseType"],"mappings":";;;AAWYA,CAAAA,SAAAA,WAAAA,EAAAA;;;;;;;GAAAA,mBAAAA,KAAAA,mBAAAA,GAAAA,EAAAA,CAAAA,CAAAA;;"}
1
+ {"version":3,"file":"types.js","sources":["../../../../src/modules/version/types.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 // Classic\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n // Other\n Latest = 'latest',\n}\n"],"names":["ReleaseType"],"mappings":";;AAWO,IAAA,WAAKA,iBAAAA,SAAAA,WAAAA,EAAAA;;;;;;;AAAAA,IAAAA,OAAAA,WAAAA;AAOX,CAAA,CAAA,EAAA;;;;"}
@@ -1,12 +1,12 @@
1
- var ReleaseType;
2
- (function(ReleaseType) {
1
+ var ReleaseType = /*#__PURE__*/ function(ReleaseType) {
3
2
  // Classic
4
3
  ReleaseType["Major"] = "major";
5
4
  ReleaseType["Minor"] = "minor";
6
5
  ReleaseType["Patch"] = "patch";
7
6
  // Other
8
7
  ReleaseType["Latest"] = "latest";
9
- })(ReleaseType || (ReleaseType = {}));
8
+ return ReleaseType;
9
+ }({});
10
10
 
11
11
  export { ReleaseType };
12
12
  //# sourceMappingURL=types.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.mjs","sources":["../../../../src/modules/version/types.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 // Classic\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n // Other\n Latest = 'latest',\n}\n"],"names":["ReleaseType"],"mappings":";AAWYA,CAAAA,SAAAA,WAAAA,EAAAA;;;;;;;GAAAA,WAAAA,KAAAA,WAAAA,GAAAA,EAAAA,CAAAA,CAAAA;;;;"}
1
+ {"version":3,"file":"types.mjs","sources":["../../../../src/modules/version/types.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 // Classic\n Major = 'major',\n Minor = 'minor',\n Patch = 'patch',\n // Other\n Latest = 'latest',\n}\n"],"names":["ReleaseType"],"mappings":"AAWO,IAAA,WAAKA,iBAAAA,SAAAA,WAAAA,EAAAA;;;;;;;AAAAA,IAAAA,OAAAA,WAAAA;AAOX,CAAA,CAAA,EAAA;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"list-codemods.js","sources":["../../../../src/tasks/codemods/list-codemods.ts"],"sourcesContent":["import { codemodRepositoryFactory } from '../../modules/codemod-repository';\nimport { projectFactory } from '../../modules/project';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport * as f from '../../modules/format';\n\nimport type { ListCodemodsOptions } from './types';\n\nexport const listCodemods = async (options: ListCodemodsOptions) => {\n const { logger, target } = options;\n\n const cwd = resolvePath(options.cwd);\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n // Create a codemod repository targeting the default location of the codemods\n const repo = codemodRepositoryFactory();\n\n // Make sure all the codemods are loaded\n repo.refresh();\n\n // Find groups of codemods matching the given range\n const groups = repo.find({ range });\n\n // Flatten the groups into a simple codemod array\n const codemods = groups.flatMap((collection) => collection.codemods);\n\n // Debug\n logger.debug(`Found ${f.highlight(codemods.length)} codemods`);\n\n // Don't log an empty table\n if (codemods.length === 0) {\n logger.info(`Found no codemods matching ${f.versionRange(range)}`);\n return;\n }\n\n // Format the list to a pretty table\n const fCodemods = f.codemodList(codemods);\n\n logger.raw(fCodemods);\n};\n"],"names":["listCodemods","options","logger","target","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","debug","f","repo","codemodRepositoryFactory","refresh","groups","find","codemods","flatMap","collection","length","info","fCodemods","raw"],"mappings":";;;;;;;;;AAQO,MAAMA,eAAe,OAAOC,OAAAA,GAAAA;AACjC,IAAA,MAAM,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGF,OAAAA;IAE3B,MAAMG,GAAAA,GAAMC,iBAAYJ,CAAAA,OAAAA,CAAQG,GAAG,CAAA;AACnC,IAAA,MAAME,YAAUC,sBAAeH,CAAAA,GAAAA,CAAAA;IAC/B,MAAMI,KAAAA,GAAQC,0BAAoBH,SAASH,EAAAA,MAAAA,CAAAA;AAE3CD,IAAAA,MAAAA,CAAOQ,KAAK,CAACC,sBAAgB,CAACL,SAAAA,CAAAA,CAAAA;IAC9BJ,MAAOQ,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,oBAAc,CAACH,KAAAA,CAAAA,CAAO,CAAC,CAAA;;AAGrD,IAAA,MAAMI,IAAOC,GAAAA,mCAAAA,EAAAA;;AAGbD,IAAAA,IAAAA,CAAKE,OAAO,EAAA;;IAGZ,MAAMC,MAAAA,GAASH,IAAKI,CAAAA,IAAI,CAAC;AAAER,QAAAA;AAAM,KAAA,CAAA;;AAGjC,IAAA,MAAMS,WAAWF,MAAOG,CAAAA,OAAO,CAAC,CAACC,UAAAA,GAAeA,WAAWF,QAAQ,CAAA;;AAGnEf,IAAAA,MAAAA,CAAOQ,KAAK,CAAC,CAAC,MAAM,EAAEC,iBAAW,CAACM,QAASG,CAAAA,MAAM,CAAE,CAAA,SAAS,CAAC,CAAA;;IAG7D,IAAIH,QAAAA,CAASG,MAAM,KAAK,CAAG,EAAA;QACzBlB,MAAOmB,CAAAA,IAAI,CAAC,CAAC,2BAA2B,EAAEV,oBAAc,CAACH,KAAAA,CAAAA,CAAO,CAAC,CAAA;AACjE,QAAA;AACF;;IAGA,MAAMc,SAAAA,GAAYX,mBAAa,CAACM,QAAAA,CAAAA;AAEhCf,IAAAA,MAAAA,CAAOqB,GAAG,CAACD,SAAAA,CAAAA;AACb;;;;"}
1
+ {"version":3,"file":"list-codemods.js","sources":["../../../../src/tasks/codemods/list-codemods.ts"],"sourcesContent":["import { codemodRepositoryFactory } from '../../modules/codemod-repository';\nimport { projectFactory } from '../../modules/project';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport * as f from '../../modules/format';\n\nimport type { ListCodemodsOptions } from './types';\n\nexport const listCodemods = async (options: ListCodemodsOptions) => {\n const { logger, target } = options;\n\n const cwd = resolvePath(options.cwd);\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n // Create a codemod repository targeting the default location of the codemods\n const repo = codemodRepositoryFactory();\n\n // Make sure all the codemods are loaded\n repo.refresh();\n\n // Find groups of codemods matching the given range\n const groups = repo.find({ range });\n\n // Flatten the groups into a simple codemod array\n const codemods = groups.flatMap((collection) => collection.codemods);\n\n // Debug\n logger.debug(`Found ${f.highlight(codemods.length)} codemods`);\n\n // Don't log an empty table\n if (codemods.length === 0) {\n logger.info(`Found no codemods matching ${f.versionRange(range)}`);\n return;\n }\n\n // Format the list to a pretty table\n const fCodemods = f.codemodList(codemods);\n\n logger.raw(fCodemods);\n};\n"],"names":["listCodemods","options","logger","target","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","debug","f","repo","codemodRepositoryFactory","refresh","groups","find","codemods","flatMap","collection","length","info","fCodemods","raw"],"mappings":";;;;;;;;;AAQO,MAAMA,eAAe,OAAOC,OAAAA,GAAAA;AACjC,IAAA,MAAM,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGF,OAAAA;IAE3B,MAAMG,GAAAA,GAAMC,iBAAYJ,CAAAA,OAAAA,CAAQG,GAAG,CAAA;AACnC,IAAA,MAAME,YAAUC,sBAAeH,CAAAA,GAAAA,CAAAA;IAC/B,MAAMI,KAAAA,GAAQC,0BAAoBH,SAASH,EAAAA,MAAAA,CAAAA;AAE3CD,IAAAA,MAAAA,CAAOQ,KAAK,CAACC,sBAAgB,CAACL,SAAAA,CAAAA,CAAAA;IAC9BJ,MAAOQ,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,oBAAc,CAACH,KAAQ,CAAA,CAAA,CAAA,CAAA;;AAGrD,IAAA,MAAMI,IAAOC,GAAAA,mCAAAA,EAAAA;;AAGbD,IAAAA,IAAAA,CAAKE,OAAO,EAAA;;IAGZ,MAAMC,MAAAA,GAASH,IAAKI,CAAAA,IAAI,CAAC;AAAER,QAAAA;AAAM,KAAA,CAAA;;AAGjC,IAAA,MAAMS,WAAWF,MAAOG,CAAAA,OAAO,CAAC,CAACC,UAAAA,GAAeA,WAAWF,QAAQ,CAAA;;AAGnEf,IAAAA,MAAAA,CAAOQ,KAAK,CAAC,CAAC,MAAM,EAAEC,iBAAW,CAACM,QAASG,CAAAA,MAAM,CAAE,CAAA,SAAS,CAAC,CAAA;;IAG7D,IAAIH,QAAAA,CAASG,MAAM,KAAK,CAAG,EAAA;QACzBlB,MAAOmB,CAAAA,IAAI,CAAC,CAAC,2BAA2B,EAAEV,oBAAc,CAACH,KAAQ,CAAA,CAAA,CAAA,CAAA;AACjE,QAAA;AACF;;IAGA,MAAMc,SAAAA,GAAYX,mBAAa,CAACM,QAAAA,CAAAA;AAEhCf,IAAAA,MAAAA,CAAOqB,GAAG,CAACD,SAAAA,CAAAA;AACb;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"list-codemods.mjs","sources":["../../../../src/tasks/codemods/list-codemods.ts"],"sourcesContent":["import { codemodRepositoryFactory } from '../../modules/codemod-repository';\nimport { projectFactory } from '../../modules/project';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport * as f from '../../modules/format';\n\nimport type { ListCodemodsOptions } from './types';\n\nexport const listCodemods = async (options: ListCodemodsOptions) => {\n const { logger, target } = options;\n\n const cwd = resolvePath(options.cwd);\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n // Create a codemod repository targeting the default location of the codemods\n const repo = codemodRepositoryFactory();\n\n // Make sure all the codemods are loaded\n repo.refresh();\n\n // Find groups of codemods matching the given range\n const groups = repo.find({ range });\n\n // Flatten the groups into a simple codemod array\n const codemods = groups.flatMap((collection) => collection.codemods);\n\n // Debug\n logger.debug(`Found ${f.highlight(codemods.length)} codemods`);\n\n // Don't log an empty table\n if (codemods.length === 0) {\n logger.info(`Found no codemods matching ${f.versionRange(range)}`);\n return;\n }\n\n // Format the list to a pretty table\n const fCodemods = f.codemodList(codemods);\n\n logger.raw(fCodemods);\n};\n"],"names":["listCodemods","options","logger","target","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","debug","f","repo","codemodRepositoryFactory","refresh","groups","find","codemods","flatMap","collection","length","info","fCodemods","raw"],"mappings":";;;;;;;AAQO,MAAMA,eAAe,OAAOC,OAAAA,GAAAA;AACjC,IAAA,MAAM,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGF,OAAAA;IAE3B,MAAMG,GAAAA,GAAMC,WAAYJ,CAAAA,OAAAA,CAAQG,GAAG,CAAA;AACnC,IAAA,MAAME,UAAUC,cAAeH,CAAAA,GAAAA,CAAAA;IAC/B,MAAMI,KAAAA,GAAQC,oBAAoBH,OAASH,EAAAA,MAAAA,CAAAA;AAE3CD,IAAAA,MAAAA,CAAOQ,KAAK,CAACC,cAAgB,CAACL,OAAAA,CAAAA,CAAAA;IAC9BJ,MAAOQ,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,YAAc,CAACH,KAAAA,CAAAA,CAAO,CAAC,CAAA;;AAGrD,IAAA,MAAMI,IAAOC,GAAAA,wBAAAA,EAAAA;;AAGbD,IAAAA,IAAAA,CAAKE,OAAO,EAAA;;IAGZ,MAAMC,MAAAA,GAASH,IAAKI,CAAAA,IAAI,CAAC;AAAER,QAAAA;AAAM,KAAA,CAAA;;AAGjC,IAAA,MAAMS,WAAWF,MAAOG,CAAAA,OAAO,CAAC,CAACC,UAAAA,GAAeA,WAAWF,QAAQ,CAAA;;AAGnEf,IAAAA,MAAAA,CAAOQ,KAAK,CAAC,CAAC,MAAM,EAAEC,SAAW,CAACM,QAASG,CAAAA,MAAM,CAAE,CAAA,SAAS,CAAC,CAAA;;IAG7D,IAAIH,QAAAA,CAASG,MAAM,KAAK,CAAG,EAAA;QACzBlB,MAAOmB,CAAAA,IAAI,CAAC,CAAC,2BAA2B,EAAEV,YAAc,CAACH,KAAAA,CAAAA,CAAO,CAAC,CAAA;AACjE,QAAA;AACF;;IAGA,MAAMc,SAAAA,GAAYX,WAAa,CAACM,QAAAA,CAAAA;AAEhCf,IAAAA,MAAAA,CAAOqB,GAAG,CAACD,SAAAA,CAAAA;AACb;;;;"}
1
+ {"version":3,"file":"list-codemods.mjs","sources":["../../../../src/tasks/codemods/list-codemods.ts"],"sourcesContent":["import { codemodRepositoryFactory } from '../../modules/codemod-repository';\nimport { projectFactory } from '../../modules/project';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport * as f from '../../modules/format';\n\nimport type { ListCodemodsOptions } from './types';\n\nexport const listCodemods = async (options: ListCodemodsOptions) => {\n const { logger, target } = options;\n\n const cwd = resolvePath(options.cwd);\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n // Create a codemod repository targeting the default location of the codemods\n const repo = codemodRepositoryFactory();\n\n // Make sure all the codemods are loaded\n repo.refresh();\n\n // Find groups of codemods matching the given range\n const groups = repo.find({ range });\n\n // Flatten the groups into a simple codemod array\n const codemods = groups.flatMap((collection) => collection.codemods);\n\n // Debug\n logger.debug(`Found ${f.highlight(codemods.length)} codemods`);\n\n // Don't log an empty table\n if (codemods.length === 0) {\n logger.info(`Found no codemods matching ${f.versionRange(range)}`);\n return;\n }\n\n // Format the list to a pretty table\n const fCodemods = f.codemodList(codemods);\n\n logger.raw(fCodemods);\n};\n"],"names":["listCodemods","options","logger","target","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","debug","f","repo","codemodRepositoryFactory","refresh","groups","find","codemods","flatMap","collection","length","info","fCodemods","raw"],"mappings":";;;;;;;AAQO,MAAMA,eAAe,OAAOC,OAAAA,GAAAA;AACjC,IAAA,MAAM,EAAEC,MAAM,EAAEC,MAAM,EAAE,GAAGF,OAAAA;IAE3B,MAAMG,GAAAA,GAAMC,WAAYJ,CAAAA,OAAAA,CAAQG,GAAG,CAAA;AACnC,IAAA,MAAME,UAAUC,cAAeH,CAAAA,GAAAA,CAAAA;IAC/B,MAAMI,KAAAA,GAAQC,oBAAoBH,OAASH,EAAAA,MAAAA,CAAAA;AAE3CD,IAAAA,MAAAA,CAAOQ,KAAK,CAACC,cAAgB,CAACL,OAAAA,CAAAA,CAAAA;IAC9BJ,MAAOQ,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,YAAc,CAACH,KAAQ,CAAA,CAAA,CAAA,CAAA;;AAGrD,IAAA,MAAMI,IAAOC,GAAAA,wBAAAA,EAAAA;;AAGbD,IAAAA,IAAAA,CAAKE,OAAO,EAAA;;IAGZ,MAAMC,MAAAA,GAASH,IAAKI,CAAAA,IAAI,CAAC;AAAER,QAAAA;AAAM,KAAA,CAAA;;AAGjC,IAAA,MAAMS,WAAWF,MAAOG,CAAAA,OAAO,CAAC,CAACC,UAAAA,GAAeA,WAAWF,QAAQ,CAAA;;AAGnEf,IAAAA,MAAAA,CAAOQ,KAAK,CAAC,CAAC,MAAM,EAAEC,SAAW,CAACM,QAASG,CAAAA,MAAM,CAAE,CAAA,SAAS,CAAC,CAAA;;IAG7D,IAAIH,QAAAA,CAASG,MAAM,KAAK,CAAG,EAAA;QACzBlB,MAAOmB,CAAAA,IAAI,CAAC,CAAC,2BAA2B,EAAEV,YAAc,CAACH,KAAQ,CAAA,CAAA,CAAA,CAAA;AACjE,QAAA;AACF;;IAGA,MAAMc,SAAAA,GAAYX,WAAa,CAACM,QAAAA,CAAAA;AAEhCf,IAAAA,MAAAA,CAAOqB,GAAG,CAACD,SAAAA,CAAAA;AACb;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"run-codemods.js","sources":["../../../../src/tasks/codemods/run-codemods.ts"],"sourcesContent":["import * as f from '../../modules/format';\nimport { timerFactory } from '../../modules/timer';\nimport { projectFactory } from '../../modules/project';\nimport { codemodRunnerFactory } from '../../modules/codemod-runner';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport type { RunCodemodsOptions } from './types';\nimport type { CodemodRunnerReport } from '../../modules/codemod-runner';\n\nexport const runCodemods = async (options: RunCodemodsOptions) => {\n const timer = timerFactory();\n const { logger, uid } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = resolvePath(options.cwd);\n\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, options.target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n const codemodRunner = codemodRunnerFactory(project, range)\n .dry(options.dry ?? false)\n .onSelectCodemods(options.selectCodemods ?? null)\n .setLogger(logger);\n\n let report: CodemodRunnerReport;\n\n // If uid is defined, only run the selected codemod\n if (uid !== undefined) {\n logger.debug(`Running a single codemod: ${f.codemodUID(uid)}`);\n report = await codemodRunner.runByUID(uid);\n }\n\n // By default, only filter using the specified range\n else {\n report = await codemodRunner.run();\n }\n\n if (!report.success) {\n throw report.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${timer.elapsedMs}`);\n};\n"],"names":["runCodemods","options","timer","timerFactory","logger","uid","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","target","debug","f","codemodRunner","codemodRunnerFactory","dry","onSelectCodemods","selectCodemods","setLogger","report","undefined","runByUID","run","success","error","stop","info","elapsedMs"],"mappings":";;;;;;;;;AASO,MAAMA,cAAc,OAAOC,OAAAA,GAAAA;AAChC,IAAA,MAAMC,OAAQC,GAAAA,kBAAAA,EAAAA;AACd,IAAA,MAAM,EAAEC,MAAM,EAAEC,GAAG,EAAE,GAAGJ,OAAAA;;IAGxB,MAAMK,GAAAA,GAAMC,iBAAYN,CAAAA,OAAAA,CAAQK,GAAG,CAAA;AAEnC,IAAA,MAAME,YAAUC,sBAAeH,CAAAA,GAAAA,CAAAA;AAC/B,IAAA,MAAMI,KAAQC,GAAAA,yBAAAA,CAAoBH,SAASP,EAAAA,OAAAA,CAAQW,MAAM,CAAA;AAEzDR,IAAAA,MAAAA,CAAOS,KAAK,CAACC,sBAAgB,CAACN,SAAAA,CAAAA,CAAAA;IAC9BJ,MAAOS,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,oBAAc,CAACJ,KAAAA,CAAAA,CAAO,CAAC,CAAA;AAErD,IAAA,MAAMK,kBAAgBC,kCAAqBR,CAAAA,SAAAA,EAASE,KACjDO,CAAAA,CAAAA,GAAG,CAAChB,OAAQgB,CAAAA,GAAG,IAAI,KAAA,CAAA,CACnBC,gBAAgB,CAACjB,OAAAA,CAAQkB,cAAc,IAAI,IAAA,CAAA,CAC3CC,SAAS,CAAChB,MAAAA,CAAAA;IAEb,IAAIiB,MAAAA;;AAGJ,IAAA,IAAIhB,QAAQiB,SAAW,EAAA;QACrBlB,MAAOS,CAAAA,KAAK,CAAC,CAAC,0BAA0B,EAAEC,kBAAY,CAACT,GAAAA,CAAAA,CAAK,CAAC,CAAA;QAC7DgB,MAAS,GAAA,MAAMN,eAAcQ,CAAAA,QAAQ,CAAClB,GAAAA,CAAAA;KAInC,MAAA;QACHgB,MAAS,GAAA,MAAMN,gBAAcS,GAAG,EAAA;AAClC;IAEA,IAAI,CAACH,MAAOI,CAAAA,OAAO,EAAE;AACnB,QAAA,MAAMJ,OAAOK,KAAK;AACpB;AAEAxB,IAAAA,OAAAA,CAAMyB,IAAI,EAAA;IAEVvB,MAAOwB,CAAAA,IAAI,CAAC,CAAC,aAAa,EAAE1B,OAAM2B,CAAAA,SAAS,CAAC,CAAC,CAAA;AAC/C;;;;"}
1
+ {"version":3,"file":"run-codemods.js","sources":["../../../../src/tasks/codemods/run-codemods.ts"],"sourcesContent":["import * as f from '../../modules/format';\nimport { timerFactory } from '../../modules/timer';\nimport { projectFactory } from '../../modules/project';\nimport { codemodRunnerFactory } from '../../modules/codemod-runner';\nimport { findRangeFromTarget, resolvePath } from './utils';\n\nimport type { RunCodemodsOptions } from './types';\nimport type { CodemodRunnerReport } from '../../modules/codemod-runner';\n\nexport const runCodemods = async (options: RunCodemodsOptions) => {\n const timer = timerFactory();\n const { logger, uid } = options;\n\n // Make sure we're resolving the correct working directory based on the given input\n const cwd = resolvePath(options.cwd);\n\n const project = projectFactory(cwd);\n const range = findRangeFromTarget(project, options.target);\n\n logger.debug(f.projectDetails(project));\n logger.debug(`Range: set to ${f.versionRange(range)}`);\n\n const codemodRunner = codemodRunnerFactory(project, range)\n .dry(options.dry ?? false)\n .onSelectCodemods(options.selectCodemods ?? null)\n .setLogger(logger);\n\n let report: CodemodRunnerReport;\n\n // If uid is defined, only run the selected codemod\n if (uid !== undefined) {\n logger.debug(`Running a single codemod: ${f.codemodUID(uid)}`);\n report = await codemodRunner.runByUID(uid);\n }\n\n // By default, only filter using the specified range\n else {\n report = await codemodRunner.run();\n }\n\n if (!report.success) {\n throw report.error;\n }\n\n timer.stop();\n\n logger.info(`Completed in ${timer.elapsedMs}`);\n};\n"],"names":["runCodemods","options","timer","timerFactory","logger","uid","cwd","resolvePath","project","projectFactory","range","findRangeFromTarget","target","debug","f","codemodRunner","codemodRunnerFactory","dry","onSelectCodemods","selectCodemods","setLogger","report","undefined","runByUID","run","success","error","stop","info","elapsedMs"],"mappings":";;;;;;;;;AASO,MAAMA,cAAc,OAAOC,OAAAA,GAAAA;AAChC,IAAA,MAAMC,OAAQC,GAAAA,kBAAAA,EAAAA;AACd,IAAA,MAAM,EAAEC,MAAM,EAAEC,GAAG,EAAE,GAAGJ,OAAAA;;IAGxB,MAAMK,GAAAA,GAAMC,iBAAYN,CAAAA,OAAAA,CAAQK,GAAG,CAAA;AAEnC,IAAA,MAAME,YAAUC,sBAAeH,CAAAA,GAAAA,CAAAA;AAC/B,IAAA,MAAMI,KAAQC,GAAAA,yBAAAA,CAAoBH,SAASP,EAAAA,OAAAA,CAAQW,MAAM,CAAA;AAEzDR,IAAAA,MAAAA,CAAOS,KAAK,CAACC,sBAAgB,CAACN,SAAAA,CAAAA,CAAAA;IAC9BJ,MAAOS,CAAAA,KAAK,CAAC,CAAC,cAAc,EAAEC,oBAAc,CAACJ,KAAQ,CAAA,CAAA,CAAA,CAAA;AAErD,IAAA,MAAMK,kBAAgBC,kCAAqBR,CAAAA,SAAAA,EAASE,KACjDO,CAAAA,CAAAA,GAAG,CAAChB,OAAQgB,CAAAA,GAAG,IAAI,KAAA,CAAA,CACnBC,gBAAgB,CAACjB,OAAAA,CAAQkB,cAAc,IAAI,IAAA,CAAA,CAC3CC,SAAS,CAAChB,MAAAA,CAAAA;IAEb,IAAIiB,MAAAA;;AAGJ,IAAA,IAAIhB,QAAQiB,SAAW,EAAA;QACrBlB,MAAOS,CAAAA,KAAK,CAAC,CAAC,0BAA0B,EAAEC,kBAAY,CAACT,GAAM,CAAA,CAAA,CAAA,CAAA;QAC7DgB,MAAS,GAAA,MAAMN,eAAcQ,CAAAA,QAAQ,CAAClB,GAAAA,CAAAA;KAInC,MAAA;QACHgB,MAAS,GAAA,MAAMN,gBAAcS,GAAG,EAAA;AAClC;IAEA,IAAI,CAACH,MAAOI,CAAAA,OAAO,EAAE;AACnB,QAAA,MAAMJ,OAAOK,KAAK;AACpB;AAEAxB,IAAAA,OAAAA,CAAMyB,IAAI,EAAA;AAEVvB,IAAAA,MAAAA,CAAOwB,IAAI,CAAC,CAAC,aAAa,EAAE1B,OAAAA,CAAM2B,SAAS,CAAE,CAAA,CAAA;AAC/C;;;;"}