@kynver-app/runtime 0.1.152 → 0.1.153
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js
CHANGED
|
@@ -1,82 +1,82 @@
|
|
|
1
|
-
var
|
|
2
|
-
`)}function
|
|
1
|
+
var Kb=Object.defineProperty;var U=(e,r,t)=>()=>{if(t)throw t[0];try{return e&&(r=e(e=0)),r}catch(n){throw t=[n],n}};var $b=(e,r)=>{for(var t in r)Kb(e,t,{get:r[t],enumerable:!0})};import{existsSync as qb,mkdirSync as zb,readFileSync as dl,readdirSync as MT,statSync as gp,writeFileSync as Xb}from"node:fs";import hp from"node:path";function _r(e){console.error(e),process.exit(1)}function pe(e){return process.platform!=="win32"?e:{windowsHide:!0,...e}}function T(e,r){return e||_r(`missing ${r}`),e}function Bt(e){try{return JSON.parse(e)}catch{return null}}function w(e,r){try{return JSON.parse(dl(e,"utf8"))}catch(t){if(arguments.length>1)return r;_r(`failed to read ${e}: ${t.message}`)}}function ae(e,r){zb(hp.dirname(e),{recursive:!0}),Xb(e,`${JSON.stringify(r,null,2)}
|
|
2
|
+
`)}function v(e){return String(e||"").toLowerCase().replace(/[^a-z0-9._-]+/g,"-").replace(/^-+|-+$/g,"")||"worker"}function kp(e){return v(`${new Date().toISOString().replace(/[-:]/g,"").replace(/\..+/,"Z")}-${e}`)}function ar(e){return String(e).replace(/\/+$/,"")}function Rs(e){return String(e||"").replace(/\s+/g," ").trim()}function bs(e){try{return gp(e).size}catch{return 0}}function vs(e){try{return gp(e).mtime.toISOString()}catch{return null}}function Ss(e,r){return qb(e)?dl(e,"utf8").split(`
|
|
3
3
|
`).slice(-r).join(`
|
|
4
|
-
`):""}function
|
|
5
|
-
`).map(r=>r.trim()).filter(Boolean)}function ne(e,r){try{let t=vp("git",r,pe({cwd:e,encoding:"utf8"}));return{status:t.status,stdout:t.stdout||"",stderr:t.stderr||"",error:t.error?t.error.message:null}}catch(t){return{status:null,stdout:"",stderr:"",error:t.message}}}function Rp(e,r,t){let n=ne(e,["merge-base","--is-ancestor",r,t]);return n.status===0?{isAncestor:!0,error:null}:n.status===1?{isAncestor:!1,error:null}:{isAncestor:null,error:n.error||n.stderr||n.stdout||`git exited ${n.status}`}}function bs(e,r="origin/main"){let t=typeof r=="string"?{base:r}:r,n=t.baseCommit?.trim()||t.base?.trim()||"origin/main",o=t.baseCommit?.trim()||null;if(!e)return ml(n,"missing worktree path");let s=ne(e,["rev-parse","HEAD"]);if(s.status!==0)return ml(n,s.error||s.stderr||s.stdout||"failed to resolve HEAD");let i;if(o)i=o;else{let m=ne(e,["rev-parse",n]);if(m.status!==0)return ml(n,m.error||m.stderr||m.stdout||`failed to resolve ${n}`,s.stdout.trim());i=m.stdout.trim()}let a=s.stdout.trim();if(a===i)return{checked:!0,base:n,head:a,baseHead:i,baseIsAncestorOfHead:!0,headIsAncestorOfBase:!0,relation:"synced"};let l=Rp(e,i,a),c=Rp(e,a,i),u=l.error||c.error||void 0;if(l.isAncestor==null||c.isAncestor==null)return{checked:!1,base:n,head:a,baseHead:i,baseIsAncestorOfHead:l.isAncestor,headIsAncestorOfBase:c.isAncestor,relation:"unknown",...u?{error:u}:{}};let d=l.isAncestor?"ahead":c.isAncestor?"merged":"diverged";return{checked:!0,base:n,head:a,baseHead:i,baseIsAncestorOfHead:l.isAncestor,headIsAncestorOfBase:c.isAncestor,relation:d,...u?{error:u}:{}}}function ml(e,r,t=null){return{checked:!1,base:e,head:t,baseHead:null,baseIsAncestorOfHead:null,headIsAncestorOfBase:null,relation:"unknown",error:r}}var Pe=M(()=>{"use strict";C();jr()});import{homedir as fl}from"node:os";import Vr from"node:path";function Sp(e){return e==="~"?fl():e.startsWith("~/")||e.startsWith("~\\")?Vr.join(fl(),e.slice(2)):e}function Bt(e){return Vr.resolve(Sp(e))}function Se(e){let r=Sp(e),t=Vr.resolve(r),n=Vr.resolve(fl());return t===n?"~":t.startsWith(`${n}${Vr.sep}`)?`~/${Vr.relative(n,t).split(Vr.sep).join("/")}`:t.replace(/\\/g,"/").replace(/^\/home\/[^/]+(?=\/|$)/,"~").replace(/^\/Users\/[^/]+(?=\/|$)/,"~").replace(/^[A-Za-z]:\/home\/[^/]+(?=\/|$)/i,"~").replace(/^[A-Za-z]:\/Users\/[^/]+(?=\/|$)/i,"~")}function q(e){return Se(e)}var Je=M(()=>{"use strict"});import{existsSync as kl,readFileSync as Cp}from"node:fs";import{homedir as Vv}from"node:os";import lr from"node:path";import{fileURLToPath as Gv}from"node:url";function Jv(e){let r=lr.join(e,"package.json");if(!kl(r))return null;try{let t=JSON.parse(Cp(r,"utf8"));return typeof t.name=="string"?t.name.trim():null}catch{return null}}function wp(e){return Jv(e)==="kynver"}function hl(e){let r=lr.resolve(e);if(!kl(r))return null;let t=ne(r,["rev-parse","--show-toplevel"]);if(t.status!==0)return null;let n=t.stdout.trim();return n.length?lr.resolve(n):null}function qv(e=import.meta.url){let r=lr.dirname(Gv(e));for(let t=0;t<8;t+=1){let n=lr.join(r,"package.json");if(kl(n))try{if(JSON.parse(Cp(n,"utf8")).name==="@kynver-app/runtime")return r}catch{}let o=lr.dirname(r);if(o===r)break;r=o}return null}function gl(e,r,t,n){if(!t)return;let o=lr.resolve(t);e.has(o)||wp(o)&&(e.add(o),r.push({repo:o,source:n}))}function yl(e){let r=e?.cwd??process.cwd(),t=new Set,n=[];gl(t,n,hl(r),"cwd_git");let o=qv(e?.runtimeModuleUrl??import.meta.url);o&&gl(t,n,hl(o),"runtime_checkout");let s=Vv();for(let i of Yv)gl(t,n,Bt(lr.join(s,i)),"well_known_path");return n}function Gr(e){return yl(e)[0]??null}function _p(e){let r=lr.resolve(e).replace(/\\/g,"/");return r.includes("/.kynver/harness/worktrees/")||r.includes("/.openclaw/harness/worktrees/")||r.includes("/kynver-harness/")||r.includes("/openclaw/harness/worktrees/")}function jn(e){let r=yl(e);return r.find(n=>!_p(n.repo))??r[0]??null}var Yv,Vn=M(()=>{"use strict";Pe();Je();Yv=["Kynver","repos/Kynver","repos/kynver-source-main","code/Kynver","projects/Kynver"]});function Ft(e){let r=(e??"").trim().toLowerCase();return r==="ghost"||r==="forge"?r:r.includes("forge")?"forge":r.includes("ghost")||r.includes("openclaw")?"ghost":"forge"}function Pp(e,r){return e[r]?.trim()||null}function Ae(e=process.env,r={}){let t=[],n=r.boxKind?.trim();if(n)return{boxKind:Ft(n),source:"config",slugInferenceBlocked:!1,warnings:t};let o=Pp(e,"KYNVER_BOX_KIND");if(o)return{boxKind:Ft(o),source:"env",slugInferenceBlocked:!1,warnings:t};let s=Pp(e,"KYNVER_AGENT_OS_SLUG");return s&&t.push(`KYNVER_AGENT_OS_SLUG=${s} is a workspace slug, not box identity \u2014 set boxKind via \`kynver setup --box-kind forge|ghost\` or KYNVER_BOX_KIND (defaulting box kind to forge)`),{boxKind:"forge",source:"default",slugInferenceBlocked:!!s,warnings:t}}function qe(e={},r=process.env){return Ae(r,e).boxKind}var Oe=M(()=>{"use strict"});function Pl(e,r){return e==="forge"?4:Math.max(1,r)}function cr(e,r){return e==="forge"?Math.min(Math.max(1,r),4):Math.max(1,r)}function Kt(e,r){return e==="forge"&&r>4}var Jn=M(()=>{"use strict"});import{readFileSync as fb}from"node:fs";import Ap from"node:os";function $t(e){if(e!==void 0){let r=e.match(/^MemAvailable:\s+(\d+)\s*kB/m);return r?Number(r[1])*1024:Ap.freemem()}if(process.platform==="linux")try{let t=fb("/proc/meminfo","utf8").match(/^MemAvailable:\s+(\d+)\s*kB/m);if(t)return Number(t[1])*1024}catch{}return Ap.freemem()}var _s=M(()=>{"use strict"});import{existsSync as gb,readFileSync as hb,statfsSync as kb}from"node:fs";function xs(){if(process.platform!=="linux")return!1;for(let e of["/proc/sys/kernel/osrelease","/proc/version"])try{if(!gb(e))continue;let r=hb(e,"utf8");if(/microsoft|wsl/i.test(r))return!0}catch{}return!1}function Al(e={}){if(!(e.forceWsl===void 0?xs():e.forceWsl))return null;let t=e.wslHostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.wslHostFreeWarnBytes??Ip,o=e.wslHostFreeCriticalBytes??Op,s=e.statfs??kb,i;try{i=s(t)}catch(h){return{ok:!1,path:t,freeBytes:0,totalBytes:0,usedPercent:100,warnBelowBytes:n,criticalBelowBytes:o,reason:`Windows host disk probe failed at ${t}: ${h.message}`,probeError:h.message}}let a=Number(i.bavail)*Number(i.bsize),l=Number(i.blocks)*Number(i.bsize),c=l>0?(l-a)/l*100:100,u=a<n,d=a<o,m=!u&&!d,p=(a/(1024*1024*1024)).toFixed(1),f=null;return m||(f=`Windows host disk ${t} at ${d?"critical":"warning"}: ${p} GiB free (<${(d?o:n)/1024/1024/1024} GiB); WSL VHDX cannot grow safely. ${Np()}`),{ok:m,path:t,freeBytes:a,totalBytes:l,usedPercent:c,warnBelowBytes:n,criticalBelowBytes:o,reason:f,probeError:null}}function Np(){return"Recovery: 1) free Windows C: (empty Recycle Bin / Storage Sense / clear %TEMP% and %LOCALAPPDATA%\\Temp\\wsl-crashes); 2) shut down WSL (`wsl --shutdown`) then compact the VHDX (`Optimize-VHD` or `diskpart compact vdisk`); 3) clear local node_modules / .next / harness worktrees before restarting workers; 4) disable recurring dumps via `%USERPROFILE%/.wslconfig` (`maxCrashDumpCount=-1`) or `kynver wsl-crashes --execute`. Full runbook: docs/runbooks/wsl-disk-pressure.md."}var Ip,Op,Jr,Es=M(()=>{"use strict";Ip=25*1024*1024*1024,Op=12*1024*1024*1024,Jr="/mnt/c"});import{execFileSync as Tp}from"node:child_process";import{existsSync as As,readFileSync as Dp,readdirSync as yb,statSync as Rb}from"node:fs";import Il from"node:path";function Ps(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)?n:r}function Ol(){let e=process.env.KYNVER_WSL_WIN_USER?.trim();if(e)return e;try{let n=Tp("cmd.exe",["/c","echo","%USERNAME%"],{encoding:"utf8",timeout:5e3,stdio:["ignore","pipe","ignore"]}).trim();if(n&&n!=="%USERNAME%"&&!n.includes("%"))return n}catch{}let r=process.env.USER?.trim()||process.env.LOGNAME?.trim(),t=process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr;return r&&As(Il.join(t,"Users",r))?r:null}function Wp(e={}){let r=e.crashDumpDir?.trim()||process.env.KYNVER_WSL_CRASH_DUMP_DIR?.trim();if(r)return r;let t=e.hostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.windowsUser??Ol();return n?`${t.replace(/\\/g,"/").replace(/\/$/,"")}/Users/${n}/AppData/Local/Temp/wsl-crashes`:null}function Lp(e){let r=/^wsl-crash-\d+-(\d+)-(.+)-(\d+)\.dmp$/i.exec(e);if(!r)return{executableHint:null,signal:null,pid:null};let t=Number(r[1]),n=r[2]??"",o=Number(r[3]),s=n.split("_").filter(Boolean);return{executableHint:s.length>0?s[s.length-1]:null,signal:Number.isFinite(o)?o:null,pid:Number.isFinite(t)?t:null}}function Bp(){try{if(As("/proc/sys/kernel/core_pattern"))return Dp("/proc/sys/kernel/core_pattern","utf8").trim()}catch{}try{return Tp("sysctl",["-n","kernel.core_pattern"],{encoding:"utf8",timeout:2e3,stdio:["ignore","pipe","ignore"]}).trim()||null}catch{return null}}function Sb(e){return!!(e&&/wsl-capture-crash/i.test(e))}function Hp(e,r=Jr){let t=Il.join(r,"Users",e,".wslconfig");if(!As(t))return{maxCrashDumpCount:null,crashDumpFolder:null};let n;try{n=Dp(t,"utf8")}catch{return null}let o=null,s=null;for(let i of n.split(/\r?\n/)){let a=i.replace(/#.*$/,"").trim();if(!a||a.startsWith("["))continue;let l=a.indexOf("=");if(l<0)continue;let c=a.slice(0,l).trim().toLowerCase(),u=a.slice(l+1).trim();if(c==="maxcrashdumpcount"){let d=Number(u);o=Number.isFinite(d)?d:null}else c==="crashdumpfolder"&&(s=u.replace(/^["']|["']$/g,"")||null)}return{maxCrashDumpCount:o,crashDumpFolder:s}}function Cb(e){if(!As(e))return[];let r=yb(e,{withFileTypes:!0}),t=[];for(let n of r){if(!n.isFile()||!n.name.toLowerCase().endsWith(".dmp"))continue;let o=Il.join(e,n.name);try{let s=Rb(o),i=Lp(n.name);t.push({name:n.name,path:o,bytes:s.size,mtimeMs:s.mtimeMs,executableHint:i.executableHint,signal:i.signal,pid:i.pid})}catch{}}return t.sort((n,o)=>o.mtimeMs-n.mtimeMs),t}function ur(e={}){if(!(e.forceWsl===void 0?xs():e.forceWsl))return null;let t=e.hostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.windowsUser??Ol(),o=e.warnBelowBytes??Ps("KYNVER_WSL_CRASH_DUMP_WARN_BYTES",Mp),s=e.criticalBelowBytes??Ps("KYNVER_WSL_CRASH_DUMP_CRITICAL_BYTES",Up),i=e.warnCount??Ps("KYNVER_WSL_CRASH_DUMP_WARN_COUNT",vb),a=e.criticalCount??Ps("KYNVER_WSL_CRASH_DUMP_CRITICAL_COUNT",bb),l=(e.readCorePattern??Bp)(),c=Sb(l),u=null;n&&(u=(e.readWslConfig??Hp)(n,t));let d=u?.maxCrashDumpCount??null,m=d===-1,p=Wp({hostMount:t,windowsUser:n,crashDumpDir:e.crashDumpDir});if(!p)return{ok:!0,path:null,windowsUser:n,dumpCount:0,totalBytes:0,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:[],executables:[],corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:m,reason:null,probeError:"windows_user_unresolved"};let f;try{f=(e.listDumps??Cb)(p)}catch(F){return{ok:!1,path:p,windowsUser:n,dumpCount:0,totalBytes:0,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:[],executables:[],corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:m,reason:`WSL crash dump probe failed at ${p}: ${F.message}`,probeError:F.message}}let h=f.reduce((F,P)=>F+P.bytes,0),k=f.length,g=[...new Set(f.map(F=>F.executableHint).filter(F=>!!F))],R=h>=s,O=h>=o,_=k>=a,E=k>=i,Y=!(R||_||O||E),$=null;if(!Y){let F=R||_?"critical":"warning",P=(h/1024**3).toFixed(1),B=g.length>0?g.join(", "):"unknown";$=`WSL crash dumps ${F}: ${k} file(s), ${P} GiB at ${p} (executables: ${B}). `+Fp({wslCaptureEnabled:c,dumpsDisabledInWslConfig:m})}return{ok:Y,path:p,windowsUser:n,dumpCount:k,totalBytes:h,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:f,executables:g,corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:m,reason:$,probeError:null}}function Fp(e={}){let r=["Recovery:","1) run `kynver wsl-crashes --execute` or scripts/cleanup-wsl-crashes.ps1 to prune old .dmp files;"];return e.dumpsDisabledInWslConfig||r.push("2) add `[wsl2]\\nmaxCrashDumpCount=-1` to %USERPROFILE%/.wslconfig then `wsl --shutdown` to disable future dumps;"),e.wslCaptureEnabled&&r.push("3) investigate crashing executables (node OOM/SIGBUS often follows Windows C: pressure \u2014 see docs/runbooks/wsl-disk-pressure.md);"),r.push("full runbook: docs/runbooks/wsl-disk-pressure.md."),r.join(" ")}var Mp,Up,vb,bb,jt=M(()=>{"use strict";Es();Mp=5*1024*1024*1024,Up=10*1024*1024*1024,vb=2,bb=4});import{statfsSync as wb}from"node:fs";function Le(e={}){let r=e.diskPath?.trim()||"/",t=e.diskFreeWarnBytes??_b,n=e.diskFreeCriticalBytes??xb,o=e.diskMaxUsedPercent??Eb,s=e.diskHardMaxUsedPercent??Pb,i=wb(r),a=Number(i.bavail)*Number(i.bsize),l=Number(i.blocks)*Number(i.bsize),c=l>0?(l-a)/l*100:100,u=a<t,d=a<n,m=a<t*2,p=m&&c>o,f=m&&c>s,h=!u&&!d&&!p&&!f,k=e.skipWslHostCheck?null:Al(e.wslHost),g=e.skipWslCrashDumpCheck?null:ur(e.wslCrashDumps),R=h&&(k?k.ok:!0)&&(g?g.ok:!0),O=null;return R||(O=[d?`free space below critical ${n} bytes`:null,u?`free space below warning ${t} bytes`:null,f?`used percent above hard cap ${s}%`:null,p?`used percent above cap ${o}%`:null,k&&!k.ok?k.reason:null,g&&!g.ok?g.reason:null].filter(Boolean).join("; ")),Ab({ok:R,path:r,freeBytes:a,totalBytes:l,usedPercent:c,warnBelowBytes:t,criticalBelowBytes:n,maxUsedPercent:o,hardMaxUsedPercent:s,reason:O,wslHost:k,wslCrashDumps:g?{ok:g.ok,path:g.path,dumpCount:g.dumpCount,totalBytes:g.totalBytes,executables:g.executables,wslCaptureEnabled:g.wslCaptureEnabled,dumpsDisabledInWslConfig:g.dumpsDisabledInWslConfig,reason:g.reason,probeError:g.probeError}:null})}function Ab(e){let r=process.env.KYNVER_DISPATCH_DISK_GATE_FORCE?.trim().toLowerCase();return r?r==="ok"||r==="open"||r==="none"?e.ok?e:{...e,ok:!0,reason:`disk gate forced open by KYNVER_DISPATCH_DISK_GATE_FORCE (suppressed: ${e.reason??"no reason"})`}:r==="block"||r==="pressured"?{...e,ok:!1,reason:`disk gate forced closed by KYNVER_DISPATCH_DISK_GATE_FORCE${e.reason?` (underlying: ${e.reason})`:""}`}:e:e}var _b,xb,Eb,Pb,Vt=M(()=>{"use strict";jt();Es();_b=30*1024*1024*1024,xb=15*1024*1024*1024,Eb=80,Pb=90});import{existsSync as Kp}from"node:fs";import{homedir as jp}from"node:os";import Pr from"node:path";function le(e){let r=Pr.resolve(Bt(e.trim()));for(;Ib.has(Pr.basename(r));)r=Pr.dirname(r);return r}function fe(){let e=process.env.KYNVER_HARNESS_ROOT||process.env.OPUS_HARNESS_ROOT;if(e)return le(e);let r=y().harnessRoot?.trim();if(r)return le(r);let t=Pr.join(jp(),".kynver","harness");return Kp(t)?t:Kp($p)?$p:t}function ge(e){return Pr.join(le(e),"runs")}function dr(e){return Pr.join(le(e),"worktrees")}function qr(){let e=fe();return{harnessRoot:e,runsDir:ge(e),worktreesDir:dr(e)}}function Gt(e,r){return Pr.join(e,b(r))}var $p,Ib,Ce=M(()=>{"use strict";I();Je();C();$p=Pr.join(jp(),".openclaw","harness"),Ib=new Set(["runs","worktrees"])});import{existsSync as Ob,readdirSync as Nb,statSync as Tb}from"node:fs";import Yt from"node:path";function Z(){return qr()}function L(e){let{runsDir:r}=Z();return w(Yt.join(Gt(r,b(e)),"run.json"))}function X(){let{runsDir:e}=Z();return Vp(e)}function Is(e){return Vp(ge(e))}function Db(e){try{return Tb(e).isDirectory()}catch{return!1}}function Vp(e){if(!Ob(e))return[];let r=[];for(let t of Nb(e,{withFileTypes:!0})){if(t.name==="runs")continue;let n=Yt.join(e,t.name);if(!Db(n))continue;let o=w(Yt.join(n,"run.json"),void 0);o?.id&&r.push(o)}return r}function he(e,r){let{runsDir:t}=Z();return w(Yt.join(Gt(t,b(e)),"workers",b(r),"worker.json"))}function Be(e){let{runsDir:r}=Z();ae(Yt.join(Gt(r,e.id),"run.json"),e)}function K(e,r){let{runsDir:t}=Z();ae(Yt.join(Gt(t,e),"workers",r.name,"worker.json"),r)}function x(e){let{harnessRoot:r}=Z();return qn(r,e)}function qn(e,r){return Gt(ge(e),b(r))}var T=M(()=>{"use strict";Ce();C()});import{existsSync as Mb,readdirSync as Ub}from"node:fs";import Wb from"node:path";function ke(e){let r=new Set;for(let n of Object.keys(e.workers||{}))r.add(b(n));let t=Wb.join(x(e.id),"workers");if(!Mb(t))return[...r];for(let n of Ub(t,{withFileTypes:!0}))n.isDirectory()&&r.add(b(n.name));return[...r]}var zr=M(()=>{"use strict";T();C()});function Nl(e){let r=e.trim();if(!r.startsWith("{"))return null;try{let t=JSON.parse(r);if(t&&typeof t=="object"&&!Array.isArray(t))return t}catch{return null}return null}function Gp(e){let r=e.trim();if(!r)return null;let t=Nl(r);if(t)return t;let n=[],o=/```(?:json)?\s*([\s\S]*?)```/gi,s;for(;(s=o.exec(r))!==null;){let l=Nl(s[1]??"");l&&n.push(l)}let i=r.indexOf("{"),a=r.lastIndexOf("}");if(i>=0&&a>i){let l=Nl(r.slice(i,a+1));l&&n.push(l)}return n.length>0?n[n.length-1]:null}function Yp(e){let r=e.finalResult??e.final_result;if(r!=null)return typeof r=="string"?Gp(r)??(r.trim()||null):r;let t=typeof e.summary=="string"?e.summary.trim():"";if(!t)return null;let n=Gp(t);return n||t}var Jp=M(()=>{"use strict"});import{existsSync as Lb,readFileSync as Bb}from"node:fs";function Tl(e){return e==="complete"}function ze(e){return Tl(e.lastHeartbeatPhase)?e.terminalFinalResult!==void 0&&e.terminalFinalResult!==null?e.terminalFinalResult:e.lastHeartbeatSummary?.trim()||"completed":null}function ce(e){let r={heartbeatCount:0,lastHeartbeatAt:null,lastHeartbeatPhase:null,lastHeartbeatSummary:null,terminalFinalResult:null,heartbeatBlocker:null,timestampAnomalies:[],lastBoxResourceSnapshot:null,lastPrEvidence:[]};if(!Lb(e))return r;let t=Date.now()+Hb,n=new Date(t).toISOString(),o=Bb(e,"utf8").split(`
|
|
6
|
-
`).filter(Boolean);for(let s of o){let i=
|
|
7
|
-
`).find(Boolean)??o,160):"npm audit failed"}function
|
|
8
|
-
${e.stderr}`.trim(),t=
|
|
9
|
-
`).filter(Boolean);for(let n of t){let o=Lt(n);if(!o)continue;let s=oS(o);if(s&&(r.firstEventAt||=s,r.lastEventAt=s),o.type==="stream_event"&&o.event&&typeof o.event=="object"&&o.event.type==="content_block_start"){let a=o.event.content_block;a?.type==="tool_use"&&(r.currentTool=String(a.name||"tool"))}if(o.type==="assistant"&&o.message&&typeof o.message=="object"){let a=o.message.content;if(Array.isArray(a)){let l=a.find(c=>c?.type==="tool_use");l&&(r.currentTool=String(l.name||r.currentTool))}}if(o.type==="tool_call"&&o.subtype==="started"){let a=o.tool_call&&typeof o.tool_call=="object"&&!Array.isArray(o.tool_call)?o.tool_call:void 0,l=nm(a);l&&(r.currentTool=l)}let i=om(o);i&&iS(r,Ms({command:i.command,exitCode:i.exitCode,stdout:i.stdout,stderr:i.stderr,interleavedOutput:i.interleaved})),o.type==="result"&&sS(r,o)}return r}function aS(e){return Ar(e)}function sm(e){let r=om(e);if(!r)return;let t=Ms({command:r.command,exitCode:r.exitCode,stdout:r.stdout,stderr:r.stderr,interleavedOutput:r.interleaved}),n=ks(r.command).slice(0,120);return t.kind==="audit_findings"?`[audit:findings] ${t.summary}${n?` \xB7 ${n}`:""}`:t.kind==="search_no_matches"?`[search:no_matches] ${t.summary}${n?` \xB7 ${n}`:""}`:t.kind==="command_failure"?`[command:failed] ${t.summary}${n?` \xB7 ${n}`:""}`:`[command:ok] exit 0${n?` \xB7 ${n}`:""}`}function Wl(e){if(e.type==="system"&&e.subtype)return`[system:${e.subtype}] ${String(e.status||e.cwd||"")}`.trim();if(e.type==="stream_event"&&e.event&&typeof e.event=="object"){let r=e.event.type;if(r==="content_block_start"){let t=e.event.content_block;if(t?.type==="tool_use")return`[tool:start] ${t.name}`}if(r==="content_block_delta"){let t=e.event.delta;if(t?.partial_json)return`[tool:input] ${t.partial_json}`}return r==="message_stop"?"[message:stop]":r?`[stream:${r}]`:void 0}if(e.type==="assistant"&&e.message&&typeof e.message=="object"){let r=e.message.content;if(Array.isArray(r)){let t=r.find(o=>o?.type==="text");if(t)return`[assistant] ${ks(String(t.text||""))}`;let n=r.find(o=>o?.type==="tool_use");if(n)return`[tool] ${n.name} ${JSON.stringify(n.input||{})}`}}if(e.type==="user"&&e.tool_use_result){let r=e.tool_use_result;return`[tool:result] stdout=${JSON.stringify(r.stdout||"")} stderr=${JSON.stringify(r.stderr||"")}`}if(e.type==="tool_call"){let r=String(e.subtype||""),t=r==="completed"?sm(e):void 0;if(t)return t;let n=e.tool_call&&typeof e.tool_call=="object"&&!Array.isArray(e.tool_call)?e.tool_call:void 0,o=nm(n)??"tool";return`[tool:${r}] ${o}`}if(e.type==="result")return`[result] ${e.subtype||""} ${ks(String(e.result||""))}`.trim()}var Jt=M(()=>{"use strict";Ul();C()});function cS(e,r=240){let t=e.replace(/\s+/g," ").trim();return t.length>r?`${t.slice(0,r-1)}\u2026`:t}function Us(e){let r=(e??"").trim();if(!r)return null;for(let t of lS)if(t.test.test(r))return{blocked:!0,reason:`${t.label}: ${cS(r)}`};return null}var lS,Ll=M(()=>{"use strict";lS=[{test:/\b(?:invalid|unknown|unsupported|unrecognized)\b[^.\n]*\bmodel\b/i,label:"provider rejected the requested model"},{test:/\bmodel\b[^.\n]*\b(?:not\s+(?:found|supported|available|recognized|valid)|is\s+not\s+valid|does\s+not\s+exist)/i,label:"provider rejected the requested model"},{test:/\b(?:did you mean|available models|choose (?:a|one of)|supported models)\b/i,label:"provider rejected the requested model"},{test:/model preflight failed/i,label:"model/provider preflight failed"},{test:/\b(?:command not found|ENOENT|is the .*CLI on PATH|executable not found|no such file or directory)\b/i,label:"provider CLI is missing or not on PATH"},{test:/\bfailed to spawn\b/i,label:"provider failed to spawn the worker process"},{test:/\b(?:not logged in|unauthorized|authentication (?:failed|required)|invalid api key|missing api key|401)\b/i,label:"provider authentication failed"}]});function im(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function uS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function dS(e){return!e?.checked||e.headIsAncestorOfBase!==!1?null:im(e.head)}function pS(e,r,t){let n=["exited_with_changes_salvage"];if((e==="uncommitted"||e==="both")&&n.push(`${r} uncommitted change${r===1?"":"s"} with no final result`),(e==="committed_ahead"||e==="both")&&t){let o=t.length>12?t.slice(0,12):t;n.push(`commit ${o} ahead of base with no final result`)}return n.push("review worktree \u2014 commit, open a PR, or run a salvage worker before discarding"),n.join(": ")}function Xr(e){if(e.alive||uS(e.finalResult))return null;let r=(e.changedFiles??[]).filter(i=>i.trim()).length,t=im(e.headCommit)??dS(e.gitAncestry),n=r>0,o=!!t;if(!n&&!o)return{kind:"none",salvageable:!1,uncommittedCount:0,headCommit:null,attentionReason:"process exited without a final result"};let s=n&&o?"both":n?"uncommitted":"committed_ahead";return{kind:s,salvageable:!0,uncommittedCount:r,headCommit:t,attentionReason:pS(s,r,t)}}var Qn=M(()=>{"use strict"});function Zn(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function mS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function fS(e){if(Zn(e.headCommit)||Zn(e.prUrl)||Zn(e.artifactBundlePath)||Zn(e.patchPath))return!0;let r=e.gitAncestry;return!!(r?.checked&&r.headIsAncestorOfBase===!1&&Zn(r.head))}function Qr(e){return mS(e.finalResult)?e.changedFiles.length===0?{blocked:!1}:fS(e)?{blocked:!0,detail:`Worktree has ${e.changedFiles.length} uncommitted change(s); commit or discard before landing`}:{blocked:!0,reason:"dirty_worktree_no_pr",detail:`Worktree has ${e.changedFiles.length} uncommitted change(s) with no commit or PR; commit, open a PR, or discard before landing`}:{blocked:!1}}function am(e){if(e.blocked)return e.detail??e.reason??"dirty_worktree_no_pr"}var eo=M(()=>{"use strict"});function Bl(e){let r=e.trim();if(!r.startsWith("{"))return null;try{let t=JSON.parse(r);if(t&&typeof t=="object"&&!Array.isArray(t))return t}catch{return null}return null}function lm(e){let r=e.targetPrReconciliation??e.target_pr_reconciliation??e.targetPrs??e.target_prs;return Array.isArray(r)?r.length:0}function qt(e){let r=e.trim();if(!r)return null;let t=Bl(r);if(t)return t;let n=[],o=/```(?:json)?\s*([\s\S]*?)```/gi,s;for(;(s=o.exec(r))!==null;){let u=Bl(s[1]??"");u&&n.push(u)}let i=r.indexOf("{"),a=r.lastIndexOf("}");if(i>=0&&a>i){let u=Bl(r.slice(i,a+1));u&&n.push(u)}if(n.length===0)return null;let l=n[n.length-1],c=lm(l);for(let u of n){let d=lm(u);d>c&&(l=u,c=d)}return l}var Ws=M(()=>{"use strict"});function cm(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:e.trim()||null}function um(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`${r[1].toLowerCase()}/pull/${r[2]}`:e.trim().toLowerCase()}function gS(e){return new Set(e.map(r=>um(cm(r)??r)).filter(Boolean))}function dm(e,r,t){let n=cm(e)??e;if(!n)return"unrelated";let o=um(n);return gS(r).has(o)?"contract":t?(t.outcome==="skipped"||t.outcome==="blocked")&&t.reason?.trim()?"support":(t.outcome==="merged","unrelated"):"unrelated"}var pm=M(()=>{"use strict"});function zt(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function hS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="object"?Object.keys(e).length>0:!0}function Zr(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:zt(e)}function Ls(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`${r[1].toLowerCase()}/pull/${r[2]}`:e.trim().toLowerCase()}function mm(e){let r=null;if(typeof e=="string"){let o=qt(e);o&&(r=o)}else e&&typeof e=="object"&&!Array.isArray(e)&&(r=e);if(!r)return[];let t=r.targetPrReconciliation??r.target_pr_reconciliation;if(!Array.isArray(t))return[];let n=[];for(let o of t){if(!o||typeof o!="object"||Array.isArray(o))continue;let s=o,i=Zr(String(s.prUrl??s.pr_url??"")),a=zt(s.outcome);!i||a!=="merged"&&a!=="skipped"&&a!=="blocked"||n.push({prUrl:i,outcome:a,mergeCommit:zt(s.mergeCommit??s.merge_commit),reason:zt(s.reason)})}return n}function fm(e,r){let t=[],n=Zr(zt(e.prUrl)??"");if(n&&t.push(n),r&&typeof r=="object"&&!Array.isArray(r)){let o=r,s=Zr(String(o.prUrl??o.pr_url??""));s&&t.push(s)}return[...new Set(t)]}function Hl(e){let{contract:r,snapshot:t}=e,n=e.finalResult??t.finalResult;if(!r.landingOnly&&r.targetPrUrls.length===0&&!r.repairEnforceOriginalPr)return{blocked:!1};if(!hS(n))return(r.requiresTargetPrReconciliation??(r.landingOnly||!!r.repairEnforceOriginalPr||r.targetPrUrls.length>0))&&r.targetPrUrls.length>0?{blocked:!0,reason:"missing_target_pr_reconciliation",detail:`Final result required to reconcile target PR(s): ${r.targetPrUrls.join(", ")}`}:{blocked:!1};if(!(r.requiresTargetPrReconciliation??(r.landingOnly||!!r.repairEnforceOriginalPr||r.targetPrUrls.length>0))&&!r.repairEnforceOriginalPr)return{blocked:!1};let s=r.repairEnforceOriginalPr?Zr(zt(r.targetPrUrl)??"")??(r.targetPrUrls.length===1?Zr(r.targetPrUrls[0]):null):null;if(s){let d=fm(t,n);if(!(n&&typeof n=="object"&&!Array.isArray(n)&&n.supersedesOriginalTargetPr===!0)){for(let h of d)if(h!==s)return{blocked:!0,reason:"duplicate_repair_pr",detail:`Repair worker opened or attached PR ${h} instead of canonical target ${s}`}}let f=mm(n).find(h=>h.prUrl===s);if(!f||f.outcome!=="merged"&&!(f.reason?.trim()&&(f.outcome==="skipped"||f.outcome==="blocked")))return{blocked:!0,reason:"missing_repair_target_reconciliation",detail:`Repair worker must reconcile target PR ${s}`}}let i=mm(n),a=new Map(i.map(d=>[Ls(d.prUrl),d])),l=new Set(r.targetPrUrls.map(d=>Ls(Zr(d)??d)).filter(Boolean)),c=fm(t,n);if(r.landingOnly)for(let d of c){let m=a.get(Ls(d)),p=dm(d,r.targetPrUrls,m);if(!(p==="contract"||p==="support"))return l.size>0?{blocked:!0,reason:"unrelated_implementation_pr",detail:`Landing-only worker attached unrelated PR ${d}`}:{blocked:!0,reason:"unrelated_implementation_pr",detail:"Landing-only worker must not open new implementation PRs"}}if(r.targetPrUrls.length===0)return{blocked:!1};let u=[];for(let d of r.targetPrUrls){let m=Ls(Zr(d)??d),p=a.get(m);if(!p){u.push(m);continue}p.outcome!=="merged"&&!p.reason?.trim()&&u.push(m)}return u.length>0?{blocked:!0,reason:u.every(d=>a.has(d))?"incomplete_target_pr_landing":"missing_target_pr_reconciliation",detail:`Target PR reconciliation incomplete: ${u.join(", ")}`}:{blocked:!1}}function Fl(e){if(e.blocked)return e.detail??e.reason}var Kl=M(()=>{"use strict";Ws();pm()});function gm(e){let r=Date.now();if(e.completionBlocker&&!hm(e.completionBlocker))return{state:"blocked",reason:e.completionBlocker};if(e.finalResult){if(e.localOnly&&RS(e.finalResult))return{state:"done",reason:"local-only worker superseded by merged PR"};let o={finalResult:e.finalResult,changedFiles:e.changedFiles??[],gitAncestry:e.gitAncestry??null,prUrl:e.prUrl??null},s=Qr(o);if(s.blocked){let i=am(s);return{state:"needs_attention",reason:s.reason?`landing blocked (${s.reason}): ${i}`:`landing blocked: ${i}`}}if(e.landingContract){let i=Hl({contract:e.landingContract,snapshot:o,finalResult:e.finalResult}),a=Fl(i);if(a)return{state:"needs_attention",reason:i.reason?`landing contract (${i.reason}): ${a}`:`landing contract: ${a}`}}return{state:"done",reason:"final result recorded"}}if(!e.alive){if(yS(e))return{state:"done",reason:"empty abandoned worker record"};let o=Us(e.error);if(o)return{state:"blocked",reason:o.reason};let s=Xr({alive:!1,finalResult:null,changedFiles:e.changedFiles,gitAncestry:e.gitAncestry});if(s?.salvageable){let a=e.error?.trim();return{state:"needs_attention",reason:a?`${s.attentionReason} (${a})`:s.attentionReason}}let i=e.error?.trim();return{state:"needs_attention",reason:i?`process exited without a final result: ${i}`:s?.attentionReason??"process exited without a final result"}}if(e.heartbeatBlocker)return{state:"blocked",reason:`worker heartbeat reported blocker: ${e.heartbeatBlocker}`};let t=e.startedAt?Date.parse(e.startedAt):NaN;if(!e.firstEventAt&&e.stdoutBytes===0&&e.heartbeatBytes===0&&Number.isFinite(t)&&r-t>kS)return{state:"needs_attention",reason:`no first stream event ${dl(t)}s after start`};let n=e.lastActivityAt?Date.parse(e.lastActivityAt):NaN;return Number.isFinite(n)&&r-n>Xt?{state:"stale",reason:`no log/event/heartbeat activity for ${dl(n)}s`}:{state:"ok",reason:"recent activity"}}function hm(e){let r=e?.trim();return r?/completion acknowledged but board not advanced/i.test(r)&&/task already terminal/i.test(r):!1}function yS(e){return e.finalResult||e.taskId||e.agentOsId||e.stdoutBytes>0||(e.stderrBytes??0)>0||e.heartbeatBytes>0||e.error?.trim()||(e.changedFiles??[]).some(r=>r.trim())?!1:/empty worker dir|marked abandoned/i.test(e.reconcileReason??"")}function RS(e){let r=null;if(typeof e=="string"?r=qt(e):e&&typeof e=="object"&&!Array.isArray(e)&&(r=e),!r)return!1;let t=r.targetPrReconciliation??r.target_pr_reconciliation;return Array.isArray(t)?t.some(n=>!n||typeof n!="object"||Array.isArray(n)?!1:String(n.outcome??"").trim()==="merged"):!1}function vS(e,r,t){let n=e.completionSnapshot?.finalResult;return e.completionAckSource==="local-pr-merged-reconcile"&&n!==void 0&&n!==null?n:r||(n??ze(t))}function D(e,r={}){let t=Ar(e.stdoutPath),n=ce(e.heartbeatPath),o=typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim().length>0,s=vS(e,t.finalResult,n),i=o?!1:H(e.pid),a=ys(e.stdoutPath),l=ys(e.stderrPath),c=ys(e.heartbeatPath),u=$n(e.worktreePath),d=bs(e.worktreePath,{base:r.base,baseCommit:r.baseCommit}),m=gp([t.lastEventAt,n.lastHeartbeatAt,Rs(e.stdoutPath),Rs(e.stderrPath),Rs(e.heartbeatPath)]),p=t.error||!i&&!s&&vs(e.stderrPath,10).trim()||void 0,f=typeof e.completionBlocker=="string"&&e.completionBlocker.trim()?e.completionBlocker.trim():null,h=hm(f)?null:f,k=e.repairTargetPrUrl?{landingOnly:!1,targetPrUrls:[e.repairTargetPrUrl],targetPrUrl:e.repairTargetPrUrl,repairEnforceOriginalPr:!0}:null,g=gm({alive:i,finalResult:s,firstEventAt:t.firstEventAt,stdoutBytes:a,stderrBytes:l,heartbeatBytes:c,lastActivityAt:m,heartbeatBlocker:n.heartbeatBlocker,startedAt:e.startedAt,error:p,changedFiles:u,gitAncestry:d,completionBlocker:h,landingContract:k,prUrl:e.repairTargetPrUrl??e.taskPrUrl??null,localOnly:e.localOnly===!0,taskId:e.taskId??null,agentOsId:e.agentOsId??null,reconcileReason:e.reconcileReason??null}),R=h||g.state==="blocked"?"blocked":o||g.state==="done"?"done":s?"exited":i?"running":"exited";return{runId:e.runId,worker:e.name,pid:e.pid,alive:i,status:R,attention:g,branch:e.branch,worktreePath:e.worktreePath,ownedPaths:e.ownedPaths,stdoutBytes:a,stderrBytes:l,heartbeatBytes:c,firstEventAt:t.firstEventAt,lastEventAt:t.lastEventAt,lastActivityAt:m,currentTool:o?null:t.currentTool,heartbeatCount:n.heartbeatCount,lastHeartbeatAt:n.lastHeartbeatAt,lastHeartbeatPhase:n.lastHeartbeatPhase,lastHeartbeatSummary:n.lastHeartbeatSummary,heartbeatBlocker:n.heartbeatBlocker,timestampAnomalies:n.timestampAnomalies,finalResult:s,error:p,changedFiles:u,gitAncestry:d,instructionPolicyFingerprint:e.instructionPolicyFingerprint??null,instructionPolicyEvidence:e.instructionPolicyEvidence??null,model:e.model??e.orchestrationAudit?.model??null,provider:e.orchestrationAudit?.provider??null,boxKind:e.boxKind??null,boxId:e.boxId??null,runtimeId:e.runtimeId??null,personaSlug:e.personaSlug??null,dispatched:e.dispatched??null,localOnly:e.localOnly??null}}function oe(e){return!!(e.finalResult||e.alive===!1||e.status==="exited"||e.status==="done")}function et(e){return e.finalResult?e.attention.state==="needs_attention"||e.attention.state==="blocked":!1}function Qt(e,r){return r.length===0?e:r.some(t=>t.attention==="needs_attention"||t.attention==="stale"||t.attention==="blocked")?"needs_attention":r.every(t=>t.status==="done")?"done":r.some(t=>t.status==="running")?"running":e}var kS,Xt,z=M(()=>{"use strict";pr();Jt();Ll();Qn();Pe();eo();Kl();Ws();C();kS=18e4,Xt=6e5});import{readFileSync as bS}from"node:fs";function SS(e){if(!e||process.platform!=="linux")return null;try{return bS(`/proc/${e}/cmdline`,"utf8").replace(/\0/g," ")}catch{return null}}function Bs(e){if(!e.pid||process.platform!=="linux")return!0;let r=SS(e.pid);return r?[e.worktreePath,e.workerDir,e.heartbeatPath].filter(n=>typeof n=="string"&&n.trim().length>0).some(n=>r.includes(n)):!1}function rt(e){if(typeof e.completionBlocker=="string"&&e.completionBlocker.trim())return!1;let r=D(e);return r.alive&&!Bs(e)?!1:r.alive&&!r.finalResult&&r.attention.state!=="done"}var Zt=M(()=>{"use strict";z()});import ym from"node:os";import CS from"node:path";function km(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function wS(e=y(),r,t){let n=km(e.perWorkerMemBytes,ro),o=km(e.memReserveBytes,to),s=Math.min(1,Math.max(.1,Number(e.memUtilization)>0?Number(e.memUtilization):no)),i=Fs({config:e,configuredMaxWorkersOverride:r,totalMemBytes:t??ym.totalmem()});return{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s,configuredMaxWorkers:i.configuredMaxWorkers,autoCap:i.autoCap,workerCapSource:i.workerCapSource}}function $l(e,r={}){let t=r.perWorkerMemBytes??ro,n=r.memReserveBytes??to,o=r.memUtilization??no,s=Math.max(0,Math.floor(e*o)-n),i=Math.max(1,Math.floor(s/t));return Math.min(i,Hs)}function _S(){return $t()}function xS(e){let r=0;for(let t of ke(e)){let n=w(CS.join(x(e.id),"workers",b(t),"worker.json"),void 0);!n||!rt(n)||r++}return r}function ES(){let e=0;for(let r of X())e+=xS(r);return e}function mr(e){let r=e.config??y(),t=e.totalMemBytes??ym.totalmem(),{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s,configuredMaxWorkers:i,autoCap:a,workerCapSource:l}=wS(r,e.configuredMaxWorkersOverride,t),c=qe(r),u=e.freeMemBytes??_S(),d=e.activeWorkers??ES(),m=Math.max(0,Math.floor(t*s)-o),p=Math.max(0,Math.floor(m/n)),f=Math.max(0,Math.floor(Math.max(0,u-o)/n)),h=a,k=cr(c,i??h),g=Math.max(0,Math.min(k,p)),R=Math.max(0,g-d),_=Math.min(R,f),U=e.skipDiskGate||process.env.KYNVER_RESOURCE_GATE_SKIP_DISK==="1"?void 0:Le({diskPath:e.diskPath?.trim()||process.env.KYNVER_DISK_GUARD_PATH?.trim()||"/"});U&&!U.ok&&(_=0);let Y=null;return _<=0&&(U&&!U.ok?Y=U.reason??"disk gate blocked worker admission":d>=g?Y=`at worker limit (${d}/${g} running)`:f<=0?Y="insufficient free memory \u2014 waiting for workers to finish":Y="no worker slots available"),{ok:_>0,totalMemBytes:t,freeMemBytes:u,memReserveBytes:o,perWorkerMemBytes:n,configuredMaxWorkers:i,workerCapSource:l,boxKind:c,autoCap:h,capacityWorkers:p,maxConcurrentWorkers:g,activeWorkers:d,slotsAvailable:_,reason:Y,...U?{diskGate:U}:{}}}var ro,to,no,Hs,en=M(()=>{"use strict";_s();I();Oe();Jn();Ks();Vt();T();zr();Zt();C();ro=500*1024*1024,to=4*1024*1024*1024,no=.85,Hs=64});function tt(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function Fs(e){let r=e.config??{},t=e.env??process.env,n=tt(r.perWorkerMemBytes,ro),o=tt(r.memReserveBytes,to),s=Math.min(1,Math.max(.1,Number(r.memUtilization)>0?Number(r.memUtilization):no)),i=$l(e.totalMemBytes,{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s});if(e.configuredMaxWorkersOverride!==void 0&&e.configuredMaxWorkersOverride!==null)return{configuredMaxWorkers:tt(e.configuredMaxWorkersOverride,i),autoCap:i,workerCapSource:"workspace_override"};if(r.maxConcurrentWorkers!==void 0&&r.maxConcurrentWorkers!==null){let c=tt(r.maxConcurrentWorkers,0)||null;if(c)return{configuredMaxWorkers:Math.min(c,Hs),autoCap:i,workerCapSource:"config"}}let l=(t.KYNVER_MAX_WORKERS_INTENTIONAL==="1"||t.KYNVER_MAX_WORKERS_INTENTIONAL==="true")&&t.KYNVER_MAX_WORKERS&&tt(t.KYNVER_MAX_WORKERS,0)||null;return l?{configuredMaxWorkers:Math.min(l,Hs),autoCap:i,workerCapSource:"env"}:{configuredMaxWorkers:null,autoCap:i,workerCapSource:"auto"}}function jl(e={}){let r=e.totalMemBytes??0,t=$l(r,{perWorkerMemBytes:tt(e.config?.perWorkerMemBytes,ro),memReserveBytes:tt(e.config?.memReserveBytes,to),memUtilization:e.config?.memUtilization&&Number(e.config.memUtilization)>0?Number(e.config.memUtilization):no}),n=e.diskGateOk??!0,o=n?t:Math.max(1,Math.min(t,4));return{totalMemBytes:r,autoCap:t,recommendedMaxWorkers:o,diskPath:e.diskPath??"/",diskGateOk:n,diskFreeBytes:e.diskFreeBytes??null}}var Ks=M(()=>{"use strict";en()});import{existsSync as Rm,mkdirSync as PS,readFileSync as vm,writeFileSync as AS}from"node:fs";import{homedir as IS}from"node:os";import bm from"node:path";function Vl(e){let r=new Map;for(let t of e.split(/\r?\n/)){let n=t.trim();if(!n||n.startsWith("#"))continue;let o=n.indexOf("=");if(o<=0)continue;let s=n.slice(0,o).trim(),i=n.slice(o+1).trim();(i.startsWith('"')&&i.endsWith('"')||i.startsWith("'")&&i.endsWith("'"))&&(i=i.slice(1,-1)),r.set(s,i)}return r}function OS(e,r=`# Managed by kynver cron install \u2014 safe to edit; re-run install to merge keys.
|
|
4
|
+
`):""}function yp(e){return e?dl(hp.resolve(e),"utf8"):""}function $r(e){Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,e)}function xr(e){return new Promise(r=>setTimeout(r,e))}function H(e){if(!e)return!1;try{return process.kill(e,0),!0}catch{return!1}}function Er(e,r){try{process.kill(-e,r)}catch{process.kill(e,r)}}function Rp(e){let r=null,t=-1/0;for(let n of e){if(!n)continue;let o=Date.parse(n);Number.isFinite(o)&&o>t&&(t=o,r=n)}return r}function pl(e){return Math.max(0,Math.round((Date.now()-e)/1e3))}var C=U(()=>{"use strict"});function ml(e){return Qb.has(e)?!0:Zb.some(r=>e.endsWith(r))}function vp(e){return Object.keys(e).filter(ml).sort()}function We(e){let r={...e};for(let t of Object.keys(r))ml(t)&&delete r[t];return r}function ev(e){let r=vp(e);return{forbiddenPresent:r,safe:r.length===0}}function Sp(e){return We(e)}var bp,Qb,Zb,jr=U(()=>{"use strict";bp=["ANTHROPIC_API_KEY","ANALYST_API_KEY","RECRUITER_API_KEY","AUTH_SECRET","NEXTAUTH_SECRET","DATABASE_URL","PRODUCTION_DATABASE_URL","KYNVER_PRODUCTION_DATABASE_URL","REDIS_URL","GOOGLE_CLIENT_SECRET","GITHUB_CLIENT_SECRET","KYNVER_API_KEY","KYNVER_SERVICE_SECRET","KYNVER_RUNTIME_SECRET","KYNVER_CRON_SECRET","OPENCLAW_CRON_SECRET","QSTASH_TOKEN","QSTASH_CURRENT_SIGNING_KEY","QSTASH_NEXT_SIGNING_KEY","TOOL_SECRETS_KEK","TOOL_EXECUTOR_DISPATCH_SECRET","CLOUDFLARE_API_TOKEN","STRIPE_SECRET_KEY","STRIPE_WEBHOOK_SECRET","STRIPE_IDENTITY_WEBHOOK_SECRET","VOYAGE_API_KEY","PERPLEXITY_API_KEY","FRED_API_KEY","FMP_API_KEY","CURSOR_API_KEY"],Qb=new Set(bp),Zb=["_SECRET","_API_KEY"]});import{spawnSync as wp}from"node:child_process";function me(e,r,t={}){let n=wp("git",r,pe({cwd:e,encoding:"utf8"}));if(n.status!==0&&!t.allowFailure){let o=`git ${r.join(" ")} failed: ${n.stderr||n.stdout}`;if(t.throwError)throw new Error(o);_r(o)}return n.stdout||""}function _p(e){me(e,["rev-parse","--show-toplevel"])}function jn(e){return me(e,["status","--short"],{allowFailure:!0}).split(`
|
|
5
|
+
`).map(r=>r.trim()).filter(Boolean)}function ne(e,r){try{let t=wp("git",r,pe({cwd:e,encoding:"utf8"}));return{status:t.status,stdout:t.stdout||"",stderr:t.stderr||"",error:t.error?t.error.message:null}}catch(t){return{status:null,stdout:"",stderr:"",error:t.message}}}function Cp(e,r,t){let n=ne(e,["merge-base","--is-ancestor",r,t]);return n.status===0?{isAncestor:!0,error:null}:n.status===1?{isAncestor:!1,error:null}:{isAncestor:null,error:n.error||n.stderr||n.stdout||`git exited ${n.status}`}}function Cs(e,r="origin/main"){let t=typeof r=="string"?{base:r}:r,n=t.baseCommit?.trim()||t.base?.trim()||"origin/main",o=t.baseCommit?.trim()||null;if(!e)return fl(n,"missing worktree path");let s=ne(e,["rev-parse","HEAD"]);if(s.status!==0)return fl(n,s.error||s.stderr||s.stdout||"failed to resolve HEAD");let i;if(o)i=o;else{let f=ne(e,["rev-parse",n]);if(f.status!==0)return fl(n,f.error||f.stderr||f.stdout||`failed to resolve ${n}`,s.stdout.trim());i=f.stdout.trim()}let a=s.stdout.trim();if(a===i)return{checked:!0,base:n,head:a,baseHead:i,baseIsAncestorOfHead:!0,headIsAncestorOfBase:!0,relation:"synced"};let l=Cp(e,i,a),c=Cp(e,a,i),u=l.error||c.error||void 0;if(l.isAncestor==null||c.isAncestor==null)return{checked:!1,base:n,head:a,baseHead:i,baseIsAncestorOfHead:l.isAncestor,headIsAncestorOfBase:c.isAncestor,relation:"unknown",...u?{error:u}:{}};let d=l.isAncestor?"ahead":c.isAncestor?"merged":"diverged";return{checked:!0,base:n,head:a,baseHead:i,baseIsAncestorOfHead:l.isAncestor,headIsAncestorOfBase:c.isAncestor,relation:d,...u?{error:u}:{}}}function fl(e,r,t=null){return{checked:!1,base:e,head:t,baseHead:null,baseIsAncestorOfHead:null,headIsAncestorOfBase:null,relation:"unknown",error:r}}var Pe=U(()=>{"use strict";C();jr()});import{homedir as gl}from"node:os";import Vr from"node:path";function xp(e){return e==="~"?gl():e.startsWith("~/")||e.startsWith("~\\")?Vr.join(gl(),e.slice(2)):e}function Ht(e){return Vr.resolve(xp(e))}function Se(e){let r=xp(e),t=Vr.resolve(r),n=Vr.resolve(gl());return t===n?"~":t.startsWith(`${n}${Vr.sep}`)?`~/${Vr.relative(n,t).split(Vr.sep).join("/")}`:t.replace(/\\/g,"/").replace(/^\/home\/[^/]+(?=\/|$)/,"~").replace(/^\/Users\/[^/]+(?=\/|$)/,"~").replace(/^[A-Za-z]:\/home\/[^/]+(?=\/|$)/i,"~").replace(/^[A-Za-z]:\/Users\/[^/]+(?=\/|$)/i,"~")}function q(e){return Se(e)}var Je=U(()=>{"use strict"});import{existsSync as yl,readFileSync as Ep}from"node:fs";import{homedir as rv}from"node:os";import lr from"node:path";import{fileURLToPath as tv}from"node:url";function ov(e){let r=lr.join(e,"package.json");if(!yl(r))return null;try{let t=JSON.parse(Ep(r,"utf8"));return typeof t.name=="string"?t.name.trim():null}catch{return null}}function Pp(e){return ov(e)==="kynver"}function kl(e){let r=lr.resolve(e);if(!yl(r))return null;let t=ne(r,["rev-parse","--show-toplevel"]);if(t.status!==0)return null;let n=t.stdout.trim();return n.length?lr.resolve(n):null}function sv(e=import.meta.url){let r=lr.dirname(tv(e));for(let t=0;t<8;t+=1){let n=lr.join(r,"package.json");if(yl(n))try{if(JSON.parse(Ep(n,"utf8")).name==="@kynver-app/runtime")return r}catch{}let o=lr.dirname(r);if(o===r)break;r=o}return null}function hl(e,r,t,n){if(!t)return;let o=lr.resolve(t);e.has(o)||Pp(o)&&(e.add(o),r.push({repo:o,source:n}))}function Rl(e){let r=e?.cwd??process.cwd(),t=new Set,n=[];hl(t,n,kl(r),"cwd_git");let o=sv(e?.runtimeModuleUrl??import.meta.url);o&&hl(t,n,kl(o),"runtime_checkout");let s=rv();for(let i of nv)hl(t,n,Ht(lr.join(s,i)),"well_known_path");return n}function Gr(e){return Rl(e)[0]??null}function Ap(e){let r=lr.resolve(e).replace(/\\/g,"/");return r.includes("/.kynver/harness/worktrees/")||r.includes("/.openclaw/harness/worktrees/")||r.includes("/kynver-harness/")||r.includes("/openclaw/harness/worktrees/")}function Vn(e){let r=Rl(e);return r.find(n=>!Ap(n.repo))??r[0]??null}var nv,Gn=U(()=>{"use strict";Pe();Je();nv=["Kynver","repos/Kynver","repos/kynver-source-main","code/Kynver","projects/Kynver"]});function Kt(e){let r=(e??"").trim().toLowerCase();return r==="ghost"||r==="forge"?r:r.includes("forge")?"forge":r.includes("ghost")||r.includes("openclaw")?"ghost":"forge"}function Np(e,r){return e[r]?.trim()||null}function Ae(e=process.env,r={}){let t=[],n=r.boxKind?.trim();if(n)return{boxKind:Kt(n),source:"config",slugInferenceBlocked:!1,warnings:t};let o=Np(e,"KYNVER_BOX_KIND");if(o)return{boxKind:Kt(o),source:"env",slugInferenceBlocked:!1,warnings:t};let s=Np(e,"KYNVER_AGENT_OS_SLUG");return s&&t.push(`KYNVER_AGENT_OS_SLUG=${s} is a workspace slug, not box identity \u2014 set boxKind via \`kynver setup --box-kind forge|ghost\` or KYNVER_BOX_KIND (defaulting box kind to forge)`),{boxKind:"forge",source:"default",slugInferenceBlocked:!!s,warnings:t}}function qe(e={},r=process.env){return Ae(r,e).boxKind}var Ie=U(()=>{"use strict"});function Al(e,r){return e==="forge"?4:Math.max(1,r)}function cr(e,r){return e==="forge"?Math.min(Math.max(1,r),4):Math.max(1,r)}function $t(e,r){return e==="forge"&&r>4}var qn=U(()=>{"use strict"});import{readFileSync as wv}from"node:fs";import Tp from"node:os";function jt(e){if(e!==void 0){let r=e.match(/^MemAvailable:\s+(\d+)\s*kB/m);return r?Number(r[1])*1024:Tp.freemem()}if(process.platform==="linux")try{let t=wv("/proc/meminfo","utf8").match(/^MemAvailable:\s+(\d+)\s*kB/m);if(t)return Number(t[1])*1024}catch{}return Tp.freemem()}var Es=U(()=>{"use strict"});import{existsSync as _v,readFileSync as xv,statfsSync as Ev}from"node:fs";function Ps(){if(process.platform!=="linux")return!1;for(let e of["/proc/sys/kernel/osrelease","/proc/version"])try{if(!_v(e))continue;let r=xv(e,"utf8");if(/microsoft|wsl/i.test(r))return!0}catch{}return!1}function Ol(e={}){if(!(e.forceWsl===void 0?Ps():e.forceWsl))return null;let t=e.wslHostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.wslHostFreeWarnBytes??Dp,o=e.wslHostFreeCriticalBytes??Mp,s=e.statfs??Ev,i;try{i=s(t)}catch(h){return{ok:!1,path:t,freeBytes:0,totalBytes:0,usedPercent:100,warnBelowBytes:n,criticalBelowBytes:o,reason:`Windows host disk probe failed at ${t}: ${h.message}`,probeError:h.message}}let a=Number(i.bavail)*Number(i.bsize),l=Number(i.blocks)*Number(i.bsize),c=l>0?(l-a)/l*100:100,u=a<n,d=a<o,f=!u&&!d,p=(a/(1024*1024*1024)).toFixed(1),m=null;return f||(m=`Windows host disk ${t} at ${d?"critical":"warning"}: ${p} GiB free (<${(d?o:n)/1024/1024/1024} GiB); WSL VHDX cannot grow safely. ${Up()}`),{ok:f,path:t,freeBytes:a,totalBytes:l,usedPercent:c,warnBelowBytes:n,criticalBelowBytes:o,reason:m,probeError:null}}function Up(){return"Recovery: 1) free Windows C: (empty Recycle Bin / Storage Sense / clear %TEMP% and %LOCALAPPDATA%\\Temp\\wsl-crashes); 2) shut down WSL (`wsl --shutdown`) then compact the VHDX (`Optimize-VHD` or `diskpart compact vdisk`); 3) clear local node_modules / .next / harness worktrees before restarting workers; 4) disable recurring dumps via `%USERPROFILE%/.wslconfig` (`maxCrashDumpCount=-1`) or `kynver wsl-crashes --execute`. Full runbook: docs/runbooks/wsl-disk-pressure.md."}var Dp,Mp,Jr,As=U(()=>{"use strict";Dp=25*1024*1024*1024,Mp=12*1024*1024*1024,Jr="/mnt/c"});import{execFileSync as Wp}from"node:child_process";import{existsSync as Is,readFileSync as Lp,readdirSync as Pv,statSync as Av}from"node:fs";import Il from"node:path";function Os(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)?n:r}function Nl(){let e=process.env.KYNVER_WSL_WIN_USER?.trim();if(e)return e;try{let n=Wp("cmd.exe",["/c","echo","%USERNAME%"],{encoding:"utf8",timeout:5e3,stdio:["ignore","pipe","ignore"]}).trim();if(n&&n!=="%USERNAME%"&&!n.includes("%"))return n}catch{}let r=process.env.USER?.trim()||process.env.LOGNAME?.trim(),t=process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr;return r&&Is(Il.join(t,"Users",r))?r:null}function Fp(e={}){let r=e.crashDumpDir?.trim()||process.env.KYNVER_WSL_CRASH_DUMP_DIR?.trim();if(r)return r;let t=e.hostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.windowsUser??Nl();return n?`${t.replace(/\\/g,"/").replace(/\/$/,"")}/Users/${n}/AppData/Local/Temp/wsl-crashes`:null}function Kp(e){let r=/^wsl-crash-\d+-(\d+)-(.+)-(\d+)\.dmp$/i.exec(e);if(!r)return{executableHint:null,signal:null,pid:null};let t=Number(r[1]),n=r[2]??"",o=Number(r[3]),s=n.split("_").filter(Boolean);return{executableHint:s.length>0?s[s.length-1]:null,signal:Number.isFinite(o)?o:null,pid:Number.isFinite(t)?t:null}}function $p(){try{if(Is("/proc/sys/kernel/core_pattern"))return Lp("/proc/sys/kernel/core_pattern","utf8").trim()}catch{}try{return Wp("sysctl",["-n","kernel.core_pattern"],{encoding:"utf8",timeout:2e3,stdio:["ignore","pipe","ignore"]}).trim()||null}catch{return null}}function Nv(e){return!!(e&&/wsl-capture-crash/i.test(e))}function jp(e,r=Jr){let t=Il.join(r,"Users",e,".wslconfig");if(!Is(t))return{maxCrashDumpCount:null,crashDumpFolder:null};let n;try{n=Lp(t,"utf8")}catch{return null}let o=null,s=null;for(let i of n.split(/\r?\n/)){let a=i.replace(/#.*$/,"").trim();if(!a||a.startsWith("["))continue;let l=a.indexOf("=");if(l<0)continue;let c=a.slice(0,l).trim().toLowerCase(),u=a.slice(l+1).trim();if(c==="maxcrashdumpcount"){let d=Number(u);o=Number.isFinite(d)?d:null}else c==="crashdumpfolder"&&(s=u.replace(/^["']|["']$/g,"")||null)}return{maxCrashDumpCount:o,crashDumpFolder:s}}function Tv(e){if(!Is(e))return[];let r=Pv(e,{withFileTypes:!0}),t=[];for(let n of r){if(!n.isFile()||!n.name.toLowerCase().endsWith(".dmp"))continue;let o=Il.join(e,n.name);try{let s=Av(o),i=Kp(n.name);t.push({name:n.name,path:o,bytes:s.size,mtimeMs:s.mtimeMs,executableHint:i.executableHint,signal:i.signal,pid:i.pid})}catch{}}return t.sort((n,o)=>o.mtimeMs-n.mtimeMs),t}function ur(e={}){if(!(e.forceWsl===void 0?Ps():e.forceWsl))return null;let t=e.hostMount?.trim()||process.env.KYNVER_WSL_HOST_MOUNT?.trim()||Jr,n=e.windowsUser??Nl(),o=e.warnBelowBytes??Os("KYNVER_WSL_CRASH_DUMP_WARN_BYTES",Bp),s=e.criticalBelowBytes??Os("KYNVER_WSL_CRASH_DUMP_CRITICAL_BYTES",Hp),i=e.warnCount??Os("KYNVER_WSL_CRASH_DUMP_WARN_COUNT",Ov),a=e.criticalCount??Os("KYNVER_WSL_CRASH_DUMP_CRITICAL_COUNT",Iv),l=(e.readCorePattern??$p)(),c=Nv(l),u=null;n&&(u=(e.readWslConfig??jp)(n,t));let d=u?.maxCrashDumpCount??null,f=d===-1,p=Fp({hostMount:t,windowsUser:n,crashDumpDir:e.crashDumpDir});if(!p)return{ok:!0,path:null,windowsUser:n,dumpCount:0,totalBytes:0,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:[],executables:[],corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:f,reason:null,probeError:"windows_user_unresolved"};let m;try{m=(e.listDumps??Tv)(p)}catch(F){return{ok:!1,path:p,windowsUser:n,dumpCount:0,totalBytes:0,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:[],executables:[],corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:f,reason:`WSL crash dump probe failed at ${p}: ${F.message}`,probeError:F.message}}let h=m.reduce((F,O)=>F+O.bytes,0),k=m.length,g=[...new Set(m.map(F=>F.executableHint).filter(F=>!!F))],y=h>=s,_=h>=o,x=k>=a,E=k>=i,Y=!(y||x||_||E),$=null;if(!Y){let F=y||x?"critical":"warning",O=(h/1024**3).toFixed(1),B=g.length>0?g.join(", "):"unknown";$=`WSL crash dumps ${F}: ${k} file(s), ${O} GiB at ${p} (executables: ${B}). `+Vp({wslCaptureEnabled:c,dumpsDisabledInWslConfig:f})}return{ok:Y,path:p,windowsUser:n,dumpCount:k,totalBytes:h,warnBelowBytes:o,criticalBelowBytes:s,warnCount:i,criticalCount:a,dumps:m,executables:g,corePattern:l,wslCaptureEnabled:c,maxCrashDumpCount:d,dumpsDisabledInWslConfig:f,reason:$,probeError:null}}function Vp(e={}){let r=["Recovery:","1) run `kynver wsl-crashes --execute` or scripts/cleanup-wsl-crashes.ps1 to prune old .dmp files;"];return e.dumpsDisabledInWslConfig||r.push("2) add `[wsl2]\\nmaxCrashDumpCount=-1` to %USERPROFILE%/.wslconfig then `wsl --shutdown` to disable future dumps;"),e.wslCaptureEnabled&&r.push("3) investigate crashing executables (node OOM/SIGBUS often follows Windows C: pressure \u2014 see docs/runbooks/wsl-disk-pressure.md);"),r.push("full runbook: docs/runbooks/wsl-disk-pressure.md."),r.join(" ")}var Bp,Hp,Ov,Iv,Vt=U(()=>{"use strict";As();Bp=5*1024*1024*1024,Hp=10*1024*1024*1024,Ov=2,Iv=4});import{statfsSync as Dv}from"node:fs";function Le(e={}){let r=e.diskPath?.trim()||"/",t=e.diskFreeWarnBytes??Mv,n=e.diskFreeCriticalBytes??Uv,o=e.diskMaxUsedPercent??Wv,s=e.diskHardMaxUsedPercent??Lv,i=Dv(r),a=Number(i.bavail)*Number(i.bsize),l=Number(i.blocks)*Number(i.bsize),c=l>0?(l-a)/l*100:100,u=a<t,d=a<n,f=a<t*2,p=f&&c>o,m=f&&c>s,h=!u&&!d&&!p&&!m,k=e.skipWslHostCheck?null:Ol(e.wslHost),g=e.skipWslCrashDumpCheck?null:ur(e.wslCrashDumps),y=h&&(k?k.ok:!0)&&(g?g.ok:!0),_=null;return y||(_=[d?`free space below critical ${n} bytes`:null,u?`free space below warning ${t} bytes`:null,m?`used percent above hard cap ${s}%`:null,p?`used percent above cap ${o}%`:null,k&&!k.ok?k.reason:null,g&&!g.ok?g.reason:null].filter(Boolean).join("; ")),Bv({ok:y,path:r,freeBytes:a,totalBytes:l,usedPercent:c,warnBelowBytes:t,criticalBelowBytes:n,maxUsedPercent:o,hardMaxUsedPercent:s,reason:_,wslHost:k,wslCrashDumps:g?{ok:g.ok,path:g.path,dumpCount:g.dumpCount,totalBytes:g.totalBytes,executables:g.executables,wslCaptureEnabled:g.wslCaptureEnabled,dumpsDisabledInWslConfig:g.dumpsDisabledInWslConfig,reason:g.reason,probeError:g.probeError}:null})}function Bv(e){let r=process.env.KYNVER_DISPATCH_DISK_GATE_FORCE?.trim().toLowerCase();return r?r==="ok"||r==="open"||r==="none"?e.ok?e:{...e,ok:!0,reason:`disk gate forced open by KYNVER_DISPATCH_DISK_GATE_FORCE (suppressed: ${e.reason??"no reason"})`}:r==="block"||r==="pressured"?{...e,ok:!1,reason:`disk gate forced closed by KYNVER_DISPATCH_DISK_GATE_FORCE${e.reason?` (underlying: ${e.reason})`:""}`}:e:e}var Mv,Uv,Wv,Lv,Gt=U(()=>{"use strict";Vt();As();Mv=30*1024*1024*1024,Uv=15*1024*1024*1024,Wv=80,Lv=90});import{existsSync as Gp}from"node:fs";import{homedir as Jp}from"node:os";import Pr from"node:path";function le(e){let r=Pr.resolve(Ht(e.trim()));for(;Hv.has(Pr.basename(r));)r=Pr.dirname(r);return r}function fe(){let e=process.env.KYNVER_HARNESS_ROOT||process.env.OPUS_HARNESS_ROOT;if(e)return le(e);let r=R().harnessRoot?.trim();if(r)return le(r);let t=Pr.join(Jp(),".kynver","harness");return Gp(t)?t:Gp(Yp)?Yp:t}function ge(e){return Pr.join(le(e),"runs")}function dr(e){return Pr.join(le(e),"worktrees")}function qr(){let e=fe();return{harnessRoot:e,runsDir:ge(e),worktreesDir:dr(e)}}function Yt(e,r){return Pr.join(e,v(r))}var Yp,Hv,Ce=U(()=>{"use strict";N();Je();C();Yp=Pr.join(Jp(),".openclaw","harness"),Hv=new Set(["runs","worktrees"])});import{existsSync as Fv,readdirSync as Kv,statSync as $v}from"node:fs";import Jt from"node:path";function Z(){return qr()}function L(e){let{runsDir:r}=Z();return w(Jt.join(Yt(r,v(e)),"run.json"))}function X(){let{runsDir:e}=Z();return qp(e)}function Ns(e){return qp(ge(e))}function jv(e){try{return $v(e).isDirectory()}catch{return!1}}function qp(e){if(!Fv(e))return[];let r=[];for(let t of Kv(e,{withFileTypes:!0})){if(t.name==="runs")continue;let n=Jt.join(e,t.name);if(!jv(n))continue;let o=w(Jt.join(n,"run.json"),void 0);o?.id&&r.push(o)}return r}function he(e,r){let{runsDir:t}=Z();return w(Jt.join(Yt(t,v(e)),"workers",v(r),"worker.json"))}function Be(e){let{runsDir:r}=Z();ae(Jt.join(Yt(r,e.id),"run.json"),e)}function K(e,r){let{runsDir:t}=Z();ae(Jt.join(Yt(t,e),"workers",r.name,"worker.json"),r)}function P(e){let{harnessRoot:r}=Z();return zn(r,e)}function zn(e,r){return Yt(ge(e),v(r))}var D=U(()=>{"use strict";Ce();C()});import{existsSync as Vv,readdirSync as Gv}from"node:fs";import Yv from"node:path";function ke(e){let r=new Set;for(let n of Object.keys(e.workers||{}))r.add(v(n));let t=Yv.join(P(e.id),"workers");if(!Vv(t))return[...r];for(let n of Gv(t,{withFileTypes:!0}))n.isDirectory()&&r.add(v(n.name));return[...r]}var zr=U(()=>{"use strict";D();C()});function Tl(e){let r=e.trim();if(!r.startsWith("{"))return null;try{let t=JSON.parse(r);if(t&&typeof t=="object"&&!Array.isArray(t))return t}catch{return null}return null}function zp(e){let r=e.trim();if(!r)return null;let t=Tl(r);if(t)return t;let n=[],o=/```(?:json)?\s*([\s\S]*?)```/gi,s;for(;(s=o.exec(r))!==null;){let l=Tl(s[1]??"");l&&n.push(l)}let i=r.indexOf("{"),a=r.lastIndexOf("}");if(i>=0&&a>i){let l=Tl(r.slice(i,a+1));l&&n.push(l)}return n.length>0?n[n.length-1]:null}function Xp(e){let r=e.finalResult??e.final_result;if(r!=null)return typeof r=="string"?zp(r)??(r.trim()||null):r;let t=typeof e.summary=="string"?e.summary.trim():"";if(!t)return null;let n=zp(t);return n||t}var Qp=U(()=>{"use strict"});import{existsSync as Jv,readFileSync as qv}from"node:fs";function Dl(e){return e==="complete"}function ze(e){return Dl(e.lastHeartbeatPhase)?e.terminalFinalResult!==void 0&&e.terminalFinalResult!==null?e.terminalFinalResult:e.lastHeartbeatSummary?.trim()||"completed":null}function ce(e){let r={heartbeatCount:0,lastHeartbeatAt:null,lastHeartbeatPhase:null,lastHeartbeatSummary:null,terminalFinalResult:null,heartbeatBlocker:null,timestampAnomalies:[],lastBoxResourceSnapshot:null,lastPrEvidence:[]};if(!Jv(e))return r;let t=Date.now()+zv,n=new Date(t).toISOString(),o=qv(e,"utf8").split(`
|
|
6
|
+
`).filter(Boolean);for(let s of o){let i=Bt(s);if(!i||typeof i!="object"||Array.isArray(i))continue;let a=i;if(r.heartbeatCount++,a.ts){let l=String(a.ts),c=Date.parse(l);Number.isFinite(c)&&c>t?r.timestampAnomalies.push({kind:"future_heartbeat_timestamp",observedAt:l,clampedTo:n}):r.lastHeartbeatAt=l}a.phase!==void 0&&a.phase!==null&&(r.lastHeartbeatPhase=String(a.phase)),a.summary!==void 0&&a.summary!==null&&(r.lastHeartbeatSummary=String(a.summary)),Dl(r.lastHeartbeatPhase)&&(r.terminalFinalResult=Xp(a)),r.heartbeatBlocker=a.blocker?String(a.blocker):null,a.boxResourceSnapshot&&typeof a.boxResourceSnapshot=="object"&&!Array.isArray(a.boxResourceSnapshot)&&(r.lastBoxResourceSnapshot=a.boxResourceSnapshot),Array.isArray(a.prEvidence)&&(r.lastPrEvidence=a.prEvidence.filter(l=>!!l&&typeof l=="object"&&typeof l.prUrl=="string"))}return r}var zv,pr=U(()=>{"use strict";Qp();C();zv=6e4});function Qv(e){return e?(e.split("/").pop()??e).replace(/\.exe$/i,"").toLowerCase():null}function Zv(e){if(!e)return[];let r=[],t="",n,o=!1;for(let s of e){if(o){t+=s,o=!1;continue}if(s==="\\"){o=!0;continue}if(n){s===n?n=void 0:t+=s;continue}if(s==='"'||s==="'"){n=s;continue}if(/\s/.test(s)){t&&(r.push(t),t="");continue}t+=s}return t&&r.push(t),r}function eS(e){let r=Qv(e[0]);return!!(r&&Xv.has(r))}function Ts(e){return!e||e.includes("/")||e.includes("*")?!1:/\.(?:json|md|mjs|cjs|js|ts|tsx|yaml|yml)$/iu.test(e)}function Ds(e){if(!e)return!1;let r=e.trim();return r.startsWith("!")&&!r.includes("/")&&!r.endsWith("/**")}function rS(e){if(!e.startsWith("--glob="))return e;let r=e.slice(7);return r.startsWith("!")&&!r.includes("/")&&!r.endsWith("/**")?`--glob=${r}/**`:e}function tS(e){let r=[];for(let t=1;t<e.length;t+=1){let n=e[t];if(n){if(n==="--"){r.push(...e.slice(t+1));break}if(n.startsWith("-")){if(n.includes("="))continue;Zp.has(n)&&(t+=1);continue}r.push(n)}}return r}function em(e){let r=!1,t=e.map((o,s)=>{let i=rS(o),a=e[s-1];return a&&Zp.has(a)&&o.startsWith("!")&&!o.includes("/")&&!o.endsWith("/**")&&(i=`${o}/**`),i!==o&&(r=!0),i}),n=tS(t);if(n.length===2){let[o,s]=n;if(Ds(s))return{argv:[t[0]??"rg",o,"-g",`${s}/**`,"."],changed:!0};if(Ts(s))return{argv:[t[0]??"rg","-g",s,o,"."],changed:!0}}return r&&n.length===1?{argv:[...t,"."],changed:!0}:{argv:t,changed:r}}function Ms(e){let r=e.trim();if(!r)return{command:r,changed:!1};let t=r.includes("&&")?" && ":r.includes("||")?" || ":"; ",n=r.split(/\s*(?:&&|\|\||;)\s*/u),o=!1,s=n.map(i=>{let a=Zv(i.trim());if(!a.length||!eS(a))return i;let l=em(a);return l.changed?(o=!0,l.argv.join(" ")):i});return o?{command:s.join(t),changed:!0}:{command:r,changed:!1}}function Ml(e){if(!e)return{};let r=e.match(/search\s+"(.+)"\s+in\s+([^()]+?)(?:\s*\(|$)/iu);if(r)return{pattern:r[1],target:r[2]?.trim()};let t=e.match(/^search\s+"(.+)"\s+in\s+(.+)$/iu);return t?{pattern:t[1],target:t[2]?.trim()}:{}}function rm(e){let{pattern:r,target:t}=Ml(e);return r?Ds(t)?{kind:"rg_exclude_syntax",pattern:r,target:t}:Ts(t)?{kind:"bad_scope",pattern:r,target:t}:{kind:"not_repo_search",pattern:r,target:t}:{kind:"not_repo_search"}}function tm(e){let{pattern:r,target:t}=Ml(e);if(!r)return null;if(Ds(t)){let n=`${t.trim()}/**`;return{command:`rg "${r}" -g '${n}' .`,changed:!0}}return t&&Ts(t)?{command:`rg -g ${t} "${r}" .`,changed:!0}:null}function nm(e){if(e.kind==="bad_scope"&&e.pattern?.includes("agent-os-land-pr")&&e.target==="package.json")return"Search package.json with a glob from the repo root: `rg -g package.json agent-os-land-pr .` \u2014 or run `node scripts/agent-os-land-pr.mjs <pr-url>` directly.";if(e.kind==="bad_scope"&&e.pattern&&e.target)return`Use \`rg -g '${e.target}' ${e.pattern} .\` from the repo root instead of treating ${e.target} as a folder.`;if(e.kind==="rg_exclude_syntax"&&e.pattern){let r=e.target?`${e.target.trim()}/**`:"!node_modules/**";return`Repo search scope \`${e.target??"!node_modules"}\` is not a valid ripgrep path. Use \`rg "${e.pattern}" -g '${r}' .\` from the repo root (exclude globs need a \`/**\` suffix).`}return e.kind==="no_matches"&&e.pattern?`No matches for "${e.pattern}". Try a broader pattern, drop overly short tokens, or search from the repo root with \`rg "${e.pattern}" .\`.`:null}function om(e){let r=e.match(/search\s+"(.+)"\s+in\s+([^()]+?)(?:\s*\(agent\)|\s*failed|$)/iu);return r?`search "${r[1]}" in ${r[2]?.trim()}`:null}function Us(e){let r=e.meta?.trim()||(e.command?om(e.command):null)||null;if(r){let t=rm(r),n=nm(t);if(n)return n;let o=tm(r);if(o?.changed)return`Repo search used an invalid scope. Retry with: \`${o.command}\`.`}if(e.command&&/\b(rg|ripgrep)\b/i.test(e.command)){let t=Ms(e.command);if(t.changed)return`Ripgrep scope may be invalid. Retry with: \`${t.command}\`.`;if(e.exitCode===1)return"Ripgrep returned no matches (exit 1). Try a broader pattern or search from the repo root."}return null}var Xv,Zp,Ul=U(()=>{"use strict";Xv=new Set(["rg","ripgrep","grep"]),Zp=new Set(["-e","--regexp","-f","--file","-m","--max-count","-A","--after-context","-B","--before-context","-C","--context","-g","--glob","--iglob"])});function Xn(e,r=200){let t=e.replace(/\s+/g," ").trim();return t.length>r?`${t.slice(0,r-1)}\u2026`:t}function iS(e){let r=e.trim();if(!r)return null;if(r.startsWith("{"))try{return JSON.parse(r)}catch{}let t=r.indexOf("{"),n=r.lastIndexOf("}");if(t>=0&&n>t)try{return JSON.parse(r.slice(t,n+1))}catch{return null}return null}function Qn(e){return!!e&&typeof e=="object"&&!Array.isArray(e)}function sm(e){let r=e.metadata;if(!Qn(r))return null;let t=r.vulnerabilities;if(!Qn(t))return null;let n=s=>typeof t[s]=="number"?t[s]:0,o={info:n("info"),low:n("low"),moderate:n("moderate"),high:n("high"),critical:n("critical"),total:n("total")};return typeof t.total!="number"&&!o.critical&&!o.high&&!o.moderate&&!o.low&&!o.info?null:o}function aS(e){let r=[];e.critical&&r.push(`${e.critical} critical`),e.high&&r.push(`${e.high} high`),e.moderate&&r.push(`${e.moderate} moderate`),e.low&&r.push(`${e.low} low`),e.info&&r.push(`${e.info} info`);let t=r.length?r.join(", "):"see report";return`npm audit: ${e.total} vulnerabilit${e.total===1?"y":"ies"} (${t}) \u2014 remediation required`}function lS(e,r){let t=e.error;if(Qn(t)){let s=typeof t.summary=="string"?t.summary.trim():"",i=typeof t.code=="string"?t.code.trim():"";if(s)return i?`${i}: ${s}`:s;if(i)return i}let n=typeof e.message=="string"?e.message.trim():"";if(n)return n;let o=r.trim();return o?Xn(o.split(`
|
|
7
|
+
`).find(Boolean)??o,160):"npm audit failed"}function im(e){let r=`${e.stdout}
|
|
8
|
+
${e.stderr}`.trim(),t=iS(r);if(!t||!Qn(t)){let o=Xn(r||`exit ${e.exitCode}`,180);return{kind:"command_failure",exitCode:e.exitCode,summary:`npm audit failed (invalid or missing JSON): ${o}`,parseError:"invalid_json"}}if(Qn(t.error))return{kind:"command_failure",exitCode:e.exitCode,summary:`npm audit command failed: ${lS(t,e.stderr)}`};let n=sm(t);return n?e.exitCode===0&&n.total===0?{kind:"success",exitCode:0,summary:"npm audit: no vulnerabilities reported",audit:n}:{kind:"audit_findings",exitCode:e.exitCode,summary:aS(n),audit:n}:{kind:"command_failure",exitCode:e.exitCode,summary:"npm audit failed: JSON response missing vulnerability metadata",parseError:"missing_metadata"}}function cS(e){return nS.test(e)}function uS(e){return oS.test(e)}function dS(e){let r=Us({command:e.command,exitCode:e.exitCode});if(e.exitCode===0)return{kind:"success",exitCode:0,summary:"ripgrep finished (exit 0)"};if(e.exitCode===1){let n=(e.stderr||e.interleaved).trim();if(n&&sS.test(n)){let i=Xn(n,160);return{kind:"command_failure",exitCode:1,summary:r??`ripgrep failed (exit 1): ${i}`}}let o=Ms(e.command),s=o.changed&&!r?` Retry with: \`${o.command}\`.`:"";return{kind:"search_no_matches",exitCode:1,summary:r??`ripgrep: no matches (exit 1).${s} Try a broader pattern or search from the repo root.`}}let t=Xn(e.interleaved||e.stdout||e.stderr||`exit ${e.exitCode}`,180);return{kind:"command_failure",exitCode:e.exitCode,summary:r??`ripgrep failed (exit ${e.exitCode}): ${t}`}}function Ws(e){let r=e.stdout??"",t=e.stderr??"",n=e.interleavedOutput??"";if(cS(e.command)){let i=r.trim()||n.trim()||t.trim();return im({exitCode:e.exitCode,stdout:i,stderr:t})}if(uS(e.command))return dS({command:e.command,exitCode:e.exitCode,stdout:r,stderr:t,interleaved:n});let o=Us({command:e.command,exitCode:e.exitCode});if(o&&e.exitCode!==0)return{kind:"command_failure",exitCode:e.exitCode,summary:o};if(e.exitCode===0)return{kind:"success",exitCode:0,summary:"command succeeded (exit 0)"};let s=Xn(n||r||t||`exit ${e.exitCode}`,180);return{kind:"command_failure",exitCode:e.exitCode,summary:`command failed (exit ${e.exitCode}): ${s}`}}var nS,oS,sS,Wl=U(()=>{"use strict";Ul();nS=/\bnpm\s+audit\b/i,oS=/\b(rg|ripgrep)\b/i,sS=/\b(error|invalid|unknown|panic|not found)\b/i});import{existsSync as pS,readFileSync as mS}from"node:fs";function fS(e){let r=e.timestamp_ms;return e.timestamp||e.ts||(r?new Date(r).toISOString():void 0)}function am(e){if(!e)return null;for(let r of Object.keys(e))if(r.endsWith("ToolCall")){let t=r.slice(0,-8);return t.length?t:r}return null}function gS(e,r){e.finalResult=r.result||r.subtype||r.terminal_reason||"completed",r.is_error&&(e.error=String(r.result||r.api_error_status||"stream result error"))}function lm(e){if(e.type!=="tool_call"||e.subtype!=="completed")return null;let t=(e.tool_call&&typeof e.tool_call=="object"&&!Array.isArray(e.tool_call)?e.tool_call:null)?.shellToolCall;if(!t||typeof t!="object"||Array.isArray(t))return null;let n=t,o=n.args,s=o&&typeof o=="object"&&!Array.isArray(o)&&typeof o.command=="string"?String(o.command):"",i=n.result;if(!i||typeof i!="object"||Array.isArray(i))return null;let a=i.success??i.failure;if(!a||typeof a!="object"||Array.isArray(a))return null;let l=a,c=typeof l.exitCode=="number"?l.exitCode:0;return{command:s,exitCode:c,stdout:typeof l.stdout=="string"?l.stdout:"",stderr:typeof l.stderr=="string"?l.stderr:"",interleaved:typeof l.interleavedOutput=="string"?l.interleavedOutput:""}}function hS(e,r){r.kind==="success"||r.kind==="search_no_matches"||(e.lastShellOutcome=r)}function Ar(e){let r={firstEventAt:null,lastEventAt:null,currentTool:null,finalResult:null,error:null,lastShellOutcome:null};if(!pS(e))return r;let t=mS(e,"utf8").split(`
|
|
9
|
+
`).filter(Boolean);for(let n of t){let o=Bt(n);if(!o)continue;let s=fS(o);if(s&&(r.firstEventAt||=s,r.lastEventAt=s),o.type==="stream_event"&&o.event&&typeof o.event=="object"&&o.event.type==="content_block_start"){let a=o.event.content_block;a?.type==="tool_use"&&(r.currentTool=String(a.name||"tool"))}if(o.type==="assistant"&&o.message&&typeof o.message=="object"){let a=o.message.content;if(Array.isArray(a)){let l=a.find(c=>c?.type==="tool_use");l&&(r.currentTool=String(l.name||r.currentTool))}}if(o.type==="tool_call"&&o.subtype==="started"){let a=o.tool_call&&typeof o.tool_call=="object"&&!Array.isArray(o.tool_call)?o.tool_call:void 0,l=am(a);l&&(r.currentTool=l)}let i=lm(o);i&&hS(r,Ws({command:i.command,exitCode:i.exitCode,stdout:i.stdout,stderr:i.stderr,interleavedOutput:i.interleaved})),o.type==="result"&&gS(r,o)}return r}function kS(e){return Ar(e)}function cm(e){let r=lm(e);if(!r)return;let t=Ws({command:r.command,exitCode:r.exitCode,stdout:r.stdout,stderr:r.stderr,interleavedOutput:r.interleaved}),n=Rs(r.command).slice(0,120);return t.kind==="audit_findings"?`[audit:findings] ${t.summary}${n?` \xB7 ${n}`:""}`:t.kind==="search_no_matches"?`[search:no_matches] ${t.summary}${n?` \xB7 ${n}`:""}`:t.kind==="command_failure"?`[command:failed] ${t.summary}${n?` \xB7 ${n}`:""}`:`[command:ok] exit 0${n?` \xB7 ${n}`:""}`}function Ll(e){if(e.type==="system"&&e.subtype)return`[system:${e.subtype}] ${String(e.status||e.cwd||"")}`.trim();if(e.type==="stream_event"&&e.event&&typeof e.event=="object"){let r=e.event.type;if(r==="content_block_start"){let t=e.event.content_block;if(t?.type==="tool_use")return`[tool:start] ${t.name}`}if(r==="content_block_delta"){let t=e.event.delta;if(t?.partial_json)return`[tool:input] ${t.partial_json}`}return r==="message_stop"?"[message:stop]":r?`[stream:${r}]`:void 0}if(e.type==="assistant"&&e.message&&typeof e.message=="object"){let r=e.message.content;if(Array.isArray(r)){let t=r.find(o=>o?.type==="text");if(t)return`[assistant] ${Rs(String(t.text||""))}`;let n=r.find(o=>o?.type==="tool_use");if(n)return`[tool] ${n.name} ${JSON.stringify(n.input||{})}`}}if(e.type==="user"&&e.tool_use_result){let r=e.tool_use_result;return`[tool:result] stdout=${JSON.stringify(r.stdout||"")} stderr=${JSON.stringify(r.stderr||"")}`}if(e.type==="tool_call"){let r=String(e.subtype||""),t=r==="completed"?cm(e):void 0;if(t)return t;let n=e.tool_call&&typeof e.tool_call=="object"&&!Array.isArray(e.tool_call)?e.tool_call:void 0,o=am(n)??"tool";return`[tool:${r}] ${o}`}if(e.type==="result")return`[result] ${e.subtype||""} ${Rs(String(e.result||""))}`.trim()}var qt=U(()=>{"use strict";Wl();C()});function RS(e,r=240){let t=e.replace(/\s+/g," ").trim();return t.length>r?`${t.slice(0,r-1)}\u2026`:t}function Ls(e){let r=(e??"").trim();if(!r)return null;for(let t of yS)if(t.test.test(r))return{blocked:!0,reason:`${t.label}: ${RS(r)}`};return null}var yS,Bl=U(()=>{"use strict";yS=[{test:/\b(?:invalid|unknown|unsupported|unrecognized)\b[^.\n]*\bmodel\b/i,label:"provider rejected the requested model"},{test:/\bmodel\b[^.\n]*\b(?:not\s+(?:found|supported|available|recognized|valid)|is\s+not\s+valid|does\s+not\s+exist)/i,label:"provider rejected the requested model"},{test:/\b(?:did you mean|available models|choose (?:a|one of)|supported models)\b/i,label:"provider rejected the requested model"},{test:/model preflight failed/i,label:"model/provider preflight failed"},{test:/\b(?:command not found|ENOENT|is the .*CLI on PATH|executable not found|no such file or directory)\b/i,label:"provider CLI is missing or not on PATH"},{test:/\bfailed to spawn\b/i,label:"provider failed to spawn the worker process"},{test:/\b(?:not logged in|unauthorized|authentication (?:failed|required)|invalid api key|missing api key|401)\b/i,label:"provider authentication failed"}]});function um(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function bS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function vS(e){return!e?.checked||e.headIsAncestorOfBase!==!1?null:um(e.head)}function SS(e,r,t){let n=["exited_with_changes_salvage"];if((e==="uncommitted"||e==="both")&&n.push(`${r} uncommitted change${r===1?"":"s"} with no final result`),(e==="committed_ahead"||e==="both")&&t){let o=t.length>12?t.slice(0,12):t;n.push(`commit ${o} ahead of base with no final result`)}return n.push("review worktree \u2014 commit, open a PR, or run a salvage worker before discarding"),n.join(": ")}function Xr(e){if(e.alive||bS(e.finalResult))return null;let r=(e.changedFiles??[]).filter(i=>i.trim()).length,t=um(e.headCommit)??vS(e.gitAncestry),n=r>0,o=!!t;if(!n&&!o)return{kind:"none",salvageable:!1,uncommittedCount:0,headCommit:null,attentionReason:"process exited without a final result"};let s=n&&o?"both":n?"uncommitted":"committed_ahead";return{kind:s,salvageable:!0,uncommittedCount:r,headCommit:t,attentionReason:SS(s,r,t)}}var Zn=U(()=>{"use strict"});function eo(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function CS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function wS(e){if(eo(e.headCommit)||eo(e.prUrl)||eo(e.artifactBundlePath)||eo(e.patchPath))return!0;let r=e.gitAncestry;return!!(r?.checked&&r.headIsAncestorOfBase===!1&&eo(r.head))}function Qr(e){return CS(e.finalResult)?e.changedFiles.length===0?{blocked:!1}:wS(e)?{blocked:!0,detail:`Worktree has ${e.changedFiles.length} uncommitted change(s); commit or discard before landing`}:{blocked:!0,reason:"dirty_worktree_no_pr",detail:`Worktree has ${e.changedFiles.length} uncommitted change(s) with no commit or PR; commit, open a PR, or discard before landing`}:{blocked:!1}}function dm(e){if(e.blocked)return e.detail??e.reason??"dirty_worktree_no_pr"}var ro=U(()=>{"use strict"});function Hl(e){let r=e.trim();if(!r.startsWith("{"))return null;try{let t=JSON.parse(r);if(t&&typeof t=="object"&&!Array.isArray(t))return t}catch{return null}return null}function pm(e){let r=e.targetPrReconciliation??e.target_pr_reconciliation??e.targetPrs??e.target_prs;return Array.isArray(r)?r.length:0}function zt(e){let r=e.trim();if(!r)return null;let t=Hl(r);if(t)return t;let n=[],o=/```(?:json)?\s*([\s\S]*?)```/gi,s;for(;(s=o.exec(r))!==null;){let u=Hl(s[1]??"");u&&n.push(u)}let i=r.indexOf("{"),a=r.lastIndexOf("}");if(i>=0&&a>i){let u=Hl(r.slice(i,a+1));u&&n.push(u)}if(n.length===0)return null;let l=n[n.length-1],c=pm(l);for(let u of n){let d=pm(u);d>c&&(l=u,c=d)}return l}var Bs=U(()=>{"use strict"});function mm(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:e.trim()||null}function fm(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`${r[1].toLowerCase()}/pull/${r[2]}`:e.trim().toLowerCase()}function _S(e){return new Set(e.map(r=>fm(mm(r)??r)).filter(Boolean))}function gm(e,r,t){let n=mm(e)??e;if(!n)return"unrelated";let o=fm(n);return _S(r).has(o)?"contract":t?(t.outcome==="skipped"||t.outcome==="blocked")&&t.reason?.trim()?"support":(t.outcome==="merged","unrelated"):"unrelated"}var hm=U(()=>{"use strict"});function Xt(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function xS(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="object"?Object.keys(e).length>0:!0}function Zr(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:Xt(e)}function Hs(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`${r[1].toLowerCase()}/pull/${r[2]}`:e.trim().toLowerCase()}function km(e){let r=null;if(typeof e=="string"){let o=zt(e);o&&(r=o)}else e&&typeof e=="object"&&!Array.isArray(e)&&(r=e);if(!r)return[];let t=r.targetPrReconciliation??r.target_pr_reconciliation;if(!Array.isArray(t))return[];let n=[];for(let o of t){if(!o||typeof o!="object"||Array.isArray(o))continue;let s=o,i=Zr(String(s.prUrl??s.pr_url??"")),a=Xt(s.outcome);!i||a!=="merged"&&a!=="skipped"&&a!=="blocked"||n.push({prUrl:i,outcome:a,mergeCommit:Xt(s.mergeCommit??s.merge_commit),reason:Xt(s.reason)})}return n}function ym(e,r){let t=[],n=Zr(Xt(e.prUrl)??"");if(n&&t.push(n),r&&typeof r=="object"&&!Array.isArray(r)){let o=r,s=Zr(String(o.prUrl??o.pr_url??""));s&&t.push(s)}return[...new Set(t)]}function Fl(e){let{contract:r,snapshot:t}=e,n=e.finalResult??t.finalResult;if(!r.landingOnly&&r.targetPrUrls.length===0&&!r.repairEnforceOriginalPr)return{blocked:!1};if(!xS(n))return(r.requiresTargetPrReconciliation??(r.landingOnly||!!r.repairEnforceOriginalPr||r.targetPrUrls.length>0))&&r.targetPrUrls.length>0?{blocked:!0,reason:"missing_target_pr_reconciliation",detail:`Final result required to reconcile target PR(s): ${r.targetPrUrls.join(", ")}`}:{blocked:!1};if(!(r.requiresTargetPrReconciliation??(r.landingOnly||!!r.repairEnforceOriginalPr||r.targetPrUrls.length>0))&&!r.repairEnforceOriginalPr)return{blocked:!1};let s=r.repairEnforceOriginalPr?Zr(Xt(r.targetPrUrl)??"")??(r.targetPrUrls.length===1?Zr(r.targetPrUrls[0]):null):null;if(s){let d=ym(t,n);if(!(n&&typeof n=="object"&&!Array.isArray(n)&&n.supersedesOriginalTargetPr===!0)){for(let h of d)if(h!==s)return{blocked:!0,reason:"duplicate_repair_pr",detail:`Repair worker opened or attached PR ${h} instead of canonical target ${s}`}}let m=km(n).find(h=>h.prUrl===s);if(!m||m.outcome!=="merged"&&!(m.reason?.trim()&&(m.outcome==="skipped"||m.outcome==="blocked")))return{blocked:!0,reason:"missing_repair_target_reconciliation",detail:`Repair worker must reconcile target PR ${s}`}}let i=km(n),a=new Map(i.map(d=>[Hs(d.prUrl),d])),l=new Set(r.targetPrUrls.map(d=>Hs(Zr(d)??d)).filter(Boolean)),c=ym(t,n);if(r.landingOnly)for(let d of c){let f=a.get(Hs(d)),p=gm(d,r.targetPrUrls,f);if(!(p==="contract"||p==="support"))return l.size>0?{blocked:!0,reason:"unrelated_implementation_pr",detail:`Landing-only worker attached unrelated PR ${d}`}:{blocked:!0,reason:"unrelated_implementation_pr",detail:"Landing-only worker must not open new implementation PRs"}}if(r.targetPrUrls.length===0)return{blocked:!1};let u=[];for(let d of r.targetPrUrls){let f=Hs(Zr(d)??d),p=a.get(f);if(!p){u.push(f);continue}p.outcome!=="merged"&&!p.reason?.trim()&&u.push(f)}return u.length>0?{blocked:!0,reason:u.every(d=>a.has(d))?"incomplete_target_pr_landing":"missing_target_pr_reconciliation",detail:`Target PR reconciliation incomplete: ${u.join(", ")}`}:{blocked:!1}}function Kl(e){if(e.blocked)return e.detail??e.reason}var $l=U(()=>{"use strict";Bs();hm()});function Rm(e){let r=Date.now();if(e.completionBlocker&&!bm(e.completionBlocker))return{state:"blocked",reason:e.completionBlocker};if(e.finalResult){if(e.localOnly&&AS(e.finalResult))return{state:"done",reason:"local-only worker superseded by merged PR"};let o={finalResult:e.finalResult,changedFiles:e.changedFiles??[],gitAncestry:e.gitAncestry??null,prUrl:e.prUrl??null},s=Qr(o);if(s.blocked){let i=dm(s);return{state:"needs_attention",reason:s.reason?`landing blocked (${s.reason}): ${i}`:`landing blocked: ${i}`}}if(e.landingContract){let i=Fl({contract:e.landingContract,snapshot:o,finalResult:e.finalResult}),a=Kl(i);if(a)return{state:"needs_attention",reason:i.reason?`landing contract (${i.reason}): ${a}`:`landing contract: ${a}`}}return{state:"done",reason:"final result recorded"}}if(!e.alive){if(PS(e))return{state:"done",reason:"empty abandoned worker record"};let o=Ls(e.error);if(o)return{state:"blocked",reason:o.reason};let s=Xr({alive:!1,finalResult:null,changedFiles:e.changedFiles,gitAncestry:e.gitAncestry});if(s?.salvageable){let a=e.error?.trim();return{state:"needs_attention",reason:a?`${s.attentionReason} (${a})`:s.attentionReason}}let i=e.error?.trim();return{state:"needs_attention",reason:i?`process exited without a final result: ${i}`:s?.attentionReason??"process exited without a final result"}}if(e.heartbeatBlocker)return{state:"blocked",reason:`worker heartbeat reported blocker: ${e.heartbeatBlocker}`};let t=e.startedAt?Date.parse(e.startedAt):NaN;if(!e.firstEventAt&&e.stdoutBytes===0&&e.heartbeatBytes===0&&Number.isFinite(t)&&r-t>ES)return{state:"needs_attention",reason:`no first stream event ${pl(t)}s after start`};let n=e.lastActivityAt?Date.parse(e.lastActivityAt):NaN;return Number.isFinite(n)&&r-n>Qt?{state:"stale",reason:`no log/event/heartbeat activity for ${pl(n)}s`}:{state:"ok",reason:"recent activity"}}function bm(e){let r=e?.trim();return r?/completion acknowledged but board not advanced/i.test(r)&&/task already terminal/i.test(r):!1}function PS(e){return e.finalResult||e.taskId||e.agentOsId||e.stdoutBytes>0||(e.stderrBytes??0)>0||e.heartbeatBytes>0||e.error?.trim()||(e.changedFiles??[]).some(r=>r.trim())?!1:/empty worker dir|marked abandoned/i.test(e.reconcileReason??"")}function AS(e){let r=null;if(typeof e=="string"?r=zt(e):e&&typeof e=="object"&&!Array.isArray(e)&&(r=e),!r)return!1;let t=r.targetPrReconciliation??r.target_pr_reconciliation;return Array.isArray(t)?t.some(n=>!n||typeof n!="object"||Array.isArray(n)?!1:String(n.outcome??"").trim()==="merged"):!1}function OS(e,r,t){let n=e.completionSnapshot?.finalResult;return e.completionAckSource==="local-pr-merged-reconcile"&&n!==void 0&&n!==null?n:r||(n??ze(t))}function M(e,r={}){let t=Ar(e.stdoutPath),n=ce(e.heartbeatPath),o=typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim().length>0,s=OS(e,t.finalResult,n),i=o?!1:H(e.pid),a=bs(e.stdoutPath),l=bs(e.stderrPath),c=bs(e.heartbeatPath),u=jn(e.worktreePath),d=Cs(e.worktreePath,{base:r.base,baseCommit:r.baseCommit}),f=Rp([t.lastEventAt,n.lastHeartbeatAt,vs(e.stdoutPath),vs(e.stderrPath),vs(e.heartbeatPath)]),p=t.error||!i&&!s&&Ss(e.stderrPath,10).trim()||void 0,m=typeof e.completionBlocker=="string"&&e.completionBlocker.trim()?e.completionBlocker.trim():null,h=bm(m)?null:m,k=e.repairTargetPrUrl?{landingOnly:!1,targetPrUrls:[e.repairTargetPrUrl],targetPrUrl:e.repairTargetPrUrl,repairEnforceOriginalPr:!0}:null,g=Rm({alive:i,finalResult:s,firstEventAt:t.firstEventAt,stdoutBytes:a,stderrBytes:l,heartbeatBytes:c,lastActivityAt:f,heartbeatBlocker:n.heartbeatBlocker,startedAt:e.startedAt,error:p,changedFiles:u,gitAncestry:d,completionBlocker:h,landingContract:k,prUrl:e.repairTargetPrUrl??e.taskPrUrl??null,localOnly:e.localOnly===!0,taskId:e.taskId??null,agentOsId:e.agentOsId??null,reconcileReason:e.reconcileReason??null}),y=h||g.state==="blocked"?"blocked":o||g.state==="done"?"done":s?"exited":i?"running":"exited";return{runId:e.runId,worker:e.name,pid:e.pid,alive:i,status:y,attention:g,branch:e.branch,worktreePath:e.worktreePath,ownedPaths:e.ownedPaths,stdoutBytes:a,stderrBytes:l,heartbeatBytes:c,firstEventAt:t.firstEventAt,lastEventAt:t.lastEventAt,lastActivityAt:f,currentTool:o?null:t.currentTool,heartbeatCount:n.heartbeatCount,lastHeartbeatAt:n.lastHeartbeatAt,lastHeartbeatPhase:n.lastHeartbeatPhase,lastHeartbeatSummary:n.lastHeartbeatSummary,heartbeatBlocker:n.heartbeatBlocker,timestampAnomalies:n.timestampAnomalies,finalResult:s,error:p,changedFiles:u,gitAncestry:d,instructionPolicyFingerprint:e.instructionPolicyFingerprint??null,instructionPolicyEvidence:e.instructionPolicyEvidence??null,model:e.model??e.orchestrationAudit?.model??null,provider:e.orchestrationAudit?.provider??null,boxKind:e.boxKind??null,boxId:e.boxId??null,runtimeId:e.runtimeId??null,personaSlug:e.personaSlug??null,dispatched:e.dispatched??null,localOnly:e.localOnly??null}}function oe(e){return!!(e.finalResult||e.alive===!1||e.status==="exited"||e.status==="done")}function et(e){return e.finalResult?e.attention.state==="needs_attention"||e.attention.state==="blocked":!1}function Zt(e,r){return r.length===0?e:r.some(t=>t.attention==="needs_attention"||t.attention==="stale"||t.attention==="blocked")?"needs_attention":r.every(t=>t.status==="done")?"done":r.some(t=>t.status==="running")?"running":e}var ES,Qt,z=U(()=>{"use strict";pr();qt();Bl();Zn();Pe();ro();$l();Bs();C();ES=18e4,Qt=6e5});import{readFileSync as IS}from"node:fs";function NS(e){if(!e||process.platform!=="linux")return null;try{return IS(`/proc/${e}/cmdline`,"utf8").replace(/\0/g," ")}catch{return null}}function Fs(e){if(!e.pid||process.platform!=="linux")return!0;let r=NS(e.pid);return r?[e.worktreePath,e.workerDir,e.heartbeatPath].filter(n=>typeof n=="string"&&n.trim().length>0).some(n=>r.includes(n)):!1}function rt(e){if(typeof e.completionBlocker=="string"&&e.completionBlocker.trim())return!1;let r=M(e);return r.alive&&!Fs(e)?!1:r.alive&&!r.finalResult&&r.attention.state!=="done"}var en=U(()=>{"use strict";z()});import Sm from"node:os";import TS from"node:path";function vm(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function DS(e=R(),r,t){let n=vm(e.perWorkerMemBytes,to),o=vm(e.memReserveBytes,no),s=Math.min(1,Math.max(.1,Number(e.memUtilization)>0?Number(e.memUtilization):oo)),i=$s({config:e,configuredMaxWorkersOverride:r,totalMemBytes:t??Sm.totalmem()});return{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s,configuredMaxWorkers:i.configuredMaxWorkers,autoCap:i.autoCap,workerCapSource:i.workerCapSource}}function jl(e,r={}){let t=r.perWorkerMemBytes??to,n=r.memReserveBytes??no,o=r.memUtilization??oo,s=Math.max(0,Math.floor(e*o)-n),i=Math.max(1,Math.floor(s/t));return Math.min(i,Ks)}function MS(){return jt()}function US(e){let r=0;for(let t of ke(e)){let n=w(TS.join(P(e.id),"workers",v(t),"worker.json"),void 0);!n||!rt(n)||r++}return r}function WS(){let e=0;for(let r of X())e+=US(r);return e}function mr(e){let r=e.config??R(),t=e.totalMemBytes??Sm.totalmem(),{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s,configuredMaxWorkers:i,autoCap:a,workerCapSource:l}=DS(r,e.configuredMaxWorkersOverride,t),c=qe(r),u=e.freeMemBytes??MS(),d=e.activeWorkers??WS(),f=Math.max(0,Math.floor(t*s)-o),p=Math.max(0,Math.floor(f/n)),m=Math.max(0,Math.floor(Math.max(0,u-o)/n)),h=a,k=cr(c,i??h),g=Math.max(0,Math.min(k,p)),y=Math.max(0,g-d),x=Math.min(y,m),A=e.skipDiskGate||process.env.KYNVER_RESOURCE_GATE_SKIP_DISK==="1"?void 0:Le({diskPath:e.diskPath?.trim()||process.env.KYNVER_DISK_GUARD_PATH?.trim()||"/"});A&&!A.ok&&(x=0);let Y=null;return x<=0&&(A&&!A.ok?Y=A.reason??"disk gate blocked worker admission":d>=g?Y=`at worker limit (${d}/${g} running)`:m<=0?Y="insufficient free memory \u2014 waiting for workers to finish":Y="no worker slots available"),{ok:x>0,totalMemBytes:t,freeMemBytes:u,memReserveBytes:o,perWorkerMemBytes:n,configuredMaxWorkers:i,workerCapSource:l,boxKind:c,autoCap:h,capacityWorkers:p,maxConcurrentWorkers:g,activeWorkers:d,slotsAvailable:x,reason:Y,...A?{diskGate:A}:{}}}var to,no,oo,Ks,rn=U(()=>{"use strict";Es();N();Ie();qn();js();Gt();D();zr();en();C();to=500*1024*1024,no=4*1024*1024*1024,oo=.85,Ks=64});function tt(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function $s(e){let r=e.config??{},t=e.env??process.env,n=tt(r.perWorkerMemBytes,to),o=tt(r.memReserveBytes,no),s=Math.min(1,Math.max(.1,Number(r.memUtilization)>0?Number(r.memUtilization):oo)),i=jl(e.totalMemBytes,{perWorkerMemBytes:n,memReserveBytes:o,memUtilization:s});if(e.configuredMaxWorkersOverride!==void 0&&e.configuredMaxWorkersOverride!==null)return{configuredMaxWorkers:tt(e.configuredMaxWorkersOverride,i),autoCap:i,workerCapSource:"workspace_override"};if(r.maxConcurrentWorkers!==void 0&&r.maxConcurrentWorkers!==null){let c=tt(r.maxConcurrentWorkers,0)||null;if(c)return{configuredMaxWorkers:Math.min(c,Ks),autoCap:i,workerCapSource:"config"}}let l=(t.KYNVER_MAX_WORKERS_INTENTIONAL==="1"||t.KYNVER_MAX_WORKERS_INTENTIONAL==="true")&&t.KYNVER_MAX_WORKERS&&tt(t.KYNVER_MAX_WORKERS,0)||null;return l?{configuredMaxWorkers:Math.min(l,Ks),autoCap:i,workerCapSource:"env"}:{configuredMaxWorkers:null,autoCap:i,workerCapSource:"auto"}}function Vl(e={}){let r=e.totalMemBytes??0,t=jl(r,{perWorkerMemBytes:tt(e.config?.perWorkerMemBytes,to),memReserveBytes:tt(e.config?.memReserveBytes,no),memUtilization:e.config?.memUtilization&&Number(e.config.memUtilization)>0?Number(e.config.memUtilization):oo}),n=e.diskGateOk??!0,o=n?t:Math.max(1,Math.min(t,4));return{totalMemBytes:r,autoCap:t,recommendedMaxWorkers:o,diskPath:e.diskPath??"/",diskGateOk:n,diskFreeBytes:e.diskFreeBytes??null}}var js=U(()=>{"use strict";rn()});import{existsSync as Cm,mkdirSync as LS,readFileSync as wm,writeFileSync as BS}from"node:fs";import{homedir as HS}from"node:os";import _m from"node:path";function Gl(e){let r=new Map;for(let t of e.split(/\r?\n/)){let n=t.trim();if(!n||n.startsWith("#"))continue;let o=n.indexOf("=");if(o<=0)continue;let s=n.slice(0,o).trim(),i=n.slice(o+1).trim();(i.startsWith('"')&&i.endsWith('"')||i.startsWith("'")&&i.endsWith("'"))&&(i=i.slice(1,-1)),r.set(s,i)}return r}function FS(e,r=`# Managed by kynver cron install \u2014 safe to edit; re-run install to merge keys.
|
|
10
10
|
`){let t=[r.trimEnd(),""];for(let[n,o]of[...e.entries()].sort(([s],[i])=>s.localeCompare(i))){let s=o.includes(" ")||o.includes("#")||o.includes('"')?`"${o.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}"`:o;t.push(`${n}=${s}`)}return t.push(""),t.join(`
|
|
11
|
-
`)}function
|
|
12
|
-
`)}function
|
|
13
|
-
`,{mode:384})}function
|
|
14
|
-
`,{mode:384})}function se(){return process.env.KYNVER_API_KEY?process.env.KYNVER_API_KEY:mo().apiKey}function uo(e){Wm({...mo(),apiKey:e})}function Nm(e){let r=process.env.KYNVER_RUNNER_TOKEN?.trim();if(r)return r;let t=mo();if(t.runnerToken&&!(e&&t.runnerTokenAgentOsId&&t.runnerTokenAgentOsId!==e))return t.runnerToken}function nt(e,r){Wm({...mo(),runnerToken:r,runnerTokenAgentOsId:e})}function V(e){let r=fo(e);return r||go("requires --base-url, KYNVER_API_URL, KYNVER_CRON_FIRE_BASE_URL, or ~/.kynver/config.json apiBaseUrl"),r}function ec(e){return fo(e)}function fo(e){let r=e||process.env.KYNVER_API_URL||process.env.KYNVER_CRON_FIRE_BASE_URL||process.env.OPENCLAW_CRON_FIRE_BASE_URL||y().apiBaseUrl;return r?ar(String(r)):void 0}function Lm(e,r){let t=e||Nm(r)||(r?void 0:Nm(y().agentOsId));if(t)return String(t);let n=process.env.KYNVER_RUNTIME_SECRET||process.env.KYNVER_CRON_SECRET||process.env.OPENCLAW_CRON_SECRET;if(n)return console.warn("[kynver] using deployment-level callback secret; run `kynver runner credential --agent-os-id <id>` for a scoped token"),String(n)}function rC(e,r){let t=Lm(e,r);if(t)return t;go("requires --secret, KYNVER_RUNNER_TOKEN, a scoped runner token (`kynver runner credential`), ~/.kynver/credentials runnerToken, KYNVER_API_KEY with an API base URL to mint one, or (legacy) KYNVER_RUNTIME_SECRET / KYNVER_CRON_SECRET / OPENCLAW_CRON_SECRET")}async function ri(e,r,t){let n=Lm(e,r);if(n)return{ok:!0,secret:n};let o=se(),s=fo(t?.baseUrl);if(o&&r&&s)try{let i=await ot(r,{baseUrl:s,apiKey:o});return nt(r,i),{ok:!0,secret:i}}catch(i){return{ok:!1,reason:`runner credential mint failed: ${i.message}`}}return{ok:!1,reason:"no runner credential: requires --secret, KYNVER_RUNNER_TOKEN, a scoped runner token (`kynver runner credential`), ~/.kynver/credentials runnerToken, or KYNVER_API_KEY + API base URL to mint one"}}async function J(e,r,t){let n=await ri(e,r,t);if(n.ok)return n.secret;go(n.reason)}async function Bm(e,r){let t=se(),n=fo(r?.baseUrl);if(!t||!e||!n)return null;try{let o=await ot(e,{baseUrl:n,apiKey:t});return nt(e,o),o}catch{return null}}async function Hm(e,r,t){let n=se(),o=fo(t?.baseUrl);if(!n)return{ok:!1,reason:"KYNVER_API_KEY is required to refresh a rejected runner token"};if(!r)return{ok:!1,reason:"agentOsId is required to refresh a rejected runner token"};if(!o)return{ok:!1,reason:"KYNVER_API_URL or --base-url is required to refresh a rejected runner token"};try{let s=await ot(r,{baseUrl:o,apiKey:n});return s&&s!==e?(nt(r,s),{ok:!0,token:s}):{ok:!1,reason:"runner credential refresh returned the rejected token"}}catch(s){return{ok:!1,reason:s.message}}}async function ot(e,r){let t=r?.apiKey||se();if(!t)throw new Error("API key required \u2014 run `kynver login` first");let o=`${V(r?.baseUrl)}/api/agent-os/by-id/${encodeURIComponent(e)}/runner-credentials`,s=await fetch(o,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t}`},body:JSON.stringify({})}),i=await s.text(),a=null;try{a=JSON.parse(i)}catch{a=null}if(!s.ok||!a?.token)throw new Error(`runner credential mint failed (${s.status}): ${a?.error??i.slice(0,200)}`);return a.token}async function Fm(e){let r=(e.agentOsId?String(e.agentOsId):y().agentOsId)||"";r||go("runner credential requires --agent-os-id or agentOsId in ~/.kynver/config.json");try{let t=await ot(r,{baseUrl:e.baseUrl?String(e.baseUrl):void 0});nt(r,t),console.log(JSON.stringify({ok:!0,agentOsId:r,credentialsPath:q(sn),tokenPrefix:`${t.slice(0,12)}\u2026`,note:"Scoped runner token saved; callbacks use X-Kynver-Runner-Token."},null,2))}catch(t){console.error(t instanceof Error?t.message:String(t)),process.exit(1)}}function go(e){console.error(e),process.exit(1)}function ho(e){let r={};for(let t=0;t<e.length;t++){let n=e[t];if(!n.startsWith("--"))continue;let o=n.slice(2).replace(/-([a-z])/g,(i,a)=>a.toUpperCase()),s=e[t+1];!s||s.startsWith("--")?r[o]=!0:(r[o]=s,t++)}return r}async function ti(e){let r=y(),t=Le({diskPath:typeof e.diskPath=="string"?e.diskPath:"/"}),n=jl({totalMemBytes:zS.totalmem(),diskPath:t.path,diskGateOk:t.ok,diskFreeBytes:t.freeBytes,config:r}),o=eC(r,e),s=Zl({...r,...ZS(r,e),...o,workerProvider:typeof e.provider=="string"?e.provider:r.workerProvider||"cursor",...e.chatOauth===!0?{chatUseClaudeOauth:!0}:{}});s.agentOsId&&!po(s.agentOsId).ok&&go(ei(s.agentOsId)),ue(s);let i=Ae(process.env,s),a=zs(s,e);a.configUpdated&&(s=y());let l,c=se(),u=s.agentOsId;if(c&&u)try{let d=await ot(u,{baseUrl:typeof e.apiBaseUrl=="string"?e.apiBaseUrl:s.apiBaseUrl,apiKey:c});nt(u,d),l="Scoped runner token minted and saved to ~/.kynver/credentials."}catch{l="Runner token not minted (server offline or master secret unset). Run `kynver runner credential` after deploy."}console.log(JSON.stringify({ok:!0,configPath:q(Qs),config:an(s),boxKind:s.boxKind,boxKindSource:i.source,workerCapRecommendation:n,daemonSupervision:{hostKind:a.policy.hostKind,owner:a.policy.owner,envFilePath:a.envFilePath},...i.warnings.length?{boxIdentityWarnings:i.warnings}:{},note:l??"boxKind and maxConcurrentWorkers persisted; override with --box-kind and --max-workers. Run `kynver login` + `kynver runner credential` for scoped callbacks."},null,2))}async function Km(e){let r=typeof e.apiKey=="string"?e.apiKey:process.env.KYNVER_API_KEY;if(r){uo(r),console.log(JSON.stringify({ok:!0,credentialsPath:q(sn)},null,2));return}let{runDeviceLogin:t}=await Promise.resolve().then(()=>(Xl(),Om));(await t(e)).ok||process.exit(1),console.log(JSON.stringify({ok:!0,credentialsPath:q(sn)},null,2))}var Zs,Qs,sn,XS,QS,fU,gU,I=M(()=>{"use strict";Vn();Je();C();Oe();Jn();Ks();Vt();co();Zs=Ql.join(JS(),".kynver"),Qs=Ql.join(Zs,"config.json"),sn=Ql.join(Zs,"credentials"),XS=/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i,QS=new Set(["aos","aos-1","agent-os-id","agentosid","agent_os_id","<agent-os-id>","<agentosid>","todo","changeme","change-me","placeholder"]);fU=500*1024*1024,gU=4*1024*1024*1024});import{existsSync as Dv,readFileSync as Mv}from"node:fs";import{dirname as cl,join as lp}from"node:path";import{fileURLToPath as ap}from"node:url";function Uv(e){let r=cl(ap(e));for(let t=0;t<6;t+=1){if(Dv(lp(r,"package.json")))return r;let n=cl(r);if(n===r)break;r=n}throw new Error(`package.json not found above ${cl(ap(e))}`)}function cp(e=import.meta.url){let r=lp(Uv(e),"package.json"),t=JSON.parse(Mv(r,"utf8"));if(typeof t.version!="string"||!t.version.trim())throw new Error(`Missing package.json version at ${r}`);return t.version}var Kn=cp();function Wv(e){return e.some(r=>r==="--version"||r==="-v")}function Lv(e,r){console.log(r?`${r} ${e}`:e),process.exit(0)}function up(e,r=import.meta.url,t){return Wv(e)?(Lv(cp(r),t),!0):!1}Vn();import{existsSync as xp,readFileSync as zv}from"node:fs";import Ss from"node:path";var vl={"@kynver-app/runtime":"0.1.83","@kynver-app/openclaw-agent-os":"0.1.43","@kynver-app/mcp-agent-os":"0.3.34"},bl=Object.keys(vl),Rl={"@kynver-app/runtime":"Kynver runtime","@kynver-app/openclaw-agent-os":"OpenClaw AgentOS plugin","@kynver-app/mcp-agent-os":"AgentOS MCP server"},Xv={"@kynver-app/runtime":"packages/kynver-runtime/package.json","@kynver-app/openclaw-agent-os":"packages/kynver-openclaw-agent-os/package.json","@kynver-app/mcp-agent-os":"packages/kynver-mcp-agent-os/package.json"};function Ep(e){let r=e.trim().split("-")[0]?.split("+")[0];if(!r)return null;let t=r.split(".");if(t.length<1||t.length>3)return null;let n=t.map(o=>Number.parseInt(o,10));if(n.some(o=>!Number.isFinite(o)||o<0))return null;for(;n.length<3;)n.push(0);return[n[0],n[1],n[2]]}function Yn(e,r){let t=Ep(e),n=Ep(r);if(!t||!n)return 0;for(let o=0;o<3;o+=1){if(t[o]>n[o])return 1;if(t[o]<n[o])return-1}return 0}function Sl(e,r){return Yn(e,r)>=0}function Qv(e){let r=null;for(let t of e)(!r||Yn(t,r)>0)&&(r=t);return r}function Zv(e){try{let r=JSON.parse(zv(e,"utf8"));return typeof r.version=="string"&&r.version.trim()?r.version.trim():null}catch{return null}}function eb(e,r){let t=[r,process.env.KYNVER_REPO,e].filter(o=>!!o?.trim());for(let o of t){let s=Ss.resolve(o);if(xp(Ss.join(s,"packages/kynver-runtime/package.json"))&&xp(Ss.join(s,"package.json")))return s}return Gr({cwd:e})?.repo??null}function Cl(e={}){let r=e.cwd??process.cwd(),t=eb(r,e.repoRoot);if(!t)return{};let n={};for(let o of bl){let s=Ss.join(t,Xv[o]),i=Zv(s);i&&(n[o]={version:i,source:"repo",path:s})}return n}function rb(e){return e==="@kynver-app/runtime"?["npm run kynver:build","npm run kynver"]:[`npm run build -w ${e}`]}function tb(e){let{packageName:r,minimumVersion:t,effectiveVersion:n,effectiveSource:o,repoVersion:s}=e,i=[];return s&&Sl(s,t)?(i.push(`Use the monorepo checkout (${s}) instead of a stale npm install: ${rb(r).join("; ")}.`),i.push("Do not publish npm packages or wait on an operator release."),i):(n?i.push(`Upgrade ${r} from ${n} to >= ${t} (npm install -g ${r}@latest or align OpenClaw npm prefix).`):i.push(`Install ${r} >= ${t} before running memory-heavy AgentOS paths.`),r==="@kynver-app/runtime"&&i.push("Repo-source alternative: npm run kynver:build && npm run kynver"),o==="installed"&&s&&i.push(`Repo checkout reports ${s}; rebuild/link repo source if you develop from the monorepo.`),i)}function nb(e){if(e.length===0)return{version:null,source:"unknown"};let r=Qv(e.map(n=>n.version));if(!r)return{version:null,source:"unknown"};let t=e.find(n=>n.version===r)??e[0];return{version:t.version,source:t.source}}function Cs(e={}){let r=(i,a)=>i?typeof i=="string"?{version:i,source:a}:i:null,t=bl.map(i=>{let a=vl[i],l=[],c=r(e.installed?.[i],"installed"),u=r(e.repo?.[i],"repo"),d=r(e.self?.[i],"self");c&&l.push(c),u&&l.push(u),d&&l.push(d);let{version:m,source:p}=nb(l),f=u?.version??null,h=m?Sl(m,a):!1,k=h?[]:tb({packageName:i,minimumVersion:a,effectiveVersion:m,effectiveSource:p,repoVersion:f}),g=h?`${Rl[i]} ${m} meets memory-cost minimum ${a} (${p}).`:`${Rl[i]} is below memory-cost minimum ${a}`+(m?` (effective ${m} via ${p})`:" (no version detected)")+".";return{packageName:i,displayName:Rl[i],minimumVersion:a,effectiveVersion:m,effectiveSource:p,ok:h,summary:g,remediation:k}}),n=t.filter(i=>!i.ok),o=n.length===0,s=o?"All managed AgentOS packages meet memory-cost minimum versions.":`Memory-cost package guard blocked ${n.length} stale package(s): ${n.map(i=>`${i.packageName} < ${i.minimumVersion}`).join("; ")}.`;return{ok:o,summary:s,packages:t}}var Gn=class extends Error{result;constructor(r){let t=[r.summary,...r.packages.filter(n=>!n.ok).flatMap(n=>[`- ${n.summary}`,...n.remediation.map(o=>` \u2192 ${o}`)])];super(t.join(`
|
|
15
|
-
`)),this.name="MemoryCostPackageVersionGuardError",this.result=r}};function
|
|
11
|
+
`)}function tn(e=we){return Cm(e)?Gl(wm(e,"utf8")):new Map}function Vs(e,r={}){let t=r.filePath??we,n=Cm(t)?wm(t,"utf8"):"",o=Gl(n),s=[],i=[];for(let u of r.removeKeys??[])o.delete(u)&&i.push(u);for(let[u,d]of Object.entries(e)){if(d===void 0)continue;let f=o.get(u);o.set(u,d),f!==d&&s.push(u)}let a=Gl(n),l=a.size!==o.size;if(!l){for(let[u,d]of o)if(a.get(u)!==d){l=!0;break}}let c=FS(o);return l&&(LS(_m.dirname(t),{recursive:!0}),BS(t,c,{mode:384})),{path:t,changed:l,keysWritten:s,keysRemoved:i}}var we,Or=U(()=>{"use strict";we=_m.join(HS(),".kynver",".env")});var Yl,so=U(()=>{"use strict";Yl="1.5G"});import{spawnSync as KS}from"node:child_process";function nn(){return process.env.KYNVER_BUILD_SKIP_SYSTEMD==="1"||process.env.KYNVER_BUILD_SKIP_SYSTEMD==="true"?!1:io!==void 0?io:process.platform!=="linux"?(io=!1,!1):(io=KS("systemd-run",["--version"],{encoding:"utf8",stdio:["ignore","ignore","pipe"]}).status===0,io)}function Gs(e){let r=e.memoryMax??process.env.KYNVER_BUILD_SYSTEMD_MEMORY_MAX??Yl,t=e.memorySwapMax??process.env.KYNVER_BUILD_SYSTEMD_MEMORY_SWAP_MAX??"2G",n=["systemd-run","--scope","--collect","-p",`MemoryMax=${r}`,"-p",`MemorySwapMax=${t}`];return e.cwd&&n.push("--working-directory",e.cwd),n.push("--",...e.command),n}var io,Ys=U(()=>{"use strict";so()});import{realpathSync as $S}from"node:fs";function on(e=process.argv[1]){let r=process.env.KYNVER_BIN?.trim();if(r)return r;let t=e?.trim();if(!t)return"kynver";try{return $S.native(t)}catch{return t}}function Em(e){return/\s/.test(e)?`"${e.replace(/"/g,'\\"')}"`:e}var Js=U(()=>{"use strict"});import{existsSync as jS,mkdirSync as VS,writeFileSync as GS}from"node:fs";import{homedir as YS}from"node:os";import Am from"node:path";import{spawnSync as Pm}from"node:child_process";function JS(){return Am.join(YS(),".config","systemd","user")}function qS(e){let r=Em(e.kynverBin?.trim()||on());return["[Unit]","Description=Kynver AgentOS daemon (keeper-supervised pipeline + cron tick)","After=network-online.target","","[Service]","Type=simple",`EnvironmentFile=${e.envFilePath}`,`ExecStart=${r} daemon --run ${e.runId} --agent-os-id ${e.agentOsId} --execute`,"Restart=always","RestartSec=10","","[Install]","WantedBy=default.target",""].join(`
|
|
12
|
+
`)}function qs(e,r){if(!nn())return{supported:!1,unitPath:null,written:!1,enabled:!1,started:!1,note:process.platform==="linux"?"systemd-run not available \u2014 install user service manually or run `kynver daemon` under your supervisor.":"systemd user units are only supported on Linux; use `kynver daemon` manually on macOS/Windows."};let t=JS(),n=Am.join(t,ao),o=qS(e);if(!r)return{supported:!0,unitPath:n,written:!1,enabled:!1,started:!1,note:"Dry-run \u2014 pass --execute to write and enable the user unit."};VS(t,{recursive:!0});let s=jS(n);GS(n,o,"utf8");let i=Pm("systemctl",["--user","daemon-reload"],{encoding:"utf8"});if(i.status!==0)return{supported:!0,unitPath:n,written:!0,enabled:!1,started:!1,note:`Wrote ${n} but systemctl --user daemon-reload failed: ${i.stderr||i.stdout}`};let a=Pm("systemctl",["--user","enable","--now",ao],{encoding:"utf8"});return{supported:!0,unitPath:n,written:!s||!0,enabled:a.status===0,started:a.status===0,note:a.status===0?`Enabled and started ${ao}`:`Wrote ${n} but enable failed: ${a.stderr||a.stdout}`}}var ao,zs=U(()=>{"use strict";Ys();Js();ao="kynver-cron-daemon.service"});import{existsSync as zS,readFileSync as XS}from"node:fs";function sn(){if(process.platform==="win32")return"win32";if(process.platform==="darwin")return"darwin";if(process.platform==="linux"){if(process.env.WSL_DISTRO_NAME?.trim())return"wsl";try{if(zS("/proc/version")){let e=XS("/proc/version","utf8");if(/microsoft/i.test(e))return"wsl"}}catch{}return"linux"}return"linux"}function lo(e){return e==="linux"}var co=U(()=>{"use strict"});function Om(e){return e===!0||e==="true"||e==="1"||e==="yes"||e==="on"}function QS(e){return"keeper"}function Im(e,r,t={}){if(Om(t.installSystemd)||Om(t["install-systemd"]))return lo(r)?"systemd":"keeper";let n=e.daemonSupervisionOwner;return n==="systemd"&&lo(r)?"systemd":n==="keeper"?"keeper":QS(r)}function ZS(){return{KYNVER_CRON_DAEMON_PRESENT:"1"}}function Jl(e,r){let t=["Daemon restart hardening is Kynver-owned: `kynver start` runs the in-process keeper by default (crash + heartbeat-stall respawn)."];return e==="linux"?t.push("For logout-surviving supervision on Linux: `kynver start --install-systemd` (or `kynver cron install --install-systemd`)."):e==="wsl"?t.push("WSL: run `kynver start` in a persistent tmux/screen session, or use Windows `start-tier2-wsl.ps1` which delegates to the keeper."):e==="darwin"?t.push("macOS: run `kynver start` under launchd or a terminal multiplexer for session survival."):e==="win32"&&t.push("Native Windows: prefer WSL (`kynver start` inside WSL). Native console daemon is blocked unless KYNVER_DAEMON_ALLOW_NATIVE_WINDOWS=1."),r==="systemd"&&t.push("This box is configured for systemd user-unit supervision (~/.config/systemd/user/kynver-cron-daemon.service)."),t}function ql(e,r={},t){let n=t??sn(),o=Im(e,n,r);return{hostKind:n,owner:o,envUpdates:ZS(),guidance:Jl(n,o)}}var Xs=U(()=>{"use strict";co()});import{existsSync as eC}from"node:fs";import Nm from"node:path";import{homedir as Tm}from"node:os";function rC(){return Nm.join(Tm(),".config","systemd","user",ao)}function zl(){return eC(rC())}function Qs(e,r={},t){let n=ql(e,r,t),o={};e.daemonSupervisionOwner||(o.daemonSupervisionOwner=n.owner);let s={...e,...o},i=!1;Object.keys(o).length>0&&(ue(s),i=!0);let a=Vs(n.envUpdates,{filePath:we});return{policy:n,configPath:q(Nm.join(Tm(),".kynver","config.json")),envFilePath:q(a.path),envChanged:a.changed,configUpdated:i}}function Zs(e,r){return e.daemonSupervisionOwner==="systemd"&&zl()?"systemd":e.daemonSupervisionOwner??"keeper"}var uo=U(()=>{"use strict";Or();Je();N();zs();Xs()});var Mm={};$b(Mm,{runDeviceLogin:()=>Xl});import Dm from"node:os";function tC(e){let r=(typeof e.apiBaseUrl=="string"?e.apiBaseUrl:void 0)||(typeof e.baseUrl=="string"?e.baseUrl:void 0)||process.env.KYNVER_API_URL||R().apiBaseUrl;return r?ar(String(r)):void 0}async function nC(e){await new Promise(r=>setTimeout(r,e))}async function Xl(e){let r=tC(e);if(!r)return console.error("kynver login (device flow) requires a Kynver URL \u2014 pass --api-base-url https://your-kynver-site, set KYNVER_API_URL, or run `kynver setup` first."),{ok:!1};let t=`${Dm.hostname()} (${Dm.platform()})`,n;try{let a=await fetch(`${r}/api/auth/device/code`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientName:t})});if(!a.ok)return console.error(`Could not start device authorization (${a.status}).`),{ok:!1};n=await a.json()}catch(a){return console.error(`Could not reach ${r}: ${a.message}`),{ok:!1}}let o=n.verification_uri_complete||n.verification_uri;console.log(""),console.log(" Authorize this machine:"),console.log(` 1. Open: ${o}`),console.log(` 2. Confirm the code: ${n.user_code}`),console.log(""),console.log(" Waiting for approval\u2026");let s=Date.now()+n.expires_in*1e3,i=Math.max(1,n.interval)*1e3;for(;Date.now()<s;){await nC(i);let a;try{a=await(await fetch(`${r}/api/auth/device/token`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({device_code:n.device_code})})).json().catch(()=>({}))}catch{continue}switch(a.status){case"approved":return a.api_key?(po(a.api_key),console.log(" Approved \u2014 this machine is now linked to your Kynver account."),{ok:!0,apiKey:a.api_key}):{ok:!1};case"slow_down":i+=2e3;break;case"authorization_pending":typeof a.interval=="number"&&(i=Math.max(i,a.interval*1e3));break;case"access_denied":return console.error(" Request was denied in the browser."),{ok:!1};case"expired_token":return console.error(" The code expired before it was approved. Run `kynver login` again."),{ok:!1};default:break}}return console.error(" Timed out waiting for approval. Run `kynver login` again."),{ok:!1}}var Ql=U(()=>{"use strict";N();C()});import{existsSync as Wm,mkdirSync as Lm,readFileSync as Bm,writeFileSync as Hm}from"node:fs";import{homedir as oC,totalmem as sC}from"node:os";import Zl from"node:path";import iC from"node:os";function mo(e){let r=String(e??"").trim();if(!r)return{ok:!1,reason:"missing"};let t=r.toLowerCase();return lC.has(t)?{ok:!1,value:r,reason:"placeholder"}:aC.test(r)?{ok:!0,value:r}:{ok:!1,value:r,reason:"not a UUID"}}function ti(e){let r=mo(e),t=r.value??String(e??"").trim(),n=t?`"${t}"`:"<empty>",o=r.reason==="placeholder"?"looks like a placeholder":r.reason??"is invalid";return[`Invalid AgentOS id ${n}: ${o}.`,"AgentOS ids are UUIDs from the AgentOS registry, not slugs or examples (for example, not `aos`).","Fix: run `kynver bootstrap` to relink this runner, or run `kynver setup --agent-os-id <uuid>` / pass `--agent-os-id <uuid>` after copying the id from Command Center.","If this came from stale ~/.kynver/config.json, remove or replace the agentOsId value before starting the daemon."].join(" ")}function R(){if(!Wm(ei))return{};try{return JSON.parse(Bm(ei,"utf8"))}catch{return{}}}function ue(e){Lm(ri,{recursive:!0}),Hm(ei,`${JSON.stringify(ec(e),null,2)}
|
|
13
|
+
`,{mode:384})}function ec(e){return{...e,...e.harnessRoot?.trim()?{harnessRoot:Se(e.harnessRoot.trim())}:{},...e.defaultRepo?.trim()?{defaultRepo:Se(e.defaultRepo.trim())}:{}}}function ln(e){return ec(e)}function cC(e,r){let t=fo(),n=(typeof r.apiBaseUrl=="string"?r.apiBaseUrl:void 0)||e.apiBaseUrl?.trim()||process.env.KYNVER_API_URL?.trim()||process.env.KYNVER_CRON_FIRE_BASE_URL?.trim()||process.env.OPENCLAW_CRON_FIRE_BASE_URL?.trim(),o=(typeof r.agentOsId=="string"?r.agentOsId:void 0)||e.agentOsId?.trim()||process.env.KYNVER_AGENT_OS_ID?.trim()||(t.runnerToken?.trim().startsWith("krc1.")?t.runnerTokenAgentOsId?.trim():void 0),i=(typeof r.repo=="string"?r.repo:r.discoverRepo===!0||r.discoverRepo==="true"?Gr()?.repo:void 0)||e.defaultRepo?.trim()||process.env.KYNVER_DEFAULT_REPO?.trim()||process.env.KYNVER_HARNESS_REPO?.trim()||Vn()?.repo,a=(typeof r.harnessRoot=="string"?r.harnessRoot:void 0)||e.harnessRoot?.trim()||process.env.KYNVER_HARNESS_ROOT?.trim()||process.env.OPUS_HARNESS_ROOT?.trim();return{...n?{apiBaseUrl:ar(n)}:{},...o?{agentOsId:o}:{},...i?{defaultRepo:i}:{},...a?{harnessRoot:a}:{},...typeof r.agentOsSlug=="string"?{agentOsSlug:r.agentOsSlug}:e.agentOsSlug?{agentOsSlug:e.agentOsSlug}:{}}}function uC(e,r,t=sC()){let n=typeof r.maxWorkers=="string"?r.maxWorkers:typeof r.maxConcurrentWorkers=="string"?r.maxConcurrentWorkers:void 0,o=typeof r.boxKind=="string"?r.boxKind:typeof r["box-kind"]=="string"?String(r["box-kind"]):void 0,s=Ae(process.env,{...e,...o?{boxKind:Kt(o)}:{}}).boxKind,i=Le({diskPath:typeof r.diskPath=="string"?r.diskPath:"/"}),a=Vl({totalMemBytes:t,diskPath:i.path,diskGateOk:i.ok,diskFreeBytes:i.freeBytes,config:e});if(n){let l=Math.max(1,Math.floor(Number(n)));return{maxConcurrentWorkers:cr(s,l),maxConcurrentWorkersSource:"setup-flag",boxKind:s}}if(e.maxConcurrentWorkers!==void 0&&e.maxConcurrentWorkers!==null){let l=Math.max(1,Math.floor(Number(e.maxConcurrentWorkers)));return $t(s,l)?{maxConcurrentWorkers:Al(s,a.recommendedMaxWorkers),maxConcurrentWorkersSource:"setup-auto",boxKind:s}:{maxConcurrentWorkers:cr(s,l),maxConcurrentWorkersSource:e.maxConcurrentWorkersSource??"operator",boxKind:s}}return{maxConcurrentWorkers:Al(s,a.recommendedMaxWorkers),maxConcurrentWorkersSource:"setup-auto",boxKind:s}}function fo(){if(!Wm(an))return{};try{return JSON.parse(Bm(an,"utf8"))}catch{return{}}}function Fm(e){Lm(ri,{recursive:!0}),Hm(an,`${JSON.stringify(e,null,2)}
|
|
14
|
+
`,{mode:384})}function se(){return process.env.KYNVER_API_KEY?process.env.KYNVER_API_KEY:fo().apiKey}function po(e){Fm({...fo(),apiKey:e})}function Um(e){let r=process.env.KYNVER_RUNNER_TOKEN?.trim();if(r)return r;let t=fo();if(t.runnerToken&&!(e&&t.runnerTokenAgentOsId&&t.runnerTokenAgentOsId!==e))return t.runnerToken}function nt(e,r){Fm({...fo(),runnerToken:r,runnerTokenAgentOsId:e})}function V(e){let r=go(e);return r||ho("requires --base-url, KYNVER_API_URL, KYNVER_CRON_FIRE_BASE_URL, or ~/.kynver/config.json apiBaseUrl"),r}function rc(e){return go(e)}function go(e){let r=e||process.env.KYNVER_API_URL||process.env.KYNVER_CRON_FIRE_BASE_URL||process.env.OPENCLAW_CRON_FIRE_BASE_URL||R().apiBaseUrl;return r?ar(String(r)):void 0}function Km(e,r){let t=e||Um(r)||(r?void 0:Um(R().agentOsId));if(t)return String(t);let n=process.env.KYNVER_RUNTIME_SECRET||process.env.KYNVER_CRON_SECRET||process.env.OPENCLAW_CRON_SECRET;if(n)return console.warn("[kynver] using deployment-level callback secret; run `kynver runner credential --agent-os-id <id>` for a scoped token"),String(n)}function dC(e,r){let t=Km(e,r);if(t)return t;ho("requires --secret, KYNVER_RUNNER_TOKEN, a scoped runner token (`kynver runner credential`), ~/.kynver/credentials runnerToken, KYNVER_API_KEY with an API base URL to mint one, or (legacy) KYNVER_RUNTIME_SECRET / KYNVER_CRON_SECRET / OPENCLAW_CRON_SECRET")}async function ni(e,r,t){let n=Km(e,r);if(n)return{ok:!0,secret:n};let o=se(),s=go(t?.baseUrl);if(o&&r&&s)try{let i=await ot(r,{baseUrl:s,apiKey:o});return nt(r,i),{ok:!0,secret:i}}catch(i){return{ok:!1,reason:`runner credential mint failed: ${i.message}`}}return{ok:!1,reason:"no runner credential: requires --secret, KYNVER_RUNNER_TOKEN, a scoped runner token (`kynver runner credential`), ~/.kynver/credentials runnerToken, or KYNVER_API_KEY + API base URL to mint one"}}async function J(e,r,t){let n=await ni(e,r,t);if(n.ok)return n.secret;ho(n.reason)}async function $m(e,r){let t=se(),n=go(r?.baseUrl);if(!t||!e||!n)return null;try{let o=await ot(e,{baseUrl:n,apiKey:t});return nt(e,o),o}catch{return null}}async function jm(e,r,t){let n=se(),o=go(t?.baseUrl);if(!n)return{ok:!1,reason:"KYNVER_API_KEY is required to refresh a rejected runner token"};if(!r)return{ok:!1,reason:"agentOsId is required to refresh a rejected runner token"};if(!o)return{ok:!1,reason:"KYNVER_API_URL or --base-url is required to refresh a rejected runner token"};try{let s=await ot(r,{baseUrl:o,apiKey:n});return s&&s!==e?(nt(r,s),{ok:!0,token:s}):{ok:!1,reason:"runner credential refresh returned the rejected token"}}catch(s){return{ok:!1,reason:s.message}}}async function ot(e,r){let t=r?.apiKey||se();if(!t)throw new Error("API key required \u2014 run `kynver login` first");let o=`${V(r?.baseUrl)}/api/agent-os/by-id/${encodeURIComponent(e)}/runner-credentials`,s=await fetch(o,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${t}`},body:JSON.stringify({})}),i=await s.text(),a=null;try{a=JSON.parse(i)}catch{a=null}if(!s.ok||!a?.token)throw new Error(`runner credential mint failed (${s.status}): ${a?.error??i.slice(0,200)}`);return a.token}async function Vm(e){let r=(e.agentOsId?String(e.agentOsId):R().agentOsId)||"";r||ho("runner credential requires --agent-os-id or agentOsId in ~/.kynver/config.json");try{let t=await ot(r,{baseUrl:e.baseUrl?String(e.baseUrl):void 0});nt(r,t),console.log(JSON.stringify({ok:!0,agentOsId:r,credentialsPath:q(an),tokenPrefix:`${t.slice(0,12)}\u2026`,note:"Scoped runner token saved; callbacks use X-Kynver-Runner-Token."},null,2))}catch(t){console.error(t instanceof Error?t.message:String(t)),process.exit(1)}}function ho(e){console.error(e),process.exit(1)}function ko(e){let r={};for(let t=0;t<e.length;t++){let n=e[t];if(!n.startsWith("--"))continue;let o=n.slice(2).replace(/-([a-z])/g,(i,a)=>a.toUpperCase()),s=e[t+1];!s||s.startsWith("--")?r[o]=!0:(r[o]=s,t++)}return r}async function oi(e){let r=R(),t=Le({diskPath:typeof e.diskPath=="string"?e.diskPath:"/"}),n=Vl({totalMemBytes:iC.totalmem(),diskPath:t.path,diskGateOk:t.ok,diskFreeBytes:t.freeBytes,config:r}),o=uC(r,e),s=ec({...r,...cC(r,e),...o,workerProvider:typeof e.provider=="string"?e.provider:r.workerProvider||"cursor",...e.chatOauth===!0?{chatUseClaudeOauth:!0}:{}});s.agentOsId&&!mo(s.agentOsId).ok&&ho(ti(s.agentOsId)),ue(s);let i=Ae(process.env,s),a=Qs(s,e);a.configUpdated&&(s=R());let l,c=se(),u=s.agentOsId;if(c&&u)try{let d=await ot(u,{baseUrl:typeof e.apiBaseUrl=="string"?e.apiBaseUrl:s.apiBaseUrl,apiKey:c});nt(u,d),l="Scoped runner token minted and saved to ~/.kynver/credentials."}catch{l="Runner token not minted (server offline or master secret unset). Run `kynver runner credential` after deploy."}console.log(JSON.stringify({ok:!0,configPath:q(ei),config:ln(s),boxKind:s.boxKind,boxKindSource:i.source,workerCapRecommendation:n,daemonSupervision:{hostKind:a.policy.hostKind,owner:a.policy.owner,envFilePath:a.envFilePath},...i.warnings.length?{boxIdentityWarnings:i.warnings}:{},note:l??"boxKind and maxConcurrentWorkers persisted; override with --box-kind and --max-workers. Run `kynver login` + `kynver runner credential` for scoped callbacks."},null,2))}async function Gm(e){let r=typeof e.apiKey=="string"?e.apiKey:process.env.KYNVER_API_KEY;if(r){po(r),console.log(JSON.stringify({ok:!0,credentialsPath:q(an)},null,2));return}let{runDeviceLogin:t}=await Promise.resolve().then(()=>(Ql(),Mm));(await t(e)).ok||process.exit(1),console.log(JSON.stringify({ok:!0,credentialsPath:q(an)},null,2))}var ri,ei,an,aC,lC,OU,IU,N=U(()=>{"use strict";Gn();Je();C();Ie();qn();js();Gt();uo();ri=Zl.join(oC(),".kynver"),ei=Zl.join(ri,"config.json"),an=Zl.join(ri,"credentials"),aC=/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i,lC=new Set(["aos","aos-1","agent-os-id","agentosid","agent_os_id","<agent-os-id>","<agentosid>","todo","changeme","change-me","placeholder"]);OU=500*1024*1024,IU=4*1024*1024*1024});import{existsSync as jb,readFileSync as Vb}from"node:fs";import{dirname as ul,join as pp}from"node:path";import{fileURLToPath as dp}from"node:url";function Gb(e){let r=ul(dp(e));for(let t=0;t<6;t+=1){if(jb(pp(r,"package.json")))return r;let n=ul(r);if(n===r)break;r=n}throw new Error(`package.json not found above ${ul(dp(e))}`)}function mp(e=import.meta.url){let r=pp(Gb(e),"package.json"),t=JSON.parse(Vb(r,"utf8"));if(typeof t.version!="string"||!t.version.trim())throw new Error(`Missing package.json version at ${r}`);return t.version}var $n=mp();function Yb(e){return e.some(r=>r==="--version"||r==="-v")}function Jb(e,r){console.log(r?`${r} ${e}`:e),process.exit(0)}function fp(e,r=import.meta.url,t){return Yb(e)?(Jb(mp(r),t),!0):!1}Gn();import{existsSync as Op,readFileSync as iv}from"node:fs";import ws from"node:path";var vl={"@kynver-app/runtime":"0.1.83","@kynver-app/openclaw-agent-os":"0.1.43","@kynver-app/mcp-agent-os":"0.3.34"},Sl=Object.keys(vl),bl={"@kynver-app/runtime":"Kynver runtime","@kynver-app/openclaw-agent-os":"OpenClaw AgentOS plugin","@kynver-app/mcp-agent-os":"AgentOS MCP server"},av={"@kynver-app/runtime":"packages/kynver-runtime/package.json","@kynver-app/openclaw-agent-os":"packages/kynver-openclaw-agent-os/package.json","@kynver-app/mcp-agent-os":"packages/kynver-mcp-agent-os/package.json"};function Ip(e){let r=e.trim().split("-")[0]?.split("+")[0];if(!r)return null;let t=r.split(".");if(t.length<1||t.length>3)return null;let n=t.map(o=>Number.parseInt(o,10));if(n.some(o=>!Number.isFinite(o)||o<0))return null;for(;n.length<3;)n.push(0);return[n[0],n[1],n[2]]}function Jn(e,r){let t=Ip(e),n=Ip(r);if(!t||!n)return 0;for(let o=0;o<3;o+=1){if(t[o]>n[o])return 1;if(t[o]<n[o])return-1}return 0}function Cl(e,r){return Jn(e,r)>=0}function lv(e){let r=null;for(let t of e)(!r||Jn(t,r)>0)&&(r=t);return r}function cv(e){try{let r=JSON.parse(iv(e,"utf8"));return typeof r.version=="string"&&r.version.trim()?r.version.trim():null}catch{return null}}function uv(e,r){let t=[r,process.env.KYNVER_REPO,e].filter(o=>!!o?.trim());for(let o of t){let s=ws.resolve(o);if(Op(ws.join(s,"packages/kynver-runtime/package.json"))&&Op(ws.join(s,"package.json")))return s}return Gr({cwd:e})?.repo??null}function wl(e={}){let r=e.cwd??process.cwd(),t=uv(r,e.repoRoot);if(!t)return{};let n={};for(let o of Sl){let s=ws.join(t,av[o]),i=cv(s);i&&(n[o]={version:i,source:"repo",path:s})}return n}function dv(e){return e==="@kynver-app/runtime"?["npm run kynver:build","npm run kynver"]:[`npm run build -w ${e}`]}function pv(e){let{packageName:r,minimumVersion:t,effectiveVersion:n,effectiveSource:o,repoVersion:s}=e,i=[];return s&&Cl(s,t)?(i.push(`Use the monorepo checkout (${s}) instead of a stale npm install: ${dv(r).join("; ")}.`),i.push("Do not publish npm packages or wait on an operator release."),i):(n?i.push(`Upgrade ${r} from ${n} to >= ${t} (npm install -g ${r}@latest or align OpenClaw npm prefix).`):i.push(`Install ${r} >= ${t} before running memory-heavy AgentOS paths.`),r==="@kynver-app/runtime"&&i.push("Repo-source alternative: npm run kynver:build && npm run kynver"),o==="installed"&&s&&i.push(`Repo checkout reports ${s}; rebuild/link repo source if you develop from the monorepo.`),i)}function mv(e){if(e.length===0)return{version:null,source:"unknown"};let r=lv(e.map(n=>n.version));if(!r)return{version:null,source:"unknown"};let t=e.find(n=>n.version===r)??e[0];return{version:t.version,source:t.source}}function _s(e={}){let r=(i,a)=>i?typeof i=="string"?{version:i,source:a}:i:null,t=Sl.map(i=>{let a=vl[i],l=[],c=r(e.installed?.[i],"installed"),u=r(e.repo?.[i],"repo"),d=r(e.self?.[i],"self");c&&l.push(c),u&&l.push(u),d&&l.push(d);let{version:f,source:p}=mv(l),m=u?.version??null,h=f?Cl(f,a):!1,k=h?[]:pv({packageName:i,minimumVersion:a,effectiveVersion:f,effectiveSource:p,repoVersion:m}),g=h?`${bl[i]} ${f} meets memory-cost minimum ${a} (${p}).`:`${bl[i]} is below memory-cost minimum ${a}`+(f?` (effective ${f} via ${p})`:" (no version detected)")+".";return{packageName:i,displayName:bl[i],minimumVersion:a,effectiveVersion:f,effectiveSource:p,ok:h,summary:g,remediation:k}}),n=t.filter(i=>!i.ok),o=n.length===0,s=o?"All managed AgentOS packages meet memory-cost minimum versions.":`Memory-cost package guard blocked ${n.length} stale package(s): ${n.map(i=>`${i.packageName} < ${i.minimumVersion}`).join("; ")}.`;return{ok:o,summary:s,packages:t}}var Yn=class extends Error{result;constructor(r){let t=[r.summary,...r.packages.filter(n=>!n.ok).flatMap(n=>[`- ${n.summary}`,...n.remediation.map(o=>` \u2192 ${o}`)])];super(t.join(`
|
|
15
|
+
`)),this.name="MemoryCostPackageVersionGuardError",this.result=r}};function _l(e={}){let r=_s(e);if(!r.ok)throw new Yn(r);return r}function fv(e){return new Yn(e).message}import{readFile as gv}from"node:fs/promises";import{homedir as hv}from"node:os";import Yr from"node:path";var kv=["@kynver-app/runtime","@kynver-app/openclaw-agent-os","@kynver-app/mcp-agent-os"];function Ft(e){let r=e?.trim();return r||null}function yv(e){return[...new Set(e.filter(r=>!!r))]}function Rv(){let e=hv(),r=Ft(process.env.KYNVER_OPENCLAW_NPM_ROOT)??Ft(process.env.OPENCLAW_NPM_ROOT)??Yr.join(e,".openclaw","npm"),t=Ft(process.env.KYNVER_NPM_GLOBAL_ROOT)??Ft(process.env.KYNVER_NPM_GLOBAL_MODULES_ROOT)??(Ft(process.env.NPM_CONFIG_PREFIX)?Yr.join(Ft(process.env.NPM_CONFIG_PREFIX),"lib","node_modules"):Yr.join(e,".npm-global","lib","node_modules"));return yv([Yr.join(r,"lib","node_modules"),Yr.join(r,"node_modules"),t.endsWith("node_modules")?t:Yr.join(t,"lib","node_modules")])}async function bv(e){try{let r=JSON.parse(await gv(e,"utf8"));return typeof r.version=="string"&&r.version.trim()?r.version.trim():null}catch{return null}}function vv(e){let r=Rv(),t=new Set,n=[];for(let o of r){let s=Yr.join(o,e,"package.json");t.has(s)||(t.add(s),n.push(s))}return n}async function xs(e=new Date().toISOString()){let r={};for(let t of kv){let n=null;for(let o of vv(t)){let s=await bv(o);s&&(!n||Jn(s,n.version)>0)&&(n={version:s,path:o})}n&&(r[t]={version:n.version,observedAt:e,path:n.path})}return r}function Sv(e){let r={};for(let[t,n]of Object.entries(e))n?.version&&(r[t]={version:n.version,source:"installed",path:n.path});return r}async function xl(e={}){let[r,t]=await Promise.all([xs(),Promise.resolve(wl({cwd:e.cwd,repoRoot:e.repoRoot}))]),n={},o=e.selfPackageName==="@kynver-app/runtime"&&e.selfVersion?e.selfVersion:$n;return n["@kynver-app/runtime"]={version:o,source:"self"},e.selfPackageName&&e.selfVersion&&e.selfPackageName!=="@kynver-app/runtime"&&(n[e.selfPackageName]={version:e.selfVersion,source:"self"}),{installed:Sv(r),repo:t,self:n}}async function Cv(e={}){let r=await xl(e);return _s(r)}async function El(e={}){let r=await xl(e);return _l(r)}function Pl(e,r){return e?e==="daemon"||e==="start"||e==="worker"||e==="monitor"||e==="run"&&(r==="dispatch"||r==="sweep"||r==="reconcile"||r==="unblock")||e==="cron"&&r==="tick":!1}N();function He(e){let r=String(e).trim();return r.startsWith("krc1.")?{"Content-Type":"application/json","X-Kynver-Runner-Token":r}:{"Content-Type":"application/json","X-Kynver-Cron-Secret":r,"X-OpenClaw-Cron-Secret":r,"X-Kynver-Runtime-Secret":r}}N();function Ym(e){if(e!==void 0&&Number.isFinite(e)&&e>0)return Math.floor(e);let r=Number(process.env.KYNVER_CALLBACK_TIMEOUT_MS);return Number.isFinite(r)&&r>0?Math.floor(r):3e4}async function Jm(e,r){let t=Ym(r),n=new AbortController,o;try{return await Promise.race([e(n.signal),new Promise((s,i)=>{o=setTimeout(()=>{n.abort(),i(new Error(`callback timeout after ${t}ms`))},t)})])}finally{o&&clearTimeout(o)}}function qm(e,r){let t=Ym(r);return{ok:!1,status:0,response:{error:e instanceof Error?e.message:String(e),timeoutMs:t}}}async function Ir(e,r,t,n){try{return await Jm(async o=>{let s=await fetch(e,{method:"POST",headers:He(r),body:JSON.stringify(t),signal:o}),i=null;try{i=await s.json()}catch{i=null}return{ok:s.ok,status:s.status,response:i}},n?.timeoutMs)}catch(o){return qm(o,n?.timeoutMs)}}async function re(e,r,t,n){let o=await Ir(e,r,t,{timeoutMs:n.timeoutMs});if(o.ok||o.status!==401)return o;let s=await jm(r,n.agentOsId,{baseUrl:n.baseUrl});return s.ok?{...await Ir(e,s.token,t,{timeoutMs:n.timeoutMs}),refreshedAuth:!0}:{...o,authRefreshFailure:s.reason}}async function si(e,r,t){try{return await Jm(async n=>{let o=await fetch(e,{method:"GET",headers:He(r),signal:n}),s=null;try{s=await o.json()}catch{s=null}return{ok:o.ok,status:o.status,response:s}},t?.timeoutMs)}catch(n){return qm(n,t?.timeoutMs)}}function zm(){let e=Number(process.env.KYNVER_DISPATCH_CALLBACK_TIMEOUT_MS);return Number.isFinite(e)&&e>0?Math.floor(e):12e4}function tc(e){console.error(JSON.stringify({event:"dispatch_progress",ts:new Date().toISOString(),...e}))}function Xm(e){if(!e||typeof e!="object")return!1;let r=e;if(r.timeoutMs!==void 0)return!0;let t=r.error;if(typeof t!="string"||!t.trim())return!1;let n=t.toLowerCase();return n.includes("abort")||n.includes("timeout")}var Qm="embedded-1",pC=[{slug:"ghost",displayName:"Ghost",description:"Orchestration persona.",dispatchLane:null,defaultRoleLane:"system"},{slug:"astra",displayName:"Astra",description:"Planning persona.",dispatchLane:"implementation",defaultRoleLane:"plan_author"},{slug:"rhea",displayName:"Rhea",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"mnemo",displayName:"Mnemo",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"sentinel",displayName:"Sentinel",description:"Review persona.",dispatchLane:"review",defaultRoleLane:"deep_reviewer"},{slug:"pixel",displayName:"Pixel",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"schema",displayName:"Schema",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"atlas",displayName:"Atlas",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"runtime_verifier"},{slug:"bridge",displayName:"Bridge",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"catalyst",displayName:"Catalyst",description:"Implementation persona.",dispatchLane:"implementation",defaultRoleLane:"implementer"},{slug:"lorentz",displayName:"Lorentz",description:"Review persona.",dispatchLane:"review",defaultRoleLane:"report_reviewer"},{slug:"dalton",displayName:"Dalton",description:"Landing persona.",dispatchLane:"landing",defaultRoleLane:"implementer"}],mC={"worker.prompt.core_rules":["Structured final result (recommended): record completion as JSON with summary, files, PR URLs, verification, risks, and blockers.","Completion handoff (required): before you stop, summarize the outcome in your last message and append a heartbeat line with phase `complete` and a structured finalResult object. Commit your work cleanly and open a GitHub PR (draft OK) for substantial changes \u2014 never leave uncommitted changes behind without reporting them.","Review-only workers must not open new implementation PRs \u2014 review the existing PR and record a verdict in the final result. Prefer `gh pr view` / `gh pr diff`; if a local checkout is needed, use a disposable ref or detached worktree, not a checked-out `pr-*` branch.","Keep verification targeted to touched paths; avoid full-monorepo verification unless explicitly requested.","Do not run `npm publish`.","If verification fails, append a heartbeat line immediately with the failing command, reason, and next action."].join(`
|
|
16
16
|
`),"worker.prompt.progress.compact":"Plan progress: when planId is set, report progress with `kynver plan progress --plan <planId> --row <rowKey> --role implementer --status in_progress|running|partial|blocked`. Do not mark rows done from the worker CLI.","worker.prompt.progress.full":["Structured plan progress (required when planId is set):","- Report checkpoints with `kynver plan progress --plan <planId> --row <rowKey> --role implementer --status in_progress|running|partial|blocked`.","- When a slice is finished, emit `partial` with evidence (`--evidence pr:<url>`, `--evidence path:<file>`, or `--evidence command:<cmd>`).","- Do not propose or confirm row `done` from the worker CLI."].join(`
|
|
17
17
|
`),"worker.prompt.merge_gate.compact":"Verification cost control: prefer local verification before requesting CI runs; do not push empty commits to re-trigger CI; record verification evidence on the PR.","worker.prompt.merge_gate.full":["Verification cost control:","- Prefer local verification of touched paths before requesting any CI run.","- Do not push empty commits to re-trigger CI.","- Record verification evidence on the PR before requesting review."].join(`
|
|
18
18
|
`),"worker.prompt.plan_artifacts.compact":"Plan artifacts: when authoring or revising plan documents, open a GitHub PR early and iterate from that PR branch; do not leave the canonical plan only in a local worktree.","worker.prompt.plan_artifacts.full":["Plan artifacts (when authoring or revising plan documents):","- Create a feature branch and open a GitHub PR (draft OK) before substantial drafting; commit and push the plan file.","- Iterate on that PR branch and link the PR URL on the related task and progress evidence."].join(`
|
|
19
|
-
`)},oC={"harness.maxTaskAttempts":4,"harness.dispatchCooldownMs":5e3,"daemon.idleIntervalMs":5*6e4,"daemon.maxIdleStreak":10},st={version:Jm,generatedAt:"1970-01-01T00:00:00.000Z",personas:tC,instructions:nC,policyThresholds:oC};var ln=st,qm="embedded";function sC(){return ln}function Nr(){return ln.version}function fr(){return qm}function tc(e,r){ln=e,qm=r}function cn(e){let r=ln.instructions[e];if(typeof r=="string"&&r.trim())return r;let t=st.instructions[e];return typeof t=="string"?t:""}function it(e,r){let t=ln.policyThresholds[e];if(typeof t=="number"&&Number.isFinite(t))return t;let n=st.policyThresholds[e];return typeof n=="number"&&Number.isFinite(n)?n:r}function oi(e){if(!e)return null;let r=e.trim().toLowerCase();return ln.personas.find(t=>t.slug===r)??null}var iC=["implementation","review","landing"],aC=["plan_author","implementer","report_reviewer","deep_reviewer","runtime_verifier","system"];function lC(e){return iC.includes(e)}function cC(e){return aC.includes(e)}function zm(e){return{slug:e.slug,displayName:e.displayName,description:e.description,dispatchLane:e.dispatchLane===null||lC(e.dispatchLane)?e.dispatchLane:null,defaultRoleLane:cC(e.defaultRoleLane)?e.defaultRoleLane:"implementer"}}var si=st.personas.map(zm),Xm=new Map(si.map(e=>[e.slug,e]));function nc(e){if(!e)return null;let r=e.trim().toLowerCase(),t=Xm.get(r)??null,n=oi(r);if(!n)return t;let o=zm(n);return t?{...o,dispatchLane:t.dispatchLane,defaultRoleLane:t.defaultRoleLane}:o}function Qm(e){return nc(e)?.dispatchLane??null}function ii(e){return nc(e)?.defaultRoleLane??null}function uC(e){if(!e)return!1;let r=e.trim().toLowerCase();return Xm.has(r)||oi(r)!==null}function oc(){return si.filter(e=>e.dispatchLane==="review").map(e=>e.slug)}function dC(){return si.filter(e=>e.dispatchLane==="landing").map(e=>e.slug)}function Zm(e){return(e??"").trim().toLowerCase()}function pC(e){switch(Zm(e)){case"implementer":case"repair_implementer":case"plan_author":case"runtime_verifier":return"implementation";case"plan_reviewer":case"report_reviewer":case"deep_reviewer":return"review";default:return null}}function mC(e){let r=Zm(e);if(!r)return;if(r==="implementation"||r==="review"||r==="landing"||r==="any")return r;let t=pC(r);if(t)return t;if(r==="implement"||r==="repair"||r==="coding")return"implementation";if(r==="land"||r==="merge")return"landing"}function ef(e){return mC(e)??"any"}Vt();en();T();T();function ai(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function sc(e){return e.toLowerCase()}function fC(e){let r=ai(e,"roleLane");if(r)return r;let t=sc(ai(e,"executorRef")),n=sc(ai(e,"title")),o=sc(ai(e,"personaSlug")),s=`${t} ${n}`;if(s.includes("deep review")||s.includes("security review")||t.includes("deep-reviewer"))return"deep_reviewer";if(s.includes("plan author")||s.includes("plan-author")||n.includes("strategy plan"))return"plan_author";if(s.includes("plan review")||t.includes("plan-reviewer"))return"plan_reviewer";if(s.includes("report review")||s.includes("completion report"))return"report_reviewer";if(s.includes("repair")||n.startsWith("fix ")||t.includes("repair"))return"repair_implementer";if(t.includes("cursor")||t.includes("codex")||t.includes("composer")||n.includes("implement")||n.includes("land:"))return"implementer";let i=ii(o);if(i)return o==="lorentz"&&(s.includes("deep")||s.includes("security"))?"deep_reviewer":i;if(s.includes("review"))return"report_reviewer"}function rf(e){let r=fC(e);return r?{...e,roleLane:r}:e}I();var Ie="cursor",gC=new Set(["claude","opus","anthropic"]),hC=[/\[worker-provider:\s*claude\]/i,/\[use-claude-worker\]/i,/\[operator-worker-provider:\s*claude\]/i];function ic(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function Xe(e){if(!e?.trim())return!1;let r=e.trim().toLowerCase();return gC.has(r)?!0:r.includes("claude")||r.includes("opus")}function li(e){if(!e)return!1;let r=e.workerProviderOverride;if(typeof r=="string"&&Xe(r))return!0;let t=ic(e,"executorRef").toLowerCase();if(t==="provider:claude"||t.startsWith("provider:claude:")||t.includes("claude-worker-override")||t.includes("operator-claude"))return!0;let n=ic(e,"description");if(hC.some(s=>s.test(n)))return!0;let o=ic(e,"title");return!!/\[use-claude-worker\]/i.test(o)}function kC(e,r){return{provider:Ie,model:lc,rule:`policy:cursor_default${r}`,requestedModel:e}}function ac(e){let{routing:r,task:t}=e,n=e.explicitProvider?.trim().toLowerCase();if(e.explicitProviderIsOperatorOverride&&Xe(n))return{...r,provider:"claude",rule:r.rule.startsWith("explicit:")?r.rule:"explicit:operator_provider"};if(li(t)||r.rule==="explicit:cli"&&Xe(r.provider)||!Xe(r.provider))return r;let o=r.rule&&r.rule!=="default:global"?`:${r.rule.replace(/:/g,"_")}`:"";return kC(r.model,o)}function ko(e,r=Ie){let t=e?.trim();return t?Xe(t)?Ie:t==="codex"?"codex":t:r}function yC(e){let r=[...new Set(e.map(t=>t.trim().toLowerCase()).filter(Boolean))];return r.includes(Ie)?[...new Set(r.map(t=>Xe(t)?Ie:t))]:r.every(t=>Xe(t))?[Ie]:r}var tf={codex:{id:"codex",displayName:"Codex (BYO OAuth / Hermes openai-codex)",costTier:"low",authSources:["oauth_local","api_key_env","subscription_hermes"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!1},cursor:{id:"cursor",displayName:"Cursor / Composer",costTier:"medium",authSources:["oauth_local","api_key_env"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!0},claude:{id:"claude",displayName:"Claude Code",costTier:"high",authSources:["oauth_local"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!0}};function at(e){return tf[e]}function cc(){return Object.values(tf)}import{existsSync as vC}from"node:fs";import{homedir as bC}from"node:os";import sf from"node:path";import{createHash as nf}from"node:crypto";import{statSync as RC}from"node:fs";import{spawnSync as of}from"node:child_process";function Qe(e){try{let r=RC(e),t=`${e}|${r.size}|${r.mtimeMs}`;return nf("sha256").update(t).digest("hex").slice(0,16)}catch{return}}function un(e){return nf("sha256").update(`env:${e}`).digest("hex").slice(0,16)}function Ne(e,r){for(let t of r){let n=process.env[t]?.trim();if(n)return n}return e}function Ze(e,r,t={}){let n=t.timeoutMs??8e3;try{let o=of(e,r,{encoding:"utf8",timeout:n,env:{...process.env,CI:"1",NO_COLOR:"1"}});if(o.status===0)return{ok:!0,note:t.okNote??`${e} ${r.join(" ")}: ok`};let s=(o.stderr||o.stdout||"").trim(),i=t.failPrefix??`${e} ${r.join(" ")} failed`;return{ok:!1,note:s?`${i}: ${s.slice(0,200)}`:i}}catch(o){return{ok:!1,note:o instanceof Error?o.message:`${e} probe failed`}}}function ci(e,r,t={}){let n=t.timeoutMs??8e3;try{return of(e,r,{stdio:"ignore",timeout:n,env:{...process.env,CI:"1",NO_COLOR:"1"}}).status===0?{ok:!0,note:t.okNote??`${e} authenticated`}:{ok:!1,note:t.failNote??`${e} not authenticated`}}catch(o){return{ok:!1,note:o instanceof Error?o.message:`${e} auth probe failed`}}}var SC="codex";function CC(){let e=bC();return[sf.join(e,".codex","auth.json"),sf.join(e,".config","codex","auth.json")]}function uc(e=new Date().toISOString()){let r=Ne(SC,["KYNVER_CODEX_BIN","CODEX_BIN"]);if(process.env.CODEX_API_KEY?.trim())return{providerId:"codex",ready:!0,authSource:"api_key_env",sessionFingerprint:un("CODEX_API_KEY"),checkedAt:e,note:"CODEX_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=CC().find(s=>vC(s)),n=Ze(r,["login","status"],{okNote:"codex login status: authenticated",failPrefix:"codex login status"}),o=!!t&&n.ok;return{providerId:"codex",ready:o,authSource:"oauth_local",sessionFingerprint:t?Qe(t):void 0,checkedAt:e,note:o?"Local Codex OAuth session bound on runner":[n.note,t?void 0:"no ~/.codex/auth.json"].filter(Boolean).join("; ")}}import{existsSync as wC}from"node:fs";import{homedir as _C}from"node:os";import dc from"node:path";function xC(){let e=process.env.HERMES_HOME?.trim(),r=e?dc.resolve(e):dc.join(_C(),".hermes");return dc.join(r,"auth.json")}function yo(e=new Date().toISOString()){let r=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=xC(),o=wC(n),s=ci(r,["auth","status","openai-codex"],{okNote:"hermes openai-codex: logged in",failNote:"hermes openai-codex: not logged in"}),i=t.ok&&s.ok;return{path:"hermes_openai_codex",ready:i,authSource:i?"subscription_hermes":"none",sessionFingerprint:o?Qe(n):void 0,checkedAt:e,note:i?"Hermes openai-codex subscription session bound (ChatGPT Codex OAuth)":[t.note,s.note,o?void 0:"no ~/.hermes/auth.json"].filter(Boolean).join("; ")}}function Tr(e=new Date().toISOString()){let r=uc(e);if(r.ready)return{...r,path:"codex_cli"};let t=yo(e);return t.ready?{providerId:"codex",ready:!0,authSource:t.authSource,sessionFingerprint:t.sessionFingerprint,checkedAt:t.checkedAt,note:t.note,path:"hermes_openai_codex",hermesOpenAiCodex:t}:{providerId:"codex",ready:!1,authSource:"none",checkedAt:e,path:"none",hermesOpenAiCodex:t,note:[r.note,t.note].filter(Boolean).join("; ")||"Codex CLI and Hermes openai-codex unavailable"}}var af=["low","medium","high"],lf={oauth_local:0,subscription_hermes:0,runner_token:1,api_key_env:2,none:3};function pc(e,r){let t=at(e);return r==="privileged"?t.supportsPrivilegedPlatformActions:r==="low"?t.supportsLowRiskOrchestration:!0}function cf(e,r){let t=at(e.providerId),n=at(r.providerId),o=af.indexOf(t.costTier)-af.indexOf(n.costTier);if(o!==0)return o;let s=lf[e.binding.authSource]-lf[r.binding.authSource];return s!==0?s:e.providerId.localeCompare(r.providerId)}function ui(e){let r=cc().map(a=>({providerId:a.id,binding:e.inventory.bindings[a.id]})).filter(a=>a.binding.ready&&pc(a.providerId,e.riskClass));if(r.length===0)return null;let n=[...r].sort(cf)[0],o="codex";if(n.providerId===o)return{providerId:n.providerId,binding:n.binding};let s=e.inventory.bindings[o],i;return pc(o,e.riskClass)?s.ready||(i=s.note??`${o} not bound`):i=`${e.riskClass} orchestration requires privileged-capable provider`,{providerId:n.providerId,binding:n.binding,escalatedFrom:o,escalatedReason:i}}import{existsSync as EC}from"node:fs";import{homedir as PC}from"node:os";import AC from"node:path";var IC="claude";function OC(){let e=PC();return[AC.join(e,".claude",".credentials.json")]}function di(e=new Date().toISOString()){let r=Ne(IC,["KYNVER_CLAUDE_BIN","CLAUDE_BIN"]);if(process.env.ANTHROPIC_API_KEY?.trim())return{providerId:"claude",ready:!0,authSource:"api_key_env",sessionFingerprint:un("ANTHROPIC_API_KEY"),checkedAt:e,note:"ANTHROPIC_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=OC().find(i=>EC(i)),o=ci(r,["auth","status"],{okNote:"claude auth status: authenticated",failNote:"claude auth status: not authenticated"}),s=t.ok&&(o.ok||!!n);return{providerId:"claude",ready:s,authSource:"oauth_local",sessionFingerprint:n?Qe(n):void 0,checkedAt:e,note:s?"Local Claude Code OAuth session bound on runner":[t.note,o.note,n?void 0:"no ~/.claude/.credentials.json"].filter(Boolean).join("; ")}}import{existsSync as NC}from"node:fs";import{homedir as TC}from"node:os";import DC from"node:path";var MC="agent";function UC(){let e=TC();return[DC.join(e,".config","cursor","auth.json")]}function pi(e=new Date().toISOString()){let r=Ne(MC,["KYNVER_CURSOR_AGENT_BIN","CURSOR_AGENT_BIN"]);if(process.env.CURSOR_API_KEY?.trim())return{providerId:"cursor",ready:!0,authSource:"api_key_env",sessionFingerprint:un("CURSOR_API_KEY"),checkedAt:e,note:"CURSOR_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=Ze(r,["-v"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=UC().find(s=>NC(s)),o=!!n&&t.ok;return{providerId:"cursor",ready:o,authSource:"oauth_local",sessionFingerprint:n?Qe(n):void 0,checkedAt:e,note:o?"Local Cursor/Composer OAuth session bound on runner":[t.note,n?void 0:"no ~/.config/cursor/auth.json"].filter(Boolean).join("; ")}}import{existsSync as WC,readFileSync as LC}from"node:fs";import{homedir as BC}from"node:os";import mc from"node:path";var HC=["OPENAI_API_KEY","ANTHROPIC_API_KEY","KYNVER_API_KEY","KYNVER_BASE_URL"];function FC(){let e=process.env.HERMES_HOME?.trim(),r=e?mc.resolve(e):mc.join(BC(),".hermes");return mc.join(r,".env")}function KC(e){try{let r=LC(e,"utf8"),t=[];for(let n of HC)new RegExp(`^${n}=`,"m").test(r)&&t.push(n);return t}catch{return[]}}function fc(e=new Date().toISOString()){let r=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=FC(),o=WC(n),s=o?KC(n):[],a=s.some(c=>c.endsWith("_API_KEY"))?"api_key_env":o?"oauth_local":"none",l=t.ok&&o;return{adapterId:"hermes",cliAvailable:t.ok,profileBound:o,authSource:a,sessionFingerprint:o?Qe(n):void 0,checkedAt:e,note:l?`Hermes profile bound (${s.length?`keys: ${s.join(", ")}`:"no API keys detected"})`:[t.note,o?void 0:"no ~/.hermes/.env"].filter(Boolean).join("; ")}}function gc(e={}){let r=e.nowIso?.()??new Date().toISOString(),t=Tr(r),n={codex:t,cursor:pi(r),claude:di(r)},o=Object.values(n).filter(s=>s.ready).length;return{generatedAt:r,bindings:n,cloudApiCredits:{anthropicApiKey:!!process.env.ANTHROPIC_API_KEY?.trim(),openaiApiKey:!!process.env.OPENAI_API_KEY?.trim(),codexApiKey:!!process.env.CODEX_API_KEY?.trim()},hermes:fc(r),hermesOpenAiCodex:yo(r),codexAdapterPath:t.path,readyCount:o}}function $C(e,r){switch(e){case"codex":return Tr(r);case"cursor":return pi(r);case"claude":return di(r)}}var jC=[/\bprivileged\b/i,/\bproduction\s+db\b/i,/\bdb:push\b/i,/\bmigration\b/i,/\bdeploy\b/i,/\bsecrets?\b/i,/\bstripe\b/i,/\[require-approval\]/i,/\[operator-only\]/i],VC=[/\borchestration\b/i,/\bplan[- ]?progress\b/i,/\bstatus\s+sync\b/i,/\bheartbeat\b/i,/\bboard[- ]?drain\b/i,/\bmaintenance\b/i,/\[orchestration:\s*low-risk\]/i];function hc(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function uf(e){let r=hc(e,"executorRef").toLowerCase(),t=hc(e,"title").toLowerCase(),n=hc(e,"description").toLowerCase(),o=`${r}
|
|
19
|
+
`)},fC={"harness.maxTaskAttempts":4,"harness.dispatchCooldownMs":5e3,"daemon.idleIntervalMs":5*6e4,"daemon.maxIdleStreak":10},st={version:Qm,generatedAt:"1970-01-01T00:00:00.000Z",personas:pC,instructions:mC,policyThresholds:fC};var cn=st,Zm="embedded";function gC(){return cn}function Nr(){return cn.version}function fr(){return Zm}function nc(e,r){cn=e,Zm=r}function un(e){let r=cn.instructions[e];if(typeof r=="string"&&r.trim())return r;let t=st.instructions[e];return typeof t=="string"?t:""}function it(e,r){let t=cn.policyThresholds[e];if(typeof t=="number"&&Number.isFinite(t))return t;let n=st.policyThresholds[e];return typeof n=="number"&&Number.isFinite(n)?n:r}function ii(e){if(!e)return null;let r=e.trim().toLowerCase();return cn.personas.find(t=>t.slug===r)??null}var hC=["implementation","review","landing"],kC=["plan_author","implementer","report_reviewer","deep_reviewer","runtime_verifier","system"];function yC(e){return hC.includes(e)}function RC(e){return kC.includes(e)}function ef(e){return{slug:e.slug,displayName:e.displayName,description:e.description,dispatchLane:e.dispatchLane===null||yC(e.dispatchLane)?e.dispatchLane:null,defaultRoleLane:RC(e.defaultRoleLane)?e.defaultRoleLane:"implementer"}}var ai=st.personas.map(ef),rf=new Map(ai.map(e=>[e.slug,e]));function oc(e){if(!e)return null;let r=e.trim().toLowerCase(),t=rf.get(r)??null,n=ii(r);if(!n)return t;let o=ef(n);return t?{...o,dispatchLane:t.dispatchLane,defaultRoleLane:t.defaultRoleLane}:o}function tf(e){return oc(e)?.dispatchLane??null}function li(e){return oc(e)?.defaultRoleLane??null}function bC(e){if(!e)return!1;let r=e.trim().toLowerCase();return rf.has(r)||ii(r)!==null}function sc(){return ai.filter(e=>e.dispatchLane==="review").map(e=>e.slug)}function vC(){return ai.filter(e=>e.dispatchLane==="landing").map(e=>e.slug)}function nf(e){return(e??"").trim().toLowerCase()}function SC(e){switch(nf(e)){case"implementer":case"repair_implementer":case"plan_author":case"runtime_verifier":return"implementation";case"plan_reviewer":case"report_reviewer":case"deep_reviewer":return"review";default:return null}}function CC(e){let r=nf(e);if(!r)return;if(r==="implementation"||r==="review"||r==="landing"||r==="any")return r;let t=SC(r);if(t)return t;if(r==="implement"||r==="repair"||r==="coding")return"implementation";if(r==="land"||r==="merge")return"landing"}function of(e){return CC(e)??"any"}Gt();rn();D();D();function ci(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function ic(e){return e.toLowerCase()}function wC(e){let r=ci(e,"roleLane");if(r)return r;let t=ic(ci(e,"executorRef")),n=ic(ci(e,"title")),o=ic(ci(e,"personaSlug")),s=`${t} ${n}`;if(s.includes("deep review")||s.includes("security review")||t.includes("deep-reviewer"))return"deep_reviewer";if(s.includes("plan author")||s.includes("plan-author")||n.includes("strategy plan"))return"plan_author";if(s.includes("plan review")||t.includes("plan-reviewer"))return"plan_reviewer";if(s.includes("report review")||s.includes("completion report"))return"report_reviewer";if(s.includes("repair")||n.startsWith("fix ")||t.includes("repair"))return"repair_implementer";if(t.includes("cursor")||t.includes("codex")||t.includes("composer")||n.includes("implement")||n.includes("land:"))return"implementer";let i=li(o);if(i)return o==="lorentz"&&(s.includes("deep")||s.includes("security"))?"deep_reviewer":i;if(s.includes("review"))return"report_reviewer"}function sf(e){let r=wC(e);return r?{...e,roleLane:r}:e}N();var Oe="cursor",_C=new Set(["claude","opus","anthropic"]),xC=[/\[worker-provider:\s*claude\]/i,/\[use-claude-worker\]/i,/\[operator-worker-provider:\s*claude\]/i];function ac(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function Xe(e){if(!e?.trim())return!1;let r=e.trim().toLowerCase();return _C.has(r)?!0:r.includes("claude")||r.includes("opus")}function ui(e){if(!e)return!1;let r=e.workerProviderOverride;if(typeof r=="string"&&Xe(r))return!0;let t=ac(e,"executorRef").toLowerCase();if(t==="provider:claude"||t.startsWith("provider:claude:")||t.includes("claude-worker-override")||t.includes("operator-claude"))return!0;let n=ac(e,"description");if(xC.some(s=>s.test(n)))return!0;let o=ac(e,"title");return!!/\[use-claude-worker\]/i.test(o)}function EC(e,r){return{provider:Oe,model:cc,rule:`policy:cursor_default${r}`,requestedModel:e}}function lc(e){let{routing:r,task:t}=e,n=e.explicitProvider?.trim().toLowerCase();if(e.explicitProviderIsOperatorOverride&&Xe(n))return{...r,provider:"claude",rule:r.rule.startsWith("explicit:")?r.rule:"explicit:operator_provider"};if(ui(t)||r.rule==="explicit:cli"&&Xe(r.provider)||!Xe(r.provider))return r;let o=r.rule&&r.rule!=="default:global"?`:${r.rule.replace(/:/g,"_")}`:"";return EC(r.model,o)}function yo(e,r=Oe){let t=e?.trim();return t?Xe(t)?Oe:t==="codex"?"codex":t:r}function PC(e){let r=[...new Set(e.map(t=>t.trim().toLowerCase()).filter(Boolean))];return r.includes(Oe)?[...new Set(r.map(t=>Xe(t)?Oe:t))]:r.every(t=>Xe(t))?[Oe]:r}var af={codex:{id:"codex",displayName:"Codex (BYO OAuth / Hermes openai-codex)",costTier:"low",authSources:["oauth_local","api_key_env","subscription_hermes"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!1},cursor:{id:"cursor",displayName:"Cursor / Composer",costTier:"medium",authSources:["oauth_local","api_key_env"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!0},claude:{id:"claude",displayName:"Claude Code",costTier:"high",authSources:["oauth_local"],supportsLowRiskOrchestration:!0,supportsPrivilegedPlatformActions:!0}};function at(e){return af[e]}function uc(){return Object.values(af)}import{existsSync as OC}from"node:fs";import{homedir as IC}from"node:os";import uf from"node:path";import{createHash as lf}from"node:crypto";import{statSync as AC}from"node:fs";import{spawnSync as cf}from"node:child_process";function Qe(e){try{let r=AC(e),t=`${e}|${r.size}|${r.mtimeMs}`;return lf("sha256").update(t).digest("hex").slice(0,16)}catch{return}}function dn(e){return lf("sha256").update(`env:${e}`).digest("hex").slice(0,16)}function Ne(e,r){for(let t of r){let n=process.env[t]?.trim();if(n)return n}return e}function Ze(e,r,t={}){let n=t.timeoutMs??8e3;try{let o=cf(e,r,{encoding:"utf8",timeout:n,env:{...process.env,CI:"1",NO_COLOR:"1"}});if(o.status===0)return{ok:!0,note:t.okNote??`${e} ${r.join(" ")}: ok`};let s=(o.stderr||o.stdout||"").trim(),i=t.failPrefix??`${e} ${r.join(" ")} failed`;return{ok:!1,note:s?`${i}: ${s.slice(0,200)}`:i}}catch(o){return{ok:!1,note:o instanceof Error?o.message:`${e} probe failed`}}}function di(e,r,t={}){let n=t.timeoutMs??8e3;try{return cf(e,r,{stdio:"ignore",timeout:n,env:{...process.env,CI:"1",NO_COLOR:"1"}}).status===0?{ok:!0,note:t.okNote??`${e} authenticated`}:{ok:!1,note:t.failNote??`${e} not authenticated`}}catch(o){return{ok:!1,note:o instanceof Error?o.message:`${e} auth probe failed`}}}var NC="codex";function TC(){let e=IC();return[uf.join(e,".codex","auth.json"),uf.join(e,".config","codex","auth.json")]}function dc(e=new Date().toISOString()){let r=Ne(NC,["KYNVER_CODEX_BIN","CODEX_BIN"]);if(process.env.CODEX_API_KEY?.trim())return{providerId:"codex",ready:!0,authSource:"api_key_env",sessionFingerprint:dn("CODEX_API_KEY"),checkedAt:e,note:"CODEX_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=TC().find(s=>OC(s)),n=Ze(r,["login","status"],{okNote:"codex login status: authenticated",failPrefix:"codex login status"}),o=!!t&&n.ok;return{providerId:"codex",ready:o,authSource:"oauth_local",sessionFingerprint:t?Qe(t):void 0,checkedAt:e,note:o?"Local Codex OAuth session bound on runner":[n.note,t?void 0:"no ~/.codex/auth.json"].filter(Boolean).join("; ")}}import{existsSync as DC}from"node:fs";import{homedir as MC}from"node:os";import pc from"node:path";function UC(){let e=process.env.HERMES_HOME?.trim(),r=e?pc.resolve(e):pc.join(MC(),".hermes");return pc.join(r,"auth.json")}function Ro(e=new Date().toISOString()){let r=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=UC(),o=DC(n),s=di(r,["auth","status","openai-codex"],{okNote:"hermes openai-codex: logged in",failNote:"hermes openai-codex: not logged in"}),i=t.ok&&s.ok;return{path:"hermes_openai_codex",ready:i,authSource:i?"subscription_hermes":"none",sessionFingerprint:o?Qe(n):void 0,checkedAt:e,note:i?"Hermes openai-codex subscription session bound (ChatGPT Codex OAuth)":[t.note,s.note,o?void 0:"no ~/.hermes/auth.json"].filter(Boolean).join("; ")}}function Tr(e=new Date().toISOString()){let r=dc(e);if(r.ready)return{...r,path:"codex_cli"};let t=Ro(e);return t.ready?{providerId:"codex",ready:!0,authSource:t.authSource,sessionFingerprint:t.sessionFingerprint,checkedAt:t.checkedAt,note:t.note,path:"hermes_openai_codex",hermesOpenAiCodex:t}:{providerId:"codex",ready:!1,authSource:"none",checkedAt:e,path:"none",hermesOpenAiCodex:t,note:[r.note,t.note].filter(Boolean).join("; ")||"Codex CLI and Hermes openai-codex unavailable"}}var df=["low","medium","high"],pf={oauth_local:0,subscription_hermes:0,runner_token:1,api_key_env:2,none:3};function mc(e,r){let t=at(e);return r==="privileged"?t.supportsPrivilegedPlatformActions:r==="low"?t.supportsLowRiskOrchestration:!0}function mf(e,r){let t=at(e.providerId),n=at(r.providerId),o=df.indexOf(t.costTier)-df.indexOf(n.costTier);if(o!==0)return o;let s=pf[e.binding.authSource]-pf[r.binding.authSource];return s!==0?s:e.providerId.localeCompare(r.providerId)}function pi(e){let r=uc().map(a=>({providerId:a.id,binding:e.inventory.bindings[a.id]})).filter(a=>a.binding.ready&&mc(a.providerId,e.riskClass));if(r.length===0)return null;let n=[...r].sort(mf)[0],o="codex";if(n.providerId===o)return{providerId:n.providerId,binding:n.binding};let s=e.inventory.bindings[o],i;return mc(o,e.riskClass)?s.ready||(i=s.note??`${o} not bound`):i=`${e.riskClass} orchestration requires privileged-capable provider`,{providerId:n.providerId,binding:n.binding,escalatedFrom:o,escalatedReason:i}}import{existsSync as WC}from"node:fs";import{homedir as LC}from"node:os";import BC from"node:path";var HC="claude";function FC(){let e=LC();return[BC.join(e,".claude",".credentials.json")]}function mi(e=new Date().toISOString()){let r=Ne(HC,["KYNVER_CLAUDE_BIN","CLAUDE_BIN"]);if(process.env.ANTHROPIC_API_KEY?.trim())return{providerId:"claude",ready:!0,authSource:"api_key_env",sessionFingerprint:dn("ANTHROPIC_API_KEY"),checkedAt:e,note:"ANTHROPIC_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=FC().find(i=>WC(i)),o=di(r,["auth","status"],{okNote:"claude auth status: authenticated",failNote:"claude auth status: not authenticated"}),s=t.ok&&(o.ok||!!n);return{providerId:"claude",ready:s,authSource:"oauth_local",sessionFingerprint:n?Qe(n):void 0,checkedAt:e,note:s?"Local Claude Code OAuth session bound on runner":[t.note,o.note,n?void 0:"no ~/.claude/.credentials.json"].filter(Boolean).join("; ")}}import{existsSync as KC}from"node:fs";import{homedir as $C}from"node:os";import jC from"node:path";var VC="agent";function GC(){let e=$C();return[jC.join(e,".config","cursor","auth.json")]}function fi(e=new Date().toISOString()){let r=Ne(VC,["KYNVER_CURSOR_AGENT_BIN","CURSOR_AGENT_BIN"]);if(process.env.CURSOR_API_KEY?.trim())return{providerId:"cursor",ready:!0,authSource:"api_key_env",sessionFingerprint:dn("CURSOR_API_KEY"),checkedAt:e,note:"CURSOR_API_KEY present (env binding \u2014 cloud credits path, no token stored in Kynver)"};let t=Ze(r,["-v"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=GC().find(s=>KC(s)),o=!!n&&t.ok;return{providerId:"cursor",ready:o,authSource:"oauth_local",sessionFingerprint:n?Qe(n):void 0,checkedAt:e,note:o?"Local Cursor/Composer OAuth session bound on runner":[t.note,n?void 0:"no ~/.config/cursor/auth.json"].filter(Boolean).join("; ")}}import{existsSync as YC,readFileSync as JC}from"node:fs";import{homedir as qC}from"node:os";import fc from"node:path";var zC=["OPENAI_API_KEY","ANTHROPIC_API_KEY","KYNVER_API_KEY","KYNVER_BASE_URL"];function XC(){let e=process.env.HERMES_HOME?.trim(),r=e?fc.resolve(e):fc.join(qC(),".hermes");return fc.join(r,".env")}function QC(e){try{let r=JC(e,"utf8"),t=[];for(let n of zC)new RegExp(`^${n}=`,"m").test(r)&&t.push(n);return t}catch{return[]}}function gc(e=new Date().toISOString()){let r=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),t=Ze(r,["--version"],{okNote:`${r} CLI available`,failPrefix:`${r} CLI not available`}),n=XC(),o=YC(n),s=o?QC(n):[],a=s.some(c=>c.endsWith("_API_KEY"))?"api_key_env":o?"oauth_local":"none",l=t.ok&&o;return{adapterId:"hermes",cliAvailable:t.ok,profileBound:o,authSource:a,sessionFingerprint:o?Qe(n):void 0,checkedAt:e,note:l?`Hermes profile bound (${s.length?`keys: ${s.join(", ")}`:"no API keys detected"})`:[t.note,o?void 0:"no ~/.hermes/.env"].filter(Boolean).join("; ")}}function hc(e={}){let r=e.nowIso?.()??new Date().toISOString(),t=Tr(r),n={codex:t,cursor:fi(r),claude:mi(r)},o=Object.values(n).filter(s=>s.ready).length;return{generatedAt:r,bindings:n,cloudApiCredits:{anthropicApiKey:!!process.env.ANTHROPIC_API_KEY?.trim(),openaiApiKey:!!process.env.OPENAI_API_KEY?.trim(),codexApiKey:!!process.env.CODEX_API_KEY?.trim()},hermes:gc(r),hermesOpenAiCodex:Ro(r),codexAdapterPath:t.path,readyCount:o}}function ZC(e,r){switch(e){case"codex":return Tr(r);case"cursor":return fi(r);case"claude":return mi(r)}}var ew=[/\bprivileged\b/i,/\bproduction\s+db\b/i,/\bdb:push\b/i,/\bmigration\b/i,/\bdeploy\b/i,/\bsecrets?\b/i,/\bstripe\b/i,/\[require-approval\]/i,/\[operator-only\]/i],rw=[/\borchestration\b/i,/\bplan[- ]?progress\b/i,/\bstatus\s+sync\b/i,/\bheartbeat\b/i,/\bboard[- ]?drain\b/i,/\bmaintenance\b/i,/\[orchestration:\s*low-risk\]/i];function kc(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function ff(e){let r=kc(e,"executorRef").toLowerCase(),t=kc(e,"title").toLowerCase(),n=kc(e,"description").toLowerCase(),o=`${r}
|
|
20
20
|
${t}
|
|
21
|
-
${n}`;return jC.some(s=>s.test(o))?"privileged":r.includes("provider:claude")||r.includes("deep_review")||r.includes("security")||r.includes("landing")||r.includes("review")||t.startsWith("land:")||r.includes("implementer")||r.includes("repair")||t.includes("implement")?"elevated":VC.some(s=>s.test(o))?"low":"elevated"}function GC(e){let r=at(e.provider),t=e.escalatedFrom&&e.escalatedReason?`Escalated from ${e.escalatedFrom} (${e.escalatedReason}); using ${r.displayName} (${r.costTier} tier)`:`${r.displayName} selected for ${e.riskClass} orchestration (${r.costTier} tier, auth=${e.authSource})`;return{provider:e.provider,model:e.model,authSource:e.authSource,costTier:r.costTier,riskClass:e.riskClass,costRationale:t,routingRule:e.routingRule,escalatedFrom:e.escalatedFrom,escalatedReason:e.escalatedReason}}function YC(e){let r=e.inventory??gc();return e.codexBinding?{...r,bindings:{...r.bindings,codex:e.codexBinding}}:r}function lt(e){let r=GC({provider:e.providerId,model:e.model,authSource:e.binding.authSource,riskClass:e.riskClass,routingRule:e.routingRule,escalatedFrom:e.escalatedFrom,escalatedReason:e.escalatedReason});return{provider:e.providerId,model:e.model,rule:r.routingRule,audit:r}}function kc(e){let r=e.task??{},t=uf(r),n=YC({inventory:e.inventory,codexBinding:e.codexBinding??(e.inventory?null:Tr())}),o=e.preferLowCost===!1?null:e.explicitProvider?.trim().toLowerCase(),s=e.explicitModel?.trim()||void 0,i=Ie;if(o==="codex"||o==="provider:codex"){let c=n.bindings.codex;if(!c.ready){let u=ui({inventory:n,riskClass:t});return lt(u?{providerId:u.providerId,binding:u.binding,riskClass:t,routingRule:"orchestration:explicit_codex_unavailable_cost_aware",model:s,escalatedFrom:"codex",escalatedReason:c.note??"codex oauth not bound"}:{providerId:i,binding:n.bindings[i],riskClass:t,routingRule:"orchestration:codex_unavailable_escalate_cursor",model:s,escalatedFrom:"codex",escalatedReason:c.note??"codex oauth not bound"})}return lt({providerId:"codex",binding:c,riskClass:t,routingRule:"orchestration:explicit_codex",model:s})}if(o==="cursor"||o==="provider:cursor"){let c=n.bindings.cursor;if(c.ready)return lt({providerId:"cursor",binding:c,riskClass:t,routingRule:"orchestration:explicit_cursor",model:s})}if(o==="claude"||o==="provider:claude"){let c=n.bindings.claude;if(c.ready)return lt({providerId:"claude",binding:c,riskClass:t,routingRule:"orchestration:explicit_claude",model:s})}let a=ui({inventory:n,riskClass:t});if(a)return lt({providerId:a.providerId,binding:a.binding,riskClass:t,routingRule:`orchestration:cost_aware_${a.providerId}`,model:s,escalatedFrom:a.escalatedFrom,escalatedReason:a.escalatedReason});let l=n.bindings.codex;return lt({providerId:i,binding:n.bindings[i],riskClass:t,routingRule:l.ready?"orchestration:inventory_empty_default_cursor":"orchestration:codex_unavailable_default_cursor",model:s,...l.ready?{}:{escalatedFrom:"codex",escalatedReason:l.note??"codex oauth not bound"}})}jr();C();import{closeSync as pf,openSync as mf}from"node:fs";import{spawn as QC}from"node:child_process";var JC=/-(?:thinking(?:-(?:high|medium|low|minimal|max|none))?|high|medium|low|minimal)$/i;function qC(e){return e.replace(JC,"")}var zC=/^(?:gpt-|gpt5|o1|o3|o4|gemini-|grok-|composer|deepseek|llama|mistral|qwen|command-)/i;function yc(e){return/^claude[-_]/i.test(e)||/^(?:opus|sonnet|haiku)\b/i.test(e)}var XC=new Set(["cursor"]);function df(e){let r=e.trim().toLowerCase();return XC.has(r)?"auto":null}function mi(e,r){let t=(e??"").trim();if(!t)return{ok:!0,model:r,normalized:!1};let o=qC(t).trim()||r;return zC.test(o)||!yc(o)&&o!==r?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is not a Claude model \u2014 the "claude" provider drives the Claude CLI, which only accepts claude-* model ids (got "${o}"). Pick a Claude model or switch the worker provider.`}:o!==t?{ok:!0,model:o,normalized:!0,requested:t,note:`normalized model "${t}" \u2192 "${o}" (the Claude CLI rejects reasoning-effort suffixes)`}:{ok:!0,model:o,normalized:!1}}function ct(e,r){let t=(e??"").trim();return t?yc(t)?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is a Claude model but the worker provider is "codex". Switch the provider or pick a Codex/OpenAI model.`}:{ok:!0,model:t,normalized:!1}:{ok:!0,model:r,normalized:!1}}function fi(e,r){let t=(e??"").trim();if(!t)return{ok:!0,model:r,normalized:!1};let n=df(t);return n?{ok:!0,model:n,normalized:!0,requested:t,note:`normalized model "${t}" \u2192 "${n}" (Cursor provider alias \u2014 use "auto" or a composer id, not "cursor")`}:yc(t)?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is a Claude model but the worker provider is "cursor". Switch the provider to "claude" or pick a Cursor model.`}:{ok:!0,model:t,normalized:!1}}var dn="claude-sonnet-4-6",ff={name:"claude",defaultModel:dn,preflightModel(e){return mi(e,dn)},start(e){let r=mi(e.model,dn);if(!r.ok)throw new Error(`claude provider model preflight failed: ${r.note}`);let t=r.model,n=mf(e.stdoutPath,"a"),o=mf(e.stderrPath,"a"),s=["ignore",n,o],i=QC("claude",["--model",t,"-p","--verbose","--permission-mode","bypassPermissions","--output-format","stream-json","--include-partial-messages",e.prompt],pe({cwd:e.worktreePath,detached:!0,stdio:s,env:We(process.env)}));if(pf(n),pf(o),!i.pid)throw new Error("failed to spawn claude worker process (is the `claude` CLI on PATH?)");return i.unref(),{pid:i.pid,model:t}}};jr();C();import{closeSync as yf,existsSync as rw,openSync as Rf}from"node:fs";import{spawn as vf}from"node:child_process";jr();C();import{closeSync as gf,openSync as hf}from"node:fs";import{spawn as ZC}from"node:child_process";var gi=process.env.KYNVER_CODEX_DEFAULT_MODEL?.trim()||"gpt-5.4";function ew(){return We({...process.env,CI:"1",NO_COLOR:"1",HERMES_ACCEPT_HOOKS:process.env.HERMES_ACCEPT_HOOKS??"1"})}function kf(e,r){let t=process.env.KYNVER_HERMES_CODEX_MAX_TURNS?.trim()||"40";return["chat","-q",r,"--provider","openai-codex","-m",e,"-Q","--accept-hooks","--max-turns",t,"--toolsets","hermes-cli"]}var Rc={name:"hermes-codex",defaultModel:gi,preflightModel(e){return ct(e,gi)},start(e){let r=ct(e.model,gi);if(!r.ok)throw new Error(`hermes-codex provider model preflight failed: ${r.note}`);let t=r.model,n=hf(e.stdoutPath,"a"),o=hf(e.stderrPath,"a"),s=["ignore",n,o],i=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),a=kf(t,e.prompt),l=ZC(i,a,pe({cwd:e.worktreePath,detached:!0,shell:!1,stdio:s,env:ew()}));if(gf(n),gf(o),!l.pid)throw new Error(`failed to spawn Hermes openai-codex worker (is \`${i}\` on PATH? run \`hermes auth status openai-codex\`)`);return l.unref(),{pid:l.pid,model:t}}};function tw(){return process.env.KYNVER_CODEX_DEFAULT_MODEL?.trim()||"gpt-5.4"}var Dr=tw();function nw(){return process.env.KYNVER_CODEX_BIN?.trim()||process.env.CODEX_BIN?.trim()||"codex"}function ow(){return We({...process.env,CI:"1",NO_COLOR:"1"})}function bf(e,r){return["exec","--sandbox","read-only","--ask-for-approval","never","--model",e,r]}function sw(e,r,t){if(!(process.platform!=="win32"&&rw("/usr/bin/script")))return vf(e,r,t);let o=[e,...r].map(s=>`'${s.replace(/'/g,"'\\''")}'`).join(" ");return vf("script",["-qfc",o,"/dev/null"],t)}var vc={name:"codex",defaultModel:Dr,preflightModel(e){return ct(e,Dr)},start(e){if(Tr().path==="hermes_openai_codex")return Rc.start(e);let t=ct(e.model,Dr);if(!t.ok)throw new Error(`codex provider model preflight failed: ${t.note}`);let n=t.model,o=Rf(e.stdoutPath,"a"),s=Rf(e.stderrPath,"a"),i=["ignore",o,s],a=nw(),l=bf(n,e.prompt),c=sw(a,l,pe({cwd:e.worktreePath,detached:!0,shell:!1,stdio:i,env:ow()}));if(yf(o),yf(s),!c.pid)throw new Error(`failed to spawn Codex worker (is \`${a}\` on PATH? run \`codex login\` or set CODEX_API_KEY)`);return c.unref(),{pid:c.pid,model:n}}};var iw="claude-sonnet-4-6",lc="composer-2.5";function hi(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function Sf(e){return e.toLowerCase()}function Sc(e=y()){let r=e.defaultModel?.trim();if(r)return r;let t=process.env.KYNVER_DEFAULT_MODEL?.trim();return t||iw}function bc(e){let r=(e??"").toLowerCase();return!r||r.includes("composer")||r.includes("cursor")||r.includes("codex")||r.startsWith("gpt-")||r.startsWith("gpt5")?"cursor":/^claude[-_]/i.test(r)||/^(?:opus|sonnet|haiku)\b/i.test(r)?"claude":"cursor"}function aw(e,r){let t=e.trim().toLowerCase(),n=r?.trim();return t==="cursor"?{model:lc,provider:"cursor",rule:n&&n!=="cursor"?"explicit:model_provider_alias_overrode_provider":"explicit:model_provider_alias",requestedModel:e}:t==="claude"||t==="anthropic"?{model:dn,provider:"claude",rule:n&&n!=="claude"?"explicit:model_provider_alias_overrode_provider":"explicit:model_provider_alias",requestedModel:e}:null}function Cf(e,r){return!!(e.includes("deep")&&e.includes("review")||e.includes("security")||e.includes("plan_author")||e.includes("plan-author")||r.includes("deep review")||r.includes("security review")||e.includes("plan")&&!e.includes("review")&&(e.includes("author")||e.includes("strategy")))}function lw(e){let r=Sf(hi(e,"executorRef")),t=hi(e,"title").toLowerCase(),n=hi(e,"priority")||"normal",o=Sf(hi(e,"roleLane"));if(r.includes("provider:codex")||r.startsWith("codex:"))return{provider:"codex",model:Dr,rule:"lane:codex_orchestration"};if(r.includes("cursor")||r.includes("composer")||r.includes("copilot")||o==="implementer"||o==="repair_implementer")return{provider:"cursor",rule:"lane:implementation"};if(r.includes("codex"))return{provider:"codex",model:Dr,rule:"lane:codex_orchestration"};if(r.includes("landing")||t.startsWith("land:")||t.includes(" merge"))return{provider:"cursor",rule:"lane:landing"};if(r.includes("review")||/^review[\s:]/.test(t)||o.includes("review"))return Cf(r,t)||o==="deep_reviewer"?{provider:"cursor",rule:"lane:deep_review"}:{provider:"cursor",rule:"lane:review"};if(Cf(r,t)||o==="plan_author")return{provider:"cursor",rule:"lane:planning"};if(n==="critical")return{provider:"cursor",rule:"priority:critical"};if(n==="high")return{provider:"cursor",rule:"priority:high"};if(n==="low")return{provider:"cursor",rule:"priority:low"};let s=Sc();return{model:s,provider:bc(s),rule:"default:global"}}function ki(e){let r;if(e.explicitModel?.trim()){let o=e.explicitModel.trim(),s=aw(o,e.explicitProvider);s?r=s:r={model:o,provider:e.explicitProvider?.trim()||bc(o),rule:"explicit:cli",requestedModel:o}}else if(e.task&&Object.keys(e.task).length>0){let o=lw(e.task);r={...o,requestedModel:o.model}}else{let o=Sc();r={model:o,provider:e.explicitProvider?.trim()||bc(o),rule:"default:global",requestedModel:o}}let t=ac({routing:r,task:e.task,explicitProvider:e.explicitProvider,explicitProviderIsOperatorOverride:e.explicitProviderIsOperatorOverride});if(!e.task||Object.keys(e.task).length===0||t.rule==="explicit:model_provider_alias"||t.rule==="explicit:model_provider_alias_overrode_provider"||t.rule==="explicit:cli"||Xe(t.provider)&&(e.explicitProviderIsOperatorOverride||li(e.task)))return t;let n=kc({task:e.task,explicitProvider:e.explicitProvider??t.provider,explicitModel:t.model});return{provider:n.provider,model:n.provider==="codex"?n.model??t.model??Dr:t.model,rule:n.rule,requestedModel:t.requestedModel,orchestrationAudit:n.audit}}function wf(e,r,t){return e||r||t||Sc()||dn}function _f(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function xf(){return{maxTaskAttempts:_f(process.env.KYNVER_MAX_TASK_ATTEMPTS,Math.floor(it("harness.maxTaskAttempts",4))),dispatchCooldownMs:_f(process.env.KYNVER_DISPATCH_COOLDOWN_MS,Math.floor(it("harness.dispatchCooldownMs",5e3)))}}I();import pw from"node:path";T();z();C();var Cc="kynver-harness:",Ef="@runner:";function wc(e){return e?.trim()?e.trim():null}function cw(e){let r=wc(e);if(!r?.startsWith(Cc))return null;let t=r.slice(Cc.length),n=t.indexOf(Ef);return n>=0?t.slice(0,n).trim()||null:t.trim()||null}function _c(e,r){let t=e.trim(),n=r.trim();return`${Cc}${t}${Ef}${n}`}function xc(e,r){let t=wc(r);return t?cw(e)===t:!1}function yi(e){let r=wc(e.workerLeaseOwner);return r&&xc(r,e.runId)?r:_c(e.runId,e.runnerId)}import Pf from"node:os";Oe();Oe();import uw from"node:os";function dw(e=process.env){return Ae(e).boxKind}function Ro(e,r){let t=(r??uw.hostname()).trim().toLowerCase().replace(/\s+/g,"-")||"unknown-host";return`${e}:${t}`}function Mr(e){return e?.trim()?e.trim():null}function er(e={}){let r=e.env??process.env;return{runnerId:Mr(r.KYNVER_RUNTIME_ID)??Mr(r.OPENCLAW_RUNTIME_ID)??Mr(r.HOSTNAME)??Pf.hostname(),hostname:Mr(r.HOSTNAME)??Pf.hostname(),profile:Mr(r.KYNVER_RUNNER_PROFILE)??Mr(r.OPENCLAW_RUNNER_PROFILE),harnessRepo:Mr(r.KYNVER_HARNESS_REPO)??Mr(r.KYNVER_DEFAULT_REPO),runId:e.runId??null,instructionBundleVersion:Nr()}}I();async function pn(e){let r=new Map,t=e.agentOsId?.trim();if(!t||e.taskIds.length===0)return r;let n=V(e.baseUrl);try{let o=await J(e.secret,t,{baseUrl:n}),s=`${n}/api/agent-os/by-id/${encodeURIComponent(t)}/harness/monitor/task-leases`,i=await re(s,o,{taskIds:[...new Set(e.taskIds)]},{agentOsId:t,baseUrl:n});if(!i.ok||!i.response||typeof i.response!="object")return r;let a=i.response.tasks;if(!Array.isArray(a))return r;for(let l of a)l?.taskId&&r.set(l.taskId,l)}catch{}return r}T();async function Ri(e){let r=e.worker.leaseOwner?.trim()??null,t=e.worker.leaseToken?.trim()??null;if(t)return{leaseOwner:r,leaseToken:t};let n=e.worker.taskId?.trim();if(!n)return{leaseOwner:r,leaseToken:null};let s=(await pn({agentOsId:e.agentOsId,taskIds:[n],baseUrl:e.baseUrl,secret:e.secret})).get(n),i=s?.leaseOwner?.trim()??null,a=s?.leaseToken?.trim()??null;if(!a)return{leaseOwner:r??i,leaseToken:null};let l=r??i;return(!e.worker.leaseToken||e.worker.leaseToken!==a)&&K(e.worker.runId,{...e.worker,...l?{leaseOwner:l}:{},leaseToken:a}),{leaseOwner:l,leaseToken:a}}function Af(e,r){return w(pw.join(x(e),"workers",b(r),"worker.json"),void 0)}async function vi(e,r){let t=L(e),n=String(r.agentOsId||"");if(!n)return{renewed:[],failed:[],skipped:[]};let o=V(r.baseUrl?String(r.baseUrl):void 0),s=await J(r.secret?String(r.secret):void 0,n,{baseUrl:o}),i=Number(r.leaseMs)>0?Math.floor(Number(r.leaseMs)):bi,a=er({runId:e}).runnerId,l=[],c=[],u=[];for(let d of Object.keys(t.workers||{})){let m=Af(e,d);if(!m?.taskId||!m.agentOsId){u.push(d);continue}if(!H(m.pid)){u.push(d);continue}if(D(m).status==="done"){u.push(d);continue}let f=yi({runId:e,workerLeaseOwner:m.leaseOwner??null,runnerId:a}),h=await Ri({worker:m,agentOsId:n,baseUrl:o,secret:s}),k=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/${encodeURIComponent(m.taskId)}/renew-lease`,g=await re(k,s,{leaseOwner:h.leaseOwner??f,leaseDurationMs:i,...h.leaseToken?{leaseToken:h.leaseToken}:{}},{agentOsId:n,baseUrl:o});if(g.ok){l.push(d);continue}let R=g.response&&typeof g.response=="object"&&"reason"in g.response?String(g.response.reason??`http ${g.status}`):`http ${g.status}`;c.push({worker:d,reason:R})}return{renewed:l,failed:c,skipped:u}}function If(e,r){let t=L(e);for(let n of Object.keys(t.workers||{})){let o=Af(e,n);if(!(!o||o.taskId!==r||!H(o.pid)||D(o).status==="done"))return!0}return!1}Pe();T();T();import{existsSync as N_,mkdirSync as T_}from"node:fs";import mn from"node:path";var mw=/<!--\s*harness-contract:\s*(\{[\s\S]*?\})\s*-->/i,fw="next-action-fix:";function Si(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function Of(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:Si(e)}function gw(e){let r=(e.title??"").trim().toLowerCase();if(r.startsWith("fix:")||r.startsWith("repair:"))return!0;let t=(e.executorRef??"").toLowerCase();return!!(t.startsWith(fw)||t.includes("repair")||t.includes("unblock"))}function hw(e){let r={repairEnforceOriginalPr:!1,targetPrUrl:null,targetPrBranch:null};if(!e)return r;let t=e.match(mw);if(!t?.[1])return r;try{let n=JSON.parse(t[1]),o=Si(String(n.targetPrUrl??n.target_pr_url??"")),s=Si(String(n.targetPrBranch??n.target_pr_branch??""));return{repairEnforceOriginalPr:n.repairEnforceOriginalPr===!0||n.repair_enforce_original_pr===!0||!!o,targetPrUrl:o?Of(o):null,targetPrBranch:s}}catch{return r}}function Nf(e){if(!gw(e))return null;let r=hw(e.description),t=e.prUrl?Of(e.prUrl):null,n=r.targetPrUrl??t;return n?{targetPrUrl:n,targetPrBranch:r.targetPrBranch??Si(e.branch)}:null}function Tf(e){return["Repair target PR policy:","- Work on the existing target PR branch \u2014 do not open a duplicate repair PR by default.",`- Canonical target PR: ${e.targetPrUrl}`,...e.targetPrBranch?[`- Canonical target branch: \`${e.targetPrBranch}\` (checkout is already on this branch).`]:[],`- Reconcile ${e.targetPrUrl} in structured finalResult.targetPrReconciliation.`,"- Only supersede the original when the branch is inaccessible: set supersedesOriginalTargetPr: true with reason and close/comment on the original PR."]}function Ec(e){let r=e.ownedPaths.length?`Owned paths: ${e.ownedPaths.join(", ")}. Do not edit outside these paths without stopping and reporting why.`:"Owned paths: unrestricted for this worker, but keep edits tightly scoped.",t=!!e.model?.toLowerCase().includes("haiku"),n=t?"compact":"full",o=t?e.planId?`Active planId: ${e.planId}`:"No planId on this worker.":e.planId?`Active planId: ${e.planId}${e.taskId?` \xB7 taskId: ${e.taskId}`:""}`:"No planId on this worker \u2014 still emit progress when you touch plan-scoped work.",s=[...cn(`worker.prompt.progress.${n}`).split(`
|
|
22
|
-
`),o],i=
|
|
23
|
-
`),a=
|
|
24
|
-
`);return["You are running under the Kynver AgentOS runtime.","Immediately state your plan before editing.",r,`Worktree: ${e.worktreePath}`,`Progress heartbeat file: ${e.heartbeatPath}`,"After each major step, append one JSON line to the heartbeat file with fields: ts, phase, summary, changedFiles, blocker.","Before exiting, append a terminal heartbeat with phase `complete` and a structured finalResult object; if you cannot complete, append blocker plus the recovery next action instead of exiting silently.","Final response must include files changed, verification commands, and unresolved risks.",...
|
|
25
|
-
`),"",...s,"",...i,"",...a,"",...e.contextEnvelopeMarkdown?.trim()?[e.contextEnvelopeMarkdown.trim(),""]:[],...e.personaMarkdown?.trim()?[e.personaMarkdown.trim(),""]:[],...e.instructionPolicyMarkdown?.trim()?["Operating rules (from AgentOS memory policy):",e.instructionPolicyMarkdown.trim(),""]:[],...e.memoryQualityMarkdown?.trim()?[e.memoryQualityMarkdown.trim(),""]:[],...e.repairTargetPrUrl?[...
|
|
26
|
-
`)}C();
|
|
27
|
-
`).map(r=>r.trim()).find(Boolean)??""}function
|
|
28
|
-
`)}function Wc(e){if(e.snapshot.changedFiles.length===0)return{ok:!0,prUrl:e.prUrl,headCommit:e.snapshot.headCommit??So(e.snapshot.worktreePath,e.exec)??void 0};let r=Pi({worktreePath:e.snapshot.worktreePath,branch:e.snapshot.branch,commitMessage:e.commitMessage,hasDirtyFiles:!0,exec:e.exec});return r.ok?{ok:!0,prUrl:e.prUrl,headCommit:r.headCommit??e.snapshot.headCommit??void 0,committed:r.committed,pushed:r.pushed}:{ok:!1,reason:`PR-ready handoff blocked: ${r.detail??"git commit/push failed"}`,nextAction:"Commit and push the dirty worker changes to the existing PR branch, then rerun `kynver worker complete`."}}function Ai(e,r=Ei){let t=e.prUrlHint??Mc(e.status.finalResult)??null,n=Yf(e.status,{prUrl:t,headCommit:null}),o=e.run.baseCommit?.trim()||e.run.base?.trim()||"origin/main";if(!Uc({dispatched:e.worker.dispatched,routingRule:e.worker.routingRule,personaSlug:e.worker.personaSlug,prUrl:t,taskTitle:e.worker.taskTitle,executorRef:e.worker.executorRef,parentTaskId:e.worker.parentTaskId,taskPrUrl:e.worker.taskPrUrl,repairTargetPrUrl:e.worker.repairTargetPrUrl,baseRef:o,exec:r,worker:e.worker,snapshot:n}).required)return t?Wc({snapshot:n,prUrl:t,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r}):{ok:!0};if(t)return Wc({snapshot:n,prUrl:t,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r});if(!Jw(r)){let g=n.changedFiles.length;return{ok:!1,reason:`PR-ready handoff blocked: ${g?`${g} uncommitted change(s) with no PR URL`:"committed branch with no PR URL"}`,nextAction:"Install and authenticate GitHub CLI (`gh auth login`), then commit, push, and run `gh pr create` (or rerun `kynver worker complete` after the PR exists)."}}let i=zf(n.worktreePath,r);if(!i)return{ok:!1,reason:"PR-ready handoff blocked: could not resolve github.com origin for the worktree",nextAction:"Ensure `origin` points at GitHub, push the branch, open a PR, and rerun `kynver worker complete`."};let a=e.worker.repairTargetPrUrl?.trim();if(a){let g=!1,R=!1,O=n.headCommit??So(n.worktreePath,r)??void 0;if(n.changedFiles.length>0){let _=Pi({worktreePath:n.worktreePath,branch:n.branch,commitMessage:`fix(harness): repair target PR ${a}`,hasDirtyFiles:!0,exec:r});if(!_.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${_.detail??"git commit/push failed"}`,nextAction:"Commit and push to the target PR branch, then rerun `kynver worker complete`."};g=_.committed,R=_.pushed,O=_.headCommit??O}else{let _=r.git(n.worktreePath,["push","-u","origin",n.branch]);if(_.status!==0&&!/already up to date/i.test(_.stderr||_.stdout))return{ok:!1,reason:`PR-ready handoff blocked: ${_.stderr||_.stdout||"git push failed"}`,nextAction:"Push the target branch to origin, then rerun `kynver worker complete`."};R=_.status===0}return{ok:!0,prUrl:a,headCommit:O,committed:g,pushed:R}}let l=xi(n.worktreePath,i,n.branch,r);if(l)return Wc({snapshot:n,prUrl:l,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r});let c=n.changedFiles.length>0,u=!1,d=!1,m=n.headCommit??void 0,p=Pi({worktreePath:n.worktreePath,branch:n.branch,commitMessage:`chore(harness): PR-ready handoff for ${e.worker.name}`,hasDirtyFiles:c,exec:r});if(c&&!p.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${p.detail??"git commit/push failed"}`,nextAction:"Commit and push the branch, run `gh pr create`, then rerun `kynver worker complete`."};if(c){if(u=p.committed,d=p.pushed,!p.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${p.detail??"git push failed"}`,nextAction:"Fix git auth or merge conflicts, push the branch, run `gh pr create`, then rerun `kynver worker complete`."}}else{let g=r.git(n.worktreePath,["push","-u","origin",n.branch]);if(g.status!==0&&!/already up to date/i.test(g.stderr||g.stdout))return{ok:!1,reason:`PR-ready handoff blocked: ${g.stderr||g.stdout||g.error||"git push failed"}`,nextAction:"Push the branch to origin, run `gh pr create`, then rerun `kynver worker complete`."};d=g.status===0}m=p.headCommit??m??So(n.worktreePath,r)??void 0;let f=m?Qf(n.worktreePath,i,m,r):null;if(f)return{ok:!0,prUrl:f.prUrl,headCommit:m,committed:u,pushed:d,created:!1};let h=e.run.base?.trim()||"main",k=Xf({worktreePath:n.worktreePath,repo:i,branch:n.branch,base:h.replace(/^origin\//,""),title:qw(e.worker.name,e.worker.runId),body:zw(e.worker.taskId,e.worker.name,e.worker.runId),exec:r});if(!k.ok||!k.prUrl){if(Vf(k.detail))return{ok:!0,headCommit:m??void 0,committed:u,pushed:d};let g=n.changedFiles.length;return{ok:!1,reason:`PR-ready handoff blocked: ${g?`${g} uncommitted change(s) and no PR URL after handoff attempt`:"no PR URL after handoff attempt"}${k.detail?` (${k.detail})`:""}`,nextAction:"Run `gh pr create` on the worker branch (or fix `gh` auth), attach the PR URL to the task, then rerun `kynver worker complete`."}}return{ok:!0,prUrl:k.prUrl,headCommit:m??void 0,committed:u,pushed:d,created:k.created}}z();Jt();function Ii(e){return e.filter(r=>{let t=r.trim(),n=t.startsWith("??")?t.slice(2).trim():t.length>3?t.slice(3).trim():t;return n!=="node_modules"&&!n.startsWith("node_modules/")})}function Zf(e){let r=e.trim();return r.startsWith("??")?r.slice(2).trim():r.length>3&&/^[ MADRCU?!]{2} /.test(r.slice(0,3))?r.slice(3).trim():r}function eg(e){return Array.isArray(e)?e.map(r=>typeof r=="string"?r.trim():"").filter(Boolean):[]}function rg(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function ng(e){let r=rg(e);if(!r)return[];let t=rg(r.worktreeHandoff),n=eg(t?.disposableArtifactsRemoved);return n.length?n:eg(r.disposableArtifactsRemoved)}function tg(e){return e.replace(/\\/g,"/").replace(/^\.\//,"").replace(/\/+$/,"")}function og(e,r){let t=Ii(e);if(t.length===0)return!0;if(r.length===0)return!1;let n=new Set(r.map(o=>tg(o)));return t.every(o=>{let s=tg(Zf(o));return n.has(s)})}function Oi(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function sg(e){return Array.isArray(e)?e.map(r=>typeof r=="string"?r.trim():"").filter(Boolean):[]}function Xw(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function Qw(e){let r=sg(e.disposableArtifactsRemoved),t=ng(e.finalResult);return[...new Set([...r,...t])]}function ig(e){let r=sg(e.changedFiles),t=Ii(r),n=Qw(e),o=t.length===0||og(r,n);return Oi(e.prUrl)?o?{allowed:!0,state:"pr_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with a PR attached; commit or discard before completing`}:Oi(e.headCommit)?o?{allowed:!0,state:"commit_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) on top of a commit; commit or discard before completing`}:Oi(e.artifactBundlePath)||Oi(e.patchPath)?o?{allowed:!0,state:"commit_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with a patch/bundle handoff; clean the tree before completing`}:o?{allowed:!0,state:"clean",materialDirtyCount:0}:Xw(e.finalResult)?{allowed:!1,state:"dirty_worktree_no_pr",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with no commit or PR; commit, open a PR, discard, or remove one-off files via \`kynver worker discard-disposable\` before completing`}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with no final result`}}T();z();C();import Zw from"node:path";var e_=new Set(["awaiting_review","blocked","done","needs_input","waiting","scheduled","ready","cancelled","failed"]);function ag(e){return!!(typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim())}function r_(e){if(typeof e=="string"){let r=e.trim();return r.length?r:null}if(e&&typeof e=="object"&&!Array.isArray(e)){let r=e,t=r.summary??r.finalSummary??r.message;if(typeof t=="string"&&t.trim())return t.trim();try{return JSON.stringify(e)}catch{return null}}return null}function pt(e){let r=e.finalResult??null,t=typeof e.lastHeartbeatSummary=="string"?e.lastHeartbeatSummary:r_(r);return{finalResult:r??t??"completed",summary:t}}function Lc(e,r,t){if(ag(e)&&e.status==="done"&&e.completionSnapshot!=null)return;let n=new Date().toISOString(),o=pt(r),s=t?.source?.trim();e.completionReportedAt=n,e.completionSnapshot=o,e.status="done",s&&(e.completionAckSource=s),K(e.runId,e)}function t_(e){let r=new Map,n=e.response?.tick?.filteredItems;if(!Array.isArray(n))return r;for(let o of n){if(o.kind!=="task"||typeof o.id!="string")continue;let s=typeof o.taskStatus=="string"?o.taskStatus.trim():"";s&&r.set(o.id,s)}return r}function lg(e,r){let t=t_(r);if(t.size===0)return[];let n=L(e),o=[];for(let s of Object.keys(n.workers||{})){let i=w(Zw.join(x(n.id),"workers",b(s),"worker.json"),void 0);if(!i?.taskId||ag(i))continue;let a=t.get(i.taskId);if(!a||a==="running"||!e_.has(a))continue;let l=D(i,{base:n.base,baseCommit:n.baseCommit});Lc(i,l,{source:`board-task-${a}`}),o.push({worker:s,taskId:i.taskId,taskStatus:a})}return o}C();C();import Ni from"node:path";var n_=/^[a-z0-9][a-z0-9._-]{0,127}$/i,o_=/^[a-z0-9][a-z0-9._-]{0,63}$/i,Bc=new Set(["undefined","null"]),cg="usage: kynver worker <action> --run RUN_ID --name WORKER_NAME";function Co(e){let r=e.trim();if(!n_.test(r))throw new Error(`invalid run id: ${e}`);return r}function ug(e){let r=e.trim();if(!o_.test(r))throw new Error(`invalid worker name: ${e}`);return r}function Hc(e){return typeof e=="string"?e.trim():""}function Fe(e){let r=Hc(e.run),t=Hc(e.name);return(!r||Bc.has(r))&&_r(`missing --run RUN_ID (${cg})`),(!t||Bc.has(t))&&_r(`missing --name WORKER_NAME (${cg})`),{runId:Co(r),workerName:ug(t)}}function Ti(e){let r=Hc(e.run);return(!r||Bc.has(r))&&_r("missing --run RUN_ID (usage: kynver run status --run RUN_ID)"),Co(r)}function Fc(e){let r=Ni.resolve(e);if(r.includes(".."))throw new Error("repo path must not contain .. segments");return r}function s_(e,r){return r.map(t=>{let n=Ni.resolve(e,t),o=Ni.relative(e,n);if(o.startsWith("..")||Ni.isAbsolute(o))throw new Error(`owned path escapes repo: ${t}`);return n})}function i_(e){return!Number.isFinite(e)||e<=0||e>500?40:Math.floor(e)}async function dg(e,r,t){let n=await fetch(e,{method:"POST",headers:He(r),body:JSON.stringify(t)}),o=null;try{o=await n.json()}catch{o=null}return{ok:n.ok,status:n.status,parsed:o}}function a_(e){if(e&&typeof e=="object"){let r=e.error;if(typeof r=="string"&&r.trim())return r.trim()}}function pg(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function wo(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function l_(e){return e.completionBlocker?`blocked:${e.completionBlocker}`:e.completionOutcome?e.completionOutcome:e.completionReportedAt?"completion_acknowledged":e.finished?"worker_finished":"in_progress"}function c_(e){return e.completionBlocker?"Resolve completion blocker, then rerun `kynver worker complete`.":e.completionOutcome==="review_scheduled"||e.completionOutcome==="review_already_scheduled"?"Await review lane and landing decision in Command Center.":e.completionOutcome==="needs_attention"?"Inspect blocker/attention reason in Command Center and dispatch a repair task.":e.finished&&!e.completionReportedAt?"Post completion acknowledgement to AgentOS (`kynver worker complete`).":null}function fg(e){let r=e?.trim();return r?/completion acknowledged but board not advanced/i.test(r)&&/task already terminal/i.test(r):!1}function u_(e){return e.prUrl?"pr_handoff":e.headCommit?"commit_handoff":e.changedFiles.length>0?"dirty_worktree":"none"}function _o(e,r){(e.completionBlocker??void 0)!==(r??void 0)&&(r?e.completionBlocker=r:delete e.completionBlocker,K(e.runId,e))}function d_(e){e.completionBlocker&&(delete e.completionBlocker,K(e.runId,e))}function Di(e){return e?{base:e.base,baseCommit:e.baseCommit}:{}}function p_(e,r){return{...e,...r.prUrl?{prUrl:r.prUrl}:{},...r.headCommit?{headCommit:r.headCommit}:{}}}async function Eo(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=D(n,Di(o)),i=(e.agentOsId?String(e.agentOsId):n.agentOsId)||"",a=(e.taskId?String(e.taskId):n.taskId)||null;if(!oe(s))return{ok:!0,skipped:!0,reason:"worker-not-finished"};if(n.localOnly)return{ok:!0,skipped:!0,reason:"local-only-worker"};if(!i)return{ok:!1,reason:"missing agentOsId"};let l=e.force===!0||e.force==="true";if(!l&&dt(n))return{ok:!0,skipped:!0,reason:"completion-already-acknowledged",httpStatus:200};if(!l&&Tc(n)&&d_(n),!(e.skipPrHandoff===!0||e.skipPrHandoff==="true")&&n.dispatched&&a){let E=Ai({worker:n,run:o,status:s});if(!E.ok)return _o(n,E.reason),{ok:!1,reason:E.reason,nextAction:E.nextAction,completionBlocked:!0};(E.prUrl||E.headCommit)&&(s=D(n,Di(o)),s=p_(s,E))}let u=s.gitAncestry.headIsAncestorOfBase===!1&&s.gitAncestry.head?s.gitAncestry.head:s.headCommit;if(n.dispatched){let E=ig({changedFiles:s.changedFiles,finalResult:s.finalResult,prUrl:s.prUrl,headCommit:u,disposableArtifactsRemoved:n.disposableArtifactsRemoved});if(!E.allowed){let U=E.detail??`worktree completion blocked (${E.state})`;return _o(n,U),{ok:!1,reason:U,nextAction:"Clean the worktree (commit, open a PR, or `kynver worker discard-disposable --path <file>`), then rerun `kynver worker complete`.",completionBlocked:!0}}}let d=V(e.baseUrl?String(e.baseUrl):void 0),m=e.secret?String(e.secret):void 0,p=await J(m,i,{baseUrl:d});a&&(await Ri({worker:n,agentOsId:i,baseUrl:d,secret:p}),n=he(r,t));let f=`${d}/api/agent-os/by-id/${encodeURIComponent(i)}/harness/completion`,h={...s};n.disposableArtifactsRemoved?.length&&(h.disposableArtifactsRemoved=n.disposableArtifactsRemoved);let k={source:"kynver-harness",agentOsId:i,runId:n.runId,workerName:n.name,taskId:a,leaseToken:n.leaseToken??null,startedAt:n.startedAt,finishedAt:s.lastActivityAt||new Date().toISOString(),status:n.leaseToken?{...h,leaseToken:n.leaseToken}:h,workerInjection:{instructionPolicyFingerprint:n.instructionPolicyFingerprint??null,instructionPolicyEvidence:n.instructionPolicyEvidence??null,memoryQualityCapture:n.memoryQualityCapture??null,policyAt:n.instructionPolicyEvidence&&typeof n.instructionPolicyEvidence=="object"&&"policyAt"in n.instructionPolicyEvidence&&typeof n.instructionPolicyEvidence.policyAt=="string"?n.instructionPolicyEvidence.policyAt:null,personaSlug:n.personaSlug??null,personaEvidence:n.personaEvidence??null,contextEnvelopeEvidence:n.contextEnvelopeEvidence??null}},g=await dg(f,p,k);if((g.status===401||g.status===403)&&!m){let E=await Bm(i,{baseUrl:d});E&&E!==p&&(p=E,g=await dg(f,p,k))}if(g.ok){let E=Hf(g.parsed);if(!Ff(E)){let P=`completion acknowledged but board not advanced: ${E.detail??(E.routeOutcome?`harness completion returned ${E.routeOutcome}`:"harness completion did not advance the linked task")}`;_o(n,P);let B={completionReportedAt:new Date().toISOString(),completionOutcome:"rejected",completionResponse:g.parsed};return Nc(n,n.runId,B),{ok:!1,httpStatus:g.status,response:g.parsed,reason:P,completionBlocked:!0}}_o(n,void 0);let U=E.routeOutcome??"acknowledged",Y={completionReportedAt:new Date().toISOString(),completionOutcome:"acknowledged",completionResponse:g.parsed};Nc(n,n.runId,Y),Lc(n,s,{source:"harness-completion"});let $=s.prUrl;return{ok:!0,httpStatus:g.status,response:g.parsed,reason:U,...$?{prHandoff:{prUrl:$}}:{}}}let R=g.status===401||g.status===403,O=a_(g.parsed)??(R?"runner token unauthorized":"non-2xx response"),_=R?`completion replay rejected (${g.status}): ${O}`:`completion replay failed (${g.status}): ${O}`;return _o(n,_),{ok:!1,httpStatus:g.status,response:g.parsed,completionBlocked:!0}}async function Mi(e){try{let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=D(n,Di(o)),i=(e.agentOsId?String(e.agentOsId):n.agentOsId)||"",a=(e.taskId?String(e.taskId):n.taskId)||null;if(!oe(s)){console.log(JSON.stringify({worker:n.name,runId:n.runId,status:"skipped",reason:"worker-not-finished",workerStatus:s.status,alive:s.alive},null,2));return}if(n.localOnly){console.log(JSON.stringify({worker:n.name,runId:n.runId,status:"skipped",reason:"local-only-worker"},null,2));return}i||(console.error("worker complete requires --agent-os-id (or an agentOsId persisted at worker start)"),process.exit(1));let l=await Eo(e);console.log(JSON.stringify({worker:n.name,runId:n.runId,...l.skipped?{status:"skipped"}:{},...l.reason?{reason:l.reason}:{},...l.nextAction?{nextAction:l.nextAction}:{},...l.completionBlocked?{completionBlocked:l.completionBlocked}:{},agentOsId:i,taskId:a,httpStatus:l.httpStatus,response:l.response},null,2)),l.ok||process.exit(1)}catch(r){console.error(`worker complete failed: ${r.message}`),process.exit(1)}}function $c(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=D(n,Di(o));ae(xo.join(n.workerDir,"last-status.json"),s),console.log(JSON.stringify(s,null,2))}function m_(e){return{full:`kynver worker list --run ${e} --full`,blocked:`kynver worker list --run ${e} --blocked`,running:`kynver worker list --run ${e} --running`,task:`kynver worker list --run ${e} --task <task-id>`,worker:`kynver worker list --run ${e} --worker <worker>`,runFull:`kynver run status --run ${e} --full`,workerFull:`kynver worker status --run ${e} --name <worker>`,workerTail:`kynver worker tail --run ${e} --name <worker> --lines 80`}}function Kc(e){if(typeof e!="string")return;let r=e.trim();return r.length?r:void 0}function f_(e){let r={};(e.blocked===!0||e.blocked==="true")&&(r.blocked=!0),(e.running===!0||e.running==="true")&&(r.running=!0);let t=Kc(e.task??e.taskId);t&&(r.task=t);let n=Kc(e.worker??e.name);n&&(r.worker=n);let o=Kc(e.status);return o&&(r.status=o),r}function g_(e,r){if(r.blocked){let t=typeof e.attention=="string"?e.attention:"",n=typeof e.status=="string"?e.status:"";if(!(t==="blocked"||t==="needs_attention"||t==="stale"||n==="blocked"))return!1}return!(r.running&&!(e.status==="running"&&e.attention!=="blocked"&&e.attention!=="needs_attention")||typeof r.task=="string"&&e.taskId!==r.task||typeof r.worker=="string"&&e.worker!==r.worker||typeof r.status=="string"&&e.status!==r.status)}function gg(e,r){let t=f_(r);if(Object.keys(t).length===0)return e;let n=e.workers.filter(s=>g_(s,t)),o={...e,workerCount:n.length,needsAttention:n.filter(s=>s.attention&&s.attention!=="ok"&&s.attention!=="done").map(s=>s.worker),workers:n,activeFilters:t};return e.summary&&(o.summary={statusCounts:Ur(n,"status"),attentionCounts:Ur(n,"attention"),lifecycleCounts:Ur(n,"lifecycleStage")}),e.controller&&(o.controller=yg(n)),o}function hg(e){let r=Ti(e),t=e.full===!0||e.full==="true",n=gg(t?Po(r):Ao(r),e),o=n.workers;console.log(JSON.stringify({runId:n.runId,status:n.status,projection:t?"full":"compact",workerCount:n.workerCount,...n.activeFilters?{activeFilters:n.activeFilters}:{},...t?{}:{resultContract:{projection:"compact",rawWorkerPayloadsOmitted:!0,deepDetailAvailableVia:["--full","worker status","worker tail","run status --full"]},drilldownCommands:m_(r)},needsAttention:n.needsAttention,..."summary"in n?{summary:n.summary}:{},..."controller"in n?{controller:n.controller}:{},workers:o},null,2))}function kg(e){let{run:r,workerName:t,worker:n}=e,o=D(n,{base:r.base,baseCommit:r.baseCommit}),s=o.gitAncestry.headIsAncestorOfBase===!1&&o.gitAncestry.head?o.gitAncestry.head:void 0,i=Xr({alive:o.alive,finalResult:o.finalResult,changedFiles:o.changedFiles,gitAncestry:o.gitAncestry,headCommit:s}),a=n.completionBlocker,l=typeof a=="string"&&a?a:void 0,c=fg(l)?void 0:l,u=c?"blocked":o.status,d=c?"blocked":o.attention.state,m=pg(n.completionResponse),p=pg(m?.task),f=wo(m?.outcome),h=wo(m?.status),k=Array.isArray(m?.warnings)?m.warnings.filter(U=>typeof U=="string"&&U.trim().length>0):[],g=wo(p?.prUrl)??wo(m?.prUrl),R=wo(n.completionReportedAt),O=l_({finished:oe(o),completionBlocker:c,completionOutcome:f,completionReportedAt:R}),_=c_({completionBlocker:c,completionOutcome:f,completionReportedAt:R,finished:oe(o)}),E=u_({changedFiles:o.changedFiles,headCommit:s,prUrl:g??void 0});return{worker:o.worker,status:u,attention:d,attentionReason:c??o.attention.reason,landingBlocked:o.finalResult?d==="needs_attention"||d==="blocked":!1,exitedWithoutFinalResult:!o.finalResult&&!o.alive,salvageState:i?.salvageable?"review_needed":"none",salvageReason:i?.salvageable?i.attentionReason:void 0,pid:o.pid,alive:o.alive,currentTool:o.currentTool,lastActivityAt:o.lastActivityAt,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary,heartbeatBlocker:o.heartbeatBlocker,changedFileCount:o.changedFiles.length,changedFiles:o.changedFiles,branch:o.branch,taskId:n.taskId??null,planId:n.planId??null,instructionPolicyFingerprint:typeof n.instructionPolicyFingerprint=="string"?n.instructionPolicyFingerprint:null,instructionPolicyRuleCount:(()=>{let U=n.instructionPolicyEvidence;if(!U||typeof U!="object")return null;let Y=U.ruleSlugs;return Array.isArray(Y)?Y.length:null})(),leaseOwner:n.leaseOwner??null,model:typeof n.model=="string"?n.model:void 0,routingRule:typeof n.routingRule=="string"?n.routingRule:void 0,requestedModel:typeof n.requestedModel=="string"?n.requestedModel:void 0,headCommit:s,prUrl:g,handoffState:E,gitAncestry:o.gitAncestry,finalResult:o.finalResult,lifecycleStage:O,completionReportedAt:R,completionOutcome:n.completionOutcome??null,completionRouteStatus:h,completionRouteOutcome:f,completionWarnings:k,completionBlocker:c??null,checkpoint:{phase:o.lastHeartbeatPhase,summary:o.lastHeartbeatSummary,blocker:o.heartbeatBlocker},lastCommandHint:o.currentTool??o.lastHeartbeatSummary,failureReason:c??o.error??null,nextAction:_,ancestry:o.gitAncestry.relation,ancestryChecked:o.gitAncestry.checked}}function h_(e){let r=typeof e.status=="string"?e.status:"",t=typeof e.completionBlocker=="string"&&e.completionBlocker.trim().length>0?e.completionBlocker:void 0;return t&&!fg(t)?!1:typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim()||e.completionOutcome==="acknowledged"?!0:r==="done"}function k_(e,r){return{worker:e,status:"done",attention:"done",attentionReason:"metadata terminal worker; full status skipped in compact snapshot",alive:!1,pid:typeof r.pid=="number"?r.pid:void 0,branch:typeof r.branch=="string"?r.branch:void 0,taskId:r.taskId??null,planId:r.planId??null,model:typeof r.model=="string"?r.model:void 0,routingRule:typeof r.routingRule=="string"?r.routingRule:void 0,requestedModel:typeof r.requestedModel=="string"?r.requestedModel:void 0,lifecycleStage:r.completionReportedAt?"completion_acknowledged":"worker_finished",completionReportedAt:typeof r.completionReportedAt=="string"?r.completionReportedAt:null,completionOutcome:r.completionOutcome??null,localOnly:r.localOnly===!0,compactStatus:!0}}function Ur(e,r){let t={};for(let n of e){let o=n[r],s=typeof o=="string"&&o.trim()?o:"unknown";t[s]=(t[s]??0)+1}return t}function mg(e){if(e.attention!=="blocked")return!1;let r=typeof e.attentionReason=="string"?e.attentionReason:"";return r.includes("cli-config.json.tmp")||r.includes("Invalid authentication credentials")||r.includes("provider CLI is missing or not on PATH")||r.includes("unknown command:")}function yg(e){let r=e.filter(mg),t=e.filter(n=>{if(mg(n))return!1;let o=n.attention;return o==="needs_attention"||o==="blocked"||o==="stale"||n.status==="running"});return{actionableCount:t.length,runningCount:e.filter(n=>n.status==="running").length,blockedCount:e.filter(n=>n.attention==="blocked").length,staleCount:e.filter(n=>n.attention==="stale").length,needsAttentionCount:e.filter(n=>n.attention==="needs_attention").length,doneCount:e.filter(n=>n.status==="done").length,systemHealthBlockerCount:r.length,systemHealthBlockers:r.slice(0,10).map(n=>({worker:n.worker,status:n.status,attention:n.attention,attentionReason:n.attentionReason,model:n.model,routingRule:n.routingRule,lastActivityAt:n.lastActivityAt})),actionableWorkers:t.slice(0,25).map(n=>({worker:n.worker,status:n.status,attention:n.attention,attentionReason:n.attentionReason,taskId:n.taskId,planId:n.planId,model:n.model,routingRule:n.routingRule,lastActivityAt:n.lastActivityAt,nextAction:n.nextAction}))}}function Rg(e,r,t){let n={runId:e.id,name:e.name,status:Qt(e.status,r),repo:e.repo,workerCount:r.length,needsAttention:r.filter(o=>o.attention&&o.attention!=="ok"&&o.attention!=="done").map(o=>o.worker),workers:r};return t&&(n.summary={statusCounts:Ur(r,"status"),attentionCounts:Ur(r,"attention"),lifecycleCounts:Ur(r,"lifecycleStage")},n.controller=yg(r)),n}function y_(e){return e.status==="done"&&e.attention==="done"}function Po(e){let r=L(e),n=Object.keys(r.workers||{}).map(s=>{let i=w(xo.join(x(r.id),"workers",b(s),"worker.json"),void 0);return i?kg({run:r,workerName:s,worker:i}):{worker:s,status:"missing",attention:"needs_attention",attentionReason:"worker.json not found"}}),o=Rg(r,n,!1);return ae(xo.join(x(r.id),"last-board.json"),o),o}function Ao(e){let r=L(e),n=Object.keys(r.workers||{}).map(i=>{let a=w(xo.join(x(r.id),"workers",b(i),"worker.json"),void 0);return a?h_(a)?k_(i,a):kg({run:r,workerName:i,worker:a}):{worker:i,status:"missing",attention:"needs_attention",attentionReason:"worker.json not found"}}),o=n.filter(i=>!y_(i)),s=Rg(r,o,!0);return s.status=Qt(r.status,n),s.summary={...s.summary??{},totalWorkerCount:n.length,shownWorkerCount:o.length,omittedTerminalDoneWorkerCount:n.length-o.length,allStatusCounts:Ur(n,"status"),allAttentionCounts:Ur(n,"attention")},ae(xo.join(x(r.id),"last-board-compact.json"),s),s}async function vg(e,r){let t=String(e.run||""),n=String(e.agentOsId||"");if(!t||!n)return null;let o=Po(t),s=V(e.baseUrl?String(e.baseUrl):void 0),i=await J(e.secret?String(e.secret):void 0,n,{baseUrl:s}),a=`${s}/api/agent-os/by-id/${encodeURIComponent(n)}/harness/snapshot`,l=await re(a,i,{agentOsId:n,runId:t,source:r,snapshot:o},{agentOsId:n,baseUrl:s});return{ok:l.ok,httpStatus:l.status,response:l.response,authRefreshed:l.refreshedAuth,authRefreshFailure:l.authRefreshFailure}}function R_(e){return{full:`kynver run status --run ${e} --full`,blocked:`kynver status --run ${e} --blocked`,running:`kynver status --run ${e} --running`,task:`kynver status --run ${e} --task <task-id>`,worker:`kynver status --run ${e} --worker <worker>`,workersFull:`kynver worker list --run ${e} --full`,workerFull:`kynver worker status --run ${e} --name <worker>`,workerTail:`kynver worker tail --run ${e} --name <worker> --lines 80`,monitorTick:`kynver monitor status --run ${e} --tick`}}function jc(e){let r=Ti(e),t=e.full===!0||e.full==="true",n=gg(t?Po(r):Ao(r),e);n.projection=t?"full":"compact",t||(n.resultContract={projection:"compact",rawWorkerPayloadsOmitted:!0,omittedWorkerFields:["finalResult","changedFiles","gitAncestry","completionResponse","stdout/stderr tails"],deepDetailAvailableVia:["--full","worker status","worker tail","monitor status --tick"]},n.drilldownCommands=R_(r)),console.log(JSON.stringify(n,null,2))}function Vc(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=vs(n.stdoutPath,Number(e.lines||40));if(e.raw===!0||e.raw==="true"){process.stdout.write(o);return}for(let s of o.split(`
|
|
29
|
-
`).filter(Boolean)){let i=Lt(s),a=i?Wl(i):s;a&&console.log(a)}}function Gc(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t);if(!H(n.pid)){console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"not_running"},null,2));return}if(Er(n.pid,"SIGTERM"),$r(1500),H(n.pid)){Er(n.pid,"SIGKILL"),console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"sigkill_sent"},null,2));return}console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"stopped"},null,2))}C();import{existsSync as Ui}from"node:fs";import mt from"node:path";import{fileURLToPath as v_}from"node:url";function b_(e,r){let t=mt.resolve(e);for(;;){let n=mt.join(t,r);if(Ui(n))return n;let o=mt.dirname(t);if(o===t)return null;t=o}}function S_(e){return b_(e,mt.join("node_modules",".bin","tsx"))??"npx"}function Yc(e,r){if(e.endsWith(".ts")){let t=S_(mt.dirname(e));return{command:t,argsPrefix:t==="npx"?["tsx",e]:[e],cliPath:e}}return{command:r,argsPrefix:[e],cliPath:e}}function Wi(e){if(e.explicitCliPath)return Ui(e.explicitCliPath)?Yc(e.explicitCliPath,e.nodeExecutable):null;let r=v_(new URL(".",e.importMetaUrl)),t=mt.join(r,"cli.js");if(Ui(t))return Yc(t,e.nodeExecutable);let n=mt.join(r,"cli.ts");return Ui(n)?Yc(n,e.nodeExecutable):null}var E_=5e3,P_=360*60*1e3,A_=3,I_=5e3;function O_(e){let{runId:r,workerName:t}=Fe(e);return{run:r,name:t,agentOsId:e.agentOsId?String(e.agentOsId):void 0,pollMs:Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):void 0,maxTotalMs:Number(e.maxTotalMs)>0?Math.floor(Number(e.maxTotalMs)):void 0,completeAttempts:Number(e.completeAttempts)>0?Math.floor(Number(e.completeAttempts)):void 0,completeBackoffMs:Number(e.completeBackoffMs)>0?Math.floor(Number(e.completeBackoffMs)):void 0,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0}}async function ft(e){let r=O_(e),t=r.pollMs??E_,n=r.maxTotalMs??P_,o=r.completeAttempts??A_,s=r.completeBackoffMs??I_,i=he(r.run,r.name);if(!i.agentOsId||!i.taskId)return{worker:i.name,runId:i.runId,outcome:"missing_link",attempts:0,reason:"worker has no agentOsId/taskId \u2014 nothing to attribute completion to"};if(dt(i))return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:200,attempts:0,reason:"completion-already-acknowledged"};let a=Date.now();for(;;){if(i=he(r.run,r.name),dt(i))return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:200,attempts:0,reason:"completion-already-acknowledged"};let u=D(i);if(oe(u)||!H(i.pid))break;if(Date.now()-a>n)return{worker:i.name,runId:i.runId,outcome:"timed_out",attempts:0,reason:`worker did not finish within ${n}ms`};$r(t)}let l,c;for(let u=1;u<=o;u++){let d=await Eo({run:r.run,name:r.name,...r.agentOsId?{agentOsId:r.agentOsId}:{},...r.baseUrl?{baseUrl:r.baseUrl}:{},...r.secret?{secret:r.secret}:{}});if(l=d.httpStatus,d.ok)return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:d.httpStatus,attempts:u};if(d.httpStatus===401||d.httpStatus===403)return c=typeof d.reason=="string"?d.reason:"completion replay refused",{worker:i.name,runId:i.runId,outcome:"blocked",httpStatus:d.httpStatus,attempts:u,reason:c};c=typeof d.reason=="string"?d.reason:"transient failure",u<o&&$r(s)}return{worker:i.name,runId:i.runId,outcome:"blocked",httpStatus:l,attempts:o,reason:c??"completion failed after retries"}}async function Jc(e){try{let r=await ft(e);console.log(JSON.stringify(r,null,2)),(r.outcome==="missing_link"||r.outcome==="timed_out")&&process.exit(1),process.exit(0)}catch(r){console.error(`worker auto-complete failed: ${r.message}`),process.exit(1)}}function qc(e){let r=e.nodeExecutable??process.execPath,t=Wi({importMetaUrl:import.meta.url,explicitCliPath:e.cliPath,nodeExecutable:r});if(!t)return;let n=t.cliPath;if(!w_(n))return;let o=x_.join(e.workerDir,"auto-complete.log"),s;try{s=__(o,"a")}catch{s=void 0}let i=["ignore",s??"ignore",s??"ignore"],a=[...t.argsPrefix,"worker","auto-complete","--run",e.runId,"--name",e.workerName];e.agentOsId&&a.push("--agent-os-id",e.agentOsId),e.baseUrl&&a.push("--base-url",e.baseUrl),e.secret&&a.push("--secret",e.secret);try{let l=C_(t.command,a,pe({detached:!0,stdio:i,env:process.env}));return s!==void 0&&bg(s),l.unref(),{pid:l.pid,logPath:o,cliPath:n}}catch{if(s!==void 0)try{bg(s)}catch{}return}}function Sg(e){let r=e.branch?.trim()||"unknown branch",t=e.pid!=null?`pid ${e.pid}`:"pid pending";return`Harness worker started: ${e.worker} (${t}, ${r})`}function zc(e){return JSON.stringify(e,null,2)}Pe();function Cg(e,r,t){me(e,["fetch","origin",t,"--prune"],{allowFailure:!0});let n=`origin/${t}`,o=ne(e,["worktree","add","-B",t,r,n]);if(o.status===0)return;let s=ne(e,["worktree","add","-b",t,r,"HEAD"]);if(s.status!==0){let i=o.stderr||o.stdout||s.stderr||s.stdout||"git worktree add failed for repair target branch";throw new Error(i)}}Oe();I();function Li(e,r){let t=typeof r.name=="string"?r.name.trim():"";if(!t||t==="undefined"||t==="null")throw new Error(`worker name is required and must be a real identifier (got: ${JSON.stringify(r.name)})`);let n=b(t);if(e.workers?.[n])throw new Error(`worker already exists in run ${e.id}: ${n}`);if(!r.task)throw new Error(`missing task text for worker ${n}`);let o=r.routingRule||r.requestedModel?{provider:r.provider||Ie,model:r.model,rule:r.routingRule||"explicit:spawn",requestedModel:r.requestedModel??r.model}:ki({explicitModel:r.model,explicitProvider:r.provider,explicitProviderIsOperatorOverride:!!r.provider?.trim()}),s=Bf(o.provider),i=o.model;if(s.preflightModel){let F=s.preflightModel(r.model);if(!F.ok)throw new Error(`model preflight failed for provider "${s.name}": ${F.note??"invalid model/provider combination"}`);F.normalized&&console.error(`[supervisor] ${n}: ${F.note}`),i=F.model}let{worktreesDir:a}=Z(),l=mn.join(x(e.id),"workers",n);T_(l,{recursive:!0});let c=mn.join(a,e.id,n),u=r.repairTargetBranch?.trim()||void 0,d=u||r.branch||`agent/${e.id}/${n}`;if(N_(c))throw new Error(`worktree path already exists: ${c}`);me(e.repo,["fetch","origin","--prune"],{allowFailure:!0}),u?Cg(e.repo,c,u):me(e.repo,["worktree","add","-b",d,c,e.baseCommit],{throwError:!0});let m=mn.join(l,"stdout.jsonl"),p=mn.join(l,"stderr.log"),f=mn.join(l,"heartbeat.jsonl"),h=Ec({task:r.task,ownedPaths:r.ownedPaths||[],worktreePath:c,heartbeatPath:f,planId:r.planId,taskId:r.taskId,instructionPolicyMarkdown:r.instructionPolicyMarkdown,memoryQualityMarkdown:r.memoryQualityPromptMarkdown??r.memoryQualityCapture?.promptMarkdown??null,personaMarkdown:r.personaMarkdown,contextEnvelopeMarkdown:r.contextEnvelopeMarkdown,model:i,repairTargetPrUrl:r.repairTargetPrUrl,repairTargetBranch:r.repairTargetBranch??(u||void 0)}),k=process.env.KYNVER_HARNESS_TASK_ID,g=process.env.KYNVER_HARNESS_AGENT_OS_ID;r.taskId&&(process.env.KYNVER_HARNESS_TASK_ID=String(r.taskId)),r.agentOsId&&(process.env.KYNVER_HARNESS_AGENT_OS_ID=String(r.agentOsId));let R;try{R=s.start({name:n,task:r.task,ownedPaths:r.ownedPaths,model:i,branch:d,worktreePath:c,workerDir:l,stdoutPath:m,stderrPath:p,heartbeatPath:f,prompt:h})}catch(F){throw me(e.repo,["worktree","remove","--force",c],{allowFailure:!0}),me(e.repo,["branch","-D",d],{allowFailure:!0}),F}finally{k===void 0?delete process.env.KYNVER_HARNESS_TASK_ID:process.env.KYNVER_HARNESS_TASK_ID=k,g===void 0?delete process.env.KYNVER_HARNESS_AGENT_OS_ID:process.env.KYNVER_HARNESS_AGENT_OS_ID=g}let O=wf(R.model,i,s.defaultModel),_=y(),E=Ae(process.env,_),U=er().runnerId,Y=Ro(E.boxKind),$={name:n,runId:e.id,status:"running",pid:R.pid,model:O,branch:d,worktreePath:c,workerDir:l,stdoutPath:m,stderrPath:p,heartbeatPath:f,ownedPaths:r.ownedPaths,...r.agentOsId?{agentOsId:String(r.agentOsId)}:{},...r.taskId?{taskId:String(r.taskId)}:{},...r.planId?{planId:String(r.planId)}:{},...r.instructionPolicyFingerprint?{instructionPolicyFingerprint:String(r.instructionPolicyFingerprint)}:{},...r.instructionPolicyEvidence?{instructionPolicyEvidence:r.instructionPolicyEvidence}:{},...r.memoryQualityCapture?{memoryQualityCapture:r.memoryQualityCapture}:{},...r.personaSlug?{personaSlug:String(r.personaSlug)}:{},...r.personaEvidence?{personaEvidence:r.personaEvidence}:{},...r.contextEnvelopeEvidence?{contextEnvelopeEvidence:r.contextEnvelopeEvidence}:{},...r.leaseOwner?{leaseOwner:String(r.leaseOwner)}:{},...r.leaseToken?{leaseToken:String(r.leaseToken)}:{},...r.dispatched?{dispatched:!0}:{},...!r.agentOsId||!r.taskId?{localOnly:!0}:{},routingRule:o.rule,...o.requestedModel?{requestedModel:o.requestedModel}:{},...o.orchestrationAudit?{orchestrationAudit:o.orchestrationAudit}:{},...r.executorRef?{executorRef:String(r.executorRef)}:{},...r.parentTaskId?{parentTaskId:String(r.parentTaskId)}:{},...r.taskTitle?{taskTitle:String(r.taskTitle)}:{},...r.taskPrUrl?{taskPrUrl:String(r.taskPrUrl)}:{},...r.repairTargetPrUrl?{repairTargetPrUrl:String(r.repairTargetPrUrl)}:{},...r.repairTargetBranch?{repairTargetBranch:String(r.repairTargetBranch)}:{},boxKind:E.boxKind,boxId:Y,runtimeId:U,startedAt:new Date().toISOString()};if(K(e.id,$),e.workers={...e.workers||{},[n]:{workerDir:l,statusPath:mn.join(l,"worker.json")}},e.status="running",Be(e),$.agentOsId&&$.taskId){let F;try{F=qc({runId:e.id,workerName:n,workerDir:l,agentOsId:$.agentOsId})}catch(P){let B=`completion sidecar failed to spawn: ${P.message}`;$.completionBlocker=B,K(e.id,$)}if(F)F.pid&&($.completionSidecarPid=F.pid,K(e.id,$));else{let P="completion sidecar failed to spawn (CLI not found or spawn error)";$.completionBlocker=P,$.completionSidecarSpawnFailedAt=new Date().toISOString(),K(e.id,$)}}return $}async function Xc(e){let r=L(String(e.run)),t=typeof e.name=="string"?e.name.trim():"";t||(console.error("worker start failed: --name is required"),process.exit(1));let n=e.task?String(e.task):fp(e.taskFile?String(e.taskFile):void 0);n||(console.error("missing --task or --task-file"),process.exit(1));let o=!!(e.agentOsId&&e.taskId),s=e.localOnly===!0||e.localOnly==="true";!o&&!s&&(e.agentOsId||e.taskId)&&(console.error("worker start: board-linked workers require both --agent-os-id and --task-id (or pass --local-only for direct runs)"),process.exit(1));let i=e.wait===!0||e.wait==="true",a=e.emitJson===!0||e.emitJson==="true",l;try{l=Li(r,{name:t,task:n,ownedPaths:e.owned?String(e.owned).split(",").map(d=>d.trim()).filter(Boolean):[],model:e.model?String(e.model):void 0,branch:e.branch?String(e.branch):void 0,agentOsId:e.agentOsId?String(e.agentOsId):void 0,taskId:e.taskId?String(e.taskId):void 0,provider:e.provider?String(e.provider):void 0});let u={runId:r.id,worker:l.name,pid:l.pid,branch:l.branch,worktreePath:l.worktreePath,workerDir:l.workerDir};a?console.log(zc(u)):(console.log(Sg(u)),console.error(zc(u)))}catch(u){console.error(`worker start failed: ${u.message}`),process.exit(1)}if(!i||!l)return;let c=await ft({run:String(e.run),name:l.name,...l.agentOsId?{agentOsId:l.agentOsId}:{},...e.baseUrl?{baseUrl:String(e.baseUrl)}:{},...e.secret?{secret:String(e.secret)}:{}});console.error(JSON.stringify({event:"start_wait_outcome",...c})),c.outcome==="timed_out"&&(process.exitCode=1)}T();Zt();C();import D_ from"node:path";function M_(e){let r=Array.isArray(e.ownedPaths)?e.ownedPaths.filter(n=>typeof n=="string"):[],t=Array.isArray(e.writeSetPrefixes)?(e.writeSetPrefixes??[]).filter(n=>typeof n=="string"):[];return{...r.length?{ownedPaths:r}:{},...t.length?{writeSetPrefixes:t}:{},...e.allowConcurrentHotspot?{allowConcurrentHotspot:!0}:{}}}function Bi(e){let r=L(e),t=[];for(let n of Object.keys(r.workers||{})){let o=w(D_.join(x(r.id),"workers",b(n),"worker.json"),void 0);!o?.taskId||!rt(o)||t.push({runId:r.id,workerName:n,taskId:o.taskId,pid:o.pid,...M_(o)})}return t}C();import{createHash as wg}from"node:crypto";function gr(e){let r=e.replace(/\r\n/g,`
|
|
30
|
-
`).trimEnd();return
|
|
31
|
-
`,{mode:384}),l}function
|
|
32
|
-
`,{mode:384})}function
|
|
33
|
-
`)}function
|
|
34
|
-
`)}var
|
|
35
|
-
`)}function dx(e){let r=new Set;if(e.targetTaskId)return r.add(String(e.targetTaskId)),r;if(e.targetTaskIds)for(let t of String(e.targetTaskIds).split(",")){let n=t.trim();n&&r.add(n)}return r}async function Wr(e){let r=e.pipeline===!0||e.pipeline==="true";try{let Dt=function(){return Q.filter(S=>S.started).length},Ge=function(S,v){rc({runId:i.id,agentOsId:a,phase:S,startedCount:Dt(),outcomeCount:Q.length,cappedStarts:_,...v})},ve=function(){return Q.some(S=>(typeof S.error=="string"?S.error:"").startsWith("dispatch_start_readback_failed:"))},W=function(S){return S.landPrDispatch===!0?!0:S.task?.executor==="land_pr"};var t=Dt,n=Ge,o=ve,s=W;let i=L(String(N(String(e.run||""),"--run"))),a=String(N(String(e.agentOsId||""),"--agent-os-id")),l=V(e.baseUrl?String(e.baseUrl):void 0),c=await J(e.secret?String(e.secret):void 0,a,{baseUrl:l}),d=!(e.execute===!0||e.execute==="true"),m=er({runId:i.id}),p=_c(i.id,m.runnerId),f=e.diskPath?Le({diskPath:String(e.diskPath)}):Le({diskPath:i.repo}),h=mr({runId:i.id}),k=dx(e),g=k.size>0,R=Number(e.maxStarts)>0?Math.floor(Number(e.maxStarts)):1,O=g?Math.min(R,k.size):R,_=d?O:Math.min(O,h.slotsAvailable);if(!d&&_<=0){let S={runId:i.id,agentOsId:a,dryRun:!1,skipped:!0,reason:h.reason??"no resource slots",resourceGate:h};if(r)return{ok:!0,...S};console.log(JSON.stringify(S,null,2));return}let E=Bi(i.id);if(e.reconcileStaleBlockers===!0||e.reconcileStaleBlockers==="true"){let S=`${l}/api/agent-os/by-id/${encodeURIComponent(a)}/lane-hygiene`;try{await re(S,c,{agentOsId:a,dryRun:!1,includeBoardReconcile:!0},{agentOsId:a,baseUrl:l})}catch(v){console.error(`[dispatch] reconcile-stale-blockers lane-hygiene call failed: ${v.message}`)}}let U=`${l}/api/agent-os/by-id/${encodeURIComponent(a)}/tasks/dispatch-next`,Y=S=>({agentOsId:a,dryRun:d,maxStarts:S,leaseOwner:p,leaseDurationMs:Number(e.leaseMs)>0?Math.floor(Number(e.leaseMs)):bi,runnerDiskGate:f,runnerResourceGate:h,activeHarnessWorkers:E,runnerPresence:m,harnessBoardSnapshot:Po(i.id),...e.lane?{lane:ef(String(e.lane))}:{},...e.executor?{executor:String(e.executor)}:{},...e.diskPath?{diskPath:String(e.diskPath)}:{},...e.targetTaskId?{targetTaskId:String(e.targetTaskId)}:{},...!e.targetTaskId&&e.targetTaskIds?{targetTaskIds:String(e.targetTaskIds).split(",").map(v=>v.trim()).filter(Boolean)}:{}}),$=Gm(),F=async S=>{let v=await re(U,c,Y(S),{agentOsId:a,baseUrl:l,timeoutMs:$})??{ok:!1,status:0,response:null},A=v.response;return{dispatch:v,result:A?.result}},P=await F(g||d?_:1);if(!P.dispatch.ok||!P.result){let S={runId:i.id,agentOsId:a,action:"dispatch",httpStatus:P.dispatch.status,response:P.dispatch.response,authRefreshed:P.dispatch.refreshedAuth===!0,authRefreshFailure:P.dispatch.authRefreshFailure};if(r)return{ok:!1,...S};console.log(JSON.stringify(S,null,2)),process.exit(1)}let B=P.result;if(d){let S=zg(B),v=Xg(B),A={runId:i.id,agentOsId:a,dryRun:!0,wouldStart:B.started.map(j=>({taskId:j.task.id,title:j.task.title,reason:j.reason})),skipped:B.skipped.map(j=>({taskId:j.task.id,skipReason:j.skipReason,reason:j.reason})),diskGate:B.diskGate,resourceGate:B.resourceGate,inspected:B.inspected,pagesScanned:B.pagesScanned??null,candidatesExhausted:B.candidatesExhausted??null,capacityIdle:S?.capacityIdle===!0,admissionExhaustion:S,dispatchSkipDrain:v};if(r)return{ok:!0,...A};console.log(JSON.stringify(A,null,2));return}let Kr=xf(),Q=[],Cr=[],Tt=Number(B.inspected)||0,Ve=!1;async function G(S,v,A){let j=await iu({baseUrl:l,secret:c,agentOsId:a,taskId:String(S.id),leaseOwner:p,failureDetail:v}),de={taskId:S.id,started:!1,error:v,released:j.released,releaseResponse:j.releaseResponse,...A};return Q.push(de),Ge("outcome",{lastOutcome:de}),!1}async function be(S){let v=S.task,A=String(v.id);if(g&&!k.has(A))return G(v,"exact_target_mismatch: dispatch-next returned a different task than requested",{requestedTargetTaskIds:[...k]});let j=v.prUrl?String(v.prUrl):"";if(!j)return G(v,"land_pr task missing prUrl");try{let de=await Vg({prUrl:j,repo:$g(j),cwd:i.repo}),Ut=await Gg({baseUrl:l,secret:c,agentOsId:a,runId:i.id,task:v,report:de});return Ut.ok?(Q.push({taskId:A,started:!0,landPr:!0,outcome:de.outcome,completionStatus:Ut.status}),!0):G(v,`land_pr completion POST failed (HTTP ${Ut.status})`,{landPr:!0,outcome:de.outcome})}catch(de){return G(v,de.message)}}async function xe(S){let v="duplicate_dispatch_prevented: live local worker already owns this task",A=await iu({baseUrl:l,secret:c,agentOsId:a,taskId:String(S.id),leaseOwner:p,failureDetail:v}),j={taskId:S.id,started:!1,error:v,alreadyRunning:!0,nonFatal:!0,released:A.released,releaseResponse:A.releaseResponse};return Q.push(j),Ge("outcome",{lastOutcome:j}),!1}async function wr(S){let v=S.task,A=cx(S),j=String(v.id);if(g&&!k.has(j))return G(v,"exact_target_mismatch: dispatch-next returned a different task than requested",{requestedTargetTaskIds:[...k]});let de=ux(v.personaSlug);if(de&&(!A?.personaInjectionReady||!A.personaMarkdown))return G(v,`persona_injection_required: missing anchored context-envelope persona block for "${de}"`);if(If(i.id,j))return xe(v);let Ut=Number(v.attempt)||1;if(Ut>Kr.maxTaskAttempts)return G(v,`task attempt ${Ut} exceeds KYNVER_MAX_TASK_ATTEMPTS (${Kr.maxTaskAttempts})`);let Fn=v.leaseToken?String(v.leaseToken).trim():"";if(!Fn)return G(v,"dispatch_start_failed: claimed task missing leaseToken \u2014 refusing local spawn");let Iv=b(`t-${v.id}-a${v.attempt}`),Wt=ki({explicitModel:e.model?String(e.model):void 0,explicitProvider:e.provider?String(e.provider):void 0,explicitProviderIsOperatorOverride:!!e.provider,task:rf(v)});try{let ll=v.planId?String(v.planId):void 0,gs=Nf({title:v.title?String(v.title):void 0,description:v.description?String(v.description):null,executorRef:v.executorRef?String(v.executorRef):null,prUrl:v.prUrl?String(v.prUrl):null,branch:v.branch?String(v.branch):null}),Ye=Li(i,{name:Iv,task:Qg(v,a),ownedPaths:e.owned?String(e.owned).split(",").map(Ov=>Ov.trim()).filter(Boolean):[],model:Wt.model,provider:Wt.provider,routingRule:Wt.rule,requestedModel:Wt.requestedModel,agentOsId:a,taskId:String(v.id),planId:ll,branch:gs?.targetPrBranch??void 0,executorRef:v.executorRef?String(v.executorRef):void 0,parentTaskId:v.parentTaskId?String(v.parentTaskId):void 0,taskTitle:v.title?String(v.title):void 0,taskPrUrl:gs?.targetPrUrl??(v.prUrl?String(v.prUrl):void 0),repairTargetPrUrl:gs?.targetPrUrl,repairTargetBranch:gs?.targetPrBranch??void 0,instructionPolicyMarkdown:A?.instructionPolicyMarkdown??null,instructionPolicyFingerprint:A?.instructionPolicyFingerprint??null,instructionPolicyEvidence:A?.instructionPolicyEvidence??null,memoryQualityCapture:A?.memoryQualityCapture??null,memoryQualityPromptMarkdown:A?.memoryQualityPromptMarkdown??null,personaMarkdown:A?.personaMarkdown??null,personaSlug:A?.personaSlug??de,personaEvidence:A?.personaEvidence??null,contextEnvelopeMarkdown:A?.contextEnvelopeMarkdown??null,contextEnvelopeEvidence:A?.contextEnvelopeEvidence??null,leaseOwner:p,leaseToken:Fn,dispatched:!0}),hs=await Jg({agentOsId:a,taskId:String(v.id),leaseOwner:p,expectedLeaseToken:Fn,worker:Ye,baseUrl:l,secret:c});if(!hs.ok)return qg(i.id,Ye,hs.error??"dispatch_start_readback_failed"),G(v,hs.error??"dispatch_start_readback_failed",{readback:hs.detail??null});Ye.leaseToken!==Fn&&(Ye.leaseToken=Fn,Ye.leaseOwner=p,K(i.id,Ye));let ip={taskId:v.id,started:!0,worker:Ye.name,pid:Ye.pid,branch:Ye.branch,model:Ye.model,provider:Wt.provider,routingRule:Wt.rule,instructionPolicyFingerprint:A?.instructionPolicyFingerprint??null,instructionPolicyRuleCount:Array.isArray(A?.instructionPolicyEvidence?.ruleSlugs)?A.instructionPolicyEvidence.ruleSlugs.length:null,personaSlug:A?.personaSlug??de,personaOperatingRuleCount:A?.personaEvidence?.operatingRuleCount??null};return Q.push(ip),Ge("worker_started",{lastOutcome:ip}),A?.instructionPolicyFingerprint&&console.error(`[dispatch] task ${j}: operating-rules policy injected fingerprint=${A.instructionPolicyFingerprint}`),A?.personaSlug&&console.error(`[dispatch] task ${j}: persona context injected slug=${A.personaSlug}`),A?.contextEnvelopeReady&&console.error(`[dispatch] task ${j}: context envelope injected anchor=${A.contextEnvelopeEvidence?.anchorTaskId??j}`),!0}catch(ll){return G(v,ll.message)}}let Ee=new Set;async function ps(S){let v=S.task,A=String(v.id);if(Ee.has(A))return G(v,"dispatch_retry_loop_prevented: task already failed to start this tick");let j=W(S)?await be(S):await wr(S);return j||Ee.add(A),j}for(let S of B.started)await ps(S);if(Cr.push(...B.skipped??[]),g)for(let S of Cr){let v=String(S.task.id);k.has(v)&&Q.push({taskId:v,started:!1,error:`exact_target_not_started:${S.skipReason}`,skipReason:S.skipReason,detail:S.reason??null,requestedTargetTaskIds:[...k]})}for(;!g&&Q.length<_;){if(ve()){let A={started:!1,error:"dispatch_circuit_breaker: start readback failed; stopping top-up for this tick",nonFatal:!0};Q.push(A),Ge("circuit_breaker",{lastOutcome:A});break}let S=await F(1);if(!S.dispatch.ok||!S.result){let A=Ym(S.dispatch.response),j=Dt();Ve=A&&j>0;let de={started:!1,error:"dispatch_next request failed during top-up",httpStatus:S.dispatch.status,response:S.dispatch.response,...Ve?{nonFatal:!0,partialTopUp:!0}:{}};Q.push(de),Ge("top_up_failed",{partialTopUpInterrupted:Ve,lastOutcome:de});break}Tt+=Number(S.result.inspected)||0,Cr.push(...S.result.skipped??[]);let v=S.result.started??[];if(v.length===0)break;for(let A of v){if(Q.length>=_)break;await ps(A)}}let ms=Q.filter(S=>S.started).length,Mt=zg(B),fs=Xg(B),tp=ms===0&&(Mt?.capacityIdle===!0||Number(B.resourceGate?.slotsAvailable)>0);if(tp&&Mt?.summary){let S=Mt.skipReasonCounts?.retry_ceiling_exceeded??0,v=B.overAttemptIdleRecovery??Mt.overAttemptIdleRecovery,A=v?.attempted===!0?`; over_attempt_recovery minted=${v.minted??0} started=${v.started??0}`:S>0?"; over_attempt_recovery not attempted":"",j=fs?`; dispatch_skip_drain scanned=${fs.scanned??0} advanced=${fs.advanced??0}`:"";console.error(`[dispatch] ${Mt.summary}${S>0?`; retry_ceiling_exceeded=${S}`:""}${A}${j}`)}let np={runId:i.id,agentOsId:a,dryRun:!1,leaseOwner:p,startedCount:ms,capacityIdle:tp,admissionExhaustion:Mt,dispatchSkipDrain:fs,outcomes:Q,skipped:Cr.map(S=>({taskId:S.task.id,skipReason:S.skipReason})),inspected:Tt,pagesScanned:B.pagesScanned??null,candidatesExhausted:B.candidatesExhausted??null,diskGate:B.diskGate,resourceGate:B.resourceGate,...Ve?{partialTopUpInterrupted:!0}:{},dispatchCallbackTimeoutMs:$},op=S=>!S.started&&S.nonFatal!==!0,Av=Q.some(op),sp=Ve&&ms>0?!0:!Av;if(rc({runId:i.id,agentOsId:a,phase:"complete",partial:Ve,startedCount:ms,ok:sp}),r)return{ok:sp,...np};console.log(JSON.stringify(np,null,2)),Q.some(op)&&process.exit(1)}catch(i){if(r)return{ok:!1,error:i.message};console.error(`run dispatch failed: ${i.message}`),process.exit(1)}}Vt();Es();jt();jt();import{unlinkSync as px}from"node:fs";function qi(e){let r=process.env[e];return r==="1"||r==="true"||r==="yes"}function Zg(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)?n:r}function mx(e,r,t){return e.length===0?[]:t?[...e]:e.length<=r?[]:e.slice(r)}function Do(e={}){let r=e.execute===!0||qi("KYNVER_WSL_CRASH_DUMP_EXECUTE")||qi("KYNVER_CLEANUP_EXECUTE"),t=e.purgeAll===!0||qi("KYNVER_WSL_CRASH_DUMP_PURGE_ALL"),n=Math.max(0,e.keepNewest??Zg("KYNVER_WSL_CRASH_DUMP_KEEP_NEWEST",t?0:1)),o=ur({forceWsl:e.forceWsl});if(!o?.path)return{observation:o,execute:r,keepNewest:n,removed:[],removedBytes:0,skipped:o?.probeError?[{path:o.path??"(unresolved)",reason:o.probeError}]:[]};let s=mx(o.dumps,n,t),i=[],a=[],l=0;for(let c of s){if(!r){a.push({path:c.path,reason:"dry_run"});continue}try{px(c.path),i.push({path:c.path,bytes:c.bytes,name:c.name}),l+=c.bytes}catch(u){a.push({path:c.path,reason:u.message})}}return{observation:o,execute:r,keepNewest:n,removed:i,removedBytes:l,skipped:a}}function cu(e){return e?qi("KYNVER_WSL_CRASH_DUMP_CLEANUP")||!e.ok?!0:e.dumpCount>Zg("KYNVER_WSL_CRASH_DUMP_KEEP_NEWEST",1):!1}Jt();Ul();Ml();pr();I();Oe();import fx from"node:os";function Mo(e,r={}){let t=(r.boxKind??qe(y())).trim().toLowerCase()||"forge",n=r.hostLabel??fx.hostname();return{boxId:r.boxId??Ro(t,n),boxKind:t,displayName:r.displayName??null,hostLabel:n,observedAt:r.observedAt??new Date().toISOString(),totalMemBytes:e.totalMemBytes,freeMemBytes:e.freeMemBytes,activeWorkers:e.activeWorkers,maxConcurrentWorkers:e.maxConcurrentWorkers,autoCap:e.autoCap,slotsAvailable:e.slotsAvailable,harnessRunId:r.harnessRunId??null,queuedTasks:r.queuedTasks??null,reason:e.reason,...r.prEvidence?.length?{prEvidence:r.prEvidence}:{}}}function gx(e){let r={ts:e.ts??new Date().toISOString(),phase:e.phase,summary:e.summary,changedFiles:e.changedFiles??[],blocker:e.blocker??null};return e.boxResourceSnapshot&&(r.boxResourceSnapshot=e.boxResourceSnapshot),e.prEvidence?.length&&(r.prEvidence=e.prEvidence),`${JSON.stringify(r)}
|
|
36
|
-
`}z();eo();function hx(e){if(e.skipReason==="engagement_required")return!0;let r=e.reason??"";return r.includes("engagement_required")||r.includes("engagement_not_found")||r.includes("engagement_expired")||r.includes("engagement_revoked")}Kl();Qn();pr();Ll();Jt();function zi(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="object"&&!Array.isArray(e)?Object.keys(e).length>0:!0}function kx(e){let r=e.lastHeartbeatPhase?.trim();if(!r||r==="complete")return null;let t=e.lastHeartbeatSummary?.trim();return t?{summary:t,handoffState:"exited_without_complete_heartbeat",lastHeartbeatPhase:r,...e.heartbeatBlocker?{blocker:e.heartbeatBlocker}:{}}:null}function yx(e){let r=Us(e);return r?{summary:r.reason,handoffState:"exit_failure",blocked:r.blocked}:null}function uu(e){let{worker:r,status:t}=e;if(zi(t.finalResult)){let l=ce(r.heartbeatPath),c=ze(l),u=zi(c)&&JSON.stringify(c)===JSON.stringify(t.finalResult)?"heartbeat_complete":"stdout_stream";return{finalResult:t.finalResult,source:u,snapshot:pt(t)}}if(t.alive)return null;let n=Ar(r.stdoutPath);if(zi(n.finalResult)){let l={...t,finalResult:n.finalResult};return{finalResult:n.finalResult,source:"stdout_stream",snapshot:pt(l)}}let o=ce(r.heartbeatPath),s=ze(o);if(zi(s)){let l={...t,finalResult:s,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary};return{finalResult:s,source:"heartbeat_complete",snapshot:pt(l)}}let i=yx(t.error??n.error);if(i){let l={...t,finalResult:i};return{finalResult:i,source:"exit_failure",snapshot:pt(l)}}let a=kx(o);if(a){let l={...t,finalResult:a,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary};return{finalResult:a,source:"heartbeat_summary",snapshot:pt(l)}}return null}function du(e,r){return e.completionSnapshot?.finalResult!=null?!1:(e.completionSnapshot=r.snapshot,e.completionHandoffSource=r.source,!0)}import{createHash as eh}from"node:crypto";function Xi(e){return JSON.stringify(pu(e))}function pu(e){if(Array.isArray(e))return e.map(pu);if(e&&typeof e=="object"){let r={};for(let t of Object.keys(e).sort())r[t]=pu(e[t]);return r}return e}function Rx(e){return`ib1-${eh("sha256").update(Xi(e),"utf8").digest("hex").slice(0,16)}`}function vx(e){return`ib-${eh("sha256").update(Buffer.from(e)).digest("hex").slice(0,12)}`}function Qi(e){if(!e)return null;let r=e.trim();if(!r)return null;if(/^[0-9a-fA-F]{64}$/.test(r))return new Uint8Array(r.match(/.{2}/g).map(t=>parseInt(t,16)));try{let t=Buffer.from(r,"base64");if(t.length===32)return new Uint8Array(t)}catch{}return null}function kn(e){if(!e||typeof e!="object")return!1;let r=e;if(typeof r.signature!="string"||!r.signature||typeof r.publicKeyId!="string"||!r.publicKeyId)return!1;let t=r.bundle;return!(!t||typeof t!="object"||typeof t.version!="string"||!t.version||typeof t.generatedAt!="string"||!Array.isArray(t.personas)||!t.instructions||typeof t.instructions!="object"||!t.policyThresholds||typeof t.policyThresholds!="object")}var rh={"ib-3bab6314f0ba":"53a2040646cd479e1f5f1aea9abf7848ce8b62e32001efb8044dfd90e8ab87ed","ib-26e6c695da06":"bb1700f25b2ee7d7cdcdb9f446f0f44ef2cc22a3096bc161232fb658e7cdaf38"};function mu(e,r=process.env){let t=Qi(r.KYNVER_INSTRUCTION_BUNDLE_PUBLIC_KEY);if(t)return t;let n=rh[e];return n?Qi(n):null}import{createPublicKey as bx,verify as Sx}from"node:crypto";var Cx=Buffer.from("302a300506032b6570032100","hex");function wx(e){return bx({key:Buffer.concat([Cx,Buffer.from(e)]),format:"der",type:"spki"})}function th(e,r){if(!kn(e))return{ok:!1,reason:"malformed signed bundle payload"};let t;try{t=Buffer.from(e.signature,"base64url")}catch{return{ok:!1,reason:"signature is not base64url"}}if(t.length!==64)return{ok:!1,reason:"signature is not a 64-byte Ed25519 signature"};try{let n=Buffer.from(Xi(e.bundle),"utf8");return Sx(null,n,wx(r),t)?{ok:!0,bundle:e.bundle}:{ok:!1,reason:"Ed25519 signature mismatch"}}catch(n){return{ok:!1,reason:`signature verification failed: ${n.message}`}}}function fu(e,r=process.env){if(!kn(e))return{ok:!1,reason:"malformed signed bundle payload"};let t=mu(e.publicKeyId,r);return t?th(e,t):{ok:!1,reason:`no verification key for publicKeyId "${e.publicKeyId}" (not pinned; set KYNVER_INSTRUCTION_BUNDLE_PUBLIC_KEY)`}}import{mkdirSync as _x,readFileSync as xx,renameSync as Ex,writeFileSync as Px}from"node:fs";import{homedir as Ax}from"node:os";import nh from"node:path";function gu(e){let r=e.replace(/[^A-Za-z0-9_-]/g,"_");return nh.join(Ax(),".kynver",`instruction-bundle-${r}.json`)}function hu(e,r){try{let t=gu(e);_x(nh.dirname(t),{recursive:!0});let n=`${t}.tmp-${process.pid}`;Px(n,JSON.stringify(r),"utf8"),Ex(n,t)}catch{}}function ku(e){try{let r=xx(gu(e),"utf8"),t=JSON.parse(r);return kn(t)?t:null}catch{return null}}var oh=15*6e4,Ix=1e4,hr={lastAttemptAtMs:0,etag:null,diskCacheTried:!1,routeMissingLogged:!1};function Wo(e,r){console.error(JSON.stringify({event:e,...r}))}function sh(e,r,t){let n=fu(e);return n.ok?(tc(n.bundle,r),r==="server"&&hu(t,e),!0):(Wo("instruction_bundle_signature_invalid",{agentOsId:t,source:r,publicKeyId:e.publicKeyId,reason:n.reason}),!1)}function Uo(e){if(hr.diskCacheTried)return!1;hr.diskCacheTried=!0;let r=ku(e);return r?sh(r,"disk",e):!1}async function yu(e){let r=e.nowMs??Date.now(),t=()=>({source:fr(),version:Nr(),updated:!1});if(!e.force&&r-hr.lastAttemptAtMs<oh)return t();hr.lastAttemptAtMs=r;let n=e.baseUrl?.trim().replace(/\/$/,""),o=e.secret?.trim();if(!n||!o)return fr()==="embedded"&&Uo(e.agentOsId)?{...t(),updated:!0}:t();let s=e.fetchImpl??fetch,i=new AbortController,a=setTimeout(()=>i.abort(),Ix);try{let l=He(o);delete l["Content-Type"],hr.etag&&fr()==="server"&&(l["If-None-Match"]=hr.etag);let c=await s(`${n}/api/agent-os/by-id/${encodeURIComponent(e.agentOsId)}/runtime/instruction-bundle`,{headers:l,signal:i.signal});if(c.status===304)return t();if(c.status===404)return hr.routeMissingLogged||(hr.routeMissingLogged=!0,Wo("instruction_bundle_route_missing",{agentOsId:e.agentOsId,baseUrl:n})),fr()==="embedded"&&Uo(e.agentOsId)?{...t(),updated:!0}:t();if(!c.ok)return Wo("instruction_bundle_fetch_failed",{agentOsId:e.agentOsId,status:c.status}),fr()==="embedded"&&Uo(e.agentOsId)?{...t(),updated:!0}:t();let u=await c.json().catch(()=>null);return!u||!sh(u,"server",e.agentOsId)?fr()==="embedded"&&Uo(e.agentOsId)?{...t(),updated:!0}:t():(hr.etag=c.headers.get("etag"),Wo("instruction_bundle_loaded",{agentOsId:e.agentOsId,version:Nr(),publicKeyId:u.publicKeyId}),{...t(),updated:!0})}catch(l){return Wo("instruction_bundle_fetch_error",{agentOsId:e.agentOsId,error:l instanceof Error?l.message:String(l)}),fr()==="embedded"&&Uo(e.agentOsId)?{...t(),updated:!0}:t()}finally{clearTimeout(a)}}var Ru="openai-codex",Ox=new Set(["upstream_503","connection_refused","connection_reset","sse_no_event","sse_idle_timeout"]),Nx=[/\bsk-[a-zA-Z0-9_-]{8,}\b/g,/\bBearer\s+[a-zA-Z0-9._-]{8,}\b/gi,/\baccess[_-]?token["\s:=]+[a-zA-Z0-9._-]{8,}/gi];function kr(e,r=400){let t=String(e??"").replace(/\s+/g," ").trim();for(let n of Nx)t=t.replace(n,"[redacted]");return t.length>r?`${t.slice(0,r)}\u2026`:t}function Tx(e,r){let t=[];e instanceof Error?(t.push(e.message),t.push(e.name)):typeof e=="string"?t.push(e):e!=null&&t.push(String(e));let n=e,o=r??n?.status_code??n?.statusCode??void 0;return o!=null&&t.push(`http ${o}`),{haystack:t.join(" ").toLowerCase(),statusCode:o}}function ah(e,r){let{haystack:t,statusCode:n}=Tx(e,r),o=e instanceof Error?e.message:typeof e=="string"?e:String(e??"");if(n===402||/billing|credit|payment required|insufficient_quota/.test(t))return{errorClass:"billing",summary:kr(o||"Billing or credits exhausted"),statusCode:n,transient:!1};if(n===401||n===403||/\bunauthorized\b|\bforbidden\b/.test(t))return{errorClass:"auth",summary:kr(o||"Authentication failed"),statusCode:n,transient:!1};if(n===429||/rate limit|too many requests|throttl/.test(t))return{errorClass:"rate_limit",summary:kr(o||"Rate limited"),statusCode:n,transient:!0};if(n===503||/upstream connect error|connection termination|remote connection failure|delayed connect error/.test(t))return{errorClass:"upstream_503",summary:kr(o||"ChatGPT Codex backend returned HTTP 503"),statusCode:n??503,transient:!0};if(/connection refused/.test(t))return{errorClass:"connection_refused",summary:kr(o||"Connection refused by ChatGPT Codex backend"),statusCode:n,transient:!0};if(/no sse events|no bytes within|no stream events|codex stream produced no/.test(t)){let s=/no bytes|ttfb|first byte/.test(t)?"sse_no_event":"sse_idle_timeout";return{errorClass:s,summary:kr(o||(s==="sse_no_event"?"Codex stream opened but sent no events":"Codex stream stalled after the first event")),statusCode:n,transient:!0}}return/connection reset|connection lost|connection closed|disconnect\/reset/.test(t)?{errorClass:"connection_reset",summary:kr(o||"Connection reset while talking to ChatGPT Codex"),statusCode:n,transient:!0}:{errorClass:"unknown",summary:kr(o||"Unknown provider error"),statusCode:n,transient:!1}}function lh(e){let r=e.env??process.env,t=Math.max(1,e.defaultRetries??3),n=String(e.provider??"").toLowerCase(),o=String(e.platform??"").toLowerCase();if(n!==Ru||o!=="cron")return t;let s=r.HERMES_CODEX_CRON_API_MAX_RETRIES?.trim();if(!s)return Math.max(t,5);let i=Number.parseInt(s,10);return!Number.isFinite(i)||i<1?Math.max(t,5):Math.max(t,i)}var ih={upstream_503:"ChatGPT Codex backend outage (HTTP 503)",connection_refused:"ChatGPT Codex backend refused the connection",connection_reset:"ChatGPT Codex connection dropped mid-request",sse_no_event:"Codex stream never started (no SSE events)",sse_idle_timeout:"Codex stream stalled (no SSE events after the first byte)",rate_limit:"ChatGPT Codex rate limit",billing:"ChatGPT Codex billing or quota limit",auth:"ChatGPT Codex authentication problem",unknown:"ChatGPT Codex provider error"};function ch(e){let r=e.provider?.trim()||Ru,t=e.model?.trim()||"(unknown model)",n=e.jobName?.trim()||"Scheduled Hermes job",o=ih[e.errorClass]??ih.unknown,s=e.degraded?"degraded":"failed";return[`\u26A0\uFE0F ${n} \u2014 AI provider ${s} (not a Kynver harness failure).`,"",`Provider: ${r} (ChatGPT Codex subscription)`,`Model: ${t}`,`What happened: ${o} after ${e.attempts} attempt(s) with backoff.`,`Details: ${e.summary}`,"","This is a ChatGPT/Codex API issue on chatgpt.com \u2014 not AgentOS, not the Kynver runtime, and not your local harness.","The cron job will run again on its next schedule. If it persists, check ChatGPT/Codex status or re-auth with: hermes auth status openai-codex"].join(`
|
|
37
|
-
`)}function
|
|
21
|
+
${n}`;return ew.some(s=>s.test(o))?"privileged":r.includes("provider:claude")||r.includes("deep_review")||r.includes("security")||r.includes("landing")||r.includes("review")||t.startsWith("land:")||r.includes("implementer")||r.includes("repair")||t.includes("implement")?"elevated":rw.some(s=>s.test(o))?"low":"elevated"}function tw(e){let r=at(e.provider),t=e.escalatedFrom&&e.escalatedReason?`Escalated from ${e.escalatedFrom} (${e.escalatedReason}); using ${r.displayName} (${r.costTier} tier)`:`${r.displayName} selected for ${e.riskClass} orchestration (${r.costTier} tier, auth=${e.authSource})`;return{provider:e.provider,model:e.model,authSource:e.authSource,costTier:r.costTier,riskClass:e.riskClass,costRationale:t,routingRule:e.routingRule,escalatedFrom:e.escalatedFrom,escalatedReason:e.escalatedReason}}function nw(e){let r=e.inventory??hc();return e.codexBinding?{...r,bindings:{...r.bindings,codex:e.codexBinding}}:r}function lt(e){let r=tw({provider:e.providerId,model:e.model,authSource:e.binding.authSource,riskClass:e.riskClass,routingRule:e.routingRule,escalatedFrom:e.escalatedFrom,escalatedReason:e.escalatedReason});return{provider:e.providerId,model:e.model,rule:r.routingRule,audit:r}}function yc(e){let r=e.task??{},t=ff(r),n=nw({inventory:e.inventory,codexBinding:e.codexBinding??(e.inventory?null:Tr())}),o=e.preferLowCost===!1?null:e.explicitProvider?.trim().toLowerCase(),s=e.explicitModel?.trim()||void 0,i=Oe;if(o==="codex"||o==="provider:codex"){let c=n.bindings.codex;if(!c.ready){let u=pi({inventory:n,riskClass:t});return lt(u?{providerId:u.providerId,binding:u.binding,riskClass:t,routingRule:"orchestration:explicit_codex_unavailable_cost_aware",model:s,escalatedFrom:"codex",escalatedReason:c.note??"codex oauth not bound"}:{providerId:i,binding:n.bindings[i],riskClass:t,routingRule:"orchestration:codex_unavailable_escalate_cursor",model:s,escalatedFrom:"codex",escalatedReason:c.note??"codex oauth not bound"})}return lt({providerId:"codex",binding:c,riskClass:t,routingRule:"orchestration:explicit_codex",model:s})}if(o==="cursor"||o==="provider:cursor"){let c=n.bindings.cursor;if(c.ready)return lt({providerId:"cursor",binding:c,riskClass:t,routingRule:"orchestration:explicit_cursor",model:s})}if(o==="claude"||o==="provider:claude"){let c=n.bindings.claude;if(c.ready)return lt({providerId:"claude",binding:c,riskClass:t,routingRule:"orchestration:explicit_claude",model:s})}let a=pi({inventory:n,riskClass:t});if(a)return lt({providerId:a.providerId,binding:a.binding,riskClass:t,routingRule:`orchestration:cost_aware_${a.providerId}`,model:s,escalatedFrom:a.escalatedFrom,escalatedReason:a.escalatedReason});let l=n.bindings.codex;return lt({providerId:i,binding:n.bindings[i],riskClass:t,routingRule:l.ready?"orchestration:inventory_empty_default_cursor":"orchestration:codex_unavailable_default_cursor",model:s,...l.ready?{}:{escalatedFrom:"codex",escalatedReason:l.note??"codex oauth not bound"}})}jr();C();import{closeSync as hf,openSync as kf}from"node:fs";import{spawn as lw}from"node:child_process";var ow=/-(?:thinking(?:-(?:high|medium|low|minimal|max|none))?|high|medium|low|minimal)$/i;function sw(e){return e.replace(ow,"")}var iw=/^(?:gpt-|gpt5|o1|o3|o4|gemini-|grok-|composer|deepseek|llama|mistral|qwen|command-)/i;function Rc(e){return/^claude[-_]/i.test(e)||/^(?:opus|sonnet|haiku)\b/i.test(e)}var aw=new Set(["cursor"]);function gf(e){let r=e.trim().toLowerCase();return aw.has(r)?"auto":null}function gi(e,r){let t=(e??"").trim();if(!t)return{ok:!0,model:r,normalized:!1};let o=sw(t).trim()||r;return iw.test(o)||!Rc(o)&&o!==r?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is not a Claude model \u2014 the "claude" provider drives the Claude CLI, which only accepts claude-* model ids (got "${o}"). Pick a Claude model or switch the worker provider.`}:o!==t?{ok:!0,model:o,normalized:!0,requested:t,note:`normalized model "${t}" \u2192 "${o}" (the Claude CLI rejects reasoning-effort suffixes)`}:{ok:!0,model:o,normalized:!1}}function ct(e,r){let t=(e??"").trim();return t?Rc(t)?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is a Claude model but the worker provider is "codex". Switch the provider or pick a Codex/OpenAI model.`}:{ok:!0,model:t,normalized:!1}:{ok:!0,model:r,normalized:!1}}function hi(e,r){let t=(e??"").trim();if(!t)return{ok:!0,model:r,normalized:!1};let n=gf(t);return n?{ok:!0,model:n,normalized:!0,requested:t,note:`normalized model "${t}" \u2192 "${n}" (Cursor provider alias \u2014 use "auto" or a composer id, not "cursor")`}:Rc(t)?{ok:!1,model:t,normalized:!1,requested:t,note:`model "${t}" is a Claude model but the worker provider is "cursor". Switch the provider to "claude" or pick a Cursor model.`}:{ok:!0,model:t,normalized:!1}}var pn="claude-sonnet-4-6",yf={name:"claude",defaultModel:pn,preflightModel(e){return gi(e,pn)},start(e){let r=gi(e.model,pn);if(!r.ok)throw new Error(`claude provider model preflight failed: ${r.note}`);let t=r.model,n=kf(e.stdoutPath,"a"),o=kf(e.stderrPath,"a"),s=["ignore",n,o],i=lw("claude",["--model",t,"-p","--verbose","--permission-mode","bypassPermissions","--output-format","stream-json","--include-partial-messages",e.prompt],pe({cwd:e.worktreePath,detached:!0,stdio:s,env:We(process.env)}));if(hf(n),hf(o),!i.pid)throw new Error("failed to spawn claude worker process (is the `claude` CLI on PATH?)");return i.unref(),{pid:i.pid,model:t}}};jr();C();import{closeSync as Sf,existsSync as dw,openSync as Cf}from"node:fs";import{spawn as wf}from"node:child_process";jr();C();import{closeSync as Rf,openSync as bf}from"node:fs";import{spawn as cw}from"node:child_process";var ki=process.env.KYNVER_CODEX_DEFAULT_MODEL?.trim()||"gpt-5.4";function uw(){return We({...process.env,CI:"1",NO_COLOR:"1",HERMES_ACCEPT_HOOKS:process.env.HERMES_ACCEPT_HOOKS??"1"})}function vf(e,r){let t=process.env.KYNVER_HERMES_CODEX_MAX_TURNS?.trim()||"40";return["chat","-q",r,"--provider","openai-codex","-m",e,"-Q","--accept-hooks","--max-turns",t,"--toolsets","hermes-cli"]}var bc={name:"hermes-codex",defaultModel:ki,preflightModel(e){return ct(e,ki)},start(e){let r=ct(e.model,ki);if(!r.ok)throw new Error(`hermes-codex provider model preflight failed: ${r.note}`);let t=r.model,n=bf(e.stdoutPath,"a"),o=bf(e.stderrPath,"a"),s=["ignore",n,o],i=Ne("hermes",["KYNVER_HERMES_BIN","HERMES_BIN"]),a=vf(t,e.prompt),l=cw(i,a,pe({cwd:e.worktreePath,detached:!0,shell:!1,stdio:s,env:uw()}));if(Rf(n),Rf(o),!l.pid)throw new Error(`failed to spawn Hermes openai-codex worker (is \`${i}\` on PATH? run \`hermes auth status openai-codex\`)`);return l.unref(),{pid:l.pid,model:t}}};function pw(){return process.env.KYNVER_CODEX_DEFAULT_MODEL?.trim()||"gpt-5.4"}var Dr=pw();function mw(){return process.env.KYNVER_CODEX_BIN?.trim()||process.env.CODEX_BIN?.trim()||"codex"}function fw(){return We({...process.env,CI:"1",NO_COLOR:"1"})}function _f(e,r){return["exec","--sandbox","read-only","--ask-for-approval","never","--model",e,r]}function gw(e,r,t){if(!(process.platform!=="win32"&&dw("/usr/bin/script")))return wf(e,r,t);let o=[e,...r].map(s=>`'${s.replace(/'/g,"'\\''")}'`).join(" ");return wf("script",["-qfc",o,"/dev/null"],t)}var vc={name:"codex",defaultModel:Dr,preflightModel(e){return ct(e,Dr)},start(e){if(Tr().path==="hermes_openai_codex")return bc.start(e);let t=ct(e.model,Dr);if(!t.ok)throw new Error(`codex provider model preflight failed: ${t.note}`);let n=t.model,o=Cf(e.stdoutPath,"a"),s=Cf(e.stderrPath,"a"),i=["ignore",o,s],a=mw(),l=_f(n,e.prompt),c=gw(a,l,pe({cwd:e.worktreePath,detached:!0,shell:!1,stdio:i,env:fw()}));if(Sf(o),Sf(s),!c.pid)throw new Error(`failed to spawn Codex worker (is \`${a}\` on PATH? run \`codex login\` or set CODEX_API_KEY)`);return c.unref(),{pid:c.pid,model:n}}};var hw="claude-sonnet-4-6",cc="composer-2.5";function yi(e,r){let t=e[r];return typeof t=="string"?t.trim():""}function xf(e){return e.toLowerCase()}function Cc(e=R()){let r=e.defaultModel?.trim();if(r)return r;let t=process.env.KYNVER_DEFAULT_MODEL?.trim();return t||hw}function Sc(e){let r=(e??"").toLowerCase();return!r||r.includes("composer")||r.includes("cursor")||r.includes("codex")||r.startsWith("gpt-")||r.startsWith("gpt5")?"cursor":/^claude[-_]/i.test(r)||/^(?:opus|sonnet|haiku)\b/i.test(r)?"claude":"cursor"}function kw(e,r){let t=e.trim().toLowerCase(),n=r?.trim();return t==="cursor"?{model:cc,provider:"cursor",rule:n&&n!=="cursor"?"explicit:model_provider_alias_overrode_provider":"explicit:model_provider_alias",requestedModel:e}:t==="claude"||t==="anthropic"?{model:pn,provider:"claude",rule:n&&n!=="claude"?"explicit:model_provider_alias_overrode_provider":"explicit:model_provider_alias",requestedModel:e}:null}function Ef(e,r){return!!(e.includes("deep")&&e.includes("review")||e.includes("security")||e.includes("plan_author")||e.includes("plan-author")||r.includes("deep review")||r.includes("security review")||e.includes("plan")&&!e.includes("review")&&(e.includes("author")||e.includes("strategy")))}function yw(e){let r=xf(yi(e,"executorRef")),t=yi(e,"title").toLowerCase(),n=yi(e,"priority")||"normal",o=xf(yi(e,"roleLane"));if(r.includes("provider:codex")||r.startsWith("codex:"))return{provider:"codex",model:Dr,rule:"lane:codex_orchestration"};if(r.includes("cursor")||r.includes("composer")||r.includes("copilot")||o==="implementer"||o==="repair_implementer")return{provider:"cursor",rule:"lane:implementation"};if(r.includes("codex"))return{provider:"codex",model:Dr,rule:"lane:codex_orchestration"};if(r.includes("landing")||t.startsWith("land:")||t.includes(" merge"))return{provider:"cursor",rule:"lane:landing"};if(r.includes("review")||/^review[\s:]/.test(t)||o.includes("review"))return Ef(r,t)||o==="deep_reviewer"?{provider:"cursor",rule:"lane:deep_review"}:{provider:"cursor",rule:"lane:review"};if(Ef(r,t)||o==="plan_author")return{provider:"cursor",rule:"lane:planning"};if(n==="critical")return{provider:"cursor",rule:"priority:critical"};if(n==="high")return{provider:"cursor",rule:"priority:high"};if(n==="low")return{provider:"cursor",rule:"priority:low"};let s=Cc();return{model:s,provider:Sc(s),rule:"default:global"}}function Ri(e){let r;if(e.explicitModel?.trim()){let o=e.explicitModel.trim(),s=kw(o,e.explicitProvider);s?r=s:r={model:o,provider:e.explicitProvider?.trim()||Sc(o),rule:"explicit:cli",requestedModel:o}}else if(e.task&&Object.keys(e.task).length>0){let o=yw(e.task);r={...o,requestedModel:o.model}}else{let o=Cc();r={model:o,provider:e.explicitProvider?.trim()||Sc(o),rule:"default:global",requestedModel:o}}let t=lc({routing:r,task:e.task,explicitProvider:e.explicitProvider,explicitProviderIsOperatorOverride:e.explicitProviderIsOperatorOverride});if(!e.task||Object.keys(e.task).length===0||t.rule==="explicit:model_provider_alias"||t.rule==="explicit:model_provider_alias_overrode_provider"||t.rule==="explicit:cli"||Xe(t.provider)&&(e.explicitProviderIsOperatorOverride||ui(e.task)))return t;let n=yc({task:e.task,explicitProvider:e.explicitProvider??t.provider,explicitModel:t.model});return{provider:n.provider,model:n.provider==="codex"?n.model??t.model??Dr:t.model,rule:n.rule,requestedModel:t.requestedModel,orchestrationAudit:n.audit}}function Pf(e,r,t){return e||r||t||Cc()||pn}function Af(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function Of(){return{maxTaskAttempts:Af(process.env.KYNVER_MAX_TASK_ATTEMPTS,Math.floor(it("harness.maxTaskAttempts",4))),dispatchCooldownMs:Af(process.env.KYNVER_DISPATCH_COOLDOWN_MS,Math.floor(it("harness.dispatchCooldownMs",5e3)))}}N();import Sw from"node:path";D();z();C();var wc="kynver-harness:",If="@runner:";function _c(e){return e?.trim()?e.trim():null}function Rw(e){let r=_c(e);if(!r?.startsWith(wc))return null;let t=r.slice(wc.length),n=t.indexOf(If);return n>=0?t.slice(0,n).trim()||null:t.trim()||null}function xc(e,r){let t=e.trim(),n=r.trim();return`${wc}${t}${If}${n}`}function Ec(e,r){let t=_c(r);return t?Rw(e)===t:!1}function bi(e){let r=_c(e.workerLeaseOwner);return r&&Ec(r,e.runId)?r:xc(e.runId,e.runnerId)}import Nf from"node:os";Ie();Ie();import bw from"node:os";function vw(e=process.env){return Ae(e).boxKind}function bo(e,r){let t=(r??bw.hostname()).trim().toLowerCase().replace(/\s+/g,"-")||"unknown-host";return`${e}:${t}`}function Mr(e){return e?.trim()?e.trim():null}function er(e={}){let r=e.env??process.env;return{runnerId:Mr(r.KYNVER_RUNTIME_ID)??Mr(r.OPENCLAW_RUNTIME_ID)??Mr(r.HOSTNAME)??Nf.hostname(),hostname:Mr(r.HOSTNAME)??Nf.hostname(),profile:Mr(r.KYNVER_RUNNER_PROFILE)??Mr(r.OPENCLAW_RUNNER_PROFILE),harnessRepo:Mr(r.KYNVER_HARNESS_REPO)??Mr(r.KYNVER_DEFAULT_REPO),runId:e.runId??null,instructionBundleVersion:Nr()}}N();async function mn(e){let r=new Map,t=e.agentOsId?.trim();if(!t||e.taskIds.length===0)return r;let n=V(e.baseUrl);try{let o=await J(e.secret,t,{baseUrl:n}),s=`${n}/api/agent-os/by-id/${encodeURIComponent(t)}/harness/monitor/task-leases`,i=await re(s,o,{taskIds:[...new Set(e.taskIds)]},{agentOsId:t,baseUrl:n});if(!i.ok||!i.response||typeof i.response!="object")return r;let a=i.response.tasks;if(!Array.isArray(a))return r;for(let l of a)l?.taskId&&r.set(l.taskId,l)}catch{}return r}D();async function vi(e){let r=e.worker.leaseOwner?.trim()??null,t=e.worker.leaseToken?.trim()??null;if(t)return{leaseOwner:r,leaseToken:t};let n=e.worker.taskId?.trim();if(!n)return{leaseOwner:r,leaseToken:null};let s=(await mn({agentOsId:e.agentOsId,taskIds:[n],baseUrl:e.baseUrl,secret:e.secret})).get(n),i=s?.leaseOwner?.trim()??null,a=s?.leaseToken?.trim()??null;if(!a)return{leaseOwner:r??i,leaseToken:null};let l=r??i;return(!e.worker.leaseToken||e.worker.leaseToken!==a)&&K(e.worker.runId,{...e.worker,...l?{leaseOwner:l}:{},leaseToken:a}),{leaseOwner:l,leaseToken:a}}function Tf(e,r){return w(Sw.join(P(e),"workers",v(r),"worker.json"),void 0)}async function Si(e,r){let t=L(e),n=String(r.agentOsId||"");if(!n)return{renewed:[],failed:[],skipped:[]};let o=V(r.baseUrl?String(r.baseUrl):void 0),s=await J(r.secret?String(r.secret):void 0,n,{baseUrl:o}),i=Number(r.leaseMs)>0?Math.floor(Number(r.leaseMs)):Ci,a=er({runId:e}).runnerId,l=[],c=[],u=[];for(let d of Object.keys(t.workers||{})){let f=Tf(e,d);if(!f?.taskId||!f.agentOsId){u.push(d);continue}if(!H(f.pid)){u.push(d);continue}if(M(f).status==="done"){u.push(d);continue}let m=bi({runId:e,workerLeaseOwner:f.leaseOwner??null,runnerId:a}),h=await vi({worker:f,agentOsId:n,baseUrl:o,secret:s}),k=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/${encodeURIComponent(f.taskId)}/renew-lease`,g=await re(k,s,{leaseOwner:h.leaseOwner??m,leaseDurationMs:i,...h.leaseToken?{leaseToken:h.leaseToken}:{}},{agentOsId:n,baseUrl:o});if(g.ok){l.push(d);continue}let y=g.response&&typeof g.response=="object"&&"reason"in g.response?String(g.response.reason??`http ${g.status}`):`http ${g.status}`;c.push({worker:d,reason:y})}return{renewed:l,failed:c,skipped:u}}function Df(e,r){let t=L(e);for(let n of Object.keys(t.workers||{})){let o=Tf(e,n);if(!(!o||o.taskId!==r||!H(o.pid)||M(o).status==="done"))return!0}return!1}Pe();D();D();import{existsSync as J_,mkdirSync as q_}from"node:fs";import fn from"node:path";var Cw=/<!--\s*harness-contract:\s*(\{[\s\S]*?\})\s*-->/i,ww="next-action-fix:";function wi(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function Mf(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:wi(e)}function _w(e){let r=(e.title??"").trim().toLowerCase();if(r.startsWith("fix:")||r.startsWith("repair:"))return!0;let t=(e.executorRef??"").toLowerCase();return!!(t.startsWith(ww)||t.includes("repair")||t.includes("unblock"))}function xw(e){let r={repairEnforceOriginalPr:!1,targetPrUrl:null,targetPrBranch:null};if(!e)return r;let t=e.match(Cw);if(!t?.[1])return r;try{let n=JSON.parse(t[1]),o=wi(String(n.targetPrUrl??n.target_pr_url??"")),s=wi(String(n.targetPrBranch??n.target_pr_branch??""));return{repairEnforceOriginalPr:n.repairEnforceOriginalPr===!0||n.repair_enforce_original_pr===!0||!!o,targetPrUrl:o?Mf(o):null,targetPrBranch:s}}catch{return r}}function Uf(e){if(!_w(e))return null;let r=xw(e.description),t=e.prUrl?Mf(e.prUrl):null,n=r.targetPrUrl??t;return n?{targetPrUrl:n,targetPrBranch:r.targetPrBranch??wi(e.branch)}:null}function Wf(e){return["Repair target PR policy:","- Work on the existing target PR branch \u2014 do not open a duplicate repair PR by default.",`- Canonical target PR: ${e.targetPrUrl}`,...e.targetPrBranch?[`- Canonical target branch: \`${e.targetPrBranch}\` (checkout is already on this branch).`]:[],`- Reconcile ${e.targetPrUrl} in structured finalResult.targetPrReconciliation.`,"- Only supersede the original when the branch is inaccessible: set supersedesOriginalTargetPr: true with reason and close/comment on the original PR."]}function Pc(e){let r=e.ownedPaths.length?`Owned paths: ${e.ownedPaths.join(", ")}. Do not edit outside these paths without stopping and reporting why.`:"Owned paths: unrestricted for this worker, but keep edits tightly scoped.",t=!!e.model?.toLowerCase().includes("haiku"),n=t?"compact":"full",o=t?e.planId?`Active planId: ${e.planId}`:"No planId on this worker.":e.planId?`Active planId: ${e.planId}${e.taskId?` \xB7 taskId: ${e.taskId}`:""}`:"No planId on this worker \u2014 still emit progress when you touch plan-scoped work.",s=[...un(`worker.prompt.progress.${n}`).split(`
|
|
22
|
+
`),o],i=un(`worker.prompt.merge_gate.${n}`).split(`
|
|
23
|
+
`),a=un(`worker.prompt.plan_artifacts.${n}`).split(`
|
|
24
|
+
`);return["You are running under the Kynver AgentOS runtime.","Immediately state your plan before editing.",r,`Worktree: ${e.worktreePath}`,`Progress heartbeat file: ${e.heartbeatPath}`,"After each major step, append one JSON line to the heartbeat file with fields: ts, phase, summary, changedFiles, blocker.","Before exiting, append a terminal heartbeat with phase `complete` and a structured finalResult object; if you cannot complete, append blocker plus the recovery next action instead of exiting silently.","Final response must include files changed, verification commands, and unresolved risks.",...un("worker.prompt.core_rules").split(`
|
|
25
|
+
`),"",...s,"",...i,"",...a,"",...e.contextEnvelopeMarkdown?.trim()?[e.contextEnvelopeMarkdown.trim(),""]:[],...e.personaMarkdown?.trim()?[e.personaMarkdown.trim(),""]:[],...e.instructionPolicyMarkdown?.trim()?["Operating rules (from AgentOS memory policy):",e.instructionPolicyMarkdown.trim(),""]:[],...e.memoryQualityMarkdown?.trim()?[e.memoryQualityMarkdown.trim(),""]:[],...e.repairTargetPrUrl?[...Wf({targetPrUrl:e.repairTargetPrUrl,targetPrBranch:e.repairTargetBranch??null}),""]:[],"Task:",e.task].join(`
|
|
26
|
+
`)}C();N();C();jr();import{closeSync as Oc,existsSync as Bf,mkdirSync as Iw,openSync as Ic,statSync as Nw,unlinkSync as Lf}from"node:fs";import{spawn as Tw}from"node:child_process";import Dw from"node:os";import rr from"node:path";import{existsSync as vo,readdirSync as Ew}from"node:fs";import ut from"node:path";var Pw=/^\d{4}\.\d{1,2}\.\d{1,2}-[a-f0-9]+$/i;function Aw(e){let t=e.split("-")[0].split(".");if(t.length!==3)return null;let[n,o,s]=t;return!n||!o||!s?null:+`${n}${o.padStart(2,"0")}${s.padStart(2,"0")}`}function Ow(e){let r=ut.join(e,"versions");if(!vo(r))return null;let t=null,n=-1;for(let o of Ew(r,{withFileTypes:!0})){if(!o.isDirectory()||!Pw.test(o.name))continue;let s=Aw(o.name);s==null||s<=n||(n=s,t=ut.join(r,o.name))}return t}function _i(e){let r=e?.trim()||ut.join(process.env.LOCALAPPDATA||"","cursor-agent"),t=ut.join(r,"node.exe"),n=ut.join(r,"index.js");if(vo(t)&&vo(n))return{nodeExe:t,indexJs:n,versionDir:r};let o=Ow(r);if(!o)return null;let s=ut.join(o,"node.exe"),i=ut.join(o,"index.js");return!vo(s)||!vo(i)?null:{nodeExe:s,indexJs:i,versionDir:o}}var Ac="composer-2.5",Mw=15e3,Uw=6e4,Ww=3e4;function Lw(e,r,t){return{executable:e,prefixArgs:[r],shell:!1,detached:!0,bundledVersionDir:t}}function Bw(e){if(process.platform==="win32"){let r=/\.(cmd|bat)$/i.test(e),t=/node\.exe$/i.test(e)&&Bf(rr.join(rr.dirname(e),"index.js"));if(r||t||e==="agent"){let o=r?_i(rr.dirname(e)):t?{nodeExe:e,indexJs:rr.join(rr.dirname(e),"index.js"),versionDir:rr.dirname(e)}:_i();if(o)return Lw(o.nodeExe,o.indexJs,o.versionDir);throw new Error("Cursor Agent on Windows has no headless bundled node.exe under %LOCALAPPDATA%\\cursor-agent\\versions\\\u2026. Run `agent login` / update Cursor Agent CLI, use `--provider claude`, or set KYNVER_CURSOR_AGENT_ROOT to the cursor-agent folder.")}}return{executable:e,prefixArgs:[],shell:!1,detached:!0}}function Hw(){let e=process.env.KYNVER_CURSOR_AGENT_BIN?.trim()||process.env.CURSOR_AGENT_BIN?.trim();if(e)return e;if(process.platform==="win32"){let r=_i(process.env.KYNVER_CURSOR_AGENT_ROOT?.trim()||void 0);if(r)return r.nodeExe;let t=rr.join(process.env.LOCALAPPDATA||"","cursor-agent","agent.cmd");if(Bf(t))return t}return"agent"}function Fw(e,r){return We({...process.env,CI:"1",NO_COLOR:"1",...r.bundledVersionDir?{CURSOR_INVOKED_AS:rr.basename(e)||"agent.cmd"}:{}})}function Hf(e){e<=0||Atomics.wait(new Int32Array(new SharedArrayBuffer(4)),0,0,e)}function Nc(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)&&n>=0?Math.floor(n):r}function Kw(){let e=process.env.KYNVER_CURSOR_START_LOCK_DIR?.trim()||rr.join(Dw.homedir(),".kynver","locks");return Iw(e,{recursive:!0}),rr.join(e,"cursor-agent-start.lock")}function $w(){if(process.env.KYNVER_CURSOR_START_LOCK==="0")return()=>{};let e=Kw(),r=Nc("KYNVER_CURSOR_START_LOCK_TIMEOUT_MS",Uw),t=Nc("KYNVER_CURSOR_START_LOCK_STALE_MS",Ww),n=Date.now();for(;;)try{let o=Ic(e,"wx");return Oc(o),()=>{try{Lf(e)}catch{}}}catch(o){if(o.code!=="EEXIST")throw o;try{if(Date.now()-Nw(e).mtimeMs>t){Lf(e);continue}}catch{continue}if(Date.now()-n>r)throw new Error(`timed out waiting for Cursor agent start lock: ${e}`);Hf(250)}}var Ff={name:"cursor",defaultModel:Ac,preflightModel(e){return hi(e,Ac)},start(e){let r=hi(e.model,Ac);if(!r.ok)throw new Error(`cursor provider model preflight failed: ${r.note}`);let t=r.model,n=Ic(e.stdoutPath,"a"),o=Ic(e.stderrPath,"a"),s=["ignore",n,o],i=Hw(),a=Bw(i),l=$w(),c;try{c=Tw(a.executable,[...a.prefixArgs,"-p","--force","--trust","--workspace",e.worktreePath,"--output-format","stream-json","--stream-partial-output","--model",t,e.prompt],pe({cwd:e.worktreePath,detached:a.detached,shell:a.shell,stdio:s,env:Fw(i,a)})),Hf(Nc("KYNVER_CURSOR_START_LOCK_HOLD_MS",Mw))}finally{l(),Oc(n),Oc(o)}if(!c.pid)throw new Error(`failed to spawn Cursor agent worker (is \`${i}\` on PATH? run \`agent login\` or set CURSOR_API_KEY)`);return c.unref(),{pid:c.pid,model:t}}};var xi={claude:yf,codex:vc,cursor:Ff},Kf=null;function $f(e){if(Kf)return Kf;let r=e?.trim();if(r){let o=xi[r];if(!o)throw new Error(`unknown worker provider "${r}" \u2014 supported: ${Object.keys(xi).join(", ")}`);return o}let t=yo(R().workerProvider),n=xi[t];if(!n)throw new Error(`unknown worker provider "${t}" \u2014 supported: ${Object.keys(xi).join(", ")}`);return n}C();import{spawn as B_}from"node:child_process";import{existsSync as H_,openSync as F_,closeSync as Ig}from"node:fs";import K_ from"node:path";D();function Ei(e){return!!e.completionReportedAt?.trim()}function Tc(e,r,t){e.completionReportedAt=t.completionReportedAt,e.completionOutcome=t.completionOutcome,t.completionResponse!==void 0&&(e.completionResponse=t.completionResponse),K(r,e)}function jw(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function Dc(e){return!!(jw(e.completionBlocker)||e.completionOutcome==="rejected")}function dt(e){return Ei(e)&&!Dc(e)}D();z();N();import Po from"node:path";function Mc(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function So(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}var Vw=new Set(["review_scheduled","review_already_scheduled","skipped_terminal_task","closed","dispatched","dispatch_already_done"]);function jf(e){let r=Mc(e);if(!r)return{routeOutcome:null,taskAdvanced:!1,detail:null};let t=So(r.outcome),n=So(r.detail)??So(r.error),o=Mc(r.task),s=Mc(r.closedTask),i=o?So(o.status):null,a=s?So(s.status):null,l=t!==null&&Vw.has(t)||i==="awaiting_review"||i==="done"||a==="done";return{routeOutcome:t,taskAdvanced:l,detail:n}}function Vf(e){return e.taskAdvanced}D();Zn();var Gw="expert-lane-pr-review:",Yw="plan-review-task",Jw="scheduledjob:";function Gf(e){if(!e)return null;let r=e.trim().toLowerCase();return r.length?r:null}function Yf(e){let r=(e.executorRef??"").toLowerCase();if(r.startsWith(Gw)||r===Yw||r.startsWith("daemon-review:"))return!0;if(r.startsWith(Jw)&&e.parentTaskId){let n=Gf(e.personaSlug);if(n==="lorentz"||n==="dalton")return!0}let t=(e.title??"").toLowerCase();if(t.includes("expert pr review"))return!0;if(e.parentTaskId&&(t.startsWith("review:")||t.includes("review required")||t.includes("runtime review"))){let n=Gf(e.personaSlug);if(n==="lorentz"||n==="dalton")return!0}return!1}var Jf=/^(lane:)?(review|deep_review|planning|landing)(:|$)/i,qw=new Set(sc()),zw=/no commits between/i;function qf(e){return!!(e&&zw.test(e))}function ye(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function zf(e){return!e?.checked||e.headIsAncestorOfBase!==!1?null:ye(e.head)}function Uc(e){if(e==null)return null;let t=(typeof e=="string"?e:typeof e=="object"&&e!==null&&"summary"in e?String(e.summary??""):JSON.stringify(e)).match(/https?:\/\/[^\s)>"]+\/(?:pull|pulls|merge_requests|pull-requests)\/\d+/i);return t?ye(t[0]):null}function Xw(e,r,t){let n=r.trim();if(!n)return null;let o=t.git(e,["rev-list","--count",`${n}..HEAD`]);if(o.status!==0)return null;let s=Number.parseInt(o.stdout.trim(),10);return Number.isFinite(s)?s:null}function Qw(e,r){if(r.changedFiles.length>0)return!1;let t=ye(e.personaSlug)?.toLowerCase();if(t&&qw.has(t))return!0;let n=ye(e.routingRule)??"";return!!(n&&Jf.test(n))}function Zw(e,r){if(e.changedFiles.length>0)return!0;let t=ye(r?.baseRef);if(t&&r?.exec&&r.worktreePath){let n=Xw(r.worktreePath,t,r.exec);if(n===0)return!1;if(n!==null&&n>0)return!0}return!!(ye(e.headCommit)||zf(e.gitAncestry))}function Wc(e){if(!e.dispatched)return{required:!1,reason:"not_dispatched"};if(Yf({title:e.taskTitle??void 0,personaSlug:e.personaSlug,parentTaskId:e.parentTaskId,executorRef:e.executorRef}))return{required:!1,reason:"expert_review_task"};let r=ye(e.routingRule)??"";if(r&&Jf.test(r))return{required:!1,reason:"review_lane"};let t=e.worker??{personaSlug:e.personaSlug,routingRule:e.routingRule};if(Qw(t,e.snapshot))return{required:!1,reason:"review_artifact"};if(ye(e.patchPath)||ye(e.artifactBundlePath))return{required:!1,reason:"patch_or_bundle"};if(ye(e.repairTargetPrUrl))return{required:!1,reason:"repair_target_pr"};if(ye(e.prUrl)??ye(e.taskPrUrl)??ye(e.snapshot.prUrl))return{required:!1,reason:"already_has_pr"};let s=e.exec&&e.baseRef?{baseRef:e.baseRef,exec:e.exec,worktreePath:e.snapshot.worktreePath}:void 0;return Zw(e.snapshot,s)?{required:!0,snapshot:e.snapshot}:{required:!1,reason:"no_work_product"}}function Xf(e,r){return{changedFiles:e.changedFiles,branch:e.branch,worktreePath:e.worktreePath,gitAncestry:e.gitAncestry,finalResult:e.finalResult,headCommit:ye(r?.headCommit)??zf(e.gitAncestry),prUrl:ye(r?.prUrl)??null}}import{spawnSync as e_}from"node:child_process";function Zf(e){let r=e.trim();if(!r)return null;let t=r.match(/^git@github\.com:([^/]+\/[^/\s]+?)(?:\.git)?$/i);if(t)return Qf(t[1]);let n=r.match(/^ssh:\/\/git@github\.com\/([^/]+\/[^/\s]+?)(?:\.git)?$/i);if(n)return Qf(n[1]);try{let o=new URL(r.includes("://")?r:`https://${r}`);if(o.hostname.toLowerCase()!=="github.com")return null;let s=o.pathname.replace(/^\/+|\/+$/g,"").split("/");if(s.length<2)return null;let[i,a]=s;return!i||!a?null:`${i}/${a.replace(/\.git$/i,"")}`}catch{return null}}function Qf(e){let r=e.split("/").filter(Boolean);if(r.length<2)return null;let t=r[0],n=r[1].replace(/\.git$/i,"");return t&&n?`${t}/${n}`:null}Pe();function r_(e,r,t){try{let n=e_(e,t,{cwd:r,encoding:"utf8"});return{status:n.status,stdout:(n.stdout||"").trim(),stderr:(n.stderr||"").trim(),error:n.error?n.error.message:null}}catch(n){return{status:null,stdout:"",stderr:"",error:n.message}}}var Ai={git:(e,r)=>ne(e,r),gh:(e,r)=>r_("gh",e,r)};function t_(e){return e.split(`
|
|
27
|
+
`).map(r=>r.trim()).find(Boolean)??""}function eg(e,r){let t=r.git(e,["remote","get-url","origin"]);return t.status!==0?null:Zf(t.stdout)}function pt(e,r){let t=r.git(e,["rev-parse","HEAD"]);return t.status!==0?null:t.stdout.trim()||null}function Pi(e,r,t,n){let o=n.gh(e,["pr","list","--repo",r,"--head",t,"--state","open","--json","url","--limit","1"]);if(o.status!==0)return null;try{return JSON.parse(o.stdout)[0]?.url?.trim()||null}catch{return null}}function Co(e){let{worktreePath:r,branch:t,commitMessage:n,hasDirtyFiles:o,exec:s}=e;if(o){let l=s.git(r,["add","-A"]);if(l.status!==0)return{ok:!1,committed:!1,pushed:!1,detail:l.stderr||l.stdout||l.error||"git add failed"};let c=s.git(r,["commit","-m",n]);if(c.status!==0)return{ok:!1,committed:!1,pushed:!1,detail:c.stderr||c.stdout||c.error||"git commit failed"}}let i=s.git(r,["push","-u","origin",t]);if(i.status!==0)return{ok:!1,committed:o,pushed:!1,detail:i.stderr||i.stdout||i.error||"git push failed"};let a=pt(r,s)??void 0;return{ok:!0,committed:o,pushed:!0,headCommit:a}}function rg(e){let r=e.remoteBranch.trim();if(!r)return{ok:!1,detail:"missing remote branch"};let t=e.exec.git(e.worktreePath,["push","-u","origin",`HEAD:refs/heads/${r}`]);return t.status!==0&&!/already up to date/i.test(t.stderr||t.stdout)?{ok:!1,detail:t.stderr||t.stdout||t.error||"git push to PR branch failed"}:{ok:!0}}function tg(e){let r=Pi(e.worktreePath,e.repo,e.branch,e.exec);if(r)return{ok:!0,prUrl:r,created:!1};let t=e.exec.gh(e.worktreePath,["pr","create","--repo",e.repo,"--base",e.base,"--head",e.branch,"--title",e.title,"--body",e.body,"--draft"]);if(t.status!==0)return{ok:!1,detail:t.stderr||t.stdout||t.error||"gh pr create failed"};let n=n_(t.stdout)??Pi(e.worktreePath,e.repo,e.branch,e.exec);return n?{ok:!0,prUrl:n,created:!0}:{ok:!1,detail:"gh pr create succeeded but no PR URL was parsed"}}function n_(e){let t=t_(e).match(/https?:\/\/[^\s]+\/pull\/\d+/i);return t?t[0]:null}C();function ng(e){return`t-${v(e)}-a`}function og(e,r){let t=ng(r);if(e.headRefName.toLowerCase().includes(t))return!0;let n=r.trim();if(!n)return!1;let o=e.body??"",s=e.title??"";return o.includes(n)||o.includes(`\`${n}\``)||s.includes(n)}function wo(e){return e.trim().toLowerCase()}function sg(e,r){if(!e.length)return null;if(r){let t=wo(r),n=e.find(o=>wo(o.url)===t);if(n)return n}return[...e].sort((t,n)=>n.number-t.number)[0]??null}function ig(e,r){let t=wo(r);return e.filter(n=>wo(n.url)!==t).map(n=>n.url)}function ag(e){try{let r=JSON.parse(e);return Array.isArray(r)?r.map(t=>({url:t.url?.trim()??"",number:Number(t.number)||0,headRefName:t.headRefName?.trim()??"",createdAt:t.createdAt?.trim()??"",body:t.body,title:t.title})).filter(t=>t.url&&t.number>0&&t.headRefName):[]}catch{return[]}}function o_(e){let r=new Set,t=[];for(let n of e){let o=wo(n.url);r.has(o)||(r.add(o),t.push(n))}return t}function s_(e,r,t,n){let o=n.gh(e,["search","prs",t,"--repo",r,"--state","open","--json","url,number,headRefName,createdAt,body,title","--limit","20"]);return o.status!==0?[]:ag(o.stdout).filter(s=>og(s,t))}function i_(e,r,t,n){let o=n.gh(e,["pr","list","--repo",r,"--state","open","--json","url,number,headRefName,createdAt,body,title","--limit","100"]);if(o.status!==0)return[];let s=ng(t);return ag(o.stdout).filter(i=>i.headRefName.toLowerCase().includes(s)||og(i,t))}function Lc(e,r,t,n){let o=t.trim();if(!o)return[];let s=s_(e,r,o,n),i=i_(e,r,o,n);return o_([...s,...i])}function a_(e){let r=e.trim().match(/\/pull\/(\d+)(?:$|[?#])/i);if(!r)return null;let t=Number.parseInt(r[1],10);return Number.isFinite(t)?t:null}function Bc(e){let r=ig(e.rows,e.canonicalPrUrl),t=[],n=[];for(let o of r){let s=a_(o);if(!s){n.push({prUrl:o,detail:"could not parse PR number from URL"});continue}let i=`Superseded by ${e.canonicalPrUrl} (harness task retry dedupe).`,a=e.exec.gh(e.worktreePath,["pr","close",String(s),"--repo",e.repo,"--comment",i]);a.status===0?t.push(o):n.push({prUrl:o,detail:a.stderr||a.stdout||a.error||"gh pr close failed"})}return{closed:t,failed:n}}function lg(e,r,t,n){let o=t.trim();if(!o||!r.trim())return null;let s=n.gh(e,["api",`repos/${r}/commits/${o}/pulls`]);if(s.status!==0||!s.stdout)return null;try{let l=JSON.parse(s.stdout).filter(c=>c.merged_at&&c.html_url?.trim()).sort((c,u)=>(typeof c.number=="number"?c.number:Number.MAX_SAFE_INTEGER)-(typeof u.number=="number"?u.number:Number.MAX_SAFE_INTEGER))[0];return l?.html_url?.trim()?{prUrl:l.html_url.trim(),number:typeof l.number=="number"?l.number:null}:null}catch{return null}}function l_(e){return e.gh(process.cwd(),["--version"]).status===0}function c_(e,r){return`AgentOS harness: ${e} (${r})`}function u_(e,r,t){return["Automated PR-ready handoff from the Kynver harness runtime.","",e?`AgentOS task: \`${e}\``:"",`Harness worker: \`${r}\` \xB7 run \`${t}\``,"","Opened by orchestrator completion enforcement so production review receives a reviewable artifact."].filter(Boolean).join(`
|
|
28
|
+
`)}function Fc(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function d_(e){return Fc(e.prUrlHint)??Uc(e.status.finalResult)??Fc(e.worker.taskPrUrl)??null}function p_(e){let{snapshot:r,canonical:t,workerName:n,exec:o}=e,s=!1,i=!1,a=r.headCommit??pt(r.worktreePath,o)??void 0;if(r.changedFiles.length>0){let l=Co({worktreePath:r.worktreePath,branch:r.branch,commitMessage:`chore(harness): update PR handoff for ${n}`,hasDirtyFiles:!0,exec:o});if(!l.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${l.detail??"git commit/push failed"}`,nextAction:"Commit and push the dirty worker changes to the existing PR branch, then rerun `kynver worker complete`."};s=l.committed,i=l.pushed,a=l.headCommit??a}if(t.headRefName!==r.branch){let l=rg({worktreePath:r.worktreePath,remoteBranch:t.headRefName,exec:o});if(!l.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${l.detail??"git push to canonical PR branch failed"}`,nextAction:"Push worker commits to the canonical PR branch, then rerun `kynver worker complete`."};i=!0,a=pt(r.worktreePath,o)??a}return{ok:!0,prUrl:t.url,headCommit:a,committed:s,pushed:i}}function Hc(e){if(e.snapshot.changedFiles.length===0)return{ok:!0,prUrl:e.prUrl,headCommit:e.snapshot.headCommit??pt(e.snapshot.worktreePath,e.exec)??void 0};let r=Co({worktreePath:e.snapshot.worktreePath,branch:e.snapshot.branch,commitMessage:e.commitMessage,hasDirtyFiles:!0,exec:e.exec});return r.ok?{ok:!0,prUrl:e.prUrl,headCommit:r.headCommit??e.snapshot.headCommit??void 0,committed:r.committed,pushed:r.pushed}:{ok:!1,reason:`PR-ready handoff blocked: ${r.detail??"git commit/push failed"}`,nextAction:"Commit and push the dirty worker changes to the existing PR branch, then rerun `kynver worker complete`."}}function Oi(e,r=Ai){let t=d_(e),n=Xf(e.status,{prUrl:t,headCommit:null}),o=e.run.baseCommit?.trim()||e.run.base?.trim()||"origin/main";if(!Wc({dispatched:e.worker.dispatched,routingRule:e.worker.routingRule,personaSlug:e.worker.personaSlug,prUrl:t,taskTitle:e.worker.taskTitle,executorRef:e.worker.executorRef,parentTaskId:e.worker.parentTaskId,taskPrUrl:e.worker.taskPrUrl,repairTargetPrUrl:e.worker.repairTargetPrUrl,baseRef:o,exec:r,worker:e.worker,snapshot:n}).required)return t?Hc({snapshot:n,prUrl:t,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r}):{ok:!0};if(t)return Hc({snapshot:n,prUrl:t,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r});if(!l_(r)){let _=n.changedFiles.length;return{ok:!1,reason:`PR-ready handoff blocked: ${_?`${_} uncommitted change(s) with no PR URL`:"committed branch with no PR URL"}`,nextAction:"Install and authenticate GitHub CLI (`gh auth login`), then commit, push, and run `gh pr create` (or rerun `kynver worker complete` after the PR exists)."}}let i=eg(n.worktreePath,r);if(!i)return{ok:!1,reason:"PR-ready handoff blocked: could not resolve github.com origin for the worktree",nextAction:"Ensure `origin` points at GitHub, push the branch, open a PR, and rerun `kynver worker complete`."};let a=e.worker.repairTargetPrUrl?.trim();if(a){let _=!1,x=!1,E=n.headCommit??pt(n.worktreePath,r)??void 0;if(n.changedFiles.length>0){let A=Co({worktreePath:n.worktreePath,branch:n.branch,commitMessage:`fix(harness): repair target PR ${a}`,hasDirtyFiles:!0,exec:r});if(!A.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${A.detail??"git commit/push failed"}`,nextAction:"Commit and push to the target PR branch, then rerun `kynver worker complete`."};_=A.committed,x=A.pushed,E=A.headCommit??E}else{let A=r.git(n.worktreePath,["push","-u","origin",n.branch]);if(A.status!==0&&!/already up to date/i.test(A.stderr||A.stdout))return{ok:!1,reason:`PR-ready handoff blocked: ${A.stderr||A.stdout||"git push failed"}`,nextAction:"Push the target branch to origin, then rerun `kynver worker complete`."};x=A.status===0}return{ok:!0,prUrl:a,headCommit:E,committed:_,pushed:x}}let l=Fc(e.worker.taskId),c=[];if(l){c=Lc(n.worktreePath,i,l,r);let _=sg(c);if(_){let x=p_({snapshot:n,canonical:_,workerName:e.worker.name,exec:r});return x.ok&&x.prUrl&&Bc({worktreePath:n.worktreePath,repo:i,rows:c,canonicalPrUrl:x.prUrl,exec:r}),x}}let u=Pi(n.worktreePath,i,n.branch,r);if(u)return Hc({snapshot:n,prUrl:u,commitMessage:`chore(harness): update PR handoff for ${e.worker.name}`,exec:r});let d=n.changedFiles.length>0,f=!1,p=!1,m=n.headCommit??void 0,h=Co({worktreePath:n.worktreePath,branch:n.branch,commitMessage:`chore(harness): PR-ready handoff for ${e.worker.name}`,hasDirtyFiles:d,exec:r});if(d&&!h.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${h.detail??"git commit/push failed"}`,nextAction:"Commit and push the branch, run `gh pr create`, then rerun `kynver worker complete`."};if(d){if(f=h.committed,p=h.pushed,!h.ok)return{ok:!1,reason:`PR-ready handoff blocked: ${h.detail??"git push failed"}`,nextAction:"Fix git auth or merge conflicts, push the branch, run `gh pr create`, then rerun `kynver worker complete`."}}else{let _=r.git(n.worktreePath,["push","-u","origin",n.branch]);if(_.status!==0&&!/already up to date/i.test(_.stderr||_.stdout))return{ok:!1,reason:`PR-ready handoff blocked: ${_.stderr||_.stdout||_.error||"git push failed"}`,nextAction:"Push the branch to origin, run `gh pr create`, then rerun `kynver worker complete`."};p=_.status===0}m=h.headCommit??m??pt(n.worktreePath,r)??void 0;let k=m?lg(n.worktreePath,i,m,r):null;if(k)return{ok:!0,prUrl:k.prUrl,headCommit:m,committed:f,pushed:p,created:!1};let g=e.run.base?.trim()||"main",y=tg({worktreePath:n.worktreePath,repo:i,branch:n.branch,base:g.replace(/^origin\//,""),title:c_(e.worker.name,e.worker.runId),body:u_(e.worker.taskId,e.worker.name,e.worker.runId),exec:r});if(!y.ok||!y.prUrl){if(qf(y.detail))return{ok:!0,headCommit:m??void 0,committed:f,pushed:p};let _=n.changedFiles.length;return{ok:!1,reason:`PR-ready handoff blocked: ${_?`${_} uncommitted change(s) and no PR URL after handoff attempt`:"no PR URL after handoff attempt"}${y.detail?` (${y.detail})`:""}`,nextAction:"Run `gh pr create` on the worker branch (or fix `gh` auth), attach the PR URL to the task, then rerun `kynver worker complete`."}}if(l&&y.prUrl){let x=[...c.length>0?c:Lc(n.worktreePath,i,l,r),{url:y.prUrl,number:Number.parseInt(y.prUrl.match(/\/pull\/(\d+)/)?.[1]??"",10)||0,headRefName:n.branch,createdAt:""}];Bc({worktreePath:n.worktreePath,repo:i,rows:x,canonicalPrUrl:y.prUrl,exec:r})}return{ok:!0,prUrl:y.prUrl,headCommit:m??void 0,committed:f,pushed:p,created:y.created}}z();qt();function Ii(e){return e.filter(r=>{let t=r.trim(),n=t.startsWith("??")?t.slice(2).trim():t.length>3?t.slice(3).trim():t;return n!=="node_modules"&&!n.startsWith("node_modules/")})}function cg(e){let r=e.trim();return r.startsWith("??")?r.slice(2).trim():r.length>3&&/^[ MADRCU?!]{2} /.test(r.slice(0,3))?r.slice(3).trim():r}function ug(e){return Array.isArray(e)?e.map(r=>typeof r=="string"?r.trim():"").filter(Boolean):[]}function dg(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function mg(e){let r=dg(e);if(!r)return[];let t=dg(r.worktreeHandoff),n=ug(t?.disposableArtifactsRemoved);return n.length?n:ug(r.disposableArtifactsRemoved)}function pg(e){return e.replace(/\\/g,"/").replace(/^\.\//,"").replace(/\/+$/,"")}function fg(e,r){let t=Ii(e);if(t.length===0)return!0;if(r.length===0)return!1;let n=new Set(r.map(o=>pg(o)));return t.every(o=>{let s=pg(cg(o));return n.has(s)})}function Ni(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function gg(e){return Array.isArray(e)?e.map(r=>typeof r=="string"?r.trim():"").filter(Boolean):[]}function m_(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="boolean"?e:Array.isArray(e)?e.length>0:typeof e=="object"?Object.keys(e).length>0:!0}function f_(e){let r=gg(e.disposableArtifactsRemoved),t=mg(e.finalResult);return[...new Set([...r,...t])]}function hg(e){let r=gg(e.changedFiles),t=Ii(r),n=f_(e),o=t.length===0||fg(r,n);return Ni(e.prUrl)?o?{allowed:!0,state:"pr_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with a PR attached; commit or discard before completing`}:Ni(e.headCommit)?o?{allowed:!0,state:"commit_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) on top of a commit; commit or discard before completing`}:Ni(e.artifactBundlePath)||Ni(e.patchPath)?o?{allowed:!0,state:"commit_handoff",materialDirtyCount:0}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with a patch/bundle handoff; clean the tree before completing`}:o?{allowed:!0,state:"clean",materialDirtyCount:0}:m_(e.finalResult)?{allowed:!1,state:"dirty_worktree_no_pr",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with no commit or PR; commit, open a PR, discard, or remove one-off files via \`kynver worker discard-disposable\` before completing`}:{allowed:!1,state:"dirty_worktree",materialDirtyCount:t.length,detail:`Worktree has ${t.length} uncommitted change(s) with no final result`}}D();z();C();import g_ from"node:path";var h_=new Set(["awaiting_review","blocked","done","needs_input","waiting","scheduled","ready","cancelled","failed"]);function kg(e){return!!(typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim())}function k_(e){if(typeof e=="string"){let r=e.trim();return r.length?r:null}if(e&&typeof e=="object"&&!Array.isArray(e)){let r=e,t=r.summary??r.finalSummary??r.message;if(typeof t=="string"&&t.trim())return t.trim();try{return JSON.stringify(e)}catch{return null}}return null}function mt(e){let r=e.finalResult??null,t=typeof e.lastHeartbeatSummary=="string"?e.lastHeartbeatSummary:k_(r);return{finalResult:r??t??"completed",summary:t}}function Kc(e,r,t){if(kg(e)&&e.status==="done"&&e.completionSnapshot!=null)return;let n=new Date().toISOString(),o=mt(r),s=t?.source?.trim();e.completionReportedAt=n,e.completionSnapshot=o,e.status="done",s&&(e.completionAckSource=s),K(e.runId,e)}function y_(e){let r=new Map,n=e.response?.tick?.filteredItems;if(!Array.isArray(n))return r;for(let o of n){if(o.kind!=="task"||typeof o.id!="string")continue;let s=typeof o.taskStatus=="string"?o.taskStatus.trim():"";s&&r.set(o.id,s)}return r}function yg(e,r){let t=y_(r);if(t.size===0)return[];let n=L(e),o=[];for(let s of Object.keys(n.workers||{})){let i=w(g_.join(P(n.id),"workers",v(s),"worker.json"),void 0);if(!i?.taskId||kg(i))continue;let a=t.get(i.taskId);if(!a||a==="running"||!h_.has(a))continue;let l=M(i,{base:n.base,baseCommit:n.baseCommit});Kc(i,l,{source:`board-task-${a}`}),o.push({worker:s,taskId:i.taskId,taskStatus:a})}return o}C();C();import Ti from"node:path";var R_=/^[a-z0-9][a-z0-9._-]{0,127}$/i,b_=/^[a-z0-9][a-z0-9._-]{0,63}$/i,$c=new Set(["undefined","null"]),Rg="usage: kynver worker <action> --run RUN_ID --name WORKER_NAME";function _o(e){let r=e.trim();if(!R_.test(r))throw new Error(`invalid run id: ${e}`);return r}function bg(e){let r=e.trim();if(!b_.test(r))throw new Error(`invalid worker name: ${e}`);return r}function jc(e){return typeof e=="string"?e.trim():""}function Fe(e){let r=jc(e.run),t=jc(e.name);return(!r||$c.has(r))&&_r(`missing --run RUN_ID (${Rg})`),(!t||$c.has(t))&&_r(`missing --name WORKER_NAME (${Rg})`),{runId:_o(r),workerName:bg(t)}}function Di(e){let r=jc(e.run);return(!r||$c.has(r))&&_r("missing --run RUN_ID (usage: kynver run status --run RUN_ID)"),_o(r)}function Vc(e){let r=Ti.resolve(e);if(r.includes(".."))throw new Error("repo path must not contain .. segments");return r}function v_(e,r){return r.map(t=>{let n=Ti.resolve(e,t),o=Ti.relative(e,n);if(o.startsWith("..")||Ti.isAbsolute(o))throw new Error(`owned path escapes repo: ${t}`);return n})}function S_(e){return!Number.isFinite(e)||e<=0||e>500?40:Math.floor(e)}async function vg(e,r,t){let n=await fetch(e,{method:"POST",headers:He(r),body:JSON.stringify(t)}),o=null;try{o=await n.json()}catch{o=null}return{ok:n.ok,status:n.status,parsed:o}}function C_(e){if(e&&typeof e=="object"){let r=e.error;if(typeof r=="string"&&r.trim())return r.trim()}}function Sg(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function xo(e){if(typeof e!="string")return null;let r=e.trim();return r.length?r:null}function w_(e){return e.completionBlocker?`blocked:${e.completionBlocker}`:e.completionOutcome?e.completionOutcome:e.completionReportedAt?"completion_acknowledged":e.finished?"worker_finished":"in_progress"}function __(e){return e.completionBlocker?"Resolve completion blocker, then rerun `kynver worker complete`.":e.completionOutcome==="review_scheduled"||e.completionOutcome==="review_already_scheduled"?"Await review lane and landing decision in Command Center.":e.completionOutcome==="needs_attention"?"Inspect blocker/attention reason in Command Center and dispatch a repair task.":e.finished&&!e.completionReportedAt?"Post completion acknowledgement to AgentOS (`kynver worker complete`).":null}function wg(e){let r=e?.trim();return r?/completion acknowledged but board not advanced/i.test(r)&&/task already terminal/i.test(r):!1}function x_(e){return e.prUrl?"pr_handoff":e.headCommit?"commit_handoff":e.changedFiles.length>0?"dirty_worktree":"none"}function Eo(e,r){(e.completionBlocker??void 0)!==(r??void 0)&&(r?e.completionBlocker=r:delete e.completionBlocker,K(e.runId,e))}function E_(e){e.completionBlocker&&(delete e.completionBlocker,K(e.runId,e))}function Mi(e){return e?{base:e.base,baseCommit:e.baseCommit}:{}}function P_(e,r){return{...e,...r.prUrl?{prUrl:r.prUrl}:{},...r.headCommit?{headCommit:r.headCommit}:{}}}async function Ao(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=M(n,Mi(o)),i=(e.agentOsId?String(e.agentOsId):n.agentOsId)||"",a=(e.taskId?String(e.taskId):n.taskId)||null;if(!oe(s))return{ok:!0,skipped:!0,reason:"worker-not-finished"};if(n.localOnly)return{ok:!0,skipped:!0,reason:"local-only-worker"};if(!i)return{ok:!1,reason:"missing agentOsId"};let l=e.force===!0||e.force==="true";if(!l&&dt(n))return{ok:!0,skipped:!0,reason:"completion-already-acknowledged",httpStatus:200};if(!l&&Dc(n)&&E_(n),!(e.skipPrHandoff===!0||e.skipPrHandoff==="true")&&n.dispatched&&a){let E=Oi({worker:n,run:o,status:s});if(!E.ok)return Eo(n,E.reason),{ok:!1,reason:E.reason,nextAction:E.nextAction,completionBlocked:!0};(E.prUrl||E.headCommit)&&(s=M(n,Mi(o)),s=P_(s,E))}let u=s.gitAncestry.headIsAncestorOfBase===!1&&s.gitAncestry.head?s.gitAncestry.head:s.headCommit;if(n.dispatched){let E=hg({changedFiles:s.changedFiles,finalResult:s.finalResult,prUrl:s.prUrl,headCommit:u,disposableArtifactsRemoved:n.disposableArtifactsRemoved});if(!E.allowed){let A=E.detail??`worktree completion blocked (${E.state})`;return Eo(n,A),{ok:!1,reason:A,nextAction:"Clean the worktree (commit, open a PR, or `kynver worker discard-disposable --path <file>`), then rerun `kynver worker complete`.",completionBlocked:!0}}}let d=V(e.baseUrl?String(e.baseUrl):void 0),f=e.secret?String(e.secret):void 0,p=await J(f,i,{baseUrl:d});a&&(await vi({worker:n,agentOsId:i,baseUrl:d,secret:p}),n=he(r,t));let m=`${d}/api/agent-os/by-id/${encodeURIComponent(i)}/harness/completion`,h={...s};n.disposableArtifactsRemoved?.length&&(h.disposableArtifactsRemoved=n.disposableArtifactsRemoved);let k={source:"kynver-harness",agentOsId:i,runId:n.runId,workerName:n.name,taskId:a,leaseToken:n.leaseToken??null,startedAt:n.startedAt,finishedAt:s.lastActivityAt||new Date().toISOString(),status:n.leaseToken?{...h,leaseToken:n.leaseToken}:h,workerInjection:{instructionPolicyFingerprint:n.instructionPolicyFingerprint??null,instructionPolicyEvidence:n.instructionPolicyEvidence??null,memoryQualityCapture:n.memoryQualityCapture??null,policyAt:n.instructionPolicyEvidence&&typeof n.instructionPolicyEvidence=="object"&&"policyAt"in n.instructionPolicyEvidence&&typeof n.instructionPolicyEvidence.policyAt=="string"?n.instructionPolicyEvidence.policyAt:null,personaSlug:n.personaSlug??null,personaEvidence:n.personaEvidence??null,contextEnvelopeEvidence:n.contextEnvelopeEvidence??null}},g=await vg(m,p,k);if((g.status===401||g.status===403)&&!f){let E=await $m(i,{baseUrl:d});E&&E!==p&&(p=E,g=await vg(m,p,k))}if(g.ok){let E=jf(g.parsed);if(!Vf(E)){let O=`completion acknowledged but board not advanced: ${E.detail??(E.routeOutcome?`harness completion returned ${E.routeOutcome}`:"harness completion did not advance the linked task")}`;Eo(n,O);let B={completionReportedAt:new Date().toISOString(),completionOutcome:"rejected",completionResponse:g.parsed};return Tc(n,n.runId,B),{ok:!1,httpStatus:g.status,response:g.parsed,reason:O,completionBlocked:!0}}Eo(n,void 0);let A=E.routeOutcome??"acknowledged",Y={completionReportedAt:new Date().toISOString(),completionOutcome:"acknowledged",completionResponse:g.parsed};Tc(n,n.runId,Y),Kc(n,s,{source:"harness-completion"});let $=s.prUrl;return{ok:!0,httpStatus:g.status,response:g.parsed,reason:A,...$?{prHandoff:{prUrl:$}}:{}}}let y=g.status===401||g.status===403,_=C_(g.parsed)??(y?"runner token unauthorized":"non-2xx response"),x=y?`completion replay rejected (${g.status}): ${_}`:`completion replay failed (${g.status}): ${_}`;return Eo(n,x),{ok:!1,httpStatus:g.status,response:g.parsed,completionBlocked:!0}}async function Ui(e){try{let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=M(n,Mi(o)),i=(e.agentOsId?String(e.agentOsId):n.agentOsId)||"",a=(e.taskId?String(e.taskId):n.taskId)||null;if(!oe(s)){console.log(JSON.stringify({worker:n.name,runId:n.runId,status:"skipped",reason:"worker-not-finished",workerStatus:s.status,alive:s.alive},null,2));return}if(n.localOnly){console.log(JSON.stringify({worker:n.name,runId:n.runId,status:"skipped",reason:"local-only-worker"},null,2));return}i||(console.error("worker complete requires --agent-os-id (or an agentOsId persisted at worker start)"),process.exit(1));let l=await Ao(e);console.log(JSON.stringify({worker:n.name,runId:n.runId,...l.skipped?{status:"skipped"}:{},...l.reason?{reason:l.reason}:{},...l.nextAction?{nextAction:l.nextAction}:{},...l.completionBlocked?{completionBlocked:l.completionBlocked}:{},agentOsId:i,taskId:a,httpStatus:l.httpStatus,response:l.response},null,2)),l.ok||process.exit(1)}catch(r){console.error(`worker complete failed: ${r.message}`),process.exit(1)}}function Yc(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=L(n.runId),s=M(n,Mi(o));ae(Po.join(n.workerDir,"last-status.json"),s),console.log(JSON.stringify(s,null,2))}function A_(e){return{full:`kynver worker list --run ${e} --full`,blocked:`kynver worker list --run ${e} --blocked`,running:`kynver worker list --run ${e} --running`,task:`kynver worker list --run ${e} --task <task-id>`,worker:`kynver worker list --run ${e} --worker <worker>`,runFull:`kynver run status --run ${e} --full`,workerFull:`kynver worker status --run ${e} --name <worker>`,workerTail:`kynver worker tail --run ${e} --name <worker> --lines 80`}}function Gc(e){if(typeof e!="string")return;let r=e.trim();return r.length?r:void 0}function O_(e){let r={};(e.blocked===!0||e.blocked==="true")&&(r.blocked=!0),(e.running===!0||e.running==="true")&&(r.running=!0);let t=Gc(e.task??e.taskId);t&&(r.task=t);let n=Gc(e.worker??e.name);n&&(r.worker=n);let o=Gc(e.status);return o&&(r.status=o),r}function I_(e,r){if(r.blocked){let t=typeof e.attention=="string"?e.attention:"",n=typeof e.status=="string"?e.status:"";if(!(t==="blocked"||t==="needs_attention"||t==="stale"||n==="blocked"))return!1}return!(r.running&&!(e.status==="running"&&e.attention!=="blocked"&&e.attention!=="needs_attention")||typeof r.task=="string"&&e.taskId!==r.task||typeof r.worker=="string"&&e.worker!==r.worker||typeof r.status=="string"&&e.status!==r.status)}function _g(e,r){let t=O_(r);if(Object.keys(t).length===0)return e;let n=e.workers.filter(s=>I_(s,t)),o={...e,workerCount:n.length,needsAttention:n.filter(s=>s.attention&&s.attention!=="ok"&&s.attention!=="done").map(s=>s.worker),workers:n,activeFilters:t};return e.summary&&(o.summary={statusCounts:Ur(n,"status"),attentionCounts:Ur(n,"attention"),lifecycleCounts:Ur(n,"lifecycleStage")}),e.controller&&(o.controller=Pg(n)),o}function xg(e){let r=Di(e),t=e.full===!0||e.full==="true",n=_g(t?Oo(r):Io(r),e),o=n.workers;console.log(JSON.stringify({runId:n.runId,status:n.status,projection:t?"full":"compact",workerCount:n.workerCount,...n.activeFilters?{activeFilters:n.activeFilters}:{},...t?{}:{resultContract:{projection:"compact",rawWorkerPayloadsOmitted:!0,deepDetailAvailableVia:["--full","worker status","worker tail","run status --full"]},drilldownCommands:A_(r)},needsAttention:n.needsAttention,..."summary"in n?{summary:n.summary}:{},..."controller"in n?{controller:n.controller}:{},workers:o},null,2))}function Eg(e){let{run:r,workerName:t,worker:n}=e,o=M(n,{base:r.base,baseCommit:r.baseCommit}),s=o.gitAncestry.headIsAncestorOfBase===!1&&o.gitAncestry.head?o.gitAncestry.head:void 0,i=Xr({alive:o.alive,finalResult:o.finalResult,changedFiles:o.changedFiles,gitAncestry:o.gitAncestry,headCommit:s}),a=n.completionBlocker,l=typeof a=="string"&&a?a:void 0,c=wg(l)?void 0:l,u=c?"blocked":o.status,d=c?"blocked":o.attention.state,f=Sg(n.completionResponse),p=Sg(f?.task),m=xo(f?.outcome),h=xo(f?.status),k=Array.isArray(f?.warnings)?f.warnings.filter(A=>typeof A=="string"&&A.trim().length>0):[],g=xo(p?.prUrl)??xo(f?.prUrl),y=xo(n.completionReportedAt),_=w_({finished:oe(o),completionBlocker:c,completionOutcome:m,completionReportedAt:y}),x=__({completionBlocker:c,completionOutcome:m,completionReportedAt:y,finished:oe(o)}),E=x_({changedFiles:o.changedFiles,headCommit:s,prUrl:g??void 0});return{worker:o.worker,status:u,attention:d,attentionReason:c??o.attention.reason,landingBlocked:o.finalResult?d==="needs_attention"||d==="blocked":!1,exitedWithoutFinalResult:!o.finalResult&&!o.alive,salvageState:i?.salvageable?"review_needed":"none",salvageReason:i?.salvageable?i.attentionReason:void 0,pid:o.pid,alive:o.alive,currentTool:o.currentTool,lastActivityAt:o.lastActivityAt,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary,heartbeatBlocker:o.heartbeatBlocker,changedFileCount:o.changedFiles.length,changedFiles:o.changedFiles,branch:o.branch,taskId:n.taskId??null,planId:n.planId??null,instructionPolicyFingerprint:typeof n.instructionPolicyFingerprint=="string"?n.instructionPolicyFingerprint:null,instructionPolicyRuleCount:(()=>{let A=n.instructionPolicyEvidence;if(!A||typeof A!="object")return null;let Y=A.ruleSlugs;return Array.isArray(Y)?Y.length:null})(),leaseOwner:n.leaseOwner??null,model:typeof n.model=="string"?n.model:void 0,routingRule:typeof n.routingRule=="string"?n.routingRule:void 0,requestedModel:typeof n.requestedModel=="string"?n.requestedModel:void 0,headCommit:s,prUrl:g,handoffState:E,gitAncestry:o.gitAncestry,finalResult:o.finalResult,lifecycleStage:_,completionReportedAt:y,completionOutcome:n.completionOutcome??null,completionRouteStatus:h,completionRouteOutcome:m,completionWarnings:k,completionBlocker:c??null,checkpoint:{phase:o.lastHeartbeatPhase,summary:o.lastHeartbeatSummary,blocker:o.heartbeatBlocker},lastCommandHint:o.currentTool??o.lastHeartbeatSummary,failureReason:c??o.error??null,nextAction:x,ancestry:o.gitAncestry.relation,ancestryChecked:o.gitAncestry.checked}}function N_(e){let r=typeof e.status=="string"?e.status:"",t=typeof e.completionBlocker=="string"&&e.completionBlocker.trim().length>0?e.completionBlocker:void 0;return t&&!wg(t)?!1:typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim()||e.completionOutcome==="acknowledged"?!0:r==="done"}function T_(e,r){return{worker:e,status:"done",attention:"done",attentionReason:"metadata terminal worker; full status skipped in compact snapshot",alive:!1,pid:typeof r.pid=="number"?r.pid:void 0,branch:typeof r.branch=="string"?r.branch:void 0,taskId:r.taskId??null,planId:r.planId??null,model:typeof r.model=="string"?r.model:void 0,routingRule:typeof r.routingRule=="string"?r.routingRule:void 0,requestedModel:typeof r.requestedModel=="string"?r.requestedModel:void 0,lifecycleStage:r.completionReportedAt?"completion_acknowledged":"worker_finished",completionReportedAt:typeof r.completionReportedAt=="string"?r.completionReportedAt:null,completionOutcome:r.completionOutcome??null,localOnly:r.localOnly===!0,compactStatus:!0}}function Ur(e,r){let t={};for(let n of e){let o=n[r],s=typeof o=="string"&&o.trim()?o:"unknown";t[s]=(t[s]??0)+1}return t}function Cg(e){if(e.attention!=="blocked")return!1;let r=typeof e.attentionReason=="string"?e.attentionReason:"";return r.includes("cli-config.json.tmp")||r.includes("Invalid authentication credentials")||r.includes("provider CLI is missing or not on PATH")||r.includes("unknown command:")}function Pg(e){let r=e.filter(Cg),t=e.filter(n=>{if(Cg(n))return!1;let o=n.attention;return o==="needs_attention"||o==="blocked"||o==="stale"||n.status==="running"});return{actionableCount:t.length,runningCount:e.filter(n=>n.status==="running").length,blockedCount:e.filter(n=>n.attention==="blocked").length,staleCount:e.filter(n=>n.attention==="stale").length,needsAttentionCount:e.filter(n=>n.attention==="needs_attention").length,doneCount:e.filter(n=>n.status==="done").length,systemHealthBlockerCount:r.length,systemHealthBlockers:r.slice(0,10).map(n=>({worker:n.worker,status:n.status,attention:n.attention,attentionReason:n.attentionReason,model:n.model,routingRule:n.routingRule,lastActivityAt:n.lastActivityAt})),actionableWorkers:t.slice(0,25).map(n=>({worker:n.worker,status:n.status,attention:n.attention,attentionReason:n.attentionReason,taskId:n.taskId,planId:n.planId,model:n.model,routingRule:n.routingRule,lastActivityAt:n.lastActivityAt,nextAction:n.nextAction}))}}function Ag(e,r,t){let n={runId:e.id,name:e.name,status:Zt(e.status,r),repo:e.repo,workerCount:r.length,needsAttention:r.filter(o=>o.attention&&o.attention!=="ok"&&o.attention!=="done").map(o=>o.worker),workers:r};return t&&(n.summary={statusCounts:Ur(r,"status"),attentionCounts:Ur(r,"attention"),lifecycleCounts:Ur(r,"lifecycleStage")},n.controller=Pg(r)),n}function D_(e){return e.status==="done"&&e.attention==="done"}function Oo(e){let r=L(e),n=Object.keys(r.workers||{}).map(s=>{let i=w(Po.join(P(r.id),"workers",v(s),"worker.json"),void 0);return i?Eg({run:r,workerName:s,worker:i}):{worker:s,status:"missing",attention:"needs_attention",attentionReason:"worker.json not found"}}),o=Ag(r,n,!1);return ae(Po.join(P(r.id),"last-board.json"),o),o}function Io(e){let r=L(e),n=Object.keys(r.workers||{}).map(i=>{let a=w(Po.join(P(r.id),"workers",v(i),"worker.json"),void 0);return a?N_(a)?T_(i,a):Eg({run:r,workerName:i,worker:a}):{worker:i,status:"missing",attention:"needs_attention",attentionReason:"worker.json not found"}}),o=n.filter(i=>!D_(i)),s=Ag(r,o,!0);return s.status=Zt(r.status,n),s.summary={...s.summary??{},totalWorkerCount:n.length,shownWorkerCount:o.length,omittedTerminalDoneWorkerCount:n.length-o.length,allStatusCounts:Ur(n,"status"),allAttentionCounts:Ur(n,"attention")},ae(Po.join(P(r.id),"last-board-compact.json"),s),s}async function Og(e,r){let t=String(e.run||""),n=String(e.agentOsId||"");if(!t||!n)return null;let o=Oo(t),s=V(e.baseUrl?String(e.baseUrl):void 0),i=await J(e.secret?String(e.secret):void 0,n,{baseUrl:s}),a=`${s}/api/agent-os/by-id/${encodeURIComponent(n)}/harness/snapshot`,l=await re(a,i,{agentOsId:n,runId:t,source:r,snapshot:o},{agentOsId:n,baseUrl:s});return{ok:l.ok,httpStatus:l.status,response:l.response,authRefreshed:l.refreshedAuth,authRefreshFailure:l.authRefreshFailure}}function M_(e){return{full:`kynver run status --run ${e} --full`,blocked:`kynver status --run ${e} --blocked`,running:`kynver status --run ${e} --running`,task:`kynver status --run ${e} --task <task-id>`,worker:`kynver status --run ${e} --worker <worker>`,workersFull:`kynver worker list --run ${e} --full`,workerFull:`kynver worker status --run ${e} --name <worker>`,workerTail:`kynver worker tail --run ${e} --name <worker> --lines 80`,monitorTick:`kynver monitor status --run ${e} --tick`}}function Jc(e){let r=Di(e),t=e.full===!0||e.full==="true",n=_g(t?Oo(r):Io(r),e);n.projection=t?"full":"compact",t||(n.resultContract={projection:"compact",rawWorkerPayloadsOmitted:!0,omittedWorkerFields:["finalResult","changedFiles","gitAncestry","completionResponse","stdout/stderr tails"],deepDetailAvailableVia:["--full","worker status","worker tail","monitor status --tick"]},n.drilldownCommands=M_(r)),console.log(JSON.stringify(n,null,2))}function qc(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=Ss(n.stdoutPath,Number(e.lines||40));if(e.raw===!0||e.raw==="true"){process.stdout.write(o);return}for(let s of o.split(`
|
|
29
|
+
`).filter(Boolean)){let i=Bt(s),a=i?Ll(i):s;a&&console.log(a)}}function zc(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t);if(!H(n.pid)){console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"not_running"},null,2));return}if(Er(n.pid,"SIGTERM"),$r(1500),H(n.pid)){Er(n.pid,"SIGKILL"),console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"sigkill_sent"},null,2));return}console.log(JSON.stringify({worker:n.name,pid:n.pid,status:"stopped"},null,2))}C();import{existsSync as Wi}from"node:fs";import ft from"node:path";import{fileURLToPath as U_}from"node:url";function W_(e,r){let t=ft.resolve(e);for(;;){let n=ft.join(t,r);if(Wi(n))return n;let o=ft.dirname(t);if(o===t)return null;t=o}}function L_(e){return W_(e,ft.join("node_modules",".bin","tsx"))??"npx"}function Xc(e,r){if(e.endsWith(".ts")){let t=L_(ft.dirname(e));return{command:t,argsPrefix:t==="npx"?["tsx",e]:[e],cliPath:e}}return{command:r,argsPrefix:[e],cliPath:e}}function Li(e){if(e.explicitCliPath)return Wi(e.explicitCliPath)?Xc(e.explicitCliPath,e.nodeExecutable):null;let r=U_(new URL(".",e.importMetaUrl)),t=ft.join(r,"cli.js");if(Wi(t))return Xc(t,e.nodeExecutable);let n=ft.join(r,"cli.ts");return Wi(n)?Xc(n,e.nodeExecutable):null}var $_=5e3,j_=360*60*1e3,V_=3,G_=5e3;function Y_(e){let{runId:r,workerName:t}=Fe(e);return{run:r,name:t,agentOsId:e.agentOsId?String(e.agentOsId):void 0,pollMs:Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):void 0,maxTotalMs:Number(e.maxTotalMs)>0?Math.floor(Number(e.maxTotalMs)):void 0,completeAttempts:Number(e.completeAttempts)>0?Math.floor(Number(e.completeAttempts)):void 0,completeBackoffMs:Number(e.completeBackoffMs)>0?Math.floor(Number(e.completeBackoffMs)):void 0,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0}}async function gt(e){let r=Y_(e),t=r.pollMs??$_,n=r.maxTotalMs??j_,o=r.completeAttempts??V_,s=r.completeBackoffMs??G_,i=he(r.run,r.name);if(!i.agentOsId||!i.taskId)return{worker:i.name,runId:i.runId,outcome:"missing_link",attempts:0,reason:"worker has no agentOsId/taskId \u2014 nothing to attribute completion to"};if(dt(i))return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:200,attempts:0,reason:"completion-already-acknowledged"};let a=Date.now();for(;;){if(i=he(r.run,r.name),dt(i))return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:200,attempts:0,reason:"completion-already-acknowledged"};let u=M(i);if(oe(u)||!H(i.pid))break;if(Date.now()-a>n)return{worker:i.name,runId:i.runId,outcome:"timed_out",attempts:0,reason:`worker did not finish within ${n}ms`};$r(t)}let l,c;for(let u=1;u<=o;u++){let d=await Ao({run:r.run,name:r.name,...r.agentOsId?{agentOsId:r.agentOsId}:{},...r.baseUrl?{baseUrl:r.baseUrl}:{},...r.secret?{secret:r.secret}:{}});if(l=d.httpStatus,d.ok)return{worker:i.name,runId:i.runId,outcome:"completed",httpStatus:d.httpStatus,attempts:u};if(d.httpStatus===401||d.httpStatus===403)return c=typeof d.reason=="string"?d.reason:"completion replay refused",{worker:i.name,runId:i.runId,outcome:"blocked",httpStatus:d.httpStatus,attempts:u,reason:c};c=typeof d.reason=="string"?d.reason:"transient failure",u<o&&$r(s)}return{worker:i.name,runId:i.runId,outcome:"blocked",httpStatus:l,attempts:o,reason:c??"completion failed after retries"}}async function Qc(e){try{let r=await gt(e);console.log(JSON.stringify(r,null,2)),(r.outcome==="missing_link"||r.outcome==="timed_out")&&process.exit(1),process.exit(0)}catch(r){console.error(`worker auto-complete failed: ${r.message}`),process.exit(1)}}function Zc(e){let r=e.nodeExecutable??process.execPath,t=Li({importMetaUrl:import.meta.url,explicitCliPath:e.cliPath,nodeExecutable:r});if(!t)return;let n=t.cliPath;if(!H_(n))return;let o=K_.join(e.workerDir,"auto-complete.log"),s;try{s=F_(o,"a")}catch{s=void 0}let i=["ignore",s??"ignore",s??"ignore"],a=[...t.argsPrefix,"worker","auto-complete","--run",e.runId,"--name",e.workerName];e.agentOsId&&a.push("--agent-os-id",e.agentOsId),e.baseUrl&&a.push("--base-url",e.baseUrl),e.secret&&a.push("--secret",e.secret);try{let l=B_(t.command,a,pe({detached:!0,stdio:i,env:process.env}));return s!==void 0&&Ig(s),l.unref(),{pid:l.pid,logPath:o,cliPath:n}}catch{if(s!==void 0)try{Ig(s)}catch{}return}}function Ng(e){let r=e.branch?.trim()||"unknown branch",t=e.pid!=null?`pid ${e.pid}`:"pid pending";return`Harness worker started: ${e.worker} (${t}, ${r})`}function eu(e){return JSON.stringify(e,null,2)}Pe();function Tg(e,r,t){me(e,["fetch","origin",t,"--prune"],{allowFailure:!0});let n=`origin/${t}`,o=ne(e,["worktree","add","-B",t,r,n]);if(o.status===0)return;let s=ne(e,["worktree","add","-b",t,r,"HEAD"]);if(s.status!==0){let i=o.stderr||o.stdout||s.stderr||s.stdout||"git worktree add failed for repair target branch";throw new Error(i)}}Ie();N();function Bi(e,r){let t=typeof r.name=="string"?r.name.trim():"";if(!t||t==="undefined"||t==="null")throw new Error(`worker name is required and must be a real identifier (got: ${JSON.stringify(r.name)})`);let n=v(t);if(e.workers?.[n])throw new Error(`worker already exists in run ${e.id}: ${n}`);if(!r.task)throw new Error(`missing task text for worker ${n}`);let o=r.routingRule||r.requestedModel?{provider:r.provider||Oe,model:r.model,rule:r.routingRule||"explicit:spawn",requestedModel:r.requestedModel??r.model}:Ri({explicitModel:r.model,explicitProvider:r.provider,explicitProviderIsOperatorOverride:!!r.provider?.trim()}),s=$f(o.provider),i=o.model;if(s.preflightModel){let F=s.preflightModel(r.model);if(!F.ok)throw new Error(`model preflight failed for provider "${s.name}": ${F.note??"invalid model/provider combination"}`);F.normalized&&console.error(`[supervisor] ${n}: ${F.note}`),i=F.model}let{worktreesDir:a}=Z(),l=fn.join(P(e.id),"workers",n);q_(l,{recursive:!0});let c=fn.join(a,e.id,n),u=r.repairTargetBranch?.trim()||void 0,d=u||r.branch||`agent/${e.id}/${n}`;if(J_(c))throw new Error(`worktree path already exists: ${c}`);me(e.repo,["fetch","origin","--prune"],{allowFailure:!0}),u?Tg(e.repo,c,u):me(e.repo,["worktree","add","-b",d,c,e.baseCommit],{throwError:!0});let f=fn.join(l,"stdout.jsonl"),p=fn.join(l,"stderr.log"),m=fn.join(l,"heartbeat.jsonl"),h=Pc({task:r.task,ownedPaths:r.ownedPaths||[],worktreePath:c,heartbeatPath:m,planId:r.planId,taskId:r.taskId,instructionPolicyMarkdown:r.instructionPolicyMarkdown,memoryQualityMarkdown:r.memoryQualityPromptMarkdown??r.memoryQualityCapture?.promptMarkdown??null,personaMarkdown:r.personaMarkdown,contextEnvelopeMarkdown:r.contextEnvelopeMarkdown,model:i,repairTargetPrUrl:r.repairTargetPrUrl,repairTargetBranch:r.repairTargetBranch??(u||void 0)}),k=process.env.KYNVER_HARNESS_TASK_ID,g=process.env.KYNVER_HARNESS_AGENT_OS_ID;r.taskId&&(process.env.KYNVER_HARNESS_TASK_ID=String(r.taskId)),r.agentOsId&&(process.env.KYNVER_HARNESS_AGENT_OS_ID=String(r.agentOsId));let y;try{y=s.start({name:n,task:r.task,ownedPaths:r.ownedPaths,model:i,branch:d,worktreePath:c,workerDir:l,stdoutPath:f,stderrPath:p,heartbeatPath:m,prompt:h})}catch(F){throw me(e.repo,["worktree","remove","--force",c],{allowFailure:!0}),me(e.repo,["branch","-D",d],{allowFailure:!0}),F}finally{k===void 0?delete process.env.KYNVER_HARNESS_TASK_ID:process.env.KYNVER_HARNESS_TASK_ID=k,g===void 0?delete process.env.KYNVER_HARNESS_AGENT_OS_ID:process.env.KYNVER_HARNESS_AGENT_OS_ID=g}let _=Pf(y.model,i,s.defaultModel),x=R(),E=Ae(process.env,x),A=er().runnerId,Y=bo(E.boxKind),$={name:n,runId:e.id,status:"running",pid:y.pid,model:_,branch:d,worktreePath:c,workerDir:l,stdoutPath:f,stderrPath:p,heartbeatPath:m,ownedPaths:r.ownedPaths,...r.agentOsId?{agentOsId:String(r.agentOsId)}:{},...r.taskId?{taskId:String(r.taskId)}:{},...r.planId?{planId:String(r.planId)}:{},...r.instructionPolicyFingerprint?{instructionPolicyFingerprint:String(r.instructionPolicyFingerprint)}:{},...r.instructionPolicyEvidence?{instructionPolicyEvidence:r.instructionPolicyEvidence}:{},...r.memoryQualityCapture?{memoryQualityCapture:r.memoryQualityCapture}:{},...r.personaSlug?{personaSlug:String(r.personaSlug)}:{},...r.personaEvidence?{personaEvidence:r.personaEvidence}:{},...r.contextEnvelopeEvidence?{contextEnvelopeEvidence:r.contextEnvelopeEvidence}:{},...r.leaseOwner?{leaseOwner:String(r.leaseOwner)}:{},...r.leaseToken?{leaseToken:String(r.leaseToken)}:{},...r.dispatched?{dispatched:!0}:{},...!r.agentOsId||!r.taskId?{localOnly:!0}:{},routingRule:o.rule,...o.requestedModel?{requestedModel:o.requestedModel}:{},...o.orchestrationAudit?{orchestrationAudit:o.orchestrationAudit}:{},...r.executorRef?{executorRef:String(r.executorRef)}:{},...r.parentTaskId?{parentTaskId:String(r.parentTaskId)}:{},...r.taskTitle?{taskTitle:String(r.taskTitle)}:{},...r.taskPrUrl?{taskPrUrl:String(r.taskPrUrl)}:{},...r.repairTargetPrUrl?{repairTargetPrUrl:String(r.repairTargetPrUrl)}:{},...r.repairTargetBranch?{repairTargetBranch:String(r.repairTargetBranch)}:{},boxKind:E.boxKind,boxId:Y,runtimeId:A,startedAt:new Date().toISOString()};if(K(e.id,$),e.workers={...e.workers||{},[n]:{workerDir:l,statusPath:fn.join(l,"worker.json")}},e.status="running",Be(e),$.agentOsId&&$.taskId){let F;try{F=Zc({runId:e.id,workerName:n,workerDir:l,agentOsId:$.agentOsId})}catch(O){let B=`completion sidecar failed to spawn: ${O.message}`;$.completionBlocker=B,K(e.id,$)}if(F)F.pid&&($.completionSidecarPid=F.pid,K(e.id,$));else{let O="completion sidecar failed to spawn (CLI not found or spawn error)";$.completionBlocker=O,$.completionSidecarSpawnFailedAt=new Date().toISOString(),K(e.id,$)}}return $}async function ru(e){let r=L(String(e.run)),t=typeof e.name=="string"?e.name.trim():"";t||(console.error("worker start failed: --name is required"),process.exit(1));let n=e.task?String(e.task):yp(e.taskFile?String(e.taskFile):void 0);n||(console.error("missing --task or --task-file"),process.exit(1));let o=!!(e.agentOsId&&e.taskId),s=e.localOnly===!0||e.localOnly==="true";!o&&!s&&(e.agentOsId||e.taskId)&&(console.error("worker start: board-linked workers require both --agent-os-id and --task-id (or pass --local-only for direct runs)"),process.exit(1));let i=e.wait===!0||e.wait==="true",a=e.emitJson===!0||e.emitJson==="true",l;try{l=Bi(r,{name:t,task:n,ownedPaths:e.owned?String(e.owned).split(",").map(d=>d.trim()).filter(Boolean):[],model:e.model?String(e.model):void 0,branch:e.branch?String(e.branch):void 0,agentOsId:e.agentOsId?String(e.agentOsId):void 0,taskId:e.taskId?String(e.taskId):void 0,provider:e.provider?String(e.provider):void 0});let u={runId:r.id,worker:l.name,pid:l.pid,branch:l.branch,worktreePath:l.worktreePath,workerDir:l.workerDir};a?console.log(eu(u)):(console.log(Ng(u)),console.error(eu(u)))}catch(u){console.error(`worker start failed: ${u.message}`),process.exit(1)}if(!i||!l)return;let c=await gt({run:String(e.run),name:l.name,...l.agentOsId?{agentOsId:l.agentOsId}:{},...e.baseUrl?{baseUrl:String(e.baseUrl)}:{},...e.secret?{secret:String(e.secret)}:{}});console.error(JSON.stringify({event:"start_wait_outcome",...c})),c.outcome==="timed_out"&&(process.exitCode=1)}D();en();C();import z_ from"node:path";function X_(e){let r=Array.isArray(e.ownedPaths)?e.ownedPaths.filter(n=>typeof n=="string"):[],t=Array.isArray(e.writeSetPrefixes)?(e.writeSetPrefixes??[]).filter(n=>typeof n=="string"):[];return{...r.length?{ownedPaths:r}:{},...t.length?{writeSetPrefixes:t}:{},...e.allowConcurrentHotspot?{allowConcurrentHotspot:!0}:{}}}function Hi(e){let r=L(e),t=[];for(let n of Object.keys(r.workers||{})){let o=w(z_.join(P(r.id),"workers",v(n),"worker.json"),void 0);!o?.taskId||!rt(o)||t.push({runId:r.id,workerName:n,taskId:o.taskId,pid:o.pid,...X_(o)})}return t}C();import{createHash as Dg}from"node:crypto";function gr(e){let r=e.replace(/\r\n/g,`
|
|
30
|
+
`).trimEnd();return Dg("sha256").update(r,"utf8").digest("hex")}function gn(e){if(e==null)return null;let r=e.trim();return r?Dg("sha256").update(r,"utf8").digest("hex"):null}N();var ee=class extends Error{kind;httpStatus;constructor(r,t,n){super(t),this.name="PlanPersistError",this.kind=r,this.httpStatus=n}};function No(e,r){return e===401||e===403?new ee("auth",r,e):e>=500?new ee("server",r,e):new ee("permanent",r,e)}function tu(e){let r=e instanceof Error?e.message:String(e);return/ECONNREFUSED|ENOTFOUND|ETIMEDOUT|fetch failed|network/i.test(r)?new ee("network",r):new ee("tool_interruption",r)}function Mg(e){return e!=="permanent"}function Ki(e){let r={"Content-Type":"application/json"};return e&&(r.Authorization=`Bearer ${e}`),r}async function $i(e){let r=await e.text();try{return JSON.parse(r)}catch{return r}}async function Ug(e,r,t={}){let n=V(t.baseUrl),o=t.apiKey??se(),s=t.fetchFn??fetch,i=`${n}/api/agent-os/${encodeURIComponent(e)}/plans/${encodeURIComponent(r)}`;try{let a=await s(i,{method:"GET",headers:Ki(o)}),l=await $i(a);if(!a.ok){let c=typeof l=="object"&&l&&"error"in l?String(l.error):`GET plan failed (${a.status})`;throw No(a.status,c)}return l}catch(a){throw a instanceof ee?a:tu(a)}}async function Wg(e,r={}){let t=V(r.baseUrl),n=r.apiKey??se(),o=r.fetchFn??fetch,s=e.agentOsSlug;try{if(e.operation==="create"){let f=`${t}/api/agent-os/${encodeURIComponent(s)}/plans`,p={title:e.title,summary:e.summary??null,slug:e.planSlug??null,sourceRefs:Fi(e),initialVersion:{title:e.title,body:e.body,summary:e.summary??null,changeSummary:e.changeSummary??null,author:e.author??null,sourceRefs:Fi(e)}},m=await o(f,{method:"POST",headers:Ki(n),body:JSON.stringify(p)}),h=await $i(m);if(!m.ok){let g=typeof h=="object"&&h&&"error"in h?String(h.error):`create plan failed (${m.status})`;throw No(m.status,g)}let k=h;return{planId:k.plan.id,versionId:k.version.id,versionNumber:k.version.versionNumber}}let i=e.planId;if(!i)throw new ee("permanent","planId is required for this operation");if(e.operation==="update_metadata"){let f=`${t}/api/agent-os/${encodeURIComponent(s)}/plans/${encodeURIComponent(i)}`,p={title:e.title,summary:e.summary??null,sourceRefs:Fi(e)},m=await o(f,{method:"PATCH",headers:Ki(n),body:JSON.stringify(p)}),h=await $i(m);if(!m.ok){let g=typeof h=="object"&&h&&"error"in h?String(h.error):`update plan failed (${m.status})`;throw No(m.status,g)}let k=h;return{planId:k.id,versionId:k.currentVersionId,versionNumber:null}}let a=`${t}/api/agent-os/${encodeURIComponent(s)}/plans/${encodeURIComponent(i)}/versions`,l={title:e.title,body:e.body,summary:e.summary??null,changeSummary:e.changeSummary??null,author:e.author??null,sourceRefs:Fi(e),markCurrent:e.markCurrent!==!1},c=await o(a,{method:"POST",headers:Ki(n),body:JSON.stringify(l)}),u=await $i(c);if(!c.ok){let f=typeof u=="object"&&u&&"error"in u?String(u.error):`add version failed (${c.status})`;throw No(c.status,f)}let d=u;return{planId:d.version.planId,versionId:d.version.id,versionNumber:d.version.versionNumber}}catch(i){throw i instanceof ee?i:tu(i)}}function Fi(e){let r={...e.sourceRefs??{}};return e.model&&(r.model=e.model),Object.keys(r).length?r:e.sourceRefs??null}import{createHash as Q_}from"node:crypto";function ji(e){let r={operation:e.operation,agentOsSlug:e.agentOsSlug,planId:e.planId??null,planSlug:e.planSlug??null,title:e.title.trim(),summaryHash:gn(e.summary),bodyHash:gr(e.body),changeSummary:e.changeSummary?.trim()??null,markCurrent:e.markCurrent??!0};return Q_("sha256").update(JSON.stringify(r),"utf8").digest("hex")}import{mkdirSync as Lg}from"node:fs";import{homedir as Z_}from"node:os";import hn from"node:path";function Vi(){let e=process.env.KYNVER_STATE_ROOT;return e?hn.resolve(e):hn.join(Z_(),".kynver","state")}function Gi(){return hn.join(Vi(),"plan-outbox")}function ex(){return hn.join(Vi(),"plan-outbox-archive")}function ht(){let e=Gi(),r=ex();return Lg(e,{recursive:!0}),Lg(r,{recursive:!0}),{outboxDir:e,archiveDir:r}}function To(e){if(e.startsWith("/tmp/")||e.startsWith("/var/folders/"))return!0;let r=hn.resolve(e);return r.startsWith("/tmp/")||r.startsWith(hn.join("/var","folders"))}import{existsSync as nu,readFileSync as Hg,renameSync as Bg,readdirSync as rx,writeFileSync as ou,unlinkSync as EF}from"node:fs";import Ke from"node:path";import{randomUUID as tx}from"node:crypto";var nx=12;function kt(){let{outboxDir:e}=ht(),r=rx(e).filter(n=>n.endsWith(".json")),t=[];for(let n of r){let o=iu(Ke.join(e,n));o&&o.queueStatus==="queued"&&t.push(o)}return t.sort((n,o)=>n.createdAt.localeCompare(o.createdAt))}function su(e){for(let r of kt())if(r.idempotencyKey===e)return r;return null}function iu(e){if(!nu(e))return null;try{return JSON.parse(Hg(e,"utf8"))}catch{return null}}function Fg(e){let{outboxDir:r}=ht(),t=Ke.join(r,e.bodyPath);return Hg(t,"utf8")}function au(e,r){let{outboxDir:t}=ht(),n=new Date().toISOString(),o=r.existing?.id??tx(),s=r.existing?.bodyPath??`${o}.body.md`,i=Ke.join(t,`${o}.json`),a=Ke.join(t,s);r.existing||ou(a,e.body,"utf8");let l={id:o,idempotencyKey:ji(e),operation:e.operation,agentOsSlug:e.agentOsSlug,planId:e.planId??r.existing?.planId??null,planSlug:e.planSlug??r.existing?.planSlug??null,title:e.title,summary:e.summary??null,bodyPath:s,bodyHash:gr(e.body),author:e.author??null,model:e.model??null,sourceRefs:e.sourceRefs??null,changeSummary:e.changeSummary??null,markCurrent:e.markCurrent??!0,createdAt:r.existing?.createdAt??n,updatedAt:n,retryCount:(r.existing?.retryCount??0)+(r.existing?1:0),maxRetries:e.maxRetries??r.existing?.maxRetries??nx,lastError:r.lastError,lastFailureKind:r.lastFailureKind,queueStatus:"queued",userStatus:"queued for retry",readbackEvidence:null};return ou(i,`${JSON.stringify(l,null,2)}
|
|
31
|
+
`,{mode:384}),l}function Kg(e){let{outboxDir:r}=ht(),t=Ke.join(r,`${e.id}.json`);ou(t,`${JSON.stringify(e,null,2)}
|
|
32
|
+
`,{mode:384})}function $g(e){let{outboxDir:r,archiveDir:t}=ht(),n=Ke.join(r,`${e.id}.json`),o=Ke.join(r,e.bodyPath),s=Ke.join(t,`${e.id}.json`),i=Ke.join(t,e.bodyPath);nu(n)&&Bg(n,s),nu(o)&&Bg(o,i)}function Do(e){let{outboxDir:r}=ht();return{jsonPath:Ke.join(r,`${e.id}.json`),bodyPath:Ke.join(r,e.bodyPath)}}function jg(e,r){return{operation:e.operation,agentOsSlug:e.agentOsSlug,planId:e.planId,planSlug:e.planSlug,title:e.title,summary:e.summary,body:r,changeSummary:e.changeSummary??void 0,author:e.author??void 0,model:e.model??void 0,sourceRefs:e.sourceRefs,markCurrent:e.markCurrent??!0,maxRetries:e.maxRetries}}async function Vg(e,r,t={}){let n=await Ug(e,r.planId,t),o=n.plan,s=n.currentVersion;if(o.title.trim()!==r.title.trim())throw new ee("verification_failed",`title mismatch: expected "${r.title}", got "${o.title}"`);let i=gn(r.summary),a=gn(o.summary);if(i!==a)throw new ee("verification_failed","summary mismatch on readback");if(r.versionId&&o.currentVersionId!==r.versionId)throw new ee("verification_failed",`currentVersionId mismatch: expected ${r.versionId}, got ${o.currentVersionId}`);if(r.versionNumber!=null&&(!s||s.versionNumber!==r.versionNumber))throw new ee("verification_failed",`versionNumber mismatch: expected ${r.versionNumber}, got ${s?.versionNumber??"none"}`);let l=s?.body??"",c=gr(l);if(r.bodyHash&&c!==r.bodyHash)throw new ee("verification_failed","body hash mismatch on readback");return{planId:o.id,currentVersionId:o.currentVersionId,versionNumber:s?.versionNumber??null,title:o.title,summary:o.summary,bodyHash:r.bodyHash||c,readAt:new Date().toISOString()}}function Gg(e,r){return{planId:r.planId,title:e.title,summary:e.summary??null,body:e.body,bodyHash:gr(e.body),versionId:r.versionId,versionNumber:r.versionNumber}}var Yg="persisted and read back",ox="queued for retry",lu="failed and needs action";async function kn(e,r={}){e.bodyPathHint&&To(e.bodyPathHint);let t=ji(e),n=su(t);if(n?.readbackEvidence)return{userStatus:Yg,outboxId:n.id,planId:n.readbackEvidence.planId,readbackEvidence:n.readbackEvidence,idempotencyKey:t};if(e.immediateFailure)return Jg(e,e.immediateFailure.message,e.immediateFailure.kind,n);let o=r.writePlan??Wg,s=r.verifyReadback??Vg;try{let i=await o(e,r),a={...e,planId:i.planId},l=Gg(a,i),c=await s(e.agentOsSlug,sx(e,l),r);return n&&$g(n),{userStatus:Yg,planId:i.planId,versionId:i.versionId??void 0,readbackEvidence:c,idempotencyKey:t}}catch(i){let a=i instanceof ee?i:new ee("tool_interruption",i instanceof Error?i.message:String(i));if(!Mg(a.kind)){let l=au(e,{lastError:a.message,lastFailureKind:a.kind,existing:n??void 0}),c=Do(l),u=qg(l,a.message);return{userStatus:lu,outboxId:u.id,outboxPath:c.jsonPath,bodyPath:c.bodyPath,lastError:a.message,idempotencyKey:t}}return Jg(e,a.message,a.kind,n)}}function sx(e,r){return e.operation==="update_metadata"?{...r,body:"",bodyHash:""}:r}function Jg(e,r,t,n){let o=au(e,{lastError:r,lastFailureKind:t,existing:n??void 0}),s=Do(o);if(o.retryCount>=o.maxRetries){let i=qg(o,r);return{userStatus:lu,outboxId:i.id,outboxPath:s.jsonPath,bodyPath:s.bodyPath,lastError:r,idempotencyKey:o.idempotencyKey}}return{userStatus:ox,outboxId:o.id,outboxPath:s.jsonPath,bodyPath:s.bodyPath,lastError:r,idempotencyKey:o.idempotencyKey}}function qg(e,r){let t={...e,queueStatus:"failed",userStatus:lu,lastError:r,updatedAt:new Date().toISOString()};return Kg(t),t}import ix from"node:path";async function Yi(e={},r={}){let t=kt().filter(s=>e.outboxId?s.id===e.outboxId:!0),n=e.max&&e.max>0?t.slice(0,e.max):t,o={processed:0,succeeded:0,stillQueued:0,failed:0,results:[]};for(let s of n){o.processed+=1;let i=Fg(s),a=jg(s,i),l=await kn(a,r);l.userStatus==="persisted and read back"?o.succeeded+=1:l.userStatus==="failed and needs action"?o.failed+=1:o.stillQueued+=1,o.results.push({outboxId:s.id,userStatus:l.userStatus,lastError:l.lastError})}return o}function cu(e){let r=ix.join(Gi(),`${e}.json`);return iu(r)}function Ji(e){let r=Do(e);return["## Plan persistence risk","",`AgentOS plan write is **not** confirmed (${e.userStatus}).`,`- outboxId: \`${e.id}\``,e.planId?`- planId: \`${e.planId}\``:"- planId: (pending \u2014 create not yet applied)",`- outbox: \`${r.jsonPath}\``,`- body: \`${r.bodyPath}\``,"","Drain when approval/connectivity returns: `kynver plan outbox drain`"].join(`
|
|
33
|
+
`)}function qi(e){let r=e.metadata&&typeof e.metadata=="object"?e.metadata:null,t=typeof e.planPersistenceOutboxId=="string"&&e.planPersistenceOutboxId||(r&&typeof r.planPersistenceOutboxId=="string"?r.planPersistenceOutboxId:void 0);return t?{outboxId:t,jsonPath:typeof e.planPersistenceOutboxPath=="string"?e.planPersistenceOutboxPath:r&&typeof r.planPersistenceOutboxPath=="string"?r.planPersistenceOutboxPath:void 0,bodyPath:typeof e.planPersistenceBodyPath=="string"?e.planPersistenceBodyPath:r&&typeof r.planPersistenceBodyPath=="string"?r.planPersistenceBodyPath:void 0}:null}async function uu(e){let r=`${e.baseUrl}/api/agent-os/by-id/${encodeURIComponent(e.agentOsId)}/tasks/${encodeURIComponent(e.taskId)}/release`,t;try{t=await re(r,e.secret,{agentOsId:e.agentOsId,leaseOwner:e.leaseOwner,...e.failureDetail?{failureDetail:e.failureDetail}:{}},{agentOsId:e.agentOsId,baseUrl:e.baseUrl})}catch(s){return{released:!1,httpOk:!1,releaseResponse:{ok:!1,error:s.message}}}let n=t.response;return{released:t.ok===!0||n?.ok===!0,httpOk:t.ok===!0,releaseResponse:t.response??t}}import{spawnSync as Xg}from"node:child_process";import{spawnSync as ax}from"node:child_process";function zg(){if(process.env.GITHUB_TOKEN?.trim()||process.env.GH_TOKEN?.trim())return{source:"env",configured:!0,reason:"GitHub token already configured in environment"};let e=ax("gh",["auth","token"],{encoding:"utf8",stdio:["ignore","pipe","pipe"]});if(e.status!==0)return{source:"missing",configured:!1,reason:typeof e.stderr=="string"&&e.stderr.trim()?e.stderr.trim():"gh auth token failed; run `gh auth login` on this machine"};let r=typeof e.stdout=="string"?e.stdout.trim():"";return r?(process.env.GH_TOKEN=r,{source:"gh-cli",configured:!0,reason:"Using local GitHub CLI auth for daemon land_pr merge"}):{source:"missing",configured:!1,reason:"gh auth token returned an empty token; run `gh auth login` on this machine"}}var Qg=new Set(["SUCCESS","SKIPPED","NEUTRAL"]),lx=new Set(["CLEAN","HAS_HOOKS"]);function pu(e){return e?.trim()?["--repo",e.trim()]:[]}function Zg(e){let r=/github\.com\/([^/]+)\/([^/]+)\/pull\/\d+/i.exec(e.trim());return r?`${r[1]}/${r[2]}`:null}function eh(e,r,t){let n=e.gh(r,t);if(n.status!==0)throw new Error(n.stderr||n.stdout||`gh ${t.join(" ")} failed`);return JSON.parse(n.stdout||"{}")}function Mo(e){return typeof e.name=="string"&&e.name||typeof e.context=="string"&&e.context||typeof e.workflowName=="string"&&e.workflowName||"unknown check"}function cx(e){let r=Array.isArray(e)?e:[],t=[],n=[];for(let o of r){let s=o&&typeof o=="object"?o:{},i=typeof s.conclusion=="string"?s.conclusion.toUpperCase():"",a=typeof s.status=="string"?s.status.toUpperCase():"",l=typeof s.state=="string"?s.state.toUpperCase():"";if(!(i&&Qg.has(i))){if(i){n.push(`${Mo(s)}=${i}`);continue}if(!(l&&Qg.has(l))){if(l&&l!=="PENDING"&&l!=="EXPECTED"){n.push(`${Mo(s)}=${l}`);continue}if(l==="PENDING"||l==="EXPECTED"){t.push(`${Mo(s)}=${l}`);continue}if(a&&a!=="COMPLETED"){t.push(`${Mo(s)}=${a}`);continue}t.push(`${Mo(s)}=PENDING`)}}}return{pending:t,failed:n}}function ux(e){return(Array.isArray(e)?e:[]).some(t=>{let n=t&&typeof t=="object"?t:{},o=typeof n.name=="string"&&n.name||typeof n.context=="string"&&n.context||"",s=typeof n.conclusion=="string"?n.conclusion.toUpperCase():"",i=typeof n.state=="string"?n.state.toUpperCase():"";return/^vercel/i.test(o)&&(s==="SUCCESS"||i==="SUCCESS")})}var dx=/^##\s*(test\s*plan|verification|test\s*evidence|verify)\b/im,px=/typecheck|npm run (test|build|typecheck)|vitest|tsc\b|verify-pr-local|local verify|local-verify|tests? (pass|green)|build green|node --test/i,mx=/^docs[(:]/i,fx=/docs[- ]only|documentation only|no[- ]code change|no code changes|low[- ]risk|plan tracker only|markdown only/i;function gx(e){let r=typeof e.title=="string"?e.title.trim():"",t=typeof e.body=="string"?e.body.trim():"",n=mx.test(r)||fx.test(t),o=dx.test(t),s=px.test(t);return n||o||s||e.vercelCheckSuccess===!0}function hx(e){if(!gx({title:e.title,body:e.body,vercelCheckSuccess:ux(e.statusCheckRollup)}))throw new Error(`PR #${e.number} lacks landing verification evidence \u2014 add ## Test plan / ## Verification with local commands, Vercel preview, or docs/no-code rationale`)}function kx(e){if(e.state!=="OPEN")throw new Error(`PR #${e.number} is ${e.state}, not OPEN`);if(e.isDraft)throw new Error(`PR #${e.number} is still a draft`);if(!lx.has(e.mergeStateStatus))throw new Error(`PR #${e.number} mergeStateStatus is ${e.mergeStateStatus}`);let r=cx(e.statusCheckRollup);if(r.failed.length>0)throw new Error(`PR #${e.number} has failing checks: ${r.failed.join(", ")}`);if(r.pending.length>0)throw new Error(`PR #${e.number} has pending checks: ${r.pending.join(", ")}`);hx(e)}function yx(e){try{return kx(e),null}catch(r){return r instanceof Error?r.message:String(r)}}function Rx(e,r,t,n){if(!n?.trim())return;let o=encodeURI(`heads/${n}`);e.gh(r,["api","-X","DELETE",`repos/${t}/git/refs/${o}`])}function bx(e,r,t){if(t?.trim())return t.trim();let n=e.gh(r,["repo","view","--json","nameWithOwner"]);if(n.status!==0)throw new Error(n.stderr||"Could not resolve GitHub repo");let o=JSON.parse(n.stdout||"{}");if(!o.nameWithOwner)throw new Error("Could not resolve GitHub repo");return o.nameWithOwner}function vx(e,r){if(!r?.trim())return;let t=Xg("git",["worktree","list","--porcelain"],{cwd:e,encoding:"utf8"});if(t.status!==0)return;let n=String(t.stdout||"").split(/\r?\n/),o=null,s=null;for(let i of n){if(i.startsWith("worktree ")){o=i.slice(9).trim(),s=null;continue}i.startsWith("branch ")&&o&&(s=i.slice(7).trim(),s.endsWith(`/${r}`)&&Xg("git",["worktree","remove","--force",o],{cwd:e,encoding:"utf8"}))}}async function rh(e){let r=e.cwd??process.cwd(),t=e.exec??Ai,n=e.prUrl.trim();if(!n)throw new Error("prUrl is required");let o=zg();if(!o.configured)return{prUrl:n,outcome:"blocked",reason:o.reason};let s=eh(t,r,["pr","view",n,...pu(e.repo),"--json",["number","url","title","body","state","isDraft","mergeStateStatus","statusCheckRollup","headRefName","mergedAt","mergeCommit"].join(",")]);if(s.state==="MERGED"||s.mergedAt)return{prUrl:s.url||n,outcome:"skipped",mergeCommit:s.mergeCommit?.oid??null,reason:`PR #${s.number} is already merged \u2014 land_pr no-op (redelivery)`};let i=yx(s);if(i)return e.skipNotReady?{prUrl:s.url||n,outcome:"skipped",reason:i}:{prUrl:s.url||n,outcome:"blocked",reason:i};if(e.dryRun)return{prUrl:s.url||n,outcome:"skipped",reason:"dry-run: PR is ready to merge"};let a=String(s.number),l=t.gh(r,["pr","merge",a,...pu(e.repo),"--squash"]);if(l.status!==0){let u=du(t,r,a,e.repo);return u?{prUrl:u.url||s.url||n,outcome:"skipped",mergeCommit:u.mergeCommit?.oid??null,reason:`PR #${s.number} is already merged \u2014 merged by another lane during land_pr (race)`}:{prUrl:s.url||n,outcome:"blocked",reason:l.stderr||l.stdout||"gh pr merge failed"}}let c=du(t,r,a,e.repo);c||(c=du(t,r,a,e.repo));try{let u=bx(t,r,e.repo);Rx(t,r,u,s.headRefName),vx(r,s.headRefName)}catch{}return{prUrl:c?.url||s.url||n,outcome:"merged",mergeCommit:c?.mergeCommit?.oid??null,reason:`Daemon land_pr merged PR #${s.number}${c?"":" (post-merge view unavailable \u2014 merge verified by gh exit 0)"}`}}function du(e,r,t,n){try{let o=eh(e,r,["pr","view",t,...pu(n),"--json","number,url,mergedAt,mergeCommit,state"]);return o.state==="MERGED"||o.mergedAt?o:null}catch{return null}}N();async function th(e){let r=await J(e.secret,e.agentOsId,{baseUrl:e.baseUrl}),t=String(e.task.id),n=`${e.baseUrl}/api/agent-os/by-id/${encodeURIComponent(e.agentOsId)}/harness/completion`,o=new Date().toISOString(),s={source:"kynver-harness",agentOsId:e.agentOsId,runId:e.runId,workerName:`land-pr-${t}`,taskId:t,leaseToken:e.task.leaseToken??null,startedAt:o,finishedAt:o,status:{finalResult:e.report,prUrl:e.report.prUrl,summary:e.report.reason,leaseToken:e.task.leaseToken??null},workerInjection:null},i=await re(n,r,s,{agentOsId:e.agentOsId,baseUrl:e.baseUrl});return{ok:i.ok,status:i.status}}function nh(){return["## verify_live completion contract","Finish with a JSON finalResult object:","{",' "prUrl": "<landed pr>",',' "outcome": "passed" | "failed" | "skipped" | "no_mcp_surface",',' "reason": "<human summary>",',' "mergeCommit": "<sha optional>",',' "liveReadback": "<prod readback string from acceptance.liveReadbackQuery>",',' "mcpCalls": [{ "tool": "<name>", "ok": true, "summary": "..." }]',"}","","Drive the feature MCP tools against live production. Do not mark passed without exercising the MCP surface.","When the subject carries an acceptance snapshot, include liveReadback \u2014 the server oracle rejects passed if the original symptom still appears."].join(`
|
|
34
|
+
`)}var Sx="dispatch_start_readback_failed:";function yt(e){return`${Sx} ${e.trim()}`}function Cx(e){return e.branch?.trim()?e.worktreePath?.trim()?e.heartbeatPath?.trim()?e.startedAt?.trim()?null:"missing local worker startedAt":"missing local worker heartbeatPath":"missing local worker worktreePath":"missing local worker branch"}function wx(e){let{snapshot:r,leaseOwner:t,expectedLeaseToken:n,worker:o}=e;if(!r)return{ok:!1,error:yt("task lease snapshot missing after spawn"),detail:{taskId:o.taskId,leaseOwner:t,expectedLeaseToken:n}};if(r.status!=="running")return{ok:!1,error:yt(`AgentOS task status=${r.status} (expected running)`),detail:{taskId:r.taskId,status:r.status,leaseOwner:r.leaseOwner,blocker:r.blocker},snapshot:r};let s=r.leaseOwner?.trim()??"";if(!s||s!==t.trim())return{ok:!1,error:yt(`leaseOwner mismatch (board=${s||"null"}, expected=${t})`),detail:{taskId:r.taskId,boardLeaseOwner:s||null,expectedLeaseOwner:t},snapshot:r};let i=r.leaseToken?.trim()??"";if(!i||i!==n.trim())return{ok:!1,error:yt(`leaseToken mismatch (board=${i||"null"}, expected=${n})`),detail:{taskId:r.taskId,boardLeaseToken:i||null,expectedLeaseToken:n},snapshot:r};let a=Cx(o);return a?{ok:!1,error:yt(a),detail:{taskId:o.taskId,worker:o.name},snapshot:r}:r.heartbeatAt?.trim()?o.executorRef?.trim()&&r.executorRef?.trim()&&o.executorRef.trim()!==r.executorRef.trim()?{ok:!1,error:yt(`executorRef mismatch (board=${r.executorRef}, worker=${o.executorRef})`),detail:{taskId:r.taskId,boardExecutorRef:r.executorRef,workerExecutorRef:o.executorRef},snapshot:r}:{ok:!0,snapshot:r}:{ok:!1,error:yt("AgentOS heartbeatAt missing after claim"),detail:{taskId:r.taskId},snapshot:r}}async function oh(e){let r=await mn({agentOsId:e.agentOsId,taskIds:[e.taskId],baseUrl:e.baseUrl,secret:e.secret});return wx({snapshot:r.get(e.taskId)??null,leaseOwner:e.leaseOwner,expectedLeaseToken:e.expectedLeaseToken,worker:e.worker})}C();D();function sh(e,r,t){r.pid&&H(r.pid)&&(Er(r.pid,"SIGTERM"),H(r.pid)&&Er(r.pid,"SIGKILL"));let n={...r,status:"failed",pid:void 0,completionBlocker:t,dispatchStartReadbackFailed:!0};return K(e,n),n}D();var Ci=3600*1e3;function ih(e){let r=e.admissionExhaustion;return!r||typeof r!="object"?null:r}function ah(e){let r=e.dispatchSkipDrain;return!r||typeof r!="object"?null:r}function _x(e){let r=e.harnessWorkerContext;if(!r||typeof r!="object")return null;let t=r,n=typeof t.instructionPolicyMarkdown=="string"?t.instructionPolicyMarkdown:null,o=typeof t.instructionPolicyFingerprint=="string"?t.instructionPolicyFingerprint:null,s=t.instructionPolicyEvidence&&typeof t.instructionPolicyEvidence=="object"?t.instructionPolicyEvidence:null,i=typeof t.personaMarkdown=="string"?t.personaMarkdown:null,a=typeof t.personaEvidence=="object"&&t.personaEvidence&&typeof t.personaEvidence.injectedPersonaSlug=="string"?t.personaEvidence.injectedPersonaSlug:null,l=t.personaEvidence&&typeof t.personaEvidence=="object"?t.personaEvidence:null,c=t.personaInjectionReady===!0,u=typeof t.contextEnvelopeMarkdown=="string"?t.contextEnvelopeMarkdown:null,d=t.contextEnvelopeEvidence&&typeof t.contextEnvelopeEvidence=="object"?t.contextEnvelopeEvidence:null,f=t.contextEnvelopeReady===!0,p=t.memoryQualityCapture&&typeof t.memoryQualityCapture=="object"?t.memoryQualityCapture:null,m=typeof t.memoryQualityPromptMarkdown=="string"?t.memoryQualityPromptMarkdown:typeof p?.promptMarkdown=="string"?p.promptMarkdown:null;return{instructionPolicyMarkdown:n,instructionPolicyFingerprint:o,instructionPolicyEvidence:s,memoryQualityCapture:p,memoryQualityPromptMarkdown:m,personaMarkdown:i,personaSlug:a,personaEvidence:l,personaInjectionReady:c,contextEnvelopeMarkdown:u,contextEnvelopeEvidence:d,contextEnvelopeReady:f}}function xx(e){if(typeof e!="string")return null;let r=e.trim().toLowerCase();return r.length?r:null}function lh(e,r){let t=[`[AgentOS task ${e.id}] ${e.title}`,"",e.description?String(e.description):"(no description on the board task)","",`Board linkage: agentOsId=${r}, taskId=${e.id}, attempt=${e.attempt}, executor=${e.executor}${e.executorRef?`, executorRef=${e.executorRef}`:""}.`,"This worker was dispatched from the AgentOS board. The harness reports your completion back to the board when you finish."];e.executor==="verify_live"&&t.push("",nh());let n=qi(e);if(n?.outboxId){let o=cu(n.outboxId);o?t.push("",Ji(o)):t.push("","## Plan persistence risk","",`Unconfirmed AgentOS plan write (outboxId=${n.outboxId}).`)}return t.join(`
|
|
35
|
+
`)}function Ex(e){let r=new Set;if(e.targetTaskId)return r.add(String(e.targetTaskId)),r;if(e.targetTaskIds)for(let t of String(e.targetTaskIds).split(",")){let n=t.trim();n&&r.add(n)}return r}async function Wr(e){let r=e.pipeline===!0||e.pipeline==="true";try{let Mt=function(){return Q.filter(S=>S.started).length},Ge=function(S,b){tc({runId:i.id,agentOsId:a,phase:S,startedCount:Mt(),outcomeCount:Q.length,cappedStarts:x,...b})},be=function(){return Q.some(S=>(typeof S.error=="string"?S.error:"").startsWith("dispatch_start_readback_failed:"))},W=function(S){return S.landPrDispatch===!0?!0:S.task?.executor==="land_pr"};var t=Mt,n=Ge,o=be,s=W;let i=L(String(T(String(e.run||""),"--run"))),a=String(T(String(e.agentOsId||""),"--agent-os-id")),l=V(e.baseUrl?String(e.baseUrl):void 0),c=await J(e.secret?String(e.secret):void 0,a,{baseUrl:l}),d=!(e.execute===!0||e.execute==="true"),f=er({runId:i.id}),p=xc(i.id,f.runnerId),m=e.diskPath?Le({diskPath:String(e.diskPath)}):Le({diskPath:i.repo}),h=mr({runId:i.id}),k=Ex(e),g=k.size>0,y=Number(e.maxStarts)>0?Math.floor(Number(e.maxStarts)):1,_=g?Math.min(y,k.size):y,x=d?_:Math.min(_,h.slotsAvailable);if(!d&&x<=0){let S={runId:i.id,agentOsId:a,dryRun:!1,skipped:!0,reason:h.reason??"no resource slots",resourceGate:h};if(r)return{ok:!0,...S};console.log(JSON.stringify(S,null,2));return}let E=Hi(i.id);if(e.reconcileStaleBlockers===!0||e.reconcileStaleBlockers==="true"){let S=`${l}/api/agent-os/by-id/${encodeURIComponent(a)}/lane-hygiene`;try{await re(S,c,{agentOsId:a,dryRun:!1,includeBoardReconcile:!0},{agentOsId:a,baseUrl:l})}catch(b){console.error(`[dispatch] reconcile-stale-blockers lane-hygiene call failed: ${b.message}`)}}let A=`${l}/api/agent-os/by-id/${encodeURIComponent(a)}/tasks/dispatch-next`,Y=S=>({agentOsId:a,dryRun:d,maxStarts:S,leaseOwner:p,leaseDurationMs:Number(e.leaseMs)>0?Math.floor(Number(e.leaseMs)):Ci,runnerDiskGate:m,runnerResourceGate:h,activeHarnessWorkers:E,runnerPresence:f,harnessBoardSnapshot:Oo(i.id),...e.lane?{lane:of(String(e.lane))}:{},...e.executor?{executor:String(e.executor)}:{},...e.diskPath?{diskPath:String(e.diskPath)}:{},...e.targetTaskId?{targetTaskId:String(e.targetTaskId)}:{},...!e.targetTaskId&&e.targetTaskIds?{targetTaskIds:String(e.targetTaskIds).split(",").map(b=>b.trim()).filter(Boolean)}:{}}),$=zm(),F=async S=>{let b=await re(A,c,Y(S),{agentOsId:a,baseUrl:l,timeoutMs:$})??{ok:!1,status:0,response:null},I=b.response;return{dispatch:b,result:I?.result}},O=await F(g||d?x:1);if(!O.dispatch.ok||!O.result){let S={runId:i.id,agentOsId:a,action:"dispatch",httpStatus:O.dispatch.status,response:O.dispatch.response,authRefreshed:O.dispatch.refreshedAuth===!0,authRefreshFailure:O.dispatch.authRefreshFailure};if(r)return{ok:!1,...S};console.log(JSON.stringify(S,null,2)),process.exit(1)}let B=O.result;if(d){let S=ih(B),b=ah(B),I={runId:i.id,agentOsId:a,dryRun:!0,wouldStart:B.started.map(j=>({taskId:j.task.id,title:j.task.title,reason:j.reason})),skipped:B.skipped.map(j=>({taskId:j.task.id,skipReason:j.skipReason,reason:j.reason})),diskGate:B.diskGate,resourceGate:B.resourceGate,inspected:B.inspected,pagesScanned:B.pagesScanned??null,candidatesExhausted:B.candidatesExhausted??null,capacityIdle:S?.capacityIdle===!0,admissionExhaustion:S,dispatchSkipDrain:b};if(r)return{ok:!0,...I};console.log(JSON.stringify(I,null,2));return}let Kr=Of(),Q=[],Cr=[],Dt=Number(B.inspected)||0,Ve=!1;async function G(S,b,I){let j=await uu({baseUrl:l,secret:c,agentOsId:a,taskId:String(S.id),leaseOwner:p,failureDetail:b}),de={taskId:S.id,started:!1,error:b,released:j.released,releaseResponse:j.releaseResponse,...I};return Q.push(de),Ge("outcome",{lastOutcome:de}),!1}async function ve(S){let b=S.task,I=String(b.id);if(g&&!k.has(I))return G(b,"exact_target_mismatch: dispatch-next returned a different task than requested",{requestedTargetTaskIds:[...k]});let j=b.prUrl?String(b.prUrl):"";if(!j)return G(b,"land_pr task missing prUrl");try{let de=await rh({prUrl:j,repo:Zg(j),cwd:i.repo}),Wt=await th({baseUrl:l,secret:c,agentOsId:a,runId:i.id,task:b,report:de});return Wt.ok?(Q.push({taskId:I,started:!0,landPr:!0,outcome:de.outcome,completionStatus:Wt.status}),!0):G(b,`land_pr completion POST failed (HTTP ${Wt.status})`,{landPr:!0,outcome:de.outcome})}catch(de){return G(b,de.message)}}async function xe(S){let b="duplicate_dispatch_prevented: live local worker already owns this task",I=await uu({baseUrl:l,secret:c,agentOsId:a,taskId:String(S.id),leaseOwner:p,failureDetail:b}),j={taskId:S.id,started:!1,error:b,alreadyRunning:!0,nonFatal:!0,released:I.released,releaseResponse:I.releaseResponse};return Q.push(j),Ge("outcome",{lastOutcome:j}),!1}async function wr(S){let b=S.task,I=_x(S),j=String(b.id);if(g&&!k.has(j))return G(b,"exact_target_mismatch: dispatch-next returned a different task than requested",{requestedTargetTaskIds:[...k]});let de=xx(b.personaSlug);if(de&&(!I?.personaInjectionReady||!I.personaMarkdown))return G(b,`persona_injection_required: missing anchored context-envelope persona block for "${de}"`);if(Df(i.id,j))return xe(b);let Wt=Number(b.attempt)||1;if(Wt>Kr.maxTaskAttempts)return G(b,`task attempt ${Wt} exceeds KYNVER_MAX_TASK_ATTEMPTS (${Kr.maxTaskAttempts})`);let Kn=b.leaseToken?String(b.leaseToken).trim():"";if(!Kn)return G(b,"dispatch_start_failed: claimed task missing leaseToken \u2014 refusing local spawn");let Hb=v(`t-${b.id}-a${b.attempt}`),Lt=Ri({explicitModel:e.model?String(e.model):void 0,explicitProvider:e.provider?String(e.provider):void 0,explicitProviderIsOperatorOverride:!!e.provider,task:sf(b)});try{let cl=b.planId?String(b.planId):void 0,ks=Uf({title:b.title?String(b.title):void 0,description:b.description?String(b.description):null,executorRef:b.executorRef?String(b.executorRef):null,prUrl:b.prUrl?String(b.prUrl):null,branch:b.branch?String(b.branch):null}),Ye=Bi(i,{name:Hb,task:lh(b,a),ownedPaths:e.owned?String(e.owned).split(",").map(Fb=>Fb.trim()).filter(Boolean):[],model:Lt.model,provider:Lt.provider,routingRule:Lt.rule,requestedModel:Lt.requestedModel,agentOsId:a,taskId:String(b.id),planId:cl,branch:ks?.targetPrBranch??void 0,executorRef:b.executorRef?String(b.executorRef):void 0,parentTaskId:b.parentTaskId?String(b.parentTaskId):void 0,taskTitle:b.title?String(b.title):void 0,taskPrUrl:ks?.targetPrUrl??(b.prUrl?String(b.prUrl):void 0),repairTargetPrUrl:ks?.targetPrUrl,repairTargetBranch:ks?.targetPrBranch??void 0,instructionPolicyMarkdown:I?.instructionPolicyMarkdown??null,instructionPolicyFingerprint:I?.instructionPolicyFingerprint??null,instructionPolicyEvidence:I?.instructionPolicyEvidence??null,memoryQualityCapture:I?.memoryQualityCapture??null,memoryQualityPromptMarkdown:I?.memoryQualityPromptMarkdown??null,personaMarkdown:I?.personaMarkdown??null,personaSlug:I?.personaSlug??de,personaEvidence:I?.personaEvidence??null,contextEnvelopeMarkdown:I?.contextEnvelopeMarkdown??null,contextEnvelopeEvidence:I?.contextEnvelopeEvidence??null,leaseOwner:p,leaseToken:Kn,dispatched:!0}),ys=await oh({agentOsId:a,taskId:String(b.id),leaseOwner:p,expectedLeaseToken:Kn,worker:Ye,baseUrl:l,secret:c});if(!ys.ok)return sh(i.id,Ye,ys.error??"dispatch_start_readback_failed"),G(b,ys.error??"dispatch_start_readback_failed",{readback:ys.detail??null});Ye.leaseToken!==Kn&&(Ye.leaseToken=Kn,Ye.leaseOwner=p,K(i.id,Ye));let up={taskId:b.id,started:!0,worker:Ye.name,pid:Ye.pid,branch:Ye.branch,model:Ye.model,provider:Lt.provider,routingRule:Lt.rule,instructionPolicyFingerprint:I?.instructionPolicyFingerprint??null,instructionPolicyRuleCount:Array.isArray(I?.instructionPolicyEvidence?.ruleSlugs)?I.instructionPolicyEvidence.ruleSlugs.length:null,personaSlug:I?.personaSlug??de,personaOperatingRuleCount:I?.personaEvidence?.operatingRuleCount??null};return Q.push(up),Ge("worker_started",{lastOutcome:up}),I?.instructionPolicyFingerprint&&console.error(`[dispatch] task ${j}: operating-rules policy injected fingerprint=${I.instructionPolicyFingerprint}`),I?.personaSlug&&console.error(`[dispatch] task ${j}: persona context injected slug=${I.personaSlug}`),I?.contextEnvelopeReady&&console.error(`[dispatch] task ${j}: context envelope injected anchor=${I.contextEnvelopeEvidence?.anchorTaskId??j}`),!0}catch(cl){return G(b,cl.message)}}let Ee=new Set;async function fs(S){let b=S.task,I=String(b.id);if(Ee.has(I))return G(b,"dispatch_retry_loop_prevented: task already failed to start this tick");let j=W(S)?await ve(S):await wr(S);return j||Ee.add(I),j}for(let S of B.started)await fs(S);if(Cr.push(...B.skipped??[]),g)for(let S of Cr){let b=String(S.task.id);k.has(b)&&Q.push({taskId:b,started:!1,error:`exact_target_not_started:${S.skipReason}`,skipReason:S.skipReason,detail:S.reason??null,requestedTargetTaskIds:[...k]})}for(;!g&&Q.length<x;){if(be()){let I={started:!1,error:"dispatch_circuit_breaker: start readback failed; stopping top-up for this tick",nonFatal:!0};Q.push(I),Ge("circuit_breaker",{lastOutcome:I});break}let S=await F(1);if(!S.dispatch.ok||!S.result){let I=Xm(S.dispatch.response),j=Mt();Ve=I&&j>0;let de={started:!1,error:"dispatch_next request failed during top-up",httpStatus:S.dispatch.status,response:S.dispatch.response,...Ve?{nonFatal:!0,partialTopUp:!0}:{}};Q.push(de),Ge("top_up_failed",{partialTopUpInterrupted:Ve,lastOutcome:de});break}Dt+=Number(S.result.inspected)||0,Cr.push(...S.result.skipped??[]);let b=S.result.started??[];if(b.length===0)break;for(let I of b){if(Q.length>=x)break;await fs(I)}}let gs=Q.filter(S=>S.started).length,Ut=ih(B),hs=ah(B),ip=gs===0&&(Ut?.capacityIdle===!0||Number(B.resourceGate?.slotsAvailable)>0);if(ip&&Ut?.summary){let S=Ut.skipReasonCounts?.retry_ceiling_exceeded??0,b=B.overAttemptIdleRecovery??Ut.overAttemptIdleRecovery,I=b?.attempted===!0?`; over_attempt_recovery minted=${b.minted??0} started=${b.started??0}`:S>0?"; over_attempt_recovery not attempted":"",j=hs?`; dispatch_skip_drain scanned=${hs.scanned??0} advanced=${hs.advanced??0}`:"";console.error(`[dispatch] ${Ut.summary}${S>0?`; retry_ceiling_exceeded=${S}`:""}${I}${j}`)}let ap={runId:i.id,agentOsId:a,dryRun:!1,leaseOwner:p,startedCount:gs,capacityIdle:ip,admissionExhaustion:Ut,dispatchSkipDrain:hs,outcomes:Q,skipped:Cr.map(S=>({taskId:S.task.id,skipReason:S.skipReason})),inspected:Dt,pagesScanned:B.pagesScanned??null,candidatesExhausted:B.candidatesExhausted??null,diskGate:B.diskGate,resourceGate:B.resourceGate,...Ve?{partialTopUpInterrupted:!0}:{},dispatchCallbackTimeoutMs:$},lp=S=>!S.started&&S.nonFatal!==!0,Bb=Q.some(lp),cp=Ve&&gs>0?!0:!Bb;if(tc({runId:i.id,agentOsId:a,phase:"complete",partial:Ve,startedCount:gs,ok:cp}),r)return{ok:cp,...ap};console.log(JSON.stringify(ap,null,2)),Q.some(lp)&&process.exit(1)}catch(i){if(r)return{ok:!1,error:i.message};console.error(`run dispatch failed: ${i.message}`),process.exit(1)}}Gt();As();Vt();Vt();import{unlinkSync as Px}from"node:fs";function zi(e){let r=process.env[e];return r==="1"||r==="true"||r==="yes"}function ch(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)?n:r}function Ax(e,r,t){return e.length===0?[]:t?[...e]:e.length<=r?[]:e.slice(r)}function Uo(e={}){let r=e.execute===!0||zi("KYNVER_WSL_CRASH_DUMP_EXECUTE")||zi("KYNVER_CLEANUP_EXECUTE"),t=e.purgeAll===!0||zi("KYNVER_WSL_CRASH_DUMP_PURGE_ALL"),n=Math.max(0,e.keepNewest??ch("KYNVER_WSL_CRASH_DUMP_KEEP_NEWEST",t?0:1)),o=ur({forceWsl:e.forceWsl});if(!o?.path)return{observation:o,execute:r,keepNewest:n,removed:[],removedBytes:0,skipped:o?.probeError?[{path:o.path??"(unresolved)",reason:o.probeError}]:[]};let s=Ax(o.dumps,n,t),i=[],a=[],l=0;for(let c of s){if(!r){a.push({path:c.path,reason:"dry_run"});continue}try{Px(c.path),i.push({path:c.path,bytes:c.bytes,name:c.name}),l+=c.bytes}catch(u){a.push({path:c.path,reason:u.message})}}return{observation:o,execute:r,keepNewest:n,removed:i,removedBytes:l,skipped:a}}function mu(e){return e?zi("KYNVER_WSL_CRASH_DUMP_CLEANUP")||!e.ok?!0:e.dumpCount>ch("KYNVER_WSL_CRASH_DUMP_KEEP_NEWEST",1):!1}qt();Wl();Ul();pr();N();Ie();import Ox from"node:os";function Wo(e,r={}){let t=(r.boxKind??qe(R())).trim().toLowerCase()||"forge",n=r.hostLabel??Ox.hostname();return{boxId:r.boxId??bo(t,n),boxKind:t,displayName:r.displayName??null,hostLabel:n,observedAt:r.observedAt??new Date().toISOString(),totalMemBytes:e.totalMemBytes,freeMemBytes:e.freeMemBytes,activeWorkers:e.activeWorkers,maxConcurrentWorkers:e.maxConcurrentWorkers,autoCap:e.autoCap,slotsAvailable:e.slotsAvailable,harnessRunId:r.harnessRunId??null,queuedTasks:r.queuedTasks??null,reason:e.reason,...r.prEvidence?.length?{prEvidence:r.prEvidence}:{}}}function Ix(e){let r={ts:e.ts??new Date().toISOString(),phase:e.phase,summary:e.summary,changedFiles:e.changedFiles??[],blocker:e.blocker??null};return e.boxResourceSnapshot&&(r.boxResourceSnapshot=e.boxResourceSnapshot),e.prEvidence?.length&&(r.prEvidence=e.prEvidence),`${JSON.stringify(r)}
|
|
36
|
+
`}z();ro();function Nx(e){if(e.skipReason==="engagement_required")return!0;let r=e.reason??"";return r.includes("engagement_required")||r.includes("engagement_not_found")||r.includes("engagement_expired")||r.includes("engagement_revoked")}$l();Zn();pr();Bl();qt();function Xi(e){return e==null?!1:typeof e=="string"?e.trim().length>0:typeof e=="object"&&!Array.isArray(e)?Object.keys(e).length>0:!0}function Tx(e){let r=e.lastHeartbeatPhase?.trim();if(!r||r==="complete")return null;let t=e.lastHeartbeatSummary?.trim();return t?{summary:t,handoffState:"exited_without_complete_heartbeat",lastHeartbeatPhase:r,...e.heartbeatBlocker?{blocker:e.heartbeatBlocker}:{}}:null}function Dx(e){let r=Ls(e);return r?{summary:r.reason,handoffState:"exit_failure",blocked:r.blocked}:null}function fu(e){let{worker:r,status:t}=e;if(Xi(t.finalResult)){let l=ce(r.heartbeatPath),c=ze(l),u=Xi(c)&&JSON.stringify(c)===JSON.stringify(t.finalResult)?"heartbeat_complete":"stdout_stream";return{finalResult:t.finalResult,source:u,snapshot:mt(t)}}if(t.alive)return null;let n=Ar(r.stdoutPath);if(Xi(n.finalResult)){let l={...t,finalResult:n.finalResult};return{finalResult:n.finalResult,source:"stdout_stream",snapshot:mt(l)}}let o=ce(r.heartbeatPath),s=ze(o);if(Xi(s)){let l={...t,finalResult:s,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary};return{finalResult:s,source:"heartbeat_complete",snapshot:mt(l)}}let i=Dx(t.error??n.error);if(i){let l={...t,finalResult:i};return{finalResult:i,source:"exit_failure",snapshot:mt(l)}}let a=Tx(o);if(a){let l={...t,finalResult:a,lastHeartbeatPhase:o.lastHeartbeatPhase,lastHeartbeatSummary:o.lastHeartbeatSummary};return{finalResult:a,source:"heartbeat_summary",snapshot:mt(l)}}return null}function gu(e,r){return e.completionSnapshot?.finalResult!=null?!1:(e.completionSnapshot=r.snapshot,e.completionHandoffSource=r.source,!0)}import{createHash as uh}from"node:crypto";function Qi(e){return JSON.stringify(hu(e))}function hu(e){if(Array.isArray(e))return e.map(hu);if(e&&typeof e=="object"){let r={};for(let t of Object.keys(e).sort())r[t]=hu(e[t]);return r}return e}function Mx(e){return`ib1-${uh("sha256").update(Qi(e),"utf8").digest("hex").slice(0,16)}`}function Ux(e){return`ib-${uh("sha256").update(Buffer.from(e)).digest("hex").slice(0,12)}`}function Zi(e){if(!e)return null;let r=e.trim();if(!r)return null;if(/^[0-9a-fA-F]{64}$/.test(r))return new Uint8Array(r.match(/.{2}/g).map(t=>parseInt(t,16)));try{let t=Buffer.from(r,"base64");if(t.length===32)return new Uint8Array(t)}catch{}return null}function yn(e){if(!e||typeof e!="object")return!1;let r=e;if(typeof r.signature!="string"||!r.signature||typeof r.publicKeyId!="string"||!r.publicKeyId)return!1;let t=r.bundle;return!(!t||typeof t!="object"||typeof t.version!="string"||!t.version||typeof t.generatedAt!="string"||!Array.isArray(t.personas)||!t.instructions||typeof t.instructions!="object"||!t.policyThresholds||typeof t.policyThresholds!="object")}var dh={"ib-3bab6314f0ba":"53a2040646cd479e1f5f1aea9abf7848ce8b62e32001efb8044dfd90e8ab87ed","ib-26e6c695da06":"bb1700f25b2ee7d7cdcdb9f446f0f44ef2cc22a3096bc161232fb658e7cdaf38"};function ku(e,r=process.env){let t=Zi(r.KYNVER_INSTRUCTION_BUNDLE_PUBLIC_KEY);if(t)return t;let n=dh[e];return n?Zi(n):null}import{createPublicKey as Wx,verify as Lx}from"node:crypto";var Bx=Buffer.from("302a300506032b6570032100","hex");function Hx(e){return Wx({key:Buffer.concat([Bx,Buffer.from(e)]),format:"der",type:"spki"})}function ph(e,r){if(!yn(e))return{ok:!1,reason:"malformed signed bundle payload"};let t;try{t=Buffer.from(e.signature,"base64url")}catch{return{ok:!1,reason:"signature is not base64url"}}if(t.length!==64)return{ok:!1,reason:"signature is not a 64-byte Ed25519 signature"};try{let n=Buffer.from(Qi(e.bundle),"utf8");return Lx(null,n,Hx(r),t)?{ok:!0,bundle:e.bundle}:{ok:!1,reason:"Ed25519 signature mismatch"}}catch(n){return{ok:!1,reason:`signature verification failed: ${n.message}`}}}function yu(e,r=process.env){if(!yn(e))return{ok:!1,reason:"malformed signed bundle payload"};let t=ku(e.publicKeyId,r);return t?ph(e,t):{ok:!1,reason:`no verification key for publicKeyId "${e.publicKeyId}" (not pinned; set KYNVER_INSTRUCTION_BUNDLE_PUBLIC_KEY)`}}import{mkdirSync as Fx,readFileSync as Kx,renameSync as $x,writeFileSync as jx}from"node:fs";import{homedir as Vx}from"node:os";import mh from"node:path";function Ru(e){let r=e.replace(/[^A-Za-z0-9_-]/g,"_");return mh.join(Vx(),".kynver",`instruction-bundle-${r}.json`)}function bu(e,r){try{let t=Ru(e);Fx(mh.dirname(t),{recursive:!0});let n=`${t}.tmp-${process.pid}`;jx(n,JSON.stringify(r),"utf8"),$x(n,t)}catch{}}function vu(e){try{let r=Kx(Ru(e),"utf8"),t=JSON.parse(r);return yn(t)?t:null}catch{return null}}var fh=15*6e4,Gx=1e4,hr={lastAttemptAtMs:0,etag:null,diskCacheTried:!1,routeMissingLogged:!1};function Bo(e,r){console.error(JSON.stringify({event:e,...r}))}function gh(e,r,t){let n=yu(e);return n.ok?(nc(n.bundle,r),r==="server"&&bu(t,e),!0):(Bo("instruction_bundle_signature_invalid",{agentOsId:t,source:r,publicKeyId:e.publicKeyId,reason:n.reason}),!1)}function Lo(e){if(hr.diskCacheTried)return!1;hr.diskCacheTried=!0;let r=vu(e);return r?gh(r,"disk",e):!1}async function Su(e){let r=e.nowMs??Date.now(),t=()=>({source:fr(),version:Nr(),updated:!1});if(!e.force&&r-hr.lastAttemptAtMs<fh)return t();hr.lastAttemptAtMs=r;let n=e.baseUrl?.trim().replace(/\/$/,""),o=e.secret?.trim();if(!n||!o)return fr()==="embedded"&&Lo(e.agentOsId)?{...t(),updated:!0}:t();let s=e.fetchImpl??fetch,i=new AbortController,a=setTimeout(()=>i.abort(),Gx);try{let l=He(o);delete l["Content-Type"],hr.etag&&fr()==="server"&&(l["If-None-Match"]=hr.etag);let c=await s(`${n}/api/agent-os/by-id/${encodeURIComponent(e.agentOsId)}/runtime/instruction-bundle`,{headers:l,signal:i.signal});if(c.status===304)return t();if(c.status===404)return hr.routeMissingLogged||(hr.routeMissingLogged=!0,Bo("instruction_bundle_route_missing",{agentOsId:e.agentOsId,baseUrl:n})),fr()==="embedded"&&Lo(e.agentOsId)?{...t(),updated:!0}:t();if(!c.ok)return Bo("instruction_bundle_fetch_failed",{agentOsId:e.agentOsId,status:c.status}),fr()==="embedded"&&Lo(e.agentOsId)?{...t(),updated:!0}:t();let u=await c.json().catch(()=>null);return!u||!gh(u,"server",e.agentOsId)?fr()==="embedded"&&Lo(e.agentOsId)?{...t(),updated:!0}:t():(hr.etag=c.headers.get("etag"),Bo("instruction_bundle_loaded",{agentOsId:e.agentOsId,version:Nr(),publicKeyId:u.publicKeyId}),{...t(),updated:!0})}catch(l){return Bo("instruction_bundle_fetch_error",{agentOsId:e.agentOsId,error:l instanceof Error?l.message:String(l)}),fr()==="embedded"&&Lo(e.agentOsId)?{...t(),updated:!0}:t()}finally{clearTimeout(a)}}var Cu="openai-codex",Yx=new Set(["upstream_503","connection_refused","connection_reset","sse_no_event","sse_idle_timeout"]),Jx=[/\bsk-[a-zA-Z0-9_-]{8,}\b/g,/\bBearer\s+[a-zA-Z0-9._-]{8,}\b/gi,/\baccess[_-]?token["\s:=]+[a-zA-Z0-9._-]{8,}/gi];function kr(e,r=400){let t=String(e??"").replace(/\s+/g," ").trim();for(let n of Jx)t=t.replace(n,"[redacted]");return t.length>r?`${t.slice(0,r)}\u2026`:t}function qx(e,r){let t=[];e instanceof Error?(t.push(e.message),t.push(e.name)):typeof e=="string"?t.push(e):e!=null&&t.push(String(e));let n=e,o=r??n?.status_code??n?.statusCode??void 0;return o!=null&&t.push(`http ${o}`),{haystack:t.join(" ").toLowerCase(),statusCode:o}}function kh(e,r){let{haystack:t,statusCode:n}=qx(e,r),o=e instanceof Error?e.message:typeof e=="string"?e:String(e??"");if(n===402||/billing|credit|payment required|insufficient_quota/.test(t))return{errorClass:"billing",summary:kr(o||"Billing or credits exhausted"),statusCode:n,transient:!1};if(n===401||n===403||/\bunauthorized\b|\bforbidden\b/.test(t))return{errorClass:"auth",summary:kr(o||"Authentication failed"),statusCode:n,transient:!1};if(n===429||/rate limit|too many requests|throttl/.test(t))return{errorClass:"rate_limit",summary:kr(o||"Rate limited"),statusCode:n,transient:!0};if(n===503||/upstream connect error|connection termination|remote connection failure|delayed connect error/.test(t))return{errorClass:"upstream_503",summary:kr(o||"ChatGPT Codex backend returned HTTP 503"),statusCode:n??503,transient:!0};if(/connection refused/.test(t))return{errorClass:"connection_refused",summary:kr(o||"Connection refused by ChatGPT Codex backend"),statusCode:n,transient:!0};if(/no sse events|no bytes within|no stream events|codex stream produced no/.test(t)){let s=/no bytes|ttfb|first byte/.test(t)?"sse_no_event":"sse_idle_timeout";return{errorClass:s,summary:kr(o||(s==="sse_no_event"?"Codex stream opened but sent no events":"Codex stream stalled after the first event")),statusCode:n,transient:!0}}return/connection reset|connection lost|connection closed|disconnect\/reset/.test(t)?{errorClass:"connection_reset",summary:kr(o||"Connection reset while talking to ChatGPT Codex"),statusCode:n,transient:!0}:{errorClass:"unknown",summary:kr(o||"Unknown provider error"),statusCode:n,transient:!1}}function yh(e){let r=e.env??process.env,t=Math.max(1,e.defaultRetries??3),n=String(e.provider??"").toLowerCase(),o=String(e.platform??"").toLowerCase();if(n!==Cu||o!=="cron")return t;let s=r.HERMES_CODEX_CRON_API_MAX_RETRIES?.trim();if(!s)return Math.max(t,5);let i=Number.parseInt(s,10);return!Number.isFinite(i)||i<1?Math.max(t,5):Math.max(t,i)}var hh={upstream_503:"ChatGPT Codex backend outage (HTTP 503)",connection_refused:"ChatGPT Codex backend refused the connection",connection_reset:"ChatGPT Codex connection dropped mid-request",sse_no_event:"Codex stream never started (no SSE events)",sse_idle_timeout:"Codex stream stalled (no SSE events after the first byte)",rate_limit:"ChatGPT Codex rate limit",billing:"ChatGPT Codex billing or quota limit",auth:"ChatGPT Codex authentication problem",unknown:"ChatGPT Codex provider error"};function Rh(e){let r=e.provider?.trim()||Cu,t=e.model?.trim()||"(unknown model)",n=e.jobName?.trim()||"Scheduled Hermes job",o=hh[e.errorClass]??hh.unknown,s=e.degraded?"degraded":"failed";return[`\u26A0\uFE0F ${n} \u2014 AI provider ${s} (not a Kynver harness failure).`,"",`Provider: ${r} (ChatGPT Codex subscription)`,`Model: ${t}`,`What happened: ${o} after ${e.attempts} attempt(s) with backoff.`,`Details: ${e.summary}`,"","This is a ChatGPT/Codex API issue on chatgpt.com \u2014 not AgentOS, not the Kynver runtime, and not your local harness.","The cron job will run again on its next schedule. If it persists, check ChatGPT/Codex status or re-auth with: hermes auth status openai-codex"].join(`
|
|
37
|
+
`)}function bh(e,r){return`\u26A0\uFE0F Cron job '${e}' \u2014 provider degraded
|
|
38
38
|
|
|
39
|
-
${r}`}function
|
|
40
|
-
`)){let o=n.match(/^\s*([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(.*)$/);if(!o||!t.has(o[1]))continue;let s=o[1];r[s]=o[2].replace(/^["']|["']$/g,"").trim()}return r}function jx(e){for(let r of Cu){let t=$e(e,r);if(t)return{ok:!0,databaseUrl:t,source:`env:${r}`,hint:Bo(t)}}return null}function Vx(e,r){for(let t of ra({cwd:e,env:r})){let n=gh(t);for(let o of wu){let s=n[o]?.trim();if(s)return{ok:!0,databaseUrl:s,source:`env-file:${o}`,hint:`${Bo(s)} (${fh.basename(t)})`}}}return null}function Gx(e){let r=process.platform==="win32"?"neon.cmd":"neon",t=["connection-string",e.branch,"--prisma","-o","json","--no-color","--no-analytics"];e.projectId&&t.push("--project-id",e.projectId),e.databaseName&&t.push("--database-name",e.databaseName),e.roleName&&t.push("--role-name",e.roleName),e.pooled&&t.push("--pooled");let n;try{let o=$x(r,t,{encoding:"utf8",env:process.env,timeout:3e4});if(o.status!==0)return null;n=(o.stdout||"").trim()}catch{try{n=Kx("neonctl",t,{encoding:"utf8",env:process.env,timeout:3e4}).trim()}catch{return null}}if(!n)return null;try{let o=JSON.parse(n),s=typeof o.connection_uri=="string"&&o.connection_uri||typeof o.connection_string=="string"&&o.connection_string||typeof o.connectionString=="string"&&o.connectionString;if(s)return s}catch{}return/^postgres(ql)?:\/\//i.test(n)?n:null}function Yx(e,r){let t=$e(e,"KYNVER_NEON_BRANCH")||$e(e,"NEON_BRANCH")||"production",n=r({branch:t,projectId:$e(e,"KYNVER_NEON_PROJECT_ID")||$e(e,"NEON_PROJECT_ID"),databaseName:$e(e,"KYNVER_NEON_DATABASE_NAME")||$e(e,"NEON_DATABASE_NAME"),roleName:$e(e,"KYNVER_NEON_ROLE_NAME")||$e(e,"NEON_ROLE_NAME"),pooled:$e(e,"KYNVER_NEON_POOLED")==="1"||$e(e,"NEON_POOLED")==="1"});return n?{ok:!0,databaseUrl:n,source:"neon-cli",hint:Bo(n)}:null}function hh(e={}){let r=e.env??process.env,t=e.cwd??process.cwd(),n=e.neonConnectionString??Gx,o=[],s=ra({cwd:t,env:r}),i=Yx(r,n);if(o.push("neon-cli"),i)return i;for(let u of Cu)o.push(`env:${u}`);let a=jx(r);if(a)return a;for(let u of wu)o.push(`env-file:${u}`);let l=Vx(t,r);return l||{ok:!1,reason:"No production database credentials found. Authenticate Neon CLI (`neon auth`), set KYNVER_NEON_* / NEON_* project hints, or provide PRODUCTION_DATABASE_URL / KYNVER_PRODUCTION_DATABASE_URL (process env, KYNVER_ENV_FILE, ~/.kynver/.env, or selective .env keys in the repo / defaultRepo checkout)."+(s.length>0?` Searched env files: ${s.slice(0,6).join(", ")}${s.length>6?"\u2026":""}.`:""),attempted:o}}function Jx(e={}){let r=hh(e);if(!r.ok)throw new Error(r.reason);return process.env.DATABASE_URL=r.databaseUrl,console.error(`[kynver-cli] database target: ${r.hint} (source: ${r.source})`),r}Pe();T();import{existsSync as BE,mkdirSync as HE}from"node:fs";import FE from"node:path";T();zr();import{existsSync as NE,readFileSync as TE}from"node:fs";import Ph from"node:path";import AE from"node:path";T();zr();z();C();import qx from"node:path";var zx=new Set(["running","dispatching","pending","queued","needs_attention"]),yr=new Set(["completed","failed","cancelled","done"]);function yt(e){let r=ke(e);if(r.length===0)return"failed";let t=!1,n=!1,o=!1,s=!1;for(let i of r){let a=w(qx.join(x(e.id),"workers",b(i),"worker.json"),void 0);if(!a)continue;let l=D(a,{base:e.base,baseCommit:e.baseCommit});if(l.alive&&!l.finalResult){t=!0;break}typeof a.completionBlocker=="string"&&a.completionBlocker&&(o=!0),et(l)&&(s=!0),l.finalResult&&l.attention.state==="done"&&(n=!0)}return t||o||s?null:n?"completed":"failed"}function Ho(){let e=[];for(let r of X()){if(!zx.has(r.status))continue;let t=yt(r);if(!t||t===r.status)continue;let n=r.status;r.status=t,Be(r),e.push({runId:r.id,from:n,to:t})}return e}T();zr();z();C();pr();Jt();import{existsSync as Br,lstatSync as lE,readdirSync as cE,readlinkSync as uE,renameSync as Du,unlinkSync as dE}from"node:fs";import nr from"node:path";Ce();C();import Re from"node:path";var Xx=`${Re.sep}runs${Re.sep}runs${Re.sep}`;function yn(e){return e.includes(Xx)}function Qx(e,r){if(!yn(e))return e;let t=le(r),n=ge(t),o=`${Re.sep}runs${Re.sep}runs${Re.sep}`,s=e.indexOf(o);if(s<0)return e;let i=e.slice(s+o.length);return Re.join(n,i)}function _u(e,r){return Re.join(ge(le(e)),b(r))}function Rr(e,r,t){return Re.join(_u(e,r),"workers",b(t))}function kh(e,r,t){let n=le(e);return Re.join(n,"runs","runs",b(r),"workers",b(t))}function xu(){return["stdout.jsonl","stderr.log","heartbeat.jsonl","last-status.json","auto-complete.log","worker.json"]}function Rt(e){return{workerJsonPath:Re.join(e,"worker.json"),stdoutPath:Re.join(e,"stdout.jsonl"),stderrPath:Re.join(e,"stderr.log"),heartbeatPath:Re.join(e,"heartbeat.jsonl"),lastStatusPath:Re.join(e,"last-status.json")}}function Eu(e){let r=Rt(Rr(e.harnessRoot,e.runId,e.workerName)).workerJsonPath;return e.statusPath&&!yn(e.statusPath)?e.statusPath:r}import{existsSync as Lr,mkdirSync as rE,readdirSync as bh,renameSync as tE,statSync as Pu}from"node:fs";import te from"node:path";I();Vn();Je();import yh from"node:path";function Zx(e){return yh.resolve(Bt(e.trim()))}function Rn(e,r,t){let n=e?.trim();return n?{repo:Zx(n),source:r,persistedInConfig:t}:null}function Rh(e){return e?{repo:e.repo,source:e.source,persistedInConfig:!1}:null}function je(e={}){let r=e.env??process.env,t=e.config??y(),n=Rn(t.defaultRepo,"config",!0);if(n)return n;let o=Rn(r.KYNVER_DEFAULT_REPO,"env_default_repo",!1);if(o)return o;let s=Rn(r.KYNVER_HARNESS_REPO,"env_harness_repo",!1);return s||Rh(Gr({cwd:e.cwd,runtimeModuleUrl:e.runtimeModuleUrl}))}function na(e={}){let r=e.env??process.env,t=e.config??y(),n=Rn(t.defaultRepo,"config",!0);if(n)return n;let o=Rn(r.KYNVER_DEFAULT_REPO,"env_default_repo",!1);if(o)return o;let s=Rn(r.KYNVER_HARNESS_REPO,"env_harness_repo",!1);return s||Rh(jn({cwd:e.cwd,runtimeModuleUrl:e.runtimeModuleUrl}))}function oa(e,r){let t={...r??y(),defaultRepo:Se(yh.resolve(e))};return ue(t),t}function eE(e){let r=e?.config??y(),t=na({...e,config:r});if(!t)return{ok:!1,reason:"No Kynver git checkout found. Clone the repo, cd into it, then run `kynver setup --repo /path/to/Kynver` (or export KYNVER_DEFAULT_REPO)."};if(t.persistedInConfig)return{ok:!0,resolved:t,config:r};let n=oa(t.repo,r);return{ok:!0,resolved:{...t,persistedInConfig:!0,source:"config"},config:n}}function vn(e){return{defaultRepo:q(e.repo),source:e.source,persistedInConfig:e.persistedInConfig}}pr();Ce();T();C();var bn=900*1e3,Sh=3600*1e3;function Au(e,r){let t=te.resolve(e),n=te.resolve(ge(r)),o=te.relative(n,t);return o!==".."&&!o.startsWith("..")&&!te.isAbsolute(o)}function Iu(e){if(!Lr(e))return[];try{return bh(e,{withFileTypes:!0}).filter(r=>r.isDirectory()&&r.name!=="runs").map(r=>r.name)}catch{return[]}}function Ou(e){let r=te.join(e,"workers");if(!Lr(r))return[];try{return bh(r,{withFileTypes:!0}).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}function Ch(e){return te.join(e,"archived-workers")}function nE(e,r){let t=te.join(Ch(e),b(r));return Lr(t)?`${t}-${Date.now()}`:t}function vh(e,r,t){if(!Lr(e))return!1;try{let n=r-Pu(e).mtimeMs;return Number.isFinite(n)&&n>=0&&n<t}catch{return!1}}function Nu(e,r=Date.now(),t=bn){if(!Lr(e))return!1;let n=Rt(e),o=w(n.workerJsonPath,void 0);if(o?.status==="running"&&H(o.pid))return!0;let s=ce(n.heartbeatPath);if(s.lastHeartbeatAt){let i=r-Date.parse(s.lastHeartbeatAt);if(Number.isFinite(i)&&i>=0&&i<t)return!0}return!!(vh(n.stdoutPath,r,t)||vh(n.heartbeatPath,r,t))}function oE(e,r,t){let n=typeof r.completionReportedAt=="string"?Date.parse(r.completionReportedAt):NaN;if(Number.isFinite(n))return t-n;let o=(()=>{let s=r.completionResponse;if(!s||typeof s!="object")return NaN;let i=s.task;if(!i||typeof i!="object")return NaN;let a=i.updatedAt;return typeof a=="string"?Date.parse(a):NaN})();if(Number.isFinite(o))return t-o;try{return t-Pu(te.join(e,"worker.json")).mtimeMs}catch{return 0}}function sE(e,r,t,n){if(Nu(e,t))return{eligible:!1,reason:"worker has active/recent retention signals"};let o=typeof r.status=="string"?r.status:"";if(typeof r.completionBlocker=="string"&&r.completionBlocker.trim().length>0)return{eligible:!1,reason:"worker has completion blocker"};let i=typeof r.completionReportedAt=="string"||r.completionOutcome==="acknowledged";if(o!=="done"&&!i)return{eligible:!1,reason:`worker status is ${o||"unknown"}`};let a=oE(e,r,t);return!Number.isFinite(a)||a<n?{eligible:!1,reason:"terminal worker is still within archive grace window"}:{eligible:!0,reason:"terminal worker metadata archived"}}function vt(e,r=Date.now(),t=bn){for(let n of Ou(e))if(Nu(te.join(e,"workers",n),r,t))return!0;return!1}function iE(){return{repo:je()?.repo??"",base:"origin/main",baseCommit:"unknown"}}function aE(e,r){let t=te.join(ge(e),b(r));if(!Lr(t))return null;let n=Ou(t);if(n.length===0)return null;let o;try{o=Pu(t).birthtime.toISOString()}catch{o=new Date().toISOString()}let s={};for(let a of n){let l=Rr(e,r,a);s[a]={workerDir:l,statusPath:te.join(l,"worker.json")}}let i=vt(t);return{id:r,name:r,...iE(),status:i?"running":"needs_attention",createdAt:o,workers:s}}function sa(e){let r=le(e??fe()),t=ge(r),n=[];for(let o of Iu(t)){let s=te.join(t,o,"run.json");if(Lr(s)){n.push({runId:o,action:"skipped",reason:"run.json present"});continue}let i=aE(r,o);if(!i){n.push({runId:o,action:"skipped",reason:"no worker dirs on disk"});continue}Be(i),n.push({runId:o,action:"repaired_run_json",reason:vt(te.join(t,o))?"synthesized run.json while worker artifacts still active":"synthesized run.json from orphan worker metadata dirs"})}return{runs:n}}function ia(e,r={}){let t=le(e??fe()),n=ge(t),o=r.now??Date.now(),s=r.archiveAgeMs??Sh,i=[];sa(t);for(let a of Iu(n)){let l=te.join(n,a),c=te.join(l,"run.json"),u=w(c,void 0);if(!u?.id)continue;let d=new Set([...Object.keys(u.workers||{}),...Ou(l)]),m=!1;for(let p of d){let f=te.join(l,"workers",b(p)),h=te.join(f,"worker.json"),k=w(h,void 0);if(!k){let O=te.join(Ch(l),b(p));if(Lr(O)&&(u.workers[b(p)]||u.workers[p])){delete u.workers[b(p)],delete u.workers[p],m=!0,i.push({runId:u.id,worker:p,action:"archived",reason:"removed stale live index entry for archived worker metadata",archivePath:O});continue}i.push({runId:u.id,worker:p,action:"skipped",reason:"worker.json missing"});continue}let g=sE(f,k,o,s);if(!g.eligible){i.push({runId:u.id,worker:p,action:"skipped",reason:g.reason});continue}let R=nE(l,p);rE(te.dirname(R),{recursive:!0}),tE(f,R),delete u.workers[b(p)],delete u.workers[p],m=!0,i.push({runId:u.id,worker:p,action:"archived",reason:g.reason,archivePath:R})}m&&Be(u)}return{workers:i}}function Tu(e,r=Date.now()){let t=new Set,n=ge(e);for(let o of Iu(n)){let s=te.join(n,o);vt(s,r)&&t.add(`${e}\0${o}`)}return t}T();C();function pE(e,r){let t=_u(e,r),n;try{n=lE(t)}catch{return null}if(!n.isSymbolicLink())return null;let o=nr.resolve(nr.dirname(t),uE(t));if(vt(o)||vt(t))return null;let s=`${t}.materialize-${Date.now()}`;return Du(o,s),dE(t),Du(s,t),o}function mE(e){let r=[];for(let t of xu()){let n=nr.join(e.fromDir,t),o=nr.join(e.toDir,t);!Br(n)||Br(o)||(Du(n,o),r.push(t))}return r}function wh(e,r){let t=Rt(r),n=!1;return e.workerDir!==r&&(e.workerDir=r,n=!0),e.stdoutPath!==t.stdoutPath&&(e.stdoutPath=t.stdoutPath,n=!0),e.stderrPath!==t.stderrPath&&(e.stderrPath=t.stderrPath,n=!0),e.heartbeatPath!==t.heartbeatPath&&(e.heartbeatPath=t.heartbeatPath,n=!0),n}function fE(e){let r=typeof e.lastStatus?.status=="string"?e.lastStatus.status:void 0,t=e.lastStatus?.attention&&typeof e.lastStatus.attention=="object"?e.lastStatus.attention.state:void 0;return r==="done"||t==="done"||e.stdoutFinalResult||e.heartbeatFinalResult?"done":r==="blocked"?"blocked":r==="running"?"exited":r??"exited"}function gE(e){let r=Rt(e.canonicalDir),t=w(r.lastStatusPath,void 0),n=Br(r.stdoutPath),o=Br(r.heartbeatPath);if(!(n||o||t!=null))return null;let i=n?Ar(r.stdoutPath):{finalResult:null},a=o?ce(r.heartbeatPath):ce(""),l=ze(a),c=fE({lastStatus:t,stdoutFinalResult:i.finalResult,heartbeatFinalResult:l}),u={name:e.workerName,runId:e.run.id,status:c,branch:typeof t?.branch=="string"?t.branch:`agent/${e.run.id}/${e.workerName}`,worktreePath:typeof t?.worktreePath=="string"?t.worktreePath:nr.join(Z().worktreesDir,e.run.id,e.workerName),workerDir:e.canonicalDir,stdoutPath:r.stdoutPath,stderrPath:r.stderrPath,heartbeatPath:r.heartbeatPath,startedAt:typeof t?.startedAt=="string"?t.startedAt:e.run.createdAt,reconciledAt:new Date().toISOString(),reconcileReason:"synthesized worker.json from on-disk artifacts after metadata repair"};return typeof t?.taskId=="string"&&(u.taskId=t.taskId),typeof t?.agentOsId=="string"&&(u.agentOsId=t.agentOsId),typeof t?.planId=="string"&&(u.planId=t.planId),typeof t?.pid=="number"&&(u.pid=t.pid),(i.finalResult||l)&&(u.completionSnapshot={finalResult:i.finalResult??l??"completed",summary:a.lastHeartbeatSummary}),wh(u,e.canonicalDir),u}function hE(e,r){let t=!1,n={...e.workers||{}};for(let[o,s]of Object.entries(n)){let i=Rr(r,e.id,o),a=nr.join(i,"worker.json");(yn(s.workerDir)||yn(s.statusPath)||s.workerDir!==i||s.statusPath!==a)&&(n[o]={workerDir:i,statusPath:a},t=!0)}return t&&(e.workers=n,Be(e)),t}function kE(e){let r=[],t=Rr(e.harnessRoot,e.run.id,e.workerName),n=kh(e.harnessRoot,e.run.id,e.workerName),o=Rt(t),s=mE({fromDir:n,toDir:t});s.length>0&&r.push({runId:e.run.id,worker:e.workerName,action:"relocated_artifacts",reason:`moved ${s.join(", ")} from nested runs/runs layout`});let i=Eu({harnessRoot:e.harnessRoot,runId:e.run.id,workerName:e.workerName,statusPath:e.statusPath}),a=w(i,void 0);if(!a&&Br(o.workerJsonPath)&&(a=w(o.workerJsonPath,void 0)),!a){let l=gE({run:e.run,workerName:e.workerName,canonicalDir:t,harnessRoot:e.harnessRoot});if(l)return K(e.run.id,l),r.push({runId:e.run.id,worker:e.workerName,action:"synthesized_worker_json",reason:l.reconcileReason??"synthesized from artifacts"}),r;let c=Br(t),u=xu().some(d=>Br(nr.join(t,d)));if(c&&!u){let d={name:e.workerName,runId:e.run.id,status:"exited",branch:`agent/${e.run.id}/${e.workerName}`,worktreePath:nr.join(Z().worktreesDir,e.run.id,e.workerName),workerDir:t,stdoutPath:o.stdoutPath,stderrPath:o.stderrPath,heartbeatPath:o.heartbeatPath,startedAt:e.run.createdAt,reconciledAt:new Date().toISOString(),reconcileReason:"empty worker dir \u2014 marked abandoned during metadata reconcile"};return K(e.run.id,d),r.push({runId:e.run.id,worker:e.workerName,action:"marked_abandoned",reason:d.reconcileReason??"empty worker dir"}),r}return r.push({runId:e.run.id,worker:e.workerName,action:"skipped",reason:"worker.json missing and no recoverable artifacts"}),r}return wh(a,t)?(a.reconciledAt=new Date().toISOString(),a.reconcileReason=a.reconcileReason??"repaired nested runs/runs path fields",K(e.run.id,a),r.push({runId:e.run.id,worker:e.workerName,action:"repaired_worker_paths",reason:a.reconcileReason})):r.push({runId:e.run.id,worker:e.workerName,action:"skipped",reason:"worker metadata already canonical"}),r}function yE(e,r){let t=nr.join(x(e.id),"workers");if(!Br(t))return[];let n=new Set(Object.keys(e.workers||{})),o=[];for(let s of cE(t,{withFileTypes:!0}))s.isDirectory()&&(n.has(s.name)||o.push(s.name));return o}function aa(){let{harnessRoot:e}=Z(),r=sa(e),t=[];for(let n of X()){let o=pE(e,n.id);o&&t.push({runId:n.id,worker:"*",action:"materialized_run_symlink",reason:`replaced symlink with real run dir (was ${o})`}),hE(n,e)&&t.push({runId:n.id,worker:"*",action:"repaired_run_index",reason:"repaired nested runs/runs workerDir/statusPath entries in run.json"});let s=new Set(Object.keys(n.workers||{}));for(let i of yE(n,e))s.add(i),n.workers={...n.workers||{},[i]:{workerDir:Rr(e,n.id,i),statusPath:nr.join(Rr(e,n.id,i),"worker.json")}},Be(n),t.push({runId:n.id,worker:i,action:"repaired_run_index",reason:"indexed orphan worker dir into run.json"});for(let i of s){let a=n.workers?.[i];t.push(...kE({run:n,workerName:i,harnessRoot:e,statusPath:a?.statusPath}))}}return{workers:t,runMetadataRetention:r}}function RE(){let e=aa(),r=e.workers.reduce((n,o)=>(n[o.action]=(n[o.action]??0)+1,n),{}),t=e.runMetadataRetention.runs.reduce((n,o)=>(n[o.action]=(n[o.action]??0)+1,n),{});console.log(JSON.stringify({ok:!0,totals:r,runMetadataRetention:{totals:t,details:e.runMetadataRetention.runs},details:e.workers},null,2))}pr();Ws();z();T();zr();C();import{execFileSync as _h}from"node:child_process";import xh from"node:path";function Mu(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:null}function vE(e){let r=Mu(e)?.match(/\/pull\/(\d+)$/);if(!r)return null;let t=Number.parseInt(r[1],10);return Number.isFinite(t)?t:null}function bE(e){if(e==null)return"";if(typeof e=="string")return e;try{return JSON.stringify(e)}catch{return""}}function SE(e){let r=new Set;for(let t of e.matchAll(/github\.com\/[^/\s)>"']+\/[^/\s)>"']+\/(?:pull|pulls)\/(\d+)/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}for(let t of e.matchAll(/\bPR\s*#?\s*(\d{2,})\b/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}for(let t of e.matchAll(/\bpr[-_]?(\d{2,})\b/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}return[...r]}function CE(e){let r=null;if(typeof e=="string"?r=qt(e):e&&typeof e=="object"&&!Array.isArray(e)&&(r=e),!r)return[];let t=r.targetPrReconciliation??r.target_pr_reconciliation;if(!Array.isArray(t))return[];let n=[];for(let o of t){if(!o||typeof o!="object"||Array.isArray(o))continue;let s=o,i=Mu(String(s.prUrl??s.pr_url??"")),a=String(s.outcome??"").trim();!i||a!=="merged"||n.push({prUrl:i,mergeCommit:typeof s.mergeCommit=="string"?s.mergeCommit:typeof s.merge_commit=="string"?s.merge_commit:null,reason:typeof s.reason=="string"?s.reason:null})}return n}function wE(e){try{let n=_h("git",["config","--get","remote.origin.url"],{cwd:e.repoDir,encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().match(/github\.com[:/]([^/]+\/[^/.]+)(?:\.git)?$/i)?.[1];if(!n)return null;let o=_h("gh",["pr","view",String(e.prNumber),"--repo",n,"--json","state,mergedAt,mergeCommit,url"],{cwd:e.repoDir,encoding:"utf8",stdio:["ignore","pipe","ignore"]}),s=JSON.parse(o);return{prUrl:Mu(s.url??`https://github.com/${n}/pull/${e.prNumber}`)??`https://github.com/${n}/pull/${e.prNumber}`,state:s.state??"",mergedAt:s.mergedAt??null,mergeCommit:s.mergeCommit?.oid??null}}catch{return null}}function _E(e){let r=ce(e.heartbeatPath);return e.completionSnapshot?.finalResult??ze(r)}function xE(e){let r=new Map,t=x(e.id);for(let n of ke(e)){let o=w(xh.join(t,"workers",b(n),"worker.json"),void 0);if(o)for(let s of CE(_E(o))){let i=vE(s.prUrl);i!=null&&!r.has(i)&&r.set(i,s)}}return r}function EE(e,r){let t=ce(e.heartbeatPath),n=[e.name,e.repairTargetPrUrl,e.taskPrUrl,e.branch,t.lastHeartbeatSummary,bE(r)].filter(Boolean).join(`
|
|
41
|
-
`);return SE(n)}function PE(e){return e.localOnly===!0&&!e.taskId&&!e.agentOsId}function la(e={}){let r=e.lookupPr??wE,t=[],n=new Map;for(let o of X()){let s=xE(o),i=x(o.id);for(let a of ke(o)){let l=xh.join(i,"workers",b(a),"worker.json"),c=w(l,void 0);if(!c||!PE(c))continue;let u=D(c,{base:o.base,baseCommit:o.baseCommit});if(u.attention.state!=="needs_attention")continue;let d=null;for(let p of EE(c,u.finalResult)){if(d=s.get(p)??null,!d){let f=o.repo||c.worktreePath,h=`${f}#${p}`,k=n.has(h)?n.get(h)??null:r({repoDir:f,prNumber:p});n.has(h)||n.set(h,k),k&&(k.state==="MERGED"||k.mergedAt)&&(d={prUrl:k.prUrl,mergeCommit:k.mergeCommit??null,reason:"GitHub reports PR merged"})}if(d)break}if(!d){t.push({runId:o.id,worker:a,action:"skipped",reason:"no merged PR evidence"});continue}let m=new Date().toISOString();c.status="done",c.completionSnapshot={prUrl:d.prUrl,summary:`Local-only worker superseded by merged PR ${d.prUrl}`,finalResult:{summary:`Local-only repair/salvage worker superseded by merged PR ${d.prUrl}`,targetPrReconciliation:[{prUrl:d.prUrl,outcome:"merged",mergeCommit:d.mergeCommit??null,reason:d.reason??"PR already merged; local-only worker no longer requires attention"}]}},c.completionAckSource="local-pr-merged-reconcile",c.reconciledAt=m,c.reconcileReason="local-only needs_attention superseded by merged PR",K(o.id,c),t.push({runId:o.id,worker:a,action:"marked_done",reason:c.reconcileReason,prUrl:d.prUrl,mergeCommit:d.mergeCommit??null})}}return{workers:t}}var IE=900*1e3;function OE(){return process.env.KYNVER_NO_STALE_CLEANUP==="1"}function Eh(e,r){let t=uu({worker:e,status:r}),n=t?du(e,t):!1,o=r.attention.state==="blocked"?"blocked":r.attention.state==="done"||r.status==="done"||t?"done":"exited",s=t&&n?`captured exited-worker handoff (${t.source})`:t?"synced finished worker record after terminal stdout/heartbeat":r.attention.reason;return{nextStatus:o,reason:s,handoffCaptured:n}}function Sn(){let e=aa();if(OE()){let s=la(),i=ia();return{workers:[],finalizedRuns:Ho(),metadataReconcile:e,localPrAttentionReconcile:s,terminalWorkerArchive:i}}let r=[],t=Date.now();for(let s of X())for(let i of ke(s)){let a=AE.join(x(s.id),"workers",b(i),"worker.json"),l=w(a,void 0);if(!l||l.status!=="running"){r.push({runId:s.id,worker:i,action:"skipped",reason:l?`worker status is ${l.status}`:"worker.json missing"});continue}let c=D(l,{base:s.base,baseCommit:s.baseCommit});if(c.finalResult){if(l.status==="running"){let u=Eh(l,c);l.status=u.nextStatus,l.reconciledAt=new Date().toISOString(),l.reconcileReason=u.reason,K(s.id,l),r.push({runId:s.id,worker:i,action:"marked_exited",reason:l.reconcileReason})}else r.push({runId:s.id,worker:i,action:"skipped",reason:"final result present"});continue}if(!c.alive){let u=Eh(l,c);l.status=u.nextStatus,l.reconciledAt=new Date().toISOString(),l.reconcileReason=u.reason,K(s.id,l),r.push({runId:s.id,worker:i,action:"marked_exited",reason:c.attention.reason});continue}if(c.attention.state==="stale"&&l.pid&&H(l.pid)){let u=c.lastHeartbeatAt?Date.parse(c.lastHeartbeatAt):NaN,d=c.lastActivityAt?Date.parse(c.lastActivityAt):NaN,m=!Number.isFinite(u)||t-u>IE,p=Number.isFinite(d)&&t-d>Xt;if(m&&p){Er(l.pid,"SIGTERM"),l.status="exited",l.reconciledAt=new Date().toISOString(),l.reconcileReason=`reconciled stale worker: ${c.attention.reason}`,K(s.id,l),r.push({runId:s.id,worker:i,action:"killed_stale",reason:c.attention.reason});continue}}r.push({runId:s.id,worker:i,action:"skipped",reason:c.attention.reason})}let n=la(),o=ia();return{workers:r,finalizedRuns:Ho(),metadataReconcile:e,localPrAttentionReconcile:n,terminalWorkerArchive:o}}function Uu(){let e=Sn(),r=e.workers.filter(l=>l.action==="marked_exited").length,t=e.workers.filter(l=>l.action==="killed_stale").length,n=e.workers.filter(l=>l.action==="skipped").length,o=e.metadataReconcile.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),s=e.localPrAttentionReconcile.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),i=e.metadataReconcile.runMetadataRetention.runs.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),a=e.terminalWorkerArchive.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{});console.log(JSON.stringify({ok:!0,workers:{markedExited:r,killedStale:t,skipped:n,total:e.workers.length},metadataReconcile:{totals:o,total:e.metadataReconcile.workers.length,runMetadataRetention:{totals:i,total:e.metadataReconcile.runMetadataRetention.runs.length}},localPrAttentionReconcile:{totals:s,total:e.localPrAttentionReconcile.workers.length},terminalWorkerArchive:{totals:a,total:e.terminalWorkerArchive.workers.length},finalizedRuns:e.finalizedRuns.length,details:{workers:e.workers,metadataReconcile:e.metadataReconcile.workers,localPrAttentionReconcile:e.localPrAttentionReconcile.workers,terminalWorkerArchive:e.terminalWorkerArchive.workers,runMetadataRetention:e.metadataReconcile.runMetadataRetention.runs,finalizedRuns:e.finalizedRuns}},null,2))}z();C();function DE(e){if(!e||!NE(e))return 0;try{return TE(e,"utf8").trim().length}catch{return 0}}function ME(e,r){let t=Ph.join(x(e.id),"workers",b(r),"worker.json"),n=w(t,void 0);if(!n)return{worker:r,workerStatus:"missing",attention:"needs_attention",attentionReason:"worker.json missing",missingHeartbeat:!0,missingFinalResult:!0,landingBlocked:!1,completionBlocked:!1};let o=D(n,{base:e.base,baseCommit:e.baseCommit}),s=DE(n.heartbeatPath)===0,i=!o.finalResult&&!o.alive,a=typeof n.completionBlocker=="string"&&n.completionBlocker.length>0;return{worker:r,workerStatus:n.status,attention:o.attention.state,attentionReason:o.attention.reason,missingHeartbeat:s,missingFinalResult:i,landingBlocked:et(o),completionBlocked:a}}function UE(e){return e.openWorkerCount>0?"active_workers":e.workers.some(r=>r.completionBlocked)?"completion_blocked":e.workers.some(r=>r.landingBlocked)?"landing_blocked":null}function WE(e){let r={blocked:5,needs_attention:4,stale:3,done:2,ok:1},t="ok",n;for(let o of e){let s=o.attention;(r[s]??0)>=(r[t]??0)&&(t=s,n=o.attentionReason)}return{attention:t,attentionReason:n}}function LE(e){let r=0;for(let t of ke(e)){let n=Ph.join(x(e.id),"workers",b(t),"worker.json"),o=w(n,void 0);if(!o)continue;let s=D(o,{base:e.base,baseCommit:e.baseCommit});s.alive&&!s.finalResult&&(r+=1)}return r}function Cn(){return Sn(),X().map(e=>{let t=ke(e).map(d=>ME(e,d)),n=t.filter(d=>d.missingHeartbeat).map(d=>d.worker),o=t.filter(d=>d.missingFinalResult).map(d=>d.worker),s=t.filter(d=>d.landingBlocked).map(d=>d.worker),i=t.filter(d=>d.completionBlocked).map(d=>d.worker),{attention:a,attentionReason:l}=WE(t),c=LE(e),u=Qt(e.status,t.map(d=>({attention:d.attention,status:d.workerStatus})));return{id:e.id,name:e.name,status:e.status,effectiveStatus:u,repo:e.repo,createdAt:e.createdAt,openWorkerCount:c,attention:a,attentionReason:l,finalizeBlockedReason:UE({run:e,workers:t,openWorkerCount:c}),evidence:{missingHeartbeatWorkers:n,missingFinalResultWorkers:o,landingBlockedWorkers:s,completionBlockedWorkers:i,workers:t}}})}function Wu(){console.log(JSON.stringify(Cn(),null,2))}C();function KE(e){let r=typeof e.repo=="string"?e.repo.trim():"";if(r)return r;let t=je();return t?t.repo:(N("","--repo (or set defaultRepo via `kynver setup` / KYNVER_DEFAULT_REPO)"),"")}function Fo(e){let r=Fc(KE(e));bp(r);let t=e.id?Co(String(e.id)):mp(String(e.name||"run")),n=x(t);BE(n)&&$E(`run already exists: ${t}`),HE(n,{recursive:!0});let o=String(e.base||"origin/main"),s=me(r,["rev-parse",o]).trim(),i={id:t,name:String(e.name||t),repo:r,base:o,baseCommit:s,status:"created",createdAt:new Date().toISOString(),workers:{}};ae(FE.join(n,"run.json"),i);let a={runId:t,runDir:n,repo:r,base:o,baseCommit:s};return console.log(JSON.stringify(a,null,2)),a}function Lu(){Wu()}function $E(e){console.error(e),process.exit(1)}C();function Ah(e){let r=e.trim();return r?Cn().find(n=>n.name===r&&n.status!=="completed")??null:null}function Bu(e){let r=String(N(String(e.name||""),"--name")),t=Ah(r);console.log(JSON.stringify({runId:t?.id??null,name:r,status:t?.status??null,effectiveStatus:t?.effectiveStatus??null},null,2))}Zt();I();import jE from"node:path";T();z();C();async function wn(e){let r=e.pipeline===!0||e.pipeline==="true";try{let t=L(String(N(String(e.run||""),"--run"))),n=String(N(String(e.agentOsId||""),"--agent-os-id")),o=V(e.baseUrl?String(e.baseUrl):void 0),s=await J(e.secret?String(e.secret):void 0,n,{baseUrl:o}),i=er({runId:t.id}).runnerId,a=await vg({run:t.id,agentOsId:n,...e},"run_sweep"),l=[];for(let m of Object.keys(t.workers||{})){let p=w(jE.join(x(t.id),"workers",b(m),"worker.json"),void 0);if(!p||!p.dispatched||!p.taskId)continue;let f=D(p);if(f.alive||f.finalResult||p.completionReportedAt)continue;let h=yi({runId:t.id,workerLeaseOwner:p.leaseOwner??null,runnerId:i}),k=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/${encodeURIComponent(String(p.taskId))}/release`,g;try{g=await re(k,s,{agentOsId:n,leaseOwner:h},{agentOsId:n,baseUrl:o})}catch(R){g={ok:!1,error:R.message}}l.push({worker:m,taskId:p.taskId,pid:p.pid,released:g.ok===!0||g.response?.ok===!0,response:g.response??g})}let c=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/reap`,u;try{u=await re(c,s,{agentOsId:n,...Number(e.graceMs)>=0&&e.graceMs!==void 0&&e.graceMs!==!0?{graceMs:Math.floor(Number(e.graceMs))}:{}},{agentOsId:n,baseUrl:o})}catch(m){u={ok:!1,error:m.message}}let d={runId:t.id,agentOsId:n,snapshotPublished:a,releasedLocalOrphans:l,reap:u.response??u};if(r)return{ok:!0,...d};console.log(JSON.stringify(d,null,2))}catch(t){if(r)return{ok:!1,error:t.message};console.error(`run sweep failed: ${t.message}`),process.exit(1)}}I();Vn();Ce();Ce();import{existsSync as XE,readdirSync as Oh,statSync as QE}from"node:fs";import ZE from"node:path";import{execFileSync as VE}from"node:child_process";import{existsSync as Ih,readdirSync as GE,statSync as YE}from"node:fs";import JE from"node:path";var qE=2500;function zE(e,r=qE){if(!Ih(e))return 0;try{let n=VE("du",["-sb",e],{encoding:"utf8",timeout:r,stdio:["ignore","pipe","ignore"]}).trim().split(/\s+/)[0],o=Number(n);return Number.isFinite(o)&&o>=0?o:null}catch{return null}}function vr(e,r=5e4){if(!Ih(e))return 0;let t=zE(e);if(t!==null)return t;let n=0,o=0,s=[e];for(;s.length>0;){let i=s.pop(),a;try{a=GE(i)}catch{continue}for(let l of a){if(o++>r)return null;let c=JE.join(i,l),u;try{u=YE(c)}catch{continue}u.isDirectory()?s.push(c):n+=u.size}}return n}function Hu(e={}){let r=le(e.harnessRoot??fe()),t=dr(r),n=e.now??Date.now(),o=new Date(n).toISOString();if(!XE(t))return{harnessRoot:r,worktreesDir:t,worktreesBytes:0,runCount:0,workerCount:0,oldestRunAt:null,scannedAt:o};let s=0,i=0,a=0,l=null,c;try{c=Oh(t,{withFileTypes:!0})}catch{return{harnessRoot:r,worktreesDir:t,worktreesBytes:null,runCount:0,workerCount:0,oldestRunAt:null,scannedAt:o}}for(let u of c){if(!u.isDirectory())continue;i+=1;let d=ZE.join(t,u.name);try{let m=QE(d);l=l===null?m.mtimeMs:Math.min(l,m.mtimeMs)}catch{}try{for(let m of Oh(d,{withFileTypes:!0}))m.isDirectory()&&(a+=1)}catch{}if(s!==null&&e.perRunEntryCap!==null){let m=e.perRunEntryCap??5e4;if(m<=0)s=null;else{let p=vr(d,m);p===null?s=null:s+=p}}}return{harnessRoot:r,worktreesDir:t,worktreesBytes:s,runCount:i,workerCount:a,oldestRunAt:l===null?null:new Date(l).toISOString(),scannedAt:o}}Ce();import Ue from"node:path";eo();import pa from"node:path";Pe();z();var ca=[".next",".turbo","dist","build",".cache","node_modules/.cache"];function Fu(e){let r=e.replace(/\\/g,"/").replace(/\/+$/,"");if(r==="node_modules"||r.startsWith("node_modules/"))return!0;for(let t of ca)if(r===t||r.startsWith(`${t}/`))return!0;return!1}function Te(e){return e.filter(r=>{let t=r.trim(),n=t.startsWith("??")?t.slice(2).trim():t.length>3?t.slice(3).trim():t;return!Fu(n)})}function bt(e){if(typeof e=="string")return e.match(/https:\/\/github\.com\/[^\s]+\/pull\/\d+/i)?.[0]??null;if(e&&typeof e=="object"){let r=e;for(let t of["prUrl","pr_url","pullRequestUrl"]){let n=r[t];if(typeof n=="string"&&n.trim())return n.trim()}}return null}function Ko(e){let r=e.gitAncestry?.relation;return r==="merged"||r==="synced"?Te(e.changedFiles).length>0:!!(bt(e.finalResult)||r==="ahead"||r==="diverged"||e.changedFiles.length>0&&e.finalResult)}C();function $o(e){return e.status||(e.status=D(e.worker,{base:e.run.base,baseCommit:e.run.baseCommit})),e.status}function Ku(e,r){if(e.status)return Te(e.status.changedFiles).length>0;let t=r?r.porcelain(e.worktreePath):$n(e.worktreePath);return Te(t).length>0}function eP(e){let r=e.worker.completionSnapshot?.finalResult;return r??(e.worker.taskPrUrl?{prUrl:e.worker.taskPrUrl}:null)}function $u(e,r){if(e.status)return e.status;let t=e.worker,n=typeof t.completionReportedAt=="string"&&t.completionReportedAt.trim().length>0,o=!!(t.status&&["done","exited","blocked","failed","abandoned"].includes(t.status))||n,s=eP(e);if(o&&!H(t.pid)){let i=r?.gitStatusCache?r.gitStatusCache.porcelain(e.worktreePath):$n(e.worktreePath),a=e.run.baseCommit?.trim()||e.run.base?.trim()||"origin/main",c=r?.gitRevCache?.countAheadOfMain(e.worktreePath,a)===0?{checked:!0,base:a,relation:"synced"}:bs(e.worktreePath,{base:e.run.base,baseCommit:e.run.baseCommit}),u={runId:e.runId,worker:e.workerName,pid:t.pid,alive:!1,status:t.status??(n?"done":"exited"),attention:{state:n?"done":"stale"},branch:t.branch,worktreePath:e.worktreePath,ownedPaths:t.ownedPaths,stdoutBytes:0,stderrBytes:0,heartbeatBytes:0,firstEventAt:null,lastEventAt:null,lastActivityAt:t.completionReportedAt??null,currentTool:null,heartbeatCount:0,lastHeartbeatAt:null,lastHeartbeatPhase:null,lastHeartbeatSummary:null,heartbeatBlocker:null,changedFiles:i,gitAncestry:c,finalResult:s,completionBlocker:typeof t.completionBlocker=="string"&&t.completionBlocker.trim()||null,prUrl:t.repairTargetPrUrl??t.taskPrUrl??bt(s)};return e.status=u,u}return $o(e)}z();z();pr();C();function ju(e,r=Date.now(),t=bn){let n=ce(e.heartbeatPath);if(!n.lastHeartbeatAt)return!1;let o=r-Date.parse(n.lastHeartbeatAt);return Number.isFinite(o)&&o>=0&&o<t}function ua(e,r=Date.now(),t=bn){return H(e.pid)?!0:ju(e,r,t)}function rP(e,r){return r?r.runTerminalCache.derive(e.run):yt(e.run)}function br(e,r=Date.now()){return ua(e.worker,r)}function Vu(e,r){return yr.has(e.run.status)?!1:rP(e,r)!==null}function Nh(e,r,t=Date.now()){if(br(e,t))return!0;if(yr.has(e.run.status)||Vu(e,r))return!1;let n=$o(e);return oe(n)?!1:!!br(e,t)}eo();z();function Th(e,r){if(!(typeof e.worker.completionBlocker=="string"?e.worker.completionBlocker.trim():""))return!1;if(br(e))return!0;let n=r??$o(e);return!!(!oe(n)||Ko(n)||Te(n.changedFiles).length>0||Qr({finalResult:n.finalResult,changedFiles:n.changedFiles,gitAncestry:n.gitAncestry,prUrl:bt(n.finalResult)}).blocked)}Pe();C();import{existsSync as Mh,mkdirSync as tP,writeFileSync as Dh}from"node:fs";import da from"node:path";function Uh(e,r,t){return da.join(e,"salvage",b(r),b(t))}function Wh(e){return Mh(da.join(Uh(e.harnessRoot,e.runId,e.workerName),"evidence.json"))}function Lh(e){let r=Uh(e.harnessRoot,e.indexed.runId,e.indexed.workerName);tP(r,{recursive:!0});let t=da.join(r,"salvage.patch"),n=!1;if(Mh(e.indexed.worktreePath)){let s=ne(e.indexed.worktreePath,["diff","HEAD"]),i=ne(e.indexed.worktreePath,["diff","--cached"]),a=[s.stdout,i.stdout].filter(l=>l.trim()).join(`
|
|
42
|
-
`);a.trim()&&(
|
|
39
|
+
${r}`}function vh(e){let{provider:r,model:t,authSource:n,costTier:o,riskClass:s,costRationale:i,routingRule:a,escalatedFrom:l,escalatedReason:c}=e;return{provider:r,model:t,authSource:n,costTier:o,riskClass:s,costRationale:i,routingRule:a,escalatedFrom:l,escalatedReason:c}}function zx(e){return vh(e)}var wu=["off","observe","enforce"],Xx=["foreground_harness_spawn","shell_platform_dispatch"],Qx=["allow_local","observe_bypass","enforce_harness_task"];function Zx(e){let r=(e??"off").trim().toLowerCase();return wu.includes(r)?r:"off"}function ea(e=process.env){return Zx(e.KYNVER_ORCHESTRATION_POLICY_MODE)}function _u(e=process.env){let r=e.KYNVER_ORCHESTRATION_ENFORCE_TASKS?.trim().toLowerCase();return r?r==="1"||r==="true"||r==="yes"||r==="on":ea(e)==="enforce"}import{createHash as eE}from"node:crypto";function Ho(e){if(e==null)return null;let r=e.trim();return r.length?r:null}function xu(e){let r=Ho(e.sessionId)??"anonymous",t=Ho(e.title)??Ho(e.action)??"foreground",n=eE("sha256").update([Ho(e.planId)??"",Ho(e.parentTaskId)??"",t.toLowerCase()].join("|")).digest("hex").slice(0,16);return`hermes-foreground:${r}:${n}`}function rE(e,r){return e==="enforce"&&r?"enforce_harness_task":e==="observe"?"observe_bypass":"allow_local"}function tE(e,r=process.env){let t=ea(r),n=_u(r),o=rE(t,n),s=o==="enforce_harness_task"?xu({sessionId:e.sessionId,planId:e.planId,parentTaskId:e.parentTaskId,title:e.title,action:e.action}):null,i;return t==="off"?i="Orchestration policy off \u2014 local foreground path allowed.":o==="observe_bypass"?i=`Observe mode: ${e.action} bypass logged; local fallback preserved.`:o==="enforce_harness_task"?i=`Enforce mode: ${e.action} must create linked harness AgentTask (${s}).`:i="Local foreground path allowed.",{mode:t,decision:o,idempotencyKey:s,bypassLogged:o==="observe_bypass",reason:i}}function nE(e,r){let t=e;return r&&(t=t.split(r).join("[REDACTED_SECRET]")),t=t.replace(/kynver_[a-z0-9_]+/gi,"[REDACTED_KYNVER_TOKEN]"),t=t.replace(/sk-[a-zA-Z0-9_-]+/g,"[REDACTED_API_KEY]"),t}jr();import*as ra from"node:fs";import{homedir as Sh}from"node:os";import*as tr from"node:path";function Ch(e){return e.startsWith("~/")?tr.join(Sh(),e.slice(2)):e}function ta(e={}){let r=e.env??process.env,t=e.cwd??process.cwd(),n=e.homeDir??(r.HOME?.trim()||r.USERPROFILE?.trim()||Sh()),o=new Set,s=[],i=c=>{let u=tr.resolve(Ch(c));o.has(u)||(o.add(u),s.push(u))},a=r.KYNVER_ENV_FILE?.trim();a&&i(a);let l=t;for(let c=0;c<12;c+=1){i(tr.join(l,".env"));let u=tr.dirname(l);if(u===l)break;l=u}i(tr.join(n,".kynver",".env"));try{let c=tr.join(n,".kynver","config.json");if(ra.existsSync(c)){let d=JSON.parse(ra.readFileSync(c,"utf8")).defaultRepo?.trim();d&&i(tr.join(d,".env"))}}catch{}return s}import{execFileSync as oE,spawnSync as sE}from"node:child_process";import*as na from"node:fs";import*as wh from"node:path";function Fo(e){if(!e?.trim())return"(not set)";try{let r=new URL(e),t=(r.pathname||"").replace(/^\//,"").split("?")[0]||"(no database name)";return`${r.hostname} / ${t}`}catch{return"(invalid URL)"}}var Eu=["KYNVER_PRODUCTION_DATABASE_URL","PRODUCTION_DATABASE_URL"],Pu=[...Eu];function $e(e,r){return e[r]?.trim()||void 0}function _h(e){if(!na.existsSync(e))return{};let r={},t=new Set(Pu);for(let n of na.readFileSync(e,"utf8").split(`
|
|
40
|
+
`)){let o=n.match(/^\s*([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(.*)$/);if(!o||!t.has(o[1]))continue;let s=o[1];r[s]=o[2].replace(/^["']|["']$/g,"").trim()}return r}function iE(e){for(let r of Eu){let t=$e(e,r);if(t)return{ok:!0,databaseUrl:t,source:`env:${r}`,hint:Fo(t)}}return null}function aE(e,r){for(let t of ta({cwd:e,env:r})){let n=_h(t);for(let o of Pu){let s=n[o]?.trim();if(s)return{ok:!0,databaseUrl:s,source:`env-file:${o}`,hint:`${Fo(s)} (${wh.basename(t)})`}}}return null}function lE(e){let r=process.platform==="win32"?"neon.cmd":"neon",t=["connection-string",e.branch,"--prisma","-o","json","--no-color","--no-analytics"];e.projectId&&t.push("--project-id",e.projectId),e.databaseName&&t.push("--database-name",e.databaseName),e.roleName&&t.push("--role-name",e.roleName),e.pooled&&t.push("--pooled");let n;try{let o=sE(r,t,{encoding:"utf8",env:process.env,timeout:3e4});if(o.status!==0)return null;n=(o.stdout||"").trim()}catch{try{n=oE("neonctl",t,{encoding:"utf8",env:process.env,timeout:3e4}).trim()}catch{return null}}if(!n)return null;try{let o=JSON.parse(n),s=typeof o.connection_uri=="string"&&o.connection_uri||typeof o.connection_string=="string"&&o.connection_string||typeof o.connectionString=="string"&&o.connectionString;if(s)return s}catch{}return/^postgres(ql)?:\/\//i.test(n)?n:null}function cE(e,r){let t=$e(e,"KYNVER_NEON_BRANCH")||$e(e,"NEON_BRANCH")||"production",n=r({branch:t,projectId:$e(e,"KYNVER_NEON_PROJECT_ID")||$e(e,"NEON_PROJECT_ID"),databaseName:$e(e,"KYNVER_NEON_DATABASE_NAME")||$e(e,"NEON_DATABASE_NAME"),roleName:$e(e,"KYNVER_NEON_ROLE_NAME")||$e(e,"NEON_ROLE_NAME"),pooled:$e(e,"KYNVER_NEON_POOLED")==="1"||$e(e,"NEON_POOLED")==="1"});return n?{ok:!0,databaseUrl:n,source:"neon-cli",hint:Fo(n)}:null}function xh(e={}){let r=e.env??process.env,t=e.cwd??process.cwd(),n=e.neonConnectionString??lE,o=[],s=ta({cwd:t,env:r}),i=cE(r,n);if(o.push("neon-cli"),i)return i;for(let u of Eu)o.push(`env:${u}`);let a=iE(r);if(a)return a;for(let u of Pu)o.push(`env-file:${u}`);let l=aE(t,r);return l||{ok:!1,reason:"No production database credentials found. Authenticate Neon CLI (`neon auth`), set KYNVER_NEON_* / NEON_* project hints, or provide PRODUCTION_DATABASE_URL / KYNVER_PRODUCTION_DATABASE_URL (process env, KYNVER_ENV_FILE, ~/.kynver/.env, or selective .env keys in the repo / defaultRepo checkout)."+(s.length>0?` Searched env files: ${s.slice(0,6).join(", ")}${s.length>6?"\u2026":""}.`:""),attempted:o}}function uE(e={}){let r=xh(e);if(!r.ok)throw new Error(r.reason);return process.env.DATABASE_URL=r.databaseUrl,console.error(`[kynver-cli] database target: ${r.hint} (source: ${r.source})`),r}Pe();D();import{existsSync as rP,mkdirSync as tP}from"node:fs";import nP from"node:path";D();zr();import{existsSync as JE,readFileSync as qE}from"node:fs";import Lh from"node:path";import VE from"node:path";D();zr();z();C();import dE from"node:path";var pE=new Set(["running","dispatching","pending","queued","needs_attention"]),yr=new Set(["completed","failed","cancelled","done"]);function Rt(e){let r=ke(e);if(r.length===0)return"failed";let t=!1,n=!1,o=!1,s=!1;for(let i of r){let a=w(dE.join(P(e.id),"workers",v(i),"worker.json"),void 0);if(!a)continue;let l=M(a,{base:e.base,baseCommit:e.baseCommit});if(l.alive&&!l.finalResult){t=!0;break}typeof a.completionBlocker=="string"&&a.completionBlocker&&(o=!0),et(l)&&(s=!0),l.finalResult&&l.attention.state==="done"&&(n=!0)}return t||o||s?null:n?"completed":"failed"}function Ko(){let e=[];for(let r of X()){if(!pE.has(r.status))continue;let t=Rt(r);if(!t||t===r.status)continue;let n=r.status;r.status=t,Be(r),e.push({runId:r.id,from:n,to:t})}return e}D();zr();z();C();pr();qt();import{existsSync as Br,lstatSync as wE,readdirSync as _E,readlinkSync as xE,renameSync as Lu,unlinkSync as EE}from"node:fs";import nr from"node:path";Ce();C();import Re from"node:path";var mE=`${Re.sep}runs${Re.sep}runs${Re.sep}`;function Rn(e){return e.includes(mE)}function fE(e,r){if(!Rn(e))return e;let t=le(r),n=ge(t),o=`${Re.sep}runs${Re.sep}runs${Re.sep}`,s=e.indexOf(o);if(s<0)return e;let i=e.slice(s+o.length);return Re.join(n,i)}function Au(e,r){return Re.join(ge(le(e)),v(r))}function Rr(e,r,t){return Re.join(Au(e,r),"workers",v(t))}function Eh(e,r,t){let n=le(e);return Re.join(n,"runs","runs",v(r),"workers",v(t))}function Ou(){return["stdout.jsonl","stderr.log","heartbeat.jsonl","last-status.json","auto-complete.log","worker.json"]}function bt(e){return{workerJsonPath:Re.join(e,"worker.json"),stdoutPath:Re.join(e,"stdout.jsonl"),stderrPath:Re.join(e,"stderr.log"),heartbeatPath:Re.join(e,"heartbeat.jsonl"),lastStatusPath:Re.join(e,"last-status.json")}}function Iu(e){let r=bt(Rr(e.harnessRoot,e.runId,e.workerName)).workerJsonPath;return e.statusPath&&!Rn(e.statusPath)?e.statusPath:r}import{existsSync as Lr,mkdirSync as kE,readdirSync as Ih,renameSync as yE,statSync as Nu}from"node:fs";import te from"node:path";N();Gn();Je();import Ph from"node:path";function gE(e){return Ph.resolve(Ht(e.trim()))}function bn(e,r,t){let n=e?.trim();return n?{repo:gE(n),source:r,persistedInConfig:t}:null}function Ah(e){return e?{repo:e.repo,source:e.source,persistedInConfig:!1}:null}function je(e={}){let r=e.env??process.env,t=e.config??R(),n=bn(t.defaultRepo,"config",!0);if(n)return n;let o=bn(r.KYNVER_DEFAULT_REPO,"env_default_repo",!1);if(o)return o;let s=bn(r.KYNVER_HARNESS_REPO,"env_harness_repo",!1);return s||Ah(Gr({cwd:e.cwd,runtimeModuleUrl:e.runtimeModuleUrl}))}function oa(e={}){let r=e.env??process.env,t=e.config??R(),n=bn(t.defaultRepo,"config",!0);if(n)return n;let o=bn(r.KYNVER_DEFAULT_REPO,"env_default_repo",!1);if(o)return o;let s=bn(r.KYNVER_HARNESS_REPO,"env_harness_repo",!1);return s||Ah(Vn({cwd:e.cwd,runtimeModuleUrl:e.runtimeModuleUrl}))}function sa(e,r){let t={...r??R(),defaultRepo:Se(Ph.resolve(e))};return ue(t),t}function hE(e){let r=e?.config??R(),t=oa({...e,config:r});if(!t)return{ok:!1,reason:"No Kynver git checkout found. Clone the repo, cd into it, then run `kynver setup --repo /path/to/Kynver` (or export KYNVER_DEFAULT_REPO)."};if(t.persistedInConfig)return{ok:!0,resolved:t,config:r};let n=sa(t.repo,r);return{ok:!0,resolved:{...t,persistedInConfig:!0,source:"config"},config:n}}function vn(e){return{defaultRepo:q(e.repo),source:e.source,persistedInConfig:e.persistedInConfig}}pr();Ce();D();C();var Sn=900*1e3,Nh=3600*1e3;function Tu(e,r){let t=te.resolve(e),n=te.resolve(ge(r)),o=te.relative(n,t);return o!==".."&&!o.startsWith("..")&&!te.isAbsolute(o)}function Du(e){if(!Lr(e))return[];try{return Ih(e,{withFileTypes:!0}).filter(r=>r.isDirectory()&&r.name!=="runs").map(r=>r.name)}catch{return[]}}function Mu(e){let r=te.join(e,"workers");if(!Lr(r))return[];try{return Ih(r,{withFileTypes:!0}).filter(t=>t.isDirectory()).map(t=>t.name)}catch{return[]}}function Th(e){return te.join(e,"archived-workers")}function RE(e,r){let t=te.join(Th(e),v(r));return Lr(t)?`${t}-${Date.now()}`:t}function Oh(e,r,t){if(!Lr(e))return!1;try{let n=r-Nu(e).mtimeMs;return Number.isFinite(n)&&n>=0&&n<t}catch{return!1}}function Uu(e,r=Date.now(),t=Sn){if(!Lr(e))return!1;let n=bt(e),o=w(n.workerJsonPath,void 0);if(o?.status==="running"&&H(o.pid))return!0;let s=ce(n.heartbeatPath);if(s.lastHeartbeatAt){let i=r-Date.parse(s.lastHeartbeatAt);if(Number.isFinite(i)&&i>=0&&i<t)return!0}return!!(Oh(n.stdoutPath,r,t)||Oh(n.heartbeatPath,r,t))}function bE(e,r,t){let n=typeof r.completionReportedAt=="string"?Date.parse(r.completionReportedAt):NaN;if(Number.isFinite(n))return t-n;let o=(()=>{let s=r.completionResponse;if(!s||typeof s!="object")return NaN;let i=s.task;if(!i||typeof i!="object")return NaN;let a=i.updatedAt;return typeof a=="string"?Date.parse(a):NaN})();if(Number.isFinite(o))return t-o;try{return t-Nu(te.join(e,"worker.json")).mtimeMs}catch{return 0}}function vE(e,r,t,n){if(Uu(e,t))return{eligible:!1,reason:"worker has active/recent retention signals"};let o=typeof r.status=="string"?r.status:"";if(typeof r.completionBlocker=="string"&&r.completionBlocker.trim().length>0)return{eligible:!1,reason:"worker has completion blocker"};let i=typeof r.completionReportedAt=="string"||r.completionOutcome==="acknowledged";if(o!=="done"&&!i)return{eligible:!1,reason:`worker status is ${o||"unknown"}`};let a=bE(e,r,t);return!Number.isFinite(a)||a<n?{eligible:!1,reason:"terminal worker is still within archive grace window"}:{eligible:!0,reason:"terminal worker metadata archived"}}function vt(e,r=Date.now(),t=Sn){for(let n of Mu(e))if(Uu(te.join(e,"workers",n),r,t))return!0;return!1}function SE(){return{repo:je()?.repo??"",base:"origin/main",baseCommit:"unknown"}}function CE(e,r){let t=te.join(ge(e),v(r));if(!Lr(t))return null;let n=Mu(t);if(n.length===0)return null;let o;try{o=Nu(t).birthtime.toISOString()}catch{o=new Date().toISOString()}let s={};for(let a of n){let l=Rr(e,r,a);s[a]={workerDir:l,statusPath:te.join(l,"worker.json")}}let i=vt(t);return{id:r,name:r,...SE(),status:i?"running":"needs_attention",createdAt:o,workers:s}}function ia(e){let r=le(e??fe()),t=ge(r),n=[];for(let o of Du(t)){let s=te.join(t,o,"run.json");if(Lr(s)){n.push({runId:o,action:"skipped",reason:"run.json present"});continue}let i=CE(r,o);if(!i){n.push({runId:o,action:"skipped",reason:"no worker dirs on disk"});continue}Be(i),n.push({runId:o,action:"repaired_run_json",reason:vt(te.join(t,o))?"synthesized run.json while worker artifacts still active":"synthesized run.json from orphan worker metadata dirs"})}return{runs:n}}function aa(e,r={}){let t=le(e??fe()),n=ge(t),o=r.now??Date.now(),s=r.archiveAgeMs??Nh,i=[];ia(t);for(let a of Du(n)){let l=te.join(n,a),c=te.join(l,"run.json"),u=w(c,void 0);if(!u?.id)continue;let d=new Set([...Object.keys(u.workers||{}),...Mu(l)]),f=!1;for(let p of d){let m=te.join(l,"workers",v(p)),h=te.join(m,"worker.json"),k=w(h,void 0);if(!k){let _=te.join(Th(l),v(p));if(Lr(_)&&(u.workers[v(p)]||u.workers[p])){delete u.workers[v(p)],delete u.workers[p],f=!0,i.push({runId:u.id,worker:p,action:"archived",reason:"removed stale live index entry for archived worker metadata",archivePath:_});continue}i.push({runId:u.id,worker:p,action:"skipped",reason:"worker.json missing"});continue}let g=vE(m,k,o,s);if(!g.eligible){i.push({runId:u.id,worker:p,action:"skipped",reason:g.reason});continue}let y=RE(l,p);kE(te.dirname(y),{recursive:!0}),yE(m,y),delete u.workers[v(p)],delete u.workers[p],f=!0,i.push({runId:u.id,worker:p,action:"archived",reason:g.reason,archivePath:y})}f&&Be(u)}return{workers:i}}function Wu(e,r=Date.now()){let t=new Set,n=ge(e);for(let o of Du(n)){let s=te.join(n,o);vt(s,r)&&t.add(`${e}\0${o}`)}return t}D();C();function PE(e,r){let t=Au(e,r),n;try{n=wE(t)}catch{return null}if(!n.isSymbolicLink())return null;let o=nr.resolve(nr.dirname(t),xE(t));if(vt(o)||vt(t))return null;let s=`${t}.materialize-${Date.now()}`;return Lu(o,s),EE(t),Lu(s,t),o}function AE(e){let r=[];for(let t of Ou()){let n=nr.join(e.fromDir,t),o=nr.join(e.toDir,t);!Br(n)||Br(o)||(Lu(n,o),r.push(t))}return r}function Dh(e,r){let t=bt(r),n=!1;return e.workerDir!==r&&(e.workerDir=r,n=!0),e.stdoutPath!==t.stdoutPath&&(e.stdoutPath=t.stdoutPath,n=!0),e.stderrPath!==t.stderrPath&&(e.stderrPath=t.stderrPath,n=!0),e.heartbeatPath!==t.heartbeatPath&&(e.heartbeatPath=t.heartbeatPath,n=!0),n}function OE(e){let r=typeof e.lastStatus?.status=="string"?e.lastStatus.status:void 0,t=e.lastStatus?.attention&&typeof e.lastStatus.attention=="object"?e.lastStatus.attention.state:void 0;return r==="done"||t==="done"||e.stdoutFinalResult||e.heartbeatFinalResult?"done":r==="blocked"?"blocked":r==="running"?"exited":r??"exited"}function IE(e){let r=bt(e.canonicalDir),t=w(r.lastStatusPath,void 0),n=Br(r.stdoutPath),o=Br(r.heartbeatPath);if(!(n||o||t!=null))return null;let i=n?Ar(r.stdoutPath):{finalResult:null},a=o?ce(r.heartbeatPath):ce(""),l=ze(a),c=OE({lastStatus:t,stdoutFinalResult:i.finalResult,heartbeatFinalResult:l}),u={name:e.workerName,runId:e.run.id,status:c,branch:typeof t?.branch=="string"?t.branch:`agent/${e.run.id}/${e.workerName}`,worktreePath:typeof t?.worktreePath=="string"?t.worktreePath:nr.join(Z().worktreesDir,e.run.id,e.workerName),workerDir:e.canonicalDir,stdoutPath:r.stdoutPath,stderrPath:r.stderrPath,heartbeatPath:r.heartbeatPath,startedAt:typeof t?.startedAt=="string"?t.startedAt:e.run.createdAt,reconciledAt:new Date().toISOString(),reconcileReason:"synthesized worker.json from on-disk artifacts after metadata repair"};return typeof t?.taskId=="string"&&(u.taskId=t.taskId),typeof t?.agentOsId=="string"&&(u.agentOsId=t.agentOsId),typeof t?.planId=="string"&&(u.planId=t.planId),typeof t?.pid=="number"&&(u.pid=t.pid),(i.finalResult||l)&&(u.completionSnapshot={finalResult:i.finalResult??l??"completed",summary:a.lastHeartbeatSummary}),Dh(u,e.canonicalDir),u}function NE(e,r){let t=!1,n={...e.workers||{}};for(let[o,s]of Object.entries(n)){let i=Rr(r,e.id,o),a=nr.join(i,"worker.json");(Rn(s.workerDir)||Rn(s.statusPath)||s.workerDir!==i||s.statusPath!==a)&&(n[o]={workerDir:i,statusPath:a},t=!0)}return t&&(e.workers=n,Be(e)),t}function TE(e){let r=[],t=Rr(e.harnessRoot,e.run.id,e.workerName),n=Eh(e.harnessRoot,e.run.id,e.workerName),o=bt(t),s=AE({fromDir:n,toDir:t});s.length>0&&r.push({runId:e.run.id,worker:e.workerName,action:"relocated_artifacts",reason:`moved ${s.join(", ")} from nested runs/runs layout`});let i=Iu({harnessRoot:e.harnessRoot,runId:e.run.id,workerName:e.workerName,statusPath:e.statusPath}),a=w(i,void 0);if(!a&&Br(o.workerJsonPath)&&(a=w(o.workerJsonPath,void 0)),!a){let l=IE({run:e.run,workerName:e.workerName,canonicalDir:t,harnessRoot:e.harnessRoot});if(l)return K(e.run.id,l),r.push({runId:e.run.id,worker:e.workerName,action:"synthesized_worker_json",reason:l.reconcileReason??"synthesized from artifacts"}),r;let c=Br(t),u=Ou().some(d=>Br(nr.join(t,d)));if(c&&!u){let d={name:e.workerName,runId:e.run.id,status:"exited",branch:`agent/${e.run.id}/${e.workerName}`,worktreePath:nr.join(Z().worktreesDir,e.run.id,e.workerName),workerDir:t,stdoutPath:o.stdoutPath,stderrPath:o.stderrPath,heartbeatPath:o.heartbeatPath,startedAt:e.run.createdAt,reconciledAt:new Date().toISOString(),reconcileReason:"empty worker dir \u2014 marked abandoned during metadata reconcile"};return K(e.run.id,d),r.push({runId:e.run.id,worker:e.workerName,action:"marked_abandoned",reason:d.reconcileReason??"empty worker dir"}),r}return r.push({runId:e.run.id,worker:e.workerName,action:"skipped",reason:"worker.json missing and no recoverable artifacts"}),r}return Dh(a,t)?(a.reconciledAt=new Date().toISOString(),a.reconcileReason=a.reconcileReason??"repaired nested runs/runs path fields",K(e.run.id,a),r.push({runId:e.run.id,worker:e.workerName,action:"repaired_worker_paths",reason:a.reconcileReason})):r.push({runId:e.run.id,worker:e.workerName,action:"skipped",reason:"worker metadata already canonical"}),r}function DE(e,r){let t=nr.join(P(e.id),"workers");if(!Br(t))return[];let n=new Set(Object.keys(e.workers||{})),o=[];for(let s of _E(t,{withFileTypes:!0}))s.isDirectory()&&(n.has(s.name)||o.push(s.name));return o}function la(){let{harnessRoot:e}=Z(),r=ia(e),t=[];for(let n of X()){let o=PE(e,n.id);o&&t.push({runId:n.id,worker:"*",action:"materialized_run_symlink",reason:`replaced symlink with real run dir (was ${o})`}),NE(n,e)&&t.push({runId:n.id,worker:"*",action:"repaired_run_index",reason:"repaired nested runs/runs workerDir/statusPath entries in run.json"});let s=new Set(Object.keys(n.workers||{}));for(let i of DE(n,e))s.add(i),n.workers={...n.workers||{},[i]:{workerDir:Rr(e,n.id,i),statusPath:nr.join(Rr(e,n.id,i),"worker.json")}},Be(n),t.push({runId:n.id,worker:i,action:"repaired_run_index",reason:"indexed orphan worker dir into run.json"});for(let i of s){let a=n.workers?.[i];t.push(...TE({run:n,workerName:i,harnessRoot:e,statusPath:a?.statusPath}))}}return{workers:t,runMetadataRetention:r}}function ME(){let e=la(),r=e.workers.reduce((n,o)=>(n[o.action]=(n[o.action]??0)+1,n),{}),t=e.runMetadataRetention.runs.reduce((n,o)=>(n[o.action]=(n[o.action]??0)+1,n),{});console.log(JSON.stringify({ok:!0,totals:r,runMetadataRetention:{totals:t,details:e.runMetadataRetention.runs},details:e.workers},null,2))}pr();Bs();z();D();zr();C();import{execFileSync as Mh}from"node:child_process";import Uh from"node:path";function Bu(e){let r=e.trim().match(/github\.com\/([^/]+\/[^/]+)\/(?:pull|pulls)\/(\d+)/i);return r?`https://github.com/${r[1]}/pull/${r[2]}`:null}function UE(e){let r=Bu(e)?.match(/\/pull\/(\d+)$/);if(!r)return null;let t=Number.parseInt(r[1],10);return Number.isFinite(t)?t:null}function WE(e){if(e==null)return"";if(typeof e=="string")return e;try{return JSON.stringify(e)}catch{return""}}function LE(e){let r=new Set;for(let t of e.matchAll(/github\.com\/[^/\s)>"']+\/[^/\s)>"']+\/(?:pull|pulls)\/(\d+)/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}for(let t of e.matchAll(/\bPR\s*#?\s*(\d{2,})\b/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}for(let t of e.matchAll(/\bpr[-_]?(\d{2,})\b/gi)){let n=Number.parseInt(t[1],10);Number.isFinite(n)&&r.add(n)}return[...r]}function BE(e){let r=null;if(typeof e=="string"?r=zt(e):e&&typeof e=="object"&&!Array.isArray(e)&&(r=e),!r)return[];let t=r.targetPrReconciliation??r.target_pr_reconciliation;if(!Array.isArray(t))return[];let n=[];for(let o of t){if(!o||typeof o!="object"||Array.isArray(o))continue;let s=o,i=Bu(String(s.prUrl??s.pr_url??"")),a=String(s.outcome??"").trim();!i||a!=="merged"||n.push({prUrl:i,mergeCommit:typeof s.mergeCommit=="string"?s.mergeCommit:typeof s.merge_commit=="string"?s.merge_commit:null,reason:typeof s.reason=="string"?s.reason:null})}return n}function HE(e){try{let n=Mh("git",["config","--get","remote.origin.url"],{cwd:e.repoDir,encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().match(/github\.com[:/]([^/]+\/[^/.]+)(?:\.git)?$/i)?.[1];if(!n)return null;let o=Mh("gh",["pr","view",String(e.prNumber),"--repo",n,"--json","state,mergedAt,mergeCommit,url"],{cwd:e.repoDir,encoding:"utf8",stdio:["ignore","pipe","ignore"]}),s=JSON.parse(o);return{prUrl:Bu(s.url??`https://github.com/${n}/pull/${e.prNumber}`)??`https://github.com/${n}/pull/${e.prNumber}`,state:s.state??"",mergedAt:s.mergedAt??null,mergeCommit:s.mergeCommit?.oid??null}}catch{return null}}function FE(e){let r=ce(e.heartbeatPath);return e.completionSnapshot?.finalResult??ze(r)}function KE(e){let r=new Map,t=P(e.id);for(let n of ke(e)){let o=w(Uh.join(t,"workers",v(n),"worker.json"),void 0);if(o)for(let s of BE(FE(o))){let i=UE(s.prUrl);i!=null&&!r.has(i)&&r.set(i,s)}}return r}function $E(e,r){let t=ce(e.heartbeatPath),n=[e.name,e.repairTargetPrUrl,e.taskPrUrl,e.branch,t.lastHeartbeatSummary,WE(r)].filter(Boolean).join(`
|
|
41
|
+
`);return LE(n)}function jE(e){return e.localOnly===!0&&!e.taskId&&!e.agentOsId}function ca(e={}){let r=e.lookupPr??HE,t=[],n=new Map;for(let o of X()){let s=KE(o),i=P(o.id);for(let a of ke(o)){let l=Uh.join(i,"workers",v(a),"worker.json"),c=w(l,void 0);if(!c||!jE(c))continue;let u=M(c,{base:o.base,baseCommit:o.baseCommit});if(u.attention.state!=="needs_attention")continue;let d=null;for(let p of $E(c,u.finalResult)){if(d=s.get(p)??null,!d){let m=o.repo||c.worktreePath,h=`${m}#${p}`,k=n.has(h)?n.get(h)??null:r({repoDir:m,prNumber:p});n.has(h)||n.set(h,k),k&&(k.state==="MERGED"||k.mergedAt)&&(d={prUrl:k.prUrl,mergeCommit:k.mergeCommit??null,reason:"GitHub reports PR merged"})}if(d)break}if(!d){t.push({runId:o.id,worker:a,action:"skipped",reason:"no merged PR evidence"});continue}let f=new Date().toISOString();c.status="done",c.completionSnapshot={prUrl:d.prUrl,summary:`Local-only worker superseded by merged PR ${d.prUrl}`,finalResult:{summary:`Local-only repair/salvage worker superseded by merged PR ${d.prUrl}`,targetPrReconciliation:[{prUrl:d.prUrl,outcome:"merged",mergeCommit:d.mergeCommit??null,reason:d.reason??"PR already merged; local-only worker no longer requires attention"}]}},c.completionAckSource="local-pr-merged-reconcile",c.reconciledAt=f,c.reconcileReason="local-only needs_attention superseded by merged PR",K(o.id,c),t.push({runId:o.id,worker:a,action:"marked_done",reason:c.reconcileReason,prUrl:d.prUrl,mergeCommit:d.mergeCommit??null})}}return{workers:t}}var GE=900*1e3;function YE(){return process.env.KYNVER_NO_STALE_CLEANUP==="1"}function Wh(e,r){let t=fu({worker:e,status:r}),n=t?gu(e,t):!1,o=r.attention.state==="blocked"?"blocked":r.attention.state==="done"||r.status==="done"||t?"done":"exited",s=t&&n?`captured exited-worker handoff (${t.source})`:t?"synced finished worker record after terminal stdout/heartbeat":r.attention.reason;return{nextStatus:o,reason:s,handoffCaptured:n}}function Cn(){let e=la();if(YE()){let s=ca(),i=aa();return{workers:[],finalizedRuns:Ko(),metadataReconcile:e,localPrAttentionReconcile:s,terminalWorkerArchive:i}}let r=[],t=Date.now();for(let s of X())for(let i of ke(s)){let a=VE.join(P(s.id),"workers",v(i),"worker.json"),l=w(a,void 0);if(!l||l.status!=="running"){r.push({runId:s.id,worker:i,action:"skipped",reason:l?`worker status is ${l.status}`:"worker.json missing"});continue}let c=M(l,{base:s.base,baseCommit:s.baseCommit});if(c.finalResult){if(l.status==="running"){let u=Wh(l,c);l.status=u.nextStatus,l.reconciledAt=new Date().toISOString(),l.reconcileReason=u.reason,K(s.id,l),r.push({runId:s.id,worker:i,action:"marked_exited",reason:l.reconcileReason})}else r.push({runId:s.id,worker:i,action:"skipped",reason:"final result present"});continue}if(!c.alive){let u=Wh(l,c);l.status=u.nextStatus,l.reconciledAt=new Date().toISOString(),l.reconcileReason=u.reason,K(s.id,l),r.push({runId:s.id,worker:i,action:"marked_exited",reason:c.attention.reason});continue}if(c.attention.state==="stale"&&l.pid&&H(l.pid)){let u=c.lastHeartbeatAt?Date.parse(c.lastHeartbeatAt):NaN,d=c.lastActivityAt?Date.parse(c.lastActivityAt):NaN,f=!Number.isFinite(u)||t-u>GE,p=Number.isFinite(d)&&t-d>Qt;if(f&&p){Er(l.pid,"SIGTERM"),l.status="exited",l.reconciledAt=new Date().toISOString(),l.reconcileReason=`reconciled stale worker: ${c.attention.reason}`,K(s.id,l),r.push({runId:s.id,worker:i,action:"killed_stale",reason:c.attention.reason});continue}}r.push({runId:s.id,worker:i,action:"skipped",reason:c.attention.reason})}let n=ca(),o=aa();return{workers:r,finalizedRuns:Ko(),metadataReconcile:e,localPrAttentionReconcile:n,terminalWorkerArchive:o}}function Hu(){let e=Cn(),r=e.workers.filter(l=>l.action==="marked_exited").length,t=e.workers.filter(l=>l.action==="killed_stale").length,n=e.workers.filter(l=>l.action==="skipped").length,o=e.metadataReconcile.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),s=e.localPrAttentionReconcile.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),i=e.metadataReconcile.runMetadataRetention.runs.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{}),a=e.terminalWorkerArchive.workers.reduce((l,c)=>(l[c.action]=(l[c.action]??0)+1,l),{});console.log(JSON.stringify({ok:!0,workers:{markedExited:r,killedStale:t,skipped:n,total:e.workers.length},metadataReconcile:{totals:o,total:e.metadataReconcile.workers.length,runMetadataRetention:{totals:i,total:e.metadataReconcile.runMetadataRetention.runs.length}},localPrAttentionReconcile:{totals:s,total:e.localPrAttentionReconcile.workers.length},terminalWorkerArchive:{totals:a,total:e.terminalWorkerArchive.workers.length},finalizedRuns:e.finalizedRuns.length,details:{workers:e.workers,metadataReconcile:e.metadataReconcile.workers,localPrAttentionReconcile:e.localPrAttentionReconcile.workers,terminalWorkerArchive:e.terminalWorkerArchive.workers,runMetadataRetention:e.metadataReconcile.runMetadataRetention.runs,finalizedRuns:e.finalizedRuns}},null,2))}z();C();function zE(e){if(!e||!JE(e))return 0;try{return qE(e,"utf8").trim().length}catch{return 0}}function XE(e,r){let t=Lh.join(P(e.id),"workers",v(r),"worker.json"),n=w(t,void 0);if(!n)return{worker:r,workerStatus:"missing",attention:"needs_attention",attentionReason:"worker.json missing",missingHeartbeat:!0,missingFinalResult:!0,landingBlocked:!1,completionBlocked:!1};let o=M(n,{base:e.base,baseCommit:e.baseCommit}),s=zE(n.heartbeatPath)===0,i=!o.finalResult&&!o.alive,a=typeof n.completionBlocker=="string"&&n.completionBlocker.length>0;return{worker:r,workerStatus:n.status,attention:o.attention.state,attentionReason:o.attention.reason,missingHeartbeat:s,missingFinalResult:i,landingBlocked:et(o),completionBlocked:a}}function QE(e){return e.openWorkerCount>0?"active_workers":e.workers.some(r=>r.completionBlocked)?"completion_blocked":e.workers.some(r=>r.landingBlocked)?"landing_blocked":null}function ZE(e){let r={blocked:5,needs_attention:4,stale:3,done:2,ok:1},t="ok",n;for(let o of e){let s=o.attention;(r[s]??0)>=(r[t]??0)&&(t=s,n=o.attentionReason)}return{attention:t,attentionReason:n}}function eP(e){let r=0;for(let t of ke(e)){let n=Lh.join(P(e.id),"workers",v(t),"worker.json"),o=w(n,void 0);if(!o)continue;let s=M(o,{base:e.base,baseCommit:e.baseCommit});s.alive&&!s.finalResult&&(r+=1)}return r}function wn(){return Cn(),X().map(e=>{let t=ke(e).map(d=>XE(e,d)),n=t.filter(d=>d.missingHeartbeat).map(d=>d.worker),o=t.filter(d=>d.missingFinalResult).map(d=>d.worker),s=t.filter(d=>d.landingBlocked).map(d=>d.worker),i=t.filter(d=>d.completionBlocked).map(d=>d.worker),{attention:a,attentionReason:l}=ZE(t),c=eP(e),u=Zt(e.status,t.map(d=>({attention:d.attention,status:d.workerStatus})));return{id:e.id,name:e.name,status:e.status,effectiveStatus:u,repo:e.repo,createdAt:e.createdAt,openWorkerCount:c,attention:a,attentionReason:l,finalizeBlockedReason:QE({run:e,workers:t,openWorkerCount:c}),evidence:{missingHeartbeatWorkers:n,missingFinalResultWorkers:o,landingBlockedWorkers:s,completionBlockedWorkers:i,workers:t}}})}function Fu(){console.log(JSON.stringify(wn(),null,2))}C();function oP(e){let r=typeof e.repo=="string"?e.repo.trim():"";if(r)return r;let t=je();return t?t.repo:(T("","--repo (or set defaultRepo via `kynver setup` / KYNVER_DEFAULT_REPO)"),"")}function $o(e){let r=Vc(oP(e));_p(r);let t=e.id?_o(String(e.id)):kp(String(e.name||"run")),n=P(t);rP(n)&&sP(`run already exists: ${t}`),tP(n,{recursive:!0});let o=String(e.base||"origin/main"),s=me(r,["rev-parse",o]).trim(),i={id:t,name:String(e.name||t),repo:r,base:o,baseCommit:s,status:"created",createdAt:new Date().toISOString(),workers:{}};ae(nP.join(n,"run.json"),i);let a={runId:t,runDir:n,repo:r,base:o,baseCommit:s};return console.log(JSON.stringify(a,null,2)),a}function Ku(){Fu()}function sP(e){console.error(e),process.exit(1)}C();function Bh(e){let r=e.trim();return r?wn().find(n=>n.name===r&&n.status!=="completed")??null:null}function $u(e){let r=String(T(String(e.name||""),"--name")),t=Bh(r);console.log(JSON.stringify({runId:t?.id??null,name:r,status:t?.status??null,effectiveStatus:t?.effectiveStatus??null},null,2))}en();N();import iP from"node:path";D();z();C();async function _n(e){let r=e.pipeline===!0||e.pipeline==="true";try{let t=L(String(T(String(e.run||""),"--run"))),n=String(T(String(e.agentOsId||""),"--agent-os-id")),o=V(e.baseUrl?String(e.baseUrl):void 0),s=await J(e.secret?String(e.secret):void 0,n,{baseUrl:o}),i=er({runId:t.id}).runnerId,a=await Og({run:t.id,agentOsId:n,...e},"run_sweep"),l=[];for(let f of Object.keys(t.workers||{})){let p=w(iP.join(P(t.id),"workers",v(f),"worker.json"),void 0);if(!p||!p.dispatched||!p.taskId)continue;let m=M(p);if(m.alive||m.finalResult||p.completionReportedAt)continue;let h=bi({runId:t.id,workerLeaseOwner:p.leaseOwner??null,runnerId:i}),k=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/${encodeURIComponent(String(p.taskId))}/release`,g;try{g=await re(k,s,{agentOsId:n,leaseOwner:h},{agentOsId:n,baseUrl:o})}catch(y){g={ok:!1,error:y.message}}l.push({worker:f,taskId:p.taskId,pid:p.pid,released:g.ok===!0||g.response?.ok===!0,response:g.response??g})}let c=`${o}/api/agent-os/by-id/${encodeURIComponent(n)}/tasks/reap`,u;try{u=await re(c,s,{agentOsId:n,...Number(e.graceMs)>=0&&e.graceMs!==void 0&&e.graceMs!==!0?{graceMs:Math.floor(Number(e.graceMs))}:{}},{agentOsId:n,baseUrl:o})}catch(f){u={ok:!1,error:f.message}}let d={runId:t.id,agentOsId:n,snapshotPublished:a,releasedLocalOrphans:l,reap:u.response??u};if(r)return{ok:!0,...d};console.log(JSON.stringify(d,null,2))}catch(t){if(r)return{ok:!1,error:t.message};console.error(`run sweep failed: ${t.message}`),process.exit(1)}}N();Gn();Ce();Ce();import{existsSync as mP,readdirSync as Fh,statSync as fP}from"node:fs";import gP from"node:path";import{execFileSync as aP}from"node:child_process";import{existsSync as Hh,readdirSync as lP,statSync as cP}from"node:fs";import uP from"node:path";var dP=2500;function pP(e,r=dP){if(!Hh(e))return 0;try{let n=aP("du",["-sb",e],{encoding:"utf8",timeout:r,stdio:["ignore","pipe","ignore"]}).trim().split(/\s+/)[0],o=Number(n);return Number.isFinite(o)&&o>=0?o:null}catch{return null}}function br(e,r=5e4){if(!Hh(e))return 0;let t=pP(e);if(t!==null)return t;let n=0,o=0,s=[e];for(;s.length>0;){let i=s.pop(),a;try{a=lP(i)}catch{continue}for(let l of a){if(o++>r)return null;let c=uP.join(i,l),u;try{u=cP(c)}catch{continue}u.isDirectory()?s.push(c):n+=u.size}}return n}function ju(e={}){let r=le(e.harnessRoot??fe()),t=dr(r),n=e.now??Date.now(),o=new Date(n).toISOString();if(!mP(t))return{harnessRoot:r,worktreesDir:t,worktreesBytes:0,runCount:0,workerCount:0,oldestRunAt:null,scannedAt:o};let s=0,i=0,a=0,l=null,c;try{c=Fh(t,{withFileTypes:!0})}catch{return{harnessRoot:r,worktreesDir:t,worktreesBytes:null,runCount:0,workerCount:0,oldestRunAt:null,scannedAt:o}}for(let u of c){if(!u.isDirectory())continue;i+=1;let d=gP.join(t,u.name);try{let f=fP(d);l=l===null?f.mtimeMs:Math.min(l,f.mtimeMs)}catch{}try{for(let f of Fh(d,{withFileTypes:!0}))f.isDirectory()&&(a+=1)}catch{}if(s!==null&&e.perRunEntryCap!==null){let f=e.perRunEntryCap??5e4;if(f<=0)s=null;else{let p=br(d,f);p===null?s=null:s+=p}}}return{harnessRoot:r,worktreesDir:t,worktreesBytes:s,runCount:i,workerCount:a,oldestRunAt:l===null?null:new Date(l).toISOString(),scannedAt:o}}Ce();import Ue from"node:path";ro();import ma from"node:path";Pe();z();var ua=[".next",".turbo","dist","build",".cache","node_modules/.cache"];function Vu(e){let r=e.replace(/\\/g,"/").replace(/\/+$/,"");if(r==="node_modules"||r.startsWith("node_modules/"))return!0;for(let t of ua)if(r===t||r.startsWith(`${t}/`))return!0;return!1}function Te(e){return e.filter(r=>{let t=r.trim(),n=t.startsWith("??")?t.slice(2).trim():t.length>3?t.slice(3).trim():t;return!Vu(n)})}function St(e){if(typeof e=="string")return e.match(/https:\/\/github\.com\/[^\s]+\/pull\/\d+/i)?.[0]??null;if(e&&typeof e=="object"){let r=e;for(let t of["prUrl","pr_url","pullRequestUrl"]){let n=r[t];if(typeof n=="string"&&n.trim())return n.trim()}}return null}function jo(e){let r=e.gitAncestry?.relation;return r==="merged"||r==="synced"?Te(e.changedFiles).length>0:!!(St(e.finalResult)||r==="ahead"||r==="diverged"||e.changedFiles.length>0&&e.finalResult)}C();function Vo(e){return e.status||(e.status=M(e.worker,{base:e.run.base,baseCommit:e.run.baseCommit})),e.status}function Gu(e,r){if(e.status)return Te(e.status.changedFiles).length>0;let t=r?r.porcelain(e.worktreePath):jn(e.worktreePath);return Te(t).length>0}function hP(e){let r=e.worker.completionSnapshot?.finalResult;return r??(e.worker.taskPrUrl?{prUrl:e.worker.taskPrUrl}:null)}function Yu(e,r){if(e.status)return e.status;let t=e.worker,n=typeof t.completionReportedAt=="string"&&t.completionReportedAt.trim().length>0,o=!!(t.status&&["done","exited","blocked","failed","abandoned"].includes(t.status))||n,s=hP(e);if(o&&!H(t.pid)){let i=r?.gitStatusCache?r.gitStatusCache.porcelain(e.worktreePath):jn(e.worktreePath),a=e.run.baseCommit?.trim()||e.run.base?.trim()||"origin/main",c=r?.gitRevCache?.countAheadOfMain(e.worktreePath,a)===0?{checked:!0,base:a,relation:"synced"}:Cs(e.worktreePath,{base:e.run.base,baseCommit:e.run.baseCommit}),u={runId:e.runId,worker:e.workerName,pid:t.pid,alive:!1,status:t.status??(n?"done":"exited"),attention:{state:n?"done":"stale"},branch:t.branch,worktreePath:e.worktreePath,ownedPaths:t.ownedPaths,stdoutBytes:0,stderrBytes:0,heartbeatBytes:0,firstEventAt:null,lastEventAt:null,lastActivityAt:t.completionReportedAt??null,currentTool:null,heartbeatCount:0,lastHeartbeatAt:null,lastHeartbeatPhase:null,lastHeartbeatSummary:null,heartbeatBlocker:null,changedFiles:i,gitAncestry:c,finalResult:s,completionBlocker:typeof t.completionBlocker=="string"&&t.completionBlocker.trim()||null,prUrl:t.repairTargetPrUrl??t.taskPrUrl??St(s)};return e.status=u,u}return Vo(e)}z();z();pr();C();function Ju(e,r=Date.now(),t=Sn){let n=ce(e.heartbeatPath);if(!n.lastHeartbeatAt)return!1;let o=r-Date.parse(n.lastHeartbeatAt);return Number.isFinite(o)&&o>=0&&o<t}function da(e,r=Date.now(),t=Sn){return H(e.pid)?!0:Ju(e,r,t)}function kP(e,r){return r?r.runTerminalCache.derive(e.run):Rt(e.run)}function vr(e,r=Date.now()){return da(e.worker,r)}function qu(e,r){return yr.has(e.run.status)?!1:kP(e,r)!==null}function Kh(e,r,t=Date.now()){if(vr(e,t))return!0;if(yr.has(e.run.status)||qu(e,r))return!1;let n=Vo(e);return oe(n)?!1:!!vr(e,t)}ro();z();function $h(e,r){if(!(typeof e.worker.completionBlocker=="string"?e.worker.completionBlocker.trim():""))return!1;if(vr(e))return!0;let n=r??Vo(e);return!!(!oe(n)||jo(n)||Te(n.changedFiles).length>0||Qr({finalResult:n.finalResult,changedFiles:n.changedFiles,gitAncestry:n.gitAncestry,prUrl:St(n.finalResult)}).blocked)}Pe();C();import{existsSync as Vh,mkdirSync as yP,writeFileSync as jh}from"node:fs";import pa from"node:path";function Gh(e,r,t){return pa.join(e,"salvage",v(r),v(t))}function Yh(e){return Vh(pa.join(Gh(e.harnessRoot,e.runId,e.workerName),"evidence.json"))}function Jh(e){let r=Gh(e.harnessRoot,e.indexed.runId,e.indexed.workerName);yP(r,{recursive:!0});let t=pa.join(r,"salvage.patch"),n=!1;if(Vh(e.indexed.worktreePath)){let s=ne(e.indexed.worktreePath,["diff","HEAD"]),i=ne(e.indexed.worktreePath,["diff","--cached"]),a=[s.stdout,i.stdout].filter(l=>l.trim()).join(`
|
|
42
|
+
`);a.trim()&&(jh(t,a.endsWith(`
|
|
43
43
|
`)?a:`${a}
|
|
44
|
-
`),n=!0)}let o={capturedAt:new Date(e.now??Date.now()).toISOString(),skipReason:e.skipReason,runId:e.indexed.runId,workerName:e.indexed.workerName,worktreePath:e.indexed.worktreePath,taskId:e.indexed.worker.taskId,agentOsId:e.indexed.worker.agentOsId,branch:e.indexed.worker.branch,completionBlocker:e.indexed.worker.completionBlocker,finalResult:e.status.finalResult,changedFiles:e.status.changedFiles,gitAncestry:e.status.gitAncestry,prUrl:e.status.prUrl??null,...n?{patchPath:t}:{}};return
|
|
45
|
-
`),o}var nP=new Set(["completion_blocked","dirty_worktree","pr_or_unmerged_commits","landing_blocked"]);function oP(e){return!nP.has(e.skipReason)||br(e.indexed,e.now)?!1:Wh({harnessRoot:e.harnessRoot,runId:e.indexed.runId,workerName:e.indexed.workerName})?!0:e.writeSalvageEvidence?(Lh({harnessRoot:e.harnessRoot,indexed:e.indexed,skipReason:e.skipReason,status:e.status,now:e.now}),!0):!1}function sP(e){let{indexed:r,worktreesAgeMs:t,terminalWorktreesAgeMs:n}=e;return r&&(yr.has(r.run.status)||e.liveness&&Vu(r,e.liveness)||e.liveness&&oe($u(r,e.liveness))&&!br(r))?n:t}function iP(e){return!e.indexed||e.includeOrphans&&e.worktreesAgeMs<=0?0:sP(e)}function aP(e,r){if(e.harnessRoot?.trim())return pa.resolve(e.harnessRoot);let t=r.worker.workerDir;if(!t)return null;let n=`${pa.sep}runs${pa.sep}`,o=t.indexOf(n);return o<0?null:t.slice(0,o+n.length-1)}function Bh(e){let{indexed:r,includeOrphans:t,worktreesAgeMs:n,ageMs:o,orphanSafety:s,worktreeRemovalGuard:i}=e,a=e.now??Date.now();if(!r)return t?s??null:"orphan_without_flag";let l=iP(e);if(n<=0&&!t&&l<=0)return"worktrees_disabled";if(l>0&&o<l)return"below_age_threshold";if(br(r,a))return"active_worker";let c=$u(r,e.liveness),u=aP(e,r),d=f=>u&&oP({indexed:r,harnessRoot:u,skipReason:f,status:c,now:a,writeSalvageEvidence:e.writeSalvageEvidence===!0})?null:f;if(Th(r,c)){let f=d("completion_blocked");if(f)return f}if(Ku(r,e.liveness?.gitStatusCache)){let f=d("dirty_worktree");if(f)return f}let m=e.liveness?.gitRevCache?.countAheadOfMain(e.worktreePath);if(m!=null&&m>0){let f=d("pr_or_unmerged_commits");if(f)return f}if(Nh(r,e.liveness,a)||!oe(c))return"run_still_active";if(Ko(c)){let f=d("pr_or_unmerged_commits");if(f)return f}if(Te(c.changedFiles).length>0){let f=d("dirty_worktree");if(f)return f}if(Qr({finalResult:c.finalResult,changedFiles:c.changedFiles,gitAncestry:c.gitAncestry,prUrl:bt(c.finalResult)}).blocked){let f=d("landing_blocked");if(f)return f}if(i&&e.worktreePath){let f=i({worktreePath:e.worktreePath,indexed:!!r,runId:r?.runId,worker:r?.workerName});if(f)return f.detail?{reason:f.reason,detail:f.detail}:f.reason}return null}function Gu(e){let{indexed:r,nodeModulesAgeMs:t,ageMs:n,worktreePath:o,activeWorktreePaths:s,diskPressure:i}=e;return!i&&n<t?"below_age_threshold":s.has(pa.resolve(o))||r&&br(r)?"active_worker":r&&Ku(r,e.gitStatusCache)?"dirty_worktree":null}function Hh(e){return Gu(e)}var jo=216e5,Vo=6048e5,ma=216e5,fa=36e5,ga=120;var Fh=new Set(["active_worker","run_still_active","completion_blocked","landing_blocked"]);function Kh(e,r){let t=[],n=new Set,o=(s,i,a)=>{let l=`${s}\0${i}`;n.has(l)||t.length>=24||(n.add(l),t.push({path:s,reason:i,...a?{detail:a}:{}}))};for(let s of r)Fh.has(s.reason)&&o(s.path,s.reason,s.detail);for(let s of e)!s.skipped||!s.skipReason||Fh.has(s.skipReason)&&o(s.path,s.skipReason);return t}import{existsSync as Gh,readdirSync as Yh,statSync as uP}from"node:fs";import Jh from"node:path";T();Ce();import $h from"node:path";C();function cP(e,r){return ua(e,r)}function jh(e,r=Date.now()){let t=new Set,n=new Set;for(let o of e){for(let s of Is(o)){let i=!1;for(let a of Object.keys(s.workers||{})){let l=w($h.join(qn(o,s.id),"workers",b(a),"worker.json"),void 0);if(!l?.worktreePath)continue;let c=$h.resolve(l.worktreePath);cP(l,r)&&(i=!0,t.add(c))}i&&n.add(`${o}\0${s.id}`)}for(let s of Tu(o))n.add(s)}return{activeWorktreePaths:t,liveRunKeys:n}}function Vh(e,r,t,n){return t?n.has(`${r}\0${t}`):!1}C();function dP(e,r){try{let t=uP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function pP(e,r){let t=Jh.join(e,"runs",r,"run.json");return Gh(t)?w(t,null):null}function qh(e){try{return Yh(e).length===0}catch{return!1}}function zh(e){let{harnessRoot:r,runId:t,runPath:n,ageMs:o,runDirectoriesAgeMs:s,activeGuards:i}=e;if(Vh(n,r,t,i.liveRunKeys)||!qh(n))return"run_still_active";let a=pP(r,t);return a&&!yr.has(a.status)&&!yt(a)?"run_still_active":s>0&&o<s?"below_age_threshold":null}function Xh(e){if(!Gh(e.worktreesDir))return[];let r=[],t;try{t=Yh(e.worktreesDir,{withFileTypes:!0})}catch{return[]}for(let n of t){if(!n.isDirectory())continue;let o=n.name;if(e.runIdFilter&&o!==e.runIdFilter)continue;let s=Jh.join(e.worktreesDir,o);qh(s)&&r.push({kind:"remove_run_directory",path:s,bytes:null,harnessRoot:e.harnessRoot,runId:o,ageMs:dP(s,e.now)})}return r}Pe();import{existsSync as Ju,rmSync as ak}from"node:fs";import{existsSync as hP,rmSync as kP}from"node:fs";Ce();import{lstatSync as mP,readdirSync as fP}from"node:fs";function Qh(e){try{let r=mP(e),t=typeof process.getuid=="function"?process.getuid():null,n=typeof process.getgid=="function"?process.getgid():null,o=t!==null&&(r.uid!==t||n!==null&&r.gid!==n);return{uid:r.uid,gid:r.gid,foreign:o}}catch{return null}}function Zh(e,r=32){let t=Qh(e);if(!t)return!1;if(t.foreign)return!0;try{let n=fP(e),o=0;for(let s of n){if(o>=r)break;let i=`${e.replace(/\/$/,"")}/${s}`,a=Qh(i);if(o+=1,a?.foreign)return!0}}catch{}return!1}import{spawnSync as gP}from"node:child_process";import tk from"node:path";import De from"node:path";function ek(e,r,t,n){let o=De.resolve(e),s=`${De.sep}${n}`,i=o.endsWith(s)?o:null;if(!i)return"path_outside_harness";let a=De.relative(t,i);if(a.startsWith("..")||De.isAbsolute(a))return"path_outside_harness";let l=a.split(De.sep);return l.length<3||l[l.length-1]!==n||!o.startsWith(De.resolve(r))?"path_outside_harness":null}function ha(e,r,t){return ek(e,r,t,"node_modules")}function ka(e,r,t){return ek(e,r,t,".next")}function ya(e,r,t){let n=De.resolve(e),o=De.relative(t,n);return o.startsWith("..")||De.isAbsolute(o)||o.split(De.sep).length<3||!n.startsWith(De.resolve(r))?"path_outside_harness":null}function rk(e,r,t){let n=De.resolve(e);return ha(n,r,t)===null||ka(n,r,t)===null||ya(n,r,t)===null}function ok(){let e=(process.env.KYNVER_CLEANUP_PRIVILEGED??"auto").trim().toLowerCase();return e==="0"||e==="false"||e==="off"||e==="no"?"off":e==="1"||e==="true"||e==="force"||e==="yes"?"force":"auto"}function nk(e){let r=gP("sudo",["-n",...e],{encoding:"utf8",stdio:["ignore","pipe","pipe"]});return{ok:r.status===0,stderr:`${r.stderr??""}${r.stdout??""}`.trim()}}function sk(e,r,t){if(!rk(e,r,t))return{ok:!1,error:"path is not an allowed harness generated cache"};let n=typeof process.getuid=="function"?process.getuid():null,o=typeof process.getgid=="function"?process.getgid():null;if(n===null||o===null)return{ok:!1,error:"privileged reclaim requires POSIX uid/gid"};let s=nk(["chown","-R",`${n}:${o}`,tk.resolve(e)]);if(s.ok)return{ok:!0,method:"chown_then_rm"};let i=nk(["rm","-rf",tk.resolve(e)]);return i.ok?{ok:!0,method:"sudo_rm"}:{ok:!1,error:s.stderr||i.stderr||"sudo -n failed (password required or not permitted)"}}var Yu="Root-owned harness caches require operator reclaim: configure passwordless sudo for chown/rm under ~/.kynver/harness/worktrees, or run `node scripts/reclaim-harness-root-owned-cache.mjs --execute` as the harness owner with sudo available. See docs/runbooks/harness-root-owned-cache-reclaim.md.";function yP(e){let r=e?.code;return r==="EACCES"||r==="EPERM"}function ik(e,r,t={}){if(!hP(e.path))return{executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{executed:!1,skipped:!0,skipReason:"dry_run"};let n=e.harnessRoot,o=n?dr(n):null,i=e.bytes??vr(e.path)??void 0,a=t.removePath??kP,l=t.hasForeignOwnedEntry??Zh;try{return a(e.path,{recursive:!0,force:!0}),{executed:!0,skipped:!1,bytes:i}}catch(c){if(!yP(c)||!n||!o)return{executed:!1,skipped:!0,skipReason:"remove_failed",error:c.message};let u=l(e.path),d=ok();if(!(d==="force"||d==="auto"&&u))return u?{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${c.message}; ${Yu}`}:{executed:!1,skipped:!0,skipReason:"remove_failed",error:c.message};let p=sk(e.path,n,o);if(p.ok&&p.method==="sudo_rm")return{executed:!0,skipped:!1,bytes:i,privilegedReclaim:!0};if(p.ok)try{return a(e.path,{recursive:!0,force:!0}),{executed:!0,skipped:!1,bytes:i,privilegedReclaim:!0}}catch(f){return{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${f.message}; privileged chown succeeded but rm still failed`}}return{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${c.message}; privileged reclaim failed: ${p.error}; ${Yu}`}}}function qu(e){let r=e.harnessRoot;return!r||!Au(e.path,r)?null:{...e,executed:!1,skipped:!0,skipReason:"run_metadata_protected"}}function zu(e,r){let t=qu(e);if(t)return t;let n=ik(e,r);return{...e,bytes:n.bytes??e.bytes,executed:n.executed,skipped:n.skipped,skipReason:n.skipReason,error:n.error}}function lk(e,r){return zu(e,r)}function ck(e,r){return zu(e,r)}function uk(e,r){return zu(e,r)}function dk(e,r){let t=qu(e);if(t)return t;if(!Ju(e.path))return{...e,executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{...e,executed:!1,skipped:!0,skipReason:"dry_run"};try{let n=e.bytes??vr(e.path);return ak(e.path,{recursive:!0,force:!0}),{...e,bytes:n,executed:!0,skipped:!1}}catch(n){return{...e,executed:!1,skipped:!0,skipReason:"remove_failed",error:n.message}}}function pk(e,r){let t=qu(e);if(t)return t;if(!Ju(e.path))return{...e,executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{...e,executed:!1,skipped:!0,skipReason:"dry_run"};let n=e.repo;try{let o=e.bytes??vr(e.path);return n&&me(n,["worktree","remove","--force",e.path],{allowFailure:!0}),Ju(e.path)&&ak(e.path,{recursive:!0,force:!0}),{...e,bytes:o,executed:!0,skipped:!1}}catch(o){return{...e,executed:!1,skipped:!0,skipReason:"remove_failed",error:o.message}}}import{existsSync as Ra,readdirSync as va,statSync as RP}from"node:fs";import or from"node:path";function Xu(e,r){try{let t=RP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function fk(e,r){let t=or.relative(r,e);return t===""||!t.startsWith("..")&&!or.isAbsolute(t)}function mk(e,r,t,n){let o=[];for(let s of ca){if(s===".next")continue;let i=or.join(e,s);if(!Ra(i))continue;let a=or.resolve(i);t.has(a)||fk(a,r.harnessRoot)&&(t.add(a),o.push({kind:"remove_build_cache",path:a,bytes:null,runId:n.runId,worker:n.worker,repo:n.repo,ageMs:Xu(a,r.now)}))}return o}function gk(e){let r=[],t=new Set;for(let n of e.index.values())e.runIdFilter&&n.runId!==e.runIdFilter||r.push(...mk(n.worktreePath,e,t,{runId:n.runId,worker:n.workerName,repo:n.run.repo}));if(!e.includeOrphans||!Ra(e.worktreesDir))return r;for(let n of va(e.worktreesDir,{withFileTypes:!0})){if(!n.isDirectory())continue;let o=or.join(e.worktreesDir,n.name);for(let s of va(o,{withFileTypes:!0})){if(!s.isDirectory())continue;let i=or.join(o,s.name);r.push(...mk(i,e,t,{runId:n.name,worker:s.name}))}}return r}function hk(e){let r=e.worktreesAgeMs>0||e.includeOrphans,t=e.includeOrphans;if(!r&&!t)return[];let n=[],o=new Set;if(r)for(let i of e.index.values()){if(e.runIdFilter&&i.runId!==e.runIdFilter)continue;let a=i.worktreePath;Ra(a)&&(o.has(a)||(o.add(a),n.push({kind:"remove_worktree",path:a,bytes:null,runId:i.runId,worker:i.workerName,repo:i.run.repo,ageMs:Xu(a,e.now)})))}if(!t||!Ra(e.worktreesDir))return n;let s=new Set;for(let i of e.index.values())s.add(or.resolve(i.worktreePath));for(let i of va(e.worktreesDir,{withFileTypes:!0})){if(!i.isDirectory()||e.runIdFilter&&i.name!==e.runIdFilter)continue;let a=or.join(e.worktreesDir,i.name),l;try{l=va(a,{withFileTypes:!0})}catch{continue}for(let c of l){if(!c.isDirectory())continue;let u=or.resolve(or.join(a,c.name));o.has(u)||s.has(u)||fk(u,e.harnessRoot)&&(o.add(u),n.push({kind:"remove_worktree",path:u,bytes:null,runId:i.name,worker:c.name,ageMs:Xu(u,e.now)}))}}return n}import{existsSync as Rk,readdirSync as kk,statSync as vP}from"node:fs";import _n from"node:path";var bP=[{dirName:"node_modules",kind:"remove_node_modules"},{dirName:".next",kind:"remove_next_cache"}];function SP(e,r){try{let t=vP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function CP(e,r){let t=_n.relative(r,e);return t===""||!t.startsWith("..")&&!_n.isAbsolute(t)}function wP(e,r,t,n,o,s){if(!Rk(n))return;let i=_n.resolve(n);r.has(i)||CP(i,t.harnessRoot)&&(r.add(i),e.push({kind:o,path:i,bytes:null,harnessRoot:t.harnessRoot,runId:s.runId,worker:s.worker,repo:s.repo,ageMs:SP(i,t.now)}))}function yk(e,r,t,n,o){for(let s of bP)wP(e,r,t,_n.join(n,s.dirName),s.kind,o)}function vk(e){let r=[],t=new Set;for(let n of e.index.values())e.runIdFilter&&n.runId!==e.runIdFilter||yk(r,t,e,n.worktreePath,{runId:n.runId,worker:n.workerName,repo:n.run.repo});if(!e.includeOrphans||!Rk(e.worktreesDir))return r;for(let n of kk(e.worktreesDir,{withFileTypes:!0})){if(!n.isDirectory()||e.runIdFilter&&n.name!==e.runIdFilter)continue;let o=_n.join(e.worktreesDir,n.name),s;try{s=kk(o,{withFileTypes:!0})}catch{continue}for(let i of s){if(!i.isDirectory())continue;let a=_n.join(o,i.name);yk(r,t,e,a,{runId:n.name,worker:i.name})}}return r}Pe();import{existsSync as bk,statSync as _P}from"node:fs";import sr from"node:path";function xP(e,r){try{let t=_P(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function EP(e){let r=[],t=null;for(let n of e.split(`
|
|
46
|
-
`)){if(!n.trim())continue;let[o,...s]=n.split(" "),i=s.join(" ");if(o==="worktree"){t&&r.push(t),t={path:i};continue}t&&(o==="branch"&&(t.branch=i),o==="HEAD"&&(t.head=i),o==="bare"&&(t.bare=!0))}return t&&r.push(t),r}function
|
|
47
|
-
`).map(c=>c.trim()).filter(c=>c.length>0);if(Te(s).length>0)return"dirty_worktree";let i=ne(e.worktreePath,["rev-list","--count","@{u}..HEAD"]);if(i.status===0){let c=Number(i.stdout.trim());if(Number.isFinite(c)&&c>0)return"pr_or_unmerged_commits"}let a=ne(e.worktreePath,["rev-list","--count","origin/main..HEAD"]);if(a.status!==0)return i.status!==0?"pr_or_unmerged_commits":null;let l=Number(a.stdout.trim());return Number.isFinite(l)&&l>0?"pr_or_unmerged_commits":null}Ce();import{existsSync as
|
|
48
|
-
`).map(t=>t.trim()).filter(Boolean)}var Sa=class{cache=new Map;porcelain(r){let t=r,n=this.cache.get(t);if(n!==void 0)return n;let o=Ok(t)??[];return this.cache.set(t,o),o}};var Ca=class{cache=new Map;derive(r){let t=this.cache.get(r.id);if(t!==void 0)return t;let n=yt(r);return this.cache.set(r.id,n),n}};function KP(e){let r={};for(let t of e)r[t.kind]=(r[t.kind]??0)+1;return r}function Nk(e,r={}){let t=r.maxSampleActions??12,n=r.maxSampleSkips??8;return{harnessRoot:e.harnessRoot,scanRoots:e.scanRoots,dryRun:e.dryRun,execute:e.execute,scannedAt:e.scannedAt,finalizedRuns:e.finalizedRuns.length,actionCount:e.actions.length,actionKinds:KP(e.actions),totals:e.totals,...e.storage?{storage:e.storage}:{},...e.preservedLivePaths?.length?{preservedLivePaths:e.preservedLivePaths}:{},...e.removedRunDirectories!=null?{removedRunDirectories:e.removedRunDirectories}:{},sampleActions:e.actions.slice(0,t).map(o=>({kind:o.kind,path:o.path,...o.skipReason?{skipReason:o.skipReason}:{},...o.bytes!=null?{bytes:o.bytes}:{},...o.runId?{runId:o.runId}:{},...o.worker?{worker:o.worker}:{}})),sampleSkips:e.skips.slice(0,n)}}function $P(e={}){let r=e.harnessRoot?le(e.harnessRoot):fe(),t=Pk({harnessRoot:r}),n=e.now??Date.now();return{harnessRoot:r,scanRoots:t,now:n}}function jP(e){return typeof e=="string"?{reason:e}:e}function xn(e,r,t,n){e.push({path:r,reason:t,...n?{detail:n}:{}})}function wa(e,r,t){return!r||e.bytes!=null?e:{...e,bytes:vr(e.path,t)}}function Tk(e,r){let t={};for(let n of r)t[n.reason]=(t[n.reason]??0)+1;for(let n of e)n.skipReason&&(t[n.skipReason]=(t[n.skipReason]??0)+1);return t}function VP(e,r){return e.kind==="remove_next_cache"?ck(e,r):lk(e,r)}function GP(e,r,t){return e.kind==="remove_next_cache"?ka(e.path,r,t):ha(e.path,r,t)}function YP(e){let r=new Map;for(let t of e)for(let[n,o]of wk(t))r.set(n,o);return r}function Dk(e,r){return e.runId&&e.worker?Ue.join(r,e.runId,e.worker):Ue.resolve(e.path,"..")}function _a(e={}){let r=Qu(e),t=Ak();r=Ik(r,t);let n=$P(e);Me("scan",`${n.scanRoots.length} harness root(s)`);let o=jh(n.scanRoots,n.now),s=r.finalizeStaleRuns?Ho().map(P=>({runId:P.runId,from:P.from,to:P.to})):[];s.length>0&&Me("finalize",`${s.length} stale run(s) marked terminal`),Me("index","building worktree index");let i=YP(n.scanRoots);Me("index",`${i.size} indexed worktree(s)`);let a={runTerminalCache:new Ca,gitStatusCache:new Sa,gitRevCache:new ba},l=[],c=[],u=new Set,d=r.maxActionsPerSweep,m=()=>c.length>=d;for(let P of n.scanRoots){if(m())break;Me("root",P);let B=Ue.join(P,"worktrees"),Kr=Ck(i,P),Q={harnessRoot:P,worktreesDir:B,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,runIdFilter:r.runIdFilter,index:Kr,now:n.now},Cr=r.scanDependencyCaches?vk(Q):[];Me("dependency",r.scanDependencyCaches?`${Cr.length} cache candidate(s) at ${P}`:"skipped (worktree-only sweep)");let Tt=0;for(let ve of Cr){if(m())break;Tt+=1,Tt%50===0&&Me("dependency",`${Tt}/${Cr.length} evaluated`);let G=Ue.resolve(ve.path);if(u.has(G))continue;u.add(G);let W={...ve,path:G},be=GP(W,P,B);if(be){xn(l,W.path,be),c.push({...W,executed:!1,skipped:!0,skipReason:be});continue}let xe=Dk(W,B),wr=Kr.get(Ue.resolve(xe))??null,Ee=Gu({indexed:wr,includeOrphans:!0,nodeModulesAgeMs:r.nodeModulesAgeMs,ageMs:W.ageMs,worktreePath:xe,activeWorktreePaths:o.activeWorktreePaths,diskPressure:r.diskPressure,gitStatusCache:a.gitStatusCache});if(Ee){xn(l,W.path,Ee),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(VP(wa(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}if(r.scanDependencyCaches)for(let ve of gk(Q)){if(m())break;let G=Ue.resolve(ve.path);if(u.has(G))continue;u.add(G);let W={...ve,path:G},be=ya(W.path,P,B);if(be){xn(l,W.path,be),c.push({...W,executed:!1,skipped:!0,skipReason:be});continue}let xe=Dk(W,B),wr=Kr.get(Ue.resolve(xe))??null,Ee=Hh({indexed:wr,includeOrphans:!0,nodeModulesAgeMs:r.nodeModulesAgeMs,ageMs:W.ageMs,worktreePath:xe,activeWorktreePaths:o.activeWorktreePaths,diskPressure:r.diskPressure,gitStatusCache:a.gitStatusCache});if(Ee){xn(l,W.path,Ee),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(uk(wa(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}let Ve=[...hk(Q),...Sk(Q)];Me("worktrees",`${Ve.length} candidate(s) at ${P}`);let Dt=new Set,Ge=0;for(let ve of Ve){if(m())break;Ge+=1,Ge%50===0&&Me("worktrees",`${Ge}/${Ve.length} evaluated`);let G=Ue.resolve(ve.path);if(Dt.has(G))continue;Dt.add(G);let W={...ve,path:G},be=Kr.get(Ue.resolve(W.path))??null,xe=be?null:ed({worktreePath:W.path,harnessRoot:P,runId:W.runId,workerName:W.worker,now:n.now}),wr=Bh({indexed:be,worktreePath:Ue.resolve(W.path),includeOrphans:r.includeOrphans,worktreesAgeMs:r.worktreesAgeMs,terminalWorktreesAgeMs:r.terminalWorktreesAgeMs,ageMs:W.ageMs,orphanSafety:xe,worktreeRemovalGuard:e.worktreeRemovalGuard,liveness:a,now:n.now,harnessRoot:P,writeSalvageEvidence:r.execute});if(wr){let{reason:Ee,detail:ps}=jP(wr);xn(l,W.path,Ee,ps),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(pk(wa(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}if(!m()&&r.runDirectoriesAgeMs>=0)for(let ve of Xh({harnessRoot:P,worktreesDir:B,runDirectoriesAgeMs:r.runDirectoriesAgeMs,runIdFilter:r.runIdFilter,activeGuards:o,now:n.now})){if(m())break;let G=Ue.resolve(ve.path);if(u.has(G))continue;u.add(G);let W={...ve,path:G},be=W.runId??Ue.basename(G),xe=zh({harnessRoot:P,runId:be,runPath:G,ageMs:W.ageMs,runDirectoriesAgeMs:r.runDirectoriesAgeMs,activeGuards:o});if(xe){xn(l,W.path,xe),c.push({...W,executed:!1,skipped:!0,skipReason:xe});continue}c.push(dk(wa(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}}let p=0,f=0,h=0,k=0,g=0,R=0;for(let P of c)P.bytes&&(p+=P.bytes),!P.skipped&&!P.executed&&P.bytes&&(h+=P.bytes),P.executed?(g+=1,k+=P.bytes??0,P.kind==="remove_run_directory"&&(f+=1)):P.skipped&&(R+=1,P.skipReason==="dry_run"&&P.bytes&&(h+=P.bytes));let O=r.accountBytes?Hu({harnessRoot:n.harnessRoot,now:n.now,perRunEntryCap:r.storagePerRunEntryCap}):void 0,_=ur(),E=r.execute&&cu(_),U=E?Do({execute:!0}):null,Y=_?{observed:!0,execute:E,dumpCount:_.dumpCount,totalBytes:_.totalBytes,removedCount:U?.removed.length??0,removedBytes:U?.removedBytes??0,executables:_.executables,path:_.path,reason:_.reason}:void 0;U&&U.removed.length>0&&(k+=U.removedBytes,g+=U.removed.length,Me("wsl-crashes",`removed ${U.removed.length} dump(s), ${U.removedBytes} bytes`)),Me("complete",`${c.length} action(s), ${R} skipped, ${g} removed`);let $=Kh(c,l),F=Nk({harnessRoot:n.harnessRoot,scanRoots:n.scanRoots,dryRun:!r.execute,execute:r.execute,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,diskPressure:r.diskPressure,diskGate:r.diskGate?{ok:r.diskGate.ok,path:r.diskGate.path,freeBytes:r.diskGate.freeBytes,usedPercent:r.diskGate.usedPercent,reason:r.diskGate.reason}:void 0,scannedAt:new Date(n.now).toISOString(),finalizedRuns:s,actions:c,skips:l,totals:{candidateBytes:p,reclaimableBytes:h,removedBytes:k,removedPaths:g,skippedPaths:R,skipReasons:Tk(c,l)},...O?{storage:O}:{},...$.length>0?{preservedLivePaths:$}:{},...f>0?{removedRunDirectories:f}:{},...Y?{wslCrashDumps:Y}:{}});return{harnessRoot:n.harnessRoot,scanRoots:n.scanRoots,dryRun:!r.execute,execute:r.execute,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,diskPressure:r.diskPressure,diskGate:r.diskGate?{ok:r.diskGate.ok,path:r.diskGate.path,freeBytes:r.diskGate.freeBytes,usedPercent:r.diskGate.usedPercent,reason:r.diskGate.reason}:void 0,scannedAt:new Date(n.now).toISOString(),finalizedRuns:s,actions:c,skips:l,totals:{candidateBytes:p,reclaimableBytes:h,removedBytes:k,removedPaths:g,skippedPaths:R,skipReasons:Tk(c,l)},...O?{storage:O}:{},...$.length>0?{preservedLivePaths:$}:{},...f>0?{removedRunDirectories:f}:{},...Y?{wslCrashDumps:Y}:{},compactSummary:F}}function td(e){let r=_k(e);return _a({execute:r.execute,finalizeStaleRuns:r.finalizeStaleRuns,accountBytes:r.accountBytes,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,runIdFilter:r.runIdFilter})}function nd(){return process.env.KYNVER_PIPELINE_CLEANUP!=="0"}I();import{mkdirSync as vv,realpathSync as bv}from"node:fs";import{fileURLToPath as nT}from"node:url";I();C();Xl();import JP from"node:os";function qP(e){let r=(typeof e.apiBaseUrl=="string"?e.apiBaseUrl:void 0)||(typeof e.baseUrl=="string"?e.baseUrl:void 0)||process.env.KYNVER_API_URL||y().apiBaseUrl;return r?ar(String(r)):void 0}async function zP(e,r){let t=await fetch(`${e}/api/agent-os`,{headers:{Authorization:`Bearer ${r}`}});if(!t.ok)return null;let n=await t.json().catch(()=>null);if(!n?.primarySlug)return null;let o=n.items?.find(s=>s.slug===n.primarySlug);return o?.id&&o.slug?{id:o.id,slug:o.slug}:{id:"",slug:n.primarySlug}}async function xa(e){let r=qP(e);r||(console.error("kynver bootstrap requires a Kynver URL \u2014 pass --api-base-url https://your-kynver-site or set KYNVER_API_URL."),process.exit(1)),se()||(typeof e.apiKey=="string"?uo(e.apiKey):(await zl({...e,apiBaseUrl:r})).ok||process.exit(1));let t=se();t||(console.error("No API key after login \u2014 aborting."),process.exit(1));let n=await zP(r,t);n||(console.error("Could not resolve your AgentOS workspace from the account. Confirm this account has AgentOS access, then retry."),process.exit(1));let o={...e,apiBaseUrl:r,agentOsSlug:n.slug,...n.id?{agentOsId:n.id}:{},...typeof e.repo=="string"?{}:{discoverRepo:!0}};await ti(o),console.log(""),console.log(` Bootstrap complete \u2014 ${JP.hostname()} is linked to workspace "${n.slug}".`),console.log(" Next: `kynver start` \u2014 brings the agent online with Kynver-owned keeper supervision + local Kynver Cron when needed."),console.log(" Persistent background (Linux): `kynver start --install-systemd` or `kynver cron install --install-systemd`."),console.log(" (Advanced: `kynver run create --repo /path/to/repo` + `kynver daemon --run <RUN_ID> --agent-os-id <AOS_ID> --execute`.)")}I();import CO from"node:os";I();Je();I();import XP from"node:path";import{homedir as QP}from"node:os";var od=XP.join(QP(),".kynver","config.json");function Jo(e){let r=y(),t=na({...e,config:r});if(!t)return{ok:!1,remediated:!1,alreadyPersisted:!1,configPath:q(od),resolved:null,reason:"No Kynver git checkout found. Clone the repo, cd into it, then run `kynver setup --repo /path/to/Kynver` (or export KYNVER_DEFAULT_REPO).",remediation:"Clone the Kynver monorepo, cd into it, then run `kynver config ensure-default-repo` (or `kynver setup --repo /path/to/Kynver`)."};if(t.persistedInConfig)return{ok:!0,remediated:!1,alreadyPersisted:!0,configPath:q(od),resolved:vn(t),config:an(r)};let n=oa(t.repo,r),o=vn({...t,persistedInConfig:!0,source:"config"});return{ok:!0,remediated:!0,alreadyPersisted:!1,configPath:q(od),resolved:o,config:an(n),remediation:"defaultRepo persisted in ~/.kynver/config.json \u2014 `kynver run create` no longer requires --repo."}}function Mk(e=!1){let r=Jo();if(e){console.log(JSON.stringify(r,null,2)),r.ok||(process.exitCode=1);return}if(!r.ok){console.error(r.reason??"Could not resolve a Kynver git checkout."),r.remediation&&console.error(r.remediation),process.exitCode=1;return}if(r.alreadyPersisted){console.log(`defaultRepo already set (${r.resolved?.defaultRepo??"unknown"}) in ${r.configPath}`);return}console.log(`Persisted defaultRepo ${r.resolved?.defaultRepo??""} in ${r.configPath}. \`kynver run create\` can omit --repo.`)}function Uk(e){return e?e.persistedInConfig?{status:"pass"}:{status:"warn",remediation:"Run `kynver config ensure-default-repo` to persist defaultRepo in ~/.kynver/config.json (or `kynver doctor runtime-takeover --remediate-default-repo`)."}:{status:"warn",remediation:"Run `kynver config ensure-default-repo` from a Kynver checkout (or `kynver setup --repo /path/to/Kynver`)."}}I();Oe();Jn();Ks();import ZP from"node:os";function Wk(e,r){console.error(JSON.stringify({event:"daemon_identity",level:e,message:r}))}function Lk(e=y(),r=process.env){let t=Ae(r,e),n=Fs({config:e,totalMemBytes:ZP.totalmem(),env:r}),o=[...t.warnings],s=[];if(!e.boxKind?.trim()&&!r.KYNVER_BOX_KIND?.trim()&&o.push("boxKind is not persisted in ~/.kynver/config.json \u2014 run `kynver setup --box-kind forge|ghost` so Command Center attributes snapshots to the correct pool"),t.slugInferenceBlocked){let c=r.KYNVER_DAEMON_STRICT_IDENTITY==="1"||r.KYNVER_DAEMON_STRICT_IDENTITY==="true",u="ambiguous box identity: KYNVER_AGENT_OS_SLUG is set without KYNVER_BOX_KIND or config.boxKind; treating this host as forge";c?s.push(u):o.push(u)}let i=n.configuredMaxWorkers??n.autoCap,a=cr(t.boxKind,i);Kt(t.boxKind,i)&&o.push(`Forge box maxConcurrentWorkers=${i} exceeds pool cap \u2014 using ${a}; run kynver setup --box-kind forge --max-workers 4`);let l=s.length===0;for(let c of o)Wk("warn",c);for(let c of s)Wk("error",c);return{ok:l,box:t,workerCapSource:n.workerCapSource,maxConcurrentWorkers:a,autoCap:n.autoCap,warnings:o,errors:s}}import{mkdirSync as eA,readFileSync as rA,renameSync as tA,writeFileSync as nA}from"node:fs";import{homedir as oA}from"node:os";import Bk from"node:path";function Hk(e){let r=e.replace(/[^A-Za-z0-9_-]/g,"_");return Bk.join(oA(),".kynver",`daemon-heartbeat-${r}.json`)}function Fk(e){try{let r=Hk(e.agentOsId);eA(Bk.dirname(r),{recursive:!0});let t={observedAt:(e.now??new Date).toISOString(),pid:process.pid,runId:e.runId,agentOsId:e.agentOsId,...e.instructionBundleVersion?{instructionBundleVersion:e.instructionBundleVersion}:{}},n=`${r}.tmp-${process.pid}`;nA(n,JSON.stringify(t),"utf8"),tA(n,r)}catch{}}function Kk(e){try{let r=rA(Hk(e),"utf8"),t=JSON.parse(r);return typeof t?.observedAt!="string"?null:t}catch{return null}}function $k(e,r,t=Date.now()){if(!e)return!1;let n=Date.parse(e.observedAt);return Number.isNaN(n)?!0:t-n>r}function sA(e){let r=process.env[e]?.trim().toLowerCase();return r==="1"||r==="true"||r==="yes"||r==="on"}function En(){process.platform==="win32"&&(sA("KYNVER_DAEMON_ALLOW_NATIVE_WINDOWS")||(console.error(JSON.stringify({event:"daemon_start_blocked",reason:"native_windows_console_flash",remedy:"Run the daemon inside WSL: .\\scripts\\start-tier2-wsl.ps1 \u2014 or set KYNVER_DAEMON_ALLOW_NATIVE_WINDOWS=1 to override (flashes visible consoles)."})),process.exit(1)))}I();import{existsSync as iA}from"node:fs";import{homedir as aA}from"node:os";import lA from"node:path";function jk(e,r){let t=process.env[e]?.trim().toLowerCase();return t?t==="0"||t==="false"||t==="no"||t==="off"?!1:t==="1"||t==="true"||t==="yes"||t==="on"?!0:r:r}function qo(e,r,t=1){let n=Number(process.env[e]);return!Number.isFinite(n)||n<t?r:Math.floor(n)}function Hr(){let e=process.env.KYNVER_CRON_STORE_PATH?.trim()||process.env.OPENCLAW_CRON_STORE_PATH?.trim();return e||lA.join(aA(),".kynver","agent-os-cron.json")}function cA(e=Hr()){let r=process.env.KYNVER_CRON_TICK_STATE_PATH?.trim();return r||`${e.replace(/\.json$/i,"")}.tick-state.json`}function uA(){let e=y();return process.env.KYNVER_API_URL?.trim()||e.apiBaseUrl?.trim()||process.env.KYNVER_CRON_FIRE_BASE_URL?.trim()||process.env.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null}function sd(){return process.env.KYNVER_CRON_SECRET?.trim()||process.env.OPENCLAW_CRON_SECRET?.trim()||process.env.KYNVER_RUNTIME_SECRET?.trim()||null}function Sr(){let e=Hr(),r=cA(e),t=uA(),n=sd(),o=!!(t&&n),s=iA(e),i=o&&(s||jk("KYNVER_CRON_TICK_FORCE",!1));return{storePath:e,statePath:r,lockPath:`${r}.lock`,fireBaseUrl:t,secret:n,tickEnabled:jk("KYNVER_CRON_TICK_ENABLED",i),tickIntervalMs:qo("KYNVER_CRON_TICK_INTERVAL_MS",6e4,5e3),missedRunPolicy:process.env.KYNVER_CRON_MISSED_RUN_POLICY?.trim().toLowerCase()==="skip"?"skip":"catch_up",maxCatchUpPerTick:qo("KYNVER_CRON_MAX_CATCH_UP_PER_TICK",3,0),maxRetries:qo("KYNVER_CRON_MAX_RETRIES",3,0),retryBackoffMs:qo("KYNVER_CRON_RETRY_BACKOFF_MS",6e4,1e3),inflightLeaseMs:qo("KYNVER_CRON_INFLIGHT_LEASE_MS",12e4,5e3)}}function Ea(e=Sr()){return e.tickEnabled&&!!(e.fireBaseUrl&&e.secret)}function dA(e){return e.replace(/\/+$/,"")}async function Vk(e){let r=e.fetchFn??fetch,t=e.entry.spec.callbackPath.startsWith("/")?e.entry.spec.callbackPath:`/${e.entry.spec.callbackPath}`,n=`${dA(e.baseUrl)}${t}`,s={source:"kynver-cron",jobId:e.jobId??e.entry.spec.dedupeKey??null,agentOsId:e.entry.spec.target.agentOsId,kind:e.entry.spec.kind,target:e.entry.spec.target,...e.entry.spec.payload!==void 0&&{payload:e.entry.spec.payload}},i=await r(n,{method:"POST",headers:He(e.secret),body:JSON.stringify(s)}),a=null;try{a=await i.json()}catch{a=null}return{ok:i.ok,status:i.status,body:a}}C();import{closeSync as pA,existsSync as id,openSync as mA,readFileSync as fA,unlinkSync as Gk,writeFileSync as gA}from"node:fs";var hA=10*6e4;function Yk(e){if(!id(e))return null;try{let r=JSON.parse(fA(e,"utf8"));if(typeof r.pid=="number"&&typeof r.at=="string")return r}catch{return null}return null}function kA(e){let r=Yk(e);if(!r||!H(r.pid))return!0;let t=Date.parse(r.at);return Number.isNaN(t)?!0:Date.now()-t>hA}function Jk(e){if(id(e)&&!kA(e)){let r=Yk(e);return{acquired:!1,reason:r?`held by pid ${r.pid}`:"held by another process"}}if(id(e))try{Gk(e)}catch{}try{let r=mA(e,"wx");return gA(r,JSON.stringify({pid:process.pid,at:new Date().toISOString()}),"utf8"),pA(r),{acquired:!0}}catch(r){if(r.code==="EEXIST")return{acquired:!1,reason:"concurrent acquire"};throw r}}function qk(e){try{Gk(e)}catch{}}var yA=/^[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+$/;function RA(e){return yA.test(e.trim())}function vA(e,r,t){let n=new Set;for(let o of e.split(",")){let s=o.trim();if(!s)continue;if(s==="*"){for(let d=r;d<=t;d++)n.add(d);continue}let i=/^(.+)\/(\d+)$/.exec(s),a=i?i[1]:s,l=i?Math.max(1,Number(i[2])):1;if(a==="*"){for(let d=r;d<=t;d+=l)n.add(d);continue}let c=/^(\d+)-(\d+)$/.exec(a);if(c){let d=Math.max(r,Number(c[1])),m=Math.min(t,Number(c[2]));for(let p=d;p<=m;p+=l)n.add(p);continue}let u=Number(a);Number.isInteger(u)&&u>=r&&u<=t&&n.add(u)}return n}function zo(e,r,t,n){let o=e.trim();return o==="*"?!0:vA(o,t,n).has(r)}function bA(e,r){let t=e.trim().split(/\s+/);if(t.length!==5)return!1;let[n,o,s,i,a]=t;return zo(n,r.getUTCMinutes(),0,59)&&zo(o,r.getUTCHours(),0,23)&&zo(s,r.getUTCDate(),1,31)&&zo(i,r.getUTCMonth()+1,1,12)&&zo(a,r.getUTCDay(),0,6)}var SA=366*24*60;function CA(e){return new Date(Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),e.getUTCHours(),e.getUTCMinutes(),0,0))}function zk(e,r){if(!RA(e))return null;let t=CA(r);t=new Date(t.getTime()+6e4);for(let n=0;n<SA;n++){if(bA(e,t))return t;t=new Date(t.getTime()+6e4)}return null}function Xk(e,r){if(e.scheduleKind==="runAt"&&e.runAt){let t=Date.parse(e.runAt);return Number.isNaN(t)?null:new Date(t).toISOString()}if(e.scheduleKind==="cron"&&e.cron){let t=zk(e.cron.trim(),r);return t?t.toISOString():null}return null}function ad(e,r){if(e.scheduleKind!=="cron"||!e.cron?.trim())return null;let t=zk(e.cron.trim(),r);return t?t.toISOString():null}import{promises as wA}from"node:fs";async function Qk(e){try{return await wA.readFile(e,"utf8")}catch(r){if(r.code==="ENOENT")return null;throw r}}function _A(e){if(!e)return[];try{let r=JSON.parse(e);return Array.isArray(r.entries)?r.entries:[]}catch{return[]}}async function Ct(e=Hr()){let r=await Qk(e);return _A(r)}async function Zk(e,r){let{mkdir:t,writeFile:n,rename:o}=await import("node:fs/promises"),{randomBytes:s}=await import("node:crypto"),{dirname:i}=await import("node:path");await t(i(e),{recursive:!0});let a=`${e}.${s(4).toString("hex")}.tmp`,l=JSON.stringify({entries:r},null,2);await n(a,l,"utf8"),await o(a,e)}async function ey(e,r=Hr()){let t=await Ct(r),n=t.findIndex(o=>o.providerScheduleId===e.providerScheduleId);n>=0?t[n]=e:t.push(e),await Zk(r,t)}async function ry(e=Hr()){return await Qk(e)!==null?{created:!1}:(await Zk(e,[]),{created:!0})}import{randomBytes as xA}from"node:crypto";import{promises as Xo}from"node:fs";import EA from"node:path";var Pa={version:1,jobs:{}};async function PA(e){try{return await Xo.readFile(e,"utf8")}catch(r){if(r.code==="ENOENT")return null;throw r}}function AA(e){if(!e)return{...Pa,jobs:{...Pa.jobs}};try{let r=JSON.parse(e);return r?.version!==1||typeof r.jobs!="object"||!r.jobs?{...Pa,jobs:{}}:r}catch{return{...Pa,jobs:{}}}}async function Aa(e){let r=await PA(e);return AA(r)}async function IA(e,r){await Xo.mkdir(EA.dirname(e),{recursive:!0});let t=xA(6).toString("hex"),n=`${e}.tmp-${process.pid}-${Date.now()}-${t}`;await Xo.writeFile(n,`${JSON.stringify(r,null,2)}
|
|
49
|
-
`,"utf8");try{await
|
|
50
|
-
${e.stderr}`.toLowerCase();return r.includes("api rate limit exceeded")||r.includes("rate limit exceeded")||r.includes("secondary rate limit")}function
|
|
51
|
-
`)){let i=s.match(
|
|
52
|
-
`))!==-1;){let a=n.slice(0,i).trim();if(n=n.slice(i+1),!a.startsWith("data:"))continue;let l=a.slice(5).trim();if(!(!l||l==="[DONE]"))try{yield JSON.parse(l)}catch{}}}}finally{r.releaseLock()}}function
|
|
53
|
-
`)||n.includes("\0"))return{ok:!1,mutating:!1,reason:"control characters refused"}}let r=e[0],t=e.length>1&&!e[1].startsWith("--")?`${r} ${e[1]}`:r;return t==="doctor runtime-takeover"?e.includes("--remediate-default-repo")?{ok:!0,mutating:!0}:{ok:!0,mutating:!1}:r==="cleanup"?{ok:!0,mutating:e.includes("--execute")}:MI.has(t)?{ok:!0,mutating:!1}:UI.has(t)?{ok:!0,mutating:!0}:{ok:!1,mutating:!1,reason:`verb not allowlisted: ${t}`}}var BI=10*6e4,HI=5e3,Wy=2e5;async function Ly(e,r,t={}){let n=Uy(e);if(!n.ok)return{exitCode:null,timedOut:!1,refused:n.reason};let o=t.cliEntry??process.argv[1],s=t.timeoutMs??BI,i=new On(r);return new Promise(a=>{let l=0,c=!1,u=LI(process.execPath,[o,...e],{stdio:["ignore","pipe","pipe"],env:process.env}),d=p=>{if(l>=Wy)return;let f=p.toString("utf8").slice(0,Wy-l);l+=f.length,i.push(f)};u.stdout?.on("data",d),u.stderr?.on("data",d);let m=setTimeout(()=>{c=!0,u.kill("SIGTERM"),setTimeout(()=>u.kill("SIGKILL"),HI).unref()},s);u.on("error",p=>{clearTimeout(m),i.push(`spawn failed: ${p.message}`),i.close(),a({exitCode:null,timedOut:!1,refused:void 0})}),u.on("close",p=>{clearTimeout(m),i.close(),a({exitCode:p,timedOut:c})})})}var KI=25e3,$I=32e3,jI=5e3,VI=6e4,By=5*6e4,GI=5e3,YI="claude-sonnet-4-6";async function JI(e,r,t){let n=t.KYNVER_RUNTIME_CHAT_BRIDGE_URL?.trim();if(n)return n;if(!e)return null;let o=new AbortController,s=setTimeout(()=>o.abort(),GI);try{let i=await fetch(`${e.replace(/\/$/,"")}/api/runtime/chat-bridge`,{headers:{Authorization:`Bearer ${r}`},signal:o.signal});if(!i.ok)return null;let a=await i.json().catch(()=>null);return typeof a?.bridgeUrl=="string"&&a.bridgeUrl.trim()?a.bridgeUrl.trim():null}catch{return null}finally{clearTimeout(s)}}async function Hy(e=process.env){let r=y(),t=r.agentOsId?.trim(),n=se();if(!t||!n)return null;let o=await JI(r.apiBaseUrl,n,e);return o?{bridgeUrl:o.replace(/\/$/,""),agentOsId:t,apiKey:n,boxId:FI.hostname(),model:e.KYNVER_CHAT_MODEL?.trim()||r.defaultModel?.trim()||YI,useClaudeOauth:r.chatUseClaudeOauth===!0}:null}async function qI(e,r){let t=new AbortController,n=setTimeout(()=>t.abort(),$I),o=setInterval(()=>{r()&&t.abort()},500);try{let s=await fetch(`${e.bridgeUrl}/runtime-chat/claim`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e.apiKey}`},body:JSON.stringify({agentOsId:e.agentOsId,boxId:e.boxId,waitMs:KI}),signal:t.signal});if(s.status===204)return null;if(s.status===401||s.status===403)return"auth_error";if(!s.ok)throw new Error(`claim failed: HTTP ${s.status}`);return(await s.json().catch(()=>null))?.turn??null}catch(s){if(r())return null;throw s}finally{clearTimeout(n),clearInterval(o)}}async function wt(e,r,t){return(await fetch(`${e.bridgeUrl}/runtime-chat/turns/${encodeURIComponent(r)}/events`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e.apiKey}`},body:JSON.stringify({agentOsId:e.agentOsId,events:t})})).ok}async function zI(e,r){let t=0,n=Array.isArray(r.payload?.argv)?r.payload.argv:[],o=await Ly(n,s=>{wt(e,r.turnId,[{seq:t++,kind:"delta",text:s}])});o.refused?await wt(e,r.turnId,[{seq:t++,kind:"error",error:`command_refused: ${o.refused}`}]).catch(()=>{}):await wt(e,r.turnId,[{seq:t++,kind:"final",message:{exitCode:o.exitCode,timedOut:o.timedOut}}]).catch(()=>{}),console.error(JSON.stringify({event:"command_turn_done",turnId:r.turnId,argv:n.slice(0,4),exitCode:o.exitCode,timedOut:o.timedOut,refused:o.refused??null}))}async function XI(e,r){let t=0,n=!1,o=new AbortController,s=l=>{n||wt(e,r.turnId,[{seq:t++,kind:"delta",text:l}]).then(c=>{c||(n=!0,o.abort())})},i=new On(s),a=Dy(process.env,{oauthOptIn:e.useClaudeOauth});if(!a){await wt(e,r.turnId,[{seq:0,kind:"error",error:"no_local_credentials"}]).catch(()=>{});return}try{let l=await My({creds:a,model:e.model,payload:r.payload,onDelta:c=>i.push(c),signal:o.signal});i.close(),n||await wt(e,r.turnId,[{seq:t++,kind:"final",message:l}]),console.error(JSON.stringify({event:"chat_turn_done",turnId:r.turnId,model:e.model}))}catch(l){i.close(),n||await wt(e,r.turnId,[{seq:t++,kind:"error",error:l instanceof Error?l.message:String(l)}]).catch(()=>{}),console.error(JSON.stringify({event:"chat_turn_error",turnId:r.turnId,error:l instanceof Error?l.message:String(l)}))}}async function hd(e,r){for(let n=0;n<e&&!r();n+=500)await new Promise(o=>setTimeout(o,Math.min(500,e-n)))}async function Fy(e){let r=await Hy();for(r||console.error(JSON.stringify({event:"chat_claim_loop_waiting",reason:!se()||!y().agentOsId?.trim()?"machine_not_linked":"bridge_not_discovered (rollout off, discovery route missing/404, or API unreachable)",rediscoverMs:By}));!r&&!e.shouldStop();){if(!se()||!y().agentOsId?.trim()||(await hd(By,e.shouldStop),e.shouldStop()))return;r=await Hy()}if(!(!r||e.shouldStop())){for(console.error(JSON.stringify({event:"chat_claim_loop_start",bridgeUrl:r.bridgeUrl,agentOsId:r.agentOsId,boxId:r.boxId,model:r.model,useClaudeOauth:r.useClaudeOauth}));!e.shouldStop();)try{let t=await qI(r,e.shouldStop);if(t==="auth_error"){console.error(JSON.stringify({event:"chat_claim_auth_error"})),await hd(VI,e.shouldStop);continue}t&&(t.payload?.kind==="command"?await zI(r,t):await XI(r,t))}catch(t){console.error(JSON.stringify({event:"chat_claim_error",error:t instanceof Error?t.message:String(t)})),await hd(jI,e.shouldStop)}console.error(JSON.stringify({event:"chat_claim_loop_stop"}))}}var QI=6e4,ZI=5*6e4,eO=10,rO=250;async function kd(e,r){let t=e;for(;t>0&&!r();){let n=Math.min(rO,t);await xr(n),t-=n}}async function es(e){En();let r=String(N(String(e.run||""),"--run")),t=String(N(String(e.agentOsId||y().agentOsId||""),"--agent-os-id")),n=e.execute!==!1&&e.execute!=="false",o=Number(e.intervalMs)>0?Math.floor(Number(e.intervalMs)):QI,s=!1,i=0;process.on("SIGINT",()=>{s=!0}),process.on("SIGTERM",()=>{s=!0});let a=Jo();a.remediated&&console.error(JSON.stringify({event:"daemon_default_repo_remediated",defaultRepo:a.resolved?.defaultRepo??null,configPath:a.configPath}));let l=Lk(y());l.ok||(console.error(JSON.stringify({event:"daemon_start_blocked",runId:r,agentOsId:t,errors:l.errors})),process.exit(1)),console.error(JSON.stringify({event:"daemon_start",runId:r,agentOsId:t,execute:n,intervalMs:o,boxKind:l.box.boxKind,workerCapSource:l.workerCapSource,maxConcurrentWorkers:l.maxConcurrentWorkers}));let c=Sr(),u=Fy({shouldStop:()=>s}).catch(m=>{console.error(JSON.stringify({event:"chat_claim_loop_crashed",error:m instanceof Error?m.message:String(m)}))}),d=!1;for(;!s;)try{Fk({agentOsId:t,runId:r,instructionBundleVersion:Nr()});let m=await ri(e.secret?String(e.secret):void 0,t);if(!m.ok){d||(d=!0,console.error(JSON.stringify({event:"daemon_runner_credential_missing",agentOsId:t,reason:m.reason,remedy:`run \`kynver runner credential --agent-os-id ${t}\` (or \`kynver bootstrap\`); ticks resume automatically once the credential exists`}))),await kd(o,()=>s);continue}d&&(d=!1,console.error(JSON.stringify({event:"daemon_runner_credential_recovered",agentOsId:t}))),await yu({agentOsId:t,baseUrl:ec(e.baseUrl?String(e.baseUrl):void 0),secret:m.secret});let p=await gd({run:r,agentOsId:t,execute:n,...e});if(console.error(JSON.stringify({event:"daemon_tick",...p})),c.tickEnabled){let g=Ia(r);if(g&&!g.authorized)console.error(JSON.stringify({event:"daemon_cron_tick_skipped",reason:"mesh_cron_lease_not_authorized",holderBoxId:g.holderBoxId}));else{let R=await Pn({env:c,agentOsIdFilter:t});R.enabled&&(R.fired>0||R.errors>0||R.lockHeld)&&console.error(JSON.stringify({event:"daemon_cron_tick",...R}))}}p.idle?i++:i=0;let f=Math.floor(it("daemon.maxIdleStreak",eO)),h=Math.floor(it("daemon.idleIntervalMs",ZI)),k=i>=f?h:o;await kd(k,()=>s)}catch(m){console.error(JSON.stringify({event:"daemon_tick_error",error:m.message})),await kd(o,()=>s)}await u,console.error(JSON.stringify({event:"daemon_stop",runId:r,agentOsId:t}))}I();import{spawn as tO}from"node:child_process";C();var nO=15*6e4,Ky=2*6e4,$y=1e4,oO=5e3,sO=5*6e4,iO=30*6e4,jy=5e3;function aO(e,r=process.env){let t=typeof e=="string"?Number.parseInt(e,10):NaN;if(Number.isFinite(t)&&t>0)return t;let n=Number.parseInt(r.KYNVER_DAEMON_STALL_MS??"",10);return Number.isFinite(n)&&n>0?n:nO}function Ta(e,r=process.env){if(e.keeperChild===!0||e.keeperChild==="true"||e.noSupervise===!0||e.noSupervise==="true"||e.supervised==="false")return!1;let t=(r.KYNVER_DAEMON_SUPERVISED??"").trim().toLowerCase();return!(t==="0"||t==="false"||t==="no"||t==="off")}function lO(e,r=oO,t=sO){let n=Math.min(Math.max(e,1)-1,10);return Math.min(r*2**n,t)}function cO(e,r,t=iO){return r-e>=t}function _t(e,r={}){console.error(JSON.stringify({event:`daemon_keeper_${e}`,...r}))}function uO(e){let r=[];for(let t=0;t<e.length;t+=1){let n=e[t];if(!(n==="--supervised"||n==="--no-supervise"||n==="--keeper-child")){if(n==="--stall-ms"){t+1<e.length&&!e[t+1].startsWith("--")&&(t+=1);continue}n.startsWith("--stall-ms=")||n.startsWith("--supervised=")||r.push(n)}}return r.push("--keeper-child"),r}async function Da(e,r=process.argv.slice(2)){let t=String(N(String(e.agentOsId||y().agentOsId||""),"--agent-os-id")),n=aO(e.stallMs),o=uO(r),s=process.argv[1],i=!1,a=null,l=0,c=u=>{i=!0,_t("stop",{signal:u}),a?.pid&&a.kill(u)};for(process.on("SIGINT",()=>c("SIGINT")),process.on("SIGTERM",()=>c("SIGTERM")),_t("start",{agentOsId:t,stallMs:n,childArgv:o});!i;){let u=Date.now(),d=!1,m=null,p=null;for(a=tO(process.execPath,[s,...o],{stdio:"inherit",env:process.env}),_t("child_spawned",{pid:a.pid??null}),a.on("exit",(k,g)=>{d=!0,m=k,p=g});!d&&!i&&(await xr(jy),!(d||i));){if(Date.now()-u<Ky)continue;let k=Kk(t),g=k&&k.pid===a.pid?k:null;if(g&&$k(g,n)){_t("stall_detected",{pid:a.pid??null,lastBeatAt:g.observedAt,stallMs:n}),a.kill("SIGTERM"),await xr($y),d||a.kill("SIGKILL");break}if(!g&&Date.now()-u>n+Ky){_t("no_heartbeat_detected",{pid:a.pid??null,stallMs:n}),a.kill("SIGTERM"),await xr($y),d||a.kill("SIGKILL");break}}for(;!d&&!i;)await xr(jy);if(i)break;let f=Date.now();cO(u,f)&&(l=0),l+=1;let h=lO(l);_t("child_exited",{code:m,signal:p,uptimeMs:f-u,consecutiveFailures:l,respawnInMs:h}),await xr(h)}_t("stopped",{agentOsId:t})}T();import{existsSync as Ua}from"node:fs";async function Ma(e=Sr()){let r=await Ct(e.storePath).catch(()=>[]),t=await Aa(e.statePath).catch(()=>({version:1,jobs:{}})),n=!!(e.fireBaseUrl&&e.secret),o=Ea(e),s="disabled";return o?s="kynver-cron-daemon":process.env.QSTASH_TOKEN?.trim()&&(s="qstash"),{primary:s,env:{storePath:e.storePath,statePath:e.statePath,tickEnabled:e.tickEnabled,fireBaseUrl:e.fireBaseUrl,missedRunPolicy:e.missedRunPolicy,maxCatchUpPerTick:e.maxCatchUpPerTick,maxRetries:e.maxRetries},jobCount:r.length,stateJobCount:Object.keys(t.jobs).length,credentialsReady:n,daemonPrimary:o}}import{homedir as dO}from"node:os";import pO from"node:path";Ir();var Fr="watchdog:board-sweep",mO="*/5 * * * *",fO=["Set KYNVER_SCHEDULER_PROVIDER=kynver-cron on the hosted Kynver deployment (Vercel).","Set KYNVER_CRON_SECRET to the same value written to ~/.kynver/.env by this installer.","Unset KYNVER_CRON_STORE_PATH on Vercel \u2014 the connected box owns the local store.","Keep QSTASH_TOKEN only if other non-watchdog schedules still use QStash (analyst/market jobs)."];function Vy(e){let r=e.storePath?.trim()||Hr(),t=e.envFilePath?.trim()||we,n=pO.join(dO(),".kynver","config.json"),o=`/api/agent-os/by-id/${e.agentOsId}/scheduler/fire`,s=[];e.apiBaseUrl?.trim()||s.push("apiBaseUrl \u2014 run `kynver setup --api-base-url \u2026`"),e.agentOsId?.trim()||s.push("agentOsId \u2014 run `kynver setup --agent-os-id \u2026`");let i={KYNVER_API_URL:e.apiBaseUrl,KYNVER_CRON_SECRET:e.cronSecret,KYNVER_CRON_STORE_PATH:r,KYNVER_CRON_TICK_ENABLED:"1",KYNVER_CRON_DAEMON_PRESENT:"1"},a=["OPENCLAW_CRON_STORE_PATH","OPENCLAW_CRON_SECRET","OPENCLAW_CRON_FIRE_BASE_URL"],l={deploymentSchedulerProvider:"kynver-cron",apiBaseUrl:e.apiBaseUrl,agentOsId:e.agentOsId,...e.defaultDaemonRunId?{defaultDaemonRunId:e.defaultDaemonRunId}:{}};return{envFilePath:t,configPath:n,storePath:r,envUpdates:i,envRemovals:a,configUpdates:l,deploymentSteps:fO,prerequisites:s,systemdSupported:process.platform==="linux",watchdogSpec:{kind:"watchdog",cron:mO,dedupeKey:Fr,callbackPath:o}}}Ir();async function Nn(e){let r=e.envFilePath??we,t=[],n=Sr(),o=await Ma(n),s=rn(r);t.push({id:"config_agent_os",ok:!!e.config.agentOsId?.trim(),summary:e.config.agentOsId?`agentOsId configured (${e.config.agentOsId})`:"agentOsId missing in ~/.kynver/config.json",remediation:"Run `kynver setup --agent-os-id <id>`."}),t.push({id:"config_api_base",ok:!!(e.config.apiBaseUrl?.trim()||n.fireBaseUrl),summary:n.fireBaseUrl?`fire base URL resolved (${n.fireBaseUrl})`:"KYNVER_API_URL / apiBaseUrl not configured",remediation:"Run `kynver setup --api-base-url https://\u2026`."}),t.push({id:"deployment_provider",ok:e.config.deploymentSchedulerProvider==="kynver-cron",summary:`deploymentSchedulerProvider=${e.config.deploymentSchedulerProvider??"(unset)"}`,remediation:'Run `kynver cron install` or set deploymentSchedulerProvider to "kynver-cron".'}),t.push({id:"cron_secret",ok:!!n.secret,summary:n.secret?"KYNVER_CRON_SECRET present":"KYNVER_CRON_SECRET missing",remediation:"Run `kynver cron install` to generate and persist the shared secret."}),t.push({id:"env_file",ok:Ua(r)&&!!s.get("KYNVER_CRON_SECRET"),summary:Ua(r)?`~/.kynver/.env present (${s.size} keys)`:"~/.kynver/.env missing",remediation:"Run `kynver cron install` to write ~/.kynver/.env."}),t.push({id:"cron_store",ok:Ua(n.storePath),summary:Ua(n.storePath)?`cron store present (${n.storePath})`:`cron store missing (${n.storePath})`,remediation:"Run `kynver cron install` to initialize the local store."});let a=(await Ct(n.storePath).catch(()=>[])).find(u=>u.spec.dedupeKey===Fr);t.push({id:"watchdog_local",ok:!!a,summary:a?`watchdog entry in local store (${a.providerScheduleId})`:"watchdog entry not mirrored in local cron store",remediation:"Run `kynver cron install` (with API access) to register and mirror watchdog."}),t.push({id:"daemon_primary",ok:o.daemonPrimary,summary:o.daemonPrimary?"cron tick enabled with credentials (daemon-primary)":`cron primary=${o.primary}; tickEnabled=${o.env.tickEnabled}`,remediation:"Ensure KYNVER_CRON_TICK_ENABLED=1 and run `kynver daemon` (or enable the systemd user unit)."});let l=s.has("OPENCLAW_CRON_STORE_PATH")||s.has("OPENCLAW_CRON_SECRET")||s.has("OPENCLAW_CRON_FIRE_BASE_URL");return t.push({id:"legacy_openclaw_env",ok:!l,summary:l?"legacy OPENCLAW_CRON_* keys still present in ~/.kynver/.env":"no legacy OPENCLAW_CRON_* keys in env file",remediation:"Re-run `kynver cron install` to retire legacy aliases."}),{ok:t.every(u=>u.ok),checks:t}}I();Je();C();import{existsSync as rR}from"node:fs";import{createHash as gO}from"node:crypto";function Gy(e){let r=JSON.stringify({cb:e.callbackPath,cron:e.cron??null,runAt:e.runAt??null,kind:e.kind,target:e.target,dedupeKey:e.dedupeKey??null});return`kc-cron:${gO("sha1").update(r).digest("hex").slice(0,16)}`}async function yd(e,r,t={}){return fetch(e,{...t,headers:{"Content-Type":"application/json",Authorization:`Bearer ${r}`,...t.headers}})}async function Yy(e,r,t,n={}){let o=new URLSearchParams(n),s=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/jobs?${o}`,i=await yd(s,t),a=await i.text(),l=null;try{l=JSON.parse(a)}catch{l=null}if(!i.ok)throw new Error(`list scheduler jobs failed (${i.status}): ${l?.error??a.slice(0,200)}`);return l?.items??[]}async function Jy(e,r,t,n,o={}){let s=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/watchdog/ensure`,i={};n&&(i.cron=n),o.requireProvider&&(i.requireProvider=o.requireProvider);let a=await yd(s,t,{method:"POST",body:JSON.stringify(i)}),l=await a.text(),c=null;try{c=JSON.parse(l)}catch{c=null}if(!a.ok||!c?.job)throw new Error(`ensure watchdog failed (${a.status}): ${c?.error??l.slice(0,200)}`);return{job:c.job,route:c.route??`/api/agent-os/by-id/${r}/scheduler/fire`,dedupeKey:c.dedupeKey??Fr,requestedCron:c.requestedCron??n??"*/5 * * * *",selectedProvider:c.selectedProvider??c.job.provider??null}}async function qy(e,r,t,n){let o=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/jobs/${encodeURIComponent(t)}/cancel`,s=await yd(o,n,{method:"POST",body:"{}"});if(!s.ok){let i=await s.text();throw new Error(`cancel job ${t} failed (${s.status}): ${i.slice(0,200)}`)}}function zy(e,r,t=Fr){return{kind:"watchdog",scheduleKind:"cron",cron:r,callbackPath:`/api/agent-os/by-id/${e}/scheduler/fire`,payload:{source:"agent-os.watchdog-schedule",agentOsId:e},target:{agentOsId:e},description:"Watchdog board sweep (repair loop)",dedupeKey:t}}function Xy(e){return e.filter(r=>r.kind==="watchdog"&&r.dedupeKey===Fr&&r.provider==="qstash"&&r.status!=="cancelled")}function hO(e){return e.find(r=>r.kind==="watchdog"&&r.dedupeKey===Fr&&r.provider==="kynver-cron"&&r.status!=="cancelled")}function Qy(e){return hO(e)?{allowed:!0}:{allowed:!1,reason:"Cannot cancel QStash watchdog until hosted KYNVER_SCHEDULER_PROVIDER=kynver-cron is live and a kynver-cron watchdog row exists. Set Vercel env, redeploy, re-run `kynver cron install`, then `--confirm-qstash-removal`."}}Ir();Ir();import{randomBytes as kO}from"node:crypto";function yO(){return kO(32).toString("base64url")}function Zy(e=we){let r=sd();if(r)return{secret:r,generated:!1,source:"env"};let n=rn(e).get("KYNVER_CRON_SECRET")?.trim();return n?{secret:n,generated:!1,source:"env-file"}:{secret:yO(),generated:!0,source:"generated"}}Gs();Js();T();function eR(e,r){if(r?.trim())return r.trim();if(e.defaultDaemonRunId?.trim())return e.defaultDaemonRunId.trim();let t=Z().runsDir;return rR(t)?X().sort((o,s)=>Date.parse(s.createdAt)-Date.parse(o.createdAt))[0]?.id??null:null}async function Wa(e={}){let r=e.execute!==!1,t=y(),n=ar(e.apiBaseUrl?.trim()||t.apiBaseUrl?.trim()||process.env.KYNVER_API_URL?.trim()||""),o=e.agentOsId?.trim()||t.agentOsId?.trim()||process.env.KYNVER_AGENT_OS_ID?.trim()||"",s=Zy(),i=Vy({config:t,apiBaseUrl:n,agentOsId:o,cronSecret:s.secret,defaultDaemonRunId:e.runId?.trim()||t.defaultDaemonRunId,installSystemd:e.installSystemd===!0}),a=[...i.prerequisites],l={ok:!1,dryRun:!r,plan:i,secretGenerated:s.generated,configPath:q(i.configPath),storeInitialized:!1,blockers:a};if(a.length)return l;if(r){let c=$s(i.envUpdates,{filePath:i.envFilePath,removeKeys:i.envRemovals});l.envFile={path:q(c.path),changed:c.changed,keysWritten:c.keysWritten};let u={...t,...i.configUpdates},d=eR(u,e.runId);d&&(u.defaultDaemonRunId=d),ue(u),process.env.KYNVER_API_URL=n,process.env.KYNVER_CRON_SECRET=s.secret,process.env.KYNVER_CRON_STORE_PATH=i.storePath,process.env.KYNVER_CRON_TICK_ENABLED="1";let m=await ry(i.storePath);l.storeInitialized=m.created||rR(i.storePath);let p=se();if(p)try{let f=await ot(o,{baseUrl:n,apiKey:p});nt(o,f)}catch{}if(!e.skipWatchdog)if(!p)l.watchdog={error:"KYNVER_API_KEY required to register watchdog on server"},a.push("login \u2014 run `kynver login --api-key \u2026` to register watchdog remotely");else try{let f=await Jy(n,o,p,void 0,{requireProvider:"kynver-cron"}),h=zy(o,f.requestedCron,f.dedupeKey),k={providerScheduleId:Gy(h),spec:h,registeredAt:new Date().toISOString(),paused:!1};await ey(k,i.storePath),l.watchdog={remoteJobId:f.job.id,provider:f.selectedProvider??f.job.provider,localProviderScheduleId:k.providerScheduleId};let g=await Yy(n,o,p),R=Xy(g),O=["Phase 1 (local): `kynver cron install` writes box env/store and may fail remote watchdog until Vercel cutover.","Phase 2 (hosted): set KYNVER_SCHEDULER_PROVIDER=kynver-cron + KYNVER_CRON_SECRET on Vercel, redeploy, re-run install.","Phase 3 (cleanup): `kynver cron install --confirm-qstash-removal` after a kynver-cron watchdog row exists.","Analyst/market QStash schedules are never touched by this installer."],_=[];if(R.length)if(e.confirmQstashRemoval){let E=Qy(g);if(!E.allowed)a.push(E.reason);else for(let U of R)await qy(n,o,U.id,p),_.push(U.id)}else a.push(`${R.length} QStash watchdog job(s) still active \u2014 complete Vercel cutover (KYNVER_SCHEDULER_PROVIDER=kynver-cron + KYNVER_CRON_SECRET), re-run install, then --confirm-qstash-removal`);l.qstashWatchdog={found:R.map(E=>({id:E.id,provider:E.provider,status:E.status})),removed:_,manualSteps:O}}catch(f){l.watchdog={error:f.message},a.push(`watchdog registration failed: ${f.message}`)}if(e.installSystemd){let f=eR({...t,...i.configUpdates},e.runId);if(!f)l.systemd={supported:i.systemdSupported,unitPath:null,written:!1,enabled:!1,started:!1,note:"No harness run found \u2014 run `kynver run create` first or pass --run <runId>."},a.push("harness run \u2014 create a run before installing systemd unit");else{try{L(f)}catch{a.push(`harness run ${f} not found`)}if(l.systemd=Ys({envFilePath:i.envFilePath,agentOsId:o,runId:f,kynverBin:nn()},r),r&&l.systemd.enabled){let h=y();ue({...h,daemonSupervisionOwner:"systemd"})}}}if(!e.skipTestFire&&a.length===0){let f=await Pn({agentOsIdFilter:o});l.testFire={fired:f.fired,errors:f.errors},f.errors>0&&a.push(`test fire reported ${f.errors} error(s) \u2014 check server KYNVER_CRON_SECRET matches`)}else e.skipTestFire&&(l.testFire={fired:0,errors:0,skipped:!0});l.verify=await Nn({config:y(),envFilePath:i.envFilePath}),l.blockers=a,l.ok=a.length===0&&(l.verify?.ok??!1)}else l.ok=a.length===0;return l}var RO=["deployment_provider","cron_secret","env_file","cron_store"];function tR(e){let r=e?.trim().toLowerCase();if(r==="qstash"||r==="kynver-cron"||r==="openclaw-cron")return r;if(r==="openclaw")return"openclaw-cron"}function vO(e){let r=tR(process.env.KYNVER_SCHEDULER_PROVIDER);if(r==="qstash"||r==="openclaw-cron")return!1;if(r==="kynver-cron")return!0;let t=tR(e.deploymentSchedulerProvider);return t==="qstash"||t==="openclaw-cron"?!1:t==="kynver-cron"?!0:!!(e.agentOsId?.trim()&&e.apiBaseUrl?.trim())}async function bO(e){if(!vO(e))return{expectsKynverCron:!1,ready:!0,failedChecks:[]};let t=(await Nn({config:e})).checks.filter(n=>RO.includes(n.id)&&!n.ok);return{expectsKynverCron:!0,ready:t.length===0,failedChecks:t}}function SO(e){let r=["Run `kynver cron install` on this box."];for(let t of e)t.remediation&&r.push(` \u2022 ${t.id}: ${t.remediation}`);return r}function Rd(e){return e===!0||e==="true"||e==="1"||e==="yes"||e==="on"}async function nR(e){if(Rd(e.args.skipCron))return{action:"skipped"};let r=await bO(e.config);if(!r.expectsKynverCron||r.ready)return{action:"ready"};console.log(""),console.log(" Local Kynver Cron is not ready \u2014 running `kynver cron install`\u2026");let t=Rd(e.args.installSystemd)||Rd(e.args["install-systemd"]),n=await Wa({execute:!0,skipTestFire:!0,agentOsId:e.agentOsId,runId:e.runId,installSystemd:t});if(n.ok)return console.log(" Kynver Cron configured for this box."),console.log(""),{action:"installed",installOk:!0};console.log(""),console.log(" Cron install did not fully complete (daemon will still start):");for(let o of n.blockers)console.log(` ! ${o}`);if(n.plan.deploymentSteps.length){console.log(""),console.log(" Hosted deployment (complete on Vercel, then re-run install):");for(let o of n.plan.deploymentSteps)console.log(` - ${o}`)}for(let o of SO(r.failedChecks))console.log(` ${o}`);return console.log(""),{action:"guided",installOk:!1,blockers:n.blockers}}I();Oe();Jn();function oR(e=y(),r=process.env){let t=Ae(r,e),n=[...t.warnings],o=e.maxConcurrentWorkers,s=!1,i={...e};if(e.boxKind?.trim()||(i.boxKind=t.boxKind,s=!0,n.push(`persisted boxKind=${t.boxKind} to ~/.kynver/config.json \u2014 set explicitly via kynver setup --box-kind`)),Kt(t.boxKind,o??0))o=4,i.maxConcurrentWorkers=4,i.maxConcurrentWorkersSource="setup-auto",s=!0,n.push(`clamped Forge maxConcurrentWorkers to ${4} (was ${e.maxConcurrentWorkers}; workspace aggregate caps are Ghost-only)`);else if(o!=null){let a=cr(t.boxKind,o);a!==o&&(o=a,i.maxConcurrentWorkers=a,s=!0,n.push(`clamped maxConcurrentWorkers to ${a} for ${t.boxKind} pool`))}return s&&ue(i),{repaired:s,boxKind:t.boxKind,maxConcurrentWorkers:o??4,warnings:n}}Js();Gs();I();Ir();lo();qs();co();T();async function sR(e){let r=zs(e.config,e.args),{policy:t}=r;if(!(t.owner==="systemd"&&ao(t.hostKind)))return{action:"keeper",owner:"keeper"};try{L(e.runId)}catch{return{action:"systemd_skipped",owner:"keeper",blockers:[`harness run ${e.runId} not found \u2014 cannot install systemd unit`]}}let o=Ys({envFilePath:we,agentOsId:e.agentOsId,runId:e.runId,kynverBin:nn()},!0),s=[];if(!o.supported)return s.push(o.note??"systemd user units not supported on this host"),{action:"systemd_guided",owner:"keeper",systemd:o,blockers:s};if(!o.enabled)return s.push(o.note??"systemd unit write/enable failed"),{action:"systemd_guided",owner:"keeper",systemd:o,blockers:s};let i=y();return ue({...i,daemonSupervisionOwner:"systemd"}),console.log(""),console.log(" Daemon supervision: systemd user unit enabled (`kynver daemon` with Restart=always)."),o.unitPath&&console.log(` unit: ${o.unitPath}`),console.log(""),{action:"systemd_installed",owner:"systemd",systemd:o}}function iR(e){return e.action==="systemd_installed"}function aR(e="kynver-cron-daemon"){return["Daemon delegated to systemd user unit.","The unit runs `kynver daemon` with systemd Restart=always.",`Status: systemctl --user status ${e}`,`Stop: systemctl --user stop ${e}`]}function wO(e,r){return e.filter(n=>n.repo===r&&!yr.has(n.status)).sort((n,o)=>(o.createdAt??"").localeCompare(n.createdAt??""))[0]?.id??null}async function lR(e){En();let r=y();(!se()||!r.agentOsId?.trim())&&(console.log(" This machine isn't linked yet \u2014 running bootstrap first."),await xa(e),r=y());let t=(typeof e.agentOsId=="string"?e.agentOsId.trim():"")||r.agentOsId?.trim()||"";t||(console.error("No AgentOS workspace configured \u2014 run `kynver bootstrap` (or pass --agent-os-id)."),process.exit(1)),po(t).ok||(console.error(ei(t)),process.exit(1)),e.chatOauth===!0&&r.chatUseClaudeOauth!==!0&&(ue({...r,chatUseClaudeOauth:!0}),r=y(),console.log(" Chat: Claude Code OAuth opt-in saved (delegated turns may use your local subscription)."));let o=(typeof e.repo=="string"?e.repo.trim():"")||r.defaultRepo?.trim()||je()?.repo||"";o||(console.error("No repo configured \u2014 pass --repo /path/to/repo or run `kynver setup --discover-repo`."),process.exit(1));let s=oR(r);if(s.repaired){r=y();for(let c of s.warnings)console.log(` ${c}`)}let i=typeof e.run=="string"&&e.run.trim()?e.run.trim():"";i||(i=wO(X(),o)??"",i?console.log(` Reusing run ${i} for ${o}.`):i=Fo({...e,repo:o,name:"agent"}).runId),await nR({config:r,agentOsId:t,runId:i,args:e});let a=await sR({config:y(),agentOsId:t,runId:i,args:e});if(iR(a)){console.log("");for(let c of aR())console.log(` ${c}`);console.log("");return}console.log(""),console.log(` ${CO.hostname()} \u2014 agent coming online`),console.log(` workspace: ${t}`),console.log(` repo: ${o}`),console.log(` run: ${i}`),console.log(" Ctrl-C stops the agent. (Advanced control: `kynver daemon --help`.)"),console.log("");let l={...e,run:i,agentOsId:t};if(Ta(l)){await Da(l,_O(i,t,e));return}await es(l)}function _O(e,r,t){if(!po(r).ok)throw new Error(ei(r));let o=["daemon","--run",e,"--agent-os-id",r];return typeof t.intervalMs=="string"&&t.intervalMs.trim()&&o.push("--interval-ms",t.intervalMs.trim()),(t.execute===!1||t.execute==="false")&&o.push("--execute","false"),typeof t.stallMs=="string"&&t.stallMs.trim()&&o.push("--stall-ms",t.stallMs.trim()),o}T();T();z();import{existsSync as xO,rmSync as EO}from"node:fs";import vd from"node:path";function PO(e){let r=e.replace(/\\/g,"/").replace(/^\.\//,"").trim();if(!r||r.startsWith("/")||r.includes(".."))throw new Error(`unsafe path: ${e}`);return r}function AO(e){return typeof e!="string"||!e.trim()?[]:e.split(",").map(r=>r.trim()).filter(Boolean)}function IO(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=[...AO(e.path),...Array.isArray(e.paths)?e.paths:[]];if(o.length===0)return{ok:!1,removed:[],reason:"requires at least one --path"};let s=vd.resolve(n.worktreePath),i=[];for(let c of o){let u=PO(c),d=vd.resolve(s,u);if(!d.startsWith(s+vd.sep)&&d!==s)return{ok:!1,removed:i,reason:`path escapes worktree: ${c}`};if(!xO(d))return{ok:!1,removed:i,reason:`path not found: ${c}`};EO(d,{recursive:!0,force:!0}),i.push(u)}let a=Array.isArray(n.disposableArtifactsRemoved)?n.disposableArtifactsRemoved.filter(c=>typeof c=="string"):[];n.disposableArtifactsRemoved=[...new Set([...a,...i])],K(n.runId,n);let l=D(n);return{ok:!0,removed:i,...l.changedFiles.length?{reason:"worktree still has other changes"}:{}}}function cR(e){let r=IO(e);console.log(JSON.stringify(r,null,2)),r.ok||process.exit(1)}I();import tN from"node:path";oo();_s();oo();var OO=/--max-old-space-size=(\d+)/;function NO(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function bd(){return NO(process.env.KYNVER_NODE_OLD_SPACE_SIZE_MB,1024)}function Ba(e=process.env){let r={...e};if(process.env.KYNVER_NODE_OLD_SPACE_SIZE_MB==="0")return r;let t=r.NODE_OPTIONS??"";if(OO.test(t))return r;let o=`--max-old-space-size=${bd()}`;return r.NODE_OPTIONS=t.trim()?`${t.trim()} ${o}`:o,r}function Tn(e=bd()){return`--max-old-space-size=${e}`}Vs();I();oo();_s();import{spawnSync as TO}from"node:child_process";function Ha(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function dR(e=y()){let r=process.env.KYNVER_BUILD_MEM_BUDGET_BYTES?Ha(process.env.KYNVER_BUILD_MEM_BUDGET_BYTES,1610612736):void 0,t=process.env.KYNVER_BUILD_MEM_RESERVE_BYTES?Ha(process.env.KYNVER_BUILD_MEM_RESERVE_BYTES,2147483648):void 0;return{perBuildBudgetBytes:r??Ha(e.perWorkerMemBytes,1610612736),reserveBytes:t??Ha(e.memReserveBytes,2147483648)}}var Fa=0;function wd(){Fa+=1}function _d(){Fa=Math.max(0,Fa-1)}function xt(e={}){let r={...dR(),...e},t=e.memAvailableBytes??$t(),n=r.perBuildBudgetBytes+r.reserveBytes,o=t>=n;return{admitted:o,memAvailableBytes:t,requiredBytes:n,activeBuilds:Fa,reason:o?null:`insufficient memory: need ${n} bytes available (budget ${r.perBuildBudgetBytes} + reserve ${r.reserveBytes}), have ${t}`}}function DO(e){e<=0||TO(process.execPath,["-e",`const d=Date.now()+${Math.floor(e)};while(Date.now()<d);`],{stdio:"ignore"})}function xd(e,r=2e3,t={}){let n=Date.now()+Math.max(0,e),o=xt({...t,memAvailableBytes:t.memAvailableBytes?.()});for(;!o.admitted&&Date.now()<n;)DO(Math.min(r,n-Date.now())),o=xt({...t,memAvailableBytes:t.memAvailableBytes?.()});return o}import{spawnSync as eN}from"node:child_process";C();import{closeSync as LO,existsSync as Ed,mkdirSync as BO,openSync as HO,readdirSync as mR,readFileSync as FO,unlinkSync as Pd,writeFileSync as KO}from"node:fs";import Ad from"node:path";import{mkdirSync as MO}from"node:fs";import{tmpdir as UO}from"node:os";import Ka from"node:path";function WO(){return!!(process.env.VERCEL||process.env.VERCEL_ENV||process.env.AWS_LAMBDA_FUNCTION_NAME||process.env.AWS_EXECUTION_ENV)}function pR(){let e=process.env.KYNVER_HEAVY_VERIFICATION_STATE_ROOT;return e?Ka.resolve(e):WO()?Ka.join(UO(),"kynver","state","heavy-verification"):Ka.join(ji(),"heavy-verification")}function rs(){return Ka.join(pR(),"slots")}function Dn(){let e=rs();return MO(e,{recursive:!0}),e}var Un=120*6e4,$a=1;function $O(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function Wn(){let e=process.env.KYNVER_HEAVY_VERIFICATION_SKIP?.trim().toLowerCase();return e==="1"||e==="true"||e==="yes"}function Mn(){let e=process.env.KYNVER_HEAVY_VERIFICATION_MAX_CONCURRENT;return e?$O(e,$a):$a}function jO(e){return`slot-${e}`}function fR(e,r=rs()){return Ad.join(r,`${e}.json`)}function Id(e){if(!Ed(e))return null;try{let r=JSON.parse(FO(e,"utf8"));if(typeof r.slotId=="string"&&typeof r.pid=="number"&&typeof r.acquiredAt=="string"&&typeof r.command=="string")return r}catch{return null}return null}function ja(e,r=Un){if(!e||!H(e.pid))return!0;let t=Date.parse(e.acquiredAt);return Number.isNaN(t)?!0:Date.now()-t>r}function VO(e,r){let t=Id(e);if(ja(t,r))try{Pd(e)}catch{}}function GO(e){return BO(e,{recursive:!0}),e}function ns(e={}){let r=GO(e.slotsDir??Dn()),t=e.staleMs??Un,n=0;for(let o of mR(r)){if(!o.endsWith(".json"))continue;let s=Ad.join(r,o),i=Ed(s);VO(s,t),i&&!Ed(s)&&(n+=1)}return n}function Od(e={}){let r=e.slotsDir??Dn(),t=e.staleMs??Un;ns({slotsDir:r,staleMs:t});let n=[];for(let o of mR(r)){if(!o.endsWith(".json"))continue;let s=Id(Ad.join(r,o));s&&!ja(s,t)&&n.push(s)}return n}function ts(e={}){return Od(e).length}function Et(e,r={}){if(Wn())return{admitted:!0,slotId:null,activeSlots:0,maxSlots:Mn(),reason:null};let t=r.slotsDir??Dn(),n=r.staleMs??Un,o=r.maxSlots??Mn();ns({slotsDir:t,staleMs:n});for(let i=0;i<o;i+=1){let a=jO(i),l=fR(a,t),c=Id(l);if(c&&ja(c,n))try{Pd(l)}catch{}else if(c&&!ja(c,n))continue;let u={slotId:a,pid:process.pid,acquiredAt:new Date().toISOString(),command:e};try{let d=HO(l,"wx");KO(d,JSON.stringify(u,null,2),"utf8"),LO(d);let m=ts({slotsDir:t,staleMs:n});return{admitted:!0,slotId:a,activeSlots:m,maxSlots:o,reason:null}}catch(d){if(d.code==="EEXIST")continue;throw d}}let s=ts({slotsDir:t,staleMs:n});return{admitted:!1,slotId:null,activeSlots:s,maxSlots:o,reason:`heavy verification at capacity (${s}/${o} slots)`}}function Ln(e,r={}){if(!e)return;let t=fR(e,r.slotsDir??rs());try{Pd(t)}catch{}}function Bn(e,r={}){if(Wn())return{admitted:!0,slotId:null,activeSlots:0,maxSlots:Mn(),reason:null};let t=r.slotsDir??Dn(),n=r.staleMs??Un,o=r.maxSlots??Mn();ns({slotsDir:t,staleMs:n});let s=ts({slotsDir:t,staleMs:n}),i=s<o;return{admitted:i,slotId:null,activeSlots:s,maxSlots:o,reason:i?null:`heavy verification at capacity (${s}/${o} slots); waiting for ${e}`}}import{spawnSync as YO}from"node:child_process";function JO(e){e<=0||YO(process.execPath,["-e",`const d=Date.now()+${Math.floor(e)};while(Date.now()<d);`],{stdio:"ignore"})}function Va(e,r,t=2e3,n={}){let o=Date.now()+Math.max(0,r),s=Et(e,n);for(;!s.admitted&&Date.now()<o;)JO(Math.min(t,o-Date.now())),s=Et(e,n);return s}var qO=/\b(npm run typecheck|tsc\b[^|&;]*--noEmit|node scripts\/verify-pr-local\.mjs|kynver (harness )?verify)\b/i,zO=/\b(npm run build\b|next build\b)\b/i,XO=/\b(vercel (build|deploy|--prod))\b/i,QO=/\b(openai|anthropic|perplexity|voyage)\b.*\b(api|cli)\b|\b(paid|billable)[-_ ]?compute\b/i;function Ga(e){let r=e.trim();return r?QO.test(r)?{heavy:!0,commandClass:"paid_compute",reason:"paid external compute requires heavy-verification token and operator approval"}:XO.test(r)?{heavy:!0,commandClass:"vercel_verify",reason:"Vercel build/deploy verification requires heavy-verification token"}:zO.test(r)?{heavy:!0,commandClass:"full_build",reason:"full app build requires heavy-verification token"}:qO.test(r)?{heavy:!0,commandClass:"full_typecheck",reason:"full repo typecheck requires heavy-verification token"}:{heavy:!1,commandClass:"allowed",reason:null}:{heavy:!1,commandClass:"allowed",reason:null}}var os="heavy_verification_token_required";function Ya(e,r={}){let t=Ga(e);if(!t.heavy)return{allowed:!0,outcome:"allowed",commandClass:t.commandClass,reason:"command does not require heavy-verification token",verificationGate:{...Bn(e),slotId:null}};if(Wn())return{allowed:!0,outcome:"heavy_verification_skipped",commandClass:t.commandClass,reason:"KYNVER_HEAVY_VERIFICATION_SKIP bypasses gate",verificationGate:{...Bn(e),slotId:null}};let n=r.waitMs??0,o=n>0?Va(e,n,r.pollMs):Et(e);return o.admitted?{allowed:!0,outcome:"allowed",commandClass:t.commandClass,reason:t.reason??"heavy-verification token acquired",verificationGate:o}:{allowed:!1,outcome:os,commandClass:t.commandClass,reason:t.reason??o.reason??os,verificationGate:o}}Ce();import Nd from"node:path";function ZO(e){let r=dr(fe()),t=Nd.relative(r,Nd.resolve(e));return t.length>0&&!t.startsWith("..")&&!Nd.isAbsolute(t)}function gR(e){return ZO(e)?(typeof process.getuid=="function"?process.getuid():null)===0?{ok:!1,reason:"Refusing build/install as root inside a harness worktree \u2014 generated caches become root-owned and block daemon cleanup. Run kynver daemon and workers as the harness owner (never sudo kynver)."}:{ok:!0}:{ok:!0}}Vs();function rN(e){let r=[];for(let[t,n]of Object.entries(e))n!==void 0&&r.push(`${t}=${n}`);return r}function hR(e,r){let t=eN(e[0],e.slice(1),{cwd:r.cwd,env:r.env,encoding:"utf8",stdio:["ignore","pipe","pipe"],shell:r.shell,timeout:r.timeoutMs});return{exitCode:t.status??1,stdout:(t.stdout??"").trim(),stderr:(t.stderr??"").trim()}}function Ja(e){let r=e.waitForAdmissionMs??6e5,t=Ya(e.command,{waitMs:r}),n=t.verificationGate;if(!t.allowed)return{ok:!1,exitCode:1,stdout:"",stderr:t.reason,admitted:!1,wrappedWithSystemd:!1,nodeOptionsFlag:Tn(),admission:xt(),verificationGate:n,gateOutcome:t.outcome,command:e.command};let o=n.slotId,s=r>0?xd(r):xt();if(!s.admitted)return Ln(o),{ok:!1,exitCode:1,stdout:"",stderr:s.reason??"build admission denied",admitted:!1,wrappedWithSystemd:!1,nodeOptionsFlag:Tn(),admission:s,verificationGate:n,command:e.command};let i=gR(e.cwd);if(!i.ok)return Ln(o),{ok:!1,exitCode:1,stdout:"",stderr:i.reason,admitted:!0,wrappedWithSystemd:!1,nodeOptionsFlag:Tn(),admission:s,verificationGate:n,command:e.command};let a=Ba({...process.env,...e.env}),l=Tn(),c=tn();wd();try{let u;if(c){let d=js({cwd:e.cwd,command:["/usr/bin/env",...rN(a),"/bin/bash","-lc",e.command]});u=hR(d,{cwd:e.cwd,env:a,timeoutMs:e.timeoutMs})}else u=hR([e.command],{cwd:e.cwd,env:a,shell:!0,timeoutMs:e.timeoutMs});return{ok:u.exitCode===0,exitCode:u.exitCode,stdout:u.stdout,stderr:u.stderr,admitted:!0,wrappedWithSystemd:c,nodeOptionsFlag:l,admission:s,verificationGate:n,gateOutcome:t.outcome,command:e.command}}finally{_d(),Ln(o)}}var qa=["npm run typecheck","npm run test"];function ss(e,r=qa,t={}){let n=[],o=!0;for(let s of r){let i=Ja({cwd:e,command:s,waitForAdmissionMs:t.waitForAdmissionMs,timeoutMs:t.timeoutMs});n.push({command:s,result:i}),i.ok||(o=!1)}return{passed:o,steps:n}}C();function kR(e){let r=e.indexOf(":");if(r<=0)throw new Error(`invalid --evidence ${e} (expected type:value)`);return{type:e.slice(0,r),value:e.slice(r+1)}}async function yR(e){let r=N(e.plan?String(e.plan):void 0,"plan"),t=(e.agentOsId?String(e.agentOsId):y().agentOsId)||"";t||(console.error("requires --agent-os-id or agentOsId in ~/.kynver/config.json"),process.exit(1));let n=N(e.role?String(e.role):void 0,"role"),o=N(e.status?String(e.status):void 0,"status"),s=[],i=e.evidence;if(Array.isArray(i))for(let O of i)s.push(kR(String(O)));else typeof i=="string"&&s.push(kR(i));let a=V(e.baseUrl?String(e.baseUrl):void 0),l=await J(e.secret?String(e.secret):void 0,t,{baseUrl:a}),c=`${a}/api/agent-os/by-id/${encodeURIComponent(t)}/plans/${encodeURIComponent(r)}/progress-events`,u=y(),m=`provider:${ko(u.workerProvider,Ie)}`,f=(e.proposed===!0||e.proposed==="true"?!0:e.proposed===!1||e.proposed==="false"?!1:void 0)??(o!=="done"&&(n==="implementer"||n==="repair_implementer")),h={rowKey:e.row?String(e.row):void 0,rowId:e.rowId?String(e.rowId):void 0,taskId:e.task?String(e.task):void 0,reviewTaskId:e.reviewTask?String(e.reviewTask):void 0,roleLane:n,status:o,note:e.note?String(e.note):void 0,remainingWork:e.remaining?String(e.remaining):void 0,evidence:s.length?s:void 0,executorRef:e.executorRef?String(e.executorRef):m};f!==void 0&&(h.proposed=f);let k=await fetch(c,{method:"POST",headers:He(l),body:JSON.stringify(h)}),g=await k.text(),R=null;try{R=JSON.parse(g)}catch{R=g}k.ok||(console.error(JSON.stringify({httpStatus:k.status,response:R},null,2)),process.exit(1)),console.log(JSON.stringify(R,null,2))}function nN(e){let r=N(e.worktree?String(e.worktree):void 0,"worktree"),t=tN.resolve(r),n=ss(t),o=e.json===!0||e.json==="true",s={passed:n.passed,worktree:t,steps:n.steps};console.log(o?JSON.stringify(s,null,2):n.passed?"local plan verify passed":"local plan verify failed"),n.passed||process.exit(1)}async function RR(e){let r=N(e.plan?String(e.plan):void 0,"plan");if(e.local===!0||e.local==="true"){nN(e);return}let n=y().agentOsSlug;n||(console.error("requires agentOsSlug in ~/.kynver/config.json for verify (session route)"),process.exit(1));let o=V(e.baseUrl?String(e.baseUrl):void 0),s=process.env.KYNVER_API_KEY,i={"Content-Type":"application/json"};s&&(i.Authorization=`Bearer ${s}`);let a=`${o}/api/agent-os/${encodeURIComponent(n)}/plans/${encodeURIComponent(r)}/verify`,l=await fetch(a,{method:"POST",headers:i,body:JSON.stringify({worktreePath:e.worktree?String(e.worktree):void 0,taskId:e.task?String(e.task):void 0,humanOverride:e.humanOverride===!0||e.humanOverride==="true"})}),c=await l.text(),u=null;try{u=JSON.parse(c)}catch{u=c}l.ok||(console.error(JSON.stringify({httpStatus:l.status,response:u},null,2)),process.exit(1)),console.log(JSON.stringify(u,null,2))}import oN from"node:path";C();function vR(e){let r=oN.resolve(N(e.worktree?String(e.worktree):void 0,"worktree")),t=e.json===!0||e.json==="true"||e.emitJson===!0||e.emitJson==="true",n=[],o=e.command;if(Array.isArray(o))for(let a of o)n.push(String(a));else typeof o=="string"&&n.push(o);let s=ss(r,n.length?n:qa,{waitForAdmissionMs:e.waitForAdmissionMs?Number(e.waitForAdmissionMs):void 0,timeoutMs:e.timeoutMs?Number(e.timeoutMs):void 0}),i={passed:s.passed,worktree:r,steps:s.steps.map(a=>({command:a.command,ok:a.result.ok,exitCode:a.result.exitCode,admitted:a.result.admitted,wrappedWithSystemd:a.result.wrappedWithSystemd,nodeOptionsFlag:a.result.nodeOptionsFlag,admission:a.result.admission,verificationGate:a.result.verificationGate,stderr:a.result.stderr.slice(0,4e3)}))};if(t)console.log(JSON.stringify(i,null,2));else{console.log(s.passed?"harness verify passed":"harness verify failed");for(let a of i.steps)console.log(` ${a.ok?"\u2713":"\u2717"} ${a.command} (exit ${a.exitCode}, systemd=${a.wrappedWithSystemd})`),!a.ok&&a.stderr&&console.log(` ${a.stderr.split(`
|
|
54
|
-
`)[0]}`)}process.exit(s.passed?0:1)}
|
|
55
|
-
`)){let o=
|
|
56
|
-
`),diagnostic:ie(e)}}function
|
|
44
|
+
`),n=!0)}let o={capturedAt:new Date(e.now??Date.now()).toISOString(),skipReason:e.skipReason,runId:e.indexed.runId,workerName:e.indexed.workerName,worktreePath:e.indexed.worktreePath,taskId:e.indexed.worker.taskId,agentOsId:e.indexed.worker.agentOsId,branch:e.indexed.worker.branch,completionBlocker:e.indexed.worker.completionBlocker,finalResult:e.status.finalResult,changedFiles:e.status.changedFiles,gitAncestry:e.status.gitAncestry,prUrl:e.status.prUrl??null,...n?{patchPath:t}:{}};return jh(pa.join(r,"evidence.json"),`${JSON.stringify(o,null,2)}
|
|
45
|
+
`),o}var RP=new Set(["completion_blocked","dirty_worktree","pr_or_unmerged_commits","landing_blocked"]);function bP(e){return!RP.has(e.skipReason)||vr(e.indexed,e.now)?!1:Yh({harnessRoot:e.harnessRoot,runId:e.indexed.runId,workerName:e.indexed.workerName})?!0:e.writeSalvageEvidence?(Jh({harnessRoot:e.harnessRoot,indexed:e.indexed,skipReason:e.skipReason,status:e.status,now:e.now}),!0):!1}function vP(e){let{indexed:r,worktreesAgeMs:t,terminalWorktreesAgeMs:n}=e;return r&&(yr.has(r.run.status)||e.liveness&&qu(r,e.liveness)||e.liveness&&oe(Yu(r,e.liveness))&&!vr(r))?n:t}function SP(e){return!e.indexed||e.includeOrphans&&e.worktreesAgeMs<=0?0:vP(e)}function CP(e,r){if(e.harnessRoot?.trim())return ma.resolve(e.harnessRoot);let t=r.worker.workerDir;if(!t)return null;let n=`${ma.sep}runs${ma.sep}`,o=t.indexOf(n);return o<0?null:t.slice(0,o+n.length-1)}function qh(e){let{indexed:r,includeOrphans:t,worktreesAgeMs:n,ageMs:o,orphanSafety:s,worktreeRemovalGuard:i}=e,a=e.now??Date.now();if(!r)return t?s??null:"orphan_without_flag";let l=SP(e);if(n<=0&&!t&&l<=0)return"worktrees_disabled";if(l>0&&o<l)return"below_age_threshold";if(vr(r,a))return"active_worker";let c=Yu(r,e.liveness),u=CP(e,r),d=m=>u&&bP({indexed:r,harnessRoot:u,skipReason:m,status:c,now:a,writeSalvageEvidence:e.writeSalvageEvidence===!0})?null:m;if($h(r,c)){let m=d("completion_blocked");if(m)return m}if(Gu(r,e.liveness?.gitStatusCache)){let m=d("dirty_worktree");if(m)return m}let f=e.liveness?.gitRevCache?.countAheadOfMain(e.worktreePath);if(f!=null&&f>0){let m=d("pr_or_unmerged_commits");if(m)return m}if(Kh(r,e.liveness,a)||!oe(c))return"run_still_active";if(jo(c)){let m=d("pr_or_unmerged_commits");if(m)return m}if(Te(c.changedFiles).length>0){let m=d("dirty_worktree");if(m)return m}if(Qr({finalResult:c.finalResult,changedFiles:c.changedFiles,gitAncestry:c.gitAncestry,prUrl:St(c.finalResult)}).blocked){let m=d("landing_blocked");if(m)return m}if(i&&e.worktreePath){let m=i({worktreePath:e.worktreePath,indexed:!!r,runId:r?.runId,worker:r?.workerName});if(m)return m.detail?{reason:m.reason,detail:m.detail}:m.reason}return null}function zu(e){let{indexed:r,nodeModulesAgeMs:t,ageMs:n,worktreePath:o,activeWorktreePaths:s,diskPressure:i}=e;return!i&&n<t?"below_age_threshold":s.has(ma.resolve(o))||r&&vr(r)?"active_worker":r&&Gu(r,e.gitStatusCache)?"dirty_worktree":null}function zh(e){return zu(e)}var Go=216e5,Yo=6048e5,fa=216e5,ga=36e5,ha=120;var Xh=new Set(["active_worker","run_still_active","completion_blocked","landing_blocked"]);function Qh(e,r){let t=[],n=new Set,o=(s,i,a)=>{let l=`${s}\0${i}`;n.has(l)||t.length>=24||(n.add(l),t.push({path:s,reason:i,...a?{detail:a}:{}}))};for(let s of r)Xh.has(s.reason)&&o(s.path,s.reason,s.detail);for(let s of e)!s.skipped||!s.skipReason||Xh.has(s.skipReason)&&o(s.path,s.skipReason);return t}import{existsSync as tk,readdirSync as nk,statSync as xP}from"node:fs";import ok from"node:path";D();Ce();import Zh from"node:path";C();function _P(e,r){return da(e,r)}function ek(e,r=Date.now()){let t=new Set,n=new Set;for(let o of e){for(let s of Ns(o)){let i=!1;for(let a of Object.keys(s.workers||{})){let l=w(Zh.join(zn(o,s.id),"workers",v(a),"worker.json"),void 0);if(!l?.worktreePath)continue;let c=Zh.resolve(l.worktreePath);_P(l,r)&&(i=!0,t.add(c))}i&&n.add(`${o}\0${s.id}`)}for(let s of Wu(o))n.add(s)}return{activeWorktreePaths:t,liveRunKeys:n}}function rk(e,r,t,n){return t?n.has(`${r}\0${t}`):!1}C();function EP(e,r){try{let t=xP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function PP(e,r){let t=ok.join(e,"runs",r,"run.json");return tk(t)?w(t,null):null}function sk(e){try{return nk(e).length===0}catch{return!1}}function ik(e){let{harnessRoot:r,runId:t,runPath:n,ageMs:o,runDirectoriesAgeMs:s,activeGuards:i}=e;if(rk(n,r,t,i.liveRunKeys)||!sk(n))return"run_still_active";let a=PP(r,t);return a&&!yr.has(a.status)&&!Rt(a)?"run_still_active":s>0&&o<s?"below_age_threshold":null}function ak(e){if(!tk(e.worktreesDir))return[];let r=[],t;try{t=nk(e.worktreesDir,{withFileTypes:!0})}catch{return[]}for(let n of t){if(!n.isDirectory())continue;let o=n.name;if(e.runIdFilter&&o!==e.runIdFilter)continue;let s=ok.join(e.worktreesDir,o);sk(s)&&r.push({kind:"remove_run_directory",path:s,bytes:null,harnessRoot:e.harnessRoot,runId:o,ageMs:EP(s,e.now)})}return r}Pe();import{existsSync as Qu,rmSync as kk}from"node:fs";import{existsSync as NP,rmSync as TP}from"node:fs";Ce();import{lstatSync as AP,readdirSync as OP}from"node:fs";function lk(e){try{let r=AP(e),t=typeof process.getuid=="function"?process.getuid():null,n=typeof process.getgid=="function"?process.getgid():null,o=t!==null&&(r.uid!==t||n!==null&&r.gid!==n);return{uid:r.uid,gid:r.gid,foreign:o}}catch{return null}}function ck(e,r=32){let t=lk(e);if(!t)return!1;if(t.foreign)return!0;try{let n=OP(e),o=0;for(let s of n){if(o>=r)break;let i=`${e.replace(/\/$/,"")}/${s}`,a=lk(i);if(o+=1,a?.foreign)return!0}}catch{}return!1}import{spawnSync as IP}from"node:child_process";import pk from"node:path";import De from"node:path";function uk(e,r,t,n){let o=De.resolve(e),s=`${De.sep}${n}`,i=o.endsWith(s)?o:null;if(!i)return"path_outside_harness";let a=De.relative(t,i);if(a.startsWith("..")||De.isAbsolute(a))return"path_outside_harness";let l=a.split(De.sep);return l.length<3||l[l.length-1]!==n||!o.startsWith(De.resolve(r))?"path_outside_harness":null}function ka(e,r,t){return uk(e,r,t,"node_modules")}function ya(e,r,t){return uk(e,r,t,".next")}function Ra(e,r,t){let n=De.resolve(e),o=De.relative(t,n);return o.startsWith("..")||De.isAbsolute(o)||o.split(De.sep).length<3||!n.startsWith(De.resolve(r))?"path_outside_harness":null}function dk(e,r,t){let n=De.resolve(e);return ka(n,r,t)===null||ya(n,r,t)===null||Ra(n,r,t)===null}function fk(){let e=(process.env.KYNVER_CLEANUP_PRIVILEGED??"auto").trim().toLowerCase();return e==="0"||e==="false"||e==="off"||e==="no"?"off":e==="1"||e==="true"||e==="force"||e==="yes"?"force":"auto"}function mk(e){let r=IP("sudo",["-n",...e],{encoding:"utf8",stdio:["ignore","pipe","pipe"]});return{ok:r.status===0,stderr:`${r.stderr??""}${r.stdout??""}`.trim()}}function gk(e,r,t){if(!dk(e,r,t))return{ok:!1,error:"path is not an allowed harness generated cache"};let n=typeof process.getuid=="function"?process.getuid():null,o=typeof process.getgid=="function"?process.getgid():null;if(n===null||o===null)return{ok:!1,error:"privileged reclaim requires POSIX uid/gid"};let s=mk(["chown","-R",`${n}:${o}`,pk.resolve(e)]);if(s.ok)return{ok:!0,method:"chown_then_rm"};let i=mk(["rm","-rf",pk.resolve(e)]);return i.ok?{ok:!0,method:"sudo_rm"}:{ok:!1,error:s.stderr||i.stderr||"sudo -n failed (password required or not permitted)"}}var Xu="Root-owned harness caches require operator reclaim: configure passwordless sudo for chown/rm under ~/.kynver/harness/worktrees, or run `node scripts/reclaim-harness-root-owned-cache.mjs --execute` as the harness owner with sudo available. See docs/runbooks/harness-root-owned-cache-reclaim.md.";function DP(e){let r=e?.code;return r==="EACCES"||r==="EPERM"}function hk(e,r,t={}){if(!NP(e.path))return{executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{executed:!1,skipped:!0,skipReason:"dry_run"};let n=e.harnessRoot,o=n?dr(n):null,i=e.bytes??br(e.path)??void 0,a=t.removePath??TP,l=t.hasForeignOwnedEntry??ck;try{return a(e.path,{recursive:!0,force:!0}),{executed:!0,skipped:!1,bytes:i}}catch(c){if(!DP(c)||!n||!o)return{executed:!1,skipped:!0,skipReason:"remove_failed",error:c.message};let u=l(e.path),d=fk();if(!(d==="force"||d==="auto"&&u))return u?{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${c.message}; ${Xu}`}:{executed:!1,skipped:!0,skipReason:"remove_failed",error:c.message};let p=gk(e.path,n,o);if(p.ok&&p.method==="sudo_rm")return{executed:!0,skipped:!1,bytes:i,privilegedReclaim:!0};if(p.ok)try{return a(e.path,{recursive:!0,force:!0}),{executed:!0,skipped:!1,bytes:i,privilegedReclaim:!0}}catch(m){return{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${m.message}; privileged chown succeeded but rm still failed`}}return{executed:!1,skipped:!0,skipReason:"foreign_owner",error:`${c.message}; privileged reclaim failed: ${p.error}; ${Xu}`}}}function Zu(e){let r=e.harnessRoot;return!r||!Tu(e.path,r)?null:{...e,executed:!1,skipped:!0,skipReason:"run_metadata_protected"}}function ed(e,r){let t=Zu(e);if(t)return t;let n=hk(e,r);return{...e,bytes:n.bytes??e.bytes,executed:n.executed,skipped:n.skipped,skipReason:n.skipReason,error:n.error}}function yk(e,r){return ed(e,r)}function Rk(e,r){return ed(e,r)}function bk(e,r){return ed(e,r)}function vk(e,r){let t=Zu(e);if(t)return t;if(!Qu(e.path))return{...e,executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{...e,executed:!1,skipped:!0,skipReason:"dry_run"};try{let n=e.bytes??br(e.path);return kk(e.path,{recursive:!0,force:!0}),{...e,bytes:n,executed:!0,skipped:!1}}catch(n){return{...e,executed:!1,skipped:!0,skipReason:"remove_failed",error:n.message}}}function Sk(e,r){let t=Zu(e);if(t)return t;if(!Qu(e.path))return{...e,executed:!1,skipped:!0,skipReason:"missing_worktree"};if(!r)return{...e,executed:!1,skipped:!0,skipReason:"dry_run"};let n=e.repo;try{let o=e.bytes??br(e.path);return n&&me(n,["worktree","remove","--force",e.path],{allowFailure:!0}),Qu(e.path)&&kk(e.path,{recursive:!0,force:!0}),{...e,bytes:o,executed:!0,skipped:!1}}catch(o){return{...e,executed:!1,skipped:!0,skipReason:"remove_failed",error:o.message}}}import{existsSync as ba,readdirSync as va,statSync as MP}from"node:fs";import or from"node:path";function rd(e,r){try{let t=MP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function wk(e,r){let t=or.relative(r,e);return t===""||!t.startsWith("..")&&!or.isAbsolute(t)}function Ck(e,r,t,n){let o=[];for(let s of ua){if(s===".next")continue;let i=or.join(e,s);if(!ba(i))continue;let a=or.resolve(i);t.has(a)||wk(a,r.harnessRoot)&&(t.add(a),o.push({kind:"remove_build_cache",path:a,bytes:null,runId:n.runId,worker:n.worker,repo:n.repo,ageMs:rd(a,r.now)}))}return o}function _k(e){let r=[],t=new Set;for(let n of e.index.values())e.runIdFilter&&n.runId!==e.runIdFilter||r.push(...Ck(n.worktreePath,e,t,{runId:n.runId,worker:n.workerName,repo:n.run.repo}));if(!e.includeOrphans||!ba(e.worktreesDir))return r;for(let n of va(e.worktreesDir,{withFileTypes:!0})){if(!n.isDirectory())continue;let o=or.join(e.worktreesDir,n.name);for(let s of va(o,{withFileTypes:!0})){if(!s.isDirectory())continue;let i=or.join(o,s.name);r.push(...Ck(i,e,t,{runId:n.name,worker:s.name}))}}return r}function xk(e){let r=e.worktreesAgeMs>0||e.includeOrphans,t=e.includeOrphans;if(!r&&!t)return[];let n=[],o=new Set;if(r)for(let i of e.index.values()){if(e.runIdFilter&&i.runId!==e.runIdFilter)continue;let a=i.worktreePath;ba(a)&&(o.has(a)||(o.add(a),n.push({kind:"remove_worktree",path:a,bytes:null,runId:i.runId,worker:i.workerName,repo:i.run.repo,ageMs:rd(a,e.now)})))}if(!t||!ba(e.worktreesDir))return n;let s=new Set;for(let i of e.index.values())s.add(or.resolve(i.worktreePath));for(let i of va(e.worktreesDir,{withFileTypes:!0})){if(!i.isDirectory()||e.runIdFilter&&i.name!==e.runIdFilter)continue;let a=or.join(e.worktreesDir,i.name),l;try{l=va(a,{withFileTypes:!0})}catch{continue}for(let c of l){if(!c.isDirectory())continue;let u=or.resolve(or.join(a,c.name));o.has(u)||s.has(u)||wk(u,e.harnessRoot)&&(o.add(u),n.push({kind:"remove_worktree",path:u,bytes:null,runId:i.name,worker:c.name,ageMs:rd(u,e.now)}))}}return n}import{existsSync as Ak,readdirSync as Ek,statSync as UP}from"node:fs";import xn from"node:path";var WP=[{dirName:"node_modules",kind:"remove_node_modules"},{dirName:".next",kind:"remove_next_cache"}];function LP(e,r){try{let t=UP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function BP(e,r){let t=xn.relative(r,e);return t===""||!t.startsWith("..")&&!xn.isAbsolute(t)}function HP(e,r,t,n,o,s){if(!Ak(n))return;let i=xn.resolve(n);r.has(i)||BP(i,t.harnessRoot)&&(r.add(i),e.push({kind:o,path:i,bytes:null,harnessRoot:t.harnessRoot,runId:s.runId,worker:s.worker,repo:s.repo,ageMs:LP(i,t.now)}))}function Pk(e,r,t,n,o){for(let s of WP)HP(e,r,t,xn.join(n,s.dirName),s.kind,o)}function Ok(e){let r=[],t=new Set;for(let n of e.index.values())e.runIdFilter&&n.runId!==e.runIdFilter||Pk(r,t,e,n.worktreePath,{runId:n.runId,worker:n.workerName,repo:n.run.repo});if(!e.includeOrphans||!Ak(e.worktreesDir))return r;for(let n of Ek(e.worktreesDir,{withFileTypes:!0})){if(!n.isDirectory()||e.runIdFilter&&n.name!==e.runIdFilter)continue;let o=xn.join(e.worktreesDir,n.name),s;try{s=Ek(o,{withFileTypes:!0})}catch{continue}for(let i of s){if(!i.isDirectory())continue;let a=xn.join(o,i.name);Pk(r,t,e,a,{runId:n.name,worker:i.name})}}return r}Pe();import{existsSync as Ik,statSync as FP}from"node:fs";import sr from"node:path";function KP(e,r){try{let t=FP(e).mtimeMs;return Math.max(0,r-t)}catch{return 0}}function $P(e){let r=[],t=null;for(let n of e.split(`
|
|
46
|
+
`)){if(!n.trim())continue;let[o,...s]=n.split(" "),i=s.join(" ");if(o==="worktree"){t&&r.push(t),t={path:i};continue}t&&(o==="branch"&&(t.branch=i),o==="HEAD"&&(t.head=i),o==="bare"&&(t.bare=!0))}return t&&r.push(t),r}function jP(e,r){let t=sr.relative(sr.resolve(r),sr.resolve(e));return t!==""&&!t.startsWith("..")&&!sr.isAbsolute(t)}var VP=200;function Nk(e){if(!e.includeOrphans||!Ik(e.worktreesDir))return[];let r=new Set;for(let s of e.index.values())s.run.repo&&r.add(sr.resolve(s.run.repo));let t=new Set;for(let s of e.index.values())t.add(sr.resolve(s.worktreePath));let n=[],o=new Set;for(let s of r){let i=0,a;try{a=me(s,["worktree","list","--porcelain"],{allowFailure:!0})}catch{continue}let l=$P(a);for(let c of l){if(i>=VP)break;let u=sr.resolve(c.path);if(u===sr.resolve(s)||!jP(u,e.worktreesDir)||t.has(u)||o.has(u)||!Ik(u))continue;let f=sr.relative(e.worktreesDir,u).split(sr.sep),p=f[0],m=f[1]??"unknown";o.add(u),i+=1,n.push({kind:"remove_worktree",path:u,bytes:null,runId:p,worker:m,repo:s,ageMs:KP(u,e.now)})}}return n}D();C();import Jo from"node:path";function Tk(e,r){let t=Jo.resolve(r),n=new Map;for(let[o,s]of e){let i=s.harnessRoot?Jo.resolve(s.harnessRoot):null;i&&i!==t||n.set(o,s)}return n}function Dk(e){let r=new Map;for(let t of Ns(e))for(let n of Object.keys(t.workers||{})){let o=Jo.join(zn(e,t.id),"workers",v(n),"worker.json"),s=w(o,void 0);s?.worktreePath&&r.set(Jo.resolve(s.worktreePath),{harnessRoot:e,worktreePath:Jo.resolve(s.worktreePath),runId:t.id,workerName:n,run:t,worker:s})}return r}function qo(e){let r=process.env[e];return r==="1"||r==="true"||r==="yes"}function Ct(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)&&n>=0?n:r}function td(e={}){let r=e.execute===!0||e.execute!==!1&&qo("KYNVER_CLEANUP_EXECUTE"),t=e.finalizeStaleRuns!==!1&&!qo("KYNVER_CLEANUP_SKIP_FINALIZE"),n=e.nodeModulesAgeMs??Ct("KYNVER_CLEANUP_NODE_MODULES_AGE_MS",216e5),o=e.scanDependencyCaches??(e.nodeModulesAgeMs!==void 0||process.env.KYNVER_CLEANUP_NODE_MODULES_AGE_MS!=null),s=e.worktreesAgeMs??Ct("KYNVER_CLEANUP_WORKTREES_AGE_MS",0),i=e.terminalWorktreesAgeMs??Ct("KYNVER_CLEANUP_TERMINAL_WORKTREES_AGE_MS",216e5),a=e.runDirectoriesAgeMs??Ct("KYNVER_CLEANUP_RUN_DIRECTORIES_AGE_MS",36e5),l=e.maxActionsPerSweep??Ct("KYNVER_CLEANUP_MAX_ACTIONS_PER_SWEEP",120),c=e.includeOrphans===!0||qo("KYNVER_CLEANUP_INCLUDE_ORPHANS"),d=qo("KYNVER_CLEANUP_SCOPE_ALL")||process.env.KYNVER_CLEANUP_SCOPE==="all"?e.runIdFilter:e.runIdFilter??(process.env.KYNVER_CLEANUP_RUN_ID||void 0),f=e.accountBytes!==!1&&!qo("KYNVER_CLEANUP_SKIP_BYTE_ACCOUNTING"),p=Ct("KYNVER_CLEANUP_STORAGE_ENTRY_CAP",2e3),m=e.storagePerRunEntryCap!==void 0?e.storagePerRunEntryCap:f&&p>0?p:null,h=Ct("KYNVER_CLEANUP_BYTE_ENTRY_CAP",2e3),k=e.byteAccountingEntryCap??(Number.isFinite(h)&&h>0?Math.floor(h):2e3);return{execute:r,finalizeStaleRuns:t,scanDependencyCaches:o,nodeModulesAgeMs:n,worktreesAgeMs:s>0?s:0,terminalWorktreesAgeMs:i>=0?i:0,runDirectoriesAgeMs:a>=0?a:0,maxActionsPerSweep:Number.isFinite(l)&&l>0?Math.floor(l):120,includeOrphans:c,runIdFilter:d?String(d):void 0,accountBytes:f,storagePerRunEntryCap:m,byteAccountingEntryCap:k}}function Mk(e){let r=process.env.KYNVER_CLEANUP_SCOPE==="all",t=Number(process.env.KYNVER_CLEANUP_WORKTREES_AGE_MS),n=r?Number.isFinite(t)&&t>0?t:6048e5:Number.isFinite(t)&&t>0?t:0;return td({runIdFilter:r?void 0:e,worktreesAgeMs:n,terminalWorktreesAgeMs:r?216e5:void 0,runDirectoriesAgeMs:r?36e5:void 0,includeOrphans:r?!0:void 0,finalizeStaleRuns:!0,accountBytes:!0,scanDependencyCaches:!0})}Pe();import{existsSync as Uk}from"node:fs";import nd from"node:path";C();var GP=1800*1e3;function od(e){let r=e.now??Date.now(),t=e.heartbeatFreshMs??GP;if(!Uk(e.worktreePath))return null;if(e.runId&&e.workerName){let c=nd.join(e.harnessRoot,"runs",e.runId,"workers",e.workerName),u=w(nd.join(c,"worker.json"),void 0);if(u&&Ju(u,r,t))return"active_worker"}let n=nd.join(e.worktreePath,".git");if(!Uk(n))return null;let o=ne(e.worktreePath,["status","--porcelain"]);if(o.status!==0)return"pr_or_unmerged_commits";let s=o.stdout.split(`
|
|
47
|
+
`).map(c=>c.trim()).filter(c=>c.length>0);if(Te(s).length>0)return"dirty_worktree";let i=ne(e.worktreePath,["rev-list","--count","@{u}..HEAD"]);if(i.status===0){let c=Number(i.stdout.trim());if(Number.isFinite(c)&&c>0)return"pr_or_unmerged_commits"}let a=ne(e.worktreePath,["rev-list","--count","origin/main..HEAD"]);if(a.status!==0)return i.status!==0?"pr_or_unmerged_commits":null;let l=Number(a.stdout.trim());return Number.isFinite(l)&&l>0?"pr_or_unmerged_commits":null}Ce();import{existsSync as YP}from"node:fs";import{homedir as JP}from"node:os";import Wk from"node:path";var qP=["/var/tmp/kynver-harness",Wk.join(JP(),".openclaw","harness")];function sd(e,r,t){if(!t?.trim())return;let n=le(t.trim());e.has(n)||(e.add(n),r.push(n))}function zP(e){return e.scanWellKnown!=null?e.scanWellKnown:process.env.VITEST==="true"?!1:process.env.KYNVER_CLEANUP_SCAN_WELL_KNOWN!=="0"&&!["0","false","no"].includes((process.env.KYNVER_CLEANUP_SCAN_WELL_KNOWN??"").toLowerCase())}function Lk(e={}){let r=new Set,t=[];sd(r,t,e.harnessRoot??fe());let n=process.env.KYNVER_CLEANUP_EXTRA_ROOTS?.split(",").map(o=>o.trim()).filter(Boolean);for(let o of n??[])sd(r,t,o);if(zP(e))for(let o of qP){let s=Wk.resolve(o);!r.has(s)&&YP(s)&&sd(r,t,s)}return t}Gt();function XP(e){let r=process.env[e];return r==="1"||r==="true"||r==="yes"}function QP(e,r){let t=process.env[e];if(!t)return r;let n=Number(t);return Number.isFinite(n)?n:r}function Bk(e={}){let r=e.diskPath?.trim()||process.env.KYNVER_DISK_GUARD_PATH?.trim()||"/",t=QP("KYNVER_DISK_GUARD_MAX_USED_PERCENT",75),n=Le({...e,diskPath:r,diskMaxUsedPercent:e.diskMaxUsedPercent??t}),o=!n.ok||n.usedPercent>=t,s=process.env.KYNVER_CLEANUP_DISK_PRESSURE_FORCE?.trim().toLowerCase();return s==="none"||s==="off"||s==="0"?o=!1:(s==="pressured"||s==="on"||s==="1")&&(o=!0),{diskGate:n,pressured:o,maxUsedPercent:t}}function Hk(e,r){if(!r.pressured)return e;let t=e.execute||!XP("KYNVER_CLEANUP_DRY_RUN_ON_PRESSURE");return{...e,execute:t,nodeModulesAgeMs:0,runIdFilter:void 0,includeOrphans:!0,terminalWorktreesAgeMs:0,runDirectoriesAgeMs:0,worktreesAgeMs:e.worktreesAgeMs>0?e.worktreesAgeMs:6048e5,diskPressure:!0,diskGate:r.diskGate}}Vt();function Me(e,r){if(process.env.KYNVER_CLEANUP_QUIET==="1")return;let t=r?`: ${r}`:"";console.error(`[kynver cleanup] ${e}${t}`)}Pe();var Sa=class{aheadOfMain=new Map;countAheadOfMain(r,t="origin/main"){let n=`${r}\0${t}`;if(this.aheadOfMain.has(n))return this.aheadOfMain.get(n)??null;let o=ne(r,["rev-list","--count",`${t}..HEAD`]);if(o.status!==0)return this.aheadOfMain.set(n,null),null;let s=Number(o.stdout.trim()),i=Number.isFinite(s)?s:null;return this.aheadOfMain.set(n,i),i}};import{spawnSync as ZP}from"node:child_process";import{existsSync as eA}from"node:fs";import rA from"node:path";var tA=5e3;function nA(e,r){if(!eA(rA.join(e,".git")))return{status:null,stdout:"",stderr:"",error:"not_a_git_repo"};try{let t=ZP("git",r,{cwd:e,encoding:"utf8",timeout:tA}),n=t.error?.message?.includes("ETIMEDOUT")===!0;return{status:n?null:t.status,stdout:t.stdout||"",stderr:t.stderr||"",error:n?"git_timeout":t.error?t.error.message:null}}catch(t){return{status:null,stdout:"",stderr:"",error:t.message}}}function Fk(e){let r=nA(e,["status","--short"]);return r.error==="not_a_git_repo"?[]:r.error==="git_timeout"||r.status!==0?null:r.stdout.split(`
|
|
48
|
+
`).map(t=>t.trim()).filter(Boolean)}var Ca=class{cache=new Map;porcelain(r){let t=r,n=this.cache.get(t);if(n!==void 0)return n;let o=Fk(t)??[];return this.cache.set(t,o),o}};var wa=class{cache=new Map;derive(r){let t=this.cache.get(r.id);if(t!==void 0)return t;let n=Rt(r);return this.cache.set(r.id,n),n}};function oA(e){let r={};for(let t of e)r[t.kind]=(r[t.kind]??0)+1;return r}function Kk(e,r={}){let t=r.maxSampleActions??12,n=r.maxSampleSkips??8;return{harnessRoot:e.harnessRoot,scanRoots:e.scanRoots,dryRun:e.dryRun,execute:e.execute,scannedAt:e.scannedAt,finalizedRuns:e.finalizedRuns.length,actionCount:e.actions.length,actionKinds:oA(e.actions),totals:e.totals,...e.storage?{storage:e.storage}:{},...e.preservedLivePaths?.length?{preservedLivePaths:e.preservedLivePaths}:{},...e.removedRunDirectories!=null?{removedRunDirectories:e.removedRunDirectories}:{},sampleActions:e.actions.slice(0,t).map(o=>({kind:o.kind,path:o.path,...o.skipReason?{skipReason:o.skipReason}:{},...o.bytes!=null?{bytes:o.bytes}:{},...o.runId?{runId:o.runId}:{},...o.worker?{worker:o.worker}:{}})),sampleSkips:e.skips.slice(0,n)}}function sA(e={}){let r=e.harnessRoot?le(e.harnessRoot):fe(),t=Lk({harnessRoot:r}),n=e.now??Date.now();return{harnessRoot:r,scanRoots:t,now:n}}function iA(e){return typeof e=="string"?{reason:e}:e}function En(e,r,t,n){e.push({path:r,reason:t,...n?{detail:n}:{}})}function _a(e,r,t){return!r||e.bytes!=null?e:{...e,bytes:br(e.path,t)}}function $k(e,r){let t={};for(let n of r)t[n.reason]=(t[n.reason]??0)+1;for(let n of e)n.skipReason&&(t[n.skipReason]=(t[n.skipReason]??0)+1);return t}function aA(e,r){return e.kind==="remove_next_cache"?Rk(e,r):yk(e,r)}function lA(e,r,t){return e.kind==="remove_next_cache"?ya(e.path,r,t):ka(e.path,r,t)}function cA(e){let r=new Map;for(let t of e)for(let[n,o]of Dk(t))r.set(n,o);return r}function jk(e,r){return e.runId&&e.worker?Ue.join(r,e.runId,e.worker):Ue.resolve(e.path,"..")}function xa(e={}){let r=td(e),t=Bk();r=Hk(r,t);let n=sA(e);Me("scan",`${n.scanRoots.length} harness root(s)`);let o=ek(n.scanRoots,n.now),s=r.finalizeStaleRuns?Ko().map(O=>({runId:O.runId,from:O.from,to:O.to})):[];s.length>0&&Me("finalize",`${s.length} stale run(s) marked terminal`),Me("index","building worktree index");let i=cA(n.scanRoots);Me("index",`${i.size} indexed worktree(s)`);let a={runTerminalCache:new wa,gitStatusCache:new Ca,gitRevCache:new Sa},l=[],c=[],u=new Set,d=r.maxActionsPerSweep,f=()=>c.length>=d;for(let O of n.scanRoots){if(f())break;Me("root",O);let B=Ue.join(O,"worktrees"),Kr=Tk(i,O),Q={harnessRoot:O,worktreesDir:B,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,runIdFilter:r.runIdFilter,index:Kr,now:n.now},Cr=r.scanDependencyCaches?Ok(Q):[];Me("dependency",r.scanDependencyCaches?`${Cr.length} cache candidate(s) at ${O}`:"skipped (worktree-only sweep)");let Dt=0;for(let be of Cr){if(f())break;Dt+=1,Dt%50===0&&Me("dependency",`${Dt}/${Cr.length} evaluated`);let G=Ue.resolve(be.path);if(u.has(G))continue;u.add(G);let W={...be,path:G},ve=lA(W,O,B);if(ve){En(l,W.path,ve),c.push({...W,executed:!1,skipped:!0,skipReason:ve});continue}let xe=jk(W,B),wr=Kr.get(Ue.resolve(xe))??null,Ee=zu({indexed:wr,includeOrphans:!0,nodeModulesAgeMs:r.nodeModulesAgeMs,ageMs:W.ageMs,worktreePath:xe,activeWorktreePaths:o.activeWorktreePaths,diskPressure:r.diskPressure,gitStatusCache:a.gitStatusCache});if(Ee){En(l,W.path,Ee),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(aA(_a(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}if(r.scanDependencyCaches)for(let be of _k(Q)){if(f())break;let G=Ue.resolve(be.path);if(u.has(G))continue;u.add(G);let W={...be,path:G},ve=Ra(W.path,O,B);if(ve){En(l,W.path,ve),c.push({...W,executed:!1,skipped:!0,skipReason:ve});continue}let xe=jk(W,B),wr=Kr.get(Ue.resolve(xe))??null,Ee=zh({indexed:wr,includeOrphans:!0,nodeModulesAgeMs:r.nodeModulesAgeMs,ageMs:W.ageMs,worktreePath:xe,activeWorktreePaths:o.activeWorktreePaths,diskPressure:r.diskPressure,gitStatusCache:a.gitStatusCache});if(Ee){En(l,W.path,Ee),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(bk(_a(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}let Ve=[...xk(Q),...Nk(Q)];Me("worktrees",`${Ve.length} candidate(s) at ${O}`);let Mt=new Set,Ge=0;for(let be of Ve){if(f())break;Ge+=1,Ge%50===0&&Me("worktrees",`${Ge}/${Ve.length} evaluated`);let G=Ue.resolve(be.path);if(Mt.has(G))continue;Mt.add(G);let W={...be,path:G},ve=Kr.get(Ue.resolve(W.path))??null,xe=ve?null:od({worktreePath:W.path,harnessRoot:O,runId:W.runId,workerName:W.worker,now:n.now}),wr=qh({indexed:ve,worktreePath:Ue.resolve(W.path),includeOrphans:r.includeOrphans,worktreesAgeMs:r.worktreesAgeMs,terminalWorktreesAgeMs:r.terminalWorktreesAgeMs,ageMs:W.ageMs,orphanSafety:xe,worktreeRemovalGuard:e.worktreeRemovalGuard,liveness:a,now:n.now,harnessRoot:O,writeSalvageEvidence:r.execute});if(wr){let{reason:Ee,detail:fs}=iA(wr);En(l,W.path,Ee,fs),c.push({...W,executed:!1,skipped:!0,skipReason:Ee});continue}c.push(Sk(_a(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}if(!f()&&r.runDirectoriesAgeMs>=0)for(let be of ak({harnessRoot:O,worktreesDir:B,runDirectoriesAgeMs:r.runDirectoriesAgeMs,runIdFilter:r.runIdFilter,activeGuards:o,now:n.now})){if(f())break;let G=Ue.resolve(be.path);if(u.has(G))continue;u.add(G);let W={...be,path:G},ve=W.runId??Ue.basename(G),xe=ik({harnessRoot:O,runId:ve,runPath:G,ageMs:W.ageMs,runDirectoriesAgeMs:r.runDirectoriesAgeMs,activeGuards:o});if(xe){En(l,W.path,xe),c.push({...W,executed:!1,skipped:!0,skipReason:xe});continue}c.push(vk(_a(W,r.accountBytes,r.byteAccountingEntryCap),r.execute))}}let p=0,m=0,h=0,k=0,g=0,y=0;for(let O of c)O.bytes&&(p+=O.bytes),!O.skipped&&!O.executed&&O.bytes&&(h+=O.bytes),O.executed?(g+=1,k+=O.bytes??0,O.kind==="remove_run_directory"&&(m+=1)):O.skipped&&(y+=1,O.skipReason==="dry_run"&&O.bytes&&(h+=O.bytes));let _=r.accountBytes?ju({harnessRoot:n.harnessRoot,now:n.now,perRunEntryCap:r.storagePerRunEntryCap}):void 0,x=ur(),E=r.execute&&mu(x),A=E?Uo({execute:!0}):null,Y=x?{observed:!0,execute:E,dumpCount:x.dumpCount,totalBytes:x.totalBytes,removedCount:A?.removed.length??0,removedBytes:A?.removedBytes??0,executables:x.executables,path:x.path,reason:x.reason}:void 0;A&&A.removed.length>0&&(k+=A.removedBytes,g+=A.removed.length,Me("wsl-crashes",`removed ${A.removed.length} dump(s), ${A.removedBytes} bytes`)),Me("complete",`${c.length} action(s), ${y} skipped, ${g} removed`);let $=Qh(c,l),F=Kk({harnessRoot:n.harnessRoot,scanRoots:n.scanRoots,dryRun:!r.execute,execute:r.execute,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,diskPressure:r.diskPressure,diskGate:r.diskGate?{ok:r.diskGate.ok,path:r.diskGate.path,freeBytes:r.diskGate.freeBytes,usedPercent:r.diskGate.usedPercent,reason:r.diskGate.reason}:void 0,scannedAt:new Date(n.now).toISOString(),finalizedRuns:s,actions:c,skips:l,totals:{candidateBytes:p,reclaimableBytes:h,removedBytes:k,removedPaths:g,skippedPaths:y,skipReasons:$k(c,l)},..._?{storage:_}:{},...$.length>0?{preservedLivePaths:$}:{},...m>0?{removedRunDirectories:m}:{},...Y?{wslCrashDumps:Y}:{}});return{harnessRoot:n.harnessRoot,scanRoots:n.scanRoots,dryRun:!r.execute,execute:r.execute,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,diskPressure:r.diskPressure,diskGate:r.diskGate?{ok:r.diskGate.ok,path:r.diskGate.path,freeBytes:r.diskGate.freeBytes,usedPercent:r.diskGate.usedPercent,reason:r.diskGate.reason}:void 0,scannedAt:new Date(n.now).toISOString(),finalizedRuns:s,actions:c,skips:l,totals:{candidateBytes:p,reclaimableBytes:h,removedBytes:k,removedPaths:g,skippedPaths:y,skipReasons:$k(c,l)},..._?{storage:_}:{},...$.length>0?{preservedLivePaths:$}:{},...m>0?{removedRunDirectories:m}:{},...Y?{wslCrashDumps:Y}:{},compactSummary:F}}function id(e){let r=Mk(e);return xa({execute:r.execute,finalizeStaleRuns:r.finalizeStaleRuns,accountBytes:r.accountBytes,nodeModulesAgeMs:r.nodeModulesAgeMs,worktreesAgeMs:r.worktreesAgeMs,includeOrphans:r.includeOrphans,runIdFilter:r.runIdFilter})}function ad(){return process.env.KYNVER_PIPELINE_CLEANUP!=="0"}N();import{mkdirSync as Ob,realpathSync as Ib}from"node:fs";import{fileURLToPath as RT}from"node:url";N();C();Ql();import uA from"node:os";function dA(e){let r=(typeof e.apiBaseUrl=="string"?e.apiBaseUrl:void 0)||(typeof e.baseUrl=="string"?e.baseUrl:void 0)||process.env.KYNVER_API_URL||R().apiBaseUrl;return r?ar(String(r)):void 0}async function pA(e,r){let t=await fetch(`${e}/api/agent-os`,{headers:{Authorization:`Bearer ${r}`}});if(!t.ok)return null;let n=await t.json().catch(()=>null);if(!n?.primarySlug)return null;let o=n.items?.find(s=>s.slug===n.primarySlug);return o?.id&&o.slug?{id:o.id,slug:o.slug}:{id:"",slug:n.primarySlug}}async function Ea(e){let r=dA(e);r||(console.error("kynver bootstrap requires a Kynver URL \u2014 pass --api-base-url https://your-kynver-site or set KYNVER_API_URL."),process.exit(1)),se()||(typeof e.apiKey=="string"?po(e.apiKey):(await Xl({...e,apiBaseUrl:r})).ok||process.exit(1));let t=se();t||(console.error("No API key after login \u2014 aborting."),process.exit(1));let n=await pA(r,t);n||(console.error("Could not resolve your AgentOS workspace from the account. Confirm this account has AgentOS access, then retry."),process.exit(1));let o={...e,apiBaseUrl:r,agentOsSlug:n.slug,...n.id?{agentOsId:n.id}:{},...typeof e.repo=="string"?{}:{discoverRepo:!0}};await oi(o),console.log(""),console.log(` Bootstrap complete \u2014 ${uA.hostname()} is linked to workspace "${n.slug}".`),console.log(" Next: `kynver start` \u2014 brings the agent online with Kynver-owned keeper supervision + local Kynver Cron when needed."),console.log(" Persistent background (Linux): `kynver start --install-systemd` or `kynver cron install --install-systemd`."),console.log(" (Advanced: `kynver run create --repo /path/to/repo` + `kynver daemon --run <RUN_ID> --agent-os-id <AOS_ID> --execute`.)")}N();import BI from"node:os";N();Je();N();import mA from"node:path";import{homedir as fA}from"node:os";var ld=mA.join(fA(),".kynver","config.json");function zo(e){let r=R(),t=oa({...e,config:r});if(!t)return{ok:!1,remediated:!1,alreadyPersisted:!1,configPath:q(ld),resolved:null,reason:"No Kynver git checkout found. Clone the repo, cd into it, then run `kynver setup --repo /path/to/Kynver` (or export KYNVER_DEFAULT_REPO).",remediation:"Clone the Kynver monorepo, cd into it, then run `kynver config ensure-default-repo` (or `kynver setup --repo /path/to/Kynver`)."};if(t.persistedInConfig)return{ok:!0,remediated:!1,alreadyPersisted:!0,configPath:q(ld),resolved:vn(t),config:ln(r)};let n=sa(t.repo,r),o=vn({...t,persistedInConfig:!0,source:"config"});return{ok:!0,remediated:!0,alreadyPersisted:!1,configPath:q(ld),resolved:o,config:ln(n),remediation:"defaultRepo persisted in ~/.kynver/config.json \u2014 `kynver run create` no longer requires --repo."}}function Vk(e=!1){let r=zo();if(e){console.log(JSON.stringify(r,null,2)),r.ok||(process.exitCode=1);return}if(!r.ok){console.error(r.reason??"Could not resolve a Kynver git checkout."),r.remediation&&console.error(r.remediation),process.exitCode=1;return}if(r.alreadyPersisted){console.log(`defaultRepo already set (${r.resolved?.defaultRepo??"unknown"}) in ${r.configPath}`);return}console.log(`Persisted defaultRepo ${r.resolved?.defaultRepo??""} in ${r.configPath}. \`kynver run create\` can omit --repo.`)}function Gk(e){return e?e.persistedInConfig?{status:"pass"}:{status:"warn",remediation:"Run `kynver config ensure-default-repo` to persist defaultRepo in ~/.kynver/config.json (or `kynver doctor runtime-takeover --remediate-default-repo`)."}:{status:"warn",remediation:"Run `kynver config ensure-default-repo` from a Kynver checkout (or `kynver setup --repo /path/to/Kynver`)."}}N();Ie();qn();js();import gA from"node:os";function Yk(e,r){console.error(JSON.stringify({event:"daemon_identity",level:e,message:r}))}function Jk(e=R(),r=process.env){let t=Ae(r,e),n=$s({config:e,totalMemBytes:gA.totalmem(),env:r}),o=[...t.warnings],s=[];if(!e.boxKind?.trim()&&!r.KYNVER_BOX_KIND?.trim()&&o.push("boxKind is not persisted in ~/.kynver/config.json \u2014 run `kynver setup --box-kind forge|ghost` so Command Center attributes snapshots to the correct pool"),t.slugInferenceBlocked){let c=r.KYNVER_DAEMON_STRICT_IDENTITY==="1"||r.KYNVER_DAEMON_STRICT_IDENTITY==="true",u="ambiguous box identity: KYNVER_AGENT_OS_SLUG is set without KYNVER_BOX_KIND or config.boxKind; treating this host as forge";c?s.push(u):o.push(u)}let i=n.configuredMaxWorkers??n.autoCap,a=cr(t.boxKind,i);$t(t.boxKind,i)&&o.push(`Forge box maxConcurrentWorkers=${i} exceeds pool cap \u2014 using ${a}; run kynver setup --box-kind forge --max-workers 4`);let l=s.length===0;for(let c of o)Yk("warn",c);for(let c of s)Yk("error",c);return{ok:l,box:t,workerCapSource:n.workerCapSource,maxConcurrentWorkers:a,autoCap:n.autoCap,warnings:o,errors:s}}import{mkdirSync as hA,readFileSync as kA,renameSync as yA,writeFileSync as RA}from"node:fs";import{homedir as bA}from"node:os";import qk from"node:path";function zk(e){let r=e.replace(/[^A-Za-z0-9_-]/g,"_");return qk.join(bA(),".kynver",`daemon-heartbeat-${r}.json`)}function Xk(e){try{let r=zk(e.agentOsId);hA(qk.dirname(r),{recursive:!0});let t={observedAt:(e.now??new Date).toISOString(),pid:process.pid,runId:e.runId,agentOsId:e.agentOsId,...e.instructionBundleVersion?{instructionBundleVersion:e.instructionBundleVersion}:{}},n=`${r}.tmp-${process.pid}`;RA(n,JSON.stringify(t),"utf8"),yA(n,r)}catch{}}function Qk(e){try{let r=kA(zk(e),"utf8"),t=JSON.parse(r);return typeof t?.observedAt!="string"?null:t}catch{return null}}function Zk(e,r,t=Date.now()){if(!e)return!1;let n=Date.parse(e.observedAt);return Number.isNaN(n)?!0:t-n>r}function vA(e){let r=process.env[e]?.trim().toLowerCase();return r==="1"||r==="true"||r==="yes"||r==="on"}function Pn(){process.platform==="win32"&&(vA("KYNVER_DAEMON_ALLOW_NATIVE_WINDOWS")||(console.error(JSON.stringify({event:"daemon_start_blocked",reason:"native_windows_console_flash",remedy:"Run the daemon inside WSL: .\\scripts\\start-tier2-wsl.ps1 \u2014 or set KYNVER_DAEMON_ALLOW_NATIVE_WINDOWS=1 to override (flashes visible consoles)."})),process.exit(1)))}N();import{existsSync as SA}from"node:fs";import{homedir as CA}from"node:os";import wA from"node:path";function ey(e,r){let t=process.env[e]?.trim().toLowerCase();return t?t==="0"||t==="false"||t==="no"||t==="off"?!1:t==="1"||t==="true"||t==="yes"||t==="on"?!0:r:r}function Xo(e,r,t=1){let n=Number(process.env[e]);return!Number.isFinite(n)||n<t?r:Math.floor(n)}function Hr(){let e=process.env.KYNVER_CRON_STORE_PATH?.trim()||process.env.OPENCLAW_CRON_STORE_PATH?.trim();return e||wA.join(CA(),".kynver","agent-os-cron.json")}function _A(e=Hr()){let r=process.env.KYNVER_CRON_TICK_STATE_PATH?.trim();return r||`${e.replace(/\.json$/i,"")}.tick-state.json`}function xA(){let e=R();return process.env.KYNVER_API_URL?.trim()||e.apiBaseUrl?.trim()||process.env.KYNVER_CRON_FIRE_BASE_URL?.trim()||process.env.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null}function cd(){return process.env.KYNVER_CRON_SECRET?.trim()||process.env.OPENCLAW_CRON_SECRET?.trim()||process.env.KYNVER_RUNTIME_SECRET?.trim()||null}function Sr(){let e=Hr(),r=_A(e),t=xA(),n=cd(),o=!!(t&&n),s=SA(e),i=o&&(s||ey("KYNVER_CRON_TICK_FORCE",!1));return{storePath:e,statePath:r,lockPath:`${r}.lock`,fireBaseUrl:t,secret:n,tickEnabled:ey("KYNVER_CRON_TICK_ENABLED",i),tickIntervalMs:Xo("KYNVER_CRON_TICK_INTERVAL_MS",6e4,5e3),missedRunPolicy:process.env.KYNVER_CRON_MISSED_RUN_POLICY?.trim().toLowerCase()==="skip"?"skip":"catch_up",maxCatchUpPerTick:Xo("KYNVER_CRON_MAX_CATCH_UP_PER_TICK",3,0),maxRetries:Xo("KYNVER_CRON_MAX_RETRIES",3,0),retryBackoffMs:Xo("KYNVER_CRON_RETRY_BACKOFF_MS",6e4,1e3),inflightLeaseMs:Xo("KYNVER_CRON_INFLIGHT_LEASE_MS",12e4,5e3)}}function Pa(e=Sr()){return e.tickEnabled&&!!(e.fireBaseUrl&&e.secret)}function EA(e){return e.replace(/\/+$/,"")}async function ry(e){let r=e.fetchFn??fetch,t=e.entry.spec.callbackPath.startsWith("/")?e.entry.spec.callbackPath:`/${e.entry.spec.callbackPath}`,n=`${EA(e.baseUrl)}${t}`,s={source:"kynver-cron",jobId:e.jobId??e.entry.spec.dedupeKey??null,agentOsId:e.entry.spec.target.agentOsId,kind:e.entry.spec.kind,target:e.entry.spec.target,...e.entry.spec.payload!==void 0&&{payload:e.entry.spec.payload}},i=await r(n,{method:"POST",headers:He(e.secret),body:JSON.stringify(s)}),a=null;try{a=await i.json()}catch{a=null}return{ok:i.ok,status:i.status,body:a}}C();import{closeSync as PA,existsSync as ud,openSync as AA,readFileSync as OA,unlinkSync as ty,writeFileSync as IA}from"node:fs";var NA=10*6e4;function ny(e){if(!ud(e))return null;try{let r=JSON.parse(OA(e,"utf8"));if(typeof r.pid=="number"&&typeof r.at=="string")return r}catch{return null}return null}function TA(e){let r=ny(e);if(!r||!H(r.pid))return!0;let t=Date.parse(r.at);return Number.isNaN(t)?!0:Date.now()-t>NA}function oy(e){if(ud(e)&&!TA(e)){let r=ny(e);return{acquired:!1,reason:r?`held by pid ${r.pid}`:"held by another process"}}if(ud(e))try{ty(e)}catch{}try{let r=AA(e,"wx");return IA(r,JSON.stringify({pid:process.pid,at:new Date().toISOString()}),"utf8"),PA(r),{acquired:!0}}catch(r){if(r.code==="EEXIST")return{acquired:!1,reason:"concurrent acquire"};throw r}}function sy(e){try{ty(e)}catch{}}var DA=/^[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+\s+[\d*/,\-?LW#]+$/;function MA(e){return DA.test(e.trim())}function UA(e,r,t){let n=new Set;for(let o of e.split(",")){let s=o.trim();if(!s)continue;if(s==="*"){for(let d=r;d<=t;d++)n.add(d);continue}let i=/^(.+)\/(\d+)$/.exec(s),a=i?i[1]:s,l=i?Math.max(1,Number(i[2])):1;if(a==="*"){for(let d=r;d<=t;d+=l)n.add(d);continue}let c=/^(\d+)-(\d+)$/.exec(a);if(c){let d=Math.max(r,Number(c[1])),f=Math.min(t,Number(c[2]));for(let p=d;p<=f;p+=l)n.add(p);continue}let u=Number(a);Number.isInteger(u)&&u>=r&&u<=t&&n.add(u)}return n}function Qo(e,r,t,n){let o=e.trim();return o==="*"?!0:UA(o,t,n).has(r)}function WA(e,r){let t=e.trim().split(/\s+/);if(t.length!==5)return!1;let[n,o,s,i,a]=t;return Qo(n,r.getUTCMinutes(),0,59)&&Qo(o,r.getUTCHours(),0,23)&&Qo(s,r.getUTCDate(),1,31)&&Qo(i,r.getUTCMonth()+1,1,12)&&Qo(a,r.getUTCDay(),0,6)}var LA=366*24*60;function BA(e){return new Date(Date.UTC(e.getUTCFullYear(),e.getUTCMonth(),e.getUTCDate(),e.getUTCHours(),e.getUTCMinutes(),0,0))}function iy(e,r){if(!MA(e))return null;let t=BA(r);t=new Date(t.getTime()+6e4);for(let n=0;n<LA;n++){if(WA(e,t))return t;t=new Date(t.getTime()+6e4)}return null}function ay(e,r){if(e.scheduleKind==="runAt"&&e.runAt){let t=Date.parse(e.runAt);return Number.isNaN(t)?null:new Date(t).toISOString()}if(e.scheduleKind==="cron"&&e.cron){let t=iy(e.cron.trim(),r);return t?t.toISOString():null}return null}function dd(e,r){if(e.scheduleKind!=="cron"||!e.cron?.trim())return null;let t=iy(e.cron.trim(),r);return t?t.toISOString():null}import{promises as HA}from"node:fs";async function ly(e){try{return await HA.readFile(e,"utf8")}catch(r){if(r.code==="ENOENT")return null;throw r}}function FA(e){if(!e)return[];try{let r=JSON.parse(e);return Array.isArray(r.entries)?r.entries:[]}catch{return[]}}async function wt(e=Hr()){let r=await ly(e);return FA(r)}async function cy(e,r){let{mkdir:t,writeFile:n,rename:o}=await import("node:fs/promises"),{randomBytes:s}=await import("node:crypto"),{dirname:i}=await import("node:path");await t(i(e),{recursive:!0});let a=`${e}.${s(4).toString("hex")}.tmp`,l=JSON.stringify({entries:r},null,2);await n(a,l,"utf8"),await o(a,e)}async function uy(e,r=Hr()){let t=await wt(r),n=t.findIndex(o=>o.providerScheduleId===e.providerScheduleId);n>=0?t[n]=e:t.push(e),await cy(r,t)}async function dy(e=Hr()){return await ly(e)!==null?{created:!1}:(await cy(e,[]),{created:!0})}import{randomBytes as KA}from"node:crypto";import{promises as Zo}from"node:fs";import $A from"node:path";var Aa={version:1,jobs:{}};async function jA(e){try{return await Zo.readFile(e,"utf8")}catch(r){if(r.code==="ENOENT")return null;throw r}}function VA(e){if(!e)return{...Aa,jobs:{...Aa.jobs}};try{let r=JSON.parse(e);return r?.version!==1||typeof r.jobs!="object"||!r.jobs?{...Aa,jobs:{}}:r}catch{return{...Aa,jobs:{}}}}async function Oa(e){let r=await jA(e);return VA(r)}async function GA(e,r){await Zo.mkdir($A.dirname(e),{recursive:!0});let t=KA(6).toString("hex"),n=`${e}.tmp-${process.pid}-${Date.now()}-${t}`;await Zo.writeFile(n,`${JSON.stringify(r,null,2)}
|
|
49
|
+
`,"utf8");try{await Zo.rename(n,e)}catch(o){let s=o.code;if(s!=="EPERM"&&s!=="EEXIST"&&s!=="EACCES")throw o;await Zo.unlink(n).catch(()=>{})}}async function py(e,r){await GA(e,r)}function my(e,r){let t=e.jobs[r];if(t)return t;let n={providerScheduleId:r,nextFireAt:null,lastFiredAt:null,lastAttemptAt:null,consecutiveFailures:0,completedAt:null,inflightUntil:null};return e.jobs[r]=n,n}function YA(e,r){if(!e.inflightUntil)return!1;let t=Date.parse(e.inflightUntil);return!Number.isNaN(t)&&t>r}function JA(e){return!!e.completedAt}function qA(e,r,t,n){if(r.consecutiveFailures===0)return!0;if(e.spec.scheduleKind!=="cron"&&r.consecutiveFailures>t.maxRetries)return!1;if(!r.lastAttemptAt)return!0;let o=Date.parse(r.lastAttemptAt);return Number.isNaN(o)?!0:n-o>=t.retryBackoffMs}function zA(e,r,t){if(r.nextFireAt)return r.nextFireAt;let n=ay(e.spec,t);return r.nextFireAt=n,n}function XA(e,r,t,n){if(e.paused||JA(r)||YA(r,t)||!qA(e,r,n,t))return!1;let o=r.nextFireAt?Date.parse(r.nextFireAt):NaN;return Number.isNaN(o)?!1:t>=o}function QA(e,r,t){e.spec.scheduleKind==="cron"&&(r.nextFireAt=dd(e.spec,t))}async function An(e={}){let r=e.env??Sr(),t=e.now??new Date,n=t.getTime();if(!r.tickEnabled)return{enabled:!1,skipped:"tick_disabled",scanned:0,due:0,fired:0,skippedJobs:0,errors:0};if(!r.fireBaseUrl||!r.secret)return{enabled:!0,skipped:"missing_fire_credentials",scanned:0,due:0,fired:0,skippedJobs:0,errors:0};let o=oy(r.lockPath);if(!o.acquired)return{enabled:!0,skipped:o.reason??"lock_not_acquired",scanned:0,due:0,fired:0,skippedJobs:0,errors:0,lockHeld:!0};try{let s=await wt(r.storePath),i=e.agentOsIdFilter?s.filter(p=>p.spec.target.agentOsId===e.agentOsIdFilter):s,a=await Oa(r.statePath),l=[];for(let p of i){let m=my(a,p.providerScheduleId);zA(p,m,t),XA(p,m,n,r)&&l.push({entry:p,job:m})}l.sort((p,m)=>{let h=Date.parse(p.job.nextFireAt??"")||0,k=Date.parse(m.job.nextFireAt??"")||0;return h-k});let c=0,u=0,d=0,f=r.maxCatchUpPerTick;for(let{entry:p,job:m}of l){if(r.missedRunPolicy==="skip"&&p.spec.scheduleKind==="cron"){let h=Date.parse(m.nextFireAt??"");if(!Number.isNaN(h)&&h<n-r.tickIntervalMs*2){m.nextFireAt=dd(p.spec,t),d++;continue}}if(f<=0){d++;continue}m.inflightUntil=new Date(n+r.inflightLeaseMs).toISOString(),m.lastAttemptAt=t.toISOString(),QA(p,m,t);try{let h=await ry({entry:p,baseUrl:r.fireBaseUrl,secret:r.secret,fetchFn:e.fetchFn});m.inflightUntil=null,h.ok?(m.lastFiredAt=t.toISOString(),m.consecutiveFailures=0,p.spec.scheduleKind==="runAt"&&(m.completedAt=t.toISOString(),m.nextFireAt=null),c++,f--):(m.consecutiveFailures+=1,u++)}catch{m.inflightUntil=null,m.consecutiveFailures+=1,u++}}return await py(r.statePath,a),{enabled:!0,scanned:i.length,due:l.length,fired:c,skippedJobs:d,errors:u}}finally{sy(r.lockPath)}}C();D();import fy from"node:path";var gy="mesh-cron-lease.json";function Ia(e){return w(fy.join(P(e),gy),null)}function hy(e,r){ae(fy.join(P(e),gy),{...r,updatedAt:new Date().toISOString()})}function ky(e){if(!e||typeof e!="object"||Array.isArray(e))return null;let r=e.response;if(!r||typeof r!="object"||Array.isArray(r))return null;let t=r.meshLiveness;if(!t||typeof t!="object"||Array.isArray(t))return null;let n=t.cronLease;if(!n||typeof n!="object"||Array.isArray(n))return null;let o=n;return{leaseToken:typeof o.leaseToken=="string"?o.leaseToken:null,holderBoxId:typeof o.holderBoxId=="string"?o.holderBoxId:null,authorized:o.authorized===!0,updatedAt:new Date().toISOString()}}C();import MO from"node:path";N();var ZA=1;function On(e){if(!e||typeof e!="object")return 0;let r=e.startedCount;if(typeof r=="number")return r;let t=e.outcomes;return Array.isArray(t)?t.filter(n=>n.started).length:0}function eO(e){let{maxStarts:r,...t}=e;return t}async function pd(e,r){if(r<=0)return{ok:!0,skipped:!0,reason:"no slots",maxStarts:0,startedCount:0};let t=eO(e);if(t.targetTaskId||t.targetTaskIds){let u=await Wr({...t,execute:!0,pipeline:!0,maxStarts:String(r)});return{...typeof u=="object"&&u!==null?u:{},passes:{target:u},startedCount:On(u)}}let n=Math.min(r,ZA),o=Math.max(0,r-n),s=await Wr({...t,execute:!0,pipeline:!0,lane:"review",maxStarts:String(n)}),i=On(s),a=o+(n-i);if(a<=0)return{...typeof s=="object"&&s!==null?s:{},passes:{review:s},startedCount:i};let l=await Wr({...t,execute:!0,pipeline:!0,maxStarts:String(a)}),c=On(l);return{passes:{review:s,work:l},startedCount:i+c,ok:!0}}function yy(e){if(!e||typeof e!="object")return[];let t=e.response?.dispatch?.exactTargetTaskIds;if(!Array.isArray(t))return[];let n=new Set,o=[];for(let s of t){if(typeof s!="string")continue;let i=s.trim();!i||n.has(i)||(n.add(i),o.push(i))}return o}function rO(e){let t=e.response?.dispatch;return t&&typeof t=="object"?t:null}function es(e){return typeof e!="number"||!Number.isFinite(e)?null:Math.max(0,Math.floor(e))}function tO(e){let r=Number(process.env[e]);return!Number.isFinite(r)||r<=0?null:Math.floor(r)}function Ry(e,r){let t=rO(r),n=es(t?.recommendedMaxStarts),o=es(t?.actionableReady),s=es(t?.queuedTasks),i=es(t?.boardAdvancedThisTick)??0,a=es(t?.leaseReapedThisTick)??0,l=i+a,c=o??s,u=e.slotsAvailable;c!==null?u=Math.min(u,c):n!==null&&(u=Math.min(u,n)),c===null&&n!==null&&(u=Math.max(u,Math.min(e.slotsAvailable,n)));let d=t?.underutilized===!0||(c??0)>0&&e.slotsAvailable>0&&e.maxConcurrentWorkers>0&&e.activeWorkers<e.maxConcurrentWorkers;if(e.slotsAvailable>0&&u===0&&(d||l>0)){let m=c??(l>0?l:1);u=Math.min(e.slotsAvailable,Math.max(1,m))}let f=tO("KYNVER_DAEMON_MAX_DISPATCH_STARTS");f!==null&&(u=Math.min(u,f));let p=s!==null&&o!==null?Math.max(0,s-o):null;return{maxStarts:Math.max(0,u),underutilized:d,advisedStarts:n,actionableReady:o,queuedTasks:s,nonDispatchableReady:p,boardAdvancedThisTick:i,leaseReapedThisTick:a}}rn();D();Zn();z();C();z();D();C();import nO from"node:path";N();async function by(e){let r=V(e.baseUrl),t=await J(e.secret,e.agentOsId,{baseUrl:r}),n=`${r}/api/agent-os/by-id/${encodeURIComponent(e.agentOsId)}/tasks/${encodeURIComponent(e.taskId)}/plan-progress-sync`,o=await re(n,t,{phase:e.phase,taskId:e.taskId,blocker:e.blocker,artifact:e.artifact},{agentOsId:e.agentOsId,baseUrl:r});return{ok:o.ok,status:o.status,response:o.response}}async function vy(e,r){let t=L(e),n=String(r.agentOsId||"");if(!n)return[];let o=[];for(let s of Object.keys(t.workers||{})){let i=w(nO.join(P(t.id),"workers",v(s),"worker.json"),void 0);if(!i?.dispatched||!i.taskId)continue;let a=M(i);if(!a.heartbeatBlocker)continue;if(i.lastSyncedHeartbeatBlocker===a.heartbeatBlocker){o.push({worker:s,phase:"heartbeat_blocker",ok:!0,skipped:!0});continue}let l=await by({agentOsId:n,taskId:i.taskId,phase:"heartbeat_blocker",blocker:a.heartbeatBlocker,baseUrl:r.baseUrl?String(r.baseUrl):void 0,secret:r.secret?String(r.secret):void 0});l.ok&&(i.lastSyncedHeartbeatBlocker=a.heartbeatBlocker,K(t.id,i)),o.push({worker:s,phase:"heartbeat_blocker",ok:l.ok})}return o}en();N();Ie();function oO(e=process.env){let r=R();return qe(r,e)!=="forge"}function Sy(e,r=process.env){if(oO(r))return e?.maxConcurrentWorkers??void 0}async function Cy(e,r){let t=V(r.baseUrl?String(r.baseUrl):void 0),n=await J(r.secret?String(r.secret):void 0,e,{baseUrl:t}),o=`${t}/api/agent-os/by-id/${encodeURIComponent(e)}/runtime`;try{let s=await si(o,n);if(!s.ok)return null;let a=s.response?.preferences?.maxConcurrentWorkers;if(a==null)return{maxConcurrentWorkers:null};let l=Number(a);return!Number.isFinite(l)||l<=0?{maxConcurrentWorkers:null}:{maxConcurrentWorkers:Math.floor(l)}}catch{return null}}N();Ie();import{spawnSync as sO}from"node:child_process";var iO=1e4,aO=4*1024*1024,wy=(e,r,t)=>{try{let n=sO(e,r,{encoding:"utf8",stdio:["ignore","pipe","pipe"],timeout:t?.timeoutMs??iO,maxBuffer:aO});return{ok:n.status===0,stdout:typeof n.stdout=="string"?n.stdout:"",stderr:typeof n.stderr=="string"?n.stderr:""}}catch(n){return{ok:!1,stdout:"",stderr:n instanceof Error?n.message:String(n)}}};function Na(e,r,t){return`${e} ${r} ${t}`}function rs(e){let r=e.lastIndexOf("@");if(r<=0||r===e.length-1)return null;let t=e.slice(0,r),n=e.slice(r+1);return!/^[^/\s]+\/[^/\s]+$/.test(t)||!/^[0-9a-f]{7,40}$/i.test(n)?null:{repo:t,sha:n}}function _y(e){let r=e.trim().match(/[/:]([^/]+\/[^/]+)\/(?:pull|pulls|merge_requests|pull-requests)\/(\d+)/i);if(!r)return null;let t=Number(r[2]);return!Number.isFinite(t)||t<=0?null:{repo:r[1],number:t}}var lO=8e3,cO=30,uO=100,dO=400,pO=3600*1e3,md=0;function gd(){return Date.now()<md}function mO(e){let r=`${e.stdout}
|
|
50
|
+
${e.stderr}`.toLowerCase();return r.includes("api rate limit exceeded")||r.includes("rate limit exceeded")||r.includes("secondary rate limit")}function xy(e){mO(e)&&(md=Math.max(md,Date.now()+pO))}function fd(e,r){if(gd())return null;let t=e("gh",["api",...r]);if(!t.ok||!t.stdout.trim())return xy(t),null;try{return JSON.parse(t.stdout)}catch{return null}}function fO(e,r,t,n){if(gd())return null;let o=e("gh",["pr","view",String(t),"--repo",r,"--json",n.join(",")]);if(!o.ok||!o.stdout.trim())return xy(o),null;try{return JSON.parse(o.stdout)}catch{return null}}function hd(e){return gd()?!1:process.env.GITHUB_TOKEN?.trim()||process.env.GH_TOKEN?.trim()?!0:e("gh",["auth","token"]).ok}function In(e){return e&&typeof e=="object"&&!Array.isArray(e)?e:null}function gO(e){return Array.isArray(e)?e.map(r=>In(r)).filter(r=>r!==null).slice(0,cO).map(r=>({context:r.context??null,state:r.state??null,target_url:r.target_url??null,description:r.description??null})):[]}function hO(e,r,t){let n=fd(e,[`repos/${r}/commits/${t}/status`]);return n?{state:n.state??null,statuses:gO(n.statuses)}:null}var Ey={provider:"github",kind:"pr_snapshot",version:"2",isAvailable:hd,collect(e,r){let t=_y(e);if(!t)return null;let n=fO(r,t.repo,t.number,["url","title","body","author","state","isDraft","mergedAt","mergeCommit","mergeable","headRefName","headRefOid","headRepositoryOwner","statusCheckRollup","files"]);if(!n)return null;let o=In(n.author),s=In(n.mergeCommit),i=In(n.headRepositoryOwner),a=typeof n.body=="string"?n.body.slice(0,lO):null,l=Array.isArray(n.statusCheckRollup)?n.statusCheckRollup.map(u=>In(u)).filter(u=>u!==null).slice(0,uO).map(u=>({name:u.name??u.context??null,status:u.status??u.state??null,conclusion:u.conclusion??null})):[],c=Array.isArray(n.files)?n.files.map(u=>In(u)).map(u=>typeof u?.path=="string"?u.path.trim():"").filter(Boolean).slice(0,dO):[];return{pull:{html_url:n.url??null,title:n.title??null,body:a,user:{login:o?.login??null},state:typeof n.state=="string"?n.state.toLowerCase():null,draft:n.isDraft??null,merged:!!n.mergedAt,merged_at:n.mergedAt??null,merge_commit_sha:s?.oid??null,mergeable:null,mergeable_state:n.mergeable??null,head:{sha:n.headRefOid??null,ref:n.headRefName??null,repo:{owner:{login:i?.login??null}}}},checkRuns:l,combinedStatus:{state:null,statuses:[]},changedFiles:c}}},Py={provider:"github",kind:"commit_status",version:"1",isAvailable:hd,collect(e,r){let t=rs(e);return t?hO(r,t.repo,t.sha):null}},Ay={provider:"github",kind:"branch_reachability",version:"1",isAvailable:hd,collect(e,r){let t=rs(e);if(!t)return null;let n=fd(r,[`repos/${t.repo}`]),o=typeof n?.default_branch=="string"&&n.default_branch.trim()?n.default_branch.trim():null;if(!o)return null;let s=fd(r,[`repos/${t.repo}/compare/${encodeURIComponent(o)}...${t.sha}`]);if(!s)return null;let i=typeof s.status=="string"?s.status:null;return{defaultBranch:o,compareStatus:i,reachable:i==="identical"||i==="behind"}}};var kO=5,yO=/\b(READY|ERROR|BUILDING|QUEUED|CANCELED|INITIALIZING)\b/i,RO=/https:\/\/[^\s]+/,Oy={provider:"vercel",kind:"deployment_status",version:"1",isAvailable(e){return e("vercel",["whoami"]).ok},collect(e,r){let t=rs(e);if(!t)return null;let n=r("vercel",["list","--prod","--meta",`githubCommitSha=${t.sha}`]);if(!n.ok)return null;let o=[];for(let s of n.stdout.split(`
|
|
51
|
+
`)){let i=s.match(RO)?.[0];if(!i)continue;let a=s.match(yO)?.[1]?.toUpperCase()??null;if(o.push({url:i,state:a}),o.length>=kO)break}return{found:o.length>0,deployments:o}}};var kd=[];function Ta(e){kd.some(r=>r.provider===e.provider&&r.kind===e.kind)||kd.push(e)}function Iy(e,r){return kd.find(t=>t.provider===e&&t.kind===r)??null}function Ny(){Ta(Ey),Ta(Py),Ta(Ay),Ta(Oy)}var bO=1,vO=25e3;function Ty(e,r={}){Ny();let t=r.run??wy,n=r.now??(()=>new Date),o=r.maxSubjects??bO,s=Date.now()+(r.deadlineMs??vO),i=new Set,a=e.filter(p=>{let m=Na(p.provider,p.kind,p.subject);return i.has(m)?!1:(i.add(m),!0)}),l=a.length>0?Math.floor(n().getTime()/6e4)%a.length:0,u=a.map((p,m)=>a[(l+m)%a.length]).slice(0,o),d={attempted:0,collected:0,cached:0,items:[],skipped:[]},f=new Map;for(let p of u){let m=Na(p.provider,p.kind,p.subject),h=n(),k=r.cache?.get(m,h)??null;if(k){d.cached+=1,d.collected+=1,d.items.push(k);continue}if(Date.now()>s){d.skipped.push({...p,reason:"budget_exhausted"});continue}let g=Iy(p.provider,p.kind);if(!g){d.skipped.push({...p,reason:"no_recipe"});continue}let y=`${g.provider} ${g.kind}`,_=f.get(y);if(_===void 0&&(_=g.isAvailable(t),f.set(y,_)),!_){d.skipped.push({...p,reason:"provider_unavailable"});continue}if(r.cache?.reserve?.(p,m,n())===!1){d.skipped.push({...p,reason:"budget_exhausted"});continue}d.attempted+=1;let x=g.collect(p.subject,t);if(x==null){d.skipped.push({...p,reason:"collect_failed"});continue}d.collected+=1;let E={provider:p.provider,kind:p.kind,subject:p.subject,payload:x,observedAt:n().toISOString(),collectorVersion:g.version};d.items.push(E),r.cache?.set(m,E,n())}return d}D();C();import xO from"node:path";D();C();import Dy from"node:path";var SO="provider-evidence-wanted.json",CO="provider-evidence-cache.json",wO=600*1e3;function My(e){return Dy.join(P(e),SO)}function _O(e){return Dy.join(P(e),CO)}function Uy(e){if(!Array.isArray(e))return[];let r=[];for(let t of e){if(!t||typeof t!="object"||Array.isArray(t))continue;let n=t,o=typeof n.provider=="string"?n.provider.trim():"",s=typeof n.kind=="string"?n.kind.trim():"",i=typeof n.subject=="string"?n.subject.trim():"";!o||!s||!i||r.push({provider:o,kind:s,subject:i})}return r}function Wy(e){let r=w(My(e),null);return Uy(r?.wanted)}function Ly(e,r){ae(My(e),{savedAt:new Date().toISOString(),wanted:r})}function By(e,r={}){let t=r.ttlMs??wO,n=_O(e),s={...w(n,null)?.items??{}},i=!1;return{get(l,c){let u=s[l];if(!u)return null;let d=Date.parse(u.observedAt);return!Number.isFinite(d)||c.getTime()-d>t?(delete s[l],i=!0,null):u},set(l,c){s[l]=c,i=!0},flush(){i&&(ae(n,{savedAt:new Date().toISOString(),items:s}),i=!1)}}}function Hy(e){if(!e||typeof e!="object"||Array.isArray(e))return null;let r=e.providerEvidenceWanted;return Array.isArray(r)?Uy(r):null}var EO="provider-evidence-shared-cache.json",PO=6e4,AO=1,OO=1;function yd(e,r){let t=process.env[e];if(!t)return r;let n=Number.parseInt(t,10);return Number.isFinite(n)&&n>=0?n:r}function IO(){return xO.join(Z().harnessRoot,EO)}function NO(e){let r=e.toUpperCase().replace(/[^A-Z0-9]+/g,"_"),t=e==="github"?AO:OO;return yd(`KYNVER_PROVIDER_EVIDENCE_${r}_PER_MINUTE`,yd("KYNVER_PROVIDER_EVIDENCE_LIVE_COLLECTS_PER_MINUTE",t))}function Fy(){return yd("KYNVER_PROVIDER_EVIDENCE_SHARED_CACHE_TTL_MS",PO)}function TO(e){return Math.floor(e.getTime()/6e4)*6e4}function DO(e){return`${e.provider}:${e.kind}`}function Ky(e,r={}){let t=By(e,{ttlMs:r.ttlMs??Fy()}),n=r.file??IO(),o=w(n,null),s={...o?.items??{}},i={...o?.budget??{}},a=r.ttlMs??Fy(),l=!1;return{get(u,d){let f=t.get(u,d);if(f)return f;let p=s[u];if(!p)return null;let m=Date.parse(p.observedAt);return!Number.isFinite(m)||d.getTime()-m>a?(delete s[u],l=!0,null):(t.set(u,p,d),p)},set(u,d,f){t.set(u,d,f),s[u]=d,l=!0},reserve(u,d,f){let p=NO(u.provider);if(p===0)return!0;let m=DO(u),h=TO(f),k=i[m];return!k||k.windowStartMs!==h?(i[m]={windowStartMs:h,used:1},l=!0,!0):k.used>=p?!1:(k.used+=1,l=!0,!0)},flush(){t.flush(),l&&(ae(n,{savedAt:new Date().toISOString(),items:s,budget:i}),l=!1)}}}function UO(){let e=process.env.KYNVER_PIPELINE_SWEEP_ENABLED;return e?e==="1"||e.toLowerCase()==="true":!1}async function WO(e,r){let t=L(e),n=[],o=Math.max(0,Number.parseInt(process.env.KYNVER_PIPELINE_COMPLETION_REPLAY_MAX_DEEP_CHECKS_PER_TICK??"0",10)||0),s=0;for(let i of Object.keys(t.workers||{})){let a=w(MO.join(P(t.id),"workers",v(i),"worker.json"),void 0);if(!a?.taskId||a.localOnly||rt(a))continue;if(dt(a)){n.push({worker:i,ok:!0,taskId:a.taskId??null,skipped:!0});continue}if(s>=o)break;s++;let l=M(a);if(!oe(l))continue;let c=Xr({alive:l.alive,finalResult:l.finalResult,changedFiles:l.changedFiles,gitAncestry:l.gitAncestry});if(!a.dispatched&&!l.finalResult&&!c?.salvageable)continue;let u=await Ao({run:e,name:i,agentOsId:String(r.agentOsId||a.agentOsId||""),...r});n.push({worker:i,ok:u.ok,taskId:a.taskId??null})}return n}async function LO(e,r,t,n,o){let s=V(n.baseUrl?String(n.baseUrl):void 0),i=await J(n.secret?String(n.secret):void 0,e,{baseUrl:s}),a=`${s}/api/agent-os/by-id/${encodeURIComponent(e)}/operator/tick`,l=await xs(),c=Hi(r),u=null;try{let h=Wy(r);if(h.length>0){let k=Ky(r);u=Ty(h,{cache:k}),k.flush?.()}else u=null}catch{u=null}let d=Ia(r),f=await Ir(a,i,{agentOsId:e,runId:r,ingestHarness:!0,harnessBoardSnapshot:Io(r),resourceGate:t,boxResourceSnapshot:Wo(t,{harnessRunId:r,boxKind:qe(R())}),packageVersions:l,...o?{harnessCleanup:o}:{},runnerPresence:er({runId:r}),activeHarnessWorkers:c,...d?.leaseToken?{meshCronLeaseToken:d.leaseToken}:{},...u&&u.items.length>0?{providerEvidence:u.items}:{}}),p=Hy(f.response);if(p)try{Ly(r,p)}catch{}let m=ky(f);if(m)try{hy(r,m)}catch{}return{ok:f.ok,httpStatus:f.status,response:f.response,...u?{providerEvidence:{attempted:u.attempted,collected:u.collected,skipped:u.skipped.length}}:{}}}async function Rd(e){let r=String(T(String(e.run||""),"--run")),t=String(T(String(e.agentOsId||""),"--agent-os-id")),n=e.execute!==!1&&e.execute!=="false";Io(r);let o=await Cy(t,e),s=Sy(o),i=mr({runId:r,configuredMaxWorkersOverride:s}),a=ad()?id(r):void 0,l=await LO(t,r,i,e,a),c=yg(r,l),u=await Si(r,e),d=await WO(r,e),f=mr({runId:r,configuredMaxWorkersOverride:s}),p=Cn(),m=await vy(r,e),h=Ry(f,l),k=h.maxStarts,g=UO()?await _n({run:r,agentOsId:t,pipeline:!0,...e}):{ok:!0,skipped:!0,reason:"pipeline_sweep_disabled"},y=null,_=0,x=yy(l),E=k;if(n&&E>0&&x.length>0){let Y=Math.min(E,x.length),$=await pd({...e,run:r,agentOsId:t,targetTaskIds:x.join(",")},Y),F=On($);_+=F,E=Math.max(0,E-F),y={exactTargetTaskIds:x,exact:$,startedCount:_}}if(n&&E>0){let Y=await pd({...e,run:r,agentOsId:t},E),$=On(Y);_+=$,y=y&&typeof y=="object"?{...y,broad:Y,startedCount:_}:Y}else!n||k<=0?y||(y={ok:!0,skipped:!0,reason:n?f.reason??"no slots or queued work":"execute disabled",maxStarts:0,dispatchAdvice:h,...x.length?{exactTargetTaskIds:x,exactOnly:!0}:{}}):y&&typeof y=="object"&&(y={...y,broadSkipped:!0,startedCount:_});let A=!h.underutilized&&k===0&&d.length===0&&_===0;return{runId:r,agentOsId:t,execute:n,resourceGate:i,dispatchResourceGate:f,leaseRenewal:u,completedWorkers:d,staleReconcile:p,harnessCleanup:a,planProgressSync:m,completionAckSync:c,operatorTick:l,sweep:g,dispatchAdvice:h,dispatch:y,idle:A}}N();import nI from"node:os";import{readFileSync as BO}from"node:fs";import{homedir as HO,platform as FO}from"node:os";import KO from"node:path";import{execFileSync as $O}from"node:child_process";function $y(e,r=Date.now()){try{let t=JSON.parse(e),n=t.claudeAiOauth?.accessToken,o=t.claudeAiOauth?.expiresAt;return typeof n!="string"||!n||typeof o=="number"&&o-r<6e4?null:n}catch{return null}}function jO(){if(FO()==="darwin")try{let e=$O("security",["find-generic-password","-s","Claude Code-credentials","-w"],{encoding:"utf8",stdio:["ignore","pipe","ignore"]});return $y(e.trim())}catch{return null}try{let e=BO(KO.join(HO(),".claude",".credentials.json"),"utf8");return $y(e)}catch{return null}}function jy(e=process.env,r={}){let t=e.ANTHROPIC_API_KEY?.trim();if(t)return{kind:"api_key",key:t};let n=e.KYNVER_CHAT_USE_CLAUDE_OAUTH;if(r.oauthOptIn===!0||n==="1"||n==="true"||n==="yes"){let s=jO();if(s)return{kind:"oauth",token:s}}return null}var VO="You are Claude Code, Anthropic's official CLI for Claude.";function GO(){return{blocks:[],stopReason:null,inputTokens:0,outputTokens:0}}function YO(e,r){let t=r;switch(t.type){case"message_start":return e.inputTokens=t.message?.usage?.input_tokens??0,"";case"content_block_start":{let n=t.index??e.blocks.length;return e.blocks[n]={type:t.content_block?.type==="tool_use"?"tool_use":"text",text:"",id:t.content_block?.id,name:t.content_block?.name,inputJson:""},""}case"content_block_delta":{let n=e.blocks[t.index??e.blocks.length-1];return n?t.delta?.type==="text_delta"&&t.delta.text?(n.text+=t.delta.text,t.delta.text):(t.delta?.type==="input_json_delta"&&t.delta.partial_json&&(n.inputJson+=t.delta.partial_json),""):""}case"message_delta":return t.delta?.stop_reason&&(e.stopReason=t.delta.stop_reason),typeof t.usage?.output_tokens=="number"&&(e.outputTokens=t.usage.output_tokens),"";default:return""}}function JO(e){let r=[];for(let t of e.blocks)if(t)if(t.type==="tool_use"){let n={};try{n=t.inputJson?JSON.parse(t.inputJson):{}}catch{n={}}r.push({type:"tool_use",id:t.id??"",name:t.name??"",input:n})}else t.text&&r.push({type:"text",text:t.text});return{content:r,stop_reason:e.stopReason??"end_turn",usage:{input_tokens:e.inputTokens,output_tokens:e.outputTokens}}}async function*qO(e){let r=e.getReader(),t=new TextDecoder,n="";try{for(;;){let{done:o,value:s}=await r.read();if(o)break;n+=t.decode(s,{stream:!0});let i;for(;(i=n.indexOf(`
|
|
52
|
+
`))!==-1;){let a=n.slice(0,i).trim();if(n=n.slice(i+1),!a.startsWith("data:"))continue;let l=a.slice(5).trim();if(!(!l||l==="[DONE]"))try{yield JSON.parse(l)}catch{}}}}finally{r.releaseLock()}}function zO(e=process.env){return(e.ANTHROPIC_BASE_URL?.trim()||"https://api.anthropic.com").replace(/\/$/,"")}async function Vy(e){let{creds:r,model:t,payload:n}=e,o={"Content-Type":"application/json","anthropic-version":"2023-06-01"},s=n.system;r.kind==="api_key"?o["x-api-key"]=r.key:(o.Authorization=`Bearer ${r.token}`,o["anthropic-beta"]="oauth-2025-04-20",s=[{type:"text",text:VO},{type:"text",text:n.system}]);let i=await fetch(`${zO()}/v1/messages`,{method:"POST",headers:o,signal:e.signal,body:JSON.stringify({model:t,max_tokens:n.maxTokens,system:s,messages:n.messages,...Array.isArray(n.tools)&&n.tools.length>0?{tools:n.tools}:{},...n.temperature!==void 0?{temperature:n.temperature}:{},stream:!0})});if(!i.ok||!i.body){let l=await i.text().catch(()=>"");throw new Error(`Anthropic stream failed: HTTP ${i.status}${l?` \u2014 ${l.slice(0,300)}`:""}`)}let a=GO();for await(let l of qO(i.body)){let c=YO(a,l);c&&e.onDelta(c)}return JO(a)}var Nn=class{constructor(r,t=150){this.flushFn=r;this.floorMs=t}flushFn;floorMs;buffer="";timer=null;closed=!1;push(r){this.closed||!r||(this.buffer+=r,this.timer||(this.timer=setTimeout(()=>{this.timer=null,this.flushNow()},this.floorMs)))}flushNow(){if(!this.buffer)return;let r=this.buffer;this.buffer="",this.flushFn(r)}close(){this.closed||(this.closed=!0,this.timer&&(clearTimeout(this.timer),this.timer=null),this.flushNow())}};import{spawn as eI}from"node:child_process";var XO=new Set(["run list","run status","worker list","worker status","worker tail","status","cron status","monitor status","monitor list"]),QO=new Set(["run create","run dispatch","run sweep","worker start","worker stop","worker complete","cleanup"]),ZO=["--secret","--api-key","--keeper-child"];function Gy(e){if(!Array.isArray(e)||e.length===0||e.some(n=>typeof n!="string"))return{ok:!1,mutating:!1,reason:"argv must be a non-empty string array"};for(let n of e){if(ZO.some(o=>n===o||n.startsWith(`${o}=`)))return{ok:!1,mutating:!1,reason:`forbidden flag: ${n}`};if(n.includes(`
|
|
53
|
+
`)||n.includes("\0"))return{ok:!1,mutating:!1,reason:"control characters refused"}}let r=e[0],t=e.length>1&&!e[1].startsWith("--")?`${r} ${e[1]}`:r;return t==="doctor runtime-takeover"?e.includes("--remediate-default-repo")?{ok:!0,mutating:!0}:{ok:!0,mutating:!1}:r==="cleanup"?{ok:!0,mutating:e.includes("--execute")}:XO.has(t)?{ok:!0,mutating:!1}:QO.has(t)?{ok:!0,mutating:!0}:{ok:!1,mutating:!1,reason:`verb not allowlisted: ${t}`}}var rI=10*6e4,tI=5e3,Yy=2e5;async function Jy(e,r,t={}){let n=Gy(e);if(!n.ok)return{exitCode:null,timedOut:!1,refused:n.reason};let o=t.cliEntry??process.argv[1],s=t.timeoutMs??rI,i=new Nn(r);return new Promise(a=>{let l=0,c=!1,u=eI(process.execPath,[o,...e],{stdio:["ignore","pipe","pipe"],env:process.env}),d=p=>{if(l>=Yy)return;let m=p.toString("utf8").slice(0,Yy-l);l+=m.length,i.push(m)};u.stdout?.on("data",d),u.stderr?.on("data",d);let f=setTimeout(()=>{c=!0,u.kill("SIGTERM"),setTimeout(()=>u.kill("SIGKILL"),tI).unref()},s);u.on("error",p=>{clearTimeout(f),i.push(`spawn failed: ${p.message}`),i.close(),a({exitCode:null,timedOut:!1,refused:void 0})}),u.on("close",p=>{clearTimeout(f),i.close(),a({exitCode:p,timedOut:c})})})}var oI=25e3,sI=32e3,iI=5e3,aI=6e4,qy=5*6e4,lI=5e3,cI="claude-sonnet-4-6";async function uI(e,r,t){let n=t.KYNVER_RUNTIME_CHAT_BRIDGE_URL?.trim();if(n)return n;if(!e)return null;let o=new AbortController,s=setTimeout(()=>o.abort(),lI);try{let i=await fetch(`${e.replace(/\/$/,"")}/api/runtime/chat-bridge`,{headers:{Authorization:`Bearer ${r}`},signal:o.signal});if(!i.ok)return null;let a=await i.json().catch(()=>null);return typeof a?.bridgeUrl=="string"&&a.bridgeUrl.trim()?a.bridgeUrl.trim():null}catch{return null}finally{clearTimeout(s)}}async function zy(e=process.env){let r=R(),t=r.agentOsId?.trim(),n=se();if(!t||!n)return null;let o=await uI(r.apiBaseUrl,n,e);return o?{bridgeUrl:o.replace(/\/$/,""),agentOsId:t,apiKey:n,boxId:nI.hostname(),model:e.KYNVER_CHAT_MODEL?.trim()||r.defaultModel?.trim()||cI,useClaudeOauth:r.chatUseClaudeOauth===!0}:null}async function dI(e,r){let t=new AbortController,n=setTimeout(()=>t.abort(),sI),o=setInterval(()=>{r()&&t.abort()},500);try{let s=await fetch(`${e.bridgeUrl}/runtime-chat/claim`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e.apiKey}`},body:JSON.stringify({agentOsId:e.agentOsId,boxId:e.boxId,waitMs:oI}),signal:t.signal});if(s.status===204)return null;if(s.status===401||s.status===403)return"auth_error";if(!s.ok)throw new Error(`claim failed: HTTP ${s.status}`);return(await s.json().catch(()=>null))?.turn??null}catch(s){if(r())return null;throw s}finally{clearTimeout(n),clearInterval(o)}}async function _t(e,r,t){return(await fetch(`${e.bridgeUrl}/runtime-chat/turns/${encodeURIComponent(r)}/events`,{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e.apiKey}`},body:JSON.stringify({agentOsId:e.agentOsId,events:t})})).ok}async function pI(e,r){let t=0,n=Array.isArray(r.payload?.argv)?r.payload.argv:[],o=await Jy(n,s=>{_t(e,r.turnId,[{seq:t++,kind:"delta",text:s}])});o.refused?await _t(e,r.turnId,[{seq:t++,kind:"error",error:`command_refused: ${o.refused}`}]).catch(()=>{}):await _t(e,r.turnId,[{seq:t++,kind:"final",message:{exitCode:o.exitCode,timedOut:o.timedOut}}]).catch(()=>{}),console.error(JSON.stringify({event:"command_turn_done",turnId:r.turnId,argv:n.slice(0,4),exitCode:o.exitCode,timedOut:o.timedOut,refused:o.refused??null}))}async function mI(e,r){let t=0,n=!1,o=new AbortController,s=l=>{n||_t(e,r.turnId,[{seq:t++,kind:"delta",text:l}]).then(c=>{c||(n=!0,o.abort())})},i=new Nn(s),a=jy(process.env,{oauthOptIn:e.useClaudeOauth});if(!a){await _t(e,r.turnId,[{seq:0,kind:"error",error:"no_local_credentials"}]).catch(()=>{});return}try{let l=await Vy({creds:a,model:e.model,payload:r.payload,onDelta:c=>i.push(c),signal:o.signal});i.close(),n||await _t(e,r.turnId,[{seq:t++,kind:"final",message:l}]),console.error(JSON.stringify({event:"chat_turn_done",turnId:r.turnId,model:e.model}))}catch(l){i.close(),n||await _t(e,r.turnId,[{seq:t++,kind:"error",error:l instanceof Error?l.message:String(l)}]).catch(()=>{}),console.error(JSON.stringify({event:"chat_turn_error",turnId:r.turnId,error:l instanceof Error?l.message:String(l)}))}}async function bd(e,r){for(let n=0;n<e&&!r();n+=500)await new Promise(o=>setTimeout(o,Math.min(500,e-n)))}async function Xy(e){let r=await zy();for(r||console.error(JSON.stringify({event:"chat_claim_loop_waiting",reason:!se()||!R().agentOsId?.trim()?"machine_not_linked":"bridge_not_discovered (rollout off, discovery route missing/404, or API unreachable)",rediscoverMs:qy}));!r&&!e.shouldStop();){if(!se()||!R().agentOsId?.trim()||(await bd(qy,e.shouldStop),e.shouldStop()))return;r=await zy()}if(!(!r||e.shouldStop())){for(console.error(JSON.stringify({event:"chat_claim_loop_start",bridgeUrl:r.bridgeUrl,agentOsId:r.agentOsId,boxId:r.boxId,model:r.model,useClaudeOauth:r.useClaudeOauth}));!e.shouldStop();)try{let t=await dI(r,e.shouldStop);if(t==="auth_error"){console.error(JSON.stringify({event:"chat_claim_auth_error"})),await bd(aI,e.shouldStop);continue}t&&(t.payload?.kind==="command"?await pI(r,t):await mI(r,t))}catch(t){console.error(JSON.stringify({event:"chat_claim_error",error:t instanceof Error?t.message:String(t)})),await bd(iI,e.shouldStop)}console.error(JSON.stringify({event:"chat_claim_loop_stop"}))}}var fI=6e4,gI=5*6e4,hI=10,kI=250;async function vd(e,r){let t=e;for(;t>0&&!r();){let n=Math.min(kI,t);await xr(n),t-=n}}async function ts(e){Pn();let r=String(T(String(e.run||""),"--run")),t=String(T(String(e.agentOsId||R().agentOsId||""),"--agent-os-id")),n=e.execute!==!1&&e.execute!=="false",o=Number(e.intervalMs)>0?Math.floor(Number(e.intervalMs)):fI,s=!1,i=0;process.on("SIGINT",()=>{s=!0}),process.on("SIGTERM",()=>{s=!0});let a=zo();a.remediated&&console.error(JSON.stringify({event:"daemon_default_repo_remediated",defaultRepo:a.resolved?.defaultRepo??null,configPath:a.configPath}));let l=Jk(R());l.ok||(console.error(JSON.stringify({event:"daemon_start_blocked",runId:r,agentOsId:t,errors:l.errors})),process.exit(1)),console.error(JSON.stringify({event:"daemon_start",runId:r,agentOsId:t,execute:n,intervalMs:o,boxKind:l.box.boxKind,workerCapSource:l.workerCapSource,maxConcurrentWorkers:l.maxConcurrentWorkers}));let c=Sr(),u=Xy({shouldStop:()=>s}).catch(f=>{console.error(JSON.stringify({event:"chat_claim_loop_crashed",error:f instanceof Error?f.message:String(f)}))}),d=!1;for(;!s;)try{Xk({agentOsId:t,runId:r,instructionBundleVersion:Nr()});let f=await ni(e.secret?String(e.secret):void 0,t);if(!f.ok){d||(d=!0,console.error(JSON.stringify({event:"daemon_runner_credential_missing",agentOsId:t,reason:f.reason,remedy:`run \`kynver runner credential --agent-os-id ${t}\` (or \`kynver bootstrap\`); ticks resume automatically once the credential exists`}))),await vd(o,()=>s);continue}d&&(d=!1,console.error(JSON.stringify({event:"daemon_runner_credential_recovered",agentOsId:t}))),await Su({agentOsId:t,baseUrl:rc(e.baseUrl?String(e.baseUrl):void 0),secret:f.secret});let p=await Rd({run:r,agentOsId:t,execute:n,...e});if(console.error(JSON.stringify({event:"daemon_tick",...p})),c.tickEnabled){let g=Ia(r);if(g&&!g.authorized)console.error(JSON.stringify({event:"daemon_cron_tick_skipped",reason:"mesh_cron_lease_not_authorized",holderBoxId:g.holderBoxId}));else{let y=await An({env:c,agentOsIdFilter:t});y.enabled&&(y.fired>0||y.errors>0||y.lockHeld)&&console.error(JSON.stringify({event:"daemon_cron_tick",...y}))}}p.idle?i++:i=0;let m=Math.floor(it("daemon.maxIdleStreak",hI)),h=Math.floor(it("daemon.idleIntervalMs",gI)),k=i>=m?h:o;await vd(k,()=>s)}catch(f){console.error(JSON.stringify({event:"daemon_tick_error",error:f.message})),await vd(o,()=>s)}await u,console.error(JSON.stringify({event:"daemon_stop",runId:r,agentOsId:t}))}N();import{spawn as yI}from"node:child_process";C();var RI=15*6e4,Qy=2*6e4,Zy=1e4,bI=5e3,vI=5*6e4,SI=30*6e4,eR=5e3;function CI(e,r=process.env){let t=typeof e=="string"?Number.parseInt(e,10):NaN;if(Number.isFinite(t)&&t>0)return t;let n=Number.parseInt(r.KYNVER_DAEMON_STALL_MS??"",10);return Number.isFinite(n)&&n>0?n:RI}function Da(e,r=process.env){if(e.keeperChild===!0||e.keeperChild==="true"||e.noSupervise===!0||e.noSupervise==="true"||e.supervised==="false")return!1;let t=(r.KYNVER_DAEMON_SUPERVISED??"").trim().toLowerCase();return!(t==="0"||t==="false"||t==="no"||t==="off")}function wI(e,r=bI,t=vI){let n=Math.min(Math.max(e,1)-1,10);return Math.min(r*2**n,t)}function _I(e,r,t=SI){return r-e>=t}function xt(e,r={}){console.error(JSON.stringify({event:`daemon_keeper_${e}`,...r}))}function xI(e){let r=[];for(let t=0;t<e.length;t+=1){let n=e[t];if(!(n==="--supervised"||n==="--no-supervise"||n==="--keeper-child")){if(n==="--stall-ms"){t+1<e.length&&!e[t+1].startsWith("--")&&(t+=1);continue}n.startsWith("--stall-ms=")||n.startsWith("--supervised=")||r.push(n)}}return r.push("--keeper-child"),r}async function Ma(e,r=process.argv.slice(2)){let t=String(T(String(e.agentOsId||R().agentOsId||""),"--agent-os-id")),n=CI(e.stallMs),o=xI(r),s=process.argv[1],i=!1,a=null,l=0,c=u=>{i=!0,xt("stop",{signal:u}),a?.pid&&a.kill(u)};for(process.on("SIGINT",()=>c("SIGINT")),process.on("SIGTERM",()=>c("SIGTERM")),xt("start",{agentOsId:t,stallMs:n,childArgv:o});!i;){let u=Date.now(),d=!1,f=null,p=null;for(a=yI(process.execPath,[s,...o],{stdio:"inherit",env:process.env}),xt("child_spawned",{pid:a.pid??null}),a.on("exit",(k,g)=>{d=!0,f=k,p=g});!d&&!i&&(await xr(eR),!(d||i));){if(Date.now()-u<Qy)continue;let k=Qk(t),g=k&&k.pid===a.pid?k:null;if(g&&Zk(g,n)){xt("stall_detected",{pid:a.pid??null,lastBeatAt:g.observedAt,stallMs:n}),a.kill("SIGTERM"),await xr(Zy),d||a.kill("SIGKILL");break}if(!g&&Date.now()-u>n+Qy){xt("no_heartbeat_detected",{pid:a.pid??null,stallMs:n}),a.kill("SIGTERM"),await xr(Zy),d||a.kill("SIGKILL");break}}for(;!d&&!i;)await xr(eR);if(i)break;let m=Date.now();_I(u,m)&&(l=0),l+=1;let h=wI(l);xt("child_exited",{code:f,signal:p,uptimeMs:m-u,consecutiveFailures:l,respawnInMs:h}),await xr(h)}xt("stopped",{agentOsId:t})}D();import{existsSync as Wa}from"node:fs";async function Ua(e=Sr()){let r=await wt(e.storePath).catch(()=>[]),t=await Oa(e.statePath).catch(()=>({version:1,jobs:{}})),n=!!(e.fireBaseUrl&&e.secret),o=Pa(e),s="disabled";return o?s="kynver-cron-daemon":process.env.QSTASH_TOKEN?.trim()&&(s="qstash"),{primary:s,env:{storePath:e.storePath,statePath:e.statePath,tickEnabled:e.tickEnabled,fireBaseUrl:e.fireBaseUrl,missedRunPolicy:e.missedRunPolicy,maxCatchUpPerTick:e.maxCatchUpPerTick,maxRetries:e.maxRetries},jobCount:r.length,stateJobCount:Object.keys(t.jobs).length,credentialsReady:n,daemonPrimary:o}}import{homedir as EI}from"node:os";import PI from"node:path";Or();var Fr="watchdog:board-sweep",AI="*/5 * * * *",OI=["Set KYNVER_SCHEDULER_PROVIDER=kynver-cron on the hosted Kynver deployment (Vercel).","Set KYNVER_CRON_SECRET to the same value written to ~/.kynver/.env by this installer.","Unset KYNVER_CRON_STORE_PATH on Vercel \u2014 the connected box owns the local store.","Keep QSTASH_TOKEN only if other non-watchdog schedules still use QStash (analyst/market jobs)."];function rR(e){let r=e.storePath?.trim()||Hr(),t=e.envFilePath?.trim()||we,n=PI.join(EI(),".kynver","config.json"),o=`/api/agent-os/by-id/${e.agentOsId}/scheduler/fire`,s=[];e.apiBaseUrl?.trim()||s.push("apiBaseUrl \u2014 run `kynver setup --api-base-url \u2026`"),e.agentOsId?.trim()||s.push("agentOsId \u2014 run `kynver setup --agent-os-id \u2026`");let i={KYNVER_API_URL:e.apiBaseUrl,KYNVER_CRON_SECRET:e.cronSecret,KYNVER_CRON_STORE_PATH:r,KYNVER_CRON_TICK_ENABLED:"1",KYNVER_CRON_DAEMON_PRESENT:"1"},a=["OPENCLAW_CRON_STORE_PATH","OPENCLAW_CRON_SECRET","OPENCLAW_CRON_FIRE_BASE_URL"],l={deploymentSchedulerProvider:"kynver-cron",apiBaseUrl:e.apiBaseUrl,agentOsId:e.agentOsId,...e.defaultDaemonRunId?{defaultDaemonRunId:e.defaultDaemonRunId}:{}};return{envFilePath:t,configPath:n,storePath:r,envUpdates:i,envRemovals:a,configUpdates:l,deploymentSteps:OI,prerequisites:s,systemdSupported:process.platform==="linux",watchdogSpec:{kind:"watchdog",cron:AI,dedupeKey:Fr,callbackPath:o}}}Or();async function Tn(e){let r=e.envFilePath??we,t=[],n=Sr(),o=await Ua(n),s=tn(r);t.push({id:"config_agent_os",ok:!!e.config.agentOsId?.trim(),summary:e.config.agentOsId?`agentOsId configured (${e.config.agentOsId})`:"agentOsId missing in ~/.kynver/config.json",remediation:"Run `kynver setup --agent-os-id <id>`."}),t.push({id:"config_api_base",ok:!!(e.config.apiBaseUrl?.trim()||n.fireBaseUrl),summary:n.fireBaseUrl?`fire base URL resolved (${n.fireBaseUrl})`:"KYNVER_API_URL / apiBaseUrl not configured",remediation:"Run `kynver setup --api-base-url https://\u2026`."}),t.push({id:"deployment_provider",ok:e.config.deploymentSchedulerProvider==="kynver-cron",summary:`deploymentSchedulerProvider=${e.config.deploymentSchedulerProvider??"(unset)"}`,remediation:'Run `kynver cron install` or set deploymentSchedulerProvider to "kynver-cron".'}),t.push({id:"cron_secret",ok:!!n.secret,summary:n.secret?"KYNVER_CRON_SECRET present":"KYNVER_CRON_SECRET missing",remediation:"Run `kynver cron install` to generate and persist the shared secret."}),t.push({id:"env_file",ok:Wa(r)&&!!s.get("KYNVER_CRON_SECRET"),summary:Wa(r)?`~/.kynver/.env present (${s.size} keys)`:"~/.kynver/.env missing",remediation:"Run `kynver cron install` to write ~/.kynver/.env."}),t.push({id:"cron_store",ok:Wa(n.storePath),summary:Wa(n.storePath)?`cron store present (${n.storePath})`:`cron store missing (${n.storePath})`,remediation:"Run `kynver cron install` to initialize the local store."});let a=(await wt(n.storePath).catch(()=>[])).find(u=>u.spec.dedupeKey===Fr);t.push({id:"watchdog_local",ok:!!a,summary:a?`watchdog entry in local store (${a.providerScheduleId})`:"watchdog entry not mirrored in local cron store",remediation:"Run `kynver cron install` (with API access) to register and mirror watchdog."}),t.push({id:"daemon_primary",ok:o.daemonPrimary,summary:o.daemonPrimary?"cron tick enabled with credentials (daemon-primary)":`cron primary=${o.primary}; tickEnabled=${o.env.tickEnabled}`,remediation:"Ensure KYNVER_CRON_TICK_ENABLED=1 and run `kynver daemon` (or enable the systemd user unit)."});let l=s.has("OPENCLAW_CRON_STORE_PATH")||s.has("OPENCLAW_CRON_SECRET")||s.has("OPENCLAW_CRON_FIRE_BASE_URL");return t.push({id:"legacy_openclaw_env",ok:!l,summary:l?"legacy OPENCLAW_CRON_* keys still present in ~/.kynver/.env":"no legacy OPENCLAW_CRON_* keys in env file",remediation:"Re-run `kynver cron install` to retire legacy aliases."}),{ok:t.every(u=>u.ok),checks:t}}N();Je();C();import{existsSync as dR}from"node:fs";import{createHash as II}from"node:crypto";function tR(e){let r=JSON.stringify({cb:e.callbackPath,cron:e.cron??null,runAt:e.runAt??null,kind:e.kind,target:e.target,dedupeKey:e.dedupeKey??null});return`kc-cron:${II("sha1").update(r).digest("hex").slice(0,16)}`}async function Sd(e,r,t={}){return fetch(e,{...t,headers:{"Content-Type":"application/json",Authorization:`Bearer ${r}`,...t.headers}})}async function nR(e,r,t,n={}){let o=new URLSearchParams(n),s=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/jobs?${o}`,i=await Sd(s,t),a=await i.text(),l=null;try{l=JSON.parse(a)}catch{l=null}if(!i.ok)throw new Error(`list scheduler jobs failed (${i.status}): ${l?.error??a.slice(0,200)}`);return l?.items??[]}async function oR(e,r,t,n,o={}){let s=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/watchdog/ensure`,i={};n&&(i.cron=n),o.requireProvider&&(i.requireProvider=o.requireProvider);let a=await Sd(s,t,{method:"POST",body:JSON.stringify(i)}),l=await a.text(),c=null;try{c=JSON.parse(l)}catch{c=null}if(!a.ok||!c?.job)throw new Error(`ensure watchdog failed (${a.status}): ${c?.error??l.slice(0,200)}`);return{job:c.job,route:c.route??`/api/agent-os/by-id/${r}/scheduler/fire`,dedupeKey:c.dedupeKey??Fr,requestedCron:c.requestedCron??n??"*/5 * * * *",selectedProvider:c.selectedProvider??c.job.provider??null}}async function sR(e,r,t,n){let o=`${e}/api/agent-os/by-id/${encodeURIComponent(r)}/scheduler/jobs/${encodeURIComponent(t)}/cancel`,s=await Sd(o,n,{method:"POST",body:"{}"});if(!s.ok){let i=await s.text();throw new Error(`cancel job ${t} failed (${s.status}): ${i.slice(0,200)}`)}}function iR(e,r,t=Fr){return{kind:"watchdog",scheduleKind:"cron",cron:r,callbackPath:`/api/agent-os/by-id/${e}/scheduler/fire`,payload:{source:"agent-os.watchdog-schedule",agentOsId:e},target:{agentOsId:e},description:"Watchdog board sweep (repair loop)",dedupeKey:t}}function aR(e){return e.filter(r=>r.kind==="watchdog"&&r.dedupeKey===Fr&&r.provider==="qstash"&&r.status!=="cancelled")}function NI(e){return e.find(r=>r.kind==="watchdog"&&r.dedupeKey===Fr&&r.provider==="kynver-cron"&&r.status!=="cancelled")}function lR(e){return NI(e)?{allowed:!0}:{allowed:!1,reason:"Cannot cancel QStash watchdog until hosted KYNVER_SCHEDULER_PROVIDER=kynver-cron is live and a kynver-cron watchdog row exists. Set Vercel env, redeploy, re-run `kynver cron install`, then `--confirm-qstash-removal`."}}Or();Or();import{randomBytes as TI}from"node:crypto";function DI(){return TI(32).toString("base64url")}function cR(e=we){let r=cd();if(r)return{secret:r,generated:!1,source:"env"};let n=tn(e).get("KYNVER_CRON_SECRET")?.trim();return n?{secret:n,generated:!1,source:"env-file"}:{secret:DI(),generated:!0,source:"generated"}}Js();zs();D();function uR(e,r){if(r?.trim())return r.trim();if(e.defaultDaemonRunId?.trim())return e.defaultDaemonRunId.trim();let t=Z().runsDir;return dR(t)?X().sort((o,s)=>Date.parse(s.createdAt)-Date.parse(o.createdAt))[0]?.id??null:null}async function La(e={}){let r=e.execute!==!1,t=R(),n=ar(e.apiBaseUrl?.trim()||t.apiBaseUrl?.trim()||process.env.KYNVER_API_URL?.trim()||""),o=e.agentOsId?.trim()||t.agentOsId?.trim()||process.env.KYNVER_AGENT_OS_ID?.trim()||"",s=cR(),i=rR({config:t,apiBaseUrl:n,agentOsId:o,cronSecret:s.secret,defaultDaemonRunId:e.runId?.trim()||t.defaultDaemonRunId,installSystemd:e.installSystemd===!0}),a=[...i.prerequisites],l={ok:!1,dryRun:!r,plan:i,secretGenerated:s.generated,configPath:q(i.configPath),storeInitialized:!1,blockers:a};if(a.length)return l;if(r){let c=Vs(i.envUpdates,{filePath:i.envFilePath,removeKeys:i.envRemovals});l.envFile={path:q(c.path),changed:c.changed,keysWritten:c.keysWritten};let u={...t,...i.configUpdates},d=uR(u,e.runId);d&&(u.defaultDaemonRunId=d),ue(u),process.env.KYNVER_API_URL=n,process.env.KYNVER_CRON_SECRET=s.secret,process.env.KYNVER_CRON_STORE_PATH=i.storePath,process.env.KYNVER_CRON_TICK_ENABLED="1";let f=await dy(i.storePath);l.storeInitialized=f.created||dR(i.storePath);let p=se();if(p)try{let m=await ot(o,{baseUrl:n,apiKey:p});nt(o,m)}catch{}if(!e.skipWatchdog)if(!p)l.watchdog={error:"KYNVER_API_KEY required to register watchdog on server"},a.push("login \u2014 run `kynver login --api-key \u2026` to register watchdog remotely");else try{let m=await oR(n,o,p,void 0,{requireProvider:"kynver-cron"}),h=iR(o,m.requestedCron,m.dedupeKey),k={providerScheduleId:tR(h),spec:h,registeredAt:new Date().toISOString(),paused:!1};await uy(k,i.storePath),l.watchdog={remoteJobId:m.job.id,provider:m.selectedProvider??m.job.provider,localProviderScheduleId:k.providerScheduleId};let g=await nR(n,o,p),y=aR(g),_=["Phase 1 (local): `kynver cron install` writes box env/store and may fail remote watchdog until Vercel cutover.","Phase 2 (hosted): set KYNVER_SCHEDULER_PROVIDER=kynver-cron + KYNVER_CRON_SECRET on Vercel, redeploy, re-run install.","Phase 3 (cleanup): `kynver cron install --confirm-qstash-removal` after a kynver-cron watchdog row exists.","Analyst/market QStash schedules are never touched by this installer."],x=[];if(y.length)if(e.confirmQstashRemoval){let E=lR(g);if(!E.allowed)a.push(E.reason);else for(let A of y)await sR(n,o,A.id,p),x.push(A.id)}else a.push(`${y.length} QStash watchdog job(s) still active \u2014 complete Vercel cutover (KYNVER_SCHEDULER_PROVIDER=kynver-cron + KYNVER_CRON_SECRET), re-run install, then --confirm-qstash-removal`);l.qstashWatchdog={found:y.map(E=>({id:E.id,provider:E.provider,status:E.status})),removed:x,manualSteps:_}}catch(m){l.watchdog={error:m.message},a.push(`watchdog registration failed: ${m.message}`)}if(e.installSystemd){let m=uR({...t,...i.configUpdates},e.runId);if(!m)l.systemd={supported:i.systemdSupported,unitPath:null,written:!1,enabled:!1,started:!1,note:"No harness run found \u2014 run `kynver run create` first or pass --run <runId>."},a.push("harness run \u2014 create a run before installing systemd unit");else{try{L(m)}catch{a.push(`harness run ${m} not found`)}if(l.systemd=qs({envFilePath:i.envFilePath,agentOsId:o,runId:m,kynverBin:on()},r),r&&l.systemd.enabled){let h=R();ue({...h,daemonSupervisionOwner:"systemd"})}}}if(!e.skipTestFire&&a.length===0){let m=await An({agentOsIdFilter:o});l.testFire={fired:m.fired,errors:m.errors},m.errors>0&&a.push(`test fire reported ${m.errors} error(s) \u2014 check server KYNVER_CRON_SECRET matches`)}else e.skipTestFire&&(l.testFire={fired:0,errors:0,skipped:!0});l.verify=await Tn({config:R(),envFilePath:i.envFilePath}),l.blockers=a,l.ok=a.length===0&&(l.verify?.ok??!1)}else l.ok=a.length===0;return l}var MI=["deployment_provider","cron_secret","env_file","cron_store"];function pR(e){let r=e?.trim().toLowerCase();if(r==="qstash"||r==="kynver-cron"||r==="openclaw-cron")return r;if(r==="openclaw")return"openclaw-cron"}function UI(e){let r=pR(process.env.KYNVER_SCHEDULER_PROVIDER);if(r==="qstash"||r==="openclaw-cron")return!1;if(r==="kynver-cron")return!0;let t=pR(e.deploymentSchedulerProvider);return t==="qstash"||t==="openclaw-cron"?!1:t==="kynver-cron"?!0:!!(e.agentOsId?.trim()&&e.apiBaseUrl?.trim())}async function WI(e){if(!UI(e))return{expectsKynverCron:!1,ready:!0,failedChecks:[]};let t=(await Tn({config:e})).checks.filter(n=>MI.includes(n.id)&&!n.ok);return{expectsKynverCron:!0,ready:t.length===0,failedChecks:t}}function LI(e){let r=["Run `kynver cron install` on this box."];for(let t of e)t.remediation&&r.push(` \u2022 ${t.id}: ${t.remediation}`);return r}function Cd(e){return e===!0||e==="true"||e==="1"||e==="yes"||e==="on"}async function mR(e){if(Cd(e.args.skipCron))return{action:"skipped"};let r=await WI(e.config);if(!r.expectsKynverCron||r.ready)return{action:"ready"};console.log(""),console.log(" Local Kynver Cron is not ready \u2014 running `kynver cron install`\u2026");let t=Cd(e.args.installSystemd)||Cd(e.args["install-systemd"]),n=await La({execute:!0,skipTestFire:!0,agentOsId:e.agentOsId,runId:e.runId,installSystemd:t});if(n.ok)return console.log(" Kynver Cron configured for this box."),console.log(""),{action:"installed",installOk:!0};console.log(""),console.log(" Cron install did not fully complete (daemon will still start):");for(let o of n.blockers)console.log(` ! ${o}`);if(n.plan.deploymentSteps.length){console.log(""),console.log(" Hosted deployment (complete on Vercel, then re-run install):");for(let o of n.plan.deploymentSteps)console.log(` - ${o}`)}for(let o of LI(r.failedChecks))console.log(` ${o}`);return console.log(""),{action:"guided",installOk:!1,blockers:n.blockers}}N();Ie();qn();function fR(e=R(),r=process.env){let t=Ae(r,e),n=[...t.warnings],o=e.maxConcurrentWorkers,s=!1,i={...e};if(e.boxKind?.trim()||(i.boxKind=t.boxKind,s=!0,n.push(`persisted boxKind=${t.boxKind} to ~/.kynver/config.json \u2014 set explicitly via kynver setup --box-kind`)),$t(t.boxKind,o??0))o=4,i.maxConcurrentWorkers=4,i.maxConcurrentWorkersSource="setup-auto",s=!0,n.push(`clamped Forge maxConcurrentWorkers to ${4} (was ${e.maxConcurrentWorkers}; workspace aggregate caps are Ghost-only)`);else if(o!=null){let a=cr(t.boxKind,o);a!==o&&(o=a,i.maxConcurrentWorkers=a,s=!0,n.push(`clamped maxConcurrentWorkers to ${a} for ${t.boxKind} pool`))}return s&&ue(i),{repaired:s,boxKind:t.boxKind,maxConcurrentWorkers:o??4,warnings:n}}zs();Js();N();Or();co();Xs();uo();D();async function gR(e){let r=Qs(e.config,e.args),{policy:t}=r;if(!(t.owner==="systemd"&&lo(t.hostKind)))return{action:"keeper",owner:"keeper"};try{L(e.runId)}catch{return{action:"systemd_skipped",owner:"keeper",blockers:[`harness run ${e.runId} not found \u2014 cannot install systemd unit`]}}let o=qs({envFilePath:we,agentOsId:e.agentOsId,runId:e.runId,kynverBin:on()},!0),s=[];if(!o.supported)return s.push(o.note??"systemd user units not supported on this host"),{action:"systemd_guided",owner:"keeper",systemd:o,blockers:s};if(!o.enabled)return s.push(o.note??"systemd unit write/enable failed"),{action:"systemd_guided",owner:"keeper",systemd:o,blockers:s};let i=R();return ue({...i,daemonSupervisionOwner:"systemd"}),console.log(""),console.log(" Daemon supervision: systemd user unit enabled (`kynver daemon` with Restart=always)."),o.unitPath&&console.log(` unit: ${o.unitPath}`),console.log(""),{action:"systemd_installed",owner:"systemd",systemd:o}}function hR(e){return e.action==="systemd_installed"}function kR(e="kynver-cron-daemon"){return["Daemon delegated to systemd user unit.","The unit runs `kynver daemon` with systemd Restart=always.",`Status: systemctl --user status ${e}`,`Stop: systemctl --user stop ${e}`]}function HI(e,r){return e.filter(n=>n.repo===r&&!yr.has(n.status)).sort((n,o)=>(o.createdAt??"").localeCompare(n.createdAt??""))[0]?.id??null}async function yR(e){Pn();let r=R();(!se()||!r.agentOsId?.trim())&&(console.log(" This machine isn't linked yet \u2014 running bootstrap first."),await Ea(e),r=R());let t=(typeof e.agentOsId=="string"?e.agentOsId.trim():"")||r.agentOsId?.trim()||"";t||(console.error("No AgentOS workspace configured \u2014 run `kynver bootstrap` (or pass --agent-os-id)."),process.exit(1)),mo(t).ok||(console.error(ti(t)),process.exit(1)),e.chatOauth===!0&&r.chatUseClaudeOauth!==!0&&(ue({...r,chatUseClaudeOauth:!0}),r=R(),console.log(" Chat: Claude Code OAuth opt-in saved (delegated turns may use your local subscription)."));let o=(typeof e.repo=="string"?e.repo.trim():"")||r.defaultRepo?.trim()||je()?.repo||"";o||(console.error("No repo configured \u2014 pass --repo /path/to/repo or run `kynver setup --discover-repo`."),process.exit(1));let s=fR(r);if(s.repaired){r=R();for(let c of s.warnings)console.log(` ${c}`)}let i=typeof e.run=="string"&&e.run.trim()?e.run.trim():"";i||(i=HI(X(),o)??"",i?console.log(` Reusing run ${i} for ${o}.`):i=$o({...e,repo:o,name:"agent"}).runId),await mR({config:r,agentOsId:t,runId:i,args:e});let a=await gR({config:R(),agentOsId:t,runId:i,args:e});if(hR(a)){console.log("");for(let c of kR())console.log(` ${c}`);console.log("");return}console.log(""),console.log(` ${BI.hostname()} \u2014 agent coming online`),console.log(` workspace: ${t}`),console.log(` repo: ${o}`),console.log(` run: ${i}`),console.log(" Ctrl-C stops the agent. (Advanced control: `kynver daemon --help`.)"),console.log("");let l={...e,run:i,agentOsId:t};if(Da(l)){await Ma(l,FI(i,t,e));return}await ts(l)}function FI(e,r,t){if(!mo(r).ok)throw new Error(ti(r));let o=["daemon","--run",e,"--agent-os-id",r];return typeof t.intervalMs=="string"&&t.intervalMs.trim()&&o.push("--interval-ms",t.intervalMs.trim()),(t.execute===!1||t.execute==="false")&&o.push("--execute","false"),typeof t.stallMs=="string"&&t.stallMs.trim()&&o.push("--stall-ms",t.stallMs.trim()),o}D();D();z();import{existsSync as KI,rmSync as $I}from"node:fs";import wd from"node:path";function jI(e){let r=e.replace(/\\/g,"/").replace(/^\.\//,"").trim();if(!r||r.startsWith("/")||r.includes(".."))throw new Error(`unsafe path: ${e}`);return r}function VI(e){return typeof e!="string"||!e.trim()?[]:e.split(",").map(r=>r.trim()).filter(Boolean)}function GI(e){let{runId:r,workerName:t}=Fe(e),n=he(r,t),o=[...VI(e.path),...Array.isArray(e.paths)?e.paths:[]];if(o.length===0)return{ok:!1,removed:[],reason:"requires at least one --path"};let s=wd.resolve(n.worktreePath),i=[];for(let c of o){let u=jI(c),d=wd.resolve(s,u);if(!d.startsWith(s+wd.sep)&&d!==s)return{ok:!1,removed:i,reason:`path escapes worktree: ${c}`};if(!KI(d))return{ok:!1,removed:i,reason:`path not found: ${c}`};$I(d,{recursive:!0,force:!0}),i.push(u)}let a=Array.isArray(n.disposableArtifactsRemoved)?n.disposableArtifactsRemoved.filter(c=>typeof c=="string"):[];n.disposableArtifactsRemoved=[...new Set([...a,...i])],K(n.runId,n);let l=M(n);return{ok:!0,removed:i,...l.changedFiles.length?{reason:"worktree still has other changes"}:{}}}function RR(e){let r=GI(e);console.log(JSON.stringify(r,null,2)),r.ok||process.exit(1)}N();import yN from"node:path";so();Es();so();var YI=/--max-old-space-size=(\d+)/;function JI(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function _d(){return JI(process.env.KYNVER_NODE_OLD_SPACE_SIZE_MB,1024)}function Ha(e=process.env){let r={...e};if(process.env.KYNVER_NODE_OLD_SPACE_SIZE_MB==="0")return r;let t=r.NODE_OPTIONS??"";if(YI.test(t))return r;let o=`--max-old-space-size=${_d()}`;return r.NODE_OPTIONS=t.trim()?`${t.trim()} ${o}`:o,r}function Dn(e=_d()){return`--max-old-space-size=${e}`}Ys();N();so();Es();import{spawnSync as qI}from"node:child_process";function Fa(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function vR(e=R()){let r=process.env.KYNVER_BUILD_MEM_BUDGET_BYTES?Fa(process.env.KYNVER_BUILD_MEM_BUDGET_BYTES,1610612736):void 0,t=process.env.KYNVER_BUILD_MEM_RESERVE_BYTES?Fa(process.env.KYNVER_BUILD_MEM_RESERVE_BYTES,2147483648):void 0;return{perBuildBudgetBytes:r??Fa(e.perWorkerMemBytes,1610612736),reserveBytes:t??Fa(e.memReserveBytes,2147483648)}}var Ka=0;function Pd(){Ka+=1}function Ad(){Ka=Math.max(0,Ka-1)}function Et(e={}){let r={...vR(),...e},t=e.memAvailableBytes??jt(),n=r.perBuildBudgetBytes+r.reserveBytes,o=t>=n;return{admitted:o,memAvailableBytes:t,requiredBytes:n,activeBuilds:Ka,reason:o?null:`insufficient memory: need ${n} bytes available (budget ${r.perBuildBudgetBytes} + reserve ${r.reserveBytes}), have ${t}`}}function zI(e){e<=0||qI(process.execPath,["-e",`const d=Date.now()+${Math.floor(e)};while(Date.now()<d);`],{stdio:"ignore"})}function Od(e,r=2e3,t={}){let n=Date.now()+Math.max(0,e),o=Et({...t,memAvailableBytes:t.memAvailableBytes?.()});for(;!o.admitted&&Date.now()<n;)zI(Math.min(r,n-Date.now())),o=Et({...t,memAvailableBytes:t.memAvailableBytes?.()});return o}import{spawnSync as hN}from"node:child_process";C();import{closeSync as eN,existsSync as Id,mkdirSync as rN,openSync as tN,readdirSync as CR,readFileSync as nN,unlinkSync as Nd,writeFileSync as oN}from"node:fs";import Td from"node:path";import{mkdirSync as XI}from"node:fs";import{tmpdir as QI}from"node:os";import $a from"node:path";function ZI(){return!!(process.env.VERCEL||process.env.VERCEL_ENV||process.env.AWS_LAMBDA_FUNCTION_NAME||process.env.AWS_EXECUTION_ENV)}function SR(){let e=process.env.KYNVER_HEAVY_VERIFICATION_STATE_ROOT;return e?$a.resolve(e):ZI()?$a.join(QI(),"kynver","state","heavy-verification"):$a.join(Vi(),"heavy-verification")}function ns(){return $a.join(SR(),"slots")}function Mn(){let e=ns();return XI(e,{recursive:!0}),e}var Wn=120*6e4,ja=1;function sN(e,r){let t=Number(e);return!Number.isFinite(t)||t<=0?r:Math.floor(t)}function Ln(){let e=process.env.KYNVER_HEAVY_VERIFICATION_SKIP?.trim().toLowerCase();return e==="1"||e==="true"||e==="yes"}function Un(){let e=process.env.KYNVER_HEAVY_VERIFICATION_MAX_CONCURRENT;return e?sN(e,ja):ja}function iN(e){return`slot-${e}`}function wR(e,r=ns()){return Td.join(r,`${e}.json`)}function Dd(e){if(!Id(e))return null;try{let r=JSON.parse(nN(e,"utf8"));if(typeof r.slotId=="string"&&typeof r.pid=="number"&&typeof r.acquiredAt=="string"&&typeof r.command=="string")return r}catch{return null}return null}function Va(e,r=Wn){if(!e||!H(e.pid))return!0;let t=Date.parse(e.acquiredAt);return Number.isNaN(t)?!0:Date.now()-t>r}function aN(e,r){let t=Dd(e);if(Va(t,r))try{Nd(e)}catch{}}function lN(e){return rN(e,{recursive:!0}),e}function ss(e={}){let r=lN(e.slotsDir??Mn()),t=e.staleMs??Wn,n=0;for(let o of CR(r)){if(!o.endsWith(".json"))continue;let s=Td.join(r,o),i=Id(s);aN(s,t),i&&!Id(s)&&(n+=1)}return n}function Md(e={}){let r=e.slotsDir??Mn(),t=e.staleMs??Wn;ss({slotsDir:r,staleMs:t});let n=[];for(let o of CR(r)){if(!o.endsWith(".json"))continue;let s=Dd(Td.join(r,o));s&&!Va(s,t)&&n.push(s)}return n}function os(e={}){return Md(e).length}function Pt(e,r={}){if(Ln())return{admitted:!0,slotId:null,activeSlots:0,maxSlots:Un(),reason:null};let t=r.slotsDir??Mn(),n=r.staleMs??Wn,o=r.maxSlots??Un();ss({slotsDir:t,staleMs:n});for(let i=0;i<o;i+=1){let a=iN(i),l=wR(a,t),c=Dd(l);if(c&&Va(c,n))try{Nd(l)}catch{}else if(c&&!Va(c,n))continue;let u={slotId:a,pid:process.pid,acquiredAt:new Date().toISOString(),command:e};try{let d=tN(l,"wx");oN(d,JSON.stringify(u,null,2),"utf8"),eN(d);let f=os({slotsDir:t,staleMs:n});return{admitted:!0,slotId:a,activeSlots:f,maxSlots:o,reason:null}}catch(d){if(d.code==="EEXIST")continue;throw d}}let s=os({slotsDir:t,staleMs:n});return{admitted:!1,slotId:null,activeSlots:s,maxSlots:o,reason:`heavy verification at capacity (${s}/${o} slots)`}}function Bn(e,r={}){if(!e)return;let t=wR(e,r.slotsDir??ns());try{Nd(t)}catch{}}function Hn(e,r={}){if(Ln())return{admitted:!0,slotId:null,activeSlots:0,maxSlots:Un(),reason:null};let t=r.slotsDir??Mn(),n=r.staleMs??Wn,o=r.maxSlots??Un();ss({slotsDir:t,staleMs:n});let s=os({slotsDir:t,staleMs:n}),i=s<o;return{admitted:i,slotId:null,activeSlots:s,maxSlots:o,reason:i?null:`heavy verification at capacity (${s}/${o} slots); waiting for ${e}`}}import{spawnSync as cN}from"node:child_process";function uN(e){e<=0||cN(process.execPath,["-e",`const d=Date.now()+${Math.floor(e)};while(Date.now()<d);`],{stdio:"ignore"})}function Ga(e,r,t=2e3,n={}){let o=Date.now()+Math.max(0,r),s=Pt(e,n);for(;!s.admitted&&Date.now()<o;)uN(Math.min(t,o-Date.now())),s=Pt(e,n);return s}var dN=/\b(npm run typecheck|tsc\b[^|&;]*--noEmit|node scripts\/verify-pr-local\.mjs|kynver (harness )?verify)\b/i,pN=/\b(npm run build\b|next build\b)\b/i,mN=/\b(vercel (build|deploy|--prod))\b/i,fN=/\b(openai|anthropic|perplexity|voyage)\b.*\b(api|cli)\b|\b(paid|billable)[-_ ]?compute\b/i;function Ya(e){let r=e.trim();return r?fN.test(r)?{heavy:!0,commandClass:"paid_compute",reason:"paid external compute requires heavy-verification token and operator approval"}:mN.test(r)?{heavy:!0,commandClass:"vercel_verify",reason:"Vercel build/deploy verification requires heavy-verification token"}:pN.test(r)?{heavy:!0,commandClass:"full_build",reason:"full app build requires heavy-verification token"}:dN.test(r)?{heavy:!0,commandClass:"full_typecheck",reason:"full repo typecheck requires heavy-verification token"}:{heavy:!1,commandClass:"allowed",reason:null}:{heavy:!1,commandClass:"allowed",reason:null}}var is="heavy_verification_token_required";function Ja(e,r={}){let t=Ya(e);if(!t.heavy)return{allowed:!0,outcome:"allowed",commandClass:t.commandClass,reason:"command does not require heavy-verification token",verificationGate:{...Hn(e),slotId:null}};if(Ln())return{allowed:!0,outcome:"heavy_verification_skipped",commandClass:t.commandClass,reason:"KYNVER_HEAVY_VERIFICATION_SKIP bypasses gate",verificationGate:{...Hn(e),slotId:null}};let n=r.waitMs??0,o=n>0?Ga(e,n,r.pollMs):Pt(e);return o.admitted?{allowed:!0,outcome:"allowed",commandClass:t.commandClass,reason:t.reason??"heavy-verification token acquired",verificationGate:o}:{allowed:!1,outcome:is,commandClass:t.commandClass,reason:t.reason??o.reason??is,verificationGate:o}}Ce();import Ud from"node:path";function gN(e){let r=dr(fe()),t=Ud.relative(r,Ud.resolve(e));return t.length>0&&!t.startsWith("..")&&!Ud.isAbsolute(t)}function _R(e){return gN(e)?(typeof process.getuid=="function"?process.getuid():null)===0?{ok:!1,reason:"Refusing build/install as root inside a harness worktree \u2014 generated caches become root-owned and block daemon cleanup. Run kynver daemon and workers as the harness owner (never sudo kynver)."}:{ok:!0}:{ok:!0}}Ys();function kN(e){let r=[];for(let[t,n]of Object.entries(e))n!==void 0&&r.push(`${t}=${n}`);return r}function xR(e,r){let t=hN(e[0],e.slice(1),{cwd:r.cwd,env:r.env,encoding:"utf8",stdio:["ignore","pipe","pipe"],shell:r.shell,timeout:r.timeoutMs});return{exitCode:t.status??1,stdout:(t.stdout??"").trim(),stderr:(t.stderr??"").trim()}}function qa(e){let r=e.waitForAdmissionMs??6e5,t=Ja(e.command,{waitMs:r}),n=t.verificationGate;if(!t.allowed)return{ok:!1,exitCode:1,stdout:"",stderr:t.reason,admitted:!1,wrappedWithSystemd:!1,nodeOptionsFlag:Dn(),admission:Et(),verificationGate:n,gateOutcome:t.outcome,command:e.command};let o=n.slotId,s=r>0?Od(r):Et();if(!s.admitted)return Bn(o),{ok:!1,exitCode:1,stdout:"",stderr:s.reason??"build admission denied",admitted:!1,wrappedWithSystemd:!1,nodeOptionsFlag:Dn(),admission:s,verificationGate:n,command:e.command};let i=_R(e.cwd);if(!i.ok)return Bn(o),{ok:!1,exitCode:1,stdout:"",stderr:i.reason,admitted:!0,wrappedWithSystemd:!1,nodeOptionsFlag:Dn(),admission:s,verificationGate:n,command:e.command};let a=Ha({...process.env,...e.env}),l=Dn(),c=nn();Pd();try{let u;if(c){let d=Gs({cwd:e.cwd,command:["/usr/bin/env",...kN(a),"/bin/bash","-lc",e.command]});u=xR(d,{cwd:e.cwd,env:a,timeoutMs:e.timeoutMs})}else u=xR([e.command],{cwd:e.cwd,env:a,shell:!0,timeoutMs:e.timeoutMs});return{ok:u.exitCode===0,exitCode:u.exitCode,stdout:u.stdout,stderr:u.stderr,admitted:!0,wrappedWithSystemd:c,nodeOptionsFlag:l,admission:s,verificationGate:n,gateOutcome:t.outcome,command:e.command}}finally{Ad(),Bn(o)}}var za=["npm run typecheck","npm run test"];function as(e,r=za,t={}){let n=[],o=!0;for(let s of r){let i=qa({cwd:e,command:s,waitForAdmissionMs:t.waitForAdmissionMs,timeoutMs:t.timeoutMs});n.push({command:s,result:i}),i.ok||(o=!1)}return{passed:o,steps:n}}C();function ER(e){let r=e.indexOf(":");if(r<=0)throw new Error(`invalid --evidence ${e} (expected type:value)`);return{type:e.slice(0,r),value:e.slice(r+1)}}async function PR(e){let r=T(e.plan?String(e.plan):void 0,"plan"),t=(e.agentOsId?String(e.agentOsId):R().agentOsId)||"";t||(console.error("requires --agent-os-id or agentOsId in ~/.kynver/config.json"),process.exit(1));let n=T(e.role?String(e.role):void 0,"role"),o=T(e.status?String(e.status):void 0,"status"),s=[],i=e.evidence;if(Array.isArray(i))for(let _ of i)s.push(ER(String(_)));else typeof i=="string"&&s.push(ER(i));let a=V(e.baseUrl?String(e.baseUrl):void 0),l=await J(e.secret?String(e.secret):void 0,t,{baseUrl:a}),c=`${a}/api/agent-os/by-id/${encodeURIComponent(t)}/plans/${encodeURIComponent(r)}/progress-events`,u=R(),f=`provider:${yo(u.workerProvider,Oe)}`,m=(e.proposed===!0||e.proposed==="true"?!0:e.proposed===!1||e.proposed==="false"?!1:void 0)??(o!=="done"&&(n==="implementer"||n==="repair_implementer")),h={rowKey:e.row?String(e.row):void 0,rowId:e.rowId?String(e.rowId):void 0,taskId:e.task?String(e.task):void 0,reviewTaskId:e.reviewTask?String(e.reviewTask):void 0,roleLane:n,status:o,note:e.note?String(e.note):void 0,remainingWork:e.remaining?String(e.remaining):void 0,evidence:s.length?s:void 0,executorRef:e.executorRef?String(e.executorRef):f};m!==void 0&&(h.proposed=m);let k=await fetch(c,{method:"POST",headers:He(l),body:JSON.stringify(h)}),g=await k.text(),y=null;try{y=JSON.parse(g)}catch{y=g}k.ok||(console.error(JSON.stringify({httpStatus:k.status,response:y},null,2)),process.exit(1)),console.log(JSON.stringify(y,null,2))}function RN(e){let r=T(e.worktree?String(e.worktree):void 0,"worktree"),t=yN.resolve(r),n=as(t),o=e.json===!0||e.json==="true",s={passed:n.passed,worktree:t,steps:n.steps};console.log(o?JSON.stringify(s,null,2):n.passed?"local plan verify passed":"local plan verify failed"),n.passed||process.exit(1)}async function AR(e){let r=T(e.plan?String(e.plan):void 0,"plan");if(e.local===!0||e.local==="true"){RN(e);return}let n=R().agentOsSlug;n||(console.error("requires agentOsSlug in ~/.kynver/config.json for verify (session route)"),process.exit(1));let o=V(e.baseUrl?String(e.baseUrl):void 0),s=process.env.KYNVER_API_KEY,i={"Content-Type":"application/json"};s&&(i.Authorization=`Bearer ${s}`);let a=`${o}/api/agent-os/${encodeURIComponent(n)}/plans/${encodeURIComponent(r)}/verify`,l=await fetch(a,{method:"POST",headers:i,body:JSON.stringify({worktreePath:e.worktree?String(e.worktree):void 0,taskId:e.task?String(e.task):void 0,humanOverride:e.humanOverride===!0||e.humanOverride==="true"})}),c=await l.text(),u=null;try{u=JSON.parse(c)}catch{u=c}l.ok||(console.error(JSON.stringify({httpStatus:l.status,response:u},null,2)),process.exit(1)),console.log(JSON.stringify(u,null,2))}import bN from"node:path";C();function OR(e){let r=bN.resolve(T(e.worktree?String(e.worktree):void 0,"worktree")),t=e.json===!0||e.json==="true"||e.emitJson===!0||e.emitJson==="true",n=[],o=e.command;if(Array.isArray(o))for(let a of o)n.push(String(a));else typeof o=="string"&&n.push(o);let s=as(r,n.length?n:za,{waitForAdmissionMs:e.waitForAdmissionMs?Number(e.waitForAdmissionMs):void 0,timeoutMs:e.timeoutMs?Number(e.timeoutMs):void 0}),i={passed:s.passed,worktree:r,steps:s.steps.map(a=>({command:a.command,ok:a.result.ok,exitCode:a.result.exitCode,admitted:a.result.admitted,wrappedWithSystemd:a.result.wrappedWithSystemd,nodeOptionsFlag:a.result.nodeOptionsFlag,admission:a.result.admission,verificationGate:a.result.verificationGate,stderr:a.result.stderr.slice(0,4e3)}))};if(t)console.log(JSON.stringify(i,null,2));else{console.log(s.passed?"harness verify passed":"harness verify failed");for(let a of i.steps)console.log(` ${a.ok?"\u2713":"\u2717"} ${a.command} (exit ${a.exitCode}, systemd=${a.wrappedWithSystemd})`),!a.ok&&a.stderr&&console.log(` ${a.stderr.split(`
|
|
54
|
+
`)[0]}`)}process.exit(s.passed?0:1)}N();import{readFileSync as vN}from"node:fs";C();var SN=["create","add_version","update_metadata"],CN=["approval_guard","auth","network","server","tool_interruption"];function wN(e){let r=e.bodyFile?String(e.bodyFile):void 0;if(r)return{body:vN(r,"utf8"),bodyPathHint:r};let t=e.body?String(e.body):void 0;if(t)return{body:t};throw new Error("requires --body-file PATH or --body TEXT")}async function IR(e){let r=T(e.operation?String(e.operation):void 0,"operation");if(!SN.includes(r))throw new Error(`invalid --operation ${r}`);let t=r,n=R(),o=T(e.slug?String(e.slug):n.agentOsSlug,"slug (or agentOsSlug in ~/.kynver/config.json)"),s=T(e.title?String(e.title):void 0,"title"),{body:i,bodyPathHint:a}=wN(e);a&&To(a)&&console.warn(JSON.stringify({warning:"/tmp-only body path is not durable; AgentOS persistence requires outbox or successful API write",bodyPathHint:a}));let l={operation:t,agentOsSlug:o,title:s,body:i,bodyPathHint:a,summary:e.summary?String(e.summary):void 0,planId:e.plan?String(e.plan):void 0,planSlug:e.planSlug?String(e.planSlug):void 0,changeSummary:e.changeSummary?String(e.changeSummary):void 0,author:e.author?String(e.author):void 0,model:e.model?String(e.model):void 0,maxRetries:e.maxRetries?Number(e.maxRetries):void 0,immediateFailure:_N(e)},c=await kn(l);console.log(JSON.stringify(c,null,2)),c.userStatus==="failed and needs action"&&process.exit(1)}function _N(e){let r=e.failureKind?String(e.failureKind):void 0;if(!r)return;if(!CN.includes(r))throw new Error(`invalid --failure-kind ${r}`);let t=e.failureMessage?String(e.failureMessage):`immediate failure (${r})`;return{kind:r,message:t}}async function NR(){let e=kt();console.log(JSON.stringify({count:e.length,items:e},null,2))}async function TR(e){let r=e.max?Number(e.max):void 0,t=e.id?String(e.id):void 0,n=await Yi({max:r,outboxId:t});console.log(JSON.stringify(n,null,2)),n.failed>0&&process.exit(1)}function DR(e){let r=e.execute===!0||e.execute==="true",t=e.skipFinalize===!0||e.skipFinalize==="true",n=e.accountBytes===!0||e.accountBytes==="true",o=e.compact===!0||e.compact==="true",s=e.nodeModulesAgeMs,i=s!=null&&s!=="",a=i?Number(s):void 0,l=e.worktreesAgeMs?Number(e.worktreesAgeMs):0,c=e.includeOrphans===!0||e.includeOrphans==="true",u=e.harnessRoot?String(e.harnessRoot):void 0,d=xa({execute:r,finalizeStaleRuns:!t,accountBytes:n,scanDependencyCaches:i,nodeModulesAgeMs:a!==void 0&&Number.isFinite(a)?a:i?216e5:void 0,worktreesAgeMs:Number.isFinite(l)?l:0,includeOrphans:c,harnessRoot:u});o&&d.compactSummary?console.log(JSON.stringify(d.compactSummary,null,2)):console.log(JSON.stringify(d,null,2)),r&&d.totals.removedPaths===0&&d.actions.length===0&&(process.exitCode=0)}Vt();function MR(e){let r=e.execute===!0||e.execute==="true",t=e.json===!0||e.json==="true",n=e["purge-all"]===!0||e["purge-all"]==="true",o=e["keep-newest"]?Number(e["keep-newest"]):void 0;if(r||n){let a=Uo({execute:r,purgeAll:n,keepNewest:o}),l={...a,observation:a.observation?{...a.observation,dumps:a.observation.dumps.map(c=>({name:c.name,bytes:c.bytes,executableHint:c.executableHint,mtimeMs:c.mtimeMs}))}:null};console.log(JSON.stringify(l,null,t?2:0));return}let s=ur(),i=s?{...s,dumps:s.dumps.map(a=>({name:a.name,bytes:a.bytes,executableHint:a.executableHint,mtimeMs:a.mtimeMs}))}:{skipped:!0,reason:"not_wsl"};console.log(JSON.stringify(i,null,t?2:0))}function UR(e){let r=e.trim();if(!r.startsWith("{")&&!r.startsWith("["))return null;try{return JSON.parse(r)}catch{return null}}function ie(e,r=2400){if(e==null)return;let n=(typeof e=="string"?e:JSON.stringify(e,null,2)).trim();if(n)return n.length<=r?n:`${n.slice(0,r-1).trimEnd()}\u2026`}function Xa(e){let r=e.trim();if(!r)return null;let t=UR(r);if(t!==null)return t;for(let n of r.split(`
|
|
55
|
+
`)){let o=UR(n);if(o!==null)return o}return null}function Qa(e){let r=[];switch(r.push(`Background auto-complete \xB7 ${e.runId} / ${e.worker}`),e.outcome){case"completed":r.push("Outcome: harness completion posted to AgentOS successfully."),r.push("AgentOS task should close or advance to review per completion routing."),r.push("Next: check Command Center \u2014 no manual complete needed unless the board still shows running.");break;case"blocked":r.push(`Outcome: worker finished but completion was blocked${e.httpStatus?` (HTTP ${e.httpStatus})`:""}.`),e.reason&&r.push(`Blocker: ${e.reason}`),r.push("Next: fix the blocker (auth, landing gate, dirty worktree) and replay completion from Command Center.");break;case"timed_out":r.push(`Outcome: monitor gave up waiting \u2014 ${e.reason??"worker did not finish in time"}.`),r.push("Next: inspect the worker process/logs; stop or unblock the worker, then retry auto-complete.");break;case"missing_link":r.push(`Outcome: cannot complete \u2014 ${e.reason??"worker missing agentOsId/taskId"}.`),r.push("Next: re-dispatch with board linkage or run `kynver worker complete` with --agent-os-id.");break;default:r.push(`Outcome: ${e.outcome}`)}return{primary:r.join(`
|
|
56
|
+
`),diagnostic:ie(e)}}function Fn(e){let r=[],t=typeof e.monitorId=="string"?e.monitorId:void 0;if(r.push(t?`Harness monitor tick \xB7 ${e.runId} (${t})`:`Harness monitor tick \xB7 ${e.runId}`),!e.workers.length)return r.push("No workers in scope for this poll."),{primary:r.join(`
|
|
57
57
|
`),diagnostic:ie(e)};for(let i of e.workers){let a=i.autoComplete.eligible?"eligible for auto-complete":"not auto-completing",l=i.autoComplete.blockers.length>0?` (${i.autoComplete.blockers.slice(0,2).join("; ")})`:"";r.push(`\u2022 ${i.worker}: ${i.workerStatus}, ${i.health}${i.healthReason?` \u2014 ${i.healthReason}`:""}; ${a}${l}`),i.taskStatus&&r.push(` Board task: ${i.taskStatus}${i.leaseOwner?` (lease: ${i.leaseOwner})`:""}`)}let n=e.autoCompleted?.filter(i=>i.outcome==="completed"&&i.ok)??[],o=e.autoCompleted?.filter(i=>!i.ok&&i.outcome!=="skipped")??[];n.length&&r.push(`Auto-completed: ${n.map(i=>i.worker).join(", ")} \u2014 AgentOS completion should be posted.`),o.length&&r.push(`Auto-complete blocked: ${o.map(i=>`${i.worker}${i.reason?` (${i.reason})`:""}`).join("; ")}`),e.leaseRenewal?.failed?.length&&r.push(`Lease renew failed for: ${e.leaseRenewal.failed.map(i=>i.worker).join(", ")}`);let s=e.workers.length>0&&e.workers.every(i=>i.autoComplete.terminalVerified)&&(e.autoCompleted?.every(i=>i.ok||i.outcome==="skipped")??!0);return r.push(s?"Next: monitor loop should stop \u2014 all workers terminal and handled.":"Next: monitor will poll again until workers are terminal-verified or max time elapses."),{primary:r.join(`
|
|
58
|
-
`),diagnostic:ie(e)}}function
|
|
59
|
-
`),diagnostic:ie(e)};let l=ir(i?.outcome),c=
|
|
60
|
-
`),diagnostic:ie(e)}}function _e(e){return typeof e=="string"&&e.trim()?e.trim():null}function
|
|
61
|
-
`),diagnostic:ie(e)}}var
|
|
58
|
+
`),diagnostic:ie(e)}}function Wd(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)?e:null}function ir(e){return typeof e=="string"&&e.trim()?e.trim():null}function Za(e){let r=Wd(e);if(!r)return{primary:"Harness worker complete finished with no parseable result.",diagnostic:ie(e)};let t=ir(r.worker)??"worker",n=ir(r.runId),o=ir(r.status)==="skipped",s=typeof r.httpStatus=="number"?r.httpStatus:null,i=Wd(r.response),a=[];if(a.push(`Harness worker complete \xB7 ${t}${n?` (${n})`:""}`),o)return a.push(`Outcome: skipped \u2014 ${ir(r.reason)??"worker not finished yet"}.`),a.push("Next: wait for the worker to exit or post a finalResult, then retry complete."),{primary:a.join(`
|
|
59
|
+
`),diagnostic:ie(e)};let l=ir(i?.outcome),c=Wd(i?.task),u=ir(c?.status),d=ir(c?.prUrl)??ir(i?.prUrl);if(s&&s>=200&&s<300)a.push("Outcome: completion callback accepted by AgentOS."),l&&a.push(`Routing: ${l.replace(/_/g," ")}`),u&&a.push(`AgentOS task status: ${u}`),d&&a.push(`PR: ${d}`),a.push("Next: check Command Center for review scheduling or blockers.");else{a.push(`Outcome: completion failed${s!=null?` (HTTP ${s})`:""}.`);let f=ir(i?.detail)??ir(i?.error);f&&a.push(`Blocker: ${f}`),a.push("Next: fix the reported blocker and replay completion from the board.")}return{primary:a.join(`
|
|
60
|
+
`),diagnostic:ie(e)}}function _e(e){return typeof e=="string"&&e.trim()?e.trim():null}function Ld(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)?e:null}function xN(e){let r=Ld(e);return r?_e(r.prUrl)??_e(r.pr):null}function ls(e){let r=Ld(e);if(!r)return{primary:"Harness worker status unavailable.",diagnostic:ie(e)};let t=_e(r.worker)??_e(r.name)??"worker",n=_e(r.runId),o=_e(r.status)??"unknown",s=r.alive===!0,i=Ld(r.attention),a=_e(i?.state)??_e(r.attentionState),l=_e(i?.reason)??_e(r.attentionReason),c=_e(r.taskId),u=_e(r.prUrl)??xN(r.finalResult),d=_e(r.branch),f=_e(r.headCommit),p=[];return p.push(`Harness worker ${t}${n?` (${n})`:""}`),p.push(`Process: ${s?"running":"stopped"} \xB7 harness status: ${o}`),a&&p.push(l?`Attention: ${a} \u2014 ${l}`:`Attention: ${a}`),c&&p.push(`AgentOS task: ${c}`),u&&p.push(`PR: ${u}`),d&&p.push(`Branch: ${d}`),f&&p.push(`Commit: ${f.slice(0,12)}`),o==="done"||o==="exited"?p.push(u?"Outcome: worker finished \u2014 open the PR or check Command Center for review routing.":"Outcome: worker finished \u2014 check Command Center for task status and next action."):a==="blocked"||a==="needs_attention"?p.push("Next: resolve the blocker on the board or wait for the monitor to auto-complete when terminal."):s&&p.push("Next: wait for completion or poll again; background monitor will auto-complete when eligible."),{primary:p.join(`
|
|
61
|
+
`),diagnostic:ie(e)}}var EN="\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 Diagnostic (JSON) \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500";function WR(e){return e.diagnostic?.trim()?`${e.primary}
|
|
62
62
|
|
|
63
|
-
${
|
|
64
|
-
${e.diagnostic}`:e.primary}function
|
|
65
|
-
`).slice(-3).join(" ")}`),r.push("Next: retry on the runner host or inspect harness logs.");let n=
|
|
66
|
-
`),diagnostic:ie(n??{stdout:e.stdout,stderr:e.stderr})}}function
|
|
67
|
-
${t.slice(0,800)}`,diagnostic:ie({stdout:e.stdout,stderr:e.stderr})}}if(e.scope==="worker"&&e.action==="status")return
|
|
68
|
-
`),diagnostic:ie(r)}}if(e.scope==="run"&&e.action==="status"){let t=r.workers;return Array.isArray(t)&&t.length===1?is(t[0]):{primary:`Harness run status \xB7 ${r.runId??"run"} (${Array.isArray(t)?t.length:0} workers).`,diagnostic:ie(r)}}return{primary:`Harness ${e.scope} ${e.action} completed successfully on the runner.`,diagnostic:ie(r)}}import hN from"node:path";T();z();C();z();C();function Za(e){let{worker:r,status:t,taskLease:n}=e,o=n?.leaseOwner??null;if(r.dispatched&&n){if(n.status==="running"&&o&&!xc(o,r.runId))return{health:"orphaned",reason:`task lease held by ${o}, expected harness run ${r.runId}`};let i=r.leaseToken?.trim()??"",a=n.leaseToken?.trim()??"";if(n.status==="running"&&i&&a&&i!==a)return{health:"orphaned",reason:"task leaseToken superseded on board \u2014 completion replay would fail"};if(n.status==="running"&&!t.alive&&!t.finalResult)return{health:"orphaned",reason:"board task running but worker process is not alive"}}if(r.status==="running"&&!t.alive&&!t.finalResult)return{health:"orphaned",reason:"worker.json still running but process is dead"};if(t.attention.state==="stale")return{health:"stale",reason:t.attention.reason};let s=t.lastHeartbeatAt?Date.parse(t.lastHeartbeatAt):NaN;return t.alive&&Number.isFinite(s)&&Date.now()-s>Xt?{health:"stale",reason:`heartbeat older than ${Math.floor(Xt/1e3)}s`}:t.alive&&r.pid&&!H(r.pid)?{health:"orphaned",reason:"pid recorded but process is not alive"}:n?.status==="running"&&!t.alive&&t.finalResult?{health:"healthy",reason:"finished worker awaiting completion replay"}:{health:"healthy",reason:t.attention.reason||"worker within expected lifecycle bounds"}}Ce();C();import{existsSync as AR,mkdirSync as mN,readdirSync as fN,unlinkSync as gN}from"node:fs";import Md from"node:path";function IR(){let{harnessRoot:e}=qr(),r=Md.join(e,"monitors");return mN(r,{recursive:!0}),r}function Pt(e,r){return r?`${b(e)}--${b(r)}`:b(e)}function Ud(e){return Md.join(IR(),`${e}.json`)}function At(e){return w(Ud(e),void 0)}function It(e){ae(Ud(e.monitorId),e)}function Wd(e){let r=Ud(e);return AR(r)?(gN(r),!0):!1}function OR(){let e=IR();if(!AR(e))return[];let r=[];for(let t of fN(e)){if(!t.endsWith(".json"))continue;let n=w(Md.join(e,t),void 0);n?.monitorId&&r.push({monitorId:n.monitorId,runId:n.runId,workerName:n.workerName,agentOsId:n.agentOsId,pid:n.pid,alive:n.pid?H(n.pid):!1,startedAt:n.startedAt,pollMs:n.pollMs,logPath:n.logPath})}return r.sort((t,n)=>t.startedAt.localeCompare(n.startedAt))}z();function as(e){let{worker:r,status:t}=e,n=[];r.localOnly&&n.push("local-only worker (no board linkage)"),(!r.agentOsId||!r.taskId)&&n.push("missing agentOsId/taskId linkage"),_i(r)&&n.push("completion already acknowledged"),r.completionBlocker&&n.push(r.completionBlocker),t.heartbeatBlocker&&t.alive&&n.push(`worker heartbeat blocker: ${t.heartbeatBlocker}`),t.attention.state==="blocked"&&n.push(t.attention.reason||"worker attention blocked"),et(t)&&n.push(t.attention.reason||"landing gate blocked");let o=oe(t),s;return o?t.finalResult?s="final_result":t.alive?s="terminal_status":s="process_exited":n.push("worker has not reached a terminal condition"),{eligible:o&&n.length===0,terminalVerified:o,terminalReason:s,blockers:n}}function NR(e,r){return w(hN.join(x(e),"workers",b(r),"worker.json"),void 0)}function TR(e,r){let t=L(e),n=Object.keys(t.workers||{});if(!r)return n;let o=b(r);return n.filter(s=>b(s)===o)}function DR(e,r){let t=L(e.runId),n=D(e,{base:t.base,baseCommit:t.baseCommit}),o=e.taskId?r.get(e.taskId)??null:null,s=Za({worker:e,status:n,taskLease:o}),i=as({worker:e,status:n});return{runId:e.runId,worker:e.name,health:s.health,healthReason:s.reason,workerStatus:n.status,attentionState:n.attention.state,attentionReason:n.attention.reason,alive:n.alive,taskId:e.taskId,leaseOwner:o?.leaseOwner??void 0,taskStatus:o?.status,autoComplete:i,status:n}}async function Ot(e){let r=String(e.run||"");N(r,"--run");let t=e.name?String(e.name):void 0,n=e.agentOsId?String(e.agentOsId):void 0,o=L(r),s=TR(r,t),i=[];for(let f of s){let h=NR(r,f);h&&i.push(h)}let a=n||i.map(f=>f.agentOsId).find(f=>typeof f=="string"&&f.trim())||void 0,l=i.map(f=>f.taskId).filter(f=>!!f),c=await pn({agentOsId:a,taskIds:l,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0}),u=i.map(f=>DR(f,c)),d;a&&e.renewLeases!==!1&&e.renewLeases!=="false"&&(d=await vi(r,{...e,agentOsId:a}));let m=[];if(e.autoComplete===!0||e.autoComplete==="true")for(let f of u){if(!f.autoComplete.eligible){m.push({worker:f.worker,outcome:"skipped",ok:!1,reason:f.autoComplete.blockers.join("; ")||"not eligible"});continue}let h=await ft({run:r,name:f.worker,...a?{agentOsId:a}:{},...e.baseUrl?{baseUrl:String(e.baseUrl)}:{},...e.secret?{secret:String(e.secret)}:{}});m.push({worker:f.worker,outcome:h.outcome,ok:h.outcome==="completed",reason:h.reason})}return{runId:r,agentOsId:a,workers:u,leaseRenewal:d,autoCompleted:m}}function el(e){let r=String(e.run||"");N(r,"--run");let t=e.name?String(e.name):void 0,n=TR(r,t),o=[];for(let s of n){let i=NR(r,s);i&&o.push(DR(i,new Map))}return{runId:r,workers:o,autoCompleted:[]}}function ls(){return OR()}function Ld(e){let r=String(e.run||"");N(r,"--run");let t=Pt(r,e.name?String(e.name):void 0),n=At(t);if(!n)return{monitorId:t,stopped:!1};if(n.pid&&H(n.pid))try{process.kill(n.pid,"SIGTERM")}catch{}return n.stoppedAt=new Date().toISOString(),It(n),Wd(t),{monitorId:t,stopped:!0,pid:n.pid}}async function rl(e){let r=String(e.run||""),t=String(e.name||"");N(r,"--run"),N(t,"--name");let n=he(r,t),o=L(r),s=D(n,{base:o.base,baseCommit:o.baseCommit}),i=as({worker:n,status:s});if(!i.eligible){console.log(JSON.stringify({runId:r,worker:t,outcome:"blocked",blockers:i.blockers,terminalVerified:i.terminalVerified},null,2)),process.exitCode=1;return}let a=await ft({...e,run:r,name:t});console.log(JSON.stringify(a,null,2)),a.outcome!=="completed"&&a.outcome!=="blocked"&&(process.exitCode=1)}C();var kN=5e3,yN=360*60*1e3;async function Bd(e){let r=String(e.monitorId||""),t=Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):kN,n=Number(e.maxTotalMs)>0?Math.floor(Number(e.maxTotalMs)):yN,o=Date.now();for(;Date.now()-o<=n;){let s=r?At(r):void 0;if(s?.stoppedAt)break;let i=await Ot({...e,autoComplete:e.autoComplete??!0,renewLeases:e.renewLeases??!0}),a=Hn({monitorId:r,phase:"tick",...i});if(console.log(a.primary),a.diagnostic&&console.error(`[monitor diagnostic] ${a.diagnostic}`),i.workers.length>0&&i.workers.every(c=>c.autoComplete.terminalVerified&&(c.autoComplete.eligible||c.autoComplete.blockers.some(u=>u.includes("already acknowledged"))))&&i.autoCompleted.every(c=>c.ok||c.outcome==="skipped")){r&&s&&(s.stoppedAt=new Date().toISOString(),It(s));break}$r(t)}}C();Ce();import{spawn as RN}from"node:child_process";import{closeSync as MR,existsSync as vN,openSync as bN}from"node:fs";import SN from"node:path";function tl(e){let r=e.nodeExecutable??process.execPath,t=Wi({importMetaUrl:import.meta.url,explicitCliPath:e.cliPath,nodeExecutable:r});if(!t)return;let n=t.cliPath;if(!vN(n))return;let o=Pt(e.runId,e.workerName),{harnessRoot:s}=qr(),i=SN.join(s,"monitors",`${o}.log`),a;try{a=bN(i,"a")}catch{a=void 0}let l=e.pollMs??5e3,c=[...t.argsPrefix,"monitor","run-loop","--run",e.runId,"--monitor-id",o,"--poll-ms",String(l),"--auto-complete","true","--renew-leases","true"];e.workerName&&c.push("--name",e.workerName),e.agentOsId&&c.push("--agent-os-id",e.agentOsId),e.baseUrl&&c.push("--base-url",e.baseUrl),e.secret&&c.push("--secret",e.secret);let u=["ignore",a??"ignore",a??"ignore"];try{let d=RN(t.command,c,pe({detached:!0,stdio:u,env:process.env}));a!==void 0&&MR(a),d.unref();let m={monitorId:o,runId:e.runId,workerName:e.workerName,agentOsId:e.agentOsId,pid:d.pid,startedAt:new Date().toISOString(),pollMs:l,logPath:i};return It(m),{monitorId:o,pid:d.pid,logPath:i,session:m}}catch{if(a!==void 0)try{MR(a)}catch{}return}}C();async function UR(e){let r=String(e.run||"");N(r,"--run");let t=e.name?String(e.name):void 0,n=Pt(r,t),o=At(n);if(o?.pid&&!o.stoppedAt)return{monitorId:n,session:o,spawned:!1,pid:o.pid};let s=tl({runId:r,workerName:t,agentOsId:e.agentOsId?String(e.agentOsId):void 0,pollMs:Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):void 0,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0});if(!s)throw new Error("failed to spawn monitor sidecar (cli.js missing or spawn error)");return{monitorId:n,session:s.session,spawned:!0,pid:s.pid}}async function WR(e){if(String(e.run||"")){let t=e.tick===!0||e.tick==="true"?await Ot({...e,autoComplete:!1}):el(e);console.log(JSON.stringify(t,null,2));return}console.log(JSON.stringify({monitors:ls()},null,2))}function LR(e){console.log(JSON.stringify(Ld(e),null,2))}function BR(){console.log(JSON.stringify({monitors:ls()},null,2))}async function HR(e){await Bd(e)}async function FR(e){let r=await Ot(e);console.log(JSON.stringify(r,null,2))}T();z();C();I();import CN from"node:path";function cs(e,r,t,n,o,s){return{runId:e,worker:r,taskId:t,agentOsId:n,leaseOwner:o,action:"skipped",reason:s}}async function wN(e){let r=V(e.baseUrl?String(e.baseUrl):void 0),t=e.agentOsId?String(e.agentOsId).trim():null,n=e.dryRun===!0||e.dryRun==="true",o=[],s=[],i=[];for(let a of X())for(let l of Object.keys(a.workers??{})){let c=CN.join(x(a.id),"workers",b(l),"worker.json"),u=w(c,void 0);if(!u){s.push(cs(a.id,l,"","","","worker.json missing"));continue}let d=u.taskId??"",m=u.agentOsId??"",p=u.leaseOwner??"";if(!u.dispatched||!d||!m||!p){s.push(cs(a.id,l,d,m,p,"not a fully-leased dispatched worker"));continue}if(t&&m!==t)continue;if(u.completionReportedAt){s.push(cs(a.id,l,d,m,p,"completion already reported"));continue}let f=D(u);if(f.finalResult){s.push(cs(a.id,l,d,m,p,"has final result \u2014 let pipeline tick complete it"));continue}if(f.alive){s.push(cs(a.id,l,d,m,p,"worker process is still alive"));continue}if(n){o.push({runId:a.id,worker:l,taskId:d,agentOsId:m,leaseOwner:p,action:"released",reason:"dry-run: would release dead dispatched worker lease"});continue}try{let h=await J(e.secret?String(e.secret):void 0,m,{baseUrl:r}),k=`${r}/api/agent-os/by-id/${encodeURIComponent(m)}/tasks/${encodeURIComponent(d)}/release`,g=await re(k,h,{agentOsId:m,leaseOwner:p},{agentOsId:m,baseUrl:r});g.ok===!0||g.response?.ok===!0?o.push({runId:a.id,worker:l,taskId:d,agentOsId:m,leaseOwner:p,action:"released",reason:"dead dispatched worker lease released; task requeued"}):s.push({runId:a.id,worker:l,taskId:d,agentOsId:m,leaseOwner:p,action:"skipped",reason:`release returned ok:false (likely owner mismatch or already released): HTTP ${g.status}`})}catch(h){i.push({runId:a.id,worker:l,taskId:d,agentOsId:m,leaseOwner:p,action:"error",reason:h.message})}}return{dryRun:n,released:o,skipped:s,errors:i}}async function KR(e){let r=await wN(e),t={ok:r.errors.length===0,dryRun:r.dryRun,released:r.released.length,skipped:r.skipped.length,errors:r.errors.length,details:r};console.log(JSON.stringify(t,null,2)),r.errors.length>0&&process.exit(1)}import XR from"node:path";Je();I();import{accessSync as _N,constants as xN,existsSync as Hd,readFileSync as EN}from"node:fs";import{homedir as nl}from"node:os";import ol from"node:path";import{spawnSync as PN}from"node:child_process";Ce();function $R(e,r){try{let t=PN(e,r,{encoding:"utf8"}),n=(t.stdout||"").trim(),o=(t.stderr||"").trim();return{ok:t.status===0,stdout:n,stderr:o,error:t.error?.message}}catch(t){return{ok:!1,stdout:"",stderr:"",error:t.message}}}function jR(e){let r=e?.trim();if(r)return r.length<=12?`${r}\u2026`:`${r.slice(0,12)}\u2026`}function AN(e){if(!Hd(e))return!1;try{return _N(e,xN.W_OK),!0}catch{return!1}}var VR={packageVersion:()=>Kn,commandOnPath:e=>$R(process.platform==="win32"?"where":"which",[e]),kynverVersion:e=>$R(e,["--version"]),loadConfig:()=>y(),configFilePath:()=>ol.join(nl(),".kynver","config.json"),credentialsFilePath:()=>ol.join(nl(),".kynver","credentials"),readCredentials:()=>{let e=ol.join(nl(),".kynver","credentials");if(!Hd(e))return{hasApiKey:!1};try{let r=JSON.parse(EN(e,"utf8"));return{hasApiKey:!!r.apiKey?.trim(),runnerTokenPrefix:jR(r.runnerToken),runnerTokenAgentOsId:r.runnerTokenAgentOsId}}catch{return{hasApiKey:!1}}},envSnapshot:()=>({kynverApiUrl:process.env.KYNVER_API_URL?.trim()||void 0,openclawCronFireBaseUrl:process.env.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||void 0,kynverRunnerTokenPrefix:jR(process.env.KYNVER_RUNNER_TOKEN),kynverRuntimeSecret:!!process.env.KYNVER_RUNTIME_SECRET?.trim(),openclawCronSecret:!!process.env.OPENCLAW_CRON_SECRET?.trim(),kynverHarnessRoot:process.env.KYNVER_HARNESS_ROOT?.trim()||void 0,opusHarnessRoot:process.env.OPUS_HARNESS_ROOT?.trim()||void 0,kynverSchedulerProvider:process.env.KYNVER_SCHEDULER_PROVIDER?.trim()||void 0,openclawCronStorePath:!!(process.env.KYNVER_CRON_STORE_PATH?.trim()||process.env.OPENCLAW_CRON_STORE_PATH?.trim()),kynverCronDaemonPrimary:Ea(),qstashTokenPresent:!!process.env.QSTASH_TOKEN?.trim(),kynverHostedDeployment:(()=>{let e=process.env.KYNVER_HOSTED_DEPLOYMENT?.trim().toLowerCase();return e==="1"||e==="true"||e==="yes"})()}),harnessRoot:()=>fe(),legacyOpenclawHarnessRoot:()=>ol.join(nl(),".openclaw","harness"),pathExists:e=>Hd(e),pathWritable:e=>AN(e)};function GR(e,r){return e.kynverSchedulerProvider==="openclaw-cron"||r.deploymentSchedulerProvider==="openclaw-cron"}function IN(e,r){return e.kynverSchedulerProvider==="kynver-cron"||r.deploymentSchedulerProvider==="kynver-cron"}function YR(e){return!!e.openclawCronStorePath}function ON(e,r){return e.kynverSchedulerProvider==="qstash"||r.deploymentSchedulerProvider==="qstash"}function JR(e,r){let t={schedulerProvider:e.kynverSchedulerProvider??null,deploymentSchedulerProvider:r.deploymentSchedulerProvider??null,openclawCronStorePath:!!e.openclawCronStorePath,kynverCronDaemonPrimary:!!e.kynverCronDaemonPrimary},n=!!r.agentOsId?.trim()&&!!r.apiBaseUrl?.trim()&&r.hasScopedRunnerToken;if(ON(e,r)&&!GR(e,r)){let u=e.kynverSchedulerProvider==="qstash"?"KYNVER_SCHEDULER_PROVIDER=qstash on this host":"deploymentSchedulerProvider=qstash in ~/.kynver/config.json";return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`AgentOS scheduler cut over to QStash (${u})`,details:t}}if(IN(e,r)&&!GR(e,r)){if(YR(e)&&e.kynverCronDaemonPrimary&&n)return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"Kynver Cron local store present; `kynver daemon` owns schedule fires (kynver-cron tick loop)",details:{...t,dispatchPath:"kynver-daemon-cron-tick",kynverCronDaemonPrimary:!0}};let u=e.kynverSchedulerProvider==="kynver-cron"?"KYNVER_SCHEDULER_PROVIDER=kynver-cron on this host":"deploymentSchedulerProvider=kynver-cron in ~/.kynver/config.json";return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`AgentOS scheduler owned by Kynver Cron (${u})`,details:t}}if(YR(e)){if(e.kynverCronDaemonPrimary&&n)return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"Kynver Cron local store present; `kynver daemon` owns schedule fires (kynver-cron tick loop)",details:{...t,dispatchPath:"kynver-daemon-cron-tick",kynverCronDaemonPrimary:!0}};let u=[];return e.openclawCronStorePath&&u.push("KYNVER_CRON_STORE_PATH or OPENCLAW_CRON_STORE_PATH set (local cron store)"),{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:`Local cron store without daemon tick (${u.join("; ")})`,remediation:"Run `kynver daemon` with KYNVER_CRON_SECRET + KYNVER_API_URL (or KYNVER_CRON_FIRE_BASE_URL) so the daemon-owned cron tick fires schedules. On hosted deploys use QStash (KYNVER_SCHEDULER_PROVIDER=qstash). Legacy OpenClaw cron env aliases still work during cutover.",details:t}}let o=e.kynverSchedulerProvider==="openclaw-cron",s=r.deploymentSchedulerProvider==="openclaw-cron",i=e.kynverSchedulerProvider==="qstash",a=!!e.qstashTokenPresent||!!e.kynverHostedDeployment,l=a&&!n,c=l&&e.kynverSchedulerProvider==="openclaw-cron";return s&&!o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"deploymentSchedulerProvider=openclaw-cron in ~/.kynver/config.json \u2014 migrate to kynver-cron or qstash",remediation:'Run `kynver scheduler attest-cutover` or set deploymentSchedulerProvider to "kynver-cron" or "qstash" in ~/.kynver/config.json.',details:t}:n&&o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"KYNVER_SCHEDULER_PROVIDER=openclaw-cron on this runner \u2014 dispatch is owned by kynver daemon; unset the OpenClaw override",remediation:"Unset KYNVER_SCHEDULER_PROVIDER on user runners (or set kynver-cron). Use `kynver daemon` (pipeline-tick \u2192 operator/tick). On the Kynver server set KYNVER_SCHEDULER_PROVIDER=qstash when QStash is configured.",details:{schedulerProvider:e.kynverSchedulerProvider??null,dispatchPath:"kynver-daemon-pipeline-tick",hostedDeployment:a}}:n?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:i?"Runner override qstash present; hosted dispatch still owned by kynver daemon pipeline-tick":"Hosted dispatch owned by kynver daemon (pipeline-tick \u2192 operator/tick); no OpenClaw cron on runner",details:{schedulerProvider:e.kynverSchedulerProvider??null,dispatchPath:"kynver-daemon-pipeline-tick",hostedDeployment:a}}:o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"KYNVER_SCHEDULER_PROVIDER=openclaw-cron on this runner \u2014 hosted dispatch still depends on the OpenClaw local-cron adapter",remediation:"Unset KYNVER_SCHEDULER_PROVIDER on user runners (or set kynver-cron). Use `kynver daemon` (pipeline-tick \u2192 operator/tick). On the Kynver server set KYNVER_SCHEDULER_PROVIDER=qstash when QStash is configured.",details:{schedulerProvider:e.kynverSchedulerProvider??null,hostedDeployment:a}}:c?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"Hosted deployment has KYNVER_SCHEDULER_PROVIDER=openclaw-cron \u2014 AgentOS scheduled ticks should use QStash or kynver-cron",remediation:"Set QSTASH_TOKEN and KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server (or kynver-cron for Kynver-owned local scheduling). User runners use `kynver daemon` for dispatch and should not set a scheduler provider.",details:{schedulerProvider:e.kynverSchedulerProvider??null,qstashTokenPresent:e.qstashTokenPresent??!1,hostedDeployment:a}}:l&&e.qstashTokenPresent&&!e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"QSTASH_TOKEN present; hosted scheduler auto-selects qstash (explicit KYNVER_SCHEDULER_PROVIDER=qstash optional)",details:{schedulerProvider:null,qstashTokenPresent:!0,hostedDeployment:a}}:l&&!e.qstashTokenPresent&&!e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"Hosted deployment with no QSTASH_TOKEN and no KYNVER_SCHEDULER_PROVIDER \u2014 kynver-cron is an in-process stub here and will NOT fire; no firing scheduler is configured",remediation:"Set QSTASH_TOKEN + KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server for hosted AgentOS schedules. Only use kynver-cron when a `kynver daemon` (or local cron store) actually owns firing on this box.",details:{schedulerProvider:null,resolvedFallback:"none",qstashTokenPresent:!1,hostedDeployment:a}}:l&&!e.qstashTokenPresent&&e.kynverSchedulerProvider&&e.kynverSchedulerProvider!=="qstash"&&e.kynverSchedulerProvider!=="kynver-cron"?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:`Hosted deployment without QSTASH_TOKEN (KYNVER_SCHEDULER_PROVIDER=${e.kynverSchedulerProvider}) \u2014 use qstash or kynver-cron`,remediation:"Set QSTASH_TOKEN and KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server, or kynver-cron for Kynver-owned local scheduling. User runners use `kynver daemon` for dispatch.",details:{schedulerProvider:e.kynverSchedulerProvider??null,qstashTokenPresent:e.qstashTokenPresent??!1,hostedDeployment:a}}:e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`KYNVER_SCHEDULER_PROVIDER=${e.kynverSchedulerProvider}`,details:{schedulerProvider:e.kynverSchedulerProvider??null}}:{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"No KYNVER_SCHEDULER_PROVIDER on runner (expected) \u2014 finish runner setup so daemon pipeline-tick owns dispatch",details:{schedulerProvider:null,dispatchPath:"kynver-daemon-pipeline-tick-pending"}}}Ir();lo();co();qs();function qR(e,r={}){let t=on(),n=Xs(e,t),o=[],s=r.envFilePath??we,a=rn(s).get("KYNVER_CRON_DAEMON_PRESENT")==="1";if(o.push({id:"daemon_supervision_owner",ok:!!e.daemonSupervisionOwner,summary:e.daemonSupervisionOwner?`daemonSupervisionOwner=${e.daemonSupervisionOwner} (${t})`:"daemonSupervisionOwner unset \u2014 run `kynver setup` to persist Kynver-owned restart policy",remediation:e.daemonSupervisionOwner?void 0:"Run `kynver setup` (or `kynver bootstrap`) on this box."}),o.push({id:"daemon_present_signal",ok:a,summary:a?`KYNVER_CRON_DAEMON_PRESENT=1 (persisted in ${s})`:`KYNVER_CRON_DAEMON_PRESENT not set in persisted env (${s})`,remediation:a?void 0:"Run `kynver setup` or `kynver start` once to write ~/.kynver/.env supervision keys."}),n==="systemd"){let c=ql();o.push({id:"systemd_user_unit",ok:c,summary:c?"systemd user unit present (~/.config/systemd/user/kynver-cron-daemon.service)":"daemonSupervisionOwner=systemd but user unit missing",remediation:c?void 0:"Run `kynver start --install-systemd` or `kynver cron install --install-systemd`."})}let l=Yl(t,n);return o.push({id:"supervision_guidance",ok:!0,summary:l[0]??"Kynver keeper supervises daemon restarts by default."}),o}lo();co();function zR(e){let r=e.loadConfig(),t=on(),n=Xs(r,t),s=qR(r).map(i=>({id:i.id,label:i.id.replace(/_/g," "),status:i.ok?"pass":i.id==="daemon_supervision_owner"||i.id==="daemon_present_signal"?"warn":"fail",summary:i.summary,remediation:i.remediation}));return s.push({id:"daemon_keeper_default",label:"Kynver keeper owns in-process restarts",status:n==="keeper"||n==="systemd"?"pass":"warn",summary:n==="systemd"?"systemd persists the keeper parent \u2014 Hermes/OpenClaw cron is not required to restart the daemon":"`kynver start` / `kynver daemon` run the keeper by default (opt out with --no-supervise only when an external supervisor owns restarts)",details:{owner:n,hostKind:t}}),{id:"daemon_supervision",label:"Daemon restart supervision",checks:s}}function NN(e){let r={pass:0,warn:0,fail:0};for(let t of e)for(let n of t.checks)r[n.status]+=1;return r}function TN(e){let r=e.packageVersion(),t=e.commandOnPath("kynver"),n=t.ok&&t.stdout.length>0,o=n?t.stdout.split(/\r?\n/)[0]?.trim():void 0,s=o?q(o):void 0,i=[{id:"cli_running_version",label:"Running @kynver-app/runtime version",status:"pass",summary:`@kynver-app/runtime ${r}`,details:{version:r}},{id:"cli_on_path",label:"kynver executable on PATH",status:n?"pass":"warn",summary:n?`Found ${s}`:"kynver not found on PATH (invoked via node/npx?)",remediation:n?void 0:"Install globally (`npm i -g @kynver-app/runtime`) or invoke via `npx @kynver-app/runtime`.",details:{path:s}}];if(n&&o){let a=e.kynverVersion(o),l=a.stdout.replace(/^kynver\s+/i,"").trim()||void 0,c=a.ok&&(!l||l===r);i.push({id:"cli_installed_version",label:"Installed kynver CLI version matches running package",status:c?"pass":"warn",summary:a.ok&&l?c?`Installed ${l}`:`Installed ${l} differs from running ${r}`:a.error?`Could not read installed version (${a.error})`:a.stderr||"Could not read installed version",remediation:c?void 0:"Reinstall or rebuild @kynver-app/runtime so PATH kynver matches the harness worktree version.",details:{installedVersion:l,runningVersion:r,path:s}})}return{id:"cli_package",label:"CLI / package",checks:i}}function DN(e){let r=e.configFilePath(),t=q(r),n=e.pathExists(r),o=e.loadConfig(),s=[{id:"config_file",label:"~/.kynver/config.json present",status:n?"pass":"fail",summary:n?`Found ${t}`:`Missing ${t}`,remediation:n?void 0:"Run `kynver setup --api-base-url <url> --agent-os-id <id> --repo <path>`.",details:{configPath:t}}];if(n){let i=o.apiBaseUrl?.trim(),a=o.agentOsId?.trim(),l=je({config:o}),c=l?vn(l):null,u=Uk(l);s.push({id:"config_api_base_url",label:"Default API base URL",status:i?"pass":"warn",summary:i??"Not set in config (KYNVER_API_URL / --base-url required per command)",remediation:i?void 0:"Set `apiBaseUrl` via `kynver setup --api-base-url https://\u2026`.",details:{apiBaseUrl:i??null}},{id:"config_agent_os_id",label:"Default AgentOS id",status:a?"pass":"warn",summary:a??"Not set (pass --agent-os-id on daemon/dispatch/worker commands)",remediation:a?void 0:"Set `agentOsId` via `kynver setup --agent-os-id <uuid>`.",details:{agentOsId:a??null,agentOsSlug:o.agentOsSlug??null}},{id:"config_default_repo",label:"Default repo path",status:u.status,summary:l?l.persistedInConfig?`${c.defaultRepo} (config)`:`${c.defaultRepo} (${l.source}, not persisted in ~/.kynver/config.json)`:"Not set in ~/.kynver/config.json (`kynver run create` requires --repo)",remediation:u.remediation,details:{defaultRepo:c?.defaultRepo??null,source:c?.source??null,persistedInConfig:c?.persistedInConfig??!1,harnessRoot:o.harnessRoot?Se(o.harnessRoot):null}})}return{id:"user_config",label:"User config (~/.kynver)",checks:s}}function MN(e){let t=e.loadConfig().agentOsId?.trim(),n=e.readCredentials(),o=e.envSnapshot(),s=e.credentialsFilePath(),i=q(s),a=o.kynverRunnerTokenPrefix,l=n.runnerTokenPrefix,c=n.runnerTokenAgentOsId,u=!!l&&(!t||!c||c===t),d=!!a?.startsWith("krc1.")||u&&l?.startsWith("krc1.");return{id:"runner_token",label:"Runner token readiness",checks:[{id:"runner_token_scoped",label:"Scoped runner token (krc1.*) ready",status:d?"pass":"fail",summary:d?a?"KYNVER_RUNNER_TOKEN is set (scoped prefix shown)":`Saved scoped token for agentOsId ${c??t??"(unknown)"}`:"No scoped runner token for the configured AgentOS workspace",remediation:d?void 0:"Run `kynver login` then `kynver runner credential --agent-os-id <id>` (or `kynver setup` with API key).",details:{source:a?"env":l?"credentials":"none",tokenPrefix:a??(u?l:void 0),agentOsId:t??c??null,credentialsPath:i}},{id:"runner_token_agent_os_match",label:"Saved runner token matches configured agentOsId",status:!l||!t||!c||c===t?"pass":"warn",summary:!l||!c?"No saved token agentOsId to compare":t?c===t?"Saved token scoped to configured agentOsId":`Saved token is for ${c}, config expects ${t}`:"Config agentOsId unset \u2014 token scope not validated against config",remediation:l&&t&&c&&c!==t?"`kynver runner credential --agent-os-id <configured-id>` to mint a workspace-bound token.":void 0,details:{configuredAgentOsId:t??null,savedAgentOsId:c??null}},{id:"runner_api_key_for_refresh",label:"API key available for token refresh",status:n.hasApiKey||process.env.KYNVER_API_KEY?.trim()?"pass":"warn",summary:n.hasApiKey||process.env.KYNVER_API_KEY?"KYNVER API key present for runner credential mint/refresh":"No API key \u2014 401 callback recovery cannot auto-mint a replacement token",remediation:n.hasApiKey||process.env.KYNVER_API_KEY?void 0:"Run `kynver login --api-key \u2026`.",details:{credentialsPath:i,hasApiKey:n.hasApiKey||!!process.env.KYNVER_API_KEY}}]}}function UN(e){let r=e.commandOnPath("vercel"),t=r.ok,n=!!(process.env.GITHUB_TOKEN?.trim()||process.env.GH_TOKEN?.trim()),o=!!process.env.VERCEL_TOKEN?.trim();return{id:"vercel_deploy_evidence",label:"Vercel deploy evidence",checks:[{id:"vercel_global_cli_absent",label:"Global Vercel CLI not installed",status:t?"warn":"pass",summary:t?`Global Vercel CLI found (${r.stdout||"on PATH"}) \u2014 uninstall after operator approval`:"No global Vercel CLI on PATH",remediation:t?"Uninstall global Vercel CLI (`npm uninstall -g vercel`) \u2014 use GitHub commit status or scoped VERCEL_TOKEN + REST API instead.":void 0,details:{path:t&&r.stdout||null}},{id:"github_token_for_vercel_status",label:"GitHub token for Vercel status",status:n?"pass":"warn",summary:n?"GITHUB_TOKEN/GH_TOKEN present for GitHub Vercel StatusContext evidence":"No GITHUB_TOKEN \u2014 merge-gate Vercel evidence requires GitHub commit status API",remediation:n?void 0:"Export GITHUB_TOKEN (or GH_TOKEN) for PR head commit status lookups."},{id:"vercel_api_token_optional",label:"Vercel API token (optional fallback)",status:o?"pass":"warn",summary:o?"VERCEL_TOKEN configured for optional REST API deployment lookup":"VERCEL_TOKEN unset \u2014 GitHub status is the default path; API fallback disabled",remediation:o?void 0:"Set ephemeral/scoped VERCEL_TOKEN only when GitHub status is insufficient; avoid persistent ~/.vercel auth on runner hosts."}]}}function WN(e){let r=e.harnessRoot(),t=XR.join(r,"runs"),n=XR.join(r,"worktrees"),o=Se(r),s=Se(t),i=Se(n),a=e.pathExists(t),l=e.pathExists(n);return{id:"harness_dirs",label:"Harness / daemon directories",checks:[{id:"harness_root",label:"Harness root resolved",status:"pass",summary:o,details:{harnessRoot:o}},{id:"harness_runs_dir",label:"Runs directory ready",status:a&&e.pathWritable(t)?"pass":"warn",summary:a?e.pathWritable(t)?`Writable ${s}`:`Exists but not writable: ${s}`:`Will be created on first run: ${s}`,remediation:a&&!e.pathWritable(t)?`Fix permissions on ${s} or set KYNVER_HARNESS_ROOT to a writable path.`:void 0,details:{runsDir:s,exists:a,writable:e.pathWritable(t)}},{id:"harness_worktrees_dir",label:"Worktrees directory ready",status:l&&e.pathWritable(n)?"pass":"warn",summary:l?e.pathWritable(n)?`Writable ${i}`:`Exists but not writable: ${i}`:`Will be created on first worker: ${i}`,remediation:l&&!e.pathWritable(n)?`Fix permissions on ${i}.`:void 0,details:{worktreesDir:i,exists:l,writable:e.pathWritable(n)}}]}}function LN(e){let r=e.loadConfig(),t=e.envSnapshot(),n=t.kynverApiUrl??r.apiBaseUrl?.trim()??t.openclawCronFireBaseUrl,o=!t.kynverApiUrl&&!r.apiBaseUrl&&!!t.openclawCronFireBaseUrl,s=t.openclawCronSecret||t.kynverRuntimeSecret,i=t.kynverRunnerTokenPrefix?.startsWith("krc1."),l=e.readCredentials().runnerTokenPrefix?.startsWith("krc1.");return{id:"callback_auth",label:"Callback auth / config",checks:[{id:"callback_base_url",label:"Callback base URL configured",status:n?o?"warn":"pass":"fail",summary:n?o?`Using legacy OPENCLAW_CRON_FIRE_BASE_URL (${n})`:n:"No KYNVER_API_URL, config apiBaseUrl, or legacy OpenClaw base URL",remediation:n?o?"Migrate to KYNVER_API_URL or `kynver setup --api-base-url` and drop OPENCLAW_CRON_FIRE_BASE_URL.":void 0:"Set KYNVER_API_URL or run `kynver setup --api-base-url https://\u2026`.",details:{source:t.kynverApiUrl?"KYNVER_API_URL":r.apiBaseUrl?"config.apiBaseUrl":t.openclawCronFireBaseUrl?"OPENCLAW_CRON_FIRE_BASE_URL":"none",baseUrl:n??null}},{id:"callback_auth_mode",label:"Callback auth uses scoped runner token",status:i||l?"pass":s?"warn":"fail",summary:i?"KYNVER_RUNNER_TOKEN scoped token will be sent as X-Kynver-Runner-Token":l?"Saved krc1.* token in ~/.kynver/credentials":s?"Deployment-level KYNVER_RUNTIME_SECRET / OPENCLAW_CRON_SECRET in use (legacy headers)":"No callback secret configured",remediation:i||l?void 0:"Mint a scoped token: `kynver runner credential --agent-os-id <id>`. Avoid shared OPENCLAW_CRON_SECRET on user runners.",details:{mode:i||l?"scoped":s?"legacy_global_secret":"missing",legacyHeadersWhenNotScoped:["X-OpenClaw-Cron-Secret","X-Kynver-Runtime-Secret"]}}]}}function BN(e){let r=e.envSnapshot(),t=e.loadConfig(),n=e.readCredentials(),o=e.harnessRoot(),s=e.legacyOpenclawHarnessRoot(),i=Se(o),a=Se(s),l=r.opusHarnessRoot?Se(r.opusHarnessRoot):null,c=o===s&&e.pathExists(s),u=t.agentOsId?.trim(),d=r.kynverRunnerTokenPrefix,m=n.runnerTokenPrefix,p=n.runnerTokenAgentOsId,f=!!m&&(!u||!p||p===u),h=!!d?.startsWith("krc1.")||f&&!!m?.startsWith("krc1.");return{id:"openclaw_hotspots",label:"OpenClaw dependency hotspots",checks:[{id:"hotspot_legacy_harness_root",label:"Legacy ~/.openclaw/harness still active",status:c?"warn":"pass",summary:c?`Harness root is legacy ${a}`:r.opusHarnessRoot?`OPUS_HARNESS_ROOT override in use (${l})`:`Using ${i}`,remediation:c?"Set KYNVER_HARNESS_ROOT=~/.kynver/harness (or run setup), migrate artifacts, retire OPUS_HARNESS_ROOT.":r.opusHarnessRoot?"Prefer KYNVER_HARNESS_ROOT over OPUS_HARNESS_ROOT.":void 0,details:{harnessRoot:i,legacyRoot:a,opusHarnessRoot:l}},{id:"hotspot_openclaw_env_secrets",label:"OpenClaw deployment secrets in runner env",status:r.openclawCronSecret||r.openclawCronFireBaseUrl?"warn":"pass",summary:r.openclawCronSecret||r.openclawCronFireBaseUrl?[r.openclawCronSecret?"OPENCLAW_CRON_SECRET set":null,r.openclawCronFireBaseUrl?"OPENCLAW_CRON_FIRE_BASE_URL set":null].filter(Boolean).join("; "):"No OpenClaw cron env overrides on this runner",remediation:r.openclawCronSecret||r.openclawCronFireBaseUrl?"Move to KYNVER_API_URL + scoped runner tokens; unset OpenClaw cron env on user-hosted runners.":void 0},JR(r,{agentOsId:u??null,apiBaseUrl:t.apiBaseUrl?.trim()??r.kynverApiUrl??null,hasScopedRunnerToken:h,deploymentSchedulerProvider:t.deploymentSchedulerProvider==="qstash"||t.deploymentSchedulerProvider==="kynver-cron"||t.deploymentSchedulerProvider==="openclaw-cron"?t.deploymentSchedulerProvider:void 0}),{id:"hotspot_lease_source_names",label:"Harness lease/completion source names",status:"pass",summary:"Runtime uses kynver-harness:* lease owners and completion source kynver-harness (OpenClaw names retired in runtime)",details:{leaseOwnerPattern:"kynver-harness:<runId>",completionSource:"kynver-harness",note:"OpenClaw adapter remains optional in packages/kynver-openclaw-agent-os only"}}]}}function QR(e=VR){let r=[TN(e),DN(e),MN(e),UN(e),WN(e),LN(e),zR(e),BN(e)],t=NN(r),n=t.fail===0,o=n?t.warn>0?`Ready with ${t.warn} warning(s) \u2014 review remediation before retiring OpenClaw as primary runtime agent.`:"Ready \u2014 Kynver runtime can serve as primary runtime agent on this host.":`${t.fail} blocking check(s) \u2014 fix failures before OpenClaw takeover.`;return{command:"doctor runtime-takeover",ready:n,summary:o,counts:t,sections:r}}function ZR(e={}){let r;if(e.remediateDefaultRepo===!0){let n=Jo();if(!n.ok){console.error(n.reason??"defaultRepo remediation failed"),n.remediation&&console.error(n.remediation),process.exitCode=1;return}n.remediated?r=`Remediated defaultRepo \u2192 ${n.resolved?.defaultRepo??"unknown"}`:r=`defaultRepo already persisted (${n.resolved?.defaultRepo??"unknown"})`}let t=QR();r&&(t.notes=[...t.notes??[],r]),console.log(JSON.stringify(t,null,2)),t.ready||(process.exitCode=1)}I();async function ev(e){let r=y(),t=(e.agentOsId?String(e.agentOsId):r.agentOsId)||"";t||(console.error("requires --agent-os-id or agentOsId in ~/.kynver/config.json"),process.exit(1));let n=V(e.baseUrl?String(e.baseUrl):r.apiBaseUrl),o=await J(e.secret?String(e.secret):void 0,t,{baseUrl:n}),s=new URLSearchParams;if(typeof e.since=="string"&&e.since.trim()&&s.set("since",e.since.trim()),e.limit!=null&&String(e.limit).trim()){let c=Number(e.limit);Number.isFinite(c)&&c>0&&s.set("limit",String(Math.floor(c)))}let i=s.toString()?`?${s.toString()}`:"",a=`${n}/api/agent-os/by-id/${encodeURIComponent(t)}/command-center/dashboard-contract${i}`,l=await ni(a,o);l.ok||(console.error(`dashboard-contract GET failed: HTTP ${l.status}`),l.response&&console.error(JSON.stringify(l.response,null,2)),process.exit(1)),console.log(JSON.stringify(l.response,null,2))}Je();var Fd=["Vercel/hosted: set KYNVER_SCHEDULER_PROVIDER=qstash","Vercel/hosted: ensure QSTASH_TOKEN (and QStash signing keys) are configured","Vercel/hosted: unset OPENCLAW_CRON_STORE_PATH if present"],Kd=["User runner: unset KYNVER_SCHEDULER_PROVIDER (scheduling is deployment-owned)","User runner: unset OPENCLAW_CRON_STORE_PATH, OPENCLAW_CRON_SECRET, OPENCLAW_CRON_FIRE_BASE_URL",'User runner: after deployment cutover, run `kynver scheduler attest-cutover` (or set deploymentSchedulerProvider to "qstash" in ~/.kynver/config.json)',"Verify: kynver doctor runtime-takeover \u2014 hotspot_openclaw_scheduler should pass"];function HN(e=process.env){return{kynverSchedulerProvider:e.KYNVER_SCHEDULER_PROVIDER?.trim()||null,kynverCronStorePath:e.KYNVER_CRON_STORE_PATH?.trim()||e.OPENCLAW_CRON_STORE_PATH?.trim()||null,kynverCronSecret:!!(e.KYNVER_CRON_SECRET?.trim()||e.OPENCLAW_CRON_SECRET?.trim()),kynverCronFireBaseUrl:e.KYNVER_CRON_FIRE_BASE_URL?.trim()||e.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null,openclawCronStorePath:e.OPENCLAW_CRON_STORE_PATH?.trim()||null,openclawCronSecret:!!e.OPENCLAW_CRON_SECRET?.trim(),openclawCronFireBaseUrl:e.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null}}function $d(e,r=HN()){let t=[];return r.kynverSchedulerProvider==="openclaw-cron"&&t.push("Runner still has KYNVER_SCHEDULER_PROVIDER=openclaw-cron"),r.kynverCronStorePath&&r.kynverSchedulerProvider!=="kynver-cron"&&t.push("Runner has KYNVER_CRON_STORE_PATH but KYNVER_SCHEDULER_PROVIDER is not kynver-cron \u2014 use `kynver daemon` cron tick or unset the store for QStash-only runners"),r.openclawCronStorePath&&!r.kynverCronStorePath&&t.push("Runner still has legacy OPENCLAW_CRON_STORE_PATH (prefer KYNVER_CRON_STORE_PATH)"),e.deploymentSchedulerProvider==="openclaw-cron"&&t.push("~/.kynver/config.json deploymentSchedulerProvider is still openclaw-cron"),{ok:t.length===0,blockers:t,runnerEnv:r,deploymentSchedulerProvider:e.deploymentSchedulerProvider??null,deploymentSteps:[...Fd],runnerSteps:[...Kd]}}function rv(e){return{...e,deploymentSchedulerProvider:"qstash"}}I();import FN from"node:path";import{homedir as KN}from"node:os";var tv=FN.join(KN(),".kynver","config.json");function nv(e=!1){let r=y(),t=$d(r),n={...t,configPath:q(tv),configAttestationExample:{deploymentSchedulerProvider:"qstash"}};if(e){console.log(JSON.stringify(n,null,2)),t.ok||(process.exitCode=1);return}console.log(`AgentOS scheduler provider cutover checklist
|
|
69
|
-
`),console.log("Deployment (Vercel):");for(let o of
|
|
70
|
-
User runner:`);for(let o of
|
|
63
|
+
${EN}
|
|
64
|
+
${e.diagnostic}`:e.primary}function PN(e){let r=[`Harness ${e.scope} ${e.action} failed.`];e.timedOut?r.push("Reason: command timed out on the runner host."):e.error?r.push(`Reason: ${e.error}`):e.exitCode!=null&&r.push(`Exit code: ${e.exitCode}`);let t=e.stderr.trim();t&&r.push(`Stderr: ${t.split(`
|
|
65
|
+
`).slice(-3).join(" ")}`),r.push("Next: retry on the runner host or inspect harness logs.");let n=Xa(e.stdout);return{primary:r.join(`
|
|
66
|
+
`),diagnostic:ie(n??{stdout:e.stdout,stderr:e.stderr})}}function LR(e){if(!e.ok)return PN(e);let r=Xa(e.stdout);if(r===null){let t=e.stdout.trim()||e.stderr.trim()||"(no output)";return{primary:`Harness ${e.scope} ${e.action} finished.
|
|
67
|
+
${t.slice(0,800)}`,diagnostic:ie({stdout:e.stdout,stderr:e.stderr})}}if(e.scope==="worker"&&e.action==="status")return ls(r);if(e.scope==="worker"&&e.action==="complete")return Za(r);if(e.scope==="monitor"&&(e.action==="tick"||e.action==="run-loop"))return Fn(r);if(e.scope==="monitor"&&e.action==="auto-complete"){let t=r;if(t.outcome&&t.worker&&t.runId)return Qa(r);if(Array.isArray(t.blockers))return{primary:[`Monitor auto-complete blocked \xB7 ${t.runId??"run"} / ${t.worker??"worker"}`,`Blockers: ${t.blockers.join("; ")}`,"Next: resolve blockers on the runner, then retry auto-complete."].join(`
|
|
68
|
+
`),diagnostic:ie(r)}}if(e.scope==="run"&&e.action==="status"){let t=r.workers;return Array.isArray(t)&&t.length===1?ls(t[0]):{primary:`Harness run status \xB7 ${r.runId??"run"} (${Array.isArray(t)?t.length:0} workers).`,diagnostic:ie(r)}}return{primary:`Harness ${e.scope} ${e.action} completed successfully on the runner.`,diagnostic:ie(r)}}import NN from"node:path";D();z();C();z();C();function el(e){let{worker:r,status:t,taskLease:n}=e,o=n?.leaseOwner??null;if(r.dispatched&&n){if(n.status==="running"&&o&&!Ec(o,r.runId))return{health:"orphaned",reason:`task lease held by ${o}, expected harness run ${r.runId}`};let i=r.leaseToken?.trim()??"",a=n.leaseToken?.trim()??"";if(n.status==="running"&&i&&a&&i!==a)return{health:"orphaned",reason:"task leaseToken superseded on board \u2014 completion replay would fail"};if(n.status==="running"&&!t.alive&&!t.finalResult)return{health:"orphaned",reason:"board task running but worker process is not alive"}}if(r.status==="running"&&!t.alive&&!t.finalResult)return{health:"orphaned",reason:"worker.json still running but process is dead"};if(t.attention.state==="stale")return{health:"stale",reason:t.attention.reason};let s=t.lastHeartbeatAt?Date.parse(t.lastHeartbeatAt):NaN;return t.alive&&Number.isFinite(s)&&Date.now()-s>Qt?{health:"stale",reason:`heartbeat older than ${Math.floor(Qt/1e3)}s`}:t.alive&&r.pid&&!H(r.pid)?{health:"orphaned",reason:"pid recorded but process is not alive"}:n?.status==="running"&&!t.alive&&t.finalResult?{health:"healthy",reason:"finished worker awaiting completion replay"}:{health:"healthy",reason:t.attention.reason||"worker within expected lifecycle bounds"}}Ce();C();import{existsSync as BR,mkdirSync as AN,readdirSync as ON,unlinkSync as IN}from"node:fs";import Bd from"node:path";function HR(){let{harnessRoot:e}=qr(),r=Bd.join(e,"monitors");return AN(r,{recursive:!0}),r}function At(e,r){return r?`${v(e)}--${v(r)}`:v(e)}function Hd(e){return Bd.join(HR(),`${e}.json`)}function Ot(e){return w(Hd(e),void 0)}function It(e){ae(Hd(e.monitorId),e)}function Fd(e){let r=Hd(e);return BR(r)?(IN(r),!0):!1}function FR(){let e=HR();if(!BR(e))return[];let r=[];for(let t of ON(e)){if(!t.endsWith(".json"))continue;let n=w(Bd.join(e,t),void 0);n?.monitorId&&r.push({monitorId:n.monitorId,runId:n.runId,workerName:n.workerName,agentOsId:n.agentOsId,pid:n.pid,alive:n.pid?H(n.pid):!1,startedAt:n.startedAt,pollMs:n.pollMs,logPath:n.logPath})}return r.sort((t,n)=>t.startedAt.localeCompare(n.startedAt))}z();function cs(e){let{worker:r,status:t}=e,n=[];r.localOnly&&n.push("local-only worker (no board linkage)"),(!r.agentOsId||!r.taskId)&&n.push("missing agentOsId/taskId linkage"),Ei(r)&&n.push("completion already acknowledged"),r.completionBlocker&&n.push(r.completionBlocker),t.heartbeatBlocker&&t.alive&&n.push(`worker heartbeat blocker: ${t.heartbeatBlocker}`),t.attention.state==="blocked"&&n.push(t.attention.reason||"worker attention blocked"),et(t)&&n.push(t.attention.reason||"landing gate blocked");let o=oe(t),s;return o?t.finalResult?s="final_result":t.alive?s="terminal_status":s="process_exited":n.push("worker has not reached a terminal condition"),{eligible:o&&n.length===0,terminalVerified:o,terminalReason:s,blockers:n}}function KR(e,r){return w(NN.join(P(e),"workers",v(r),"worker.json"),void 0)}function $R(e,r){let t=L(e),n=Object.keys(t.workers||{});if(!r)return n;let o=v(r);return n.filter(s=>v(s)===o)}function jR(e,r){let t=L(e.runId),n=M(e,{base:t.base,baseCommit:t.baseCommit}),o=e.taskId?r.get(e.taskId)??null:null,s=el({worker:e,status:n,taskLease:o}),i=cs({worker:e,status:n});return{runId:e.runId,worker:e.name,health:s.health,healthReason:s.reason,workerStatus:n.status,attentionState:n.attention.state,attentionReason:n.attention.reason,alive:n.alive,taskId:e.taskId,leaseOwner:o?.leaseOwner??void 0,taskStatus:o?.status,autoComplete:i,status:n}}async function Nt(e){let r=String(e.run||"");T(r,"--run");let t=e.name?String(e.name):void 0,n=e.agentOsId?String(e.agentOsId):void 0,o=L(r),s=$R(r,t),i=[];for(let m of s){let h=KR(r,m);h&&i.push(h)}let a=n||i.map(m=>m.agentOsId).find(m=>typeof m=="string"&&m.trim())||void 0,l=i.map(m=>m.taskId).filter(m=>!!m),c=await mn({agentOsId:a,taskIds:l,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0}),u=i.map(m=>jR(m,c)),d;a&&e.renewLeases!==!1&&e.renewLeases!=="false"&&(d=await Si(r,{...e,agentOsId:a}));let f=[];if(e.autoComplete===!0||e.autoComplete==="true")for(let m of u){if(!m.autoComplete.eligible){f.push({worker:m.worker,outcome:"skipped",ok:!1,reason:m.autoComplete.blockers.join("; ")||"not eligible"});continue}let h=await gt({run:r,name:m.worker,...a?{agentOsId:a}:{},...e.baseUrl?{baseUrl:String(e.baseUrl)}:{},...e.secret?{secret:String(e.secret)}:{}});f.push({worker:m.worker,outcome:h.outcome,ok:h.outcome==="completed",reason:h.reason})}return{runId:r,agentOsId:a,workers:u,leaseRenewal:d,autoCompleted:f}}function rl(e){let r=String(e.run||"");T(r,"--run");let t=e.name?String(e.name):void 0,n=$R(r,t),o=[];for(let s of n){let i=KR(r,s);i&&o.push(jR(i,new Map))}return{runId:r,workers:o,autoCompleted:[]}}function us(){return FR()}function Kd(e){let r=String(e.run||"");T(r,"--run");let t=At(r,e.name?String(e.name):void 0),n=Ot(t);if(!n)return{monitorId:t,stopped:!1};if(n.pid&&H(n.pid))try{process.kill(n.pid,"SIGTERM")}catch{}return n.stoppedAt=new Date().toISOString(),It(n),Fd(t),{monitorId:t,stopped:!0,pid:n.pid}}async function tl(e){let r=String(e.run||""),t=String(e.name||"");T(r,"--run"),T(t,"--name");let n=he(r,t),o=L(r),s=M(n,{base:o.base,baseCommit:o.baseCommit}),i=cs({worker:n,status:s});if(!i.eligible){console.log(JSON.stringify({runId:r,worker:t,outcome:"blocked",blockers:i.blockers,terminalVerified:i.terminalVerified},null,2)),process.exitCode=1;return}let a=await gt({...e,run:r,name:t});console.log(JSON.stringify(a,null,2)),a.outcome!=="completed"&&a.outcome!=="blocked"&&(process.exitCode=1)}C();var TN=5e3,DN=360*60*1e3;async function $d(e){let r=String(e.monitorId||""),t=Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):TN,n=Number(e.maxTotalMs)>0?Math.floor(Number(e.maxTotalMs)):DN,o=Date.now();for(;Date.now()-o<=n;){let s=r?Ot(r):void 0;if(s?.stoppedAt)break;let i=await Nt({...e,autoComplete:e.autoComplete??!0,renewLeases:e.renewLeases??!0}),a=Fn({monitorId:r,phase:"tick",...i});if(console.log(a.primary),a.diagnostic&&console.error(`[monitor diagnostic] ${a.diagnostic}`),i.workers.length>0&&i.workers.every(c=>c.autoComplete.terminalVerified&&(c.autoComplete.eligible||c.autoComplete.blockers.some(u=>u.includes("already acknowledged"))))&&i.autoCompleted.every(c=>c.ok||c.outcome==="skipped")){r&&s&&(s.stoppedAt=new Date().toISOString(),It(s));break}$r(t)}}C();Ce();import{spawn as MN}from"node:child_process";import{closeSync as VR,existsSync as UN,openSync as WN}from"node:fs";import LN from"node:path";function nl(e){let r=e.nodeExecutable??process.execPath,t=Li({importMetaUrl:import.meta.url,explicitCliPath:e.cliPath,nodeExecutable:r});if(!t)return;let n=t.cliPath;if(!UN(n))return;let o=At(e.runId,e.workerName),{harnessRoot:s}=qr(),i=LN.join(s,"monitors",`${o}.log`),a;try{a=WN(i,"a")}catch{a=void 0}let l=e.pollMs??5e3,c=[...t.argsPrefix,"monitor","run-loop","--run",e.runId,"--monitor-id",o,"--poll-ms",String(l),"--auto-complete","true","--renew-leases","true"];e.workerName&&c.push("--name",e.workerName),e.agentOsId&&c.push("--agent-os-id",e.agentOsId),e.baseUrl&&c.push("--base-url",e.baseUrl),e.secret&&c.push("--secret",e.secret);let u=["ignore",a??"ignore",a??"ignore"];try{let d=MN(t.command,c,pe({detached:!0,stdio:u,env:process.env}));a!==void 0&&VR(a),d.unref();let f={monitorId:o,runId:e.runId,workerName:e.workerName,agentOsId:e.agentOsId,pid:d.pid,startedAt:new Date().toISOString(),pollMs:l,logPath:i};return It(f),{monitorId:o,pid:d.pid,logPath:i,session:f}}catch{if(a!==void 0)try{VR(a)}catch{}return}}C();async function GR(e){let r=String(e.run||"");T(r,"--run");let t=e.name?String(e.name):void 0,n=At(r,t),o=Ot(n);if(o?.pid&&!o.stoppedAt)return{monitorId:n,session:o,spawned:!1,pid:o.pid};let s=nl({runId:r,workerName:t,agentOsId:e.agentOsId?String(e.agentOsId):void 0,pollMs:Number(e.pollMs)>0?Math.floor(Number(e.pollMs)):void 0,baseUrl:e.baseUrl?String(e.baseUrl):void 0,secret:e.secret?String(e.secret):void 0});if(!s)throw new Error("failed to spawn monitor sidecar (cli.js missing or spawn error)");return{monitorId:n,session:s.session,spawned:!0,pid:s.pid}}async function YR(e){if(String(e.run||"")){let t=e.tick===!0||e.tick==="true"?await Nt({...e,autoComplete:!1}):rl(e);console.log(JSON.stringify(t,null,2));return}console.log(JSON.stringify({monitors:us()},null,2))}function JR(e){console.log(JSON.stringify(Kd(e),null,2))}function qR(){console.log(JSON.stringify({monitors:us()},null,2))}async function zR(e){await $d(e)}async function XR(e){let r=await Nt(e);console.log(JSON.stringify(r,null,2))}D();z();C();N();import BN from"node:path";function ds(e,r,t,n,o,s){return{runId:e,worker:r,taskId:t,agentOsId:n,leaseOwner:o,action:"skipped",reason:s}}async function HN(e){let r=V(e.baseUrl?String(e.baseUrl):void 0),t=e.agentOsId?String(e.agentOsId).trim():null,n=e.dryRun===!0||e.dryRun==="true",o=[],s=[],i=[];for(let a of X())for(let l of Object.keys(a.workers??{})){let c=BN.join(P(a.id),"workers",v(l),"worker.json"),u=w(c,void 0);if(!u){s.push(ds(a.id,l,"","","","worker.json missing"));continue}let d=u.taskId??"",f=u.agentOsId??"",p=u.leaseOwner??"";if(!u.dispatched||!d||!f||!p){s.push(ds(a.id,l,d,f,p,"not a fully-leased dispatched worker"));continue}if(t&&f!==t)continue;if(u.completionReportedAt){s.push(ds(a.id,l,d,f,p,"completion already reported"));continue}let m=M(u);if(m.finalResult){s.push(ds(a.id,l,d,f,p,"has final result \u2014 let pipeline tick complete it"));continue}if(m.alive){s.push(ds(a.id,l,d,f,p,"worker process is still alive"));continue}if(n){o.push({runId:a.id,worker:l,taskId:d,agentOsId:f,leaseOwner:p,action:"released",reason:"dry-run: would release dead dispatched worker lease"});continue}try{let h=await J(e.secret?String(e.secret):void 0,f,{baseUrl:r}),k=`${r}/api/agent-os/by-id/${encodeURIComponent(f)}/tasks/${encodeURIComponent(d)}/release`,g=await re(k,h,{agentOsId:f,leaseOwner:p},{agentOsId:f,baseUrl:r});g.ok===!0||g.response?.ok===!0?o.push({runId:a.id,worker:l,taskId:d,agentOsId:f,leaseOwner:p,action:"released",reason:"dead dispatched worker lease released; task requeued"}):s.push({runId:a.id,worker:l,taskId:d,agentOsId:f,leaseOwner:p,action:"skipped",reason:`release returned ok:false (likely owner mismatch or already released): HTTP ${g.status}`})}catch(h){i.push({runId:a.id,worker:l,taskId:d,agentOsId:f,leaseOwner:p,action:"error",reason:h.message})}}return{dryRun:n,released:o,skipped:s,errors:i}}async function QR(e){let r=await HN(e),t={ok:r.errors.length===0,dryRun:r.dryRun,released:r.released.length,skipped:r.skipped.length,errors:r.errors.length,details:r};console.log(JSON.stringify(t,null,2)),r.errors.length>0&&process.exit(1)}import ab from"node:path";Je();N();import{accessSync as FN,constants as KN,existsSync as jd,readFileSync as $N}from"node:fs";import{homedir as ol}from"node:os";import sl from"node:path";import{spawnSync as jN}from"node:child_process";Ce();function ZR(e,r){try{let t=jN(e,r,{encoding:"utf8"}),n=(t.stdout||"").trim(),o=(t.stderr||"").trim();return{ok:t.status===0,stdout:n,stderr:o,error:t.error?.message}}catch(t){return{ok:!1,stdout:"",stderr:"",error:t.message}}}function eb(e){let r=e?.trim();if(r)return r.length<=12?`${r}\u2026`:`${r.slice(0,12)}\u2026`}function VN(e){if(!jd(e))return!1;try{return FN(e,KN.W_OK),!0}catch{return!1}}var rb={packageVersion:()=>$n,commandOnPath:e=>ZR(process.platform==="win32"?"where":"which",[e]),kynverVersion:e=>ZR(e,["--version"]),loadConfig:()=>R(),configFilePath:()=>sl.join(ol(),".kynver","config.json"),credentialsFilePath:()=>sl.join(ol(),".kynver","credentials"),readCredentials:()=>{let e=sl.join(ol(),".kynver","credentials");if(!jd(e))return{hasApiKey:!1};try{let r=JSON.parse($N(e,"utf8"));return{hasApiKey:!!r.apiKey?.trim(),runnerTokenPrefix:eb(r.runnerToken),runnerTokenAgentOsId:r.runnerTokenAgentOsId}}catch{return{hasApiKey:!1}}},envSnapshot:()=>({kynverApiUrl:process.env.KYNVER_API_URL?.trim()||void 0,openclawCronFireBaseUrl:process.env.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||void 0,kynverRunnerTokenPrefix:eb(process.env.KYNVER_RUNNER_TOKEN),kynverRuntimeSecret:!!process.env.KYNVER_RUNTIME_SECRET?.trim(),openclawCronSecret:!!process.env.OPENCLAW_CRON_SECRET?.trim(),kynverHarnessRoot:process.env.KYNVER_HARNESS_ROOT?.trim()||void 0,opusHarnessRoot:process.env.OPUS_HARNESS_ROOT?.trim()||void 0,kynverSchedulerProvider:process.env.KYNVER_SCHEDULER_PROVIDER?.trim()||void 0,openclawCronStorePath:!!(process.env.KYNVER_CRON_STORE_PATH?.trim()||process.env.OPENCLAW_CRON_STORE_PATH?.trim()),kynverCronDaemonPrimary:Pa(),qstashTokenPresent:!!process.env.QSTASH_TOKEN?.trim(),kynverHostedDeployment:(()=>{let e=process.env.KYNVER_HOSTED_DEPLOYMENT?.trim().toLowerCase();return e==="1"||e==="true"||e==="yes"})()}),harnessRoot:()=>fe(),legacyOpenclawHarnessRoot:()=>sl.join(ol(),".openclaw","harness"),pathExists:e=>jd(e),pathWritable:e=>VN(e)};function tb(e,r){return e.kynverSchedulerProvider==="openclaw-cron"||r.deploymentSchedulerProvider==="openclaw-cron"}function GN(e,r){return e.kynverSchedulerProvider==="kynver-cron"||r.deploymentSchedulerProvider==="kynver-cron"}function nb(e){return!!e.openclawCronStorePath}function YN(e,r){return e.kynverSchedulerProvider==="qstash"||r.deploymentSchedulerProvider==="qstash"}function ob(e,r){let t={schedulerProvider:e.kynverSchedulerProvider??null,deploymentSchedulerProvider:r.deploymentSchedulerProvider??null,openclawCronStorePath:!!e.openclawCronStorePath,kynverCronDaemonPrimary:!!e.kynverCronDaemonPrimary},n=!!r.agentOsId?.trim()&&!!r.apiBaseUrl?.trim()&&r.hasScopedRunnerToken;if(YN(e,r)&&!tb(e,r)){let u=e.kynverSchedulerProvider==="qstash"?"KYNVER_SCHEDULER_PROVIDER=qstash on this host":"deploymentSchedulerProvider=qstash in ~/.kynver/config.json";return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`AgentOS scheduler cut over to QStash (${u})`,details:t}}if(GN(e,r)&&!tb(e,r)){if(nb(e)&&e.kynverCronDaemonPrimary&&n)return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"Kynver Cron local store present; `kynver daemon` owns schedule fires (kynver-cron tick loop)",details:{...t,dispatchPath:"kynver-daemon-cron-tick",kynverCronDaemonPrimary:!0}};let u=e.kynverSchedulerProvider==="kynver-cron"?"KYNVER_SCHEDULER_PROVIDER=kynver-cron on this host":"deploymentSchedulerProvider=kynver-cron in ~/.kynver/config.json";return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`AgentOS scheduler owned by Kynver Cron (${u})`,details:t}}if(nb(e)){if(e.kynverCronDaemonPrimary&&n)return{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"Kynver Cron local store present; `kynver daemon` owns schedule fires (kynver-cron tick loop)",details:{...t,dispatchPath:"kynver-daemon-cron-tick",kynverCronDaemonPrimary:!0}};let u=[];return e.openclawCronStorePath&&u.push("KYNVER_CRON_STORE_PATH or OPENCLAW_CRON_STORE_PATH set (local cron store)"),{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:`Local cron store without daemon tick (${u.join("; ")})`,remediation:"Run `kynver daemon` with KYNVER_CRON_SECRET + KYNVER_API_URL (or KYNVER_CRON_FIRE_BASE_URL) so the daemon-owned cron tick fires schedules. On hosted deploys use QStash (KYNVER_SCHEDULER_PROVIDER=qstash). Legacy OpenClaw cron env aliases still work during cutover.",details:t}}let o=e.kynverSchedulerProvider==="openclaw-cron",s=r.deploymentSchedulerProvider==="openclaw-cron",i=e.kynverSchedulerProvider==="qstash",a=!!e.qstashTokenPresent||!!e.kynverHostedDeployment,l=a&&!n,c=l&&e.kynverSchedulerProvider==="openclaw-cron";return s&&!o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"deploymentSchedulerProvider=openclaw-cron in ~/.kynver/config.json \u2014 migrate to kynver-cron or qstash",remediation:'Run `kynver scheduler attest-cutover` or set deploymentSchedulerProvider to "kynver-cron" or "qstash" in ~/.kynver/config.json.',details:t}:n&&o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"KYNVER_SCHEDULER_PROVIDER=openclaw-cron on this runner \u2014 dispatch is owned by kynver daemon; unset the OpenClaw override",remediation:"Unset KYNVER_SCHEDULER_PROVIDER on user runners (or set kynver-cron). Use `kynver daemon` (pipeline-tick \u2192 operator/tick). On the Kynver server set KYNVER_SCHEDULER_PROVIDER=qstash when QStash is configured.",details:{schedulerProvider:e.kynverSchedulerProvider??null,dispatchPath:"kynver-daemon-pipeline-tick",hostedDeployment:a}}:n?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:i?"Runner override qstash present; hosted dispatch still owned by kynver daemon pipeline-tick":"Hosted dispatch owned by kynver daemon (pipeline-tick \u2192 operator/tick); no OpenClaw cron on runner",details:{schedulerProvider:e.kynverSchedulerProvider??null,dispatchPath:"kynver-daemon-pipeline-tick",hostedDeployment:a}}:o?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"KYNVER_SCHEDULER_PROVIDER=openclaw-cron on this runner \u2014 hosted dispatch still depends on the OpenClaw local-cron adapter",remediation:"Unset KYNVER_SCHEDULER_PROVIDER on user runners (or set kynver-cron). Use `kynver daemon` (pipeline-tick \u2192 operator/tick). On the Kynver server set KYNVER_SCHEDULER_PROVIDER=qstash when QStash is configured.",details:{schedulerProvider:e.kynverSchedulerProvider??null,hostedDeployment:a}}:c?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"Hosted deployment has KYNVER_SCHEDULER_PROVIDER=openclaw-cron \u2014 AgentOS scheduled ticks should use QStash or kynver-cron",remediation:"Set QSTASH_TOKEN and KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server (or kynver-cron for Kynver-owned local scheduling). User runners use `kynver daemon` for dispatch and should not set a scheduler provider.",details:{schedulerProvider:e.kynverSchedulerProvider??null,qstashTokenPresent:e.qstashTokenPresent??!1,hostedDeployment:a}}:l&&e.qstashTokenPresent&&!e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"QSTASH_TOKEN present; hosted scheduler auto-selects qstash (explicit KYNVER_SCHEDULER_PROVIDER=qstash optional)",details:{schedulerProvider:null,qstashTokenPresent:!0,hostedDeployment:a}}:l&&!e.qstashTokenPresent&&!e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:"Hosted deployment with no QSTASH_TOKEN and no KYNVER_SCHEDULER_PROVIDER \u2014 kynver-cron is an in-process stub here and will NOT fire; no firing scheduler is configured",remediation:"Set QSTASH_TOKEN + KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server for hosted AgentOS schedules. Only use kynver-cron when a `kynver daemon` (or local cron store) actually owns firing on this box.",details:{schedulerProvider:null,resolvedFallback:"none",qstashTokenPresent:!1,hostedDeployment:a}}:l&&!e.qstashTokenPresent&&e.kynverSchedulerProvider&&e.kynverSchedulerProvider!=="qstash"&&e.kynverSchedulerProvider!=="kynver-cron"?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"warn",summary:`Hosted deployment without QSTASH_TOKEN (KYNVER_SCHEDULER_PROVIDER=${e.kynverSchedulerProvider}) \u2014 use qstash or kynver-cron`,remediation:"Set QSTASH_TOKEN and KYNVER_SCHEDULER_PROVIDER=qstash on the Kynver server, or kynver-cron for Kynver-owned local scheduling. User runners use `kynver daemon` for dispatch.",details:{schedulerProvider:e.kynverSchedulerProvider??null,qstashTokenPresent:e.qstashTokenPresent??!1,hostedDeployment:a}}:e.kynverSchedulerProvider?{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:`KYNVER_SCHEDULER_PROVIDER=${e.kynverSchedulerProvider}`,details:{schedulerProvider:e.kynverSchedulerProvider??null}}:{id:"hotspot_openclaw_scheduler",label:"Scheduler provider (runtime daemon vs OpenClaw cron)",status:"pass",summary:"No KYNVER_SCHEDULER_PROVIDER on runner (expected) \u2014 finish runner setup so daemon pipeline-tick owns dispatch",details:{schedulerProvider:null,dispatchPath:"kynver-daemon-pipeline-tick-pending"}}}Or();co();uo();Xs();function sb(e,r={}){let t=sn(),n=Zs(e,t),o=[],s=r.envFilePath??we,a=tn(s).get("KYNVER_CRON_DAEMON_PRESENT")==="1";if(o.push({id:"daemon_supervision_owner",ok:!!e.daemonSupervisionOwner,summary:e.daemonSupervisionOwner?`daemonSupervisionOwner=${e.daemonSupervisionOwner} (${t})`:"daemonSupervisionOwner unset \u2014 run `kynver setup` to persist Kynver-owned restart policy",remediation:e.daemonSupervisionOwner?void 0:"Run `kynver setup` (or `kynver bootstrap`) on this box."}),o.push({id:"daemon_present_signal",ok:a,summary:a?`KYNVER_CRON_DAEMON_PRESENT=1 (persisted in ${s})`:`KYNVER_CRON_DAEMON_PRESENT not set in persisted env (${s})`,remediation:a?void 0:"Run `kynver setup` or `kynver start` once to write ~/.kynver/.env supervision keys."}),n==="systemd"){let c=zl();o.push({id:"systemd_user_unit",ok:c,summary:c?"systemd user unit present (~/.config/systemd/user/kynver-cron-daemon.service)":"daemonSupervisionOwner=systemd but user unit missing",remediation:c?void 0:"Run `kynver start --install-systemd` or `kynver cron install --install-systemd`."})}let l=Jl(t,n);return o.push({id:"supervision_guidance",ok:!0,summary:l[0]??"Kynver keeper supervises daemon restarts by default."}),o}co();uo();function ib(e){let r=e.loadConfig(),t=sn(),n=Zs(r,t),s=sb(r).map(i=>({id:i.id,label:i.id.replace(/_/g," "),status:i.ok?"pass":i.id==="daemon_supervision_owner"||i.id==="daemon_present_signal"?"warn":"fail",summary:i.summary,remediation:i.remediation}));return s.push({id:"daemon_keeper_default",label:"Kynver keeper owns in-process restarts",status:n==="keeper"||n==="systemd"?"pass":"warn",summary:n==="systemd"?"systemd persists the keeper parent \u2014 Hermes/OpenClaw cron is not required to restart the daemon":"`kynver start` / `kynver daemon` run the keeper by default (opt out with --no-supervise only when an external supervisor owns restarts)",details:{owner:n,hostKind:t}}),{id:"daemon_supervision",label:"Daemon restart supervision",checks:s}}function JN(e){let r={pass:0,warn:0,fail:0};for(let t of e)for(let n of t.checks)r[n.status]+=1;return r}function qN(e){let r=e.packageVersion(),t=e.commandOnPath("kynver"),n=t.ok&&t.stdout.length>0,o=n?t.stdout.split(/\r?\n/)[0]?.trim():void 0,s=o?q(o):void 0,i=[{id:"cli_running_version",label:"Running @kynver-app/runtime version",status:"pass",summary:`@kynver-app/runtime ${r}`,details:{version:r}},{id:"cli_on_path",label:"kynver executable on PATH",status:n?"pass":"warn",summary:n?`Found ${s}`:"kynver not found on PATH (invoked via node/npx?)",remediation:n?void 0:"Install globally (`npm i -g @kynver-app/runtime`) or invoke via `npx @kynver-app/runtime`.",details:{path:s}}];if(n&&o){let a=e.kynverVersion(o),l=a.stdout.replace(/^kynver\s+/i,"").trim()||void 0,c=a.ok&&(!l||l===r);i.push({id:"cli_installed_version",label:"Installed kynver CLI version matches running package",status:c?"pass":"warn",summary:a.ok&&l?c?`Installed ${l}`:`Installed ${l} differs from running ${r}`:a.error?`Could not read installed version (${a.error})`:a.stderr||"Could not read installed version",remediation:c?void 0:"Reinstall or rebuild @kynver-app/runtime so PATH kynver matches the harness worktree version.",details:{installedVersion:l,runningVersion:r,path:s}})}return{id:"cli_package",label:"CLI / package",checks:i}}function zN(e){let r=e.configFilePath(),t=q(r),n=e.pathExists(r),o=e.loadConfig(),s=[{id:"config_file",label:"~/.kynver/config.json present",status:n?"pass":"fail",summary:n?`Found ${t}`:`Missing ${t}`,remediation:n?void 0:"Run `kynver setup --api-base-url <url> --agent-os-id <id> --repo <path>`.",details:{configPath:t}}];if(n){let i=o.apiBaseUrl?.trim(),a=o.agentOsId?.trim(),l=je({config:o}),c=l?vn(l):null,u=Gk(l);s.push({id:"config_api_base_url",label:"Default API base URL",status:i?"pass":"warn",summary:i??"Not set in config (KYNVER_API_URL / --base-url required per command)",remediation:i?void 0:"Set `apiBaseUrl` via `kynver setup --api-base-url https://\u2026`.",details:{apiBaseUrl:i??null}},{id:"config_agent_os_id",label:"Default AgentOS id",status:a?"pass":"warn",summary:a??"Not set (pass --agent-os-id on daemon/dispatch/worker commands)",remediation:a?void 0:"Set `agentOsId` via `kynver setup --agent-os-id <uuid>`.",details:{agentOsId:a??null,agentOsSlug:o.agentOsSlug??null}},{id:"config_default_repo",label:"Default repo path",status:u.status,summary:l?l.persistedInConfig?`${c.defaultRepo} (config)`:`${c.defaultRepo} (${l.source}, not persisted in ~/.kynver/config.json)`:"Not set in ~/.kynver/config.json (`kynver run create` requires --repo)",remediation:u.remediation,details:{defaultRepo:c?.defaultRepo??null,source:c?.source??null,persistedInConfig:c?.persistedInConfig??!1,harnessRoot:o.harnessRoot?Se(o.harnessRoot):null}})}return{id:"user_config",label:"User config (~/.kynver)",checks:s}}function XN(e){let t=e.loadConfig().agentOsId?.trim(),n=e.readCredentials(),o=e.envSnapshot(),s=e.credentialsFilePath(),i=q(s),a=o.kynverRunnerTokenPrefix,l=n.runnerTokenPrefix,c=n.runnerTokenAgentOsId,u=!!l&&(!t||!c||c===t),d=!!a?.startsWith("krc1.")||u&&l?.startsWith("krc1.");return{id:"runner_token",label:"Runner token readiness",checks:[{id:"runner_token_scoped",label:"Scoped runner token (krc1.*) ready",status:d?"pass":"fail",summary:d?a?"KYNVER_RUNNER_TOKEN is set (scoped prefix shown)":`Saved scoped token for agentOsId ${c??t??"(unknown)"}`:"No scoped runner token for the configured AgentOS workspace",remediation:d?void 0:"Run `kynver login` then `kynver runner credential --agent-os-id <id>` (or `kynver setup` with API key).",details:{source:a?"env":l?"credentials":"none",tokenPrefix:a??(u?l:void 0),agentOsId:t??c??null,credentialsPath:i}},{id:"runner_token_agent_os_match",label:"Saved runner token matches configured agentOsId",status:!l||!t||!c||c===t?"pass":"warn",summary:!l||!c?"No saved token agentOsId to compare":t?c===t?"Saved token scoped to configured agentOsId":`Saved token is for ${c}, config expects ${t}`:"Config agentOsId unset \u2014 token scope not validated against config",remediation:l&&t&&c&&c!==t?"`kynver runner credential --agent-os-id <configured-id>` to mint a workspace-bound token.":void 0,details:{configuredAgentOsId:t??null,savedAgentOsId:c??null}},{id:"runner_api_key_for_refresh",label:"API key available for token refresh",status:n.hasApiKey||process.env.KYNVER_API_KEY?.trim()?"pass":"warn",summary:n.hasApiKey||process.env.KYNVER_API_KEY?"KYNVER API key present for runner credential mint/refresh":"No API key \u2014 401 callback recovery cannot auto-mint a replacement token",remediation:n.hasApiKey||process.env.KYNVER_API_KEY?void 0:"Run `kynver login --api-key \u2026`.",details:{credentialsPath:i,hasApiKey:n.hasApiKey||!!process.env.KYNVER_API_KEY}}]}}function QN(e){let r=e.commandOnPath("vercel"),t=r.ok,n=!!(process.env.GITHUB_TOKEN?.trim()||process.env.GH_TOKEN?.trim()),o=!!process.env.VERCEL_TOKEN?.trim();return{id:"vercel_deploy_evidence",label:"Vercel deploy evidence",checks:[{id:"vercel_global_cli_absent",label:"Global Vercel CLI not installed",status:t?"warn":"pass",summary:t?`Global Vercel CLI found (${r.stdout||"on PATH"}) \u2014 uninstall after operator approval`:"No global Vercel CLI on PATH",remediation:t?"Uninstall global Vercel CLI (`npm uninstall -g vercel`) \u2014 use GitHub commit status or scoped VERCEL_TOKEN + REST API instead.":void 0,details:{path:t&&r.stdout||null}},{id:"github_token_for_vercel_status",label:"GitHub token for Vercel status",status:n?"pass":"warn",summary:n?"GITHUB_TOKEN/GH_TOKEN present for GitHub Vercel StatusContext evidence":"No GITHUB_TOKEN \u2014 merge-gate Vercel evidence requires GitHub commit status API",remediation:n?void 0:"Export GITHUB_TOKEN (or GH_TOKEN) for PR head commit status lookups."},{id:"vercel_api_token_optional",label:"Vercel API token (optional fallback)",status:o?"pass":"warn",summary:o?"VERCEL_TOKEN configured for optional REST API deployment lookup":"VERCEL_TOKEN unset \u2014 GitHub status is the default path; API fallback disabled",remediation:o?void 0:"Set ephemeral/scoped VERCEL_TOKEN only when GitHub status is insufficient; avoid persistent ~/.vercel auth on runner hosts."}]}}function ZN(e){let r=e.harnessRoot(),t=ab.join(r,"runs"),n=ab.join(r,"worktrees"),o=Se(r),s=Se(t),i=Se(n),a=e.pathExists(t),l=e.pathExists(n);return{id:"harness_dirs",label:"Harness / daemon directories",checks:[{id:"harness_root",label:"Harness root resolved",status:"pass",summary:o,details:{harnessRoot:o}},{id:"harness_runs_dir",label:"Runs directory ready",status:a&&e.pathWritable(t)?"pass":"warn",summary:a?e.pathWritable(t)?`Writable ${s}`:`Exists but not writable: ${s}`:`Will be created on first run: ${s}`,remediation:a&&!e.pathWritable(t)?`Fix permissions on ${s} or set KYNVER_HARNESS_ROOT to a writable path.`:void 0,details:{runsDir:s,exists:a,writable:e.pathWritable(t)}},{id:"harness_worktrees_dir",label:"Worktrees directory ready",status:l&&e.pathWritable(n)?"pass":"warn",summary:l?e.pathWritable(n)?`Writable ${i}`:`Exists but not writable: ${i}`:`Will be created on first worker: ${i}`,remediation:l&&!e.pathWritable(n)?`Fix permissions on ${i}.`:void 0,details:{worktreesDir:i,exists:l,writable:e.pathWritable(n)}}]}}function eT(e){let r=e.loadConfig(),t=e.envSnapshot(),n=t.kynverApiUrl??r.apiBaseUrl?.trim()??t.openclawCronFireBaseUrl,o=!t.kynverApiUrl&&!r.apiBaseUrl&&!!t.openclawCronFireBaseUrl,s=t.openclawCronSecret||t.kynverRuntimeSecret,i=t.kynverRunnerTokenPrefix?.startsWith("krc1."),l=e.readCredentials().runnerTokenPrefix?.startsWith("krc1.");return{id:"callback_auth",label:"Callback auth / config",checks:[{id:"callback_base_url",label:"Callback base URL configured",status:n?o?"warn":"pass":"fail",summary:n?o?`Using legacy OPENCLAW_CRON_FIRE_BASE_URL (${n})`:n:"No KYNVER_API_URL, config apiBaseUrl, or legacy OpenClaw base URL",remediation:n?o?"Migrate to KYNVER_API_URL or `kynver setup --api-base-url` and drop OPENCLAW_CRON_FIRE_BASE_URL.":void 0:"Set KYNVER_API_URL or run `kynver setup --api-base-url https://\u2026`.",details:{source:t.kynverApiUrl?"KYNVER_API_URL":r.apiBaseUrl?"config.apiBaseUrl":t.openclawCronFireBaseUrl?"OPENCLAW_CRON_FIRE_BASE_URL":"none",baseUrl:n??null}},{id:"callback_auth_mode",label:"Callback auth uses scoped runner token",status:i||l?"pass":s?"warn":"fail",summary:i?"KYNVER_RUNNER_TOKEN scoped token will be sent as X-Kynver-Runner-Token":l?"Saved krc1.* token in ~/.kynver/credentials":s?"Deployment-level KYNVER_RUNTIME_SECRET / OPENCLAW_CRON_SECRET in use (legacy headers)":"No callback secret configured",remediation:i||l?void 0:"Mint a scoped token: `kynver runner credential --agent-os-id <id>`. Avoid shared OPENCLAW_CRON_SECRET on user runners.",details:{mode:i||l?"scoped":s?"legacy_global_secret":"missing",legacyHeadersWhenNotScoped:["X-OpenClaw-Cron-Secret","X-Kynver-Runtime-Secret"]}}]}}function rT(e){let r=e.envSnapshot(),t=e.loadConfig(),n=e.readCredentials(),o=e.harnessRoot(),s=e.legacyOpenclawHarnessRoot(),i=Se(o),a=Se(s),l=r.opusHarnessRoot?Se(r.opusHarnessRoot):null,c=o===s&&e.pathExists(s),u=t.agentOsId?.trim(),d=r.kynverRunnerTokenPrefix,f=n.runnerTokenPrefix,p=n.runnerTokenAgentOsId,m=!!f&&(!u||!p||p===u),h=!!d?.startsWith("krc1.")||m&&!!f?.startsWith("krc1.");return{id:"openclaw_hotspots",label:"OpenClaw dependency hotspots",checks:[{id:"hotspot_legacy_harness_root",label:"Legacy ~/.openclaw/harness still active",status:c?"warn":"pass",summary:c?`Harness root is legacy ${a}`:r.opusHarnessRoot?`OPUS_HARNESS_ROOT override in use (${l})`:`Using ${i}`,remediation:c?"Set KYNVER_HARNESS_ROOT=~/.kynver/harness (or run setup), migrate artifacts, retire OPUS_HARNESS_ROOT.":r.opusHarnessRoot?"Prefer KYNVER_HARNESS_ROOT over OPUS_HARNESS_ROOT.":void 0,details:{harnessRoot:i,legacyRoot:a,opusHarnessRoot:l}},{id:"hotspot_openclaw_env_secrets",label:"OpenClaw deployment secrets in runner env",status:r.openclawCronSecret||r.openclawCronFireBaseUrl?"warn":"pass",summary:r.openclawCronSecret||r.openclawCronFireBaseUrl?[r.openclawCronSecret?"OPENCLAW_CRON_SECRET set":null,r.openclawCronFireBaseUrl?"OPENCLAW_CRON_FIRE_BASE_URL set":null].filter(Boolean).join("; "):"No OpenClaw cron env overrides on this runner",remediation:r.openclawCronSecret||r.openclawCronFireBaseUrl?"Move to KYNVER_API_URL + scoped runner tokens; unset OpenClaw cron env on user-hosted runners.":void 0},ob(r,{agentOsId:u??null,apiBaseUrl:t.apiBaseUrl?.trim()??r.kynverApiUrl??null,hasScopedRunnerToken:h,deploymentSchedulerProvider:t.deploymentSchedulerProvider==="qstash"||t.deploymentSchedulerProvider==="kynver-cron"||t.deploymentSchedulerProvider==="openclaw-cron"?t.deploymentSchedulerProvider:void 0}),{id:"hotspot_lease_source_names",label:"Harness lease/completion source names",status:"pass",summary:"Runtime uses kynver-harness:* lease owners and completion source kynver-harness (OpenClaw names retired in runtime)",details:{leaseOwnerPattern:"kynver-harness:<runId>",completionSource:"kynver-harness",note:"OpenClaw adapter remains optional in packages/kynver-openclaw-agent-os only"}}]}}function lb(e=rb){let r=[qN(e),zN(e),XN(e),QN(e),ZN(e),eT(e),ib(e),rT(e)],t=JN(r),n=t.fail===0,o=n?t.warn>0?`Ready with ${t.warn} warning(s) \u2014 review remediation before retiring OpenClaw as primary runtime agent.`:"Ready \u2014 Kynver runtime can serve as primary runtime agent on this host.":`${t.fail} blocking check(s) \u2014 fix failures before OpenClaw takeover.`;return{command:"doctor runtime-takeover",ready:n,summary:o,counts:t,sections:r}}function cb(e={}){let r;if(e.remediateDefaultRepo===!0){let n=zo();if(!n.ok){console.error(n.reason??"defaultRepo remediation failed"),n.remediation&&console.error(n.remediation),process.exitCode=1;return}n.remediated?r=`Remediated defaultRepo \u2192 ${n.resolved?.defaultRepo??"unknown"}`:r=`defaultRepo already persisted (${n.resolved?.defaultRepo??"unknown"})`}let t=lb();r&&(t.notes=[...t.notes??[],r]),console.log(JSON.stringify(t,null,2)),t.ready||(process.exitCode=1)}N();async function ub(e){let r=R(),t=(e.agentOsId?String(e.agentOsId):r.agentOsId)||"";t||(console.error("requires --agent-os-id or agentOsId in ~/.kynver/config.json"),process.exit(1));let n=V(e.baseUrl?String(e.baseUrl):r.apiBaseUrl),o=await J(e.secret?String(e.secret):void 0,t,{baseUrl:n}),s=new URLSearchParams;if(typeof e.since=="string"&&e.since.trim()&&s.set("since",e.since.trim()),e.limit!=null&&String(e.limit).trim()){let c=Number(e.limit);Number.isFinite(c)&&c>0&&s.set("limit",String(Math.floor(c)))}let i=s.toString()?`?${s.toString()}`:"",a=`${n}/api/agent-os/by-id/${encodeURIComponent(t)}/command-center/dashboard-contract${i}`,l=await si(a,o);l.ok||(console.error(`dashboard-contract GET failed: HTTP ${l.status}`),l.response&&console.error(JSON.stringify(l.response,null,2)),process.exit(1)),console.log(JSON.stringify(l.response,null,2))}Je();var Vd=["Vercel/hosted: set KYNVER_SCHEDULER_PROVIDER=qstash","Vercel/hosted: ensure QSTASH_TOKEN (and QStash signing keys) are configured","Vercel/hosted: unset OPENCLAW_CRON_STORE_PATH if present"],Gd=["User runner: unset KYNVER_SCHEDULER_PROVIDER (scheduling is deployment-owned)","User runner: unset OPENCLAW_CRON_STORE_PATH, OPENCLAW_CRON_SECRET, OPENCLAW_CRON_FIRE_BASE_URL",'User runner: after deployment cutover, run `kynver scheduler attest-cutover` (or set deploymentSchedulerProvider to "qstash" in ~/.kynver/config.json)',"Verify: kynver doctor runtime-takeover \u2014 hotspot_openclaw_scheduler should pass"];function tT(e=process.env){return{kynverSchedulerProvider:e.KYNVER_SCHEDULER_PROVIDER?.trim()||null,kynverCronStorePath:e.KYNVER_CRON_STORE_PATH?.trim()||e.OPENCLAW_CRON_STORE_PATH?.trim()||null,kynverCronSecret:!!(e.KYNVER_CRON_SECRET?.trim()||e.OPENCLAW_CRON_SECRET?.trim()),kynverCronFireBaseUrl:e.KYNVER_CRON_FIRE_BASE_URL?.trim()||e.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null,openclawCronStorePath:e.OPENCLAW_CRON_STORE_PATH?.trim()||null,openclawCronSecret:!!e.OPENCLAW_CRON_SECRET?.trim(),openclawCronFireBaseUrl:e.OPENCLAW_CRON_FIRE_BASE_URL?.trim()||null}}function Yd(e,r=tT()){let t=[];return r.kynverSchedulerProvider==="openclaw-cron"&&t.push("Runner still has KYNVER_SCHEDULER_PROVIDER=openclaw-cron"),r.kynverCronStorePath&&r.kynverSchedulerProvider!=="kynver-cron"&&t.push("Runner has KYNVER_CRON_STORE_PATH but KYNVER_SCHEDULER_PROVIDER is not kynver-cron \u2014 use `kynver daemon` cron tick or unset the store for QStash-only runners"),r.openclawCronStorePath&&!r.kynverCronStorePath&&t.push("Runner still has legacy OPENCLAW_CRON_STORE_PATH (prefer KYNVER_CRON_STORE_PATH)"),e.deploymentSchedulerProvider==="openclaw-cron"&&t.push("~/.kynver/config.json deploymentSchedulerProvider is still openclaw-cron"),{ok:t.length===0,blockers:t,runnerEnv:r,deploymentSchedulerProvider:e.deploymentSchedulerProvider??null,deploymentSteps:[...Vd],runnerSteps:[...Gd]}}function db(e){return{...e,deploymentSchedulerProvider:"qstash"}}N();import nT from"node:path";import{homedir as oT}from"node:os";var pb=nT.join(oT(),".kynver","config.json");function mb(e=!1){let r=R(),t=Yd(r),n={...t,configPath:q(pb),configAttestationExample:{deploymentSchedulerProvider:"qstash"}};if(e){console.log(JSON.stringify(n,null,2)),t.ok||(process.exitCode=1);return}console.log(`AgentOS scheduler provider cutover checklist
|
|
69
|
+
`),console.log("Deployment (Vercel):");for(let o of Vd)console.log(` - ${o}`);console.log(`
|
|
70
|
+
User runner:`);for(let o of Gd)console.log(` - ${o}`);if(console.log(`
|
|
71
71
|
This host:`),console.log(` config: ${n.configPath}`),console.log(` deploymentSchedulerProvider: ${t.deploymentSchedulerProvider??"(unset)"}`),console.log(` KYNVER_SCHEDULER_PROVIDER: ${t.runnerEnv.kynverSchedulerProvider??"(unset)"}`),console.log(` KYNVER_CRON_STORE_PATH: ${t.runnerEnv.kynverCronStorePath??"(unset)"}`),console.log(` OPENCLAW_CRON_STORE_PATH (legacy): ${t.runnerEnv.openclawCronStorePath??"(unset)"}`),t.blockers.length){console.log(`
|
|
72
72
|
Blockers:`);for(let o of t.blockers)console.log(` ! ${o}`);process.exitCode=1;return}console.log(`
|
|
73
|
-
No local blockers detected on this runner.`)}function
|
|
73
|
+
No local blockers detected on this runner.`)}function fb(e=!1){let r=R(),t=Yd(r);if(!t.ok){let s={ok:!1,attested:!1,blockers:t.blockers,remediation:"Clear local OpenClaw scheduler blockers before attesting qstash cutover."};if(e)console.log(JSON.stringify(s,null,2));else{console.error("Cannot attest scheduler cutover \u2014 local blockers remain:");for(let i of t.blockers)console.error(` ! ${i}`)}process.exitCode=1;return}let n=db(r);ue(n);let o={ok:!0,attested:!0,configPath:q(pb),deploymentSchedulerProvider:"qstash",config:ln(n),note:"Recorded deploymentSchedulerProvider=qstash in ~/.kynver/config.json. Confirm Vercel has KYNVER_SCHEDULER_PROVIDER=qstash and QSTASH_TOKEN before relying on hosted schedules."};if(e){console.log(JSON.stringify(o,null,2));return}console.log(o.note),console.log(` config: ${o.configPath}`)}async function gb(e){let r=await Ua();if(e){console.log(JSON.stringify(r,null,2));return}console.log(`Kynver Cron primary: ${r.primary}`),console.log(` store: ${r.env.storePath} (${r.jobCount} jobs)`),console.log(` tick state: ${r.env.statePath} (${r.stateJobCount} tracked)`),console.log(` tick enabled: ${r.env.tickEnabled}`),console.log(` fire base URL: ${r.env.fireBaseUrl??"(unset)"}`),console.log(` credentials ready: ${r.credentialsReady}`),console.log(` daemon-owned primary: ${r.daemonPrimary}`)}async function hb(e){let r=typeof e.agentOsId=="string"?e.agentOsId:void 0,t=await An({agentOsIdFilter:r??null});if(e.json===!0){console.log(JSON.stringify(t,null,2));return}console.log(JSON.stringify({event:"kynver_cron_tick",...t}))}N();function sT(e,r){if(e===void 0)return r;if(e===!0)return!0;if(e===!1)return!1;let t=String(e).trim().toLowerCase();return t==="0"||t==="false"||t==="no"||t==="off"?!1:t==="1"||t==="true"||t==="yes"||t==="on"?!0:r}async function kb(e){let r=e.dryRun===!0||e["dry-run"]===!0,t=await La({execute:r?!1:sT(e.execute,!0),json:e.json===!0,installSystemd:e.installSystemd===!0||e["install-systemd"]===!0,confirmQstashRemoval:e.confirmQstashRemoval===!0||e["confirm-qstash-removal"]===!0,skipWatchdog:e.skipWatchdog===!0||e["skip-watchdog"]===!0,skipTestFire:e.skipTestFire===!0||e["skip-test-fire"]===!0,agentOsId:typeof e.agentOsId=="string"?e.agentOsId:void 0,apiBaseUrl:typeof e.apiBaseUrl=="string"?e.apiBaseUrl:void 0,runId:typeof e.run=="string"?e.run:void 0});if(e.json===!0){console.log(JSON.stringify(t,null,2)),t.ok||(process.exitCode=1);return}if(console.log(t.dryRun?`Kynver Cron install (dry-run)
|
|
74
74
|
`:`Kynver Cron install
|
|
75
75
|
`),console.log(` config: ${t.configPath}`),console.log(` env file: ${t.plan.envFilePath}`),console.log(` store: ${t.plan.storePath}`),t.secretGenerated&&console.log(" generated new KYNVER_CRON_SECRET"),t.envFile&&console.log(` env merge: ${t.envFile.changed?"updated":"unchanged"} (${t.envFile.keysWritten.join(", ")||"no key changes"})`),t.watchdog?.remoteJobId?console.log(` watchdog: job ${t.watchdog.remoteJobId} provider=${t.watchdog.provider} local=${t.watchdog.localProviderScheduleId}`):t.watchdog?.error&&console.log(` watchdog: ERROR ${t.watchdog.error}`),t.qstashWatchdog?.found.length){console.log(` qstash watchdog leftovers: ${t.qstashWatchdog.found.length}`);for(let n of t.qstashWatchdog.found)console.log(` - ${n.id} (${n.status})`);t.qstashWatchdog.removed.length&&console.log(` removed: ${t.qstashWatchdog.removed.join(", ")}`)}t.systemd&&console.log(` systemd: ${t.systemd.note??(t.systemd.started?"running":"not started")}`),t.testFire&&!t.testFire.skipped&&console.log(` test fire: fired=${t.testFire.fired} errors=${t.testFire.errors}`),console.log(`
|
|
76
76
|
Hosted deployment (manual):`);for(let n of t.plan.deploymentSteps)console.log(` - ${n}`);if(t.blockers.length){console.log(`
|
|
77
|
-
Blockers:`);for(let n of t.blockers)console.log(` ! ${n}`);process.exitCode=1;return}console.log("\nInstall complete \u2014 run `kynver cron verify` to re-check.")}async function
|
|
78
|
-
`);for(let n of t.checks){let o=n.ok?"ok":"FAIL";console.log(` [${o}] ${n.id}: ${n.summary}`),!n.ok&&n.remediation&&console.log(` \u2192 ${n.remediation}`)}t.ok||(process.exitCode=1)}
|
|
79
|
-
`)}function
|
|
80
|
-
`);for(let n of e.workers)t.push(
|
|
81
|
-
`)}function
|
|
82
|
-
`)),process.exit(e)}async function Cv(e=process.argv.slice(2)){if(up(e,import.meta.url,"kynver"))return;if(e.length===0||qd(e[0]))return sl(0);let r=e.shift(),t,n;if((r==="run"||r==="worker"||r==="plan"||r==="runner"||r==="harness"||r==="monitor"||r==="doctor"||r==="config"||r==="scheduler"||r==="cron"||r==="lane"||r==="board")&&(t=e.shift()),n=e,t&&qd(t)||n.some(qd))return sl(0);let o=ho(n),{runsDir:s,worktreesDir:i}=Z();if(vv(s,{recursive:!0}),vv(i,{recursive:!0}),r==="daemon"&&En(),El(r,t)){let a,l=o.run?String(o.run).trim():"";if(l)try{a=L(l).repo}catch{a=void 0}await xl({repoRoot:a,cwd:a})}if(r==="login")return void await Km(o);if(r==="bootstrap")return void await xa(o);if(r==="start")return void await lR(o);if(r==="runner"&&t==="credential")return void await Fm(o);if(r==="setup")return void await ti(o);if(r==="status")return Rv(o);if(r==="daemon")return Ta(o)?void await Da(o):void await es(o);if(r==="plan"&&t==="progress")return void await yR(o);if(r==="plan"&&t==="verify")return void await RR(o);if(r==="harness"&&t==="verify")return vR(o);if(r==="plan"&&t==="persist")return void await bR(o);if(r==="plan"&&t==="outbox"){let a=n.shift();if(a==="list")return void await SR();if(a==="drain")return void await CR(ho(n));Sv("plan",`outbox ${a??""}`.trim())}if(r==="cleanup")return wR(o);if(r==="wsl-crashes")return _R(o);if(r==="config"&&t==="ensure-default-repo")return Mk(o.json===!0);if(r==="doctor"&&t==="runtime-takeover")return ZR(o);if(r==="scheduler"&&t==="cutover-check")return nv(o.json===!0);if(r==="scheduler"&&t==="attest-cutover")return ov(o.json===!0);if(r==="cron"&&t==="install")return void await av(o);if(r==="cron"&&t==="verify")return void await lv(o);if(r==="cron"&&t==="status")return void await sv(o.json===!0);if(r==="cron"&&t==="tick")return void await iv(o);if(r==="lane"&&t==="tick"){let a=n.shift();return void await mv(ho(n),a)}if(r==="board"&&t==="contract")return void await ev(o);if(r==="run"&&t==="create")return void Fo(o);if(r==="run"&&t==="list")return Lu();if(r==="run"&&t==="resolve")return Bu(o);if(r==="run"&&t==="status")return jc(o);if(r==="run"&&t==="dispatch")return void await Wr(o);if(r==="run"&&t==="sweep")return void await wn(o);if(r==="run"&&t==="reconcile")return Uu();if(r==="run"&&t==="unblock")return void await KR(o);if(r==="worker"&&t==="start")return void await Xc(o);if(r==="worker"&&t==="list")return hg(o);if(r==="worker"&&t==="status")return $c(o);if(r==="worker"&&t==="tail")return Vc(o);if(r==="worker"&&t==="stop")return Gc(o);if(r==="worker"&&t==="complete")return void await Mi(o);if(r==="worker"&&t==="discard-disposable")return cR(o);if(r==="worker"&&t==="auto-complete")return void await Jc(o);if(r==="monitor"&&t==="start"){let a=await UR(o);console.log(JSON.stringify(a,null,2));return}if(r==="monitor"&&t==="status")return void await WR(o);if(r==="monitor"&&t==="stop")return LR(o);if(r==="monitor"&&t==="list")return BR();if(r==="monitor"&&t==="tick")return void await FR(o);if(r==="monitor"&&t==="auto-complete")return void await rl(o);if(r==="monitor"&&t==="run-loop")return void await HR(o);Sv(r,t)}var oT=process.argv[1]&&bv.native(process.argv[1])===bv.native(nT(import.meta.url));oT&&Cv().catch(e=>{console.error(e),process.exit(1)});var sT="https://api.vercel.com";function iT(e){let r=e?.trim();return r||process.env.VERCEL_TOKEN?.trim()||null}function wv(e){return(e??"").trim().toUpperCase()}function aT(e){if(typeof e!="string"||!e.trim())return null;let r=e.trim();return r.startsWith("http")?r:`https://${r}`}async function zd(e,r={}){let t=e.trim();if(!t)return{ok:!1,readyState:null,previewUrl:null,error:"missing deployment id or URL"};let n=iT(r.token);if(!n)return{ok:!1,readyState:null,previewUrl:null,error:"VERCEL_TOKEN not configured"};let o=r.teamId?.trim()||process.env.VERCEL_TEAM_ID?.trim(),s=o?`?teamId=${encodeURIComponent(o)}`:"",i=r.fetchImpl??fetch;try{let a=await i(`${sT}/v13/deployments/${encodeURIComponent(t)}${s}`,{headers:{Authorization:`Bearer ${n}`}});if(!a.ok){let u=await a.text();return{ok:!1,readyState:null,previewUrl:null,error:`Vercel API ${a.status}: ${u.slice(0,200)}`}}let l=await a.json();return{ok:!0,readyState:wv(l.readyState??l.state)||null,previewUrl:aT(l.url),error:null}}catch(a){return{ok:!1,readyState:null,previewUrl:null,error:a instanceof Error?a.message:"Vercel API fetch failed"}}}function Xd(e,r){let t=wv(e);return t==="READY"?"ready":t==="ERROR"||t==="CANCELED"?"error":t==="BUILDING"||t==="QUEUED"||t==="INITIALIZING"||r?"building":"error"}var _v=/(^|\.)vercel\.app$/i,xv=/^dpl_[a-z0-9]+$/i;function il(e){let r=e.trim();if(!r||/vercel\.com/i.test(r))return!1;if(xv.test(r))return!0;try{let t=new URL(r.startsWith("http")?r:`https://${r}`);return _v.test(t.hostname)}catch{return!1}}function lT(e){let r=e.trim();if(!r)return null;try{return new URL(r)}catch{return null}}function cT(e){let r=e.pathname.split("/").filter(Boolean);if(r.length<3)return null;let t=r[r.length-1]?.trim();return!t||t==="deployments"?null:t}function uT(e){let r=e.pathname.split("/").filter(Boolean),t=r.indexOf("deployments");return t<0||t>=r.length-1?null:r[t+1]?.trim()||null}function Nt(e){let r={kind:"unknown",previewUrl:null,inspectTarget:null,deploymentId:null},t=e.trim();if(!t)return r;if(/^dpl_[a-z0-9]+$/i.test(t))return{kind:"deployment_id",previewUrl:null,inspectTarget:t,deploymentId:t};let n=lT(t);if(!n)return r;if(_v.test(n.hostname)){let o=n.origin;return{kind:"deployment_host",previewUrl:o,inspectTarget:o,deploymentId:null}}if(n.hostname==="vercel.com"||n.hostname.endsWith(".vercel.com")){let o=uT(n)??cT(n);return{kind:"dashboard",previewUrl:null,inspectTarget:o&&xv.test(o)?o:null,deploymentId:o}}return r}function Ev(e){return Nt(e).kind==="dashboard"}var dT=/vercel/i;function Qd(e){let r=typeof e=="string"?e.trim().toLowerCase():"";return r==="success"?"success":r==="pending"?"pending":r==="failure"?"failure":r==="error"?"error":"unknown"}function Zd(e){let r=typeof e=="string"?e.trim():"";return!!(r&&dT.test(r))}function ds(e){let t=(Array.isArray(e)?e:[]).filter(l=>Zd(l.context));if(t.length===0)return null;let n=l=>l==="failure"||l==="error"?0:l==="pending"?1:l==="success"?2:1,o=null,s=1/0;for(let l of t){let c=n(Qd(l.state));c<s&&(o=l,s=c)}if(!o)return null;let i=typeof o.target_url=="string"&&o.target_url.trim()?o.target_url.trim():null,a=i?Nt(i):null;return{context:String(o.context??"Vercel").trim(),state:Qd(o.state),targetUrl:i,description:typeof o.description=="string"&&o.description.trim()?o.description.trim():null,deploymentId:a?.deploymentId??null,previewUrl:a?.previewUrl??null,dashboardUrl:a?.kind==="dashboard"?i:null}}function pT(e){return e==="success"?"ready":e==="pending"?"building":e==="failure"||e==="error"?"error":"unavailable"}function al(e){return e.filter(Boolean).join("; ")}function ep(e){let r=typeof e=="string"?e.trim():"";if(!r)return{target:null,classified:null,reason:"missing target_url"};let t=Nt(r);return t.inspectTarget&&il(t.inspectTarget)?{target:t.inspectTarget,classified:t,reason:null}:t.kind==="dashboard"?{target:null,classified:t,reason:t.deploymentId?"dashboard deployment id is not API-inspectable; trust GitHub Vercel status":"dashboard URL is not valid for Vercel API lookup"}:{target:null,classified:t,reason:"unrecognized Vercel URL"}}function rp(e,r={}){let t=r.observedAt??new Date().toISOString(),n=ds(e);if(!n)return{status:"not_run",previewUrl:null,deploymentUrl:null,summary:"No Vercel GitHub status context on commit",observedAt:t,inspectSkipped:!0,inspectReason:"no_vercel_status_context",githubState:null,vercelContext:null};let o=pT(n.state),s=n.previewUrl??n.dashboardUrl,i=n.previewUrl??n.dashboardUrl;return{status:o,previewUrl:s,deploymentUrl:i,summary:al([`GitHub ${n.context}=${n.state}`,n.description??"",n.dashboardUrl?"dashboard target_url (API lookup skipped)":""]),observedAt:t,inspectSkipped:!0,inspectReason:n.dashboardUrl&&n.state==="success"?"trusted_github_status_dashboard_url":n.dashboardUrl?"dashboard_url_not_api_inspectable":"github_status_only",githubState:n.state,vercelContext:n.context}}async function Pv(e){let r=e.observedAt??new Date().toISOString(),t=rp(e.statuses??[],{observedAt:r}),n=ds(e.statuses??[]);if(!n)return t;if(n.state==="success")return{...t,inspectSkipped:!0,inspectReason:n.dashboardUrl?"trusted_github_status_dashboard_url":"trusted_github_status"};if(!e.allowInspect)return{...t,inspectSkipped:!0,inspectReason:"api_lookup_disabled"};let{target:o,reason:s}=ep(n.targetUrl);if(!o)return{...t,inspectSkipped:!0,inspectReason:s??"not_api_inspectable",summary:al([t.summary??"",s??"skipped Vercel API lookup"])};let a=await(e.runInspect??zd)(o),l=new Date().toISOString();if(!a.ok&&a.error?.includes("VERCEL_TOKEN"))return{status:"unavailable",previewUrl:t.previewUrl,deploymentUrl:t.deploymentUrl,summary:"VERCEL_TOKEN not configured for API fallback",observedAt:l,inspectSkipped:!0,inspectReason:"vercel_token_missing",githubState:n.state,vercelContext:n.context};if(!a.ok)return{status:n.state==="pending"?"building":"error",previewUrl:t.previewUrl,deploymentUrl:o.startsWith("http")?o:t.deploymentUrl,summary:al([`Vercel API lookup ${o} failed`,a.error??""]),observedAt:l,inspectSkipped:!1,inspectReason:null,githubState:n.state,vercelContext:n.context};let c=Xd(a.readyState,n.state==="pending"),u=a.previewUrl??(o.startsWith("http")?o:t.previewUrl);return{status:c,previewUrl:u,deploymentUrl:u??t.deploymentUrl,summary:al([`Vercel API ${o}=${a.readyState??"unknown"}`,c==="ready"?"preview ready":""]),observedAt:l,inspectSkipped:!1,inspectReason:null,githubState:n.state,vercelContext:n.context}}export{Dr as CODEX_DEFAULT_MODEL,bi as DEFAULT_DISPATCH_LEASE_MS,qa as DEFAULT_HARNESS_VERIFY_COMMANDS,$a as DEFAULT_HEAVY_VERIFICATION_MAX_CONCURRENT,ga as DEFAULT_MAX_ACTIONS_PER_SWEEP,jo as DEFAULT_NODE_MODULES_AGE_MS,fa as DEFAULT_RUN_DIRECTORIES_AGE_MS,ma as DEFAULT_TERMINAL_WORKTREES_AGE_MS,Ie as DEFAULT_WORKER_PROVIDER,Vo as DEFAULT_WORKTREES_AGE_MS,Up as DEFAULT_WSL_CRASH_DUMP_CRITICAL_BYTES,Mp as DEFAULT_WSL_CRASH_DUMP_WARN_BYTES,Op as DEFAULT_WSL_HOST_CRITICAL_FREE_BYTES,Jr as DEFAULT_WSL_HOST_MOUNT,Ip as DEFAULT_WSL_HOST_WARN_FREE_BYTES,st as EMBEDDED_INSTRUCTION_BUNDLE,Jm as EMBEDDED_INSTRUCTION_BUNDLE_VERSION,hp as FORBIDDEN_WORKER_ENV_KEYS,ca as HARNESS_BUILD_CACHE_RELATIVE_PATHS,os as HEAVY_VERIFICATION_TOKEN_REQUIRED,gi as HERMES_OPENAI_CODEX_DEFAULT_MODEL,oh as INSTRUCTION_BUNDLE_REFRESH_TTL_MS,bl as MEMORY_COST_MANAGED_PACKAGES,vl as MEMORY_COST_PACKAGE_MIN_VERSIONS,Gn as MemoryCostPackageVersionGuardError,Ru as OPENAI_CODEX_PROVIDER,Mx as ORCHESTRATION_ACTION_KINDS,Ux as ORCHESTRATION_POLICY_DECISIONS,vu as ORCHESTRATION_POLICY_MODES,Kn as PACKAGE_VERSION,rh as PINNED_INSTRUCTION_BUNDLE_PUBLIC_KEYS,bn as RUN_METADATA_ACTIVE_SIGNAL_MS,Sh as TERMINAL_WORKER_ARCHIVE_AGE_MS,Ox as TRANSIENT_OPENAI_CODEX_ERROR_CLASSES,si as WORKER_PERSONA_CATALOG,Jx as applyProductionDatabaseToProcess,ia as archiveTerminalWorkerMetadata,wl as assertMemoryCostPackageVersionGuard,as as assessAutoCompleteEligibility,xt as assessBuildAdmission,Xr as assessExitedWorkerSalvage,Bn as assessHeavyVerificationGate,ed as assessOrphanWorktreeSafety,Uc as assessPrHandoffRequirement,Qr as assessWorkerLanding,Hl as assessWorkerLandingContract,jv as auditWorkerEnv,ft as autoCompleteWorker,Jc as autoCompleteWorkerCli,Mo as buildBoxResourceSnapshotFromGate,bf as buildCodexExecArgv,Qg as buildDispatchTaskText,Su as buildForegroundHarnessIdempotencyKey,kf as buildHermesOpenAiCodexChatArgv,_l as buildMemoryCostPackageGuardInput,gc as buildOrchestrationProviderInventory,Ec as buildPrompt,Cn as buildRunListRows,js as buildSystemdRunArgv,Xi as canonicalJsonStringify,Rr as canonicalWorkerDir,Ga as classifyHeavyShellCommand,tm as classifyNpmAuditOutcome,ah as classifyOpenAiCodexError,uf as classifyOrchestrationRisk,Xp as classifyRepoSearchMeta,Ms as classifyShellCommandOutcome,Nt as classifyVercelUrl,Za as classifyWorkerHealth,Do as cleanupWslCrashDumps,vc as codexProvider,Tu as collectFilesystemLiveRunKeys,Pv as collectVercelEvidence,cf as compareProviderCandidates,Yn as compareSemver,Mi as completeWorker,gm as computeAttention,Rx as computeInstructionBundleVersion,D as computeWorkerStatus,ts as countActiveHeavyVerificationSlots,Fo as createRun,Ro as defaultBoxId,vx as deriveInstructionBundleKeyId,Qt as deriveRunStatus,Ds as diagnoseRepoSearchFailure,Gr as discoverDefaultRepo,yl as discoverDefaultRepoCandidates,jn as discoverDefaultRepoForPersistence,ra as discoverProductionDbEnvFilePaths,Wr as dispatchRun,Gi as drainPlanOutbox,ac as enforceCursorWorkerProvider,xl as enforceMemoryCostPackageGuardAtStartup,yu as ensureInstructionBundle,Ai as ensurePrReadyHandoff,mb as evaluateMemoryCostPackageGuardAtStartup,Cs as evaluateMemoryCostPackageVersionGuard,Hx as evaluateOrchestrationPolicy,rp as evidenceFromGitHubVercelStatus,mh as expandHomePath,Ji as extractPlanOutboxFromTask,Mc as extractPrUrlFromText,Dl as extractSearchMeta,em as extractSearchMetaFromToolLine,Xa as formatAutoCompleteOutcomeNotice,uh as formatCronJobDeliveryFailure,PR as formatHarnessToolReadable,gx as formatHeartbeatLine,ob as formatMemoryCostPackageGuardError,Hn as formatMonitorTickNotice,ch as formatOpenAiCodexFailureNotice,Yi as formatPlanOutboxHandoffBlock,Zp as formatRepoSearchGuidance,vn as formatResolvedDefaultRepo,Qa as formatWorkerCompleteNotice,is as formatWorkerStatusNotice,Ya as gateWorkerShellCommand,sC as getActiveInstructionBundle,fr as getActiveInstructionBundleSource,Nr as getActiveInstructionBundleVersion,qr as getHarnessPaths,el as getMonitorStatus,at as getOrchestrationProviderCapability,ii as getPersonaDefaultRoleLane,Qm as getPersonaDispatchLane,nc as getWorkerPersonaCatalogEntry,hl as gitRepoRoot,ge as harnessRunsDir,Hu as harnessStorageSnapshot,dr as harnessWorktreesDir,yn as hasNestedRunsSegment,gr as hashPlanBody,Rc as hermesCodexProvider,gu as instructionBundleCachePath,rt as isActiveHarnessWorker,Xe as isClaudeFamilyProvider,Ev as isDashboardVercelUrl,hx as isEngagementRequiredSkip,oe as isFinishedWorkerStatus,pl as isForbiddenWorkerEnvKey,Fu as isGeneratedHarnessPath,Au as isHarnessRunMetadataPath,_p as isHarnessWorktreeRepo,Wn as isHeavyVerificationGateSkipped,il as isInspectableVercelTarget,uC as isKnownWorkerPersonaSlug,wp as isKynverMonorepoRoot,et as isLandingBlockedWorkerStatus,bu as isOrchestrationEnforceTasksEnabled,nd as isPipelineCleanupEnabled,Ns as isRgExcludeScopeTarget,kn as isSignedInstructionBundleShape,Os as isSingleFileSearchTarget,tn as isSystemdRunAvailable,Tl as isTerminalHeartbeatPhase,Zd as isVercelStatusContext,xs as isWslHost,ER as joinHarnessNotice,Fl as landingContractAttentionReason,Od as listActiveHeavyVerificationSlots,kp as listForbiddenWorkerEnvKeys,ls as listMonitors,cc as listOrchestrationProviderCapabilities,ht as listOutboxItems,Lu as listRuns,Wu as listRunsCli,ku as loadInstructionBundleCache,y as loadUserConfig,Cv as main,Ba as mergeNodeOptionsForBuildCheck,Qp as metaToNormalizedRgCommand,df as normalizeCursorModelAlias,le as normalizeHarnessRoot,Ts as normalizeRepoSearchCommand,zp as normalizeRgArgv,Le as observeRunnerDiskGate,ur as observeWslCrashDumps,Al as observeWslHostDisk,Dx as orchestrationAuditForWorkerJson,ho as parseArgs,aS as parseClaudeStream,Ar as parseHarnessStream,ce as parseHeartbeat,Qi as parseRawEd25519Key,Lp as parseWslCrashDumpFilename,oa as persistDefaultRepo,du as persistExitedWorkerHandoffCapture,hn as persistPlan,ds as pickVercelStatusContext,Or as postJson,yC as preferCursorExecutor,mi as preflightClaudeModel,ct as preflightCodexModel,fi as preflightCursorModel,di as probeClaudeOAuthBinding,uc as probeCodexOAuthBinding,pi as probeCursorOAuthBinding,fc as probeHermesCliAdapter,yo as probeHermesOpenAiCodexBinding,$C as probeOrchestrationProviderBinding,Cl as probeRepoPackageVersions,pc as providerCapableForRisk,Bp as readKernelCorePattern,$t as readMemAvailableBytes,gh as readProductionDbKeysFromEnvFile,Hp as readWslConfigCrashDumpSettings,ns as reclaimStaleHeavyVerificationSlots,la as reconcileLocalOnlyMergedPrAttention,Uu as reconcileRunsCli,Sn as reconcileStaleWorkers,aa as reconcileWorkerMetadata,RE as reconcileWorkerMetadataCli,Fx as redactHarness,kr as redactProviderErrorText,Ln as releaseHeavyVerificationSlot,eE as remediateDefaultRepo,sa as repairMissingRunMetadata,Qx as repairNestedRunsPath,V as resolveBaseUrl,dw as resolveBoxKindFromEnv,oi as resolveBundlePersona,rC as resolveCallbackSecret,J as resolveCallbackSecretWithMint,Tr as resolveCodexOrchestrationAdapter,ko as resolveConfiguredWorkerProvider,je as resolveDefaultRepo,na as resolveDefaultRepoForPersistence,uu as resolveExitedWorkerFinalResult,fe as resolveHarnessRoot,Ah as resolveHarnessRunByName,Bu as resolveHarnessRunCli,Mn as resolveHeavyVerificationMaxConcurrent,mu as resolveInstructionBundlePublicKey,cn as resolveInstructionText,lh as resolveOpenAiCodexRetryBudget,Zi as resolveOrchestrationPolicyMode,kc as resolveOrchestrationRouting,it as resolvePolicyThreshold,hh as resolveProductionDatabaseUrl,Ti as resolveRunTargetArg,ep as resolveVercelInspectTarget,Eu as resolveWorkerJsonPath,Fe as resolveWorkerTargetArgs,Wp as resolveWslCrashDumpDir,Ol as resolveWslWindowsUsername,Ja as runBoundedBuildCheck,es as runDaemon,vt as runDirHasActiveRetentionSignals,_a as runHarnessCleanup,ss as runHarnessVerifyCommands,Ot as runMonitorTick,td as runPipelineHarnessCleanup,jc as runStatus,Bo as safeDatabaseUrlHint,dh as sanitizeOrchestrationAudit,hu as saveInstructionBundleCache,ue as saveUserConfig,yp as scrubClaudeEnv,We as scrubWorkerEnv,ui as selectCheapestCapableProvider,Sl as semverAtLeast,tc as setActiveInstructionBundle,cu as shouldAutoCleanupWslCrashDumps,El as shouldEnforceMemoryCostPackageGuardCli,qc as spawnCompletionSidecar,tl as spawnMonitorSidecar,Li as spawnWorkerProcess,Xc as startWorker,Gc as stopWorker,Wl as summarizeEvent,rm as summarizeNpmAuditReport,sm as summarizeShellToolCallEvent,Fp as summarizeWslCrashDumpRecoverySteps,Np as summarizeWslRecoverySteps,wn as sweepRun,Vc as tailWorker,li as taskAllowsClaudeWorker,ze as terminalFinalResultFromHeartbeat,Et as tryAcquireHeavyVerificationSlot,ec as tryResolveBaseUrl,ri as tryResolveCallbackSecretWithMint,sl as usage,s_ as validateOwnedPaths,Fc as validateRepo,Co as validateRunId,i_ as validateTailLines,ug as validateWorkerName,th as verifyInstructionBundleSignatureWithKey,fu as verifySignedInstructionBundle,Va as waitForHeavyVerificationSlot,Nu as workerDirHasActiveRetentionSignals,dC as workerPersonaLandingSlugs,oc as workerPersonaReviewSlugs,$c as workerStatus};
|
|
77
|
+
Blockers:`);for(let n of t.blockers)console.log(` ! ${n}`);process.exitCode=1;return}console.log("\nInstall complete \u2014 run `kynver cron verify` to re-check.")}async function yb(e){let r=R(),t=await Tn({config:r});if(e.json===!0){console.log(JSON.stringify(t,null,2)),t.ok||(process.exitCode=1);return}console.log(`Kynver Cron verify: ${t.ok?"PASS":"FAIL"}
|
|
78
|
+
`);for(let n of t.checks){let o=n.ok?"ok":"FAIL";console.log(` [${o}] ${n.id}: ${n.summary}`),!n.ok&&n.remediation&&console.log(` \u2192 ${n.remediation}`)}t.ok||(process.exitCode=1)}N();import aT from"node:os";N();Ie();rn();C();var ps={slug:"landing-maintainer",originCron:"maintain-8-blocker-and-pr-landing-workers",defaultRepo:"Totalsolutionsync/Kynver",landScript:"scripts/agent-os-land-pr.mjs",landScriptArgs:["--skip-not-ready"]};import{spawnSync as iT}from"node:child_process";import Rb from"node:path";function bb(e,r,t){let o=[Rb.join(r,ps.landScript),String(e),...ps.landScriptArgs];if(!t)return{action:{kind:"land_pr",prNumber:e,reason:"dry-run"},executed:!1,exitCode:0,stdout:`dry-run: node ${o.join(" ")}`,stderr:""};let s=iT("node",o,{cwd:r,encoding:"utf8",timeout:600*1e3});return{action:{kind:"land_pr",prNumber:e,reason:"landing wrapper invoked"},executed:!0,exitCode:s.status,stdout:s.stdout??"",stderr:s.stderr??""}}function vb(e){let r=e.repoPath?String(e.repoPath).trim():"";return r?Rb.resolve(r):je()?.repo??process.cwd()}async function Sb(e){let r=String(T(String(e.agentOsId||""),"--agent-os-id")),t=String(e.repo||ps.defaultRepo).trim(),n=e.fleet===!0||e.fleet==="true",o=e.execute===!0||e.execute==="true",s=e.run?String(e.run):void 0,i=mr({runId:s??"fleet-lane-tick"}),a={...Wo(i,{harnessRunId:s,boxKind:qe(R()),hostLabel:aT.hostname()}),providerHealthy:i.ok,authorizedForRepair:i.ok,authorizedForLanding:i.ok,systemHealthBlockers:i.ok?[]:[i.reason??"resource_gate_blocked"],actionableWorkers:i.activeWorkers},l=V(e.baseUrl?String(e.baseUrl):void 0),c=await J(e.secret?String(e.secret):void 0,r,{baseUrl:l}),u=`${l}/api/agent-os/by-id/${encodeURIComponent(r)}/fleet-landing-maintainer/tick`,f=(await Ir(u,c,{repo:t,fleet:n,execute:o,runId:s,boxCapacity:a})).response,p=[],m=vb(e),h=Array.isArray(f?.localActions)?f.localActions:[],k=a.boxId;for(let g of h){if(g.kind==="land_pr"&&typeof g.prNumber=="number"){let y=bb(g.prNumber,m,o);if(p.push({action:y.action,executed:y.executed,exitCode:y.exitCode}),o&&y.executed){let _=y.exitCode===0,x=typeof g.prUrl=="string"&&g.prUrl.trim()?g.prUrl.trim():`https://github.com/${t}/pull/${g.prNumber}`;try{await Ir(`${l}/api/agent-os/by-id/${encodeURIComponent(r)}/fleet-landing-maintainer/outcome`,c,{repo:t,prUrl:x,holderBoxId:k,merged:_})}catch{}}continue}p.push({action:g,executed:!1,exitCode:null})}return{repo:t,fleet:n,execute:o,coordinator:f,localOutcomes:p}}async function Cb(e,r){let t=String(r??e.lane??"").trim();t!=="landing-maintainer"&&(console.error(`unknown lane: ${t||"(none)"}`),process.exit(1));let n=await Sb(e);if(e.json===!0||e.json==="true"){console.log(JSON.stringify(n,null,2));return}console.log(["fleet landing-maintainer tick",`repo=${n.repo}`,`fleet=${n.fleet}`,`execute=${n.execute}`,`localOutcomes=${n.localOutcomes.length}`].join(" "));for(let o of n.localOutcomes)console.log(` ${o.action.kind} pr=${o.action.prNumber??"-"} executed=${o.executed}`)}N();D();zr();rn();import dT from"node:path";C();pr();en();D();C();import lT from"node:path";function wb(e){let r=e?.trim();return r?/completion acknowledged but board not advanced/i.test(r)&&/task already terminal/i.test(r):!1}function _b(e){let r=typeof e.status=="string"?e.status:"",t=typeof e.completionBlocker=="string"&&e.completionBlocker.trim().length>0?e.completionBlocker:void 0;return t&&!wb(t)?!1:typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim()||e.completionOutcome==="acknowledged"?!0:r==="done"}function Jd(e){return typeof e.completionReportedAt=="string"&&e.completionReportedAt.trim()||!H(e.pid)?!1:Fs(e)}function cT(e,r){let t=e.completionBlocker?.trim();if(t&&!wb(t))return{attention:"blocked",attentionReason:t,status:"blocked"};if(r.heartbeatBlocker)return{attention:"blocked",attentionReason:r.heartbeatBlocker,status:"blocked"};if(_b(e))return{attention:"done",attentionReason:"completion acknowledged",status:"done"};let n=Jd(e);return n?{attention:"ok",status:e.status?.trim()||"running"}:e.status==="done"?{attention:"done",status:"done"}:n?{attention:"ok",status:e.status?.trim()||"unknown"}:{attention:"needs_attention",attentionReason:"process not alive",status:"exited"}}function uT(e){return typeof e.completionBlocker=="string"&&e.completionBlocker.trim()||_b(e)?!1:Jd(e)}function qd(e,r){let t=w(lT.join(P(e.id),"workers",v(r),"worker.json"),void 0);if(!t)return null;let n=ce(t.heartbeatPath),{attention:o,attentionReason:s,status:i}=cT(t,n),a=Jd(t),l=uT(t);return{runId:e.id,runName:e.name,worker:r,status:i,attention:o,attentionReason:s,alive:a,isActive:l,taskId:t.taskId?.trim()||null,planId:t.planId?.trim()||null,leaseOwner:t.leaseOwner?.trim()||null,pid:t.pid,model:t.model,currentTask:n.lastHeartbeatSummary,lastHeartbeatPhase:n.lastHeartbeatPhase,lastHeartbeatSummary:n.lastHeartbeatSummary,heartbeatBlocker:n.heartbeatBlocker,completionBlocker:t.completionBlocker?.trim()||null}}function zd(e,r){let t={};for(let n of e){let o=r(n).trim()||"unknown";t[o]=(t[o]??0)+1}return t}function xb(e){return e.filter(r=>r.attention==="blocked"||r.attention==="needs_attention"||r.attention==="stale").map(r=>({runId:r.runId,worker:r.worker,taskId:r.taskId,reason:r.completionBlocker??r.heartbeatBlocker??r.attentionReason??r.attention}))}function Eb(e){return e.filter(r=>r.isActive&&r.taskId).map(r=>r.taskId.trim())}function pT(){let e=[];for(let r of X())for(let t of ke(r)){let n=qd(r,t);n&&e.push(n)}return e}function mT(e){let r=e.trim().toLowerCase();if(!r)return null;for(let t of X())for(let n of ke(t)){let s=w(dT.join(P(t.id),"workers",v(n),"worker.json"),void 0)?.taskId?.trim();if(s&&(s.toLowerCase()===r||s.toLowerCase().endsWith(r)))return qd(t,n)}return null}function Xd(e){if(e.mode==="full")return{mode:"full",runs:wn()};let r=R(),{harnessRoot:t}=Z(),n=X(),o=pT(),s=o.filter(l=>l.isActive).length,i=mr({runId:n[0]?.id??"fleet",activeWorkers:s}),a={generatedAt:new Date().toISOString(),mode:e.mode,harnessRoot:t,agentOsId:r.agentOsId?.trim()||null,resourceGate:i,runCount:n.length,runStatusCounts:zd(n,l=>l.status),workerCount:o.length,workerStatusCounts:zd(o,l=>l.status),workerAttentionCounts:zd(o,l=>l.attention),activeTaskIds:Eb(o),blocked:xb(o).slice(0,25),workers:o};if(e.mode==="task"){let l=e.taskId?.trim()??"",c=l?mT(l):null;return{...a,mode:"task",taskId:l,taskFound:!!c,workers:c?[c]:[]}}if(e.mode==="workers"){let l=o.filter(c=>c.alive||c.attention==="blocked"||c.attention==="needs_attention"||c.attention==="stale");return{...a,mode:"workers",workers:l,blocked:xb(l).slice(0,25),activeTaskIds:Eb(l)}}return a}function Qd(e,r=72){let t=e.trim();return t.length<=r?t:`${t.slice(0,r-1)}\u2026`}function fT(e){let r=[`${e.runId}/${e.worker}`,e.taskId?`task=${e.taskId}`:"task=\u2014",e.leaseOwner?`lease=${e.leaseOwner}`:"lease=\u2014",`${e.status}/${e.attention}`];return e.currentTask&&r.push(`tool=${Qd(e.currentTask,48)}`),r.join(" \xB7 ")}function gT(e){let r=e.resourceGate,t=[];if(t.push("Kynver factory status"),t.push(`Slots: ${r.activeWorkers}/${r.maxConcurrentWorkers} active \xB7 ${r.slotsAvailable} available`+(r.reason?` (${r.reason})`:"")),t.push(`Runs: ${e.runCount} \xB7 Workers: ${e.workerCount}`),e.activeTaskIds.length>0&&t.push(`Active tasks: ${e.activeTaskIds.slice(0,12).join(", ")}`),e.blocked.length>0){t.push(`Blocked (${e.blocked.length}):`);for(let n of e.blocked.slice(0,8)){let o=n.taskId?` task=${n.taskId}`:"";t.push(` \xB7 ${n.runId}/${n.worker}${o}: ${Qd(n.reason)}`)}e.blocked.length>8&&t.push(` \xB7 \u2026and ${e.blocked.length-8} more (use kynver status --workers)`)}else t.push("Blocked: none");return t.push("Drilldown: kynver status --workers | --task <id> | --json | --full"),t.join(`
|
|
79
|
+
`)}function hT(e){let r=e.resourceGate,t=[];if(t.push(`Worker slots ${r.activeWorkers}/${r.maxConcurrentWorkers} \xB7 available ${r.slotsAvailable}`),e.workers.length===0)return t.push("No active or attention workers."),t.join(`
|
|
80
|
+
`);for(let n of e.workers)t.push(fT(n));return t.join(`
|
|
81
|
+
`)}function kT(e){if(!e.taskId)return"missing --task <id>";if(!e.taskFound||e.workers.length===0)return`No harness worker found for task ${e.taskId}`;let r=e.workers[0];return[`task ${e.taskId}`,`${r.runId}/${r.worker}`,r.status,r.attention,r.leaseOwner?`lease=${r.leaseOwner}`:null,r.model?`model=${r.model}`:null,r.currentTask?`tool=${Qd(r.currentTask)}`:null,r.completionBlocker??r.heartbeatBlocker??r.attentionReason??null].filter(n=>!!n).join(" \xB7 ")}function Pb(e){return e.mode==="workers"?hT(e):e.mode==="task"?kT(e):gT(e)}function yT(e){return e.full===!0||e.full==="true"?"full":e.json===!0||e.json==="true"?"json":e.workers===!0||e.workers==="true"?"workers":typeof e.task=="string"&&e.task.trim()?"task":"compact"}function Ab(e){let r=yT(e);if(r==="full"){let n=Xd({mode:"full"});console.log(JSON.stringify(n,null,2));return}let t=Xd({mode:r,taskId:typeof e.task=="string"?e.task:void 0});if(r==="json"){console.log(JSON.stringify(t,null,2));return}console.log(Pb(t))}function Zd(e){return e==="help"||e==="--help"||e==="-h"}function Nb(e,r){let t=[e,r].filter(Boolean).join(" ");console.error(`unknown command: ${t||"(none)"}`),il(1)}function il(e=0){(e===0?console.log:console.error)(["Usage:"," kynver login [--api-key KEY] [--api-base-url URL] (omit --api-key to authorize in the browser)"," kynver bootstrap [--api-base-url URL] [--api-key KEY] [--repo PATH] (login + setup + runner credential in one shot)"," kynver start [--repo PATH] [--api-base-url URL] [--run RUN_ID] [--interval-ms MS] [--chat-oauth] [--install-systemd] (bring your agent online: bootstrap if needed + run + keeper-supervised daemon; --install-systemd enables Linux user unit)"," kynver runner credential [--agent-os-id ID] [--base-url URL]"," kynver setup [--api-base-url URL] [--agent-os-id ID] [--agent-os-slug SLUG] [--box-kind forge|ghost] [--repo PATH] [--discover-repo] [--max-workers N] [--provider claude|cursor] [--chat-oauth]"," kynver daemon --run RUN_ID --agent-os-id AOS_ID [--execute] [--interval-ms MS] [--stall-ms MS] [--no-supervise]"," kynver status [--compact] [--workers] [--task TASK_ID] [--json] [--full] # factory-wide harness summary"," kynver run list"," kynver run resolve --name RUN_NAME"," kynver run status --run RUN_ID [--full] # defaults to compact shallow map with drill-down commands"," kynver run dispatch --run RUN_ID --agent-os-id AOS_ID [--base-url URL] [--secret SECRET] [--execute] [--lane any|implementation|review|landing] [--target-task-id TASK_ID] [--executor harness] [--max-starts 1] [--lease-ms MS] [--owned path[,path]] [--model claude-opus-4-8] [--disk-path /] [--reconcile-stale-blockers]"," kynver run sweep --run RUN_ID --agent-os-id AOS_ID [--base-url URL] [--secret SECRET] [--grace-ms MS]",' kynver worker start --run RUN_ID --name worker --task "..." [--owned path[,path]] [--model MODEL] [--provider claude|cursor] [--agent-os-id AOS_ID] [--task-id TASK_ID] [--wait] [--emit-json]'," kynver worker list --run RUN_ID [--full] # defaults to compact shallow map with drill-down commands"," kynver worker status --run RUN_ID --name worker"," kynver worker tail --run RUN_ID --name worker [--lines 40] [--raw]"," kynver worker stop --run RUN_ID --name worker"," kynver worker complete --run RUN_ID --name worker [--agent-os-id AOS_ID] [--task-id TASK_ID] [--base-url URL] [--secret SECRET]"," kynver worker discard-disposable --run RUN_ID --name worker --path scripts/helper.mjs[,other]"," kynver worker auto-complete --run RUN_ID --name worker [--agent-os-id AOS_ID] [--poll-ms 5000] [--max-total-ms 21600000] [--complete-attempts 3] [--complete-backoff-ms 5000] [--base-url URL] [--secret SECRET]"," kynver run reconcile"," kynver run unblock [--agent-os-id AOS_ID] [--base-url URL] [--secret SECRET] [--dry-run]"," kynver plan progress --plan PLAN_ID --row ROW_KEY --role ROLE --status STATUS [--task TASK_ID] [--note NOTE] [--evidence type:value] [--agent-os-id AOS_ID]"," kynver plan verify --plan PLAN_ID [--worktree PATH] [--task TASK_ID] [--human-override] [--local]"," kynver harness verify --worktree PATH [--command CMD] [--json] [--wait-for-admission-ms MS] [--timeout-ms MS]"," kynver plan persist --operation create|add_version|update_metadata --title TITLE (--body-file PATH | --body TEXT) [--slug SLUG] [--plan PLAN_ID] [--summary TEXT] [--failure-kind approval_guard|auth|network|server|tool_interruption]"," kynver plan outbox list"," kynver plan outbox drain [--max N] [--id OUTBOX_ID]"," kynver cleanup [--execute] [--compact] [--node-modules-age-ms MS] [--worktrees-age-ms MS] [--harness-root PATH] [--include-orphans] [--skip-finalize] [--account-bytes]"," kynver wsl-crashes [--json] [--execute] [--purge-all] [--keep-newest N]"," --include-orphans also scans whole worktree directories (<harnessRoot>/worktrees/<runId>/<workerId>/) that no run/worker.json references; orphans pass salvage gates (recent heartbeat, dirty git, ahead of origin/main) before removal."," Dry-run defaults to fast scan (no byte accounting). Pass --account-bytes for reclaimable byte totals. Pass --compact for a bounded operator summary (no full action list)."," kynver monitor start --run RUN_ID [--name worker] [--agent-os-id AOS_ID] [--poll-ms MS]"," kynver monitor status [--run RUN_ID] [--name worker] [--tick]"," kynver monitor stop --run RUN_ID [--name worker]"," kynver monitor list"," kynver monitor tick --run RUN_ID [--name worker] [--agent-os-id AOS_ID] [--auto-complete] [--renew-leases]"," kynver monitor auto-complete --run RUN_ID --name worker [--agent-os-id AOS_ID] [--base-url URL] [--secret SECRET]"," kynver monitor run-loop --run RUN_ID --monitor-id ID [--name worker] [--agent-os-id AOS_ID] [--poll-ms MS] [--auto-complete] [--renew-leases]"," kynver config ensure-default-repo [--json]"," kynver doctor runtime-takeover [--remediate-default-repo]"," kynver scheduler cutover-check [--json]"," kynver scheduler attest-cutover [--json]"," kynver cron install [--dry-run] [--json] [--install-systemd] [--confirm-qstash-removal] [--skip-watchdog] [--skip-test-fire] [--agent-os-id ID] [--api-base-url URL] [--run RUN_ID]"," kynver cron verify [--json]"," kynver cron status [--json]"," kynver cron tick [--agent-os-id AOS_ID] [--json]"," kynver lane tick landing-maintainer [--fleet] [--repo OWNER/NAME] [--agent-os-id AOS_ID] [--execute] [--json]"," kynver board contract [--agent-os-id ID] [--base-url URL] [--since ISO] [--limit N]"].join(`
|
|
82
|
+
`)),process.exit(e)}async function Tb(e=process.argv.slice(2)){if(fp(e,import.meta.url,"kynver"))return;if(e.length===0||Zd(e[0]))return il(0);let r=e.shift(),t,n;if((r==="run"||r==="worker"||r==="plan"||r==="runner"||r==="harness"||r==="monitor"||r==="doctor"||r==="config"||r==="scheduler"||r==="cron"||r==="lane"||r==="board")&&(t=e.shift()),n=e,t&&Zd(t)||n.some(Zd))return il(0);let o=ko(n),{runsDir:s,worktreesDir:i}=Z();if(Ob(s,{recursive:!0}),Ob(i,{recursive:!0}),r==="daemon"&&Pn(),Pl(r,t)){let a,l=o.run?String(o.run).trim():"";if(l)try{a=L(l).repo}catch{a=void 0}await El({repoRoot:a,cwd:a})}if(r==="login")return void await Gm(o);if(r==="bootstrap")return void await Ea(o);if(r==="start")return void await yR(o);if(r==="runner"&&t==="credential")return void await Vm(o);if(r==="setup")return void await oi(o);if(r==="status")return Ab(o);if(r==="daemon")return Da(o)?void await Ma(o):void await ts(o);if(r==="plan"&&t==="progress")return void await PR(o);if(r==="plan"&&t==="verify")return void await AR(o);if(r==="harness"&&t==="verify")return OR(o);if(r==="plan"&&t==="persist")return void await IR(o);if(r==="plan"&&t==="outbox"){let a=n.shift();if(a==="list")return void await NR();if(a==="drain")return void await TR(ko(n));Nb("plan",`outbox ${a??""}`.trim())}if(r==="cleanup")return DR(o);if(r==="wsl-crashes")return MR(o);if(r==="config"&&t==="ensure-default-repo")return Vk(o.json===!0);if(r==="doctor"&&t==="runtime-takeover")return cb(o);if(r==="scheduler"&&t==="cutover-check")return mb(o.json===!0);if(r==="scheduler"&&t==="attest-cutover")return fb(o.json===!0);if(r==="cron"&&t==="install")return void await kb(o);if(r==="cron"&&t==="verify")return void await yb(o);if(r==="cron"&&t==="status")return void await gb(o.json===!0);if(r==="cron"&&t==="tick")return void await hb(o);if(r==="lane"&&t==="tick"){let a=n.shift();return void await Cb(ko(n),a)}if(r==="board"&&t==="contract")return void await ub(o);if(r==="run"&&t==="create")return void $o(o);if(r==="run"&&t==="list")return Ku();if(r==="run"&&t==="resolve")return $u(o);if(r==="run"&&t==="status")return Jc(o);if(r==="run"&&t==="dispatch")return void await Wr(o);if(r==="run"&&t==="sweep")return void await _n(o);if(r==="run"&&t==="reconcile")return Hu();if(r==="run"&&t==="unblock")return void await QR(o);if(r==="worker"&&t==="start")return void await ru(o);if(r==="worker"&&t==="list")return xg(o);if(r==="worker"&&t==="status")return Yc(o);if(r==="worker"&&t==="tail")return qc(o);if(r==="worker"&&t==="stop")return zc(o);if(r==="worker"&&t==="complete")return void await Ui(o);if(r==="worker"&&t==="discard-disposable")return RR(o);if(r==="worker"&&t==="auto-complete")return void await Qc(o);if(r==="monitor"&&t==="start"){let a=await GR(o);console.log(JSON.stringify(a,null,2));return}if(r==="monitor"&&t==="status")return void await YR(o);if(r==="monitor"&&t==="stop")return JR(o);if(r==="monitor"&&t==="list")return qR();if(r==="monitor"&&t==="tick")return void await XR(o);if(r==="monitor"&&t==="auto-complete")return void await tl(o);if(r==="monitor"&&t==="run-loop")return void await zR(o);Nb(r,t)}var bT=process.argv[1]&&Ib.native(process.argv[1])===Ib.native(RT(import.meta.url));bT&&Tb().catch(e=>{console.error(e),process.exit(1)});var vT="https://api.vercel.com";function ST(e){let r=e?.trim();return r||process.env.VERCEL_TOKEN?.trim()||null}function Db(e){return(e??"").trim().toUpperCase()}function CT(e){if(typeof e!="string"||!e.trim())return null;let r=e.trim();return r.startsWith("http")?r:`https://${r}`}async function ep(e,r={}){let t=e.trim();if(!t)return{ok:!1,readyState:null,previewUrl:null,error:"missing deployment id or URL"};let n=ST(r.token);if(!n)return{ok:!1,readyState:null,previewUrl:null,error:"VERCEL_TOKEN not configured"};let o=r.teamId?.trim()||process.env.VERCEL_TEAM_ID?.trim(),s=o?`?teamId=${encodeURIComponent(o)}`:"",i=r.fetchImpl??fetch;try{let a=await i(`${vT}/v13/deployments/${encodeURIComponent(t)}${s}`,{headers:{Authorization:`Bearer ${n}`}});if(!a.ok){let u=await a.text();return{ok:!1,readyState:null,previewUrl:null,error:`Vercel API ${a.status}: ${u.slice(0,200)}`}}let l=await a.json();return{ok:!0,readyState:Db(l.readyState??l.state)||null,previewUrl:CT(l.url),error:null}}catch(a){return{ok:!1,readyState:null,previewUrl:null,error:a instanceof Error?a.message:"Vercel API fetch failed"}}}function rp(e,r){let t=Db(e);return t==="READY"?"ready":t==="ERROR"||t==="CANCELED"?"error":t==="BUILDING"||t==="QUEUED"||t==="INITIALIZING"||r?"building":"error"}var Mb=/(^|\.)vercel\.app$/i,Ub=/^dpl_[a-z0-9]+$/i;function al(e){let r=e.trim();if(!r||/vercel\.com/i.test(r))return!1;if(Ub.test(r))return!0;try{let t=new URL(r.startsWith("http")?r:`https://${r}`);return Mb.test(t.hostname)}catch{return!1}}function wT(e){let r=e.trim();if(!r)return null;try{return new URL(r)}catch{return null}}function _T(e){let r=e.pathname.split("/").filter(Boolean);if(r.length<3)return null;let t=r[r.length-1]?.trim();return!t||t==="deployments"?null:t}function xT(e){let r=e.pathname.split("/").filter(Boolean),t=r.indexOf("deployments");return t<0||t>=r.length-1?null:r[t+1]?.trim()||null}function Tt(e){let r={kind:"unknown",previewUrl:null,inspectTarget:null,deploymentId:null},t=e.trim();if(!t)return r;if(/^dpl_[a-z0-9]+$/i.test(t))return{kind:"deployment_id",previewUrl:null,inspectTarget:t,deploymentId:t};let n=wT(t);if(!n)return r;if(Mb.test(n.hostname)){let o=n.origin;return{kind:"deployment_host",previewUrl:o,inspectTarget:o,deploymentId:null}}if(n.hostname==="vercel.com"||n.hostname.endsWith(".vercel.com")){let o=xT(n)??_T(n);return{kind:"dashboard",previewUrl:null,inspectTarget:o&&Ub.test(o)?o:null,deploymentId:o}}return r}function Wb(e){return Tt(e).kind==="dashboard"}var ET=/vercel/i;function tp(e){let r=typeof e=="string"?e.trim().toLowerCase():"";return r==="success"?"success":r==="pending"?"pending":r==="failure"?"failure":r==="error"?"error":"unknown"}function np(e){let r=typeof e=="string"?e.trim():"";return!!(r&&ET.test(r))}function ms(e){let t=(Array.isArray(e)?e:[]).filter(l=>np(l.context));if(t.length===0)return null;let n=l=>l==="failure"||l==="error"?0:l==="pending"?1:l==="success"?2:1,o=null,s=1/0;for(let l of t){let c=n(tp(l.state));c<s&&(o=l,s=c)}if(!o)return null;let i=typeof o.target_url=="string"&&o.target_url.trim()?o.target_url.trim():null,a=i?Tt(i):null;return{context:String(o.context??"Vercel").trim(),state:tp(o.state),targetUrl:i,description:typeof o.description=="string"&&o.description.trim()?o.description.trim():null,deploymentId:a?.deploymentId??null,previewUrl:a?.previewUrl??null,dashboardUrl:a?.kind==="dashboard"?i:null}}function PT(e){return e==="success"?"ready":e==="pending"?"building":e==="failure"||e==="error"?"error":"unavailable"}function ll(e){return e.filter(Boolean).join("; ")}function op(e){let r=typeof e=="string"?e.trim():"";if(!r)return{target:null,classified:null,reason:"missing target_url"};let t=Tt(r);return t.inspectTarget&&al(t.inspectTarget)?{target:t.inspectTarget,classified:t,reason:null}:t.kind==="dashboard"?{target:null,classified:t,reason:t.deploymentId?"dashboard deployment id is not API-inspectable; trust GitHub Vercel status":"dashboard URL is not valid for Vercel API lookup"}:{target:null,classified:t,reason:"unrecognized Vercel URL"}}function sp(e,r={}){let t=r.observedAt??new Date().toISOString(),n=ms(e);if(!n)return{status:"not_run",previewUrl:null,deploymentUrl:null,summary:"No Vercel GitHub status context on commit",observedAt:t,inspectSkipped:!0,inspectReason:"no_vercel_status_context",githubState:null,vercelContext:null};let o=PT(n.state),s=n.previewUrl??n.dashboardUrl,i=n.previewUrl??n.dashboardUrl;return{status:o,previewUrl:s,deploymentUrl:i,summary:ll([`GitHub ${n.context}=${n.state}`,n.description??"",n.dashboardUrl?"dashboard target_url (API lookup skipped)":""]),observedAt:t,inspectSkipped:!0,inspectReason:n.dashboardUrl&&n.state==="success"?"trusted_github_status_dashboard_url":n.dashboardUrl?"dashboard_url_not_api_inspectable":"github_status_only",githubState:n.state,vercelContext:n.context}}async function Lb(e){let r=e.observedAt??new Date().toISOString(),t=sp(e.statuses??[],{observedAt:r}),n=ms(e.statuses??[]);if(!n)return t;if(n.state==="success")return{...t,inspectSkipped:!0,inspectReason:n.dashboardUrl?"trusted_github_status_dashboard_url":"trusted_github_status"};if(!e.allowInspect)return{...t,inspectSkipped:!0,inspectReason:"api_lookup_disabled"};let{target:o,reason:s}=op(n.targetUrl);if(!o)return{...t,inspectSkipped:!0,inspectReason:s??"not_api_inspectable",summary:ll([t.summary??"",s??"skipped Vercel API lookup"])};let a=await(e.runInspect??ep)(o),l=new Date().toISOString();if(!a.ok&&a.error?.includes("VERCEL_TOKEN"))return{status:"unavailable",previewUrl:t.previewUrl,deploymentUrl:t.deploymentUrl,summary:"VERCEL_TOKEN not configured for API fallback",observedAt:l,inspectSkipped:!0,inspectReason:"vercel_token_missing",githubState:n.state,vercelContext:n.context};if(!a.ok)return{status:n.state==="pending"?"building":"error",previewUrl:t.previewUrl,deploymentUrl:o.startsWith("http")?o:t.deploymentUrl,summary:ll([`Vercel API lookup ${o} failed`,a.error??""]),observedAt:l,inspectSkipped:!1,inspectReason:null,githubState:n.state,vercelContext:n.context};let c=rp(a.readyState,n.state==="pending"),u=a.previewUrl??(o.startsWith("http")?o:t.previewUrl);return{status:c,previewUrl:u,deploymentUrl:u??t.deploymentUrl,summary:ll([`Vercel API ${o}=${a.readyState??"unknown"}`,c==="ready"?"preview ready":""]),observedAt:l,inspectSkipped:!1,inspectReason:null,githubState:n.state,vercelContext:n.context}}export{Dr as CODEX_DEFAULT_MODEL,Ci as DEFAULT_DISPATCH_LEASE_MS,za as DEFAULT_HARNESS_VERIFY_COMMANDS,ja as DEFAULT_HEAVY_VERIFICATION_MAX_CONCURRENT,ha as DEFAULT_MAX_ACTIONS_PER_SWEEP,Go as DEFAULT_NODE_MODULES_AGE_MS,ga as DEFAULT_RUN_DIRECTORIES_AGE_MS,fa as DEFAULT_TERMINAL_WORKTREES_AGE_MS,Oe as DEFAULT_WORKER_PROVIDER,Yo as DEFAULT_WORKTREES_AGE_MS,Hp as DEFAULT_WSL_CRASH_DUMP_CRITICAL_BYTES,Bp as DEFAULT_WSL_CRASH_DUMP_WARN_BYTES,Mp as DEFAULT_WSL_HOST_CRITICAL_FREE_BYTES,Jr as DEFAULT_WSL_HOST_MOUNT,Dp as DEFAULT_WSL_HOST_WARN_FREE_BYTES,st as EMBEDDED_INSTRUCTION_BUNDLE,Qm as EMBEDDED_INSTRUCTION_BUNDLE_VERSION,bp as FORBIDDEN_WORKER_ENV_KEYS,ua as HARNESS_BUILD_CACHE_RELATIVE_PATHS,is as HEAVY_VERIFICATION_TOKEN_REQUIRED,ki as HERMES_OPENAI_CODEX_DEFAULT_MODEL,fh as INSTRUCTION_BUNDLE_REFRESH_TTL_MS,Sl as MEMORY_COST_MANAGED_PACKAGES,vl as MEMORY_COST_PACKAGE_MIN_VERSIONS,Yn as MemoryCostPackageVersionGuardError,Cu as OPENAI_CODEX_PROVIDER,Xx as ORCHESTRATION_ACTION_KINDS,Qx as ORCHESTRATION_POLICY_DECISIONS,wu as ORCHESTRATION_POLICY_MODES,$n as PACKAGE_VERSION,dh as PINNED_INSTRUCTION_BUNDLE_PUBLIC_KEYS,Sn as RUN_METADATA_ACTIVE_SIGNAL_MS,Nh as TERMINAL_WORKER_ARCHIVE_AGE_MS,Yx as TRANSIENT_OPENAI_CODEX_ERROR_CLASSES,ai as WORKER_PERSONA_CATALOG,uE as applyProductionDatabaseToProcess,aa as archiveTerminalWorkerMetadata,_l as assertMemoryCostPackageVersionGuard,cs as assessAutoCompleteEligibility,Et as assessBuildAdmission,Xr as assessExitedWorkerSalvage,Hn as assessHeavyVerificationGate,od as assessOrphanWorktreeSafety,Wc as assessPrHandoffRequirement,Qr as assessWorkerLanding,Fl as assessWorkerLandingContract,ev as auditWorkerEnv,gt as autoCompleteWorker,Qc as autoCompleteWorkerCli,Wo as buildBoxResourceSnapshotFromGate,_f as buildCodexExecArgv,lh as buildDispatchTaskText,xu as buildForegroundHarnessIdempotencyKey,vf as buildHermesOpenAiCodexChatArgv,xl as buildMemoryCostPackageGuardInput,hc as buildOrchestrationProviderInventory,Pc as buildPrompt,wn as buildRunListRows,Gs as buildSystemdRunArgv,Qi as canonicalJsonStringify,Rr as canonicalWorkerDir,Ya as classifyHeavyShellCommand,im as classifyNpmAuditOutcome,kh as classifyOpenAiCodexError,ff as classifyOrchestrationRisk,rm as classifyRepoSearchMeta,Ws as classifyShellCommandOutcome,Tt as classifyVercelUrl,el as classifyWorkerHealth,Uo as cleanupWslCrashDumps,vc as codexProvider,Wu as collectFilesystemLiveRunKeys,Lb as collectVercelEvidence,mf as compareProviderCandidates,Jn as compareSemver,Ui as completeWorker,Rm as computeAttention,Mx as computeInstructionBundleVersion,M as computeWorkerStatus,os as countActiveHeavyVerificationSlots,$o as createRun,bo as defaultBoxId,Ux as deriveInstructionBundleKeyId,Zt as deriveRunStatus,Us as diagnoseRepoSearchFailure,Gr as discoverDefaultRepo,Rl as discoverDefaultRepoCandidates,Vn as discoverDefaultRepoForPersistence,ta as discoverProductionDbEnvFilePaths,Wr as dispatchRun,Yi as drainPlanOutbox,lc as enforceCursorWorkerProvider,El as enforceMemoryCostPackageGuardAtStartup,Su as ensureInstructionBundle,Oi as ensurePrReadyHandoff,Cv as evaluateMemoryCostPackageGuardAtStartup,_s as evaluateMemoryCostPackageVersionGuard,tE as evaluateOrchestrationPolicy,sp as evidenceFromGitHubVercelStatus,Ch as expandHomePath,qi as extractPlanOutboxFromTask,Uc as extractPrUrlFromText,Ml as extractSearchMeta,om as extractSearchMetaFromToolLine,Qa as formatAutoCompleteOutcomeNotice,bh as formatCronJobDeliveryFailure,LR as formatHarnessToolReadable,Ix as formatHeartbeatLine,fv as formatMemoryCostPackageGuardError,Fn as formatMonitorTickNotice,Rh as formatOpenAiCodexFailureNotice,Ji as formatPlanOutboxHandoffBlock,nm as formatRepoSearchGuidance,vn as formatResolvedDefaultRepo,Za as formatWorkerCompleteNotice,ls as formatWorkerStatusNotice,Ja as gateWorkerShellCommand,gC as getActiveInstructionBundle,fr as getActiveInstructionBundleSource,Nr as getActiveInstructionBundleVersion,qr as getHarnessPaths,rl as getMonitorStatus,at as getOrchestrationProviderCapability,li as getPersonaDefaultRoleLane,tf as getPersonaDispatchLane,oc as getWorkerPersonaCatalogEntry,kl as gitRepoRoot,ge as harnessRunsDir,ju as harnessStorageSnapshot,dr as harnessWorktreesDir,Rn as hasNestedRunsSegment,gr as hashPlanBody,bc as hermesCodexProvider,Ru as instructionBundleCachePath,rt as isActiveHarnessWorker,Xe as isClaudeFamilyProvider,Wb as isDashboardVercelUrl,Nx as isEngagementRequiredSkip,oe as isFinishedWorkerStatus,ml as isForbiddenWorkerEnvKey,Vu as isGeneratedHarnessPath,Tu as isHarnessRunMetadataPath,Ap as isHarnessWorktreeRepo,Ln as isHeavyVerificationGateSkipped,al as isInspectableVercelTarget,bC as isKnownWorkerPersonaSlug,Pp as isKynverMonorepoRoot,et as isLandingBlockedWorkerStatus,_u as isOrchestrationEnforceTasksEnabled,ad as isPipelineCleanupEnabled,Ds as isRgExcludeScopeTarget,yn as isSignedInstructionBundleShape,Ts as isSingleFileSearchTarget,nn as isSystemdRunAvailable,Dl as isTerminalHeartbeatPhase,np as isVercelStatusContext,Ps as isWslHost,WR as joinHarnessNotice,Kl as landingContractAttentionReason,Md as listActiveHeavyVerificationSlots,vp as listForbiddenWorkerEnvKeys,us as listMonitors,uc as listOrchestrationProviderCapabilities,kt as listOutboxItems,Ku as listRuns,Fu as listRunsCli,vu as loadInstructionBundleCache,R as loadUserConfig,Tb as main,Ha as mergeNodeOptionsForBuildCheck,tm as metaToNormalizedRgCommand,gf as normalizeCursorModelAlias,le as normalizeHarnessRoot,Ms as normalizeRepoSearchCommand,em as normalizeRgArgv,Le as observeRunnerDiskGate,ur as observeWslCrashDumps,Ol as observeWslHostDisk,zx as orchestrationAuditForWorkerJson,ko as parseArgs,kS as parseClaudeStream,Ar as parseHarnessStream,ce as parseHeartbeat,Zi as parseRawEd25519Key,Kp as parseWslCrashDumpFilename,sa as persistDefaultRepo,gu as persistExitedWorkerHandoffCapture,kn as persistPlan,ms as pickVercelStatusContext,Ir as postJson,PC as preferCursorExecutor,gi as preflightClaudeModel,ct as preflightCodexModel,hi as preflightCursorModel,mi as probeClaudeOAuthBinding,dc as probeCodexOAuthBinding,fi as probeCursorOAuthBinding,gc as probeHermesCliAdapter,Ro as probeHermesOpenAiCodexBinding,ZC as probeOrchestrationProviderBinding,wl as probeRepoPackageVersions,mc as providerCapableForRisk,$p as readKernelCorePattern,jt as readMemAvailableBytes,_h as readProductionDbKeysFromEnvFile,jp as readWslConfigCrashDumpSettings,ss as reclaimStaleHeavyVerificationSlots,ca as reconcileLocalOnlyMergedPrAttention,Hu as reconcileRunsCli,Cn as reconcileStaleWorkers,la as reconcileWorkerMetadata,ME as reconcileWorkerMetadataCli,nE as redactHarness,kr as redactProviderErrorText,Bn as releaseHeavyVerificationSlot,hE as remediateDefaultRepo,ia as repairMissingRunMetadata,fE as repairNestedRunsPath,V as resolveBaseUrl,vw as resolveBoxKindFromEnv,ii as resolveBundlePersona,dC as resolveCallbackSecret,J as resolveCallbackSecretWithMint,Tr as resolveCodexOrchestrationAdapter,yo as resolveConfiguredWorkerProvider,je as resolveDefaultRepo,oa as resolveDefaultRepoForPersistence,fu as resolveExitedWorkerFinalResult,fe as resolveHarnessRoot,Bh as resolveHarnessRunByName,$u as resolveHarnessRunCli,Un as resolveHeavyVerificationMaxConcurrent,ku as resolveInstructionBundlePublicKey,un as resolveInstructionText,yh as resolveOpenAiCodexRetryBudget,ea as resolveOrchestrationPolicyMode,yc as resolveOrchestrationRouting,it as resolvePolicyThreshold,xh as resolveProductionDatabaseUrl,Di as resolveRunTargetArg,op as resolveVercelInspectTarget,Iu as resolveWorkerJsonPath,Fe as resolveWorkerTargetArgs,Fp as resolveWslCrashDumpDir,Nl as resolveWslWindowsUsername,qa as runBoundedBuildCheck,ts as runDaemon,vt as runDirHasActiveRetentionSignals,xa as runHarnessCleanup,as as runHarnessVerifyCommands,Nt as runMonitorTick,id as runPipelineHarnessCleanup,Jc as runStatus,Fo as safeDatabaseUrlHint,vh as sanitizeOrchestrationAudit,bu as saveInstructionBundleCache,ue as saveUserConfig,Sp as scrubClaudeEnv,We as scrubWorkerEnv,pi as selectCheapestCapableProvider,Cl as semverAtLeast,nc as setActiveInstructionBundle,mu as shouldAutoCleanupWslCrashDumps,Pl as shouldEnforceMemoryCostPackageGuardCli,Zc as spawnCompletionSidecar,nl as spawnMonitorSidecar,Bi as spawnWorkerProcess,ru as startWorker,zc as stopWorker,Ll as summarizeEvent,sm as summarizeNpmAuditReport,cm as summarizeShellToolCallEvent,Vp as summarizeWslCrashDumpRecoverySteps,Up as summarizeWslRecoverySteps,_n as sweepRun,qc as tailWorker,ui as taskAllowsClaudeWorker,ze as terminalFinalResultFromHeartbeat,Pt as tryAcquireHeavyVerificationSlot,rc as tryResolveBaseUrl,ni as tryResolveCallbackSecretWithMint,il as usage,v_ as validateOwnedPaths,Vc as validateRepo,_o as validateRunId,S_ as validateTailLines,bg as validateWorkerName,ph as verifyInstructionBundleSignatureWithKey,yu as verifySignedInstructionBundle,Ga as waitForHeavyVerificationSlot,Uu as workerDirHasActiveRetentionSignals,vC as workerPersonaLandingSlugs,sc as workerPersonaReviewSlugs,Yc as workerStatus};
|