@pear-protocol/agent-sdk 0.4.0 → 0.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -5
- package/dist/{client-CJNmyV0P.d.cts → client-BSUkCr7k.d.cts} +0 -2
- package/dist/{client-CJNmyV0P.d.ts → client-BSUkCr7k.d.ts} +0 -2
- package/dist/index.cjs +0 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +0 -2
- package/dist/index.js.map +1 -1
- package/dist/react/index.d.cts +3 -3
- package/dist/react/index.d.ts +3 -3
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -60,11 +60,12 @@ There's also a sync `client.sendMessage({ sessionId, message })` returning a
|
|
|
60
60
|
`getMessages`).
|
|
61
61
|
|
|
62
62
|
Both `streamChat` and `sendMessage` require a `surface`
|
|
63
|
-
(`pear_v3` | `pear_pro` | `base_mini` | `
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
63
|
+
(`pear_v3` | `pear_pro` | `base_mini` | `web`) declaring which Pear client you
|
|
64
|
+
are — the API rejects requests without a valid one. The agent applies
|
|
65
|
+
per-surface universe and execution policy — e.g. `base_mini` surfaces only SYMM
|
|
66
|
+
assets and is analysis-only. (`useAgentChat` defaults to `pear_v3`; set it via
|
|
67
|
+
the returned `setSurface`.) The Telegram surfaces are resolved server-side and
|
|
68
|
+
are not client-declarable.
|
|
68
69
|
|
|
69
70
|
## React
|
|
70
71
|
|
package/dist/index.cjs
CHANGED
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/errors.ts","../src/http.ts","../src/protocol/primitives.ts","../src/protocol/tickets.ts","../src/protocol/events.ts","../src/protocol/link.ts","../src/protocol/messages.ts","../src/stream.ts","../src/client.ts"],"names":["z"],"mappings":";;;;;AAAO,IAAM,cAAA,GAAN,cAA6B,KAAA,CAAM;AAAA,EAChC,MAAA;AAAA,EACA,IAAA;AAAA,EACT,WAAA,CAAY,OAAA,EAAiB,MAAA,EAAiB,IAAA,EAAe;AAC5D,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,OAAO,GAAA,CAAA,MAAA,CAAW,IAAA;AACvB,IAAA,IAAA,CAAK,MAAA,GAAS,MAAA;AACd,IAAA,IAAA,CAAK,IAAA,GAAO,IAAA;AAAA,EACb;AACD;AAEO,IAAM,SAAA,GAAN,cAAwB,cAAA,CAAe;AAAC;AACxC,IAAM,cAAA,GAAN,cAA6B,cAAA,CAAe;AAAC;AAC7C,IAAM,aAAA,GAAN,cAA4B,cAAA,CAAe;AAAC;AAC5C,IAAM,kBAAA,GAAN,cAAiC,cAAA,CAAe;AAAC;AACjD,IAAM,cAAA,GAAN,cAA6B,cAAA,CAAe;AAAC;AAC7C,IAAM,WAAA,GAAN,cAA0B,cAAA,CAAe;AAAC;AAE1C,SAAS,eAAA,CAAgB,QAAgB,IAAA,EAA8B;AAC7E,EAAA,MAAM,GAAA,GAAM,CAAA,gBAAA,EAAmB,MAAM,CAAA,EAAA,EAAK,IAAI,CAAA,CAAA;AAC9C,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,SAAA,CAAU,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC1D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC/D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,aAAA,CAAc,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC9D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,kBAAA,CAAmB,GAAA,EAAK,QAAQ,IAAI,CAAA;AACnE,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC/D,EAAA,IAAI,UAAU,GAAA,EAAK,OAAO,IAAI,WAAA,CAAY,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC3D,EAAA,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,MAAA,EAAQ,IAAI,CAAA;AAC5C;;;ACNO,SAAS,WAAW,MAAA,EAAqC;AAC/D,EAAA,MAAM,OAAA,GAAU,MAAA,CAAO,OAAA,CAAQ,OAAA,CAAQ,QAAQ,EAAE,CAAA;AACjD,EAAA,MAAM,YAAA,GAAe,OAAO,YAAA,IAAgB,IAAA;AAC5C,EAAA,MAAM,QAAA,GAAW,MAAA,CAAO,KAAA,IAAS,UAAA,CAAW,KAAA;AAC5C,EAAA,IAAI,CAAC,QAAA,EAAU;AACd,IAAA,MAAM,IAAI,MAAM,6DAAwD,CAAA;AAAA,EACzE;AAMA,EAAA,MAAM,OAAA,GAAwB,QAAA,CAAS,IAAA,CAAK,UAAU,CAAA;AAEtD,EAAA,MAAM,QAAA,GAAW,CAAC,IAAA,KACjB,CAAA,EAAG,OAAO,CAAA,EAAG,IAAA,CAAK,UAAA,CAAW,GAAG,CAAA,GAAI,IAAA,GAAO,CAAA,CAAA,EAAI,IAAI,CAAA,CAAE,CAAA,CAAA;AAEtD,EAAA,MAAM,cAAc,YAA6C;AAChE,IAAA,MAAM,KAAA,GAAQ,MAAM,MAAA,CAAO,QAAA,EAAS;AACpC,IAAA,OAAO;AAAA,MACN,aAAA,EAAe,UAAU,KAAK,CAAA,CAAA;AAAA,MAC9B,sBAAA,EAAwB;AAAA,KACzB;AAAA,EACD,CAAA;AAEA,EAAA,MAAM,IAAA,GAAO,OACZ,MAAA,EACA,IAAA,EACA,IAAA,KACgB;AAChB,IAAA,MAAM,OAAA,GAAU,MAAM,WAAA,EAAY;AAClC,IAAA,IAAI,IAAA,KAAS,MAAA,EAAW,OAAA,CAAQ,cAAc,CAAA,GAAI,kBAAA;AAClD,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA,EAAG;AAAA,MACzC,MAAA;AAAA,MACA,OAAA;AAAA,MACA,MAAM,IAAA,KAAS,MAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAI,CAAA,GAAI;AAAA,KAClD,CAAA;AACD,IAAA,IAAI,CAAC,IAAI,EAAA,EAAI;AACZ,MAAA,MAAM,eAAA,CAAgB,GAAA,CAAI,MAAA,EAAQ,MAAM,GAAA,CAAI,MAAK,CAAE,KAAA,CAAM,MAAM,EAAE,CAAC,CAAA;AAAA,IACnE;AACA,IAAA,IAAI,GAAA,CAAI,MAAA,KAAW,GAAA,EAAK,OAAO,MAAA;AAC/B,IAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,IAAA,OAAQ,IAAA,GAAO,IAAA,CAAK,KAAA,CAAM,IAAI,CAAA,GAAI,MAAA;AAAA,EACnC,CAAA;AAEA,EAAA,OAAO,EAAE,QAAA,EAAU,WAAA,EAAa,KAAA,EAAO,SAAS,IAAA,EAAK;AACtD;AC/DO,IAAM,eAAA,GAAkBA,MAAE,MAAA,CAAO;AAAA,EACvC,IAAA,EAAMA,MAAE,MAAA,EAAO;AAAA,EACf,QAAA,EAAUA,MAAE,MAAA,EAAO;AAAA,EACnB,KAAA,EAAOA,MAAE,MAAA;AACV,CAAC;AAGM,IAAM,mBAAA,GAAsBA,MAAE,MAAA,CAAO;AAAA,EAC3C,MAAA,EAAQA,MAAE,MAAA,EAAO;AAAA,EACjB,QAAA,EAAUA,MAAE,MAAA,EAAO;AAAA,EACnB,WAAA,EAAaA,MAAE,MAAA;AAChB,CAAC;AAMD,IAAM,oBAAA,GAAuBA,MAAE,MAAA,CAAO;AAAA,EACrC,GAAA,EAAKA,MAAE,MAAA,EAAO;AAAA,EACd,WAAA,EAAaA,KAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACjC,SAAA,EAAWA,KAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EAC/B,KAAA,EAAOA,KAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACnB,CAAC,CAAA;AACM,IAAM,oBAAA,GAAuBA,MAAE,KAAA,CAAM;AAAA,EAC3CA,KAAA,CAAE,QAAO,CAAE,SAAA,CAAU,CAAC,GAAA,MAAS,EAAE,KAAI,CAAE,CAAA;AAAA,EACvC;AACD,CAAC;AAGM,IAAM,qBAAA,GAAwBA,MAAE,MAAA,CAAO;AAAA,EAC7C,QAAA,EAAUA,MAAE,MAAA,EAAO;AAAA,EACnB,OAAA,EAASA,KAAA,CAAE,KAAA,CAAMA,KAAA,CAAE,QAAQ;AAC5B,CAAC;AAGM,IAAM,iBAAiBA,KAAA,CAAE,IAAA,CAAK,CAAC,UAAA,EAAY,UAAU,CAAC;AAMtD,IAAM,iBAAA,GAAoBA,MAAE,IAAA,CAAK;AAAA,EACvC,SAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,OAAA;AAAA,EACA,UAAA;AAAA,EACA;AACD,CAAC;AChDM,IAAM,kBAAA,GAAqBA,MAAE,IAAA,CAAK;AAAA,EACxC,eAAA;AAAA,EACA,gBAAA;AAAA,EACA,qBAAA;AAAA,EACA,iBAAA;AAAA,EACA,yBAAA;AAAA,EACA,kBAAA;AAAA,EACA,oBAAA;AAAA,EACA;AACD,CAAC;AAGM,IAAM,kBAAA,GAAqBA,MAAE,IAAA,CAAK;AAAA,EACxC,SAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA;AACD,CAAC;AAMM,IAAM,mBAAA,GAAsBA,MAAE,MAAA,CAAO;AAAA,EAC3C,QAAA,EAAUA,MAAE,MAAA,EAAO;AAAA,EACnB,MAAA,EAAQA,MAAE,MAAA,EAAO;AAAA,EACjB,WAAA,EAAaA,MAAE,MAAA,EAAO;AAAA,EACtB,OAAA,EAASA,KAAAA,CAAE,KAAA,CAAMA,KAAAA,CAAE,QAAQ;AAC5B,CAAC;AAOM,IAAM,mBAAA,GAAsBA,MAAE,WAAA,CAAY;AAAA,EAChD,EAAA,EAAIA,MAAE,OAAA,EAAQ;AAAA,EACd,QAAQA,KAAAA,CAAE,IAAA,CAAK,CAAC,UAAA,EAAY,QAAQ,CAAC,CAAA;AAAA;AAAA;AAAA,EAGrC,MAAA,EAAQA,KAAAA,CAAE,OAAA,EAAQ,CAAE,QAAA,EAAS;AAAA,EAC7B,iBAAA,EAAmBA,KAAAA,CAAE,OAAA,EAAQ,CAAE,QAAA,EAAS;AAAA,EACxC,QAAQA,KAAAA,CAAE,KAAA,CAAMA,MAAE,MAAA,EAAQ,EAAE,QAAA;AAC7B,CAAC;AAGM,IAAM,kBAAA,GAAqBA,MAAE,MAAA,CAAO;AAAA,EAC1C,EAAA,EAAIA,KAAAA,CAAE,OAAA,CAAQ,IAAI,CAAA;AAAA,EAClB,MAAA,EAAQA,KAAAA,CAAE,OAAA,CAAQ,WAAW;AAC9B,CAAC;AAGM,IAAM,4BAAA,GAA+BA,MAAE,MAAA,CAAO;AAAA,EACpD,EAAA,EAAIA,MAAE,OAAA,EAAQ;AAAA,EACd,OAAA,EAASA,MAAE,OAAA;AACZ,CAAC;AAQM,IAAM,mBAAA,GAAsBA,MAAE,MAAA,CAAO;AAAA,EAC3C,gBAAA,EAAkBA,MAAE,OAAA,EAAQ;AAAA,EAC5B,oBAAA,EAAsBA,MAAE,OAAA;AACzB,CAAC;AAIM,IAAM,wBAAA,GAA2BA,MAAE,MAAA,CAAO;AAAA,EAChD,EAAA,EAAIA,MAAE,OAAA,EAAQ;AAAA,EACd,OAAA,EAASA,MAAE,OAAA;AACZ,CAAC;;;ACrEM,IAAM,gBAAA,GAAmBA,MAAE,MAAA,CAAO;AAAA,EACxC,IAAA,EAAMA,KAAAA,CAAE,OAAA,CAAQ,OAAO,CAAA;AAAA,EACvB,IAAA,EAAMA,MAAE,MAAA;AACT,CAAC;AAEM,IAAM,mBAAA,GAAsBA,MAAE,MAAA,CAAO;AAAA,EAC3C,IAAA,EAAMA,KAAAA,CAAE,OAAA,CAAQ,UAAU,CAAA;AAAA,EAC1B,IAAA,EAAMA,MAAE,MAAA;AACT,CAAC;AACM,IAAM,iBAAA,GAAoBA,MAAE,MAAA,CAAO;AAAA,EACzC,IAAA,EAAMA,KAAAA,CAAE,OAAA,CAAQ,QAAQ,CAAA;AAAA,EACxB,IAAA,EAAMA,MAAE,MAAA,EAAO;AAAA,EACf,KAAA,EAAOA,MAAE,IAAA,CAAK,CAAC,SAAS,KAAK,CAAC,EAAE,QAAA,EAAS;AAAA,EACzC,IAAA,EAAMA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AAClB,CAAC;AACM,IAAM,kBAAA,GAAqBA,MAAE,MAAA,CAAO;AAAA,EAC1C,IAAA,EAAMA,KAAAA,CAAE,OAAA,CAAQ,SAAS,CAAA;AAAA;AAAA;AAAA;AAAA,EAIzB,mBAAA,EAAqBA,MAAE,KAAA,CAAM,oBAAoB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACtE,cAAA,EAAgBA,MAAE,KAAA,CAAM,mBAAmB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EAChE,UAAA,EAAYA,MAAE,KAAA,CAAM,eAAe,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACxD,MAAA,EAAQA,KAAAA,CAAE,KAAA,CAAMA,KAAAA,CAAE,MAAA,EAAQ,CAAA,CAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA;AAAA,EAC/C,eAAA,EAAiB,qBAAA,CAAsB,OAAA,EAAQ,CAAE,MAAM,IAAI,CAAA;AAAA;AAAA;AAAA,EAG3D,aAAA,EAAe,oBAAoB,OAAA;AACpC,CAAC;AACM,IAAM,gBAAA,GAAmBA,MAAE,MAAA,CAAO;AAAA,EACxC,IAAA,EAAMA,KAAAA,CAAE,OAAA,CAAQ,OAAO,CAAA;AAAA,EACvB,OAAA,EAASA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACrB,CAAC;AAKM,IAAM,oBAAA,GAAuBA,KAAAA,CAAE,kBAAA,CAAmB,MAAA,EAAQ;AAAA,EAChE,gBAAA;AAAA,EACA,mBAAA;AAAA,EACA,iBAAA;AAAA,EACA,kBAAA;AAAA,EACA;AACD,CAAC;AAKM,IAAM,gBAAA,GAAmBA,MAAE,MAAA,CAAO;AAAA,EACxC,SAAA,EAAWA,MAAE,MAAA,EAAO;AAAA,EACpB,SAAA,EAAWA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA;AAAA;AAAA,EAG/B,mBAAA,EAAqBA,MAAE,KAAA,CAAM,oBAAoB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACtE,cAAA,EAAgBA,MAAE,KAAA,CAAM,mBAAmB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EAChE,UAAA,EAAYA,MAAE,KAAA,CAAM,eAAe,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACxD,MAAA,EAAQA,MAAE,KAAA,CAAMA,KAAAA,CAAE,QAAQ,CAAA,CAAE,OAAA,CAAQ,EAAE,CAAA;AAAA,EACtC,eAAA,EAAiB,sBAAsB,QAAA,EAAS,CAAE,QAAQ,IAAI,CAAA,CAAE,MAAM,IAAI,CAAA;AAAA,EAC1E,aAAA,EAAe,mBAAA,CAAoB,QAAA,EAAS,CAAE,QAAQ,IAAI;AAC3D,CAAC;AChEM,IAAM,gBAAA,GAAmBA,MAAE,MAAA,CAAO;AAAA,EACxC,MAAA,EAAQA,MAAE,OAAA,EAAQ;AAAA,EAClB,aAAA,EAAeA,MAAE,MAAA;AAClB,CAAC;AAKM,IAAM,oBAAA,GAAuBA,MAAE,MAAA,CAAO;AAAA,EAC5C,EAAA,EAAIA,MAAE,OAAA,EAAQ;AAAA,EACd,MAAA,EAAQA,KAAAA,CAAE,OAAA,CAAQ,IAAI,CAAA;AAAA,EACtB,OAAA,EAASA,MAAE,OAAA;AACZ,CAAC;AAIM,IAAM,sBAAA,GAAyBA,MAAE,MAAA,CAAO;AAAA,EAC9C,EAAA,EAAIA,MAAE,OAAA,EAAQ;AAAA,EACd,MAAA,EAAQA,KAAAA,CAAE,OAAA,CAAQ,KAAK;AACxB,CAAC;ACfM,IAAM,qBAAA,GAAwBA,MAAE,MAAA,CAAO;AAAA,EAC7C,EAAA,EAAIA,MAAE,MAAA,EAAO;AAAA,EACb,OAAA,EAASA,MAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,MAAE,MAAA;AAAO;AACrB,CAAC;AAGM,IAAM,oBAAA,GAAuBA,MAAE,MAAA,CAAO;AAAA,EAC5C,EAAA,EAAIA,MAAE,MAAA,EAAO;AAAA,EACb,OAAA,EAASA,MAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,MAAE,MAAA,EAAO;AAAA,EACpB,gBAAA,EAAkBA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACtC,eAAA,EAAiBA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACrC,iBAAA,EAAmBA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACvC,sBAAA,EAAwBA,KAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACpC,CAAC;AAGM,IAAM,aAAA,GAAgBA,MAAE,MAAA,CAAO;AAAA,EACrC,EAAA,EAAIA,MAAE,MAAA,EAAO;AAAA,EACb,MAAA,EAAQA,MAAE,MAAA,EAAO;AAAA,EACjB,OAAA,EAASA,MAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,MAAE,MAAA;AACd,CAAC;AAKM,IAAM,sBAAA,GAAyBA,MAAE,WAAA,CAAY;AAAA,EACnD,EAAA,EAAIA,MAAE,MAAA,EAAO;AAAA,EACb,IAAA,EAAMA,MAAE,MAAA,EAAO;AAAA,EACf,OAAA,EAASA,MAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,MAAE,MAAA,EAAO;AAAA,EACpB,mBAAA,EAAqBA,KAAAA,CAAE,KAAA,CAAM,oBAAoB,EAAE,OAAA,EAAQ;AAAA,EAC3D,cAAA,EAAgBA,KAAAA,CAAE,KAAA,CAAM,mBAAmB,EAAE,OAAA,EAAQ;AAAA,EACrD,UAAA,EAAYA,KAAAA,CAAE,KAAA,CAAM,eAAe,EAAE,OAAA,EAAQ;AAAA,EAC7C,QAAQA,KAAAA,CAAE,KAAA,CAAMA,MAAE,MAAA,EAAQ,EAAE,OAAA,EAAQ;AAAA,EACpC,eAAA,EAAiB,sBAAsB,OAAA;AACxC,CAAC;;;ACpCD,gBAAuB,eACtB,IAAA,EAC8B;AAC9B,EAAA,MAAM,MAAA,GAAS,KAAK,SAAA,EAAU;AAC9B,EAAA,MAAM,OAAA,GAAU,IAAI,WAAA,EAAY;AAChC,EAAA,IAAI,MAAA,GAAS,EAAA;AAEb,EAAA,IAAI;AACH,IAAA,OAAO,IAAA,EAAM;AACZ,MAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,MAAM,OAAO,IAAA,EAAK;AAC1C,MAAA,IAAI,IAAA,EAAM;AACV,MAAA,MAAA,IAAU,QAAQ,MAAA,CAAO,KAAA,EAAO,EAAE,MAAA,EAAQ,MAAM,CAAA;AAKhD,MAAA,OAAO,IAAA,EAAM;AACZ,QAAA,MAAM,GAAA,GAAM,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA;AACjC,QAAA,IAAI,MAAM,CAAA,EAAG;AACb,QAAA,MAAM,QAAA,GAAW,MAAA,CAAO,KAAA,CAAM,CAAA,EAAG,GAAG,CAAA;AACpC,QAAA,MAAA,GAAS,MAAA,CAAO,KAAA,CAAM,GAAA,GAAM,CAAC,CAAA;AAE7B,QAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,IAAI,CAAA;AACjC,QAAA,MAAM,SAAA,GAAY,MAAM,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,UAAA,CAAW,QAAQ,CAAC,CAAA;AAC1D,QAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,UAAA,CAAW,OAAO,CAAC,CAAA;AACxD,QAAA,IAAI,CAAC,QAAA,EAAU;AACf,QAAA,MAAM,WAAA,GAAc,QAAA,CAAS,OAAA,CAAQ,WAAA,EAAa,EAAE,CAAA;AAIpD,QAAA,IAAI,SAAA,EAAW,OAAA,CAAQ,YAAA,EAAc,EAAE,MAAM,OAAA,EAAS;AACrD,UAAA,MAAM,EAAE,IAAA,EAAM,OAAA,EAAS,OAAA,EAAS,WAAA,EAAY;AAC5C,UAAA;AAAA,QACD;AAEA,QAAA,IAAI,IAAA;AACJ,QAAA,IAAI;AACH,UAAA,IAAA,GAAO,IAAA,CAAK,MAAM,WAAW,CAAA;AAAA,QAC9B,CAAA,CAAA,MAAQ;AACP,UAAA;AAAA,QACD;AAEA,QAAA,MAAM,MAAA,GAAS,oBAAA,CAAqB,SAAA,CAAU,IAAI,CAAA;AAClD,QAAA,IAAI,CAAC,OAAO,OAAA,EAAS;AAGpB,UAAA,IACE,IAAA,EAA4B,IAAA,KAAS,SAAA,IACrC,IAAA,EAAsC,aAAA,EACtC;AACD,YAAA,MAAM;AAAA,cACL,IAAA,EAAM,OAAA;AAAA,cACN,OAAA,EAAS;AAAA,aACV;AAAA,UACD;AACA,UAAA;AAAA,QACD;AAEA,QAAA,MAAM,KAAK,MAAA,CAAO,IAAA;AAClB,QAAA,IAAI,EAAA,CAAG,SAAS,OAAA,EAAS;AACxB,UAAA,MAAM,EAAE,GAAG,EAAA,EAAI,KAAA,EAAO,GAAG,IAAA,EAAK;AAAA,QAC/B,CAAA,MAAA,IAAW,EAAA,CAAG,IAAA,KAAS,UAAA,EAAY;AAClC,UAAA,MAAM,EAAE,GAAG,EAAA,EAAI,KAAA,EAAO,GAAG,IAAA,EAAK;AAAA,QAC/B,CAAA,MAAO;AACN,UAAA,MAAM,EAAA;AAAA,QACP;AAAA,MACD;AAAA,IACD;AAAA,EACD,CAAA,SAAE;AACD,IAAA,MAAA,CAAO,MAAA,EAAO,CAAE,KAAA,CAAM,MAAM,MAAS,CAAA;AAAA,EACtC;AACD;;;AC/CA,SAAS,gBAAgB,GAAA,EAA0B;AAClD,EAAA,MAAM,MAAA,GAAS,gBAAA,CAAiB,SAAA,CAAU,GAAG,CAAA;AAC7C,EAAA,IAAI,MAAA,CAAO,OAAA,EAAS,OAAO,MAAA,CAAO,IAAA;AAClC,EAAA,MAAM,CAAA,GAAI,GAAA;AAIV,EAAA,MAAM,EAAA,GAAK,mBAAA,CAAoB,SAAA,CAAU,CAAA,EAAG,aAAa,CAAA;AACzD,EAAA,OAAO;AAAA,IACN,WAAW,OAAO,CAAA,EAAG,SAAA,KAAc,QAAA,GAAW,EAAE,SAAA,GAAY,EAAA;AAAA,IAC5D,QAAQ,EAAC;AAAA,IACT,eAAA,EAAiB,IAAA;AAAA,IACjB,aAAA,EAAe,EAAA,CAAG,OAAA,GAAU,EAAA,CAAG,IAAA,GAAO;AAAA,GACvC;AACD;AAEA,SAAS,cAAA,CACR,SAAA,EACA,SAAA,EACA,OAAA,EACa;AACb,EAAA,OAAO,eAAA,CAAgB;AAAA,IACtB,SAAA;AAAA,IACA,SAAA;AAAA,IACA,qBAAqB,OAAA,EAAS,mBAAA;AAAA,IAC9B,gBAAgB,OAAA,EAAS,cAAA;AAAA,IACzB,YAAY,OAAA,EAAS,UAAA;AAAA,IACrB,MAAA,EAAQ,OAAA,EAAS,MAAA,IAAU,EAAC;AAAA,IAC5B,eAAA,EAAiB,SAAS,eAAA,IAAmB,IAAA;AAAA,IAC7C,aAAA,EAAe,SAAS,aAAA,IAAiB;AAAA,GACzC,CAAA;AACF;AAEO,IAAM,kBAAN,MAAsB;AAAA,EACX,IAAA;AAAA,EAEjB,YAAY,MAAA,EAA+B;AAC1C,IAAA,IAAA,CAAK,IAAA,GAAO,WAAW,MAAM,CAAA;AAAA,EAC9B;AAAA,EAEA,YAAA,GAA2C;AAC1C,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,KAAA,EAAO,gBAAgB,CAAA;AAAA,EAC9C;AAAA,EAEA,oBAAA,GAAkD;AACjD,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,KAAA,EAAO,wBAAwB,CAAA;AAAA,EACtD;AAAA,EAEA,aAAA,GAAyC;AACxC,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,MAAA,EAAQ,gBAAgB,CAAA;AAAA,EAC/C;AAAA,EAEA,WAAW,SAAA,EAAqC;AAC/C,IAAA,OAAO,KAAK,IAAA,CAAK,IAAA;AAAA,MAChB,KAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,KAChD;AAAA,EACD;AAAA,EAEA,MAAM,cAAc,SAAA,EAAkC;AACrD,IAAA,MAAM,KAAK,IAAA,CAAK,IAAA;AAAA,MACf,QAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,KAChD;AAAA,EACD;AAAA,EAEA,WAAA,CACC,WACA,IAAA,EAC8B;AAC9B,IAAA,MAAM,MAAA,GAAS,IAAI,eAAA,EAAgB;AACnC,IAAA,IAAI,IAAA,EAAM,UAAU,MAAA,EAAW,MAAA,CAAO,IAAI,OAAA,EAAS,MAAA,CAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AACrE,IAAA,IAAI,MAAM,MAAA,EAAQ,MAAA,CAAO,GAAA,CAAI,QAAA,EAAU,KAAK,MAAM,CAAA;AAClD,IAAA,MAAM,EAAA,GAAK,OAAO,QAAA,EAAS;AAC3B,IAAA,OAAO,KAAK,IAAA,CAAK,IAAA;AAAA,MAChB,KAAA;AAAA,MACA,CAAA,eAAA,EAAkB,mBAAmB,SAAS,CAAC,YAAY,EAAA,GAAK,CAAA,CAAA,EAAI,EAAE,CAAA,CAAA,GAAK,EAAE,CAAA;AAAA,KAC9E;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,WAAW,IAAA,EAWqD;AACtE,IAAA,MAAM,MAAA,GAAS,IAAI,eAAA,CAAgB;AAAA,MAClC,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,WAAW,IAAA,CAAK,SAAA;AAAA,MAChB,IAAA,EAAM,KAAK,IAAA,IAAQ;AAAA,KACnB,CAAA;AACD,IAAA,MAAA,CAAO,GAAA,CAAI,SAAA,EAAW,IAAA,CAAK,OAAO,CAAA;AAClC,IAAA,IAAI,KAAK,GAAA,EAAK;AACb,MAAA,MAAA,CAAO,GAAA,CAAI,6BAAA,EAA+B,IAAA,CAAK,GAAA,CAAI,YAAY,CAAA;AAC/D,MAAA,MAAA,CAAO,GAAA,CAAI,yBAAA,EAA2B,IAAA,CAAK,GAAA,CAAI,QAAQ,CAAA;AACvD,MAAA,MAAA,CAAO,GAAA,CAAI,+BAAA,EAAiC,IAAA,CAAK,GAAA,CAAI,cAAc,CAAA;AAAA,IACpE;AACA,IAAA,MAAM,OAAA,GAAU,MAAM,IAAA,CAAK,IAAA,CAAK,WAAA,EAAY;AAC5C,IAAA,OAAA,CAAQ,MAAA,GAAS,mBAAA;AACjB,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,KAAA;AAAA,MAC3B,KAAK,IAAA,CAAK,QAAA,CAAS,gBAAgB,MAAA,CAAO,QAAA,EAAU,CAAA,CAAE,CAAA;AAAA,MACtD,EAAE,MAAA,EAAQ,KAAA,EAAO,OAAA,EAAS,MAAA,EAAQ,KAAK,MAAA;AAAO,KAC/C;AACA,IAAA,IAAI,CAAC,GAAA,CAAI,EAAA,IAAM,CAAC,IAAI,IAAA,EAAM;AACzB,MAAA,MAAM,eAAA,CAAgB,GAAA,CAAI,MAAA,EAAQ,MAAM,GAAA,CAAI,MAAK,CAAE,KAAA,CAAM,MAAM,EAAE,CAAC,CAAA;AAAA,IACnE;AAEA,IAAA,IAAI,SAAA,GAAY,EAAA;AAChB,IAAA,IAAI,OAAA;AACJ,IAAA,WAAA,MAAiB,EAAA,IAAM,cAAA,CAAe,GAAA,CAAI,IAAI,CAAA,EAAG;AAChD,MAAA,IAAI,EAAA,CAAG,SAAS,OAAA,EAAS;AACxB,QAAA,MAAM,IAAI,cAAA,CAAe,EAAA,CAAG,OAAA,IAAW,oBAAoB,CAAA;AAAA,MAC5D;AACA,MAAA,IAAI,EAAA,CAAG,IAAA,KAAS,OAAA,EAAS,SAAA,IAAa,EAAA,CAAG,KAAA;AACzC,MAAA,IAAI,EAAA,CAAG,IAAA,KAAS,SAAA,EAAW,OAAA,GAAU,EAAA;AACrC,MAAA,MAAM,EAAA;AAAA,IACP;AAEA,IAAA,MAAM;AAAA,MACL,IAAA,EAAM,MAAA;AAAA,MACN,MAAA,EAAQ,cAAA,CAAe,IAAA,CAAK,SAAA,EAAW,WAAW,OAAO;AAAA,KAC1D;AAAA,EACD;AAAA;AAAA,EAGA,YAAY,IAAA,EAMY;AACvB,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,OAAA,EAAS;AAAA,MAC/B,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,WAAW,IAAA,CAAK,SAAA;AAAA,MAChB,IAAA,EAAM,KAAK,IAAA,IAAQ,UAAA;AAAA,MACnB,SAAS,IAAA,CAAK;AAAA,KACd,CAAA,CACA,IAAA,CAAK,eAAe,CAAA;AAAA,EACvB;AAAA,EAEA,cAAc,QAAA,EAA0C;AACvD,IAAA,OAAO,KAAK,IAAA,CACV,IAAA;AAAA,MACA,MAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,QAAQ,CAAC,CAAA,QAAA;AAAA,MAE9C,IAAA,CAAK,CAAC,QAAQ,mBAAA,CAAoB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC/C;AAAA,EAEA,aAAa,QAAA,EAAyC;AACrD,IAAA,OAAO,KAAK,IAAA,CACV,IAAA;AAAA,MACA,MAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,QAAQ,CAAC,CAAA,OAAA;AAAA,MAE9C,IAAA,CAAK,CAAC,QAAQ,kBAAA,CAAmB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC9C;AAAA,EAEA,sBAAsB,OAAA,EAAmD;AACxE,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,2BAA2B,EAAE,OAAA,EAAS,CAAA,CAC5D,KAAK,CAAC,GAAA,KAAQ,4BAAA,CAA6B,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EACxD;AAAA;AAAA;AAAA,EAIA,gBAAA,GAA2C;AAC1C,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,KAAA,EAAO,yBAAyB,CAAA,CAC9C,IAAA,CAAK,CAAC,GAAA,KAAQ,mBAAA,CAAoB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC/C;AAAA;AAAA;AAAA,EAIA,kBAAkB,OAAA,EAA+C;AAChE,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,4BAA4B,EAAE,OAAA,EAAS,CAAA,CAC7D,KAAK,CAAC,GAAA,KAAQ,wBAAA,CAAyB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EACpD;AAAA;AAAA;AAAA,EAIA,aAAA,GAAqC;AACpC,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,KAAA,EAAO,wBAAwB,CAAA,CAC7C,IAAA,CAAK,CAAC,GAAA,KAAQ,gBAAA,CAAiB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,WAAW,IAAA,EAGiB;AAC3B,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,0BAA0B,IAAA,IAAQ,EAAE,CAAA,CAC1D,KAAK,CAAC,GAAA,KAAQ,oBAAA,CAAqB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAChD;AAAA;AAAA,EAGA,YAAA,GAA0C;AACzC,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,QAAA,EAAU,wBAAwB,CAAA,CAChD,IAAA,CAAK,CAAC,GAAA,KAAQ,sBAAA,CAAuB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAClD;AACD","file":"index.cjs","sourcesContent":["export class AgentChatError extends Error {\n\treadonly status?: number;\n\treadonly body?: string;\n\tconstructor(message: string, status?: number, body?: string) {\n\t\tsuper(message);\n\t\tthis.name = new.target.name;\n\t\tthis.status = status;\n\t\tthis.body = body;\n\t}\n}\n\nexport class AuthError extends AgentChatError {}\nexport class ForbiddenError extends AgentChatError {}\nexport class ConflictError extends AgentChatError {}\nexport class TicketExpiredError extends AgentChatError {}\nexport class RateLimitError extends AgentChatError {}\nexport class ServerError extends AgentChatError {}\n\nexport function errorFromStatus(status: number, body: string): AgentChatError {\n\tconst msg = `Agent API error ${status}: ${body}`;\n\tif (status === 401) return new AuthError(msg, status, body);\n\tif (status === 403) return new ForbiddenError(msg, status, body);\n\tif (status === 409) return new ConflictError(msg, status, body);\n\tif (status === 410) return new TicketExpiredError(msg, status, body);\n\tif (status === 429) return new RateLimitError(msg, status, body);\n\tif (status >= 500) return new ServerError(msg, status, body);\n\treturn new AgentChatError(msg, status, body);\n}\n","import { errorFromStatus } from \"./errors\";\n\nexport interface AgentChatClientConfig {\n\t/** Base URL of the agent API, e.g. https://hl-v2-agent.pearprotocol.io */\n\tbaseUrl: string;\n\t/** Returns the freshest auth token (handles rotation). Required. */\n\tgetToken: () => string | Promise<string>;\n\t/** Sent as `X-Auth-Token-Version`. Defaults to \"v2\". */\n\ttokenVersion?: \"v2\" | \"v3\";\n\t/** Optional fetch override (SSR / tests). Defaults to global fetch. */\n\tfetch?: typeof fetch;\n}\n\nexport interface Http {\n\tbuildUrl: (path: string) => string;\n\tauthHeaders: () => Promise<Record<string, string>>;\n\t/** The resolved fetch — the single authoritative one (JSON + SSE share it). */\n\tfetch: typeof fetch;\n\tjson: <T>(method: string, path: string, body?: unknown) => Promise<T>;\n}\n\nexport function createHttp(config: AgentChatClientConfig): Http {\n\tconst baseUrl = config.baseUrl.replace(/\\/+$/, \"\");\n\tconst tokenVersion = config.tokenVersion ?? \"v2\";\n\tconst rawFetch = config.fetch ?? globalThis.fetch;\n\tif (!rawFetch) {\n\t\tthrow new Error(\"No fetch available — pass `fetch` in the client config\");\n\t}\n\t// Bind to globalThis. `fetch` is exposed on the Http object and the SSE path\n\t// invokes it as `http.fetch(...)` — called as a method, the browser's native\n\t// fetch runs with `this === the http object` and throws \"Illegal invocation\".\n\t// The JSON path calls it as a bare `doFetch(...)` (this === undefined), which\n\t// is why createSession worked but streamChat didn't. Binding pins `this`.\n\tconst doFetch: typeof fetch = rawFetch.bind(globalThis);\n\n\tconst buildUrl = (path: string): string =>\n\t\t`${baseUrl}${path.startsWith(\"/\") ? path : `/${path}`}`;\n\n\tconst authHeaders = async (): Promise<Record<string, string>> => {\n\t\tconst token = await config.getToken();\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${token}`,\n\t\t\t\"X-Auth-Token-Version\": tokenVersion,\n\t\t};\n\t};\n\n\tconst json = async <T>(\n\t\tmethod: string,\n\t\tpath: string,\n\t\tbody?: unknown,\n\t): Promise<T> => {\n\t\tconst headers = await authHeaders();\n\t\tif (body !== undefined) headers[\"Content-Type\"] = \"application/json\";\n\t\tconst res = await doFetch(buildUrl(path), {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\t\tif (!res.ok) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\t\tif (res.status === 204) return undefined as T;\n\t\tconst text = await res.text();\n\t\treturn (text ? JSON.parse(text) : undefined) as T;\n\t};\n\n\treturn { buildUrl, authHeaders, fetch: doFetch, json };\n}\n","import { z } from \"zod\";\n\n/** A Pear trade link surfaced with an agent reply. `platform` is left an open\n * string (not an enum) so a new venue doesn't break older SDK consumers. */\nexport const TradeLinkSchema = z.object({\n\tlink: z.string(),\n\tplatform: z.string(),\n\tlabel: z.string(),\n});\nexport type TradeLink = z.infer<typeof TradeLinkSchema>;\n\nexport const TwitterSourceSchema = z.object({\n\tauthor: z.string(),\n\ttweetUrl: z.string(),\n\tpublishedAt: z.string(),\n});\nexport type TwitterSource = z.infer<typeof TwitterSourceSchema>;\n\n/** Research web-citation. The research node emits a bare URL **string** on the\n * wire (research/agent.ts maps annotations -> `url_citation.url`); a future\n * object form is also accepted and normalized to `{ url, ... }`. */\nconst CitationObjectSchema = z.object({\n\turl: z.string(),\n\tstart_index: z.number().optional(),\n\tend_index: z.number().optional(),\n\ttitle: z.string().optional(),\n});\nexport const CitationSourceSchema = z.union([\n\tz.string().transform((url) => ({ url })),\n\tCitationObjectSchema,\n]);\nexport type CitationSource = z.infer<typeof CitationSourceSchema>;\n\nexport const SuggestedActionSchema = z.object({\n\tquestion: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type SuggestedAction = z.infer<typeof SuggestedActionSchema>;\n\nexport const ChatModeSchema = z.enum([\"standard\", \"advanced\"]);\nexport type ChatMode = z.infer<typeof ChatModeSchema>;\n\n/** The Pear client surface a chat request is from. Drives per-surface behavior\n * server-side (analysis universe / execution policy). Optional on the wire —\n * when omitted the server falls back to the sessionId-derived value. */\nexport const ChatSurfaceSchema = z.enum([\n\t\"pear_v3\",\n\t\"pear_pro\",\n\t\"base_mini\",\n\t\"tg_dm\",\n\t\"tg_group\",\n\t\"web\",\n]);\nexport type ChatSurface = z.infer<typeof ChatSurfaceSchema>;\n","import { z } from \"zod\";\n\n/** Known ticket actions. Used for typing; the wire `action` field is parsed\n * permissively (plain string) elsewhere for forward-compat. */\nexport const TicketActionSchema = z.enum([\n\t\"open_position\",\n\t\"close_position\",\n\t\"close_all_positions\",\n\t\"adjust_position\",\n\t\"adjust_advance_position\",\n\t\"reverse_position\",\n\t\"rebalance_position\",\n\t\"set_risk_parameters\",\n]);\nexport type TicketAction = z.infer<typeof TicketActionSchema>;\n\nexport const TicketStatusSchema = z.enum([\n\t\"PENDING\",\n\t\"EXECUTING\",\n\t\"EXECUTED\",\n\t\"CANCELLED\",\n\t\"FAILED\",\n]);\nexport type TicketStatus = z.infer<typeof TicketStatusSchema>;\n\n/** Surfaced on a turn when a money-moving write was FROZEN (nothing executed).\n * `action` is a plain string (forward-compatible); compare against\n * `TicketActionSchema.options` if you need to switch on known actions. */\nexport const PendingActionSchema = z.object({\n\tticketId: z.string(),\n\taction: z.string(),\n\tconsequence: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type PendingAction = z.infer<typeof PendingActionSchema>;\n\n/** Response of POST /trade/tickets/:id/confirm. Strict on the money fields,\n * loose (passthrough) on the action-specific `result` payload. `status` is\n * intentionally narrowed to the two TERMINAL confirm outcomes this endpoint\n * returns; widen to `TicketStatusSchema` if the BE can ever return another. */\nexport const ConfirmResultSchema = z.looseObject({\n\tok: z.boolean(),\n\tstatus: z.enum([\"EXECUTED\", \"FAILED\"]),\n\t// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER\n\t// implicitly optional, so dropping it would make these fields required.\n\tresult: z.unknown().optional(),\n\tpositionsSnapshot: z.unknown().optional(),\n\timages: z.array(z.string()).optional(),\n});\nexport type ConfirmResult = z.infer<typeof ConfirmResultSchema>;\n\nexport const CancelResultSchema = z.object({\n\tok: z.literal(true),\n\tstatus: z.literal(\"CANCELLED\"),\n});\nexport type CancelResult = z.infer<typeof CancelResultSchema>;\n\nexport const SetConfirmationsResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetConfirmationsResult = z.infer<\n\ttypeof SetConfirmationsResultSchema\n>;\n\n/** Response of GET /trade/tickets/settings — the caller's two independent trade\n * toggles. `executionEnabled` is the master execution switch (any write at all);\n * `confirmationsEnabled` is the confirm-before-write preference. */\nexport const TradeSettingsSchema = z.object({\n\texecutionEnabled: z.boolean(),\n\tconfirmationsEnabled: z.boolean(),\n});\nexport type TradeSettings = z.infer<typeof TradeSettingsSchema>;\n\n/** Response of POST /trade/tickets/execution — the new master-switch state. */\nexport const SetExecutionResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetExecutionResult = z.infer<typeof SetExecutionResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\nimport { PendingActionSchema } from \"./tickets\";\n\nexport const TokenEventSchema = z.object({\n\ttype: z.literal(\"token\"),\n\ttext: z.string(),\n});\n// `thinking` is emitted by ADVANCED mode only (the standard pipeline doesn't).\nexport const ThinkingEventSchema = z.object({\n\ttype: z.literal(\"thinking\"),\n\ttext: z.string(),\n});\nexport const StatusEventSchema = z.object({\n\ttype: z.literal(\"status\"),\n\ttext: z.string(),\n\tphase: z.enum([\"start\", \"end\"]).optional(),\n\tnode: z.string().optional(),\n});\nexport const SourcesEventSchema = z.object({\n\ttype: z.literal(\"sources\"),\n\t// `.catch` on every NON-critical field so a malformed metadata array can\n\t// never sink the whole event — `pendingAction` (a staged money-moving trade)\n\t// rides on this same frame and MUST always survive.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).catch([]).optional(), // resolved URL strings\n\tsuggestedAction: SuggestedActionSchema.nullish().catch(null),\n\t// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,\n\t// never be fabricated.\n\tpendingAction: PendingActionSchema.nullish(),\n});\nexport const ErrorEventSchema = z.object({\n\ttype: z.literal(\"error\"),\n\tmessage: z.string().optional(),\n});\n\n/** The discriminated union of events the SSE wire delivers. Parse each event\n * with `.safeParse`; on failure (unknown/legacy `cycle` etc.) IGNORE it — do\n * not throw. */\nexport const AgentWireEventSchema = z.discriminatedUnion(\"type\", [\n\tTokenEventSchema,\n\tThinkingEventSchema,\n\tStatusEventSchema,\n\tSourcesEventSchema,\n\tErrorEventSchema,\n]);\nexport type AgentWireEvent = z.infer<typeof AgentWireEventSchema>;\n\n/** Final assembled turn — the shape of `POST /chat` AND the SDK's synthetic\n * `done` event (the SSE wire has no `done` frame; the SDK assembles it). */\nexport const ChatResultSchema = z.object({\n\tfinalText: z.string(),\n\tsessionId: z.string().optional(),\n\t// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null\n\t// on drift so a hard `.parse` can never throw away a real `pendingAction`.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).default([]),\n\tsuggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),\n\tpendingAction: PendingActionSchema.nullable().default(null),\n});\nexport type ChatResult = z.infer<typeof ChatResultSchema>;\n\n/** The RAW wire union plus a synthetic terminal `done`. NOTE: the SDK actually\n * emits a NORMALIZED `StreamEvent` (token/thinking carry a `delta`) defined in\n * the SDK's stream module; this `AgentEvent` is the pre-normalization shape. */\nexport type AgentEvent = AgentWireEvent | { type: \"done\"; result: ChatResult };\n","import { z } from \"zod\";\n\n/** Response of GET /auth/link-wallet/self — whether the caller's wallet has a\n * WalletLink (i.e. the agent holds an API key and can execute trades). */\nexport const LinkStatusSchema = z.object({\n\tlinked: z.boolean(),\n\twalletAddress: z.string(),\n});\nexport type LinkStatus = z.infer<typeof LinkStatusSchema>;\n\n/** Response of POST /auth/link-wallet/self. `created` is true only when this\n * call minted a new key (false on the idempotent already-linked path). */\nexport const SelfLinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(true),\n\tcreated: z.boolean(),\n});\nexport type SelfLinkResult = z.infer<typeof SelfLinkResultSchema>;\n\n/** Response of DELETE /auth/link-wallet/self. */\nexport const SelfUnlinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(false),\n});\nexport type SelfUnlinkResult = z.infer<typeof SelfUnlinkResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\n\nexport const SessionListItemSchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(), // ISO (Date serialized over the wire)\n});\nexport type SessionListItem = z.infer<typeof SessionListItemSchema>;\n\nexport const SessionSummarySchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n\tfirstUserMessage: z.string().optional(),\n\tlastUserMessage: z.string().optional(),\n\tlastUserMessageAt: z.string().optional(),\n\tlastAssistantMessageAt: z.string().optional(),\n});\nexport type SessionSummary = z.infer<typeof SessionSummarySchema>;\n\nexport const SessionSchema = z.object({\n\tid: z.string(),\n\tuserId: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n});\nexport type Session = z.infer<typeof SessionSchema>;\n\n/** A persisted chat message (history). `images` are pre-resolved URL strings.\n * `z.looseObject` keeps unknown future fields instead of stripping them. */\nexport const AgentChatMessageSchema = z.looseObject({\n\tid: z.string(),\n\trole: z.string(),\n\tcontent: z.string(),\n\tcreatedAt: z.string(),\n\tresearchAnnotations: z.array(CitationSourceSchema).nullish(),\n\ttwitterSources: z.array(TwitterSourceSchema).nullish(),\n\ttradeLinks: z.array(TradeLinkSchema).nullish(),\n\timages: z.array(z.string()).nullish(),\n\tsuggestedAction: SuggestedActionSchema.nullish(),\n});\nexport type AgentChatMessage = z.infer<typeof AgentChatMessageSchema>;\n","import { type AgentWireEvent, AgentWireEventSchema } from \"./protocol\";\n\n/** A token/thinking event normalized to expose an incremental `delta`. This\n * backend is DELTA-only on every path, so `delta === text` — there is no\n * cumulative reconciliation (a `startsWith` heuristic corrupts real output). */\nexport type StreamEvent =\n\t| (Extract<AgentWireEvent, { type: \"token\" }> & { delta: string })\n\t| (Extract<AgentWireEvent, { type: \"thinking\" }> & { delta: string })\n\t| Exclude<AgentWireEvent, { type: \"token\" | \"thinking\" }>;\n\nexport async function* parseSseStream(\n\tbody: ReadableStream<Uint8Array>,\n): AsyncGenerator<StreamEvent> {\n\tconst reader = body.getReader();\n\tconst decoder = new TextDecoder();\n\tlet buffer = \"\";\n\n\ttry {\n\t\twhile (true) {\n\t\t\tconst { done, value } = await reader.read();\n\t\t\tif (done) break;\n\t\t\tbuffer += decoder.decode(value, { stream: true });\n\n\t\t\t// Drain every complete `\\n\\n`-delimited frame in the buffer. `const idx`\n\t\t\t// is recomputed each iteration (no assignment-in-`while`-head: that trips\n\t\t\t// biome `noAssignInExpressions`, a non-auto-fixable CI error).\n\t\t\twhile (true) {\n\t\t\t\tconst idx = buffer.indexOf(\"\\n\\n\");\n\t\t\t\tif (idx < 0) break;\n\t\t\t\tconst rawEvent = buffer.slice(0, idx);\n\t\t\t\tbuffer = buffer.slice(idx + 2);\n\n\t\t\t\tconst lines = rawEvent.split(\"\\n\");\n\t\t\t\tconst eventLine = lines.find((l) => l.startsWith(\"event:\"));\n\t\t\t\tconst dataLine = lines.find((l) => l.startsWith(\"data:\"));\n\t\t\t\tif (!dataLine) continue;\n\t\t\t\tconst payloadText = dataLine.replace(/^data:\\s?/, \"\");\n\n\t\t\t\t// NestJS surfaces stream errors as `event: error\\ndata: <plain string>`\n\t\t\t\t// (NON-JSON). Detect it BEFORE JSON.parse so it isn't swallowed.\n\t\t\t\tif (eventLine?.replace(/^event:\\s?/, \"\") === \"error\") {\n\t\t\t\t\tyield { type: \"error\", message: payloadText };\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet json: unknown;\n\t\t\t\ttry {\n\t\t\t\t\tjson = JSON.parse(payloadText);\n\t\t\t\t} catch {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst parsed = AgentWireEventSchema.safeParse(json);\n\t\t\t\tif (!parsed.success) {\n\t\t\t\t\t// Never SILENTLY drop a money-path frame: if it looks like a sources\n\t\t\t\t\t// event carrying pendingAction, fail loud instead of losing a trade.\n\t\t\t\t\tif (\n\t\t\t\t\t\t(json as { type?: string })?.type === \"sources\" &&\n\t\t\t\t\t\t(json as { pendingAction?: unknown })?.pendingAction\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\ttype: \"error\",\n\t\t\t\t\t\t\tmessage: \"malformed sources frame with pendingAction\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst ev = parsed.data;\n\t\t\t\tif (ev.type === \"token\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else if (ev.type === \"thinking\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else {\n\t\t\t\t\tyield ev;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} finally {\n\t\treader.cancel().catch(() => undefined);\n\t}\n}\n","import { AgentChatError, errorFromStatus } from \"./errors\";\nimport { type AgentChatClientConfig, createHttp, type Http } from \"./http\";\nimport {\n\ttype AgentChatMessage,\n\ttype CancelResult,\n\tCancelResultSchema,\n\ttype ChatMode,\n\ttype ChatResult,\n\tChatResultSchema,\n\ttype ChatSurface,\n\ttype ConfirmResult,\n\tConfirmResultSchema,\n\ttype LinkStatus,\n\tLinkStatusSchema,\n\tPendingActionSchema,\n\ttype SelfLinkResult,\n\tSelfLinkResultSchema,\n\ttype SelfUnlinkResult,\n\tSelfUnlinkResultSchema,\n\ttype Session,\n\ttype SessionListItem,\n\ttype SessionSummary,\n\ttype SetConfirmationsResult,\n\tSetConfirmationsResultSchema,\n\ttype SetExecutionResult,\n\tSetExecutionResultSchema,\n\ttype TradeSettings,\n\tTradeSettingsSchema,\n} from \"./protocol\";\nimport { parseSseStream, type StreamEvent } from \"./stream\";\n\n/** Parse a ChatResult but NEVER throw away a real `pendingAction` on metadata\n * drift: on a parse failure, fall back to a minimal result that preserves\n * `finalText` + `pendingAction` rather than rejecting the whole turn. */\nfunction parseChatResult(raw: unknown): ChatResult {\n\tconst parsed = ChatResultSchema.safeParse(raw);\n\tif (parsed.success) return parsed.data;\n\tconst r = raw as { finalText?: unknown; pendingAction?: unknown };\n\t// Salvage finalText, but NEVER fabricate a ticket: keep pendingAction only if\n\t// it INDEPENDENTLY validates — a corrupt ticket is dropped, never handed to\n\t// confirmTicket() (the money endpoint).\n\tconst pa = PendingActionSchema.safeParse(r?.pendingAction);\n\treturn {\n\t\tfinalText: typeof r?.finalText === \"string\" ? r.finalText : \"\",\n\t\timages: [],\n\t\tsuggestedAction: null,\n\t\tpendingAction: pa.success ? pa.data : null,\n\t};\n}\n\nfunction assembleResult(\n\tsessionId: string,\n\tfinalText: string,\n\tsources: Extract<StreamEvent, { type: \"sources\" }> | undefined,\n): ChatResult {\n\treturn parseChatResult({\n\t\tfinalText,\n\t\tsessionId,\n\t\tresearchAnnotations: sources?.researchAnnotations,\n\t\ttwitterSources: sources?.twitterSources,\n\t\ttradeLinks: sources?.tradeLinks,\n\t\timages: sources?.images ?? [],\n\t\tsuggestedAction: sources?.suggestedAction ?? null,\n\t\tpendingAction: sources?.pendingAction ?? null,\n\t});\n}\n\nexport class AgentChatClient {\n\tprivate readonly http: Http;\n\n\tconstructor(config: AgentChatClientConfig) {\n\t\tthis.http = createHttp(config);\n\t}\n\n\tlistSessions(): Promise<SessionListItem[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions\");\n\t}\n\n\tlistSessionSummaries(): Promise<SessionSummary[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions/summary\");\n\t}\n\n\tcreateSession(): Promise<{ id: string }> {\n\t\treturn this.http.json(\"POST\", \"/chat/sessions\");\n\t}\n\n\tgetSession(sessionId: string): Promise<Session> {\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tasync deleteSession(sessionId: string): Promise<void> {\n\t\tawait this.http.json(\n\t\t\t\"DELETE\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tgetMessages(\n\t\tsessionId: string,\n\t\topts?: { limit?: number; before?: string },\n\t): Promise<AgentChatMessage[]> {\n\t\tconst params = new URLSearchParams();\n\t\tif (opts?.limit !== undefined) params.set(\"limit\", String(opts.limit));\n\t\tif (opts?.before) params.set(\"before\", opts.before);\n\t\tconst qs = params.toString();\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : \"\"}`,\n\t\t);\n\t}\n\n\t/** Stream a turn. Yields token/thinking/status/sources events, then a\n\t * synthetic `{type:'done', result}` assembled from accumulated token deltas +\n\t * the final `sources` payload (the SSE wire has no `done` frame). Throws an\n\t * `AgentChatError` if the backend emits a mid-stream `error` frame. */\n\tasync *streamChat(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Declares the client surface (pear_v3 / pear_pro / base_mini / …). Required —\n\t\t * the API rejects requests without a valid surface. Drives per-surface behavior. */\n\t\tsurface: ChatSurface;\n\t\tsignal?: AbortSignal;\n\t\t/** CTA callback — set when the user clicks a suggested-action option; the\n\t\t * agent rebuilds the turn from this context server-side. */\n\t\tcta?: { previousText: string; question: string; selectedOption: string };\n\t}): AsyncGenerator<StreamEvent | { type: \"done\"; result: ChatResult }> {\n\t\tconst params = new URLSearchParams({\n\t\t\tmessage: args.message,\n\t\t\tsessionId: args.sessionId,\n\t\t\tmode: args.mode ?? \"standard\",\n\t\t});\n\t\tparams.set(\"surface\", args.surface);\n\t\tif (args.cta) {\n\t\t\tparams.set(\"suggestedActionPreviousText\", args.cta.previousText);\n\t\t\tparams.set(\"suggestedActionQuestion\", args.cta.question);\n\t\t\tparams.set(\"suggestedActionSelectedOption\", args.cta.selectedOption);\n\t\t}\n\t\tconst headers = await this.http.authHeaders();\n\t\theaders.Accept = \"text/event-stream\";\n\t\tconst res = await this.http.fetch(\n\t\t\tthis.http.buildUrl(`/chat/stream?${params.toString()}`),\n\t\t\t{ method: \"GET\", headers, signal: args.signal },\n\t\t);\n\t\tif (!res.ok || !res.body) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\n\t\tlet finalText = \"\";\n\t\tlet sources: Extract<StreamEvent, { type: \"sources\" }> | undefined;\n\t\tfor await (const ev of parseSseStream(res.body)) {\n\t\t\tif (ev.type === \"error\") {\n\t\t\t\tthrow new AgentChatError(ev.message ?? \"Agent stream error\");\n\t\t\t}\n\t\t\tif (ev.type === \"token\") finalText += ev.delta;\n\t\t\tif (ev.type === \"sources\") sources = ev;\n\t\t\tyield ev;\n\t\t}\n\n\t\tyield {\n\t\t\ttype: \"done\",\n\t\t\tresult: assembleResult(args.sessionId, finalText, sources),\n\t\t};\n\t}\n\n\t/** Sync send (POST /chat). Prefer `streamChat` for UX. */\n\tsendMessage(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Required — the API rejects requests without a valid surface. */\n\t\tsurface: ChatSurface;\n\t}): Promise<ChatResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/chat\", {\n\t\t\t\tmessage: args.message,\n\t\t\t\tsessionId: args.sessionId,\n\t\t\t\tmode: args.mode ?? \"standard\",\n\t\t\t\tsurface: args.surface,\n\t\t\t})\n\t\t\t.then(parseChatResult);\n\t}\n\n\tconfirmTicket(ticketId: string): Promise<ConfirmResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`,\n\t\t\t)\n\t\t\t.then((raw) => ConfirmResultSchema.parse(raw));\n\t}\n\n\tcancelTicket(ticketId: string): Promise<CancelResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`,\n\t\t\t)\n\t\t\t.then((raw) => CancelResultSchema.parse(raw));\n\t}\n\n\tsetTradeConfirmations(enabled: boolean): Promise<SetConfirmationsResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/settings\", { enabled })\n\t\t\t.then((raw) => SetConfirmationsResultSchema.parse(raw));\n\t}\n\n\t/** Read both trade toggles for the caller wallet: the master execution switch\n\t * and the confirm-before-write preference. */\n\tgetTradeSettings(): Promise<TradeSettings> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/trade/tickets/settings\")\n\t\t\t.then((raw) => TradeSettingsSchema.parse(raw));\n\t}\n\n\t/** Flip the caller's master execution switch. `false` opts the wallet out of\n\t * all money-moving writes; `true` restores the default-ON state. */\n\tsetTradeExecution(enabled: boolean): Promise<SetExecutionResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/execution\", { enabled })\n\t\t\t.then((raw) => SetExecutionResultSchema.parse(raw));\n\t}\n\n\t/** Whether the caller's wallet is linked to the agent (i.e. the agent can\n\t * execute trades for it). Backend-verified — don't cache this locally. */\n\tgetLinkStatus(): Promise<LinkStatus> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => LinkStatusSchema.parse(raw));\n\t}\n\n\t/** Link the caller's wallet: the agent mints a Pear API key server-side AS\n\t * the caller (their token is forwarded) — the key never exists client-side.\n\t * Idempotent when already linked; `force` re-mints (recovery), `code` binds\n\t * a Telegram identity (replaces the legacy secret-based flow). */\n\tlinkWallet(opts?: {\n\t\tforce?: boolean;\n\t\tcode?: string;\n\t}): Promise<SelfLinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/auth/link-wallet/self\", opts ?? {})\n\t\t\t.then((raw) => SelfLinkResultSchema.parse(raw));\n\t}\n\n\t/** Unlink the caller's wallet — the agent loses trade authority. */\n\tunlinkWallet(): Promise<SelfUnlinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"DELETE\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => SelfUnlinkResultSchema.parse(raw));\n\t}\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/errors.ts","../src/http.ts","../src/protocol/primitives.ts","../src/protocol/tickets.ts","../src/protocol/events.ts","../src/protocol/link.ts","../src/protocol/messages.ts","../src/stream.ts","../src/client.ts"],"names":["z"],"mappings":"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","file":"index.cjs","sourcesContent":["export class AgentChatError extends Error {\n\treadonly status?: number;\n\treadonly body?: string;\n\tconstructor(message: string, status?: number, body?: string) {\n\t\tsuper(message);\n\t\tthis.name = new.target.name;\n\t\tthis.status = status;\n\t\tthis.body = body;\n\t}\n}\n\nexport class AuthError extends AgentChatError {}\nexport class ForbiddenError extends AgentChatError {}\nexport class ConflictError extends AgentChatError {}\nexport class TicketExpiredError extends AgentChatError {}\nexport class RateLimitError extends AgentChatError {}\nexport class ServerError extends AgentChatError {}\n\nexport function errorFromStatus(status: number, body: string): AgentChatError {\n\tconst msg = `Agent API error ${status}: ${body}`;\n\tif (status === 401) return new AuthError(msg, status, body);\n\tif (status === 403) return new ForbiddenError(msg, status, body);\n\tif (status === 409) return new ConflictError(msg, status, body);\n\tif (status === 410) return new TicketExpiredError(msg, status, body);\n\tif (status === 429) return new RateLimitError(msg, status, body);\n\tif (status >= 500) return new ServerError(msg, status, body);\n\treturn new AgentChatError(msg, status, body);\n}\n","import { errorFromStatus } from \"./errors\";\n\nexport interface AgentChatClientConfig {\n\t/** Base URL of the agent API, e.g. https://hl-v2-agent.pearprotocol.io */\n\tbaseUrl: string;\n\t/** Returns the freshest auth token (handles rotation). Required. */\n\tgetToken: () => string | Promise<string>;\n\t/** Sent as `X-Auth-Token-Version`. Defaults to \"v2\". */\n\ttokenVersion?: \"v2\" | \"v3\";\n\t/** Optional fetch override (SSR / tests). Defaults to global fetch. */\n\tfetch?: typeof fetch;\n}\n\nexport interface Http {\n\tbuildUrl: (path: string) => string;\n\tauthHeaders: () => Promise<Record<string, string>>;\n\t/** The resolved fetch — the single authoritative one (JSON + SSE share it). */\n\tfetch: typeof fetch;\n\tjson: <T>(method: string, path: string, body?: unknown) => Promise<T>;\n}\n\nexport function createHttp(config: AgentChatClientConfig): Http {\n\tconst baseUrl = config.baseUrl.replace(/\\/+$/, \"\");\n\tconst tokenVersion = config.tokenVersion ?? \"v2\";\n\tconst rawFetch = config.fetch ?? globalThis.fetch;\n\tif (!rawFetch) {\n\t\tthrow new Error(\"No fetch available — pass `fetch` in the client config\");\n\t}\n\t// Bind to globalThis. `fetch` is exposed on the Http object and the SSE path\n\t// invokes it as `http.fetch(...)` — called as a method, the browser's native\n\t// fetch runs with `this === the http object` and throws \"Illegal invocation\".\n\t// The JSON path calls it as a bare `doFetch(...)` (this === undefined), which\n\t// is why createSession worked but streamChat didn't. Binding pins `this`.\n\tconst doFetch: typeof fetch = rawFetch.bind(globalThis);\n\n\tconst buildUrl = (path: string): string =>\n\t\t`${baseUrl}${path.startsWith(\"/\") ? path : `/${path}`}`;\n\n\tconst authHeaders = async (): Promise<Record<string, string>> => {\n\t\tconst token = await config.getToken();\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${token}`,\n\t\t\t\"X-Auth-Token-Version\": tokenVersion,\n\t\t};\n\t};\n\n\tconst json = async <T>(\n\t\tmethod: string,\n\t\tpath: string,\n\t\tbody?: unknown,\n\t): Promise<T> => {\n\t\tconst headers = await authHeaders();\n\t\tif (body !== undefined) headers[\"Content-Type\"] = \"application/json\";\n\t\tconst res = await doFetch(buildUrl(path), {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\t\tif (!res.ok) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\t\tif (res.status === 204) return undefined as T;\n\t\tconst text = await res.text();\n\t\treturn (text ? JSON.parse(text) : undefined) as T;\n\t};\n\n\treturn { buildUrl, authHeaders, fetch: doFetch, json };\n}\n","import { z } from \"zod\";\n\n/** A Pear trade link surfaced with an agent reply. `platform` is left an open\n * string (not an enum) so a new venue doesn't break older SDK consumers. */\nexport const TradeLinkSchema = z.object({\n\tlink: z.string(),\n\tplatform: z.string(),\n\tlabel: z.string(),\n});\nexport type TradeLink = z.infer<typeof TradeLinkSchema>;\n\nexport const TwitterSourceSchema = z.object({\n\tauthor: z.string(),\n\ttweetUrl: z.string(),\n\tpublishedAt: z.string(),\n});\nexport type TwitterSource = z.infer<typeof TwitterSourceSchema>;\n\n/** Research web-citation. The research node emits a bare URL **string** on the\n * wire (research/agent.ts maps annotations -> `url_citation.url`); a future\n * object form is also accepted and normalized to `{ url, ... }`. */\nconst CitationObjectSchema = z.object({\n\turl: z.string(),\n\tstart_index: z.number().optional(),\n\tend_index: z.number().optional(),\n\ttitle: z.string().optional(),\n});\nexport const CitationSourceSchema = z.union([\n\tz.string().transform((url) => ({ url })),\n\tCitationObjectSchema,\n]);\nexport type CitationSource = z.infer<typeof CitationSourceSchema>;\n\nexport const SuggestedActionSchema = z.object({\n\tquestion: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type SuggestedAction = z.infer<typeof SuggestedActionSchema>;\n\nexport const ChatModeSchema = z.enum([\"standard\", \"advanced\"]);\nexport type ChatMode = z.infer<typeof ChatModeSchema>;\n\n/** The Pear client surface a chat request declares — drives per-surface behavior\n * server-side (analysis universe / execution policy). REQUIRED on the wire. The\n * Telegram surfaces (tg_dm / tg_group) are resolved server-side from the TG\n * session and are NOT client-declarable, so they're intentionally absent here. */\nexport const ChatSurfaceSchema = z.enum([\n\t\"pear_v3\",\n\t\"pear_pro\",\n\t\"base_mini\",\n\t\"web\",\n]);\nexport type ChatSurface = z.infer<typeof ChatSurfaceSchema>;\n","import { z } from \"zod\";\n\n/** Known ticket actions. Used for typing; the wire `action` field is parsed\n * permissively (plain string) elsewhere for forward-compat. */\nexport const TicketActionSchema = z.enum([\n\t\"open_position\",\n\t\"close_position\",\n\t\"close_all_positions\",\n\t\"adjust_position\",\n\t\"adjust_advance_position\",\n\t\"reverse_position\",\n\t\"rebalance_position\",\n\t\"set_risk_parameters\",\n]);\nexport type TicketAction = z.infer<typeof TicketActionSchema>;\n\nexport const TicketStatusSchema = z.enum([\n\t\"PENDING\",\n\t\"EXECUTING\",\n\t\"EXECUTED\",\n\t\"CANCELLED\",\n\t\"FAILED\",\n]);\nexport type TicketStatus = z.infer<typeof TicketStatusSchema>;\n\n/** Surfaced on a turn when a money-moving write was FROZEN (nothing executed).\n * `action` is a plain string (forward-compatible); compare against\n * `TicketActionSchema.options` if you need to switch on known actions. */\nexport const PendingActionSchema = z.object({\n\tticketId: z.string(),\n\taction: z.string(),\n\tconsequence: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type PendingAction = z.infer<typeof PendingActionSchema>;\n\n/** Response of POST /trade/tickets/:id/confirm. Strict on the money fields,\n * loose (passthrough) on the action-specific `result` payload. `status` is\n * intentionally narrowed to the two TERMINAL confirm outcomes this endpoint\n * returns; widen to `TicketStatusSchema` if the BE can ever return another. */\nexport const ConfirmResultSchema = z.looseObject({\n\tok: z.boolean(),\n\tstatus: z.enum([\"EXECUTED\", \"FAILED\"]),\n\t// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER\n\t// implicitly optional, so dropping it would make these fields required.\n\tresult: z.unknown().optional(),\n\tpositionsSnapshot: z.unknown().optional(),\n\timages: z.array(z.string()).optional(),\n});\nexport type ConfirmResult = z.infer<typeof ConfirmResultSchema>;\n\nexport const CancelResultSchema = z.object({\n\tok: z.literal(true),\n\tstatus: z.literal(\"CANCELLED\"),\n});\nexport type CancelResult = z.infer<typeof CancelResultSchema>;\n\nexport const SetConfirmationsResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetConfirmationsResult = z.infer<\n\ttypeof SetConfirmationsResultSchema\n>;\n\n/** Response of GET /trade/tickets/settings — the caller's two independent trade\n * toggles. `executionEnabled` is the master execution switch (any write at all);\n * `confirmationsEnabled` is the confirm-before-write preference. */\nexport const TradeSettingsSchema = z.object({\n\texecutionEnabled: z.boolean(),\n\tconfirmationsEnabled: z.boolean(),\n});\nexport type TradeSettings = z.infer<typeof TradeSettingsSchema>;\n\n/** Response of POST /trade/tickets/execution — the new master-switch state. */\nexport const SetExecutionResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetExecutionResult = z.infer<typeof SetExecutionResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\nimport { PendingActionSchema } from \"./tickets\";\n\nexport const TokenEventSchema = z.object({\n\ttype: z.literal(\"token\"),\n\ttext: z.string(),\n});\n// `thinking` is emitted by ADVANCED mode only (the standard pipeline doesn't).\nexport const ThinkingEventSchema = z.object({\n\ttype: z.literal(\"thinking\"),\n\ttext: z.string(),\n});\nexport const StatusEventSchema = z.object({\n\ttype: z.literal(\"status\"),\n\ttext: z.string(),\n\tphase: z.enum([\"start\", \"end\"]).optional(),\n\tnode: z.string().optional(),\n});\nexport const SourcesEventSchema = z.object({\n\ttype: z.literal(\"sources\"),\n\t// `.catch` on every NON-critical field so a malformed metadata array can\n\t// never sink the whole event — `pendingAction` (a staged money-moving trade)\n\t// rides on this same frame and MUST always survive.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).catch([]).optional(), // resolved URL strings\n\tsuggestedAction: SuggestedActionSchema.nullish().catch(null),\n\t// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,\n\t// never be fabricated.\n\tpendingAction: PendingActionSchema.nullish(),\n});\nexport const ErrorEventSchema = z.object({\n\ttype: z.literal(\"error\"),\n\tmessage: z.string().optional(),\n});\n\n/** The discriminated union of events the SSE wire delivers. Parse each event\n * with `.safeParse`; on failure (unknown/legacy `cycle` etc.) IGNORE it — do\n * not throw. */\nexport const AgentWireEventSchema = z.discriminatedUnion(\"type\", [\n\tTokenEventSchema,\n\tThinkingEventSchema,\n\tStatusEventSchema,\n\tSourcesEventSchema,\n\tErrorEventSchema,\n]);\nexport type AgentWireEvent = z.infer<typeof AgentWireEventSchema>;\n\n/** Final assembled turn — the shape of `POST /chat` AND the SDK's synthetic\n * `done` event (the SSE wire has no `done` frame; the SDK assembles it). */\nexport const ChatResultSchema = z.object({\n\tfinalText: z.string(),\n\tsessionId: z.string().optional(),\n\t// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null\n\t// on drift so a hard `.parse` can never throw away a real `pendingAction`.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).default([]),\n\tsuggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),\n\tpendingAction: PendingActionSchema.nullable().default(null),\n});\nexport type ChatResult = z.infer<typeof ChatResultSchema>;\n\n/** The RAW wire union plus a synthetic terminal `done`. NOTE: the SDK actually\n * emits a NORMALIZED `StreamEvent` (token/thinking carry a `delta`) defined in\n * the SDK's stream module; this `AgentEvent` is the pre-normalization shape. */\nexport type AgentEvent = AgentWireEvent | { type: \"done\"; result: ChatResult };\n","import { z } from \"zod\";\n\n/** Response of GET /auth/link-wallet/self — whether the caller's wallet has a\n * WalletLink (i.e. the agent holds an API key and can execute trades). */\nexport const LinkStatusSchema = z.object({\n\tlinked: z.boolean(),\n\twalletAddress: z.string(),\n});\nexport type LinkStatus = z.infer<typeof LinkStatusSchema>;\n\n/** Response of POST /auth/link-wallet/self. `created` is true only when this\n * call minted a new key (false on the idempotent already-linked path). */\nexport const SelfLinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(true),\n\tcreated: z.boolean(),\n});\nexport type SelfLinkResult = z.infer<typeof SelfLinkResultSchema>;\n\n/** Response of DELETE /auth/link-wallet/self. */\nexport const SelfUnlinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(false),\n});\nexport type SelfUnlinkResult = z.infer<typeof SelfUnlinkResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\n\nexport const SessionListItemSchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(), // ISO (Date serialized over the wire)\n});\nexport type SessionListItem = z.infer<typeof SessionListItemSchema>;\n\nexport const SessionSummarySchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n\tfirstUserMessage: z.string().optional(),\n\tlastUserMessage: z.string().optional(),\n\tlastUserMessageAt: z.string().optional(),\n\tlastAssistantMessageAt: z.string().optional(),\n});\nexport type SessionSummary = z.infer<typeof SessionSummarySchema>;\n\nexport const SessionSchema = z.object({\n\tid: z.string(),\n\tuserId: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n});\nexport type Session = z.infer<typeof SessionSchema>;\n\n/** A persisted chat message (history). `images` are pre-resolved URL strings.\n * `z.looseObject` keeps unknown future fields instead of stripping them. */\nexport const AgentChatMessageSchema = z.looseObject({\n\tid: z.string(),\n\trole: z.string(),\n\tcontent: z.string(),\n\tcreatedAt: z.string(),\n\tresearchAnnotations: z.array(CitationSourceSchema).nullish(),\n\ttwitterSources: z.array(TwitterSourceSchema).nullish(),\n\ttradeLinks: z.array(TradeLinkSchema).nullish(),\n\timages: z.array(z.string()).nullish(),\n\tsuggestedAction: SuggestedActionSchema.nullish(),\n});\nexport type AgentChatMessage = z.infer<typeof AgentChatMessageSchema>;\n","import { type AgentWireEvent, AgentWireEventSchema } from \"./protocol\";\n\n/** A token/thinking event normalized to expose an incremental `delta`. This\n * backend is DELTA-only on every path, so `delta === text` — there is no\n * cumulative reconciliation (a `startsWith` heuristic corrupts real output). */\nexport type StreamEvent =\n\t| (Extract<AgentWireEvent, { type: \"token\" }> & { delta: string })\n\t| (Extract<AgentWireEvent, { type: \"thinking\" }> & { delta: string })\n\t| Exclude<AgentWireEvent, { type: \"token\" | \"thinking\" }>;\n\nexport async function* parseSseStream(\n\tbody: ReadableStream<Uint8Array>,\n): AsyncGenerator<StreamEvent> {\n\tconst reader = body.getReader();\n\tconst decoder = new TextDecoder();\n\tlet buffer = \"\";\n\n\ttry {\n\t\twhile (true) {\n\t\t\tconst { done, value } = await reader.read();\n\t\t\tif (done) break;\n\t\t\tbuffer += decoder.decode(value, { stream: true });\n\n\t\t\t// Drain every complete `\\n\\n`-delimited frame in the buffer. `const idx`\n\t\t\t// is recomputed each iteration (no assignment-in-`while`-head: that trips\n\t\t\t// biome `noAssignInExpressions`, a non-auto-fixable CI error).\n\t\t\twhile (true) {\n\t\t\t\tconst idx = buffer.indexOf(\"\\n\\n\");\n\t\t\t\tif (idx < 0) break;\n\t\t\t\tconst rawEvent = buffer.slice(0, idx);\n\t\t\t\tbuffer = buffer.slice(idx + 2);\n\n\t\t\t\tconst lines = rawEvent.split(\"\\n\");\n\t\t\t\tconst eventLine = lines.find((l) => l.startsWith(\"event:\"));\n\t\t\t\tconst dataLine = lines.find((l) => l.startsWith(\"data:\"));\n\t\t\t\tif (!dataLine) continue;\n\t\t\t\tconst payloadText = dataLine.replace(/^data:\\s?/, \"\");\n\n\t\t\t\t// NestJS surfaces stream errors as `event: error\\ndata: <plain string>`\n\t\t\t\t// (NON-JSON). Detect it BEFORE JSON.parse so it isn't swallowed.\n\t\t\t\tif (eventLine?.replace(/^event:\\s?/, \"\") === \"error\") {\n\t\t\t\t\tyield { type: \"error\", message: payloadText };\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet json: unknown;\n\t\t\t\ttry {\n\t\t\t\t\tjson = JSON.parse(payloadText);\n\t\t\t\t} catch {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst parsed = AgentWireEventSchema.safeParse(json);\n\t\t\t\tif (!parsed.success) {\n\t\t\t\t\t// Never SILENTLY drop a money-path frame: if it looks like a sources\n\t\t\t\t\t// event carrying pendingAction, fail loud instead of losing a trade.\n\t\t\t\t\tif (\n\t\t\t\t\t\t(json as { type?: string })?.type === \"sources\" &&\n\t\t\t\t\t\t(json as { pendingAction?: unknown })?.pendingAction\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\ttype: \"error\",\n\t\t\t\t\t\t\tmessage: \"malformed sources frame with pendingAction\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst ev = parsed.data;\n\t\t\t\tif (ev.type === \"token\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else if (ev.type === \"thinking\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else {\n\t\t\t\t\tyield ev;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} finally {\n\t\treader.cancel().catch(() => undefined);\n\t}\n}\n","import { AgentChatError, errorFromStatus } from \"./errors\";\nimport { type AgentChatClientConfig, createHttp, type Http } from \"./http\";\nimport {\n\ttype AgentChatMessage,\n\ttype CancelResult,\n\tCancelResultSchema,\n\ttype ChatMode,\n\ttype ChatResult,\n\tChatResultSchema,\n\ttype ChatSurface,\n\ttype ConfirmResult,\n\tConfirmResultSchema,\n\ttype LinkStatus,\n\tLinkStatusSchema,\n\tPendingActionSchema,\n\ttype SelfLinkResult,\n\tSelfLinkResultSchema,\n\ttype SelfUnlinkResult,\n\tSelfUnlinkResultSchema,\n\ttype Session,\n\ttype SessionListItem,\n\ttype SessionSummary,\n\ttype SetConfirmationsResult,\n\tSetConfirmationsResultSchema,\n\ttype SetExecutionResult,\n\tSetExecutionResultSchema,\n\ttype TradeSettings,\n\tTradeSettingsSchema,\n} from \"./protocol\";\nimport { parseSseStream, type StreamEvent } from \"./stream\";\n\n/** Parse a ChatResult but NEVER throw away a real `pendingAction` on metadata\n * drift: on a parse failure, fall back to a minimal result that preserves\n * `finalText` + `pendingAction` rather than rejecting the whole turn. */\nfunction parseChatResult(raw: unknown): ChatResult {\n\tconst parsed = ChatResultSchema.safeParse(raw);\n\tif (parsed.success) return parsed.data;\n\tconst r = raw as { finalText?: unknown; pendingAction?: unknown };\n\t// Salvage finalText, but NEVER fabricate a ticket: keep pendingAction only if\n\t// it INDEPENDENTLY validates — a corrupt ticket is dropped, never handed to\n\t// confirmTicket() (the money endpoint).\n\tconst pa = PendingActionSchema.safeParse(r?.pendingAction);\n\treturn {\n\t\tfinalText: typeof r?.finalText === \"string\" ? r.finalText : \"\",\n\t\timages: [],\n\t\tsuggestedAction: null,\n\t\tpendingAction: pa.success ? pa.data : null,\n\t};\n}\n\nfunction assembleResult(\n\tsessionId: string,\n\tfinalText: string,\n\tsources: Extract<StreamEvent, { type: \"sources\" }> | undefined,\n): ChatResult {\n\treturn parseChatResult({\n\t\tfinalText,\n\t\tsessionId,\n\t\tresearchAnnotations: sources?.researchAnnotations,\n\t\ttwitterSources: sources?.twitterSources,\n\t\ttradeLinks: sources?.tradeLinks,\n\t\timages: sources?.images ?? [],\n\t\tsuggestedAction: sources?.suggestedAction ?? null,\n\t\tpendingAction: sources?.pendingAction ?? null,\n\t});\n}\n\nexport class AgentChatClient {\n\tprivate readonly http: Http;\n\n\tconstructor(config: AgentChatClientConfig) {\n\t\tthis.http = createHttp(config);\n\t}\n\n\tlistSessions(): Promise<SessionListItem[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions\");\n\t}\n\n\tlistSessionSummaries(): Promise<SessionSummary[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions/summary\");\n\t}\n\n\tcreateSession(): Promise<{ id: string }> {\n\t\treturn this.http.json(\"POST\", \"/chat/sessions\");\n\t}\n\n\tgetSession(sessionId: string): Promise<Session> {\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tasync deleteSession(sessionId: string): Promise<void> {\n\t\tawait this.http.json(\n\t\t\t\"DELETE\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tgetMessages(\n\t\tsessionId: string,\n\t\topts?: { limit?: number; before?: string },\n\t): Promise<AgentChatMessage[]> {\n\t\tconst params = new URLSearchParams();\n\t\tif (opts?.limit !== undefined) params.set(\"limit\", String(opts.limit));\n\t\tif (opts?.before) params.set(\"before\", opts.before);\n\t\tconst qs = params.toString();\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : \"\"}`,\n\t\t);\n\t}\n\n\t/** Stream a turn. Yields token/thinking/status/sources events, then a\n\t * synthetic `{type:'done', result}` assembled from accumulated token deltas +\n\t * the final `sources` payload (the SSE wire has no `done` frame). Throws an\n\t * `AgentChatError` if the backend emits a mid-stream `error` frame. */\n\tasync *streamChat(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Declares the client surface (pear_v3 / pear_pro / base_mini / …). Required —\n\t\t * the API rejects requests without a valid surface. Drives per-surface behavior. */\n\t\tsurface: ChatSurface;\n\t\tsignal?: AbortSignal;\n\t\t/** CTA callback — set when the user clicks a suggested-action option; the\n\t\t * agent rebuilds the turn from this context server-side. */\n\t\tcta?: { previousText: string; question: string; selectedOption: string };\n\t}): AsyncGenerator<StreamEvent | { type: \"done\"; result: ChatResult }> {\n\t\tconst params = new URLSearchParams({\n\t\t\tmessage: args.message,\n\t\t\tsessionId: args.sessionId,\n\t\t\tmode: args.mode ?? \"standard\",\n\t\t});\n\t\tparams.set(\"surface\", args.surface);\n\t\tif (args.cta) {\n\t\t\tparams.set(\"suggestedActionPreviousText\", args.cta.previousText);\n\t\t\tparams.set(\"suggestedActionQuestion\", args.cta.question);\n\t\t\tparams.set(\"suggestedActionSelectedOption\", args.cta.selectedOption);\n\t\t}\n\t\tconst headers = await this.http.authHeaders();\n\t\theaders.Accept = \"text/event-stream\";\n\t\tconst res = await this.http.fetch(\n\t\t\tthis.http.buildUrl(`/chat/stream?${params.toString()}`),\n\t\t\t{ method: \"GET\", headers, signal: args.signal },\n\t\t);\n\t\tif (!res.ok || !res.body) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\n\t\tlet finalText = \"\";\n\t\tlet sources: Extract<StreamEvent, { type: \"sources\" }> | undefined;\n\t\tfor await (const ev of parseSseStream(res.body)) {\n\t\t\tif (ev.type === \"error\") {\n\t\t\t\tthrow new AgentChatError(ev.message ?? \"Agent stream error\");\n\t\t\t}\n\t\t\tif (ev.type === \"token\") finalText += ev.delta;\n\t\t\tif (ev.type === \"sources\") sources = ev;\n\t\t\tyield ev;\n\t\t}\n\n\t\tyield {\n\t\t\ttype: \"done\",\n\t\t\tresult: assembleResult(args.sessionId, finalText, sources),\n\t\t};\n\t}\n\n\t/** Sync send (POST /chat). Prefer `streamChat` for UX. */\n\tsendMessage(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Required — the API rejects requests without a valid surface. */\n\t\tsurface: ChatSurface;\n\t}): Promise<ChatResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/chat\", {\n\t\t\t\tmessage: args.message,\n\t\t\t\tsessionId: args.sessionId,\n\t\t\t\tmode: args.mode ?? \"standard\",\n\t\t\t\tsurface: args.surface,\n\t\t\t})\n\t\t\t.then(parseChatResult);\n\t}\n\n\tconfirmTicket(ticketId: string): Promise<ConfirmResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`,\n\t\t\t)\n\t\t\t.then((raw) => ConfirmResultSchema.parse(raw));\n\t}\n\n\tcancelTicket(ticketId: string): Promise<CancelResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`,\n\t\t\t)\n\t\t\t.then((raw) => CancelResultSchema.parse(raw));\n\t}\n\n\tsetTradeConfirmations(enabled: boolean): Promise<SetConfirmationsResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/settings\", { enabled })\n\t\t\t.then((raw) => SetConfirmationsResultSchema.parse(raw));\n\t}\n\n\t/** Read both trade toggles for the caller wallet: the master execution switch\n\t * and the confirm-before-write preference. */\n\tgetTradeSettings(): Promise<TradeSettings> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/trade/tickets/settings\")\n\t\t\t.then((raw) => TradeSettingsSchema.parse(raw));\n\t}\n\n\t/** Flip the caller's master execution switch. `false` opts the wallet out of\n\t * all money-moving writes; `true` restores the default-ON state. */\n\tsetTradeExecution(enabled: boolean): Promise<SetExecutionResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/execution\", { enabled })\n\t\t\t.then((raw) => SetExecutionResultSchema.parse(raw));\n\t}\n\n\t/** Whether the caller's wallet is linked to the agent (i.e. the agent can\n\t * execute trades for it). Backend-verified — don't cache this locally. */\n\tgetLinkStatus(): Promise<LinkStatus> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => LinkStatusSchema.parse(raw));\n\t}\n\n\t/** Link the caller's wallet: the agent mints a Pear API key server-side AS\n\t * the caller (their token is forwarded) — the key never exists client-side.\n\t * Idempotent when already linked; `force` re-mints (recovery), `code` binds\n\t * a Telegram identity (replaces the legacy secret-based flow). */\n\tlinkWallet(opts?: {\n\t\tforce?: boolean;\n\t\tcode?: string;\n\t}): Promise<SelfLinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/auth/link-wallet/self\", opts ?? {})\n\t\t\t.then((raw) => SelfLinkResultSchema.parse(raw));\n\t}\n\n\t/** Unlink the caller's wallet — the agent loses trade authority. */\n\tunlinkWallet(): Promise<SelfUnlinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"DELETE\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => SelfUnlinkResultSchema.parse(raw));\n\t}\n}\n"]}
|
package/dist/index.d.cts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { A as AgentChatClient, a as AgentChatClientConfig, b as AgentChatMessage, c as AgentChatMessageSchema, d as AgentEvent, e as AgentWireEvent, f as AgentWireEventSchema, C as CancelResult, g as CancelResultSchema, h as ChatMode, i as ChatModeSchema, j as ChatResult, k as ChatResultSchema, l as ChatSurface, m as ChatSurfaceSchema, n as CitationSource, o as CitationSourceSchema, p as ConfirmResult, q as ConfirmResultSchema, E as ErrorEventSchema, L as LinkStatus, r as LinkStatusSchema, P as PendingAction, s as PendingActionSchema, S as SelfLinkResult, t as SelfLinkResultSchema, u as SelfUnlinkResult, v as SelfUnlinkResultSchema, w as Session, x as SessionListItem, y as SessionListItemSchema, z as SessionSchema, B as SessionSummary, D as SessionSummarySchema, F as SetConfirmationsResult, G as SetConfirmationsResultSchema, H as SetExecutionResult, I as SetExecutionResultSchema, J as SourcesEventSchema, K as StatusEventSchema, M as StreamEvent, N as SuggestedAction, O as SuggestedActionSchema, T as ThinkingEventSchema, Q as TicketAction, R as TicketActionSchema, U as TicketStatus, V as TicketStatusSchema, W as TokenEventSchema, X as TradeLink, Y as TradeLinkSchema, Z as TradeSettings, _ as TradeSettingsSchema, $ as TwitterSource, a0 as TwitterSourceSchema } from './client-
|
|
1
|
+
export { A as AgentChatClient, a as AgentChatClientConfig, b as AgentChatMessage, c as AgentChatMessageSchema, d as AgentEvent, e as AgentWireEvent, f as AgentWireEventSchema, C as CancelResult, g as CancelResultSchema, h as ChatMode, i as ChatModeSchema, j as ChatResult, k as ChatResultSchema, l as ChatSurface, m as ChatSurfaceSchema, n as CitationSource, o as CitationSourceSchema, p as ConfirmResult, q as ConfirmResultSchema, E as ErrorEventSchema, L as LinkStatus, r as LinkStatusSchema, P as PendingAction, s as PendingActionSchema, S as SelfLinkResult, t as SelfLinkResultSchema, u as SelfUnlinkResult, v as SelfUnlinkResultSchema, w as Session, x as SessionListItem, y as SessionListItemSchema, z as SessionSchema, B as SessionSummary, D as SessionSummarySchema, F as SetConfirmationsResult, G as SetConfirmationsResultSchema, H as SetExecutionResult, I as SetExecutionResultSchema, J as SourcesEventSchema, K as StatusEventSchema, M as StreamEvent, N as SuggestedAction, O as SuggestedActionSchema, T as ThinkingEventSchema, Q as TicketAction, R as TicketActionSchema, U as TicketStatus, V as TicketStatusSchema, W as TokenEventSchema, X as TradeLink, Y as TradeLinkSchema, Z as TradeSettings, _ as TradeSettingsSchema, $ as TwitterSource, a0 as TwitterSourceSchema } from './client-BSUkCr7k.cjs';
|
|
2
2
|
import 'zod';
|
|
3
3
|
|
|
4
4
|
declare class AgentChatError extends Error {
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { A as AgentChatClient, a as AgentChatClientConfig, b as AgentChatMessage, c as AgentChatMessageSchema, d as AgentEvent, e as AgentWireEvent, f as AgentWireEventSchema, C as CancelResult, g as CancelResultSchema, h as ChatMode, i as ChatModeSchema, j as ChatResult, k as ChatResultSchema, l as ChatSurface, m as ChatSurfaceSchema, n as CitationSource, o as CitationSourceSchema, p as ConfirmResult, q as ConfirmResultSchema, E as ErrorEventSchema, L as LinkStatus, r as LinkStatusSchema, P as PendingAction, s as PendingActionSchema, S as SelfLinkResult, t as SelfLinkResultSchema, u as SelfUnlinkResult, v as SelfUnlinkResultSchema, w as Session, x as SessionListItem, y as SessionListItemSchema, z as SessionSchema, B as SessionSummary, D as SessionSummarySchema, F as SetConfirmationsResult, G as SetConfirmationsResultSchema, H as SetExecutionResult, I as SetExecutionResultSchema, J as SourcesEventSchema, K as StatusEventSchema, M as StreamEvent, N as SuggestedAction, O as SuggestedActionSchema, T as ThinkingEventSchema, Q as TicketAction, R as TicketActionSchema, U as TicketStatus, V as TicketStatusSchema, W as TokenEventSchema, X as TradeLink, Y as TradeLinkSchema, Z as TradeSettings, _ as TradeSettingsSchema, $ as TwitterSource, a0 as TwitterSourceSchema } from './client-
|
|
1
|
+
export { A as AgentChatClient, a as AgentChatClientConfig, b as AgentChatMessage, c as AgentChatMessageSchema, d as AgentEvent, e as AgentWireEvent, f as AgentWireEventSchema, C as CancelResult, g as CancelResultSchema, h as ChatMode, i as ChatModeSchema, j as ChatResult, k as ChatResultSchema, l as ChatSurface, m as ChatSurfaceSchema, n as CitationSource, o as CitationSourceSchema, p as ConfirmResult, q as ConfirmResultSchema, E as ErrorEventSchema, L as LinkStatus, r as LinkStatusSchema, P as PendingAction, s as PendingActionSchema, S as SelfLinkResult, t as SelfLinkResultSchema, u as SelfUnlinkResult, v as SelfUnlinkResultSchema, w as Session, x as SessionListItem, y as SessionListItemSchema, z as SessionSchema, B as SessionSummary, D as SessionSummarySchema, F as SetConfirmationsResult, G as SetConfirmationsResultSchema, H as SetExecutionResult, I as SetExecutionResultSchema, J as SourcesEventSchema, K as StatusEventSchema, M as StreamEvent, N as SuggestedAction, O as SuggestedActionSchema, T as ThinkingEventSchema, Q as TicketAction, R as TicketActionSchema, U as TicketStatus, V as TicketStatusSchema, W as TokenEventSchema, X as TradeLink, Y as TradeLinkSchema, Z as TradeSettings, _ as TradeSettingsSchema, $ as TwitterSource, a0 as TwitterSourceSchema } from './client-BSUkCr7k.js';
|
|
2
2
|
import 'zod';
|
|
3
3
|
|
|
4
4
|
declare class AgentChatError extends Error {
|
package/dist/index.js
CHANGED
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/errors.ts","../src/http.ts","../src/protocol/primitives.ts","../src/protocol/tickets.ts","../src/protocol/events.ts","../src/protocol/link.ts","../src/protocol/messages.ts","../src/stream.ts","../src/client.ts"],"names":["z"],"mappings":";;;AAAO,IAAM,cAAA,GAAN,cAA6B,KAAA,CAAM;AAAA,EAChC,MAAA;AAAA,EACA,IAAA;AAAA,EACT,WAAA,CAAY,OAAA,EAAiB,MAAA,EAAiB,IAAA,EAAe;AAC5D,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,OAAO,GAAA,CAAA,MAAA,CAAW,IAAA;AACvB,IAAA,IAAA,CAAK,MAAA,GAAS,MAAA;AACd,IAAA,IAAA,CAAK,IAAA,GAAO,IAAA;AAAA,EACb;AACD;AAEO,IAAM,SAAA,GAAN,cAAwB,cAAA,CAAe;AAAC;AACxC,IAAM,cAAA,GAAN,cAA6B,cAAA,CAAe;AAAC;AAC7C,IAAM,aAAA,GAAN,cAA4B,cAAA,CAAe;AAAC;AAC5C,IAAM,kBAAA,GAAN,cAAiC,cAAA,CAAe;AAAC;AACjD,IAAM,cAAA,GAAN,cAA6B,cAAA,CAAe;AAAC;AAC7C,IAAM,WAAA,GAAN,cAA0B,cAAA,CAAe;AAAC;AAE1C,SAAS,eAAA,CAAgB,QAAgB,IAAA,EAA8B;AAC7E,EAAA,MAAM,GAAA,GAAM,CAAA,gBAAA,EAAmB,MAAM,CAAA,EAAA,EAAK,IAAI,CAAA,CAAA;AAC9C,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,SAAA,CAAU,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC1D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC/D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,aAAA,CAAc,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC9D,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,kBAAA,CAAmB,GAAA,EAAK,QAAQ,IAAI,CAAA;AACnE,EAAA,IAAI,WAAW,GAAA,EAAK,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC/D,EAAA,IAAI,UAAU,GAAA,EAAK,OAAO,IAAI,WAAA,CAAY,GAAA,EAAK,QAAQ,IAAI,CAAA;AAC3D,EAAA,OAAO,IAAI,cAAA,CAAe,GAAA,EAAK,MAAA,EAAQ,IAAI,CAAA;AAC5C;;;ACNO,SAAS,WAAW,MAAA,EAAqC;AAC/D,EAAA,MAAM,OAAA,GAAU,MAAA,CAAO,OAAA,CAAQ,OAAA,CAAQ,QAAQ,EAAE,CAAA;AACjD,EAAA,MAAM,YAAA,GAAe,OAAO,YAAA,IAAgB,IAAA;AAC5C,EAAA,MAAM,QAAA,GAAW,MAAA,CAAO,KAAA,IAAS,UAAA,CAAW,KAAA;AAC5C,EAAA,IAAI,CAAC,QAAA,EAAU;AACd,IAAA,MAAM,IAAI,MAAM,6DAAwD,CAAA;AAAA,EACzE;AAMA,EAAA,MAAM,OAAA,GAAwB,QAAA,CAAS,IAAA,CAAK,UAAU,CAAA;AAEtD,EAAA,MAAM,QAAA,GAAW,CAAC,IAAA,KACjB,CAAA,EAAG,OAAO,CAAA,EAAG,IAAA,CAAK,UAAA,CAAW,GAAG,CAAA,GAAI,IAAA,GAAO,CAAA,CAAA,EAAI,IAAI,CAAA,CAAE,CAAA,CAAA;AAEtD,EAAA,MAAM,cAAc,YAA6C;AAChE,IAAA,MAAM,KAAA,GAAQ,MAAM,MAAA,CAAO,QAAA,EAAS;AACpC,IAAA,OAAO;AAAA,MACN,aAAA,EAAe,UAAU,KAAK,CAAA,CAAA;AAAA,MAC9B,sBAAA,EAAwB;AAAA,KACzB;AAAA,EACD,CAAA;AAEA,EAAA,MAAM,IAAA,GAAO,OACZ,MAAA,EACA,IAAA,EACA,IAAA,KACgB;AAChB,IAAA,MAAM,OAAA,GAAU,MAAM,WAAA,EAAY;AAClC,IAAA,IAAI,IAAA,KAAS,MAAA,EAAW,OAAA,CAAQ,cAAc,CAAA,GAAI,kBAAA;AAClD,IAAA,MAAM,GAAA,GAAM,MAAM,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA,EAAG;AAAA,MACzC,MAAA;AAAA,MACA,OAAA;AAAA,MACA,MAAM,IAAA,KAAS,MAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAI,CAAA,GAAI;AAAA,KAClD,CAAA;AACD,IAAA,IAAI,CAAC,IAAI,EAAA,EAAI;AACZ,MAAA,MAAM,eAAA,CAAgB,GAAA,CAAI,MAAA,EAAQ,MAAM,GAAA,CAAI,MAAK,CAAE,KAAA,CAAM,MAAM,EAAE,CAAC,CAAA;AAAA,IACnE;AACA,IAAA,IAAI,GAAA,CAAI,MAAA,KAAW,GAAA,EAAK,OAAO,MAAA;AAC/B,IAAA,MAAM,IAAA,GAAO,MAAM,GAAA,CAAI,IAAA,EAAK;AAC5B,IAAA,OAAQ,IAAA,GAAO,IAAA,CAAK,KAAA,CAAM,IAAI,CAAA,GAAI,MAAA;AAAA,EACnC,CAAA;AAEA,EAAA,OAAO,EAAE,QAAA,EAAU,WAAA,EAAa,KAAA,EAAO,SAAS,IAAA,EAAK;AACtD;AC/DO,IAAM,eAAA,GAAkB,EAAE,MAAA,CAAO;AAAA,EACvC,IAAA,EAAM,EAAE,MAAA,EAAO;AAAA,EACf,QAAA,EAAU,EAAE,MAAA,EAAO;AAAA,EACnB,KAAA,EAAO,EAAE,MAAA;AACV,CAAC;AAGM,IAAM,mBAAA,GAAsB,EAAE,MAAA,CAAO;AAAA,EAC3C,MAAA,EAAQ,EAAE,MAAA,EAAO;AAAA,EACjB,QAAA,EAAU,EAAE,MAAA,EAAO;AAAA,EACnB,WAAA,EAAa,EAAE,MAAA;AAChB,CAAC;AAMD,IAAM,oBAAA,GAAuB,EAAE,MAAA,CAAO;AAAA,EACrC,GAAA,EAAK,EAAE,MAAA,EAAO;AAAA,EACd,WAAA,EAAa,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACjC,SAAA,EAAW,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EAC/B,KAAA,EAAO,CAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACnB,CAAC,CAAA;AACM,IAAM,oBAAA,GAAuB,EAAE,KAAA,CAAM;AAAA,EAC3C,CAAA,CAAE,QAAO,CAAE,SAAA,CAAU,CAAC,GAAA,MAAS,EAAE,KAAI,CAAE,CAAA;AAAA,EACvC;AACD,CAAC;AAGM,IAAM,qBAAA,GAAwB,EAAE,MAAA,CAAO;AAAA,EAC7C,QAAA,EAAU,EAAE,MAAA,EAAO;AAAA,EACnB,OAAA,EAAS,CAAA,CAAE,KAAA,CAAM,CAAA,CAAE,QAAQ;AAC5B,CAAC;AAGM,IAAM,iBAAiB,CAAA,CAAE,IAAA,CAAK,CAAC,UAAA,EAAY,UAAU,CAAC;AAMtD,IAAM,iBAAA,GAAoB,EAAE,IAAA,CAAK;AAAA,EACvC,SAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,OAAA;AAAA,EACA,UAAA;AAAA,EACA;AACD,CAAC;AChDM,IAAM,kBAAA,GAAqBA,EAAE,IAAA,CAAK;AAAA,EACxC,eAAA;AAAA,EACA,gBAAA;AAAA,EACA,qBAAA;AAAA,EACA,iBAAA;AAAA,EACA,yBAAA;AAAA,EACA,kBAAA;AAAA,EACA,oBAAA;AAAA,EACA;AACD,CAAC;AAGM,IAAM,kBAAA,GAAqBA,EAAE,IAAA,CAAK;AAAA,EACxC,SAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA;AACD,CAAC;AAMM,IAAM,mBAAA,GAAsBA,EAAE,MAAA,CAAO;AAAA,EAC3C,QAAA,EAAUA,EAAE,MAAA,EAAO;AAAA,EACnB,MAAA,EAAQA,EAAE,MAAA,EAAO;AAAA,EACjB,WAAA,EAAaA,EAAE,MAAA,EAAO;AAAA,EACtB,OAAA,EAASA,CAAAA,CAAE,KAAA,CAAMA,CAAAA,CAAE,QAAQ;AAC5B,CAAC;AAOM,IAAM,mBAAA,GAAsBA,EAAE,WAAA,CAAY;AAAA,EAChD,EAAA,EAAIA,EAAE,OAAA,EAAQ;AAAA,EACd,QAAQA,CAAAA,CAAE,IAAA,CAAK,CAAC,UAAA,EAAY,QAAQ,CAAC,CAAA;AAAA;AAAA;AAAA,EAGrC,MAAA,EAAQA,CAAAA,CAAE,OAAA,EAAQ,CAAE,QAAA,EAAS;AAAA,EAC7B,iBAAA,EAAmBA,CAAAA,CAAE,OAAA,EAAQ,CAAE,QAAA,EAAS;AAAA,EACxC,QAAQA,CAAAA,CAAE,KAAA,CAAMA,EAAE,MAAA,EAAQ,EAAE,QAAA;AAC7B,CAAC;AAGM,IAAM,kBAAA,GAAqBA,EAAE,MAAA,CAAO;AAAA,EAC1C,EAAA,EAAIA,CAAAA,CAAE,OAAA,CAAQ,IAAI,CAAA;AAAA,EAClB,MAAA,EAAQA,CAAAA,CAAE,OAAA,CAAQ,WAAW;AAC9B,CAAC;AAGM,IAAM,4BAAA,GAA+BA,EAAE,MAAA,CAAO;AAAA,EACpD,EAAA,EAAIA,EAAE,OAAA,EAAQ;AAAA,EACd,OAAA,EAASA,EAAE,OAAA;AACZ,CAAC;AAQM,IAAM,mBAAA,GAAsBA,EAAE,MAAA,CAAO;AAAA,EAC3C,gBAAA,EAAkBA,EAAE,OAAA,EAAQ;AAAA,EAC5B,oBAAA,EAAsBA,EAAE,OAAA;AACzB,CAAC;AAIM,IAAM,wBAAA,GAA2BA,EAAE,MAAA,CAAO;AAAA,EAChD,EAAA,EAAIA,EAAE,OAAA,EAAQ;AAAA,EACd,OAAA,EAASA,EAAE,OAAA;AACZ,CAAC;;;ACrEM,IAAM,gBAAA,GAAmBA,EAAE,MAAA,CAAO;AAAA,EACxC,IAAA,EAAMA,CAAAA,CAAE,OAAA,CAAQ,OAAO,CAAA;AAAA,EACvB,IAAA,EAAMA,EAAE,MAAA;AACT,CAAC;AAEM,IAAM,mBAAA,GAAsBA,EAAE,MAAA,CAAO;AAAA,EAC3C,IAAA,EAAMA,CAAAA,CAAE,OAAA,CAAQ,UAAU,CAAA;AAAA,EAC1B,IAAA,EAAMA,EAAE,MAAA;AACT,CAAC;AACM,IAAM,iBAAA,GAAoBA,EAAE,MAAA,CAAO;AAAA,EACzC,IAAA,EAAMA,CAAAA,CAAE,OAAA,CAAQ,QAAQ,CAAA;AAAA,EACxB,IAAA,EAAMA,EAAE,MAAA,EAAO;AAAA,EACf,KAAA,EAAOA,EAAE,IAAA,CAAK,CAAC,SAAS,KAAK,CAAC,EAAE,QAAA,EAAS;AAAA,EACzC,IAAA,EAAMA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AAClB,CAAC;AACM,IAAM,kBAAA,GAAqBA,EAAE,MAAA,CAAO;AAAA,EAC1C,IAAA,EAAMA,CAAAA,CAAE,OAAA,CAAQ,SAAS,CAAA;AAAA;AAAA;AAAA;AAAA,EAIzB,mBAAA,EAAqBA,EAAE,KAAA,CAAM,oBAAoB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACtE,cAAA,EAAgBA,EAAE,KAAA,CAAM,mBAAmB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EAChE,UAAA,EAAYA,EAAE,KAAA,CAAM,eAAe,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACxD,MAAA,EAAQA,CAAAA,CAAE,KAAA,CAAMA,CAAAA,CAAE,MAAA,EAAQ,CAAA,CAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA;AAAA,EAC/C,eAAA,EAAiB,qBAAA,CAAsB,OAAA,EAAQ,CAAE,MAAM,IAAI,CAAA;AAAA;AAAA;AAAA,EAG3D,aAAA,EAAe,oBAAoB,OAAA;AACpC,CAAC;AACM,IAAM,gBAAA,GAAmBA,EAAE,MAAA,CAAO;AAAA,EACxC,IAAA,EAAMA,CAAAA,CAAE,OAAA,CAAQ,OAAO,CAAA;AAAA,EACvB,OAAA,EAASA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACrB,CAAC;AAKM,IAAM,oBAAA,GAAuBA,CAAAA,CAAE,kBAAA,CAAmB,MAAA,EAAQ;AAAA,EAChE,gBAAA;AAAA,EACA,mBAAA;AAAA,EACA,iBAAA;AAAA,EACA,kBAAA;AAAA,EACA;AACD,CAAC;AAKM,IAAM,gBAAA,GAAmBA,EAAE,MAAA,CAAO;AAAA,EACxC,SAAA,EAAWA,EAAE,MAAA,EAAO;AAAA,EACpB,SAAA,EAAWA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA;AAAA;AAAA,EAG/B,mBAAA,EAAqBA,EAAE,KAAA,CAAM,oBAAoB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACtE,cAAA,EAAgBA,EAAE,KAAA,CAAM,mBAAmB,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EAChE,UAAA,EAAYA,EAAE,KAAA,CAAM,eAAe,EAAE,KAAA,CAAM,EAAE,CAAA,CAAE,QAAA,EAAS;AAAA,EACxD,MAAA,EAAQA,EAAE,KAAA,CAAMA,CAAAA,CAAE,QAAQ,CAAA,CAAE,OAAA,CAAQ,EAAE,CAAA;AAAA,EACtC,eAAA,EAAiB,sBAAsB,QAAA,EAAS,CAAE,QAAQ,IAAI,CAAA,CAAE,MAAM,IAAI,CAAA;AAAA,EAC1E,aAAA,EAAe,mBAAA,CAAoB,QAAA,EAAS,CAAE,QAAQ,IAAI;AAC3D,CAAC;AChEM,IAAM,gBAAA,GAAmBA,EAAE,MAAA,CAAO;AAAA,EACxC,MAAA,EAAQA,EAAE,OAAA,EAAQ;AAAA,EAClB,aAAA,EAAeA,EAAE,MAAA;AAClB,CAAC;AAKM,IAAM,oBAAA,GAAuBA,EAAE,MAAA,CAAO;AAAA,EAC5C,EAAA,EAAIA,EAAE,OAAA,EAAQ;AAAA,EACd,MAAA,EAAQA,CAAAA,CAAE,OAAA,CAAQ,IAAI,CAAA;AAAA,EACtB,OAAA,EAASA,EAAE,OAAA;AACZ,CAAC;AAIM,IAAM,sBAAA,GAAyBA,EAAE,MAAA,CAAO;AAAA,EAC9C,EAAA,EAAIA,EAAE,OAAA,EAAQ;AAAA,EACd,MAAA,EAAQA,CAAAA,CAAE,OAAA,CAAQ,KAAK;AACxB,CAAC;ACfM,IAAM,qBAAA,GAAwBA,EAAE,MAAA,CAAO;AAAA,EAC7C,EAAA,EAAIA,EAAE,MAAA,EAAO;AAAA,EACb,OAAA,EAASA,EAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,EAAE,MAAA;AAAO;AACrB,CAAC;AAGM,IAAM,oBAAA,GAAuBA,EAAE,MAAA,CAAO;AAAA,EAC5C,EAAA,EAAIA,EAAE,MAAA,EAAO;AAAA,EACb,OAAA,EAASA,EAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,EAAE,MAAA,EAAO;AAAA,EACpB,gBAAA,EAAkBA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACtC,eAAA,EAAiBA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACrC,iBAAA,EAAmBA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,EACvC,sBAAA,EAAwBA,CAAAA,CAAE,MAAA,EAAO,CAAE,QAAA;AACpC,CAAC;AAGM,IAAM,aAAA,GAAgBA,EAAE,MAAA,CAAO;AAAA,EACrC,EAAA,EAAIA,EAAE,MAAA,EAAO;AAAA,EACb,MAAA,EAAQA,EAAE,MAAA,EAAO;AAAA,EACjB,OAAA,EAASA,EAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,EAAE,MAAA;AACd,CAAC;AAKM,IAAM,sBAAA,GAAyBA,EAAE,WAAA,CAAY;AAAA,EACnD,EAAA,EAAIA,EAAE,MAAA,EAAO;AAAA,EACb,IAAA,EAAMA,EAAE,MAAA,EAAO;AAAA,EACf,OAAA,EAASA,EAAE,MAAA,EAAO;AAAA,EAClB,SAAA,EAAWA,EAAE,MAAA,EAAO;AAAA,EACpB,mBAAA,EAAqBA,CAAAA,CAAE,KAAA,CAAM,oBAAoB,EAAE,OAAA,EAAQ;AAAA,EAC3D,cAAA,EAAgBA,CAAAA,CAAE,KAAA,CAAM,mBAAmB,EAAE,OAAA,EAAQ;AAAA,EACrD,UAAA,EAAYA,CAAAA,CAAE,KAAA,CAAM,eAAe,EAAE,OAAA,EAAQ;AAAA,EAC7C,QAAQA,CAAAA,CAAE,KAAA,CAAMA,EAAE,MAAA,EAAQ,EAAE,OAAA,EAAQ;AAAA,EACpC,eAAA,EAAiB,sBAAsB,OAAA;AACxC,CAAC;;;ACpCD,gBAAuB,eACtB,IAAA,EAC8B;AAC9B,EAAA,MAAM,MAAA,GAAS,KAAK,SAAA,EAAU;AAC9B,EAAA,MAAM,OAAA,GAAU,IAAI,WAAA,EAAY;AAChC,EAAA,IAAI,MAAA,GAAS,EAAA;AAEb,EAAA,IAAI;AACH,IAAA,OAAO,IAAA,EAAM;AACZ,MAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,MAAM,OAAO,IAAA,EAAK;AAC1C,MAAA,IAAI,IAAA,EAAM;AACV,MAAA,MAAA,IAAU,QAAQ,MAAA,CAAO,KAAA,EAAO,EAAE,MAAA,EAAQ,MAAM,CAAA;AAKhD,MAAA,OAAO,IAAA,EAAM;AACZ,QAAA,MAAM,GAAA,GAAM,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA;AACjC,QAAA,IAAI,MAAM,CAAA,EAAG;AACb,QAAA,MAAM,QAAA,GAAW,MAAA,CAAO,KAAA,CAAM,CAAA,EAAG,GAAG,CAAA;AACpC,QAAA,MAAA,GAAS,MAAA,CAAO,KAAA,CAAM,GAAA,GAAM,CAAC,CAAA;AAE7B,QAAA,MAAM,KAAA,GAAQ,QAAA,CAAS,KAAA,CAAM,IAAI,CAAA;AACjC,QAAA,MAAM,SAAA,GAAY,MAAM,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,UAAA,CAAW,QAAQ,CAAC,CAAA;AAC1D,QAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,UAAA,CAAW,OAAO,CAAC,CAAA;AACxD,QAAA,IAAI,CAAC,QAAA,EAAU;AACf,QAAA,MAAM,WAAA,GAAc,QAAA,CAAS,OAAA,CAAQ,WAAA,EAAa,EAAE,CAAA;AAIpD,QAAA,IAAI,SAAA,EAAW,OAAA,CAAQ,YAAA,EAAc,EAAE,MAAM,OAAA,EAAS;AACrD,UAAA,MAAM,EAAE,IAAA,EAAM,OAAA,EAAS,OAAA,EAAS,WAAA,EAAY;AAC5C,UAAA;AAAA,QACD;AAEA,QAAA,IAAI,IAAA;AACJ,QAAA,IAAI;AACH,UAAA,IAAA,GAAO,IAAA,CAAK,MAAM,WAAW,CAAA;AAAA,QAC9B,CAAA,CAAA,MAAQ;AACP,UAAA;AAAA,QACD;AAEA,QAAA,MAAM,MAAA,GAAS,oBAAA,CAAqB,SAAA,CAAU,IAAI,CAAA;AAClD,QAAA,IAAI,CAAC,OAAO,OAAA,EAAS;AAGpB,UAAA,IACE,IAAA,EAA4B,IAAA,KAAS,SAAA,IACrC,IAAA,EAAsC,aAAA,EACtC;AACD,YAAA,MAAM;AAAA,cACL,IAAA,EAAM,OAAA;AAAA,cACN,OAAA,EAAS;AAAA,aACV;AAAA,UACD;AACA,UAAA;AAAA,QACD;AAEA,QAAA,MAAM,KAAK,MAAA,CAAO,IAAA;AAClB,QAAA,IAAI,EAAA,CAAG,SAAS,OAAA,EAAS;AACxB,UAAA,MAAM,EAAE,GAAG,EAAA,EAAI,KAAA,EAAO,GAAG,IAAA,EAAK;AAAA,QAC/B,CAAA,MAAA,IAAW,EAAA,CAAG,IAAA,KAAS,UAAA,EAAY;AAClC,UAAA,MAAM,EAAE,GAAG,EAAA,EAAI,KAAA,EAAO,GAAG,IAAA,EAAK;AAAA,QAC/B,CAAA,MAAO;AACN,UAAA,MAAM,EAAA;AAAA,QACP;AAAA,MACD;AAAA,IACD;AAAA,EACD,CAAA,SAAE;AACD,IAAA,MAAA,CAAO,MAAA,EAAO,CAAE,KAAA,CAAM,MAAM,MAAS,CAAA;AAAA,EACtC;AACD;;;AC/CA,SAAS,gBAAgB,GAAA,EAA0B;AAClD,EAAA,MAAM,MAAA,GAAS,gBAAA,CAAiB,SAAA,CAAU,GAAG,CAAA;AAC7C,EAAA,IAAI,MAAA,CAAO,OAAA,EAAS,OAAO,MAAA,CAAO,IAAA;AAClC,EAAA,MAAM,CAAA,GAAI,GAAA;AAIV,EAAA,MAAM,EAAA,GAAK,mBAAA,CAAoB,SAAA,CAAU,CAAA,EAAG,aAAa,CAAA;AACzD,EAAA,OAAO;AAAA,IACN,WAAW,OAAO,CAAA,EAAG,SAAA,KAAc,QAAA,GAAW,EAAE,SAAA,GAAY,EAAA;AAAA,IAC5D,QAAQ,EAAC;AAAA,IACT,eAAA,EAAiB,IAAA;AAAA,IACjB,aAAA,EAAe,EAAA,CAAG,OAAA,GAAU,EAAA,CAAG,IAAA,GAAO;AAAA,GACvC;AACD;AAEA,SAAS,cAAA,CACR,SAAA,EACA,SAAA,EACA,OAAA,EACa;AACb,EAAA,OAAO,eAAA,CAAgB;AAAA,IACtB,SAAA;AAAA,IACA,SAAA;AAAA,IACA,qBAAqB,OAAA,EAAS,mBAAA;AAAA,IAC9B,gBAAgB,OAAA,EAAS,cAAA;AAAA,IACzB,YAAY,OAAA,EAAS,UAAA;AAAA,IACrB,MAAA,EAAQ,OAAA,EAAS,MAAA,IAAU,EAAC;AAAA,IAC5B,eAAA,EAAiB,SAAS,eAAA,IAAmB,IAAA;AAAA,IAC7C,aAAA,EAAe,SAAS,aAAA,IAAiB;AAAA,GACzC,CAAA;AACF;AAEO,IAAM,kBAAN,MAAsB;AAAA,EACX,IAAA;AAAA,EAEjB,YAAY,MAAA,EAA+B;AAC1C,IAAA,IAAA,CAAK,IAAA,GAAO,WAAW,MAAM,CAAA;AAAA,EAC9B;AAAA,EAEA,YAAA,GAA2C;AAC1C,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,KAAA,EAAO,gBAAgB,CAAA;AAAA,EAC9C;AAAA,EAEA,oBAAA,GAAkD;AACjD,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,KAAA,EAAO,wBAAwB,CAAA;AAAA,EACtD;AAAA,EAEA,aAAA,GAAyC;AACxC,IAAA,OAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,MAAA,EAAQ,gBAAgB,CAAA;AAAA,EAC/C;AAAA,EAEA,WAAW,SAAA,EAAqC;AAC/C,IAAA,OAAO,KAAK,IAAA,CAAK,IAAA;AAAA,MAChB,KAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,KAChD;AAAA,EACD;AAAA,EAEA,MAAM,cAAc,SAAA,EAAkC;AACrD,IAAA,MAAM,KAAK,IAAA,CAAK,IAAA;AAAA,MACf,QAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,KAChD;AAAA,EACD;AAAA,EAEA,WAAA,CACC,WACA,IAAA,EAC8B;AAC9B,IAAA,MAAM,MAAA,GAAS,IAAI,eAAA,EAAgB;AACnC,IAAA,IAAI,IAAA,EAAM,UAAU,MAAA,EAAW,MAAA,CAAO,IAAI,OAAA,EAAS,MAAA,CAAO,IAAA,CAAK,KAAK,CAAC,CAAA;AACrE,IAAA,IAAI,MAAM,MAAA,EAAQ,MAAA,CAAO,GAAA,CAAI,QAAA,EAAU,KAAK,MAAM,CAAA;AAClD,IAAA,MAAM,EAAA,GAAK,OAAO,QAAA,EAAS;AAC3B,IAAA,OAAO,KAAK,IAAA,CAAK,IAAA;AAAA,MAChB,KAAA;AAAA,MACA,CAAA,eAAA,EAAkB,mBAAmB,SAAS,CAAC,YAAY,EAAA,GAAK,CAAA,CAAA,EAAI,EAAE,CAAA,CAAA,GAAK,EAAE,CAAA;AAAA,KAC9E;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,WAAW,IAAA,EAWqD;AACtE,IAAA,MAAM,MAAA,GAAS,IAAI,eAAA,CAAgB;AAAA,MAClC,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,WAAW,IAAA,CAAK,SAAA;AAAA,MAChB,IAAA,EAAM,KAAK,IAAA,IAAQ;AAAA,KACnB,CAAA;AACD,IAAA,MAAA,CAAO,GAAA,CAAI,SAAA,EAAW,IAAA,CAAK,OAAO,CAAA;AAClC,IAAA,IAAI,KAAK,GAAA,EAAK;AACb,MAAA,MAAA,CAAO,GAAA,CAAI,6BAAA,EAA+B,IAAA,CAAK,GAAA,CAAI,YAAY,CAAA;AAC/D,MAAA,MAAA,CAAO,GAAA,CAAI,yBAAA,EAA2B,IAAA,CAAK,GAAA,CAAI,QAAQ,CAAA;AACvD,MAAA,MAAA,CAAO,GAAA,CAAI,+BAAA,EAAiC,IAAA,CAAK,GAAA,CAAI,cAAc,CAAA;AAAA,IACpE;AACA,IAAA,MAAM,OAAA,GAAU,MAAM,IAAA,CAAK,IAAA,CAAK,WAAA,EAAY;AAC5C,IAAA,OAAA,CAAQ,MAAA,GAAS,mBAAA;AACjB,IAAA,MAAM,GAAA,GAAM,MAAM,IAAA,CAAK,IAAA,CAAK,KAAA;AAAA,MAC3B,KAAK,IAAA,CAAK,QAAA,CAAS,gBAAgB,MAAA,CAAO,QAAA,EAAU,CAAA,CAAE,CAAA;AAAA,MACtD,EAAE,MAAA,EAAQ,KAAA,EAAO,OAAA,EAAS,MAAA,EAAQ,KAAK,MAAA;AAAO,KAC/C;AACA,IAAA,IAAI,CAAC,GAAA,CAAI,EAAA,IAAM,CAAC,IAAI,IAAA,EAAM;AACzB,MAAA,MAAM,eAAA,CAAgB,GAAA,CAAI,MAAA,EAAQ,MAAM,GAAA,CAAI,MAAK,CAAE,KAAA,CAAM,MAAM,EAAE,CAAC,CAAA;AAAA,IACnE;AAEA,IAAA,IAAI,SAAA,GAAY,EAAA;AAChB,IAAA,IAAI,OAAA;AACJ,IAAA,WAAA,MAAiB,EAAA,IAAM,cAAA,CAAe,GAAA,CAAI,IAAI,CAAA,EAAG;AAChD,MAAA,IAAI,EAAA,CAAG,SAAS,OAAA,EAAS;AACxB,QAAA,MAAM,IAAI,cAAA,CAAe,EAAA,CAAG,OAAA,IAAW,oBAAoB,CAAA;AAAA,MAC5D;AACA,MAAA,IAAI,EAAA,CAAG,IAAA,KAAS,OAAA,EAAS,SAAA,IAAa,EAAA,CAAG,KAAA;AACzC,MAAA,IAAI,EAAA,CAAG,IAAA,KAAS,SAAA,EAAW,OAAA,GAAU,EAAA;AACrC,MAAA,MAAM,EAAA;AAAA,IACP;AAEA,IAAA,MAAM;AAAA,MACL,IAAA,EAAM,MAAA;AAAA,MACN,MAAA,EAAQ,cAAA,CAAe,IAAA,CAAK,SAAA,EAAW,WAAW,OAAO;AAAA,KAC1D;AAAA,EACD;AAAA;AAAA,EAGA,YAAY,IAAA,EAMY;AACvB,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,OAAA,EAAS;AAAA,MAC/B,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,WAAW,IAAA,CAAK,SAAA;AAAA,MAChB,IAAA,EAAM,KAAK,IAAA,IAAQ,UAAA;AAAA,MACnB,SAAS,IAAA,CAAK;AAAA,KACd,CAAA,CACA,IAAA,CAAK,eAAe,CAAA;AAAA,EACvB;AAAA,EAEA,cAAc,QAAA,EAA0C;AACvD,IAAA,OAAO,KAAK,IAAA,CACV,IAAA;AAAA,MACA,MAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,QAAQ,CAAC,CAAA,QAAA;AAAA,MAE9C,IAAA,CAAK,CAAC,QAAQ,mBAAA,CAAoB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC/C;AAAA,EAEA,aAAa,QAAA,EAAyC;AACrD,IAAA,OAAO,KAAK,IAAA,CACV,IAAA;AAAA,MACA,MAAA;AAAA,MACA,CAAA,eAAA,EAAkB,kBAAA,CAAmB,QAAQ,CAAC,CAAA,OAAA;AAAA,MAE9C,IAAA,CAAK,CAAC,QAAQ,kBAAA,CAAmB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC9C;AAAA,EAEA,sBAAsB,OAAA,EAAmD;AACxE,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,2BAA2B,EAAE,OAAA,EAAS,CAAA,CAC5D,KAAK,CAAC,GAAA,KAAQ,4BAAA,CAA6B,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EACxD;AAAA;AAAA;AAAA,EAIA,gBAAA,GAA2C;AAC1C,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,KAAA,EAAO,yBAAyB,CAAA,CAC9C,IAAA,CAAK,CAAC,GAAA,KAAQ,mBAAA,CAAoB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC/C;AAAA;AAAA;AAAA,EAIA,kBAAkB,OAAA,EAA+C;AAChE,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,4BAA4B,EAAE,OAAA,EAAS,CAAA,CAC7D,KAAK,CAAC,GAAA,KAAQ,wBAAA,CAAyB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EACpD;AAAA;AAAA;AAAA,EAIA,aAAA,GAAqC;AACpC,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,KAAA,EAAO,wBAAwB,CAAA,CAC7C,IAAA,CAAK,CAAC,GAAA,KAAQ,gBAAA,CAAiB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,WAAW,IAAA,EAGiB;AAC3B,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,MAAA,EAAQ,0BAA0B,IAAA,IAAQ,EAAE,CAAA,CAC1D,KAAK,CAAC,GAAA,KAAQ,oBAAA,CAAqB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAChD;AAAA;AAAA,EAGA,YAAA,GAA0C;AACzC,IAAA,OAAO,IAAA,CAAK,IAAA,CACV,IAAA,CAAc,QAAA,EAAU,wBAAwB,CAAA,CAChD,IAAA,CAAK,CAAC,GAAA,KAAQ,sBAAA,CAAuB,KAAA,CAAM,GAAG,CAAC,CAAA;AAAA,EAClD;AACD","file":"index.js","sourcesContent":["export class AgentChatError extends Error {\n\treadonly status?: number;\n\treadonly body?: string;\n\tconstructor(message: string, status?: number, body?: string) {\n\t\tsuper(message);\n\t\tthis.name = new.target.name;\n\t\tthis.status = status;\n\t\tthis.body = body;\n\t}\n}\n\nexport class AuthError extends AgentChatError {}\nexport class ForbiddenError extends AgentChatError {}\nexport class ConflictError extends AgentChatError {}\nexport class TicketExpiredError extends AgentChatError {}\nexport class RateLimitError extends AgentChatError {}\nexport class ServerError extends AgentChatError {}\n\nexport function errorFromStatus(status: number, body: string): AgentChatError {\n\tconst msg = `Agent API error ${status}: ${body}`;\n\tif (status === 401) return new AuthError(msg, status, body);\n\tif (status === 403) return new ForbiddenError(msg, status, body);\n\tif (status === 409) return new ConflictError(msg, status, body);\n\tif (status === 410) return new TicketExpiredError(msg, status, body);\n\tif (status === 429) return new RateLimitError(msg, status, body);\n\tif (status >= 500) return new ServerError(msg, status, body);\n\treturn new AgentChatError(msg, status, body);\n}\n","import { errorFromStatus } from \"./errors\";\n\nexport interface AgentChatClientConfig {\n\t/** Base URL of the agent API, e.g. https://hl-v2-agent.pearprotocol.io */\n\tbaseUrl: string;\n\t/** Returns the freshest auth token (handles rotation). Required. */\n\tgetToken: () => string | Promise<string>;\n\t/** Sent as `X-Auth-Token-Version`. Defaults to \"v2\". */\n\ttokenVersion?: \"v2\" | \"v3\";\n\t/** Optional fetch override (SSR / tests). Defaults to global fetch. */\n\tfetch?: typeof fetch;\n}\n\nexport interface Http {\n\tbuildUrl: (path: string) => string;\n\tauthHeaders: () => Promise<Record<string, string>>;\n\t/** The resolved fetch — the single authoritative one (JSON + SSE share it). */\n\tfetch: typeof fetch;\n\tjson: <T>(method: string, path: string, body?: unknown) => Promise<T>;\n}\n\nexport function createHttp(config: AgentChatClientConfig): Http {\n\tconst baseUrl = config.baseUrl.replace(/\\/+$/, \"\");\n\tconst tokenVersion = config.tokenVersion ?? \"v2\";\n\tconst rawFetch = config.fetch ?? globalThis.fetch;\n\tif (!rawFetch) {\n\t\tthrow new Error(\"No fetch available — pass `fetch` in the client config\");\n\t}\n\t// Bind to globalThis. `fetch` is exposed on the Http object and the SSE path\n\t// invokes it as `http.fetch(...)` — called as a method, the browser's native\n\t// fetch runs with `this === the http object` and throws \"Illegal invocation\".\n\t// The JSON path calls it as a bare `doFetch(...)` (this === undefined), which\n\t// is why createSession worked but streamChat didn't. Binding pins `this`.\n\tconst doFetch: typeof fetch = rawFetch.bind(globalThis);\n\n\tconst buildUrl = (path: string): string =>\n\t\t`${baseUrl}${path.startsWith(\"/\") ? path : `/${path}`}`;\n\n\tconst authHeaders = async (): Promise<Record<string, string>> => {\n\t\tconst token = await config.getToken();\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${token}`,\n\t\t\t\"X-Auth-Token-Version\": tokenVersion,\n\t\t};\n\t};\n\n\tconst json = async <T>(\n\t\tmethod: string,\n\t\tpath: string,\n\t\tbody?: unknown,\n\t): Promise<T> => {\n\t\tconst headers = await authHeaders();\n\t\tif (body !== undefined) headers[\"Content-Type\"] = \"application/json\";\n\t\tconst res = await doFetch(buildUrl(path), {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\t\tif (!res.ok) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\t\tif (res.status === 204) return undefined as T;\n\t\tconst text = await res.text();\n\t\treturn (text ? JSON.parse(text) : undefined) as T;\n\t};\n\n\treturn { buildUrl, authHeaders, fetch: doFetch, json };\n}\n","import { z } from \"zod\";\n\n/** A Pear trade link surfaced with an agent reply. `platform` is left an open\n * string (not an enum) so a new venue doesn't break older SDK consumers. */\nexport const TradeLinkSchema = z.object({\n\tlink: z.string(),\n\tplatform: z.string(),\n\tlabel: z.string(),\n});\nexport type TradeLink = z.infer<typeof TradeLinkSchema>;\n\nexport const TwitterSourceSchema = z.object({\n\tauthor: z.string(),\n\ttweetUrl: z.string(),\n\tpublishedAt: z.string(),\n});\nexport type TwitterSource = z.infer<typeof TwitterSourceSchema>;\n\n/** Research web-citation. The research node emits a bare URL **string** on the\n * wire (research/agent.ts maps annotations -> `url_citation.url`); a future\n * object form is also accepted and normalized to `{ url, ... }`. */\nconst CitationObjectSchema = z.object({\n\turl: z.string(),\n\tstart_index: z.number().optional(),\n\tend_index: z.number().optional(),\n\ttitle: z.string().optional(),\n});\nexport const CitationSourceSchema = z.union([\n\tz.string().transform((url) => ({ url })),\n\tCitationObjectSchema,\n]);\nexport type CitationSource = z.infer<typeof CitationSourceSchema>;\n\nexport const SuggestedActionSchema = z.object({\n\tquestion: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type SuggestedAction = z.infer<typeof SuggestedActionSchema>;\n\nexport const ChatModeSchema = z.enum([\"standard\", \"advanced\"]);\nexport type ChatMode = z.infer<typeof ChatModeSchema>;\n\n/** The Pear client surface a chat request is from. Drives per-surface behavior\n * server-side (analysis universe / execution policy). Optional on the wire —\n * when omitted the server falls back to the sessionId-derived value. */\nexport const ChatSurfaceSchema = z.enum([\n\t\"pear_v3\",\n\t\"pear_pro\",\n\t\"base_mini\",\n\t\"tg_dm\",\n\t\"tg_group\",\n\t\"web\",\n]);\nexport type ChatSurface = z.infer<typeof ChatSurfaceSchema>;\n","import { z } from \"zod\";\n\n/** Known ticket actions. Used for typing; the wire `action` field is parsed\n * permissively (plain string) elsewhere for forward-compat. */\nexport const TicketActionSchema = z.enum([\n\t\"open_position\",\n\t\"close_position\",\n\t\"close_all_positions\",\n\t\"adjust_position\",\n\t\"adjust_advance_position\",\n\t\"reverse_position\",\n\t\"rebalance_position\",\n\t\"set_risk_parameters\",\n]);\nexport type TicketAction = z.infer<typeof TicketActionSchema>;\n\nexport const TicketStatusSchema = z.enum([\n\t\"PENDING\",\n\t\"EXECUTING\",\n\t\"EXECUTED\",\n\t\"CANCELLED\",\n\t\"FAILED\",\n]);\nexport type TicketStatus = z.infer<typeof TicketStatusSchema>;\n\n/** Surfaced on a turn when a money-moving write was FROZEN (nothing executed).\n * `action` is a plain string (forward-compatible); compare against\n * `TicketActionSchema.options` if you need to switch on known actions. */\nexport const PendingActionSchema = z.object({\n\tticketId: z.string(),\n\taction: z.string(),\n\tconsequence: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type PendingAction = z.infer<typeof PendingActionSchema>;\n\n/** Response of POST /trade/tickets/:id/confirm. Strict on the money fields,\n * loose (passthrough) on the action-specific `result` payload. `status` is\n * intentionally narrowed to the two TERMINAL confirm outcomes this endpoint\n * returns; widen to `TicketStatusSchema` if the BE can ever return another. */\nexport const ConfirmResultSchema = z.looseObject({\n\tok: z.boolean(),\n\tstatus: z.enum([\"EXECUTED\", \"FAILED\"]),\n\t// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER\n\t// implicitly optional, so dropping it would make these fields required.\n\tresult: z.unknown().optional(),\n\tpositionsSnapshot: z.unknown().optional(),\n\timages: z.array(z.string()).optional(),\n});\nexport type ConfirmResult = z.infer<typeof ConfirmResultSchema>;\n\nexport const CancelResultSchema = z.object({\n\tok: z.literal(true),\n\tstatus: z.literal(\"CANCELLED\"),\n});\nexport type CancelResult = z.infer<typeof CancelResultSchema>;\n\nexport const SetConfirmationsResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetConfirmationsResult = z.infer<\n\ttypeof SetConfirmationsResultSchema\n>;\n\n/** Response of GET /trade/tickets/settings — the caller's two independent trade\n * toggles. `executionEnabled` is the master execution switch (any write at all);\n * `confirmationsEnabled` is the confirm-before-write preference. */\nexport const TradeSettingsSchema = z.object({\n\texecutionEnabled: z.boolean(),\n\tconfirmationsEnabled: z.boolean(),\n});\nexport type TradeSettings = z.infer<typeof TradeSettingsSchema>;\n\n/** Response of POST /trade/tickets/execution — the new master-switch state. */\nexport const SetExecutionResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetExecutionResult = z.infer<typeof SetExecutionResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\nimport { PendingActionSchema } from \"./tickets\";\n\nexport const TokenEventSchema = z.object({\n\ttype: z.literal(\"token\"),\n\ttext: z.string(),\n});\n// `thinking` is emitted by ADVANCED mode only (the standard pipeline doesn't).\nexport const ThinkingEventSchema = z.object({\n\ttype: z.literal(\"thinking\"),\n\ttext: z.string(),\n});\nexport const StatusEventSchema = z.object({\n\ttype: z.literal(\"status\"),\n\ttext: z.string(),\n\tphase: z.enum([\"start\", \"end\"]).optional(),\n\tnode: z.string().optional(),\n});\nexport const SourcesEventSchema = z.object({\n\ttype: z.literal(\"sources\"),\n\t// `.catch` on every NON-critical field so a malformed metadata array can\n\t// never sink the whole event — `pendingAction` (a staged money-moving trade)\n\t// rides on this same frame and MUST always survive.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).catch([]).optional(), // resolved URL strings\n\tsuggestedAction: SuggestedActionSchema.nullish().catch(null),\n\t// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,\n\t// never be fabricated.\n\tpendingAction: PendingActionSchema.nullish(),\n});\nexport const ErrorEventSchema = z.object({\n\ttype: z.literal(\"error\"),\n\tmessage: z.string().optional(),\n});\n\n/** The discriminated union of events the SSE wire delivers. Parse each event\n * with `.safeParse`; on failure (unknown/legacy `cycle` etc.) IGNORE it — do\n * not throw. */\nexport const AgentWireEventSchema = z.discriminatedUnion(\"type\", [\n\tTokenEventSchema,\n\tThinkingEventSchema,\n\tStatusEventSchema,\n\tSourcesEventSchema,\n\tErrorEventSchema,\n]);\nexport type AgentWireEvent = z.infer<typeof AgentWireEventSchema>;\n\n/** Final assembled turn — the shape of `POST /chat` AND the SDK's synthetic\n * `done` event (the SSE wire has no `done` frame; the SDK assembles it). */\nexport const ChatResultSchema = z.object({\n\tfinalText: z.string(),\n\tsessionId: z.string().optional(),\n\t// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null\n\t// on drift so a hard `.parse` can never throw away a real `pendingAction`.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).default([]),\n\tsuggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),\n\tpendingAction: PendingActionSchema.nullable().default(null),\n});\nexport type ChatResult = z.infer<typeof ChatResultSchema>;\n\n/** The RAW wire union plus a synthetic terminal `done`. NOTE: the SDK actually\n * emits a NORMALIZED `StreamEvent` (token/thinking carry a `delta`) defined in\n * the SDK's stream module; this `AgentEvent` is the pre-normalization shape. */\nexport type AgentEvent = AgentWireEvent | { type: \"done\"; result: ChatResult };\n","import { z } from \"zod\";\n\n/** Response of GET /auth/link-wallet/self — whether the caller's wallet has a\n * WalletLink (i.e. the agent holds an API key and can execute trades). */\nexport const LinkStatusSchema = z.object({\n\tlinked: z.boolean(),\n\twalletAddress: z.string(),\n});\nexport type LinkStatus = z.infer<typeof LinkStatusSchema>;\n\n/** Response of POST /auth/link-wallet/self. `created` is true only when this\n * call minted a new key (false on the idempotent already-linked path). */\nexport const SelfLinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(true),\n\tcreated: z.boolean(),\n});\nexport type SelfLinkResult = z.infer<typeof SelfLinkResultSchema>;\n\n/** Response of DELETE /auth/link-wallet/self. */\nexport const SelfUnlinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(false),\n});\nexport type SelfUnlinkResult = z.infer<typeof SelfUnlinkResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\n\nexport const SessionListItemSchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(), // ISO (Date serialized over the wire)\n});\nexport type SessionListItem = z.infer<typeof SessionListItemSchema>;\n\nexport const SessionSummarySchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n\tfirstUserMessage: z.string().optional(),\n\tlastUserMessage: z.string().optional(),\n\tlastUserMessageAt: z.string().optional(),\n\tlastAssistantMessageAt: z.string().optional(),\n});\nexport type SessionSummary = z.infer<typeof SessionSummarySchema>;\n\nexport const SessionSchema = z.object({\n\tid: z.string(),\n\tuserId: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n});\nexport type Session = z.infer<typeof SessionSchema>;\n\n/** A persisted chat message (history). `images` are pre-resolved URL strings.\n * `z.looseObject` keeps unknown future fields instead of stripping them. */\nexport const AgentChatMessageSchema = z.looseObject({\n\tid: z.string(),\n\trole: z.string(),\n\tcontent: z.string(),\n\tcreatedAt: z.string(),\n\tresearchAnnotations: z.array(CitationSourceSchema).nullish(),\n\ttwitterSources: z.array(TwitterSourceSchema).nullish(),\n\ttradeLinks: z.array(TradeLinkSchema).nullish(),\n\timages: z.array(z.string()).nullish(),\n\tsuggestedAction: SuggestedActionSchema.nullish(),\n});\nexport type AgentChatMessage = z.infer<typeof AgentChatMessageSchema>;\n","import { type AgentWireEvent, AgentWireEventSchema } from \"./protocol\";\n\n/** A token/thinking event normalized to expose an incremental `delta`. This\n * backend is DELTA-only on every path, so `delta === text` — there is no\n * cumulative reconciliation (a `startsWith` heuristic corrupts real output). */\nexport type StreamEvent =\n\t| (Extract<AgentWireEvent, { type: \"token\" }> & { delta: string })\n\t| (Extract<AgentWireEvent, { type: \"thinking\" }> & { delta: string })\n\t| Exclude<AgentWireEvent, { type: \"token\" | \"thinking\" }>;\n\nexport async function* parseSseStream(\n\tbody: ReadableStream<Uint8Array>,\n): AsyncGenerator<StreamEvent> {\n\tconst reader = body.getReader();\n\tconst decoder = new TextDecoder();\n\tlet buffer = \"\";\n\n\ttry {\n\t\twhile (true) {\n\t\t\tconst { done, value } = await reader.read();\n\t\t\tif (done) break;\n\t\t\tbuffer += decoder.decode(value, { stream: true });\n\n\t\t\t// Drain every complete `\\n\\n`-delimited frame in the buffer. `const idx`\n\t\t\t// is recomputed each iteration (no assignment-in-`while`-head: that trips\n\t\t\t// biome `noAssignInExpressions`, a non-auto-fixable CI error).\n\t\t\twhile (true) {\n\t\t\t\tconst idx = buffer.indexOf(\"\\n\\n\");\n\t\t\t\tif (idx < 0) break;\n\t\t\t\tconst rawEvent = buffer.slice(0, idx);\n\t\t\t\tbuffer = buffer.slice(idx + 2);\n\n\t\t\t\tconst lines = rawEvent.split(\"\\n\");\n\t\t\t\tconst eventLine = lines.find((l) => l.startsWith(\"event:\"));\n\t\t\t\tconst dataLine = lines.find((l) => l.startsWith(\"data:\"));\n\t\t\t\tif (!dataLine) continue;\n\t\t\t\tconst payloadText = dataLine.replace(/^data:\\s?/, \"\");\n\n\t\t\t\t// NestJS surfaces stream errors as `event: error\\ndata: <plain string>`\n\t\t\t\t// (NON-JSON). Detect it BEFORE JSON.parse so it isn't swallowed.\n\t\t\t\tif (eventLine?.replace(/^event:\\s?/, \"\") === \"error\") {\n\t\t\t\t\tyield { type: \"error\", message: payloadText };\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet json: unknown;\n\t\t\t\ttry {\n\t\t\t\t\tjson = JSON.parse(payloadText);\n\t\t\t\t} catch {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst parsed = AgentWireEventSchema.safeParse(json);\n\t\t\t\tif (!parsed.success) {\n\t\t\t\t\t// Never SILENTLY drop a money-path frame: if it looks like a sources\n\t\t\t\t\t// event carrying pendingAction, fail loud instead of losing a trade.\n\t\t\t\t\tif (\n\t\t\t\t\t\t(json as { type?: string })?.type === \"sources\" &&\n\t\t\t\t\t\t(json as { pendingAction?: unknown })?.pendingAction\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\ttype: \"error\",\n\t\t\t\t\t\t\tmessage: \"malformed sources frame with pendingAction\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst ev = parsed.data;\n\t\t\t\tif (ev.type === \"token\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else if (ev.type === \"thinking\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else {\n\t\t\t\t\tyield ev;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} finally {\n\t\treader.cancel().catch(() => undefined);\n\t}\n}\n","import { AgentChatError, errorFromStatus } from \"./errors\";\nimport { type AgentChatClientConfig, createHttp, type Http } from \"./http\";\nimport {\n\ttype AgentChatMessage,\n\ttype CancelResult,\n\tCancelResultSchema,\n\ttype ChatMode,\n\ttype ChatResult,\n\tChatResultSchema,\n\ttype ChatSurface,\n\ttype ConfirmResult,\n\tConfirmResultSchema,\n\ttype LinkStatus,\n\tLinkStatusSchema,\n\tPendingActionSchema,\n\ttype SelfLinkResult,\n\tSelfLinkResultSchema,\n\ttype SelfUnlinkResult,\n\tSelfUnlinkResultSchema,\n\ttype Session,\n\ttype SessionListItem,\n\ttype SessionSummary,\n\ttype SetConfirmationsResult,\n\tSetConfirmationsResultSchema,\n\ttype SetExecutionResult,\n\tSetExecutionResultSchema,\n\ttype TradeSettings,\n\tTradeSettingsSchema,\n} from \"./protocol\";\nimport { parseSseStream, type StreamEvent } from \"./stream\";\n\n/** Parse a ChatResult but NEVER throw away a real `pendingAction` on metadata\n * drift: on a parse failure, fall back to a minimal result that preserves\n * `finalText` + `pendingAction` rather than rejecting the whole turn. */\nfunction parseChatResult(raw: unknown): ChatResult {\n\tconst parsed = ChatResultSchema.safeParse(raw);\n\tif (parsed.success) return parsed.data;\n\tconst r = raw as { finalText?: unknown; pendingAction?: unknown };\n\t// Salvage finalText, but NEVER fabricate a ticket: keep pendingAction only if\n\t// it INDEPENDENTLY validates — a corrupt ticket is dropped, never handed to\n\t// confirmTicket() (the money endpoint).\n\tconst pa = PendingActionSchema.safeParse(r?.pendingAction);\n\treturn {\n\t\tfinalText: typeof r?.finalText === \"string\" ? r.finalText : \"\",\n\t\timages: [],\n\t\tsuggestedAction: null,\n\t\tpendingAction: pa.success ? pa.data : null,\n\t};\n}\n\nfunction assembleResult(\n\tsessionId: string,\n\tfinalText: string,\n\tsources: Extract<StreamEvent, { type: \"sources\" }> | undefined,\n): ChatResult {\n\treturn parseChatResult({\n\t\tfinalText,\n\t\tsessionId,\n\t\tresearchAnnotations: sources?.researchAnnotations,\n\t\ttwitterSources: sources?.twitterSources,\n\t\ttradeLinks: sources?.tradeLinks,\n\t\timages: sources?.images ?? [],\n\t\tsuggestedAction: sources?.suggestedAction ?? null,\n\t\tpendingAction: sources?.pendingAction ?? null,\n\t});\n}\n\nexport class AgentChatClient {\n\tprivate readonly http: Http;\n\n\tconstructor(config: AgentChatClientConfig) {\n\t\tthis.http = createHttp(config);\n\t}\n\n\tlistSessions(): Promise<SessionListItem[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions\");\n\t}\n\n\tlistSessionSummaries(): Promise<SessionSummary[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions/summary\");\n\t}\n\n\tcreateSession(): Promise<{ id: string }> {\n\t\treturn this.http.json(\"POST\", \"/chat/sessions\");\n\t}\n\n\tgetSession(sessionId: string): Promise<Session> {\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tasync deleteSession(sessionId: string): Promise<void> {\n\t\tawait this.http.json(\n\t\t\t\"DELETE\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tgetMessages(\n\t\tsessionId: string,\n\t\topts?: { limit?: number; before?: string },\n\t): Promise<AgentChatMessage[]> {\n\t\tconst params = new URLSearchParams();\n\t\tif (opts?.limit !== undefined) params.set(\"limit\", String(opts.limit));\n\t\tif (opts?.before) params.set(\"before\", opts.before);\n\t\tconst qs = params.toString();\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : \"\"}`,\n\t\t);\n\t}\n\n\t/** Stream a turn. Yields token/thinking/status/sources events, then a\n\t * synthetic `{type:'done', result}` assembled from accumulated token deltas +\n\t * the final `sources` payload (the SSE wire has no `done` frame). Throws an\n\t * `AgentChatError` if the backend emits a mid-stream `error` frame. */\n\tasync *streamChat(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Declares the client surface (pear_v3 / pear_pro / base_mini / …). Required —\n\t\t * the API rejects requests without a valid surface. Drives per-surface behavior. */\n\t\tsurface: ChatSurface;\n\t\tsignal?: AbortSignal;\n\t\t/** CTA callback — set when the user clicks a suggested-action option; the\n\t\t * agent rebuilds the turn from this context server-side. */\n\t\tcta?: { previousText: string; question: string; selectedOption: string };\n\t}): AsyncGenerator<StreamEvent | { type: \"done\"; result: ChatResult }> {\n\t\tconst params = new URLSearchParams({\n\t\t\tmessage: args.message,\n\t\t\tsessionId: args.sessionId,\n\t\t\tmode: args.mode ?? \"standard\",\n\t\t});\n\t\tparams.set(\"surface\", args.surface);\n\t\tif (args.cta) {\n\t\t\tparams.set(\"suggestedActionPreviousText\", args.cta.previousText);\n\t\t\tparams.set(\"suggestedActionQuestion\", args.cta.question);\n\t\t\tparams.set(\"suggestedActionSelectedOption\", args.cta.selectedOption);\n\t\t}\n\t\tconst headers = await this.http.authHeaders();\n\t\theaders.Accept = \"text/event-stream\";\n\t\tconst res = await this.http.fetch(\n\t\t\tthis.http.buildUrl(`/chat/stream?${params.toString()}`),\n\t\t\t{ method: \"GET\", headers, signal: args.signal },\n\t\t);\n\t\tif (!res.ok || !res.body) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\n\t\tlet finalText = \"\";\n\t\tlet sources: Extract<StreamEvent, { type: \"sources\" }> | undefined;\n\t\tfor await (const ev of parseSseStream(res.body)) {\n\t\t\tif (ev.type === \"error\") {\n\t\t\t\tthrow new AgentChatError(ev.message ?? \"Agent stream error\");\n\t\t\t}\n\t\t\tif (ev.type === \"token\") finalText += ev.delta;\n\t\t\tif (ev.type === \"sources\") sources = ev;\n\t\t\tyield ev;\n\t\t}\n\n\t\tyield {\n\t\t\ttype: \"done\",\n\t\t\tresult: assembleResult(args.sessionId, finalText, sources),\n\t\t};\n\t}\n\n\t/** Sync send (POST /chat). Prefer `streamChat` for UX. */\n\tsendMessage(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Required — the API rejects requests without a valid surface. */\n\t\tsurface: ChatSurface;\n\t}): Promise<ChatResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/chat\", {\n\t\t\t\tmessage: args.message,\n\t\t\t\tsessionId: args.sessionId,\n\t\t\t\tmode: args.mode ?? \"standard\",\n\t\t\t\tsurface: args.surface,\n\t\t\t})\n\t\t\t.then(parseChatResult);\n\t}\n\n\tconfirmTicket(ticketId: string): Promise<ConfirmResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`,\n\t\t\t)\n\t\t\t.then((raw) => ConfirmResultSchema.parse(raw));\n\t}\n\n\tcancelTicket(ticketId: string): Promise<CancelResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`,\n\t\t\t)\n\t\t\t.then((raw) => CancelResultSchema.parse(raw));\n\t}\n\n\tsetTradeConfirmations(enabled: boolean): Promise<SetConfirmationsResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/settings\", { enabled })\n\t\t\t.then((raw) => SetConfirmationsResultSchema.parse(raw));\n\t}\n\n\t/** Read both trade toggles for the caller wallet: the master execution switch\n\t * and the confirm-before-write preference. */\n\tgetTradeSettings(): Promise<TradeSettings> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/trade/tickets/settings\")\n\t\t\t.then((raw) => TradeSettingsSchema.parse(raw));\n\t}\n\n\t/** Flip the caller's master execution switch. `false` opts the wallet out of\n\t * all money-moving writes; `true` restores the default-ON state. */\n\tsetTradeExecution(enabled: boolean): Promise<SetExecutionResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/execution\", { enabled })\n\t\t\t.then((raw) => SetExecutionResultSchema.parse(raw));\n\t}\n\n\t/** Whether the caller's wallet is linked to the agent (i.e. the agent can\n\t * execute trades for it). Backend-verified — don't cache this locally. */\n\tgetLinkStatus(): Promise<LinkStatus> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => LinkStatusSchema.parse(raw));\n\t}\n\n\t/** Link the caller's wallet: the agent mints a Pear API key server-side AS\n\t * the caller (their token is forwarded) — the key never exists client-side.\n\t * Idempotent when already linked; `force` re-mints (recovery), `code` binds\n\t * a Telegram identity (replaces the legacy secret-based flow). */\n\tlinkWallet(opts?: {\n\t\tforce?: boolean;\n\t\tcode?: string;\n\t}): Promise<SelfLinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/auth/link-wallet/self\", opts ?? {})\n\t\t\t.then((raw) => SelfLinkResultSchema.parse(raw));\n\t}\n\n\t/** Unlink the caller's wallet — the agent loses trade authority. */\n\tunlinkWallet(): Promise<SelfUnlinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"DELETE\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => SelfUnlinkResultSchema.parse(raw));\n\t}\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/errors.ts","../src/http.ts","../src/protocol/primitives.ts","../src/protocol/tickets.ts","../src/protocol/events.ts","../src/protocol/link.ts","../src/protocol/messages.ts","../src/stream.ts","../src/client.ts"],"names":["z"],"mappings":"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","file":"index.js","sourcesContent":["export class AgentChatError extends Error {\n\treadonly status?: number;\n\treadonly body?: string;\n\tconstructor(message: string, status?: number, body?: string) {\n\t\tsuper(message);\n\t\tthis.name = new.target.name;\n\t\tthis.status = status;\n\t\tthis.body = body;\n\t}\n}\n\nexport class AuthError extends AgentChatError {}\nexport class ForbiddenError extends AgentChatError {}\nexport class ConflictError extends AgentChatError {}\nexport class TicketExpiredError extends AgentChatError {}\nexport class RateLimitError extends AgentChatError {}\nexport class ServerError extends AgentChatError {}\n\nexport function errorFromStatus(status: number, body: string): AgentChatError {\n\tconst msg = `Agent API error ${status}: ${body}`;\n\tif (status === 401) return new AuthError(msg, status, body);\n\tif (status === 403) return new ForbiddenError(msg, status, body);\n\tif (status === 409) return new ConflictError(msg, status, body);\n\tif (status === 410) return new TicketExpiredError(msg, status, body);\n\tif (status === 429) return new RateLimitError(msg, status, body);\n\tif (status >= 500) return new ServerError(msg, status, body);\n\treturn new AgentChatError(msg, status, body);\n}\n","import { errorFromStatus } from \"./errors\";\n\nexport interface AgentChatClientConfig {\n\t/** Base URL of the agent API, e.g. https://hl-v2-agent.pearprotocol.io */\n\tbaseUrl: string;\n\t/** Returns the freshest auth token (handles rotation). Required. */\n\tgetToken: () => string | Promise<string>;\n\t/** Sent as `X-Auth-Token-Version`. Defaults to \"v2\". */\n\ttokenVersion?: \"v2\" | \"v3\";\n\t/** Optional fetch override (SSR / tests). Defaults to global fetch. */\n\tfetch?: typeof fetch;\n}\n\nexport interface Http {\n\tbuildUrl: (path: string) => string;\n\tauthHeaders: () => Promise<Record<string, string>>;\n\t/** The resolved fetch — the single authoritative one (JSON + SSE share it). */\n\tfetch: typeof fetch;\n\tjson: <T>(method: string, path: string, body?: unknown) => Promise<T>;\n}\n\nexport function createHttp(config: AgentChatClientConfig): Http {\n\tconst baseUrl = config.baseUrl.replace(/\\/+$/, \"\");\n\tconst tokenVersion = config.tokenVersion ?? \"v2\";\n\tconst rawFetch = config.fetch ?? globalThis.fetch;\n\tif (!rawFetch) {\n\t\tthrow new Error(\"No fetch available — pass `fetch` in the client config\");\n\t}\n\t// Bind to globalThis. `fetch` is exposed on the Http object and the SSE path\n\t// invokes it as `http.fetch(...)` — called as a method, the browser's native\n\t// fetch runs with `this === the http object` and throws \"Illegal invocation\".\n\t// The JSON path calls it as a bare `doFetch(...)` (this === undefined), which\n\t// is why createSession worked but streamChat didn't. Binding pins `this`.\n\tconst doFetch: typeof fetch = rawFetch.bind(globalThis);\n\n\tconst buildUrl = (path: string): string =>\n\t\t`${baseUrl}${path.startsWith(\"/\") ? path : `/${path}`}`;\n\n\tconst authHeaders = async (): Promise<Record<string, string>> => {\n\t\tconst token = await config.getToken();\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${token}`,\n\t\t\t\"X-Auth-Token-Version\": tokenVersion,\n\t\t};\n\t};\n\n\tconst json = async <T>(\n\t\tmethod: string,\n\t\tpath: string,\n\t\tbody?: unknown,\n\t): Promise<T> => {\n\t\tconst headers = await authHeaders();\n\t\tif (body !== undefined) headers[\"Content-Type\"] = \"application/json\";\n\t\tconst res = await doFetch(buildUrl(path), {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\t\tif (!res.ok) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\t\tif (res.status === 204) return undefined as T;\n\t\tconst text = await res.text();\n\t\treturn (text ? JSON.parse(text) : undefined) as T;\n\t};\n\n\treturn { buildUrl, authHeaders, fetch: doFetch, json };\n}\n","import { z } from \"zod\";\n\n/** A Pear trade link surfaced with an agent reply. `platform` is left an open\n * string (not an enum) so a new venue doesn't break older SDK consumers. */\nexport const TradeLinkSchema = z.object({\n\tlink: z.string(),\n\tplatform: z.string(),\n\tlabel: z.string(),\n});\nexport type TradeLink = z.infer<typeof TradeLinkSchema>;\n\nexport const TwitterSourceSchema = z.object({\n\tauthor: z.string(),\n\ttweetUrl: z.string(),\n\tpublishedAt: z.string(),\n});\nexport type TwitterSource = z.infer<typeof TwitterSourceSchema>;\n\n/** Research web-citation. The research node emits a bare URL **string** on the\n * wire (research/agent.ts maps annotations -> `url_citation.url`); a future\n * object form is also accepted and normalized to `{ url, ... }`. */\nconst CitationObjectSchema = z.object({\n\turl: z.string(),\n\tstart_index: z.number().optional(),\n\tend_index: z.number().optional(),\n\ttitle: z.string().optional(),\n});\nexport const CitationSourceSchema = z.union([\n\tz.string().transform((url) => ({ url })),\n\tCitationObjectSchema,\n]);\nexport type CitationSource = z.infer<typeof CitationSourceSchema>;\n\nexport const SuggestedActionSchema = z.object({\n\tquestion: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type SuggestedAction = z.infer<typeof SuggestedActionSchema>;\n\nexport const ChatModeSchema = z.enum([\"standard\", \"advanced\"]);\nexport type ChatMode = z.infer<typeof ChatModeSchema>;\n\n/** The Pear client surface a chat request declares — drives per-surface behavior\n * server-side (analysis universe / execution policy). REQUIRED on the wire. The\n * Telegram surfaces (tg_dm / tg_group) are resolved server-side from the TG\n * session and are NOT client-declarable, so they're intentionally absent here. */\nexport const ChatSurfaceSchema = z.enum([\n\t\"pear_v3\",\n\t\"pear_pro\",\n\t\"base_mini\",\n\t\"web\",\n]);\nexport type ChatSurface = z.infer<typeof ChatSurfaceSchema>;\n","import { z } from \"zod\";\n\n/** Known ticket actions. Used for typing; the wire `action` field is parsed\n * permissively (plain string) elsewhere for forward-compat. */\nexport const TicketActionSchema = z.enum([\n\t\"open_position\",\n\t\"close_position\",\n\t\"close_all_positions\",\n\t\"adjust_position\",\n\t\"adjust_advance_position\",\n\t\"reverse_position\",\n\t\"rebalance_position\",\n\t\"set_risk_parameters\",\n]);\nexport type TicketAction = z.infer<typeof TicketActionSchema>;\n\nexport const TicketStatusSchema = z.enum([\n\t\"PENDING\",\n\t\"EXECUTING\",\n\t\"EXECUTED\",\n\t\"CANCELLED\",\n\t\"FAILED\",\n]);\nexport type TicketStatus = z.infer<typeof TicketStatusSchema>;\n\n/** Surfaced on a turn when a money-moving write was FROZEN (nothing executed).\n * `action` is a plain string (forward-compatible); compare against\n * `TicketActionSchema.options` if you need to switch on known actions. */\nexport const PendingActionSchema = z.object({\n\tticketId: z.string(),\n\taction: z.string(),\n\tconsequence: z.string(),\n\toptions: z.array(z.string()),\n});\nexport type PendingAction = z.infer<typeof PendingActionSchema>;\n\n/** Response of POST /trade/tickets/:id/confirm. Strict on the money fields,\n * loose (passthrough) on the action-specific `result` payload. `status` is\n * intentionally narrowed to the two TERMINAL confirm outcomes this endpoint\n * returns; widen to `TicketStatusSchema` if the BE can ever return another. */\nexport const ConfirmResultSchema = z.looseObject({\n\tok: z.boolean(),\n\tstatus: z.enum([\"EXECUTED\", \"FAILED\"]),\n\t// `.optional()` is load-bearing: in zod v4 `z.unknown()` is NO LONGER\n\t// implicitly optional, so dropping it would make these fields required.\n\tresult: z.unknown().optional(),\n\tpositionsSnapshot: z.unknown().optional(),\n\timages: z.array(z.string()).optional(),\n});\nexport type ConfirmResult = z.infer<typeof ConfirmResultSchema>;\n\nexport const CancelResultSchema = z.object({\n\tok: z.literal(true),\n\tstatus: z.literal(\"CANCELLED\"),\n});\nexport type CancelResult = z.infer<typeof CancelResultSchema>;\n\nexport const SetConfirmationsResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetConfirmationsResult = z.infer<\n\ttypeof SetConfirmationsResultSchema\n>;\n\n/** Response of GET /trade/tickets/settings — the caller's two independent trade\n * toggles. `executionEnabled` is the master execution switch (any write at all);\n * `confirmationsEnabled` is the confirm-before-write preference. */\nexport const TradeSettingsSchema = z.object({\n\texecutionEnabled: z.boolean(),\n\tconfirmationsEnabled: z.boolean(),\n});\nexport type TradeSettings = z.infer<typeof TradeSettingsSchema>;\n\n/** Response of POST /trade/tickets/execution — the new master-switch state. */\nexport const SetExecutionResultSchema = z.object({\n\tok: z.boolean(),\n\tenabled: z.boolean(),\n});\nexport type SetExecutionResult = z.infer<typeof SetExecutionResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\nimport { PendingActionSchema } from \"./tickets\";\n\nexport const TokenEventSchema = z.object({\n\ttype: z.literal(\"token\"),\n\ttext: z.string(),\n});\n// `thinking` is emitted by ADVANCED mode only (the standard pipeline doesn't).\nexport const ThinkingEventSchema = z.object({\n\ttype: z.literal(\"thinking\"),\n\ttext: z.string(),\n});\nexport const StatusEventSchema = z.object({\n\ttype: z.literal(\"status\"),\n\ttext: z.string(),\n\tphase: z.enum([\"start\", \"end\"]).optional(),\n\tnode: z.string().optional(),\n});\nexport const SourcesEventSchema = z.object({\n\ttype: z.literal(\"sources\"),\n\t// `.catch` on every NON-critical field so a malformed metadata array can\n\t// never sink the whole event — `pendingAction` (a staged money-moving trade)\n\t// rides on this same frame and MUST always survive.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).catch([]).optional(), // resolved URL strings\n\tsuggestedAction: SuggestedActionSchema.nullish().catch(null),\n\t// pendingAction is deliberately NOT `.catch`-ed: a corrupt ticket must reject,\n\t// never be fabricated.\n\tpendingAction: PendingActionSchema.nullish(),\n});\nexport const ErrorEventSchema = z.object({\n\ttype: z.literal(\"error\"),\n\tmessage: z.string().optional(),\n});\n\n/** The discriminated union of events the SSE wire delivers. Parse each event\n * with `.safeParse`; on failure (unknown/legacy `cycle` etc.) IGNORE it — do\n * not throw. */\nexport const AgentWireEventSchema = z.discriminatedUnion(\"type\", [\n\tTokenEventSchema,\n\tThinkingEventSchema,\n\tStatusEventSchema,\n\tSourcesEventSchema,\n\tErrorEventSchema,\n]);\nexport type AgentWireEvent = z.infer<typeof AgentWireEventSchema>;\n\n/** Final assembled turn — the shape of `POST /chat` AND the SDK's synthetic\n * `done` event (the SSE wire has no `done` frame; the SDK assembles it). */\nexport const ChatResultSchema = z.object({\n\tfinalText: z.string(),\n\tsessionId: z.string().optional(),\n\t// Same money-path guard as SourcesEventSchema: metadata degrades to [] / null\n\t// on drift so a hard `.parse` can never throw away a real `pendingAction`.\n\tresearchAnnotations: z.array(CitationSourceSchema).catch([]).optional(),\n\ttwitterSources: z.array(TwitterSourceSchema).catch([]).optional(),\n\ttradeLinks: z.array(TradeLinkSchema).catch([]).optional(),\n\timages: z.array(z.string()).default([]),\n\tsuggestedAction: SuggestedActionSchema.nullable().default(null).catch(null),\n\tpendingAction: PendingActionSchema.nullable().default(null),\n});\nexport type ChatResult = z.infer<typeof ChatResultSchema>;\n\n/** The RAW wire union plus a synthetic terminal `done`. NOTE: the SDK actually\n * emits a NORMALIZED `StreamEvent` (token/thinking carry a `delta`) defined in\n * the SDK's stream module; this `AgentEvent` is the pre-normalization shape. */\nexport type AgentEvent = AgentWireEvent | { type: \"done\"; result: ChatResult };\n","import { z } from \"zod\";\n\n/** Response of GET /auth/link-wallet/self — whether the caller's wallet has a\n * WalletLink (i.e. the agent holds an API key and can execute trades). */\nexport const LinkStatusSchema = z.object({\n\tlinked: z.boolean(),\n\twalletAddress: z.string(),\n});\nexport type LinkStatus = z.infer<typeof LinkStatusSchema>;\n\n/** Response of POST /auth/link-wallet/self. `created` is true only when this\n * call minted a new key (false on the idempotent already-linked path). */\nexport const SelfLinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(true),\n\tcreated: z.boolean(),\n});\nexport type SelfLinkResult = z.infer<typeof SelfLinkResultSchema>;\n\n/** Response of DELETE /auth/link-wallet/self. */\nexport const SelfUnlinkResultSchema = z.object({\n\tok: z.boolean(),\n\tlinked: z.literal(false),\n});\nexport type SelfUnlinkResult = z.infer<typeof SelfUnlinkResultSchema>;\n","import { z } from \"zod\";\nimport {\n\tCitationSourceSchema,\n\tSuggestedActionSchema,\n\tTradeLinkSchema,\n\tTwitterSourceSchema,\n} from \"./primitives\";\n\nexport const SessionListItemSchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(), // ISO (Date serialized over the wire)\n});\nexport type SessionListItem = z.infer<typeof SessionListItemSchema>;\n\nexport const SessionSummarySchema = z.object({\n\tid: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n\tfirstUserMessage: z.string().optional(),\n\tlastUserMessage: z.string().optional(),\n\tlastUserMessageAt: z.string().optional(),\n\tlastAssistantMessageAt: z.string().optional(),\n});\nexport type SessionSummary = z.infer<typeof SessionSummarySchema>;\n\nexport const SessionSchema = z.object({\n\tid: z.string(),\n\tuserId: z.string(),\n\tappType: z.string(),\n\tcreatedAt: z.string(),\n});\nexport type Session = z.infer<typeof SessionSchema>;\n\n/** A persisted chat message (history). `images` are pre-resolved URL strings.\n * `z.looseObject` keeps unknown future fields instead of stripping them. */\nexport const AgentChatMessageSchema = z.looseObject({\n\tid: z.string(),\n\trole: z.string(),\n\tcontent: z.string(),\n\tcreatedAt: z.string(),\n\tresearchAnnotations: z.array(CitationSourceSchema).nullish(),\n\ttwitterSources: z.array(TwitterSourceSchema).nullish(),\n\ttradeLinks: z.array(TradeLinkSchema).nullish(),\n\timages: z.array(z.string()).nullish(),\n\tsuggestedAction: SuggestedActionSchema.nullish(),\n});\nexport type AgentChatMessage = z.infer<typeof AgentChatMessageSchema>;\n","import { type AgentWireEvent, AgentWireEventSchema } from \"./protocol\";\n\n/** A token/thinking event normalized to expose an incremental `delta`. This\n * backend is DELTA-only on every path, so `delta === text` — there is no\n * cumulative reconciliation (a `startsWith` heuristic corrupts real output). */\nexport type StreamEvent =\n\t| (Extract<AgentWireEvent, { type: \"token\" }> & { delta: string })\n\t| (Extract<AgentWireEvent, { type: \"thinking\" }> & { delta: string })\n\t| Exclude<AgentWireEvent, { type: \"token\" | \"thinking\" }>;\n\nexport async function* parseSseStream(\n\tbody: ReadableStream<Uint8Array>,\n): AsyncGenerator<StreamEvent> {\n\tconst reader = body.getReader();\n\tconst decoder = new TextDecoder();\n\tlet buffer = \"\";\n\n\ttry {\n\t\twhile (true) {\n\t\t\tconst { done, value } = await reader.read();\n\t\t\tif (done) break;\n\t\t\tbuffer += decoder.decode(value, { stream: true });\n\n\t\t\t// Drain every complete `\\n\\n`-delimited frame in the buffer. `const idx`\n\t\t\t// is recomputed each iteration (no assignment-in-`while`-head: that trips\n\t\t\t// biome `noAssignInExpressions`, a non-auto-fixable CI error).\n\t\t\twhile (true) {\n\t\t\t\tconst idx = buffer.indexOf(\"\\n\\n\");\n\t\t\t\tif (idx < 0) break;\n\t\t\t\tconst rawEvent = buffer.slice(0, idx);\n\t\t\t\tbuffer = buffer.slice(idx + 2);\n\n\t\t\t\tconst lines = rawEvent.split(\"\\n\");\n\t\t\t\tconst eventLine = lines.find((l) => l.startsWith(\"event:\"));\n\t\t\t\tconst dataLine = lines.find((l) => l.startsWith(\"data:\"));\n\t\t\t\tif (!dataLine) continue;\n\t\t\t\tconst payloadText = dataLine.replace(/^data:\\s?/, \"\");\n\n\t\t\t\t// NestJS surfaces stream errors as `event: error\\ndata: <plain string>`\n\t\t\t\t// (NON-JSON). Detect it BEFORE JSON.parse so it isn't swallowed.\n\t\t\t\tif (eventLine?.replace(/^event:\\s?/, \"\") === \"error\") {\n\t\t\t\t\tyield { type: \"error\", message: payloadText };\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tlet json: unknown;\n\t\t\t\ttry {\n\t\t\t\t\tjson = JSON.parse(payloadText);\n\t\t\t\t} catch {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst parsed = AgentWireEventSchema.safeParse(json);\n\t\t\t\tif (!parsed.success) {\n\t\t\t\t\t// Never SILENTLY drop a money-path frame: if it looks like a sources\n\t\t\t\t\t// event carrying pendingAction, fail loud instead of losing a trade.\n\t\t\t\t\tif (\n\t\t\t\t\t\t(json as { type?: string })?.type === \"sources\" &&\n\t\t\t\t\t\t(json as { pendingAction?: unknown })?.pendingAction\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\ttype: \"error\",\n\t\t\t\t\t\t\tmessage: \"malformed sources frame with pendingAction\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tconst ev = parsed.data;\n\t\t\t\tif (ev.type === \"token\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else if (ev.type === \"thinking\") {\n\t\t\t\t\tyield { ...ev, delta: ev.text };\n\t\t\t\t} else {\n\t\t\t\t\tyield ev;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t} finally {\n\t\treader.cancel().catch(() => undefined);\n\t}\n}\n","import { AgentChatError, errorFromStatus } from \"./errors\";\nimport { type AgentChatClientConfig, createHttp, type Http } from \"./http\";\nimport {\n\ttype AgentChatMessage,\n\ttype CancelResult,\n\tCancelResultSchema,\n\ttype ChatMode,\n\ttype ChatResult,\n\tChatResultSchema,\n\ttype ChatSurface,\n\ttype ConfirmResult,\n\tConfirmResultSchema,\n\ttype LinkStatus,\n\tLinkStatusSchema,\n\tPendingActionSchema,\n\ttype SelfLinkResult,\n\tSelfLinkResultSchema,\n\ttype SelfUnlinkResult,\n\tSelfUnlinkResultSchema,\n\ttype Session,\n\ttype SessionListItem,\n\ttype SessionSummary,\n\ttype SetConfirmationsResult,\n\tSetConfirmationsResultSchema,\n\ttype SetExecutionResult,\n\tSetExecutionResultSchema,\n\ttype TradeSettings,\n\tTradeSettingsSchema,\n} from \"./protocol\";\nimport { parseSseStream, type StreamEvent } from \"./stream\";\n\n/** Parse a ChatResult but NEVER throw away a real `pendingAction` on metadata\n * drift: on a parse failure, fall back to a minimal result that preserves\n * `finalText` + `pendingAction` rather than rejecting the whole turn. */\nfunction parseChatResult(raw: unknown): ChatResult {\n\tconst parsed = ChatResultSchema.safeParse(raw);\n\tif (parsed.success) return parsed.data;\n\tconst r = raw as { finalText?: unknown; pendingAction?: unknown };\n\t// Salvage finalText, but NEVER fabricate a ticket: keep pendingAction only if\n\t// it INDEPENDENTLY validates — a corrupt ticket is dropped, never handed to\n\t// confirmTicket() (the money endpoint).\n\tconst pa = PendingActionSchema.safeParse(r?.pendingAction);\n\treturn {\n\t\tfinalText: typeof r?.finalText === \"string\" ? r.finalText : \"\",\n\t\timages: [],\n\t\tsuggestedAction: null,\n\t\tpendingAction: pa.success ? pa.data : null,\n\t};\n}\n\nfunction assembleResult(\n\tsessionId: string,\n\tfinalText: string,\n\tsources: Extract<StreamEvent, { type: \"sources\" }> | undefined,\n): ChatResult {\n\treturn parseChatResult({\n\t\tfinalText,\n\t\tsessionId,\n\t\tresearchAnnotations: sources?.researchAnnotations,\n\t\ttwitterSources: sources?.twitterSources,\n\t\ttradeLinks: sources?.tradeLinks,\n\t\timages: sources?.images ?? [],\n\t\tsuggestedAction: sources?.suggestedAction ?? null,\n\t\tpendingAction: sources?.pendingAction ?? null,\n\t});\n}\n\nexport class AgentChatClient {\n\tprivate readonly http: Http;\n\n\tconstructor(config: AgentChatClientConfig) {\n\t\tthis.http = createHttp(config);\n\t}\n\n\tlistSessions(): Promise<SessionListItem[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions\");\n\t}\n\n\tlistSessionSummaries(): Promise<SessionSummary[]> {\n\t\treturn this.http.json(\"GET\", \"/chat/sessions/summary\");\n\t}\n\n\tcreateSession(): Promise<{ id: string }> {\n\t\treturn this.http.json(\"POST\", \"/chat/sessions\");\n\t}\n\n\tgetSession(sessionId: string): Promise<Session> {\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tasync deleteSession(sessionId: string): Promise<void> {\n\t\tawait this.http.json(\n\t\t\t\"DELETE\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}`,\n\t\t);\n\t}\n\n\tgetMessages(\n\t\tsessionId: string,\n\t\topts?: { limit?: number; before?: string },\n\t): Promise<AgentChatMessage[]> {\n\t\tconst params = new URLSearchParams();\n\t\tif (opts?.limit !== undefined) params.set(\"limit\", String(opts.limit));\n\t\tif (opts?.before) params.set(\"before\", opts.before);\n\t\tconst qs = params.toString();\n\t\treturn this.http.json(\n\t\t\t\"GET\",\n\t\t\t`/chat/sessions/${encodeURIComponent(sessionId)}/messages${qs ? `?${qs}` : \"\"}`,\n\t\t);\n\t}\n\n\t/** Stream a turn. Yields token/thinking/status/sources events, then a\n\t * synthetic `{type:'done', result}` assembled from accumulated token deltas +\n\t * the final `sources` payload (the SSE wire has no `done` frame). Throws an\n\t * `AgentChatError` if the backend emits a mid-stream `error` frame. */\n\tasync *streamChat(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Declares the client surface (pear_v3 / pear_pro / base_mini / …). Required —\n\t\t * the API rejects requests without a valid surface. Drives per-surface behavior. */\n\t\tsurface: ChatSurface;\n\t\tsignal?: AbortSignal;\n\t\t/** CTA callback — set when the user clicks a suggested-action option; the\n\t\t * agent rebuilds the turn from this context server-side. */\n\t\tcta?: { previousText: string; question: string; selectedOption: string };\n\t}): AsyncGenerator<StreamEvent | { type: \"done\"; result: ChatResult }> {\n\t\tconst params = new URLSearchParams({\n\t\t\tmessage: args.message,\n\t\t\tsessionId: args.sessionId,\n\t\t\tmode: args.mode ?? \"standard\",\n\t\t});\n\t\tparams.set(\"surface\", args.surface);\n\t\tif (args.cta) {\n\t\t\tparams.set(\"suggestedActionPreviousText\", args.cta.previousText);\n\t\t\tparams.set(\"suggestedActionQuestion\", args.cta.question);\n\t\t\tparams.set(\"suggestedActionSelectedOption\", args.cta.selectedOption);\n\t\t}\n\t\tconst headers = await this.http.authHeaders();\n\t\theaders.Accept = \"text/event-stream\";\n\t\tconst res = await this.http.fetch(\n\t\t\tthis.http.buildUrl(`/chat/stream?${params.toString()}`),\n\t\t\t{ method: \"GET\", headers, signal: args.signal },\n\t\t);\n\t\tif (!res.ok || !res.body) {\n\t\t\tthrow errorFromStatus(res.status, await res.text().catch(() => \"\"));\n\t\t}\n\n\t\tlet finalText = \"\";\n\t\tlet sources: Extract<StreamEvent, { type: \"sources\" }> | undefined;\n\t\tfor await (const ev of parseSseStream(res.body)) {\n\t\t\tif (ev.type === \"error\") {\n\t\t\t\tthrow new AgentChatError(ev.message ?? \"Agent stream error\");\n\t\t\t}\n\t\t\tif (ev.type === \"token\") finalText += ev.delta;\n\t\t\tif (ev.type === \"sources\") sources = ev;\n\t\t\tyield ev;\n\t\t}\n\n\t\tyield {\n\t\t\ttype: \"done\",\n\t\t\tresult: assembleResult(args.sessionId, finalText, sources),\n\t\t};\n\t}\n\n\t/** Sync send (POST /chat). Prefer `streamChat` for UX. */\n\tsendMessage(args: {\n\t\tsessionId: string;\n\t\tmessage: string;\n\t\tmode?: ChatMode;\n\t\t/** Required — the API rejects requests without a valid surface. */\n\t\tsurface: ChatSurface;\n\t}): Promise<ChatResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/chat\", {\n\t\t\t\tmessage: args.message,\n\t\t\t\tsessionId: args.sessionId,\n\t\t\t\tmode: args.mode ?? \"standard\",\n\t\t\t\tsurface: args.surface,\n\t\t\t})\n\t\t\t.then(parseChatResult);\n\t}\n\n\tconfirmTicket(ticketId: string): Promise<ConfirmResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/confirm`,\n\t\t\t)\n\t\t\t.then((raw) => ConfirmResultSchema.parse(raw));\n\t}\n\n\tcancelTicket(ticketId: string): Promise<CancelResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\n\t\t\t\t\"POST\",\n\t\t\t\t`/trade/tickets/${encodeURIComponent(ticketId)}/cancel`,\n\t\t\t)\n\t\t\t.then((raw) => CancelResultSchema.parse(raw));\n\t}\n\n\tsetTradeConfirmations(enabled: boolean): Promise<SetConfirmationsResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/settings\", { enabled })\n\t\t\t.then((raw) => SetConfirmationsResultSchema.parse(raw));\n\t}\n\n\t/** Read both trade toggles for the caller wallet: the master execution switch\n\t * and the confirm-before-write preference. */\n\tgetTradeSettings(): Promise<TradeSettings> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/trade/tickets/settings\")\n\t\t\t.then((raw) => TradeSettingsSchema.parse(raw));\n\t}\n\n\t/** Flip the caller's master execution switch. `false` opts the wallet out of\n\t * all money-moving writes; `true` restores the default-ON state. */\n\tsetTradeExecution(enabled: boolean): Promise<SetExecutionResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/trade/tickets/execution\", { enabled })\n\t\t\t.then((raw) => SetExecutionResultSchema.parse(raw));\n\t}\n\n\t/** Whether the caller's wallet is linked to the agent (i.e. the agent can\n\t * execute trades for it). Backend-verified — don't cache this locally. */\n\tgetLinkStatus(): Promise<LinkStatus> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"GET\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => LinkStatusSchema.parse(raw));\n\t}\n\n\t/** Link the caller's wallet: the agent mints a Pear API key server-side AS\n\t * the caller (their token is forwarded) — the key never exists client-side.\n\t * Idempotent when already linked; `force` re-mints (recovery), `code` binds\n\t * a Telegram identity (replaces the legacy secret-based flow). */\n\tlinkWallet(opts?: {\n\t\tforce?: boolean;\n\t\tcode?: string;\n\t}): Promise<SelfLinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"POST\", \"/auth/link-wallet/self\", opts ?? {})\n\t\t\t.then((raw) => SelfLinkResultSchema.parse(raw));\n\t}\n\n\t/** Unlink the caller's wallet — the agent loses trade authority. */\n\tunlinkWallet(): Promise<SelfUnlinkResult> {\n\t\treturn this.http\n\t\t\t.json<unknown>(\"DELETE\", \"/auth/link-wallet/self\")\n\t\t\t.then((raw) => SelfUnlinkResultSchema.parse(raw));\n\t}\n}\n"]}
|
package/dist/react/index.d.cts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as react from 'react';
|
|
2
|
-
import { X as TradeLink, $ as TwitterSource, n as CitationSource, N as SuggestedAction, A as AgentChatClient } from '../client-
|
|
2
|
+
import { X as TradeLink, $ as TwitterSource, n as CitationSource, N as SuggestedAction, A as AgentChatClient } from '../client-BSUkCr7k.cjs';
|
|
3
3
|
import 'zod';
|
|
4
4
|
|
|
5
5
|
interface DisplayMessage {
|
|
@@ -26,8 +26,8 @@ declare function useAgentChat(opts: UseAgentChatOptions): {
|
|
|
26
26
|
error: Error | null;
|
|
27
27
|
mode: "standard" | "advanced";
|
|
28
28
|
setMode: react.Dispatch<react.SetStateAction<"standard" | "advanced">>;
|
|
29
|
-
surface: "pear_v3" | "pear_pro" | "base_mini" | "
|
|
30
|
-
setSurface: react.Dispatch<react.SetStateAction<"pear_v3" | "pear_pro" | "base_mini" | "
|
|
29
|
+
surface: "pear_v3" | "pear_pro" | "base_mini" | "web";
|
|
30
|
+
setSurface: react.Dispatch<react.SetStateAction<"pear_v3" | "pear_pro" | "base_mini" | "web">>;
|
|
31
31
|
pendingAction: {
|
|
32
32
|
ticketId: string;
|
|
33
33
|
action: string;
|
package/dist/react/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as react from 'react';
|
|
2
|
-
import { X as TradeLink, $ as TwitterSource, n as CitationSource, N as SuggestedAction, A as AgentChatClient } from '../client-
|
|
2
|
+
import { X as TradeLink, $ as TwitterSource, n as CitationSource, N as SuggestedAction, A as AgentChatClient } from '../client-BSUkCr7k.js';
|
|
3
3
|
import 'zod';
|
|
4
4
|
|
|
5
5
|
interface DisplayMessage {
|
|
@@ -26,8 +26,8 @@ declare function useAgentChat(opts: UseAgentChatOptions): {
|
|
|
26
26
|
error: Error | null;
|
|
27
27
|
mode: "standard" | "advanced";
|
|
28
28
|
setMode: react.Dispatch<react.SetStateAction<"standard" | "advanced">>;
|
|
29
|
-
surface: "pear_v3" | "pear_pro" | "base_mini" | "
|
|
30
|
-
setSurface: react.Dispatch<react.SetStateAction<"pear_v3" | "pear_pro" | "base_mini" | "
|
|
29
|
+
surface: "pear_v3" | "pear_pro" | "base_mini" | "web";
|
|
30
|
+
setSurface: react.Dispatch<react.SetStateAction<"pear_v3" | "pear_pro" | "base_mini" | "web">>;
|
|
31
31
|
pendingAction: {
|
|
32
32
|
ticketId: string;
|
|
33
33
|
action: string;
|