orbitchat 2.5.4 → 2.5.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. package/README.md +1 -1
  2. package/bin/orbitchat.js +12 -3
  3. package/dist/assets/{_baseUniq-BPMphbq5-DCIcpFFh.js → _baseUniq-BPMphbq5-DyhKuQ9D.js} +1 -1
  4. package/dist/assets/{api-DRvytIiv.js → api-CD9Nzq0O.js} +1 -1
  5. package/dist/assets/{arc-D9rhTKV0-C059YeZ6.js → arc-D9rhTKV0-DNQNLJPM.js} +1 -1
  6. package/dist/assets/{architectureDiagram-VXUJARFQ-BiqZtsDe-BkkqKtHd.js → architectureDiagram-VXUJARFQ-BiqZtsDe-OAB_WdXP.js} +1 -1
  7. package/dist/assets/{blockDiagram-VD42YOAC-zcRIdFTD-CmrwN1rO.js → blockDiagram-VD42YOAC-zcRIdFTD-Co_XtUK4.js} +1 -1
  8. package/dist/assets/{c4Diagram-YG6GDRKO-DYXNcDX4-Cad8FH2r.js → c4Diagram-YG6GDRKO-DYXNcDX4-CHxegSJq.js} +1 -1
  9. package/dist/assets/channel-CUIutAfm-CRfssE8A.js +1 -0
  10. package/dist/assets/{chunk-4BX2VUAB-DAh9ktmY-CTR2yEQ6.js → chunk-4BX2VUAB-DAh9ktmY-BMA6rd4j.js} +1 -1
  11. package/dist/assets/{chunk-55IACEB6-Cza7pcpr-BW20Pjrx.js → chunk-55IACEB6-Cza7pcpr-D7qVo0l1.js} +1 -1
  12. package/dist/assets/{chunk-B4BG7PRW-BTUSpeKy-DkvbW85c.js → chunk-B4BG7PRW-BTUSpeKy-Cv9tn5FL.js} +1 -1
  13. package/dist/assets/{chunk-DI55MBZ5-DKt4WII7-DTiT3Y9F.js → chunk-DI55MBZ5-DKt4WII7-CD7PH56S.js} +1 -1
  14. package/dist/assets/{chunk-FMBD7UC4-DdcCR8w3-BlBHn52v.js → chunk-FMBD7UC4-DdcCR8w3-f2kPxnxt.js} +1 -1
  15. package/dist/assets/{chunk-QN33PNHL-v6AkzOl1-g_BOez-F.js → chunk-QN33PNHL-v6AkzOl1-BDN4BA8H.js} +1 -1
  16. package/dist/assets/{chunk-QZHKN3VN-DVJOrqBZ-DR6erlsb.js → chunk-QZHKN3VN-DVJOrqBZ-C9KSl1Oi.js} +1 -1
  17. package/dist/assets/{chunk-TZMSLE5B-G2jJHqli-sohz2g8-.js → chunk-TZMSLE5B-G2jJHqli-BEWUJNAb.js} +1 -1
  18. package/dist/assets/{classDiagram-2ON5EDUG-CxmgTanh-BX4-nAtT.js → classDiagram-2ON5EDUG-CxmgTanh-D8XJiPRf.js} +1 -1
  19. package/dist/assets/{classDiagram-v2-WZHVMYZB-CxmgTanh-BX4-nAtT.js → classDiagram-v2-WZHVMYZB-CxmgTanh-D8XJiPRf.js} +1 -1
  20. package/dist/assets/clone-CsNB4mMi-CrH0uuE1.js +1 -0
  21. package/dist/assets/{cose-bilkent-S5V4N54A-BRr2Y6dg-36TGosfX.js → cose-bilkent-S5V4N54A-BRr2Y6dg-D6uw80ha.js} +1 -1
  22. package/dist/assets/{dagre-6UL2VRFP-DX8gNHmJ-BhNHmM1j.js → dagre-6UL2VRFP-DX8gNHmJ-DMpjORIV.js} +1 -1
  23. package/dist/assets/{diagram-PSM6KHXK-DNX818To-R2KZc8Jv.js → diagram-PSM6KHXK-DNX818To-CxJ9VQrf.js} +1 -1
  24. package/dist/assets/{diagram-QEK2KX5R-BDO6hKtm-1K9Hv6pd.js → diagram-QEK2KX5R-BDO6hKtm-J0PP4QNf.js} +1 -1
  25. package/dist/assets/{diagram-S2PKOQOG-IEqaDwzi-DIJwiYeR.js → diagram-S2PKOQOG-IEqaDwzi-CJ60bco2.js} +1 -1
  26. package/dist/assets/{erDiagram-Q2GNP2WA-DbLpN8Jp-DotWh_LO.js → erDiagram-Q2GNP2WA-DbLpN8Jp-B76YSpnw.js} +1 -1
  27. package/dist/assets/{flowDiagram-NV44I4VS-pJlHae8Y-D1k5TBn8.js → flowDiagram-NV44I4VS-pJlHae8Y-V2lN8HRy.js} +1 -1
  28. package/dist/assets/{ganttDiagram-JELNMOA3-J0Tkq5TR-BiMPaD7j.js → ganttDiagram-JELNMOA3-J0Tkq5TR-CDnKa5cJ.js} +1 -1
  29. package/dist/assets/{gitGraphDiagram-NY62KEGX-DgYonpsZ-BMaggilF.js → gitGraphDiagram-NY62KEGX-DgYonpsZ-BnPQvCQc.js} +1 -1
  30. package/dist/assets/{graph-BpcfrHXY-DE2bH6Ay.js → graph-BpcfrHXY-r8ucjuVo.js} +1 -1
  31. package/dist/assets/{index-2ZR5memZ.js → index-BIBo0u38.js} +6 -6
  32. package/dist/assets/{index-DvNpGWs7-BzZ8mD-G.js → index-DvNpGWs7-DSHfKWeY.js} +1 -1
  33. package/dist/assets/{infoDiagram-WHAUD3N6-C3JLOAnb-yCw2u01J.js → infoDiagram-WHAUD3N6-C3JLOAnb-DZz70Wlt.js} +1 -1
  34. package/dist/assets/{journeyDiagram-XKPGCS4Q-CfjB2Qdf-fXnO8HX4.js → journeyDiagram-XKPGCS4Q-CfjB2Qdf-LESHFhGE.js} +1 -1
  35. package/dist/assets/{kanban-definition-3W4ZIXB7-CrW8yVmd-fdlrwsFK.js → kanban-definition-3W4ZIXB7-CrW8yVmd-CS7O7CRH.js} +1 -1
  36. package/dist/assets/{layout-bsfAhWjc-Bj6QUo1l.js → layout-bsfAhWjc-0bqYAaFs.js} +1 -1
  37. package/dist/assets/{min-C2aDz5ZK-CJIJX-DJ.js → min-C2aDz5ZK-DHktDX_3.js} +1 -1
  38. package/dist/assets/{mindmap-definition-VGOIOE7T-Dj37RkY_-Dj5-Yjbe.js → mindmap-definition-VGOIOE7T-Dj37RkY_-Q2Y5JCNR.js} +1 -1
  39. package/dist/assets/{pieDiagram-ADFJNKIX-BiQvDx8I-CkPhSLyi.js → pieDiagram-ADFJNKIX-BiQvDx8I-Csm4P_6v.js} +1 -1
  40. package/dist/assets/{quadrantDiagram-AYHSOK5B-D4b-YFzI-CX_Ua3Al.js → quadrantDiagram-AYHSOK5B-D4b-YFzI-DgqYZ4Fj.js} +1 -1
  41. package/dist/assets/{requirementDiagram-UZGBJVZJ-km07nlVd-C-b1Icnw.js → requirementDiagram-UZGBJVZJ-km07nlVd-Czal8CN1.js} +1 -1
  42. package/dist/assets/{sankeyDiagram-TZEHDZUN-LfuSRRbf-CbI5lK7z.js → sankeyDiagram-TZEHDZUN-LfuSRRbf-DbQtBnKn.js} +1 -1
  43. package/dist/assets/{sequenceDiagram-WL72ISMW-CQ4J-0_7-CjlnLt1h.js → sequenceDiagram-WL72ISMW-CQ4J-0_7-DA8azeWg.js} +1 -1
  44. package/dist/assets/{stateDiagram-FKZM4ZOC-JtogJwt6-B15bdEEI.js → stateDiagram-FKZM4ZOC-JtogJwt6-CAuan9bg.js} +1 -1
  45. package/dist/assets/{stateDiagram-v2-4FDKWEC3-DuQ7UaeU-BT0Qr9wo.js → stateDiagram-v2-4FDKWEC3-DuQ7UaeU-wMtwfJb0.js} +1 -1
  46. package/dist/assets/{timeline-definition-IT6M3QCI-Cs3NnF2M-DW3Bzv7v.js → timeline-definition-IT6M3QCI-Cs3NnF2M-CHRQfxoL.js} +1 -1
  47. package/dist/assets/{treemap-KMMF4GRG-CkW25-tn-CIS9X-Ea.js → treemap-KMMF4GRG-CkW25-tn-B1iWs4HR.js} +1 -1
  48. package/dist/assets/{xychartDiagram-PRI3JC2R-JzAaXa5z-Dal7GCHB.js → xychartDiagram-PRI3JC2R-JzAaXa5z-0D-bLJ7B.js} +1 -1
  49. package/dist/index.html +3 -3
  50. package/dist/orbit-icon.svg +1 -0
  51. package/package.json +1 -1
  52. package/dist/assets/channel-CUIutAfm-BiWQuvt2.js +0 -1
  53. package/dist/assets/clone-CsNB4mMi-CzUA2RIQ.js +0 -1
package/README.md CHANGED
@@ -115,7 +115,7 @@ You can prevent API keys from ever reaching the browser by enabling the built-in
115
115
  ```
116
116
  2. Start the CLI with `--enable-api-middleware` (or export `VITE_ENABLE_API_MIDDLEWARE=true`). The Express server now:
117
117
  - Serves `GET /api/adapters` so the React app can list safe adapter names.
118
- - Proxies all chat/file/thread/admin calls through `/api/proxy/...`, injecting the adapters real `X-API-Key`.
118
+ - Proxies all chat/file/thread/admin calls through `/api/...`, injecting the adapter's real `X-API-Key`.
119
119
  3. The UI automatically swaps the API-key modal for an Adapter Selector and stores adapter names per conversation.
120
120
 
121
121
  Keep `adapters.yaml` out of source control and run the CLI behind HTTPS (or another reverse proxy) when deploying.
package/bin/orbitchat.js CHANGED
@@ -328,8 +328,12 @@ function createServer(distPath, config) {
328
328
  proxyInstances[adapterName] = createProxyMiddleware({
329
329
  target: adapter.apiUrl,
330
330
  changeOrigin: true,
331
- pathRewrite: {
332
- '^/api/proxy': '', // Remove /api/proxy prefix
331
+ // Restore /api prefix for backend paths that need it (files, threads)
332
+ pathRewrite: (path) => {
333
+ if (path.startsWith('/files') || path.startsWith('/threads')) {
334
+ return '/api' + path;
335
+ }
336
+ return path;
333
337
  },
334
338
  // Set headers directly - this is more reliable than onProxyReq for some cases
335
339
  headers: {
@@ -399,7 +403,12 @@ function createServer(distPath, config) {
399
403
  });
400
404
 
401
405
  // Proxy middleware for API requests - must be before body parsers to preserve request stream
402
- app.use('/api/proxy', (req, res, next) => {
406
+ // Note: Uses /api path instead of /api/proxy for security (hides proxy nature)
407
+ app.use('/api', (req, res, next) => {
408
+ // Skip the /api/adapters route - it's handled separately above
409
+ if (req.path === '/adapters') {
410
+ return next('route');
411
+ }
403
412
  const adapterName = req.headers['x-adapter-name'];
404
413
 
405
414
  if (!adapterName) {
@@ -1 +1 @@
1
- import{bI as cr,bJ as ir,aT as Z,aL as h,aM as U,bK as A,bL as lr,aQ as sr,bx as k,bs as P,bM as vr,bN as br,aR as hr,bO as X,bo as K,bp as N,bP as gr,bz as _,aH as pr,bQ as R,bR as yr,aU as dr}from"./index-2ZR5memZ.js";var jr="[object Symbol]";function z(r){return typeof r=="symbol"||k(r)&&vr(r)==jr}function _r(r,t){for(var e=-1,n=r==null?0:r.length,a=Array(n);++e<n;)a[e]=t(r[e],e,r);return a}var D=_?_.prototype:void 0,E=D?D.toString:void 0;function V(r){if(typeof r=="string")return r;if(h(r))return _r(r,V)+"";if(z(r))return E?E.call(r):"";var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function mr(){}function wr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n&&t(r[e],e,r)!==!1;);return r}function Or(r,t,e,n){for(var a=r.length,u=e+-1;++u<a;)if(t(r[u],u,r))return u;return-1}function Lr(r){return r!==r}function Pr(r,t,e){for(var n=e-1,a=r.length;++n<a;)if(r[n]===t)return n;return-1}function Sr(r,t,e){return t===t?Pr(r,t,e):Or(r,Lr,e)}function Ar(r,t){var e=r==null?0:r.length;return!!e&&Sr(r,t,0)>-1}function M(r){return Z(r)?cr(r):ir(r)}var Br=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,kr=/^\w*$/;function $(r,t){if(h(r))return!1;var e=typeof r;return e=="number"||e=="symbol"||e=="boolean"||r==null||z(r)?!0:kr.test(r)||!Br.test(r)||t!=null&&r in Object(t)}var zr=500;function Mr(r){var t=yr(r,function(n){return e.size===zr&&e.clear(),n}),e=t.cache;return t}var $r=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,xr=/\\(\\)?/g,Cr=Mr(function(r){var t=[];return r.charCodeAt(0)===46&&t.push(""),r.replace($r,function(e,n,a,u){t.push(a?u.replace(xr,"$1"):n||e)}),t});function Fr(r){return r==null?"":V(r)}function W(r,t){return h(r)?r:$(r,t)?[r]:Cr(Fr(r))}function S(r){if(typeof r=="string"||z(r))return r;var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function rr(r,t){t=W(t,r);for(var e=0,n=t.length;r!=null&&e<n;)r=r[S(t[e++])];return e&&e==n?r:void 0}function Jr(r,t,e){var n=r==null?void 0:rr(r,t);return n===void 0?e:n}function tr(r,t){for(var e=-1,n=t.length,a=r.length;++e<n;)r[a+e]=t[e];return r}var H=_?_.isConcatSpreadable:void 0;function Kr(r){return h(r)||X(r)||!!(H&&r&&r[H])}function Et(r,t,e,n,a){var u=-1,o=r.length;for(e||(e=Kr),a||(a=[]);++u<o;){var f=r[u];e(f)?tr(a,f):n||(a[a.length]=f)}return a}function Nr(r,t,e,n){var a=-1,u=r==null?0:r.length;for(n&&u&&(e=r[++a]);++a<u;)e=t(e,r[a],a,r);return e}function er(r,t){for(var e=-1,n=r==null?0:r.length,a=0,u=[];++e<n;){var o=r[e];t(o,e,r)&&(u[a++]=o)}return u}function Rr(){return[]}var Dr=Object.prototype,Er=Dr.propertyIsEnumerable,I=Object.getOwnPropertySymbols,Hr=I?function(r){return r==null?[]:(r=Object(r),er(I(r),function(t){return Er.call(r,t)}))}:Rr;function Ir(r,t,e){var n=t(r);return h(r)?n:tr(n,e(r))}function T(r){return Ir(r,M,Hr)}var Tr="__lodash_hash_undefined__";function Yr(r){return this.__data__.set(r,Tr),this}function qr(r){return this.__data__.has(r)}function m(r){var t=-1,e=r==null?0:r.length;for(this.__data__=new lr;++t<e;)this.add(r[t])}m.prototype.add=m.prototype.push=Yr;m.prototype.has=qr;function Gr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n;)if(t(r[e],e,r))return!0;return!1}function nr(r,t){return r.has(t)}var Qr=1,Zr=2;function ur(r,t,e,n,a,u){var o=e&Qr,f=r.length,c=t.length;if(f!=c&&!(o&&c>f))return!1;var v=u.get(r),l=u.get(t);if(v&&l)return v==t&&l==r;var i=-1,s=!0,p=e&Zr?new m:void 0;for(u.set(r,t),u.set(t,r);++i<f;){var b=r[i],g=t[i];if(n)var y=o?n(g,b,i,t,r,u):n(b,g,i,r,t,u);if(y!==void 0){if(y)continue;s=!1;break}if(p){if(!Gr(t,function(d,j){if(!nr(p,j)&&(b===d||a(b,d,e,n,u)))return p.push(j)})){s=!1;break}}else if(!(b===g||a(b,g,e,n,u))){s=!1;break}}return u.delete(r),u.delete(t),s}function Ur(r){var t=-1,e=Array(r.size);return r.forEach(function(n,a){e[++t]=[a,n]}),e}function x(r){var t=-1,e=Array(r.size);return r.forEach(function(n){e[++t]=n}),e}var Xr=1,Vr=2,Wr="[object Boolean]",rt="[object Date]",tt="[object Error]",et="[object Map]",nt="[object Number]",ut="[object RegExp]",at="[object Set]",ot="[object String]",ft="[object Symbol]",ct="[object ArrayBuffer]",it="[object DataView]",Y=_?_.prototype:void 0,B=Y?Y.valueOf:void 0;function lt(r,t,e,n,a,u,o){switch(e){case it:if(r.byteLength!=t.byteLength||r.byteOffset!=t.byteOffset)return!1;r=r.buffer,t=t.buffer;case ct:return!(r.byteLength!=t.byteLength||!u(new R(r),new R(t)));case Wr:case rt:case nt:return pr(+r,+t);case tt:return r.name==t.name&&r.message==t.message;case ut:case ot:return r==t+"";case et:var f=Ur;case at:var c=n&Xr;if(f||(f=x),r.size!=t.size&&!c)return!1;var v=o.get(r);if(v)return v==t;n|=Vr,o.set(r,t);var l=ur(f(r),f(t),n,a,u,o);return o.delete(r),l;case ft:if(B)return B.call(r)==B.call(t)}return!1}var st=1,vt=Object.prototype,bt=vt.hasOwnProperty;function ht(r,t,e,n,a,u){var o=e&st,f=T(r),c=f.length,v=T(t),l=v.length;if(c!=l&&!o)return!1;for(var i=c;i--;){var s=f[i];if(!(o?s in t:bt.call(t,s)))return!1}var p=u.get(r),b=u.get(t);if(p&&b)return p==t&&b==r;var g=!0;u.set(r,t),u.set(t,r);for(var y=o;++i<c;){s=f[i];var d=r[s],j=t[s];if(n)var J=o?n(j,d,s,t,r,u):n(d,j,s,r,t,u);if(!(J===void 0?d===j||a(d,j,e,n,u):J)){g=!1;break}y||(y=s=="constructor")}if(g&&!y){var w=r.constructor,O=t.constructor;w!=O&&"constructor"in r&&"constructor"in t&&!(typeof w=="function"&&w instanceof w&&typeof O=="function"&&O instanceof O)&&(g=!1)}return u.delete(r),u.delete(t),g}var gt=1,q="[object Arguments]",G="[object Array]",L="[object Object]",pt=Object.prototype,Q=pt.hasOwnProperty;function yt(r,t,e,n,a,u){var o=h(r),f=h(t),c=o?G:K(r),v=f?G:K(t);c=c==q?L:c,v=v==q?L:v;var l=c==L,i=v==L,s=c==v;if(s&&N(r)){if(!N(t))return!1;o=!0,l=!1}if(s&&!l)return u||(u=new P),o||gr(r)?ur(r,t,e,n,a,u):lt(r,t,c,e,n,a,u);if(!(e&gt)){var p=l&&Q.call(r,"__wrapped__"),b=i&&Q.call(t,"__wrapped__");if(p||b){var g=p?r.value():r,y=b?t.value():t;return u||(u=new P),a(g,y,e,n,u)}}return s?(u||(u=new P),ht(r,t,e,n,a,u)):!1}function C(r,t,e,n,a){return r===t?!0:r==null||t==null||!k(r)&&!k(t)?r!==r&&t!==t:yt(r,t,e,n,C,a)}var dt=1,jt=2;function _t(r,t,e,n){var a=e.length,u=a;if(r==null)return!u;for(r=Object(r);a--;){var o=e[a];if(o[2]?o[1]!==r[o[0]]:!(o[0]in r))return!1}for(;++a<u;){o=e[a];var f=o[0],c=r[f],v=o[1];if(o[2]){if(c===void 0&&!(f in r))return!1}else{var l=new P,i;if(!(i===void 0?C(v,c,dt|jt,n,l):i))return!1}}return!0}function ar(r){return r===r&&!sr(r)}function mt(r){for(var t=M(r),e=t.length;e--;){var n=t[e],a=r[n];t[e]=[n,a,ar(a)]}return t}function or(r,t){return function(e){return e==null?!1:e[r]===t&&(t!==void 0||r in Object(e))}}function wt(r){var t=mt(r);return t.length==1&&t[0][2]?or(t[0][0],t[0][1]):function(e){return e===r||_t(e,r,t)}}function Ot(r,t){return r!=null&&t in Object(r)}function Lt(r,t,e){t=W(t,r);for(var n=-1,a=t.length,u=!1;++n<a;){var o=S(t[n]);if(!(u=r!=null&&e(r,o)))break;r=r[o]}return u||++n!=a?u:(a=r==null?0:r.length,!!a&&br(a)&&hr(o,a)&&(h(r)||X(r)))}function Pt(r,t){return r!=null&&Lt(r,t,Ot)}var St=1,At=2;function Bt(r,t){return $(r)&&ar(t)?or(S(r),t):function(e){var n=Jr(e,r);return n===void 0&&n===t?Pt(e,r):C(t,n,St|At)}}function kt(r){return function(t){return t==null?void 0:t[r]}}function zt(r){return function(t){return rr(t,r)}}function Mt(r){return $(r)?kt(S(r)):zt(r)}function fr(r){return typeof r=="function"?r:r==null?U:typeof r=="object"?h(r)?Bt(r[0],r[1]):wt(r):Mt(r)}function $t(r,t){return r&&dr(r,t,M)}function xt(r,t){return function(e,n){if(e==null)return e;if(!Z(e))return r(e,n);for(var a=e.length,u=-1,o=Object(e);++u<a&&n(o[u],u,o)!==!1;);return e}}var F=xt($t);function Ct(r){return typeof r=="function"?r:U}function Ht(r,t){var e=h(r)?wr:F;return e(r,Ct(t))}function Ft(r,t){var e=[];return F(r,function(n,a,u){t(n,a,u)&&e.push(n)}),e}function It(r,t){var e=h(r)?er:Ft;return e(r,fr(t))}function Jt(r,t,e,n,a){return a(r,function(u,o,f){e=n?(n=!1,u):t(e,u,o,f)}),e}function Tt(r,t,e){var n=h(r)?Nr:Jt,a=arguments.length<3;return n(r,fr(t),e,a,F)}var Kt=1/0,Nt=A&&1/x(new A([,-0]))[1]==Kt?function(r){return new A(r)}:mr,Rt=200;function Yt(r,t,e){var n=-1,a=Ar,u=r.length,o=!0,f=[],c=f;if(u>=Rt){var v=t?null:Nt(r);if(v)return x(v);o=!1,a=nr,c=new m}else c=t?[]:f;r:for(;++n<u;){var l=r[n],i=t?t(l):l;if(l=l!==0?l:0,o&&i===i){for(var s=c.length;s--;)if(c[s]===i)continue r;t&&c.push(i),f.push(l)}else a(c,i,e)||(c!==f&&c.push(i),f.push(l))}return f}export{$t as $,Et as B,wr as E,Ct as F,Fr as G,S as I,Yt as J,Rr as K,M,Lt as T,Tt as Y,It as Z,fr as a,Pt as b,Or as c,T as d,Hr as e,Ir as f,F as g,W as j,rr as n,Ht as q,tr as r,_r as v,z as x};
1
+ import{bI as cr,bJ as ir,aT as Z,aL as h,aM as U,bK as A,bL as lr,aQ as sr,bx as k,bs as P,bM as vr,bN as br,aR as hr,bO as X,bo as K,bp as N,bP as gr,bz as _,aH as pr,bQ as R,bR as yr,aU as dr}from"./index-BIBo0u38.js";var jr="[object Symbol]";function z(r){return typeof r=="symbol"||k(r)&&vr(r)==jr}function _r(r,t){for(var e=-1,n=r==null?0:r.length,a=Array(n);++e<n;)a[e]=t(r[e],e,r);return a}var D=_?_.prototype:void 0,E=D?D.toString:void 0;function V(r){if(typeof r=="string")return r;if(h(r))return _r(r,V)+"";if(z(r))return E?E.call(r):"";var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function mr(){}function wr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n&&t(r[e],e,r)!==!1;);return r}function Or(r,t,e,n){for(var a=r.length,u=e+-1;++u<a;)if(t(r[u],u,r))return u;return-1}function Lr(r){return r!==r}function Pr(r,t,e){for(var n=e-1,a=r.length;++n<a;)if(r[n]===t)return n;return-1}function Sr(r,t,e){return t===t?Pr(r,t,e):Or(r,Lr,e)}function Ar(r,t){var e=r==null?0:r.length;return!!e&&Sr(r,t,0)>-1}function M(r){return Z(r)?cr(r):ir(r)}var Br=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,kr=/^\w*$/;function $(r,t){if(h(r))return!1;var e=typeof r;return e=="number"||e=="symbol"||e=="boolean"||r==null||z(r)?!0:kr.test(r)||!Br.test(r)||t!=null&&r in Object(t)}var zr=500;function Mr(r){var t=yr(r,function(n){return e.size===zr&&e.clear(),n}),e=t.cache;return t}var $r=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,xr=/\\(\\)?/g,Cr=Mr(function(r){var t=[];return r.charCodeAt(0)===46&&t.push(""),r.replace($r,function(e,n,a,u){t.push(a?u.replace(xr,"$1"):n||e)}),t});function Fr(r){return r==null?"":V(r)}function W(r,t){return h(r)?r:$(r,t)?[r]:Cr(Fr(r))}function S(r){if(typeof r=="string"||z(r))return r;var t=r+"";return t=="0"&&1/r==-1/0?"-0":t}function rr(r,t){t=W(t,r);for(var e=0,n=t.length;r!=null&&e<n;)r=r[S(t[e++])];return e&&e==n?r:void 0}function Jr(r,t,e){var n=r==null?void 0:rr(r,t);return n===void 0?e:n}function tr(r,t){for(var e=-1,n=t.length,a=r.length;++e<n;)r[a+e]=t[e];return r}var H=_?_.isConcatSpreadable:void 0;function Kr(r){return h(r)||X(r)||!!(H&&r&&r[H])}function Et(r,t,e,n,a){var u=-1,o=r.length;for(e||(e=Kr),a||(a=[]);++u<o;){var f=r[u];e(f)?tr(a,f):n||(a[a.length]=f)}return a}function Nr(r,t,e,n){var a=-1,u=r==null?0:r.length;for(n&&u&&(e=r[++a]);++a<u;)e=t(e,r[a],a,r);return e}function er(r,t){for(var e=-1,n=r==null?0:r.length,a=0,u=[];++e<n;){var o=r[e];t(o,e,r)&&(u[a++]=o)}return u}function Rr(){return[]}var Dr=Object.prototype,Er=Dr.propertyIsEnumerable,I=Object.getOwnPropertySymbols,Hr=I?function(r){return r==null?[]:(r=Object(r),er(I(r),function(t){return Er.call(r,t)}))}:Rr;function Ir(r,t,e){var n=t(r);return h(r)?n:tr(n,e(r))}function T(r){return Ir(r,M,Hr)}var Tr="__lodash_hash_undefined__";function Yr(r){return this.__data__.set(r,Tr),this}function qr(r){return this.__data__.has(r)}function m(r){var t=-1,e=r==null?0:r.length;for(this.__data__=new lr;++t<e;)this.add(r[t])}m.prototype.add=m.prototype.push=Yr;m.prototype.has=qr;function Gr(r,t){for(var e=-1,n=r==null?0:r.length;++e<n;)if(t(r[e],e,r))return!0;return!1}function nr(r,t){return r.has(t)}var Qr=1,Zr=2;function ur(r,t,e,n,a,u){var o=e&Qr,f=r.length,c=t.length;if(f!=c&&!(o&&c>f))return!1;var v=u.get(r),l=u.get(t);if(v&&l)return v==t&&l==r;var i=-1,s=!0,p=e&Zr?new m:void 0;for(u.set(r,t),u.set(t,r);++i<f;){var b=r[i],g=t[i];if(n)var y=o?n(g,b,i,t,r,u):n(b,g,i,r,t,u);if(y!==void 0){if(y)continue;s=!1;break}if(p){if(!Gr(t,function(d,j){if(!nr(p,j)&&(b===d||a(b,d,e,n,u)))return p.push(j)})){s=!1;break}}else if(!(b===g||a(b,g,e,n,u))){s=!1;break}}return u.delete(r),u.delete(t),s}function Ur(r){var t=-1,e=Array(r.size);return r.forEach(function(n,a){e[++t]=[a,n]}),e}function x(r){var t=-1,e=Array(r.size);return r.forEach(function(n){e[++t]=n}),e}var Xr=1,Vr=2,Wr="[object Boolean]",rt="[object Date]",tt="[object Error]",et="[object Map]",nt="[object Number]",ut="[object RegExp]",at="[object Set]",ot="[object String]",ft="[object Symbol]",ct="[object ArrayBuffer]",it="[object DataView]",Y=_?_.prototype:void 0,B=Y?Y.valueOf:void 0;function lt(r,t,e,n,a,u,o){switch(e){case it:if(r.byteLength!=t.byteLength||r.byteOffset!=t.byteOffset)return!1;r=r.buffer,t=t.buffer;case ct:return!(r.byteLength!=t.byteLength||!u(new R(r),new R(t)));case Wr:case rt:case nt:return pr(+r,+t);case tt:return r.name==t.name&&r.message==t.message;case ut:case ot:return r==t+"";case et:var f=Ur;case at:var c=n&Xr;if(f||(f=x),r.size!=t.size&&!c)return!1;var v=o.get(r);if(v)return v==t;n|=Vr,o.set(r,t);var l=ur(f(r),f(t),n,a,u,o);return o.delete(r),l;case ft:if(B)return B.call(r)==B.call(t)}return!1}var st=1,vt=Object.prototype,bt=vt.hasOwnProperty;function ht(r,t,e,n,a,u){var o=e&st,f=T(r),c=f.length,v=T(t),l=v.length;if(c!=l&&!o)return!1;for(var i=c;i--;){var s=f[i];if(!(o?s in t:bt.call(t,s)))return!1}var p=u.get(r),b=u.get(t);if(p&&b)return p==t&&b==r;var g=!0;u.set(r,t),u.set(t,r);for(var y=o;++i<c;){s=f[i];var d=r[s],j=t[s];if(n)var J=o?n(j,d,s,t,r,u):n(d,j,s,r,t,u);if(!(J===void 0?d===j||a(d,j,e,n,u):J)){g=!1;break}y||(y=s=="constructor")}if(g&&!y){var w=r.constructor,O=t.constructor;w!=O&&"constructor"in r&&"constructor"in t&&!(typeof w=="function"&&w instanceof w&&typeof O=="function"&&O instanceof O)&&(g=!1)}return u.delete(r),u.delete(t),g}var gt=1,q="[object Arguments]",G="[object Array]",L="[object Object]",pt=Object.prototype,Q=pt.hasOwnProperty;function yt(r,t,e,n,a,u){var o=h(r),f=h(t),c=o?G:K(r),v=f?G:K(t);c=c==q?L:c,v=v==q?L:v;var l=c==L,i=v==L,s=c==v;if(s&&N(r)){if(!N(t))return!1;o=!0,l=!1}if(s&&!l)return u||(u=new P),o||gr(r)?ur(r,t,e,n,a,u):lt(r,t,c,e,n,a,u);if(!(e&gt)){var p=l&&Q.call(r,"__wrapped__"),b=i&&Q.call(t,"__wrapped__");if(p||b){var g=p?r.value():r,y=b?t.value():t;return u||(u=new P),a(g,y,e,n,u)}}return s?(u||(u=new P),ht(r,t,e,n,a,u)):!1}function C(r,t,e,n,a){return r===t?!0:r==null||t==null||!k(r)&&!k(t)?r!==r&&t!==t:yt(r,t,e,n,C,a)}var dt=1,jt=2;function _t(r,t,e,n){var a=e.length,u=a;if(r==null)return!u;for(r=Object(r);a--;){var o=e[a];if(o[2]?o[1]!==r[o[0]]:!(o[0]in r))return!1}for(;++a<u;){o=e[a];var f=o[0],c=r[f],v=o[1];if(o[2]){if(c===void 0&&!(f in r))return!1}else{var l=new P,i;if(!(i===void 0?C(v,c,dt|jt,n,l):i))return!1}}return!0}function ar(r){return r===r&&!sr(r)}function mt(r){for(var t=M(r),e=t.length;e--;){var n=t[e],a=r[n];t[e]=[n,a,ar(a)]}return t}function or(r,t){return function(e){return e==null?!1:e[r]===t&&(t!==void 0||r in Object(e))}}function wt(r){var t=mt(r);return t.length==1&&t[0][2]?or(t[0][0],t[0][1]):function(e){return e===r||_t(e,r,t)}}function Ot(r,t){return r!=null&&t in Object(r)}function Lt(r,t,e){t=W(t,r);for(var n=-1,a=t.length,u=!1;++n<a;){var o=S(t[n]);if(!(u=r!=null&&e(r,o)))break;r=r[o]}return u||++n!=a?u:(a=r==null?0:r.length,!!a&&br(a)&&hr(o,a)&&(h(r)||X(r)))}function Pt(r,t){return r!=null&&Lt(r,t,Ot)}var St=1,At=2;function Bt(r,t){return $(r)&&ar(t)?or(S(r),t):function(e){var n=Jr(e,r);return n===void 0&&n===t?Pt(e,r):C(t,n,St|At)}}function kt(r){return function(t){return t==null?void 0:t[r]}}function zt(r){return function(t){return rr(t,r)}}function Mt(r){return $(r)?kt(S(r)):zt(r)}function fr(r){return typeof r=="function"?r:r==null?U:typeof r=="object"?h(r)?Bt(r[0],r[1]):wt(r):Mt(r)}function $t(r,t){return r&&dr(r,t,M)}function xt(r,t){return function(e,n){if(e==null)return e;if(!Z(e))return r(e,n);for(var a=e.length,u=-1,o=Object(e);++u<a&&n(o[u],u,o)!==!1;);return e}}var F=xt($t);function Ct(r){return typeof r=="function"?r:U}function Ht(r,t){var e=h(r)?wr:F;return e(r,Ct(t))}function Ft(r,t){var e=[];return F(r,function(n,a,u){t(n,a,u)&&e.push(n)}),e}function It(r,t){var e=h(r)?er:Ft;return e(r,fr(t))}function Jt(r,t,e,n,a){return a(r,function(u,o,f){e=n?(n=!1,u):t(e,u,o,f)}),e}function Tt(r,t,e){var n=h(r)?Nr:Jt,a=arguments.length<3;return n(r,fr(t),e,a,F)}var Kt=1/0,Nt=A&&1/x(new A([,-0]))[1]==Kt?function(r){return new A(r)}:mr,Rt=200;function Yt(r,t,e){var n=-1,a=Ar,u=r.length,o=!0,f=[],c=f;if(u>=Rt){var v=t?null:Nt(r);if(v)return x(v);o=!1,a=nr,c=new m}else c=t?[]:f;r:for(;++n<u;){var l=r[n],i=t?t(l):l;if(l=l!==0?l:0,o&&i===i){for(var s=c.length;s--;)if(c[s]===i)continue r;t&&c.push(i),f.push(l)}else a(c,i,e)||(c!==f&&c.push(i),f.push(l))}return f}export{$t as $,Et as B,wr as E,Ct as F,Fr as G,S as I,Yt as J,Rr as K,M,Lt as T,Tt as Y,It as Z,fr as a,Pt as b,Or as c,T as d,Hr as e,Ir as f,F as g,W as j,rr as n,Ht as q,tr as r,_r as v,z as x};
@@ -1,2 +1,2 @@
1
- import{_ as O}from"./index-2ZR5memZ.js";var q=Object.defineProperty,D=(l,i,e)=>i in l?q(l,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):l[i]=e,I=(l,i,e)=>D(l,typeof i!="symbol"?i+"":i,e);let F=null,$=null;typeof window>"u"&&Promise.all([O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null),O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null)]).then(([l,i])=>{var e,t;(e=l==null?void 0:l.default)!=null&&e.Agent?F=new l.default.Agent({keepAlive:!0}):l!=null&&l.Agent&&(F=new l.Agent({keepAlive:!0})),(t=i==null?void 0:i.default)!=null&&t.Agent?$=new i.default.Agent({keepAlive:!0}):i!=null&&i.Agent&&($=new i.Agent({keepAlive:!0}))}).catch(l=>{console.warn("Failed to initialize HTTP agents:",l.message)});class N{constructor(i){if(I(this,"apiUrl"),I(this,"apiKey"),I(this,"sessionId"),!i.apiUrl||typeof i.apiUrl!="string")throw new Error("API URL must be a valid string");if(i.apiKey!==void 0&&i.apiKey!==null&&typeof i.apiKey!="string")throw new Error("API key must be a valid string or null");if(i.sessionId!==void 0&&i.sessionId!==null&&typeof i.sessionId!="string")throw new Error("Session ID must be a valid string or null");this.apiUrl=i.apiUrl,this.apiKey=i.apiKey??null,this.sessionId=i.sessionId??null}setSessionId(i){if(i!==null&&typeof i!="string")throw new Error("Session ID must be a valid string or null");this.sessionId=i}getSessionId(){return this.sessionId}async validateApiKey(){var i;if(!this.apiKey)throw new Error("API key is required for validation");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/${this.apiKey}/status`,{...this.getFetchOptions({method:"GET"})}).catch(r=>{throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r});if(!e.ok){let r="";try{r=await e.text()}catch{r=`HTTP ${e.status}`}let s,n;try{const a=JSON.parse(r);s=a.detail||a.message||r}catch{s=r||`HTTP ${e.status}`}switch(e.status){case 401:n="API key is invalid or expired";break;case 403:n="Access denied: API key does not have required permissions";break;case 404:n="API key not found";break;case 503:n="API key management is not available in inference-only mode";break;default:n=`Failed to validate API key: ${s}`;break}throw new Error(n)}const t=await e.json();if(!t.exists){const r="API key does not exist";throw new Error(r)}if(!t.active){const r="API key is inactive";throw new Error(r)}return t}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Access denied")||e.message.includes("invalid")||e.message.includes("expired")||e.message.includes("inactive")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`API key validation failed: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="API key validation failed. Please check your API key and try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}async getAdapterInfo(){var i;if(!this.apiKey)throw new Error("API key is required to get adapter information");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/info`,{...this.getFetchOptions({method:"GET"})}).catch(t=>{throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t});if(!e.ok){let t="";try{t=await e.text()}catch{t=`HTTP ${e.status}`}let r,s;try{const n=JSON.parse(t);r=n.detail||n.message||t}catch{r=t||`HTTP ${e.status}`}switch(e.status){case 401:s="API key is invalid, disabled, or has no associated adapter";break;case 404:s="Adapter configuration not found";break;case 503:s="Service is not available";break;default:s=`Failed to get adapter info: ${r}`;break}throw new Error(s)}return await e.json()}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Adapter")||e.message.includes("invalid")||e.message.includes("disabled")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`Failed to get adapter info: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="Failed to get adapter information. Please try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}getFetchOptions(i={}){const e={};if(typeof window>"u"){const r=this.apiUrl.startsWith("https:")?$:F;r&&(e.agent=r)}else e.headers={Connection:"keep-alive"};const t={"X-Request-ID":Date.now().toString(36)+Math.random().toString(36).substring(2)};if(e.headers&&Object.assign(t,e.headers),i.headers){const r=i.headers;for(const[s,n]of Object.entries(r))(s.toLowerCase()!=="x-api-key"||!this.apiKey)&&(t[s]=n)}return this.apiKey&&(t["X-API-Key"]=this.apiKey),this.sessionId&&(t["X-Session-ID"]=this.sessionId),{...i,...e,headers:t}}createChatRequest(i,e=!0,t,r,s,n,a,h,p,y,v){const c={messages:[{role:"user",content:i}],stream:e};return t&&t.length>0&&(c.file_ids=t),r&&(c.thread_id=r),s&&(c.audio_input=s),n&&(c.audio_format=n),a&&(c.language=a),h!==void 0&&(c.return_audio=h),p&&(c.tts_voice=p),y&&(c.source_language=y),v&&(c.target_language=v),c}async*streamChat(i,e=!0,t,r,s,n,a,h,p,y,v){var c,C,b;try{const w=new AbortController,_=setTimeout(()=>w.abort(),6e4),g=await fetch(`${this.apiUrl}/v1/chat`,{...this.getFetchOptions({method:"POST",headers:{"Content-Type":"application/json",Accept:e?"text/event-stream":"application/json"},body:JSON.stringify(this.createChatRequest(i,e,t,r,s,n,a,h,p,y,v))}),signal:w.signal});if(clearTimeout(_),!g.ok){const f=await g.text();throw new Error(`Network response was not ok: ${g.status} ${f}`)}if(!e){const f=await g.json();f.response&&(yield{text:f.response,done:!0,audio:f.audio,audioFormat:f.audio_format});return}const A=(c=g.body)==null?void 0:c.getReader();if(!A)throw new Error("No reader available");const S=new TextDecoder;let u="",E=!1;try{for(;;){const{done:f,value:U}=await A.read();if(f)break;const j=S.decode(U,{stream:!0});u+=j;let k=0,P;for(;(P=u.indexOf(`
1
+ import{_ as O}from"./index-BIBo0u38.js";var q=Object.defineProperty,D=(l,i,e)=>i in l?q(l,i,{enumerable:!0,configurable:!0,writable:!0,value:e}):l[i]=e,I=(l,i,e)=>D(l,typeof i!="symbol"?i+"":i,e);let F=null,$=null;typeof window>"u"&&Promise.all([O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null),O(()=>import("./__vite-browser-external-BIHI7g3E.js"),[]).catch(()=>null)]).then(([l,i])=>{var e,t;(e=l==null?void 0:l.default)!=null&&e.Agent?F=new l.default.Agent({keepAlive:!0}):l!=null&&l.Agent&&(F=new l.Agent({keepAlive:!0})),(t=i==null?void 0:i.default)!=null&&t.Agent?$=new i.default.Agent({keepAlive:!0}):i!=null&&i.Agent&&($=new i.Agent({keepAlive:!0}))}).catch(l=>{console.warn("Failed to initialize HTTP agents:",l.message)});class N{constructor(i){if(I(this,"apiUrl"),I(this,"apiKey"),I(this,"sessionId"),!i.apiUrl||typeof i.apiUrl!="string")throw new Error("API URL must be a valid string");if(i.apiKey!==void 0&&i.apiKey!==null&&typeof i.apiKey!="string")throw new Error("API key must be a valid string or null");if(i.sessionId!==void 0&&i.sessionId!==null&&typeof i.sessionId!="string")throw new Error("Session ID must be a valid string or null");this.apiUrl=i.apiUrl,this.apiKey=i.apiKey??null,this.sessionId=i.sessionId??null}setSessionId(i){if(i!==null&&typeof i!="string")throw new Error("Session ID must be a valid string or null");this.sessionId=i}getSessionId(){return this.sessionId}async validateApiKey(){var i;if(!this.apiKey)throw new Error("API key is required for validation");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/${this.apiKey}/status`,{...this.getFetchOptions({method:"GET"})}).catch(r=>{throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r});if(!e.ok){let r="";try{r=await e.text()}catch{r=`HTTP ${e.status}`}let s,n;try{const a=JSON.parse(r);s=a.detail||a.message||r}catch{s=r||`HTTP ${e.status}`}switch(e.status){case 401:n="API key is invalid or expired";break;case 403:n="Access denied: API key does not have required permissions";break;case 404:n="API key not found";break;case 503:n="API key management is not available in inference-only mode";break;default:n=`Failed to validate API key: ${s}`;break}throw new Error(n)}const t=await e.json();if(!t.exists){const r="API key does not exist";throw new Error(r)}if(!t.active){const r="API key is inactive";throw new Error(r)}return t}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Access denied")||e.message.includes("invalid")||e.message.includes("expired")||e.message.includes("inactive")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`API key validation failed: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="API key validation failed. Please check your API key and try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}async getAdapterInfo(){var i;if(!this.apiKey)throw new Error("API key is required to get adapter information");try{const e=await fetch(`${this.apiUrl}/admin/api-keys/info`,{...this.getFetchOptions({method:"GET"})}).catch(t=>{throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t});if(!e.ok){let t="";try{t=await e.text()}catch{t=`HTTP ${e.status}`}let r,s;try{const n=JSON.parse(t);r=n.detail||n.message||t}catch{r=t||`HTTP ${e.status}`}switch(e.status){case 401:s="API key is invalid, disabled, or has no associated adapter";break;case 404:s="Adapter configuration not found";break;case 503:s="Service is not available";break;default:s=`Failed to get adapter info: ${r}`;break}throw new Error(s)}return await e.json()}catch(e){let t;throw e instanceof Error&&e.message?e.message.includes("API key")||e.message.includes("Adapter")||e.message.includes("invalid")||e.message.includes("disabled")||e.message.includes("not found")||e.message.includes("Could not connect")?t=e.message:t=`Failed to get adapter info: ${e.message}`:e.name==="TypeError"&&(i=e.message)!=null&&i.includes("Failed to fetch")?t="Could not connect to the server. Please check if the server is running.":t="Failed to get adapter information. Please try again.",console.warn(`[ApiClient] ${t}`),new Error(t)}}getFetchOptions(i={}){const e={};if(typeof window>"u"){const r=this.apiUrl.startsWith("https:")?$:F;r&&(e.agent=r)}else e.headers={Connection:"keep-alive"};const t={"X-Request-ID":Date.now().toString(36)+Math.random().toString(36).substring(2)};if(e.headers&&Object.assign(t,e.headers),i.headers){const r=i.headers;for(const[s,n]of Object.entries(r))(s.toLowerCase()!=="x-api-key"||!this.apiKey)&&(t[s]=n)}return this.apiKey&&(t["X-API-Key"]=this.apiKey),this.sessionId&&(t["X-Session-ID"]=this.sessionId),{...i,...e,headers:t}}createChatRequest(i,e=!0,t,r,s,n,a,h,p,y,v){const c={messages:[{role:"user",content:i}],stream:e};return t&&t.length>0&&(c.file_ids=t),r&&(c.thread_id=r),s&&(c.audio_input=s),n&&(c.audio_format=n),a&&(c.language=a),h!==void 0&&(c.return_audio=h),p&&(c.tts_voice=p),y&&(c.source_language=y),v&&(c.target_language=v),c}async*streamChat(i,e=!0,t,r,s,n,a,h,p,y,v){var c,C,b;try{const w=new AbortController,_=setTimeout(()=>w.abort(),6e4),g=await fetch(`${this.apiUrl}/v1/chat`,{...this.getFetchOptions({method:"POST",headers:{"Content-Type":"application/json",Accept:e?"text/event-stream":"application/json"},body:JSON.stringify(this.createChatRequest(i,e,t,r,s,n,a,h,p,y,v))}),signal:w.signal});if(clearTimeout(_),!g.ok){const f=await g.text();throw new Error(`Network response was not ok: ${g.status} ${f}`)}if(!e){const f=await g.json();f.response&&(yield{text:f.response,done:!0,audio:f.audio,audioFormat:f.audio_format});return}const A=(c=g.body)==null?void 0:c.getReader();if(!A)throw new Error("No reader available");const S=new TextDecoder;let u="",E=!1;try{for(;;){const{done:f,value:U}=await A.read();if(f)break;const j=S.decode(U,{stream:!0});u+=j;let k=0,P;for(;(P=u.indexOf(`
2
2
  `,k))!==-1;){const m=u.slice(k,P).trim();if(k=P+1,m&&m.startsWith("data: ")){const d=m.slice(6).trim();if(!d||d==="[DONE]"){yield{text:"",done:!0};return}try{const o=JSON.parse(d);if(o.error){const K=`Server error: ${((C=o.error)==null?void 0:C.message)||o.error||"Unknown server error"}`;throw console.warn(`[ApiClient] ${K}`),new Error(K)}if(o.done===!0){E=!0,yield{text:"",done:!0,audio:o.audio,audioFormat:o.audio_format||o.audioFormat,threading:o.threading};return}const x=o.response||"";o.audio_chunk!==void 0&&(yield{text:"",done:!1,audio_chunk:o.audio_chunk,audioFormat:o.audioFormat||o.audio_format||"opus",chunk_index:o.chunk_index??0}),(x||o.audio)&&(E=!0,yield{text:x,done:o.done||!1,audio:o.audio,audioFormat:o.audio_format||o.audioFormat,threading:o.threading})}catch(o){if((b=o==null?void 0:o.message)!=null&&b.startsWith("Server error:"))throw o;console.warn("[ApiClient] Unable to parse server response. This may be a temporary issue."),console.warn("[ApiClient] Parse error details:",o==null?void 0:o.message),console.warn("[ApiClient] JSON text length:",d==null?void 0:d.length),console.warn("[ApiClient] JSON text preview (first 200 chars):",d==null?void 0:d.substring(0,200)),console.warn("[ApiClient] JSON text preview (last 200 chars):",d==null?void 0:d.substring(d.length-200))}}else m&&(E=!0,yield{text:m,done:!1})}u=u.slice(k),u.length>1e6&&(console.warn("[ApiClient] Buffer too large, truncating..."),u=u.slice(-5e5))}E&&(yield{text:"",done:!0})}finally{A.releaseLock()}}catch(w){throw w.name==="AbortError"?new Error("Connection timed out. Please check if the server is running."):w.name==="TypeError"&&w.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):w}}async clearConversationHistory(i){const e=i||this.sessionId;if(!e)throw new Error("No session ID provided and no current session available");if(!this.apiKey)throw new Error("API key is required for clearing conversation history");const t={"Content-Type":"application/json","X-Session-ID":e,"X-API-Key":this.apiKey};try{const r=await fetch(`${this.apiUrl}/admin/chat-history/${e}`,{...this.getFetchOptions({method:"DELETE",headers:t})});if(!r.ok){const s=await r.text();throw new Error(`Failed to clear conversation history: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async deleteConversationWithFiles(i,e){const t=i||this.sessionId;if(!t)throw new Error("No session ID provided and no current session available");if(!this.apiKey)throw new Error("API key is required for deleting conversation");const r={"Content-Type":"application/json","X-Session-ID":t,"X-API-Key":this.apiKey},s=e&&e.length>0?`?file_ids=${e.join(",")}`:"",n=`${this.apiUrl}/admin/conversations/${t}${s}`;try{const a=await fetch(n,{...this.getFetchOptions({method:"DELETE",headers:r})});if(!a.ok){const h=await a.text();throw new Error(`Failed to delete conversation: ${a.status} ${h}`)}return await a.json()}catch(a){throw a.name==="TypeError"&&a.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):a}}async createThread(i,e){if(!this.apiKey)throw new Error("API key is required for creating threads");const t={"Content-Type":"application/json","X-API-Key":this.apiKey};try{const r=await fetch(`${this.apiUrl}/api/threads`,{...this.getFetchOptions({method:"POST",headers:t,body:JSON.stringify({message_id:i,session_id:e})})});if(!r.ok){const s=await r.text();throw new Error(`Failed to create thread: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async getThreadInfo(i){if(!this.apiKey)throw new Error("API key is required for getting thread info");const e={"X-API-Key":this.apiKey};try{const t=await fetch(`${this.apiUrl}/api/threads/${i}`,{...this.getFetchOptions({method:"GET",headers:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to get thread info: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async deleteThread(i){if(!this.apiKey)throw new Error("API key is required for deleting threads");const e={"X-API-Key":this.apiKey};try{const t=await fetch(`${this.apiUrl}/api/threads/${i}`,{...this.getFetchOptions({method:"DELETE",headers:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to delete thread: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async uploadFile(i){if(!this.apiKey)throw new Error("API key is required for file upload");const e=new FormData;e.append("file",i);try{const t=await fetch(`${this.apiUrl}/api/files/upload`,{...this.getFetchOptions({method:"POST",body:e})});if(!t.ok){const r=await t.text();throw new Error(`Failed to upload file: ${t.status} ${r}`)}return await t.json()}catch(t){throw t.name==="TypeError"&&t.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):t}}async listFiles(){if(!this.apiKey)throw new Error("API key is required for listing files");try{const i=await fetch(`${this.apiUrl}/api/files`,{...this.getFetchOptions({method:"GET"})});if(!i.ok){const e=await i.text();throw new Error(`Failed to list files: ${i.status} ${e}`)}return await i.json()}catch(i){throw i.name==="TypeError"&&i.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):i}}async getFileInfo(i){if(!this.apiKey)throw new Error("API key is required for getting file info");try{const e=await fetch(`${this.apiUrl}/api/files/${i}`,{...this.getFetchOptions({method:"GET"})});if(!e.ok){const t=await e.text();throw new Error(`Failed to get file info: ${e.status} ${t}`)}return await e.json()}catch(e){throw e.name==="TypeError"&&e.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):e}}async queryFile(i,e,t=10){if(!this.apiKey)throw new Error("API key is required for querying files");try{const r=await fetch(`${this.apiUrl}/api/files/${i}/query`,{...this.getFetchOptions({method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({query:e,max_results:t})})});if(!r.ok){const s=await r.text();throw new Error(`Failed to query file: ${r.status} ${s}`)}return await r.json()}catch(r){throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?new Error("Could not connect to the server. Please check if the server is running."):r}}async deleteFile(i){if(!this.apiKey)throw new Error("API key is required for deleting files");const e=`${this.apiUrl}/api/files/${i}`,t=this.getFetchOptions({method:"DELETE"});try{const r=await fetch(e,t);if(!r.ok){const s=await r.text();let n;try{const a=JSON.parse(s);n=a.detail||a.message||`Failed to delete file (HTTP ${r.status})`}catch{n=`Failed to delete file (HTTP ${r.status})`}throw console.warn(`[ApiClient] ${n}`),new Error(n)}return await r.json()}catch(r){let s;throw r.name==="TypeError"&&r.message.includes("Failed to fetch")?s="Could not connect to the server. Please check if the server is running.":r.message&&!r.message.includes("Failed to delete file")?s=r.message:s="Failed to delete file. Please try again.",console.warn(`[ApiClient] ${s}`),new Error(s)}}}let T=null;const L=(l,i=null,e=null)=>{T=new N({apiUrl:l,apiKey:i,sessionId:e})};async function*X(l,i=!0,e,t,r,s,n,a,h,p,y){if(!T)throw new Error("API not configured. Please call configureApi() with your server URL before using any API functions.");yield*T.streamChat(l,i,e,t,r,s,n,a,h,p,y)}export{N as ApiClient,L as configureApi,X as streamChat};
@@ -1 +1 @@
1
- import{b0 as sn,b1 as an,b2 as l,as as on,b3 as L,b4 as q,b5 as E,b6 as un,aq as D,b7 as cn,b8 as z,b9 as e,ba as rn,bb as en,bc as yn}from"./index-2ZR5memZ.js";function fn(i){return i.innerRadius}function ln(i){return i.outerRadius}function gn(i){return i.startAngle}function pn(i){return i.endAngle}function xn(i){return i&&i.padAngle}function mn(i,d,W,B,v,b,G,a){var C=W-i,r=B-d,n=G-v,p=a-b,u=p*C-n*r;if(!(u*u<l))return u=(n*(d-b)-p*(i-v))/u,[i+u*C,d+u*r]}function U(i,d,W,B,v,b,G){var a=i-W,C=d-B,r=(G?b:-b)/z(a*a+C*C),n=r*C,p=-r*a,u=i+n,s=d+p,y=W+n,f=B+p,H=(u+y)/2,o=(s+f)/2,x=y-u,g=f-s,T=x*x+g*g,A=v-b,O=u*f-y*s,J=(g<0?-1:1)*z(en(0,A*A*T-O*O)),P=(O*g-x*J)/T,_=(-O*x-g*J)/T,R=(O*g+x*J)/T,m=(-O*x+g*J)/T,h=P-H,t=_-o,c=R-H,I=m-o;return h*h+t*t>c*c+I*I&&(P=R,_=m),{cx:P,cy:_,x01:-n,y01:-p,x11:P*(v/A-1),y11:_*(v/A-1)}}function dn(){var i=fn,d=ln,W=D(0),B=null,v=gn,b=pn,G=xn,a=null,C=sn(r);function r(){var n,p,u=+i.apply(this,arguments),s=+d.apply(this,arguments),y=v.apply(this,arguments)-an,f=b.apply(this,arguments)-an,H=un(f-y),o=f>y;if(a||(a=n=C()),s<u&&(p=s,s=u,u=p),!(s>l))a.moveTo(0,0);else if(H>on-l)a.moveTo(s*L(y),s*q(y)),a.arc(0,0,s,y,f,!o),u>l&&(a.moveTo(u*L(f),u*q(f)),a.arc(0,0,u,f,y,o));else{var x=y,g=f,T=y,A=f,O=H,J=H,P=G.apply(this,arguments)/2,_=P>l&&(B?+B.apply(this,arguments):z(u*u+s*s)),R=E(un(s-u)/2,+W.apply(this,arguments)),m=R,h=R,t,c;if(_>l){var I=rn(_/u*q(P)),S=rn(_/s*q(P));(O-=I*2)>l?(I*=o?1:-1,T+=I,A-=I):(O=0,T=A=(y+f)/2),(J-=S*2)>l?(S*=o?1:-1,x+=S,g-=S):(J=0,x=g=(y+f)/2)}var $=s*L(x),j=s*q(x),X=u*L(A),Z=u*q(A);if(R>l){var k=s*L(g),N=s*q(g),V=u*L(T),Y=u*q(T),F;if(H<cn)if(F=mn($,j,V,Y,k,N,X,Z)){var K=$-F[0],M=j-F[1],Q=k-F[0],w=N-F[1],nn=1/q(yn((K*Q+M*w)/(z(K*K+M*M)*z(Q*Q+w*w)))/2),tn=z(F[0]*F[0]+F[1]*F[1]);m=E(R,(u-tn)/(nn-1)),h=E(R,(s-tn)/(nn+1))}else m=h=0}J>l?h>l?(t=U(V,Y,$,j,s,h,o),c=U(k,N,X,Z,s,h,o),a.moveTo(t.cx+t.x01,t.cy+t.y01),h<R?a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,s,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),!o),a.arc(c.cx,c.cy,h,e(c.y11,c.x11),e(c.y01,c.x01),!o))):(a.moveTo($,j),a.arc(0,0,s,x,g,!o)):a.moveTo($,j),!(u>l)||!(O>l)?a.lineTo(X,Z):m>l?(t=U(X,Z,k,N,u,-m,o),c=U($,j,V,Y,u,-m,o),a.lineTo(t.cx+t.x01,t.cy+t.y01),m<R?a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,u,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),o),a.arc(c.cx,c.cy,m,e(c.y11,c.x11),e(c.y01,c.x01),!o))):a.arc(0,0,u,A,T,o)}if(a.closePath(),n)return a=null,n+""||null}return r.centroid=function(){var n=(+i.apply(this,arguments)+ +d.apply(this,arguments))/2,p=(+v.apply(this,arguments)+ +b.apply(this,arguments))/2-cn/2;return[L(p)*n,q(p)*n]},r.innerRadius=function(n){return arguments.length?(i=typeof n=="function"?n:D(+n),r):i},r.outerRadius=function(n){return arguments.length?(d=typeof n=="function"?n:D(+n),r):d},r.cornerRadius=function(n){return arguments.length?(W=typeof n=="function"?n:D(+n),r):W},r.padRadius=function(n){return arguments.length?(B=n==null?null:typeof n=="function"?n:D(+n),r):B},r.startAngle=function(n){return arguments.length?(v=typeof n=="function"?n:D(+n),r):v},r.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:D(+n),r):b},r.padAngle=function(n){return arguments.length?(G=typeof n=="function"?n:D(+n),r):G},r.context=function(n){return arguments.length?(a=n??null,r):a},r}export{dn as h};
1
+ import{b0 as sn,b1 as an,b2 as l,as as on,b3 as L,b4 as q,b5 as E,b6 as un,aq as D,b7 as cn,b8 as z,b9 as e,ba as rn,bb as en,bc as yn}from"./index-BIBo0u38.js";function fn(i){return i.innerRadius}function ln(i){return i.outerRadius}function gn(i){return i.startAngle}function pn(i){return i.endAngle}function xn(i){return i&&i.padAngle}function mn(i,d,W,B,v,b,G,a){var C=W-i,r=B-d,n=G-v,p=a-b,u=p*C-n*r;if(!(u*u<l))return u=(n*(d-b)-p*(i-v))/u,[i+u*C,d+u*r]}function U(i,d,W,B,v,b,G){var a=i-W,C=d-B,r=(G?b:-b)/z(a*a+C*C),n=r*C,p=-r*a,u=i+n,s=d+p,y=W+n,f=B+p,H=(u+y)/2,o=(s+f)/2,x=y-u,g=f-s,T=x*x+g*g,A=v-b,O=u*f-y*s,J=(g<0?-1:1)*z(en(0,A*A*T-O*O)),P=(O*g-x*J)/T,_=(-O*x-g*J)/T,R=(O*g+x*J)/T,m=(-O*x+g*J)/T,h=P-H,t=_-o,c=R-H,I=m-o;return h*h+t*t>c*c+I*I&&(P=R,_=m),{cx:P,cy:_,x01:-n,y01:-p,x11:P*(v/A-1),y11:_*(v/A-1)}}function dn(){var i=fn,d=ln,W=D(0),B=null,v=gn,b=pn,G=xn,a=null,C=sn(r);function r(){var n,p,u=+i.apply(this,arguments),s=+d.apply(this,arguments),y=v.apply(this,arguments)-an,f=b.apply(this,arguments)-an,H=un(f-y),o=f>y;if(a||(a=n=C()),s<u&&(p=s,s=u,u=p),!(s>l))a.moveTo(0,0);else if(H>on-l)a.moveTo(s*L(y),s*q(y)),a.arc(0,0,s,y,f,!o),u>l&&(a.moveTo(u*L(f),u*q(f)),a.arc(0,0,u,f,y,o));else{var x=y,g=f,T=y,A=f,O=H,J=H,P=G.apply(this,arguments)/2,_=P>l&&(B?+B.apply(this,arguments):z(u*u+s*s)),R=E(un(s-u)/2,+W.apply(this,arguments)),m=R,h=R,t,c;if(_>l){var I=rn(_/u*q(P)),S=rn(_/s*q(P));(O-=I*2)>l?(I*=o?1:-1,T+=I,A-=I):(O=0,T=A=(y+f)/2),(J-=S*2)>l?(S*=o?1:-1,x+=S,g-=S):(J=0,x=g=(y+f)/2)}var $=s*L(x),j=s*q(x),X=u*L(A),Z=u*q(A);if(R>l){var k=s*L(g),N=s*q(g),V=u*L(T),Y=u*q(T),F;if(H<cn)if(F=mn($,j,V,Y,k,N,X,Z)){var K=$-F[0],M=j-F[1],Q=k-F[0],w=N-F[1],nn=1/q(yn((K*Q+M*w)/(z(K*K+M*M)*z(Q*Q+w*w)))/2),tn=z(F[0]*F[0]+F[1]*F[1]);m=E(R,(u-tn)/(nn-1)),h=E(R,(s-tn)/(nn+1))}else m=h=0}J>l?h>l?(t=U(V,Y,$,j,s,h,o),c=U(k,N,X,Z,s,h,o),a.moveTo(t.cx+t.x01,t.cy+t.y01),h<R?a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,h,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,s,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),!o),a.arc(c.cx,c.cy,h,e(c.y11,c.x11),e(c.y01,c.x01),!o))):(a.moveTo($,j),a.arc(0,0,s,x,g,!o)):a.moveTo($,j),!(u>l)||!(O>l)?a.lineTo(X,Z):m>l?(t=U(X,Z,k,N,u,-m,o),c=U($,j,V,Y,u,-m,o),a.lineTo(t.cx+t.x01,t.cy+t.y01),m<R?a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(c.y01,c.x01),!o):(a.arc(t.cx,t.cy,m,e(t.y01,t.x01),e(t.y11,t.x11),!o),a.arc(0,0,u,e(t.cy+t.y11,t.cx+t.x11),e(c.cy+c.y11,c.cx+c.x11),o),a.arc(c.cx,c.cy,m,e(c.y11,c.x11),e(c.y01,c.x01),!o))):a.arc(0,0,u,A,T,o)}if(a.closePath(),n)return a=null,n+""||null}return r.centroid=function(){var n=(+i.apply(this,arguments)+ +d.apply(this,arguments))/2,p=(+v.apply(this,arguments)+ +b.apply(this,arguments))/2-cn/2;return[L(p)*n,q(p)*n]},r.innerRadius=function(n){return arguments.length?(i=typeof n=="function"?n:D(+n),r):i},r.outerRadius=function(n){return arguments.length?(d=typeof n=="function"?n:D(+n),r):d},r.cornerRadius=function(n){return arguments.length?(W=typeof n=="function"?n:D(+n),r):W},r.padRadius=function(n){return arguments.length?(B=n==null?null:typeof n=="function"?n:D(+n),r):B},r.startAngle=function(n){return arguments.length?(v=typeof n=="function"?n:D(+n),r):v},r.endAngle=function(n){return arguments.length?(b=typeof n=="function"?n:D(+n),r):b},r.padAngle=function(n){return arguments.length?(G=typeof n=="function"?n:D(+n),r):G},r.context=function(n){return arguments.length?(a=n??null,r):a},r}export{dn as h};