@visulima/vis 1.0.0-alpha.27 → 1.0.0-alpha.29

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 (132) hide show
  1. package/CHANGELOG.md +42 -0
  2. package/LICENSE.md +3217 -99
  3. package/dist/bin.js +1 -1
  4. package/dist/binx.js +1 -1
  5. package/dist/packem_chunks/bin.js +468 -364
  6. package/dist/packem_chunks/bloom-status.js +1 -1
  7. package/dist/packem_chunks/bloom-sync.js +1 -1
  8. package/dist/packem_chunks/config.js +15 -15
  9. package/dist/packem_chunks/devtools.js +82 -0
  10. package/dist/packem_chunks/doctor-probe.js +1 -1
  11. package/dist/packem_chunks/fix.js +1 -1
  12. package/dist/packem_chunks/handler.js +1 -1
  13. package/dist/packem_chunks/handler10.js +1 -2
  14. package/dist/packem_chunks/handler11.js +5 -1
  15. package/dist/packem_chunks/handler12.js +1 -5
  16. package/dist/packem_chunks/handler13.js +27 -1
  17. package/dist/packem_chunks/handler14.js +5 -27
  18. package/dist/packem_chunks/handler15.js +1 -5
  19. package/dist/packem_chunks/handler16.js +1 -1
  20. package/dist/packem_chunks/handler17.js +1 -1
  21. package/dist/packem_chunks/handler18.js +1 -1
  22. package/dist/packem_chunks/handler19.js +1 -1
  23. package/dist/packem_chunks/handler2.js +1 -1
  24. package/dist/packem_chunks/handler20.js +5 -1
  25. package/dist/packem_chunks/handler21.js +2 -5
  26. package/dist/packem_chunks/handler22.js +2 -2
  27. package/dist/packem_chunks/handler23.js +1 -2
  28. package/dist/packem_chunks/handler24.js +1 -1
  29. package/dist/packem_chunks/handler25.js +5 -1
  30. package/dist/packem_chunks/handler26.js +1 -5
  31. package/dist/packem_chunks/handler27.js +3 -1
  32. package/dist/packem_chunks/handler28.js +1 -3
  33. package/dist/packem_chunks/handler29.js +7 -1
  34. package/dist/packem_chunks/handler3.js +4 -4
  35. package/dist/packem_chunks/handler30.js +32 -6
  36. package/dist/packem_chunks/handler31.js +3 -33
  37. package/dist/packem_chunks/handler32.js +8 -3
  38. package/dist/packem_chunks/handler33.js +1 -1
  39. package/dist/packem_chunks/handler34.js +4 -4
  40. package/dist/packem_chunks/handler35.js +11 -3
  41. package/dist/packem_chunks/handler36.js +3 -22
  42. package/dist/packem_chunks/handler37.js +21 -60
  43. package/dist/packem_chunks/handler38.js +61 -3
  44. package/dist/packem_chunks/handler39.js +3 -6
  45. package/dist/packem_chunks/handler4.js +5 -5
  46. package/dist/packem_chunks/handler40.js +6 -24
  47. package/dist/packem_chunks/handler41.js +24 -153
  48. package/dist/packem_chunks/handler42.js +153 -10
  49. package/dist/packem_chunks/handler43.js +6 -6
  50. package/dist/packem_chunks/handler44.js +10 -708
  51. package/dist/packem_chunks/handler45.js +708 -24
  52. package/dist/packem_chunks/handler46.js +24 -322
  53. package/dist/packem_chunks/handler47.js +322 -48
  54. package/dist/packem_chunks/handler48.js +48 -3
  55. package/dist/packem_chunks/handler49.js +3 -27
  56. package/dist/packem_chunks/handler5.js +7 -7
  57. package/dist/packem_chunks/handler50.js +21 -190
  58. package/dist/packem_chunks/handler51.js +194 -33
  59. package/dist/packem_chunks/handler52.js +34 -0
  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 +1 -1
  65. package/dist/packem_chunks/heal.js +1 -1
  66. package/dist/packem_chunks/help-command.js +7 -17
  67. package/dist/packem_chunks/index.js +3 -3
  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 +1 -1
  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 +1 -1
  75. package/dist/packem_chunks/sync.js +1 -1
  76. package/dist/packem_chunks/sync2.js +1 -1
  77. package/dist/packem_chunks/tripwire.js +2 -2
  78. package/dist/packem_chunks/verify-lockfile.js +1 -1
  79. package/dist/packem_shared/Table-3pFgIUZ2-DABgc6rj.js +12 -0
  80. package/dist/packem_shared/_commonjsHelpers-CLblCigl.js +1 -0
  81. package/dist/packem_shared/{advisories-xIOdLbAI.js → advisories-DpgSuWDH.js} +1 -1
  82. package/dist/packem_shared/{affected-shas-Dm7eqcI8.js → affected-shas-BkXXecyi.js} +1 -1
  83. package/dist/packem_shared/ai-analysis-KP8b5lc0.js +68 -0
  84. package/dist/packem_shared/{ai-fix-BlYyz5bI.js → ai-fix-CfFWatGY.js} +5 -5
  85. package/dist/packem_shared/{applyDefaults-KxZkvlp3.js → applyDefaults-DLvOqXGX.js} +1 -1
  86. package/dist/packem_shared/{build-scripts-3E2pmscY.js → build-scripts-D-ysm_bS.js} +1 -1
  87. package/dist/packem_shared/{cyclonedx-B3ILsY74.js → cyclonedx-B04lIvwu.js} +3 -3
  88. package/dist/packem_shared/{dependency-scan-s2MD0vi-.js → dependency-scan-B9wTcLxf.js} +1 -1
  89. package/dist/packem_shared/{docker-BynKrOLe.js → docker-DxA80dRx.js} +1 -1
  90. package/dist/packem_shared/{failure-log-B0Uh-65U.js → failure-log-n3j_-w8s.js} +1 -1
  91. package/dist/packem_shared/index-BDF8gawl.js +29 -0
  92. package/dist/packem_shared/{index-B_KtN1MB.js → index-BfG9_znI.js} +1 -1
  93. package/dist/packem_shared/{lifecycle-CJRNbN3x.js → lifecycle-NHIKDiCh.js} +2 -2
  94. package/dist/packem_shared/lockfile-CoeFxWAv.js +1 -0
  95. package/dist/packem_shared/lockfile-DAuTDwow.js +1 -0
  96. package/dist/packem_shared/{manifests-Z3spBpxv.js → manifests-B7wUR3Rk.js} +1 -1
  97. package/dist/packem_shared/{min-release-age-aEn0x8Vy.js → min-release-age-YyNI7gqV.js} +1 -1
  98. package/dist/packem_shared/{native-config-sync-DdhTLlKL.js → native-config-sync-CgRIIRZV.js} +2 -2
  99. package/dist/packem_shared/{osv-bloom-BJhlc_I2.js → osv-bloom-BQSIHt5h.js} +2 -2
  100. package/dist/packem_shared/pm-runner-Ta_yz2uP.js +1 -0
  101. package/dist/packem_shared/{provenance-BuiEsWbI.js → provenance-DoEp2uOo.js} +1 -1
  102. package/dist/packem_shared/{readFileSync-CGmzMUF2-D6rUjGDn.js → readFileSync-4c_c6Qey-6SWMDNdw.js} +1 -1
  103. package/dist/packem_shared/{registry-keys-pemEkRM9.js → registry-keys-CD1xHavV.js} +1 -1
  104. package/dist/packem_shared/{resolve-explicit-RgRrUDZv.js → resolve-explicit-DpSc7RN2.js} +1 -1
  105. package/dist/packem_shared/{runtime-check-DgXsKCsv.js → runtime-check-Cbtb_Utb.js} +1 -1
  106. package/dist/packem_shared/s1ngularity-CIX7UcT5.js +1 -0
  107. package/dist/packem_shared/scan-progress-CTVVf9WW.js +2 -0
  108. package/dist/packem_shared/{selectors-BE2BCnTR.js → selectors-BU8aTRQm.js} +1 -1
  109. package/dist/packem_shared/{signatures-LYMy8OR5.js → signatures-BHM7cnqB.js} +1 -1
  110. package/dist/packem_shared/spinner-C8xs6QZv.js +1 -0
  111. package/dist/packem_shared/spinners-f91Rbo99-Bjf3NcO0.js +1 -0
  112. package/dist/packem_shared/tabs-xZkm6Y_J.js +1 -0
  113. package/dist/packem_shared/{toolchain-Jx2lkAYy.js → toolchain-juKl-WgV.js} +1 -1
  114. package/dist/packem_shared/typosquats-DRKU6d2S.js +1 -0
  115. package/dist/packem_shared/use-measured-height-Lea6TCVD.js +1 -0
  116. package/dist/packem_shared/{verify-C8EAHql6.js → verify-DA80ja1b.js} +1 -1
  117. package/dist/packem_shared/vis-update-app-BCKzlqj8.js +1 -0
  118. package/dist/packem_shared/{watch-BSVsZ_1I.js → watch-DdR-pFzX.js} +1 -1
  119. package/dist/packem_shared/{watch-loop-DLlMLg_J.js → watch-loop-C8csFvRU.js} +2 -2
  120. package/index.d.ts +201 -201
  121. package/index.js +567 -751
  122. package/package.json +13 -13
  123. package/dist/packem_shared/ai-analysis-Csn82p17.js +0 -68
  124. package/dist/packem_shared/index-efSniSRN.js +0 -29
  125. package/dist/packem_shared/index.server-B7ETiT4C.js +0 -2
  126. package/dist/packem_shared/lockfile-BG1HvBzH.js +0 -1
  127. package/dist/packem_shared/pm-runner-BwX5AL3W.js +0 -1
  128. package/dist/packem_shared/s1ngularity-Bs9fUf3q.js +0 -1
  129. package/dist/packem_shared/scan-progress-DjPT66jy.js +0 -2
  130. package/dist/packem_shared/typosquats-znskIR5j.js +0 -1
  131. package/dist/packem_shared/use-measured-height-DjYgUOKk.js +0 -1
  132. package/dist/packem_shared/vis-update-app-qhQPV97i.js +0 -1
@@ -1,2 +1,2 @@
1
- var h=Object.defineProperty;var p=(e,t)=>h(e,"name",{value:t,configurable:!0});import{I as g,T as l,j as m,E as n,q as b,e as d}from"../packem_shared/index.server-B7ETiT4C.js";import{ReapiRemoteCache as f,resolveTurboEnvCompat as k}from"@visulima/task-runner";import{p as $}from"./bin.js";var w=Object.defineProperty,s=p((e,t)=>w(e,"name",{value:t,configurable:!0}),"s");const y=s((e,t)=>t==="http"||t==="reapi"?t:e.startsWith("grpc://")||e.startsWith("grpcs://")?"reapi":"http","inferBackend"),S=s(async(e,t)=>{const o=Date.now(),a=new AbortController,r=setTimeout(()=>{a.abort()},t);try{const i=await fetch(e,{method:"HEAD",signal:a.signal});return{backend:"http",durationMs:Date.now()-o,httpStatus:i.status,ok:!0,url:e}}catch(i){return{backend:"http",durationMs:Date.now()-o,error:i instanceof Error?i.message:String(i),ok:!1,url:e}}finally{clearTimeout(r)}},"probeHttp"),C=s(async(e,t)=>{const o=Date.now(),a=new f({...e,timeout:t});try{return{backend:"reapi",capabilities:await a.probeCapabilities(),durationMs:Date.now()-o,ok:!0,url:e.url}}catch(r){return{backend:"reapi",durationMs:Date.now()-o,error:r instanceof Error?r.message:String(r),ok:!1,url:e.url}}finally{try{await a.close()}catch{}}},"probeReapi"),D=s(e=>{const t=[],o=e.ok?g("OK"):l("FAIL");if(t.push(`${m("Remote cache")} ${o}`),t.push(` ${n("URL:")} ${b(e.url)}`),t.push(` ${n("Backend:")} ${e.backend}`),t.push(` ${n("Latency:")} ${String(e.durationMs)}ms`),e.httpStatus!==void 0&&t.push(` ${n("Status:")} ${String(e.httpStatus)}`),e.capabilities){const a=e.capabilities.digestFunctions.length>0?e.capabilities.digestFunctions.join(", "):d("(none advertised)");t.push(` ${n("Digests:")} ${a}`),t.push(` ${n("Batch:")} ${String(e.capabilities.maxBatchTotalSizeBytes)} bytes`)}return e.error&&t.push(` ${n("Error:")} ${l(e.error)}`),t.join(`
1
+ var h=Object.defineProperty;var p=(e,t)=>h(e,"name",{value:t,configurable:!0});import{I as g,T as l,j as m,E as n,q as b,e as d}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{ReapiRemoteCache as f,resolveTurboEnvCompat as k}from"@visulima/task-runner";import{p as $}from"./bin.js";var w=Object.defineProperty,s=p((e,t)=>w(e,"name",{value:t,configurable:!0}),"s");const y=s((e,t)=>t==="http"||t==="reapi"?t:e.startsWith("grpc://")||e.startsWith("grpcs://")?"reapi":"http","inferBackend"),S=s(async(e,t)=>{const o=Date.now(),a=new AbortController,r=setTimeout(()=>{a.abort()},t);try{const i=await fetch(e,{method:"HEAD",signal:a.signal});return{backend:"http",durationMs:Date.now()-o,httpStatus:i.status,ok:!0,url:e}}catch(i){return{backend:"http",durationMs:Date.now()-o,error:i instanceof Error?i.message:String(i),ok:!1,url:e}}finally{clearTimeout(r)}},"probeHttp"),C=s(async(e,t)=>{const o=Date.now(),a=new f({...e,timeout:t});try{return{backend:"reapi",capabilities:await a.probeCapabilities(),durationMs:Date.now()-o,ok:!0,url:e.url}}catch(r){return{backend:"reapi",durationMs:Date.now()-o,error:r instanceof Error?r.message:String(r),ok:!1,url:e.url}}finally{try{await a.close()}catch{}}},"probeReapi"),D=s(e=>{const t=[],o=e.ok?g("OK"):l("FAIL");if(t.push(`${m("Remote cache")} ${o}`),t.push(` ${n("URL:")} ${b(e.url)}`),t.push(` ${n("Backend:")} ${e.backend}`),t.push(` ${n("Latency:")} ${String(e.durationMs)}ms`),e.httpStatus!==void 0&&t.push(` ${n("Status:")} ${String(e.httpStatus)}`),e.capabilities){const a=e.capabilities.digestFunctions.length>0?e.capabilities.digestFunctions.join(", "):d("(none advertised)");t.push(` ${n("Digests:")} ${a}`),t.push(` ${n("Batch:")} ${String(e.capabilities.maxBatchTotalSizeBytes)} bytes`)}return e.error&&t.push(` ${n("Error:")} ${l(e.error)}`),t.join(`
2
2
  `)},"formatTable"),T=s(async({logger:e,options:t,visConfig:o})=>{const a=k((o??{}).taskRunner?.remoteCache),r=t.url??a?.url,i=t.format??"table",u=t.timeout??5e3;if(!r){$.error("No remote cache configured. Set taskRunner.remoteCache.url in vis.config.ts, pass --url=..., or export TURBO_API."),process.exitCode=1;return}const c=y(r,t.backend)==="reapi"?await C({...a??{url:r},backend:"reapi",url:r},u):await S(r,u);i==="json"?e.log(JSON.stringify(c,null,2)):e.log(D(c)),c.ok||(process.exitCode=1)},"cacheDoctorExecute");export{T as cacheDoctorExecute};
@@ -1,4 +1,4 @@
1
- var O=Object.defineProperty;var v=(e,t)=>O(e,"name",{value:t,configurable:!0});import{createRequire as q}from"node:module";import{j as $,E as P,e as R,q as D,T as j,I}from"../packem_shared/index.server-B7ETiT4C.js";import{z as _}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{r as W,a as B,b as L,c as w}from"../packem_shared/ai-fix-BlYyz5bI.js";import{p}from"./bin.js";import{l as N}from"../packem_shared/failure-log-B0Uh-65U.js";const A=q(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,J=v(e=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[t,r]=m.versions.node.split(".").map(Number);if(t>22||t===22&&r>=3||t===20&&r>=16)return m.getBuiltinModule(e)}return A(e)},"__cjs_getBuiltinModule"),{createInterface:z}=J("node:readline");var M=Object.defineProperty,l=v((e,t)=>M(e,"name",{value:t,configurable:!0}),"c");const U={"ambiguous-match":"ambiguous match",applied:"applied",error:"error","missing-file":"missing file","no-match":"no match","outside-workspace":"outside workspace"},S=l((e,t,r)=>{const o=W(e,t,r),s=_(e,o);return s===""||s.startsWith("..")?o:s},"formatDisplayPath"),E=l((e,t,r)=>{const o=[$(`Fix proposal (${e.provider}, confidence: ${e.confidence})`),"",e.explanation||P("<no explanation>")];if(e.cannotFix)return o.push(""),o.push(R(`Cannot fix automatically: ${e.cannotFix}`)),o.join(`
1
+ var O=Object.defineProperty;var v=(e,t)=>O(e,"name",{value:t,configurable:!0});import{createRequire as q}from"node:module";import{j as $,E as P,e as R,q as D,T as j,I}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{z as _}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{r as W,a as B,b as L,c as w}from"../packem_shared/ai-fix-CfFWatGY.js";import{p}from"./bin.js";import{l as N}from"../packem_shared/failure-log-n3j_-w8s.js";const A=q(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,J=v(e=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[t,r]=m.versions.node.split(".").map(Number);if(t>22||t===22&&r>=3||t===20&&r>=16)return m.getBuiltinModule(e)}return A(e)},"__cjs_getBuiltinModule"),{createInterface:z}=J("node:readline");var M=Object.defineProperty,l=v((e,t)=>M(e,"name",{value:t,configurable:!0}),"c");const U={"ambiguous-match":"ambiguous match",applied:"applied",error:"error","missing-file":"missing file","no-match":"no match","outside-workspace":"outside workspace"},S=l((e,t,r)=>{const o=W(e,t,r),s=_(e,o);return s===""||s.startsWith("..")?o:s},"formatDisplayPath"),E=l((e,t,r)=>{const o=[$(`Fix proposal (${e.provider}, confidence: ${e.confidence})`),"",e.explanation||P("<no explanation>")];if(e.cannotFix)return o.push(""),o.push(R(`Cannot fix automatically: ${e.cannotFix}`)),o.join(`
2
2
  `);if(e.patches.length===0)return o.push(""),o.push(R("No patches were proposed.")),o.join(`
3
3
  `);o.push(""),o.push($(`Patches (${String(e.patches.length)}):`));for(const[s,i]of e.patches.entries()){const a=S(t,r,i.file);o.push(""),o.push(D(`[${String(s+1)}] ${a}`)),i.reason&&o.push(P(` reason: ${i.reason}`));for(const c of i.oldString.split(`
4
4
  `))o.push(j(` - ${c}`));for(const c of i.newString.split(`
@@ -1 +1 @@
1
- var O=Object.defineProperty;var v=(r,e)=>O(r,"name",{value:e,configurable:!0});import{createTaskGraph as E}from"@visulima/task-runner";import{C as R,S}from"./bin.js";import{r as C,f as P}from"../packem_shared/selectors-BE2BCnTR.js";var x=Object.defineProperty,d=v((r,e)=>x(r,"name",{value:e,configurable:!0}),"u");const G=d((r,e,n)=>{const c=[],t=new Set,i=d((o,f)=>{if(t.has(o))return;t.add(o);const m=e[o]??[];for(const u of m)i(u,f+1);const s=n[o],h=" ".repeat(f);c.push(`${h}${o}${s?.cache===!1?" (no-cache)":""}`)},"walk");for(const o of r)i(o,0);return c},"renderPlan"),J=d((r,e,n)=>({roots:r,tasks:Object.fromEntries(Object.entries(n).map(([c,t])=>[c,{cache:t.cache,dependsOn:e[c]??[],outputs:t.outputs,parallelism:t.parallelism,projectRoot:t.projectRoot,target:t.target}]))}),"toJson"),D=d(async({argument:r,logger:e,options:n,process:c,visConfig:t,workspaceRoot:i})=>{const o=r[0];if(!o)throw new Error("Missing selector. Usage: vis action-graph <selector>");if(!i)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{config:f,packageJsons:m,workspace:s}=R(i,t),h=S(i,s,m),u=await C(o,s,c.cwd,i),{target:l}=u;let j=u.projects;n.query&&(j=P(j,s,n.query));const k=j.filter(p=>s.projects[p]?.targets?.[l]!==void 0);if(k.length===0){e.info(`No projects have a "${l}" target.`);return}const y=k.map(p=>{const w=s.projects[p],g=w.targets?.[l],b={project:p,target:l};return{cache:g?.cache,id:`${p}:${l}`,outputs:g?.outputs??[],overrides:{command:g?.command},parallelism:g?.parallelism,projectRoot:w.root,target:b}}),a=E(y,{projectGraph:h,targetDefaults:f.tasks,workspace:s});if(n.json){e.info(JSON.stringify(J(a.roots,a.dependencies,a.tasks),null,2));return}const $=G(a.roots,a.dependencies,a.tasks);e.info(`Execution plan (${Object.keys(a.tasks).length} task(s), ${a.roots.length} root(s)):`),e.info("");for(const p of $)e.info(p)},"execute");export{D as default};
1
+ var O=Object.defineProperty;var v=(r,e)=>O(r,"name",{value:e,configurable:!0});import{createTaskGraph as E}from"@visulima/task-runner";import{C as R,S}from"./bin.js";import{r as C,f as P}from"../packem_shared/selectors-BU8aTRQm.js";var x=Object.defineProperty,d=v((r,e)=>x(r,"name",{value:e,configurable:!0}),"u");const G=d((r,e,n)=>{const c=[],t=new Set,i=d((o,f)=>{if(t.has(o))return;t.add(o);const m=e[o]??[];for(const u of m)i(u,f+1);const s=n[o],h=" ".repeat(f);c.push(`${h}${o}${s?.cache===!1?" (no-cache)":""}`)},"walk");for(const o of r)i(o,0);return c},"renderPlan"),J=d((r,e,n)=>({roots:r,tasks:Object.fromEntries(Object.entries(n).map(([c,t])=>[c,{cache:t.cache,dependsOn:e[c]??[],outputs:t.outputs,parallelism:t.parallelism,projectRoot:t.projectRoot,target:t.target}]))}),"toJson"),D=d(async({argument:r,logger:e,options:n,process:c,visConfig:t,workspaceRoot:i})=>{const o=r[0];if(!o)throw new Error("Missing selector. Usage: vis action-graph <selector>");if(!i)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{config:f,packageJsons:m,workspace:s}=R(i,t),h=S(i,s,m),u=await C(o,s,c.cwd,i),{target:l}=u;let j=u.projects;n.query&&(j=P(j,s,n.query));const k=j.filter(p=>s.projects[p]?.targets?.[l]!==void 0);if(k.length===0){e.info(`No projects have a "${l}" target.`);return}const y=k.map(p=>{const w=s.projects[p],g=w.targets?.[l],b={project:p,target:l};return{cache:g?.cache,id:`${p}:${l}`,outputs:g?.outputs??[],overrides:{command:g?.command},parallelism:g?.parallelism,projectRoot:w.root,target:b}}),a=E(y,{projectGraph:h,targetDefaults:f.tasks,workspace:s});if(n.json){e.info(JSON.stringify(J(a.roots,a.dependencies,a.tasks),null,2));return}const $=G(a.roots,a.dependencies,a.tasks);e.info(`Execution plan (${Object.keys(a.tasks).length} task(s), ${a.roots.length} root(s)):`),e.info("");for(const p of $)e.info(p)},"execute");export{D as default};
@@ -1,2 +1 @@
1
- var g=Object.defineProperty;var d=(t,o)=>g(t,"name",{value:o,configurable:!0});import{M as l}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{C as v,S as h}from"./bin.js";import{s as j,p as x}from"../packem_shared/docker-BynKrOLe.js";var C=Object.defineProperty,m=d((t,o)=>C(t,"name",{value:o,configurable:!0}),"f");const $=m(async({argument:t,logger:o,options:s,visConfig:w,workspaceRoot:e})=>{const n=t[0];if(!n)throw new Error("Missing subcommand. Usage: vis docker <scaffold|prune>");if(!e)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{packageJsons:k,workspace:c}=v(e,w);if(n==="scaffold"){const a=h(e,c,k),r=s.focus;if(!r)throw new Error("Missing --focus. Pass one or more project names, comma-separated.");const f=r.split(",").map(i=>i.trim()).filter(Boolean);if(f.length===0)throw new Error("--focus resolved to an empty list. Provide at least one project name.");const u=l(e,s.out??".vis/docker"),{projects:p}=j({focus:f,includeSources:!!s.includeSources,log:m(i=>{o.info(i)},"log"),outDir:u,projectGraph:a,pruneLockfile:s.pruneLockfile!==!1,workspace:c,workspaceRoot:e});o.info(`Scaffolded ${p.length} project(s) into ${u}`),o.info(`Focus closure: ${p.toSorted().join(", ")}`);return}if(n==="prune"){const a=l(e,s.context??".vis/docker"),{removed:r}=x({contextRoot:a,workspace:c,workspaceRoot:e});o.info(`Pruned ${r.length} unfocused project(s)`),r.length>0&&o.debug?.(r.join(`
2
- `));return}throw new Error(`Unknown subcommand: "${n}". Expected scaffold or prune.`)},"execute");export{$ as default};
1
+ var d=Object.defineProperty;var n=(o,r)=>d(o,"name",{value:r,configurable:!0});import{R as m,N as g}from"../packem_shared/pm-runner-Ta_yz2uP.js";import{o as u}from"../packem_shared/utils-DrNg0XTR.js";var v=Object.defineProperty,k=n((o,r)=>v(o,"name",{value:r,configurable:!0}),"t");const x=k(async({argument:o,logger:r,options:e,visConfig:s,workspaceRoot:t})=>{const a=o;if(!a||a.length===0)throw new Error("No command specified. Usage: vis exec <command> [args...]");const[i,...f]=a,l=t??process.cwd(),p=m(l,{configBackend:s?.install?.backend,configCorepack:s?.install?.corepack}),c=g(p,{args:f,command:i,filter:u(e.filter),parallel:e.parallel||!1,recursive:e.recursive||!1,reverse:e.reverse||!1,shellMode:e.shellMode||!1,workspaceRoot:e.workspaceRoot||!1},l,r);c!==0&&(process.exitCode=c)},"execute");export{x as default};
@@ -1 +1,5 @@
1
- var d=Object.defineProperty;var n=(o,r)=>d(o,"name",{value:r,configurable:!0});import{R as m,N as g}from"../packem_shared/pm-runner-BwX5AL3W.js";import{o as u}from"../packem_shared/utils-DrNg0XTR.js";var v=Object.defineProperty,k=n((o,r)=>v(o,"name",{value:r,configurable:!0}),"t");const x=k(async({argument:o,logger:r,options:e,visConfig:s,workspaceRoot:t})=>{const a=o;if(!a||a.length===0)throw new Error("No command specified. Usage: vis exec <command> [args...]");const[i,...f]=a,l=t??process.cwd(),p=m(l,{configBackend:s?.install?.backend,configCorepack:s?.install?.corepack}),c=g(p,{args:f,command:i,filter:u(e.filter),parallel:e.parallel||!1,recursive:e.recursive||!1,reverse:e.reverse||!1,shellMode:e.shellMode||!1,workspaceRoot:e.workspaceRoot||!1},l,r);c!==0&&(process.exitCode=c)},"execute");export{x as default};
1
+ var g=Object.defineProperty;var a=(e,i)=>g(e,"name",{value:i,configurable:!0});import{createRequire as _}from"node:module";import{M as n,i as u,$ as p}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{q as $}from"./config.js";import{x as j}from"./bin.js";const b=_(import.meta.url),c=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,d=a(e=>{if(typeof c<"u"&&c.versions&&c.versions.node){const[i,s]=c.versions.node.split(".").map(Number);if(i>22||i===22&&s>=3||i===20&&s>=16)return c.getBuiltinModule(e)}return b(e)},"__cjs_getBuiltinModule"),{rmSync:y}=d("node:fs"),{homedir:r}=d("node:os"),{createInterface:w}=d("node:readline");var T=Object.defineProperty,m=a((e,i)=>T(e,"name",{value:i,configurable:!0}),"l");const f=j(),h=[n(r(),".zshrc"),n(r(),".zshenv"),n(r(),".bashrc"),n(r(),".bash_profile"),n(r(),".profile"),n(r(),".config","fish","config.fish")],q=m(e=>{const i=[];for(const s of h)if(u(s))try{const l=p(s).split(`
2
+ `),o=l.filter(t=>!t.includes(".vis/bin")&&!t.includes("VIS_HOME")&&!t.includes("# vis "));o.length!==l.length&&($(s,o.join(`
3
+ `)),i.push(s))}catch{e.warn(`warning: could not clean ${s}`)}return i},"cleanShellProfiles"),R=m(async({logger:e,options:i})=>{if(!u(f)){e.info("vis is not installed (no ~/.vis directory found).");return}e.info("This will remove:"),e.info(` ${f}/`);const s=h.filter(o=>u(o)&&p(o).includes(".vis"));for(const o of s)e.info(` Lines in ${o}`);if(!i.yes){if(!process.stdin.isTTY)throw new Error("Non-interactive terminal. Use --yes to confirm.");const o=w({input:process.stdin,output:process.stdout}),t=await new Promise(v=>{o.question(`
4
+ Type "uninstall" to confirm: `,v)});if(o.close(),t.trim()!=="uninstall"){e.info("Aborted.");return}}const l=q(e);for(const o of l)e.info(`Cleaned ${o}`);try{y(f,{force:!0,recursive:!0}),e.info(`
5
+ ✓ Removed ${f}`)}catch(o){throw new Error(`Failed to remove ${f}: ${o instanceof Error?o.message:String(o)}`,{cause:o})}e.info("✓ vis has been uninstalled.")},"execute");export{R as default};
@@ -1,5 +1 @@
1
- var g=Object.defineProperty;var a=(e,i)=>g(e,"name",{value:i,configurable:!0});import{createRequire as _}from"node:module";import{M as n,i as u,$ as p}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{d as $}from"./config.js";import{l as j}from"./bin.js";const b=_(import.meta.url),c=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,d=a(e=>{if(typeof c<"u"&&c.versions&&c.versions.node){const[i,s]=c.versions.node.split(".").map(Number);if(i>22||i===22&&s>=3||i===20&&s>=16)return c.getBuiltinModule(e)}return b(e)},"__cjs_getBuiltinModule"),{rmSync:y}=d("node:fs"),{homedir:r}=d("node:os"),{createInterface:w}=d("node:readline");var T=Object.defineProperty,m=a((e,i)=>T(e,"name",{value:i,configurable:!0}),"l");const f=j(),h=[n(r(),".zshrc"),n(r(),".zshenv"),n(r(),".bashrc"),n(r(),".bash_profile"),n(r(),".profile"),n(r(),".config","fish","config.fish")],M=m(e=>{const i=[];for(const s of h)if(u(s))try{const l=p(s).split(`
2
- `),o=l.filter(t=>!t.includes(".vis/bin")&&!t.includes("VIS_HOME")&&!t.includes("# vis "));o.length!==l.length&&($(s,o.join(`
3
- `)),i.push(s))}catch{e.warn(`warning: could not clean ${s}`)}return i},"cleanShellProfiles"),R=m(async({logger:e,options:i})=>{if(!u(f)){e.info("vis is not installed (no ~/.vis directory found).");return}e.info("This will remove:"),e.info(` ${f}/`);const s=h.filter(o=>u(o)&&p(o).includes(".vis"));for(const o of s)e.info(` Lines in ${o}`);if(!i.yes){if(!process.stdin.isTTY)throw new Error("Non-interactive terminal. Use --yes to confirm.");const o=w({input:process.stdin,output:process.stdout}),t=await new Promise(v=>{o.question(`
4
- Type "uninstall" to confirm: `,v)});if(o.close(),t.trim()!=="uninstall"){e.info("Aborted.");return}}const l=M(e);for(const o of l)e.info(`Cleaned ${o}`);try{y(f,{force:!0,recursive:!0}),e.info(`
5
- ✓ Removed ${f}`)}catch(o){throw new Error(`Failed to remove ${f}: ${o instanceof Error?o.message:String(o)}`,{cause:o})}e.info("✓ vis has been uninstalled.")},"execute");export{R as default};
1
+ var g=Object.defineProperty;var c=(e,a)=>g(e,"name",{value:a,configurable:!0});import{R as d,S as k}from"../packem_shared/pm-runner-Ta_yz2uP.js";var u=Object.defineProperty,v=c((e,a)=>u(e,"name",{value:a,configurable:!0}),"t");const x=v(async({argument:e,logger:a,options:r,process:i,visConfig:n,workspaceRoot:t})=>{if(!e||e.length===0)throw new Error("No package specified. Usage: vis info <package> [field...]");const[f,...p]=e,s=t??i.cwd,l=d(s,{configBackend:n?.install?.backend,configCorepack:n?.install?.corepack}),o=k(l,{fields:p,json:r.json||!1,package:f},s,a);o!==0&&o!==1&&(process.exitCode=o)},"execute");export{x as default};
@@ -1 +1,27 @@
1
- var g=Object.defineProperty;var c=(e,a)=>g(e,"name",{value:a,configurable:!0});import{R as d,S as k}from"../packem_shared/pm-runner-BwX5AL3W.js";var u=Object.defineProperty,v=c((e,a)=>u(e,"name",{value:a,configurable:!0}),"t");const x=v(async({argument:e,logger:a,options:r,process:i,visConfig:n,workspaceRoot:t})=>{if(!e||e.length===0)throw new Error("No package specified. Usage: vis info <package> [field...]");const[f,...p]=e,s=t??i.cwd,l=d(s,{configBackend:n?.install?.backend,configCorepack:n?.install?.corepack}),o=k(l,{fields:p,json:r.json||!1,package:f},s,a);o!==0&&o!==1&&(process.exitCode=o)},"execute");export{x as default};
1
+ var M=Object.defineProperty;var j=(o,s)=>M(o,"name",{value:s,configurable:!0});import{createRequire as N}from"node:module";import{i as b,M as d,z as P}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{H as v,q as w,j as q}from"./config.js";import{p as e}from"./bin.js";import{A as K}from"../packem_shared/pm-runner-Ta_yz2uP.js";import{O as G}from"../packem_shared/build-scripts-D-ysm_bS.js";import{N as A}from"../packem_shared/native-config-sync-CgRIIRZV.js";import{E as T}from"../packem_shared/min-release-age-YyNI7gqV.js";const B=N(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,C=j(o=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[s,t]=h.versions.node.split(".").map(Number);if(s>22||s===22&&t>=3||s===20&&t>=16)return h.getBuiltinModule(o)}return B(o)},"__cjs_getBuiltinModule"),{execFileSync:I}=C("node:child_process"),{createInterface:F}=C("node:readline");var L=Object.defineProperty,u=j((o,s)=>L(o,"name",{value:s,configurable:!0}),"f");const Y=u(o=>{const s=[];return b(d(o,"turbo.json"))&&s.push("turborepo"),b(d(o,"nx.json"))&&s.push("nx"),b(d(o,".moon"))&&s.push("moon"),s},"detectExistingTools"),E=u((o,s)=>new Promise(t=>{o.question(s,i=>{t(i.trim())})}),"ask"),m=u(async(o,s,t=!0)=>{const i=await E(o,`${s} ${t?"[Y/n]":"[y/N]"} `);return i===""?t:i.toLowerCase()==="y"||i.toLowerCase()==="yes"},"confirm"),k=u((o,s)=>{const t=[],i=Object.entries(s.allowBuilds).filter(([,l])=>l).map(([l])=>` "${l}": true,`).join(`
2
+ `),a=[` installScripts: {
3
+ allow: ${i?`{
4
+ ${i}
5
+ }`:"{}"},
6
+ },`];s.minimumReleaseAge!==void 0&&a.push(` firstSeen: {
7
+ minutes: ${String(s.minimumReleaseAge)},
8
+ },`);let n=` policies: {
9
+ ${a.join(`
10
+ `)}
11
+ },`;return s.enableSocket&&(n+=`
12
+ socket: { enabled: true },`),s.enableDepsDev&&(n+=`
13
+ depsDev: { enabled: true },`),t.push(` security: {
14
+ ${n}
15
+ },`),s.staged&&t.push(` staged: {
16
+ "*": ["vis lint --staged --fix", "vis fmt --staged"],
17
+ },`),`import { defineConfig } from "@visulima/vis/config";
18
+
19
+ export default defineConfig({
20
+ ${t.join(`
21
+
22
+ `)}
23
+ });
24
+ `},"generateConfigContent"),z=u(async(o,s,t)=>{const i=F({input:process.stdin,output:process.stdout});e.info(`
25
+ vis init — interactive setup
26
+ `);const a=await m(i," Enable Socket.dev security scanning?");a&&(e.success(" Socket.dev enabled — scores, alerts, and supply chain data active."),process.env.VIS_SOCKET_TOKEN||e.notice(" Set VIS_SOCKET_TOKEN for a custom API token (optional).")),e.info("");const n=await m(i," Enable Google deps.dev (OpenSSF Scorecard + GHSA advisories)?");n&&e.success(" deps.dev enabled — Scorecard signals and advisories merged into the security report."),e.info("");const l=await m(i," Scan for packages with build scripts?"),g={};if(l){e.info(" Scanning node_modules...");const c=G(o,{});if(c.length>0){e.info(` Found ${String(c.length)} package${c.length===1?"":"s"} with build scripts:
27
+ `);for(const r of c){const f=await m(i,` Allow ${r}?`,!1),x=r.split(" (")[0]??r;g[x]=f,f&&e.success(` ✓ ${x} approved`)}}else e.info(" No packages with build scripts found.")}e.info("");const O=await m(i," Enforce a minimum release age (block freshly-published versions)?");let p;if(O){const c=await E(i,` Minimum age in minutes (default ${String(v)} = 2 days): `),r=c===""?v:Number.parseInt(c,10);p=Number.isFinite(r)&&r>0?r:v,e.success(` minimumReleaseAge: ${String(p)} minutes`)}e.info("");const S=await m(i," Set up pre-commit hooks (lint-staged)?",!1);let y=!1;(s.name==="pnpm"||s.name==="yarn"||s.name==="npm"||s.name==="bun")&&(e.info(""),y=await m(i,` Sync security settings to ${s.name} config?`));const $=Y(o);if($.length>0&&(e.info(""),e.info(` Detected existing tools: ${$.join(", ")}`),await m(i,` Run \`vis migrate\` for ${$.join(", ")}?`,!1))){i.close();const[c,...r]=s.name==="pnpm"?["pnpm","exec"]:s.name==="yarn"?["yarn","exec"]:s.name==="bun"?["bunx"]:["npx"];for(const f of $){e.info(` Migrating from ${f}...`);try{I(c,[...r,"vis","migrate",f],{cwd:o,stdio:"inherit"})}catch{e.warn(` Migration from ${f} had issues — run \`vis migrate ${f}\` manually.`)}}if(b(t))e.success(`Migrated config written to ${t}`);else{const f=k(s.name,{allowBuilds:g,enableDepsDev:n,enableSocket:a,minimumReleaseAge:p,staged:S});w(t,f),e.success(`Created ${t}`)}e.notice(" Run 'vis doctor' to see your project's full health status.");return}i.close(),e.info("");const D=k(s.name,{allowBuilds:g,enableDepsDev:n,enableSocket:a,minimumReleaseAge:p,staged:S});if(w(t,D),e.success(`Created ${t}`),y){const c=Object.fromEntries(Object.entries(g).filter(([,r])=>r));for(const r of A(s.name,o,c))e.success(` ${r}`);for(const r of T(s.name,o,p))e.success(` ${r}`)}e.info(""),e.info(" Setup complete. Your config:");const _=[a&&"Socket.dev",n&&"deps.dev"].filter(Boolean);e.info(` Security: ${_.length>0?`${_.join(" + ")} enabled`:"defaults only"}`),e.info(` Build scripts: ${Object.values(g).filter(Boolean).length} approved`),e.info(` Min age: ${p===void 0?"not enforced":`${String(p)} minutes`}`),e.info(` Git hooks: ${S?"lint-staged configured":"not configured"}`),e.info(` PM sync: ${y?"done":"skipped"}`),e.info(""),e.notice(" Run 'vis doctor' to see your project's full health status."),e.info("")},"runInteractiveInit"),H=u((o,s,t,i)=>{const a=k(s.name,{allowBuilds:{},enableDepsDev:!1,enableSocket:!1,minimumReleaseAge:v,staged:!1});if(w(i,a),e.success(`Created ${i}`),e.info(" Secure defaults are applied automatically by defineConfig()."),t.syncNative){for(const n of A(s.name,o,{}))e.success(` ${n}`);for(const n of T(s.name,o,v))e.success(` ${n}`)}e.info(""),e.notice("Run 'vis doctor' for a full health check, or 'vis init' in a terminal for guided setup.")},"runStaticInit"),R=u((o,s,t)=>{const i=d(o,".."),a=d(s,"node_modules","@visulima","vis","schemas",t),n=P(i,a),l=n===""?`./${t}`:n.split(/[/\\]/u).join("/");return l.startsWith(".")?l:`./${l}`},"buildSchemaRef"),V=u((o,s)=>{const t=R(d(o,"project.json"),s,"project.schema.json"),i=R(d(o,"vis.config.ts"),s,"vis-config.schema.json");e.info(""),e.info("Paste these into your config files to get editor IntelliSense:"),e.info(""),e.info(` project.json → "$schema": "${t}"`),e.info(` vis.config.ts → see ${i} (vis.config.ts is TypeScript; use the import path directly)`),e.info(""),e.notice("For nested project.json files, the `..` depth changes — run `vis migrate nx` to auto-rewrite all of them.")},"printSchemaPaths"),te=u(async({options:o,workspaceRoot:s})=>{const t=s??process.cwd();if(o.schema){V(t,t);return}const i=K(t),a=q(t);if(a&&!o.force){e.warn(`Config already exists: ${a}`),e.notice("Use --force to overwrite, or edit the existing file.");return}const n=a??d(t,"vis.config.ts");process.stdin.isTTY&&o.interactive!==!1?await z(t,i,n):H(t,i,o,n)},"execute");export{R as buildSchemaRefForTesting,te as default};
@@ -1,27 +1,5 @@
1
- var D=Object.defineProperty;var j=(o,s)=>D(o,"name",{value:s,configurable:!0});import{createRequire as M}from"node:module";import{i as b,M as d,z as P}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{H as v,d as w,j as K}from"./config.js";import{p as e}from"./bin.js";import{A as q}from"../packem_shared/pm-runner-BwX5AL3W.js";import{O as G}from"../packem_shared/build-scripts-3E2pmscY.js";import{N as A}from"../packem_shared/native-config-sync-DdhTLlKL.js";import{E as T}from"../packem_shared/min-release-age-aEn0x8Vy.js";const N=M(import.meta.url),h=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,C=j(o=>{if(typeof h<"u"&&h.versions&&h.versions.node){const[s,t]=h.versions.node.split(".").map(Number);if(s>22||s===22&&t>=3||s===20&&t>=16)return h.getBuiltinModule(o)}return N(o)},"__cjs_getBuiltinModule"),{execFileSync:I}=C("node:child_process"),{createInterface:F}=C("node:readline");var L=Object.defineProperty,u=j((o,s)=>L(o,"name",{value:s,configurable:!0}),"f");const Y=u(o=>{const s=[];return b(d(o,"turbo.json"))&&s.push("turborepo"),b(d(o,"nx.json"))&&s.push("nx"),b(d(o,".moon"))&&s.push("moon"),s},"detectExistingTools"),E=u((o,s)=>new Promise(t=>{o.question(s,i=>{t(i.trim())})}),"ask"),m=u(async(o,s,t=!0)=>{const i=await E(o,`${s} ${t?"[Y/n]":"[y/N]"} `);return i===""?t:i.toLowerCase()==="y"||i.toLowerCase()==="yes"},"confirm"),k=u((o,s)=>{const t=[],i=Object.entries(s.allowBuilds).filter(([,l])=>l).map(([l])=>` "${l}": true,`).join(`
2
- `),a=[` installScripts: {
3
- allow: ${i?`{
4
- ${i}
5
- }`:"{}"},
6
- },`];s.minimumReleaseAge!==void 0&&a.push(` firstSeen: {
7
- minutes: ${String(s.minimumReleaseAge)},
8
- },`);let n=` policies: {
9
- ${a.join(`
10
- `)}
11
- },`;return s.enableSocket&&(n+=`
12
- socket: { enabled: true },`),s.enableDepsDev&&(n+=`
13
- depsDev: { enabled: true },`),t.push(` security: {
14
- ${n}
15
- },`),s.staged&&t.push(` staged: {
16
- "*": ["vis lint --staged --fix", "vis fmt --staged"],
17
- },`),`import { defineConfig } from "@visulima/vis/config";
18
-
19
- export default defineConfig({
20
- ${t.join(`
21
-
22
- `)}
23
- });
24
- `},"generateConfigContent"),z=u(async(o,s,t)=>{const i=F({input:process.stdin,output:process.stdout});e.info(`
25
- vis init — interactive setup
26
- `);const a=await m(i," Enable Socket.dev security scanning?");a&&(e.success(" Socket.dev enabled — scores, alerts, and supply chain data active."),process.env.VIS_SOCKET_TOKEN||e.notice(" Set VIS_SOCKET_TOKEN for a custom API token (optional).")),e.info("");const n=await m(i," Enable Google deps.dev (OpenSSF Scorecard + GHSA advisories)?");n&&e.success(" deps.dev enabled — Scorecard signals and advisories merged into the security report."),e.info("");const l=await m(i," Scan for packages with build scripts?"),g={};if(l){e.info(" Scanning node_modules...");const c=G(o,{});if(c.length>0){e.info(` Found ${String(c.length)} package${c.length===1?"":"s"} with build scripts:
27
- `);for(const r of c){const f=await m(i,` Allow ${r}?`,!1),x=r.split(" (")[0]??r;g[x]=f,f&&e.success(` ✓ ${x} approved`)}}else e.info(" No packages with build scripts found.")}e.info("");const O=await m(i," Enforce a minimum release age (block freshly-published versions)?");let p;if(O){const c=await E(i,` Minimum age in minutes (default ${String(v)} = 2 days): `),r=c===""?v:Number.parseInt(c,10);p=Number.isFinite(r)&&r>0?r:v,e.success(` minimumReleaseAge: ${String(p)} minutes`)}e.info("");const S=await m(i," Set up pre-commit hooks (lint-staged)?",!1);let y=!1;(s.name==="pnpm"||s.name==="yarn"||s.name==="npm"||s.name==="bun")&&(e.info(""),y=await m(i,` Sync security settings to ${s.name} config?`));const $=Y(o);if($.length>0&&(e.info(""),e.info(` Detected existing tools: ${$.join(", ")}`),await m(i,` Run \`vis migrate\` for ${$.join(", ")}?`,!1))){i.close();const[c,...r]=s.name==="pnpm"?["pnpm","exec"]:s.name==="yarn"?["yarn","exec"]:s.name==="bun"?["bunx"]:["npx"];for(const f of $){e.info(` Migrating from ${f}...`);try{I(c,[...r,"vis","migrate",f],{cwd:o,stdio:"inherit"})}catch{e.warn(` Migration from ${f} had issues — run \`vis migrate ${f}\` manually.`)}}if(b(t))e.success(`Migrated config written to ${t}`);else{const f=k(s.name,{allowBuilds:g,enableDepsDev:n,enableSocket:a,minimumReleaseAge:p,staged:S});w(t,f),e.success(`Created ${t}`)}e.notice(" Run 'vis doctor' to see your project's full health status.");return}i.close(),e.info("");const B=k(s.name,{allowBuilds:g,enableDepsDev:n,enableSocket:a,minimumReleaseAge:p,staged:S});if(w(t,B),e.success(`Created ${t}`),y){const c=Object.fromEntries(Object.entries(g).filter(([,r])=>r));for(const r of A(s.name,o,c))e.success(` ${r}`);for(const r of T(s.name,o,p))e.success(` ${r}`)}e.info(""),e.info(" Setup complete. Your config:");const _=[a&&"Socket.dev",n&&"deps.dev"].filter(Boolean);e.info(` Security: ${_.length>0?`${_.join(" + ")} enabled`:"defaults only"}`),e.info(` Build scripts: ${Object.values(g).filter(Boolean).length} approved`),e.info(` Min age: ${p===void 0?"not enforced":`${String(p)} minutes`}`),e.info(` Git hooks: ${S?"lint-staged configured":"not configured"}`),e.info(` PM sync: ${y?"done":"skipped"}`),e.info(""),e.notice(" Run 'vis doctor' to see your project's full health status."),e.info("")},"runInteractiveInit"),H=u((o,s,t,i)=>{const a=k(s.name,{allowBuilds:{},enableDepsDev:!1,enableSocket:!1,minimumReleaseAge:v,staged:!1});if(w(i,a),e.success(`Created ${i}`),e.info(" Secure defaults are applied automatically by defineConfig()."),t.syncNative){for(const n of A(s.name,o,{}))e.success(` ${n}`);for(const n of T(s.name,o,v))e.success(` ${n}`)}e.info(""),e.notice("Run 'vis doctor' for a full health check, or 'vis init' in a terminal for guided setup.")},"runStaticInit"),R=u((o,s,t)=>{const i=d(o,".."),a=d(s,"node_modules","@visulima","vis","schemas",t),n=P(i,a),l=n===""?`./${t}`:n.split(/[/\\]/u).join("/");return l.startsWith(".")?l:`./${l}`},"buildSchemaRef"),V=u((o,s)=>{const t=R(d(o,"project.json"),s,"project.schema.json"),i=R(d(o,"vis.config.ts"),s,"vis-config.schema.json");e.info(""),e.info("Paste these into your config files to get editor IntelliSense:"),e.info(""),e.info(` project.json → "$schema": "${t}"`),e.info(` vis.config.ts → see ${i} (vis.config.ts is TypeScript; use the import path directly)`),e.info(""),e.notice("For nested project.json files, the `..` depth changes — run `vis migrate nx` to auto-rewrite all of them.")},"printSchemaPaths"),te=u(async({options:o,workspaceRoot:s})=>{const t=s??process.cwd();if(o.schema){V(t,t);return}const i=q(t),a=K(t);if(a&&!o.force){e.warn(`Config already exists: ${a}`),e.notice("Use --force to overwrite, or edit the existing file.");return}const n=a??d(t,"vis.config.ts");process.stdin.isTTY&&o.interactive!==!1?await z(t,i,n):H(t,i,o,n)},"execute");export{R as buildSchemaRefForTesting,te as default};
1
+ var y=Object.defineProperty;var w=(r,e)=>y(r,"name",{value:e,configurable:!0});import{I as N,E as $,T as M,e as R}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{p as g}from"./bin.js";import{r as S,M as x,a as A,b,c as P,d as j,e as C,f as E,g as B,h as D}from"../packem_shared/s1ngularity-CIX7UcT5.js";import{g as O,a as V,r as F}from"../packem_shared/provenance-DoEp2uOo.js";import{r as I}from"../packem_shared/signatures-BHM7cnqB.js";var T=Object.defineProperty,p=w((r,e)=>T(r,"name",{value:e,configurable:!0}),"p");const k=new Set(["archivedRepo","author","downloads","expiredDomains","metadata","newBin","provenance","s1ngularity","signatures"]),U=p(r=>{const e=r.trim();if(e==="")return;if(e.startsWith("@")){const o=e.indexOf("@",1);return o===-1?{name:e,spec:void 0}:{name:e.slice(0,o),spec:e.slice(o+1)||void 0}}const i=e.indexOf("@");return i===-1?{name:e,spec:void 0}:{name:e.slice(0,i),spec:e.slice(i+1)||void 0}},"parsePackageArg"),L=p(r=>{if(r===void 0||r.trim()==="")return;const e=new Set;for(const i of r.split(",")){const o=i.trim();if(!k.has(o))throw new Error(`Unknown marshall in --only: ${o}. Known: ${[...k].sort().join(", ")}.`);e.add(o)}return e},"parseOnlyFlag"),l=p((r,e)=>r===void 0||r.has(e),"should"),J=p(r=>r?.has("signatures")??!1,"shouldRunSignatures"),Q=p(async({argument:r,options:e,workspaceRoot:i})=>{if(!r||r.length===0)throw new Error("No package specified. Usage: vis inspect <package>[@<spec>]");const o=U(r[0]);if(o===void 0)throw new Error(`Invalid package argument: "${String(r[0])}". Usage: vis inspect <package>[@<spec>]`);const t=L(e.only),u=await O(o.name,{workspaceRoot:i});if(u===void 0){g.error(`Package ${o.name} not found in the registry.`),process.exitCode=2;return}const h=V(u,o.spec);if(h===void 0){g.error(`Could not resolve ${o.name}@${o.spec??"latest"} to a published version.`),process.exitCode=2;return}const c=[{name:o.name,version:h}],n=new x;if(l(t,"author")){const s=await S(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"author",message:a.message,packageName:a.packageName,severity:a.severity})}if(l(t,"provenance")){const s=await F(c);for(const a of s)n.add({marshall:"provenance",message:`Prior version ${a.priorVersionWithProvenance} had provenance but ${a.version} does not.`,packageName:a.packageName,severity:"error"})}if(l(t,"s1ngularity")){const s=await A(c,{workspaceRoot:i});for(const a of s){const d=a.hookChanges.map(v=>`${v.hook} (${v.kind})`).join(", "),m=a.hookChanges.length===1;n.add({marshall:"s1ngularity",message:`${a.version} ${m?"has an":"has"} install-script ${m?"change":"changes"} [${d}] AND dropped the provenance attestation that ${a.priorVersion} carried — this is the s1ngularity compromised-publish shape.`,packageName:a.packageName,severity:"error"})}}if(l(t,"newBin")){const s=await b(c);for(const a of s){const d=a.newBins.map(m=>m.command).join(", ");n.add({marshall:"newBin",message:`${a.toVersion} adds new bin script${a.newBins.length===1?"":"s"}: ${d} (prior: ${a.fromVersion}).`,packageName:a.packageName,severity:"warning"})}}if(l(t,"metadata")){const s=await P(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"metadata",message:`Missing/invalid metadata: ${a.issues.join(", ")}.`,packageName:a.packageName,severity:"warning"})}if(l(t,"downloads")){const s=await j([o.name]);for(const a of s){const d=a.downloadsLastMonth===void 0?"unknown":String(a.downloadsLastMonth);n.add({marshall:"downloads",message:a.kind==="no-data"?"npm stats API returned no monthly download data.":`Only ${d} downloads in the past month.`,packageName:a.packageName,severity:a.severity})}}if(l(t,"expiredDomains")){const s=await C(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"expiredDomains",message:a.kind==="expired"?`Maintainer email domain ${a.domain} (${a.maintainer}) is unregistered — potential hijack risk.`:`Could not verify maintainer email domain ${a.domain} (${a.maintainer}).`,packageName:a.packageName,severity:a.severity})}if(J(t)){const s=await I(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"signatures",message:a.message,packageName:a.packageName,severity:a.severity})}if(l(t,"archivedRepo")){const s=await E(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"archivedRepo",message:a.kind==="archived"?`Source repo ${a.owner}/${a.repo} is archived${a.archivedAt===void 0?"":` (since ${a.archivedAt})`}.`:`Source repo ${a.owner}/${a.repo} returned 404 from GitHub.`,packageName:a.packageName,severity:"warning"})}const f=n.all();if(e.json===!0)process.stdout.write(`${JSON.stringify(B(f),void 0,2)}
2
+ `);else{const s=`${o.name}@${h}`;if(f.length===0)g.info(`${N("✓")} ${s} — no findings.`);else{g.info(`${$("Inspecting")} ${s}`);for(const m of D(f))process.stdout.write(`${m}
3
+ `);const a=n.errors().length,d=n.warnings().length;process.stdout.write(`
4
+ ${$("Summary:")} ${M(`${String(a)} error${a===1?"":"s"}`)}, ${R(`${String(d)} warning${d===1?"":"s"}`)}.
5
+ `)}}(n.hasErrors()||e.strict===!0&&!n.isEmpty())&&(process.exitCode=1)},"execute");export{Q as default,U as parsePackageArg};
@@ -1,5 +1 @@
1
- var y=Object.defineProperty;var w=(r,e)=>y(r,"name",{value:e,configurable:!0});import{I as N,E as $,T as M,e as R}from"../packem_shared/index.server-B7ETiT4C.js";import{p as g}from"./bin.js";import{r as S,M as x,a as A,b,c as P,d as j,e as C,f as E,g as B,h as D}from"../packem_shared/s1ngularity-Bs9fUf3q.js";import{g as O,a as V,r as F}from"../packem_shared/provenance-BuiEsWbI.js";import{r as I}from"../packem_shared/signatures-LYMy8OR5.js";var T=Object.defineProperty,p=w((r,e)=>T(r,"name",{value:e,configurable:!0}),"p");const k=new Set(["archivedRepo","author","downloads","expiredDomains","metadata","newBin","provenance","s1ngularity","signatures"]),U=p(r=>{const e=r.trim();if(e==="")return;if(e.startsWith("@")){const o=e.indexOf("@",1);return o===-1?{name:e,spec:void 0}:{name:e.slice(0,o),spec:e.slice(o+1)||void 0}}const i=e.indexOf("@");return i===-1?{name:e,spec:void 0}:{name:e.slice(0,i),spec:e.slice(i+1)||void 0}},"parsePackageArg"),L=p(r=>{if(r===void 0||r.trim()==="")return;const e=new Set;for(const i of r.split(",")){const o=i.trim();if(!k.has(o))throw new Error(`Unknown marshall in --only: ${o}. Known: ${[...k].sort().join(", ")}.`);e.add(o)}return e},"parseOnlyFlag"),l=p((r,e)=>r===void 0||r.has(e),"should"),J=p(r=>r?.has("signatures")??!1,"shouldRunSignatures"),Q=p(async({argument:r,options:e,workspaceRoot:i})=>{if(!r||r.length===0)throw new Error("No package specified. Usage: vis inspect <package>[@<spec>]");const o=U(r[0]);if(o===void 0)throw new Error(`Invalid package argument: "${String(r[0])}". Usage: vis inspect <package>[@<spec>]`);const t=L(e.only),u=await O(o.name,{workspaceRoot:i});if(u===void 0){g.error(`Package ${o.name} not found in the registry.`),process.exitCode=2;return}const h=V(u,o.spec);if(h===void 0){g.error(`Could not resolve ${o.name}@${o.spec??"latest"} to a published version.`),process.exitCode=2;return}const c=[{name:o.name,version:h}],n=new x;if(l(t,"author")){const s=await S(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"author",message:a.message,packageName:a.packageName,severity:a.severity})}if(l(t,"provenance")){const s=await F(c);for(const a of s)n.add({marshall:"provenance",message:`Prior version ${a.priorVersionWithProvenance} had provenance but ${a.version} does not.`,packageName:a.packageName,severity:"error"})}if(l(t,"s1ngularity")){const s=await A(c,{workspaceRoot:i});for(const a of s){const d=a.hookChanges.map(v=>`${v.hook} (${v.kind})`).join(", "),m=a.hookChanges.length===1;n.add({marshall:"s1ngularity",message:`${a.version} ${m?"has an":"has"} install-script ${m?"change":"changes"} [${d}] AND dropped the provenance attestation that ${a.priorVersion} carried — this is the s1ngularity compromised-publish shape.`,packageName:a.packageName,severity:"error"})}}if(l(t,"newBin")){const s=await b(c);for(const a of s){const d=a.newBins.map(m=>m.command).join(", ");n.add({marshall:"newBin",message:`${a.toVersion} adds new bin script${a.newBins.length===1?"":"s"}: ${d} (prior: ${a.fromVersion}).`,packageName:a.packageName,severity:"warning"})}}if(l(t,"metadata")){const s=await P(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"metadata",message:`Missing/invalid metadata: ${a.issues.join(", ")}.`,packageName:a.packageName,severity:"warning"})}if(l(t,"downloads")){const s=await j([o.name]);for(const a of s){const d=a.downloadsLastMonth===void 0?"unknown":String(a.downloadsLastMonth);n.add({marshall:"downloads",message:a.kind==="no-data"?"npm stats API returned no monthly download data.":`Only ${d} downloads in the past month.`,packageName:a.packageName,severity:a.severity})}}if(l(t,"expiredDomains")){const s=await C(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"expiredDomains",message:a.kind==="expired"?`Maintainer email domain ${a.domain} (${a.maintainer}) is unregistered — potential hijack risk.`:`Could not verify maintainer email domain ${a.domain} (${a.maintainer}).`,packageName:a.packageName,severity:a.severity})}if(J(t)){const s=await I(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"signatures",message:a.message,packageName:a.packageName,severity:a.severity})}if(l(t,"archivedRepo")){const s=await E(c,{workspaceRoot:i});for(const a of s)n.add({marshall:"archivedRepo",message:a.kind==="archived"?`Source repo ${a.owner}/${a.repo} is archived${a.archivedAt===void 0?"":` (since ${a.archivedAt})`}.`:`Source repo ${a.owner}/${a.repo} returned 404 from GitHub.`,packageName:a.packageName,severity:"warning"})}const f=n.all();if(e.json===!0)process.stdout.write(`${JSON.stringify(B(f),void 0,2)}
2
- `);else{const s=`${o.name}@${h}`;if(f.length===0)g.info(`${N("✓")} ${s} — no findings.`);else{g.info(`${$("Inspecting")} ${s}`);for(const m of D(f))process.stdout.write(`${m}
3
- `);const a=n.errors().length,d=n.warnings().length;process.stdout.write(`
4
- ${$("Summary:")} ${M(`${String(a)} error${a===1?"":"s"}`)}, ${R(`${String(d)} warning${d===1?"":"s"}`)}.
5
- `)}}(n.hasErrors()||e.strict===!0&&!n.isEmpty())&&(process.exitCode=1)},"execute");export{Q as default,U as parsePackageArg};
1
+ var M=Object.defineProperty;var d=(s,r)=>M(s,"name",{value:r,configurable:!0});import{createRequire as T}from"node:module";import{i as F,M as h,K as N,O as H}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{p as n}from"./bin.js";import{A as J,R as K,I as Q,C as U}from"../packem_shared/pm-runner-Ta_yz2uP.js";import{s as W}from"../packem_shared/typosquats-DRKU6d2S.js";import{h as G,P as V}from"../packem_shared/peer-warnings-EvSJ18gE.js";import{o as X}from"../packem_shared/utils-DrNg0XTR.js";const B=T(import.meta.url),l=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,A=d(s=>{if(typeof l<"u"&&l.versions&&l.versions.node){const[r,t]=l.versions.node.split(".").map(Number);if(r>22||r===22&&t>=3||r===20&&t>=16)return l.getBuiltinModule(s)}return B(s)},"__cjs_getBuiltinModule"),{rmSync:$}=A("node:fs");var Y=Object.defineProperty,y=d((s,r)=>Y(s,"name",{value:r,configurable:!0}),"u");const Z=["pnpm-lock.yaml","yarn.lock","package-lock.json","npm-shrinkwrap.json","bun.lock","bun.lockb"],ee=y(s=>{let r=s;for(;;){for(const e of Z)if(F(h(r,e)))return!0;const t=N(r);if(t===r||H(r).root===r)return!1;r=t}},"hasLockfile"),g=new Set(["aube","auto","bun","npm","pnpm","yarn"]),ce=y(async s=>{const{argument:r,logger:t,options:e,visConfig:c,workspaceRoot:C}=s,a=C??process.cwd();if(r&&r.length>0){const o=e,{default:j}=await import("./handler16.js"),q=o.marshallCheck===!1||o["no-marshall-check"]===!0?!1:void 0,S=o.socketCheck===!1||o["no-socket-check"]===!0?!1:void 0,P=o.typosquatCheck===!1||o["no-typosquat-check"]===!0?!1:void 0,z=o.runScripts===!0||o["run-scripts"]===!0,E=o.workspaceRoot===!0||o["workspace-root"]===!0,I=o.saveOptional===!0||o["save-optional"]===!0,D=e.dev===!0,L={autoInstallPeers:!1,exact:o.exact===!0,filter:e.filter,global:!1,marshallCheck:q,runScripts:z,saveDev:D,saveOptional:I,savePeer:!1,socketCheck:S,to:void 0,typosquatCheck:P,workspace:!1,workspaceRoot:E};await j({...s,argument:r,options:L});return}if(e.typosquatCheck!==!1&&!await W(a,c?.security?.typosquatAllowlist)){process.exitCode=1;return}const i=e.installer;if(i&&!g.has(i)){n.error(`Invalid --installer value: "${i}". Expected one of: ${[...g].join(", ")}.`),process.exitCode=1;return}const w=i,b=e.aube===!1;let f;try{f=b?J(a):K(a,{backend:w,configBackend:c?.install?.backend,configCorepack:c?.install?.corepack})}catch(o){n.error(o instanceof Error?o.message:String(o)),process.exitCode=1;return}const k=Q(a,f);k&&n.warn(k);const _=X(e.filter),p=e.ci||!1,m=e.frozenLockfile||p,O=e.frozenLockfile===!1||e.force||e.lockfileOnly,x=ee(a),v=m||!O&&x;if(!m&&v&&!e.silent&&n.info("Defaulting to frozen lockfile (pass --no-frozen-lockfile to allow lockfile updates)."),p){n.info("Clean install: removing node_modules...");try{$(h(a,"node_modules"),{force:!0,recursive:!0})}catch(o){n.error(`Failed to remove node_modules: ${o instanceof Error?o.message:String(o)}`),process.exitCode=1;return}}const{code:u,output:R}=await U(f,{dev:e.dev||!1,filter:_,force:e.force||!1,frozenLockfile:v,ignoreScripts:!e.runScripts,lockfileOnly:e.lockfileOnly||!1,noOptional:e.optional===!1,offline:e.offline||!1,prod:e.prod||!1,recursive:e.recursive||!1,silent:e.silent||!1,workspaceRoot:e.workspaceRoot||!1},a,t,{ciMode:p,preferOffline:e.preferOffline||!1});u!==0&&(process.exitCode=u),u===0&&!e.silent&&G(R)&&n.info(V)},"execute");export{ce as default};
@@ -1 +1 @@
1
- var M=Object.defineProperty;var d=(s,r)=>M(s,"name",{value:r,configurable:!0});import{createRequire as T}from"node:module";import{i as F,M as h,K as N,O as H}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{p as n}from"./bin.js";import{A as J,R as K,I as Q,C as U}from"../packem_shared/pm-runner-BwX5AL3W.js";import{s as W}from"../packem_shared/typosquats-znskIR5j.js";import{h as G,P as V}from"../packem_shared/peer-warnings-EvSJ18gE.js";import{o as X}from"../packem_shared/utils-DrNg0XTR.js";const B=T(import.meta.url),l=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,A=d(s=>{if(typeof l<"u"&&l.versions&&l.versions.node){const[r,t]=l.versions.node.split(".").map(Number);if(r>22||r===22&&t>=3||r===20&&t>=16)return l.getBuiltinModule(s)}return B(s)},"__cjs_getBuiltinModule"),{rmSync:$}=A("node:fs");var Y=Object.defineProperty,y=d((s,r)=>Y(s,"name",{value:r,configurable:!0}),"u");const Z=["pnpm-lock.yaml","yarn.lock","package-lock.json","npm-shrinkwrap.json","bun.lock","bun.lockb"],ee=y(s=>{let r=s;for(;;){for(const e of Z)if(F(h(r,e)))return!0;const t=N(r);if(t===r||H(r).root===r)return!1;r=t}},"hasLockfile"),g=new Set(["aube","auto","bun","npm","pnpm","yarn"]),ce=y(async s=>{const{argument:r,logger:t,options:e,visConfig:c,workspaceRoot:C}=s,a=C??process.cwd();if(r&&r.length>0){const o=e,{default:j}=await import("./handler17.js"),q=o.marshallCheck===!1||o["no-marshall-check"]===!0?!1:void 0,S=o.socketCheck===!1||o["no-socket-check"]===!0?!1:void 0,P=o.typosquatCheck===!1||o["no-typosquat-check"]===!0?!1:void 0,z=o.runScripts===!0||o["run-scripts"]===!0,E=o.workspaceRoot===!0||o["workspace-root"]===!0,I=o.saveOptional===!0||o["save-optional"]===!0,D=e.dev===!0,L={autoInstallPeers:!1,exact:o.exact===!0,filter:e.filter,global:!1,marshallCheck:q,runScripts:z,saveDev:D,saveOptional:I,savePeer:!1,socketCheck:S,to:void 0,typosquatCheck:P,workspace:!1,workspaceRoot:E};await j({...s,argument:r,options:L});return}if(e.typosquatCheck!==!1&&!await W(a,c?.security?.typosquatAllowlist)){process.exitCode=1;return}const i=e.installer;if(i&&!g.has(i)){n.error(`Invalid --installer value: "${i}". Expected one of: ${[...g].join(", ")}.`),process.exitCode=1;return}const w=i,b=e.aube===!1;let f;try{f=b?J(a):K(a,{backend:w,configBackend:c?.install?.backend,configCorepack:c?.install?.corepack})}catch(o){n.error(o instanceof Error?o.message:String(o)),process.exitCode=1;return}const k=Q(a,f);k&&n.warn(k);const _=X(e.filter),p=e.ci||!1,m=e.frozenLockfile||p,O=e.frozenLockfile===!1||e.force||e.lockfileOnly,x=ee(a),v=m||!O&&x;if(!m&&v&&!e.silent&&n.info("Defaulting to frozen lockfile (pass --no-frozen-lockfile to allow lockfile updates)."),p){n.info("Clean install: removing node_modules...");try{$(h(a,"node_modules"),{force:!0,recursive:!0})}catch(o){n.error(`Failed to remove node_modules: ${o instanceof Error?o.message:String(o)}`),process.exitCode=1;return}}const{code:u,output:R}=await U(f,{dev:e.dev||!1,filter:_,force:e.force||!1,frozenLockfile:v,ignoreScripts:!e.runScripts,lockfileOnly:e.lockfileOnly||!1,noOptional:e.optional===!1,offline:e.offline||!1,prod:e.prod||!1,recursive:e.recursive||!1,silent:e.silent||!1,workspaceRoot:e.workspaceRoot||!1},a,t,{ciMode:p,preferOffline:e.preferOffline||!1});u!==0&&(process.exitCode=u),u===0&&!e.silent&&G(R)&&n.info(V)},"execute");export{ce as default};
1
+ var O=Object.defineProperty;var $=(s,a)=>O(s,"name",{value:a,configurable:!0});import{createRequire as A}from"node:module";import{E,T as N,e as z,I as M}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{n as B,w as U}from"./config.js";import{l as V,Y as C,$ as Y,p as f,a0 as x,a1 as J,a2 as K,f as Q,C as W,T as G,a as H,a3 as X,i as P,c as Z,a4 as ee}from"./bin.js";import{M as oe}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{y as se,R as te,P as ne}from"../packem_shared/pm-runner-Ta_yz2uP.js";import{r as D,a as ae,b as re,p as ie}from"../packem_shared/resolve-explicit-DpSc7RN2.js";import{r as ce}from"../packem_shared/typosquats-DRKU6d2S.js";import{d as T,o as R}from"../packem_shared/utils-DrNg0XTR.js";const L=A(import.meta.url),v=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,F=$(s=>{if(typeof v<"u"&&v.versions&&v.versions.node){const[a,e]=v.versions.node.split(".").map(Number);if(a>22||a===22&&e>=3||a===20&&e>=16)return v.getBuiltinModule(s)}return L(s)},"__cjs_getBuiltinModule"),{createInterface:I}=F("node:readline");var le=Object.defineProperty,w=$((s,a)=>le(s,"name",{value:a,configurable:!0}),"c");const j=w(s=>s==="default"?"catalog:":`catalog:${s}`,"buildCatalogRef"),b=w(s=>s==="default"?"default catalog":`catalog "${s}"`,"labelForCatalog"),pe=w((s,a)=>{const e=[];for(const[o,n]of a)o.includes(":")||n.has(s)&&e.push(o);if(e.length===0)return;if(e.length===1){const[o]=e;return{source:b(o),spec:j(o)}}const r=e.find(o=>o==="default")??e[0],i=e.filter(o=>o!==r);return{candidates:[...e],conflict:!0,source:`${b(r)} (also in: ${i.map(o=>b(o)).join(", ")})`,spec:j(r)}},"resolveFromCatalogs"),fe=w((s,a)=>{const e=new Map;for(const[c,l]of a){if(!c.includes(":"))continue;const u=l.get(s);u!==void 0&&e.set(u,(e.get(u)??0)+1)}if(e.size===0)return;const r=[...e.entries()],i=r.reduce((c,[,l])=>c+l,0);if(r.length===1){const[[c]]=r;return{source:`siblings (${String(i)} pkg${i===1?"":"s"} on ${c})`,spec:c}}const o=[...r].sort((c,l)=>l[1]-c[1]),[n,t]=o[0],p=o.slice(1).map(([c,l])=>`${c} (×${String(l)})`);return{candidates:o.map(([c])=>c),conflict:!0,source:`siblings (most common: ${n} ×${String(t)}; conflicts: ${p.join(", ")})`,spec:n}},"resolveFromSiblings"),ue=w((s,a)=>pe(s,a)||fe(s,a),"conformToCatalog");var de=Object.defineProperty,g=$((s,a)=>de(s,"name",{value:a,configurable:!0}),"u");const ge=g((s,a,e)=>{const r=[];for(const i of s.values()){const{overall:o}=i.score,n=V(o),t=`${String(Math.round(o*100))}%`,p=i.alerts.length,c=C(i),l=Y(c,i.version,e),u=n==="red"?N:n==="yellow"?z:M;if(l?f.info(` ${u(t)} ${x(i)} ${E(`[accepted: ${l.reason}]`)}`):f.info(` ${u(t)} ${x(i)}`),p>0){const d=i.alerts.filter(m=>m.severity==="critical"||m.severity==="high").length;d>0&&f.warn(` ${String(d)} critical/high alert${d===1?"":"s"}`)}o<a&&!l&&r.push(i)}return r},"displaySecurityReports"),me=g(async(s,a)=>{const e=I({input:process.stdin,output:process.stdout}),r=g(t=>new Promise(p=>{e.question(t,c=>{p(c.trim())})}),"ask"),i=String(Math.round(a*100));f.warn(""),f.warn(`${String(s.length)} package${s.length===1?"":"s"} scored below the minimum threshold (${i}%):`);for(const t of s){const p=C(t),c=`${String(Math.round(t.score.overall*100))}%`;f.warn(` • ${p}@${t.version} — score: ${c} (${J(t.score.overall)})`)}f.warn("");const o=await r("Continue adding these packages? [y/N] ");if(o.toLowerCase()!=="y"&&o.toLowerCase()!=="yes")return e.close(),!1;const n=await r("Remember this decision? (prints config snippet) [y/N] ");if(e.close(),n.toLowerCase()==="y"||n.toLowerCase()==="yes"){f.notice(""),f.notice("Add the following to security.acceptedRisks in vis.config.ts:"),f.notice("");for(const t of s){const p=C(t),c=K(p,t.version,t.score.overall,"Reviewed and accepted");f.notice(c)}f.notice("")}return!0},"confirmLowScorePackages"),ke=g(async(s,a,e,r)=>{const i=await D(s);if(i.length===0)return!0;f.info(""),f.info(`${a.map(t=>t.displayName).join(" + ")} security check:`);const o=await Q(a,i);if(o.size===0)return f.info(" Could not fetch security data. Proceeding."),!0;const n=ge(o,e,r);return n.length===0?(f.info(""),!0):process.stdin.isTTY?me(n,e):(f.warn(`Aborting: ${String(n.length)} package${n.length===1?"":"s"} below minimum score. Use --no-socket-check to skip.`),!1)},"runSocketPreCheck"),he=["dependencies","devDependencies","peerDependencies","optionalDependencies"],ve=g(s=>s.savePeer?"peerDependencies":s.saveOptional?"optionalDependencies":s.saveDev?"devDependencies":"dependencies","pickDepSection"),_=g((s,a)=>s.startsWith("catalog:")||!a?s:s.replace(/^[\^~]/,""),"applyExactPrefix"),we=g(async(s,a)=>{const e=[];for(const o of s){const{name:n,versionSpec:t}=T(o);if(!n)continue;if(t!==void 0){e.push({explicit:t,name:n});continue}const p=ue(n,a);if(p){p.conflict&&f.warn(`${n}: ambiguous constraint — picking ${p.spec} (${p.source}). Pass ${n}@<version> to override.`),e.push({entry:{name:n,source:p.source,spec:p.spec},kind:"resolved",name:n});continue}e.push({kind:"missing",name:n})}const r=e.filter(o=>"kind"in o&&o.kind==="missing").map(o=>o.name),i=r.length>0?await ae(r):new Map;return e.map(o=>{if("explicit"in o)return{name:o.name,source:"explicit",spec:o.explicit};if(o.kind==="resolved")return o.entry;const n=i.get(o.name);if(n===void 0)throw new Error(`--to: cannot resolve a version for "${o.name}" (not in any catalog or sibling, and registry lookup failed). Pass ${o.name}@<version> explicitly.`);const t=`^${n}`;return f.info(`${o.name}: no existing constraint — using registry latest (${t}). Add to a catalog to share this version across workspace packages.`),{name:o.name,source:"registry latest",spec:t}})},"planConformedSpecs"),$e=g((s,a,e,r)=>{for(const{name:i,spec:o}of a){const n=_(o,r);for(const p of he){if(p===e)continue;const c=s[p];c?.[i]!==void 0&&(delete c[i],Object.keys(c).length===0&&delete s[p])}let t=s[e];t===void 0&&(t={},s[e]=t),t[i]=n}},"applyPlannedSpecsToPackageJson"),ye=g(async({ignoreScripts:s,logger:a,options:e,packages:r,pm:i,target:o,visConfig:n,workspaceRoot:t})=>{const{workspace:p}=W(t,n??{}),c=p.projects[o];if(!c){const k=Object.keys(p.projects).sort();throw new Error(`--to: workspace package "${o}" not found. Available: ${k.length>0?k.slice(0,10).join(", "):"(none)"}${k.length>10?`, ... (${String(k.length-10)} more)`:""}.`)}const l=oe(t,c.root,"package.json"),{packageManager:u}=G(t),d=H(t,u),m=ve(e),h=e.exact??!1,y=await we(r,d);if(y.length===0)return 0;const S=B(l);$e(S,y,m,h),U(l,S,{indent:X(l,{useEditorconfig:n?.editorconfig??!0}),overwrite:!0});for(const k of y){const q=_(k.spec,h);f.info(`${M("+")} ${k.name}@${q} ${o}/${m} (${E(k.source)})`)}return se(i,{dev:!1,filter:[],force:!1,frozenLockfile:!1,ignoreScripts:s,lockfileOnly:!1,noOptional:!1,offline:!1,prod:!1,recursive:!1,silent:!1,workspaceRoot:!1},t,a)},"applyConformedAdd"),Te=g(async({argument:s,logger:a,options:e,visConfig:r,workspaceRoot:i})=>{let o=s;if(!o||o.length===0)throw new Error("No packages specified. Usage: vis add <packages...>");if(e.typosquatCheck!==!1){const l=o.map(d=>T(d)),u=await ce(l.map(d=>d.name),r?.security?.typosquatAllowlist);if(!u.ok){process.exitCode=1;return}o=l.map((d,m)=>{const h=u.packages[m];return h!==d.name?d.versionSpec?`${h}@${d.versionSpec}`:h??"":o[m]??""})}if(e.marshallCheck!==!1){const l=await D(o);if(l.length>0){const u=await re(l,{config:r?.security?.marshalls,workspaceRoot:i});if(!await ie(u)){process.exitCode=1;return}}}if(e.socketCheck!==!1){const l=new Set;P("socket")&&l.add("socket"),P("depsDev")&&l.add("deps-dev");const u=Z(r?.security,{disabled:l,minimumScore:r?.security?.policies?.score?.minimum});if(u.length>0){const d=r?.security?.policies?.score?.minimum??ee;if(!await ke(o,u,d,r?.security?.acceptedRisks)){process.exitCode=1;return}}}const n=process.cwd(),t=te(i??n,{configBackend:r?.install?.backend,configCorepack:r?.install?.corepack}),p=!e.runScripts;if(e.to){if(e.global||e.workspaceRoot)throw new Error("--to is incompatible with --global / --workspace-root.");if(e.filter&&R(e.filter).length>0)throw new Error("--to and --filter are mutually exclusive — --to already targets one package.");if(!i)throw new Error("--to requires a monorepo workspace. Run from inside a pnpm/bun/yarn/npm workspace.");const l=await ye({ignoreScripts:p,logger:a,options:e,packages:o,pm:t,target:e.to,visConfig:r,workspaceRoot:i});l!==0&&(process.exitCode=l);return}const c=ne(t,{exact:e.exact||!1,filter:R(e.filter),global:e.global||!1,optional:e.saveOptional||!1,packages:o,peer:e.savePeer||!1,saveDev:e.saveDev||!1,workspace:e.workspace||!1,workspaceRoot:e.workspaceRoot||!1},n,a,{autoInstallPeers:e.autoInstallPeers||!1,ignoreScripts:p});c!==0&&(process.exitCode=c)},"execute");export{Te as default};
@@ -1 +1 @@
1
- var L=Object.defineProperty;var $=(s,a)=>L(s,"name",{value:a,configurable:!0});import{createRequire as O}from"node:module";import{E as M,T as N,e as z,I as E}from"../packem_shared/index.server-B7ETiT4C.js";import{n as B,w as U}from"./config.js";import{K as V,I as C,L as Y,p as f,M as R,N as J,Q as K,f as Q,C as W,U as X,R as G,X as H,i as x,b as Z,Y as ee}from"./bin.js";import{M as oe}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{y as se,R as te,P as ne}from"../packem_shared/pm-runner-BwX5AL3W.js";import{r as D,a as ae,b as re,p as ie}from"../packem_shared/resolve-explicit-RgRrUDZv.js";import{r as ce}from"../packem_shared/typosquats-znskIR5j.js";import{d as _,o as P}from"../packem_shared/utils-DrNg0XTR.js";const A=O(import.meta.url),v=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,F=$(s=>{if(typeof v<"u"&&v.versions&&v.versions.node){const[a,e]=v.versions.node.split(".").map(Number);if(a>22||a===22&&e>=3||a===20&&e>=16)return v.getBuiltinModule(s)}return A(s)},"__cjs_getBuiltinModule"),{createInterface:I}=F("node:readline");var le=Object.defineProperty,w=$((s,a)=>le(s,"name",{value:a,configurable:!0}),"c");const j=w(s=>s==="default"?"catalog:":`catalog:${s}`,"buildCatalogRef"),b=w(s=>s==="default"?"default catalog":`catalog "${s}"`,"labelForCatalog"),pe=w((s,a)=>{const e=[];for(const[o,n]of a)o.includes(":")||n.has(s)&&e.push(o);if(e.length===0)return;if(e.length===1){const[o]=e;return{source:b(o),spec:j(o)}}const r=e.find(o=>o==="default")??e[0],i=e.filter(o=>o!==r);return{candidates:[...e],conflict:!0,source:`${b(r)} (also in: ${i.map(o=>b(o)).join(", ")})`,spec:j(r)}},"resolveFromCatalogs"),fe=w((s,a)=>{const e=new Map;for(const[c,l]of a){if(!c.includes(":"))continue;const u=l.get(s);u!==void 0&&e.set(u,(e.get(u)??0)+1)}if(e.size===0)return;const r=[...e.entries()],i=r.reduce((c,[,l])=>c+l,0);if(r.length===1){const[[c]]=r;return{source:`siblings (${String(i)} pkg${i===1?"":"s"} on ${c})`,spec:c}}const o=[...r].sort((c,l)=>l[1]-c[1]),[n,t]=o[0],p=o.slice(1).map(([c,l])=>`${c} (×${String(l)})`);return{candidates:o.map(([c])=>c),conflict:!0,source:`siblings (most common: ${n} ×${String(t)}; conflicts: ${p.join(", ")})`,spec:n}},"resolveFromSiblings"),ue=w((s,a)=>pe(s,a)||fe(s,a),"conformToCatalog");var de=Object.defineProperty,g=$((s,a)=>de(s,"name",{value:a,configurable:!0}),"u");const ge=g((s,a,e)=>{const r=[];for(const i of s.values()){const{overall:o}=i.score,n=V(o),t=`${String(Math.round(o*100))}%`,p=i.alerts.length,c=C(i),l=Y(c,i.version,e),u=n==="red"?N:n==="yellow"?z:E;if(l?f.info(` ${u(t)} ${R(i)} ${M(`[accepted: ${l.reason}]`)}`):f.info(` ${u(t)} ${R(i)}`),p>0){const d=i.alerts.filter(m=>m.severity==="critical"||m.severity==="high").length;d>0&&f.warn(` ${String(d)} critical/high alert${d===1?"":"s"}`)}o<a&&!l&&r.push(i)}return r},"displaySecurityReports"),me=g(async(s,a)=>{const e=I({input:process.stdin,output:process.stdout}),r=g(t=>new Promise(p=>{e.question(t,c=>{p(c.trim())})}),"ask"),i=String(Math.round(a*100));f.warn(""),f.warn(`${String(s.length)} package${s.length===1?"":"s"} scored below the minimum threshold (${i}%):`);for(const t of s){const p=C(t),c=`${String(Math.round(t.score.overall*100))}%`;f.warn(` • ${p}@${t.version} — score: ${c} (${J(t.score.overall)})`)}f.warn("");const o=await r("Continue adding these packages? [y/N] ");if(o.toLowerCase()!=="y"&&o.toLowerCase()!=="yes")return e.close(),!1;const n=await r("Remember this decision? (prints config snippet) [y/N] ");if(e.close(),n.toLowerCase()==="y"||n.toLowerCase()==="yes"){f.notice(""),f.notice("Add the following to security.acceptedRisks in vis.config.ts:"),f.notice("");for(const t of s){const p=C(t),c=K(p,t.version,t.score.overall,"Reviewed and accepted");f.notice(c)}f.notice("")}return!0},"confirmLowScorePackages"),ke=g(async(s,a,e,r)=>{const i=await D(s);if(i.length===0)return!0;f.info(""),f.info(`${a.map(t=>t.displayName).join(" + ")} security check:`);const o=await Q(a,i);if(o.size===0)return f.info(" Could not fetch security data. Proceeding."),!0;const n=ge(o,e,r);return n.length===0?(f.info(""),!0):process.stdin.isTTY?me(n,e):(f.warn(`Aborting: ${String(n.length)} package${n.length===1?"":"s"} below minimum score. Use --no-socket-check to skip.`),!1)},"runSocketPreCheck"),he=["dependencies","devDependencies","peerDependencies","optionalDependencies"],ve=g(s=>s.savePeer?"peerDependencies":s.saveOptional?"optionalDependencies":s.saveDev?"devDependencies":"dependencies","pickDepSection"),T=g((s,a)=>s.startsWith("catalog:")||!a?s:s.replace(/^[\^~]/,""),"applyExactPrefix"),we=g(async(s,a)=>{const e=[];for(const o of s){const{name:n,versionSpec:t}=_(o);if(!n)continue;if(t!==void 0){e.push({explicit:t,name:n});continue}const p=ue(n,a);if(p){p.conflict&&f.warn(`${n}: ambiguous constraint — picking ${p.spec} (${p.source}). Pass ${n}@<version> to override.`),e.push({entry:{name:n,source:p.source,spec:p.spec},kind:"resolved",name:n});continue}e.push({kind:"missing",name:n})}const r=e.filter(o=>"kind"in o&&o.kind==="missing").map(o=>o.name),i=r.length>0?await ae(r):new Map;return e.map(o=>{if("explicit"in o)return{name:o.name,source:"explicit",spec:o.explicit};if(o.kind==="resolved")return o.entry;const n=i.get(o.name);if(n===void 0)throw new Error(`--to: cannot resolve a version for "${o.name}" (not in any catalog or sibling, and registry lookup failed). Pass ${o.name}@<version> explicitly.`);const t=`^${n}`;return f.info(`${o.name}: no existing constraint — using registry latest (${t}). Add to a catalog to share this version across workspace packages.`),{name:o.name,source:"registry latest",spec:t}})},"planConformedSpecs"),$e=g((s,a,e,r)=>{for(const{name:i,spec:o}of a){const n=T(o,r);for(const p of he){if(p===e)continue;const c=s[p];c?.[i]!==void 0&&(delete c[i],Object.keys(c).length===0&&delete s[p])}let t=s[e];t===void 0&&(t={},s[e]=t),t[i]=n}},"applyPlannedSpecsToPackageJson"),ye=g(async({ignoreScripts:s,logger:a,options:e,packages:r,pm:i,target:o,visConfig:n,workspaceRoot:t})=>{const{workspace:p}=W(t,n??{}),c=p.projects[o];if(!c){const k=Object.keys(p.projects).sort();throw new Error(`--to: workspace package "${o}" not found. Available: ${k.length>0?k.slice(0,10).join(", "):"(none)"}${k.length>10?`, ... (${String(k.length-10)} more)`:""}.`)}const l=oe(t,c.root,"package.json"),{packageManager:u}=X(t),d=G(t,u),m=ve(e),h=e.exact??!1,y=await we(r,d);if(y.length===0)return 0;const S=B(l);$e(S,y,m,h),U(l,S,{indent:H(l,{useEditorconfig:n?.editorconfig??!0}),overwrite:!0});for(const k of y){const q=T(k.spec,h);f.info(`${E("+")} ${k.name}@${q} → ${o}/${m} (${M(k.source)})`)}return se(i,{dev:!1,filter:[],force:!1,frozenLockfile:!1,ignoreScripts:s,lockfileOnly:!1,noOptional:!1,offline:!1,prod:!1,recursive:!1,silent:!1,workspaceRoot:!1},t,a)},"applyConformedAdd"),_e=g(async({argument:s,logger:a,options:e,visConfig:r,workspaceRoot:i})=>{let o=s;if(!o||o.length===0)throw new Error("No packages specified. Usage: vis add <packages...>");if(e.typosquatCheck!==!1){const l=o.map(d=>_(d)),u=await ce(l.map(d=>d.name),r?.security?.typosquatAllowlist);if(!u.ok){process.exitCode=1;return}o=l.map((d,m)=>{const h=u.packages[m];return h!==d.name?d.versionSpec?`${h}@${d.versionSpec}`:h??"":o[m]??""})}if(e.marshallCheck!==!1){const l=await D(o);if(l.length>0){const u=await re(l,{config:r?.security?.marshalls,workspaceRoot:i});if(!await ie(u)){process.exitCode=1;return}}}if(e.socketCheck!==!1){const l=new Set;x("socket")&&l.add("socket"),x("depsDev")&&l.add("deps-dev");const u=Z(r?.security,{disabled:l,minimumScore:r?.security?.policies?.score?.minimum});if(u.length>0){const d=r?.security?.policies?.score?.minimum??ee;if(!await ke(o,u,d,r?.security?.acceptedRisks)){process.exitCode=1;return}}}const n=process.cwd(),t=te(i??n,{configBackend:r?.install?.backend,configCorepack:r?.install?.corepack}),p=!e.runScripts;if(e.to){if(e.global||e.workspaceRoot)throw new Error("--to is incompatible with --global / --workspace-root.");if(e.filter&&P(e.filter).length>0)throw new Error("--to and --filter are mutually exclusive — --to already targets one package.");if(!i)throw new Error("--to requires a monorepo workspace. Run from inside a pnpm/bun/yarn/npm workspace.");const l=await ye({ignoreScripts:p,logger:a,options:e,packages:o,pm:t,target:e.to,visConfig:r,workspaceRoot:i});l!==0&&(process.exitCode=l);return}const c=ne(t,{exact:e.exact||!1,filter:P(e.filter),global:e.global||!1,optional:e.saveOptional||!1,packages:o,peer:e.savePeer||!1,saveDev:e.saveDev||!1,workspace:e.workspace||!1,workspaceRoot:e.workspaceRoot||!1},n,a,{autoInstallPeers:e.autoInstallPeers||!1,ignoreScripts:p});c!==0&&(process.exitCode=c)},"execute");export{_e as default};
1
+ var l=Object.defineProperty;var c=(e,a)=>l(e,"name",{value:a,configurable:!0});import{R as p,$ as f}from"../packem_shared/pm-runner-Ta_yz2uP.js";var g=Object.defineProperty,u=c((e,a)=>g(e,"name",{value:a,configurable:!0}),"s");const m=u(async({argument:e,logger:a,visConfig:o,workspaceRoot:s})=>{const t=e?.[0]??null,n=s??process.cwd(),i=p(n,{configBackend:o?.install?.backend,configCorepack:o?.install?.corepack}),r=f(i,t,n,a);r!==0&&(process.exitCode=r)},"execute");export{m as default};
@@ -1 +1 @@
1
- var l=Object.defineProperty;var c=(e,a)=>l(e,"name",{value:a,configurable:!0});import{R as p,$ as f}from"../packem_shared/pm-runner-BwX5AL3W.js";var g=Object.defineProperty,u=c((e,a)=>g(e,"name",{value:a,configurable:!0}),"s");const m=u(async({argument:e,logger:a,visConfig:o,workspaceRoot:s})=>{const t=e?.[0]??null,n=s??process.cwd(),i=p(n,{configBackend:o?.install?.backend,configCorepack:o?.install?.corepack}),r=f(i,t,n,a);r!==0&&(process.exitCode=r)},"execute");export{m as default};
1
+ var d=Object.defineProperty;var i=(e,o)=>d(e,"name",{value:o,configurable:!0});import{R as g,L as u}from"../packem_shared/pm-runner-Ta_yz2uP.js";var f=Object.defineProperty,b=i((e,o)=>f(e,"name",{value:o,configurable:!0}),"t");const w=b(async({argument:e,logger:o,visConfig:c,workspaceRoot:t})=>{const a=e;if(!a||a.length===0)throw new Error("No subcommand specified. Available: cache, publish, audit, list, view, config, whoami, login, logout, pack, owner, dist-tag, search, fund, ping, token, deprecate, rebuild, prune, plugin");const[s,...l]=a,n=t??process.cwd(),p=g(n,{configBackend:c?.install?.backend,configCorepack:c?.install?.corepack}),r=u(p,s,l,n,o);r!==0&&(process.exitCode=r)},"execute");export{w as default};
@@ -1 +1 @@
1
- var d=Object.defineProperty;var i=(e,o)=>d(e,"name",{value:o,configurable:!0});import{R as g,L as u}from"../packem_shared/pm-runner-BwX5AL3W.js";var f=Object.defineProperty,b=i((e,o)=>f(e,"name",{value:o,configurable:!0}),"t");const w=b(async({argument:e,logger:o,visConfig:c,workspaceRoot:t})=>{const a=e;if(!a||a.length===0)throw new Error("No subcommand specified. Available: cache, publish, audit, list, view, config, whoami, login, logout, pack, owner, dist-tag, search, fund, ping, token, deprecate, rebuild, prune, plugin");const[s,...l]=a,n=t??process.cwd(),p=g(n,{configBackend:c?.install?.backend,configCorepack:c?.install?.corepack}),r=u(p,s,l,n,o);r!==0&&(process.exitCode=r)},"execute");export{w as default};
1
+ var f=Object.defineProperty;var n=(e,o)=>f(e,"name",{value:o,configurable:!0});import{R as p,E as g}from"../packem_shared/pm-runner-Ta_yz2uP.js";import{o as v}from"../packem_shared/utils-DrNg0XTR.js";var k=Object.defineProperty,d=n((e,o)=>k(e,"name",{value:o,configurable:!0}),"l");const b=d(async({argument:e,logger:o,options:a,visConfig:s,workspaceRoot:i})=>{const r=e;if(!r||r.length===0)throw new Error("No packages specified. Usage: vis remove <packages...>");const c=process.cwd(),l=p(i??c,{configBackend:s?.install?.backend,configCorepack:s?.install?.corepack}),t=g(l,{filter:v(a.filter),global:a.global||!1,packages:r,recursive:a.recursive||!1,saveDev:a.saveDev||!1,workspaceRoot:a.workspaceRoot||!1},c,o);t!==0&&(process.exitCode=t)},"execute");export{b as default};
@@ -1,4 +1,4 @@
1
- var $=Object.defineProperty;var j=(s,r)=>$(s,"name",{value:r,configurable:!0});import{getAffectedProjects as F}from"@visulima/task-runner";import{C as b,S as C}from"./bin.js";import{r as k}from"../packem_shared/affected-shas-Dm7eqcI8.js";import{f as A}from"../packem_shared/selectors-BE2BCnTR.js";var I=Object.defineProperty,R=j((s,r)=>I(s,"name",{value:r,configurable:!0}),"j");const B=R(async({argument:s,logger:r,options:e,runtime:v,visConfig:l,workspaceRoot:h})=>{const g=s[0];if(!g)throw new Error("Missing target. Usage: vis affected <target>");if(!h)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const i=h,{packageJsons:y,workspace:c}=b(i,l),S=C(i,c,y),m=new Set(["deep","direct","none"]),d=e.downstream??"deep",u=e.upstream??"none";if(!m.has(d))throw new Error(`Invalid --downstream value: "${d}". Must be "none", "direct", or "deep".`);if(!m.has(u))throw new Error(`Invalid --upstream value: "${u}". Must be "none", "direct", or "deep".`);let{base:f}=e,{head:p}=e;if(!f||!p){const n=k({defaultBase:l?.defaultBase,workspaceRoot:i});f=f??n.base,p=p??n.head,r.info(`▸ Resolved affected refs from ${n.provider} (${n.notes.join("; ")})`)}const E={base:f,downstream:d,head:p,projectGraph:S,projects:c.projects,upstream:u,workspaceRoot:i},a=await F(E);if(a.changedFiles.length===0){r.info("No files changed. Nothing to run.");return}if(a.affectedProjects.length===0){r.info("No projects affected by the changes.");return}let{affectedProjects:o}=a;if(e.query&&(o=A(o,c,e.query),o.length===0)){r.info(`Query "${String(e.query)}" matched no affected projects.`);return}if(e.sparseCheckout){const n=[...new Set(o.map(w=>c.projects[w]?.root??w))].sort();process.stdout.write(`${n.join(`
1
+ var $=Object.defineProperty;var j=(s,r)=>$(s,"name",{value:r,configurable:!0});import{getAffectedProjects as F}from"@visulima/task-runner";import{C as b,S as C}from"./bin.js";import{r as k}from"../packem_shared/affected-shas-BkXXecyi.js";import{f as A}from"../packem_shared/selectors-BU8aTRQm.js";var I=Object.defineProperty,R=j((s,r)=>I(s,"name",{value:r,configurable:!0}),"j");const B=R(async({argument:s,logger:r,options:e,runtime:v,visConfig:l,workspaceRoot:h})=>{const g=s[0];if(!g)throw new Error("Missing target. Usage: vis affected <target>");if(!h)throw new Error("Could not determine workspace root. Run this command inside a monorepo.");const i=h,{packageJsons:y,workspace:c}=b(i,l),S=C(i,c,y),m=new Set(["deep","direct","none"]),d=e.downstream??"deep",u=e.upstream??"none";if(!m.has(d))throw new Error(`Invalid --downstream value: "${d}". Must be "none", "direct", or "deep".`);if(!m.has(u))throw new Error(`Invalid --upstream value: "${u}". Must be "none", "direct", or "deep".`);let{base:f}=e,{head:p}=e;if(!f||!p){const n=k({defaultBase:l?.defaultBase,workspaceRoot:i});f=f??n.base,p=p??n.head,r.info(`▸ Resolved affected refs from ${n.provider} (${n.notes.join("; ")})`)}const E={base:f,downstream:d,head:p,projectGraph:S,projects:c.projects,upstream:u,workspaceRoot:i},a=await F(E);if(a.changedFiles.length===0){r.info("No files changed. Nothing to run.");return}if(a.affectedProjects.length===0){r.info("No projects affected by the changes.");return}let{affectedProjects:o}=a;if(e.query&&(o=A(o,c,e.query),o.length===0)){r.info(`Query "${String(e.query)}" matched no affected projects.`);return}if(e.sparseCheckout){const n=[...new Set(o.map(w=>c.projects[w]?.root??w))].sort();process.stdout.write(`${n.join(`
2
2
  `)}
3
3
  `);return}r.info(`Affected projects: ${o.join(", ")}`),a.changedFiles.length>0&&(process.env.VIS_AFFECTED_FILES=a.changedFiles.join(`
4
4
  `));const t=[g,`--projects=${o.join(",")}`];e.parallel!==void 0&&t.push(`--parallel=${String(e.parallel)}`),e.cache||t.push("--no-cache"),e.dryRun&&t.push("--dry-run"),e.partition&&t.push(`--partition=${String(e.partition)}`),e.reverse&&t.push("--reverse"),typeof e.runnerTags=="string"&&e.runnerTags!==""&&t.push(`--runner-tags=${e.runnerTags}`);try{await v.runCommand("run",{argv:t})}finally{delete process.env.VIS_AFFECTED_FILES}},"execute");export{B as default};
@@ -1 +1,5 @@
1
- var f=Object.defineProperty;var n=(e,o)=>f(e,"name",{value:o,configurable:!0});import{R as p,E as g}from"../packem_shared/pm-runner-BwX5AL3W.js";import{o as v}from"../packem_shared/utils-DrNg0XTR.js";var k=Object.defineProperty,d=n((e,o)=>k(e,"name",{value:o,configurable:!0}),"l");const b=d(async({argument:e,logger:o,options:a,visConfig:s,workspaceRoot:i})=>{const r=e;if(!r||r.length===0)throw new Error("No packages specified. Usage: vis remove <packages...>");const c=process.cwd(),l=p(i??c,{configBackend:s?.install?.backend,configCorepack:s?.install?.corepack}),t=g(l,{filter:v(a.filter),global:a.global||!1,packages:r,recursive:a.recursive||!1,saveDev:a.saveDev||!1,workspaceRoot:a.workspaceRoot||!1},c,o);t!==0&&(process.exitCode=t)},"execute");export{b as default};
1
+ var S=Object.defineProperty;var p=(t,a)=>S(t,"name",{value:a,configurable:!0});import{readLastRunSummary as v,getLastRunSummaryPath as x}from"@visulima/task-runner";import{p as c,A as $,D as l,E as I,F as y}from"./bin.js";var w=Object.defineProperty,n=p((t,a)=>w(t,"name",{value:a,configurable:!0}),"s");const T=new Set(["json","table"]),C=n((t,a)=>t??a,"resolveWorkspaceRoot"),h=n(t=>t===void 0?"-":t<1e3?`${String(t)}ms`:`${(t/1e3).toFixed(2)}s`,"formatDuration"),k=n(t=>t.exitCode===void 0?t.cacheStatus:t.exitCode===0?t.cacheStatus==="MISS"?"OK":t.cacheStatus:`FAIL(${String(t.exitCode)})`,"formatStatus"),o=n((t,a)=>t.length>=a?t:t+" ".repeat(a-t.length),"padCell"),R=n(t=>t.exitCode!==void 0&&t.exitCode!==0,"isFailedTask"),g=n((t,a)=>{a.info(`Run ${t.id}`),a.info(` start: ${t.startTime}`),a.info(` end: ${t.endTime}`),a.info(` duration: ${h(t.duration)}`),a.info(` totals: ${String(t.stats.total)} total · ${String(t.stats.succeeded)} ok · ${String(t.stats.cached)} cached · ${String(t.stats.skipped)} skipped · ${String(t.stats.failed)} failed`),a.info(` env: node ${t.environment.nodeVersion} · ${t.environment.platform}/${t.environment.arch}`),a.info("")},"renderRunHeader"),D=n((t,a)=>{if(t.length===0){a.info("(no tasks match the current filter)");return}const s=t.map(e=>({duration:h(e.duration),hash:e.hash?e.hash.slice(0,12):"-",status:k(e),taskId:e.taskId})),r={duration:Math.max(8,...s.map(e=>e.duration.length)),hash:Math.max(4,...s.map(e=>e.hash.length)),status:Math.max(6,...s.map(e=>e.status.length)),taskId:Math.max(4,...s.map(e=>e.taskId.length))};a.info(` ${o("task",r.taskId)} ${o("status",r.status)} ${o("duration",r.duration)} ${o("hash",r.hash)}`),a.info(` ${"-".repeat(r.taskId)} ${"-".repeat(r.status)} ${"-".repeat(r.duration)} ${"-".repeat(r.hash)}`);for(const e of s)a.info(` ${o(e.taskId,r.taskId)} ${o(e.status,r.status)} ${o(e.duration,r.duration)} ${o(e.hash,r.hash)}`)},"renderTaskTable"),j=n((t,a,s)=>{g(t,s),s.info(`Task ${a.taskId}`),s.info(` status: ${k(a)}`),s.info(` cache: ${a.cacheStatus}`),s.info(` duration: ${h(a.duration)}`),s.info(` exit: ${a.exitCode===void 0?"-":String(a.exitCode)}`),s.info(` hash: ${a.hash??"(none)"}`),s.info(` start: ${a.startTime??"-"}`),s.info(` end: ${a.endTime??"-"}`),a.dependencies.length>0&&s.info(` deps: ${a.dependencies.join(", ")}`),s.info(""),c.info(`Drill into hash inputs with: vis cache why ${a.taskId} --run ${t.id}`)},"renderTaskDetail"),M=n(t=>{process.stdout.write(`${JSON.stringify(t.map(a=>({id:a.id,mtime:new Date(a.mtimeMs).toISOString(),path:a.path})),void 0,2)}
2
+ `)},"renderListJson"),O=n((t,a,s)=>{if(t.length===0){c.info(`No recorded runs found in ${$(a)}/. Run with --summarize to record a run.`);return}const r={id:Math.max(2,...t.map(e=>e.id.length)),mtime:24};s.info(` ${o("id",r.id)} ${o("mtime",r.mtime)}`),s.info(` ${"-".repeat(r.id)} ${"-".repeat(r.mtime)}`);for(const e of t)s.info(` ${o(e.id,r.id)} ${new Date(e.mtimeMs).toISOString()}`)},"renderListTable"),b=n((t,a)=>{let{tasks:s}=t;return a.task!==void 0&&(s=s.filter(r=>r.taskId===a.task)),a.failed&&(s=s.filter(r=>R(r))),s},"filterTasks"),N=n(async(t,a)=>{const{failed:s,format:r,runId:e,task:d,workspaceRoot:u}=t,i=e===void 0?await v(u,{dataDirectory:l(u)}):await I(u,e);if(!i){if(r==="json"){process.stdout.write(`${JSON.stringify({error:"no-summary",runId:e??null},void 0,2)}
3
+ `),process.exitCode=1;return}e===void 0?c.error(`No previous run summary found. Run a task first to populate \`${x(u,{dataDirectory:l(u)})}\`.`):c.error(`Run summary "${e}" not found in ${$(u)}/.`),process.exitCode=1;return}const f=b(i,{failed:s,task:d});if(d!==void 0&&f.length===0){if(r==="json"){process.stdout.write(`${JSON.stringify({error:"task-not-in-summary",runId:i.id,taskId:d},void 0,2)}
4
+ `),process.exitCode=1;return}c.error(`Task "${d}" was not part of run ${i.id}.`),process.exitCode=1;return}if(i.stats.failed>0&&(process.exitCode=1),r==="json"){process.stdout.write(`${JSON.stringify({duration:i.duration,endTime:i.endTime,environment:i.environment,runId:i.id,startTime:i.startTime,stats:i.stats,tasks:f.map(m=>({cacheStatus:m.cacheStatus,dependencies:m.dependencies,duration:m.duration,endTime:m.endTime,exitCode:m.exitCode,hash:m.hash??null,startTime:m.startTime,taskId:m.taskId}))},void 0,2)}
5
+ `);return}if(d!==void 0){j(i,f[0],a);return}g(i,a),D(f,a)},"runReplay"),F=n(async({logger:t,options:a,process:s,workspaceRoot:r})=>{const e=C(r,s.cwd),d=a.format??"table";if(!T.has(d)){c.error(`Invalid --format: ${d}. Expected "table" or "json".`),process.exitCode=1;return}if(a.list===!0){const u=await y(e);if(d==="json"){M(u);return}O(u,e,t);return}await N({failed:a.failed===!0,format:d,runId:a.run,task:a.task,workspaceRoot:e},t)},"replayExecute");export{F as default,F as replayExecute,N as runReplay};
@@ -1,5 +1,2 @@
1
- var S=Object.defineProperty;var p=(t,a)=>S(t,"name",{value:a,configurable:!0});import{readLastRunSummary as v,getLastRunSummaryPath as x}from"@visulima/task-runner";import{p as c,n as $,q as l,r as I,t as y}from"./bin.js";var w=Object.defineProperty,n=p((t,a)=>w(t,"name",{value:a,configurable:!0}),"s");const T=new Set(["json","table"]),C=n((t,a)=>t??a,"resolveWorkspaceRoot"),h=n(t=>t===void 0?"-":t<1e3?`${String(t)}ms`:`${(t/1e3).toFixed(2)}s`,"formatDuration"),k=n(t=>t.exitCode===void 0?t.cacheStatus:t.exitCode===0?t.cacheStatus==="MISS"?"OK":t.cacheStatus:`FAIL(${String(t.exitCode)})`,"formatStatus"),o=n((t,a)=>t.length>=a?t:t+" ".repeat(a-t.length),"padCell"),R=n(t=>t.exitCode!==void 0&&t.exitCode!==0,"isFailedTask"),g=n((t,a)=>{a.info(`Run ${t.id}`),a.info(` start: ${t.startTime}`),a.info(` end: ${t.endTime}`),a.info(` duration: ${h(t.duration)}`),a.info(` totals: ${String(t.stats.total)} total · ${String(t.stats.succeeded)} ok · ${String(t.stats.cached)} cached · ${String(t.stats.skipped)} skipped · ${String(t.stats.failed)} failed`),a.info(` env: node ${t.environment.nodeVersion} · ${t.environment.platform}/${t.environment.arch}`),a.info("")},"renderRunHeader"),D=n((t,a)=>{if(t.length===0){a.info("(no tasks match the current filter)");return}const s=t.map(e=>({duration:h(e.duration),hash:e.hash?e.hash.slice(0,12):"-",status:k(e),taskId:e.taskId})),r={duration:Math.max(8,...s.map(e=>e.duration.length)),hash:Math.max(4,...s.map(e=>e.hash.length)),status:Math.max(6,...s.map(e=>e.status.length)),taskId:Math.max(4,...s.map(e=>e.taskId.length))};a.info(` ${o("task",r.taskId)} ${o("status",r.status)} ${o("duration",r.duration)} ${o("hash",r.hash)}`),a.info(` ${"-".repeat(r.taskId)} ${"-".repeat(r.status)} ${"-".repeat(r.duration)} ${"-".repeat(r.hash)}`);for(const e of s)a.info(` ${o(e.taskId,r.taskId)} ${o(e.status,r.status)} ${o(e.duration,r.duration)} ${o(e.hash,r.hash)}`)},"renderTaskTable"),j=n((t,a,s)=>{g(t,s),s.info(`Task ${a.taskId}`),s.info(` status: ${k(a)}`),s.info(` cache: ${a.cacheStatus}`),s.info(` duration: ${h(a.duration)}`),s.info(` exit: ${a.exitCode===void 0?"-":String(a.exitCode)}`),s.info(` hash: ${a.hash??"(none)"}`),s.info(` start: ${a.startTime??"-"}`),s.info(` end: ${a.endTime??"-"}`),a.dependencies.length>0&&s.info(` deps: ${a.dependencies.join(", ")}`),s.info(""),c.info(`Drill into hash inputs with: vis cache why ${a.taskId} --run ${t.id}`)},"renderTaskDetail"),M=n(t=>{process.stdout.write(`${JSON.stringify(t.map(a=>({id:a.id,mtime:new Date(a.mtimeMs).toISOString(),path:a.path})),void 0,2)}
2
- `)},"renderListJson"),O=n((t,a,s)=>{if(t.length===0){c.info(`No recorded runs found in ${$(a)}/. Run with --summarize to record a run.`);return}const r={id:Math.max(2,...t.map(e=>e.id.length)),mtime:24};s.info(` ${o("id",r.id)} ${o("mtime",r.mtime)}`),s.info(` ${"-".repeat(r.id)} ${"-".repeat(r.mtime)}`);for(const e of t)s.info(` ${o(e.id,r.id)} ${new Date(e.mtimeMs).toISOString()}`)},"renderListTable"),b=n((t,a)=>{let{tasks:s}=t;return a.task!==void 0&&(s=s.filter(r=>r.taskId===a.task)),a.failed&&(s=s.filter(r=>R(r))),s},"filterTasks"),N=n(async(t,a)=>{const{failed:s,format:r,runId:e,task:d,workspaceRoot:u}=t,i=e===void 0?await v(u,{dataDirectory:l(u)}):await I(u,e);if(!i){if(r==="json"){process.stdout.write(`${JSON.stringify({error:"no-summary",runId:e??null},void 0,2)}
3
- `),process.exitCode=1;return}e===void 0?c.error(`No previous run summary found. Run a task first to populate \`${x(u,{dataDirectory:l(u)})}\`.`):c.error(`Run summary "${e}" not found in ${$(u)}/.`),process.exitCode=1;return}const f=b(i,{failed:s,task:d});if(d!==void 0&&f.length===0){if(r==="json"){process.stdout.write(`${JSON.stringify({error:"task-not-in-summary",runId:i.id,taskId:d},void 0,2)}
4
- `),process.exitCode=1;return}c.error(`Task "${d}" was not part of run ${i.id}.`),process.exitCode=1;return}if(i.stats.failed>0&&(process.exitCode=1),r==="json"){process.stdout.write(`${JSON.stringify({duration:i.duration,endTime:i.endTime,environment:i.environment,runId:i.id,startTime:i.startTime,stats:i.stats,tasks:f.map(m=>({cacheStatus:m.cacheStatus,dependencies:m.dependencies,duration:m.duration,endTime:m.endTime,exitCode:m.exitCode,hash:m.hash??null,startTime:m.startTime,taskId:m.taskId}))},void 0,2)}
5
- `);return}if(d!==void 0){j(i,f[0],a);return}g(i,a),D(f,a)},"runReplay"),F=n(async({logger:t,options:a,process:s,workspaceRoot:r})=>{const e=C(r,s.cwd),d=a.format??"table";if(!T.has(d)){c.error(`Invalid --format: ${d}. Expected "table" or "json".`),process.exitCode=1;return}if(a.list===!0){const u=await y(e);if(d==="json"){M(u);return}O(u,e,t);return}await N({failed:a.failed===!0,format:d,runId:a.run,task:a.task,workspaceRoot:e},t)},"replayExecute");export{F as default,F as replayExecute,N as runReplay};
1
+ var x=Object.defineProperty;var c=(o,e)=>x(o,"name",{value:e,configurable:!0});import{createRequire as y}from"node:module";import{b as $}from"./config.js";import{C as B,K as S}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{C as R,S as O,p as u}from"./bin.js";import{b as T,s as q}from"../packem_shared/cyclonedx-B04lIvwu.js";const h=y(import.meta.url),r=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,k=c(o=>{if(typeof r<"u"&&r.versions&&r.versions.node){const[e,s]=r.versions.node.split(".").map(Number);if(e>22||e===22&&s>=3||e===20&&s>=16)return r.getBuiltinModule(o)}return h(o)},"__cjs_getBuiltinModule"),{writeFileSync:C}=k("node:fs");var D=Object.defineProperty,d=c((o,e)=>D(o,"name",{value:e,configurable:!0}),"m");const f=["json","xml"],E=d(o=>f.includes(o),"isSbomFormat"),G=d(async({options:o,visConfig:e,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{packageJsons:w,workspace:a}=R(s,e),b=O(s,a,w),p=o.focus,g=p?p.split(",").map(v=>v.trim()).filter(Boolean):void 0,t=(o.format??"json").toLowerCase();if(!E(t))throw new Error(`Unknown --format: "${t}". Expected one of: ${f.join(", ")}.`);const n=T({focus:g,includeDev:!!o.includeDev,projectGraph:b,workspace:a,workspaceRoot:s}),m=t==="xml"?q(n):`${JSON.stringify(n,void 0,2)}
2
+ `,l=o.output??(t==="xml"?"sbom.cdx.xml":"sbom.cdx.json");if(l==="-"){process.stdout.write(m);return}const i=B(s,l);$(S(i)),C(i,m,"utf8");const _=n.components?.length??0,j=n.dependencies?.length??0;u.success(`SBOM written to ${i}`),u.notice(`${_} components, ${j} dependency edges`)},"execute");export{G as default};
@@ -1,2 +1,2 @@
1
- var x=Object.defineProperty;var c=(o,e)=>x(o,"name",{value:e,configurable:!0});import{createRequire as y}from"node:module";import{b as $}from"./config.js";import{C as B,K as S}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{C as R,S as O,p as u}from"./bin.js";import{b as T,s as q}from"../packem_shared/cyclonedx-B3ILsY74.js";const h=y(import.meta.url),r=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,k=c(o=>{if(typeof r<"u"&&r.versions&&r.versions.node){const[e,s]=r.versions.node.split(".").map(Number);if(e>22||e===22&&s>=3||e===20&&s>=16)return r.getBuiltinModule(o)}return h(o)},"__cjs_getBuiltinModule"),{writeFileSync:C}=k("node:fs");var D=Object.defineProperty,d=c((o,e)=>D(o,"name",{value:e,configurable:!0}),"m");const f=["json","xml"],E=d(o=>f.includes(o),"isSbomFormat"),G=d(async({options:o,visConfig:e,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root. Run inside a monorepo.");const{packageJsons:w,workspace:a}=R(s,e),b=O(s,a,w),p=o.focus,g=p?p.split(",").map(v=>v.trim()).filter(Boolean):void 0,t=(o.format??"json").toLowerCase();if(!E(t))throw new Error(`Unknown --format: "${t}". Expected one of: ${f.join(", ")}.`);const n=T({focus:g,includeDev:!!o.includeDev,projectGraph:b,workspace:a,workspaceRoot:s}),m=t==="xml"?q(n):`${JSON.stringify(n,void 0,2)}
2
- `,l=o.output??(t==="xml"?"sbom.cdx.xml":"sbom.cdx.json");if(l==="-"){process.stdout.write(m);return}const i=B(s,l);$(S(i)),C(i,m,"utf8");const _=n.components?.length??0,j=n.dependencies?.length??0;u.success(`SBOM written to ${i}`),u.notice(`${_} components, ${j} dependency edges`)},"execute");export{G as default};
1
+ var T=Object.defineProperty;var k=(o,e)=>T(o,"name",{value:e,configurable:!0});import{createRequire as F}from"node:module";import{p as c,L as A,C as H,M as L,O as P,P as O,Q as U}from"./bin.js";import{c as D,r as z,s as C,S as G,a as $,b as M,d as q,p as B,i as b,e as V}from"../packem_shared/lifecycle-NHIKDiCh.js";const _=F(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,I=k(o=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[e,r]=m.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return m.getBuiltinModule(o)}return _(o)},"__cjs_getBuiltinModule"),{stat:y,open:R,watch:N}=I("node:fs/promises");var W=Object.defineProperty,g=k((o,e)=>W(o,"name",{value:e,configurable:!0}),"f");const h=g(async o=>{const e=o?.plugins;if(!e||e.length===0)return;const r=D();return await z(r,e),{callHook:g(async(d,...s)=>{try{await r.callHook(d,...s)}catch(t){const n=t instanceof Error?t.message:String(t);c.warn(`Plugin error in ${d}: ${n}`)}},"callHook")}},"loadServiceHooks"),J=g(o=>{const e=o.trim(),r=e.lastIndexOf(":");if(!(r<=0||r===e.length-1))return{project:e.slice(0,r),target:e.slice(r+1)}},"splitTargetId"),j=g(async(o,e,r)=>{const d=J(r);if(!d){c.error(`Invalid target id "${r}". Expected "<project>:<target>", e.g. "@my/api:db".`);return}const s=await A(o),{projectOptions:t,workspace:n}=H(o,e,s),i=n.projects[d.project],a=t.get(d.project)?.[d.target];if(!i||!a){c.error(`Target "${r}" not found in this workspace.`);return}const p=a.options?.service;if(!p){c.error(`Target "${r}" is not a service. Add an \`options.service\` block to make it eligible for \`vis service\`.`);return}if(!a.command){c.error(`Target "${r}" has no command — services must be runnable.`);return}const f=L(o,i.root,a.options?.runFromWorkspaceRoot===!0),v=a.options?.envFile?P(f,a.options.envFile):{};return{command:a.command,cwd:f,env:{...v,...p.env},service:p,target:a,targetId:r}},"resolveTarget"),w=g(o=>{if(!o)throw new Error("Could not determine workspace root. Run `vis service` inside a workspace.");return o},"requireWorkspace"),oe=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service start <project>:<target>"),process.exitCode=1;return}const n=await j(s,r,t);if(!n){process.exitCode=1;return}try{const{entry:i}=await C({command:n.command,config:n.service,cwd:n.cwd,env:n.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await(await h(r))?.callHook("service:start",i),c.success(`Started ${t} (pid ${String(i.pid)})`),c.info(` log: ${i.logFile}`)}catch(i){const a=i instanceof Error?i.message:String(i);i instanceof G?c.error(`Readiness probe failed for ${t}: ${a}`):c.error(`Failed to start ${t}: ${a}`),process.exitCode=1}},"serviceStartExecute"),S=g(async({graceMs:o,hookSink:e,id:r,workspaceRoot:d})=>{const s=await $(d,r),{stopped:t}=await M({graceMs:o,id:r,workspaceRoot:d});return t?(s&&await e?.callHook("service:stop",s),c.success(`Stopped ${r}`),!0):(c.info(`No running service registered for ${r}`),!1)},"stopOne"),se=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),{graceMs:t}=e,n=o[0]?.trim(),i=await h(r);if(e.all===!0){if(n){c.error("Cannot combine --all with a target id. Use one or the other."),process.exitCode=1;return}const a=await q(s);if(a.length===0){c.info("No running services registered for this workspace.");return}for(const p of a)await S({graceMs:t,hookSink:i,id:p.id,workspaceRoot:s});return}if(!n){c.error("Missing target id. Usage: vis service stop <project>:<target> | --all"),process.exitCode=1;return}await S({graceMs:t,hookSink:i,id:n,workspaceRoot:s})||(process.exitCode=1)},"serviceStopExecute"),Q=g(o=>{const e=o.config.readiness?.tcp.port??o.config.port;return e===void 0?"—":String(e)},"formatPort"),E=new Set(["json","table"]),ie=g(async({logger:o,options:e,workspaceRoot:r})=>{const d=w(r),s=e.format??"table";if(!E.has(s)){c.error(`Invalid --format "${s}". Expected one of: ${[...E].sort().join(", ")}.`),process.exitCode=1;return}const{surviving:t}=await B(d);if(s==="json"){const l=Date.now();process.stdout.write(`${JSON.stringify(t.map(u=>{const x=Date.parse(u.startedAt);return{ageMs:Number.isFinite(x)?l-x:null,alive:b(u.pid),command:u.command,cwd:u.cwd,env:u.env,id:u.id,logFile:u.logFile,pid:u.pid,port:u.config.readiness?.tcp.port??u.config.port??null,startedAt:u.startedAt,visVersion:u.visVersion}}),void 0,2)}
2
+ `);return}if(t.length===0){c.info("No running services registered for this workspace.");return}const n=Date.now(),i=t.map(l=>{const u=Date.parse(l.startedAt);return{age:Number.isFinite(u)?O(u,n):"?",id:l.id,log:l.logFile,pid:String(l.pid),port:Q(l)}}),a=Math.max(2,...i.map(l=>l.id.length)),p=Math.max(3,...i.map(l=>l.pid.length)),f=Math.max(4,...i.map(l=>l.port.length)),v=Math.max(3,...i.map(l=>l.age.length));o.info(` ${"id".padEnd(a)} ${"pid".padEnd(p)} ${"port".padEnd(f)} ${"age".padEnd(v)} log`),o.info(` ${"-".repeat(a)} ${"-".repeat(p)} ${"-".repeat(f)} ${"-".repeat(v)} ---`);for(const l of i)o.info(` ${l.id.padEnd(a)} ${l.pid.padEnd(p)} ${l.port.padEnd(f)} ${l.age.padEnd(v)} ${l.log}`)},"serviceListExecute"),ae=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service status <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!b(t.pid)){c.error(`Service ${s} is not running (pid ${String(t.pid)} is dead). Run \`vis service start ${s}\` to recover.`),process.exitCode=1;return}try{await V(t.config,{timeoutMs:e.timeout}),c.success(`${s} healthy (pid ${String(t.pid)})`)}catch(n){const i=n instanceof Error?n.message:String(n);c.error(`${s} probe failed: ${i}`),process.exitCode=1}},"serviceStatusExecute"),ne=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service restart <project>:<target>"),process.exitCode=1;return}const n=await h(r),i=await $(s,t);(await M({graceMs:e.graceMs,id:t,workspaceRoot:s})).stopped&&i&&await n?.callHook("service:stop",i);const a=await j(s,r,t);if(!a){process.exitCode=1;return}try{const{entry:p}=await C({command:a.command,config:a.service,cwd:a.cwd,env:a.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await n?.callHook("service:start",p),c.success(`Restarted ${t} (pid ${String(p.pid)})`)}catch(p){const f=p instanceof Error?p.message:String(p);c.error(`Failed to restart ${t}: ${f}`),process.exitCode=1}},"serviceRestartExecute"),K=200,X=1024*1024,Y=g(async o=>{let e=0;try{e=(await y(o)).size}catch{e=0}const r=new AbortController;let d=!1;const s=g(()=>{d=!0,r.abort()},"onSigint"),t=g(()=>{r.abort()},"onSigterm");process.on("SIGINT",s),process.on("SIGTERM",t);let n=!1;const i=g(async()=>{if(!n){n=!0;try{const a=await y(o).catch(()=>{});if(!a||(a.size<e&&(e=0),a.size===e))return;const p=a.size-e,f=Math.min(p,X),v=await R(o,"r");try{const l=Buffer.alloc(f);await v.read(l,0,f,e),process.stdout.write(l),e+=f}finally{await v.close().catch(()=>{})}}finally{n=!1}}},"tickOnce");try{const a=(async()=>{try{const p=N(o,{signal:r.signal});for(;!(await p.next()).done;)await i()}catch{}})();for(;!r.signal.aborted;)await i(),await new Promise(p=>{const f=setTimeout(p,K);r.signal.addEventListener("abort",()=>{clearTimeout(f),p()},{once:!0})});await a.catch(()=>{}),await i().catch(()=>{})}finally{process.off("SIGINT",s),process.off("SIGTERM",t)}d&&(process.exitCode=130)},"tailLog"),ce=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service logs <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!await U(t.logFile)){c.warn(`Log file is missing for ${s}: ${t.logFile}`),process.exitCode=1;return}if(e.follow===!0){await Y(t.logFile);return}const n=await R(t.logFile,"r");try{const i=n.createReadStream();await new Promise((a,p)=>{i.on("end",a),i.on("error",p),i.pipe(process.stdout,{end:!1})})}finally{await n.close().catch(()=>{})}},"serviceLogsExecute");export{ie as serviceListExecute,ce as serviceLogsExecute,ne as serviceRestartExecute,oe as serviceStartExecute,ae as serviceStatusExecute,se as serviceStopExecute};
@@ -1,2 +1 @@
1
- var T=Object.defineProperty;var k=(o,e)=>T(o,"name",{value:e,configurable:!0});import{createRequire as F}from"node:module";import{p as c,v as A,C as H,w as L,x as P,A as U,B as D}from"./bin.js";import{c as O,r as z,s as C,S as G,a as $,b,d as q,p as B,i as M,e as V}from"../packem_shared/lifecycle-CJRNbN3x.js";const _=F(import.meta.url),m=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,I=k(o=>{if(typeof m<"u"&&m.versions&&m.versions.node){const[e,r]=m.versions.node.split(".").map(Number);if(e>22||e===22&&r>=3||e===20&&r>=16)return m.getBuiltinModule(o)}return _(o)},"__cjs_getBuiltinModule"),{stat:y,open:R,watch:N}=I("node:fs/promises");var W=Object.defineProperty,g=k((o,e)=>W(o,"name",{value:e,configurable:!0}),"f");const h=g(async o=>{const e=o?.plugins;if(!e||e.length===0)return;const r=O();return await z(r,e),{callHook:g(async(d,...s)=>{try{await r.callHook(d,...s)}catch(t){const n=t instanceof Error?t.message:String(t);c.warn(`Plugin error in ${d}: ${n}`)}},"callHook")}},"loadServiceHooks"),J=g(o=>{const e=o.trim(),r=e.lastIndexOf(":");if(!(r<=0||r===e.length-1))return{project:e.slice(0,r),target:e.slice(r+1)}},"splitTargetId"),j=g(async(o,e,r)=>{const d=J(r);if(!d){c.error(`Invalid target id "${r}". Expected "<project>:<target>", e.g. "@my/api:db".`);return}const s=await A(o),{projectOptions:t,workspace:n}=H(o,e,s),i=n.projects[d.project],a=t.get(d.project)?.[d.target];if(!i||!a){c.error(`Target "${r}" not found in this workspace.`);return}const p=a.options?.service;if(!p){c.error(`Target "${r}" is not a service. Add an \`options.service\` block to make it eligible for \`vis service\`.`);return}if(!a.command){c.error(`Target "${r}" has no command — services must be runnable.`);return}const f=L(o,i.root,a.options?.runFromWorkspaceRoot===!0),v=a.options?.envFile?P(f,a.options.envFile):{};return{command:a.command,cwd:f,env:{...v,...p.env},service:p,target:a,targetId:r}},"resolveTarget"),w=g(o=>{if(!o)throw new Error("Could not determine workspace root. Run `vis service` inside a workspace.");return o},"requireWorkspace"),oe=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service start <project>:<target>"),process.exitCode=1;return}const n=await j(s,r,t);if(!n){process.exitCode=1;return}try{const{entry:i}=await C({command:n.command,config:n.service,cwd:n.cwd,env:n.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await(await h(r))?.callHook("service:start",i),c.success(`Started ${t} (pid ${String(i.pid)})`),c.info(` log: ${i.logFile}`)}catch(i){const a=i instanceof Error?i.message:String(i);i instanceof G?c.error(`Readiness probe failed for ${t}: ${a}`):c.error(`Failed to start ${t}: ${a}`),process.exitCode=1}},"serviceStartExecute"),S=g(async({graceMs:o,hookSink:e,id:r,workspaceRoot:d})=>{const s=await $(d,r),{stopped:t}=await b({graceMs:o,id:r,workspaceRoot:d});return t?(s&&await e?.callHook("service:stop",s),c.success(`Stopped ${r}`),!0):(c.info(`No running service registered for ${r}`),!1)},"stopOne"),se=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),{graceMs:t}=e,n=o[0]?.trim(),i=await h(r);if(e.all===!0){if(n){c.error("Cannot combine --all with a target id. Use one or the other."),process.exitCode=1;return}const a=await q(s);if(a.length===0){c.info("No running services registered for this workspace.");return}for(const p of a)await S({graceMs:t,hookSink:i,id:p.id,workspaceRoot:s});return}if(!n){c.error("Missing target id. Usage: vis service stop <project>:<target> | --all"),process.exitCode=1;return}await S({graceMs:t,hookSink:i,id:n,workspaceRoot:s})||(process.exitCode=1)},"serviceStopExecute"),K=g(o=>{const e=o.config.readiness?.tcp.port??o.config.port;return e===void 0?"—":String(e)},"formatPort"),E=new Set(["json","table"]),ie=g(async({logger:o,options:e,workspaceRoot:r})=>{const d=w(r),s=e.format??"table";if(!E.has(s)){c.error(`Invalid --format "${s}". Expected one of: ${[...E].sort().join(", ")}.`),process.exitCode=1;return}const{surviving:t}=await B(d);if(s==="json"){const l=Date.now();process.stdout.write(`${JSON.stringify(t.map(u=>{const x=Date.parse(u.startedAt);return{ageMs:Number.isFinite(x)?l-x:null,alive:M(u.pid),command:u.command,cwd:u.cwd,env:u.env,id:u.id,logFile:u.logFile,pid:u.pid,port:u.config.readiness?.tcp.port??u.config.port??null,startedAt:u.startedAt,visVersion:u.visVersion}}),void 0,2)}
2
- `);return}if(t.length===0){c.info("No running services registered for this workspace.");return}const n=Date.now(),i=t.map(l=>{const u=Date.parse(l.startedAt);return{age:Number.isFinite(u)?U(u,n):"?",id:l.id,log:l.logFile,pid:String(l.pid),port:K(l)}}),a=Math.max(2,...i.map(l=>l.id.length)),p=Math.max(3,...i.map(l=>l.pid.length)),f=Math.max(4,...i.map(l=>l.port.length)),v=Math.max(3,...i.map(l=>l.age.length));o.info(` ${"id".padEnd(a)} ${"pid".padEnd(p)} ${"port".padEnd(f)} ${"age".padEnd(v)} log`),o.info(` ${"-".repeat(a)} ${"-".repeat(p)} ${"-".repeat(f)} ${"-".repeat(v)} ---`);for(const l of i)o.info(` ${l.id.padEnd(a)} ${l.pid.padEnd(p)} ${l.port.padEnd(f)} ${l.age.padEnd(v)} ${l.log}`)},"serviceListExecute"),ae=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service status <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!M(t.pid)){c.error(`Service ${s} is not running (pid ${String(t.pid)} is dead). Run \`vis service start ${s}\` to recover.`),process.exitCode=1;return}try{await V(t.config,{timeoutMs:e.timeout}),c.success(`${s} healthy (pid ${String(t.pid)})`)}catch(n){const i=n instanceof Error?n.message:String(n);c.error(`${s} probe failed: ${i}`),process.exitCode=1}},"serviceStatusExecute"),ne=g(async({argument:o,options:e,visConfig:r,workspaceRoot:d})=>{const s=w(d),t=o[0]?.trim();if(!t){c.error("Missing target id. Usage: vis service restart <project>:<target>"),process.exitCode=1;return}const n=await h(r),i=await $(s,t);(await b({graceMs:e.graceMs,id:t,workspaceRoot:s})).stopped&&i&&await n?.callHook("service:stop",i);const a=await j(s,r,t);if(!a){process.exitCode=1;return}try{const{entry:p}=await C({command:a.command,config:a.service,cwd:a.cwd,env:a.env,id:t,readinessTimeoutMs:e.timeout,skipReadiness:e.readiness===!1,workspaceRoot:s});await n?.callHook("service:start",p),c.success(`Restarted ${t} (pid ${String(p.pid)})`)}catch(p){const f=p instanceof Error?p.message:String(p);c.error(`Failed to restart ${t}: ${f}`),process.exitCode=1}},"serviceRestartExecute"),Q=200,X=1024*1024,Y=g(async o=>{let e=0;try{e=(await y(o)).size}catch{e=0}const r=new AbortController;let d=!1;const s=g(()=>{d=!0,r.abort()},"onSigint"),t=g(()=>{r.abort()},"onSigterm");process.on("SIGINT",s),process.on("SIGTERM",t);let n=!1;const i=g(async()=>{if(!n){n=!0;try{const a=await y(o).catch(()=>{});if(!a||(a.size<e&&(e=0),a.size===e))return;const p=a.size-e,f=Math.min(p,X),v=await R(o,"r");try{const l=Buffer.alloc(f);await v.read(l,0,f,e),process.stdout.write(l),e+=f}finally{await v.close().catch(()=>{})}}finally{n=!1}}},"tickOnce");try{const a=(async()=>{try{const p=N(o,{signal:r.signal});for(;!(await p.next()).done;)await i()}catch{}})();for(;!r.signal.aborted;)await i(),await new Promise(p=>{const f=setTimeout(p,Q);r.signal.addEventListener("abort",()=>{clearTimeout(f),p()},{once:!0})});await a.catch(()=>{}),await i().catch(()=>{})}finally{process.off("SIGINT",s),process.off("SIGTERM",t)}d&&(process.exitCode=130)},"tailLog"),ce=g(async({argument:o,options:e,workspaceRoot:r})=>{const d=w(r),s=o[0]?.trim();if(!s){c.error("Missing target id. Usage: vis service logs <project>:<target>"),process.exitCode=1;return}const t=await $(d,s);if(!t){c.error(`No service registered for ${s}.`),process.exitCode=1;return}if(!await D(t.logFile)){c.warn(`Log file is missing for ${s}: ${t.logFile}`),process.exitCode=1;return}if(e.follow===!0){await Y(t.logFile);return}const n=await R(t.logFile,"r");try{const i=n.createReadStream();await new Promise((a,p)=>{i.on("end",a),i.on("error",p),i.pipe(process.stdout,{end:!1})})}finally{await n.close().catch(()=>{})}},"serviceLogsExecute");export{ie as serviceListExecute,ce as serviceLogsExecute,ne as serviceRestartExecute,oe as serviceStartExecute,ae as serviceStatusExecute,se as serviceStopExecute};
1
+ var R=Object.defineProperty;var j=(e,t)=>R(e,"name",{value:t,configurable:!0});import{createRequire as T}from"node:module";import{I as f,T as b,E as x,e as $}from"../packem_shared/Table-3pFgIUZ2-DABgc6rj.js";import{i as V,M as F}from"../packem_shared/readFileSync-4c_c6Qey-6SWMDNdw.js";import{n as I}from"./config.js";import{enforceProjectConstraints as P}from"@visulima/task-runner";import{C as z,S as A,W as B,A as E}from"./bin.js";import{c as J}from"../packem_shared/runtime-check-Cbtb_Utb.js";const w=T(import.meta.url),n=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,M=j(e=>{if(typeof n<"u"&&n.versions&&n.versions.node){const[t,i]=n.versions.node.split(".").map(Number);if(t>22||t===22&&i>=3||t===20&&i>=16)return n.getBuiltinModule(e)}return w(e)},"__cjs_getBuiltinModule"),{readdirSync:q}=M("node:fs");var K=Object.defineProperty,v=j((e,t)=>K(e,"name",{value:t,configurable:!0}),"h");const r=v(e=>e?f("✓"):b(""),"icon"),X=v(async({logger:e,options:t,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root.");const{config:y,packageJsons:C,workspace:u}=z(s,i),O=A(s,u,C),S=Object.keys(u.projects).length,k=new Set(Object.values(u.projects).flatMap(p=>Object.keys(p.targets??{}))).size,a=J(s);let o=0;y.constraints&&(o=P(O,y.constraints).length);const c=B(s,{minRuns:2});let l;const g=E(s);if(V(g)){const p=q(g).filter(h=>h.endsWith(".json")).sort();let m=0,_=0;for(const h of p.slice(-20))try{const d=I(F(g,h));d.stats&&(m+=d.stats.total??0,_+=d.stats.cached??0)}catch{continue}m>0&&(l=`${(_/m*100).toFixed(0)}%`)}if(t.json){e.info(JSON.stringify({cacheHitRate:l??null,constraintViolations:o,flakyTasks:c.length,projects:S,runtimeIssues:a.length,targets:k},null,2));return}e.info(""),e.info(` ${x("VIS STATUS")}`),e.info(""),e.info(` ${r(!0)} ${String(S)} projects · ${String(k)} unique targets`),e.info(` ${r(a.length===0)} Runtime: ${a.length===0?f("OK"):$(`${String(a.length)} issue(s)`)}`),e.info(` ${r(o===0)} Constraints: ${o===0?f("OK"):b(`${String(o)} violation(s)`)}`),e.info(` ${r(c.length===0)} Flaky tasks: ${c.length===0?f("none"):$(String(c.length))}`),l&&e.info(` ${r(!0)} Cache hit rate: ${l} (last 20 runs)`),e.info("")},"execute");export{X as default};
@@ -1 +1 @@
1
- var R=Object.defineProperty;var j=(e,t)=>R(e,"name",{value:t,configurable:!0});import{createRequire as T}from"node:module";import{I as f,T as b,E as x,e as $}from"../packem_shared/index.server-B7ETiT4C.js";import{i as V,M as E}from"../packem_shared/readFileSync-CGmzMUF2-D6rUjGDn.js";import{n as F}from"./config.js";import{enforceProjectConstraints as I}from"@visulima/task-runner";import{C as P,S as z,E as B,n as J}from"./bin.js";import{c as K}from"../packem_shared/runtime-check-DgXsKCsv.js";const w=T(import.meta.url),n=typeof globalThis<"u"&&typeof globalThis.process<"u"?globalThis.process:process,M=j(e=>{if(typeof n<"u"&&n.versions&&n.versions.node){const[t,i]=n.versions.node.split(".").map(Number);if(t>22||t===22&&i>=3||t===20&&i>=16)return n.getBuiltinModule(e)}return w(e)},"__cjs_getBuiltinModule"),{readdirSync:q}=M("node:fs");var N=Object.defineProperty,v=j((e,t)=>N(e,"name",{value:t,configurable:!0}),"h");const r=v(e=>e?f("✓"):b("✗"),"icon"),X=v(async({logger:e,options:t,visConfig:i,workspaceRoot:s})=>{if(!s)throw new Error("Could not determine workspace root.");const{config:y,packageJsons:C,workspace:u}=P(s,i),O=z(s,u,C),S=Object.keys(u.projects).length,k=new Set(Object.values(u.projects).flatMap(p=>Object.keys(p.targets??{}))).size,a=K(s);let o=0;y.constraints&&(o=I(O,y.constraints).length);const c=B(s,{minRuns:2});let l;const g=J(s);if(V(g)){const p=q(g).filter(h=>h.endsWith(".json")).sort();let m=0,_=0;for(const h of p.slice(-20))try{const d=F(E(g,h));d.stats&&(m+=d.stats.total??0,_+=d.stats.cached??0)}catch{continue}m>0&&(l=`${(_/m*100).toFixed(0)}%`)}if(t.json){e.info(JSON.stringify({cacheHitRate:l??null,constraintViolations:o,flakyTasks:c.length,projects:S,runtimeIssues:a.length,targets:k},null,2));return}e.info(""),e.info(` ${x("VIS STATUS")}`),e.info(""),e.info(` ${r(!0)} ${String(S)} projects · ${String(k)} unique targets`),e.info(` ${r(a.length===0)} Runtime: ${a.length===0?f("OK"):$(`${String(a.length)} issue(s)`)}`),e.info(` ${r(o===0)} Constraints: ${o===0?f("OK"):b(`${String(o)} violation(s)`)}`),e.info(` ${r(c.length===0)} Flaky tasks: ${c.length===0?f("none"):$(String(c.length))}`),l&&e.info(` ${r(!0)} Cache hit rate: ${l} (last 20 runs)`),e.info("")},"execute");export{X as default};
1
+ var b=Object.defineProperty;var j=(t,e)=>b(t,"name",{value:e,configurable:!0});import{createTaskGraph as v}from"@visulima/task-runner";import{C as y,S as E}from"./bin.js";var T=Object.defineProperty,w=j((t,e)=>T(t,"name",{value:e,configurable:!0}),"h");const O=w((t,e)=>{const s=new Map;for(const[i,r]of Object.entries(t.dependencies))for(const f of r){const c=s.get(f)??[];c.push(i),s.set(f,c)}if(!t.tasks[e])return;const a=new Set([e]),o=[{node:e,path:[e]}];for(;o.length>0;){const i=o.shift();if(t.roots.includes(i.node))return i.path;for(const r of s.get(i.node)??[])a.has(r)||(a.add(r),o.push({node:r,path:[r,...i.path]}))}return[e]},"findShortestPathToRoot"),S=w((t,e)=>{const s=[];for(const[a,o]of Object.entries(t.dependencies))o.includes(e)&&s.push(a);return s.sort()},"collectParents"),D=w(async({argument:t,logger:e,visConfig:s,workspaceRoot:a})=>{if(!a)throw new Error("Could not determine workspace root.");const o=t[0];if(!o)throw new Error("No task ID specified. Usage: vis task-why <project>:<target>");if(!o.includes(":"))throw new Error(`Invalid task ID "${o}" — expected format "project:target".`);const{packageJsons:i,workspace:r}=y(a,s),f=E(a,r,i),[c,k]=o.split(":",2),$=r.projects[c];if(!$)throw new Error(`Unknown project "${c}".`);if(!$.targets?.[k])throw new Error(`Project "${c}" has no target "${k}".`);const m=Object.entries(r.projects).flatMap(([n,u])=>Object.keys(u.targets??{}).map(h=>({id:`${n}:${h}`,outputs:[],overrides:{},target:{project:n,target:h}}))),p=v(m,{projectGraph:f,workspace:r});if(!p.tasks[o])throw new Error(`Task "${o}" is not reachable in the graph.`);const d=O(p,o),g=S(p,o);if(e.info(""),e.info(`Why ${o}?`),e.info(""),d&&d.length>1){e.info("Shortest path from a root to this task:");for(const[n,u]of d.entries()){const h=n===0?" ":`${" ".repeat(n+1)}└─ `;e.info(`${h}${u}`)}e.info("")}else e.info(" This task is itself a root — nothing upstream depends on it."),e.info("");if(g.length>0){e.info(`Directly depended on by ${g.length} task(s):`);for(const n of g)e.info(` - ${n}`);e.info("")}const l=p.dependencies[o]??[];if(l.length>0){e.info(`This task depends on ${l.length} task(s):`);for(const n of[...l].sort())e.info(` - ${n}`);e.info("")}},"execute");export{D as default};