@visulima/vis 1.0.0-alpha.22 → 1.0.0-alpha.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/CHANGELOG.md +50 -0
  2. package/LICENSE.md +132 -2
  3. package/README.md +1 -1
  4. package/dashboard/dist/index.html +152 -0
  5. package/dist/bin.js +1 -1
  6. package/dist/binx.js +3 -0
  7. package/dist/config/index.d.ts +20 -33
  8. package/dist/config/index.js +1 -1
  9. package/dist/packem_chunks/bin.js +373 -367
  10. package/dist/packem_chunks/bloom-status.js +2 -2
  11. package/dist/packem_chunks/bloom-sync.js +2 -2
  12. package/dist/packem_chunks/config.js +12 -12
  13. package/dist/packem_chunks/doctor-probe.js +2 -2
  14. package/dist/packem_chunks/fix.js +3 -3
  15. package/dist/packem_chunks/handler.js +1 -1
  16. package/dist/packem_chunks/handler10.js +1 -1
  17. package/dist/packem_chunks/handler11.js +1 -1
  18. package/dist/packem_chunks/handler12.js +3 -3
  19. package/dist/packem_chunks/handler13.js +1 -1
  20. package/dist/packem_chunks/handler14.js +10 -10
  21. package/dist/packem_chunks/handler15.js +2 -2
  22. package/dist/packem_chunks/handler16.js +1 -1
  23. package/dist/packem_chunks/handler17.js +1 -1
  24. package/dist/packem_chunks/handler18.js +1 -1
  25. package/dist/packem_chunks/handler19.js +1 -1
  26. package/dist/packem_chunks/handler2.js +1 -1
  27. package/dist/packem_chunks/handler20.js +1 -1
  28. package/dist/packem_chunks/handler21.js +2 -2
  29. package/dist/packem_chunks/handler22.js +2 -2
  30. package/dist/packem_chunks/handler23.js +2 -2
  31. package/dist/packem_chunks/handler24.js +1 -18
  32. package/dist/packem_chunks/handler25.js +1 -1
  33. package/dist/packem_chunks/handler26.js +5 -1
  34. package/dist/packem_chunks/handler27.js +1 -5
  35. package/dist/packem_chunks/handler28.js +3 -1
  36. package/dist/packem_chunks/handler29.js +1 -3
  37. package/dist/packem_chunks/handler3.js +1 -1
  38. package/dist/packem_chunks/handler30.js +7 -1
  39. package/dist/packem_chunks/handler31.js +32 -6
  40. package/dist/packem_chunks/handler32.js +3 -33
  41. package/dist/packem_chunks/handler33.js +1 -3
  42. package/dist/packem_chunks/handler34.js +26 -1
  43. package/dist/packem_chunks/handler35.js +5 -26
  44. package/dist/packem_chunks/handler36.js +22 -5
  45. package/dist/packem_chunks/handler37.js +60 -21
  46. package/dist/packem_chunks/handler38.js +6 -428
  47. package/dist/packem_chunks/handler39.js +708 -61
  48. package/dist/packem_chunks/handler4.js +1 -1
  49. package/dist/packem_chunks/handler40.js +24 -6
  50. package/dist/packem_chunks/handler41.js +237 -166
  51. package/dist/packem_chunks/handler42.js +153 -24
  52. package/dist/packem_chunks/handler43.js +10 -153
  53. package/dist/packem_chunks/handler44.js +25 -10
  54. package/dist/packem_chunks/handler45.js +24 -25
  55. package/dist/packem_chunks/handler46.js +3 -24
  56. package/dist/packem_chunks/handler47.js +27 -3
  57. package/dist/packem_chunks/handler48.js +168 -21
  58. package/dist/packem_chunks/handler49.js +33 -173
  59. package/dist/packem_chunks/handler5.js +6 -6
  60. package/dist/packem_chunks/handler6.js +1 -1
  61. package/dist/packem_chunks/handler7.js +1 -1
  62. package/dist/packem_chunks/handler8.js +1 -1
  63. package/dist/packem_chunks/handler9.js +1 -1
  64. package/dist/packem_chunks/heal-accept.js +4 -4
  65. package/dist/packem_chunks/heal.js +1 -1
  66. package/dist/packem_chunks/help-command.js +2 -2
  67. package/dist/packem_chunks/index.js +2 -2
  68. package/dist/packem_chunks/keys-refresh.js +1 -1
  69. package/dist/packem_chunks/list.js +2 -2
  70. package/dist/packem_chunks/loader.js +2 -2
  71. package/dist/packem_chunks/loader2.js +1 -1
  72. package/dist/packem_chunks/prune.js +1 -1
  73. package/dist/packem_chunks/run.js +1 -1
  74. package/dist/packem_chunks/status.js +2 -2
  75. package/dist/packem_chunks/sync.js +2 -2
  76. package/dist/packem_chunks/sync2.js +2 -2
  77. package/dist/packem_chunks/tripwire.js +2 -2
  78. package/dist/packem_chunks/verify-lockfile.js +2 -2
  79. package/dist/packem_shared/{advisories-DS8JEB_g.js → advisories-U1QKY_tg.js} +1 -1
  80. package/dist/packem_shared/{ai-analysis-DGBZYlxF.js → ai-analysis-B8pDCOuT.js} +2 -2
  81. package/dist/packem_shared/ai-fix-DiGSrGKv.js +43 -0
  82. package/dist/packem_shared/anolilab-text-CAM_E6uK.js +13 -0
  83. package/dist/packem_shared/applyDefaults-KxZkvlp3.js +1 -0
  84. package/dist/packem_shared/build-scripts-3E2pmscY.js +1 -0
  85. package/dist/packem_shared/{cyclonedx-CO7-Y1B1.js → cyclonedx-B293T7R0.js} +3 -3
  86. package/dist/packem_shared/dependency-scan-BbtivycX.js +1 -0
  87. package/dist/packem_shared/docker-BhBBfWfc.js +60 -0
  88. package/dist/packem_shared/failure-log-B0Uh-65U.js +2 -0
  89. package/dist/packem_shared/index-C1w1GXdS.js +1 -0
  90. package/dist/packem_shared/index-CZX_II5N.js +29 -0
  91. package/dist/packem_shared/index.server-B7ETiT4C.js +2 -0
  92. package/dist/packem_shared/{lifecycle-boYwVQSE.js → lifecycle-wRE7ymVc.js} +2 -2
  93. package/dist/packem_shared/{lockfile-C5DYMHVq.js → lockfile-CQLFNyVa.js} +1 -1
  94. package/dist/packem_shared/manifests-Z3spBpxv.js +1 -0
  95. package/dist/packem_shared/{min-release-age-D462DvYM.js → min-release-age-Cz6HbF-I.js} +2 -2
  96. package/dist/packem_shared/native-config-sync-BOeuyrBj.js +21 -0
  97. package/dist/packem_shared/{osv-bloom-QSAn2Dcw.js → osv-bloom-CyCDpXBl.js} +2 -2
  98. package/dist/packem_shared/pm-runner-CVliR6Ie.js +1 -0
  99. package/dist/packem_shared/provenance-BcldGs02.js +1 -0
  100. package/dist/packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js +1 -0
  101. package/dist/packem_shared/registry-keys-pemEkRM9.js +1 -0
  102. package/dist/packem_shared/{resolve-explicit-BgFQHUEP.js → resolve-explicit-2G-2HWtR.js} +3 -3
  103. package/dist/packem_shared/runtime-check-DgXsKCsv.js +1 -0
  104. package/dist/packem_shared/s1ngularity-Boxkax0D.js +1 -0
  105. package/dist/packem_shared/scan-progress-EbvmIh4i.js +2 -0
  106. package/dist/packem_shared/{selectors-B2ISH581.js → selectors-BE2BCnTR.js} +1 -1
  107. package/dist/packem_shared/{signatures-b-jJYoZd.js → signatures-SO-fyExV.js} +1 -1
  108. package/dist/packem_shared/toolchain-Jx2lkAYy.js +5 -0
  109. package/dist/packem_shared/typosquats-CioMnpnb.js +1 -0
  110. package/dist/packem_shared/verify-C8EAHql6.js +1 -0
  111. package/dist/packem_shared/{vis-update-app-Bnu1EIgE.js → vis-update-app-BWA1kA1q.js} +1 -1
  112. package/index.js +26 -26
  113. package/package.json +23 -12
  114. package/schemas/vis-config.schema.json +61 -12
  115. package/dist/packem_chunks/handler50.js +0 -34
  116. package/dist/packem_shared/ai-cache-BjlXWJtl.js +0 -1
  117. package/dist/packem_shared/ai-fix-BhcTrkuW.js +0 -43
  118. package/dist/packem_shared/applyDefaults-BOVDw1jD.js +0 -1
  119. package/dist/packem_shared/build-scripts-DsWMSWDs.js +0 -1
  120. package/dist/packem_shared/cache-directory-DQak1Vjc.js +0 -1
  121. package/dist/packem_shared/dependency-scan-DPHTzA5r.js +0 -1
  122. package/dist/packem_shared/docker-lk0-5Z-i.js +0 -60
  123. package/dist/packem_shared/failure-log-DF7nrFIs.js +0 -2
  124. package/dist/packem_shared/flakiness-DKCOYwN7.js +0 -1
  125. package/dist/packem_shared/index-B4gpNmrG.js +0 -1
  126. package/dist/packem_shared/manifests-B0fMp872.js +0 -1
  127. package/dist/packem_shared/native-config-sync-B0_ef78M.js +0 -21
  128. package/dist/packem_shared/provenance-smHa8efI.js +0 -1
  129. package/dist/packem_shared/registry-keys-3qaVog76.js +0 -1
  130. package/dist/packem_shared/run-summary-utils-DIJV_dUD.js +0 -1
  131. package/dist/packem_shared/runtime-check-DrMx4Q9L.js +0 -1
  132. package/dist/packem_shared/s1ngularity-CwSBPB3I.js +0 -1
  133. package/dist/packem_shared/scan-progress-CMynp3eA.js +0 -2
  134. package/dist/packem_shared/toolchain-OH1PXwbZ.js +0 -5
  135. package/dist/packem_shared/typosquats-CJ4o1l7U.js +0 -1
  136. package/dist/packem_shared/verify-CQbzknur.js +0 -1
  137. package/dist/packem_shared/xxh3-DrAUNq4n.js +0 -1
@@ -1 +1,7 @@
1
- var p=Object.defineProperty;var t=(a,o)=>p(a,"name",{value:o,configurable:!0});import{g as f,a8 as g}from"./bin.js";import{o as d}from"../packem_shared/utils-DrNg0XTR.js";var v=Object.defineProperty,u=t((a,o)=>v(a,"name",{value:o,configurable:!0}),"n");const h=u(async({argument:a,logger:o,options:e,visConfig:l,workspaceRoot:c})=>{const s=a;if(!s||s.length===0)throw new Error("No packages specified. Usage: vis why <package...>");const n=c??process.cwd(),i=f(n,{configBackend:l?.install?.backend,configCorepack:l?.install?.corepack}),r=g(i,{depth:e.depth===void 0?void 0:Number(e.depth),dev:e.dev||!1,filter:d(e.filter),global:e.global||!1,json:e.json||!1,long:e.long||!1,noOptional:e.optional===!1,packages:s,parseable:e.parseable||!1,prod:e.prod||!1,recursive:e.recursive||!1},n,o);r!==0&&r!==1&&(process.exitCode=r)},"execute");export{h as default};
1
+ var x=Object.defineProperty;var l=(e,o)=>x(e,"name",{value:o,configurable:!0});import{b as g,O as E,_ as S,R as f}from"../packem_shared/ai-analysis-B8pDCOuT.js";import{renderToString as w}from"@visulima/tui";import{Table as D}from"@visulima/tui/components/table";import P from"react";import{j,E as d,q as I,I as O,e as N}from"../packem_shared/index.server-B7ETiT4C.js";var T=Object.defineProperty,u=l((e,o)=>T(e,"name",{value:o,configurable:!0}),"s");const v={command:"ai",description:"AI-assisted commands: provider detection, cache management, and failure-fix proposals."},R=u(e=>{if(typeof e!="function")return String(e);const{name:o}=e;return o==="Boolean"?"boolean":o==="Number"?"number":o==="String"?"string":o??"unknown"},"typeName"),A=u(e=>{const o=[...e.commandPath??[],e.name].join(" "),i=(e.examples??[]).map(([t,s])=>({command:t??"",description:s??""})),a=(e.options??[]).map(t=>({defaultValue:t.defaultValue,description:t.description,name:t.name,type:R(t.type)}));return{argument:e.argument?{description:e.argument.description,name:e.argument.name}:void 0,description:e.description??"",examples:i,name:e.name,options:a,path:o}},"buildSubcommand"),h=u((e,o=v)=>({command:o.command,description:o.description,subcommands:e.map(i=>A(i))}),"buildDiscoveryPayload"),C=u((e,o=v)=>`${JSON.stringify(h(e,o),void 0,2)}
2
+ `,"renderDiscoveryJson"),J=u((e,o=v)=>{const i=h(e,o),a=[j(`vis ${i.command} — ${i.description}`),"",d("Subcommands:")];for(const t of i.subcommands){const s=t.argument?` ${I(`<${t.argument.name}>`)}`:"";if(a.push(""),a.push(` ${O(`vis ${t.path}`)}${s}`),t.description&&a.push(` ${t.description}`),t.options.length>0){const n=t.options.map(c=>`--${c.name}${c.type==="boolean"?"":`=<${c.type}>`}`).join(", ");a.push(d(` options: ${n}`))}if(t.examples.length>0){a.push(d(" examples:"));for(const n of t.examples){const c=n.description?d(` — ${n.description}`):"";a.push(` ${N(n.command)}${c}`)}}}return a.push(""),a.push(d(`Run \`vis ${i.command} discover-help\` for the machine-readable JSON catalogue (designed for AI agents).`)),a.push(d(`Run \`vis ${i.command} <subcommand> --help\` for full usage of a specific subcommand.`)),`${a.join(`
3
+ `)}
4
+ `},"renderDiscoveryText");var F=Object.defineProperty,p=l((e,o)=>F(e,"name",{value:o,configurable:!0}),"r");const b=p(async()=>{const{default:e}=await import("./bin.js").then(o=>o.bj);return e.filter(o=>o.name!=="ai")},"loadDiscoverableSubcommands"),K=p(async()=>{const e=await b();process.stderr.write(J(e))},"aiRootExecute"),L=p(async()=>{const e=await b();process.stdout.write(C(e))},"aiDiscoverHelpExecute"),_=p(async({logger:e,visConfig:o})=>{const i=o?.ai,a=g(i);if(!a){e.error("No AI provider available to test."),process.exitCode=1;return}e.info(`Testing ${a.name}...`);try{const t=await E(a,"Reply with exactly: OK",{timeoutMs:3e4});e.info(`Provider ${a.name} responded: ${t.stdout.trim().slice(0,200)}`)}catch(t){const s=t instanceof Error?t.message:String(t);e.error(`Provider ${a.name} failed: ${s}`),process.exitCode=1}},"aiTestExecute"),z=p(({logger:e,options:o,visConfig:i})=>{const a=o.format??"table",t=i?.ai,s=S(),n=g(t);if(a==="json"){const r=s.map(m=>({available:m.available,method:m.detectionMethod,name:m.name,path:m.path,priority:f[m.name]??0,selected:m.name===n?.name,version:m.version}));process.stdout.write(`${JSON.stringify(r,void 0,2)}
5
+ `);return}const c=s.map(r=>({method:r.detectionMethod??"-",path:r.path??"-",priority:String(f[r.name]??0),provider:r.name,selected:r.name===n?.name?">>>":"",status:r.available?"available":"not found",version:r.version??"-"})),y=process.stdout.columns||80,$=w(P.createElement(D,{data:c}),{columns:y});e.info($),n?e.info(`
6
+ Selected provider: ${n.name} (priority ${String(f[n.name]??0)})`):e.info(`
7
+ No AI provider available. Install one of the supported AI CLI tools.`)},"aiProvidersExecute"),G=p(async e=>{const{aiFix:o}=await import("./fix.js");await o(e)},"aiFixExecute");export{L as aiDiscoverHelpExecute,G as aiFixExecute,z as aiProvidersExecute,K as aiRootExecute,_ as aiTestExecute};
@@ -1,7 +1,33 @@
1
- var x=Object.defineProperty;var l=(e,o)=>x(e,"name",{value:o,configurable:!0});import{b as g,O as E,_ as S,R as f}from"../packem_shared/ai-analysis-DGBZYlxF.js";import{renderToString as w}from"@visulima/tui";import{Table as D}from"@visulima/tui/components/table";import P from"react";import{j as I,E as d,q as O,I as j,e as N}from"./bin.js";var T=Object.defineProperty,u=l((e,o)=>T(e,"name",{value:o,configurable:!0}),"s");const v={command:"ai",description:"AI-assisted commands: provider detection, cache management, and failure-fix proposals."},J=u(e=>{if(typeof e!="function")return String(e);const{name:o}=e;return o==="Boolean"?"boolean":o==="Number"?"number":o==="String"?"string":o??"unknown"},"typeName"),R=u(e=>{const o=[...e.commandPath??[],e.name].join(" "),i=(e.examples??[]).map(([t,s])=>({command:t??"",description:s??""})),a=(e.options??[]).map(t=>({defaultValue:t.defaultValue,description:t.description,name:t.name,type:J(t.type)}));return{argument:e.argument?{description:e.argument.description,name:e.argument.name}:void 0,description:e.description??"",examples:i,name:e.name,options:a,path:o}},"buildSubcommand"),h=u((e,o=v)=>({command:o.command,description:o.description,subcommands:e.map(i=>R(i))}),"buildDiscoveryPayload"),A=u((e,o=v)=>`${JSON.stringify(h(e,o),void 0,2)}
2
- `,"renderDiscoveryJson"),C=u((e,o=v)=>{const i=h(e,o),a=[I(`vis ${i.command} — ${i.description}`),"",d("Subcommands:")];for(const t of i.subcommands){const s=t.argument?` ${O(`<${t.argument.name}>`)}`:"";if(a.push(""),a.push(` ${j(`vis ${t.path}`)}${s}`),t.description&&a.push(` ${t.description}`),t.options.length>0){const n=t.options.map(c=>`--${c.name}${c.type==="boolean"?"":`=<${c.type}>`}`).join(", ");a.push(d(` options: ${n}`))}if(t.examples.length>0){a.push(d(" examples:"));for(const n of t.examples){const c=n.description?d(` — ${n.description}`):"";a.push(` ${N(n.command)}${c}`)}}}return a.push(""),a.push(d(`Run \`vis ${i.command} discover-help\` for the machine-readable JSON catalogue (designed for AI agents).`)),a.push(d(`Run \`vis ${i.command} <subcommand> --help\` for full usage of a specific subcommand.`)),`${a.join(`
1
+ var R=Object.defineProperty;var k=(n,t)=>R(n,"name",{value:t,configurable:!0});import{createRequire as B}from"node:module";import{i as D,$ as V}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{j as q,B as v}from"./config.js";import{p as e}from"./bin.js";import{A as E}from"../packem_shared/pm-runner-CVliR6Ie.js";import{x as M}from"../packem_shared/build-scripts-3E2pmscY.js";import{N as F}from"../packem_shared/native-config-sync-BOeuyrBj.js";const O=B(import.meta.url),$=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,T=k(n=>{if(typeof $<"u"&&$.versions&&$.versions.node){const[t,s]=$.versions.node.split(".").map(Number);if(t>22||t===22&&s>=3||t===20&&s>=16)return $.getBuiltinModule(n)}return O(n)},"__cjs_getBuiltinModule"),{spawnSync:A}=T("node:child_process");var W=Object.defineProperty,x=k((n,t)=>W(n,"name",{value:t,configurable:!0}),"$$1");const z=/(defineConfig\s*\(\s*\{)/,J=/(export\s+default\s+\{)/,w=x((n,t)=>`${t}${JSON.stringify(n)}: true,`,"renderEntry"),G=x((n,t)=>{if(t.length===0)return{added:[],skipped:[],status:"noop"};const s=q(n);if(!s)return{added:[],skipped:t,status:"no-config"};if(!D(s))return{added:[],skipped:t,status:"no-config"};const i=V(s),h=i.search(/installScripts\s*:\s*\{/);let p=null,c=0;if(h!==-1){const a=i.slice(h),d=/(allow\s*:\s*\{)([^}]*)(\})/.exec(a);d?.index!==void 0&&(p=d,c=h+d.index)}if(p){const a=p[2]??"",d=new Set;for(const g of a.matchAll(/["']([^"']+)["']\s*:/g))d.add(g[1]);for(const g of a.matchAll(/(?:^|,|\{)\s*([a-z_$][\w-]*)\s*:/gi))d.add(g[1]);const f=[],S=[];for(const g of t)d.has(g)?S.push(g):f.push(g);if(f.length===0)return{added:[],configPath:s,skipped:S,status:"noop"};const _=/\n([ \t]+)\S/.exec(a)?.[1]??" ",P=`
2
+ ${f.map(g=>w(g,_)).join(`
3
+ `)}`,y=a.replace(/\s+$/,""),b=a.slice(y.length),N=`${y}${y.endsWith(",")||y===""?"":","}${P}${b.length>0?b:`
4
+ `}`,C=`${i.slice(0,c)}${p[1]}${N}${p[3]}${i.slice(c+p[0].length)}`;return v(s,C),{added:f,configPath:s,skipped:S,status:"updated"}}const o=/(installScripts\s*:\s*\{)/;if(o.test(i)){const a=`
5
+ allow: {
6
+ ${t.map(f=>w(f," ")).join(`
3
7
  `)}
4
- `},"renderDiscoveryText");var F=Object.defineProperty,p=l((e,o)=>F(e,"name",{value:o,configurable:!0}),"r");const b=p(async()=>{const{default:e}=await import("./bin.js").then(o=>o.bJ);return e.filter(o=>o.name!=="ai")},"loadDiscoverableSubcommands"),K=p(async()=>{const e=await b();process.stderr.write(C(e))},"aiRootExecute"),L=p(async()=>{const e=await b();process.stdout.write(A(e))},"aiDiscoverHelpExecute"),_=p(async({logger:e,visConfig:o})=>{const i=o?.ai,a=g(i);if(!a){e.error("No AI provider available to test."),process.exitCode=1;return}e.info(`Testing ${a.name}...`);try{const t=await E(a,"Reply with exactly: OK",{timeoutMs:3e4});e.info(`Provider ${a.name} responded: ${t.stdout.trim().slice(0,200)}`)}catch(t){const s=t instanceof Error?t.message:String(t);e.error(`Provider ${a.name} failed: ${s}`),process.exitCode=1}},"aiTestExecute"),z=p(({logger:e,options:o,visConfig:i})=>{const a=o.format??"table",t=i?.ai,s=S(),n=g(t);if(a==="json"){const r=s.map(m=>({available:m.available,method:m.detectionMethod,name:m.name,path:m.path,priority:f[m.name]??0,selected:m.name===n?.name,version:m.version}));process.stdout.write(`${JSON.stringify(r,void 0,2)}
5
- `);return}const c=s.map(r=>({method:r.detectionMethod??"-",path:r.path??"-",priority:String(f[r.name]??0),provider:r.name,selected:r.name===n?.name?">>>":"",status:r.available?"available":"not found",version:r.version??"-"})),y=process.stdout.columns||80,$=w(P.createElement(D,{data:c}),{columns:y});e.info($),n?e.info(`
6
- Selected provider: ${n.name} (priority ${String(f[n.name]??0)})`):e.info(`
7
- No AI provider available. Install one of the supported AI CLI tools.`)},"aiProvidersExecute"),G=p(async e=>{const{aiFix:o}=await import("./fix.js");await o(e)},"aiFixExecute");export{L as aiDiscoverHelpExecute,G as aiFixExecute,z as aiProvidersExecute,K as aiRootExecute,_ as aiTestExecute};
8
+ },`,d=i.replace(o,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const r=/(policies\s*:\s*\{)/;if(r.test(i)){const a=`
9
+ installScripts: {
10
+ allow: {
11
+ ${t.map(f=>w(f," ")).join(`
12
+ `)}
13
+ },
14
+ },`,d=i.replace(r,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const u=/(security\s*:\s*\{)/;if(u.test(i)){const a=`
15
+ policies: {
16
+ installScripts: {
17
+ allow: {
18
+ ${t.map(f=>w(f," ")).join(`
19
+ `)}
20
+ },
21
+ },
22
+ },`,d=i.replace(u,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const l=z.exec(i)??J.exec(i);if(!l)return{added:[],configPath:s,skipped:t,status:"missing-anchor"};const m=`
23
+ security: {
24
+ policies: {
25
+ installScripts: {
26
+ allow: {
27
+ ${t.map(a=>w(a," ")).join(`
28
+ `)}
29
+ },
30
+ },
31
+ },
32
+ },`,j=`${i.slice(0,l.index+l[0].length)}${m}${i.slice(l.index+l[0].length)}`;return v(s,j),{added:t,configPath:s,skipped:[],status:"updated"}},"writeApprovedBuildsToVisConfig");var H=Object.defineProperty,I=k((n,t)=>H(n,"name",{value:t,configurable:!0}),"d");const te=I(async({options:n,visConfig:t,workspaceRoot:s})=>{const i=s??process.cwd(),h=E(i);if(h.name==="pnpm"&&!n.scan){e.info("Delegating to pnpm approve-builds...");const p=["approve-builds"];n.all&&p.push("--all");const c=A("pnpm",p,{cwd:i,stdio:"inherit"});if(c.error)throw new Error(`Failed to run pnpm approve-builds: ${c.error.message}`);if(c.status!==0&&c.status!==null&&(e.error(`pnpm approve-builds exited with code ${c.status}`),process.exitCode=c.status),!n.syncNative){e.notice(""),e.notice("Tip: vis.config.ts security.policies.installScripts.allow may now be out of sync with pnpm-workspace.yaml."),e.notice("Run 'vis check --security-config' to compare, or copy the new entries into vis.config.ts.");return}}else{const p=t?.security?.policies?.installScripts?.allow??{},c=t?.security?.pinVersions===!0,o=M(i,p,{pinVersions:c});if(o.unapproved.length===0)e.success("No unapproved build scripts found."),n.write&&(e.info(""),e.info("Nothing to write — there are no unapproved build scripts."));else{e.warn(`Found ${o.unapproved.length} package${o.unapproved.length===1?"":"s"} with unapproved build scripts:
33
+ `);for(const r of o.unapproved)e.info(` ${r.name} (${r.hooks.join(", ")})`);e.notice(""),e.notice("To approve these packages, add them to vis.config.ts:"),e.notice(""),e.notice(" security: {"),e.notice(" policies: {"),e.notice(" installScripts: {"),e.notice(" allow: {");for(const r of o.unapproved){const u=c&&r.version?`${r.name}@${r.version}`:r.name;e.notice(` "${u}": true,`)}if(e.notice(" },"),e.notice(" },"),e.notice(" },"),e.notice(" },"),h.name==="pnpm"&&(e.notice(""),e.notice("Or run 'pnpm approve-builds' to update pnpm-workspace.yaml directly.")),n.write){const r=t?.security?.pinVersions===!0,u=o.unapproved.map(m=>r&&m.version?`${m.name}@${m.version}`:m.name),l=G(i,u);switch(e.info(""),l.status){case"missing-anchor":{e.warn(`Could not locate 'defineConfig({' or 'export default {' in ${String(l.configPath)} — please add entries manually.`);break}case"no-config":{e.warn("No vis.config.ts found. Run 'vis init' first, then re-run with --write.");break}case"noop":{e.info(`All ${String(u.length)} entr${u.length===1?"y":"ies"} were already present in vis.config.ts security.policies.installScripts.allow.`);break}default:e.success(`Wrote ${String(l.added.length)} entr${l.added.length===1?"y":"ies"} to ${String(l.configPath)}.`),l.skipped.length>0&&e.info(`Skipped ${String(l.skipped.length)} already-present entr${l.skipped.length===1?"y":"ies"}.`)}}}if(o.excess.length>0){e.notice(""),e.warn(`Stale installScripts.allow entries — ${String(o.excess.length)} pattern${o.excess.length===1?"":"s"} no longer match any installed package:`);for(const r of o.excess)e.info(` ${r}`);e.notice("Consider removing these entries from vis.config.ts security.policies.installScripts.allow.")}if(o.versionDrift.length>0){e.notice(""),e.warn(`Version drift — ${String(o.versionDrift.length)} entr${o.versionDrift.length===1?"y":"ies"} pinned to an outdated version:`);for(const{from:r,to:u}of o.versionDrift)e.info(` ${r} → ${u}`);e.notice("Rename the keys in vis.config.ts security.policies.installScripts.allow to migrate.")}}if(n.syncNative){const p=t?.security?.policies?.installScripts?.allow??{};if(Object.keys(p).length===0)e.warn("No security.policies.installScripts.allow configured in vis.config.ts. Nothing to sync.");else{const c=F(h.name,i,p);e.info("");for(const o of c)e.success(o)}}},"execute");export{te as default};
@@ -1,33 +1,3 @@
1
- var R=Object.defineProperty;var k=(n,t)=>R(n,"name",{value:t,configurable:!0});import{createRequire as B}from"node:module";import{j as D,i as V,$ as q,B as v}from"./config.js";import{A as E,p as e}from"./bin.js";import{x as M}from"../packem_shared/build-scripts-DsWMSWDs.js";import{N as F}from"../packem_shared/native-config-sync-B0_ef78M.js";const O=B(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,T=k(n=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[t,s]=m.versions.node.split(".").map(Number);if(t>22||t===22&&s>=3||t===20&&s>=16)return m.getBuiltinModule(n)}return O(n)},"__cjs_getBuiltinModule"),{spawnSync:A}=T("node:child_process");var W=Object.defineProperty,x=k((n,t)=>W(n,"name",{value:t,configurable:!0}),"$$1");const z=/(defineConfig\s*\(\s*\{)/,J=/(export\s+default\s+\{)/,w=x((n,t)=>`${t}${JSON.stringify(n)}: true,`,"renderEntry"),G=x((n,t)=>{if(t.length===0)return{added:[],skipped:[],status:"noop"};const s=D(n);if(!s)return{added:[],skipped:t,status:"no-config"};if(!V(s))return{added:[],skipped:t,status:"no-config"};const i=q(s),h=i.search(/installScripts\s*:\s*\{/);let p=null,c=0;if(h!==-1){const a=i.slice(h),d=/(allow\s*:\s*\{)([^}]*)(\})/.exec(a);d?.index!==void 0&&(p=d,c=h+d.index)}if(p){const a=p[2]??"",d=new Set;for(const g of a.matchAll(/["']([^"']+)["']\s*:/g))d.add(g[1]);for(const g of a.matchAll(/(?:^|,|\{)\s*([a-z_$][\w-]*)\s*:/gi))d.add(g[1]);const f=[],S=[];for(const g of t)d.has(g)?S.push(g):f.push(g);if(f.length===0)return{added:[],configPath:s,skipped:S,status:"noop"};const _=/\n([ \t]+)\S/.exec(a)?.[1]??" ",P=`
2
- ${f.map(g=>w(g,_)).join(`
3
- `)}`,y=a.replace(/\s+$/,""),b=a.slice(y.length),N=`${y}${y.endsWith(",")||y===""?"":","}${P}${b.length>0?b:`
4
- `}`,C=`${i.slice(0,c)}${p[1]}${N}${p[3]}${i.slice(c+p[0].length)}`;return v(s,C),{added:f,configPath:s,skipped:S,status:"updated"}}const o=/(installScripts\s*:\s*\{)/;if(o.test(i)){const a=`
5
- allow: {
6
- ${t.map(f=>w(f," ")).join(`
7
- `)}
8
- },`,d=i.replace(o,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const r=/(policies\s*:\s*\{)/;if(r.test(i)){const a=`
9
- installScripts: {
10
- allow: {
11
- ${t.map(f=>w(f," ")).join(`
12
- `)}
13
- },
14
- },`,d=i.replace(r,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const u=/(security\s*:\s*\{)/;if(u.test(i)){const a=`
15
- policies: {
16
- installScripts: {
17
- allow: {
18
- ${t.map(f=>w(f," ")).join(`
19
- `)}
20
- },
21
- },
22
- },`,d=i.replace(u,`$1${a}`);return v(s,d),{added:t,configPath:s,skipped:[],status:"updated"}}const l=z.exec(i)??J.exec(i);if(!l)return{added:[],configPath:s,skipped:t,status:"missing-anchor"};const $=`
23
- security: {
24
- policies: {
25
- installScripts: {
26
- allow: {
27
- ${t.map(a=>w(a," ")).join(`
28
- `)}
29
- },
30
- },
31
- },
32
- },`,j=`${i.slice(0,l.index+l[0].length)}${$}${i.slice(l.index+l[0].length)}`;return v(s,j),{added:t,configPath:s,skipped:[],status:"updated"}},"writeApprovedBuildsToVisConfig");var H=Object.defineProperty,I=k((n,t)=>H(n,"name",{value:t,configurable:!0}),"d");const Z=I(async({options:n,visConfig:t,workspaceRoot:s})=>{const i=s??process.cwd(),h=E(i);if(h.name==="pnpm"&&!n.scan){e.info("Delegating to pnpm approve-builds...");const p=["approve-builds"];n.all&&p.push("--all");const c=A("pnpm",p,{cwd:i,stdio:"inherit"});if(c.error)throw new Error(`Failed to run pnpm approve-builds: ${c.error.message}`);if(c.status!==0&&c.status!==null&&(e.error(`pnpm approve-builds exited with code ${c.status}`),process.exitCode=c.status),!n.syncNative){e.notice(""),e.notice("Tip: vis.config.ts security.policies.installScripts.allow may now be out of sync with pnpm-workspace.yaml."),e.notice("Run 'vis check --security-config' to compare, or copy the new entries into vis.config.ts.");return}}else{const p=t?.security?.policies?.installScripts?.allow??{},c=t?.security?.pinVersions===!0,o=M(i,p,{pinVersions:c});if(o.unapproved.length===0)e.success("No unapproved build scripts found."),n.write&&(e.info(""),e.info("Nothing to write — there are no unapproved build scripts."));else{e.warn(`Found ${o.unapproved.length} package${o.unapproved.length===1?"":"s"} with unapproved build scripts:
33
- `);for(const r of o.unapproved)e.info(` ${r.name} (${r.hooks.join(", ")})`);e.notice(""),e.notice("To approve these packages, add them to vis.config.ts:"),e.notice(""),e.notice(" security: {"),e.notice(" policies: {"),e.notice(" installScripts: {"),e.notice(" allow: {");for(const r of o.unapproved){const u=c&&r.version?`${r.name}@${r.version}`:r.name;e.notice(` "${u}": true,`)}if(e.notice(" },"),e.notice(" },"),e.notice(" },"),e.notice(" },"),h.name==="pnpm"&&(e.notice(""),e.notice("Or run 'pnpm approve-builds' to update pnpm-workspace.yaml directly.")),n.write){const r=t?.security?.pinVersions===!0,u=o.unapproved.map($=>r&&$.version?`${$.name}@${$.version}`:$.name),l=G(i,u);switch(e.info(""),l.status){case"missing-anchor":{e.warn(`Could not locate 'defineConfig({' or 'export default {' in ${String(l.configPath)} — please add entries manually.`);break}case"no-config":{e.warn("No vis.config.ts found. Run 'vis init' first, then re-run with --write.");break}case"noop":{e.info(`All ${String(u.length)} entr${u.length===1?"y":"ies"} were already present in vis.config.ts security.policies.installScripts.allow.`);break}default:e.success(`Wrote ${String(l.added.length)} entr${l.added.length===1?"y":"ies"} to ${String(l.configPath)}.`),l.skipped.length>0&&e.info(`Skipped ${String(l.skipped.length)} already-present entr${l.skipped.length===1?"y":"ies"}.`)}}}if(o.excess.length>0){e.notice(""),e.warn(`Stale installScripts.allow entries — ${String(o.excess.length)} pattern${o.excess.length===1?"":"s"} no longer match any installed package:`);for(const r of o.excess)e.info(` ${r}`);e.notice("Consider removing these entries from vis.config.ts security.policies.installScripts.allow.")}if(o.versionDrift.length>0){e.notice(""),e.warn(`Version drift — ${String(o.versionDrift.length)} entr${o.versionDrift.length===1?"y":"ies"} pinned to an outdated version:`);for(const{from:r,to:u}of o.versionDrift)e.info(` ${r} → ${u}`);e.notice("Rename the keys in vis.config.ts security.policies.installScripts.allow to migrate.")}}if(n.syncNative){const p=t?.security?.policies?.installScripts?.allow??{};if(Object.keys(p).length===0)e.warn("No security.policies.installScripts.allow configured in vis.config.ts. Nothing to sync.");else{const c=F(h.name,i,p);e.info("");for(const o of c)e.success(o)}}},"execute");export{Z as default};
1
+ var I=Object.defineProperty;var w=(e,t)=>I(e,"name",{value:t,configurable:!0});import{createRequire as D}from"node:module";import{getAffectedProjects as G}from"@visulima/task-runner";import{C as q,O as L}from"./bin.js";const T=D(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,C=w(e=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[t,r]=h.versions.node.split(".").map(Number);if(t>22||t===22&&r>=3||t===20&&r>=16)return h.getBuiltinModule(e)}return T(e)},"__cjs_getBuiltinModule"),{execFile:N}=C("node:child_process"),{promisify:U}=C("node:util");var V=Object.defineProperty,i=w((e,t)=>V(e,"name",{value:t,configurable:!0}),"t");const O=U(N),J=["[skip ci]","[ci skip]","[no ci]","[vis skip]","[nx skip]"],z=["[vis deploy]","[nx deploy]"],W=["vis","nx"],Z=["CACHED_COMMIT_REF","VERCEL_GIT_PREVIOUS_SHA","GITHUB_BASE_REF","CI_COMMIT_BEFORE_SHA"],K=/^[\w./~^@{}][\w.\-/~^@{}]*$/,Q=i((e=process.env)=>{for(const t of Z){const r=e[t];if(r&&r.trim().length>0)return r.trim()}},"resolveCiBaseSha"),R=i(e=>{if(!K.test(e))throw new Error(`Invalid git ref: "${e}". Refs must start with an alphanumeric character or one of _ . / ~ ^ @ { } and may only contain letters, digits, dots, dashes, underscores, slashes, tildes, carets, @, and braces.`)},"validateGitRef"),X=i(async(e,t)=>{try{return await O("git",["rev-parse","--verify",`${t}^{commit}`],{cwd:e}),!0}catch{return!1}},"isRefReachable"),Y=i(async e=>{try{const{stdout:t}=await O("git",["log","-1","--pretty=%B"],{cwd:e});return t}catch{return""}},"readLastCommitMessage"),A=i((e,t,r)=>W.some(a=>e.includes(`[${a} ${t} ${r}]`)),"matchesPerProjectToken"),ee=i((e,t)=>J.some(r=>e.includes(r))||A(e,"skip",t),"commitHasSkipMessage"),te=i((e,t)=>z.some(r=>e.includes(r))||A(e,"deploy",t),"commitHasForceDeployMessage"),l=i((e,t,r,a)=>({action:"build",message:r,project:e,reason:t,...a}),"decideBuild"),k=i((e,t,r,a)=>({action:"skip",message:r,project:e,reason:t,...a}),"decideSkip"),re=i(e=>`${e.action==="skip"?"🛑":"✅"} ${e.message}`,"formatDecisionLine"),oe=i((e,t)=>e.action==="skip"||t?0:1,"exitCodeFor");var se=Object.defineProperty,_=w((e,t)=>se(e,"name",{value:t,configurable:!0}),"u");const S=new Set(["deep","direct","none"]),de=_(async({argument:e,logger:t,options:r,visConfig:a,workspaceRoot:p})=>{const o=e[0]??"",E=!!r.json,M=!!r.verbose,B=!!(r["exit-zero-on-build"]??r.exitZeroOnBuild),u=_(s=>{M&&!E&&t.info(`❱ ${s}`)},"debug"),n=_(s=>{E?process.stdout.write(`${JSON.stringify(s)}
2
+ `):t.info(re(s)),process.exit(oe(s,B))},"emit");if(!o)return n(l("","missing-project-argument","Missing project argument. Usage: vis ignore <project>"));if(!p)return n(l(o,"workspace-error","Could not determine workspace root — building defensively"));const g=await Y(p),y=g.trim().split(`
3
+ `)[0]??"";if(u(`commit: ${y}`),g&&te(g,o))return n(l(o,"commit-force-deploy",`Force-deploy keyword in commit: "${y}"`));if(g&&ee(g,o))return n(k(o,"commit-skip",`Skip keyword in commit: "${y}"`));let $,P;try{({packageJsons:P,workspace:$}=q(p,a))}catch(s){const d=s instanceof Error?s.message:String(s);return n(l(o,"workspace-error",`Workspace discovery failed (${d}) — building defensively`))}if(!Object.hasOwn($.projects,o))return n(l(o,"project-unknown",`Project "${o}" not found in workspace — building defensively`));try{const s=r.base?.trim(),d=Q();let c=s||d||"HEAD~1";const m=r.head?.trim()||"HEAD";R(c),R(m),u(`resolved base ref: ${c} (source: ${s?"flag":d?"ci-env":"default"})`);const x=X(p,c),F=L(p,$,P);await x||(u(`base ref ${c} not reachable — falling back to HEAD~1`),c="HEAD~1"),u(`comparing ${c}...${m}`);const j=r.downstream??"deep",b=r.upstream??"none";if(!S.has(j))throw new Error(`Invalid --downstream value: "${j}". Must be "none", "direct", or "deep".`);if(!S.has(b))throw new Error(`Invalid --upstream value: "${b}". Must be "none", "direct", or "deep".`);const H={base:c,downstream:j,head:m,projectGraph:F,projects:$.projects,upstream:b,workspaceRoot:p},f=await G(H);u(`changed files: ${f.changedFiles.length}`),u(`affected projects: ${f.affectedProjects.join(", ")||"(none)"}`);const v={base:c,head:m};return f.changedFiles.length===0?n(k(o,"no-changes",`No files changed between ${c}...${m}`,{...v,affectedProjects:[]})):f.affectedProjects.includes(o)?n(l(o,"project-affected",`Build ${o}: affected by ${f.changedFiles.length} changed file(s)`,{...v,affectedProjects:f.affectedProjects})):n(k(o,"project-not-affected",`Skip ${o}: not affected by changes between ${c}...${m}`,{...v,affectedProjects:f.affectedProjects}))}catch(s){const d=s instanceof Error?s.message:String(s);return t.error(`Affected detection failed: ${d}`),n(l(o,"workspace-error",`Affected detection failed (${d}) — building defensively`))}},"execute");export{de as default};
@@ -1,3 +1 @@
1
- var I=Object.defineProperty;var w=(e,t)=>I(e,"name",{value:t,configurable:!0});import{createRequire as D}from"node:module";import{getAffectedProjects as G}from"@visulima/task-runner";import{C as q,O as L}from"./bin.js";const T=D(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,C=w(e=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[t,r]=h.versions.node.split(".").map(Number);if(t>22||t===22&&r>=3||t===20&&r>=16)return h.getBuiltinModule(e)}return T(e)},"__cjs_getBuiltinModule"),{execFile:N}=C("node:child_process"),{promisify:U}=C("node:util");var V=Object.defineProperty,i=w((e,t)=>V(e,"name",{value:t,configurable:!0}),"t");const O=U(N),J=["[skip ci]","[ci skip]","[no ci]","[vis skip]","[nx skip]"],z=["[vis deploy]","[nx deploy]"],W=["vis","nx"],Z=["CACHED_COMMIT_REF","VERCEL_GIT_PREVIOUS_SHA","GITHUB_BASE_REF","CI_COMMIT_BEFORE_SHA"],K=/^[\w./~^@{}][\w.\-/~^@{}]*$/,Q=i((e=process.env)=>{for(const t of Z){const r=e[t];if(r&&r.trim().length>0)return r.trim()}},"resolveCiBaseSha"),R=i(e=>{if(!K.test(e))throw new Error(`Invalid git ref: "${e}". Refs must start with an alphanumeric character or one of _ . / ~ ^ @ { } and may only contain letters, digits, dots, dashes, underscores, slashes, tildes, carets, @, and braces.`)},"validateGitRef"),X=i(async(e,t)=>{try{return await O("git",["rev-parse","--verify",`${t}^{commit}`],{cwd:e}),!0}catch{return!1}},"isRefReachable"),Y=i(async e=>{try{const{stdout:t}=await O("git",["log","-1","--pretty=%B"],{cwd:e});return t}catch{return""}},"readLastCommitMessage"),A=i((e,t,r)=>W.some(a=>e.includes(`[${a} ${t} ${r}]`)),"matchesPerProjectToken"),ee=i((e,t)=>J.some(r=>e.includes(r))||A(e,"skip",t),"commitHasSkipMessage"),te=i((e,t)=>z.some(r=>e.includes(r))||A(e,"deploy",t),"commitHasForceDeployMessage"),l=i((e,t,r,a)=>({action:"build",message:r,project:e,reason:t,...a}),"decideBuild"),k=i((e,t,r,a)=>({action:"skip",message:r,project:e,reason:t,...a}),"decideSkip"),re=i(e=>`${e.action==="skip"?"🛑":""} ${e.message}`,"formatDecisionLine"),oe=i((e,t)=>e.action==="skip"||t?0:1,"exitCodeFor");var se=Object.defineProperty,_=w((e,t)=>se(e,"name",{value:t,configurable:!0}),"u");const S=new Set(["deep","direct","none"]),de=_(async({argument:e,logger:t,options:r,visConfig:a,workspaceRoot:p})=>{const o=e[0]??"",E=!!r.json,M=!!r.verbose,B=!!(r["exit-zero-on-build"]??r.exitZeroOnBuild),u=_(s=>{M&&!E&&t.info(`❱ ${s}`)},"debug"),n=_(s=>{E?process.stdout.write(`${JSON.stringify(s)}
2
- `):t.info(re(s)),process.exit(oe(s,B))},"emit");if(!o)return n(l("","missing-project-argument","Missing project argument. Usage: vis ignore <project>"));if(!p)return n(l(o,"workspace-error","Could not determine workspace root — building defensively"));const g=await Y(p),y=g.trim().split(`
3
- `)[0]??"";if(u(`commit: ${y}`),g&&te(g,o))return n(l(o,"commit-force-deploy",`Force-deploy keyword in commit: "${y}"`));if(g&&ee(g,o))return n(k(o,"commit-skip",`Skip keyword in commit: "${y}"`));let $,P;try{({packageJsons:P,workspace:$}=q(p,a))}catch(s){const d=s instanceof Error?s.message:String(s);return n(l(o,"workspace-error",`Workspace discovery failed (${d}) — building defensively`))}if(!Object.hasOwn($.projects,o))return n(l(o,"project-unknown",`Project "${o}" not found in workspace — building defensively`));try{const s=r.base?.trim(),d=Q();let c=s||d||"HEAD~1";const m=r.head?.trim()||"HEAD";R(c),R(m),u(`resolved base ref: ${c} (source: ${s?"flag":d?"ci-env":"default"})`);const x=X(p,c),F=L(p,$,P);await x||(u(`base ref ${c} not reachable — falling back to HEAD~1`),c="HEAD~1"),u(`comparing ${c}...${m}`);const j=r.downstream??"deep",b=r.upstream??"none";if(!S.has(j))throw new Error(`Invalid --downstream value: "${j}". Must be "none", "direct", or "deep".`);if(!S.has(b))throw new Error(`Invalid --upstream value: "${b}". Must be "none", "direct", or "deep".`);const H={base:c,downstream:j,head:m,projectGraph:F,projects:$.projects,upstream:b,workspaceRoot:p},f=await G(H);u(`changed files: ${f.changedFiles.length}`),u(`affected projects: ${f.affectedProjects.join(", ")||"(none)"}`);const v={base:c,head:m};return f.changedFiles.length===0?n(k(o,"no-changes",`No files changed between ${c}...${m}`,{...v,affectedProjects:[]})):f.affectedProjects.includes(o)?n(l(o,"project-affected",`Build ${o}: affected by ${f.changedFiles.length} changed file(s)`,{...v,affectedProjects:f.affectedProjects})):n(k(o,"project-not-affected",`Skip ${o}: not affected by changes between ${c}...${m}`,{...v,affectedProjects:f.affectedProjects}))}catch(s){const d=s instanceof Error?s.message:String(s);return t.error(`Affected detection failed: ${d}`),n(l(o,"workspace-error",`Affected detection failed (${d}) — building defensively`))}},"execute");export{de as default};
1
+ var J=Object.defineProperty;var T=(e,t)=>J(e,"name",{value:t,configurable:!0});import{z as S}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{a5 as q,C as b}from"./bin.js";import{f as $}from"../packem_shared/selectors-BE2BCnTR.js";import{o as L}from"../packem_shared/index-DH-5hsrC.js";var M=Object.defineProperty,I=T((e,t)=>M(e,"name",{value:t,configurable:!0}),"p");const D=I((e,t)=>{for(const f of t)if(L(f,e))return!0;return!1},"matchesAny"),z=I((e,t={})=>{const{depTypes:f,excludePatterns:l,externalOnly:y,includePatterns:d,internalOnly:j}=t;if(j&&y)return[];const u=f&&f.length>0?new Set(f):void 0,N=d&&d.length>0?d:void 0,O=l&&l.length>0?l:void 0,w=[];for(const m of e)j&&!m.isInternal||y&&m.isInternal||u&&!u.has(m.depType)||N&&(!m.packageName||!D(m.packageName,N))||O&&m.packageName&&D(m.packageName,O)||w.push(m);return w},"filterDepInstances");var B=Object.defineProperty,v=T((e,t)=>B(e,"name",{value:t,configurable:!0}),"y");const F=new Set(["json","ndjson","table"]),R=v(e=>{if(e===void 0)return"table";const t=e.toLowerCase();if(!F.has(t))throw new Error(`--format must be one of: table, json, ndjson (got "${e}")`);return t},"resolveFormat"),x=v((e,t)=>({depName:e.depName,depType:e.depType,isInternal:e.isInternal,packageDir:e.packageDir,packageJsonPath:S(t,e.packageJsonPath),packageName:e.packageName,specifier:e.specifier}),"toDepRecord"),P=new Set(["dependencies","devDependencies","optionalDependencies","overrides","peerDependencies","pnpm.overrides","resolutions"]),V=v(e=>{if(!e||e.length===0)return;const t=[],f=[];for(const l of e)for(const y of l.split(",")){const d=y.trim();d&&(P.has(d)?t.push(d):f.push(d))}if(f.length>0)throw new Error(`Unknown --dep-type value(s): ${f.join(", ")}. Valid: ${[...P].join(", ")}`);return t.length>0?t:void 0},"parseDepTypes"),H=v(async({logger:e,options:t,visConfig:f,workspaceRoot:l})=>{if(!l)throw new Error("Could not determine workspace root.");const y=R(t.format);if(t.deps===!0){if(t.internalOnly&&t.externalOnly)throw new Error("--internal-only and --external-only are mutually exclusive");const c=V(t.depType),i=q(l);let n=z(i,{depTypes:c,excludePatterns:t.exclude,externalOnly:t.externalOnly,includePatterns:t.include,internalOnly:t.internalOnly});if(t.query){const{workspace:r}=b(l,f),p=new Set($(Object.keys(r.projects),r,t.query));n=n.filter(k=>k.packageName!==void 0&&p.has(k.packageName))}const g=[...n].sort((r,p)=>{const k=`${r.packageName??r.packageDir} ${r.depType} ${r.depName}`,E=`${p.packageName??p.packageDir} ${p.depType} ${p.depName}`;return k.localeCompare(E)});if(y==="ndjson"){for(const r of g)e.info(JSON.stringify(x(r,l)));return}if(y==="json"){const r=g.map(p=>x(p,l));e.info(JSON.stringify(r,null,t.pretty===!0?2:void 0));return}if(g.length===0){e.info("No matching dep-instances.");return}const a=["Package","Block","Dep","Specifier","Internal","Path"],o=g.map(r=>[r.packageName??r.packageDir,r.depType,r.depName,r.specifier,r.isInternal?"yes":"no",S(l,r.packageJsonPath)]),s=a.map((r,p)=>Math.max(r.length,...o.map(k=>(k[p]??"").length))),h=v((r,p)=>r.padEnd(p),"pad");e.info(a.map((r,p)=>h(r,s[p])).join(" ")),e.info(s.map(r=>"".repeat(r)).join("──"));for(const r of o)e.info(r.map((p,k)=>h(p,s[k])).join(" "));e.info(""),e.info(`${String(g.length)} dep-instance(s)`);return}if(y==="ndjson")throw new Error("--format=ndjson is only supported with --deps");const{projectOptions:d,workspace:j}=b(l,f);let u=Object.keys(j.projects).sort();if(t.query&&(u=$(u,j,t.query)),u.length===0){e.info("No projects found.");return}const N=t.inferred===!0,O=t.targets===!0||N;if(y==="json"){const c=u.map(i=>{const n=j.projects[i],g=d.get(i)??{},a=Object.entries(n.targets??{}).map(([o])=>{const s=g[o],h=s?.inferred===!0;return{aliases:s?.aliases??[],command:s?.command,description:s?.description,...h?{inferred:!0}:{},name:o,type:s?.type}}).filter(o=>!N||o.inferred===!0);return{language:n.language,layer:n.layer,name:i,root:n.root,stack:n.stack,tags:n.tags??[],targets:a,type:n.projectType??"library"}});e.info(JSON.stringify(c,null,2));return}const w=v((c,i)=>{const n=c.map((a,o)=>{let s=0;for(const h of i)s=Math.max(s,(h[o]??"").length);return Math.max(a.length,s)}),g=v((a,o)=>a.padEnd(o),"pad");e.info(c.map((a,o)=>g(a,n[o])).join(" ")),e.info(n.map(a=>"".repeat(a)).join("──"));for(const a of i)e.info(a.map((o,s)=>g(o,n[s])).join(" "))},"renderTable");if(O){const c=[];for(const i of u){const n=j.projects[i],g=d.get(i)??{};for(const a of Object.keys(n.targets??{}).sort()){const o=g[a],s=o?.inferred===!0;if(N&&!s)continue;const h=n.targets?.[a],r=h?.cache===!1?"no":h?.cache===!0?"yes":"default";c.push([i,a,o?.type??"",r,s?"yes":"no",o?.description??"—"])}}if(c.length===0){e.info(N?"No inferred targets found.":"No targets found.");return}w(["Project","Target","Type","Cache","Inferred","Description"],c),e.info(""),e.info(`${String(c.length)} target(s) across ${String(u.length)} project(s)`);return}const m=["Project","Type","Layer","Tags","Targets"],C=u.map(c=>{const i=j.projects[c],n=Object.keys(i.targets??{});return[c,i.projectType??"library",i.layer??"—",(i.tags??[]).join(", ")||"—",n.length>4?`${n.slice(0,4).join(", ")}… (${String(n.length)})`:n.join(", ")||"—"]});w(m,C),e.info(""),e.info(`${String(u.length)} project(s)`)},"execute");export{H as default};
@@ -1 +1,26 @@
1
- var J=Object.defineProperty;var T=(e,t)=>J(e,"name",{value:t,configurable:!0});import{z as S}from"./config.js";import{an as q,C as b}from"./bin.js";import{f as $}from"../packem_shared/selectors-B2ISH581.js";import{o as L}from"../packem_shared/index-DH-5hsrC.js";var M=Object.defineProperty,I=T((e,t)=>M(e,"name",{value:t,configurable:!0}),"p");const D=I((e,t)=>{for(const f of t)if(L(f,e))return!0;return!1},"matchesAny"),z=I((e,t={})=>{const{depTypes:f,excludePatterns:l,externalOnly:y,includePatterns:d,internalOnly:j}=t;if(j&&y)return[];const u=f&&f.length>0?new Set(f):void 0,N=d&&d.length>0?d:void 0,O=l&&l.length>0?l:void 0,w=[];for(const m of e)j&&!m.isInternal||y&&m.isInternal||u&&!u.has(m.depType)||N&&(!m.packageName||!D(m.packageName,N))||O&&m.packageName&&D(m.packageName,O)||w.push(m);return w},"filterDepInstances");var B=Object.defineProperty,v=T((e,t)=>B(e,"name",{value:t,configurable:!0}),"y");const F=new Set(["json","ndjson","table"]),R=v(e=>{if(e===void 0)return"table";const t=e.toLowerCase();if(!F.has(t))throw new Error(`--format must be one of: table, json, ndjson (got "${e}")`);return t},"resolveFormat"),x=v((e,t)=>({depName:e.depName,depType:e.depType,isInternal:e.isInternal,packageDir:e.packageDir,packageJsonPath:S(t,e.packageJsonPath),packageName:e.packageName,specifier:e.specifier}),"toDepRecord"),P=new Set(["dependencies","devDependencies","optionalDependencies","overrides","peerDependencies","pnpm.overrides","resolutions"]),V=v(e=>{if(!e||e.length===0)return;const t=[],f=[];for(const l of e)for(const y of l.split(",")){const d=y.trim();d&&(P.has(d)?t.push(d):f.push(d))}if(f.length>0)throw new Error(`Unknown --dep-type value(s): ${f.join(", ")}. Valid: ${[...P].join(", ")}`);return t.length>0?t:void 0},"parseDepTypes"),H=v(async({logger:e,options:t,visConfig:f,workspaceRoot:l})=>{if(!l)throw new Error("Could not determine workspace root.");const y=R(t.format);if(t.deps===!0){if(t.internalOnly&&t.externalOnly)throw new Error("--internal-only and --external-only are mutually exclusive");const c=V(t.depType),i=q(l);let n=z(i,{depTypes:c,excludePatterns:t.exclude,externalOnly:t.externalOnly,includePatterns:t.include,internalOnly:t.internalOnly});if(t.query){const{workspace:r}=b(l,f),p=new Set($(Object.keys(r.projects),r,t.query));n=n.filter(k=>k.packageName!==void 0&&p.has(k.packageName))}const g=[...n].sort((r,p)=>{const k=`${r.packageName??r.packageDir} ${r.depType} ${r.depName}`,E=`${p.packageName??p.packageDir} ${p.depType} ${p.depName}`;return k.localeCompare(E)});if(y==="ndjson"){for(const r of g)e.info(JSON.stringify(x(r,l)));return}if(y==="json"){const r=g.map(p=>x(p,l));e.info(JSON.stringify(r,null,t.pretty===!0?2:void 0));return}if(g.length===0){e.info("No matching dep-instances.");return}const a=["Package","Block","Dep","Specifier","Internal","Path"],o=g.map(r=>[r.packageName??r.packageDir,r.depType,r.depName,r.specifier,r.isInternal?"yes":"no",S(l,r.packageJsonPath)]),s=a.map((r,p)=>Math.max(r.length,...o.map(k=>(k[p]??"").length))),h=v((r,p)=>r.padEnd(p),"pad");e.info(a.map((r,p)=>h(r,s[p])).join(" ")),e.info(s.map(r=>"".repeat(r)).join("──"));for(const r of o)e.info(r.map((p,k)=>h(p,s[k])).join(" "));e.info(""),e.info(`${String(g.length)} dep-instance(s)`);return}if(y==="ndjson")throw new Error("--format=ndjson is only supported with --deps");const{projectOptions:d,workspace:j}=b(l,f);let u=Object.keys(j.projects).sort();if(t.query&&(u=$(u,j,t.query)),u.length===0){e.info("No projects found.");return}const N=t.inferred===!0,O=t.targets===!0||N;if(y==="json"){const c=u.map(i=>{const n=j.projects[i],g=d.get(i)??{},a=Object.entries(n.targets??{}).map(([o])=>{const s=g[o],h=s?.inferred===!0;return{aliases:s?.aliases??[],command:s?.command,description:s?.description,...h?{inferred:!0}:{},name:o,type:s?.type}}).filter(o=>!N||o.inferred===!0);return{language:n.language,layer:n.layer,name:i,root:n.root,stack:n.stack,tags:n.tags??[],targets:a,type:n.projectType??"library"}});e.info(JSON.stringify(c,null,2));return}const w=v((c,i)=>{const n=c.map((a,o)=>{let s=0;for(const h of i)s=Math.max(s,(h[o]??"").length);return Math.max(a.length,s)}),g=v((a,o)=>a.padEnd(o),"pad");e.info(c.map((a,o)=>g(a,n[o])).join(" ")),e.info(n.map(a=>"".repeat(a)).join("──"));for(const a of i)e.info(a.map((o,s)=>g(o,n[s])).join(" "))},"renderTable");if(O){const c=[];for(const i of u){const n=j.projects[i],g=d.get(i)??{};for(const a of Object.keys(n.targets??{}).sort()){const o=g[a],s=o?.inferred===!0;if(N&&!s)continue;const h=n.targets?.[a],r=h?.cache===!1?"no":h?.cache===!0?"yes":"default";c.push([i,a,o?.type??"",r,s?"yes":"no",o?.description??""])}}if(c.length===0){e.info(N?"No inferred targets found.":"No targets found.");return}w(["Project","Target","Type","Cache","Inferred","Description"],c),e.info(""),e.info(`${String(c.length)} target(s) across ${String(u.length)} project(s)`);return}const m=["Project","Type","Layer","Tags","Targets"],C=u.map(c=>{const i=j.projects[c],n=Object.keys(i.targets??{});return[c,i.projectType??"library",i.layer??"—",(i.tags??[]).join(", ")||"—",n.length>4?`${n.slice(0,4).join(", ")}… (${String(n.length)})`:n.join(", ")||"—"]});w(m,C),e.info(""),e.info(`${String(u.length)} project(s)`)},"execute");export{H as default};
1
+ var Se=Object.defineProperty;var D=(e,t)=>Se(e,"name",{value:t,configurable:!0});import{createRequire as Ae}from"node:module";import{e as G,T as me}from"../packem_shared/index.server-B7ETiT4C.js";import{M as W,i as V,$ as Te}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{o as oe,a8 as Ne,F as N,a9 as Me,W as Ue,G as je,H as fe,aa as Fe,ab as he,i as X,c as _e,R as qe,b as Be,V as Le,ac as Oe,K as Pe,ad as Ie,s as ve,U as De,ae as We,af as Ve,ag as Ge,ah as He}from"./bin.js";import{render as re,renderToString as Q}from"@visulima/tui";import{Text as C}from"@visulima/tui/components/text";import k from"react";import{H as Ye,e as ze,Z as ie}from"../packem_shared/ai-analysis-B8pDCOuT.js";import{k as Ze,I as Je}from"../packem_shared/pm-runner-CVliR6Ie.js";import{r as Ke,b as Xe,p as Qe}from"../packem_shared/resolve-explicit-2G-2HWtR.js";import{r as et,s as tt}from"../packem_shared/typosquats-CioMnpnb.js";import{U as nt,C as at,a as le}from"../packem_shared/vis-update-app-BWA1kA1q.js";import{d as st}from"../packem_shared/utils-DrNg0XTR.js";const xe=Ae(import.meta.url),_=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,pe=D(e=>{if(typeof _<"u"&&_.versions&&_.versions.node){const[t,n]=_.versions.node.split(".").map(Number);if(t>22||t===22&&n>=3||t===20&&n>=16)return _.getBuiltinModule(e)}return xe(e)},"__cjs_getBuiltinModule"),{execFileSync:ge}=pe("node:child_process"),{createInterface:Ee}=pe("node:readline");var ot=Object.defineProperty,x=D((e,t)=>ot(e,"name",{value:t,configurable:!0}),"s");const rt=x(e=>{const t=[];for(const n of e.filters)t.push("--filter",n);return e.workspaceRoot&&t.push("--filter","."),t.push("update"),e.latest&&t.push("--latest"),e.recursive&&t.push("--recursive"),e.interactive&&t.push("--interactive"),e.dev&&t.push("--dev"),e.prod&&t.push("--prod"),e.noOptional&&t.push("--no-optional"),e.noSave&&t.push("--no-save"),t.push(...e.packages),{args:t,bin:"pnpm"}},"resolvePnpm"),it=x(e=>{const t=[];return e.filters.length>0&&t.push("workspace",e.filters[0]),t.push("upgrade"),e.latest&&t.push("--latest"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnV1"),lt=x(e=>{const t=[];if(e.filters.length>0||e.recursive){t.push("workspaces","foreach","--all");for(const n of e.filters)t.push("--include",n)}return t.push("up"),e.interactive&&t.push("--interactive"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnBerry"),ct=x((e,t)=>{const n=["update"];e.latest&&t.push("npm does not support --latest flag. Packages will be updated within their semver range."),e.interactive&&t.push("npm does not support --interactive mode.");for(const a of e.filters)n.push("--workspace",a);return e.recursive&&n.push("--workspaces"),e.workspaceRoot&&n.push("--include-workspace-root"),e.dev&&n.push("--dev"),e.prod&&n.push("--production"),e.noOptional&&n.push("--no-optional"),e.noSave&&n.push("--no-save"),n.push(...e.packages),{args:n,bin:"npm"}},"resolveNpm"),ut=x(e=>{const t=["update"];e.latest&&t.push("--latest");for(const n of e.filters)t.push("--filter",n);return t.push(...e.packages),{args:t,bin:"bun"}},"resolveBun"),dt=x((e,t)=>{const n=["outdated","--update"];return e.latest&&n.push("--latest"),e.interactive&&n.push("--interactive"),e.filters.length>0&&t.push("deno outdated has no --filter flag; ignoring."),(e.dev||e.prod)&&t.push("deno outdated has no --dev / --prod flags; dev/prod is governed by deno.json."),e.noOptional&&t.push("deno outdated has no --no-optional flag; ignoring."),e.noSave&&t.push("deno outdated has no --no-save flag; ignoring."),n.push(...e.packages),{args:n,bin:"deno"}},"resolveDeno"),pt=x((e,t,n)=>{const a=[];if(n.global&&e!=="aube"&&e!=="deno")return{command:{args:["update","--global",...n.packages],bin:"npm"},warnings:a};let o;switch(e){case"aube":{const s=Ze(n);o={args:s.args,bin:s.bin},a.push(...s.warnings);break}case"bun":{o=ut(n);break}case"deno":{o=dt(n,a);break}case"npm":{o=ct(n,a);break}case"pnpm":{o=rt(n);break}case"yarn":{o=t.startsWith("1.")?it(n):lt(n);break}default:{const s=e;throw new Error(`Unsupported package manager: ${String(s)}`)}}return{command:o,warnings:a}},"resolveUpdateCommand");var gt=Object.defineProperty,$=D((e,t)=>gt(e,"name",{value:t,configurable:!0}),"y");const $e=$(e=>{const t=e.trim();if(t==="")return;const n=/^(\d+(?:\.\d+)?)\s*([mhdw])?$/i.exec(t);if(!n)return;const a=Number.parseFloat(n[1]);if(!(!Number.isFinite(a)||a<0))switch((n[2]??"m").toLowerCase()){case"d":return a*60*24;case"h":return a*60;case"m":return a;case"w":return a*60*24*7;default:return}},"parseTimeStringToMinutes"),mt=$(e=>{const t=e.trim();return/^\d+(?:\.\d+)?$/.test(t)?Number.parseFloat(t)*1440:$e(t)},"parseNpmReleaseAgeValue"),Ft=$(e=>!Number.isFinite(e)||e<=0?"0m":e%1440===0?`${String(e/1440)}d`:e%60===0?`${String(e/60)}h`:`${String(e)}m`,"formatMinutesAsTimeString"),ft=$((e,t)=>{try{switch(t){case"bun":{const n=W(e,"bunfig.toml");if(V(n)){const a=Ne(n),o=a?.install?.minimumReleaseAge;return{excludes:Array.isArray(a?.install?.minimumReleaseAgeExcludes)?a.install.minimumReleaseAgeExcludes:void 0,minutes:typeof o=="number"?Math.round(o/60):void 0}}break}case"npm":{const n=W(e,".npmrc");if(V(n)){const a=Te(n),o=/^\s*min-release-age\s*=\s*([^\s#;]+)/m.exec(a);return{minutes:o?mt(o[1]):void 0}}break}case"pnpm":{const n=W(e,"pnpm-workspace.yaml");if(V(n)){const a=oe(n);return{excludes:Array.isArray(a?.minimumReleaseAgeExclude)?a.minimumReleaseAgeExclude:void 0,minutes:typeof a?.minimumReleaseAge=="number"?a.minimumReleaseAge:void 0}}break}case"yarn":{const n=W(e,".yarnrc.yml");if(V(n)){const a=oe(n)?.npmMinimalAgeGate;if(typeof a=="string")return{minutes:$e(a)};if(typeof a=="number")return{minutes:a}}break}}}catch{}return{}},"readPmNativeMinimumReleaseAge"),ht=$((e,t,n)=>{const a=e.latest?"latest":e.target??t.target??"latest";if(!["latest","minor","patch"].includes(a))throw new Error(`Invalid target "${a}". Use: latest, minor, or patch.`);const o=e.maxConcurrentRequests,s=typeof o=="number"&&o>0?o:t.maxConcurrentRequests,i=typeof e.releaseChannel=="string"?e.releaseChannel.toLowerCase():void 0;if(i!==void 0&&!["any","same","stable"].includes(i))throw new Error(`Invalid --release-channel "${String(e.releaseChannel)}". Use: any, same, or stable.`);const p=i??t.releaseChannel;return{exclude:[...N(e.exclude),...N(t.exclude)],ignore:N(t.ignore),include:[...N(e.include),...N(t.include),...n],includeLocked:e.includeLocked||t.includeLocked||!1,includePrerelease:e.prerelease||t.prerelease||!1,maxConcurrentRequests:s,minimumReleaseAge:t.minimumReleaseAge,minimumReleaseAgeExclude:t.minimumReleaseAgeExclude,packageMode:t.packageMode,releaseChannel:p,security:e.security===!1?!1:e.ai||(t.security??!0),target:a}},"buildCatalogCheckOptions"),ce=$((e,t)=>{if(e.length!==0){t.info(`
2
+ ${G("⚠")} ${String(e.length)} package${e.length===1?"":"s"} skipped by target constraint (use --target latest to include):`);for(const n of e)t.info(` ${n.packageName} ${n.currentRange} → ${n.newRange} (${n.updateType})`)}},"logFilteredByTarget"),ue=$((e,t,n,a,o)=>{n==="json"?process.stdout.write(`${Me({checkedCount:0,failed:t,filteredByTarget:[],ignored:[],outdated:e})}
3
+ `):n==="minimal"?process.stdout.write(`${Ue(e)}
4
+ `):(je(e,a),a.info(fe(e,o)))},"writeFormattedOutput"),de=$(async(e,t,n,a,o,s,i)=>{const p=Fe(e,n,t,!0,{useEditorconfig:i}),g=t==="pnpm"?"pnpm-workspace.yaml":"package.json";if(o.info(`
5
+ Updated ${g}`),p&&o.info(`Backup saved to ${p}`),a.changelog){o.info(`
6
+ Fetching changelogs...`);const m=await he(n,void 0,s);for(const l of m){const f=l.releaseUrl??l.repoUrl??l.npmUrl;o.info(` ${l.packageName}: ${f}`)}}if(a.install??!0){const m=t,l=["install"];o.info(`Running ${m} ${l.join(" ")}...
7
+ `);try{ge(m,l,{cwd:e,env:process.env,stdio:"inherit"})}catch{o.warn(`${m} ${l.join(" ")} failed. You may need to run it manually.`)}}},"applyCatalogAndInstall"),vt=$(async(e,t,n,a,o,s)=>{const i=n.update??{},p=[["global","--global is not supported in catalog mode"],["recursive","--recursive is not needed in catalog mode (catalogs are workspace-level)"],["filter","--filter is not supported in catalog mode (use --include/--exclude instead)"],["no-save","--no-save is not supported in catalog mode"],["workspace-root","--workspace-root is not needed in catalog mode"],["no-optional","--no-optional is not supported in catalog mode"]];for(const[r,c]of p)a[r]&&s.warn(`${G("⚠")} ${c}, ignoring.`);const g=X("minReleaseAge"),{excludes:m,minutes:l}=g?{excludes:void 0,minutes:void 0}:ft(e,t),f=g?void 0:i.minimumReleaseAge??l,q=g?void 0:i.minimumReleaseAgeExclude??m;if(g&&(i.minimumReleaseAge!==void 0||l!==void 0)&&s.info("minimumReleaseAge gate disabled via MARSHALL_DISABLE_MIN_RELEASE_AGE."),!g&&i.minimumReleaseAge!==void 0&&l!==void 0&&i.minimumReleaseAge!==l){const r=t==="pnpm"?"pnpm-workspace.yaml":"bunfig.toml";s.warn(`${G("⚠")} minimumReleaseAge mismatch: vis config = ${String(i.minimumReleaseAge)} min, ${r} = ${String(l)} min. Consider keeping them in sync.`)}const b=_e(e),ee=a["include-internal"],te=a.peer,M=qe(e,t,{depFields:i.depFields,dev:a.dev,includeInternal:ee,peer:te,prod:a.prod});if(M.size===0){s.info("No catalogs found.");return}const ke={...i,minimumReleaseAge:f,minimumReleaseAgeExclude:q},E=ht(a,ke,o);let H=0;for(const r of M.values())H+=r.size;const B=!!process.stdout.isTTY&&!ve;let T;const we=B?(r,c)=>{T?T.rerender(k.createElement(le,{current:r,total:c})):(process.stdout.write(`
8
+ `),T=re(k.createElement(le,{current:r,total:c}),{interactive:!0,patchConsole:!1}))}:(r,c)=>{s.info(`Checking ${String(r)}/${String(c)} dependencies...`)};B||s.info(`Checking ${String(H)} catalog dependencies...
9
+ `);const Y=new Set;X("socket")&&Y.add("socket"),X("depsDev")&&Y.add("deps-dev");const L=n.security?.policies?.score?.minimum,ye=Be(n.security,{disabled:Y,minimumScore:L}),{checkedCount:w,failed:y,filteredByTarget:h,ignored:S,outdated:d}=await Le(M,E,b,we,e,ye,n.security?.acceptedRisks);T&&(T.clear(),T.unmount());const O=ee?{ignored:[],outdated:[]}:Oe(e,{depFields:i.depFields,dev:a.dev,exclude:E.exclude,ignore:E.ignore,include:E.include,packageMode:E.packageMode,peer:te,prod:a.prod,target:E.target});if(O.outdated.length>0){const r=new Set(d.map(c=>`${c.catalogName}|${c.packageName}`));for(const c of O.outdated)r.has(`${c.catalogName}|${c.packageName}`)||d.push(c)}if(O.ignored.length>0)for(const r of O.ignored)S.includes(r)||S.push(r);const ne=w-d.length-y.length;if(y.length>0&&s.warn(`Failed to fetch: ${y.join(", ")}`),S.length>0&&s.info(`Skipped ${String(S.length)} ignored package${S.length===1?"":"s"}: ${S.join(", ")}`),!B&&w>d.length){const r=[...M.values()].reduce((F,z)=>F+z.size,0),c=r>w?` (${String(r)} catalog entries, ${String(r-w)} duplicates)`:"";s.info(`Checked ${String(w)} unique packages${c}: ${String(d.length)} outdated, ${String(ne)} up-to-date${y.length>0?`, ${String(y.length)} failed`:""}${h.length>0?`, ${String(h.length)} skipped by target`:""}`)}if(d.length===0){h.length>0?s.info(`All catalog dependencies are up to date within the current target.
10
+ ${String(h.length)} package${h.length===1?" has":"s have"} newer versions available with --target latest:
11
+ ${h.map(r=>` ${r.packageName} ${r.currentRange} → ${r.newRange} (${r.updateType})`).join(`
12
+ `)}`):s.info("All catalog dependencies are up to date.");return}const U=a.format??i.format??"table";let R;if(a.ai){const r=Ye(a.aiType??"impact");R=await ze(d,s,n.ai,r)}const P=!!a.dryRun;if(!P&&o.length>0&&a.marshallCheck!==!1){const r=await Ke(o);if(r.length>0){const c=await Xe(r,{config:n?.security?.marshalls,workspaceRoot:e});if(!await Qe(c)){process.exitCode=1;return}}}if(B&&U==="table"){const r=new nt(d,R??null);let c;if(a.changelog){s.info("Fetching changelogs...");const u=await he(d,void 0,b);c=new Map;for(const v of u){const A=v.releaseUrl??v.repoUrl??v.npmUrl;A&&c.set(v.packageName,A)}}const F=n.tui?.autoExit??!1,z=F===!0?3:typeof F=="number"?F:0,ae=await re(k.createElement(at,{autoExitSeconds:z,changelogUrls:c,checkedCount:w,filteredOutEntries:h,isDryRun:P,store:r,totalCatalogEntries:H}),{alternateScreen:!0,exitOnCtrlC:!1,interactive:!0,patchConsole:!0}).waitUntilExit(),Z=process.stdout.columns||80;process.stdout.write(`
13
+ `);for(const u of d){const v=u.vulnerabilities?.length||u.socketReport&&u.socketReport.alerts.length>0,A=!!u.acceptedRisk,K=v?A?"✓":"⚠":"✓",Re=A?"gray":u.updateType==="major"?"red":u.updateType==="minor"?"yellow":"green",I=u.socketReport?.score.overall,Ce=I===void 0?"":` [${String(Math.round(I*100))}%]`,se=I===void 0?void 0:Pe(I);process.stdout.write(`${Q(k.createElement(C,null," ",k.createElement(C,{color:Re},K),` ${u.packageName} ${u.currentRange} → ${u.newRange}`,k.createElement(C,{dimColor:!0},` ${u.updateType}`),se?k.createElement(C,{color:se},Ce):null),{columns:Z})}
14
+ `)}if(process.stdout.write(`
15
+ `),s.info(fe(d,L)),w>d.length){const u=[...M.values()].reduce((A,K)=>A+K.size,0),v=u>w?` (${String(u)} catalog entries, ${String(u-w)} duplicates)`:"";s.log(),s.info(`Checked ${String(w)} unique packages${v}: ${String(ne)} up-to-date${y.length>0?`, ${String(y.length)} failed`:""}`)}if(h.length>0){process.stdout.write(`
16
+ `);const u=`${String(h.length)} package${h.length===1?"":"s"} skipped by target constraint (use --target latest to include):`;process.stdout.write(`${Q(k.createElement(C,{color:"yellow"},` ${u}`),{columns:Z})}
17
+ `);for(const v of h)process.stdout.write(`${Q(k.createElement(C,null," ",k.createElement(C,{dimColor:!0},v.packageName),` ${v.currentRange} → ${v.newRange}`,k.createElement(C,{dimColor:!0},` ${v.updateType}`)),{columns:Z})}
18
+ `)}const J=Array.isArray(ae)?ae:[];if(J.length>0&&!P){s.info(`
19
+ Applying ${String(J.length)} updates...
20
+ `);const u={...a,install:a.install??i.install};await de(e,t,J,u,s,b,n.editorconfig??!0)}return}if(P){if(U==="json"){const r={failed:y,filteredByTarget:h,ignored:S,outdated:d};R&&(r.aiAnalysis=R),process.stdout.write(`${JSON.stringify(r,void 0,2)}
21
+ `)}else s.info(`Would update ${String(d.length)} dependencies:
22
+ `),ue(d,y,U,s,L),R&&(s.info(""),s.info(ie(R))),ce(h,s);return}R&&U!=="json"&&(s.info(ie(R)),s.info(""));let j=d;if(a.interactive&&(j=await Ie(d),j.length===0)){s.info("No updates selected.");return}s.info(`Updating ${String(j.length)} catalog dependencies...
23
+ `),ue(j,[],U,s,L),ce(h,s);const be={...a,install:a.install??i.install};await de(e,t,j,be,s,b)},"executeCatalogUpdate"),$t=$((e,t,n,a,o,s)=>{const i={dev:a.dev,filters:N(a.filter),global:a.global,interactive:a.interactive,latest:a.latest||a.target==="latest",noOptional:a.optional===!1,noSave:a.save===!1,packages:o,prod:a.prod,recursive:a.recursive,workspaceRoot:a.workspaceRoot},{command:p,warnings:g}=pt(t,n,i);for(const l of g)s.warn(l);const m=`${p.bin} ${p.args.join(" ")}`.trim();if(a.dryRun){s.info(`Would run: ${m}`);return}s.info(`Running: ${m}`);try{ge(p.bin,p.args,{cwd:e,env:process.env,stdio:"inherit"})}catch(l){const f=l.status??1;s.error(`
24
+ ${me("✖")} Update failed (exit code ${String(f)})`),s.error(` Command: ${m}`),s.error(` Directory: ${e}
25
+ `),process.exitCode=f}},"executePmWrapper"),kt=$(async(e,t,n)=>{const a=e.latest===!0||e.target==="latest";if(t||!a||e.dryRun===!0||e.yes===!0||e.interactive===!0)return!0;if(!(process.stdout.isTTY&&!ve))return n.error(`${me("✖")} Refusing to run blanket --latest update in a non-interactive context.`),n.error(" Re-run with --yes to confirm, --dry-run to preview, or pass explicit package names."),process.exitCode=1,!1;const o=Ee({input:process.stdin,output:process.stdout});try{const s=(await new Promise(i=>{o.question(`${G("⚠")} About to upgrade ALL dependencies to their latest versions. This may include breaking changes.
26
+ Continue? [y/N] `,i)})).trim().toLowerCase();return s==="y"||s==="yes"?!0:(n.info("Aborted."),!1)}finally{o.close()}},"requireBlanketUpdateConfirmation"),_t=$(async({argument:e,logger:t,options:n,visConfig:a,workspaceRoot:o})=>{if(!o)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");let s=e;const i=o,{packageManager:p}=De(i);if(n.typosquatCheck!==!1){if(s.length>0){const g=s.map(f=>st(f)),m=a?.security?.typosquatAllowlist,l=await et(g.map(f=>f.name),m);if(!l.ok){process.exitCode=1;return}s=g.map((f,q)=>{const b=l.packages[q];return b!==f.name?f.versionSpec?`${b}@${f.versionSpec}`:b??"":s[q]??""})}else if(!await tt(i,a?.security?.typosquatAllowlist)){process.exitCode=1;return}}if(n.rollback){if(!We(i,p)){t.info("No backup found. Run 'vis update' first to create a backup.");return}if(Ve(i,p))t.info("Restored from backup.");else throw new Error("Failed to restore from backup.");return}if(await kt(n,s.length>0,t))if(n.catalog!==!1&&Ge(i,p))await vt(i,p,a??{},n,s,t);else{const g=Je(i,{configBackend:a?.install?.backend,configCorepack:a?.install?.corepack}),m=g.name==="aube"?"":He(g.name);$t(i,g.name,m,n,s,t)}},"execute");export{_t as default,Ft as formatMinutesAsTimeString,mt as parseNpmReleaseAgeValue,$e as parseTimeStringToMinutes,ft as readPmNativeMinimumReleaseAge,kt as requireBlanketUpdateConfirmation};
@@ -1,26 +1,5 @@
1
- var Se=Object.defineProperty;var D=(e,t)=>Se(e,"name",{value:t,configurable:!0});import{createRequire as Ae}from"node:module";import{aq as Te,o as oe,ar as Ne,F as N,e as z,as as Me,W as Ue,G as je,H as me,at as Fe,au as fe,i as X,d as qe,R as _e,b as Be,V as Le,av as Oe,K as Pe,aw as Ie,s as he,a as ve,U as De,ax as We,ay as Ve,az as ze,g as Ge,aA as He}from"./bin.js";import{M as W,i as V,$ as Ye}from"./config.js";import{render as re,renderToString as Q}from"@visulima/tui";import{Text as C}from"@visulima/tui/components/text";import k from"react";import{H as Ze,e as Je,Z as ie}from"../packem_shared/ai-analysis-DGBZYlxF.js";import{r as Ke,b as Xe,p as Qe}from"../packem_shared/resolve-explicit-BgFQHUEP.js";import{r as et,s as tt}from"../packem_shared/typosquats-CJ4o1l7U.js";import{U as nt,C as at,a as le}from"../packem_shared/vis-update-app-Bnu1EIgE.js";import{d as st}from"../packem_shared/utils-DrNg0XTR.js";const xe=Ae(import.meta.url),q=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,pe=D(e=>{if(typeof q<"u"&&q.versions&&q.versions.node){const[t,n]=q.versions.node.split(".").map(Number);if(t>22||t===22&&n>=3||t===20&&n>=16)return q.getBuiltinModule(e)}return xe(e)},"__cjs_getBuiltinModule"),{execFileSync:ge}=pe("node:child_process"),{createInterface:Ee}=pe("node:readline");var ot=Object.defineProperty,x=D((e,t)=>ot(e,"name",{value:t,configurable:!0}),"s");const rt=x(e=>{const t=[];for(const n of e.filters)t.push("--filter",n);return e.workspaceRoot&&t.push("--filter","."),t.push("update"),e.latest&&t.push("--latest"),e.recursive&&t.push("--recursive"),e.interactive&&t.push("--interactive"),e.dev&&t.push("--dev"),e.prod&&t.push("--prod"),e.noOptional&&t.push("--no-optional"),e.noSave&&t.push("--no-save"),t.push(...e.packages),{args:t,bin:"pnpm"}},"resolvePnpm"),it=x(e=>{const t=[];return e.filters.length>0&&t.push("workspace",e.filters[0]),t.push("upgrade"),e.latest&&t.push("--latest"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnV1"),lt=x(e=>{const t=[];if(e.filters.length>0||e.recursive){t.push("workspaces","foreach","--all");for(const n of e.filters)t.push("--include",n)}return t.push("up"),e.interactive&&t.push("--interactive"),t.push(...e.packages),{args:t,bin:"yarn"}},"resolveYarnBerry"),ct=x((e,t)=>{const n=["update"];e.latest&&t.push("npm does not support --latest flag. Packages will be updated within their semver range."),e.interactive&&t.push("npm does not support --interactive mode.");for(const a of e.filters)n.push("--workspace",a);return e.recursive&&n.push("--workspaces"),e.workspaceRoot&&n.push("--include-workspace-root"),e.dev&&n.push("--dev"),e.prod&&n.push("--production"),e.noOptional&&n.push("--no-optional"),e.noSave&&n.push("--no-save"),n.push(...e.packages),{args:n,bin:"npm"}},"resolveNpm"),ut=x(e=>{const t=["update"];e.latest&&t.push("--latest");for(const n of e.filters)t.push("--filter",n);return t.push(...e.packages),{args:t,bin:"bun"}},"resolveBun"),dt=x((e,t)=>{const n=["outdated","--update"];return e.latest&&n.push("--latest"),e.interactive&&n.push("--interactive"),e.filters.length>0&&t.push("deno outdated has no --filter flag; ignoring."),(e.dev||e.prod)&&t.push("deno outdated has no --dev / --prod flags; dev/prod is governed by deno.json."),e.noOptional&&t.push("deno outdated has no --no-optional flag; ignoring."),e.noSave&&t.push("deno outdated has no --no-save flag; ignoring."),n.push(...e.packages),{args:n,bin:"deno"}},"resolveDeno"),pt=x((e,t,n)=>{const a=[];if(n.global&&e!=="aube"&&e!=="deno")return{command:{args:["update","--global",...n.packages],bin:"npm"},warnings:a};let o;switch(e){case"aube":{const s=Te(n);o={args:s.args,bin:s.bin},a.push(...s.warnings);break}case"bun":{o=ut(n);break}case"deno":{o=dt(n,a);break}case"npm":{o=ct(n,a);break}case"pnpm":{o=rt(n);break}case"yarn":{o=t.startsWith("1.")?it(n):lt(n);break}default:{const s=e;throw new Error(`Unsupported package manager: ${String(s)}`)}}return{command:o,warnings:a}},"resolveUpdateCommand");var gt=Object.defineProperty,$=D((e,t)=>gt(e,"name",{value:t,configurable:!0}),"y");const $e=$(e=>{const t=e.trim();if(t==="")return;const n=/^(\d+(?:\.\d+)?)\s*([mhdw])?$/i.exec(t);if(!n)return;const a=Number.parseFloat(n[1]);if(!(!Number.isFinite(a)||a<0))switch((n[2]??"m").toLowerCase()){case"d":return a*60*24;case"h":return a*60;case"m":return a;case"w":return a*60*24*7;default:return}},"parseTimeStringToMinutes"),mt=$(e=>{const t=e.trim();return/^\d+(?:\.\d+)?$/.test(t)?Number.parseFloat(t)*1440:$e(t)},"parseNpmReleaseAgeValue"),Ut=$(e=>!Number.isFinite(e)||e<=0?"0m":e%1440===0?`${String(e/1440)}d`:e%60===0?`${String(e/60)}h`:`${String(e)}m`,"formatMinutesAsTimeString"),ft=$((e,t)=>{try{switch(t){case"bun":{const n=W(e,"bunfig.toml");if(V(n)){const a=Ne(n),o=a?.install?.minimumReleaseAge;return{excludes:Array.isArray(a?.install?.minimumReleaseAgeExcludes)?a.install.minimumReleaseAgeExcludes:void 0,minutes:typeof o=="number"?Math.round(o/60):void 0}}break}case"npm":{const n=W(e,".npmrc");if(V(n)){const a=Ye(n),o=/^\s*min-release-age\s*=\s*([^\s#;]+)/m.exec(a);return{minutes:o?mt(o[1]):void 0}}break}case"pnpm":{const n=W(e,"pnpm-workspace.yaml");if(V(n)){const a=oe(n);return{excludes:Array.isArray(a?.minimumReleaseAgeExclude)?a.minimumReleaseAgeExclude:void 0,minutes:typeof a?.minimumReleaseAge=="number"?a.minimumReleaseAge:void 0}}break}case"yarn":{const n=W(e,".yarnrc.yml");if(V(n)){const a=oe(n)?.npmMinimalAgeGate;if(typeof a=="string")return{minutes:$e(a)};if(typeof a=="number")return{minutes:a}}break}}}catch{}return{}},"readPmNativeMinimumReleaseAge"),ht=$((e,t,n)=>{const a=e.latest?"latest":e.target??t.target??"latest";if(!["latest","minor","patch"].includes(a))throw new Error(`Invalid target "${a}". Use: latest, minor, or patch.`);const o=e.maxConcurrentRequests,s=typeof o=="number"&&o>0?o:t.maxConcurrentRequests,i=typeof e.releaseChannel=="string"?e.releaseChannel.toLowerCase():void 0;if(i!==void 0&&!["any","same","stable"].includes(i))throw new Error(`Invalid --release-channel "${String(e.releaseChannel)}". Use: any, same, or stable.`);const p=i??t.releaseChannel;return{exclude:[...N(e.exclude),...N(t.exclude)],ignore:N(t.ignore),include:[...N(e.include),...N(t.include),...n],includeLocked:e.includeLocked||t.includeLocked||!1,includePrerelease:e.prerelease||t.prerelease||!1,maxConcurrentRequests:s,minimumReleaseAge:t.minimumReleaseAge,minimumReleaseAgeExclude:t.minimumReleaseAgeExclude,packageMode:t.packageMode,releaseChannel:p,security:e.security===!1?!1:e.ai||(t.security??!0),target:a}},"buildCatalogCheckOptions"),ce=$((e,t)=>{if(e.length!==0){t.info(`
2
- ${z("⚠")} ${String(e.length)} package${e.length===1?"":"s"} skipped by target constraint (use --target latest to include):`);for(const n of e)t.info(` ${n.packageName} ${n.currentRange} → ${n.newRange} (${n.updateType})`)}},"logFilteredByTarget"),ue=$((e,t,n,a,o)=>{n==="json"?process.stdout.write(`${Me({checkedCount:0,failed:t,filteredByTarget:[],ignored:[],outdated:e})}
3
- `):n==="minimal"?process.stdout.write(`${Ue(e)}
4
- `):(je(e,a),a.info(me(e,o)))},"writeFormattedOutput"),de=$(async(e,t,n,a,o,s,i)=>{const p=Fe(e,n,t,!0,{useEditorconfig:i}),g=t==="pnpm"?"pnpm-workspace.yaml":"package.json";if(o.info(`
5
- Updated ${g}`),p&&o.info(`Backup saved to ${p}`),a.changelog){o.info(`
6
- Fetching changelogs...`);const m=await fe(n,void 0,s);for(const l of m){const f=l.releaseUrl??l.repoUrl??l.npmUrl;o.info(` ${l.packageName}: ${f}`)}}if(a.install??!0){const m=t,l=["install"];o.info(`Running ${m} ${l.join(" ")}...
7
- `);try{ge(m,l,{cwd:e,env:process.env,stdio:"inherit"})}catch{o.warn(`${m} ${l.join(" ")} failed. You may need to run it manually.`)}}},"applyCatalogAndInstall"),vt=$(async(e,t,n,a,o,s)=>{const i=n.update??{},p=[["global","--global is not supported in catalog mode"],["recursive","--recursive is not needed in catalog mode (catalogs are workspace-level)"],["filter","--filter is not supported in catalog mode (use --include/--exclude instead)"],["no-save","--no-save is not supported in catalog mode"],["workspace-root","--workspace-root is not needed in catalog mode"],["no-optional","--no-optional is not supported in catalog mode"]];for(const[r,c]of p)a[r]&&s.warn(`${z("⚠")} ${c}, ignoring.`);const g=X("minReleaseAge"),{excludes:m,minutes:l}=g?{excludes:void 0,minutes:void 0}:ft(e,t),f=g?void 0:i.minimumReleaseAge??l,_=g?void 0:i.minimumReleaseAgeExclude??m;if(g&&(i.minimumReleaseAge!==void 0||l!==void 0)&&s.info("minimumReleaseAge gate disabled via MARSHALL_DISABLE_MIN_RELEASE_AGE."),!g&&i.minimumReleaseAge!==void 0&&l!==void 0&&i.minimumReleaseAge!==l){const r=t==="pnpm"?"pnpm-workspace.yaml":"bunfig.toml";s.warn(`${z("⚠")} minimumReleaseAge mismatch: vis config = ${String(i.minimumReleaseAge)} min, ${r} = ${String(l)} min. Consider keeping them in sync.`)}const b=qe(e),ee=a["include-internal"],te=a.peer,M=_e(e,t,{depFields:i.depFields,dev:a.dev,includeInternal:ee,peer:te,prod:a.prod});if(M.size===0){s.info("No catalogs found.");return}const ke={...i,minimumReleaseAge:f,minimumReleaseAgeExclude:_},E=ht(a,ke,o);let G=0;for(const r of M.values())G+=r.size;const B=!!process.stdout.isTTY&&!he;let T;const we=B?(r,c)=>{T?T.rerender(k.createElement(le,{current:r,total:c})):(process.stdout.write(`
8
- `),T=re(k.createElement(le,{current:r,total:c}),{interactive:!0,patchConsole:!1}))}:(r,c)=>{s.info(`Checking ${String(r)}/${String(c)} dependencies...`)};B||s.info(`Checking ${String(G)} catalog dependencies...
9
- `);const H=new Set;X("socket")&&H.add("socket"),X("depsDev")&&H.add("deps-dev");const L=n.security?.policies?.score?.minimum,ye=Be(n.security,{disabled:H,minimumScore:L}),{checkedCount:w,failed:y,filteredByTarget:h,ignored:S,outdated:d}=await Le(M,E,b,we,e,ye,n.security?.acceptedRisks);T&&(T.clear(),T.unmount());const O=ee?{ignored:[],outdated:[]}:Oe(e,{depFields:i.depFields,dev:a.dev,exclude:E.exclude,ignore:E.ignore,include:E.include,packageMode:E.packageMode,peer:te,prod:a.prod,target:E.target});if(O.outdated.length>0){const r=new Set(d.map(c=>`${c.catalogName}|${c.packageName}`));for(const c of O.outdated)r.has(`${c.catalogName}|${c.packageName}`)||d.push(c)}if(O.ignored.length>0)for(const r of O.ignored)S.includes(r)||S.push(r);const ne=w-d.length-y.length;if(y.length>0&&s.warn(`Failed to fetch: ${y.join(", ")}`),S.length>0&&s.info(`Skipped ${String(S.length)} ignored package${S.length===1?"":"s"}: ${S.join(", ")}`),!B&&w>d.length){const r=[...M.values()].reduce((F,Y)=>F+Y.size,0),c=r>w?` (${String(r)} catalog entries, ${String(r-w)} duplicates)`:"";s.info(`Checked ${String(w)} unique packages${c}: ${String(d.length)} outdated, ${String(ne)} up-to-date${y.length>0?`, ${String(y.length)} failed`:""}${h.length>0?`, ${String(h.length)} skipped by target`:""}`)}if(d.length===0){h.length>0?s.info(`All catalog dependencies are up to date within the current target.
10
- ${String(h.length)} package${h.length===1?" has":"s have"} newer versions available with --target latest:
11
- ${h.map(r=>` ${r.packageName} ${r.currentRange} → ${r.newRange} (${r.updateType})`).join(`
12
- `)}`):s.info("All catalog dependencies are up to date.");return}const U=a.format??i.format??"table";let R;if(a.ai){const r=Ze(a.aiType??"impact");R=await Je(d,s,n.ai,r)}const P=!!a.dryRun;if(!P&&o.length>0&&a.marshallCheck!==!1){const r=await Ke(o);if(r.length>0){const c=await Xe(r,{config:n?.security?.marshalls,workspaceRoot:e});if(!await Qe(c)){process.exitCode=1;return}}}if(B&&U==="table"){const r=new nt(d,R??null);let c;if(a.changelog){s.info("Fetching changelogs...");const u=await fe(d,void 0,b);c=new Map;for(const v of u){const A=v.releaseUrl??v.repoUrl??v.npmUrl;A&&c.set(v.packageName,A)}}const F=n.tui?.autoExit??!1,Y=F===!0?3:typeof F=="number"?F:0,ae=await re(k.createElement(at,{autoExitSeconds:Y,changelogUrls:c,checkedCount:w,filteredOutEntries:h,isDryRun:P,store:r,totalCatalogEntries:G}),{alternateScreen:!0,exitOnCtrlC:!1,interactive:!0,patchConsole:!0}).waitUntilExit(),Z=process.stdout.columns||80;process.stdout.write(`
13
- `);for(const u of d){const v=u.vulnerabilities?.length||u.socketReport&&u.socketReport.alerts.length>0,A=!!u.acceptedRisk,K=v?A?"✓":"⚠":"✓",Re=A?"gray":u.updateType==="major"?"red":u.updateType==="minor"?"yellow":"green",I=u.socketReport?.score.overall,Ce=I===void 0?"":` [${String(Math.round(I*100))}%]`,se=I===void 0?void 0:Pe(I);process.stdout.write(`${Q(k.createElement(C,null," ",k.createElement(C,{color:Re},K),` ${u.packageName} ${u.currentRange} → ${u.newRange}`,k.createElement(C,{dimColor:!0},` ${u.updateType}`),se?k.createElement(C,{color:se},Ce):null),{columns:Z})}
14
- `)}if(process.stdout.write(`
15
- `),s.info(me(d,L)),w>d.length){const u=[...M.values()].reduce((A,K)=>A+K.size,0),v=u>w?` (${String(u)} catalog entries, ${String(u-w)} duplicates)`:"";s.log(),s.info(`Checked ${String(w)} unique packages${v}: ${String(ne)} up-to-date${y.length>0?`, ${String(y.length)} failed`:""}`)}if(h.length>0){process.stdout.write(`
16
- `);const u=`${String(h.length)} package${h.length===1?"":"s"} skipped by target constraint (use --target latest to include):`;process.stdout.write(`${Q(k.createElement(C,{color:"yellow"},` ${u}`),{columns:Z})}
17
- `);for(const v of h)process.stdout.write(`${Q(k.createElement(C,null," ",k.createElement(C,{dimColor:!0},v.packageName),` ${v.currentRange} → ${v.newRange}`,k.createElement(C,{dimColor:!0},` ${v.updateType}`)),{columns:Z})}
18
- `)}const J=Array.isArray(ae)?ae:[];if(J.length>0&&!P){s.info(`
19
- Applying ${String(J.length)} updates...
20
- `);const u={...a,install:a.install??i.install};await de(e,t,J,u,s,b,n.editorconfig??!0)}return}if(P){if(U==="json"){const r={failed:y,filteredByTarget:h,ignored:S,outdated:d};R&&(r.aiAnalysis=R),process.stdout.write(`${JSON.stringify(r,void 0,2)}
21
- `)}else s.info(`Would update ${String(d.length)} dependencies:
22
- `),ue(d,y,U,s,L),R&&(s.info(""),s.info(ie(R))),ce(h,s);return}R&&U!=="json"&&(s.info(ie(R)),s.info(""));let j=d;if(a.interactive&&(j=await Ie(d),j.length===0)){s.info("No updates selected.");return}s.info(`Updating ${String(j.length)} catalog dependencies...
23
- `),ue(j,[],U,s,L),ce(h,s);const be={...a,install:a.install??i.install};await de(e,t,j,be,s,b)},"executeCatalogUpdate"),$t=$((e,t,n,a,o,s)=>{const i={dev:a.dev,filters:N(a.filter),global:a.global,interactive:a.interactive,latest:a.latest||a.target==="latest",noOptional:a.optional===!1,noSave:a.save===!1,packages:o,prod:a.prod,recursive:a.recursive,workspaceRoot:a.workspaceRoot},{command:p,warnings:g}=pt(t,n,i);for(const l of g)s.warn(l);const m=`${p.bin} ${p.args.join(" ")}`.trim();if(a.dryRun){s.info(`Would run: ${m}`);return}s.info(`Running: ${m}`);try{ge(p.bin,p.args,{cwd:e,env:process.env,stdio:"inherit"})}catch(l){const f=l.status??1;s.error(`
24
- ${ve("✖")} Update failed (exit code ${String(f)})`),s.error(` Command: ${m}`),s.error(` Directory: ${e}
25
- `),process.exitCode=f}},"executePmWrapper"),kt=$(async(e,t,n)=>{const a=e.latest===!0||e.target==="latest";if(t||!a||e.dryRun===!0||e.yes===!0||e.interactive===!0)return!0;if(!(process.stdout.isTTY&&!he))return n.error(`${ve("✖")} Refusing to run blanket --latest update in a non-interactive context.`),n.error(" Re-run with --yes to confirm, --dry-run to preview, or pass explicit package names."),process.exitCode=1,!1;const o=Ee({input:process.stdin,output:process.stdout});try{const s=(await new Promise(i=>{o.question(`${z("⚠")} About to upgrade ALL dependencies to their latest versions. This may include breaking changes.
26
- Continue? [y/N] `,i)})).trim().toLowerCase();return s==="y"||s==="yes"?!0:(n.info("Aborted."),!1)}finally{o.close()}},"requireBlanketUpdateConfirmation"),jt=$(async({argument:e,logger:t,options:n,visConfig:a,workspaceRoot:o})=>{if(!o)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");let s=e;const i=o,{packageManager:p}=De(i);if(n.typosquatCheck!==!1){if(s.length>0){const g=s.map(f=>st(f)),m=a?.security?.typosquatAllowlist,l=await et(g.map(f=>f.name),m);if(!l.ok){process.exitCode=1;return}s=g.map((f,_)=>{const b=l.packages[_];return b!==f.name?f.versionSpec?`${b}@${f.versionSpec}`:b??"":s[_]??""})}else if(!await tt(i,a?.security?.typosquatAllowlist)){process.exitCode=1;return}}if(n.rollback){if(!We(i,p)){t.info("No backup found. Run 'vis update' first to create a backup.");return}if(Ve(i,p))t.info("Restored from backup.");else throw new Error("Failed to restore from backup.");return}if(await kt(n,s.length>0,t))if(n.catalog!==!1&&ze(i,p))await vt(i,p,a??{},n,s,t);else{const g=Ge(i,{configBackend:a?.install?.backend,configCorepack:a?.install?.corepack}),m=g.name==="aube"?"":He(g.name);$t(i,g.name,m,n,s,t)}},"execute");export{jt as default,Ut as formatMinutesAsTimeString,mt as parseNpmReleaseAgeValue,$e as parseTimeStringToMinutes,ft as readPmNativeMinimumReleaseAge,kt as requireBlanketUpdateConfirmation};
1
+ var F=Object.defineProperty;var R=(e,t)=>F(e,"name",{value:t,configurable:!0});import{createRequire as J}from"node:module";import{o as Q,am as G,an as I,ao as B,ap as K,aq as Y,ar as g,as as H,at as U,au as X,av as Z,aw as ee,ax as te,ay as oe,az as ne,aA as se,aB as ie,aC as re,aD as ae}from"./bin.js";import{i as $,$ as T,M as d,Q as pe}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{e as fe,B as A}from"./config.js";import{v as le}from"../packem_shared/verify-C8EAHql6.js";const L=J(import.meta.url),C=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,z=R(e=>{if(typeof C<"u"&&C.versions&&C.versions.node){const[t,n]=C.versions.node.split(".").map(Number);if(t>22||t===22&&n>=3||t===20&&n>=16)return C.getBuiltinModule(e)}return L(e)},"__cjs_getBuiltinModule"),{readdirSync:ce,statSync:ue}=z("node:fs"),{stdin:_,stdout:ge}=C,{createInterface:de}=z("node:readline/promises");var me=Object.defineProperty,p=R((e,t)=>me(e,"name",{value:t,configurable:!0}),"u");const x="__global__",b=p(e=>[...new Set(e)].sort((t,n)=>t.localeCompare(n)),"sortStrings"),ve=p(e=>`{${Object.keys(e).sort().map(t=>`${t}=${JSON.stringify(e[t])}`).join(",")}}`,"canonicalizeObjectToken"),h=p(e=>{if(!Array.isArray(e))return[];const t=[];for(const n of e)typeof n=="string"?t.push(n):n&&typeof n=="object"&&t.push(ve(n));return b(t)},"normalizeTokenList"),w=p(e=>({cache:void 0,dependsOn:[],env:[],id:e,inputs:[],outputs:[]}),"emptyNode"),k=p((e,t,n)=>n?`^${t}`:e&&e!=="self"&&e!=="~"?`${e}#${t}`:t,"canonicalEdge"),ye=p((e,t)=>{const n=e.trim();if(t==="moon"){if(n.startsWith("^:"))return k(void 0,n.slice(2),!0);if(n.startsWith("~:"))return k(void 0,n.slice(2),!1);if(n.includes(":")){const[s,o]=n.split(":");return k(s,o??"",!1)}return n}if(n.startsWith("^"))return k(void 0,n.slice(1),!0);if(n.includes("#")){const[s,o]=n.split("#");return k(s,o??"",!1)}return n},"normalizeStringEdge"),M=p((e,t)=>{if(!Array.isArray(e))return[];const n=[];for(const s of e){if(typeof s=="string"){n.push(ye(s,t));continue}if(!s||typeof s!="object")continue;const o=s,{target:r}=o;if(!r)continue;if(o.dependencies===!0){n.push(k(void 0,r,!0));continue}if(o.projects===void 0){n.push(k(void 0,r,!1));continue}const i=Array.isArray(o.projects)?o.projects:[o.projects];for(const c of i)n.push(c==="^"?k(void 0,r,!0):k(c,r,!1))}return b(n)},"normalizeDependsOn"),O=p(e=>{if($(e))try{return JSON.parse(T(e))}catch{return}},"readJson"),he=p(e=>{const t=new Map,n=O(d(e,"turbo.json"));if(!n)return t;const s=n.tasks??n.pipeline??{};for(const[r,i]of Object.entries(s)){const c=r.includes("#")?r:`*#${r}`,a=w(c);a.dependsOn=M(i.dependsOn,"turbo"),a.inputs=h(i.inputs),a.outputs=h(i.outputs),a.env=b([...i.env??[],...i.passThroughEnv??[]]),a.cache=i.cache===!1?!1:void 0,t.set(c,a)}const o=w(x);return o.inputs=h(n.globalDependencies),o.env=b([...n.globalEnv??[],...n.globalPassThroughEnv??[]]),(o.inputs.length>0||o.env.length>0)&&t.set(x,o),t},"parseTurboModel"),ke=new Set([".git",".nx",".turbo",".vis","build","coverage","dist","node_modules"]),N=p((e,t,n=8)=>{const s=[],o=p((r,i)=>{if(i>n)return;let c;try{c=ce(r)}catch{return}for(const a of c.toSorted()){if(a===t){s.push(d(r,a));continue}if(a.startsWith(".")&&a!==".moon"||ke.has(a))continue;const u=d(r,a);try{ue(u).isDirectory()&&o(u,i+1)}catch{}}},"walk");return o(e,0),s},"findFiles"),D=p((e,t)=>{e.dependsOn=M(t.dependsOn,"nx"),e.inputs=h(t.inputs),e.outputs=h(t.outputs),e.cache=typeof t.cache=="boolean"?t.cache:void 0},"applyNxTarget"),we=p(e=>{const t=new Map,n=O(d(e,"nx.json"));for(const[s,o]of Object.entries(n?.targetDefaults??{})){const r=`*#${s}`,i=w(r);D(i,o),t.set(r,i)}for(const s of N(e,"project.json")){const o=O(s);if(!(!o?.name||!o.targets))for(const[r,i]of Object.entries(o.targets)){const c=`${o.name}#${r}`,a=w(c);D(a,i),t.set(c,a)}}return t},"parseNxModel"),V=p((e,t)=>{e.dependsOn=M(t.deps,"moon"),e.inputs=h(t.inputs),e.outputs=h(t.outputs),e.cache=typeof t.options?.cache=="boolean"?t.options.cache:void 0},"applyMoonTask"),q=p(e=>{if($(e))try{return Q(e)}catch{return}},"readMoonYaml"),$e=p(e=>{const t=new Map,n=d(e,".moon"),s=[d(n,"tasks.yml"),d(n,"tasks.yaml")];for(const o of s){const r=q(o);if(r){for(const[i,c]of Object.entries(r.tasks??{})){const a=`*#${i}`,u=w(a);V(u,c),t.set(a,u)}if(r.implicitInputs&&r.implicitInputs.length>0){const i=w(x);i.inputs=h(r.implicitInputs),t.set(x,i)}}}for(const o of[...N(e,"moon.yml"),...N(e,"moon.yaml")]){const r=q(o);if(!r?.tasks)continue;const i=o.split(/[/\\]/).at(-2)??"*";for(const[c,a]of Object.entries(r.tasks)){const u=`${i}#${c}`,y=w(u);V(y,a),t.set(u,y)}}return t},"parseMoonModel"),xe=p((e,t)=>{e.dependsOn=M(t.dependsOn,"vis"),e.inputs=h(t.inputs),e.outputs=h(t.outputs),e.env=b([...t.env??[],...t.passThroughEnv??[],...t.options?.passThroughEnv??[]]),e.cache=t.cache===!1?!1:typeof t.cache=="boolean"?t.cache:void 0},"applyVisTask"),be=p(async e=>{const t=new Map,n=await fe(e);for(const[r,i]of Object.entries(n.tasks??{})){const c=`*#${r}`,a=w(c);xe(a,i??{}),t.set(c,a)}const s=n.taskRunner??{},o=w(x);return o.inputs=h(s.globalInputs),o.env=b([...s.globalEnv??[],...s.globalPassThroughEnv??[]]),(o.inputs.length>0||o.env.length>0)&&t.set(x,o),t},"buildVisModel"),Re=p((e,t)=>{switch(t){case"moon":return $e(e);case"nx":return we(e);default:return he(e)}},"buildSourceModel"),Ce=p(e=>{const t=[];return $(d(e,"turbo.json"))&&t.push("turbo"),$(d(e,"nx.json"))&&t.push("nx"),($(d(e,".moon","tasks.yml"))||$(d(e,".moon","tasks.yaml")))&&t.push("moon"),t.length===1?t[0]:void 0},"detectSourceTool"),S=p((e,t,n,s,o)=>{const r=s.filter(a=>!o.includes(a)),i=o.filter(a=>!s.includes(a));if(r.length===0&&i.length===0)return;const c=[];r.length>0&&c.push(`dropped [${r.join(", ")}]`),i.length>0&&c.push(`added [${i.join(", ")}]`),e.push({axis:n,detail:`${n} diverged: ${c.join("; ")}`,node:t,severity:r.length>0?"error":"warning"})},"diffArrayAxis"),Ee=p((e,t,n)=>{const s=[],o=b([...e.keys(),...t.keys()]);for(const r of o){const i=e.get(r),c=t.get(r);if(i&&!c){const a=n==="turbo"&&r.includes("#")&&!r.startsWith("*#")&&r!==x;s.push({axis:"target-set",detail:a?`source target \`${r}\` was skipped by design (turbo project#task is migrated into per-project project.json — move it there and re-verify)`:`source target \`${r}\` has no equivalent in the migrated vis config`,node:r,severity:a?"warning":"error"});continue}if(!i&&c){s.push({axis:"target-set",detail:`migrated vis config defines \`${r}\` with no source equivalent (extra target — not a regression, but review)`,node:r,severity:"warning"});continue}!i||!c||(S(s,r,"dependsOn",i.dependsOn,c.dependsOn),S(s,r,"inputs",i.inputs,c.inputs),S(s,r,"outputs",i.outputs,c.outputs),S(s,r,"env",i.env,c.env),i.cache!==void 0&&c.cache!==void 0&&i.cache!==c.cache&&s.push({axis:"cache",detail:`cache flag diverged: source=${String(i.cache)} vis=${String(c.cache)} (changes what invalidates the cache)`,node:r,severity:"error"}))}return s.sort((r,i)=>r.node.localeCompare(i.node)||r.axis.localeCompare(i.axis)),{findings:s,source:n,sourceNodeCount:e.size,visNodeCount:t.size}},"diffModels"),je=new Set(["json","ndjson","table"]),Se=p(e=>({equivalent:e.findings.every(t=>t.severity!=="error"),findings:e.findings,source:e.source,sourceNodeCount:e.sourceNodeCount,visNodeCount:e.visNodeCount}),"toJsonPayload"),Me=p((e,t,n)=>{if(t==="json"){process.stdout.write(`${JSON.stringify(Se(e),void 0,2)}
2
+ `);return}if(t==="ndjson"){for(const s of e.findings)process.stdout.write(`${JSON.stringify(s)}
3
+ `);return}if(n.info(`Migration equivalence: ${e.source} → vis`),n.info(` source nodes: ${String(e.sourceNodeCount)} vis nodes: ${String(e.visNodeCount)}`),e.findings.length===0){n.info(" ✓ task graph + cache-key surface preserved (no divergence).");return}for(const s of e.findings){const o=` [${s.severity}] ${s.node} (${s.axis}) — ${s.detail}`;s.severity==="error"?n.warn(o):n.info(o)}},"formatEquivalenceReport"),Te=p((e,t)=>e.findings.some(n=>t==="warning"?!0:n.severity==="error")?1:0,"equivalenceExitCode");var Oe=Object.defineProperty,Ne=R((e,t)=>Oe(e,"name",{value:t,configurable:!0}),"n");const W=Ne(async e=>{if(!_.isTTY)return!0;const t=de({input:_,output:ge});try{const n=(await t.question(`${e} [Y/n] `)).trim().toLowerCase();return n===""||n==="y"||n==="yes"}finally{t.close()}},"confirm");var Ie=Object.defineProperty,E=R((e,t)=>Ie(e,"name",{value:t,configurable:!0}),"p");const Ae=[{description:"VisConfig.targetDefaults → VisConfig.tasks",next:"tasks",previous:"targetDefaults"},{description:"VisConfig.taskDefaults → VisConfig.scopedTasks",next:"scopedTasks",previous:"taskDefaults"},{description:"VisConfig.taskRunnerOptions → VisConfig.taskRunner",next:"taskRunner",previous:"taskRunnerOptions"},{description:"ScopedTasksBlock.scope → ScopedTasksBlock.match",next:"match",previous:"scope"},{description:"ScopedTasksBlock.targets → ScopedTasksBlock.tasks",next:"tasks",previous:"targets"}],_e=[{description:"VisTaskConfig.targets → VisTaskConfig.tasks",next:"tasks",previous:"targets"}],De=E(e=>new RegExp(String.raw`(^|[\s,{(\[])(["']?)${e}\2(\s*:)`,"gmu"),"buildKeyRegex"),Ve=E((e,t)=>{let n=e;const s=[];for(const o of t){const r=De(o.previous);r.test(n)&&(r.lastIndex=0,n=n.replace(r,(i,c,a,u)=>`${c}${a}${o.next}${a}${u}`),s.push(o))}return{applied:s,output:n}},"applyRenames"),P=E((e,t)=>Ve(e,t),"rewriteSource"),qe=["vis.config.ts","vis.config.mts","vis.config.cts","vis.config.js","vis.config.mjs","vis.config.cjs"],Pe=new Set(["vis.task.cjs","vis.task.cts","vis.task.js","vis.task.mjs","vis.task.mts","vis.task.ts"]),ze=E(e=>{for(const t of qe){const n=d(e,t);if($(n))return n}},"findConfigFile"),Be=E(e=>{const t=[];try{for(const n of G(e,{includeDirs:!1,includeFiles:!0,includeSymlinks:!1,skip:[/node_modules/,/\.git/,/\.vis\b/,/dist\b/,/\.next\b/,/\.nuxt\b/]}))Pe.has(pe(n.path))&&t.push(n.path)}catch{}return t},"findTaskConfigFiles"),We=E((e,t,n,s)=>{const o=ze(e);if(o){const i=T(o),{applied:c,output:a}=P(i,Ae);if(c.length===0)n.info(`${o} already uses the current schema — no rewrite needed.`);else if(t.dryRun)n.info(`── ${o} (preview) ──`),n.info(a),n.info("── end preview ──"),n.info(`Would apply ${String(c.length)} rename(s): ${c.map(u=>u.description).join(", ")}`);else{I(o,s),A(o,a),n.info(`Rewrote ${o} (backup at ${o}.bak). Applied ${String(c.length)} rename(s).`);for(const u of c)s.manualSteps.push(`Renamed ${u.description} in ${o}`)}}else n.warn("No vis.config.ts found at workspace root — nothing to migrate."),s.warnings.push("No vis.config.{ts,mts,cts,js,mjs,cjs} at workspace root.");const r=t.taskConfigPaths??Be(e);for(const i of r){if(!$(i))continue;const c=T(i),a=P(c,_e);if(a.applied.length!==0)if(t.dryRun)n.info(`── ${i} (preview) ──`),n.info(a.output),n.info("── end preview ──"),n.info(`Would apply ${String(a.applied.length)} rename(s): ${a.applied.map(u=>u.description).join(", ")}`);else{I(i,s),A(i,a.output),n.info(`Rewrote ${i} (backup at ${i}.bak). Applied ${String(a.applied.length)} rename(s).`);for(const u of a.applied)s.manualSteps.push(`Renamed ${u.description} in ${i}`)}}},"migrateSelf");var Fe=Object.defineProperty,f=R((e,t)=>Fe(e,"name",{value:t,configurable:!0}),"r");const l=f(e=>{const t=e.workspaceRoot??process.cwd(),n=e.visConfig??{};return{config:n,dryRun:!!e.options.dryRun,logger:e.logger,packageManager:K(t),report:B(),root:t,useEditorconfig:typeof n.editorconfig=="boolean"?n.editorconfig:!0}},"buildContext"),m=f(async(e,t,n)=>{if(t.yes||t.dryRun)return!0;const s=await W(`This will edit files, scripts, and hooks for "${e}". Backups (.bak) will be created. Continue?`);return s||n.info("Aborted."),s},"maybeConfirm"),v=f(e=>{e.dryRun&&e.logger.info(`Running in dry-run mode — no changes will be made.
4
+ `)},"announceDryRun"),Je=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("deps",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating dependencies and scripts ──"),Y(o.root,o.packageManager,o.config,{dryRun:o.dryRun},e,o.report),e.info(""),g(o.report,e)},"migrateDepsExecuteImpl"),Le=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("lint-staged",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating lint-staged ──"),H(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateLintStagedExecuteImpl"),Qe=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("nano-staged",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating nano-staged ──"),U(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateNanoStagedExecuteImpl"),Ge=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("turborepo",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating turborepo ──"),X(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateTurborepoExecuteImpl"),Ke=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("nx",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating nx ──"),Z(o.root,{dryRun:o.dryRun,force:!!t.force,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateNxExecuteImpl"),Ye=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("moon",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating moon ──"),ee(o.root,{copyTemplates:!!t.copyTemplates,dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateMoonExecuteImpl"),He=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("gitleaks",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating gitleaks ──"),te(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateGitleaksExecuteImpl"),Ue=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("kingfisher",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating Kingfisher ──"),oe(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateKingfisherExecuteImpl"),Xe=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("secretlint",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating secretlint ──"),ne(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateSecretlintExecuteImpl"),Ze=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("syncpack",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating syncpack ──"),se(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateSyncpackExecuteImpl"),et=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("sherif",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating sherif ──"),ie(o.root,{dryRun:o.dryRun,useEditorconfig:o.useEditorconfig},e,o.report),e.info(""),g(o.report,e)},"migrateSherifExecuteImpl"),tt=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{if(!await m("self",t,e))return;const o=l({logger:e,options:t,visConfig:n,workspaceRoot:s});v(o),e.info("── Migrating vis.config.ts to current schema ──"),We(o.root,{dryRun:o.dryRun},e,o.report),e.info(""),g(o.report,e)},"migrateSelfExecuteImpl"),ot=f(({logger:e,workspaceRoot:t})=>{const n=t??process.cwd();le(n,e).length>0&&(process.exitCode=1)},"migrateVerifyExecuteImpl"),nt=f(async({logger:e,options:t,workspaceRoot:n})=>{const s=n??process.cwd(),o=t.format??"table";if(!je.has(o)){e.warn(`Invalid --format: ${String(t.format)}. Expected table | json | ndjson.`),process.exitCode=1;return}const r=t.failOn==="warning"?"warning":"error";let i;if(t.from){if(t.from!=="turbo"&&t.from!=="nx"&&t.from!=="moon"){e.warn(`Invalid --from: ${t.from}. Expected turbo | nx | moon.`),process.exitCode=1;return}i=t.from}else if(i=Ce(s),!i){e.warn("Could not auto-detect the source tool (need exactly one of turbo.json / nx.json / .moon/tasks.yml). Pass --from <turbo|nx|moon>."),process.exitCode=1;return}const c=Re(s,i);if(c.size===0){e.warn(`No ${i} task graph found at ${s} — nothing to verify.`),process.exitCode=1;return}const a=await be(s);if(a.size===0){e.warn("No migrated vis task graph found (vis.config.ts has no tasks). Run the migrator first."),process.exitCode=1;return}const u=Ee(c,a,i);Me(u,o,e),process.exitCode=Te(u,r)},"migrateVerifyGraphExecuteImpl"),st=f(async({logger:e,options:t,visConfig:n,workspaceRoot:s})=>{const o=s??process.cwd(),r=re(o,n??{}),i=ae(r);if(i.length===0){e.info("No applicable migrations detected in this workspace.");return}const c=!!t.dryRun;e.info(`Detected ${String(i.length)} migration(s):`);for(const y of i)e.info(` • ${y.title} — ${y.description}`);if(e.info(""),!t.yes&&!c&&!await W("Apply all detected migrations? Backups (.bak) will be created.")){e.info("Aborted.");return}c&&e.info(`Running in dry-run mode — no changes will be made.
5
+ `);const a=B(),u=[];for(const y of i)try{if(e.info(`── Applying ${y.title} ──`),c)for(const j of y.probe(r))e.info(j);else y.apply(r,a,e);e.info("")}catch(j){u.push({error:j,id:y.id}),e.warn(`Failed to apply ${y.title}: ${j.message}`)}g(a,e),u.length>0&&(e.warn(""),e.warn(`${String(u.length)} migration(s) failed — see messages above.`),process.exitCode=1)},"migrateAllExecuteImpl"),ft=Je,gt=Le,dt=Qe,lt=Ge,mt=Ke,vt=Ye,yt=He,ht=Ue,kt=Xe,wt=Ze,$t=et,xt=tt,bt=ot,Rt=nt,Ct=st;export{Ct as migrateAllExecute,ft as migrateDepsExecute,yt as migrateGitleaksExecute,ht as migrateKingfisherExecute,gt as migrateLintStagedExecute,vt as migrateMoonExecute,dt as migrateNanoStagedExecute,mt as migrateNxExecute,kt as migrateSecretlintExecute,xt as migrateSelfExecute,$t as migrateSherifExecute,wt as migrateSyncpackExecute,lt as migrateTurborepoExecute,bt as migrateVerifyExecute,Rt as migrateVerifyGraphExecute};