@witqq/agent-sdk 0.4.0 → 0.5.0

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/types.ts","../../src/errors.ts","../../src/base-agent.ts","../../src/utils/schema.ts","../../src/backends/claude.ts"],"names":[],"mappings":";;;AA0YO,SAAS,eAAe,OAAA,EAAiC;AAC9D,EAAA,IAAI,OAAO,OAAA,KAAY,QAAA,EAAU,OAAO,OAAA;AACxC,EAAA,OAAO,OAAA,CACJ,MAAA,CAAO,CAAC,CAAA,KAAmD,EAAE,IAAA,KAAS,MAAM,CAAA,CAC5E,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAE,IAAI,CAAA,CACjB,KAAK,IAAI,CAAA;AACd;;;AC/YO,IAAM,aAAA,GAAN,cAA4B,KAAA,CAAM;AAAA,EACvC,WAAA,CAAY,SAAiB,OAAA,EAAwB;AACnD,IAAA,KAAA,CAAM,SAAS,OAAO,CAAA;AACtB,IAAA,IAAA,CAAK,IAAA,GAAO,eAAA;AAAA,EACd;AACF,CAAA;AAGO,IAAM,eAAA,GAAN,cAA8B,aAAA,CAAc;AAAA,EACjD,WAAA,GAAc;AACZ,IAAA,KAAA,CAAM,0EAA0E,CAAA;AAChF,IAAA,IAAA,CAAK,IAAA,GAAO,iBAAA;AAAA,EACd;AACF,CAAA;AAGO,IAAM,aAAA,GAAN,cAA4B,aAAA,CAAc;AAAA,EAC/C,YAAY,MAAA,EAAgB;AAC1B,IAAA,KAAA,CAAM,CAAA,EAAG,MAAM,CAAA,sCAAA,CAAwC,CAAA;AACvD,IAAA,IAAA,CAAK,IAAA,GAAO,eAAA;AAAA,EACd;AACF,CAAA;AAuBO,IAAM,eAAA,GAAN,cAA8B,aAAA,CAAc;AAAA,EACjD,WAAA,CAAY,SAAiB,OAAA,EAAwB;AACnD,IAAA,KAAA,CAAM,SAAS,OAAO,CAAA;AACtB,IAAA,IAAA,CAAK,IAAA,GAAO,iBAAA;AAAA,EACd;AACF,CAAA;AAcO,IAAM,UAAA,GAAN,cAAyB,aAAA,CAAc;AAAA,EAC5C,WAAA,GAAc;AACZ,IAAA,KAAA,CAAM,wBAAwB,CAAA;AAC9B,IAAA,IAAA,CAAK,IAAA,GAAO,YAAA;AAAA,EACd;AACF,CAAA;;;ACrDO,IAAe,YAAf,MAA2C;AAAA,EACtC,KAAA,GAAoB,MAAA;AAAA,EACpB,eAAA,GAA0C,IAAA;AAAA,EACjC,MAAA;AAAA;AAAA,EAMnB,IAAI,SAAA,GAAgC;AAClC,IAAA,OAAO,MAAA;AAAA,EACT;AAAA,EAEA,YAAY,MAAA,EAAqB;AAC/B,IAAA,IAAA,CAAK,SAAS,MAAA,CAAO,MAAA,CAAO,EAAE,GAAG,QAAQ,CAAA;AAAA,EAC3C;AAAA;AAAA,EAIA,MAAM,GAAA,CACJ,MAAA,EACA,OAAA,EACsB;AACtB,IAAA,IAAA,CAAK,eAAA,EAAgB;AACrB,IAAA,IAAA,CAAK,aAAA,EAAc;AAEnB,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,qBAAA,CAAsB,OAAA,EAAS,MAAM,CAAA;AACrD,IAAA,IAAA,CAAK,KAAA,GAAQ,SAAA;AAEb,IAAA,IAAI;AACF,MAAA,MAAM,WAAsB,CAAC,EAAE,MAAM,MAAA,EAAQ,OAAA,EAAS,QAAQ,CAAA;AAC9D,MAAA,MAAM,SAAS,MAAM,IAAA,CAAK,WAAW,QAAA,EAAU,OAAA,EAAS,GAAG,MAAM,CAAA;AACjE,MAAA,IAAA,CAAK,qBAAqB,MAAM,CAAA;AAChC,MAAA,OAAO,MAAA;AAAA,IACT,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AACb,MAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,IACzB;AAAA,EACF;AAAA,EAEA,MAAM,cAAA,CACJ,QAAA,EACA,OAAA,EACsB;AACtB,IAAA,IAAA,CAAK,eAAA,EAAgB;AACrB,IAAA,IAAA,CAAK,aAAA,EAAc;AAEnB,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,qBAAA,CAAsB,OAAA,EAAS,MAAM,CAAA;AACrD,IAAA,IAAA,CAAK,KAAA,GAAQ,SAAA;AAEb,IAAA,IAAI;AACF,MAAA,MAAM,SAAS,MAAM,IAAA,CAAK,WAAW,QAAA,EAAU,OAAA,EAAS,GAAG,MAAM,CAAA;AACjE,MAAA,IAAA,CAAK,qBAAqB,MAAM,CAAA;AAChC,MAAA,OAAO,MAAA;AAAA,IACT,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AACb,MAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,IACzB;AAAA,EACF;AAAA,EAEA,MAAM,aAAA,CACJ,MAAA,EACA,MAAA,EACA,OAAA,EACyB;AACzB,IAAA,IAAA,CAAK,eAAA,EAAgB;AACrB,IAAA,IAAA,CAAK,aAAA,EAAc;AAEnB,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,qBAAA,CAAsB,OAAA,EAAS,MAAM,CAAA;AACrD,IAAA,IAAA,CAAK,KAAA,GAAQ,SAAA;AAEb,IAAA,IAAI;AACF,MAAA,MAAM,WAAsB,CAAC,EAAE,MAAM,MAAA,EAAQ,OAAA,EAAS,QAAQ,CAAA;AAC9D,MAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,oBAAA;AAAA,QACxB,QAAA;AAAA,QACA,MAAA;AAAA,QACA,OAAA;AAAA,QACA,EAAA,CAAG;AAAA,OACL;AACA,MAAA,IAAA,CAAK,qBAAqB,MAAM,CAAA;AAChC,MAAA,OAAO,MAAA;AAAA,IACT,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AACb,MAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,IACzB;AAAA,EACF;AAAA,EAEA,OAAO,MAAA,CACL,MAAA,EACA,OAAA,EAC2B;AAC3B,IAAA,IAAA,CAAK,eAAA,EAAgB;AACrB,IAAA,IAAA,CAAK,aAAA,EAAc;AAEnB,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,qBAAA,CAAsB,OAAA,EAAS,MAAM,CAAA;AACrD,IAAA,IAAA,CAAK,KAAA,GAAQ,WAAA;AAEb,IAAA,IAAI;AACF,MAAA,MAAM,WAAsB,CAAC,EAAE,MAAM,MAAA,EAAQ,OAAA,EAAS,QAAQ,CAAA;AAC9D,MAAA,MAAM,QAAA,GAAW,KAAK,YAAA,CAAa,IAAA,CAAK,cAAc,QAAA,EAAU,OAAA,EAAS,EAAA,CAAG,MAAM,CAAC,CAAA;AACnF,MAAA,OAAO,IAAA,CAAK,gBAAgB,QAAQ,CAAA;AAAA,IACtC,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AACb,MAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,IACzB;AAAA,EACF;AAAA,EAEA,OAAO,iBAAA,CACL,QAAA,EACA,OAAA,EAC2B;AAC3B,IAAA,IAAA,CAAK,eAAA,EAAgB;AACrB,IAAA,IAAA,CAAK,aAAA,EAAc;AAEnB,IAAA,MAAM,EAAA,GAAK,IAAA,CAAK,qBAAA,CAAsB,OAAA,EAAS,MAAM,CAAA;AACrD,IAAA,IAAA,CAAK,KAAA,GAAQ,WAAA;AAEb,IAAA,IAAI;AACF,MAAA,MAAM,QAAA,GAAW,KAAK,YAAA,CAAa,IAAA,CAAK,cAAc,QAAA,EAAU,OAAA,EAAS,EAAA,CAAG,MAAM,CAAC,CAAA;AACnF,MAAA,OAAO,IAAA,CAAK,gBAAgB,QAAQ,CAAA;AAAA,IACtC,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,KAAA,GAAQ,MAAA;AACb,MAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,IACzB;AAAA,EACF;AAAA,EAEA,KAAA,GAAc;AACZ,IAAA,IAAI,KAAK,eAAA,EAAiB;AACxB,MAAA,IAAA,CAAK,gBAAgB,KAAA,EAAM;AAAA,IAC7B;AAAA,EACF;AAAA,EAEA,QAAA,GAAuB;AACrB,IAAA,OAAO,IAAA,CAAK,KAAA;AAAA,EACd;AAAA,EAEA,SAAA,GAAmC;AACjC,IAAA,OAAO,IAAA,CAAK,MAAA;AAAA,EACd;AAAA;AAAA,EAGA,OAAA,GAAgB;AACd,IAAA,IAAA,CAAK,KAAA,EAAM;AACX,IAAA,IAAA,CAAK,KAAA,GAAQ,UAAA;AAAA,EACf;AAAA;AAAA;AAAA,EA6BQ,qBAAqB,MAAA,EAAoC;AAC/D,IAAA,IAAI,OAAO,KAAA,EAAO;AAChB,MAAA,MAAA,CAAO,KAAA,GAAQ;AAAA,QACb,GAAG,MAAA,CAAO,KAAA;AAAA,QACV,KAAA,EAAO,KAAK,MAAA,CAAO,KAAA;AAAA,QACnB,SAAS,IAAA,CAAK;AAAA,OAChB;AACA,MAAA,IAAA,CAAK,WAAA,CAAY,OAAO,KAAK,CAAA;AAAA,IAC/B;AAAA,EACF;AAAA;AAAA,EAGA,OAAe,aACb,MAAA,EAC2B;AAC3B,IAAA,WAAA,MAAiB,SAAS,MAAA,EAAQ;AAChC,MAAA,IAAI,KAAA,CAAM,SAAS,cAAA,EAAgB;AACjC,QAAA,MAAM,KAAA,GAAmB;AAAA,UACvB,cAAc,KAAA,CAAM,YAAA;AAAA,UACpB,kBAAkB,KAAA,CAAM,gBAAA;AAAA,UACxB,KAAA,EAAO,KAAK,MAAA,CAAO,KAAA;AAAA,UACnB,SAAS,IAAA,CAAK;AAAA,SAChB;AACA,QAAA,IAAA,CAAK,YAAY,KAAK,CAAA;AACtB,QAAA,MAAM,EAAE,IAAA,EAAM,cAAA,EAAgB,GAAG,KAAA,EAAM;AAAA,MACzC,CAAA,MAAO;AACL,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAAA;AAAA,EAGQ,YAAY,KAAA,EAAwB;AAC1C,IAAA,IAAI,CAAC,IAAA,CAAK,MAAA,CAAO,OAAA,EAAS;AAC1B,IAAA,IAAI;AACF,MAAA,IAAA,CAAK,MAAA,CAAO,QAAQ,KAAK,CAAA;AAAA,IAC3B,SAAS,CAAA,EAAG;AACV,MAAA,OAAA,CAAQ,IAAA;AAAA,QACN,qCAAA;AAAA,QACA,CAAA,YAAa,KAAA,GAAQ,CAAA,CAAE,OAAA,GAAU,OAAO,CAAC;AAAA,OAC3C;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,OAAe,gBACb,MAAA,EAC2B;AAC3B,IAAA,MAAM,QAAA,GAAW,KAAK,MAAA,CAAO,iBAAA;AAC7B,IAAA,IAAI,CAAC,QAAA,IAAY,QAAA,IAAY,CAAA,EAAG;AAC9B,MAAA,OAAO,MAAA;AACP,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,MAAA,CAAO,aAAa,CAAA,EAAE;AAC9C,IAAA,IAAI,YAAA,GAA2D,IAAA;AAC/D,IAAA,IAAI,gBAAA,GAAwC,IAAA;AAE5C,IAAA,MAAM,KAAA,GAAQ,YAAY,MAAM;AAC9B,MAAA,IAAI,gBAAA,EAAkB;AACpB,QAAA,MAAM,OAAA,GAAU,gBAAA;AAChB,QAAA,gBAAA,GAAmB,IAAA;AACnB,QAAA,OAAA,EAAQ;AAAA,MACV;AAAA,IACF,GAAG,QAAQ,CAAA;AAEX,IAAA,IAAI;AACF,MAAA,OAAO,IAAA,EAAM;AACX,QAAA,IAAI,CAAC,YAAA,EAAc;AACjB,UAAA,YAAA,GAAe,SAAS,IAAA,EAAK;AAAA,QAC/B;AAEA,QAAA,MAAM,gBAAA,GAAmB,IAAI,OAAA,CAAc,CAAC,OAAA,KAAY;AACtD,UAAA,gBAAA,GAAmB,OAAA;AAAA,QACrB,CAAC,CAAA;AAED,QAAA,MAAM,YAAY,YAAA,CAAa,IAAA;AAAA,UAC7B,CAAC,CAAA,MAAO,EAAE,IAAA,EAAM,OAAA,EAAkB,QAAQ,CAAA,EAAE;AAAA,SAC9C;AACA,QAAA,MAAM,gBAAgB,gBAAA,CAAiB,IAAA;AAAA,UACrC,OAAO,EAAE,IAAA,EAAM,WAAA,EAAqB;AAAA,SACtC;AAEA,QAAA,MAAM,SAAS,MAAM,OAAA,CAAQ,KAAK,CAAC,SAAA,EAAW,aAAa,CAAC,CAAA;AAE5D,QAAA,IAAI,MAAA,CAAO,SAAS,WAAA,EAAa;AAC/B,UAAA,MAAM,EAAE,MAAM,WAAA,EAAY;AAAA,QAC5B,CAAA,MAAO;AACL,UAAA,YAAA,GAAe,IAAA;AACf,UAAA,gBAAA,GAAmB,IAAA;AACnB,UAAA,IAAI,MAAA,CAAO,OAAO,IAAA,EAAM;AACxB,UAAA,MAAM,OAAO,MAAA,CAAO,KAAA;AAAA,QACtB;AAAA,MACF;AAAA,IACF,CAAA,SAAE;AACA,MAAA,aAAA,CAAc,KAAK,CAAA;AACnB,MAAA,gBAAA,GAAmB,IAAA;AAAA,IACrB;AAAA,EACF;AAAA;AAAA,EAIU,eAAA,GAAwB;AAChC,IAAA,IAAI,IAAA,CAAK,KAAA,KAAU,SAAA,IAAa,IAAA,CAAK,UAAU,WAAA,EAAa;AAC1D,MAAA,MAAM,IAAI,eAAA,EAAgB;AAAA,IAC5B;AAAA,EACF;AAAA,EAEU,aAAA,GAAsB;AAC9B,IAAA,IAAI,IAAA,CAAK,UAAU,UAAA,EAAY;AAC7B,MAAA,MAAM,IAAI,cAAc,OAAO,CAAA;AAAA,IACjC;AAAA,EACF;AAAA;AAAA,EAGU,WAAW,MAAA,EAA2B;AAC9C,IAAA,IAAI,OAAO,OAAA,EAAS;AAClB,MAAA,MAAM,IAAI,UAAA,EAAW;AAAA,IACvB;AAAA,EACF;AAAA;AAAA,EAIQ,sBAAsB,cAAA,EAA+C;AAC3E,IAAA,MAAM,EAAA,GAAK,IAAI,eAAA,EAAgB;AAC/B,IAAA,IAAA,CAAK,eAAA,GAAkB,EAAA;AAEvB,IAAA,IAAI,cAAA,EAAgB;AAClB,MAAA,IAAI,eAAe,OAAA,EAAS;AAC1B,QAAA,EAAA,CAAG,KAAA,EAAM;AAAA,MACX,CAAA,MAAO;AACL,QAAA,cAAA,CAAe,gBAAA,CAAiB,OAAA,EAAS,MAAM,EAAA,CAAG,OAAM,EAAG;AAAA,UACzD,IAAA,EAAM;AAAA,SACP,CAAA;AAAA,MACH;AAAA,IACF;AAEA,IAAA,OAAO,EAAA;AAAA,EACT;AACF,CAAA;;;ACvUO,SAAS,gBAAgB,MAAA,EAA4C;AAC1E,EAAA,MAAM,SAAA,GAAY,MAAA;AAGlB,EAAA,IAAI,cAAA,IAAkB,MAAA,IAAU,OAAO,SAAA,CAAU,iBAAiB,UAAA,EAAY;AAC5E,IAAA,OAAQ,UAAU,YAAA,EAA+C;AAAA,EACnE;AAGA,EAAA,IAAI,YAAA,IAAgB,MAAA,IAAU,OAAO,SAAA,CAAU,eAAe,UAAA,EAAY;AACxE,IAAA,OAAQ,UAAU,UAAA,EAA6C;AAAA,EACjE;AAGA,EAAA,OAAO,qBAAqB,MAAM,CAAA;AACpC;AAGA,SAAS,qBAAqB,MAAA,EAA4C;AACxE,EAAA,MAAM,MAAO,MAAA,CAAoD,IAAA;AACjE,EAAA,MAAM,WAAW,GAAA,CAAI,QAAA;AAErB,EAAA,QAAQ,QAAA;AAAU,IAChB,KAAK,WAAA;AACH,MAAA,OAAO,EAAE,MAAM,QAAA,EAAS;AAAA,IAC1B,KAAK,WAAA;AACH,MAAA,OAAO,EAAE,MAAM,QAAA,EAAS;AAAA,IAC1B,KAAK,YAAA;AACH,MAAA,OAAO,EAAE,MAAM,SAAA,EAAU;AAAA,IAC3B,KAAK,SAAA;AACH,MAAA,OAAO,EAAE,MAAM,MAAA,EAAO;AAAA,IACxB,KAAK,UAAA;AACH,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,OAAA;AAAA,QACN,KAAA,EAAO,oBAAA,CAAqB,GAAA,CAAI,IAAiB;AAAA,OACnD;AAAA,IACF,KAAK,WAAA,EAAa;AAChB,MAAA,MAAM,QAAS,MAAA,CAA2D,KAAA;AAC1E,MAAA,MAAM,aAAsC,EAAC;AAC7C,MAAA,MAAM,WAAqB,EAAC;AAE5B,MAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,KAAK,CAAA,EAAG;AAChD,QAAA,MAAM,WAAY,KAAA,CAAmD,IAAA;AACrE,QAAA,IAAI,QAAA,CAAS,aAAa,aAAA,EAAe;AACvC,UAAA,UAAA,CAAW,GAAG,CAAA,GAAI,oBAAA,CAAqB,QAAA,CAAS,SAAsB,CAAA;AAAA,QACxE,CAAA,MAAO;AACL,UAAA,UAAA,CAAW,GAAG,CAAA,GAAI,oBAAA,CAAqB,KAAK,CAAA;AAC5C,UAAA,QAAA,CAAS,KAAK,GAAG,CAAA;AAAA,QACnB;AAAA,MACF;AAEA,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,QAAA;AAAA,QACN,UAAA;AAAA,QACA,GAAI,QAAA,CAAS,MAAA,GAAS,IAAI,EAAE,QAAA,KAAa;AAAC,OAC5C;AAAA,IACF;AAAA,IACA,KAAK,aAAA;AACH,MAAA,OAAO,oBAAA,CAAqB,IAAI,SAAsB,CAAA;AAAA,IACxD,KAAK,SAAA;AACH,MAAA,OAAO,EAAE,IAAA,EAAM,QAAA,EAAU,IAAA,EAAM,IAAI,MAAA,EAAmB;AAAA,IACxD;AACE,MAAA,OAAO,EAAC;AAAA;AAEd;;;ACyGA,IAAI,SAAA,GAA8B,IAAA;AAElC,eAAe,OAAA,GAA8B;AAC3C,EAAA,IAAI,WAAW,OAAO,SAAA;AACtB,EAAA,IAAI;AAEF,IAAA,SAAA,GAAa,MAAM,OAAO,gCAAgC,CAAA;AAC1D,IAAA,OAAO,SAAA;AAAA,EACT,CAAA,CAAA,MAAQ;AACN,IAAA,MAAM,IAAI,eAAA;AAAA,MACR;AAAA,KACF;AAAA,EACF;AACF;AAGO,SAAS,WAAW,IAAA,EAA8B;AACvD,EAAA,SAAA,GAAY,IAAA;AACd;AAGO,SAAS,SAAA,GAAkB;AAChC,EAAA,SAAA,GAAY,IAAA;AACd;AAIA,IAAM,oBAAA,GAAuB,qCAAA;AAC7B,IAAM,qBAAA,GAAwB,YAAA;AAC9B,IAAM,oBAAA,GAAuB,kBAAA;AAI7B,SAAS,cAAA,CACP,GAAA,EACA,KAAA,EACA,iBAAA,EAC4C;AAC5C,EAAA,IAAI,KAAA,CAAM,MAAA,KAAW,CAAA,EAAG,OAAO,MAAA;AAE/B,EAAA,MAAM,WAAW,KAAA,CAAM,GAAA;AAAA,IAAI,CAAC,SAC1B,GAAA,CAAI,IAAA;AAAA,MACF,IAAA,CAAK,IAAA;AAAA,MACL,KAAK,WAAA,IAAe,EAAA;AAAA,MACpB,eAAA,CAAgB,KAAK,UAAU,CAAA;AAAA,MAC/B,OAAO,IAAA,KAAkC;AACvC,QAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,OAAA,CAAQ,IAAI,CAAA;AAEtC,QAAA,IAAI,iBAAA,EAAmB;AACrB,UAAA,iBAAA,CAAkB,GAAA,CAAI,IAAA,CAAK,IAAA,EAAM,MAAmB,CAAA;AAAA,QACtD;AACA,QAAA,OAAO;AAAA,UACL,OAAA,EAAS;AAAA,YACP;AAAA,cACE,IAAA,EAAM,MAAA;AAAA,cACN,MAAM,OAAO,MAAA,KAAW,WAAW,MAAA,GAAS,IAAA,CAAK,UAAU,MAAM;AAAA;AACnE;AACF,SACF;AAAA,MACF;AAAA;AACF,GACF;AAEA,EAAA,OAAO,IAAI,kBAAA,CAAmB;AAAA,IAC5B,IAAA,EAAM,iBAAA;AAAA,IACN,OAAA,EAAS,OAAA;AAAA,IACT,KAAA,EAAO;AAAA,GACR,CAAA;AACH;AAKA,SAAS,mBAAmB,KAAA,EAAqD;AAC/E,EAAA,QAAQ,KAAA;AAAO,IACb,KAAK,MAAA;AACH,MAAA,OAAO,SAAA;AAAA,IACT,KAAK,SAAA;AACH,MAAA,OAAO,SAAA;AAAA,IACT,KAAK,SAAA;AACH,MAAA,OAAO,iBAAA;AAAA,IACT,KAAK,QAAA;AACH,MAAA,OAAO,cAAA;AAAA;AAEb;AAGA,SAAS,mBAAmB,IAAA,EAAoD;AAC9E,EAAA,QAAQ,IAAA;AAAM,IACZ,KAAK,SAAA;AAAA,IACL,KAAK,QAAA;AACH,MAAA,OAAO,SAAA;AAAA,IACT,KAAK,iBAAA;AAAA,IACL,KAAK,eAAA;AACH,MAAA,OAAO,SAAA;AAAA,IACT,KAAK,cAAA;AACH,MAAA,OAAO,QAAA;AAAA;AAEb;AAGA,SAAS,sBACP,WAAA,EAC6B;AAC7B,EAAA,IAAI,CAAC,WAAA,IAAe,WAAA,CAAY,MAAA,KAAW,GAAG,OAAO,MAAA;AAErD,EAAA,OAAO,kBAAA,CAAmB,WAAA,CAAY,CAAC,CAAA,CAAE,WAAW,CAAA;AACtD;AAEA,SAAS,gBACP,MAAA,EAC2B;AAC3B,EAAA,MAAM,YAAA,GAAe,OAAO,UAAA,EAAY,YAAA;AACxC,EAAA,IAAI,CAAC,cAAc,OAAO,MAAA;AAE1B,EAAA,MAAM,kBAAkB,MAAA,CAAO,eAAA;AAE/B,EAAA,OAAO,OACL,QAAA,EACA,KAAA,EACA,OAAA,KACiC;AAEjC,IAAA,IAAI,eAAA,IAAmB,MAAM,eAAA,CAAgB,UAAA,CAAW,QAAQ,CAAA,EAAG;AACjE,MAAA,OAAO;AAAA,QACL,QAAA,EAAU,OAAA;AAAA,QACV,WAAW,OAAA,CAAQ;AAAA,OACrB;AAAA,IACF;AAEA,IAAA,MAAM,cAAA,GAA2C;AAAA,MAC/C,QAAA;AAAA,MACA,QAAA,EAAU,KAAA;AAAA,MACV,cAAA,EAAgB,qBAAA,CAAsB,OAAA,CAAQ,WAAW,CAAA;AAAA,MACzD,aAAA,EAAe,EAAE,QAAA,EAAU,KAAA,EAAO,GAAG,OAAA;AAAQ,KAC/C;AAEA,IAAA,MAAM,WAA+B,MAAM,YAAA;AAAA,MACzC,cAAA;AAAA,MACA,OAAA,CAAQ;AAAA,KACV;AAEA,IAAA,IAAI,SAAS,OAAA,EAAS;AAEpB,MAAA,IAAI,eAAA,IAAmB,SAAS,KAAA,EAAO;AACrC,QAAA,MAAM,eAAA,CAAgB,OAAA,CAAQ,QAAA,EAAU,QAAA,CAAS,KAAK,CAAA;AAAA,MACxD;AAEA,MAAA,MAAM,MAAA,GAA8B;AAAA,QAClC,QAAA,EAAU,OAAA;AAAA,QACV,WAAW,OAAA,CAAQ;AAAA,OACrB;AACA,MAAA,IAAI,SAAS,aAAA,EAAe;AAC1B,QAAC,MAAA,CAAsD,eACrD,QAAA,CAAS,aAAA;AAAA,MACb;AAEA,MAAA,IAAI,SAAS,KAAA,IAAS,QAAA,CAAS,KAAA,KAAU,MAAA,IAAU,QAAQ,WAAA,EAAa;AACtE,QAAC,OAA0D,kBAAA,GACzD,OAAA,CAAQ,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,MAAO;AAAA,UAC9B,GAAG,CAAA;AAAA,UACH,WAAA,EAAa,kBAAA,CAAmB,QAAA,CAAS,KAAM;AAAA,SACjD,CAAE,CAAA;AAAA,MACN;AACA,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,OAAO;AAAA,MACL,QAAA,EAAU,MAAA;AAAA,MACV,OAAA,EAAS,SAAS,MAAA,IAAU,mBAAA;AAAA,MAC5B,WAAW,OAAA,CAAQ;AAAA,KACrB;AAAA,EACF,CAAA;AACF;AAIA,SAAS,eACP,UAAA,EACoD;AACpD,EAAA,IAAI,YAAA,GAAe,CAAA;AACnB,EAAA,IAAI,gBAAA,GAAmB,CAAA;AACvB,EAAA,KAAA,MAAW,KAAK,MAAA,CAAO,MAAA,CAAO,UAAA,IAAc,EAAE,CAAA,EAAG;AAC/C,IAAA,YAAA,IAAgB,EAAE,WAAA,IAAe,CAAA;AACjC,IAAA,gBAAA,IAAoB,EAAE,YAAA,IAAgB,CAAA;AAAA,EACxC;AACA,EAAA,OAAO,EAAE,cAAc,gBAAA,EAAiB;AAC1C;AAYA,IAAM,wBAAN,MAA4B;AAAA,EAClB,MAAA,uBAAa,GAAA,EAAsB;AAAA,EAE3C,UAAA,CAAW,YAAoB,QAAA,EAAwB;AACrD,IAAA,IAAI,CAAC,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,QAAQ,CAAA,EAAG;AAC9B,MAAA,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,QAAA,EAAU,EAAE,CAAA;AAAA,IAC9B;AACA,IAAA,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,QAAQ,CAAA,CAAG,KAAK,UAAU,CAAA;AAAA,EAC5C;AAAA;AAAA,EAGA,eAAe,QAAA,EAA0B;AACvC,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,QAAQ,CAAA;AACtC,IAAA,IAAI,CAAC,KAAA,IAAS,KAAA,CAAM,MAAA,KAAW,GAAG,OAAO,EAAA;AACzC,IAAA,OAAO,MAAM,CAAC,CAAA;AAAA,EAChB;AAAA;AAAA,EAGA,kBAAkB,QAAA,EAA0B;AAC1C,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,QAAQ,CAAA;AACtC,IAAA,IAAI,CAAC,KAAA,IAAS,KAAA,CAAM,MAAA,KAAW,GAAG,OAAO,EAAA;AACzC,IAAA,OAAO,MAAM,KAAA,EAAM;AAAA,EACrB;AAAA,EAEA,KAAA,GAAc;AACZ,IAAA,IAAA,CAAK,OAAO,KAAA,EAAM;AAAA,EACpB;AACF,CAAA;AAEA,SAAS,aAAA,CAAc,GAAA,EAAiB,oBAAA,EAAoC,eAAA,EAA2E;AACrJ,EAAA,QAAQ,IAAI,IAAA;AAAM,IAChB,KAAK,WAAA,EAAa;AAEhB,MAAA,MAAM,cAAc,GAAA,CAAI,OAAA;AASxB,MAAA,IAAI,CAAC,WAAA,EAAa,OAAA,EAAS,OAAO,IAAA;AAElC,MAAA,MAAM,SAAuB,EAAC;AAG9B,MAAA,MAAM,YAAY,WAAA,CAAY,OAAA,CAC3B,OAAO,CAAC,CAAA,KAAM,EAAE,IAAA,KAAS,MAAA,IAAU,EAAE,IAAI,CAAA,CACzC,IAAI,CAAC,CAAA,KAAM,EAAE,IAAK,CAAA,CAClB,KAAK,EAAE,CAAA;AAEV,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,MAAA,CAAO,KAAK,EAAE,IAAA,EAAM,YAAA,EAAc,IAAA,EAAM,WAAW,CAAA;AAAA,MACrD;AAGA,MAAA,KAAA,MAAW,KAAA,IAAS,YAAY,OAAA,EAAS;AACvC,QAAA,IAAI,KAAA,CAAM,SAAS,UAAA,EAAY;AAC7B,UAAA,MAAM,UAAA,GAAa,MAAA,CAAO,KAAA,CAAM,EAAA,IAAM,EAAE,CAAA;AACxC,UAAA,MAAM,QAAA,GAAW,MAAM,IAAA,IAAQ,SAAA;AAC/B,UAAA,IAAI,eAAA,EAAiB;AACnB,YAAA,eAAA,CAAgB,UAAA,CAAW,YAAY,QAAQ,CAAA;AAAA,UACjD;AACA,UAAA,MAAA,CAAO,IAAA,CAAK;AAAA,YACV,IAAA,EAAM,iBAAA;AAAA,YACN,UAAA;AAAA,YACA,QAAA;AAAA,YACA,IAAA,EAAO,KAAA,CAAM,KAAA,IAAuB;AAAC,WACtC,CAAA;AAAA,QACH;AAAA,MACF;AAEA,MAAA,OAAO,MAAA,CAAO,MAAA,GAAS,CAAA,GAAI,MAAA,GAAS,IAAA;AAAA,IACtC;AAAA,IAEA,KAAK,MAAA,EAAQ;AAEX,MAAA,MAAM,aAAa,GAAA,CAAI,eAAA;AAEvB,MAAA,IAAI,eAAe,MAAA,EAAW;AAG5B,QAAA,OAAO,IAAA;AAAA,MACT;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,IAEA,KAAK,kBAAA,EAAoB;AAEvB,MAAA,MAAM,UAAU,GAAA,CAAI,OAAA;AACpB,MAAA,MAAM,QAAA,GAAY,IAAI,SAAA,IAAoC,SAAA;AAE1D,MAAA,MAAM,eAAe,GAAA,CAAI,sBAAA;AACzB,MAAA,IAAI,UAAA,GAAa,EAAA;AACjB,MAAA,IAAI,YAAA,IAAgB,YAAA,CAAa,MAAA,GAAS,CAAA,EAAG;AAC3C,QAAA,UAAA,GAAa,aAAa,CAAC,CAAA;AAE3B,QAAA,IAAI,eAAA,EAAiB,eAAA,CAAgB,iBAAA,CAAkB,QAAQ,CAAA;AAAA,MACjE,WAAW,eAAA,EAAiB;AAC1B,QAAA,UAAA,GAAa,eAAA,CAAgB,kBAAkB,QAAQ,CAAA;AAAA,MACzD;AAEA,MAAA,IAAI,OAAA,EAAS;AACX,QAAA,OAAO;AAAA,UACL,IAAA,EAAM,eAAA;AAAA,UACN,UAAA;AAAA,UACA,QAAA;AAAA,UACA,MAAA,EAAQ;AAAA,SACV;AAAA,MACF;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,IAEA,KAAK,cAAA,EAAgB;AAEnB,MAAA,MAAM,QAAQ,GAAA,CAAI,KAAA;AAMlB,MAAA,IAAI,CAAC,OAAO,OAAO,IAAA;AAEnB,MAAA,IACE,KAAA,CAAM,SAAS,qBAAA,IACf,KAAA,CAAM,OAAO,IAAA,KAAS,YAAA,IACtB,KAAA,CAAM,KAAA,CAAM,IAAA,EACZ;AACA,QAAA,OAAO,EAAE,IAAA,EAAM,YAAA,EAAc,IAAA,EAAM,KAAA,CAAM,MAAM,IAAA,EAAK;AAAA,MACtD;AAEA,MAAA,IAAI,MAAM,IAAA,KAAS,qBAAA,IAAyB,KAAA,CAAM,aAAA,EAAe,SAAS,UAAA,EAAY;AACpF,QAAA,IAAI,oBAAA,IAAwB,KAAA,CAAM,KAAA,KAAU,MAAA,EAAW;AACrD,UAAA,oBAAA,CAAqB,GAAA,CAAI,MAAM,KAAK,CAAA;AAAA,QACtC;AACA,QAAA,OAAO,EAAE,MAAM,gBAAA,EAAiB;AAAA,MAClC;AAEA,MAAA,IAAI,KAAA,CAAM,IAAA,KAAS,oBAAA,IAAwB,KAAA,CAAM,KAAA,KAAU,UAAa,oBAAA,EAAsB,GAAA,CAAI,KAAA,CAAM,KAAK,CAAA,EAAG;AAC9G,QAAA,oBAAA,CAAqB,MAAA,CAAO,MAAM,KAAK,CAAA;AACvC,QAAA,OAAO,EAAE,MAAM,cAAA,EAAe;AAAA,MAChC;AAEA,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,IAEA,KAAK,eAAA,EAAiB;AACpB,MAAA,MAAM,WAAW,GAAA,CAAI,SAAA;AACrB,MAAA,IAAI,CAAC,UAAU,OAAO,IAAA;AACtB,MAAA,MAAM,UAAA,GAAa,eAAA,EAAiB,cAAA,CAAe,QAAQ,CAAA,IAAK,EAAA;AAChE,MAAA,OAAO,EAAE,IAAA,EAAM,iBAAA,EAAmB,YAAY,QAAA,EAAU,IAAA,EAAM,EAAC,EAAE;AAAA,IACnE;AAAA,IAEA,KAAK,QAAA,EAAU;AACb,MAAA,IAAI,GAAA,CAAI,YAAY,SAAA,EAAW;AAC7B,QAAA,MAAM,CAAA,GAAI,GAAA;AACV,QAAA,OAAO;AAAA,UACL,IAAA,EAAM,cAAA;AAAA,UACN,GAAG,cAAA,CAAe,CAAA,CAAE,UAAU;AAAA,SAChC;AAAA,MACF;AACA,MAAA,IAAI,IAAI,QAAA,EAAU;AAChB,QAAA,MAAM,CAAA,GAAI,GAAA;AACV,QAAA,OAAO;AAAA,UACL,IAAA,EAAM,OAAA;AAAA,UACN,KAAA,EAAO,CAAA,CAAE,MAAA,EAAQ,IAAA,CAAK,IAAI,CAAA,IAAK,eAAA;AAAA,UAC/B,WAAA,EAAa;AAAA,SACf;AAAA,MACF;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,IAEA;AACE,MAAA,OAAO,IAAA;AAAA;AAEb;AAIA,IAAM,WAAA,GAAN,cAA0B,SAAA,CAAU;AAAA,EACf,WAAA,GAAc,QAAA;AAAA,EAChB,OAAA;AAAA,EACA,KAAA;AAAA,EACA,UAAA;AAAA,EACA,YAAA;AAAA,EACT,UAAA;AAAA,EAER,WAAA,CAAY,QAAqB,OAAA,EAA+B;AAC9D,IAAA,KAAA,CAAM,MAAM,CAAA;AACZ,IAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AACf,IAAA,IAAA,CAAK,QAAQ,MAAA,CAAO,KAAA;AACpB,IAAA,IAAA,CAAK,UAAA,GAAa,gBAAgB,MAAM,CAAA;AACxC,IAAA,IAAA,CAAK,YAAA,GAAe,OAAO,WAAA,KAAgB,YAAA;AAG3C,IAAA,IAAI,MAAA,CAAO,YAAY,SAAA,EAAW;AAChC,MAAA,OAAA,CAAQ,IAAA;AAAA,QACN;AAAA,OAEF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,IAAa,SAAA,GAAgC;AAC3C,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA,EAGQ,sBAAA,GAA+B;AACrC,IAAA,IAAA,CAAK,UAAA,GAAa,MAAA;AAAA,EACpB;AAAA,EAEQ,kBAAkB,MAAA,EAAiC;AACzD,IAAA,MAAM,EAAA,GAAK,IAAI,eAAA,EAAgB;AAE/B,IAAA,MAAA,CAAO,gBAAA,CAAiB,SAAS,MAAM,EAAA,CAAG,OAAM,EAAG,EAAE,IAAA,EAAM,IAAA,EAAM,CAAA;AAEjE,IAAA,MAAM,IAAA,GAAmB;AAAA,MACvB,eAAA,EAAiB,EAAA;AAAA,MACjB,KAAA,EAAO,KAAK,MAAA,CAAO,KAAA;AAAA,MACnB,QAAA,EAAU,KAAK,OAAA,CAAQ,QAAA;AAAA,MACvB,GAAA,EAAK,KAAK,OAAA,CAAQ,gBAAA;AAAA,MAClB,0BAAA,EAA4B,KAAK,OAAA,CAAQ,OAAA;AAAA,MACzC,gBAAgB,IAAA,CAAK,YAAA;AAAA,MACrB,sBAAA,EAAwB,IAAA;AAAA,MACxB,YAAY,IAAA,CAAK;AAAA,KACnB;AAGA,IAAA,IAAI,IAAA,CAAK,YAAA,IAAgB,IAAA,CAAK,UAAA,EAAY;AACxC,MAAA,IAAA,CAAK,SAAS,IAAA,CAAK,UAAA;AAAA,IACrB;AAEA,IAAA,IAAI,IAAA,CAAK,OAAO,YAAA,EAAc;AAC5B,MAAA,IAAA,CAAK,YAAA,GAAe,KAAK,MAAA,CAAO,YAAA;AAAA,IAClC;AAEA,IAAA,IAAI,IAAA,CAAK,QAAQ,UAAA,EAAY;AAC3B,MAAA,IAAA,CAAK,GAAA,GAAM,EAAE,GAAG,OAAA,CAAQ,KAAK,uBAAA,EAAyB,IAAA,CAAK,QAAQ,UAAA,EAAW;AAAA,IAChF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,MAAc,cAAA,CACZ,IAAA,EACA,iBAAA,EACqB;AACrB,IAAA,IAAI,IAAA,CAAK,KAAA,CAAM,MAAA,KAAW,CAAA,EAAG,OAAO,IAAA;AAEpC,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,EAAQ;AAC1B,IAAA,MAAM,SAAA,GAAY,cAAA,CAAe,GAAA,EAAK,IAAA,CAAK,OAAO,iBAAiB,CAAA;AACnE,IAAA,IAAI,SAAA,EAAW;AACb,MAAA,IAAA,CAAK,UAAA,GAAa;AAAA,QAChB,iBAAA,EAAmB;AAAA,OACrB;AAAA,IACF;AACA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA,EAIA,MAAgB,UAAA,CACd,QAAA,EACA,QAAA,EACA,MAAA,EACsB;AACtB,IAAA,IAAA,CAAK,WAAW,MAAM,CAAA;AAEtB,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,EAAQ;AAC1B,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,YAAA,IAAgB,IAAA,CAAK,UAAA,KAAe,MAAA;AAC5D,IAAA,MAAM,SAAS,UAAA,GACX,qBAAA,CAAsB,QAAQ,CAAA,GAC9B,sBAAsB,QAAQ,CAAA;AAClC,IAAA,IAAI,IAAA,GAAO,IAAA,CAAK,iBAAA,CAAkB,MAAM,CAAA;AACxC,IAAA,MAAM,iBAAA,uBAAwB,GAAA,EAAuB;AACrD,IAAA,IAAA,GAAO,MAAM,IAAA,CAAK,cAAA,CAAe,IAAA,EAAM,iBAAiB,CAAA;AAExD,IAAA,MAAM,IAAI,GAAA,CAAI,KAAA,CAAM,EAAE,MAAA,EAAQ,OAAA,EAAS,MAAM,CAAA;AAC7C,IAAA,MAAM,YAAsC,EAAC;AAC7C,IAAA,IAAI,MAAA,GAAwB,IAAA;AAC5B,IAAA,IAAI,KAAA;AAEJ,IAAA,IAAI;AACF,MAAA,WAAA,MAAiB,OAAO,CAAA,EAAG;AAEzB,QAAA,IAAI,GAAA,CAAI,SAAS,WAAA,EAAa;AAC5B,UAAA,MAAM,cAAc,GAAA,CAAI,OAAA;AASxB,UAAA,IAAI,aAAa,OAAA,EAAS;AACxB,YAAA,KAAA,MAAW,KAAA,IAAS,YAAY,OAAA,EAAS;AACvC,cAAA,IAAI,KAAA,CAAM,SAAS,UAAA,EAAY;AAC7B,gBAAA,MAAM,QAAA,GAAW,MAAM,IAAA,IAAQ,SAAA;AAC/B,gBAAA,SAAA,CAAU,IAAA,CAAK;AAAA,kBACb,QAAA;AAAA,kBACA,IAAA,EAAO,KAAA,CAAM,KAAA,IAAuB,EAAC;AAAA,kBACrC,MAAA,EAAQ,iBAAA,CAAkB,GAAA,CAAI,QAAQ,CAAA,IAAK,IAAA;AAAA,kBAC3C,QAAA,EAAU;AAAA,iBACX,CAAA;AAAA,cACH;AAAA,YACF;AAAA,UACF;AAAA,QACF;AAGA,QAAA,IAAI,GAAA,CAAI,IAAA,KAAS,kBAAA,IAAsB,GAAA,CAAI,SAAS,QAAA,EAAU;AAC5D,UAAA,KAAA,MAAW,MAAM,SAAA,EAAW;AAC1B,YAAA,IAAI,EAAA,CAAG,WAAW,IAAA,EAAM;AACtB,cAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,GAAA,CAAI,EAAA,CAAG,QAAQ,CAAA;AAClD,cAAA,IAAI,QAAA,KAAa,KAAA,CAAA,EAAW,EAAA,CAAG,MAAA,GAAS,QAAA;AAAA,YAC1C;AAAA,UACF;AAAA,QACF;AAGA,QAAA,IAAI,GAAA,CAAI,SAAS,QAAA,EAAU;AACzB,UAAA,IAAI,GAAA,CAAI,YAAY,SAAA,EAAW;AAC7B,YAAA,MAAM,CAAA,GAAI,GAAA;AACV,YAAA,MAAA,GAAS,CAAA,CAAE,MAAA;AACX,YAAA,KAAA,GAAQ,cAAA,CAAe,EAAE,UAAU,CAAA;AACnC,YAAA,IAAI,IAAA,CAAK,YAAA,IAAgB,CAAA,CAAE,UAAA,EAAY;AACrC,cAAA,IAAA,CAAK,aAAa,CAAA,CAAE,UAAA;AAAA,YACtB;AAAA,UACF,CAAA,MAAA,IAAW,IAAI,QAAA,EAAU;AACvB,YAAA,MAAM,CAAA,GAAI,GAAA;AACV,YAAA,MAAM,IAAI,KAAA;AAAA,cACR,wBAAwB,CAAA,CAAE,MAAA,EAAQ,IAAA,CAAK,IAAI,KAAK,eAAe,CAAA;AAAA,aACjE;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,IACF,SAAS,CAAA,EAAG;AACV,MAAA,IAAI,IAAA,CAAK,YAAA,EAAc,IAAA,CAAK,sBAAA,EAAuB;AACnD,MAAA,IAAI,MAAA,CAAO,OAAA,EAAS,MAAM,IAAI,UAAA,EAAW;AACzC,MAAA,MAAM,CAAA;AAAA,IACR;AAEA,IAAA,OAAO;AAAA,MACL,MAAA;AAAA,MACA,gBAAA,EAAkB,MAAA;AAAA,MAClB,SAAA;AAAA,MACA,QAAA,EAAU;AAAA,QACR,GAAG,QAAA;AAAA,QACH,GAAI,MAAA,KAAW,IAAA,GACX,CAAC,EAAE,IAAA,EAAM,WAAA,EAAsB,OAAA,EAAS,MAAA,EAAQ,CAAA,GAChD;AAAC,OACP;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA,EAIA,MAAgB,oBAAA,CACd,QAAA,EACA,MAAA,EACA,UACA,MAAA,EACyB;AACzB,IAAA,IAAA,CAAK,WAAW,MAAM,CAAA;AAEtB,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,EAAQ;AAC1B,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,YAAA,IAAgB,IAAA,CAAK,UAAA,KAAe,MAAA;AAC5D,IAAA,MAAM,SAAS,UAAA,GACX,qBAAA,CAAsB,QAAQ,CAAA,GAC9B,sBAAsB,QAAQ,CAAA;AAClC,IAAA,IAAI,IAAA,GAAO,IAAA,CAAK,iBAAA,CAAkB,MAAM,CAAA;AACxC,IAAA,IAAA,GAAO,MAAM,IAAA,CAAK,cAAA,CAAe,IAAI,CAAA;AAGrC,IAAA,MAAM,UAAA,GAAa,eAAA,CAAgB,MAAA,CAAO,MAAM,CAAA;AAChD,IAAA,IAAA,CAAK,YAAA,GAAe;AAAA,MAClB,IAAA,EAAM,aAAA;AAAA,MACN,MAAA,EAAQ;AAAA,KACV;AAEA,IAAA,MAAM,IAAI,GAAA,CAAI,KAAA,CAAM,EAAE,MAAA,EAAQ,OAAA,EAAS,MAAM,CAAA;AAC7C,IAAA,MAAM,YAAsC,EAAC;AAC7C,IAAA,IAAI,MAAA,GAAwB,IAAA;AAC5B,IAAA,IAAI,gBAAA;AACJ,IAAA,IAAI,KAAA;AAEJ,IAAA,IAAI;AACF,MAAA,WAAA,MAAiB,OAAO,CAAA,EAAG;AACzB,QAAA,IAAI,GAAA,CAAI,IAAA,KAAS,QAAA,IAAY,GAAA,CAAI,YAAY,SAAA,EAAW;AACtD,UAAA,MAAM,CAAA,GAAI,GAAA;AACV,UAAA,MAAA,GAAS,CAAA,CAAE,MAAA;AAGX,UAAA,IAAI,CAAA,CAAE,sBAAsB,KAAA,CAAA,EAAW;AACrC,YAAA,IAAI;AACF,cAAA,gBAAA,GAAmB,MAAA,CAAO,MAAA,CAAO,KAAA,CAAM,CAAA,CAAE,iBAAiB,CAAA;AAAA,YAC5D,CAAA,CAAA,MAAQ;AAEN,cAAA,IAAI;AACF,gBAAA,gBAAA,GAAmB,OAAO,MAAA,CAAO,KAAA,CAAM,KAAK,KAAA,CAAM,CAAA,CAAE,MAAM,CAAC,CAAA;AAAA,cAC7D,CAAA,CAAA,MAAQ;AAAA,cAER;AAAA,YACF;AAAA,UACF,CAAA,MAAA,IAAW,EAAE,MAAA,EAAQ;AAEnB,YAAA,IAAI;AACF,cAAA,MAAM,SAAA,GAAY,CAAA,CAAE,MAAA,CAAO,KAAA,CAAM,8BAA8B,CAAA;AAC/D,cAAA,MAAM,GAAA,GAAM,YAAY,SAAA,CAAU,CAAC,EAAG,IAAA,EAAK,GAAI,CAAA,CAAE,MAAA,CAAO,IAAA,EAAK;AAC7D,cAAA,gBAAA,GAAmB,OAAO,MAAA,CAAO,KAAA,CAAM,IAAA,CAAK,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,YACxD,CAAA,CAAA,MAAQ;AAAA,YAER;AAAA,UACF;AAEA,UAAA,KAAA,GAAQ,cAAA,CAAe,EAAE,UAAU,CAAA;AACnC,UAAA,IAAI,IAAA,CAAK,YAAA,IAAgB,CAAA,CAAE,UAAA,EAAY;AACrC,YAAA,IAAA,CAAK,aAAa,CAAA,CAAE,UAAA;AAAA,UACtB;AAAA,QACF,CAAA,MAAA,IAAW,GAAA,CAAI,IAAA,KAAS,QAAA,IAAY,IAAI,QAAA,EAAU;AAChD,UAAA,MAAM,CAAA,GAAI,GAAA;AACV,UAAA,MAAM,IAAI,KAAA;AAAA,YACR,wBAAwB,CAAA,CAAE,MAAA,EAAQ,IAAA,CAAK,IAAI,KAAK,eAAe,CAAA;AAAA,WACjE;AAAA,QACF;AAAA,MACF;AAAA,IACF,SAAS,CAAA,EAAG;AACV,MAAA,IAAI,IAAA,CAAK,YAAA,EAAc,IAAA,CAAK,sBAAA,EAAuB;AACnD,MAAA,IAAI,MAAA,CAAO,OAAA,EAAS,MAAM,IAAI,UAAA,EAAW;AACzC,MAAA,MAAM,CAAA;AAAA,IACR;AAEA,IAAA,OAAO;AAAA,MACL,MAAA;AAAA,MACA,gBAAA;AAAA,MACA,SAAA;AAAA,MACA,QAAA,EAAU;AAAA,QACR,GAAG,QAAA;AAAA,QACH,GAAI,MAAA,KAAW,IAAA,GACX,CAAC,EAAE,IAAA,EAAM,WAAA,EAAsB,OAAA,EAAS,MAAA,EAAQ,CAAA,GAChD;AAAC,OACP;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA,EAIA,OAAiB,aAAA,CACf,QAAA,EACA,QAAA,EACA,MAAA,EAC2B;AAC3B,IAAA,IAAA,CAAK,WAAW,MAAM,CAAA;AAEtB,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,EAAQ;AAC1B,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,YAAA,IAAgB,IAAA,CAAK,UAAA,KAAe,MAAA;AAC5D,IAAA,MAAM,SAAS,UAAA,GACX,qBAAA,CAAsB,QAAQ,CAAA,GAC9B,sBAAsB,QAAQ,CAAA;AAClC,IAAA,IAAI,IAAA,GAAO,IAAA,CAAK,iBAAA,CAAkB,MAAM,CAAA;AACxC,IAAA,IAAA,GAAO,MAAM,IAAA,CAAK,cAAA,CAAe,IAAI,CAAA;AAErC,IAAA,MAAM,IAAI,GAAA,CAAI,KAAA,CAAM,EAAE,MAAA,EAAQ,OAAA,EAAS,MAAM,CAAA;AAC7C,IAAA,MAAM,oBAAA,uBAA2B,GAAA,EAAY;AAC7C,IAAA,MAAM,eAAA,GAAkB,IAAI,qBAAA,EAAsB;AAElD,IAAA,IAAI;AACF,MAAA,WAAA,MAAiB,OAAO,CAAA,EAAG;AACzB,QAAA,IAAI,MAAA,CAAO,OAAA,EAAS,MAAM,IAAI,UAAA,EAAW;AAEzC,QAAA,MAAM,KAAA,GAAQ,aAAA,CAAc,GAAA,EAAK,oBAAA,EAAsB,eAAe,CAAA;AACtE,QAAA,IAAI,KAAA,EAAO;AACT,UAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACxB,YAAA,KAAA,MAAW,CAAA,IAAK,OAAO,MAAM,CAAA;AAAA,UAC/B,CAAA,MAAO;AACL,YAAA,MAAM,KAAA;AAAA,UACR;AAAA,QACF;AAGA,QAAA,IAAI,GAAA,CAAI,IAAA,KAAS,QAAA,IAAY,GAAA,CAAI,YAAY,SAAA,EAAW;AACtD,UAAA,MAAM,CAAA,GAAI,GAAA;AACV,UAAA,IAAI,IAAA,CAAK,YAAA,IAAgB,CAAA,CAAE,UAAA,EAAY;AACrC,YAAA,IAAA,CAAK,aAAa,CAAA,CAAE,UAAA;AAAA,UACtB;AACA,UAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,WAAA,EAAa,EAAE,MAAA,EAAO;AAAA,QAC9C;AAAA,MACF;AAAA,IACF,SAAS,CAAA,EAAG;AACV,MAAA,IAAI,IAAA,CAAK,YAAA,EAAc,IAAA,CAAK,sBAAA,EAAuB;AACnD,MAAA,IAAI,MAAA,CAAO,OAAA,EAAS,MAAM,IAAI,UAAA,EAAW;AACzC,MAAA,MAAM,CAAA;AAAA,IACR;AAAA,EACF;AAAA,EAES,OAAA,GAAgB;AACvB,IAAA,IAAA,CAAK,UAAA,GAAa,MAAA;AAClB,IAAA,KAAA,CAAM,OAAA,EAAQ;AAAA,EAChB;AACF,CAAA;AAIA,SAAS,sBAAsB,QAAA,EAA6B;AAC1D,EAAA,KAAA,IAAS,IAAI,QAAA,CAAS,MAAA,GAAS,CAAA,EAAG,CAAA,IAAK,GAAG,CAAA,EAAA,EAAK;AAC7C,IAAA,MAAM,GAAA,GAAM,SAAS,CAAC,CAAA;AACtB,IAAA,IAAI,GAAA,CAAI,SAAS,MAAA,EAAQ;AACvB,MAAA,OAAO,cAAA,CAAe,IAAI,OAAO,CAAA;AAAA,IACnC;AAAA,EACF;AACA,EAAA,OAAO,EAAA;AACT;AAGA,SAAS,sBAAsB,QAAA,EAA6B;AAC1D,EAAA,IAAI,QAAA,CAAS,UAAU,CAAA,EAAG;AACxB,IAAA,OAAO,sBAAsB,QAAQ,CAAA;AAAA,EACvC;AAEA,EAAA,MAAM,OAAA,GAAU,SAAS,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,CAAE,GAAA,CAAI,CAAC,GAAA,KAAQ;AACjD,IAAA,MAAM,OAAO,GAAA,CAAI,OAAA,GAAU,cAAA,CAAe,GAAA,CAAI,OAAO,CAAA,GAAI,EAAA;AACzD,IAAA,OAAO,IAAI,IAAA,KAAS,MAAA,GAAS,SAAS,IAAI,CAAA,CAAA,GAAK,cAAc,IAAI,CAAA,CAAA;AAAA,EACnE,CAAC,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAEZ,EAAA,MAAM,UAAA,GAAa,sBAAsB,QAAQ,CAAA;AAEjD,EAAA,OAAO,CAAA;AAAA,EAA0B,OAAO;;AAAA,MAAA,EAAa,UAAU,CAAA,CAAA;AACjE;AAEA,IAAM,qBAAN,MAAkD;AAAA,EACvC,IAAA,GAAO,QAAA;AAAA,EACR,QAAA,GAAW,KAAA;AAAA,EACF,OAAA;AAAA,EACT,YAAA,GAAmC,IAAA;AAAA,EAE3C,YAAY,OAAA,EAA+B;AACzC,IAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AAAA,EACjB;AAAA,EAEA,YAAY,MAAA,EAA6B;AACvC,IAAA,IAAI,IAAA,CAAK,QAAA,EAAU,MAAM,IAAI,cAAc,oBAAoB,CAAA;AAC/D,IAAA,OAAO,IAAI,WAAA,CAAY,MAAA,EAAQ,IAAA,CAAK,OAAO,CAAA;AAAA,EAC7C;AAAA,EAEA,MAAM,UAAA,GAAmC;AACvC,IAAA,IAAI,IAAA,CAAK,QAAA,EAAU,MAAM,IAAI,cAAc,oBAAoB,CAAA;AAC/D,IAAA,IAAI,IAAA,CAAK,YAAA,EAAc,OAAO,IAAA,CAAK,YAAA;AAEnC,IAAA,MAAM,KAAA,GAAQ,KAAK,OAAA,CAAQ,UAAA;AAC3B,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,OAAO,EAAC;AAAA,IACV;AAEA,IAAA,MAAM,GAAA,GAAM,MAAM,UAAA,CAAW,KAAA;AAAA,MAC3B,GAAG,oBAAoB,CAAA,UAAA,CAAA;AAAA,MACvB;AAAA,QACE,OAAA,EAAS;AAAA,UACP,aAAA,EAAe,UAAU,KAAK,CAAA,CAAA;AAAA,UAC9B,mBAAA,EAAqB,qBAAA;AAAA,UACrB,gBAAA,EAAkB;AAAA;AACpB;AACF,KACF;AAEA,IAAA,IAAI,CAAC,IAAI,EAAA,EAAI;AACX,MAAA,OAAO,EAAC;AAAA,IACV;AAEA,IAAA,MAAM,IAAA,GAAQ,MAAM,GAAA,CAAI,IAAA,EAAK;AAI7B,IAAA,IAAI,CAAC,IAAA,CAAK,IAAA,IAAQ,IAAA,CAAK,IAAA,CAAK,WAAW,CAAA,EAAG;AACxC,MAAA,OAAO,EAAC;AAAA,IACV;AAEA,IAAA,IAAA,CAAK,YAAA,GAAe,IAAA,CAAK,IAAA,CAAK,GAAA,CAAI,CAAC,CAAA,MAAO;AAAA,MACxC,IAAI,CAAA,CAAE,EAAA;AAAA,MACN,MAAM,CAAA,CAAE,YAAA;AAAA,MACR,QAAA,EAAU;AAAA,KACZ,CAAE,CAAA;AACF,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA,EAEA,MAAM,QAAA,GAAsC;AAC1C,IAAA,IAAI,IAAA,CAAK,QAAA,EAAU,MAAM,IAAI,cAAc,oBAAoB,CAAA;AAE/D,IAAA,MAAM,SAAmB,EAAC;AAC1B,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,EAAQ;AAAA,IAChB,SAAS,CAAA,EAAG;AACV,MAAA,MAAA,CAAO,IAAA;AAAA,QACL,CAAA,YAAa,KAAA,GAAQ,CAAA,CAAE,OAAA,GAAU,OAAO,CAAC;AAAA,OAC3C;AACA,MAAA,OAAO,EAAE,KAAA,EAAO,KAAA,EAAO,MAAA,EAAO;AAAA,IAChC;AAGA,IAAA,IAAI;AACF,MAAA,MAAM,GAAA,GAAM,MAAM,OAAA,EAAQ;AAC1B,MAAA,MAAM,CAAA,GAAI,IAAI,KAAA,CAAM;AAAA,QAClB,MAAA,EAAQ,WAAA;AAAA,QACR,OAAA,EAAS;AAAA,UACP,KAAA,EAAO,0BAAA;AAAA,UACP,0BAAA,EAA4B,KAAK,OAAA,CAAQ,OAAA;AAAA,UACzC,GAAA,EAAK,KAAK,OAAA,CAAQ,gBAAA;AAAA,UAClB,cAAA,EAAgB,KAAA;AAAA,UAChB,QAAA,EAAU,CAAA;AAAA,UACV,cAAA,EAAgB;AAAA;AAClB,OACD,CAAA;AAED,MAAA,MAAM,KAAA,GAAQ,MAAM,CAAA,CAAE,IAAA,EAAK;AAC3B,MAAA,CAAA,CAAE,KAAA,EAAM;AACR,MAAA,IAAI,MAAM,IAAA,EAAM;AACd,QAAA,MAAA,CAAO,KAAK,kEAA6D,CAAA;AAAA,MAC3E;AAAA,IACF,SAAS,CAAA,EAAG;AACV,MAAA,MAAA,CAAO,IAAA;AAAA,QACL,oCAAoC,CAAA,YAAa,KAAA,GAAQ,EAAE,OAAA,GAAU,MAAA,CAAO,CAAC,CAAC,CAAA;AAAA,OAChF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,KAAA,EAAO,MAAA,CAAO,MAAA,KAAW,GAAG,MAAA,EAAO;AAAA,EAC9C;AAAA,EAEA,MAAM,OAAA,GAAyB;AAC7B,IAAA,IAAI,KAAK,QAAA,EAAU;AACnB,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA;AAChB,IAAA,IAAA,CAAK,YAAA,GAAe,IAAA;AAAA,EACtB;AACF,CAAA;AAKO,SAAS,oBACd,OAAA,EACe;AACf,EAAA,OAAO,IAAI,mBAAmB,OAAO,CAAA;AACvC","file":"claude.cjs","sourcesContent":["import type { z } from \"zod\";\nimport type { IPermissionStore } from \"./permission-store.js\";\n\n// ─── JSON Value ────────────────────────────────────────────────\n\n/** JSON-serializable value used for tool arguments and results */\nexport type JSONValue =\n | string\n | number\n | boolean\n | null\n | JSONValue[]\n | { [key: string]: JSONValue };\n\n// ─── Message Content ───────────────────────────────────────────\n\n/** Message content — plain string or array of text/image parts */\nexport type MessageContent = string | Array<ContentPart>;\n\n/** Individual content part within a multi-part message */\nexport type ContentPart =\n | { type: \"text\"; text: string }\n | { type: \"image\"; data: string; mimeType: string };\n\n// ─── Tool System (B1: Declaration/Definition split) ────────────\n\n/** What the LLM sees — name, description, schema. Passed to all backends. */\nexport interface ToolDeclaration<TParams = unknown> {\n name: string;\n description: string;\n parameters: z.ZodType<TParams>;\n needsApproval?: boolean;\n metadata?: {\n category?: string;\n icon?: string;\n tags?: string[];\n };\n}\n\n/** Full tool with execute function. Required for API-based backends.\n * CLI backends extract declaration; execute map held internally. */\nexport interface ToolDefinition<TParams = unknown>\n extends ToolDeclaration<TParams> {\n execute: (params: TParams) => Promise<JSONValue> | JSONValue;\n}\n\n// ─── Tool Calls / Results ──────────────────────────────────────\n\n/** A tool call made by the LLM during execution */\nexport interface ToolCall {\n id: string;\n name: string;\n args: JSONValue;\n}\n\n/** Result of executing a tool call */\nexport interface ToolResult {\n toolCallId: string;\n name: string;\n result: JSONValue;\n isError?: boolean;\n}\n\n// ─── Messages (Discriminated Union) ────────────────────────────\n\n/** Conversation message — discriminated union on `role` */\nexport type Message =\n | { role: \"user\"; content: MessageContent }\n | { role: \"assistant\"; content: MessageContent; toolCalls?: ToolCall[] }\n | { role: \"tool\"; content?: string; toolResults: ToolResult[] }\n | { role: \"system\"; content: string };\n\n// ─── Permission System (v3.1 with scopes) ──────────────────────\n\n/** Scope for \"remember this decision\" */\nexport type PermissionScope = \"once\" | \"session\" | \"project\" | \"always\";\n\n/** What the permission callback receives */\nexport interface PermissionRequest {\n toolName: string;\n toolArgs: Record<string, unknown>;\n /** SDK-suggested scope (from Claude CLI's suggestions) */\n suggestedScope?: PermissionScope;\n /** Original SDK permission request (for pass-through) */\n rawSDKRequest?: unknown;\n}\n\n/** What the permission callback returns */\nexport interface PermissionDecision {\n allowed: boolean;\n /** How long to remember this decision */\n scope?: PermissionScope;\n /** Modified tool arguments (tool args may be altered by user) */\n modifiedInput?: Record<string, unknown>;\n /** Denial reason (if denied) */\n reason?: string;\n}\n\n/** Permission callback signature */\nexport type PermissionCallback = (\n request: PermissionRequest,\n signal: AbortSignal,\n) => Promise<PermissionDecision>;\n\n// ─── User Input (Ask User) ────────────────────────────────────\n\n/** Request for user input — separate from permissions */\nexport interface UserInputRequest {\n question: string;\n choices?: string[];\n /** Whether to allow freeform text input (default: true) */\n allowFreeform?: boolean;\n}\n\n/** Response from user to an input request */\nexport interface UserInputResponse {\n answer: string;\n /** true if user typed a custom answer instead of selecting a choice */\n wasFreeform: boolean;\n /** Index of selected choice (if choice was selected) */\n selectedChoiceIndex?: number;\n}\n\n// ─── Supervisor Hooks ──────────────────────────────────────────\n\n/** Hooks for supervisor/UI to intercept agent actions */\nexport interface SupervisorHooks {\n onPermission?: PermissionCallback;\n onAskUser?: (\n request: UserInputRequest,\n signal: AbortSignal,\n ) => Promise<UserInputResponse>;\n}\n\n// ─── Structured Output ─────────────────────────────────────────\n\n/** Configuration for typed structured output from LLM */\nexport interface StructuredOutputConfig<T = unknown> {\n schema: z.ZodType<T>;\n name?: string;\n description?: string;\n}\n\n// ─── Usage Data ────────────────────────────────────────────────\n\n/** Usage data from LLM execution — tokens consumed plus optional metadata */\nexport interface UsageData {\n promptTokens: number;\n completionTokens: number;\n model?: string;\n backend?: string;\n}\n\n// ─── Agent Events (Streaming) ──────────────────────────────────\n\n/** Events emitted during streaming agent execution */\nexport type AgentEvent =\n | { type: \"text_delta\"; text: string }\n | { type: \"thinking_delta\"; text: string }\n | { type: \"tool_call_start\"; toolCallId: string; toolName: string; args: JSONValue }\n | { type: \"tool_call_end\"; toolCallId: string; toolName: string; result: JSONValue }\n | { type: \"permission_request\"; request: PermissionRequest }\n | {\n type: \"permission_response\";\n toolName: string;\n decision: PermissionDecision;\n }\n | { type: \"ask_user\"; request: UserInputRequest }\n | { type: \"ask_user_response\"; answer: string }\n | { type: \"thinking_start\" }\n | { type: \"thinking_end\" }\n | {\n type: \"usage_update\";\n promptTokens: number;\n completionTokens: number;\n model?: string;\n backend?: string;\n }\n | { type: \"heartbeat\" }\n | { type: \"error\"; error: string; recoverable: boolean }\n | { type: \"done\"; finalOutput: string | null; structuredOutput?: unknown };\n\n// ─── Run Options ───────────────────────────────────────────────\n\n/** Options passed to agent.run() / agent.stream() */\nexport interface RunOptions {\n /** AbortSignal for cancellation */\n signal?: AbortSignal;\n /** Arbitrary context passed to the agent run */\n context?: Record<string, unknown>;\n}\n\n// ─── Agent Configuration ───────────────────────────────────────\n\n/** LLM model parameters */\nexport interface ModelParams {\n temperature?: number;\n maxTokens?: number;\n topP?: number;\n stopSequences?: string[];\n}\n\n/** Timeout configuration for agent operations */\nexport interface TimeoutConfig {\n /** Max time for entire agent run (ms) */\n total?: number;\n /** Max time for a single tool execution (ms) */\n perTool?: number;\n /** Max time for a single LLM request (ms) */\n perLLMRequest?: number;\n}\n\n/** Error handling strategy configuration */\nexport interface ErrorHandlingConfig {\n /** What to do when a tool throws */\n onToolError?: \"fail\" | \"continue\" | \"ask-llm\";\n /** Retry config for transient LLM failures */\n retryLLM?: { maxAttempts: number; backoffMs: number };\n /** Global error callback for monitoring */\n onError?: (\n error: Error,\n context: { phase: \"tool\" | \"llm\" | \"permission\" | \"ask-user\" },\n ) => void;\n}\n\n/** Configuration for creating an agent */\nexport interface AgentConfig {\n model?: string;\n modelParams?: ModelParams;\n systemPrompt: string;\n tools: ToolDefinition[];\n supervisor?: SupervisorHooks;\n maxTurns?: number;\n timeout?: TimeoutConfig;\n errorHandling?: ErrorHandlingConfig;\n /** Pluggable store for persisting permission scope decisions across runs */\n permissionStore?: IPermissionStore;\n /** How to apply systemPrompt: \"append\" adds to backend default, \"replace\" overrides it.\n * Default: \"append\". Currently used by the Copilot backend. */\n systemMessageMode?: \"append\" | \"replace\";\n /** Filter for backend built-in tools (e.g. [\"web_search\", \"web_fetch\"] for Copilot).\n * When set, only listed built-in tools are available. Backend-specific. */\n availableTools?: string[];\n /** Callback invoked with usage data after run completion or during streaming.\n * Fire-and-forget: errors are logged but not propagated. */\n onUsage?: (usage: UsageData) => void;\n /** Interval in milliseconds for emitting heartbeat events during streaming.\n * When set, heartbeat events are emitted to keep the stream alive during\n * long tool executions. Default: off (no heartbeats). */\n heartbeatInterval?: number;\n /** Session reuse mode for CLI backends (Copilot, Claude).\n * \"per-call\" (default): creates a fresh CLI session for each run/stream call.\n * \"persistent\": reuses the same CLI session across calls, preserving conversation\n * history natively in the CLI backend. Session is destroyed on agent dispose(). */\n sessionMode?: \"per-call\" | \"persistent\";\n}\n\n// ─── Agent Result (Generic) ────────────────────────────────────\n\n/** Result of an agent run, generic over structured output type T */\nexport interface AgentResult<T = void> {\n output: string | null;\n structuredOutput: T extends void ? undefined : T;\n toolCalls: Array<{\n toolName: string;\n args: JSONValue;\n result: JSONValue;\n approved: boolean;\n }>;\n messages: Message[];\n usage?: UsageData;\n}\n\n// ─── Agent State ───────────────────────────────────────────────\n\n/** Agent lifecycle state */\nexport type AgentState = \"idle\" | \"running\" | \"streaming\" | \"disposed\";\n\n// ─── Agent Interface ───────────────────────────────────────────\n\n/** Core agent interface — run prompts, stream events, manage lifecycle */\nexport interface IAgent {\n /** The CLI session ID when using persistent session mode. Undefined in per-call mode\n * or before the first call. Can be stored externally for session resume. */\n readonly sessionId: string | undefined;\n /** Run a single prompt and return the result. Wraps prompt in a user message. */\n run(prompt: MessageContent, options?: RunOptions): Promise<AgentResult>;\n /** Run with full conversation history. Messages are passed directly to the backend. */\n runWithContext(\n messages: Message[],\n options?: RunOptions,\n ): Promise<AgentResult>;\n /** Run with structured output validated against a Zod schema. */\n runStructured<T>(\n prompt: MessageContent,\n schema: StructuredOutputConfig<T>,\n options?: RunOptions,\n ): Promise<AgentResult<T>>;\n /** Stream events for a single prompt. Wraps prompt in a user message. */\n stream(\n prompt: MessageContent,\n options?: RunOptions,\n ): AsyncIterable<AgentEvent>;\n /** Stream events with full conversation history. Messages are passed directly to the backend. */\n streamWithContext(\n messages: Message[],\n options?: RunOptions,\n ): AsyncIterable<AgentEvent>;\n /** Abort the current operation. No-op if not running. */\n abort(): void;\n /** Get current agent lifecycle state. */\n getState(): AgentState;\n /** Get frozen agent configuration. */\n getConfig(): Readonly<AgentConfig>;\n /** Release resources. After dispose(), agent must not be used. */\n dispose(): void;\n}\n\n// ─── Service Interface ─────────────────────────────────────────\n\n/** Model metadata returned by listModels() */\nexport interface ModelInfo {\n id: string;\n name?: string;\n provider?: string;\n}\n\n/** Result of backend validation check */\nexport interface ValidationResult {\n valid: boolean;\n errors: string[];\n}\n\n/** Backend service interface — creates agents, lists models, validates config */\nexport interface IAgentService {\n readonly name: string;\n createAgent(config: AgentConfig): IAgent;\n listModels(): Promise<ModelInfo[]>;\n validate(): Promise<ValidationResult>;\n dispose(): Promise<void>;\n}\n\n// ─── Backend Options ───────────────────────────────────────────\n\n/** Options for Copilot CLI backend */\nexport interface CopilotBackendOptions {\n cliPath?: string;\n workingDirectory?: string;\n githubToken?: string;\n useLoggedInUser?: boolean;\n /** Extra CLI arguments passed to the Copilot subprocess (e.g. [\"--allow-all\"]) */\n cliArgs?: string[];\n /** Timeout in milliseconds for sendAndWait() calls. When undefined, uses copilot-sdk default (60s). */\n timeout?: number;\n}\n\n/** Options for Claude CLI backend */\nexport interface ClaudeBackendOptions {\n cliPath?: string;\n workingDirectory?: string;\n maxTurns?: number;\n /** OAuth token for Claude authentication (set as CLAUDE_CODE_OAUTH_TOKEN env var) */\n oauthToken?: string;\n}\n\n/** Options for Vercel AI SDK backend */\nexport interface VercelAIBackendOptions {\n apiKey: string;\n provider?: string;\n baseUrl?: string;\n}\n\n// ─── Type Guards ───────────────────────────────────────────────\n\n/** Type guard: checks if a ToolDeclaration has an execute function (i.e., is a ToolDefinition) */\nexport function isToolDefinition(\n tool: ToolDeclaration,\n): tool is ToolDefinition {\n return \"execute\" in tool && typeof (tool as ToolDefinition).execute === \"function\";\n}\n\n/** Type guard: checks if MessageContent is plain string */\nexport function isTextContent(content: MessageContent): content is string {\n return typeof content === \"string\";\n}\n\n/** Type guard: checks if MessageContent is multi-part array */\nexport function isMultiPartContent(\n content: MessageContent,\n): content is ContentPart[] {\n return Array.isArray(content);\n}\n\n/** Extract text from MessageContent regardless of format */\nexport function getTextContent(content: MessageContent): string {\n if (typeof content === \"string\") return content;\n return content\n .filter((p): p is Extract<ContentPart, { type: \"text\" }> => p.type === \"text\")\n .map((p) => p.text)\n .join(\"\\n\");\n}\n","/** Base error class for agent-sdk */\nexport class AgentSDKError extends Error {\n constructor(message: string, options?: ErrorOptions) {\n super(message, options);\n this.name = \"AgentSDKError\";\n }\n}\n\n/** Thrown when agent.run() is called while already running (M8 re-entrancy guard) */\nexport class ReentrancyError extends AgentSDKError {\n constructor() {\n super(\"Agent is already running. Await the current run before starting another.\");\n this.name = \"ReentrancyError\";\n }\n}\n\n/** Thrown when an operation is attempted on a disposed agent/service */\nexport class DisposedError extends AgentSDKError {\n constructor(entity: string) {\n super(`${entity} has been disposed and cannot be used.`);\n this.name = \"DisposedError\";\n }\n}\n\n/** Thrown when a backend is not found in the registry */\nexport class BackendNotFoundError extends AgentSDKError {\n constructor(backend: string) {\n super(\n `Unknown backend: \"${backend}\". ` +\n `Built-in: copilot, claude, vercel-ai. ` +\n `Custom: use registerBackend() first.`,\n );\n this.name = \"BackendNotFoundError\";\n }\n}\n\n/** Thrown when a backend is already registered */\nexport class BackendAlreadyRegisteredError extends AgentSDKError {\n constructor(backend: string) {\n super(`Backend \"${backend}\" is already registered. Use a different name or unregister first.`);\n this.name = \"BackendAlreadyRegisteredError\";\n }\n}\n\n/** Thrown when subprocess management fails */\nexport class SubprocessError extends AgentSDKError {\n constructor(message: string, options?: ErrorOptions) {\n super(message, options);\n this.name = \"SubprocessError\";\n }\n}\n\n/** Thrown when a required peer dependency is not installed */\nexport class DependencyError extends AgentSDKError {\n public readonly packageName: string;\n\n constructor(packageName: string) {\n super(`${packageName} is not installed. Install it: npm install ${packageName}`);\n this.name = \"DependencyError\";\n this.packageName = packageName;\n }\n}\n\n/** Thrown when an agent run is aborted */\nexport class AbortError extends AgentSDKError {\n constructor() {\n super(\"Agent run was aborted.\");\n this.name = \"AbortError\";\n }\n}\n\n/** Thrown when a tool execution fails */\nexport class ToolExecutionError extends AgentSDKError {\n public readonly toolName: string;\n\n constructor(toolName: string, message: string, options?: ErrorOptions) {\n super(`Tool \"${toolName}\" failed: ${message}`, options);\n this.name = \"ToolExecutionError\";\n this.toolName = toolName;\n }\n}\n\n/** Thrown when structured output parsing fails */\nexport class StructuredOutputError extends AgentSDKError {\n constructor(message: string, options?: ErrorOptions) {\n super(`Structured output error: ${message}`, options);\n this.name = \"StructuredOutputError\";\n }\n}\n","import type {\n IAgent,\n AgentConfig,\n AgentState,\n AgentResult,\n AgentEvent,\n MessageContent,\n Message,\n RunOptions,\n StructuredOutputConfig,\n UsageData,\n} from \"./types.js\";\nimport { ReentrancyError, DisposedError, AbortError } from \"./errors.js\";\n\n/** Abstract base agent with shared lifecycle logic.\n * Concrete backends extend this and implement the protected _run/_stream methods. */\nexport abstract class BaseAgent implements IAgent {\n protected state: AgentState = \"idle\";\n protected abortController: AbortController | null = null;\n protected readonly config: AgentConfig;\n\n /** Backend identifier (e.g. \"copilot\", \"claude\", \"vercel-ai\") */\n protected abstract readonly backendName: string;\n\n /** CLI session ID for persistent mode. Override in backends that support it. */\n get sessionId(): string | undefined {\n return undefined;\n }\n\n constructor(config: AgentConfig) {\n this.config = Object.freeze({ ...config });\n }\n\n // ─── Public Interface ─────────────────────────────────────────\n\n async run(\n prompt: MessageContent,\n options?: RunOptions,\n ): Promise<AgentResult> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const result = await this.executeRun(messages, options, ac.signal);\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async runWithContext(\n messages: Message[],\n options?: RunOptions,\n ): Promise<AgentResult> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const result = await this.executeRun(messages, options, ac.signal);\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async runStructured<T>(\n prompt: MessageContent,\n schema: StructuredOutputConfig<T>,\n options?: RunOptions,\n ): Promise<AgentResult<T>> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const result = await this.executeRunStructured(\n messages,\n schema,\n options,\n ac.signal,\n );\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async *stream(\n prompt: MessageContent,\n options?: RunOptions,\n ): AsyncIterable<AgentEvent> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"streaming\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const enriched = this.enrichStream(this.executeStream(messages, options, ac.signal));\n yield* this.heartbeatStream(enriched);\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async *streamWithContext(\n messages: Message[],\n options?: RunOptions,\n ): AsyncIterable<AgentEvent> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"streaming\";\n\n try {\n const enriched = this.enrichStream(this.executeStream(messages, options, ac.signal));\n yield* this.heartbeatStream(enriched);\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n abort(): void {\n if (this.abortController) {\n this.abortController.abort();\n }\n }\n\n getState(): AgentState {\n return this.state;\n }\n\n getConfig(): Readonly<AgentConfig> {\n return this.config;\n }\n\n /** Mark agent as disposed. Override to add cleanup. */\n dispose(): void {\n this.abort();\n this.state = \"disposed\";\n }\n\n // ─── Abstract Methods (implemented by backends) ───────────────\n\n /** Execute a blocking run. Backend implements the actual LLM call. */\n protected abstract executeRun(\n messages: Message[],\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult>;\n\n /** Execute a structured output run. Backend implements parsing. */\n protected abstract executeRunStructured<T>(\n messages: Message[],\n schema: StructuredOutputConfig<T>,\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult<T>>;\n\n /** Execute a streaming run. Backend yields events. */\n protected abstract executeStream(\n messages: Message[],\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): AsyncIterable<AgentEvent>;\n\n // ─── Usage Enrichment ───────────────────────────────────────────\n\n /** Enrich result usage with model/backend and fire onUsage callback */\n private enrichAndNotifyUsage(result: AgentResult<unknown>): void {\n if (result.usage) {\n result.usage = {\n ...result.usage,\n model: this.config.model,\n backend: this.backendName,\n };\n this.callOnUsage(result.usage);\n }\n }\n\n /** Wrap a stream to enrich usage_update events and fire onUsage callback */\n private async *enrichStream(\n source: AsyncIterable<AgentEvent>,\n ): AsyncIterable<AgentEvent> {\n for await (const event of source) {\n if (event.type === \"usage_update\") {\n const usage: UsageData = {\n promptTokens: event.promptTokens,\n completionTokens: event.completionTokens,\n model: this.config.model,\n backend: this.backendName,\n };\n this.callOnUsage(usage);\n yield { type: \"usage_update\", ...usage };\n } else {\n yield event;\n }\n }\n }\n\n /** Fire onUsage callback (fire-and-forget: errors logged, not propagated) */\n private callOnUsage(usage: UsageData): void {\n if (!this.config.onUsage) return;\n try {\n this.config.onUsage(usage);\n } catch (e) {\n console.warn(\n \"[agent-sdk] onUsage callback error:\",\n e instanceof Error ? e.message : String(e),\n );\n }\n }\n\n // ─── Heartbeat ───────────────────────────────────────────────\n\n /** Wrap a stream to emit heartbeat events at configured intervals.\n * When heartbeatInterval is not set, passes through directly. */\n private async *heartbeatStream(\n source: AsyncIterable<AgentEvent>,\n ): AsyncIterable<AgentEvent> {\n const interval = this.config.heartbeatInterval;\n if (!interval || interval <= 0) {\n yield* source;\n return;\n }\n\n const iterator = source[Symbol.asyncIterator]();\n let pendingEvent: Promise<IteratorResult<AgentEvent>> | null = null;\n let heartbeatResolve: (() => void) | null = null;\n\n const timer = setInterval(() => {\n if (heartbeatResolve) {\n const resolve = heartbeatResolve;\n heartbeatResolve = null;\n resolve();\n }\n }, interval);\n\n try {\n while (true) {\n if (!pendingEvent) {\n pendingEvent = iterator.next();\n }\n\n const heartbeatPromise = new Promise<void>((resolve) => {\n heartbeatResolve = resolve;\n });\n\n const eventDone = pendingEvent.then(\n (r) => ({ kind: \"event\" as const, result: r }),\n );\n const heartbeatDone = heartbeatPromise.then(\n () => ({ kind: \"heartbeat\" as const }),\n );\n\n const winner = await Promise.race([eventDone, heartbeatDone]);\n\n if (winner.kind === \"heartbeat\") {\n yield { type: \"heartbeat\" };\n } else {\n pendingEvent = null;\n heartbeatResolve = null;\n if (winner.result.done) break;\n yield winner.result.value;\n }\n }\n } finally {\n clearInterval(timer);\n heartbeatResolve = null;\n }\n }\n\n // ─── Guards ───────────────────────────────────────────────────\n\n protected guardReentrancy(): void {\n if (this.state === \"running\" || this.state === \"streaming\") {\n throw new ReentrancyError();\n }\n }\n\n protected guardDisposed(): void {\n if (this.state === \"disposed\") {\n throw new DisposedError(\"Agent\");\n }\n }\n\n /** Throw AbortError if signal is already aborted */\n protected checkAbort(signal: AbortSignal): void {\n if (signal.aborted) {\n throw new AbortError();\n }\n }\n\n // ─── Internal Helpers ─────────────────────────────────────────\n\n private createAbortController(externalSignal?: AbortSignal): AbortController {\n const ac = new AbortController();\n this.abortController = ac;\n\n if (externalSignal) {\n if (externalSignal.aborted) {\n ac.abort();\n } else {\n externalSignal.addEventListener(\"abort\", () => ac.abort(), {\n once: true,\n });\n }\n }\n\n return ac;\n }\n}\n","import type { z } from \"zod\";\n\n/** Convert a Zod schema to JSON Schema.\n * Detection order: toJSONSchema() (Zod v4) → jsonSchema() (Zod v3.24+) → _def extraction (Zod v3 legacy). */\nexport function zodToJsonSchema(schema: z.ZodType): Record<string, unknown> {\n const schemaAny = schema as unknown as Record<string, unknown>;\n\n // Zod v4: toJSONSchema()\n if (\"toJSONSchema\" in schema && typeof schemaAny.toJSONSchema === \"function\") {\n return (schemaAny.toJSONSchema as () => Record<string, unknown>)();\n }\n\n // Zod v3.24+: jsonSchema()\n if (\"jsonSchema\" in schema && typeof schemaAny.jsonSchema === \"function\") {\n return (schemaAny.jsonSchema as () => Record<string, unknown>)();\n }\n\n // Zod v3 legacy: _def.typeName extraction\n return extractSchemaFromDef(schema);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction extractSchemaFromDef(schema: z.ZodType): Record<string, unknown> {\n const def = (schema as unknown as { _def: Record<string, any> })._def;\n const typeName = def.typeName as string;\n\n switch (typeName) {\n case \"ZodString\":\n return { type: \"string\" };\n case \"ZodNumber\":\n return { type: \"number\" };\n case \"ZodBoolean\":\n return { type: \"boolean\" };\n case \"ZodNull\":\n return { type: \"null\" };\n case \"ZodArray\":\n return {\n type: \"array\",\n items: extractSchemaFromDef(def.type as z.ZodType),\n };\n case \"ZodObject\": {\n const shape = (schema as unknown as { shape: Record<string, z.ZodType> }).shape;\n const properties: Record<string, unknown> = {};\n const required: string[] = [];\n\n for (const [key, value] of Object.entries(shape)) {\n const valueDef = (value as unknown as { _def: Record<string, any> })._def;\n if (valueDef.typeName === \"ZodOptional\") {\n properties[key] = extractSchemaFromDef(valueDef.innerType as z.ZodType);\n } else {\n properties[key] = extractSchemaFromDef(value);\n required.push(key);\n }\n }\n\n return {\n type: \"object\",\n properties,\n ...(required.length > 0 ? { required } : {}),\n };\n }\n case \"ZodOptional\":\n return extractSchemaFromDef(def.innerType as z.ZodType);\n case \"ZodEnum\":\n return { type: \"string\", enum: def.values as string[] };\n default:\n return {};\n }\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n","import type {\n IAgent,\n IAgentService,\n AgentConfig,\n AgentResult,\n AgentEvent,\n Message,\n RunOptions,\n StructuredOutputConfig,\n ToolDefinition,\n ClaudeBackendOptions,\n ModelInfo,\n ValidationResult,\n JSONValue,\n PermissionRequest as UnifiedPermissionRequest,\n PermissionDecision,\n PermissionScope,\n} from \"../types.js\";\nimport { getTextContent } from \"../types.js\";\nimport { BaseAgent } from \"../base-agent.js\";\nimport { DisposedError, SubprocessError, AbortError } from \"../errors.js\";\nimport { zodToJsonSchema } from \"../utils/schema.js\";\n\nexport type { ClaudeBackendOptions } from \"../types.js\";\n\n// ─── Local Type Definitions (matching @anthropic-ai/claude-agent-sdk shapes) ──\n// Avoids requiring the SDK to be installed at compile time.\n\n/** @internal Claude SDK PermissionUpdate destination */\ntype PermissionUpdateDestination =\n | \"userSettings\"\n | \"projectSettings\"\n | \"localSettings\"\n | \"session\"\n | \"cliArg\";\n\n/** @internal Claude SDK PermissionUpdate */\ninterface SDKPermissionUpdate {\n type: \"addRules\" | \"replaceRules\" | \"removeRules\" | \"setMode\" | \"addDirectories\" | \"removeDirectories\";\n destination: PermissionUpdateDestination;\n [key: string]: unknown;\n}\n\n/** @internal Claude SDK PermissionResult */\ntype SDKPermissionResult =\n | {\n behavior: \"allow\";\n updatedInput?: Record<string, unknown>;\n updatedPermissions?: SDKPermissionUpdate[];\n toolUseID?: string;\n }\n | {\n behavior: \"deny\";\n message: string;\n interrupt?: boolean;\n toolUseID?: string;\n };\n\n/** @internal Claude SDK CanUseTool callback */\ntype SDKCanUseTool = (\n toolName: string,\n input: Record<string, unknown>,\n options: {\n signal: AbortSignal;\n suggestions?: SDKPermissionUpdate[];\n blockedPath?: string;\n decisionReason?: string;\n toolUseID: string;\n agentID?: string;\n },\n) => Promise<SDKPermissionResult>;\n\n/** @internal Claude SDK Options */\ninterface SDKOptions {\n abortController?: AbortController;\n allowedTools?: string[];\n canUseTool?: SDKCanUseTool;\n cwd?: string;\n disallowedTools?: string[];\n env?: { [envVar: string]: string | undefined };\n includePartialMessages?: boolean;\n maxTurns?: number;\n model?: string;\n outputFormat?: { type: \"json_schema\"; schema: Record<string, unknown> };\n pathToClaudeCodeExecutable?: string;\n permissionMode?: string;\n persistSession?: boolean;\n resume?: string;\n sessionId?: string;\n systemPrompt?:\n | string\n | { type: \"preset\"; preset: \"claude_code\"; append?: string };\n mcpServers?: Record<string, unknown>;\n}\n\n/** @internal Claude SDK ModelInfo */\ninterface SDKModelInfo {\n value: string;\n displayName: string;\n description: string;\n}\n\n/** @internal Claude SDK ResultSuccess */\ninterface SDKResultSuccess {\n type: \"result\";\n subtype: \"success\";\n result: string;\n structured_output?: unknown;\n num_turns: number;\n total_cost_usd: number;\n usage: Record<string, number>;\n modelUsage: Record<string, { inputTokens: number; outputTokens: number }>;\n session_id: string;\n}\n\n/** @internal Claude SDK ResultError */\ninterface SDKResultError {\n type: \"result\";\n subtype: string;\n errors: string[];\n is_error: boolean;\n usage: Record<string, number>;\n modelUsage: Record<string, { inputTokens: number; outputTokens: number }>;\n session_id: string;\n}\n\n/** @internal Claude SDK message union */\ninterface SDKMessage {\n type: string;\n subtype?: string;\n [key: string]: unknown;\n}\n\n/** @internal Claude SDK Query interface — AsyncGenerator<SDKMessage> with control methods */\ninterface SDKQuery extends AsyncGenerator<SDKMessage, void> {\n close(): void;\n interrupt(): Promise<void>;\n supportedModels(): Promise<SDKModelInfo[]>;\n}\n\n/** @internal SDK's MCP tool definition */\ninterface SDKMcpToolDefinition {\n name: string;\n description: string;\n inputSchema: Record<string, unknown>;\n handler: (args: Record<string, unknown>, extra: unknown) => Promise<{ content: Array<{ type: string; text: string }> }>;\n}\n\n/** @internal SDK server config */\ninterface SDKMcpServerConfigWithInstance {\n type: \"sdk\";\n name: string;\n instance: unknown;\n}\n\n/** @internal */\ntype SDKModule = {\n query: (params: { prompt: string; options?: SDKOptions }) => SDKQuery;\n createSdkMcpServer: (options: {\n name: string;\n version?: string;\n tools?: SDKMcpToolDefinition[];\n }) => SDKMcpServerConfigWithInstance;\n tool: (\n name: string,\n description: string,\n inputSchema: Record<string, unknown>,\n handler: (args: Record<string, unknown>, extra: unknown) => Promise<{ content: Array<{ type: string; text: string }> }>,\n ) => SDKMcpToolDefinition;\n};\n\n// ─── Dynamic SDK Loader ─────────────────────────────────────────\n\nlet sdkModule: SDKModule | null = null;\n\nasync function loadSDK(): Promise<SDKModule> {\n if (sdkModule) return sdkModule;\n try {\n // @ts-ignore — peer dependency, not present at compile time\n sdkModule = (await import(\"@anthropic-ai/claude-agent-sdk\")) as SDKModule;\n return sdkModule!;\n } catch {\n throw new SubprocessError(\n \"@anthropic-ai/claude-agent-sdk is not installed. Install it: npm install @anthropic-ai/claude-agent-sdk\",\n );\n }\n}\n\n/** @internal For testing: inject mock SDK module */\nexport function _injectSDK(mock: SDKModule | null): void {\n sdkModule = mock;\n}\n\n/** @internal For testing: reset injected SDK */\nexport function _resetSDK(): void {\n sdkModule = null;\n}\n\n// ─── Known Models ───────────────────────────────────────────────\n\nconst ANTHROPIC_MODELS_URL = \"https://api.anthropic.com/v1/models\";\nconst ANTHROPIC_API_VERSION = \"2023-06-01\";\nconst ANTHROPIC_OAUTH_BETA = \"oauth-2025-04-20\";\n\n// ─── Tool Mapping ───────────────────────────────────────────────\n\nfunction buildMcpServer(\n sdk: SDKModule,\n tools: ToolDefinition[],\n toolResultCapture?: Map<string, JSONValue>,\n): SDKMcpServerConfigWithInstance | undefined {\n if (tools.length === 0) return undefined;\n\n const mcpTools = tools.map((tool) =>\n sdk.tool(\n tool.name,\n tool.description ?? \"\",\n zodToJsonSchema(tool.parameters) as Record<string, unknown>,\n async (args: Record<string, unknown>) => {\n const result = await tool.execute(args);\n // Capture result for AgentResult.toolCalls\n if (toolResultCapture) {\n toolResultCapture.set(tool.name, result as JSONValue);\n }\n return {\n content: [\n {\n type: \"text\" as const,\n text: typeof result === \"string\" ? result : JSON.stringify(result),\n },\n ],\n };\n },\n ),\n );\n\n return sdk.createSdkMcpServer({\n name: \"agent-sdk-tools\",\n version: \"1.0.0\",\n tools: mcpTools,\n });\n}\n\n// ─── Permission Mapping ─────────────────────────────────────────\n\n/** Map our PermissionScope to Claude SDK's PermissionUpdateDestination */\nfunction scopeToDestination(scope: PermissionScope): PermissionUpdateDestination {\n switch (scope) {\n case \"once\":\n return \"session\";\n case \"session\":\n return \"session\";\n case \"project\":\n return \"projectSettings\";\n case \"always\":\n return \"userSettings\";\n }\n}\n\n/** Map Claude SDK suggestions to our PermissionScope */\nfunction destinationToScope(dest: PermissionUpdateDestination): PermissionScope {\n switch (dest) {\n case \"session\":\n case \"cliArg\":\n return \"session\";\n case \"projectSettings\":\n case \"localSettings\":\n return \"project\";\n case \"userSettings\":\n return \"always\";\n }\n}\n\n/** Extract best suggestedScope from SDK's PermissionUpdate[] */\nfunction extractSuggestedScope(\n suggestions?: SDKPermissionUpdate[],\n): PermissionScope | undefined {\n if (!suggestions || suggestions.length === 0) return undefined;\n // Use the destination of the first suggestion as the scope hint\n return destinationToScope(suggestions[0].destination);\n}\n\nfunction buildCanUseTool(\n config: AgentConfig,\n): SDKCanUseTool | undefined {\n const onPermission = config.supervisor?.onPermission;\n if (!onPermission) return undefined;\n\n const permissionStore = config.permissionStore;\n\n return async (\n toolName: string,\n input: Record<string, unknown>,\n options,\n ): Promise<SDKPermissionResult> => {\n // Check store first — if already approved, skip callback\n if (permissionStore && await permissionStore.isApproved(toolName)) {\n return {\n behavior: \"allow\",\n toolUseID: options.toolUseID,\n };\n }\n\n const unifiedRequest: UnifiedPermissionRequest = {\n toolName,\n toolArgs: input,\n suggestedScope: extractSuggestedScope(options.suggestions),\n rawSDKRequest: { toolName, input, ...options },\n };\n\n const decision: PermissionDecision = await onPermission(\n unifiedRequest,\n options.signal,\n );\n\n if (decision.allowed) {\n // Persist approval to store\n if (permissionStore && decision.scope) {\n await permissionStore.approve(toolName, decision.scope);\n }\n\n const result: SDKPermissionResult = {\n behavior: \"allow\",\n toolUseID: options.toolUseID,\n };\n if (decision.modifiedInput) {\n (result as { updatedInput?: Record<string, unknown> }).updatedInput =\n decision.modifiedInput;\n }\n // Map scope decision to SDK's updatedPermissions\n if (decision.scope && decision.scope !== \"once\" && options.suggestions) {\n (result as { updatedPermissions?: SDKPermissionUpdate[] }).updatedPermissions =\n options.suggestions.map((s) => ({\n ...s,\n destination: scopeToDestination(decision.scope!),\n }));\n }\n return result;\n }\n\n return {\n behavior: \"deny\",\n message: decision.reason ?? \"Permission denied\",\n toolUseID: options.toolUseID,\n };\n };\n}\n\n// ─── Usage Aggregation Helper ───────────────────────────────────\n\nfunction aggregateUsage(\n modelUsage?: Record<string, { inputTokens: number; outputTokens: number }>,\n): { promptTokens: number; completionTokens: number } {\n let promptTokens = 0;\n let completionTokens = 0;\n for (const u of Object.values(modelUsage ?? {})) {\n promptTokens += u.inputTokens ?? 0;\n completionTokens += u.outputTokens ?? 0;\n }\n return { promptTokens, completionTokens };\n}\n\n// ─── Event Mapping ──────────────────────────────────────────────\n\n/**\n * Tracks tool call IDs to tool names for Claude backend.\n *\n * The Claude SDK emits tool_use blocks (with `id` and `name`) in assistant messages,\n * but tool_use_summary messages only carry `tool_name` (and optionally\n * `preceding_tool_use_ids`). This tracker correlates start/end events using a\n * per-tool-name FIFO queue to handle parallel calls to the same tool.\n */\nclass ClaudeToolCallTracker {\n private queues = new Map<string, string[]>();\n\n trackStart(toolCallId: string, toolName: string): void {\n if (!this.queues.has(toolName)) {\n this.queues.set(toolName, []);\n }\n this.queues.get(toolName)!.push(toolCallId);\n }\n\n /** Peek at the current tool call ID for a tool name (does not consume) */\n peekToolCallId(toolName: string): string {\n const queue = this.queues.get(toolName);\n if (!queue || queue.length === 0) return \"\";\n return queue[0];\n }\n\n /** Consume and return the first tool call ID for a tool name */\n consumeToolCallId(toolName: string): string {\n const queue = this.queues.get(toolName);\n if (!queue || queue.length === 0) return \"\";\n return queue.shift()!;\n }\n\n clear(): void {\n this.queues.clear();\n }\n}\n\nfunction mapSDKMessage(msg: SDKMessage, thinkingBlockIndices?: Set<number>, toolCallTracker?: ClaudeToolCallTracker): AgentEvent | AgentEvent[] | null {\n switch (msg.type) {\n case \"assistant\": {\n // Full assistant message — contains BetaMessage with content blocks\n const betaMessage = msg.message as {\n content?: Array<{\n type: string;\n text?: string;\n name?: string;\n input?: unknown;\n id?: string;\n }>;\n } | undefined;\n if (!betaMessage?.content) return null;\n\n const events: AgentEvent[] = [];\n\n // Extract text content from the message\n const textParts = betaMessage.content\n .filter((b) => b.type === \"text\" && b.text)\n .map((b) => b.text!)\n .join(\"\");\n\n if (textParts) {\n events.push({ type: \"text_delta\", text: textParts });\n }\n\n // Emit tool_call_start for each tool_use block\n for (const block of betaMessage.content) {\n if (block.type === \"tool_use\") {\n const toolCallId = String(block.id ?? \"\");\n const toolName = block.name ?? \"unknown\";\n if (toolCallTracker) {\n toolCallTracker.trackStart(toolCallId, toolName);\n }\n events.push({\n type: \"tool_call_start\",\n toolCallId,\n toolName,\n args: (block.input as JSONValue) ?? {},\n });\n }\n }\n\n return events.length > 0 ? events : null;\n }\n\n case \"user\": {\n // User messages with tool_use_result indicate tool completion\n const toolResult = msg.tool_use_result as JSONValue | undefined;\n // Extract tool name from the message context if available\n if (toolResult !== undefined) {\n // The user message after tool execution — emit tool_call_end\n // tool_name may not be in user messages, but we can infer from context\n return null; // Handled via tool_use_summary below\n }\n return null;\n }\n\n case \"tool_use_summary\": {\n // Emitted after tool execution — contains summary of tool results\n const summary = msg.summary as string | undefined;\n const toolName = (msg.tool_name as string | undefined) ?? \"unknown\";\n // Resolve toolCallId: prefer preceding_tool_use_ids, fall back to tracker\n const precedingIds = msg.preceding_tool_use_ids as string[] | undefined;\n let toolCallId = \"\";\n if (precedingIds && precedingIds.length > 0) {\n toolCallId = precedingIds[0];\n // Consume from tracker to keep queue in sync\n if (toolCallTracker) toolCallTracker.consumeToolCallId(toolName);\n } else if (toolCallTracker) {\n toolCallId = toolCallTracker.consumeToolCallId(toolName);\n }\n // Emit as tool_call_end with summary as result\n if (summary) {\n return {\n type: \"tool_call_end\",\n toolCallId,\n toolName,\n result: summary as JSONValue,\n };\n }\n return null;\n }\n\n case \"stream_event\": {\n // Partial streaming events — BetaRawMessageStreamEvent\n const event = msg.event as {\n type: string;\n delta?: { type: string; text?: string };\n content_block?: { type: string; name?: string; id?: string };\n index?: number;\n } | undefined;\n if (!event) return null;\n\n if (\n event.type === \"content_block_delta\" &&\n event.delta?.type === \"text_delta\" &&\n event.delta.text\n ) {\n return { type: \"text_delta\", text: event.delta.text };\n }\n\n if (event.type === \"content_block_start\" && event.content_block?.type === \"thinking\") {\n if (thinkingBlockIndices && event.index !== undefined) {\n thinkingBlockIndices.add(event.index);\n }\n return { type: \"thinking_start\" };\n }\n\n if (event.type === \"content_block_stop\" && event.index !== undefined && thinkingBlockIndices?.has(event.index)) {\n thinkingBlockIndices.delete(event.index);\n return { type: \"thinking_end\" };\n }\n\n return null;\n }\n\n case \"tool_progress\": {\n const toolName = msg.tool_name as string | undefined;\n if (!toolName) return null;\n const toolCallId = toolCallTracker?.peekToolCallId(toolName) ?? \"\";\n return { type: \"tool_call_start\", toolCallId, toolName, args: {} };\n }\n\n case \"result\": {\n if (msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n return {\n type: \"usage_update\",\n ...aggregateUsage(r.modelUsage),\n };\n }\n if (msg.is_error) {\n const r = msg as unknown as SDKResultError;\n return {\n type: \"error\",\n error: r.errors?.join(\"; \") ?? \"Unknown error\",\n recoverable: false,\n };\n }\n return null;\n }\n\n default:\n return null;\n }\n}\n\n// ─── ClaudeAgent ────────────────────────────────────────────────\n\nclass ClaudeAgent extends BaseAgent {\n protected readonly backendName = \"claude\";\n private readonly options: ClaudeBackendOptions;\n private readonly tools: ToolDefinition[];\n private readonly canUseTool: SDKCanUseTool | undefined;\n private readonly isPersistent: boolean;\n private _sessionId: string | undefined;\n\n constructor(config: AgentConfig, options: ClaudeBackendOptions) {\n super(config);\n this.options = options;\n this.tools = config.tools;\n this.canUseTool = buildCanUseTool(config);\n this.isPersistent = config.sessionMode === \"persistent\";\n\n // Warn if onAskUser is set — Claude CLI SDK doesn't support user interaction hooks\n if (config.supervisor?.onAskUser) {\n console.warn(\n \"[agent-sdk/claude] supervisor.onAskUser is not supported by the Claude CLI backend. \" +\n \"User interaction requests from the model will not be forwarded.\",\n );\n }\n }\n\n override get sessionId(): string | undefined {\n return this._sessionId;\n }\n\n /** Clear persistent session state after an error so next call starts fresh */\n private clearPersistentSession(): void {\n this._sessionId = undefined;\n }\n\n private buildQueryOptions(signal: AbortSignal): SDKOptions {\n const ac = new AbortController();\n // Link external signal → SDK's abort controller\n signal.addEventListener(\"abort\", () => ac.abort(), { once: true });\n\n const opts: SDKOptions = {\n abortController: ac,\n model: this.config.model,\n maxTurns: this.options.maxTurns,\n cwd: this.options.workingDirectory,\n pathToClaudeCodeExecutable: this.options.cliPath,\n persistSession: this.isPersistent,\n includePartialMessages: true,\n canUseTool: this.canUseTool,\n };\n\n // Resume persistent session on subsequent calls\n if (this.isPersistent && this._sessionId) {\n opts.resume = this._sessionId;\n }\n\n if (this.config.systemPrompt) {\n opts.systemPrompt = this.config.systemPrompt;\n }\n\n if (this.options.oauthToken) {\n opts.env = { ...process.env, CLAUDE_CODE_OAUTH_TOKEN: this.options.oauthToken };\n }\n\n return opts;\n }\n\n private async buildMcpConfig(\n opts: SDKOptions,\n toolResultCapture?: Map<string, JSONValue>,\n ): Promise<SDKOptions> {\n if (this.tools.length === 0) return opts;\n\n const sdk = await loadSDK();\n const mcpServer = buildMcpServer(sdk, this.tools, toolResultCapture);\n if (mcpServer) {\n opts.mcpServers = {\n \"agent-sdk-tools\": mcpServer,\n };\n }\n return opts;\n }\n\n // ─── executeRun ─────────────────────────────────────────────────\n\n protected async executeRun(\n messages: Message[],\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n const toolResultCapture = new Map<string, JSONValue>();\n opts = await this.buildMcpConfig(opts, toolResultCapture);\n\n const q = sdk.query({ prompt, options: opts });\n const toolCalls: AgentResult[\"toolCalls\"] = [];\n let output: string | null = null;\n let usage: AgentResult[\"usage\"];\n\n try {\n for await (const msg of q) {\n // Collect tool calls from assistant messages\n if (msg.type === \"assistant\") {\n const betaMessage = msg.message as {\n content?: Array<{\n type: string;\n text?: string;\n name?: string;\n input?: unknown;\n id?: string;\n }>;\n } | undefined;\n if (betaMessage?.content) {\n for (const block of betaMessage.content) {\n if (block.type === \"tool_use\") {\n const toolName = block.name ?? \"unknown\";\n toolCalls.push({\n toolName,\n args: (block.input as JSONValue) ?? {},\n result: toolResultCapture.get(toolName) ?? null,\n approved: true,\n });\n }\n }\n }\n }\n\n // Back-fill results from capture map for previously added tool calls\n if (msg.type === \"tool_use_summary\" || msg.type === \"result\") {\n for (const tc of toolCalls) {\n if (tc.result === null) {\n const captured = toolResultCapture.get(tc.toolName);\n if (captured !== undefined) tc.result = captured;\n }\n }\n }\n\n // Capture result and session_id\n if (msg.type === \"result\") {\n if (msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n output = r.result;\n usage = aggregateUsage(r.modelUsage);\n if (this.isPersistent && r.session_id) {\n this._sessionId = r.session_id;\n }\n } else if (msg.is_error) {\n const r = msg as unknown as SDKResultError;\n throw new Error(\n `Claude query failed: ${r.errors?.join(\"; \") ?? \"unknown error\"}`,\n );\n }\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n }\n\n return {\n output,\n structuredOutput: undefined as AgentResult[\"structuredOutput\"],\n toolCalls,\n messages: [\n ...messages,\n ...(output !== null\n ? [{ role: \"assistant\" as const, content: output }]\n : []),\n ],\n usage,\n };\n }\n\n // ─── executeRunStructured ───────────────────────────────────────\n\n protected async executeRunStructured<T>(\n messages: Message[],\n schema: StructuredOutputConfig<T>,\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult<T>> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n opts = await this.buildMcpConfig(opts);\n\n // Claude SDK has native structured output via outputFormat\n const jsonSchema = zodToJsonSchema(schema.schema);\n opts.outputFormat = {\n type: \"json_schema\",\n schema: jsonSchema as Record<string, unknown>,\n };\n\n const q = sdk.query({ prompt, options: opts });\n const toolCalls: AgentResult[\"toolCalls\"] = [];\n let output: string | null = null;\n let structuredOutput: T | undefined;\n let usage: AgentResult[\"usage\"];\n\n try {\n for await (const msg of q) {\n if (msg.type === \"result\" && msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n output = r.result;\n\n // Claude SDK returns parsed structured_output when using outputFormat\n if (r.structured_output !== undefined) {\n try {\n structuredOutput = schema.schema.parse(r.structured_output);\n } catch {\n // Fallback: try parsing result string\n try {\n structuredOutput = schema.schema.parse(JSON.parse(r.result));\n } catch {\n // Leave undefined\n }\n }\n } else if (r.result) {\n // Fallback: parse from result string\n try {\n const jsonMatch = r.result.match(/```(?:json)?\\s*([\\s\\S]*?)```/);\n const raw = jsonMatch ? jsonMatch[1]!.trim() : r.result.trim();\n structuredOutput = schema.schema.parse(JSON.parse(raw));\n } catch {\n // Leave undefined\n }\n }\n\n usage = aggregateUsage(r.modelUsage);\n if (this.isPersistent && r.session_id) {\n this._sessionId = r.session_id;\n }\n } else if (msg.type === \"result\" && msg.is_error) {\n const r = msg as unknown as SDKResultError;\n throw new Error(\n `Claude query failed: ${r.errors?.join(\"; \") ?? \"unknown error\"}`,\n );\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n }\n\n return {\n output,\n structuredOutput: structuredOutput as AgentResult<T>[\"structuredOutput\"],\n toolCalls,\n messages: [\n ...messages,\n ...(output !== null\n ? [{ role: \"assistant\" as const, content: output }]\n : []),\n ],\n usage,\n };\n }\n\n // ─── executeStream ──────────────────────────────────────────────\n\n protected async *executeStream(\n messages: Message[],\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): AsyncIterable<AgentEvent> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n opts = await this.buildMcpConfig(opts);\n\n const q = sdk.query({ prompt, options: opts });\n const thinkingBlockIndices = new Set<number>();\n const toolCallTracker = new ClaudeToolCallTracker();\n\n try {\n for await (const msg of q) {\n if (signal.aborted) throw new AbortError();\n\n const event = mapSDKMessage(msg, thinkingBlockIndices, toolCallTracker);\n if (event) {\n if (Array.isArray(event)) {\n for (const e of event) yield e;\n } else {\n yield event;\n }\n }\n\n // Capture session_id and emit done event on result\n if (msg.type === \"result\" && msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n if (this.isPersistent && r.session_id) {\n this._sessionId = r.session_id;\n }\n yield { type: \"done\", finalOutput: r.result };\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n }\n }\n\n override dispose(): void {\n this._sessionId = undefined;\n super.dispose();\n }\n}\n\n// ─── Helpers ────────────────────────────────────────────────────\n\nfunction extractLastUserPrompt(messages: Message[]): string {\n for (let i = messages.length - 1; i >= 0; i--) {\n const msg = messages[i];\n if (msg.role === \"user\") {\n return getTextContent(msg.content);\n }\n }\n return \"\";\n}\n\n/** Build prompt with conversation history for CLI backends that create fresh sessions */\nfunction buildContextualPrompt(messages: Message[]): string {\n if (messages.length <= 1) {\n return extractLastUserPrompt(messages);\n }\n\n const history = messages.slice(0, -1).map((msg) => {\n const text = msg.content ? getTextContent(msg.content) : \"\";\n return msg.role === \"user\" ? `User: ${text}` : `Assistant: ${text}`;\n }).join(\"\\n\");\n\n const lastPrompt = extractLastUserPrompt(messages);\n\n return `Conversation history:\\n${history}\\n\\nUser: ${lastPrompt}`;\n}\n\nclass ClaudeAgentService implements IAgentService {\n readonly name = \"claude\";\n private disposed = false;\n private readonly options: ClaudeBackendOptions;\n private cachedModels: ModelInfo[] | null = null;\n\n constructor(options: ClaudeBackendOptions) {\n this.options = options;\n }\n\n createAgent(config: AgentConfig): IAgent {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n return new ClaudeAgent(config, this.options);\n }\n\n async listModels(): Promise<ModelInfo[]> {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n if (this.cachedModels) return this.cachedModels;\n\n const token = this.options.oauthToken;\n if (!token) {\n return [];\n }\n\n const res = await globalThis.fetch(\n `${ANTHROPIC_MODELS_URL}?limit=100`,\n {\n headers: {\n Authorization: `Bearer ${token}`,\n \"anthropic-version\": ANTHROPIC_API_VERSION,\n \"anthropic-beta\": ANTHROPIC_OAUTH_BETA,\n },\n },\n );\n\n if (!res.ok) {\n return [];\n }\n\n const body = (await res.json()) as {\n data?: Array<{ id: string; display_name?: string }>;\n };\n\n if (!body.data || body.data.length === 0) {\n return [];\n }\n\n this.cachedModels = body.data.map((m) => ({\n id: m.id,\n name: m.display_name,\n provider: \"claude\",\n }));\n return this.cachedModels;\n }\n\n async validate(): Promise<ValidationResult> {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n\n const errors: string[] = [];\n try {\n await loadSDK();\n } catch (e) {\n errors.push(\n e instanceof Error ? e.message : String(e),\n );\n return { valid: false, errors };\n }\n\n // Verify CLI is accessible by attempting a minimal query\n try {\n const sdk = await loadSDK();\n const q = sdk.query({\n prompt: \"echo test\",\n options: {\n model: \"claude-sonnet-4-20250514\",\n pathToClaudeCodeExecutable: this.options.cliPath,\n cwd: this.options.workingDirectory,\n persistSession: false,\n maxTurns: 1,\n permissionMode: \"plan\",\n },\n });\n // Wait for first message (auth check)\n const first = await q.next();\n q.close();\n if (first.done) {\n errors.push(\"Claude CLI returned no messages — may not be authenticated.\");\n }\n } catch (e) {\n errors.push(\n `Failed to connect to Claude CLI: ${e instanceof Error ? e.message : String(e)}`,\n );\n }\n\n return { valid: errors.length === 0, errors };\n }\n\n async dispose(): Promise<void> {\n if (this.disposed) return;\n this.disposed = true;\n this.cachedModels = null;\n }\n}\n\n// ─── Factory ────────────────────────────────────────────────────\n\n/** Create Claude CLI backend service. */\nexport function createClaudeService(\n options: ClaudeBackendOptions,\n): IAgentService {\n return new ClaudeAgentService(options);\n}\n"]}
1
+ {"version":3,"sources":["../../src/types.ts","../../src/errors.ts","../../src/base-agent.ts","../../src/utils/schema.ts","../../src/backends/claude.ts"],"names":[],"mappings":"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","file":"claude.cjs","sourcesContent":["import type { z } from \"zod\";\nimport type { IPermissionStore } from \"./permission-store.js\";\n\n// ─── JSON Value ────────────────────────────────────────────────\n\n/** JSON-serializable value used for tool arguments and results */\nexport type JSONValue =\n | string\n | number\n | boolean\n | null\n | JSONValue[]\n | { [key: string]: JSONValue };\n\n// ─── Message Content ───────────────────────────────────────────\n\n/** Message content — plain string or array of text/image parts */\nexport type MessageContent = string | Array<ContentPart>;\n\n/** Individual content part within a multi-part message */\nexport type ContentPart =\n | { type: \"text\"; text: string }\n | { type: \"image\"; data: string; mimeType: string };\n\n// ─── Tool System (B1: Declaration/Definition split) ────────────\n\n/** What the LLM sees — name, description, schema. Passed to all backends. */\nexport interface ToolDeclaration<TParams = unknown> {\n name: string;\n description: string;\n parameters: z.ZodType<TParams>;\n needsApproval?: boolean;\n metadata?: {\n category?: string;\n icon?: string;\n tags?: string[];\n };\n}\n\n/** Full tool with execute function. Required for API-based backends.\n * CLI backends extract declaration; execute map held internally. */\nexport interface ToolDefinition<TParams = unknown>\n extends ToolDeclaration<TParams> {\n execute: (params: TParams) => Promise<JSONValue> | JSONValue;\n}\n\n// ─── Tool Calls / Results ──────────────────────────────────────\n\n/** A tool call made by the LLM during execution */\nexport interface ToolCall {\n id: string;\n name: string;\n args: JSONValue;\n}\n\n/** Result of executing a tool call */\nexport interface ToolResult {\n toolCallId: string;\n name: string;\n result: JSONValue;\n isError?: boolean;\n}\n\n// ─── Messages (Discriminated Union) ────────────────────────────\n\n/** Conversation message — discriminated union on `role` */\nexport type Message =\n | { role: \"user\"; content: MessageContent }\n | { role: \"assistant\"; content: MessageContent; toolCalls?: ToolCall[] }\n | { role: \"tool\"; content?: string; toolResults: ToolResult[] }\n | { role: \"system\"; content: string };\n\n// ─── Permission System (v3.1 with scopes) ──────────────────────\n\n/** Scope for \"remember this decision\" */\nexport type PermissionScope = \"once\" | \"session\" | \"project\" | \"always\";\n\n/** What the permission callback receives */\nexport interface PermissionRequest {\n toolName: string;\n toolArgs: Record<string, unknown>;\n /** SDK-suggested scope (from Claude CLI's suggestions) */\n suggestedScope?: PermissionScope;\n /** Original SDK permission request (for pass-through) */\n rawSDKRequest?: unknown;\n}\n\n/** What the permission callback returns */\nexport interface PermissionDecision {\n allowed: boolean;\n /** How long to remember this decision */\n scope?: PermissionScope;\n /** Modified tool arguments (tool args may be altered by user) */\n modifiedInput?: Record<string, unknown>;\n /** Denial reason (if denied) */\n reason?: string;\n}\n\n/** Permission callback signature */\nexport type PermissionCallback = (\n request: PermissionRequest,\n signal: AbortSignal,\n) => Promise<PermissionDecision>;\n\n// ─── User Input (Ask User) ────────────────────────────────────\n\n/** Request for user input — separate from permissions */\nexport interface UserInputRequest {\n question: string;\n choices?: string[];\n /** Whether to allow freeform text input (default: true) */\n allowFreeform?: boolean;\n}\n\n/** Response from user to an input request */\nexport interface UserInputResponse {\n answer: string;\n /** true if user typed a custom answer instead of selecting a choice */\n wasFreeform: boolean;\n /** Index of selected choice (if choice was selected) */\n selectedChoiceIndex?: number;\n}\n\n// ─── Supervisor Hooks ──────────────────────────────────────────\n\n/** Hooks for supervisor/UI to intercept agent actions */\nexport interface SupervisorHooks {\n onPermission?: PermissionCallback;\n onAskUser?: (\n request: UserInputRequest,\n signal: AbortSignal,\n ) => Promise<UserInputResponse>;\n}\n\n// ─── Structured Output ─────────────────────────────────────────\n\n/** Configuration for typed structured output from LLM */\nexport interface StructuredOutputConfig<T = unknown> {\n schema: z.ZodType<T>;\n name?: string;\n description?: string;\n}\n\n// ─── Usage Data ────────────────────────────────────────────────\n\n/** Usage data from LLM execution — tokens consumed plus optional metadata */\nexport interface UsageData {\n promptTokens: number;\n completionTokens: number;\n model?: string;\n backend?: string;\n}\n\n// ─── Agent Events (Streaming) ──────────────────────────────────\n\n/** Events emitted during streaming agent execution */\nexport type AgentEvent =\n | { type: \"text_delta\"; text: string }\n | { type: \"thinking_delta\"; text: string }\n | { type: \"tool_call_start\"; toolCallId: string; toolName: string; args: JSONValue }\n | { type: \"tool_call_end\"; toolCallId: string; toolName: string; result: JSONValue }\n | { type: \"permission_request\"; request: PermissionRequest }\n | {\n type: \"permission_response\";\n toolName: string;\n decision: PermissionDecision;\n }\n | { type: \"ask_user\"; request: UserInputRequest }\n | { type: \"ask_user_response\"; answer: string }\n | { type: \"thinking_start\" }\n | { type: \"thinking_end\" }\n | {\n type: \"usage_update\";\n promptTokens: number;\n completionTokens: number;\n model?: string;\n backend?: string;\n }\n | { type: \"session_info\"; sessionId: string; transcriptPath?: string; backend: string }\n | { type: \"heartbeat\" }\n | { type: \"error\"; error: string; recoverable: boolean }\n | { type: \"done\"; finalOutput: string | null; structuredOutput?: unknown };\n\n// ─── Run Options ───────────────────────────────────────────────\n\n/** Options passed to agent.run() / agent.stream() */\nexport interface RunOptions {\n /** AbortSignal for cancellation */\n signal?: AbortSignal;\n /** Arbitrary context passed to the agent run */\n context?: Record<string, unknown>;\n}\n\n// ─── Agent Configuration ───────────────────────────────────────\n\n/** LLM model parameters */\nexport interface ModelParams {\n temperature?: number;\n maxTokens?: number;\n topP?: number;\n stopSequences?: string[];\n}\n\n/** Timeout configuration for agent operations */\nexport interface TimeoutConfig {\n /** Max time for entire agent run (ms) */\n total?: number;\n /** Max time for a single tool execution (ms) */\n perTool?: number;\n /** Max time for a single LLM request (ms) */\n perLLMRequest?: number;\n}\n\n/** Error handling strategy configuration */\nexport interface ErrorHandlingConfig {\n /** What to do when a tool throws */\n onToolError?: \"fail\" | \"continue\" | \"ask-llm\";\n /** Retry config for transient LLM failures */\n retryLLM?: { maxAttempts: number; backoffMs: number };\n /** Global error callback for monitoring */\n onError?: (\n error: Error,\n context: { phase: \"tool\" | \"llm\" | \"permission\" | \"ask-user\" },\n ) => void;\n}\n\n/** Configuration for creating an agent */\nexport interface AgentConfig {\n model?: string;\n modelParams?: ModelParams;\n systemPrompt: string;\n tools: ToolDefinition[];\n supervisor?: SupervisorHooks;\n maxTurns?: number;\n timeout?: TimeoutConfig;\n errorHandling?: ErrorHandlingConfig;\n /** Pluggable store for persisting permission scope decisions across runs */\n permissionStore?: IPermissionStore;\n /** How to apply systemPrompt: \"append\" adds to backend default, \"replace\" overrides it.\n * Default: \"append\". Currently used by the Copilot backend. */\n systemMessageMode?: \"append\" | \"replace\";\n /** Filter for backend built-in tools (e.g. [\"web_search\", \"web_fetch\"] for Copilot).\n * When set, only listed built-in tools are available. Backend-specific. */\n availableTools?: string[];\n /** Callback invoked with usage data after run completion or during streaming.\n * Fire-and-forget: errors are logged but not propagated. */\n onUsage?: (usage: UsageData) => void;\n /** Interval in milliseconds for emitting heartbeat events during streaming.\n * When set, heartbeat events are emitted to keep the stream alive during\n * long tool executions. Default: off (no heartbeats). */\n heartbeatInterval?: number;\n /** Session reuse mode for CLI backends (Copilot, Claude).\n * \"per-call\" (default): creates a fresh CLI session for each run/stream call.\n * \"persistent\": reuses the same CLI session across calls, preserving conversation\n * history natively in the CLI backend. Session is destroyed on agent dispose(). */\n sessionMode?: \"per-call\" | \"persistent\";\n}\n\n// ─── Agent Result (Generic) ────────────────────────────────────\n\n/** Result of an agent run, generic over structured output type T */\nexport interface AgentResult<T = void> {\n output: string | null;\n structuredOutput: T extends void ? undefined : T;\n toolCalls: Array<{\n toolName: string;\n args: JSONValue;\n result: JSONValue;\n approved: boolean;\n }>;\n messages: Message[];\n usage?: UsageData;\n}\n\n// ─── Agent State ───────────────────────────────────────────────\n\n/** Agent lifecycle state */\nexport type AgentState = \"idle\" | \"running\" | \"streaming\" | \"disposed\";\n\n// ─── Agent Interface ───────────────────────────────────────────\n\n/** Core agent interface — run prompts, stream events, manage lifecycle */\nexport interface IAgent {\n /** The CLI session ID when using persistent session mode. Undefined in per-call mode\n * or before the first call. Can be stored externally for session resume. */\n readonly sessionId: string | undefined;\n /** Run a single prompt and return the result. Wraps prompt in a user message. */\n run(prompt: MessageContent, options?: RunOptions): Promise<AgentResult>;\n /** Run with full conversation history. Messages are passed directly to the backend. */\n runWithContext(\n messages: Message[],\n options?: RunOptions,\n ): Promise<AgentResult>;\n /** Run with structured output validated against a Zod schema. */\n runStructured<T>(\n prompt: MessageContent,\n schema: StructuredOutputConfig<T>,\n options?: RunOptions,\n ): Promise<AgentResult<T>>;\n /** Stream events for a single prompt. Wraps prompt in a user message. */\n stream(\n prompt: MessageContent,\n options?: RunOptions,\n ): AsyncIterable<AgentEvent>;\n /** Stream events with full conversation history. Messages are passed directly to the backend. */\n streamWithContext(\n messages: Message[],\n options?: RunOptions,\n ): AsyncIterable<AgentEvent>;\n /** Abort the current operation. No-op if not running. */\n abort(): void;\n /** Gracefully interrupt the current operation. Resolves when the backend acknowledges. */\n interrupt(): Promise<void>;\n /** Get current agent lifecycle state. */\n getState(): AgentState;\n /** Get frozen agent configuration. */\n getConfig(): Readonly<AgentConfig>;\n /** Release resources. After dispose(), agent must not be used. */\n dispose(): void;\n}\n\n// ─── Service Interface ─────────────────────────────────────────\n\n/** Model metadata returned by listModels() */\nexport interface ModelInfo {\n id: string;\n name?: string;\n provider?: string;\n}\n\n/** Result of backend validation check */\nexport interface ValidationResult {\n valid: boolean;\n errors: string[];\n}\n\n/** Backend service interface — creates agents, lists models, validates config */\nexport interface IAgentService {\n readonly name: string;\n createAgent(config: AgentConfig): IAgent;\n listModels(): Promise<ModelInfo[]>;\n validate(): Promise<ValidationResult>;\n dispose(): Promise<void>;\n}\n\n// ─── Backend Options ───────────────────────────────────────────\n\n/** Options for Copilot CLI backend */\nexport interface CopilotBackendOptions {\n cliPath?: string;\n workingDirectory?: string;\n githubToken?: string;\n useLoggedInUser?: boolean;\n /** Extra CLI arguments passed to the Copilot subprocess (e.g. [\"--allow-all\"]) */\n cliArgs?: string[];\n /** Timeout in milliseconds for sendAndWait() calls. When undefined, uses copilot-sdk default (60s). */\n timeout?: number;\n /** Custom environment variables merged into the subprocess env */\n env?: Record<string, string | undefined>;\n}\n\n/** Options for Claude CLI backend */\nexport interface ClaudeBackendOptions {\n cliPath?: string;\n workingDirectory?: string;\n maxTurns?: number;\n /** OAuth token for Claude authentication (set as CLAUDE_CODE_OAUTH_TOKEN env var) */\n oauthToken?: string;\n /** Custom environment variables merged into the subprocess env */\n env?: Record<string, string | undefined>;\n}\n\n/** Options for Vercel AI SDK backend */\nexport interface VercelAIBackendOptions {\n apiKey: string;\n provider?: string;\n baseUrl?: string;\n}\n\n// ─── Type Guards ───────────────────────────────────────────────\n\n/** Type guard: checks if a ToolDeclaration has an execute function (i.e., is a ToolDefinition) */\nexport function isToolDefinition(\n tool: ToolDeclaration,\n): tool is ToolDefinition {\n return \"execute\" in tool && typeof (tool as ToolDefinition).execute === \"function\";\n}\n\n/** Type guard: checks if MessageContent is plain string */\nexport function isTextContent(content: MessageContent): content is string {\n return typeof content === \"string\";\n}\n\n/** Type guard: checks if MessageContent is multi-part array */\nexport function isMultiPartContent(\n content: MessageContent,\n): content is ContentPart[] {\n return Array.isArray(content);\n}\n\n/** Extract text from MessageContent regardless of format */\nexport function getTextContent(content: MessageContent): string {\n if (typeof content === \"string\") return content;\n return content\n .filter((p): p is Extract<ContentPart, { type: \"text\" }> => p.type === \"text\")\n .map((p) => p.text)\n .join(\"\\n\");\n}\n","/** Base error class for agent-sdk */\nexport class AgentSDKError extends Error {\n constructor(message: string, options?: ErrorOptions) {\n super(message, options);\n this.name = \"AgentSDKError\";\n }\n}\n\n/** Thrown when agent.run() is called while already running (M8 re-entrancy guard) */\nexport class ReentrancyError extends AgentSDKError {\n constructor() {\n super(\"Agent is already running. Await the current run before starting another.\");\n this.name = \"ReentrancyError\";\n }\n}\n\n/** Thrown when an operation is attempted on a disposed agent/service */\nexport class DisposedError extends AgentSDKError {\n constructor(entity: string) {\n super(`${entity} has been disposed and cannot be used.`);\n this.name = \"DisposedError\";\n }\n}\n\n/** Thrown when a backend is not found in the registry */\nexport class BackendNotFoundError extends AgentSDKError {\n constructor(backend: string) {\n super(\n `Unknown backend: \"${backend}\". ` +\n `Built-in: copilot, claude, vercel-ai. ` +\n `Custom: use registerBackend() first.`,\n );\n this.name = \"BackendNotFoundError\";\n }\n}\n\n/** Thrown when a backend is already registered */\nexport class BackendAlreadyRegisteredError extends AgentSDKError {\n constructor(backend: string) {\n super(`Backend \"${backend}\" is already registered. Use a different name or unregister first.`);\n this.name = \"BackendAlreadyRegisteredError\";\n }\n}\n\n/** Thrown when subprocess management fails */\nexport class SubprocessError extends AgentSDKError {\n constructor(message: string, options?: ErrorOptions) {\n super(message, options);\n this.name = \"SubprocessError\";\n }\n}\n\n/** Thrown when a required peer dependency is not installed */\nexport class DependencyError extends AgentSDKError {\n public readonly packageName: string;\n\n constructor(packageName: string) {\n super(`${packageName} is not installed. Install it: npm install ${packageName}`);\n this.name = \"DependencyError\";\n this.packageName = packageName;\n }\n}\n\n/** Thrown when an agent run is aborted */\nexport class AbortError extends AgentSDKError {\n constructor() {\n super(\"Agent run was aborted.\");\n this.name = \"AbortError\";\n }\n}\n\n/** Thrown when a tool execution fails */\nexport class ToolExecutionError extends AgentSDKError {\n public readonly toolName: string;\n\n constructor(toolName: string, message: string, options?: ErrorOptions) {\n super(`Tool \"${toolName}\" failed: ${message}`, options);\n this.name = \"ToolExecutionError\";\n this.toolName = toolName;\n }\n}\n\n/** Thrown when structured output parsing fails */\nexport class StructuredOutputError extends AgentSDKError {\n constructor(message: string, options?: ErrorOptions) {\n super(`Structured output error: ${message}`, options);\n this.name = \"StructuredOutputError\";\n }\n}\n","import type {\n IAgent,\n AgentConfig,\n AgentState,\n AgentResult,\n AgentEvent,\n MessageContent,\n Message,\n RunOptions,\n StructuredOutputConfig,\n UsageData,\n} from \"./types.js\";\nimport { ReentrancyError, DisposedError, AbortError } from \"./errors.js\";\n\n/** Abstract base agent with shared lifecycle logic.\n * Concrete backends extend this and implement the protected _run/_stream methods. */\nexport abstract class BaseAgent implements IAgent {\n protected state: AgentState = \"idle\";\n protected abortController: AbortController | null = null;\n protected readonly config: AgentConfig;\n\n /** Backend identifier (e.g. \"copilot\", \"claude\", \"vercel-ai\") */\n protected abstract readonly backendName: string;\n\n /** CLI session ID for persistent mode. Override in backends that support it. */\n get sessionId(): string | undefined {\n return undefined;\n }\n\n constructor(config: AgentConfig) {\n this.config = Object.freeze({ ...config });\n }\n\n // ─── Public Interface ─────────────────────────────────────────\n\n async run(\n prompt: MessageContent,\n options?: RunOptions,\n ): Promise<AgentResult> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const result = await this.executeRun(messages, options, ac.signal);\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async runWithContext(\n messages: Message[],\n options?: RunOptions,\n ): Promise<AgentResult> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const result = await this.executeRun(messages, options, ac.signal);\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async runStructured<T>(\n prompt: MessageContent,\n schema: StructuredOutputConfig<T>,\n options?: RunOptions,\n ): Promise<AgentResult<T>> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"running\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const result = await this.executeRunStructured(\n messages,\n schema,\n options,\n ac.signal,\n );\n this.enrichAndNotifyUsage(result);\n return result;\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async *stream(\n prompt: MessageContent,\n options?: RunOptions,\n ): AsyncIterable<AgentEvent> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"streaming\";\n\n try {\n const messages: Message[] = [{ role: \"user\", content: prompt }];\n const enriched = this.enrichStream(this.executeStream(messages, options, ac.signal));\n yield* this.heartbeatStream(enriched);\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n async *streamWithContext(\n messages: Message[],\n options?: RunOptions,\n ): AsyncIterable<AgentEvent> {\n this.guardReentrancy();\n this.guardDisposed();\n\n const ac = this.createAbortController(options?.signal);\n this.state = \"streaming\";\n\n try {\n const enriched = this.enrichStream(this.executeStream(messages, options, ac.signal));\n yield* this.heartbeatStream(enriched);\n } finally {\n this.state = \"idle\";\n this.abortController = null;\n }\n }\n\n abort(): void {\n if (this.abortController) {\n this.abortController.abort();\n }\n }\n\n /** Default interrupt — falls back to abort(). Backends may override with graceful shutdown. */\n async interrupt(): Promise<void> {\n this.abort();\n }\n\n getState(): AgentState {\n return this.state;\n }\n\n getConfig(): Readonly<AgentConfig> {\n return this.config;\n }\n\n /** Mark agent as disposed. Override to add cleanup. */\n dispose(): void {\n this.abort();\n this.state = \"disposed\";\n }\n\n // ─── Abstract Methods (implemented by backends) ───────────────\n\n /** Execute a blocking run. Backend implements the actual LLM call. */\n protected abstract executeRun(\n messages: Message[],\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult>;\n\n /** Execute a structured output run. Backend implements parsing. */\n protected abstract executeRunStructured<T>(\n messages: Message[],\n schema: StructuredOutputConfig<T>,\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult<T>>;\n\n /** Execute a streaming run. Backend yields events. */\n protected abstract executeStream(\n messages: Message[],\n options: RunOptions | undefined,\n signal: AbortSignal,\n ): AsyncIterable<AgentEvent>;\n\n // ─── Usage Enrichment ───────────────────────────────────────────\n\n /** Enrich result usage with model/backend and fire onUsage callback */\n private enrichAndNotifyUsage(result: AgentResult<unknown>): void {\n if (result.usage) {\n result.usage = {\n ...result.usage,\n model: this.config.model,\n backend: this.backendName,\n };\n this.callOnUsage(result.usage);\n }\n }\n\n /** Wrap a stream to enrich usage_update events and fire onUsage callback */\n private async *enrichStream(\n source: AsyncIterable<AgentEvent>,\n ): AsyncIterable<AgentEvent> {\n for await (const event of source) {\n if (event.type === \"usage_update\") {\n const usage: UsageData = {\n promptTokens: event.promptTokens,\n completionTokens: event.completionTokens,\n model: this.config.model,\n backend: this.backendName,\n };\n this.callOnUsage(usage);\n yield { type: \"usage_update\", ...usage };\n } else {\n yield event;\n }\n }\n }\n\n /** Fire onUsage callback (fire-and-forget: errors logged, not propagated) */\n private callOnUsage(usage: UsageData): void {\n if (!this.config.onUsage) return;\n try {\n this.config.onUsage(usage);\n } catch (e) {\n console.warn(\n \"[agent-sdk] onUsage callback error:\",\n e instanceof Error ? e.message : String(e),\n );\n }\n }\n\n // ─── Heartbeat ───────────────────────────────────────────────\n\n /** Wrap a stream to emit heartbeat events at configured intervals.\n * When heartbeatInterval is not set, passes through directly. */\n private async *heartbeatStream(\n source: AsyncIterable<AgentEvent>,\n ): AsyncIterable<AgentEvent> {\n const interval = this.config.heartbeatInterval;\n if (!interval || interval <= 0) {\n yield* source;\n return;\n }\n\n const iterator = source[Symbol.asyncIterator]();\n let pendingEvent: Promise<IteratorResult<AgentEvent>> | null = null;\n let heartbeatResolve: (() => void) | null = null;\n\n const timer = setInterval(() => {\n if (heartbeatResolve) {\n const resolve = heartbeatResolve;\n heartbeatResolve = null;\n resolve();\n }\n }, interval);\n\n try {\n while (true) {\n if (!pendingEvent) {\n pendingEvent = iterator.next();\n }\n\n const heartbeatPromise = new Promise<void>((resolve) => {\n heartbeatResolve = resolve;\n });\n\n const eventDone = pendingEvent.then(\n (r) => ({ kind: \"event\" as const, result: r }),\n );\n const heartbeatDone = heartbeatPromise.then(\n () => ({ kind: \"heartbeat\" as const }),\n );\n\n const winner = await Promise.race([eventDone, heartbeatDone]);\n\n if (winner.kind === \"heartbeat\") {\n yield { type: \"heartbeat\" };\n } else {\n pendingEvent = null;\n heartbeatResolve = null;\n if (winner.result.done) break;\n yield winner.result.value;\n }\n }\n } finally {\n clearInterval(timer);\n heartbeatResolve = null;\n }\n }\n\n // ─── Guards ───────────────────────────────────────────────────\n\n protected guardReentrancy(): void {\n if (this.state === \"running\" || this.state === \"streaming\") {\n throw new ReentrancyError();\n }\n }\n\n protected guardDisposed(): void {\n if (this.state === \"disposed\") {\n throw new DisposedError(\"Agent\");\n }\n }\n\n /** Throw AbortError if signal is already aborted */\n protected checkAbort(signal: AbortSignal): void {\n if (signal.aborted) {\n throw new AbortError();\n }\n }\n\n // ─── Internal Helpers ─────────────────────────────────────────\n\n private createAbortController(externalSignal?: AbortSignal): AbortController {\n const ac = new AbortController();\n this.abortController = ac;\n\n if (externalSignal) {\n if (externalSignal.aborted) {\n ac.abort();\n } else {\n externalSignal.addEventListener(\"abort\", () => ac.abort(), {\n once: true,\n });\n }\n }\n\n return ac;\n }\n}\n","import type { z } from \"zod\";\n\n/** Convert a Zod schema to JSON Schema.\n * Detection order: toJSONSchema() (Zod v4) → jsonSchema() (Zod v3.24+) → _def extraction (Zod v3 legacy). */\nexport function zodToJsonSchema(schema: z.ZodType): Record<string, unknown> {\n const schemaAny = schema as unknown as Record<string, unknown>;\n\n // Zod v4: toJSONSchema()\n if (\"toJSONSchema\" in schema && typeof schemaAny.toJSONSchema === \"function\") {\n return (schemaAny.toJSONSchema as () => Record<string, unknown>)();\n }\n\n // Zod v3.24+: jsonSchema()\n if (\"jsonSchema\" in schema && typeof schemaAny.jsonSchema === \"function\") {\n return (schemaAny.jsonSchema as () => Record<string, unknown>)();\n }\n\n // Zod v3 legacy: _def.typeName extraction\n return extractSchemaFromDef(schema);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction extractSchemaFromDef(schema: z.ZodType): Record<string, unknown> {\n const def = (schema as unknown as { _def: Record<string, any> })._def;\n const typeName = def.typeName as string;\n\n switch (typeName) {\n case \"ZodString\":\n return { type: \"string\" };\n case \"ZodNumber\":\n return { type: \"number\" };\n case \"ZodBoolean\":\n return { type: \"boolean\" };\n case \"ZodNull\":\n return { type: \"null\" };\n case \"ZodArray\":\n return {\n type: \"array\",\n items: extractSchemaFromDef(def.type as z.ZodType),\n };\n case \"ZodObject\": {\n const shape = (schema as unknown as { shape: Record<string, z.ZodType> }).shape;\n const properties: Record<string, unknown> = {};\n const required: string[] = [];\n\n for (const [key, value] of Object.entries(shape)) {\n const valueDef = (value as unknown as { _def: Record<string, any> })._def;\n if (valueDef.typeName === \"ZodOptional\") {\n properties[key] = extractSchemaFromDef(valueDef.innerType as z.ZodType);\n } else {\n properties[key] = extractSchemaFromDef(value);\n required.push(key);\n }\n }\n\n return {\n type: \"object\",\n properties,\n ...(required.length > 0 ? { required } : {}),\n };\n }\n case \"ZodOptional\":\n return extractSchemaFromDef(def.innerType as z.ZodType);\n case \"ZodEnum\":\n return { type: \"string\", enum: def.values as string[] };\n default:\n return {};\n }\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n","import type {\n IAgent,\n IAgentService,\n AgentConfig,\n AgentResult,\n AgentEvent,\n Message,\n RunOptions,\n StructuredOutputConfig,\n ToolDefinition,\n ClaudeBackendOptions,\n ModelInfo,\n ValidationResult,\n JSONValue,\n PermissionRequest as UnifiedPermissionRequest,\n PermissionDecision,\n PermissionScope,\n} from \"../types.js\";\nimport { getTextContent } from \"../types.js\";\nimport { BaseAgent } from \"../base-agent.js\";\nimport { DisposedError, SubprocessError, AbortError } from \"../errors.js\";\nimport { zodToJsonSchema } from \"../utils/schema.js\";\n\nexport type { ClaudeBackendOptions } from \"../types.js\";\n\n// ─── Local Type Definitions (matching @anthropic-ai/claude-agent-sdk shapes) ──\n// Avoids requiring the SDK to be installed at compile time.\n\n/** @internal Claude SDK PermissionUpdate destination */\ntype PermissionUpdateDestination =\n | \"userSettings\"\n | \"projectSettings\"\n | \"localSettings\"\n | \"session\"\n | \"cliArg\";\n\n/** @internal Claude SDK PermissionUpdate */\ninterface SDKPermissionUpdate {\n type: \"addRules\" | \"replaceRules\" | \"removeRules\" | \"setMode\" | \"addDirectories\" | \"removeDirectories\";\n destination: PermissionUpdateDestination;\n [key: string]: unknown;\n}\n\n/** @internal Claude SDK PermissionResult */\ntype SDKPermissionResult =\n | {\n behavior: \"allow\";\n updatedInput?: Record<string, unknown>;\n updatedPermissions?: SDKPermissionUpdate[];\n toolUseID?: string;\n }\n | {\n behavior: \"deny\";\n message: string;\n interrupt?: boolean;\n toolUseID?: string;\n };\n\n/** @internal Claude SDK CanUseTool callback */\ntype SDKCanUseTool = (\n toolName: string,\n input: Record<string, unknown>,\n options: {\n signal: AbortSignal;\n suggestions?: SDKPermissionUpdate[];\n blockedPath?: string;\n decisionReason?: string;\n toolUseID: string;\n agentID?: string;\n },\n) => Promise<SDKPermissionResult>;\n\n/** @internal Claude SDK Options */\ninterface SDKOptions {\n abortController?: AbortController;\n allowedTools?: string[];\n canUseTool?: SDKCanUseTool;\n cwd?: string;\n disallowedTools?: string[];\n env?: { [envVar: string]: string | undefined };\n includePartialMessages?: boolean;\n maxTurns?: number;\n model?: string;\n outputFormat?: { type: \"json_schema\"; schema: Record<string, unknown> };\n pathToClaudeCodeExecutable?: string;\n permissionMode?: string;\n persistSession?: boolean;\n resume?: string;\n sessionId?: string;\n systemPrompt?:\n | string\n | { type: \"preset\"; preset: \"claude_code\"; append?: string };\n mcpServers?: Record<string, unknown>;\n}\n\n/** @internal Claude SDK ModelInfo */\ninterface SDKModelInfo {\n value: string;\n displayName: string;\n description: string;\n}\n\n/** @internal Claude SDK ResultSuccess */\ninterface SDKResultSuccess {\n type: \"result\";\n subtype: \"success\";\n result: string;\n structured_output?: unknown;\n num_turns: number;\n total_cost_usd: number;\n usage: Record<string, number>;\n modelUsage: Record<string, { inputTokens: number; outputTokens: number }>;\n session_id: string;\n}\n\n/** @internal Claude SDK ResultError */\ninterface SDKResultError {\n type: \"result\";\n subtype: string;\n errors: string[];\n is_error: boolean;\n usage: Record<string, number>;\n modelUsage: Record<string, { inputTokens: number; outputTokens: number }>;\n session_id: string;\n}\n\n/** @internal Claude SDK message union */\ninterface SDKMessage {\n type: string;\n subtype?: string;\n [key: string]: unknown;\n}\n\n/** @internal Claude SDK Query interface — AsyncGenerator<SDKMessage> with control methods */\ninterface SDKQuery extends AsyncGenerator<SDKMessage, void> {\n close(): void;\n interrupt(): Promise<void>;\n supportedModels(): Promise<SDKModelInfo[]>;\n}\n\n/** @internal SDK's MCP tool definition */\ninterface SDKMcpToolDefinition {\n name: string;\n description: string;\n inputSchema: Record<string, unknown>;\n handler: (args: Record<string, unknown>, extra: unknown) => Promise<{ content: Array<{ type: string; text: string }> }>;\n}\n\n/** @internal SDK server config */\ninterface SDKMcpServerConfigWithInstance {\n type: \"sdk\";\n name: string;\n instance: unknown;\n}\n\n/** @internal */\ntype SDKModule = {\n query: (params: { prompt: string; options?: SDKOptions }) => SDKQuery;\n createSdkMcpServer: (options: {\n name: string;\n version?: string;\n tools?: SDKMcpToolDefinition[];\n }) => SDKMcpServerConfigWithInstance;\n tool: (\n name: string,\n description: string,\n inputSchema: Record<string, unknown>,\n handler: (args: Record<string, unknown>, extra: unknown) => Promise<{ content: Array<{ type: string; text: string }> }>,\n ) => SDKMcpToolDefinition;\n};\n\n// ─── Dynamic SDK Loader ─────────────────────────────────────────\n\nlet sdkModule: SDKModule | null = null;\n\nasync function loadSDK(): Promise<SDKModule> {\n if (sdkModule) return sdkModule;\n try {\n // @ts-ignore — peer dependency, not present at compile time\n sdkModule = (await import(\"@anthropic-ai/claude-agent-sdk\")) as SDKModule;\n return sdkModule!;\n } catch {\n throw new SubprocessError(\n \"@anthropic-ai/claude-agent-sdk is not installed. Install it: npm install @anthropic-ai/claude-agent-sdk\",\n );\n }\n}\n\n/** @internal For testing: inject mock SDK module */\nexport function _injectSDK(mock: SDKModule | null): void {\n sdkModule = mock;\n}\n\n/** @internal For testing: reset injected SDK */\nexport function _resetSDK(): void {\n sdkModule = null;\n}\n\n// ─── Known Models ───────────────────────────────────────────────\n\nconst ANTHROPIC_MODELS_URL = \"https://api.anthropic.com/v1/models\";\nconst ANTHROPIC_API_VERSION = \"2023-06-01\";\nconst ANTHROPIC_OAUTH_BETA = \"oauth-2025-04-20\";\n\n// ─── Tool Mapping ───────────────────────────────────────────────\n\nfunction buildMcpServer(\n sdk: SDKModule,\n tools: ToolDefinition[],\n toolResultCapture?: Map<string, JSONValue>,\n): SDKMcpServerConfigWithInstance | undefined {\n if (tools.length === 0) return undefined;\n\n const mcpTools = tools.map((tool) =>\n sdk.tool(\n tool.name,\n tool.description ?? \"\",\n zodToJsonSchema(tool.parameters) as Record<string, unknown>,\n async (args: Record<string, unknown>) => {\n const result = await tool.execute(args);\n // Capture result for AgentResult.toolCalls\n if (toolResultCapture) {\n toolResultCapture.set(tool.name, result as JSONValue);\n }\n return {\n content: [\n {\n type: \"text\" as const,\n text: typeof result === \"string\" ? result : JSON.stringify(result),\n },\n ],\n };\n },\n ),\n );\n\n return sdk.createSdkMcpServer({\n name: \"agent-sdk-tools\",\n version: \"1.0.0\",\n tools: mcpTools,\n });\n}\n\n// ─── Permission Mapping ─────────────────────────────────────────\n\n/** Map our PermissionScope to Claude SDK's PermissionUpdateDestination */\nfunction scopeToDestination(scope: PermissionScope): PermissionUpdateDestination {\n switch (scope) {\n case \"once\":\n return \"session\";\n case \"session\":\n return \"session\";\n case \"project\":\n return \"projectSettings\";\n case \"always\":\n return \"userSettings\";\n }\n}\n\n/** Map Claude SDK suggestions to our PermissionScope */\nfunction destinationToScope(dest: PermissionUpdateDestination): PermissionScope {\n switch (dest) {\n case \"session\":\n case \"cliArg\":\n return \"session\";\n case \"projectSettings\":\n case \"localSettings\":\n return \"project\";\n case \"userSettings\":\n return \"always\";\n }\n}\n\n/** Extract best suggestedScope from SDK's PermissionUpdate[] */\nfunction extractSuggestedScope(\n suggestions?: SDKPermissionUpdate[],\n): PermissionScope | undefined {\n if (!suggestions || suggestions.length === 0) return undefined;\n // Use the destination of the first suggestion as the scope hint\n return destinationToScope(suggestions[0].destination);\n}\n\nfunction buildCanUseTool(\n config: AgentConfig,\n): SDKCanUseTool | undefined {\n const onPermission = config.supervisor?.onPermission;\n if (!onPermission) return undefined;\n\n const permissionStore = config.permissionStore;\n\n return async (\n toolName: string,\n input: Record<string, unknown>,\n options,\n ): Promise<SDKPermissionResult> => {\n // Check store first — if already approved, skip callback\n if (permissionStore && await permissionStore.isApproved(toolName)) {\n return {\n behavior: \"allow\",\n toolUseID: options.toolUseID,\n };\n }\n\n const unifiedRequest: UnifiedPermissionRequest = {\n toolName,\n toolArgs: input,\n suggestedScope: extractSuggestedScope(options.suggestions),\n rawSDKRequest: { toolName, input, ...options },\n };\n\n const decision: PermissionDecision = await onPermission(\n unifiedRequest,\n options.signal,\n );\n\n if (decision.allowed) {\n // Persist approval to store\n if (permissionStore && decision.scope) {\n await permissionStore.approve(toolName, decision.scope);\n }\n\n const result: SDKPermissionResult = {\n behavior: \"allow\",\n toolUseID: options.toolUseID,\n };\n if (decision.modifiedInput) {\n (result as { updatedInput?: Record<string, unknown> }).updatedInput =\n decision.modifiedInput;\n }\n // Map scope decision to SDK's updatedPermissions\n if (decision.scope && decision.scope !== \"once\" && options.suggestions) {\n (result as { updatedPermissions?: SDKPermissionUpdate[] }).updatedPermissions =\n options.suggestions.map((s) => ({\n ...s,\n destination: scopeToDestination(decision.scope!),\n }));\n }\n return result;\n }\n\n return {\n behavior: \"deny\",\n message: decision.reason ?? \"Permission denied\",\n toolUseID: options.toolUseID,\n };\n };\n}\n\n// ─── Usage Aggregation Helper ───────────────────────────────────\n\nfunction aggregateUsage(\n modelUsage?: Record<string, { inputTokens: number; outputTokens: number }>,\n): { promptTokens: number; completionTokens: number } {\n let promptTokens = 0;\n let completionTokens = 0;\n for (const u of Object.values(modelUsage ?? {})) {\n promptTokens += u.inputTokens ?? 0;\n completionTokens += u.outputTokens ?? 0;\n }\n return { promptTokens, completionTokens };\n}\n\n// ─── Event Mapping ──────────────────────────────────────────────\n\n/**\n * Tracks tool call IDs to tool names for Claude backend.\n *\n * The Claude SDK emits tool_use blocks (with `id` and `name`) in assistant messages,\n * but tool_use_summary messages only carry `tool_name` (and optionally\n * `preceding_tool_use_ids`). This tracker correlates start/end events using a\n * per-tool-name FIFO queue to handle parallel calls to the same tool.\n */\nclass ClaudeToolCallTracker {\n private queues = new Map<string, string[]>();\n\n trackStart(toolCallId: string, toolName: string): void {\n if (!this.queues.has(toolName)) {\n this.queues.set(toolName, []);\n }\n this.queues.get(toolName)!.push(toolCallId);\n }\n\n /** Peek at the current tool call ID for a tool name (does not consume) */\n peekToolCallId(toolName: string): string {\n const queue = this.queues.get(toolName);\n if (!queue || queue.length === 0) return \"\";\n return queue[0];\n }\n\n /** Consume and return the first tool call ID for a tool name */\n consumeToolCallId(toolName: string): string {\n const queue = this.queues.get(toolName);\n if (!queue || queue.length === 0) return \"\";\n return queue.shift()!;\n }\n\n clear(): void {\n this.queues.clear();\n }\n}\n\nfunction mapSDKMessage(msg: SDKMessage, thinkingBlockIndices?: Set<number>, toolCallTracker?: ClaudeToolCallTracker): AgentEvent | AgentEvent[] | null {\n switch (msg.type) {\n case \"assistant\": {\n // Full assistant message — contains BetaMessage with content blocks\n const betaMessage = msg.message as {\n content?: Array<{\n type: string;\n text?: string;\n name?: string;\n input?: unknown;\n id?: string;\n }>;\n } | undefined;\n if (!betaMessage?.content) return null;\n\n const events: AgentEvent[] = [];\n\n // Extract text content from the message\n const textParts = betaMessage.content\n .filter((b) => b.type === \"text\" && b.text)\n .map((b) => b.text!)\n .join(\"\");\n\n if (textParts) {\n events.push({ type: \"text_delta\", text: textParts });\n }\n\n // Emit tool_call_start for each tool_use block\n for (const block of betaMessage.content) {\n if (block.type === \"tool_use\") {\n const toolCallId = String(block.id ?? \"\");\n const toolName = block.name ?? \"unknown\";\n if (toolCallTracker) {\n toolCallTracker.trackStart(toolCallId, toolName);\n }\n events.push({\n type: \"tool_call_start\",\n toolCallId,\n toolName,\n args: (block.input as JSONValue) ?? {},\n });\n }\n }\n\n return events.length > 0 ? events : null;\n }\n\n case \"user\": {\n // User messages with tool_use_result indicate tool completion\n const toolResult = msg.tool_use_result as JSONValue | undefined;\n // Extract tool name from the message context if available\n if (toolResult !== undefined) {\n // The user message after tool execution — emit tool_call_end\n // tool_name may not be in user messages, but we can infer from context\n return null; // Handled via tool_use_summary below\n }\n return null;\n }\n\n case \"tool_use_summary\": {\n // Emitted after tool execution — contains summary of tool results\n const summary = msg.summary as string | undefined;\n const toolName = (msg.tool_name as string | undefined) ?? \"unknown\";\n // Resolve toolCallId: prefer preceding_tool_use_ids, fall back to tracker\n const precedingIds = msg.preceding_tool_use_ids as string[] | undefined;\n let toolCallId = \"\";\n if (precedingIds && precedingIds.length > 0) {\n toolCallId = precedingIds[0];\n // Consume from tracker to keep queue in sync\n if (toolCallTracker) toolCallTracker.consumeToolCallId(toolName);\n } else if (toolCallTracker) {\n toolCallId = toolCallTracker.consumeToolCallId(toolName);\n }\n // Emit as tool_call_end with summary as result\n if (summary) {\n return {\n type: \"tool_call_end\",\n toolCallId,\n toolName,\n result: summary as JSONValue,\n };\n }\n return null;\n }\n\n case \"stream_event\": {\n // Partial streaming events — BetaRawMessageStreamEvent\n const event = msg.event as {\n type: string;\n delta?: { type: string; text?: string };\n content_block?: { type: string; name?: string; id?: string };\n index?: number;\n } | undefined;\n if (!event) return null;\n\n if (\n event.type === \"content_block_delta\" &&\n event.delta?.type === \"text_delta\" &&\n event.delta.text\n ) {\n return { type: \"text_delta\", text: event.delta.text };\n }\n\n if (event.type === \"content_block_start\" && event.content_block?.type === \"thinking\") {\n if (thinkingBlockIndices && event.index !== undefined) {\n thinkingBlockIndices.add(event.index);\n }\n return { type: \"thinking_start\" };\n }\n\n if (event.type === \"content_block_stop\" && event.index !== undefined && thinkingBlockIndices?.has(event.index)) {\n thinkingBlockIndices.delete(event.index);\n return { type: \"thinking_end\" };\n }\n\n return null;\n }\n\n case \"tool_progress\": {\n const toolName = msg.tool_name as string | undefined;\n if (!toolName) return null;\n const toolCallId = toolCallTracker?.peekToolCallId(toolName) ?? \"\";\n return { type: \"tool_call_start\", toolCallId, toolName, args: {} };\n }\n\n case \"result\": {\n if (msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n return {\n type: \"usage_update\",\n ...aggregateUsage(r.modelUsage),\n };\n }\n if (msg.is_error) {\n const r = msg as unknown as SDKResultError;\n return {\n type: \"error\",\n error: r.errors?.join(\"; \") ?? \"Unknown error\",\n recoverable: false,\n };\n }\n return null;\n }\n\n default:\n return null;\n }\n}\n\n// ─── ClaudeAgent ────────────────────────────────────────────────\n\nclass ClaudeAgent extends BaseAgent {\n protected readonly backendName = \"claude\";\n private readonly options: ClaudeBackendOptions;\n private readonly tools: ToolDefinition[];\n private readonly canUseTool: SDKCanUseTool | undefined;\n private readonly isPersistent: boolean;\n private _sessionId: string | undefined;\n private activeQuery: SDKQuery | null = null;\n\n constructor(config: AgentConfig, options: ClaudeBackendOptions) {\n super(config);\n this.options = options;\n this.tools = config.tools;\n this.canUseTool = buildCanUseTool(config);\n this.isPersistent = config.sessionMode === \"persistent\";\n\n // Warn if onAskUser is set — Claude CLI SDK doesn't support user interaction hooks\n if (config.supervisor?.onAskUser) {\n console.warn(\n \"[agent-sdk/claude] supervisor.onAskUser is not supported by the Claude CLI backend. \" +\n \"User interaction requests from the model will not be forwarded.\",\n );\n }\n }\n\n override get sessionId(): string | undefined {\n return this._sessionId;\n }\n\n override async interrupt(): Promise<void> {\n try {\n if (this.activeQuery) {\n await this.activeQuery.interrupt();\n }\n } catch {\n // fire-and-forget: SDK interrupt errors should not prevent abort\n } finally {\n this.abort();\n }\n }\n\n /** Clear persistent session state after an error so next call starts fresh */\n private clearPersistentSession(): void {\n this._sessionId = undefined;\n }\n\n private emitSessionInfo(sessionId: string): AgentEvent {\n const home = process.env.HOME ?? process.env.USERPROFILE ?? \"\";\n const transcriptPath = home\n ? `${home}/.claude/projects/.session/sessions/${sessionId}/conversation.jsonl`\n : undefined;\n return { type: \"session_info\", sessionId, transcriptPath, backend: \"claude\" };\n }\n\n private buildQueryOptions(signal: AbortSignal): SDKOptions {\n const ac = new AbortController();\n // Link external signal → SDK's abort controller\n signal.addEventListener(\"abort\", () => ac.abort(), { once: true });\n\n const opts: SDKOptions = {\n abortController: ac,\n model: this.config.model,\n maxTurns: this.options.maxTurns,\n cwd: this.options.workingDirectory,\n pathToClaudeCodeExecutable: this.options.cliPath,\n persistSession: this.isPersistent,\n includePartialMessages: true,\n canUseTool: this.canUseTool,\n };\n\n // Resume persistent session on subsequent calls\n if (this.isPersistent && this._sessionId) {\n opts.resume = this._sessionId;\n }\n\n if (this.config.systemPrompt) {\n opts.systemPrompt = this.config.systemPrompt;\n }\n\n if (this.options.oauthToken || this.options.env) {\n opts.env = {\n ...process.env,\n ...(this.options.env ?? {}),\n ...(this.options.oauthToken\n ? { CLAUDE_CODE_OAUTH_TOKEN: this.options.oauthToken }\n : {}),\n };\n }\n\n // Auto-set permissionMode when canUseTool is configured so Claude CLI\n // actually invokes the callback instead of using built-in rules.\n if (opts.canUseTool && !opts.permissionMode) {\n opts.permissionMode = \"default\";\n }\n\n return opts;\n }\n\n private async buildMcpConfig(\n opts: SDKOptions,\n toolResultCapture?: Map<string, JSONValue>,\n ): Promise<SDKOptions> {\n if (this.tools.length === 0) return opts;\n\n const sdk = await loadSDK();\n const mcpServer = buildMcpServer(sdk, this.tools, toolResultCapture);\n if (mcpServer) {\n opts.mcpServers = {\n \"agent-sdk-tools\": mcpServer,\n };\n }\n return opts;\n }\n\n // ─── executeRun ─────────────────────────────────────────────────\n\n protected async executeRun(\n messages: Message[],\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n const toolResultCapture = new Map<string, JSONValue>();\n opts = await this.buildMcpConfig(opts, toolResultCapture);\n\n const q = sdk.query({ prompt, options: opts });\n this.activeQuery = q;\n const toolCalls: AgentResult[\"toolCalls\"] = [];\n let output: string | null = null;\n let usage: AgentResult[\"usage\"];\n\n try {\n for await (const msg of q) {\n // Collect tool calls from assistant messages\n if (msg.type === \"assistant\") {\n const betaMessage = msg.message as {\n content?: Array<{\n type: string;\n text?: string;\n name?: string;\n input?: unknown;\n id?: string;\n }>;\n } | undefined;\n if (betaMessage?.content) {\n for (const block of betaMessage.content) {\n if (block.type === \"tool_use\") {\n const toolName = block.name ?? \"unknown\";\n toolCalls.push({\n toolName,\n args: (block.input as JSONValue) ?? {},\n result: toolResultCapture.get(toolName) ?? null,\n approved: true,\n });\n }\n }\n }\n }\n\n // Back-fill results from capture map for previously added tool calls\n if (msg.type === \"tool_use_summary\" || msg.type === \"result\") {\n for (const tc of toolCalls) {\n if (tc.result === null) {\n const captured = toolResultCapture.get(tc.toolName);\n if (captured !== undefined) tc.result = captured;\n }\n }\n }\n\n // Capture result and session_id\n if (msg.type === \"result\") {\n if (msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n output = r.result;\n usage = aggregateUsage(r.modelUsage);\n if (this.isPersistent && r.session_id) {\n this._sessionId = r.session_id;\n }\n } else if (msg.is_error) {\n const r = msg as unknown as SDKResultError;\n throw new Error(\n `Claude query failed: ${r.errors?.join(\"; \") ?? \"unknown error\"}`,\n );\n }\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n } finally {\n this.activeQuery = null;\n }\n\n return {\n output,\n structuredOutput: undefined as AgentResult[\"structuredOutput\"],\n toolCalls,\n messages: [\n ...messages,\n ...(output !== null\n ? [{ role: \"assistant\" as const, content: output }]\n : []),\n ],\n usage,\n };\n }\n\n // ─── executeRunStructured ───────────────────────────────────────\n\n protected async executeRunStructured<T>(\n messages: Message[],\n schema: StructuredOutputConfig<T>,\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): Promise<AgentResult<T>> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n opts = await this.buildMcpConfig(opts);\n\n // Claude SDK has native structured output via outputFormat\n const jsonSchema = zodToJsonSchema(schema.schema);\n opts.outputFormat = {\n type: \"json_schema\",\n schema: jsonSchema as Record<string, unknown>,\n };\n\n const q = sdk.query({ prompt, options: opts });\n this.activeQuery = q;\n const toolCalls: AgentResult[\"toolCalls\"] = [];\n let output: string | null = null;\n let structuredOutput: T | undefined;\n let usage: AgentResult[\"usage\"];\n\n try {\n for await (const msg of q) {\n if (msg.type === \"result\" && msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n output = r.result;\n\n // Claude SDK returns parsed structured_output when using outputFormat\n if (r.structured_output !== undefined) {\n try {\n structuredOutput = schema.schema.parse(r.structured_output);\n } catch {\n // Fallback: try parsing result string\n try {\n structuredOutput = schema.schema.parse(JSON.parse(r.result));\n } catch {\n // Leave undefined\n }\n }\n } else if (r.result) {\n // Fallback: parse from result string\n try {\n const jsonMatch = r.result.match(/```(?:json)?\\s*([\\s\\S]*?)```/);\n const raw = jsonMatch ? jsonMatch[1]!.trim() : r.result.trim();\n structuredOutput = schema.schema.parse(JSON.parse(raw));\n } catch {\n // Leave undefined\n }\n }\n\n usage = aggregateUsage(r.modelUsage);\n if (this.isPersistent && r.session_id) {\n this._sessionId = r.session_id;\n }\n } else if (msg.type === \"result\" && msg.is_error) {\n const r = msg as unknown as SDKResultError;\n throw new Error(\n `Claude query failed: ${r.errors?.join(\"; \") ?? \"unknown error\"}`,\n );\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n } finally {\n this.activeQuery = null;\n }\n\n return {\n output,\n structuredOutput: structuredOutput as AgentResult<T>[\"structuredOutput\"],\n toolCalls,\n messages: [\n ...messages,\n ...(output !== null\n ? [{ role: \"assistant\" as const, content: output }]\n : []),\n ],\n usage,\n };\n }\n\n // ─── executeStream ──────────────────────────────────────────────\n\n protected async *executeStream(\n messages: Message[],\n _options: RunOptions | undefined,\n signal: AbortSignal,\n ): AsyncIterable<AgentEvent> {\n this.checkAbort(signal);\n\n const sdk = await loadSDK();\n const isResuming = this.isPersistent && this._sessionId !== undefined;\n const prompt = isResuming\n ? extractLastUserPrompt(messages)\n : buildContextualPrompt(messages);\n let opts = this.buildQueryOptions(signal);\n opts = await this.buildMcpConfig(opts);\n\n const q = sdk.query({ prompt, options: opts });\n this.activeQuery = q;\n const thinkingBlockIndices = new Set<number>();\n const toolCallTracker = new ClaudeToolCallTracker();\n\n try {\n for await (const msg of q) {\n if (signal.aborted) throw new AbortError();\n\n const event = mapSDKMessage(msg, thinkingBlockIndices, toolCallTracker);\n if (event) {\n if (Array.isArray(event)) {\n for (const e of event) yield e;\n } else {\n yield event;\n }\n }\n\n // Capture session_id and emit done event on result\n if (msg.type === \"result\" && msg.subtype === \"success\") {\n const r = msg as unknown as SDKResultSuccess;\n if (r.session_id) {\n if (this.isPersistent) {\n this._sessionId = r.session_id;\n }\n yield this.emitSessionInfo(r.session_id);\n }\n yield { type: \"done\", finalOutput: r.result };\n }\n }\n } catch (e) {\n if (this.isPersistent) this.clearPersistentSession();\n if (signal.aborted) throw new AbortError();\n throw e;\n } finally {\n this.activeQuery = null;\n }\n }\n\n override dispose(): void {\n this._sessionId = undefined;\n super.dispose();\n }\n}\n\n// ─── Helpers ────────────────────────────────────────────────────\n\nfunction extractLastUserPrompt(messages: Message[]): string {\n for (let i = messages.length - 1; i >= 0; i--) {\n const msg = messages[i];\n if (msg.role === \"user\") {\n return getTextContent(msg.content);\n }\n }\n return \"\";\n}\n\n/** Build prompt with conversation history for CLI backends that create fresh sessions */\nfunction buildContextualPrompt(messages: Message[]): string {\n if (messages.length <= 1) {\n return extractLastUserPrompt(messages);\n }\n\n const history = messages.slice(0, -1).map((msg) => {\n const text = msg.content ? getTextContent(msg.content) : \"\";\n return msg.role === \"user\" ? `User: ${text}` : `Assistant: ${text}`;\n }).join(\"\\n\");\n\n const lastPrompt = extractLastUserPrompt(messages);\n\n return `Conversation history:\\n${history}\\n\\nUser: ${lastPrompt}`;\n}\n\nclass ClaudeAgentService implements IAgentService {\n readonly name = \"claude\";\n private disposed = false;\n private readonly options: ClaudeBackendOptions;\n private cachedModels: ModelInfo[] | null = null;\n\n constructor(options: ClaudeBackendOptions) {\n this.options = options;\n }\n\n createAgent(config: AgentConfig): IAgent {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n return new ClaudeAgent(config, this.options);\n }\n\n async listModels(): Promise<ModelInfo[]> {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n if (this.cachedModels) return this.cachedModels;\n\n const token = this.options.oauthToken;\n if (!token) {\n return [];\n }\n\n const res = await globalThis.fetch(\n `${ANTHROPIC_MODELS_URL}?limit=100`,\n {\n headers: {\n Authorization: `Bearer ${token}`,\n \"anthropic-version\": ANTHROPIC_API_VERSION,\n \"anthropic-beta\": ANTHROPIC_OAUTH_BETA,\n },\n },\n );\n\n if (!res.ok) {\n return [];\n }\n\n const body = (await res.json()) as {\n data?: Array<{ id: string; display_name?: string }>;\n };\n\n if (!body.data || body.data.length === 0) {\n return [];\n }\n\n this.cachedModels = body.data.map((m) => ({\n id: m.id,\n name: m.display_name,\n provider: \"claude\",\n }));\n return this.cachedModels;\n }\n\n async validate(): Promise<ValidationResult> {\n if (this.disposed) throw new DisposedError(\"ClaudeAgentService\");\n\n const errors: string[] = [];\n try {\n await loadSDK();\n } catch (e) {\n errors.push(\n e instanceof Error ? e.message : String(e),\n );\n return { valid: false, errors };\n }\n\n // Verify CLI is accessible by attempting a minimal query\n try {\n const sdk = await loadSDK();\n const q = sdk.query({\n prompt: \"echo test\",\n options: {\n model: \"claude-sonnet-4-20250514\",\n pathToClaudeCodeExecutable: this.options.cliPath,\n cwd: this.options.workingDirectory,\n persistSession: false,\n maxTurns: 1,\n permissionMode: \"plan\",\n },\n });\n // Wait for first message (auth check)\n const first = await q.next();\n q.close();\n if (first.done) {\n errors.push(\"Claude CLI returned no messages — may not be authenticated.\");\n }\n } catch (e) {\n errors.push(\n `Failed to connect to Claude CLI: ${e instanceof Error ? e.message : String(e)}`,\n );\n }\n\n return { valid: errors.length === 0, errors };\n }\n\n async dispose(): Promise<void> {\n if (this.disposed) return;\n this.disposed = true;\n this.cachedModels = null;\n }\n}\n\n// ─── Factory ────────────────────────────────────────────────────\n\n/** Create Claude CLI backend service. */\nexport function createClaudeService(\n options: ClaudeBackendOptions,\n): IAgentService {\n return new ClaudeAgentService(options);\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { a as ClaudeBackendOptions, I as IAgentService } from '../types-CYtx9gvQ.cjs';
1
+ import { a as ClaudeBackendOptions, I as IAgentService } from '../types-CQEyww7V.cjs';
2
2
  import 'zod';
3
3
 
4
4
  /** @internal Claude SDK PermissionUpdate destination */
@@ -1,4 +1,4 @@
1
- import { a as ClaudeBackendOptions, I as IAgentService } from '../types-CYtx9gvQ.js';
1
+ import { a as ClaudeBackendOptions, I as IAgentService } from '../types-CQEyww7V.js';
2
2
  import 'zod';
3
3
 
4
4
  /** @internal Claude SDK PermissionUpdate destination */
@@ -130,6 +130,10 @@ var BaseAgent = class {
130
130
  this.abortController.abort();
131
131
  }
132
132
  }
133
+ /** Default interrupt — falls back to abort(). Backends may override with graceful shutdown. */
134
+ async interrupt() {
135
+ this.abort();
136
+ }
133
137
  getState() {
134
138
  return this.state;
135
139
  }
@@ -587,6 +591,7 @@ var ClaudeAgent = class extends BaseAgent {
587
591
  canUseTool;
588
592
  isPersistent;
589
593
  _sessionId;
594
+ activeQuery = null;
590
595
  constructor(config, options) {
591
596
  super(config);
592
597
  this.options = options;
@@ -602,10 +607,25 @@ var ClaudeAgent = class extends BaseAgent {
602
607
  get sessionId() {
603
608
  return this._sessionId;
604
609
  }
610
+ async interrupt() {
611
+ try {
612
+ if (this.activeQuery) {
613
+ await this.activeQuery.interrupt();
614
+ }
615
+ } catch {
616
+ } finally {
617
+ this.abort();
618
+ }
619
+ }
605
620
  /** Clear persistent session state after an error so next call starts fresh */
606
621
  clearPersistentSession() {
607
622
  this._sessionId = void 0;
608
623
  }
624
+ emitSessionInfo(sessionId) {
625
+ const home = process.env.HOME ?? process.env.USERPROFILE ?? "";
626
+ const transcriptPath = home ? `${home}/.claude/projects/.session/sessions/${sessionId}/conversation.jsonl` : void 0;
627
+ return { type: "session_info", sessionId, transcriptPath, backend: "claude" };
628
+ }
609
629
  buildQueryOptions(signal) {
610
630
  const ac = new AbortController();
611
631
  signal.addEventListener("abort", () => ac.abort(), { once: true });
@@ -625,8 +645,15 @@ var ClaudeAgent = class extends BaseAgent {
625
645
  if (this.config.systemPrompt) {
626
646
  opts.systemPrompt = this.config.systemPrompt;
627
647
  }
628
- if (this.options.oauthToken) {
629
- opts.env = { ...process.env, CLAUDE_CODE_OAUTH_TOKEN: this.options.oauthToken };
648
+ if (this.options.oauthToken || this.options.env) {
649
+ opts.env = {
650
+ ...process.env,
651
+ ...this.options.env ?? {},
652
+ ...this.options.oauthToken ? { CLAUDE_CODE_OAUTH_TOKEN: this.options.oauthToken } : {}
653
+ };
654
+ }
655
+ if (opts.canUseTool && !opts.permissionMode) {
656
+ opts.permissionMode = "default";
630
657
  }
631
658
  return opts;
632
659
  }
@@ -651,6 +678,7 @@ var ClaudeAgent = class extends BaseAgent {
651
678
  const toolResultCapture = /* @__PURE__ */ new Map();
652
679
  opts = await this.buildMcpConfig(opts, toolResultCapture);
653
680
  const q = sdk.query({ prompt, options: opts });
681
+ this.activeQuery = q;
654
682
  const toolCalls = [];
655
683
  let output = null;
656
684
  let usage;
@@ -700,6 +728,8 @@ var ClaudeAgent = class extends BaseAgent {
700
728
  if (this.isPersistent) this.clearPersistentSession();
701
729
  if (signal.aborted) throw new AbortError();
702
730
  throw e;
731
+ } finally {
732
+ this.activeQuery = null;
703
733
  }
704
734
  return {
705
735
  output,
@@ -726,6 +756,7 @@ var ClaudeAgent = class extends BaseAgent {
726
756
  schema: jsonSchema
727
757
  };
728
758
  const q = sdk.query({ prompt, options: opts });
759
+ this.activeQuery = q;
729
760
  const toolCalls = [];
730
761
  let output = null;
731
762
  let structuredOutput;
@@ -767,6 +798,8 @@ var ClaudeAgent = class extends BaseAgent {
767
798
  if (this.isPersistent) this.clearPersistentSession();
768
799
  if (signal.aborted) throw new AbortError();
769
800
  throw e;
801
+ } finally {
802
+ this.activeQuery = null;
770
803
  }
771
804
  return {
772
805
  output,
@@ -788,6 +821,7 @@ var ClaudeAgent = class extends BaseAgent {
788
821
  let opts = this.buildQueryOptions(signal);
789
822
  opts = await this.buildMcpConfig(opts);
790
823
  const q = sdk.query({ prompt, options: opts });
824
+ this.activeQuery = q;
791
825
  const thinkingBlockIndices = /* @__PURE__ */ new Set();
792
826
  const toolCallTracker = new ClaudeToolCallTracker();
793
827
  try {
@@ -803,8 +837,11 @@ var ClaudeAgent = class extends BaseAgent {
803
837
  }
804
838
  if (msg.type === "result" && msg.subtype === "success") {
805
839
  const r = msg;
806
- if (this.isPersistent && r.session_id) {
807
- this._sessionId = r.session_id;
840
+ if (r.session_id) {
841
+ if (this.isPersistent) {
842
+ this._sessionId = r.session_id;
843
+ }
844
+ yield this.emitSessionInfo(r.session_id);
808
845
  }
809
846
  yield { type: "done", finalOutput: r.result };
810
847
  }
@@ -813,6 +850,8 @@ var ClaudeAgent = class extends BaseAgent {
813
850
  if (this.isPersistent) this.clearPersistentSession();
814
851
  if (signal.aborted) throw new AbortError();
815
852
  throw e;
853
+ } finally {
854
+ this.activeQuery = null;
816
855
  }
817
856
  }
818
857
  dispose() {