renovate 43.94.0 → 43.94.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.
- package/dist/modules/manager/fingerprint.generated.js +1 -1
- package/dist/modules/manager/fingerprint.generated.js.map +1 -1
- package/dist/modules/manager/npm/post-update/index.js +1 -1
- package/dist/modules/manager/npm/post-update/index.js.map +1 -1
- package/dist/modules/manager/npm/post-update/npm.js +1 -38
- package/dist/modules/manager/npm/post-update/npm.js.map +1 -1
- package/dist/modules/manager/types.d.ts +1 -2
- package/package.json +1 -1
- package/renovate-schema.json +2 -2
|
@@ -72,7 +72,7 @@ hashMap.set("mise", "a8b4ffca9953d2e49f3b7f8da81cf66251c2616c462d34d81a32a2b1d3b
|
|
|
72
72
|
hashMap.set("mix", "1116e1adf1c18c866f0a9e6fa065c4fb9da055d8d150e625344899bb94095481");
|
|
73
73
|
hashMap.set("nix", "f3ffec2f14e7261de8068895b91392e992dcef208fbaf52110d6862e4712c031");
|
|
74
74
|
hashMap.set("nodenv", "ac652c28481b001f7471f4183eac07b45d98ecbe83efc275830b0a1b2e0459b8");
|
|
75
|
-
hashMap.set("npm", "
|
|
75
|
+
hashMap.set("npm", "f100896f5ac7854ba443e149226b399f76f356015131ebe8f298d6dc08589472");
|
|
76
76
|
hashMap.set("nuget", "a8162c2819fb23fe6de82c8eb4196133701bb3c538202fe8dc9cab4a326d47e4");
|
|
77
77
|
hashMap.set("nvm", "3eb77c7b0acf6d64753de78fad2499b352719853aa6872878c40675d14152322");
|
|
78
78
|
hashMap.set("ocb", "032b216684c14b0954e0bb019513a2aca3faaee5748587acb668d377d7c891ca");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fingerprint.generated.js","names":[],"sources":["../../../lib/modules/manager/fingerprint.generated.ts"],"sourcesContent":["export const hashMap = new Map<string, string>();\n\nhashMap.set('ansible','1fbc76f78daa14a8c9ab1142e9d1e05c746c0419a9f1455e4279f476590d0c04');\nhashMap.set('ansible-galaxy','8226d47128f2018825d4d6f84794e3183eb79c706045fa7e88491edd5e64106f');\nhashMap.set('argocd','5d35b1992e53130bf83b0e59a0f90ccd3a78919974c69044f306dc5d162f48ce');\nhashMap.set('asdf','1f6fcf620e9c6cd35991380cb6eafb94ec60cd77cbd13335ebe3a1d9727416c9');\nhashMap.set('azure-pipelines','4f635b0ecd388ee266d992e8281fd40e3db2f5867d86fc1cbce72dc33a66e796');\nhashMap.set('batect','fad98996bea8626525ab925f83a6ae0ce9262c53770e7aa7cb448a1e0f1ddf21');\nhashMap.set('batect-wrapper','d999355511ea7f4053325a18b8cfc8d2b586c61e6760c35e557d383a673e3939');\nhashMap.set('bazel','c6e0ad88ea468664c3a33263baf7452d83d2d37ff09ba920e18f64ee81fd0acb');\nhashMap.set('bazel-module','ecafa538746c1d307b44e2478a0ad187c2b00d4900b6f739c8d2b88cd539b97b');\nhashMap.set('bazelisk','b6ec532dfa7c8f82ad4084df864ac6276e87c27285369323902afc146d3537ac');\nhashMap.set('bicep','7246e0bfc06e0e28cbb03ac088c5591f648956b086e106aeb251fe5d628329db');\nhashMap.set('bitbucket-pipelines','09eb044219d74331fea135f50121b7d4d146333eb97e4ccbfa9ddf0eb4012963');\nhashMap.set('bitrise','afdb46fe37fc0307943089e18b6724065394805e628b4b6c4430a6068c494030');\nhashMap.set('buildkite','a93effb1f1c5d65b3277c3b4709924eacde282e8efd028a8e3d8c1ce3ef69407');\nhashMap.set('buildpacks','6bef3cb04d66b5cfbb195adb4829bcbccae6408518706744d291bacf0610421f');\nhashMap.set('bun','1322232bf1d0c4fa796e31a00488453bdcd00d4958431d9e424c1635e60a99bd');\nhashMap.set('bun-version','df3ae8e4a5de1fa1b4544f3d7fc8117e80adb1e151c46d1ede54a4dbea6521e4');\nhashMap.set('bundler','6d7e9d2018ac03e15f19e8b40ef70dd87d509d5affca24bc464d085899880a25');\nhashMap.set('cake','288c3c36a50371b26957fa71992cc335228d53563c75597b36919ac7286e96eb');\nhashMap.set('cargo','308d7ab4c6d24027b050bf659dfab0e510d9a22f8134695a7c68214908ee4634');\nhashMap.set('cdnurl','d3edf6cdc38e92eb43ff5a2b4e8df6a6a13154cf83244725c39e28d7e6ea9177');\nhashMap.set('circleci','135937d4720718304adb0ba998516f8ce38c3220ccd18b00b8c70c62b45df4da');\nhashMap.set('cloudbuild','8c0c739f7e4082bbfe8e3fdffebaf43e26f70a1314d95b306e9b93e4f4297886');\nhashMap.set('cocoapods','b6ac3b4a6b8a5b32daed37bf695fe177cdb1b4a94ae7f7fb2f4c4c096c0a004c');\nhashMap.set('composer','cdb6895574020cec402e0b878e4078b62f1acfd0392a861cbb523036634f6383');\nhashMap.set('conan','aecc3917d77146db4e57dd12944be1beff860e90b7ebdd2d8fbc449fc1a06574');\nhashMap.set('copier','09f1aeccd473843a231bae41e7c39c6b8c45dd46102cb4f1fb4fc3852d849493');\nhashMap.set('cpanfile','6a1d67d9c8751123deaf0c7f3ac38a07024e960c140f8228fcbcb93954fdca01');\nhashMap.set('crossplane','5c26b1201a1a51454ffb94d829e223a76a781569bf79cdb1e47087c30233ec40');\nhashMap.set('crow','eb9a5f9f95041855dded67bcce3dd54724f690995ed6268d272e8a666ff28fd0');\nhashMap.set('deps-edn','c87dd5e88587147ad1a78f047b814f3c4aa60d6de30d0c49d849391eeaf1b64c');\nhashMap.set('devbox','bcf5334e8a21190baaa25436acf2f17fbf095504262a4e9ee7c62ffb644eb716');\nhashMap.set('devcontainer','24320ed1cb6191d04cb8b2707214d82c08c682597aed1d84f250aa00ad1632ec');\nhashMap.set('docker-compose','5441af5b5abf8d347e46002d47f02f85743401bda28232f49fb7b3bbb772a4fb');\nhashMap.set('dockerfile','322b95f7e55dd78d7fe71306a6f649479eca61c60d75bb10b23604a230dbdd08');\nhashMap.set('droneci','237c8de87b9bf653fb943b56e84e99c45f6d86ae27d86e599b3f3f99c35ba8ee');\nhashMap.set('fleet','d73d5d35f10df0599a561d9c8d25f3935350407d0e3bd3a1d1545295f278912e');\nhashMap.set('flux','427e0c1a5b1d8337503a9a568a76532fbde0bab8b355fa8f47312de50eadf2f6');\nhashMap.set('fvm','9b161df0f14bc6e536368952adf373e343630097121a913cea60ee284027fb90');\nhashMap.set('git-submodules','a286e097a5fcc6c946e792b812871147b39ad93f9ad041b5b3216b100f972e95');\nhashMap.set('github-actions','d3b1deb4dfcdba586cd97b4d2d2f9f1b89531bcc31b6ead0d960b990586d6058');\nhashMap.set('gitlabci','0dec44dd398bfc5b3c19d0929bea2fef7f386c94acfd1b1d7bc2a31d81d96fd6');\nhashMap.set('gitlabci-include','354cfc4ea327c6d5cd5bee1f17763832efc7f5402e9fd22c579239fccb9c6dab');\nhashMap.set('glasskube','253d6db30bdec75ed5ab5d26f31d69bc07813ba10089a28da12c6a29eff4ec70');\nhashMap.set('gleam','b717a48c525ad6b1d434c6a9db828ddebbb85e94519e89ddc4040878e3600e84');\nhashMap.set('gomod','93c6d963bd46456b438d693f4a385a490e5c729ad544564f2a9d58a1b975fe7b');\nhashMap.set('gradle','39435c4a5525a2c99a303934c23526d972ee9a40672afed801feb144a97c4eb8');\nhashMap.set('gradle-wrapper','8d5f573816e63739d264768b7f2565905036153385a0216b82ea6fed34b1a233');\nhashMap.set('haskell-cabal','d796ec6859e63ab4f1b7030c4016071202c3a44c7c11d4a9131d7e2ba19b396d');\nhashMap.set('helm-requirements','4d90e5e18a380876ad48e21e1ad88ea62e25d973a1ddaa3763447fc0a9f9915b');\nhashMap.set('helm-values','b5c52c6a27d805557418c585c5d3030c95ee641d53057021f3fe060f81b6e1af');\nhashMap.set('helmfile','e5783484b81247279563da3c835afe4002edfc412e13fb91877818ca44ae65f2');\nhashMap.set('helmsman','ef9680c612f702c7f07aea9b6e5d811e91214dcfa5755c9f3803e9528090935e');\nhashMap.set('helmv3','7724bf6cc3ff4afec1809899f619a332f4350049b9578b5c4634514b4448cf2b');\nhashMap.set('hermit','0ed751a4a1db928d5ca3e925408ed8aa453681ca3ab1cb6ea2334759663df6eb');\nhashMap.set('homeassistant-manifest','05043c6db870cffbb6f8f3e351c025e3de227eaae0b24134b796aec46f84b65f');\nhashMap.set('homebrew','3cd972c03dc6333a12fd26413150ffe18c0305aa61a16b490e3306fcec9f0000');\nhashMap.set('html','67c5f3c5c58e96f5dd257ba5987d900cf7fef81d667c3640e96c847b37de35a8');\nhashMap.set('jenkins','268ebfc8a1caf3edeb2192c2b1b2fa4bf18a78a3e731ba20a6c104940a5539f3');\nhashMap.set('jsonnet-bundler','4b73c32ddc3fe45d9777106d45b116777a2960e6e631256a6553060e602f893c');\nhashMap.set('kotlin-script','99ef296792a0ca575ed31d3defb514b05a58083dc01c52ea0890c69d867ba1dd');\nhashMap.set('kubernetes','87d87b2c410facdd0400691e87080a3e1ffe83158f51f52cd784442713122f30');\nhashMap.set('kustomize','1e44d6ef8622252dac6d9649fb04badd12d4827eb2a55f74792aa9de2b915775');\nhashMap.set('leiningen','133fca2c3423f53f2ccc22518153ddbcafbf0f4812376c77e952eb3d24d81f85');\nhashMap.set('maven','6faa1a3a70542bc7e84683c31b2fb86468fdf82a25c264cf2f7fc45dbc98b1d8');\nhashMap.set('maven-wrapper','9a868d1328f911eb72f9e65a64d46c86ae347aab0153d1cf4e9a62ad9e0d6cb0');\nhashMap.set('meteor','4a93a326b27bedfe52118e27e06f39fecd7c55bd4cd7fccec4cb120cac14cec4');\nhashMap.set('mint','b816a49c8525716454d0a2bc9127916d5b27e5cca7b2aa2030312f218942af3e');\nhashMap.set('mise','a8b4ffca9953d2e49f3b7f8da81cf66251c2616c462d34d81a32a2b1d3bedd64');\nhashMap.set('mix','1116e1adf1c18c866f0a9e6fa065c4fb9da055d8d150e625344899bb94095481');\nhashMap.set('nix','f3ffec2f14e7261de8068895b91392e992dcef208fbaf52110d6862e4712c031');\nhashMap.set('nodenv','ac652c28481b001f7471f4183eac07b45d98ecbe83efc275830b0a1b2e0459b8');\nhashMap.set('npm','5598a469be81122cdc17d6882d670ace848488d93022576bcc37f2504085176d');\nhashMap.set('nuget','a8162c2819fb23fe6de82c8eb4196133701bb3c538202fe8dc9cab4a326d47e4');\nhashMap.set('nvm','3eb77c7b0acf6d64753de78fad2499b352719853aa6872878c40675d14152322');\nhashMap.set('ocb','032b216684c14b0954e0bb019513a2aca3faaee5748587acb668d377d7c891ca');\nhashMap.set('osgi','32233a1a8a2725699d7448ba438e3d0b78141f7799cd2b588de278d41e26ed10');\nhashMap.set('pep621','f503497a4adef31b29572176e9a69d52fa9b0bfe3477b6e228c906aeb4861de5');\nhashMap.set('pep723','b96683163de63ed93207ec0538066705b1e58a1cd5b8bd11c63fc28b26bddba1');\nhashMap.set('pip-compile','89152ad6c89f278395f32d289dc3890823c233366547d228e97dd1319aa144b5');\nhashMap.set('pip_requirements','d5c474c524bc7adc1aae065da0531bd22d9f7f52523b018f2461f6c29e12fdf3');\nhashMap.set('pip_setup','0175fe550c19d9bd31c978bd83fdc088cb40fcacd5d6751f640164274ae64e61');\nhashMap.set('pipenv','50f5a54ed714fd3d738c1aa9a353cf3aab767899acdcb763088d4bd04f3a737b');\nhashMap.set('pixi','b17af6eaa33e7babcc52cfc9a617c7801c0efb1125bbd6d0d4e9f6fe33afd353');\nhashMap.set('poetry','7f227b8b912b405df7735e9dc7c178f03021844f0c027d4b321c023c330c390a');\nhashMap.set('pre-commit','a6a6e847fdb0f56650e66ef7d69e68de752b390913f79ac31d1a7ec5955d03da');\nhashMap.set('pub','0fbad9f77579fcec3a623c6feab56e71934c67a79bb8f4f0f847452051d2a0ba');\nhashMap.set('puppet','ba58ab689e44acc8f61c3569ab8b40fde01b8a9d3aad712708e2a419e57d8b45');\nhashMap.set('pyenv','9ede8becc97774f9040b40f4472d3e933534b596e04c360bfe0f3c6f95f25182');\nhashMap.set('quadlet','e355e13e104351a8b3516a8e272fc5f7e625c9f39b0c492ba27283a36227c2d4');\nhashMap.set('renovate-config-presets','a394fe55f8b6ba356f29f76efd9f0d34b56baceb111e6d92f95b29b5ca50ac67');\nhashMap.set('ruby-version','2db2140d9eee8c555e729a4de0396fa2d78846d3149890ee12fa515bd654be97');\nhashMap.set('runtime-version','b582b168c0cc595e39010feb10f4b97a82683eb269e9598216fbb11cc186e160');\nhashMap.set('sbt','61f9323c91c45227da71d43120fa1eddc41685502be017118975f77b44fb1b8e');\nhashMap.set('scalafmt','9d36159b56835e96498af026a1fb0543200db0581681ef95ec54988f411e180f');\nhashMap.set('setup-cfg','7dea08c5708625e753bd56918bc214df7fb4d8543a26e936926a21ab43b5f785');\nhashMap.set('sveltos','167a5cc79098803be3b815a28cc40ef3361c455751e1d6a7a99ba91bfce26709');\nhashMap.set('swift','99e8666dd3b6c9e86c29e2451650e3d86d345df19cab6aba1995b02dcbaaa756');\nhashMap.set('tekton','4e35c75bba4abc9c3cf49c55da6c19db4f4e9181d1fd9583288ab55ef7c944fd');\nhashMap.set('terraform','5bd62ce12c23896b8ecb2385a60a3cb9eb72badf10f9984bfed38f50f9262266');\nhashMap.set('terraform-version','ec8f786b9731d47f2c2fe0307caf64d7ddd83046fe7ff1f7d8423239f8b0f2aa');\nhashMap.set('terragrunt','b8474c65383a702602eee432cc1434f9a49a1ef886d1213de92d7a84fb98b9cd');\nhashMap.set('terragrunt-version','eea6087b33717d22ede2fc68c2f64df8390b75abe82110ed831a180648feb51d');\nhashMap.set('tflint-plugin','4a975f0cc1aa22cd258aa835de3dc98d7a5c0d1cee0a1092324338968e08a827');\nhashMap.set('travis','bb482a0195cd009ec3896a6227bb95617f5c84bedb518c7d971e50c62235d9ca');\nhashMap.set('typst','d080a79fbd961c6e21fcc505d544b7e0ff2126142acb1dcabdf6abbcd9339248');\nhashMap.set('unity3d','f13e25e115e3443f4e16cf31578acffa78fb1a5e23339680a92d8d6de6052920');\nhashMap.set('velaci','fda00ddb7cc23e9a37e0a8a253151df0a6930b4276d3e4f78cc54b9ac09af7de');\nhashMap.set('vendir','4627230d3b7698c41aac192d57b65b091c860c8f858c89d6af4b06ed6a32fae6');\nhashMap.set('woodpecker','6110d3bec33aaeb3511d4bbfa896cec3c8e02fb04a6cff50c9ba81061c851045');\nhashMap.set('jsonata','3b5f465b586993f92c8490e70885e7eecce9b6556bcc376dd9c11db8ee9e6960');\nhashMap.set('regex','7b643b49e498465cf91b25b8b840bb1fec8c8a3a59bfa8f97a39c976675325a0');"],"mappings":";AAAA,MAAa,0BAAU,IAAI,KAAqB;AAEhD,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,mBAAkB,mEAAmE;AACjG,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,gBAAe,mEAAmE;AAC9F,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,uBAAsB,mEAAmE;AACrG,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,eAAc,mEAAmE;AAC7F,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,gBAAe,mEAAmE;AAC9F,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,oBAAmB,mEAAmE;AAClG,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,kBAAiB,mEAAmE;AAChG,QAAQ,IAAI,iBAAgB,mEAAmE;AAC/F,QAAQ,IAAI,qBAAoB,mEAAmE;AACnG,QAAQ,IAAI,eAAc,mEAAmE;AAC7F,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,0BAAyB,mEAAmE;AACxG,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,mBAAkB,mEAAmE;AACjG,QAAQ,IAAI,iBAAgB,mEAAmE;AAC/F,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,iBAAgB,mEAAmE;AAC/F,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,eAAc,mEAAmE;AAC7F,QAAQ,IAAI,oBAAmB,mEAAmE;AAClG,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,QAAO,mEAAmE;AACtF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,2BAA0B,mEAAmE;AACzG,QAAQ,IAAI,gBAAe,mEAAmE;AAC9F,QAAQ,IAAI,mBAAkB,mEAAmE;AACjG,QAAQ,IAAI,OAAM,mEAAmE;AACrF,QAAQ,IAAI,YAAW,mEAAmE;AAC1F,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,aAAY,mEAAmE;AAC3F,QAAQ,IAAI,qBAAoB,mEAAmE;AACnG,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,sBAAqB,mEAAmE;AACpG,QAAQ,IAAI,iBAAgB,mEAAmE;AAC/F,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,SAAQ,mEAAmE;AACvF,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,UAAS,mEAAmE;AACxF,QAAQ,IAAI,cAAa,mEAAmE;AAC5F,QAAQ,IAAI,WAAU,mEAAmE;AACzF,QAAQ,IAAI,SAAQ,mEAAmE"}
|
|
1
|
+
{"version":3,"file":"fingerprint.generated.js","names":[],"sources":["../../../lib/modules/manager/fingerprint.generated.ts"],"sourcesContent":["export const hashMap = new Map<string, string>();\n\nhashMap.set('ansible','1fbc76f78daa14a8c9ab1142e9d1e05c746c0419a9f1455e4279f476590d0c04');\nhashMap.set('ansible-galaxy','8226d47128f2018825d4d6f84794e3183eb79c706045fa7e88491edd5e64106f');\nhashMap.set('argocd','5d35b1992e53130bf83b0e59a0f90ccd3a78919974c69044f306dc5d162f48ce');\nhashMap.set('asdf','1f6fcf620e9c6cd35991380cb6eafb94ec60cd77cbd13335ebe3a1d9727416c9');\nhashMap.set('azure-pipelines','4f635b0ecd388ee266d992e8281fd40e3db2f5867d86fc1cbce72dc33a66e796');\nhashMap.set('batect','fad98996bea8626525ab925f83a6ae0ce9262c53770e7aa7cb448a1e0f1ddf21');\nhashMap.set('batect-wrapper','d999355511ea7f4053325a18b8cfc8d2b586c61e6760c35e557d383a673e3939');\nhashMap.set('bazel','c6e0ad88ea468664c3a33263baf7452d83d2d37ff09ba920e18f64ee81fd0acb');\nhashMap.set('bazel-module','ecafa538746c1d307b44e2478a0ad187c2b00d4900b6f739c8d2b88cd539b97b');\nhashMap.set('bazelisk','b6ec532dfa7c8f82ad4084df864ac6276e87c27285369323902afc146d3537ac');\nhashMap.set('bicep','7246e0bfc06e0e28cbb03ac088c5591f648956b086e106aeb251fe5d628329db');\nhashMap.set('bitbucket-pipelines','09eb044219d74331fea135f50121b7d4d146333eb97e4ccbfa9ddf0eb4012963');\nhashMap.set('bitrise','afdb46fe37fc0307943089e18b6724065394805e628b4b6c4430a6068c494030');\nhashMap.set('buildkite','a93effb1f1c5d65b3277c3b4709924eacde282e8efd028a8e3d8c1ce3ef69407');\nhashMap.set('buildpacks','6bef3cb04d66b5cfbb195adb4829bcbccae6408518706744d291bacf0610421f');\nhashMap.set('bun','1322232bf1d0c4fa796e31a00488453bdcd00d4958431d9e424c1635e60a99bd');\nhashMap.set('bun-version','df3ae8e4a5de1fa1b4544f3d7fc8117e80adb1e151c46d1ede54a4dbea6521e4');\nhashMap.set('bundler','6d7e9d2018ac03e15f19e8b40ef70dd87d509d5affca24bc464d085899880a25');\nhashMap.set('cake','288c3c36a50371b26957fa71992cc335228d53563c75597b36919ac7286e96eb');\nhashMap.set('cargo','308d7ab4c6d24027b050bf659dfab0e510d9a22f8134695a7c68214908ee4634');\nhashMap.set('cdnurl','d3edf6cdc38e92eb43ff5a2b4e8df6a6a13154cf83244725c39e28d7e6ea9177');\nhashMap.set('circleci','135937d4720718304adb0ba998516f8ce38c3220ccd18b00b8c70c62b45df4da');\nhashMap.set('cloudbuild','8c0c739f7e4082bbfe8e3fdffebaf43e26f70a1314d95b306e9b93e4f4297886');\nhashMap.set('cocoapods','b6ac3b4a6b8a5b32daed37bf695fe177cdb1b4a94ae7f7fb2f4c4c096c0a004c');\nhashMap.set('composer','cdb6895574020cec402e0b878e4078b62f1acfd0392a861cbb523036634f6383');\nhashMap.set('conan','aecc3917d77146db4e57dd12944be1beff860e90b7ebdd2d8fbc449fc1a06574');\nhashMap.set('copier','09f1aeccd473843a231bae41e7c39c6b8c45dd46102cb4f1fb4fc3852d849493');\nhashMap.set('cpanfile','6a1d67d9c8751123deaf0c7f3ac38a07024e960c140f8228fcbcb93954fdca01');\nhashMap.set('crossplane','5c26b1201a1a51454ffb94d829e223a76a781569bf79cdb1e47087c30233ec40');\nhashMap.set('crow','eb9a5f9f95041855dded67bcce3dd54724f690995ed6268d272e8a666ff28fd0');\nhashMap.set('deps-edn','c87dd5e88587147ad1a78f047b814f3c4aa60d6de30d0c49d849391eeaf1b64c');\nhashMap.set('devbox','bcf5334e8a21190baaa25436acf2f17fbf095504262a4e9ee7c62ffb644eb716');\nhashMap.set('devcontainer','24320ed1cb6191d04cb8b2707214d82c08c682597aed1d84f250aa00ad1632ec');\nhashMap.set('docker-compose','5441af5b5abf8d347e46002d47f02f85743401bda28232f49fb7b3bbb772a4fb');\nhashMap.set('dockerfile','322b95f7e55dd78d7fe71306a6f649479eca61c60d75bb10b23604a230dbdd08');\nhashMap.set('droneci','237c8de87b9bf653fb943b56e84e99c45f6d86ae27d86e599b3f3f99c35ba8ee');\nhashMap.set('fleet','d73d5d35f10df0599a561d9c8d25f3935350407d0e3bd3a1d1545295f278912e');\nhashMap.set('flux','427e0c1a5b1d8337503a9a568a76532fbde0bab8b355fa8f47312de50eadf2f6');\nhashMap.set('fvm','9b161df0f14bc6e536368952adf373e343630097121a913cea60ee284027fb90');\nhashMap.set('git-submodules','a286e097a5fcc6c946e792b812871147b39ad93f9ad041b5b3216b100f972e95');\nhashMap.set('github-actions','d3b1deb4dfcdba586cd97b4d2d2f9f1b89531bcc31b6ead0d960b990586d6058');\nhashMap.set('gitlabci','0dec44dd398bfc5b3c19d0929bea2fef7f386c94acfd1b1d7bc2a31d81d96fd6');\nhashMap.set('gitlabci-include','354cfc4ea327c6d5cd5bee1f17763832efc7f5402e9fd22c579239fccb9c6dab');\nhashMap.set('glasskube','253d6db30bdec75ed5ab5d26f31d69bc07813ba10089a28da12c6a29eff4ec70');\nhashMap.set('gleam','b717a48c525ad6b1d434c6a9db828ddebbb85e94519e89ddc4040878e3600e84');\nhashMap.set('gomod','93c6d963bd46456b438d693f4a385a490e5c729ad544564f2a9d58a1b975fe7b');\nhashMap.set('gradle','39435c4a5525a2c99a303934c23526d972ee9a40672afed801feb144a97c4eb8');\nhashMap.set('gradle-wrapper','8d5f573816e63739d264768b7f2565905036153385a0216b82ea6fed34b1a233');\nhashMap.set('haskell-cabal','d796ec6859e63ab4f1b7030c4016071202c3a44c7c11d4a9131d7e2ba19b396d');\nhashMap.set('helm-requirements','4d90e5e18a380876ad48e21e1ad88ea62e25d973a1ddaa3763447fc0a9f9915b');\nhashMap.set('helm-values','b5c52c6a27d805557418c585c5d3030c95ee641d53057021f3fe060f81b6e1af');\nhashMap.set('helmfile','e5783484b81247279563da3c835afe4002edfc412e13fb91877818ca44ae65f2');\nhashMap.set('helmsman','ef9680c612f702c7f07aea9b6e5d811e91214dcfa5755c9f3803e9528090935e');\nhashMap.set('helmv3','7724bf6cc3ff4afec1809899f619a332f4350049b9578b5c4634514b4448cf2b');\nhashMap.set('hermit','0ed751a4a1db928d5ca3e925408ed8aa453681ca3ab1cb6ea2334759663df6eb');\nhashMap.set('homeassistant-manifest','05043c6db870cffbb6f8f3e351c025e3de227eaae0b24134b796aec46f84b65f');\nhashMap.set('homebrew','3cd972c03dc6333a12fd26413150ffe18c0305aa61a16b490e3306fcec9f0000');\nhashMap.set('html','67c5f3c5c58e96f5dd257ba5987d900cf7fef81d667c3640e96c847b37de35a8');\nhashMap.set('jenkins','268ebfc8a1caf3edeb2192c2b1b2fa4bf18a78a3e731ba20a6c104940a5539f3');\nhashMap.set('jsonnet-bundler','4b73c32ddc3fe45d9777106d45b116777a2960e6e631256a6553060e602f893c');\nhashMap.set('kotlin-script','99ef296792a0ca575ed31d3defb514b05a58083dc01c52ea0890c69d867ba1dd');\nhashMap.set('kubernetes','87d87b2c410facdd0400691e87080a3e1ffe83158f51f52cd784442713122f30');\nhashMap.set('kustomize','1e44d6ef8622252dac6d9649fb04badd12d4827eb2a55f74792aa9de2b915775');\nhashMap.set('leiningen','133fca2c3423f53f2ccc22518153ddbcafbf0f4812376c77e952eb3d24d81f85');\nhashMap.set('maven','6faa1a3a70542bc7e84683c31b2fb86468fdf82a25c264cf2f7fc45dbc98b1d8');\nhashMap.set('maven-wrapper','9a868d1328f911eb72f9e65a64d46c86ae347aab0153d1cf4e9a62ad9e0d6cb0');\nhashMap.set('meteor','4a93a326b27bedfe52118e27e06f39fecd7c55bd4cd7fccec4cb120cac14cec4');\nhashMap.set('mint','b816a49c8525716454d0a2bc9127916d5b27e5cca7b2aa2030312f218942af3e');\nhashMap.set('mise','a8b4ffca9953d2e49f3b7f8da81cf66251c2616c462d34d81a32a2b1d3bedd64');\nhashMap.set('mix','1116e1adf1c18c866f0a9e6fa065c4fb9da055d8d150e625344899bb94095481');\nhashMap.set('nix','f3ffec2f14e7261de8068895b91392e992dcef208fbaf52110d6862e4712c031');\nhashMap.set('nodenv','ac652c28481b001f7471f4183eac07b45d98ecbe83efc275830b0a1b2e0459b8');\nhashMap.set('npm','f100896f5ac7854ba443e149226b399f76f356015131ebe8f298d6dc08589472');\nhashMap.set('nuget','a8162c2819fb23fe6de82c8eb4196133701bb3c538202fe8dc9cab4a326d47e4');\nhashMap.set('nvm','3eb77c7b0acf6d64753de78fad2499b352719853aa6872878c40675d14152322');\nhashMap.set('ocb','032b216684c14b0954e0bb019513a2aca3faaee5748587acb668d377d7c891ca');\nhashMap.set('osgi','32233a1a8a2725699d7448ba438e3d0b78141f7799cd2b588de278d41e26ed10');\nhashMap.set('pep621','f503497a4adef31b29572176e9a69d52fa9b0bfe3477b6e228c906aeb4861de5');\nhashMap.set('pep723','b96683163de63ed93207ec0538066705b1e58a1cd5b8bd11c63fc28b26bddba1');\nhashMap.set('pip-compile','89152ad6c89f278395f32d289dc3890823c233366547d228e97dd1319aa144b5');\nhashMap.set('pip_requirements','d5c474c524bc7adc1aae065da0531bd22d9f7f52523b018f2461f6c29e12fdf3');\nhashMap.set('pip_setup','0175fe550c19d9bd31c978bd83fdc088cb40fcacd5d6751f640164274ae64e61');\nhashMap.set('pipenv','50f5a54ed714fd3d738c1aa9a353cf3aab767899acdcb763088d4bd04f3a737b');\nhashMap.set('pixi','b17af6eaa33e7babcc52cfc9a617c7801c0efb1125bbd6d0d4e9f6fe33afd353');\nhashMap.set('poetry','7f227b8b912b405df7735e9dc7c178f03021844f0c027d4b321c023c330c390a');\nhashMap.set('pre-commit','a6a6e847fdb0f56650e66ef7d69e68de752b390913f79ac31d1a7ec5955d03da');\nhashMap.set('pub','0fbad9f77579fcec3a623c6feab56e71934c67a79bb8f4f0f847452051d2a0ba');\nhashMap.set('puppet','ba58ab689e44acc8f61c3569ab8b40fde01b8a9d3aad712708e2a419e57d8b45');\nhashMap.set('pyenv','9ede8becc97774f9040b40f4472d3e933534b596e04c360bfe0f3c6f95f25182');\nhashMap.set('quadlet','e355e13e104351a8b3516a8e272fc5f7e625c9f39b0c492ba27283a36227c2d4');\nhashMap.set('renovate-config-presets','a394fe55f8b6ba356f29f76efd9f0d34b56baceb111e6d92f95b29b5ca50ac67');\nhashMap.set('ruby-version','2db2140d9eee8c555e729a4de0396fa2d78846d3149890ee12fa515bd654be97');\nhashMap.set('runtime-version','b582b168c0cc595e39010feb10f4b97a82683eb269e9598216fbb11cc186e160');\nhashMap.set('sbt','61f9323c91c45227da71d43120fa1eddc41685502be017118975f77b44fb1b8e');\nhashMap.set('scalafmt','9d36159b56835e96498af026a1fb0543200db0581681ef95ec54988f411e180f');\nhashMap.set('setup-cfg','7dea08c5708625e753bd56918bc214df7fb4d8543a26e936926a21ab43b5f785');\nhashMap.set('sveltos','167a5cc79098803be3b815a28cc40ef3361c455751e1d6a7a99ba91bfce26709');\nhashMap.set('swift','99e8666dd3b6c9e86c29e2451650e3d86d345df19cab6aba1995b02dcbaaa756');\nhashMap.set('tekton','4e35c75bba4abc9c3cf49c55da6c19db4f4e9181d1fd9583288ab55ef7c944fd');\nhashMap.set('terraform','5bd62ce12c23896b8ecb2385a60a3cb9eb72badf10f9984bfed38f50f9262266');\nhashMap.set('terraform-version','ec8f786b9731d47f2c2fe0307caf64d7ddd83046fe7ff1f7d8423239f8b0f2aa');\nhashMap.set('terragrunt','b8474c65383a702602eee432cc1434f9a49a1ef886d1213de92d7a84fb98b9cd');\nhashMap.set('terragrunt-version','eea6087b33717d22ede2fc68c2f64df8390b75abe82110ed831a180648feb51d');\nhashMap.set('tflint-plugin','4a975f0cc1aa22cd258aa835de3dc98d7a5c0d1cee0a1092324338968e08a827');\nhashMap.set('travis','bb482a0195cd009ec3896a6227bb95617f5c84bedb518c7d971e50c62235d9ca');\nhashMap.set('typst','d080a79fbd961c6e21fcc505d544b7e0ff2126142acb1dcabdf6abbcd9339248');\nhashMap.set('unity3d','f13e25e115e3443f4e16cf31578acffa78fb1a5e23339680a92d8d6de6052920');\nhashMap.set('velaci','fda00ddb7cc23e9a37e0a8a253151df0a6930b4276d3e4f78cc54b9ac09af7de');\nhashMap.set('vendir','4627230d3b7698c41aac192d57b65b091c860c8f858c89d6af4b06ed6a32fae6');\nhashMap.set('woodpecker','6110d3bec33aaeb3511d4bbfa896cec3c8e02fb04a6cff50c9ba81061c851045');\nhashMap.set('jsonata','3b5f465b586993f92c8490e70885e7eecce9b6556bcc376dd9c11db8ee9e6960');\nhashMap.set('regex','7b643b49e498465cf91b25b8b840bb1fec8c8a3a59bfa8f97a39c976675325a0');"],"mappings":"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"}
|
|
@@ -267,7 +267,7 @@ async function getAdditionalFiles(config, packageFiles) {
|
|
|
267
267
|
await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);
|
|
268
268
|
const fileName = upath.basename(npmLock);
|
|
269
269
|
logger.debug(`Generating ${fileName} for ${lockFileDir}`);
|
|
270
|
-
const res = await generateLockFile(lockFileDir, env, fileName, config, config.upgrades.filter((upgrade) => upgrade.managerData?.npmLock === npmLock)
|
|
270
|
+
const res = await generateLockFile(lockFileDir, env, fileName, config, config.upgrades.filter((upgrade) => upgrade.managerData?.npmLock === npmLock));
|
|
271
271
|
if (res.error) {
|
|
272
272
|
/* v8 ignore next -- needs test */
|
|
273
273
|
if (res.stderr?.includes("No matching version found for")) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["hostRules.find","npm.generateLockFile","deepmerge","yarn.fuzzyMatchAdditionalYarnrcYml","yarn.generateLockFile","yarn.isYarnUpdate","pnpm.generateLockFile"],"sources":["../../../../../lib/modules/manager/npm/post-update/index.ts"],"sourcesContent":["// TODO: types (#22198)\nimport { isNonEmptyStringAndNotWhitespace, isString } from '@sindresorhus/is';\nimport deepmerge from 'deepmerge';\nimport upath from 'upath';\nimport { logger } from '../../../../logger/index.ts';\nimport { ExternalHostError } from '../../../../types/errors/external-host-error.ts';\nimport { getEnv } from '../../../../util/env.ts';\nimport {\n ensureCacheDir,\n getSiblingFileName,\n readLocalFile,\n writeLocalFile,\n} from '../../../../util/fs/index.ts';\nimport { getFile, getRepoStatus } from '../../../../util/git/index.ts';\nimport type { FileChange } from '../../../../util/git/types.ts';\nimport * as hostRules from '../../../../util/host-rules.ts';\nimport { newlineRegex, regEx } from '../../../../util/regex.ts';\nimport { ensureTrailingSlash } from '../../../../util/url.ts';\nimport { dump, parseSingleYaml } from '../../../../util/yaml.ts';\nimport { NpmDatasource } from '../../../datasource/npm/index.ts';\nimport { scm } from '../../../platform/scm.ts';\nimport type {\n ArtifactError,\n PackageFile,\n PostUpdateConfig,\n Upgrade,\n} from '../../types.ts';\nimport {\n NPM_CACHE_DIR,\n PNPM_CACHE_BASE_DIR,\n YARN_CACHE_DIR,\n YARN_GLOBAL_DIR,\n} from '../constants.ts';\nimport { getZeroInstallPaths } from '../extract/yarn.ts';\nimport type { NpmManagerData } from '../types.ts';\nimport {\n composeLockFile,\n getNpmrcContent,\n parseLockFile,\n resetNpmrcContent,\n updateNpmrcContent,\n} from '../utils.ts';\nimport * as npm from './npm.ts';\nimport * as pnpm from './pnpm.ts';\nimport { processHostRules } from './rules.ts';\nimport type {\n AdditionalPackageFiles,\n DetermineLockFileDirsResult,\n WriteExistingFilesResult,\n YarnRcYmlFile,\n} from './types.ts';\nimport * as yarn from './yarn.ts';\n\n// Strips empty values, deduplicates, and returns the directories from filenames\nconst getDirs = (arr: (string | null | undefined)[]): string[] =>\n Array.from(new Set(arr.filter(isString)));\n\nexport function determineLockFileDirs(\n config: PostUpdateConfig,\n packageFiles: AdditionalPackageFiles,\n): DetermineLockFileDirsResult {\n const npmLockDirs: (string | undefined)[] = [];\n const yarnLockDirs: (string | undefined)[] = [];\n const pnpmShrinkwrapDirs: (string | undefined)[] = [];\n\n for (const upgrade of config.upgrades) {\n if (\n upgrade.updateType === 'lockFileMaintenance' ||\n upgrade.isRemediation === true ||\n upgrade.isLockfileUpdate === true\n ) {\n yarnLockDirs.push(upgrade.managerData?.yarnLock);\n npmLockDirs.push(upgrade.managerData?.npmLock);\n pnpmShrinkwrapDirs.push(upgrade.managerData?.pnpmShrinkwrap);\n }\n }\n\n if (\n config.upgrades.every(\n (upgrade: Upgrade) =>\n upgrade.updateType === 'lockFileMaintenance' ||\n upgrade.isLockfileUpdate,\n )\n ) {\n return {\n yarnLockDirs: getDirs(yarnLockDirs),\n npmLockDirs: getDirs(npmLockDirs),\n pnpmShrinkwrapDirs: getDirs(pnpmShrinkwrapDirs),\n };\n }\n\n function getPackageFile(\n fileName: string,\n ): Partial<PackageFile<NpmManagerData>> {\n logger.trace('Looking for packageFile: ' + fileName);\n\n for (const packageFile of packageFiles.npm!) {\n if (packageFile.packageFile === fileName) {\n logger.trace({ packageFile }, 'Found packageFile');\n return packageFile;\n }\n logger.trace('No match');\n }\n return {};\n }\n\n // TODO #22198\n for (const p of config.updatedPackageFiles!) {\n logger.trace(`Checking ${String(p.path)} for lock files`);\n const packageFile = getPackageFile(p.path);\n /* v8 ignore next 3 -- needs test */\n if (!packageFile.managerData) {\n continue;\n }\n // push full lock file names and convert them later\n yarnLockDirs.push(packageFile.managerData.yarnLock);\n npmLockDirs.push(packageFile.managerData.npmLock);\n pnpmShrinkwrapDirs.push(packageFile.managerData.pnpmShrinkwrap);\n }\n\n return {\n yarnLockDirs: getDirs(yarnLockDirs),\n npmLockDirs: getDirs(npmLockDirs),\n pnpmShrinkwrapDirs: getDirs(pnpmShrinkwrapDirs),\n };\n}\n\nexport async function writeExistingFiles(\n config: PostUpdateConfig,\n packageFiles: AdditionalPackageFiles,\n): Promise<void> {\n if (!packageFiles.npm) {\n return;\n }\n const npmFiles = packageFiles.npm;\n logger.debug(\n { packageFiles: npmFiles.map((n) => n.packageFile) },\n 'Writing package.json files',\n );\n for (const packageFile of npmFiles) {\n /* v8 ignore next 3 -- needs test */\n if (!packageFile.managerData) {\n continue;\n }\n // TODO #22198\n const basedir = upath.dirname(packageFile.packageFile!);\n const npmrc = packageFile.npmrc;\n const npmrcFilename = upath.join(basedir, '.npmrc');\n // Write out the file unless the npmrc came from the workspace\n // npmrcFilename will be set whenever the file was read from disk during extract\n if (\n isString(npmrc) &&\n (npmrcFilename === packageFile.managerData.npmrcFileName ||\n !packageFile.managerData.npmrcFileName)\n ) {\n try {\n await writeLocalFile(npmrcFilename, npmrc.replace(/\\n?$/, '\\n'));\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ npmrcFilename, err }, 'Error writing .npmrc');\n }\n }\n const npmLock = packageFile.managerData.npmLock;\n if (npmLock) {\n const npmLockPath = npmLock;\n logger.debug(`Writing ${npmLock}`);\n let existingNpmLock: string;\n try {\n existingNpmLock = (await getFile(npmLock)) ?? '';\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ err }, 'Error reading npm lock file');\n existingNpmLock = '';\n }\n const { detectedIndent, lockFileParsed: npmLockParsed } =\n parseLockFile(existingNpmLock);\n if (npmLockParsed) {\n const packageNames =\n 'packages' in npmLockParsed\n ? Object.keys(npmLockParsed.packages)\n : [];\n const widens: string[] = [];\n let lockFileChanged = false;\n for (const upgrade of config.upgrades) {\n if (upgrade.lockFiles && !upgrade.lockFiles.includes(npmLock)) {\n continue;\n }\n if (!upgrade.managerData) {\n continue;\n }\n if (\n upgrade.rangeStrategy === 'widen' &&\n upgrade.managerData.npmLock === npmLock\n ) {\n // TODO #22198\n widens.push(upgrade.depName!);\n }\n const { depName } = upgrade;\n for (const packageName of packageNames) {\n if (\n 'packages' in npmLockParsed &&\n (packageName === `node_modules/${depName}` ||\n packageName.startsWith(`node_modules/${depName}/`))\n ) {\n logger.trace({ packageName }, 'Massaging out package name');\n lockFileChanged = true;\n delete npmLockParsed.packages[packageName];\n }\n }\n }\n if (widens.length) {\n logger.debug(\n `Removing ${String(widens)} from ${npmLock} to force an update`,\n );\n lockFileChanged = true;\n try {\n if ('dependencies' in npmLockParsed && npmLockParsed.dependencies) {\n widens.forEach((depName) => {\n // TODO #22198\n delete npmLockParsed.dependencies![depName];\n });\n }\n /* v8 ignore next -- needs test */\n } catch {\n logger.warn(\n { npmLock },\n 'Error massaging package-lock.json for widen',\n );\n }\n }\n if (lockFileChanged) {\n logger.debug('Massaging npm lock file before writing to disk');\n existingNpmLock = composeLockFile(npmLockParsed, detectedIndent);\n }\n await writeLocalFile(npmLockPath, existingNpmLock);\n }\n }\n }\n}\n\nexport async function writeUpdatedPackageFiles(\n config: PostUpdateConfig,\n): Promise<void> {\n logger.trace({ config }, 'writeUpdatedPackageFiles');\n logger.debug('Writing any updated package files');\n if (!config.updatedPackageFiles) {\n logger.debug('No files found');\n return;\n }\n const supportedLockFiles = ['package-lock.json', 'yarn.lock'];\n for (const packageFile of config.updatedPackageFiles) {\n if (packageFile.type !== 'addition') {\n continue;\n }\n if (\n supportedLockFiles.some((fileName) => packageFile.path.endsWith(fileName))\n ) {\n logger.debug(`Writing lock file: ${packageFile.path}`);\n // TODO #22198\n\n await writeLocalFile(packageFile.path, packageFile.contents!);\n continue;\n }\n if (\n !(\n packageFile.path.endsWith('package.json') ||\n packageFile.path.endsWith('pnpm-workspace.yaml') ||\n packageFile.path.endsWith('.yarnrc.yml')\n )\n ) {\n continue;\n }\n logger.debug(`Writing ${packageFile.path}`);\n await writeLocalFile(packageFile.path, packageFile.contents!);\n }\n}\n\n/* v8 ignore next -- needs test */\nasync function updateYarnOffline(\n lockFileDir: string,\n updatedArtifacts: FileChange[],\n): Promise<void> {\n try {\n const resolvedPaths: string[] = [];\n const yarnrcYml = await getFile(upath.join(lockFileDir, '.yarnrc.yml'));\n const yarnrc = await getFile(upath.join(lockFileDir, '.yarnrc'));\n\n // As .yarnrc.yml overrides .yarnrc in Yarn 1 (https://git.io/JUcco)\n // both files may exist, so check for .yarnrc.yml first\n if (yarnrcYml) {\n // Yarn 2 (offline cache and zero-installs)\n const paths = getZeroInstallPaths(yarnrcYml);\n resolvedPaths.push(...paths.map((p) => upath.join(lockFileDir, p)));\n } else if (yarnrc) {\n // Yarn 1 (offline mirror)\n const mirrorLine = yarnrc\n .split(newlineRegex)\n .find((line) => line.startsWith('yarn-offline-mirror '));\n if (mirrorLine) {\n const mirrorPath = ensureTrailingSlash(\n mirrorLine.split(' ')[1].replace(regEx(/\"/g), ''),\n );\n resolvedPaths.push(upath.join(lockFileDir, mirrorPath));\n }\n }\n logger.debug({ resolvedPaths }, 'updateYarnOffline resolvedPaths');\n\n if (resolvedPaths.length) {\n const status = await getRepoStatus();\n for (const f of status.modified.concat(status.not_added)) {\n if (resolvedPaths.some((p) => f.startsWith(p))) {\n updatedArtifacts.push({\n type: 'addition',\n path: f,\n contents: await readLocalFile(f),\n });\n }\n }\n for (const f of status.deleted || []) {\n if (resolvedPaths.some((p) => f.startsWith(p))) {\n updatedArtifacts.push({ type: 'deletion', path: f });\n }\n }\n }\n } catch (err) {\n logger.error({ err }, 'Error updating yarn offline packages');\n }\n}\n\n// TODO: move to ./yarn.ts\n// exported for testing\nexport async function updateYarnBinary(\n lockFileDir: string,\n updatedArtifacts: FileChange[],\n existingYarnrcYmlContent: string | undefined | null,\n): Promise<string | undefined | null> {\n let yarnrcYml = existingYarnrcYmlContent;\n try {\n const yarnrcYmlFilename = upath.join(lockFileDir, '.yarnrc.yml');\n yarnrcYml ??= (await getFile(yarnrcYmlFilename)) ?? undefined;\n const newYarnrcYml = await readLocalFile(yarnrcYmlFilename, 'utf8');\n if (!isString(yarnrcYml) || !isString(newYarnrcYml)) {\n return existingYarnrcYmlContent;\n }\n\n // TODO: use schema (#9610)\n const oldYarnPath = parseSingleYaml<YarnRcYmlFile>(yarnrcYml)?.yarnPath;\n const newYarnPath = parseSingleYaml<YarnRcYmlFile>(newYarnrcYml)?.yarnPath;\n if (\n !isNonEmptyStringAndNotWhitespace(oldYarnPath) ||\n !isNonEmptyStringAndNotWhitespace(newYarnPath)\n ) {\n return existingYarnrcYmlContent;\n }\n\n const oldYarnFullPath = upath.join(lockFileDir, oldYarnPath);\n const newYarnFullPath = upath.join(lockFileDir, newYarnPath);\n logger.debug({ oldYarnPath, newYarnPath }, 'Found updated Yarn binary');\n\n yarnrcYml = yarnrcYml.replace(oldYarnPath, newYarnPath);\n updatedArtifacts.push(\n {\n type: 'addition',\n path: yarnrcYmlFilename,\n contents: yarnrcYml,\n },\n {\n type: 'deletion',\n path: oldYarnFullPath,\n },\n {\n type: 'addition',\n path: newYarnFullPath,\n contents: await readLocalFile(newYarnFullPath, 'utf8'),\n isExecutable: true,\n },\n );\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.error({ err }, 'Error updating Yarn binary');\n }\n return existingYarnrcYmlContent && yarnrcYml;\n}\n\nexport async function getAdditionalFiles(\n config: PostUpdateConfig<NpmManagerData>,\n packageFiles: AdditionalPackageFiles,\n): Promise<WriteExistingFilesResult> {\n logger.trace({ config }, 'getAdditionalFiles');\n const artifactErrors: ArtifactError[] = [];\n const updatedArtifacts: FileChange[] = [];\n if (!packageFiles.npm?.length) {\n return { artifactErrors, updatedArtifacts };\n }\n if (config.skipArtifactsUpdate) {\n logger.debug('Skipping lock file generation');\n return { artifactErrors, updatedArtifacts };\n }\n logger.debug('Getting updated lock files');\n if (\n config.isLockFileMaintenance &&\n config.reuseExistingBranch &&\n (await scm.branchExists(config.branchName))\n ) {\n logger.debug('Skipping lockFileMaintenance update');\n return { artifactErrors, updatedArtifacts };\n }\n const dirs = determineLockFileDirs(config, packageFiles);\n logger.trace({ dirs }, 'lock file dirs');\n await writeExistingFiles(config, packageFiles);\n await writeUpdatedPackageFiles(config);\n\n const { additionalNpmrcContent, additionalYarnRcYml } = processHostRules();\n\n // This isn't passed directly to the child process, so no need to filter.\n // But pass custom env and user vars.\n const env = {\n ...getEnv(),\n NPM_CONFIG_CACHE: await ensureCacheDir(NPM_CACHE_DIR),\n YARN_CACHE_FOLDER: await ensureCacheDir(YARN_CACHE_DIR),\n YARN_GLOBAL_FOLDER: await ensureCacheDir(YARN_GLOBAL_DIR),\n npm_config_store: await ensureCacheDir(PNPM_CACHE_BASE_DIR),\n NODE_ENV: 'dev',\n };\n\n let token: string | undefined;\n try {\n ({ token } = hostRules.find({\n hostType: 'github',\n url: 'https://api.github.com/',\n }));\n token = token ? /* v8 ignore next */ `${token}@` : token;\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ err }, 'Error getting token for packageFile');\n }\n const tokenRe = regEx(`${token ?? ''}`, 'g', false);\n for (const npmLock of dirs.npmLockDirs) {\n const lockFileDir = upath.dirname(npmLock);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n const fileName = upath.basename(npmLock);\n logger.debug(`Generating ${fileName} for ${lockFileDir}`);\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.npmLock === npmLock,\n );\n const res = await npm.generateLockFile(\n lockFileDir,\n env,\n fileName,\n config,\n upgrades,\n npmrcContent,\n );\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stderr?.includes('No matching version found for')) {\n for (const upgrade of config.upgrades) {\n if (\n res.stderr.includes(\n `No matching version found for ${upgrade.depName}`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'npm' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n const err = new Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(err, NpmDatasource.id);\n }\n }\n }\n\n artifactErrors.push({\n fileName: npmLock,\n stderr: res.stderr,\n });\n } else if (res.lockFile) {\n const existingContent = await getFile(\n npmLock,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(`${npmLock} hasn't changed`);\n } else {\n logger.debug(`${npmLock} needs updating`);\n updatedArtifacts.push({\n type: 'addition',\n path: npmLock,\n // TODO: can this be undefined? (#22198)\n\n contents: res.lockFile.replace(tokenRe, ''),\n });\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n }\n\n for (const yarnLock of dirs.yarnLockDirs) {\n const lockFileDir = upath.dirname(yarnLock);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n let yarnRcYmlFilename: string | undefined;\n let existingYarnrcYmlContent: string | undefined | null;\n if (additionalYarnRcYml) {\n yarnRcYmlFilename = getSiblingFileName(yarnLock, '.yarnrc.yml');\n existingYarnrcYmlContent = await readLocalFile(yarnRcYmlFilename, 'utf8');\n if (existingYarnrcYmlContent) {\n try {\n // TODO: use schema (#9610)\n const existingYarnrRcYml = parseSingleYaml<Record<string, unknown>>(\n existingYarnrcYmlContent,\n );\n\n const updatedYarnYrcYml = deepmerge(\n existingYarnrRcYml,\n yarn.fuzzyMatchAdditionalYarnrcYml(\n additionalYarnRcYml,\n existingYarnrRcYml,\n ),\n );\n\n await writeLocalFile(yarnRcYmlFilename, dump(updatedYarnYrcYml));\n logger.debug('Added authentication to .yarnrc.yml');\n } catch (err) {\n logger.warn({ err }, 'Error appending .yarnrc.yml content');\n }\n }\n }\n logger.debug(`Generating yarn.lock for ${lockFileDir}`);\n const lockFileName = upath.join(lockFileDir, 'yarn.lock');\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.yarnLock === yarnLock,\n );\n const res = await yarn.generateLockFile(lockFileDir, env, config, upgrades);\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stderr?.includes(`Couldn't find any versions for`)) {\n for (const upgrade of config.upgrades) {\n /* eslint-disable no-useless-escape */\n if (\n res.stderr.includes(\n `Couldn't find any versions for \\\\\\\"${upgrade.depName}\\\\\\\"`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'yarn' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(\n new Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n ),\n NpmDatasource.id,\n );\n }\n /* eslint-enable no-useless-escape */\n }\n }\n\n artifactErrors.push({\n fileName: yarnLock,\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing\n stderr: res.stderr || res.stdout,\n });\n } else {\n const existingContent = await getFile(\n lockFileName,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(\"yarn.lock hasn't changed\");\n } else {\n logger.debug('yarn.lock needs updating');\n updatedArtifacts.push({\n type: 'addition',\n path: lockFileName,\n // TODO #22198\n contents: res.lockFile!,\n });\n await updateYarnOffline(lockFileDir, updatedArtifacts);\n }\n\n /* v8 ignore next 7 -- needs test */\n if (upgrades.some(yarn.isYarnUpdate)) {\n existingYarnrcYmlContent = await updateYarnBinary(\n lockFileDir,\n updatedArtifacts,\n existingYarnrcYmlContent,\n );\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n /* v8 ignore next 4 -- needs test */\n if (existingYarnrcYmlContent) {\n // TODO #22198\n await writeLocalFile(yarnRcYmlFilename!, existingYarnrcYmlContent);\n }\n }\n\n for (const pnpmShrinkwrap of dirs.pnpmShrinkwrapDirs) {\n const lockFileDir = upath.dirname(pnpmShrinkwrap);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n logger.debug(`Generating pnpm-lock.yaml for ${lockFileDir}`);\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.pnpmShrinkwrap === pnpmShrinkwrap,\n );\n const res = await pnpm.generateLockFile(lockFileDir, env, config, upgrades);\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stdout?.includes(`No compatible version found:`)) {\n for (const upgrade of config.upgrades) {\n if (\n res.stdout.includes(\n `No compatible version found: ${upgrade.depName}`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'pnpm' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(\n Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n ),\n NpmDatasource.id,\n );\n }\n }\n }\n\n artifactErrors.push({\n fileName: pnpmShrinkwrap,\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing\n stderr: res.stderr || res.stdout,\n });\n } else {\n const existingContent = await getFile(\n pnpmShrinkwrap,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(\"pnpm-lock.yaml hasn't changed\");\n } else {\n logger.debug('pnpm-lock.yaml needs updating');\n updatedArtifacts.push({\n type: 'addition',\n path: pnpmShrinkwrap,\n // TODO: can be undefined? (#22198)\n contents: res.lockFile!,\n });\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n }\n\n return { artifactErrors, updatedArtifacts };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAsDA,MAAM,WAAW,QACf,MAAM,KAAK,IAAI,IAAI,IAAI,OAAO,SAAS,CAAC,CAAC;AAE3C,SAAgB,sBACd,QACA,cAC6B;CAC7B,MAAM,cAAsC,EAAE;CAC9C,MAAM,eAAuC,EAAE;CAC/C,MAAM,qBAA6C,EAAE;AAErD,MAAK,MAAM,WAAW,OAAO,SAC3B,KACE,QAAQ,eAAe,yBACvB,QAAQ,kBAAkB,QAC1B,QAAQ,qBAAqB,MAC7B;AACA,eAAa,KAAK,QAAQ,aAAa,SAAS;AAChD,cAAY,KAAK,QAAQ,aAAa,QAAQ;AAC9C,qBAAmB,KAAK,QAAQ,aAAa,eAAe;;AAIhE,KACE,OAAO,SAAS,OACb,YACC,QAAQ,eAAe,yBACvB,QAAQ,iBACX,CAED,QAAO;EACL,cAAc,QAAQ,aAAa;EACnC,aAAa,QAAQ,YAAY;EACjC,oBAAoB,QAAQ,mBAAmB;EAChD;CAGH,SAAS,eACP,UACsC;AACtC,SAAO,MAAM,8BAA8B,SAAS;AAEpD,OAAK,MAAM,eAAe,aAAa,KAAM;AAC3C,OAAI,YAAY,gBAAgB,UAAU;AACxC,WAAO,MAAM,EAAE,aAAa,EAAE,oBAAoB;AAClD,WAAO;;AAET,UAAO,MAAM,WAAW;;AAE1B,SAAO,EAAE;;AAIX,MAAK,MAAM,KAAK,OAAO,qBAAsB;AAC3C,SAAO,MAAM,YAAY,OAAO,EAAE,KAAK,CAAC,iBAAiB;EACzD,MAAM,cAAc,eAAe,EAAE,KAAK;;AAE1C,MAAI,CAAC,YAAY,YACf;AAGF,eAAa,KAAK,YAAY,YAAY,SAAS;AACnD,cAAY,KAAK,YAAY,YAAY,QAAQ;AACjD,qBAAmB,KAAK,YAAY,YAAY,eAAe;;AAGjE,QAAO;EACL,cAAc,QAAQ,aAAa;EACnC,aAAa,QAAQ,YAAY;EACjC,oBAAoB,QAAQ,mBAAmB;EAChD;;AAGH,eAAsB,mBACpB,QACA,cACe;AACf,KAAI,CAAC,aAAa,IAChB;CAEF,MAAM,WAAW,aAAa;AAC9B,QAAO,MACL,EAAE,cAAc,SAAS,KAAK,MAAM,EAAE,YAAY,EAAE,EACpD,6BACD;AACD,MAAK,MAAM,eAAe,UAAU;;AAElC,MAAI,CAAC,YAAY,YACf;EAGF,MAAM,UAAU,MAAM,QAAQ,YAAY,YAAa;EACvD,MAAM,QAAQ,YAAY;EAC1B,MAAM,gBAAgB,MAAM,KAAK,SAAS,SAAS;AAGnD,MACE,SAAS,MAAM,KACd,kBAAkB,YAAY,YAAY,iBACzC,CAAC,YAAY,YAAY,eAE3B,KAAI;AACF,SAAM,eAAe,eAAe,MAAM,QAAQ,QAAQ,KAAK,CAAC;WAEzD,KAAK;AACZ,UAAO,KAAK;IAAE;IAAe;IAAK,EAAE,uBAAuB;;EAG/D,MAAM,UAAU,YAAY,YAAY;AACxC,MAAI,SAAS;GACX,MAAM,cAAc;AACpB,UAAO,MAAM,WAAW,UAAU;GAClC,IAAI;AACJ,OAAI;AACF,sBAAmB,MAAM,QAAQ,QAAQ,IAAK;YAEvC,KAAK;AACZ,WAAO,KAAK,EAAE,KAAK,EAAE,8BAA8B;AACnD,sBAAkB;;GAEpB,MAAM,EAAE,gBAAgB,gBAAgB,kBACtC,cAAc,gBAAgB;AAChC,OAAI,eAAe;IACjB,MAAM,eACJ,cAAc,gBACV,OAAO,KAAK,cAAc,SAAS,GACnC,EAAE;IACR,MAAM,SAAmB,EAAE;IAC3B,IAAI,kBAAkB;AACtB,SAAK,MAAM,WAAW,OAAO,UAAU;AACrC,SAAI,QAAQ,aAAa,CAAC,QAAQ,UAAU,SAAS,QAAQ,CAC3D;AAEF,SAAI,CAAC,QAAQ,YACX;AAEF,SACE,QAAQ,kBAAkB,WAC1B,QAAQ,YAAY,YAAY,QAGhC,QAAO,KAAK,QAAQ,QAAS;KAE/B,MAAM,EAAE,YAAY;AACpB,UAAK,MAAM,eAAe,aACxB,KACE,cAAc,kBACb,gBAAgB,gBAAgB,aAC/B,YAAY,WAAW,gBAAgB,QAAQ,GAAG,GACpD;AACA,aAAO,MAAM,EAAE,aAAa,EAAE,6BAA6B;AAC3D,wBAAkB;AAClB,aAAO,cAAc,SAAS;;;AAIpC,QAAI,OAAO,QAAQ;AACjB,YAAO,MACL,YAAY,OAAO,OAAO,CAAC,QAAQ,QAAQ,qBAC5C;AACD,uBAAkB;AAClB,SAAI;AACF,UAAI,kBAAkB,iBAAiB,cAAc,aACnD,QAAO,SAAS,YAAY;AAE1B,cAAO,cAAc,aAAc;QACnC;aAGE;AACN,aAAO,KACL,EAAE,SAAS,EACX,8CACD;;;AAGL,QAAI,iBAAiB;AACnB,YAAO,MAAM,iDAAiD;AAC9D,uBAAkB,gBAAgB,eAAe,eAAe;;AAElE,UAAM,eAAe,aAAa,gBAAgB;;;;;AAM1D,eAAsB,yBACpB,QACe;AACf,QAAO,MAAM,EAAE,QAAQ,EAAE,2BAA2B;AACpD,QAAO,MAAM,oCAAoC;AACjD,KAAI,CAAC,OAAO,qBAAqB;AAC/B,SAAO,MAAM,iBAAiB;AAC9B;;CAEF,MAAM,qBAAqB,CAAC,qBAAqB,YAAY;AAC7D,MAAK,MAAM,eAAe,OAAO,qBAAqB;AACpD,MAAI,YAAY,SAAS,WACvB;AAEF,MACE,mBAAmB,MAAM,aAAa,YAAY,KAAK,SAAS,SAAS,CAAC,EAC1E;AACA,UAAO,MAAM,sBAAsB,YAAY,OAAO;AAGtD,SAAM,eAAe,YAAY,MAAM,YAAY,SAAU;AAC7D;;AAEF,MACE,EACE,YAAY,KAAK,SAAS,eAAe,IACzC,YAAY,KAAK,SAAS,sBAAsB,IAChD,YAAY,KAAK,SAAS,cAAc,EAG1C;AAEF,SAAO,MAAM,WAAW,YAAY,OAAO;AAC3C,QAAM,eAAe,YAAY,MAAM,YAAY,SAAU;;;;AAKjE,eAAe,kBACb,aACA,kBACe;AACf,KAAI;EACF,MAAM,gBAA0B,EAAE;EAClC,MAAM,YAAY,MAAM,QAAQ,MAAM,KAAK,aAAa,cAAc,CAAC;EACvE,MAAM,SAAS,MAAM,QAAQ,MAAM,KAAK,aAAa,UAAU,CAAC;AAIhE,MAAI,WAAW;GAEb,MAAM,QAAQ,oBAAoB,UAAU;AAC5C,iBAAc,KAAK,GAAG,MAAM,KAAK,MAAM,MAAM,KAAK,aAAa,EAAE,CAAC,CAAC;aAC1D,QAAQ;GAEjB,MAAM,aAAa,OAChB,MAAM,aAAa,CACnB,MAAM,SAAS,KAAK,WAAW,uBAAuB,CAAC;AAC1D,OAAI,YAAY;IACd,MAAM,aAAa,oBACjB,WAAW,MAAM,IAAI,CAAC,GAAG,QAAQ,MAAM,KAAK,EAAE,GAAG,CAClD;AACD,kBAAc,KAAK,MAAM,KAAK,aAAa,WAAW,CAAC;;;AAG3D,SAAO,MAAM,EAAE,eAAe,EAAE,kCAAkC;AAElE,MAAI,cAAc,QAAQ;GACxB,MAAM,SAAS,MAAM,eAAe;AACpC,QAAK,MAAM,KAAK,OAAO,SAAS,OAAO,OAAO,UAAU,CACtD,KAAI,cAAc,MAAM,MAAM,EAAE,WAAW,EAAE,CAAC,CAC5C,kBAAiB,KAAK;IACpB,MAAM;IACN,MAAM;IACN,UAAU,MAAM,cAAc,EAAE;IACjC,CAAC;AAGN,QAAK,MAAM,KAAK,OAAO,WAAW,EAAE,CAClC,KAAI,cAAc,MAAM,MAAM,EAAE,WAAW,EAAE,CAAC,CAC5C,kBAAiB,KAAK;IAAE,MAAM;IAAY,MAAM;IAAG,CAAC;;UAInD,KAAK;AACZ,SAAO,MAAM,EAAE,KAAK,EAAE,uCAAuC;;;AAMjE,eAAsB,iBACpB,aACA,kBACA,0BACoC;CACpC,IAAI,YAAY;AAChB,KAAI;EACF,MAAM,oBAAoB,MAAM,KAAK,aAAa,cAAc;AAChE,gBAAe,MAAM,QAAQ,kBAAkB,IAAK,KAAA;EACpD,MAAM,eAAe,MAAM,cAAc,mBAAmB,OAAO;AACnE,MAAI,CAAC,SAAS,UAAU,IAAI,CAAC,SAAS,aAAa,CACjD,QAAO;EAIT,MAAM,cAAc,gBAA+B,UAAU,EAAE;EAC/D,MAAM,cAAc,gBAA+B,aAAa,EAAE;AAClE,MACE,CAAC,iCAAiC,YAAY,IAC9C,CAAC,iCAAiC,YAAY,CAE9C,QAAO;EAGT,MAAM,kBAAkB,MAAM,KAAK,aAAa,YAAY;EAC5D,MAAM,kBAAkB,MAAM,KAAK,aAAa,YAAY;AAC5D,SAAO,MAAM;GAAE;GAAa;GAAa,EAAE,4BAA4B;AAEvE,cAAY,UAAU,QAAQ,aAAa,YAAY;AACvD,mBAAiB,KACf;GACE,MAAM;GACN,MAAM;GACN,UAAU;GACX,EACD;GACE,MAAM;GACN,MAAM;GACP,EACD;GACE,MAAM;GACN,MAAM;GACN,UAAU,MAAM,cAAc,iBAAiB,OAAO;GACtD,cAAc;GACf,CACF;UAEM,KAAK;AACZ,SAAO,MAAM,EAAE,KAAK,EAAE,6BAA6B;;AAErD,QAAO,4BAA4B;;AAGrC,eAAsB,mBACpB,QACA,cACmC;AACnC,QAAO,MAAM,EAAE,QAAQ,EAAE,qBAAqB;CAC9C,MAAM,iBAAkC,EAAE;CAC1C,MAAM,mBAAiC,EAAE;AACzC,KAAI,CAAC,aAAa,KAAK,OACrB,QAAO;EAAE;EAAgB;EAAkB;AAE7C,KAAI,OAAO,qBAAqB;AAC9B,SAAO,MAAM,gCAAgC;AAC7C,SAAO;GAAE;GAAgB;GAAkB;;AAE7C,QAAO,MAAM,6BAA6B;AAC1C,KACE,OAAO,yBACP,OAAO,uBACN,MAAM,IAAI,aAAa,OAAO,WAAW,EAC1C;AACA,SAAO,MAAM,sCAAsC;AACnD,SAAO;GAAE;GAAgB;GAAkB;;CAE7C,MAAM,OAAO,sBAAsB,QAAQ,aAAa;AACxD,QAAO,MAAM,EAAE,MAAM,EAAE,iBAAiB;AACxC,OAAM,mBAAmB,QAAQ,aAAa;AAC9C,OAAM,yBAAyB,OAAO;CAEtC,MAAM,EAAE,wBAAwB,wBAAwB,kBAAkB;CAI1E,MAAM,MAAM;EACV,GAAG,QAAQ;EACX,kBAAkB,MAAM,eAAA,MAA6B;EACrD,mBAAmB,MAAM,eAAe,eAAe;EACvD,oBAAoB,MAAM,eAAe,gBAAgB;EACzD,kBAAkB,MAAM,eAAe,oBAAoB;EAC3D,UAAU;EACX;CAED,IAAI;AACJ,KAAI;AACF,GAAC,CAAE,SAAUA,KAAe;GAC1B,UAAU;GACV,KAAK;GACN,CAAC;AACF,UAAQ,QAA6B,GAAG,MAAM,KAAK;UAE5C,KAAK;AACZ,SAAO,KAAK,EAAE,KAAK,EAAE,sCAAsC;;CAE7D,MAAM,UAAU,MAAM,GAAG,SAAS,MAAM,KAAK,MAAM;AACnD,MAAK,MAAM,WAAW,KAAK,aAAa;EACtC,MAAM,cAAc,MAAM,QAAQ,QAAQ;EAC1C,MAAM,eAAe,MAAM,gBAAgB,YAAY;AACvD,QAAM,mBAAmB,aAAa,cAAc,uBAAuB;EAC3E,MAAM,WAAW,MAAM,SAAS,QAAQ;AACxC,SAAO,MAAM,cAAc,SAAS,OAAO,cAAc;EAIzD,MAAM,MAAM,MAAMC,iBAChB,aACA,KACA,UACA,QAPe,OAAO,SAAS,QAC9B,YAAY,QAAQ,aAAa,YAAY,QAC/C,EAOC,aACD;AACD,MAAI,IAAI,OAAO;;AAEb,OAAI,IAAI,QAAQ,SAAS,gCAAgC;SAClD,MAAM,WAAW,OAAO,SAC3B,KACE,IAAI,OAAO,SACT,iCAAiC,QAAQ,UAC1C,EACD;AACA,YAAO,MACL;MAAE,YAAY,QAAQ;MAAS,MAAM;MAAO,EAC5C,+EACD;AAID,WAAM,IAAI,kCAHE,IAAI,MACd,+EACD,EACgC,cAAc,GAAG;;;AAKxD,kBAAe,KAAK;IAClB,UAAU;IACV,QAAQ,IAAI;IACb,CAAC;aACO,IAAI,UAAU;GACvB,MAAM,kBAAkB,MAAM,QAC5B,SACA,OAAO,sBAAsB,OAAO,aAAa,OAAO,WACzD;AACD,OAAI,IAAI,aAAa,gBACnB,QAAO,MAAM,GAAG,QAAQ,iBAAiB;QACpC;AACL,WAAO,MAAM,GAAG,QAAQ,iBAAiB;AACzC,qBAAiB,KAAK;KACpB,MAAM;KACN,MAAM;KAGN,UAAU,IAAI,SAAS,QAAQ,SAAS,GAAG;KAC5C,CAAC;;;AAGN,QAAM,kBAAkB,aAAa,aAAa;;AAGpD,MAAK,MAAM,YAAY,KAAK,cAAc;EACxC,MAAM,cAAc,MAAM,QAAQ,SAAS;EAC3C,MAAM,eAAe,MAAM,gBAAgB,YAAY;AACvD,QAAM,mBAAmB,aAAa,cAAc,uBAAuB;EAC3E,IAAI;EACJ,IAAI;AACJ,MAAI,qBAAqB;AACvB,uBAAoB,mBAAmB,UAAU,cAAc;AAC/D,8BAA2B,MAAM,cAAc,mBAAmB,OAAO;AACzE,OAAI,yBACF,KAAI;IAEF,MAAM,qBAAqB,gBACzB,yBACD;IAED,MAAM,oBAAoBC,MACxB,oBACAC,8BACE,qBACA,mBACD,CACF;AAED,UAAM,eAAe,mBAAmB,KAAK,kBAAkB,CAAC;AAChE,WAAO,MAAM,sCAAsC;YAC5C,KAAK;AACZ,WAAO,KAAK,EAAE,KAAK,EAAE,sCAAsC;;;AAIjE,SAAO,MAAM,4BAA4B,cAAc;EACvD,MAAM,eAAe,MAAM,KAAK,aAAa,YAAY;EACzD,MAAM,WAAW,OAAO,SAAS,QAC9B,YAAY,QAAQ,aAAa,aAAa,SAChD;EACD,MAAM,MAAM,MAAMC,mBAAsB,aAAa,KAAK,QAAQ,SAAS;AAC3E,MAAI,IAAI,OAAO;;AAEb,OAAI,IAAI,QAAQ,SAAS,iCAAiC;SACnD,MAAM,WAAW,OAAO,SAE3B,KACE,IAAI,OAAO,SACT,sCAAsC,QAAQ,QAAQ,MACvD,EACD;AACA,YAAO,MACL;MAAE,YAAY,QAAQ;MAAS,MAAM;MAAQ,EAC7C,+EACD;AACD,WAAM,IAAI,kCACR,IAAI,MACF,+EACD,EACD,cAAc,GACf;;;AAMP,kBAAe,KAAK;IAClB,UAAU;IAEV,QAAQ,IAAI,UAAU,IAAI;IAC3B,CAAC;SACG;GACL,MAAM,kBAAkB,MAAM,QAC5B,cACA,OAAO,sBAAsB,OAAO,aAAa,OAAO,WACzD;AACD,OAAI,IAAI,aAAa,gBACnB,QAAO,MAAM,2BAA2B;QACnC;AACL,WAAO,MAAM,2BAA2B;AACxC,qBAAiB,KAAK;KACpB,MAAM;KACN,MAAM;KAEN,UAAU,IAAI;KACf,CAAC;AACF,UAAM,kBAAkB,aAAa,iBAAiB;;;AAIxD,OAAI,SAAS,KAAKC,aAAkB,CAClC,4BAA2B,MAAM,iBAC/B,aACA,kBACA,yBACD;;AAGL,QAAM,kBAAkB,aAAa,aAAa;;AAElD,MAAI,yBAEF,OAAM,eAAe,mBAAoB,yBAAyB;;AAItE,MAAK,MAAM,kBAAkB,KAAK,oBAAoB;EACpD,MAAM,cAAc,MAAM,QAAQ,eAAe;EACjD,MAAM,eAAe,MAAM,gBAAgB,YAAY;AACvD,QAAM,mBAAmB,aAAa,cAAc,uBAAuB;AAC3E,SAAO,MAAM,iCAAiC,cAAc;EAI5D,MAAM,MAAM,MAAMC,mBAAsB,aAAa,KAAK,QAHzC,OAAO,SAAS,QAC9B,YAAY,QAAQ,aAAa,mBAAmB,eACtD,CAC0E;AAC3E,MAAI,IAAI,OAAO;;AAEb,OAAI,IAAI,QAAQ,SAAS,+BAA+B;SACjD,MAAM,WAAW,OAAO,SAC3B,KACE,IAAI,OAAO,SACT,gCAAgC,QAAQ,UACzC,EACD;AACA,YAAO,MACL;MAAE,YAAY,QAAQ;MAAS,MAAM;MAAQ,EAC7C,+EACD;AACD,WAAM,IAAI,kBACR,MACE,+EACD,EACD,cAAc,GACf;;;AAKP,kBAAe,KAAK;IAClB,UAAU;IAEV,QAAQ,IAAI,UAAU,IAAI;IAC3B,CAAC;SACG;GACL,MAAM,kBAAkB,MAAM,QAC5B,gBACA,OAAO,sBAAsB,OAAO,aAAa,OAAO,WACzD;AACD,OAAI,IAAI,aAAa,gBACnB,QAAO,MAAM,gCAAgC;QACxC;AACL,WAAO,MAAM,gCAAgC;AAC7C,qBAAiB,KAAK;KACpB,MAAM;KACN,MAAM;KAEN,UAAU,IAAI;KACf,CAAC;;;AAGN,QAAM,kBAAkB,aAAa,aAAa;;AAGpD,QAAO;EAAE;EAAgB;EAAkB"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["hostRules.find","npm.generateLockFile","deepmerge","yarn.fuzzyMatchAdditionalYarnrcYml","yarn.generateLockFile","yarn.isYarnUpdate","pnpm.generateLockFile"],"sources":["../../../../../lib/modules/manager/npm/post-update/index.ts"],"sourcesContent":["// TODO: types (#22198)\nimport { isNonEmptyStringAndNotWhitespace, isString } from '@sindresorhus/is';\nimport deepmerge from 'deepmerge';\nimport upath from 'upath';\nimport { logger } from '../../../../logger/index.ts';\nimport { ExternalHostError } from '../../../../types/errors/external-host-error.ts';\nimport { getEnv } from '../../../../util/env.ts';\nimport {\n ensureCacheDir,\n getSiblingFileName,\n readLocalFile,\n writeLocalFile,\n} from '../../../../util/fs/index.ts';\nimport { getFile, getRepoStatus } from '../../../../util/git/index.ts';\nimport type { FileChange } from '../../../../util/git/types.ts';\nimport * as hostRules from '../../../../util/host-rules.ts';\nimport { newlineRegex, regEx } from '../../../../util/regex.ts';\nimport { ensureTrailingSlash } from '../../../../util/url.ts';\nimport { dump, parseSingleYaml } from '../../../../util/yaml.ts';\nimport { NpmDatasource } from '../../../datasource/npm/index.ts';\nimport { scm } from '../../../platform/scm.ts';\nimport type {\n ArtifactError,\n PackageFile,\n PostUpdateConfig,\n Upgrade,\n} from '../../types.ts';\nimport {\n NPM_CACHE_DIR,\n PNPM_CACHE_BASE_DIR,\n YARN_CACHE_DIR,\n YARN_GLOBAL_DIR,\n} from '../constants.ts';\nimport { getZeroInstallPaths } from '../extract/yarn.ts';\nimport type { NpmManagerData } from '../types.ts';\nimport {\n composeLockFile,\n getNpmrcContent,\n parseLockFile,\n resetNpmrcContent,\n updateNpmrcContent,\n} from '../utils.ts';\nimport * as npm from './npm.ts';\nimport * as pnpm from './pnpm.ts';\nimport { processHostRules } from './rules.ts';\nimport type {\n AdditionalPackageFiles,\n DetermineLockFileDirsResult,\n WriteExistingFilesResult,\n YarnRcYmlFile,\n} from './types.ts';\nimport * as yarn from './yarn.ts';\n\n// Strips empty values, deduplicates, and returns the directories from filenames\nconst getDirs = (arr: (string | null | undefined)[]): string[] =>\n Array.from(new Set(arr.filter(isString)));\n\nexport function determineLockFileDirs(\n config: PostUpdateConfig,\n packageFiles: AdditionalPackageFiles,\n): DetermineLockFileDirsResult {\n const npmLockDirs: (string | undefined)[] = [];\n const yarnLockDirs: (string | undefined)[] = [];\n const pnpmShrinkwrapDirs: (string | undefined)[] = [];\n\n for (const upgrade of config.upgrades) {\n if (\n upgrade.updateType === 'lockFileMaintenance' ||\n upgrade.isRemediation === true ||\n upgrade.isLockfileUpdate === true\n ) {\n yarnLockDirs.push(upgrade.managerData?.yarnLock);\n npmLockDirs.push(upgrade.managerData?.npmLock);\n pnpmShrinkwrapDirs.push(upgrade.managerData?.pnpmShrinkwrap);\n }\n }\n\n if (\n config.upgrades.every(\n (upgrade: Upgrade) =>\n upgrade.updateType === 'lockFileMaintenance' ||\n upgrade.isLockfileUpdate,\n )\n ) {\n return {\n yarnLockDirs: getDirs(yarnLockDirs),\n npmLockDirs: getDirs(npmLockDirs),\n pnpmShrinkwrapDirs: getDirs(pnpmShrinkwrapDirs),\n };\n }\n\n function getPackageFile(\n fileName: string,\n ): Partial<PackageFile<NpmManagerData>> {\n logger.trace('Looking for packageFile: ' + fileName);\n\n for (const packageFile of packageFiles.npm!) {\n if (packageFile.packageFile === fileName) {\n logger.trace({ packageFile }, 'Found packageFile');\n return packageFile;\n }\n logger.trace('No match');\n }\n return {};\n }\n\n // TODO #22198\n for (const p of config.updatedPackageFiles!) {\n logger.trace(`Checking ${String(p.path)} for lock files`);\n const packageFile = getPackageFile(p.path);\n /* v8 ignore next 3 -- needs test */\n if (!packageFile.managerData) {\n continue;\n }\n // push full lock file names and convert them later\n yarnLockDirs.push(packageFile.managerData.yarnLock);\n npmLockDirs.push(packageFile.managerData.npmLock);\n pnpmShrinkwrapDirs.push(packageFile.managerData.pnpmShrinkwrap);\n }\n\n return {\n yarnLockDirs: getDirs(yarnLockDirs),\n npmLockDirs: getDirs(npmLockDirs),\n pnpmShrinkwrapDirs: getDirs(pnpmShrinkwrapDirs),\n };\n}\n\nexport async function writeExistingFiles(\n config: PostUpdateConfig,\n packageFiles: AdditionalPackageFiles,\n): Promise<void> {\n if (!packageFiles.npm) {\n return;\n }\n const npmFiles = packageFiles.npm;\n logger.debug(\n { packageFiles: npmFiles.map((n) => n.packageFile) },\n 'Writing package.json files',\n );\n for (const packageFile of npmFiles) {\n /* v8 ignore next 3 -- needs test */\n if (!packageFile.managerData) {\n continue;\n }\n // TODO #22198\n const basedir = upath.dirname(packageFile.packageFile!);\n const npmrc = packageFile.npmrc;\n const npmrcFilename = upath.join(basedir, '.npmrc');\n // Write out the file unless the npmrc came from the workspace\n // npmrcFilename will be set whenever the file was read from disk during extract\n if (\n isString(npmrc) &&\n (npmrcFilename === packageFile.managerData.npmrcFileName ||\n !packageFile.managerData.npmrcFileName)\n ) {\n try {\n await writeLocalFile(npmrcFilename, npmrc.replace(/\\n?$/, '\\n'));\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ npmrcFilename, err }, 'Error writing .npmrc');\n }\n }\n const npmLock = packageFile.managerData.npmLock;\n if (npmLock) {\n const npmLockPath = npmLock;\n logger.debug(`Writing ${npmLock}`);\n let existingNpmLock: string;\n try {\n existingNpmLock = (await getFile(npmLock)) ?? '';\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ err }, 'Error reading npm lock file');\n existingNpmLock = '';\n }\n const { detectedIndent, lockFileParsed: npmLockParsed } =\n parseLockFile(existingNpmLock);\n if (npmLockParsed) {\n const packageNames =\n 'packages' in npmLockParsed\n ? Object.keys(npmLockParsed.packages)\n : [];\n const widens: string[] = [];\n let lockFileChanged = false;\n for (const upgrade of config.upgrades) {\n if (upgrade.lockFiles && !upgrade.lockFiles.includes(npmLock)) {\n continue;\n }\n if (!upgrade.managerData) {\n continue;\n }\n if (\n upgrade.rangeStrategy === 'widen' &&\n upgrade.managerData.npmLock === npmLock\n ) {\n // TODO #22198\n widens.push(upgrade.depName!);\n }\n const { depName } = upgrade;\n for (const packageName of packageNames) {\n if (\n 'packages' in npmLockParsed &&\n (packageName === `node_modules/${depName}` ||\n packageName.startsWith(`node_modules/${depName}/`))\n ) {\n logger.trace({ packageName }, 'Massaging out package name');\n lockFileChanged = true;\n delete npmLockParsed.packages[packageName];\n }\n }\n }\n if (widens.length) {\n logger.debug(\n `Removing ${String(widens)} from ${npmLock} to force an update`,\n );\n lockFileChanged = true;\n try {\n if ('dependencies' in npmLockParsed && npmLockParsed.dependencies) {\n widens.forEach((depName) => {\n // TODO #22198\n delete npmLockParsed.dependencies![depName];\n });\n }\n /* v8 ignore next -- needs test */\n } catch {\n logger.warn(\n { npmLock },\n 'Error massaging package-lock.json for widen',\n );\n }\n }\n if (lockFileChanged) {\n logger.debug('Massaging npm lock file before writing to disk');\n existingNpmLock = composeLockFile(npmLockParsed, detectedIndent);\n }\n await writeLocalFile(npmLockPath, existingNpmLock);\n }\n }\n }\n}\n\nexport async function writeUpdatedPackageFiles(\n config: PostUpdateConfig,\n): Promise<void> {\n logger.trace({ config }, 'writeUpdatedPackageFiles');\n logger.debug('Writing any updated package files');\n if (!config.updatedPackageFiles) {\n logger.debug('No files found');\n return;\n }\n const supportedLockFiles = ['package-lock.json', 'yarn.lock'];\n for (const packageFile of config.updatedPackageFiles) {\n if (packageFile.type !== 'addition') {\n continue;\n }\n if (\n supportedLockFiles.some((fileName) => packageFile.path.endsWith(fileName))\n ) {\n logger.debug(`Writing lock file: ${packageFile.path}`);\n // TODO #22198\n\n await writeLocalFile(packageFile.path, packageFile.contents!);\n continue;\n }\n if (\n !(\n packageFile.path.endsWith('package.json') ||\n packageFile.path.endsWith('pnpm-workspace.yaml') ||\n packageFile.path.endsWith('.yarnrc.yml')\n )\n ) {\n continue;\n }\n logger.debug(`Writing ${packageFile.path}`);\n await writeLocalFile(packageFile.path, packageFile.contents!);\n }\n}\n\n/* v8 ignore next -- needs test */\nasync function updateYarnOffline(\n lockFileDir: string,\n updatedArtifacts: FileChange[],\n): Promise<void> {\n try {\n const resolvedPaths: string[] = [];\n const yarnrcYml = await getFile(upath.join(lockFileDir, '.yarnrc.yml'));\n const yarnrc = await getFile(upath.join(lockFileDir, '.yarnrc'));\n\n // As .yarnrc.yml overrides .yarnrc in Yarn 1 (https://git.io/JUcco)\n // both files may exist, so check for .yarnrc.yml first\n if (yarnrcYml) {\n // Yarn 2 (offline cache and zero-installs)\n const paths = getZeroInstallPaths(yarnrcYml);\n resolvedPaths.push(...paths.map((p) => upath.join(lockFileDir, p)));\n } else if (yarnrc) {\n // Yarn 1 (offline mirror)\n const mirrorLine = yarnrc\n .split(newlineRegex)\n .find((line) => line.startsWith('yarn-offline-mirror '));\n if (mirrorLine) {\n const mirrorPath = ensureTrailingSlash(\n mirrorLine.split(' ')[1].replace(regEx(/\"/g), ''),\n );\n resolvedPaths.push(upath.join(lockFileDir, mirrorPath));\n }\n }\n logger.debug({ resolvedPaths }, 'updateYarnOffline resolvedPaths');\n\n if (resolvedPaths.length) {\n const status = await getRepoStatus();\n for (const f of status.modified.concat(status.not_added)) {\n if (resolvedPaths.some((p) => f.startsWith(p))) {\n updatedArtifacts.push({\n type: 'addition',\n path: f,\n contents: await readLocalFile(f),\n });\n }\n }\n for (const f of status.deleted || []) {\n if (resolvedPaths.some((p) => f.startsWith(p))) {\n updatedArtifacts.push({ type: 'deletion', path: f });\n }\n }\n }\n } catch (err) {\n logger.error({ err }, 'Error updating yarn offline packages');\n }\n}\n\n// TODO: move to ./yarn.ts\n// exported for testing\nexport async function updateYarnBinary(\n lockFileDir: string,\n updatedArtifacts: FileChange[],\n existingYarnrcYmlContent: string | undefined | null,\n): Promise<string | undefined | null> {\n let yarnrcYml = existingYarnrcYmlContent;\n try {\n const yarnrcYmlFilename = upath.join(lockFileDir, '.yarnrc.yml');\n yarnrcYml ??= (await getFile(yarnrcYmlFilename)) ?? undefined;\n const newYarnrcYml = await readLocalFile(yarnrcYmlFilename, 'utf8');\n if (!isString(yarnrcYml) || !isString(newYarnrcYml)) {\n return existingYarnrcYmlContent;\n }\n\n // TODO: use schema (#9610)\n const oldYarnPath = parseSingleYaml<YarnRcYmlFile>(yarnrcYml)?.yarnPath;\n const newYarnPath = parseSingleYaml<YarnRcYmlFile>(newYarnrcYml)?.yarnPath;\n if (\n !isNonEmptyStringAndNotWhitespace(oldYarnPath) ||\n !isNonEmptyStringAndNotWhitespace(newYarnPath)\n ) {\n return existingYarnrcYmlContent;\n }\n\n const oldYarnFullPath = upath.join(lockFileDir, oldYarnPath);\n const newYarnFullPath = upath.join(lockFileDir, newYarnPath);\n logger.debug({ oldYarnPath, newYarnPath }, 'Found updated Yarn binary');\n\n yarnrcYml = yarnrcYml.replace(oldYarnPath, newYarnPath);\n updatedArtifacts.push(\n {\n type: 'addition',\n path: yarnrcYmlFilename,\n contents: yarnrcYml,\n },\n {\n type: 'deletion',\n path: oldYarnFullPath,\n },\n {\n type: 'addition',\n path: newYarnFullPath,\n contents: await readLocalFile(newYarnFullPath, 'utf8'),\n isExecutable: true,\n },\n );\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.error({ err }, 'Error updating Yarn binary');\n }\n return existingYarnrcYmlContent && yarnrcYml;\n}\n\nexport async function getAdditionalFiles(\n config: PostUpdateConfig<NpmManagerData>,\n packageFiles: AdditionalPackageFiles,\n): Promise<WriteExistingFilesResult> {\n logger.trace({ config }, 'getAdditionalFiles');\n const artifactErrors: ArtifactError[] = [];\n const updatedArtifacts: FileChange[] = [];\n if (!packageFiles.npm?.length) {\n return { artifactErrors, updatedArtifacts };\n }\n if (config.skipArtifactsUpdate) {\n logger.debug('Skipping lock file generation');\n return { artifactErrors, updatedArtifacts };\n }\n logger.debug('Getting updated lock files');\n if (\n config.isLockFileMaintenance &&\n config.reuseExistingBranch &&\n (await scm.branchExists(config.branchName))\n ) {\n logger.debug('Skipping lockFileMaintenance update');\n return { artifactErrors, updatedArtifacts };\n }\n const dirs = determineLockFileDirs(config, packageFiles);\n logger.trace({ dirs }, 'lock file dirs');\n await writeExistingFiles(config, packageFiles);\n await writeUpdatedPackageFiles(config);\n\n const { additionalNpmrcContent, additionalYarnRcYml } = processHostRules();\n\n // This isn't passed directly to the child process, so no need to filter.\n // But pass custom env and user vars.\n const env = {\n ...getEnv(),\n NPM_CONFIG_CACHE: await ensureCacheDir(NPM_CACHE_DIR),\n YARN_CACHE_FOLDER: await ensureCacheDir(YARN_CACHE_DIR),\n YARN_GLOBAL_FOLDER: await ensureCacheDir(YARN_GLOBAL_DIR),\n npm_config_store: await ensureCacheDir(PNPM_CACHE_BASE_DIR),\n NODE_ENV: 'dev',\n };\n\n let token: string | undefined;\n try {\n ({ token } = hostRules.find({\n hostType: 'github',\n url: 'https://api.github.com/',\n }));\n token = token ? /* v8 ignore next */ `${token}@` : token;\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.warn({ err }, 'Error getting token for packageFile');\n }\n const tokenRe = regEx(`${token ?? ''}`, 'g', false);\n for (const npmLock of dirs.npmLockDirs) {\n const lockFileDir = upath.dirname(npmLock);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n const fileName = upath.basename(npmLock);\n logger.debug(`Generating ${fileName} for ${lockFileDir}`);\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.npmLock === npmLock,\n );\n const res = await npm.generateLockFile(\n lockFileDir,\n env,\n fileName,\n config,\n upgrades,\n );\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stderr?.includes('No matching version found for')) {\n for (const upgrade of config.upgrades) {\n if (\n res.stderr.includes(\n `No matching version found for ${upgrade.depName}`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'npm' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n const err = new Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(err, NpmDatasource.id);\n }\n }\n }\n\n artifactErrors.push({\n fileName: npmLock,\n stderr: res.stderr,\n });\n } else if (res.lockFile) {\n const existingContent = await getFile(\n npmLock,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(`${npmLock} hasn't changed`);\n } else {\n logger.debug(`${npmLock} needs updating`);\n updatedArtifacts.push({\n type: 'addition',\n path: npmLock,\n // TODO: can this be undefined? (#22198)\n\n contents: res.lockFile.replace(tokenRe, ''),\n });\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n }\n\n for (const yarnLock of dirs.yarnLockDirs) {\n const lockFileDir = upath.dirname(yarnLock);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n let yarnRcYmlFilename: string | undefined;\n let existingYarnrcYmlContent: string | undefined | null;\n if (additionalYarnRcYml) {\n yarnRcYmlFilename = getSiblingFileName(yarnLock, '.yarnrc.yml');\n existingYarnrcYmlContent = await readLocalFile(yarnRcYmlFilename, 'utf8');\n if (existingYarnrcYmlContent) {\n try {\n // TODO: use schema (#9610)\n const existingYarnrRcYml = parseSingleYaml<Record<string, unknown>>(\n existingYarnrcYmlContent,\n );\n\n const updatedYarnYrcYml = deepmerge(\n existingYarnrRcYml,\n yarn.fuzzyMatchAdditionalYarnrcYml(\n additionalYarnRcYml,\n existingYarnrRcYml,\n ),\n );\n\n await writeLocalFile(yarnRcYmlFilename, dump(updatedYarnYrcYml));\n logger.debug('Added authentication to .yarnrc.yml');\n } catch (err) {\n logger.warn({ err }, 'Error appending .yarnrc.yml content');\n }\n }\n }\n logger.debug(`Generating yarn.lock for ${lockFileDir}`);\n const lockFileName = upath.join(lockFileDir, 'yarn.lock');\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.yarnLock === yarnLock,\n );\n const res = await yarn.generateLockFile(lockFileDir, env, config, upgrades);\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stderr?.includes(`Couldn't find any versions for`)) {\n for (const upgrade of config.upgrades) {\n /* eslint-disable no-useless-escape */\n if (\n res.stderr.includes(\n `Couldn't find any versions for \\\\\\\"${upgrade.depName}\\\\\\\"`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'yarn' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(\n new Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n ),\n NpmDatasource.id,\n );\n }\n /* eslint-enable no-useless-escape */\n }\n }\n\n artifactErrors.push({\n fileName: yarnLock,\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing\n stderr: res.stderr || res.stdout,\n });\n } else {\n const existingContent = await getFile(\n lockFileName,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(\"yarn.lock hasn't changed\");\n } else {\n logger.debug('yarn.lock needs updating');\n updatedArtifacts.push({\n type: 'addition',\n path: lockFileName,\n // TODO #22198\n contents: res.lockFile!,\n });\n await updateYarnOffline(lockFileDir, updatedArtifacts);\n }\n\n /* v8 ignore next 7 -- needs test */\n if (upgrades.some(yarn.isYarnUpdate)) {\n existingYarnrcYmlContent = await updateYarnBinary(\n lockFileDir,\n updatedArtifacts,\n existingYarnrcYmlContent,\n );\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n /* v8 ignore next 4 -- needs test */\n if (existingYarnrcYmlContent) {\n // TODO #22198\n await writeLocalFile(yarnRcYmlFilename!, existingYarnrcYmlContent);\n }\n }\n\n for (const pnpmShrinkwrap of dirs.pnpmShrinkwrapDirs) {\n const lockFileDir = upath.dirname(pnpmShrinkwrap);\n const npmrcContent = await getNpmrcContent(lockFileDir);\n await updateNpmrcContent(lockFileDir, npmrcContent, additionalNpmrcContent);\n logger.debug(`Generating pnpm-lock.yaml for ${lockFileDir}`);\n const upgrades = config.upgrades.filter(\n (upgrade) => upgrade.managerData?.pnpmShrinkwrap === pnpmShrinkwrap,\n );\n const res = await pnpm.generateLockFile(lockFileDir, env, config, upgrades);\n if (res.error) {\n /* v8 ignore next -- needs test */\n if (res.stdout?.includes(`No compatible version found:`)) {\n for (const upgrade of config.upgrades) {\n if (\n res.stdout.includes(\n `No compatible version found: ${upgrade.depName}`,\n )\n ) {\n logger.debug(\n { dependency: upgrade.depName, type: 'pnpm' },\n 'lock file failed for the dependency being updated - skipping branch creation',\n );\n throw new ExternalHostError(\n Error(\n 'lock file failed for the dependency being updated - skipping branch creation',\n ),\n NpmDatasource.id,\n );\n }\n }\n }\n\n artifactErrors.push({\n fileName: pnpmShrinkwrap,\n // oxlint-disable-next-line typescript/prefer-nullish-coalescing\n stderr: res.stderr || res.stdout,\n });\n } else {\n const existingContent = await getFile(\n pnpmShrinkwrap,\n config.reuseExistingBranch ? config.branchName : config.baseBranch,\n );\n if (res.lockFile === existingContent) {\n logger.debug(\"pnpm-lock.yaml hasn't changed\");\n } else {\n logger.debug('pnpm-lock.yaml needs updating');\n updatedArtifacts.push({\n type: 'addition',\n path: pnpmShrinkwrap,\n // TODO: can be undefined? (#22198)\n contents: res.lockFile!,\n });\n }\n }\n await resetNpmrcContent(lockFileDir, npmrcContent);\n }\n\n return { artifactErrors, updatedArtifacts };\n}\n"],"mappings":"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"}
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
import { SYSTEM_INSUFFICIENT_DISK_SPACE } from "../../../../constants/error-messages.js";
|
|
2
|
-
import { regEx } from "../../../../util/regex.js";
|
|
3
2
|
import { GlobalConfig } from "../../../../config/global.js";
|
|
4
3
|
import { minimatch } from "../../../../util/minimatch.js";
|
|
5
4
|
import { logger } from "../../../../logger/index.js";
|
|
6
|
-
import { toMs } from "../../../../util/pretty-time.js";
|
|
7
5
|
import { trimSlashes } from "../../../../util/url.js";
|
|
8
6
|
import { deleteLocalFile, localPathExists, readLocalFile, renameLocalFile } from "../../../../util/fs/index.js";
|
|
9
7
|
import { Result } from "../../../../util/result.js";
|
|
@@ -13,24 +11,10 @@ import { PackageLock } from "../schema.js";
|
|
|
13
11
|
import { composeLockFile, parseLockFile } from "../utils.js";
|
|
14
12
|
import { getNodeOptions, getPackageManagerVersion, lazyLoadPackageJson } from "./utils.js";
|
|
15
13
|
import { isNonEmptyString, isString } from "@sindresorhus/is";
|
|
16
|
-
import { DateTime } from "luxon";
|
|
17
14
|
import { quote } from "shlex";
|
|
18
15
|
import upath from "upath";
|
|
19
16
|
import semver from "semver";
|
|
20
17
|
//#region lib/modules/manager/npm/post-update/npm.ts
|
|
21
|
-
const npmrcBeforeRegex = regEx(/^\s*before\s*=\s*"?(\d{4}-\d{2}-\d{2}(?:T[\d:.]+Z?)?)"?(?:\s+[;#].*)?\s*$/m);
|
|
22
|
-
const npmrcMinReleaseAgeRegex = regEx(/^\s*min-release-age\s*=\s*"?(\d+)"?(?:\s+[;#].*)?\s*$/m);
|
|
23
|
-
function parseNpmrcCooldownDate(npmrcContent) {
|
|
24
|
-
const dateStr = npmrcContent?.match(npmrcBeforeRegex)?.[1];
|
|
25
|
-
if (dateStr) {
|
|
26
|
-
const parsed = DateTime.fromISO(dateStr, { zone: "utc" });
|
|
27
|
-
if (parsed.isValid) return parsed;
|
|
28
|
-
logger.debug(`Invalid before date in .npmrc: ${dateStr}, ignoring`);
|
|
29
|
-
}
|
|
30
|
-
const daysStr = npmrcContent?.match(npmrcMinReleaseAgeRegex)?.[1];
|
|
31
|
-
if (daysStr) return DateTime.now().minus({ days: parseInt(daysStr, 10) }).toUTC();
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
18
|
async function getNpmConstraintFromPackageLock(lockFileDir, filename) {
|
|
35
19
|
const packageLockFileName = upath.join(lockFileDir, filename);
|
|
36
20
|
const packageLockContents = await readLocalFile(packageLockFileName, "utf8");
|
|
@@ -50,7 +34,7 @@ async function getNpmConstraintFromPackageLock(lockFileDir, filename) {
|
|
|
50
34
|
}
|
|
51
35
|
return null;
|
|
52
36
|
}
|
|
53
|
-
async function generateLockFile(lockFileDir, env, filename, config = {}, upgrades = []
|
|
37
|
+
async function generateLockFile(lockFileDir, env, filename, config = {}, upgrades = []) {
|
|
54
38
|
const lockFileName = upath.join(lockFileDir, filename);
|
|
55
39
|
logger.debug(`Spawning npm install to create ${lockFileDir}/${filename}`);
|
|
56
40
|
const { skipInstalls, postUpdateOptions } = config;
|
|
@@ -76,27 +60,6 @@ async function generateLockFile(lockFileDir, env, filename, config = {}, upgrade
|
|
|
76
60
|
cmdOptions += " --prefer-dedupe";
|
|
77
61
|
}
|
|
78
62
|
if (!GlobalConfig.get("allowScripts") || config.ignoreScripts) cmdOptions += " --ignore-scripts";
|
|
79
|
-
if (config.minimumReleaseAge) {
|
|
80
|
-
const ms = toMs(config.minimumReleaseAge);
|
|
81
|
-
if (ms === null) logger.debug({ minimumReleaseAge: config.minimumReleaseAge }, "Invalid minimumReleaseAge, skipping --before for npm install");
|
|
82
|
-
else {
|
|
83
|
-
let beforeDate = DateTime.now().minus(ms).toUTC();
|
|
84
|
-
const npmrcDate = parseNpmrcCooldownDate(npmrcContent);
|
|
85
|
-
if (npmrcDate && npmrcDate < beforeDate) {
|
|
86
|
-
logger.debug({
|
|
87
|
-
npmrcDate: npmrcDate.toISO(),
|
|
88
|
-
beforeDate: beforeDate.toISO()
|
|
89
|
-
}, "Using stricter .npmrc cooldown date over minimumReleaseAge date");
|
|
90
|
-
beforeDate = npmrcDate;
|
|
91
|
-
}
|
|
92
|
-
const beforeISO = beforeDate.toISO();
|
|
93
|
-
logger.debug({
|
|
94
|
-
beforeISO,
|
|
95
|
-
minimumReleaseAge: config.minimumReleaseAge
|
|
96
|
-
}, "Setting npm --before based on minimumReleaseAge");
|
|
97
|
-
cmdOptions += ` --before=${beforeISO}`;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
63
|
const extraEnv = {
|
|
101
64
|
NPM_CONFIG_CACHE: env.NPM_CONFIG_CACHE,
|
|
102
65
|
npm_config_store: env.npm_config_store
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"npm.js","names":[],"sources":["../../../../../lib/modules/manager/npm/post-update/npm.ts"],"sourcesContent":["// TODO: types (#22198)\nimport { isNonEmptyString, isString } from '@sindresorhus/is';\nimport { DateTime } from 'luxon';\nimport semver from 'semver';\nimport { quote } from 'shlex';\nimport upath from 'upath';\nimport { GlobalConfig } from '../../../../config/global.ts';\nimport {\n SYSTEM_INSUFFICIENT_DISK_SPACE,\n TEMPORARY_ERROR,\n} from '../../../../constants/error-messages.ts';\nimport { logger } from '../../../../logger/index.ts';\nimport { exec, getToolSettingsOptions } from '../../../../util/exec/index.ts';\nimport type {\n ExecOptions,\n ExtraEnv,\n ToolConstraint,\n} from '../../../../util/exec/types.ts';\nimport {\n deleteLocalFile,\n localPathExists,\n readLocalFile,\n renameLocalFile,\n} from '../../../../util/fs/index.ts';\nimport { minimatch } from '../../../../util/minimatch.ts';\nimport { toMs } from '../../../../util/pretty-time.ts';\nimport { regEx } from '../../../../util/regex.ts';\nimport { Result } from '../../../../util/result.ts';\nimport { trimSlashes } from '../../../../util/url.ts';\nimport type { PostUpdateConfig, Upgrade } from '../../types.ts';\nimport { PackageLock } from '../schema.ts';\nimport { composeLockFile, parseLockFile } from '../utils.ts';\nimport { getNodeToolConstraint } from './node-version.ts';\nimport type { GenerateLockFileResult } from './types.ts';\nimport {\n getNodeOptions,\n getPackageManagerVersion,\n lazyLoadPackageJson,\n} from './utils.ts';\n\nconst npmrcBeforeRegex = regEx(\n /^\\s*before\\s*=\\s*\"?(\\d{4}-\\d{2}-\\d{2}(?:T[\\d:.]+Z?)?)\"?(?:\\s+[;#].*)?\\s*$/m,\n);\nconst npmrcMinReleaseAgeRegex = regEx(\n /^\\s*min-release-age\\s*=\\s*\"?(\\d+)\"?(?:\\s+[;#].*)?\\s*$/m,\n);\n\nexport function parseNpmrcCooldownDate(\n npmrcContent: string | null,\n): DateTime<true> | null {\n const dateStr = npmrcContent?.match(npmrcBeforeRegex)?.[1];\n if (dateStr) {\n const parsed = DateTime.fromISO(dateStr, { zone: 'utc' });\n if (parsed.isValid) {\n return parsed;\n }\n logger.debug(`Invalid before date in .npmrc: ${dateStr}, ignoring`);\n }\n\n const daysStr = npmrcContent?.match(npmrcMinReleaseAgeRegex)?.[1];\n if (daysStr) {\n return DateTime.now()\n .minus({ days: parseInt(daysStr, 10) })\n .toUTC();\n }\n\n return null;\n}\n\nasync function getNpmConstraintFromPackageLock(\n lockFileDir: string,\n filename: string,\n): Promise<string | null> {\n const packageLockFileName = upath.join(lockFileDir, filename);\n const packageLockContents = await readLocalFile(packageLockFileName, 'utf8');\n const packageLockJson = Result.parse(\n packageLockContents,\n PackageLock,\n ).unwrapOrNull();\n if (!packageLockJson) {\n logger.debug(`Could not parse ${packageLockFileName}`);\n return null;\n }\n const { lockfileVersion } = packageLockJson;\n if (lockfileVersion === 1) {\n logger.debug(`Using npm constraint <7 for lockfileVersion=1`);\n return `<7`;\n }\n if (lockfileVersion === 2) {\n logger.debug(`Using npm constraint <9 for lockfileVersion=2`);\n return `<9`;\n }\n return null;\n}\n\nexport async function generateLockFile(\n lockFileDir: string,\n env: NodeJS.ProcessEnv,\n filename: string,\n config: Partial<PostUpdateConfig> = {},\n upgrades: Upgrade[] = [],\n npmrcContent: string | null = null,\n): Promise<GenerateLockFileResult> {\n // TODO: don't assume package-lock.json is in the same directory\n const lockFileName = upath.join(lockFileDir, filename);\n\n logger.debug(`Spawning npm install to create ${lockFileDir}/${filename}`);\n const { skipInstalls, postUpdateOptions } = config;\n\n let lockFile: string | null = null;\n try {\n const lazyPkgJson = lazyLoadPackageJson(lockFileDir);\n const npmToolConstraint: ToolConstraint = {\n toolName: 'npm',\n constraint:\n config.constraints?.npm ??\n getPackageManagerVersion('npm', await lazyPkgJson.getValue()) ??\n (await getNpmConstraintFromPackageLock(lockFileDir, filename)) ??\n null,\n };\n const supportsPreferDedupeFlag =\n !npmToolConstraint.constraint ||\n semver.intersects('>=7.0.0', npmToolConstraint.constraint);\n let commands: string[] = [];\n let cmdOptions = '';\n if (\n (postUpdateOptions?.includes('npmDedupe') === true &&\n !supportsPreferDedupeFlag) ||\n skipInstalls === false\n ) {\n logger.debug('Performing node_modules install');\n cmdOptions += '--no-audit';\n } else {\n logger.debug('Updating lock file only');\n cmdOptions += '--package-lock-only --no-audit';\n }\n\n if (postUpdateOptions?.includes('npmDedupe') && supportsPreferDedupeFlag) {\n logger.debug('Deduplicate dependencies on installation');\n cmdOptions += ' --prefer-dedupe';\n }\n\n if (!GlobalConfig.get('allowScripts') || config.ignoreScripts) {\n cmdOptions += ' --ignore-scripts';\n }\n\n if (config.minimumReleaseAge) {\n const ms = toMs(config.minimumReleaseAge);\n if (ms === null) {\n logger.debug(\n {\n minimumReleaseAge: config.minimumReleaseAge,\n },\n 'Invalid minimumReleaseAge, skipping --before for npm install',\n );\n } else {\n let beforeDate = DateTime.now().minus(ms).toUTC();\n\n const npmrcDate = parseNpmrcCooldownDate(npmrcContent);\n if (npmrcDate && npmrcDate < beforeDate) {\n logger.debug(\n {\n npmrcDate: npmrcDate.toISO(),\n beforeDate: beforeDate.toISO(),\n },\n 'Using stricter .npmrc cooldown date over minimumReleaseAge date',\n );\n beforeDate = npmrcDate;\n }\n\n const beforeISO = beforeDate.toISO();\n logger.debug(\n {\n beforeISO,\n minimumReleaseAge: config.minimumReleaseAge,\n },\n 'Setting npm --before based on minimumReleaseAge',\n );\n cmdOptions += ` --before=${beforeISO}`;\n }\n }\n\n const extraEnv: ExtraEnv = {\n NPM_CONFIG_CACHE: env.NPM_CONFIG_CACHE,\n npm_config_store: env.npm_config_store,\n };\n\n const { nodeMaxMemory } = getToolSettingsOptions(config.toolSettings);\n if (nodeMaxMemory) {\n extraEnv.NODE_OPTIONS = getNodeOptions(nodeMaxMemory);\n }\n\n const execOptions: ExecOptions = {\n cwdFile: lockFileName,\n extraEnv,\n toolConstraints: [\n await getNodeToolConstraint(config, upgrades, lockFileDir, lazyPkgJson),\n ...(isNonEmptyString(npmToolConstraint.constraint)\n ? [npmToolConstraint]\n : []),\n ],\n docker: {},\n };\n /* v8 ignore next 4 -- needs test */\n if (GlobalConfig.get('exposeAllEnv')) {\n extraEnv.NPM_AUTH = env.NPM_AUTH;\n extraEnv.NPM_EMAIL = env.NPM_EMAIL;\n }\n\n if (!upgrades.every((upgrade) => upgrade.isLockfileUpdate)) {\n // This command updates the lock file based on package.json\n commands.push(`npm install ${cmdOptions}`.trim());\n }\n\n // rangeStrategy = update-lockfile\n const lockUpdates = upgrades.filter((upgrade) => upgrade.isLockfileUpdate);\n\n // divide the deps in two categories: workspace and root\n const { lockRootUpdates, lockWorkspacesUpdates, workspaces, rootDeps } =\n divideWorkspaceAndRootDeps(lockFileDir, lockUpdates);\n\n if (workspaces.size && lockWorkspacesUpdates.length) {\n logger.debug('Performing lockfileUpdate (npm-workspaces)');\n for (const workspace of workspaces) {\n const currentWorkspaceUpdates = lockWorkspacesUpdates\n .filter((update) => update.workspace === workspace)\n .map((update) => update.managerData?.packageKey)\n .filter((packageKey) => !rootDeps.has(packageKey));\n\n if (currentWorkspaceUpdates.length) {\n const updateCmd = `npm install ${cmdOptions} --workspace=${quote(workspace)} ${currentWorkspaceUpdates\n .map(quote)\n .join(' ')}`;\n commands.push(updateCmd);\n }\n }\n }\n\n if (lockRootUpdates.length) {\n logger.debug('Performing lockfileUpdate (npm)');\n const updateCmd = `npm install ${cmdOptions} ${lockRootUpdates\n .map((update) => update.managerData?.packageKey)\n .map(quote)\n .join(' ')}`;\n commands.push(updateCmd);\n }\n\n if (upgrades.some((upgrade) => upgrade.isRemediation)) {\n // We need to run twice to get the correct lock file\n commands.push(`npm install ${cmdOptions}`.trim());\n }\n\n // postUpdateOptions\n if (\n config.postUpdateOptions?.includes('npmDedupe') &&\n !supportsPreferDedupeFlag\n ) {\n logger.debug('Performing npm dedupe after installation');\n commands.push('npm dedupe');\n }\n\n if (upgrades.find((upgrade) => upgrade.isLockFileMaintenance)) {\n logger.debug(\n `Removing ${lockFileName} first due to lock file maintenance upgrade`,\n );\n try {\n await deleteLocalFile(lockFileName);\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.debug(\n { err, lockFileName },\n 'Error removing `package-lock.json` for lock file maintenance',\n );\n }\n }\n\n if (postUpdateOptions?.includes('npmInstallTwice')) {\n logger.debug('Running npm install twice');\n // Run the install command twice to ensure the lock file is up to date\n // iterate through commands and if any command starts with `npm install`, add it again\n const existingCommands = [...commands];\n commands = [];\n for (const command of existingCommands) {\n commands.push(command);\n if (command.startsWith('npm install')) {\n commands.push(command);\n }\n }\n }\n\n // Run the commands\n await exec(commands, execOptions);\n\n // massage to shrinkwrap if necessary\n if (\n filename === 'npm-shrinkwrap.json' &&\n (await localPathExists(upath.join(lockFileDir, 'package-lock.json')))\n ) {\n await renameLocalFile(\n upath.join(lockFileDir, 'package-lock.json'),\n upath.join(lockFileDir, 'npm-shrinkwrap.json'),\n );\n }\n\n // Read the result\n // TODO #22198\n lockFile = (await readLocalFile(\n upath.join(lockFileDir, filename),\n 'utf8',\n ))!;\n\n // Massage lockfile counterparts of package.json that were modified\n // because npm install was called with an explicit version for rangeStrategy=update-lockfile\n if (lockUpdates.length) {\n const { detectedIndent, lockFileParsed } = parseLockFile(lockFile);\n if (\n lockFileParsed?.lockfileVersion === 2 ||\n lockFileParsed?.lockfileVersion === 3\n ) {\n lockUpdates.forEach((lockUpdate) => {\n const depType = lockUpdate.depType as\n | 'dependencies'\n | 'optionalDependencies';\n\n // TODO #22198\n if (\n lockFileParsed.packages?.['']?.[depType]?.[lockUpdate.packageName!]\n ) {\n lockFileParsed.packages[''][depType][lockUpdate.packageName!] =\n lockUpdate.newValue!;\n }\n });\n lockFile = composeLockFile(lockFileParsed, detectedIndent);\n }\n }\n /* v8 ignore next -- needs test */\n } catch (err) {\n if (err.message === TEMPORARY_ERROR) {\n throw err;\n }\n logger.debug(\n {\n err,\n type: 'npm',\n },\n 'lock file error',\n );\n if (err.stderr?.includes('ENOSPC: no space left on device')) {\n throw new Error(SYSTEM_INSUFFICIENT_DISK_SPACE);\n }\n return { error: true, stderr: err.stderr };\n }\n return { error: !lockFile, lockFile };\n}\n\nexport function divideWorkspaceAndRootDeps(\n lockFileDir: string,\n lockUpdates: Upgrade[],\n): {\n lockRootUpdates: Upgrade[];\n lockWorkspacesUpdates: Upgrade[];\n workspaces: Set<string>;\n rootDeps: Set<string>;\n} {\n const lockRootUpdates: Upgrade[] = []; // stores all upgrades which are present in root package.json\n const lockWorkspacesUpdates: Upgrade[] = []; // stores all upgrades which are present in workspaces package.json\n const workspaces = new Set<string>(); // name of all workspaces\n const rootDeps = new Set<string>(); // packageName of all upgrades in root package.json (makes it check duplicate deps in root)\n\n // divide the deps in two categories: workspace and root\n for (const upgrade of lockUpdates) {\n upgrade.managerData ??= {};\n upgrade.managerData.packageKey = generatePackageKey(\n upgrade.packageName!,\n upgrade.newVersion!,\n );\n if (\n upgrade.managerData.workspacesPackages?.length &&\n isString(upgrade.packageFile)\n ) {\n const workspacePatterns = upgrade.managerData.workspacesPackages; // glob pattern or directory name/path\n const packageFileDir = trimSlashes(\n upgrade.packageFile.replace('package.json', ''),\n );\n\n // workspaceDir = packageFileDir - lockFileDir\n const workspaceDir = trimSlashes(\n packageFileDir.startsWith(lockFileDir)\n ? packageFileDir.slice(lockFileDir.length)\n : packageFileDir,\n );\n\n if (isNonEmptyString(workspaceDir)) {\n let workspaceName: string | undefined;\n // compare workspaceDir to workspace patterns\n // stop when the first match is found and\n // add workspaceDir to workspaces set and upgrade object\n for (const workspacePattern of workspacePatterns) {\n const massagedPattern = (workspacePattern as string).replace(\n /^\\.\\//,\n '',\n );\n if (minimatch(massagedPattern).match(workspaceDir)) {\n workspaceName = workspaceDir;\n break;\n }\n }\n if (workspaceName) {\n if (\n !rootDeps.has(upgrade.managerData.packageKey) // prevent same dep from existing in root and workspace\n ) {\n workspaces.add(workspaceName);\n upgrade.workspace = workspaceName;\n lockWorkspacesUpdates.push(upgrade);\n }\n } else {\n logger.warn(\n { workspacePatterns, workspaceDir },\n 'workspaceDir not found',\n );\n }\n continue;\n }\n }\n lockRootUpdates.push(upgrade);\n rootDeps.add(upgrade.managerData.packageKey);\n }\n\n return { lockRootUpdates, lockWorkspacesUpdates, workspaces, rootDeps };\n}\n\nfunction generatePackageKey(packageName: string, version: string): string {\n return `${packageName}@${version}`;\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"npm.js","names":[],"sources":["../../../../../lib/modules/manager/npm/post-update/npm.ts"],"sourcesContent":["// TODO: types (#22198)\nimport { isNonEmptyString, isString } from '@sindresorhus/is';\nimport semver from 'semver';\nimport { quote } from 'shlex';\nimport upath from 'upath';\nimport { GlobalConfig } from '../../../../config/global.ts';\nimport {\n SYSTEM_INSUFFICIENT_DISK_SPACE,\n TEMPORARY_ERROR,\n} from '../../../../constants/error-messages.ts';\nimport { logger } from '../../../../logger/index.ts';\nimport { exec, getToolSettingsOptions } from '../../../../util/exec/index.ts';\nimport type {\n ExecOptions,\n ExtraEnv,\n ToolConstraint,\n} from '../../../../util/exec/types.ts';\nimport {\n deleteLocalFile,\n localPathExists,\n readLocalFile,\n renameLocalFile,\n} from '../../../../util/fs/index.ts';\nimport { minimatch } from '../../../../util/minimatch.ts';\nimport { Result } from '../../../../util/result.ts';\nimport { trimSlashes } from '../../../../util/url.ts';\nimport type { PostUpdateConfig, Upgrade } from '../../types.ts';\nimport { PackageLock } from '../schema.ts';\nimport { composeLockFile, parseLockFile } from '../utils.ts';\nimport { getNodeToolConstraint } from './node-version.ts';\nimport type { GenerateLockFileResult } from './types.ts';\nimport {\n getNodeOptions,\n getPackageManagerVersion,\n lazyLoadPackageJson,\n} from './utils.ts';\n\nasync function getNpmConstraintFromPackageLock(\n lockFileDir: string,\n filename: string,\n): Promise<string | null> {\n const packageLockFileName = upath.join(lockFileDir, filename);\n const packageLockContents = await readLocalFile(packageLockFileName, 'utf8');\n const packageLockJson = Result.parse(\n packageLockContents,\n PackageLock,\n ).unwrapOrNull();\n if (!packageLockJson) {\n logger.debug(`Could not parse ${packageLockFileName}`);\n return null;\n }\n const { lockfileVersion } = packageLockJson;\n if (lockfileVersion === 1) {\n logger.debug(`Using npm constraint <7 for lockfileVersion=1`);\n return `<7`;\n }\n if (lockfileVersion === 2) {\n logger.debug(`Using npm constraint <9 for lockfileVersion=2`);\n return `<9`;\n }\n return null;\n}\n\nexport async function generateLockFile(\n lockFileDir: string,\n env: NodeJS.ProcessEnv,\n filename: string,\n config: Partial<PostUpdateConfig> = {},\n upgrades: Upgrade[] = [],\n): Promise<GenerateLockFileResult> {\n // TODO: don't assume package-lock.json is in the same directory\n const lockFileName = upath.join(lockFileDir, filename);\n\n logger.debug(`Spawning npm install to create ${lockFileDir}/${filename}`);\n const { skipInstalls, postUpdateOptions } = config;\n\n let lockFile: string | null = null;\n try {\n const lazyPkgJson = lazyLoadPackageJson(lockFileDir);\n const npmToolConstraint: ToolConstraint = {\n toolName: 'npm',\n constraint:\n config.constraints?.npm ??\n getPackageManagerVersion('npm', await lazyPkgJson.getValue()) ??\n (await getNpmConstraintFromPackageLock(lockFileDir, filename)) ??\n null,\n };\n const supportsPreferDedupeFlag =\n !npmToolConstraint.constraint ||\n semver.intersects('>=7.0.0', npmToolConstraint.constraint);\n let commands: string[] = [];\n let cmdOptions = '';\n if (\n (postUpdateOptions?.includes('npmDedupe') === true &&\n !supportsPreferDedupeFlag) ||\n skipInstalls === false\n ) {\n logger.debug('Performing node_modules install');\n cmdOptions += '--no-audit';\n } else {\n logger.debug('Updating lock file only');\n cmdOptions += '--package-lock-only --no-audit';\n }\n\n if (postUpdateOptions?.includes('npmDedupe') && supportsPreferDedupeFlag) {\n logger.debug('Deduplicate dependencies on installation');\n cmdOptions += ' --prefer-dedupe';\n }\n\n if (!GlobalConfig.get('allowScripts') || config.ignoreScripts) {\n cmdOptions += ' --ignore-scripts';\n }\n\n const extraEnv: ExtraEnv = {\n NPM_CONFIG_CACHE: env.NPM_CONFIG_CACHE,\n npm_config_store: env.npm_config_store,\n };\n\n const { nodeMaxMemory } = getToolSettingsOptions(config.toolSettings);\n if (nodeMaxMemory) {\n extraEnv.NODE_OPTIONS = getNodeOptions(nodeMaxMemory);\n }\n\n const execOptions: ExecOptions = {\n cwdFile: lockFileName,\n extraEnv,\n toolConstraints: [\n await getNodeToolConstraint(config, upgrades, lockFileDir, lazyPkgJson),\n ...(isNonEmptyString(npmToolConstraint.constraint)\n ? [npmToolConstraint]\n : []),\n ],\n docker: {},\n };\n /* v8 ignore next 4 -- needs test */\n if (GlobalConfig.get('exposeAllEnv')) {\n extraEnv.NPM_AUTH = env.NPM_AUTH;\n extraEnv.NPM_EMAIL = env.NPM_EMAIL;\n }\n\n if (!upgrades.every((upgrade) => upgrade.isLockfileUpdate)) {\n // This command updates the lock file based on package.json\n commands.push(`npm install ${cmdOptions}`.trim());\n }\n\n // rangeStrategy = update-lockfile\n const lockUpdates = upgrades.filter((upgrade) => upgrade.isLockfileUpdate);\n\n // divide the deps in two categories: workspace and root\n const { lockRootUpdates, lockWorkspacesUpdates, workspaces, rootDeps } =\n divideWorkspaceAndRootDeps(lockFileDir, lockUpdates);\n\n if (workspaces.size && lockWorkspacesUpdates.length) {\n logger.debug('Performing lockfileUpdate (npm-workspaces)');\n for (const workspace of workspaces) {\n const currentWorkspaceUpdates = lockWorkspacesUpdates\n .filter((update) => update.workspace === workspace)\n .map((update) => update.managerData?.packageKey)\n .filter((packageKey) => !rootDeps.has(packageKey));\n\n if (currentWorkspaceUpdates.length) {\n const updateCmd = `npm install ${cmdOptions} --workspace=${quote(workspace)} ${currentWorkspaceUpdates\n .map(quote)\n .join(' ')}`;\n commands.push(updateCmd);\n }\n }\n }\n\n if (lockRootUpdates.length) {\n logger.debug('Performing lockfileUpdate (npm)');\n const updateCmd = `npm install ${cmdOptions} ${lockRootUpdates\n .map((update) => update.managerData?.packageKey)\n .map(quote)\n .join(' ')}`;\n commands.push(updateCmd);\n }\n\n if (upgrades.some((upgrade) => upgrade.isRemediation)) {\n // We need to run twice to get the correct lock file\n commands.push(`npm install ${cmdOptions}`.trim());\n }\n\n // postUpdateOptions\n if (\n config.postUpdateOptions?.includes('npmDedupe') &&\n !supportsPreferDedupeFlag\n ) {\n logger.debug('Performing npm dedupe after installation');\n commands.push('npm dedupe');\n }\n\n if (upgrades.find((upgrade) => upgrade.isLockFileMaintenance)) {\n logger.debug(\n `Removing ${lockFileName} first due to lock file maintenance upgrade`,\n );\n try {\n await deleteLocalFile(lockFileName);\n /* v8 ignore next -- needs test */\n } catch (err) {\n logger.debug(\n { err, lockFileName },\n 'Error removing `package-lock.json` for lock file maintenance',\n );\n }\n }\n\n if (postUpdateOptions?.includes('npmInstallTwice')) {\n logger.debug('Running npm install twice');\n // Run the install command twice to ensure the lock file is up to date\n // iterate through commands and if any command starts with `npm install`, add it again\n const existingCommands = [...commands];\n commands = [];\n for (const command of existingCommands) {\n commands.push(command);\n if (command.startsWith('npm install')) {\n commands.push(command);\n }\n }\n }\n\n // Run the commands\n await exec(commands, execOptions);\n\n // massage to shrinkwrap if necessary\n if (\n filename === 'npm-shrinkwrap.json' &&\n (await localPathExists(upath.join(lockFileDir, 'package-lock.json')))\n ) {\n await renameLocalFile(\n upath.join(lockFileDir, 'package-lock.json'),\n upath.join(lockFileDir, 'npm-shrinkwrap.json'),\n );\n }\n\n // Read the result\n // TODO #22198\n lockFile = (await readLocalFile(\n upath.join(lockFileDir, filename),\n 'utf8',\n ))!;\n\n // Massage lockfile counterparts of package.json that were modified\n // because npm install was called with an explicit version for rangeStrategy=update-lockfile\n if (lockUpdates.length) {\n const { detectedIndent, lockFileParsed } = parseLockFile(lockFile);\n if (\n lockFileParsed?.lockfileVersion === 2 ||\n lockFileParsed?.lockfileVersion === 3\n ) {\n lockUpdates.forEach((lockUpdate) => {\n const depType = lockUpdate.depType as\n | 'dependencies'\n | 'optionalDependencies';\n\n // TODO #22198\n if (\n lockFileParsed.packages?.['']?.[depType]?.[lockUpdate.packageName!]\n ) {\n lockFileParsed.packages[''][depType][lockUpdate.packageName!] =\n lockUpdate.newValue!;\n }\n });\n lockFile = composeLockFile(lockFileParsed, detectedIndent);\n }\n }\n /* v8 ignore next -- needs test */\n } catch (err) {\n if (err.message === TEMPORARY_ERROR) {\n throw err;\n }\n logger.debug(\n {\n err,\n type: 'npm',\n },\n 'lock file error',\n );\n if (err.stderr?.includes('ENOSPC: no space left on device')) {\n throw new Error(SYSTEM_INSUFFICIENT_DISK_SPACE);\n }\n return { error: true, stderr: err.stderr };\n }\n return { error: !lockFile, lockFile };\n}\n\nexport function divideWorkspaceAndRootDeps(\n lockFileDir: string,\n lockUpdates: Upgrade[],\n): {\n lockRootUpdates: Upgrade[];\n lockWorkspacesUpdates: Upgrade[];\n workspaces: Set<string>;\n rootDeps: Set<string>;\n} {\n const lockRootUpdates: Upgrade[] = []; // stores all upgrades which are present in root package.json\n const lockWorkspacesUpdates: Upgrade[] = []; // stores all upgrades which are present in workspaces package.json\n const workspaces = new Set<string>(); // name of all workspaces\n const rootDeps = new Set<string>(); // packageName of all upgrades in root package.json (makes it check duplicate deps in root)\n\n // divide the deps in two categories: workspace and root\n for (const upgrade of lockUpdates) {\n upgrade.managerData ??= {};\n upgrade.managerData.packageKey = generatePackageKey(\n upgrade.packageName!,\n upgrade.newVersion!,\n );\n if (\n upgrade.managerData.workspacesPackages?.length &&\n isString(upgrade.packageFile)\n ) {\n const workspacePatterns = upgrade.managerData.workspacesPackages; // glob pattern or directory name/path\n const packageFileDir = trimSlashes(\n upgrade.packageFile.replace('package.json', ''),\n );\n\n // workspaceDir = packageFileDir - lockFileDir\n const workspaceDir = trimSlashes(\n packageFileDir.startsWith(lockFileDir)\n ? packageFileDir.slice(lockFileDir.length)\n : packageFileDir,\n );\n\n if (isNonEmptyString(workspaceDir)) {\n let workspaceName: string | undefined;\n // compare workspaceDir to workspace patterns\n // stop when the first match is found and\n // add workspaceDir to workspaces set and upgrade object\n for (const workspacePattern of workspacePatterns) {\n const massagedPattern = (workspacePattern as string).replace(\n /^\\.\\//,\n '',\n );\n if (minimatch(massagedPattern).match(workspaceDir)) {\n workspaceName = workspaceDir;\n break;\n }\n }\n if (workspaceName) {\n if (\n !rootDeps.has(upgrade.managerData.packageKey) // prevent same dep from existing in root and workspace\n ) {\n workspaces.add(workspaceName);\n upgrade.workspace = workspaceName;\n lockWorkspacesUpdates.push(upgrade);\n }\n } else {\n logger.warn(\n { workspacePatterns, workspaceDir },\n 'workspaceDir not found',\n );\n }\n continue;\n }\n }\n lockRootUpdates.push(upgrade);\n rootDeps.add(upgrade.managerData.packageKey);\n }\n\n return { lockRootUpdates, lockWorkspacesUpdates, workspaces, rootDeps };\n}\n\nfunction generatePackageKey(packageName: string, version: string): string {\n return `${packageName}@${version}`;\n}\n"],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@ import { Category } from "../../constants/category.js";
|
|
|
2
2
|
import { ModuleApi } from "../../types/base.js";
|
|
3
3
|
import { SkipReason, StageName } from "../../types/skip-reason.js";
|
|
4
4
|
import { RangeStrategy } from "../../types/versioning.js";
|
|
5
|
-
import { MaybePromise
|
|
5
|
+
import { MaybePromise } from "../../types/index.js";
|
|
6
6
|
import { FileChange } from "../../util/git/types.js";
|
|
7
7
|
import { MergeConfidence } from "../../util/merge-confidence/types.js";
|
|
8
8
|
import { Timestamp } from "../../util/timestamp.js";
|
|
@@ -283,7 +283,6 @@ interface PostUpdateConfig<T = Record<string, any>> extends Record<string, any>,
|
|
|
283
283
|
branchName: string;
|
|
284
284
|
reuseExistingBranch?: boolean;
|
|
285
285
|
toolSettings?: ToolSettingsOptions;
|
|
286
|
-
minimumReleaseAge?: Nullish<string>;
|
|
287
286
|
isLockFileMaintenance?: boolean;
|
|
288
287
|
}
|
|
289
288
|
//#endregion
|
package/package.json
CHANGED
package/renovate-schema.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"$id": "https://docs.renovatebot.com/renovate-schema.json",
|
|
3
|
-
"title": "JSON schema for Renovate 43.94.
|
|
3
|
+
"title": "JSON schema for Renovate 43.94.1 config files (https://renovatebot.com/)",
|
|
4
4
|
"$schema": "http://json-schema.org/draft-07/schema#",
|
|
5
|
-
"x-renovate-version": "43.94.
|
|
5
|
+
"x-renovate-version": "43.94.1",
|
|
6
6
|
"allowComments": true,
|
|
7
7
|
"type": "object",
|
|
8
8
|
"properties": {
|