@entrydesk/cli 1.11.9 → 1.11.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{agents-AZHKB45D.js → agents-VXW275KJ.js} +1 -1
- package/dist/{budget-7EHNHULF.js → budget-3M4AZTD7.js} +1 -1
- package/dist/chat-DOV7VJMR.js +182 -0
- package/dist/{chats-PGXZJ76M.js → chats-RSDRD5DF.js} +1 -1
- package/dist/{chunk-JB5ASFUE.js → chunk-GIUYIB5E.js} +1 -1
- package/dist/{config-DUIXZF5U.js → config-DNYBZSPQ.js} +1 -1
- package/dist/{config-SQ273QT4.js → config-GB3HY2CY.js} +1 -1
- package/dist/{config-help-CHDTLOJ3.js → config-help-TKBWLL6J.js} +1 -1
- package/dist/{connectors-CJWYJG3N.js → connectors-NU4CMNGK.js} +1 -1
- package/dist/index.js +1 -1
- package/dist/{login-T4BWELNV.js → login-I2YZBF3J.js} +1 -1
- package/dist/{logout-CCONJMSY.js → logout-SXTN4T2O.js} +1 -1
- package/dist/{mcp-H4GZHRIO.js → mcp-GU4IRQE2.js} +1 -1
- package/dist/{models-2MBZX4IZ.js → models-4TPZZCHY.js} +1 -1
- package/dist/{profile-JWJXSKJB.js → profile-J6L7MJWK.js} +1 -1
- package/dist/{schedules-U3WFJ5ZU.js → schedules-YBMVIND4.js} +1 -1
- package/dist/{skills-JE5Y5GZX.js → skills-5OI5GFCZ.js} +1 -1
- package/dist/{status-B4NRW3ZM.js → status-56L4JVYX.js} +1 -1
- package/dist/{tool-OJJNLOPD.js → tool-B6Y4W75M.js} +1 -1
- package/dist/{usage-AIDCBDJ3.js → usage-VZ5VJVTO.js} +1 -1
- package/dist/version-3ARCFM7W.js +2 -0
- package/dist/{workspaces-XLJJGG5J.js → workspaces-JO4RT6UA.js} +1 -1
- package/package.json +1 -1
- package/dist/chat-4JHCW4MC.js +0 -182
- package/dist/version-TI2ROJQT.js +0 -2
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import{a as ce,b as ge,c as Yt,h as ft,i as be,l as Qe,o as xn,p as Ve,r as bn}from"./chunk-GIUYIB5E.js";import{render as Tr}from"ink";import{v4 as Ut}from"uuid";import{exec as ko}from"child_process";import Io from"fs";import We from"fs/promises";import yn from"os";import Vt from"path";import{promisify as So}from"util";import{glob as vo}from"glob";var Po=So(ko),_o=`## Filesystem Tool Instructions
|
|
3
|
+
|
|
4
|
+
You have access to filesystem tools that allow you to interact with the user's local filesystem.
|
|
5
|
+
|
|
6
|
+
### Available Operations
|
|
7
|
+
|
|
8
|
+
- **Read File**: Read the contents of a file
|
|
9
|
+
- **Read Multiple Files**: Read multiple files at once (max 10)
|
|
10
|
+
- **Write File**: Create or overwrite a file
|
|
11
|
+
- **Create Directory**: Create a new directory (including parent directories)
|
|
12
|
+
- **List Directory**: List files and subdirectories
|
|
13
|
+
- **Search Files**: Search for files matching a glob pattern
|
|
14
|
+
- **Get File Info**: Get metadata about a file or directory
|
|
15
|
+
- **Move File**: Move or rename a file or directory
|
|
16
|
+
- **Execute Command**: Run shell commands on the user's machine
|
|
17
|
+
|
|
18
|
+
### Important Notes
|
|
19
|
+
|
|
20
|
+
- Always use absolute paths when possible
|
|
21
|
+
- Be mindful of file permissions and access restrictions
|
|
22
|
+
- Large files will be truncated in responses
|
|
23
|
+
- Search results are limited to prevent overwhelming responses
|
|
24
|
+
- Execute Command has a default timeout of 30 seconds (max 5 minutes)
|
|
25
|
+
- The current working directory is: ${process.cwd()}
|
|
26
|
+
- The user's home directory is: ${yn.homedir()}
|
|
27
|
+
`,Eo=[{name:"filesystem__read_file",description:"Read the contents of a file from the local filesystem.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to the file to read."}},required:["path"]}},{name:"filesystem__read_multiple_files",description:"Read multiple files at once (max 10 files).",inputSchema:{type:"object",properties:{paths:{type:"array",items:{type:"string"},description:"Array of absolute file paths to read."}},required:["paths"]}},{name:"filesystem__write_file",description:"Create or overwrite a file with the given content.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to the file to write."},content:{type:"string",description:"The content to write to the file."}},required:["path","content"]}},{name:"filesystem__create_directory",description:"Create a new directory (including parent directories if needed).",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path of the directory to create."}},required:["path"]}},{name:"filesystem__list_directory",description:"List files and subdirectories in a directory.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path of the directory to list."}},required:["path"]}},{name:"filesystem__search_files",description:"Search for files matching a glob pattern.",inputSchema:{type:"object",properties:{pattern:{type:"string",description:'Glob pattern to match files (e.g., "**/*.ts").'},cwd:{type:"string",description:"Base directory to search in (optional)."}},required:["pattern"]}},{name:"filesystem__get_file_info",description:"Get metadata about a file or directory.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to get info for."}},required:["path"]}},{name:"filesystem__move_file",description:"Move or rename a file or directory.",inputSchema:{type:"object",properties:{source:{type:"string",description:"The source path."},destination:{type:"string",description:"The destination path."}},required:["source","destination"]}},{name:"filesystem__execute_command",description:"Execute a shell command on the local machine.",inputSchema:{type:"object",properties:{command:{type:"string",description:"The command to execute."},cwd:{type:"string",description:"Working directory for the command (optional)."},timeout:{type:"number",description:"Timeout in milliseconds (default: 30000, max: 300000)."}},required:["command"]}}];function wn(){return{name:"filesystem",systemPrompt:_o,tools:Eo}}function Re(e){return e.startsWith("~/")?Vt.join(yn.homedir(),e.slice(2)):e}function vt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
|
|
28
|
+
|
|
29
|
+
... (truncated, ${e.length-t} more characters)`}async function Cn(e,t){try{switch(e){case"filesystem__read_file":{let n=Re(t.path),s=await We.readFile(n,"utf-8");return{success:!0,result:vt(s)}}case"filesystem__read_multiple_files":{let n=t.paths.slice(0,10),s={};for(let i of n){let l=Re(i);try{let f=await We.readFile(l,"utf-8");s[i]=vt(f,5e4)}catch(f){s[i]={error:f instanceof Error?f.message:String(f)}}}return{success:!0,result:s}}case"filesystem__write_file":{let n=Re(t.path),s=t.content;return await We.mkdir(Vt.dirname(n),{recursive:!0}),await We.writeFile(n,s,"utf-8"),{success:!0,result:{written:n}}}case"filesystem__create_directory":{let n=Re(t.path);return await We.mkdir(n,{recursive:!0}),{success:!0,result:{created:n}}}case"filesystem__list_directory":{let n=Re(t.path);return{success:!0,result:(await We.readdir(n,{withFileTypes:!0})).map(l=>({name:l.name,type:l.isDirectory()?"directory":l.isFile()?"file":l.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let n=t.pattern,s=t.cwd?Re(t.cwd):process.cwd(),i=await vo(n,{cwd:s,nodir:!0,maxDepth:10});return{success:!0,result:{files:i.slice(0,100),total:i.length,truncated:i.length>100}}}case"filesystem__get_file_info":{let n=Re(t.path),s=await We.stat(n);return{success:!0,result:{path:n,type:s.isDirectory()?"directory":s.isFile()?"file":"other",size:s.size,created:s.birthtime.toISOString(),modified:s.mtime.toISOString(),accessed:s.atime.toISOString(),mode:s.mode.toString(8)}}}case"filesystem__move_file":{let n=Re(t.source),s=Re(t.destination);return await We.mkdir(Vt.dirname(s),{recursive:!0}),await We.rename(n,s),{success:!0,result:{moved:{from:n,to:s}}}}case"filesystem__execute_command":{let n=t.command,s=t.cwd?Re(t.cwd):process.cwd(),i=Math.min(t.timeout||3e4,3e5);if(!Io.existsSync(s))return{success:!1,error:`Working directory does not exist: ${s}`};let{stdout:l,stderr:f}=await Po(n,{cwd:s,timeout:i,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:vt(l,5e4),stderr:vt(f,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(n){return{success:!1,error:n instanceof Error?n.message:String(n)}}}function zt(e){return e.startsWith("filesystem__")}function Tn(){return[wn()]}function Pt(){return Tn().flatMap(e=>e.tools)}function _t(){return Tn().map(e=>e.systemPrompt).filter(Boolean).join(`
|
|
30
|
+
|
|
31
|
+
`)}function je(e){return zt(e)}async function Et(e,t){return zt(e)?Cn(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as Te,Text as K,useInput as pn}from"ink";import mn from"ink-spinner";import{useCallback as gn,useEffect as jt,useRef as go,useState as mr}from"react";import{Box as Nt,Text as pt}from"ink";import{jsx as At,jsxs as mt}from"react/jsx-runtime";function $n(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function kn({items:e,activeIndex:t,selectedIds:n,multiSelect:s=!1,visible:i,title:l,pageSize:f=10}){if(!i||e.length===0)return null;let m=process.stdout.columns??80,b=s?4:0,g=Math.max(20,m-2-2-b),U=Math.max(1,f),D=Math.floor(t/U)*U,I=Math.min(e.length,D+U),P=e.slice(D,I);return mt(Nt,{flexDirection:"column",marginBottom:1,children:[At(pt,{bold:!0,color:"cyan",children:l}),At(Nt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:P.map(($,x)=>{let M=D+x===t,J=n?.has($.id),X=$n($.name,g),oe=$.description?$n($.description,Math.max(0,g-b)):"",Y=s?" ".repeat(b):"";return mt(Nt,{paddingX:1,flexDirection:"column",children:[mt(Nt,{children:[s&&At(pt,{color:J?"green":"gray",children:J?"[\u2713] ":"[ ] "}),At(pt,{backgroundColor:M?"cyan":void 0,color:M?"black":J?"green":"white",bold:!0,children:X})]}),oe&&mt(pt,{dimColor:!0,children:[Y,"\xB7 ",oe]})]},$.id)})}),mt(pt,{dimColor:!0,children:[s?"\u2191\u2193 Navigate \xB7 Space Toggle \xB7 a All \xB7 n None \xB7 Enter Confirm \xB7 Esc Cancel":"\u2191\u2193 Navigate \xB7 Enter Select \xB7 Esc Cancel",e.length>U?` \xB7 Showing ${D+1}-${I} of ${e.length}`:""]})]})}import{Box as Xt,Text as gt}from"ink";import{jsx as ht,jsxs as Qt}from"react/jsx-runtime";function In({suggestions:e,activeIndex:t,visible:n}){return!n||e.length===0?null:Qt(Xt,{flexDirection:"column",marginBottom:1,children:[ht(Xt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((s,i)=>{let l=i===t,f=s.aliases.length>0?` (${s.aliases.join(", ")})`:"";return Qt(Xt,{paddingX:1,children:[Qt(gt,{backgroundColor:l?"cyan":void 0,color:l?"black":"cyan",bold:l,children:["/",s.name]}),ht(gt,{dimColor:!0,children:f}),ht(gt,{children:" - "}),ht(gt,{color:l?"white":"gray",children:s.description})]},s.name)})}),ht(gt,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as No,Text as Sn,useInput as Ao,useStdout as Do}from"ink";import{useCallback as vn,useEffect as Pn,useMemo as Zt,useRef as _n,useState as En}from"react";import{jsx as nn}from"react/jsx-runtime";function Dt(e,t){return e<0?0:e>t?t:e}function en(e){return Array.from(e)}function Rt(e){return/\s/.test(e)}function tn(e,t){let n=t;for(;n>0&&Rt(e[n-1]??"");)n-=1;for(;n>0&&!Rt(e[n-1]??"");)n-=1;return n}function Nn(e,t){let n=t;for(;n<e.length&&Rt(e[n]??"");)n+=1;for(;n<e.length&&!Rt(e[n]??"");)n+=1;return n}function Ro(e){let t=[],n=[],s=[],i=0;n.push(0),e.forEach((f,m)=>{if(f===`
|
|
32
|
+
`){t.push(s),s=[],i=m+1,n.push(i);return}s.push(f)}),t.push(s);let l=t.map(f=>f.length);return{lines:t,lineStarts:n,lineLengths:l}}function An(e,t,n){for(let i=0;i<t.length;i+=1){let l=t[i]??0,f=n[i]??0,m=l+f;if(e<=m)return{row:i,col:e-l}}let s=Math.max(0,t.length-1);return{row:s,col:n[s]??0}}var Lo=2;function Dn({value:e,onChange:t,onSubmit:n,onPaste:s,focus:i=!0,leadingOffset:l=0,multiline:f=!1}){let[m,b]=En(()=>en(e).length),g=_n(null),[U,D]=En(0),I=_n(null),{stdout:P}=Do(),$=Zt(()=>en(e),[e]),{lines:x,lineStarts:v,lineLengths:M}=Zt(()=>Ro($),[$]),{row:J,col:X}=Zt(()=>An(m,v,M),[m,v,M]),oe=Math.max(1,(P?.columns??80)-l);Pn(()=>{g.current!==e?(b($.length),I.current=null):b(O=>Dt(O,$.length)),g.current=e},[e,$.length]),Pn(()=>{D(O=>{let T=O;X<T?T=X:X>=T+oe&&(T=X-oe+1);let S=M[J]??0,R=X===S?S+1:S,G=Math.max(0,R-oe);return T>G&&(T=G),T<0&&(T=0),T})},[oe,X,J,M]);let Y=vn((O,T)=>{g.current=O,t(O),b(T),I.current=null},[t]),xe=vn(async(O,T)=>{if(!i)return;let{row:S,col:R}=An(m,v,M),G=x[S]??[],_=M[S]??0,ue=x.length>1;if(f&&(T.meta&&T.return||T.ctrl&&O==="j"||T.shift&&T.return)){let N=[...$.slice(0,m),`
|
|
33
|
+
`,...$.slice(m)].join("");Y(N,m+1);return}if(T.return){n(e);return}if(T.leftArrow){T.ctrl||T.meta?(R===0&&S>0?b(v[S]-1):b(v[S]+tn(G,R)),I.current=null):(R===0&&S>0?b(v[S]-1):b(N=>Dt(N-1,$.length)),I.current=null);return}if(T.rightArrow){T.ctrl||T.meta?(R>=_&&S<x.length-1?b(v[S+1]):b(v[S]+Nn(G,R)),I.current=null):(R>=_&&S<x.length-1?b(v[S+1]):b(N=>Dt(N+1,$.length)),I.current=null);return}if(f&&ue&&T.upArrow){let N=I.current??R,c=Math.max(0,S-1),ne=Math.min(N,M[c]??0);b((v[c]??0)+ne),I.current=N;return}if(f&&ue&&T.downArrow){let N=I.current??R,c=Math.min(x.length-1,S+1),ne=Math.min(N,M[c]??0);b((v[c]??0)+ne),I.current=N;return}if(T.ctrl){if(O==="a"){b(v[S]??0),I.current=null;return}if(O==="e"){b((v[S]??0)+_),I.current=null;return}if(O==="u"){if(R>0){let N=v[S]??0,c=[...$.slice(0,N),...$.slice(m)].join("");Y(c,N)}return}if(O==="k"){if(R<_){let N=(v[S]??0)+_,c=[...$.slice(0,m),...$.slice(N)].join("");Y(c,m)}return}if(O==="w"){if(R===0&&S>0){let c=[...$.slice(0,m-1),...$.slice(m)].join("");Y(c,m-1);return}let N=tn(G,R);if(N!==R){let c=(v[S]??0)+N,ne=[...$.slice(0,c),...$.slice(m)].join("");Y(ne,c)}return}if(O==="d"){if(m<$.length){let N=[...$.slice(0,m),...$.slice(m+1)].join("");Y(N,m)}return}return}if(T.meta){O==="b"?(R===0&&S>0?b(v[S]-1):b(v[S]+tn(G,R)),I.current=null):O==="f"&&(R>=_&&S<x.length-1?b(v[S+1]):b(v[S]+Nn(G,R)),I.current=null);return}if(T.backspace||T.delete){if(m<=0)return;let N=[...$.slice(0,m-1),...$.slice(m)].join("");Y(N,m-1);return}if(!(T.tab||T.escape)&&O.length>0){let N=f?O.replace(/\r\n/g,`
|
|
34
|
+
`).replace(/\r/g,`
|
|
35
|
+
`):O.replace(/\r?\n/g,"");if(!N||(N=N.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!N))return;if((N.length>=Lo||N.includes(`
|
|
36
|
+
`))&&s){let V=!1,k={text:N,preventDefault:()=>{V=!0}};if(await Promise.resolve(s(k)),V)return}let ne=en(N),de=[...$.slice(0,m),...ne,...$.slice(m)].join("");Y(de,m+ne.length)}},[$,m,i,M,v,x,f,s,n,Y,e]);return Ao(xe,{isActive:i}),nn(No,{flexDirection:"column",children:x.map((O,T)=>{let S=T===J,G=(S&&X===O.length?[...O," "]:O).slice(U,U+oe),_=G.join("");if(!S)return nn(Sn,{children:_||" "},T);let ue=Dt(X-U,Math.max(0,G.length-1)),N=G.slice(0,ue).join(""),c=G[ue]??" ",ne=G.slice(ue+1).join(""),k=`${N}\x1B[7m${c}\x1B[27m${ne}`;return nn(Sn,{children:k},T)})})}import{Box as Le,Text as ze}from"ink";import an from"react";import{Text as _e}from"ink";import Fo from"react";import{Fragment as Wo,jsx as Ae,jsxs as Fn}from"react/jsx-runtime";var on=2,rn=1,sn=2,Oo=1,Rn=3,Ln=4,Bo=({text:e,defaultColor:t,linkColor:n,codeColor:s})=>{let i=t;if(!/[*_~`<[https?:]/.test(e))return Ae(_e,{color:i,children:e});let l=[],f=0,m=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,b;for(;(b=m.exec(e))!==null;){b.index>f&&l.push(Ae(_e,{color:i,children:e.slice(f,b.index)},`t-${f}`));let g=b[0],U=null,D=`m-${b.index}`;try{if(g.startsWith("**")&&g.endsWith("**")&&g.length>on*2)U=Ae(_e,{bold:!0,color:i,children:g.slice(on,-on)},D);else if(g.length>rn*2&&(g.startsWith("*")&&g.endsWith("*")||g.startsWith("_")&&g.endsWith("_"))&&!/\w/.test(e.substring(b.index-1,b.index))&&!/\w/.test(e.substring(m.lastIndex,m.lastIndex+1))&&!/\S[./\\]/.test(e.substring(b.index-2,b.index))&&!/[./\\]\S/.test(e.substring(m.lastIndex,m.lastIndex+2)))U=Ae(_e,{italic:!0,color:i,children:g.slice(rn,-rn)},D);else if(g.startsWith("~~")&&g.endsWith("~~")&&g.length>sn*2)U=Ae(_e,{strikethrough:!0,color:i,children:g.slice(sn,-sn)},D);else if(g.startsWith("`")&&g.endsWith("`")&&g.length>Oo){let I=g.match(/^(`+)(.+?)\1$/s);I&&I[2]&&(U=Ae(_e,{color:s,children:I[2]},D))}else if(g.startsWith("[")&&g.includes("](")&&g.endsWith(")")){let I=g.match(/\[(.*?)\]\((.*?)\)/);if(I){let P=I[1],$=I[2];U=Fn(_e,{color:i,children:[P,Fn(_e,{color:n,children:[" (",$,")"]})]},D)}}else g.startsWith("<u>")&&g.endsWith("</u>")&&g.length>Rn+Ln-1?U=Ae(_e,{underline:!0,color:i,children:g.slice(Rn,-Ln)},D):g.match(/^https?:\/\//)&&(U=Ae(_e,{color:n,children:g},D))}catch{U=null}l.push(U??Ae(_e,{color:i,children:g},D)),f=m.lastIndex}return f<e.length&&l.push(Ae(_e,{color:i,children:e.slice(f)},`t-${f}`)),Ae(Wo,{children:l.filter(g=>g!==null)})},xt=Fo.memo(Bo);import{Fragment as Ho,jsx as me,jsxs as jn}from"react/jsx-runtime";var jo=1,Wn=1,Uo=1,Mo=1,Go=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return me(Le,{paddingLeft:Wn,flexDirection:"column",children:me(ze,{wrap:"wrap",children:e})});let n=e.split(/\r?\n/),s=/^ *(#{1,4}) +(.*)/,i=/^ *(`{3,}|~{3,}) *(\w*?) *$/,l=/^([ \t]*)([-*+]) +(.*)/,f=/^([ \t]*)(\d+)\. +(.*)/,m=/^ *([-*_] *){3,} *$/,b=/^ *> ?(.*)/,g=[],U=!1,D=!0,I=[],P="";function $(x){x&&(g.push(x),D=!1)}return n.forEach((x,v)=>{let M=`line-${v}`;if(U){let T=x.match(i);T&&T[1].startsWith(P[0])&&T[1].length>=P.length?($(me(On,{content:I},M)),U=!1,I=[],P=""):I.push(x);return}let J=x.match(i),X=x.match(s),oe=x.match(l),Y=x.match(f),xe=x.match(m),O=x.match(b);if(J)U=!0,P=J[1];else if(xe)$(me(Le,{children:me(ze,{dimColor:!0,children:"---"})},M));else if(X){let T=X[1].length,S=X[2],R=T<=2?"cyan":"blue";$(me(Le,{children:me(ze,{color:R,...(T===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:me(xt,{text:S,defaultColor:R,linkColor:"cyan",codeColor:"yellow"})})},M))}else if(O){let T=O[1];$(me(Le,{paddingLeft:1,children:jn(ze,{dimColor:!0,children:["> ",me(xt,{text:T,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},M))}else if(oe){let T=oe[1],S=oe[2],R=oe[3];$(me(Bn,{itemText:R,type:"ul",marker:S,leadingWhitespace:T},M))}else if(Y){let T=Y[1],S=Y[2],R=Y[3];$(me(Bn,{itemText:R,type:"ol",marker:S,leadingWhitespace:T},M))}else x.trim().length===0?D||(g.push(me(Le,{height:jo},`spacer-${v}`)),D=!0):$(me(Le,{children:me(ze,{wrap:"wrap",children:me(xt,{text:x,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},M))}),U&&$(me(On,{content:I},"line-eof")),me(Ho,{children:g})},qo=({content:e})=>{let t=e.join(`
|
|
37
|
+
`);return me(Le,{paddingLeft:Wn,flexDirection:"column",children:me(ze,{color:"yellow",children:t})})},On=an.memo(qo),Ko=({itemText:e,type:t,marker:n,leadingWhitespace:s=""})=>{let i=t==="ol"?`${n}. `:`${n} `,l=i.length,f=s.length;return jn(Le,{paddingLeft:f+Uo,flexDirection:"row",children:[me(Le,{width:l,children:me(ze,{children:i})}),me(Le,{flexGrow:Mo,children:me(ze,{wrap:"wrap",children:me(xt,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},Bn=an.memo(Ko),ln=an.memo(Go);import{execFile as Jo}from"child_process";import Yo from"fs";import at from"fs/promises";import Un from"os";import Ft from"path";import{promisify as Vo}from"util";var Lt=Vo(Jo);async function zo(){let e=Ft.join(Un.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
|
|
38
|
+
set imageData to the clipboard as "PNGf"
|
|
39
|
+
set fileRef to open for access POSIX file "${e}" with write permission
|
|
40
|
+
set eof fileRef to 0
|
|
41
|
+
write imageData to fileRef
|
|
42
|
+
close access fileRef
|
|
43
|
+
`;return await Lt("osascript",["-e",t]),(await at.stat(e)).size===0?void 0:{buffer:await at.readFile(e),mime:"image/png"}}catch{return}finally{try{Yo.existsSync(e)&&await at.unlink(e)}catch{}}}async function Xo(){try{let e=`
|
|
44
|
+
Add-Type -AssemblyName System.Windows.Forms
|
|
45
|
+
$img = [System.Windows.Forms.Clipboard]::GetImage()
|
|
46
|
+
if ($img) {
|
|
47
|
+
$ms = New-Object System.IO.MemoryStream
|
|
48
|
+
$img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png)
|
|
49
|
+
[System.Convert]::ToBase64String($ms.ToArray())
|
|
50
|
+
}
|
|
51
|
+
`,{stdout:t}=await Lt("powershell.exe",["-command",e]),n=t.trim();if(!n)return;let s=Buffer.from(n,"base64");return s.length===0?void 0:{buffer:s,mime:"image/png"}}catch{return}}async function Qo(){try{let{stdout:e}=await Lt("wl-paste",["-t","image/png"],{encoding:"buffer",maxBuffer:52428800});if(e&&e.length>0)return{buffer:e,mime:"image/png"}}catch{}try{let{stdout:e}=await Lt("xclip",["-selection","clipboard","-t","image/png","-o"],{encoding:"buffer",maxBuffer:52428800});if(e&&e.length>0)return{buffer:e,mime:"image/png"}}catch{}}async function Mn(){let e=Un.platform();if(e==="darwin")return zo();if(e==="win32")return Xo();if(e==="linux")return Qo()}var Zo=new Set([".png",".jpg",".jpeg",".gif",".webp",".bmp",".ico",".heic",".heif",".pdf",".txt",".md",".rtf",".csv",".doc",".docx",".xls",".xlsx",".ppt",".pptx",".key",".pages",".numbers",".odt",".ods",".odp",".json",".xml",".yaml",".yml"]);function Gn(e){let t=Ft.extname(e).toLowerCase();return Zo.has(t)}function er(e){let t=Ft.extname(e).toLowerCase();return{".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp",".bmp":"image/bmp",".ico":"image/x-icon",".heic":"image/heic",".heif":"image/heif",".txt":"text/plain",".md":"text/markdown",".pdf":"application/pdf",".csv":"text/csv",".rtf":"application/rtf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".key":"application/vnd.apple.keynote",".pages":"application/vnd.apple.pages",".numbers":"application/vnd.apple.numbers",".odt":"application/vnd.oasis.opendocument.text",".ods":"application/vnd.oasis.opendocument.spreadsheet",".odp":"application/vnd.oasis.opendocument.presentation",".json":"application/json",".xml":"application/xml",".yaml":"text/yaml",".yml":"text/yaml"}[t]||"application/octet-stream"}function Ot(e){let t=e.trim();return t.startsWith("file://")&&(t=decodeURIComponent(t.slice(7))),(t.startsWith("'")&&t.endsWith("'")||t.startsWith('"')&&t.endsWith('"'))&&(t=t.slice(1,-1)),t=t.replace(/\\(.)/g,"$1"),t}async function qn(e){let t=Ot(e);if(/^https?:\/\//.test(t))return!1;try{return await at.access(t),!0}catch{return!1}}async function Kn(e){let t=Ot(e);try{if(!(await at.stat(t)).isFile())return;let s=await at.readFile(t),i=er(t),l=Ft.basename(t);return{buffer:s,mimeType:i,filename:l}}catch{return}}var Ee="\x1B[2m",ee="\x1B[0m",Ce="\x1B[36m",lt="\x1B[32m",Hn="\x1B[31m",Ze="\x1B[38;2;59;91;204m",cn="\x1B[38;2;126;200;248m",un="\x1B[38;2;244;196;78m";import{useState as Ue}from"react";import{v4 as Jn}from"uuid";function Yn(e,t){let[n,s]=Ue({status:"loading"}),[i,l]=Ue([]),[f,m]=Ue(""),[b,g]=Ue(()=>e||Jn()),[U,D]=Ue(t),[I,P]=Ue(!!e),[$,x]=Ue(null),[v,M]=Ue(""),[J,X]=Ue(!1),oe=xe=>{l(O=>[...O,{role:"system",content:xe}])};return{state:n,setState:s,messages:i,setMessages:l,input:f,setInput:m,chatId:b,setChatId:g,currentChatTitle:U,setCurrentChatTitle:D,hasPersistedChat:I,setHasPersistedChat:P,credentials:$,setCredentials:x,currentResponse:v,setCurrentResponse:M,fullOutput:J,setFullOutput:X,addSystemMessage:oe,startNewChat:xe=>{let O=Jn();g(O),D(void 0),P(!1),l([]),xe&&oe(xe)}}}import{useEffect as tr,useState as Vn}from"react";function zn(e){let[t,n]=Vn(null),[s,i]=Vn(!0);return tr(()=>{let l=!1;async function f(){try{let m=await Ve();if(l)return;n({accessToken:m.accessToken,workspaceId:m.workspaceId}),i(!1)}catch(m){if(l)return;if(m instanceof Qe){if(m.code==="not-logged-in"){e({status:"not-logged-in"}),i(!1);return}if(m.code==="no-workspace"){e({status:"no-workspace"}),i(!1);return}}let b=m instanceof Error?m.message:"Failed to authenticate";e({status:"error",message:b}),i(!1)}}return f(),()=>{l=!0}},[e]),{credentials:t,loading:s}}import{useEffect as nr,useState as bt}from"react";function Xn(e){let[t,n]=bt([]),[s,i]=bt([]),[l,f]=bt([]),[m,b]=bt([]),[g,U]=bt(!1);return nr(()=>{if(!e)return;let D=!1;U(!0);async function I(){if(e)try{let P=new be,[$,x,v,M]=await Promise.all([P.getConnectors(e.accessToken,e.workspaceId),P.getModels(e.accessToken,e.workspaceId),P.getAgents(e.accessToken,e.workspaceId),P.getModelProviders(e.accessToken,e.workspaceId)]);if(D)return;n($.connectors),i(x.models),f(v.agents),b(M.providers??[])}catch{}finally{D||U(!1)}}return I(),()=>{D=!0}},[e]),{availableConnectors:t,availableModels:s,availableAgents:l,modelProviders:m,loading:g}}import ct from"fs";import Zn from"path";import{useCallback as or}from"react";import{v4 as rr}from"uuid";function Qn(e,t){if(!e)return"(no result)";if(typeof e!="object"){let i=String(e);return t||i.length<=200?i:i.slice(0,200)+"..."}let n=e;if("structuredContent"in n&&n.structuredContent){let i=n.structuredContent;if(i.stdout&&typeof i.stdout=="string"){let l=i.stdout.trim();return t||l.length<=200?l:l.slice(0,200)+"..."}}if("content"in n&&Array.isArray(n.content)){let i=n.content.filter(l=>l.type==="text"&&l.text).map(l=>l.text).join(`
|
|
52
|
+
`);return i?t||i.length<=200?i:i.slice(0,200)+"...":"(result)"}let s=JSON.stringify(e,null,t?2:void 0);return t||s.length<=200?s:s.slice(0,200)+"..."}function et(e,t=!1){let n=[];for(let s of e)if(s.type==="text"&&s.text)n.push(s.text);else if(s.type==="reasoning"&&s.text)t?n.push(`${Ee}[Thinking]
|
|
53
|
+
${s.text}${ee}`):n.push(`${Ee}[Thinking...]${ee}`);else if(s.type==="tool-call"&&s.toolName){let i=[];if(i.push(`${Ce}\u250C\u2500 Tool: ${s.toolName}${ee}`),s.args){let l=JSON.stringify(s.args,null,t?2:void 0),f=t||l.length<=100?l:l.slice(0,100)+"...";i.push(`${Ee}\u2502 Args: ${f}${ee}`)}s.result!==void 0?(i.push(`${lt}\u2502 Result: ${Qn(s.result,t)}${ee}`),i.push(`${Ce}\u2514\u2500 completed${ee}`)):i.push(`${Ce}\u2514\u2500${ee}`),n.push(i.join(`
|
|
54
|
+
`))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let i=s.title||s.type.slice(5).replace(/__/g," "),l=[];if(l.push(`${Ce}\u250C\u2500 Tool: ${i}${ee}`),s.input){let f=JSON.stringify(s.input,null,t?2:void 0),m=t||f.length<=100?f:f.slice(0,100)+"...";l.push(`${Ee}\u2502 Input: ${m}${ee}`)}s.output!==void 0&&s.state==="output-available"?(l.push(`${lt}\u2502 Output: ${Qn(s.output,t)}${ee}`),l.push(`${Ce}\u2514\u2500 completed${ee}`)):s.state==="error"?l.push(`${Ce}\u2514\u2500 failed${ee}`):l.push(`${Ce}\u2514\u2500${ee}`),n.push(l.join(`
|
|
55
|
+
`))}return n.join(`
|
|
56
|
+
|
|
57
|
+
`).trim()}var Bt=class{pendingToolCalls=new Map;hasPending(){return this.pendingToolCalls.size>0}hasExecuting(){for(let t of this.pendingToolCalls.values())if(t.status==="executing")return!0;return!1}clear(t){this.pendingToolCalls.delete(t)}buildToolDisplay(){if(this.pendingToolCalls.size===0)return"";let t=[];for(let[,n]of this.pendingToolCalls){let s=n.toolName.replace(/__/g," "),i=`
|
|
58
|
+
|
|
59
|
+
${Ce}\u250C\u2500 Tool: ${s}${ee}`;if(n.args){let l=n.args.length>100?n.args.slice(0,100)+"...":n.args;i+=`
|
|
60
|
+
${Ee}\u2502 Input: ${l}${ee}`}if(n.output){let l=n.output.length>150?n.output.slice(0,150)+"...":n.output;i+=`
|
|
61
|
+
${lt}\u2502 Output: ${l}${ee}`}else if(n.status==="executing"){let l=n.startedAt??Date.now(),f=Math.floor((Date.now()-l)/1e3);i+=`
|
|
62
|
+
${Ce}\u2502${ee} (executing... ${f}s)`}else n.status==="preparing"&&(i+=`
|
|
63
|
+
${Ce}\u2502${ee} (preparing...)`);t.push(i)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[n,s]of this.pendingToolCalls){let i=s.toolName.replace(/__/g," "),l=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"";t+=`
|
|
64
|
+
|
|
65
|
+
${Ce}\u250C\u2500 Tool: ${i}${ee}`,l&&(t+=`
|
|
66
|
+
${Ee}\u2502 Input: ${l}${ee}`),t+=`
|
|
67
|
+
${Ce}\u2514\u2500 completed${ee}
|
|
68
|
+
`,this.pendingToolCalls.delete(n)}return t}handleToolInputStart(t){return t.toolCallId&&t.toolName?(this.pendingToolCalls.set(t.toolCallId,{toolName:t.toolName,args:"",status:"preparing"}),this.buildToolDisplay()):null}handleToolInputDelta(t){if(t.toolCallId&&t.inputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.args=(n.args||"")+t.inputTextDelta,n.status="executing",n.startedAt??=Date.now(),this.buildToolDisplay()}return null}handleToolOutputStart(t){if(t.toolCallId){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output="",n.status="output",this.buildToolDisplay()}return null}handleToolOutputDelta(t){if(t.toolCallId&&t.outputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output=(n.output||"")+t.outputTextDelta,this.buildToolDisplay()}return null}handleToolOutputEnd(t,n){if(!t.toolCallId)return null;let s=this.pendingToolCalls.get(t.toolCallId);if(!s)return null;let i=s.toolName.replace(/__/g," "),l=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"",f=(s.output||"").length>200?(s.output||"").slice(0,200)+"...":s.output||"";return n+=`
|
|
69
|
+
|
|
70
|
+
${Ce}\u250C\u2500 Tool: ${i}${ee}`,l&&(n+=`
|
|
71
|
+
${Ee}\u2502 Input: ${l}${ee}`),n+=`
|
|
72
|
+
${lt}\u2502 Output: ${f}${ee}`,n+=`
|
|
73
|
+
${Ce}\u2514\u2500 completed${ee}
|
|
74
|
+
`,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}handleToolError(t,n){if(!t.toolCallId)return null;let i=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),l=t.errorText||"Unknown error",f=l.length>200?l.slice(0,200)+"...":l;return n+=`
|
|
75
|
+
|
|
76
|
+
${Ce}\u250C\u2500 Tool: ${i}${ee}`,n+=`
|
|
77
|
+
${Hn}\u2502 Error: ${f}${ee}`,n+=`
|
|
78
|
+
${Ce}\u2514\u2500 failed${ee}
|
|
79
|
+
`,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}};var yt=Zn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function re(e,t){if(!process.env.DEBUG)return;let s=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(s+=`
|
|
80
|
+
DATA: ${JSON.stringify(t,null,2)}`),s+=`
|
|
81
|
+
`;try{ct.appendFileSync(yt,s)}catch{}}function sr(){try{if(ct.existsSync(yt)&&ct.unlinkSync(yt),process.env.DEBUG){let e=Zn.dirname(yt);ct.existsSync(e)||ct.mkdirSync(e,{recursive:!0}),ct.writeFileSync(yt,`=== Debug session started at ${new Date().toISOString()} ===
|
|
82
|
+
`)}}catch{}}function Wt(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function eo({chatId:e,credentials:t,currentAgentId:n,currentModel:s,activeConnectorIds:i,sandbox:l,webSearch:f,imageGeneration:m,chart:b,localTools:g,fullOutput:U,setMessages:D,setState:I,setCurrentResponse:P,setCredentials:$,setHasPersistedChat:x,getFileIds:v,clearFiles:M}){let J=g?Pt():void 0,X=g?_t():void 0;return{sendMessage:or(async(Y,xe,O)=>{sr(),re("=== sendMessage called ===",{text:Y,localTools:g,clientToolsCount:J?.length});let T=xe||t?.accessToken,S=O||t?.workspaceId;if(!T||!S)try{let _=await Ve();T=_.accessToken,S=_.workspaceId,$(_)}catch(_){if(_ instanceof Qe){if(_.code==="not-logged-in"){I({status:"not-logged-in"});return}if(_.code==="no-workspace"){I({status:"no-workspace"});return}}let ue=_ instanceof Error?_.message:"Authentication failed";I({status:"error",message:ue});return}else try{let _=await xn();_!==T&&(T=_,$({accessToken:_,workspaceId:S}))}catch(_){if(_ instanceof Qe&&_.code==="not-logged-in"){I({status:"not-logged-in"});return}let ue=_ instanceof Error?_.message:"Authentication failed";I({status:"error",message:ue});return}D(_=>[..._,{role:"user",content:Y}]),I({status:"sending"}),P("");let R=null,G=null;try{let _=new be,ue=v?.()??[],N={id:e,message:{id:rr(),createdAt:new Date,role:"user",parts:[{type:"text",text:Y}]}};ue.length>0&&(N.fileIds=ue),n?N.agentId=n:(s&&(N.model=s),N.connectorIds=i??[],N.enableSandbox=l,N.enableWebSearch=f,N.enableImageGeneration=m,N.enableChart=b),J&&(N.clientTools=J),X&&(N.clientToolSystemPrompt=X);let c=await _.chat(T,S,N);if(!c.ok){let j=await c.text();throw new Error(`API error ${c.status}: ${j}`)}if(!c.body)throw new Error("No response body from server");R=c.body.getReader();let ne=new TextDecoder,de="",V="",k="",ye="",B="",te="",$e="",W=new Bt,H=[],L=[],fe=[],pe=()=>{let j=W.hasExecuting();j&&!G?G=setInterval(()=>{if(!W.hasExecuting()){G&&(clearInterval(G),G=null);return}P(V+W.buildToolDisplay())},1e3):!j&&G&&(clearInterval(G),G=null)};for(;;){let{done:j,value:Z}=await R.read();if(j)break;de+=ne.decode(Z,{stream:!0});let F=de.split(`
|
|
83
|
+
`);de=F.pop()||"";for(let h of F)if(h.trim()!=="data: [DONE]"&&h.startsWith("data: "))try{let a=JSON.parse(h.slice(6));switch(re(`SSE event received: ${a.type}`,a),a.type){case"reasoning-start":ye=a.id||"0",k="";break;case"reasoning-delta":a.delta&&(k+=a.delta,P(`${Ee}[Thinking...]${ee}
|
|
84
|
+
${k}`)),a.providerMetadata?.anthropic?.signature&&(B=a.providerMetadata.anthropic.signature);break;case"reasoning-end":if(k){let y={type:"reasoning",id:ye,text:k,state:"done"};B&&(y.providerMetadata={anthropic:{signature:B}}),L.push(y),re("Added reasoning to messageParts",{reasoningLength:k.length,hasSignature:!!B,messagePartsCount:L.length})}k="",B="",P("");break;case"text-delta":a.delta&&(W.hasPending()&&(V=W.flushPending(V)),V+=a.delta,te+=a.delta,P(V));break;case"tool-input-start":{let y=W.handleToolInputStart(a);y&&P(V+y),pe();break}case"tool-input-delta":{let y=W.handleToolInputDelta(a);y&&P(V+y),pe();break}case"tool-call":case"tool-input-available":{if(re(`=== Tool event: ${a.type} ===`,{toolCallId:a.toolCallId,toolName:a.toolName,localTools:g,isClientToolResult:a.toolName?je(a.toolName):"no toolName",args:a.args,input:a.input}),a.toolCallId&&a.toolName){let y=Wt(a.args??a.input);L.push({type:a.type,toolCallId:a.toolCallId,toolName:a.toolName,args:y}),re("Added tool to messageParts",{messagePartsCount:L.length})}if(g&&a.toolCallId&&a.toolName&&je(a.toolName)){let y=Wt(a.args??a.input);H.push({toolCallId:a.toolCallId,toolName:a.toolName,args:y}),re("Added to pendingClientTools",{pendingCount:H.length,pendingClientTools:H}),P(V+W.buildToolDisplay()+`
|
|
85
|
+
[Executing ${a.toolName} locally...]`)}else re("NOT added to pendingClientTools - conditions not met",{localTools:g,hasToolCallId:!!a.toolCallId,hasToolName:!!a.toolName,isClientTool:a.toolName?je(a.toolName):!1});break}case"tool-output-start":{let y=W.handleToolOutputStart(a);y&&P(V+y),pe();break}case"tool-output-delta":{let y=W.handleToolOutputDelta(a);y&&P(V+y),pe();break}case"tool-output-end":{let y=W.handleToolOutputEnd(a,V);y&&(V=y.fullResponse,P(V+y.toolDisplay)),pe();break}case"tool-input-error":case"tool-output-error":{let y=W.handleToolError(a,V);y&&(V=y.fullResponse,P(V+y.toolDisplay)),pe();break}case"start":a.messageId&&($e=a.messageId,re("Captured messageId from start event",{messageId:$e}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":a.errorText&&console.error("Stream error:",a.errorText);break}}catch{}}if(te){let j=L.findIndex(F=>F.type!=="reasoning"),Z=j===-1?L.length:j;L.splice(Z,0,{type:"text",text:te}),re("Added accumulated text to messageParts",{textLength:te.length,insertIndex:Z})}for(re("=== Initial stream ended ===",{pendingClientToolsCount:H.length,pendingClientTools:H,messagePartsCount:L.length,messageParts:L.map(j=>({type:j.type,toolCallId:j.toolCallId,toolName:j.toolName}))});H.length>0;){re("=== Starting pending tools execution loop ===",{pendingCount:H.length});let j=[];for(let h of H){re(`Executing tool: ${h.toolName}`,{toolCallId:h.toolCallId,args:h.args}),W.handleToolInputStart({toolCallId:h.toolCallId,toolName:h.toolName}),W.handleToolInputDelta({toolCallId:h.toolCallId,inputTextDelta:JSON.stringify(h.args)}),P(V+W.buildToolDisplay()),pe();let a=await Et(h.toolName,h.args);re(`Tool execution result: ${h.toolName}`,{success:a.success,resultPreview:a.success?JSON.stringify(a.result).slice(0,200):a.error});let y=a.success?JSON.stringify(a.result):a.error||"Unknown error";if(j.push({toolCallId:h.toolCallId,toolName:h.toolName,content:[{type:"text",text:y}],isError:!a.success}),a.success){W.handleToolOutputStart({toolCallId:h.toolCallId}),W.handleToolOutputDelta({toolCallId:h.toolCallId,outputTextDelta:JSON.stringify(a.result).slice(0,200)});let Q=W.handleToolOutputEnd({toolCallId:h.toolCallId},V);Q&&(V=Q.fullResponse)}else{let Q=W.handleToolError({toolCallId:h.toolCallId,errorText:a.error},V);Q&&(V=Q.fullResponse)}P(V+W.buildToolDisplay()),pe()}H.length=0;for(let h of j){let a=L.find(y=>(y.type==="tool-input-available"||y.type==="tool-call")&&y.toolCallId===h.toolCallId);if(a){let y=[];for(let A of h.content)A.type==="text"?y.push(A.text):A.type==="image"?y.push("[Image]"):A.type==="audio"?y.push("[Audio]"):(A.type==="resource"||A.type==="resource_link")&&y.push("[Resource]");let Q=y.join(`
|
|
86
|
+
`);fe.push({type:`tool-${a.toolName}`,toolName:a.toolName,toolCallId:a.toolCallId,input:a.args,output:Q,isError:h.isError})}}if(re("=== Sending clientToolResults for continuation ===",{toolResultsCount:j.length,toolResults:j.map(h=>({toolCallId:h.toolCallId,toolName:h.toolName,isError:h.isError}))}),R)try{R.releaseLock()}catch{}let Z={id:e,clientToolResults:j};n?Z.agentId=n:(s&&(Z.model=s),Z.connectorIds=i??[],Z.enableSandbox=l,Z.enableWebSearch=f,Z.enableImageGeneration=m,Z.enableChart=b),J&&(Z.clientTools=J),X&&(Z.clientToolSystemPrompt=X),re("=== Sending continuation request ===",{chatId:e,hasAgentId:!!Z.agentId,hasModel:!!Z.model,clientToolResultsCount:j.length});let F=await _.chat(T,S,Z);if(re("=== Continuation response received ===",{ok:F.ok,status:F.status}),!F.ok){let h=await F.text();throw new Error(`Continuation failed: ${F.status}: ${h}`)}if(!F.body)break;for(re("=== Processing continuation stream ==="),R=F.body.getReader(),L.length=0,te="",k="",ye="",B="";;){let{done:h,value:a}=await R.read();if(h){re("=== Continuation stream done ===");break}de+=ne.decode(a,{stream:!0});let y=de.split(`
|
|
87
|
+
`);de=y.pop()||"";for(let Q of y)if(Q.trim()!=="data: [DONE]"&&Q.startsWith("data: "))try{let A=JSON.parse(Q.slice(6));switch(re(`Continuation SSE: ${A.type}`,A),A.type){case"reasoning-start":ye=A.id||"0",k="";break;case"reasoning-delta":A.delta&&(k+=A.delta,P(`${Ee}[Thinking...]${ee}
|
|
88
|
+
${k}`)),A.providerMetadata?.anthropic?.signature&&(B=A.providerMetadata.anthropic.signature);break;case"reasoning-end":if(k){let he={type:"reasoning",id:ye,text:k,state:"done"};B&&(he.providerMetadata={anthropic:{signature:B}}),L.push(he),re("Continuation: Added reasoning to messageParts",{reasoningLength:k.length,hasSignature:!!B,messagePartsCount:L.length})}k="",B="",P(V);break;case"text-delta":A.delta&&(V+=A.delta,te+=A.delta,P(V));break;case"tool-call":case"tool-input-available":if(A.toolCallId&&A.toolName){let he=Wt(A.args??A.input);L.push({type:A.type,toolCallId:A.toolCallId,toolName:A.toolName,args:he})}if(g&&A.toolCallId&&A.toolName&&je(A.toolName)){let he=Wt(A.args??A.input);H.push({toolCallId:A.toolCallId,toolName:A.toolName,args:he}),re("Continuation: Added to pendingClientTools",{pendingCount:H.length})}break;case"finish":re("Continuation finish event",A);break}}catch{}}if(te){let h=L.findIndex(y=>y.type!=="reasoning"),a=h===-1?L.length:h;L.splice(a,0,{type:"text",text:te})}re("=== Continuation stream processing complete ===",{pendingClientToolsCount:H.length,messagePartsCount:L.length,fullResponseLength:V.length})}if(g&&J&&J.length>0){let j=[];for(let F of fe)j.push({type:String(F.type),title:String(F.toolName).replace(/__/g," "),input:F.input,output:F.output,state:F.isError?"error":"output-available"});for(let F of L)F.type==="text"&&F.text&&j.push({type:"text",text:F.text});let Z=et(j,U);re("=== Using formatted parts for local tools ===",{executedToolsCount:fe.length,textPartsCount:L.filter(F=>F.type==="text").length,contentLength:Z.length}),D(F=>[...F,{role:"assistant",content:Z,parts:j}])}else{re("=== Fetching message from API ===",{fullResponseLength:V.length,fullResponsePreview:V.slice(0,200)});try{let{messages:j}=await _.getMessages(T,S,e,10);re("=== API messages received ===",{count:j.length,roles:j.map(F=>F.role)});let Z=j.find(F=>F.role==="assistant");if(Z){let F=Z.parts,h=et(F,U);re("=== Setting message from API ===",{partsCount:F.length,partTypes:F.map(a=>a.type),contentLength:h.length,contentPreview:h.slice(0,200)}),D(a=>[...a,{role:"assistant",content:h,parts:F}])}else re("=== No assistant message found, using fallback ==="),D(F=>[...F,{role:"assistant",content:V}])}catch(j){re("=== API fetch failed, using fallback ===",{error:j instanceof Error?j.message:String(j)}),D(Z=>[...Z,{role:"assistant",content:V}])}}re("=== Message handling complete ==="),P(""),I({status:"ready"}),x(!0),ue.length>0&&M?.()}catch(_){re("=== ERROR ===",{message:_ instanceof Error?_.message:String(_),stack:_ instanceof Error?_.stack:void 0});let ue=_ instanceof Error?_.message:"Failed to send message";I({status:"error",message:ue})}finally{if(G&&(clearInterval(G),G=null),R)try{R.releaseLock()}catch{}}},[t,e,n,s,i,l,f,m,b,g,J,X,U,D,I,P,$,x,v,M])}}import{useState as wt}from"react";var to={sandbox:{id:"sandbox",apiKey:"sandbox",name:"Sandbox",description:"Code execution",type:"server"},webSearch:{id:"webSearch",apiKey:"web_search",name:"Web Search",description:"Search the web",type:"server"},imageGeneration:{id:"imageGeneration",apiKey:"image_generation",name:"Image Generation",description:"Generate images",type:"server"},chart:{id:"chart",apiKey:"chart",name:"Chart",description:"Create charts",type:"server"},fileSystem:{id:"fileSystem",apiKey:"file_system",name:"FileSystem",description:"Local file operations",type:"client"}},no=new Map(Object.values(to).map(e=>[e.apiKey,e.name]));function oo(){return Object.values(to)}function ro(e,t,n,s,i){let[l,f]=wt(e),[m,b]=wt(t),[g,U]=wt(n),[D,I]=wt(s),[P,$]=wt(i);return{sandbox:l,setSandbox:f,webSearch:m,setWebSearch:b,imageGeneration:g,setImageGeneration:U,chart:D,setChart:I,fileSystem:P,setFileSystem:$,capabilityLabelMap:no}}import{useEffect as ir,useState as ar}from"react";function so(e,t){let[n,s]=ar(null);return ir(()=>{let i=!1;async function l(){if(!e||!t){s(null);return}try{let m=await new be().getAgent(t.accessToken,t.workspaceId,e);i||s(m)}catch{i||s(null)}}return l(),()=>{i=!0}},[e,t]),{currentAgentDetails:n}}import{useState as dn}from"react";function io(e,t,n){let[s,i]=dn(e),[l,f]=dn(t),[m,b]=dn(n);return{currentModel:s,setCurrentModel:i,currentAgentId:l,setCurrentAgentId:f,activeConnectorIds:m,setActiveConnectorIds:b}}import{useApp as cr,useInput as ur}from"ink";import{useCallback as Me,useRef as dr,useState as Ie}from"react";import{spawn as lr}from"child_process";function ao(e){return new Promise((t,n)=>{let s,i;process.platform==="darwin"?(s="open",i=[e]):process.platform==="win32"?(s="cmd",i=["/c","start","",e]):(s="xdg-open",i=[e]);let l=lr(s,i,{stdio:"ignore",detached:!0});l.once("error",f=>{n(f)}),l.once("spawn",()=>{l.unref(),t()})})}var lo=[{name:"help",aliases:["h","?"],description:"Show available commands"},{name:"clear",aliases:["cls","new"],description:"Start a new chat"},{name:"model",aliases:["m"],description:"Show/switch model",hasArgs:!0},{name:"agent",aliases:["a"],description:"Show/switch agent",hasArgs:!0},{name:"skills",aliases:["sk"],description:"List skills",hasArgs:!0},{name:"schedules",aliases:["sch"],description:"List schedules",hasArgs:!0},{name:"connectors",aliases:["conn"],description:"Select connectors"},{name:"capabilities",aliases:["cap"],description:"Select capabilities"},{name:"chats",aliases:["c"],description:"Switch to another chat"},{name:"workspace",aliases:["ws"],description:"List/switch workspace",hasArgs:!0},{name:"budget",aliases:["bg"],description:"View/set workspace budget",hasArgs:!0},{name:"usage",aliases:["u"],description:"View current month usage"},{name:"status",aliases:["s"],description:"Show session status"},{name:"profile",aliases:["p"],description:"Manage profiles",hasArgs:!0},{name:"open-in-browser",aliases:[],description:"Open current chat in browser"},{name:"share",aliases:[],description:"Get share link for current chat"},{name:"delete",aliases:["del"],description:"Delete current chat"},{name:"quit",aliases:["exit","q"],description:"Exit chat"}];function co(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?lo.filter(n=>n.name.startsWith(t)||n.aliases.some(s=>s.startsWith(t))):lo}function uo(e){let t=e.trim();if(!t.startsWith("/"))return null;let n=t.slice(1).split(/\s+/),s=n[0]?.toLowerCase(),i=n.slice(1).join(" ");switch(s){case"help":case"h":case"?":return{type:"help"};case"clear":case"cls":case"new":return{type:"clear"};case"model":case"m":return{type:"model",value:i||void 0};case"agent":case"a":return{type:"agent",value:i||void 0};case"skills":case"sk":return{type:"skills",value:i||void 0};case"schedules":case"sch":return{type:"schedules",value:i||void 0};case"connectors":case"conn":return{type:"connectors"};case"capabilities":case"cap":return{type:"capabilities"};case"chats":case"c":return{type:"chats"};case"workspace":case"ws":return{type:"workspace",value:i||void 0};case"budget":case"bg":return{type:"budget",value:i||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:i||void 0};case"open-in-browser":return{type:"open-in-browser"};case"share":return{type:"share"};case"delete":case"del":return{type:"delete"};case"quit":case"exit":case"q":return{type:"quit"};default:return{type:"unknown",input:t}}}var fo=`Available commands:
|
|
89
|
+
/help, /h, /? Show this help message
|
|
90
|
+
/clear, /cls, /new Start a new chat
|
|
91
|
+
/model [name], /m Show current model or switch to [name]
|
|
92
|
+
/agent [name], /a Show current agent or switch to [name]
|
|
93
|
+
/skills [name], /sk List skills or show details for [name]
|
|
94
|
+
/schedules [id], /sch List schedules or show details for [id]
|
|
95
|
+
/connectors, /conn Select active connectors
|
|
96
|
+
/capabilities, /cap Select capabilities (sandbox, web, etc.)
|
|
97
|
+
/chats, /c Switch to another chat
|
|
98
|
+
/workspace [id], /ws List or switch workspace
|
|
99
|
+
/budget [amount], /bg View or set workspace budget
|
|
100
|
+
/usage, /u View current month usage (top 10 by cost)
|
|
101
|
+
/status, /s Show current session status
|
|
102
|
+
/profile [args], /p Manage profiles (list/show/use/create/delete/rename/clone)
|
|
103
|
+
/open-in-browser Open current chat in browser
|
|
104
|
+
/share Get share link for current chat
|
|
105
|
+
/delete, /del Delete current chat
|
|
106
|
+
/quit, /exit, /q Exit interactive mode
|
|
107
|
+
|
|
108
|
+
Note: For detailed usage with sorting/limits, use: entrydesk usage --help
|
|
109
|
+
|
|
110
|
+
Keyboard shortcuts:
|
|
111
|
+
Ctrl+O Toggle full output mode
|
|
112
|
+
Ctrl+C Exit`;function fn(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} min`;case"hours":return`Every ${t.every} hr`;case"days":return`Every ${t.every} day at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${t.every} week`;case"months":return`Every ${t.every} month`;default:return"Unknown"}}function po({input:e,setInput:t,chatId:n,setChatId:s,currentChatTitle:i,setCurrentChatTitle:l,currentModel:f,setCurrentModel:m,currentAgentId:b,setCurrentAgentId:g,currentAgentDetails:U,setCurrentAgentDetails:D,activeConnectorIds:I,setActiveConnectorIds:P,sandbox:$,setSandbox:x,webSearch:v,setWebSearch:M,imageGeneration:J,setImageGeneration:X,chart:oe,setChart:Y,fileSystem:xe,setFileSystem:O,availableModels:T,availableAgents:S,availableConnectors:R,messages:G,hasPersistedChat:_,setHasPersistedChat:ue,setMessages:N,addSystemMessage:c,startNewChat:ne,sendMessage:de,setFullOutput:V,credentials:k,setCredentials:ye,setState:B,defaultCapabilities:te,capabilityLabelMap:$e,hasUploadingFiles:W=!1}){let{exit:H}=cr(),[L,fe]=Ie([]),[pe,j]=Ie(0),[Z,F]=Ie(!1),[h,a]=Ie(null),[y,Q]=Ie([]),[A,he]=Ie(0),[Ge,qe]=Ie(new Set),[ve,Ke]=Ie(new Set),[Kt,Tt]=Ie([]),[Ne,tt]=Ie([]),[Fe,$t]=Ie([]),[He,Ht]=Ie([]),[De,Oe]=Ie(null),[kt,nt]=Ie(""),Xe=dr(!1),[Je,ot]=Ie(!1),rt=Me(async()=>{if(!k)return[];let w=new be,d=[],o;do{let r=await w.listAvailableSkills(k.accessToken,k.workspaceId,{limit:100,nextKey:o});d.push(...r.skills),o=r.nextKey}while(o);return tt(d),d},[k]),st=Me(async()=>{if(!k)return[];let w=new be,d=[],o;do{let r=await w.getSchedules(k.accessToken,k.workspaceId,{limit:100,nextKey:o});d.push(...r.schedules),o=r.nextKey}while(o);return $t(d),d},[k]),ke=Me(async w=>{if(w==="model"){if(T.length===0){c("No models available.");return}let d=T.map(r=>({id:r.id,name:r.name,description:r.description}));Q(d);let o=f?d.findIndex(r=>r.id===f):-1;he(Math.max(o,0)),a("model")}else if(w==="agent"){if(S.length===0){c("No agents available.");return}let d=S.map(r=>({id:r.id,name:r.name,description:r.description}));Q(d);let o=b?d.findIndex(r=>r.id===b):-1;he(Math.max(o,0)),a("agent")}else if(w==="skills"){let d=Ne;if(d.length===0)try{d=await rt()}catch{c("Failed to load skills.");return}if(d.length===0){c("No skills available.");return}let o=d.map(r=>({id:r.id,name:r.name,description:r.description}));Q(o),he(0),a("skills")}else if(w==="schedules"){let d=Fe;if(d.length===0)try{d=await st()}catch{c("Failed to load schedules.");return}if(d.length===0){c("No schedules found.");return}let o=d.map(r=>({id:r.id,name:r.name,description:`${r.agent.name} - ${r.isActive?"Active":"Paused"}`}));Q(o),he(0),a("schedules")}else if(w==="connectors"){if(R.length===0){c("No connectors available.");return}let d=R.map(o=>({id:o.id,name:o.name}));Q(d),he(0),qe(new Set(I??[])),a("connectors")}else if(w==="capabilities"){let d=oo().map(r=>({id:r.id,name:r.name,description:r.description}));Q(d),he(0);let o=new Set;$&&o.add("sandbox"),v&&o.add("webSearch"),J&&o.add("imageGeneration"),oe&&o.add("chart"),xe&&o.add("fileSystem"),Ke(o),a("capabilities")}else if(w==="chats"){if(!k){c("Not authenticated.");return}try{let d=new be,{chats:o}=await d.getChats(k.accessToken,k.workspaceId,20);if(o.length===0){c("No chats available.");return}Tt(o);let r=o.map(C=>({id:C.id,name:C.title||"Untitled",description:new Date(C.createdAt).toLocaleDateString()}));Q(r);let u=r.findIndex(C=>C.id===n);he(Math.max(u,0)),a("chats")}catch{c("Failed to load chats.")}}else if(w==="profile"){let d=ce.getProfileNames(),o=ce.getCurrentProfileName(),r=d.map(C=>({id:C,name:C,description:C===o?"(current)":void 0}));Q(r);let u=r.findIndex(C=>C.id===o);he(Math.max(u,0)),a("profile")}F(!1),fe([])},[T,S,Ne,Fe,R,I,f,b,rt,st,$,v,J,oe,xe,k,n,c]),le=Me(w=>{let d=ge.getAll(w);m(d.model?.default),g(void 0),D(null);let o=d.connectors?.defaults;P(o&&o.length>0?o:void 0);let r=d.capabilities;x(r?.sandbox??te.sandbox),M(r?.webSearch??te.webSearch),X(r?.imageGeneration??te.imageGeneration),Y(r?.chart??te.chart);let u=d.localTools;O(u?.fileSystem??te.fileSystem)},[m,g,D,P,x,M,X,Y,O,te]),Be=Me(async()=>{try{let w=await Ve();ye({accessToken:w.accessToken,workspaceId:w.workspaceId}),B({status:"ready"})}catch(w){if(ye(null),w instanceof Qe){if(w.code==="not-logged-in"){B({status:"not-logged-in"});return}if(w.code==="no-workspace"){B({status:"no-workspace"});return}}let d=w instanceof Error?w.message:"Failed to authenticate";B({status:"error",message:d})}},[ye,B]),it=Me(async w=>{switch(w.type){case"help":return c(fo),!0;case"clear":return ne("Started a new chat."),!0;case"model":{if(w.value){let d=w.value.toLowerCase(),o=T.find(r=>r.id.toLowerCase()===d||r.name.toLowerCase().includes(d));if(o)b?ne(`Switched to model: ${o.name} (new chat)`):c(`Switched to model: ${o.name}`),m(o.id),g(void 0),D(null),ge.setDefaultModel(o.id);else{let r=T.map(u=>u.name).join(", ");c(`Model "${w.value}" not found.
|
|
113
|
+
Available: ${r||"none"}`)}}else{let d=T.find(o=>o.id===f)?.name||f;c(f?`Current model: ${d}`:"No model selected. Using agent mode.")}return!0}case"agent":{if(!w.value)return S.length===0?(c("No agents available."),!0):(ke("agent"),!0);let d=w.value.toLowerCase(),o=S.find(r=>r.id.toLowerCase()===d||r.name.toLowerCase().includes(d));if(o)o.id!==b?ne(`Switched to agent: ${o.name} (new chat)`):c(`Switched to agent: ${o.name}`),g(o.id),m(void 0);else{let r=S.map(u=>u.name).join(", ");c(`Agent "${w.value}" not found.
|
|
114
|
+
Available: ${r||"none"}`)}return!0}case"skills":{if(!w.value)return ke("skills"),!0;let d=w.value.toLowerCase();return(Ne.length>0?Promise.resolve(Ne):rt().catch(()=>[])).then(r=>{let u=r.find(C=>C.id.toLowerCase()===d||C.name.toLowerCase().includes(d));c(u?`Skill: ${u.name}
|
|
115
|
+
${u.description}
|
|
116
|
+
Provider: ${u.provider}
|
|
117
|
+
Author: ${u.author.name}
|
|
118
|
+
ID: ${u.id}`:`Skill "${w.value}" not found.`)}),!0}case"schedules":{if(!w.value)return ke("schedules"),!0;let d=w.value.toLowerCase();return(Fe.length>0?Promise.resolve(Fe):st().catch(()=>[])).then(r=>{let u=r.find(C=>C.id.toLowerCase()===d||C.name.toLowerCase().includes(d));if(u){let C=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";c(`Schedule: ${u.name}
|
|
119
|
+
Agent: ${u.agent.name}
|
|
120
|
+
Status: ${u.isActive?"Active":"Paused"}
|
|
121
|
+
Repeat: ${fn(u.config)}
|
|
122
|
+
Next Run: ${C}
|
|
123
|
+
ID: ${u.id}`)}else c(`Schedule "${w.value}" not found.`)}),!0}case"connectors":{if(b){let o=U?.connectors??[];if(o.length===0)c("No agent connectors.");else{let r=o.map(u=>` - ${u.name}`).join(`
|
|
124
|
+
`);c(`Agent connectors:
|
|
125
|
+
${r}`)}return!0}let d=R.filter(o=>I?.includes(o.id));if(d.length===0)c("No active connectors.");else{let o=d.map(r=>` - ${r.name}`).join(`
|
|
126
|
+
`);c(`Active connectors:
|
|
127
|
+
${o}`)}return!0}case"capabilities":{if(b){let r=(U?.capabilities??[]).map(u=>$e.get(u)??u);return c(r.length>0?`Agent capabilities:
|
|
128
|
+
${r.map(u=>` - ${u}`).join(`
|
|
129
|
+
`)}`:"No agent capabilities."),!0}let d=[];return $&&d.push("Sandbox"),v&&d.push("Web Search"),J&&d.push("Image Generation"),oe&&d.push("Chart"),xe&&d.push("FileSystem"),c(d.length>0?`Active capabilities:
|
|
130
|
+
${d.map(o=>` - ${o}`).join(`
|
|
131
|
+
`)}`:"No capabilities enabled."),!0}case"chats":return c(i?`Current chat: ${i}`:`Current chat: ${n.slice(0,8)}...`),!0;case"workspace":{if(!k)return c("Not authenticated."),!0;let d=new be;if(!w.value){try{let{workspaces:r}=await d.getWorkspaces(k.accessToken);if(r.length===0)c("No workspaces found.");else{let u=r.map(C=>` ${C.id===k.workspaceId?"* ":" "}${C.name}
|
|
132
|
+
ID: ${C.id}`);c(`Workspaces:
|
|
133
|
+
${u.join(`
|
|
134
|
+
`)}`)}}catch(r){c(`Failed to load workspaces: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}let o=w.value;try{let{workspaces:r}=await d.getWorkspaces(k.accessToken),u=r.find(C=>C.id===o);if(!u)return c(`Workspace not found: ${o}`),!0;await ft.saveWorkspaceId(o),c(`Switched to workspace: ${u.name}`),c("Please restart the chat to apply changes.")}catch(r){c(`Failed to switch workspace: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}case"budget":{if(!k)return c("Not authenticated."),!0;let d=new be;if(!w.value){try{let u=await d.getBudget(k.accessToken,k.workspaceId);u.budget===null?c("No budget set for this workspace."):c(`Current budget: $${u.budget}`)}catch(u){c(`Failed to get budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let o=w.value.toLowerCase();if(o==="clear"||o==="null"){try{await d.updateBudget(k.accessToken,k.workspaceId,null),c("Budget cleared.")}catch(u){c(`Failed to clear budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let r=parseFloat(o);if(isNaN(r)||r<0)return c("Invalid budget amount. Must be a positive number."),!0;try{await d.updateBudget(k.accessToken,k.workspaceId,o),c(`Budget set to: $${o}`)}catch(u){c(`Failed to set budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}case"usage":{if(!k)return c("Not authenticated."),!0;let d=new be;try{let o=[],r,u=0,C=10;do{let we=await d.getMonthlyUsages(k.accessToken,k.workspaceId,{nextKey:r,limit:20});if(o.push(...we.monthlyUsages),r=we.nextKey,u++,u>=C){c(`Warning: Showing first ${o.length} entries (pagination limit reached)`);break}}while(r);if(o.length===0)return c("No usage data found for this workspace."),!0;let p=0,E=0;for(let we of o)p+=parseFloat(we.totalCost),E+=we.operationCount;let ae=[...o].toSorted((we,Ye)=>parseFloat(Ye.totalCost)-parseFloat(we.totalCost)),q=10,se=ae.slice(0,q),Pe=[`Total Cost: $${p.toFixed(2)}`,`Total Operations: ${E.toLocaleString()}`,`Users: ${o.length}`,"",`Top ${se.length} Users by Cost:`,...se.map(we=>` ${we.user.name}: $${parseFloat(we.totalCost).toFixed(2)} (${we.operationCount.toLocaleString()} ops)`)];o.length>q&&(Pe.push("",`... and ${o.length-q} more users`),Pe.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),c(Pe.join(`
|
|
135
|
+
`))}catch(o){c(`Failed to get usage: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"status":{let d=ce.getCurrentProfileName(),o=f?T.find(p=>p.id===f)?.name||f:null,r=b?S.find(p=>p.id===b)?.name||b:null,u=I?R.filter(p=>I.includes(p.id)).map(p=>p.name):[],C=[];return $&&C.push("Sandbox"),v&&C.push("Web Search"),J&&C.push("Image Gen"),oe&&C.push("Chart"),xe&&C.push("FileSystem"),ft.getEmail().then(p=>{let E=[`Profile: ${d}${d!=="default"?" (non-default)":""}`,p?`Logged in as: ${p}`:"Not logged in",k?.workspaceId?`Workspace: ${k.workspaceId}`:null,_?`Chat ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${C.length>0?C.join(", "):"none"}`].filter(Boolean);c(E.join(`
|
|
136
|
+
`))}).catch(()=>{let p=[`Profile: ${d}`,"Not logged in",_?`Chat ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${C.length>0?C.join(", "):"none"}`].filter(Boolean);c(p.join(`
|
|
137
|
+
`))}),!0}case"profile":{let d=w.value?w.value.split(/\s+/).filter(Boolean):[];if(d.length===0)return ke("profile"),!0;let o=d[0]?.toLowerCase()||"list",r=d[1],u=d[2],C=ce.getProfileNames(),p=ce.getCurrentProfileName(),E=ce.getOverrideProfile(),ae=(q,se=!1)=>{if(q)return q;if(se&&C.length===1)return C[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(o==="list"){let q=[`Profiles (${C.length}):`];for(let se of C){let Pe=se===p?" (current)":"";q.push(` ${se}${Pe}`)}return c(q.join(`
|
|
138
|
+
`)),!0}if(o==="current")return c(`Current profile: ${p}`),!0;if(o==="show"){let q=ae(r,!0),se=ge.getAll(q),Pe=await ft.getAll(q),we=!!Pe?.accessToken,Ye=se.capabilities?Object.entries(se.capabilities).filter(([,Jt])=>Jt).map(([Jt])=>Jt):[],To=se.connectors?.defaults&&se.connectors.defaults.length>0?se.connectors.defaults.join(", "):"unset",$o=[`Profile: ${q}${q===p?" (current)":""}`,`API URL: ${se.apiUrl??"default"}`,`Hub URL: ${se.hubUrl??"default"}`,`Model: ${se.model?.default??"unset"}`,`Connectors: ${To}`,`Capabilities: ${Ye.length>0?Ye.join(", "):"none"}`,we?`Logged in as: ${Pe?.email??"unknown"}`:"Not logged in",we&&Pe?.workspaceId?`Workspace ID: ${Pe.workspaceId}`:null].filter(Boolean);return c($o.join(`
|
|
139
|
+
`)),!0}if(o==="create"){let q=r||ce.DEFAULT_PROFILE;return ce.createProfile(q),c(`Profile created: ${q}`),!0}if(o==="use"||o==="switch"){let q=ae(r,!0);return ce.setOverrideProfile(q),ce.setCurrentProfile(q),le(q),await Be(),ne(`Switched to profile: ${q} (new chat)`),!0}if(o==="delete"||o==="remove"||o==="rm"){let q=ae(r,!0),se=q===p,Pe=ce.deleteProfile(q),we=`Profile deleted: ${q}`;if(se)ce.setOverrideProfile(Pe.currentProfile),le(Pe.currentProfile),await Be(),ne(`${we}
|
|
140
|
+
Switched to profile: ${Pe.currentProfile} (new chat)`);else if(E===q){let Ye=ce.getCurrentProfileName();ce.setOverrideProfile(Ye),le(Ye),await Be(),ne(`${we}
|
|
141
|
+
Switched to profile: ${Ye} (new chat)`)}else c(we);return!0}if(o==="rename"||o==="move"||o==="mv"){let q=ae(r,!0);if(!u)throw new Error("New profile name is required.");let se=ce.renameProfile(q,u);return c(`Profile renamed: ${q} -> ${u}`),E===q?(ce.setOverrideProfile(u),le(u)):se.currentProfile===u&&le(u),!0}if(o==="clone"||o==="copy"){let q=ae(r,!0);if(!u)throw new Error("Target profile name is required.");let se=ge.getAll(q);return ce.createProfile(u),ge.setAll(se,u),await ft.clear(u),c(`Profile cloned: ${q} -> ${u}`),!0}c(`Unknown profile command: ${o}`)}catch(q){let se=q instanceof Error?q.message:"Unknown error";c(`Profile error: ${se}`)}return!0}case"open-in-browser":{let d=Yt().hubUrl.replace(/\/$/,""),o=_||G.some(E=>E.role!=="system"),r=k?`/${k.workspaceId}`:"",u=o?`${r}/chat/${n}`:`${r}/chat/new`,C=b?`?agentId=${encodeURIComponent(b)}`:"",p=`${d}${u}${C}`;try{await ao(p),c(`Opened in browser: ${p}`)}catch(E){c(`Failed to open browser: ${E instanceof Error?E.message:"Unknown error"}
|
|
142
|
+
URL: ${p}`)}return!0}case"share":{if(!k)return c("Not authenticated."),!0;if(!(_||G.some(o=>o.role!=="system")))return c("No conversation to share. Start a chat first."),!0;try{let r=await new be().createChatShare(k.accessToken,k.workspaceId,n,"public"),C=`${Yt().hubUrl.replace(/\/$/,"")}/share/${r.id}`;c(`Share link: ${C}`)}catch(o){c(`Failed to create share link: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"delete":return k?_?(ot(!0),c("Delete this chat? (y/N)"),!0):(c("No chat to delete."),!0):(c("Not authenticated."),!0);case"quit":return H(),!0;case"unknown":return c(`Unknown command: ${w.input}
|
|
143
|
+
Type /help for available commands.`),!0;default:return!1}},[c,T,S,R,Ne,Fe,f,b,I,$,v,J,oe,xe,n,i,H,ke,ne,$e,U,_,G,rt,st,N,m,g,D,m,le,Be]),It=Me(w=>{if(Xe.current=!1,Je){(w===""||w.startsWith("/"))&&(t(w),w.startsWith("/")&&ot(!1));return}if(t(w),nt(w),De!==null&&Oe(null),h&&(a(null),Q([])),w.startsWith("/")&&!w.includes(" ")){let d=co(w);fe(d),j(0),F(d.length>0)}else F(!1),fe([])},[h,De,Je,t]),dt=Me((w,d=!1)=>{if(w>=0&&w<L.length){let o=L[w];F(!1),fe([]),o.name==="model"?(t("/model "),ke("model")):o.name==="agent"?(t("/agent "),ke("agent")):o.name==="skills"?(t("/skills "),ke("skills")):o.name==="schedules"?(t("/schedules "),ke("schedules")):o.name==="connectors"?(t("/connectors "),ke("connectors")):o.name==="capabilities"?(t("/capabilities "),ke("capabilities")):o.name==="chats"?(t("/chats "),ke("chats")):o.name==="profile"?(t("/profile "),ke("profile")):d?(t(""),it({type:o.name})):t(`/${o.name}`)}},[L,ke,t,it]),St=Me(async w=>{Xe.current=!1;let d=w.trim();if(!d||Je)return;if(h==="model"&&y.length>0){let r=y[A];r&&(b?ne(`Switched to model: ${r.name} (new chat)`):c(`Switched to model: ${r.name}`),m(r.id),g(void 0),D(null)),a(null),Q([]),t("");return}if(h==="agent"&&y.length>0){let r=y[A];r&&(r.id!==b?ne(`Switched to agent: ${r.name} (new chat)`):c(`Switched to agent: ${r.name}`),g(r.id),m(void 0)),a(null),Q([]),t("");return}if(h==="skills"&&y.length>0){let r=y[A];if(r){let u=Ne.find(C=>C.id===r.id);u&&c(`Skill: ${u.name}
|
|
144
|
+
${u.description}
|
|
145
|
+
Provider: ${u.provider}
|
|
146
|
+
Author: ${u.author.name}
|
|
147
|
+
ID: ${u.id}`)}a(null),Q([]),t("");return}if(h==="schedules"&&y.length>0){let r=y[A];if(r){let u=Fe.find(C=>C.id===r.id);if(u){let C=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";c(`Schedule: ${u.name}
|
|
148
|
+
Agent: ${u.agent.name}
|
|
149
|
+
Status: ${u.isActive?"Active":"Paused"}
|
|
150
|
+
Repeat: ${fn(u.config)}
|
|
151
|
+
Next Run: ${C}
|
|
152
|
+
ID: ${u.id}`)}}a(null),Q([]),t("");return}if(h==="connectors"){let r=Array.from(Ge);P(r.length>0?r:void 0),ge.setDefaultConnectorIds(r);let u=R.filter(C=>Ge.has(C.id)).map(C=>C.name);c(u.length>0?`Active connectors: ${u.join(", ")}`:"All connectors disabled."),a(null),Q([]),t("");return}if(h==="capabilities"){let r=ve.has("sandbox"),u=ve.has("webSearch"),C=ve.has("imageGeneration"),p=ve.has("chart"),E=ve.has("fileSystem");x(r),M(u),X(C),Y(p),O(E),ge.setCapabilities({sandbox:r,webSearch:u,imageGeneration:C,chart:p}),ge.setLocalTools({fileSystem:E});let ae=[];r&&ae.push("Sandbox"),u&&ae.push("Web Search"),C&&ae.push("Image Generation"),p&&ae.push("Chart"),E&&ae.push("FileSystem"),c(ae.length>0?`Active capabilities: ${ae.join(", ")}`:"All capabilities disabled."),a(null),Q([]),t("");return}if(h==="profile"&&y.length>0){let r=y[A];if(r){let u=ce.getCurrentProfileName();r.id!==u?(ce.setOverrideProfile(r.id),ce.setCurrentProfile(r.id),le(r.id),Be(),ne(`Switched to profile: ${r.name}`)):c(`Already using profile: ${r.name}`)}a(null),Q([]),t("");return}if(Z&&L.length>0){dt(pe,!0);return}Oe(null),nt(""),Ht(r=>r.length>0&&r.at(-1)===d?r:[...r,d]);let o=uo(d);if(o){await it(o),t(""),F(!1);return}if(W){c("Please wait for file uploads to complete.");return}t(""),F(!1),de(d)},[de,it,Z,L,pe,dt,h,y,A,Ge,ve,R,Ne,Fe,c,t,b,ne,m,g,D,P,x,M,X,Y,O,W,le,Be,Je,k,_,n]);return ur((w,d)=>{if(d.ctrl&&w==="c"){if(e.length>0){It(""),Xe.current=!0,c("Press Ctrl+C again to exit.");return}if(Xe.current){H();return}H();return}if(d.ctrl&&w==="o"){V(o=>!o);return}if(Je){if(d.escape||d.return||w==="n"||w==="N"){ot(!1),t(""),c("Chat deletion cancelled.");return}if(w==="y"||w==="Y"){ot(!1),t(""),k&&_&&new be().deleteChat(k.accessToken,k.workspaceId,n).then(()=>{ne("Chat deleted. Started a new chat.")}).catch(r=>{c(`Failed to delete chat: ${r.message||"Unknown error"}`)});return}return}if(h&&y.length>0){if(d.upArrow){he(o=>o<=0?y.length-1:o-1);return}if(d.downArrow){he(o=>o>=y.length-1?0:o+1);return}if(d.escape){a(null),Q([]),t("");return}if(d.return){if(h==="model"){let o=y[A];o&&(b?ne(`Switched to model: ${o.name} (new chat)`):c(`Switched to model: ${o.name}`),m(o.id),g(void 0),D(null),ge.setDefaultModel(o.id))}else if(h==="agent"){let o=y[A];o&&(o.id!==b?ne(`Switched to agent: ${o.name} (new chat)`):c(`Switched to agent: ${o.name}`),g(o.id),m(void 0))}else if(h==="skills"){let o=y[A];if(o){let r=Ne.find(u=>u.id===o.id);r&&c(`Skill: ${r.name}
|
|
153
|
+
${r.description}
|
|
154
|
+
Provider: ${r.provider}
|
|
155
|
+
Author: ${r.author.name}
|
|
156
|
+
ID: ${r.id}`)}}else if(h==="schedules"){let o=y[A];if(o){let r=Fe.find(u=>u.id===o.id);if(r){let u=r.nextRunAt?new Date(r.nextRunAt).toLocaleString():"-";c(`Schedule: ${r.name}
|
|
157
|
+
Agent: ${r.agent.name}
|
|
158
|
+
Status: ${r.isActive?"Active":"Paused"}
|
|
159
|
+
Repeat: ${fn(r.config)}
|
|
160
|
+
Next Run: ${u}
|
|
161
|
+
ID: ${r.id}`)}}}else if(h==="connectors"){let o=Array.from(Ge);P(o.length>0?o:void 0),ge.setDefaultConnectorIds(o);let r=R.filter(u=>Ge.has(u.id)).map(u=>u.name);c(r.length>0?`Active connectors: ${r.join(", ")}`:"All connectors disabled.")}else if(h==="capabilities"){let o=ve.has("sandbox"),r=ve.has("webSearch"),u=ve.has("imageGeneration"),C=ve.has("chart"),p=ve.has("fileSystem");x(o),M(r),X(u),Y(C),O(p),ge.setCapabilities({sandbox:o,webSearch:r,imageGeneration:u,chart:C}),ge.setLocalTools({fileSystem:p});let E=[];o&&E.push("Sandbox"),r&&E.push("Web Search"),u&&E.push("Image Generation"),C&&E.push("Chart"),p&&E.push("FileSystem"),c(E.length>0?`Active capabilities: ${E.join(", ")}`:"All capabilities disabled.")}else if(h==="chats"){let o=y[A];if(o){let r=Kt.find(u=>u.id===o.id);r&&k&&(s(r.id),l(r.title||void 0),ue(!0),new be().getMessages(k.accessToken,k.workspaceId,r.id,20).then(({messages:C})=>{let p=C.filter(E=>E.role==="user"||E.role==="assistant").map(E=>({role:E.role,content:et(E.parts,!1),parts:E.parts})).filter(E=>E.content).toReversed();N(p),c(`Switched to: ${r.title||"Untitled"}`)}).catch(()=>{c("Failed to load chat messages.")}))}}else if(h==="profile"){let o=y[A];if(o){let r=ce.getCurrentProfileName();o.id!==r?(ce.setOverrideProfile(o.id),ce.setCurrentProfile(o.id),le(o.id),Be(),ne(`Switched to profile: ${o.name}`)):c(`Already using profile: ${o.name}`)}}a(null),Q([]),t("");return}if(w===" "&&(h==="connectors"||h==="capabilities")){let o=y[A];o&&(h==="connectors"?qe:Ke)(u=>{let C=new Set(u);return C.has(o.id)?C.delete(o.id):C.add(o.id),C});return}if(w==="a"&&(h==="connectors"||h==="capabilities")){(h==="connectors"?qe:Ke)(new Set(y.map(r=>r.id)));return}if(w==="n"&&(h==="connectors"||h==="capabilities")){(h==="connectors"?qe:Ke)(new Set);return}return}if(Z&&L.length>0){if(d.upArrow){j(o=>o<=0?L.length-1:o-1);return}if(d.downArrow){j(o=>o>=L.length-1?0:o+1);return}if(d.escape){F(!1),fe([]);return}if(d.tab){dt(pe);return}}if(d.upArrow){if(e.includes(`
|
|
162
|
+
`)||He.length===0)return;if(De===null){nt(e);let r=He.length-1;Oe(r),t(He[r]);return}let o=Math.max(0,De-1);Oe(o),t(He[o]);return}if(d.downArrow){if(e.includes(`
|
|
163
|
+
`)||De===null)return;if(De>=He.length-1){Oe(null),t(kt);return}let o=De+1;Oe(o),t(He[o])}}),{suggestions:L,suggestionIndex:pe,showSuggestions:Z,argMode:h,argItems:y,argIndex:A,selectedConnectorIds:Ge,selectedCapabilities:ve,deleteConfirmMode:Je,handleInputChange:It,handleSubmit:St}}import{useCallback as Ct,useRef as fr,useState as pr}from"react";function mo({credentials:e,currentModel:t,modelProviders:n,onUploadSuccess:s,onUploadError:i}){let[l,f]=pr([]),m=fr(0),b=Ct(x=>{if(!(!Array.isArray(n)||n.length===0)){for(let v of n)if(v.models.some(J=>J.id===x))return v.id;return n[0]?.id}},[n]),g=Ct(async x=>{if(!e){i?.(x.filename,"Not logged in");return}if(!Array.isArray(n)||n.length===0){i?.(x.filename,"Model providers not loaded yet. Please wait and try again.");return}let v=t?b(t):n[0]?.id;if(!v){i?.(x.filename,"No model provider available");return}let M=`file-${++m.current}`;f(J=>[...J,{id:M,filename:x.filename,mimeType:x.mimeType,status:"uploading"}]);try{let X=await new be().uploadFile(e.accessToken,e.workspaceId,x,v);f(oe=>oe.map(Y=>Y.id===M?{...Y,status:"uploaded",fileId:X.id}:Y)),s?.(x.filename)}catch(J){let X=J instanceof Error?J.message:"Upload failed";f(oe=>oe.map(Y=>Y.id===M?{...Y,status:"error",error:X}:Y)),i?.(x.filename,X)}},[e,t,b,n,s,i]),U=Ct(x=>{f(v=>v.filter(M=>M.id!==x))},[]),D=Ct(()=>{f([])},[]),I=Ct(()=>l.filter(x=>x.status==="uploaded"&&x.fileId).map(x=>x.fileId),[l]),P=l.some(x=>x.status==="uploading"),$=l.length>0;return{pendingFiles:l,addFile:g,removeFile:U,clearFiles:D,getUploadedFileIds:I,hasUploadingFiles:P,hasFiles:$}}import{jsx as z,jsxs as ie}from"react/jsx-runtime";var gr=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],hr=[un,un,cn,cn,Ze,Ze,Ze,Ze],ho=gr.map((e,t)=>`${hr[t]??Ze}${e}${ee}`).join(`
|
|
164
|
+
`),xr=`${Ze}EntryDesk${ee}`,br=500;function yr(e){let t="",n=0;for(;n<e.length;){if(e.charCodeAt(n)===27&&e[n+1]==="["){for(n+=2;n<e.length;){let s=e.charCodeAt(n);if(s>=64&&s<=126){n+=1;break}n+=1}continue}t+=e[n],n+=1}return t}function wr(e){let t=yr(e);return Math.max(...t.split(`
|
|
165
|
+
`).map(n=>n.length))}function Cr(e){let t=wr(ho);return e>=t?ho:xr}function xo({agentId:e,model:t,message:n,chatId:s,chatTitle:i,connectorIds:l,enableSandbox:f=!0,enableWebSearch:m=!1,enableImageGeneration:b=!1,enableChart:g=!1,enableFileSystem:U=!0}){let D=process.stdout.columns??80,I=Cr(D),P=go(null),$=Yn(s,i),{state:x,setState:v,messages:M,setMessages:J,input:X,setInput:oe,chatId:Y,setChatId:xe,currentChatTitle:O,setCurrentChatTitle:T,hasPersistedChat:S,setHasPersistedChat:R,credentials:G,setCredentials:_,currentResponse:ue,setCurrentResponse:N,fullOutput:c,setFullOutput:ne,addSystemMessage:de,startNewChat:V}=$,{credentials:k}=zn(v);jt(()=>{k&&!G&&_(k)},[k,G,_]);let{availableConnectors:ye,availableModels:B,availableAgents:te,modelProviders:$e,loading:W}=Xn(G),{currentModel:H,setCurrentModel:L,currentAgentId:fe,setCurrentAgentId:pe,activeConnectorIds:j,setActiveConnectorIds:Z}=io(t,e,l),F=go(!1);jt(()=>{if(!F.current){if(F.current=!0,!t&&!e){let p=ge.getDefaultModel();p&&L(p)}if(!l&&!e){let p=ge.getDefaultConnectorIds();p&&Z(p.length>0?p:void 0)}}},[t,e,l,L,Z]);let{currentAgentDetails:h}=so(fe,G),{sandbox:a,setSandbox:y,webSearch:Q,setWebSearch:A,imageGeneration:he,setImageGeneration:Ge,chart:qe,setChart:ve,fileSystem:Ke,setFileSystem:Kt,capabilityLabelMap:Tt}=ro(f,m,b,g,U),{pendingFiles:Ne,addFile:tt,removeFile:Fe,clearFiles:$t,getUploadedFileIds:He,hasUploadingFiles:Ht,hasFiles:De}=mo({credentials:G,currentModel:H,modelProviders:$e,onUploadSuccess:p=>{de(`\u2713 Attached: ${p}`)},onUploadError:(p,E)=>{de(`\u2717 Failed to upload ${p}: ${E}`)}}),{sendMessage:Oe}=eo({chatId:Y,credentials:G,currentAgentId:fe,currentModel:H,activeConnectorIds:j,sandbox:a,webSearch:Q,imageGeneration:he,chart:qe,localTools:Ke,fullOutput:c,setMessages:J,setState:v,setCurrentResponse:N,setCredentials:_,setHasPersistedChat:R,getFileIds:He,clearFiles:$t}),kt=gn(p=>{V(p),N("")},[V]),[nt,Xe]=mr(!1),Je=gn(async p=>{let E=p.text.trim(),ae=Ot(E);if(/^https?:\/\//.test(ae))return;if(await qn(E)&&Gn(ae)){let se=await Kn(E);se&&(p.preventDefault(),await tt(se))}},[tt]),ot=gn(async()=>{if(!(nt||x.status!=="ready")){if(W||$e.length===0){de("Please wait for resources to load before pasting images.");return}de("Reading clipboard..."),Xe(!0);try{let p=await Mn();if(p){let E=`clipboard-${Date.now()}.png`;de(`Uploading: ${E} (${Math.round(p.buffer.length/1024)}KB)`),await tt({buffer:p.buffer,filename:E,mimeType:p.mime})}else de("No image found in clipboard. Copy an image first.")}catch(p){let E=p instanceof Error?p.message:"Failed to read clipboard";de(`Clipboard error: ${E}`)}finally{Xe(!1)}}},[tt,de,nt,x.status,W,$e.length]),{suggestions:rt,suggestionIndex:st,showSuggestions:ke,argMode:le,argItems:Be,argIndex:it,selectedConnectorIds:It,selectedCapabilities:dt,deleteConfirmMode:St,handleInputChange:w,handleSubmit:d}=po({input:X,setInput:oe,chatId:Y,setChatId:xe,currentChatTitle:O,setCurrentChatTitle:T,currentModel:H,setCurrentModel:L,currentAgentId:fe,setCurrentAgentId:pe,currentAgentDetails:h,setCurrentAgentDetails:()=>{},activeConnectorIds:j,setActiveConnectorIds:Z,sandbox:a,setSandbox:y,webSearch:Q,setWebSearch:A,imageGeneration:he,setImageGeneration:Ge,chart:qe,setChart:ve,fileSystem:Ke,setFileSystem:Kt,availableModels:B,availableAgents:te,availableConnectors:ye,messages:M,hasPersistedChat:S,setHasPersistedChat:R,setMessages:J,addSystemMessage:de,startNewChat:kt,sendMessage:Oe,setFullOutput:ne,credentials:G,setCredentials:_,setState:v,defaultCapabilities:{sandbox:f,webSearch:m,imageGeneration:b,chart:g,fileSystem:U},capabilityLabelMap:Tt,hasUploadingFiles:Ht});if(pn((p,E)=>{(E.ctrl||E.meta)&&p==="v"&&ot()},{isActive:x.status==="ready"&&!le}),pn((p,E)=>{if(!E.escape)return;let ae=Date.now(),q=P.current;P.current=ae,!(!q||ae-q>br)&&(le||ke||(P.current=null,De&&$t(),X.length>0&&w("")))},{isActive:x.status==="ready"}),pn((p,E)=>{E.return&&(kt("Started a new chat."),v({status:"ready"}))},{isActive:x.status==="error"}),jt(()=>{if(G&&!W&&x.status==="loading")if(!H&&!fe){let p=ge.getDefaultModel(),E=p&&B.some(q=>q.id===p),ae=E?p:B[0]?.id;ae?(E||ge.setDefaultModel(ae),L(ae),v({status:"ready"})):te.length===0?v({status:"no-model"}):v({status:"ready"})}else v({status:"ready"})},[G,W,H,fe,B,te,x.status,L,v]),jt(()=>{n&&G&&x.status==="ready"&&Oe(n)},[G,n]),x.status==="loading")return ie(Te,{flexDirection:"column",children:[z(K,{children:I}),ie(Te,{children:[z(K,{color:"cyan",children:z(mn,{type:"dots"})}),z(K,{children:" Initializing chat..."})]})]});if(x.status==="not-logged-in")return ie(Te,{flexDirection:"column",children:[z(K,{children:I}),z(K,{color:"yellow",children:"Not logged in"}),z(K,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if(x.status==="no-workspace")return ie(Te,{flexDirection:"column",children:[z(K,{children:I}),z(K,{color:"yellow",children:"No workspace selected"}),z(K,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if(x.status==="no-model")return ie(Te,{flexDirection:"column",children:[z(K,{children:I}),z(K,{color:"yellow",children:"No model or agent specified"}),s&&z(K,{dimColor:!0,children:"Could not determine the model used in this chat."}),z(K,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),z(K,{dimColor:!0,children:"Example: entrydesk chat -c 1 -i --model gemini-2.5-flash-lite"})]});if(x.status==="error")return ie(Te,{flexDirection:"column",children:[z(K,{children:I}),ie(K,{color:"red",children:["Error: ",x.message]}),z(K,{dimColor:!0,children:"Press Enter to start a new chat, or Ctrl+C to exit"})]});let o=fe?h?h.connectors&&h.connectors.length>0?h.connectors.map(p=>p.name).join(", "):"none":"loading...":j&&j.length>0?ye.filter(p=>j.includes(p.id)).map(p=>p.name).join(", ")||`${j.length} connector(s)`:"none",r=[];if(fe)if(h?.capabilities)for(let p of h.capabilities)r.push(Tt.get(p)??p);else r.push("loading...");else a&&r.push("Sandbox"),Q&&r.push("Web"),he&&r.push("Image"),qe&&r.push("Chart");Ke&&r.push("FileSystem");let u=ce.getCurrentProfileName(),C=u!=="default";return ie(Te,{flexDirection:"column",children:[ie(Te,{marginBottom:1,flexDirection:"column",children:[z(K,{children:I}),ie(Te,{children:[z(K,{bold:!0,color:"cyan",children:O?`Continuing: ${O}`:"EntryDesk CLI"}),ie(K,{dimColor:!0,children:[" v","1.11.10"]}),C&&ie(K,{color:"magenta",children:[" [",u,"]"]}),z(K,{dimColor:!0,children:" (type /help for commands)"})]})]}),M.map((p,E)=>{let ae=p.parts&&c?et(p.parts,!0):p.content,q=p.role==="user"?"green":p.role==="system"?"yellow":"blue",se=p.role==="user"?"You":p.role==="system"?"System":"Assistant";return ie(Te,{flexDirection:"column",marginBottom:1,children:[ie(K,{bold:!0,color:q,children:[se,":"]}),z(ln,{text:ae})]},E)}),ue&&ie(Te,{flexDirection:"column",marginBottom:1,children:[z(K,{bold:!0,color:"blue",children:"Assistant:"}),z(ln,{text:ue})]}),x.status==="ready"&&z(In,{suggestions:rt,activeIndex:st,visible:ke}),x.status==="ready"&&le&&z(kn,{items:Be,activeIndex:it,pageSize:le==="agent"||le==="skills"||le==="model"?5:10,selectedIds:le==="connectors"?It:le==="capabilities"?dt:void 0,multiSelect:le==="connectors"||le==="capabilities",visible:!0,title:le==="model"?"Select model:":le==="agent"?"Select agent:":le==="skills"?"Select skill:":le==="connectors"?"Select connectors:":le==="capabilities"?"Select capabilities:":"Select chat:"}),x.status==="sending"&&!ue?ie(Te,{children:[z(K,{color:"cyan",children:z(mn,{type:"dots"})}),z(K,{children:" Thinking..."})]}):x.status==="ready"&&!le?ie(Te,{flexDirection:"column",children:[St&&z(Te,{marginBottom:1,children:z(K,{color:"yellow",children:"\u26A0\uFE0F Delete this chat? (y/N) "})}),De&&!St&&ie(Te,{marginBottom:1,flexDirection:"row",gap:1,children:[z(K,{dimColor:!0,children:"Attachments:"}),Ne.map((p,E)=>ie(K,{children:[p.status==="uploading"?ie(K,{color:"yellow",children:[z(mn,{type:"dots"})," ",p.filename]}):p.status==="error"?ie(K,{color:"red",children:["\u2717 ",p.filename]}):ie(K,{color:"green",children:["\u2713 ",p.filename]}),E<Ne.length-1&&z(K,{children:", "})]},p.id))]}),ie(Te,{children:[z(K,{color:"green",children:"> "}),z(Dn,{value:X,onChange:w,onSubmit:d,onPaste:Je,leadingOffset:2,multiline:!0})]})]}):null,ie(Te,{marginTop:1,flexDirection:"column",children:[ie(Te,{gap:2,children:[ie(K,{children:[z(K,{dimColor:!0,children:"Model: "}),z(K,{color:"magenta",children:fe?h?.model?.name||"loading...":B.find(p=>p.id===H)?.name||H||"none"})]}),ie(K,{children:[z(K,{dimColor:!0,children:"Connectors: "}),z(K,{color:"cyan",children:o})]}),ie(K,{children:[z(K,{dimColor:!0,children:"Capabilities: "}),z(K,{color:"green",children:r.length>0?r.join(", "):"none"})]})]}),ie(K,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",c?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as Sr}from"react/jsx-runtime";async function $r(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function kr(e,t,n,s){if(s<1)return console.error("Chat number must be 1 or greater"),null;let{chats:i}=await e.getChats(t,n,20);if(i.length===0)return console.error("No chats found. Start a new chat first."),null;if(s>i.length)return console.error(`Chat number ${s} not found. You have ${i.length} recent chats.`),console.error("Use `entrydesk chats` to see available chats."),null;let l=i[s-1],f;if(!l.agentId){let{messages:m}=await e.getMessages(t,n,l.id,10);f=m.find(g=>g.role==="assistant"&&g.modelId)?.modelId}return{chat:l,modelId:f}}var ut="\x1B[2m",Se="\x1B[0m",hn="\x1B[36m",Co="\x1B[33m",Mt="\x1B[32m",bo="stream-json";function yo(e,t,n,s){e&&t&&(console.error(`Error: Cannot use both ${n} and ${s}`),process.exit(1))}function Gt(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
|
|
166
|
+
`)}function qt(e,t){if(t)return e;let n=e.split(`
|
|
167
|
+
`);if(n.length<=20)return e;let s=n.slice(0,5),i=n.slice(-5),l=n.length-10;return[...s,`${ut}... (${l} lines omitted, use --full-output to see all) ...${Se}`,...i].join(`
|
|
168
|
+
`)}function Ir(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function wo(e,t){if(!e)return"(no result)";if(typeof e!="object")return qt(String(e),t);let n=e;if("structuredContent"in n&&n.structuredContent){let s=n.structuredContent,i=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&i.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&i.push(`${Co}[stderr]${Se} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let l=s.urls;for(let f of l)f.path&&f.url&&i.push(`${f.path}: ${f.url}`)}return i.length===0&&i.push(JSON.stringify(s,null,2)),qt(i.join(`
|
|
169
|
+
`),t)}if("content"in n&&Array.isArray(n.content)){let i=n.content.filter(l=>l.type==="text"&&l.text).map(l=>l.text).join(`
|
|
170
|
+
`);return qt(i||JSON.stringify(e,null,2),t)}return qt(JSON.stringify(e,null,2),t)}async function Gi(e){let t,n;try{let B=await Ve();t=B.accessToken,n=B.workspaceId}catch(B){bn(B)}let s=e.output===bo;e.output&&!s&&(console.error(`Invalid --output value. Supported: ${bo}`),process.exit(1));let i=!s&&(e.plain||!process.stdout.isTTY),l=ge.getDefaultModel(),f=e.message;!f&&!process.stdin.isTTY&&(f=await $r());let m=new be;async function b(){if(!l)try{let{models:B}=await m.getModels(t,n),te=B[0]?.id;if(!te)return;ge.setDefaultModel(te),l=te}catch{}}let g,U,D,I;if(e.continue){let B=await kr(m,t,n,e.continue);B||process.exit(1),g=B.chat.id,U=B.chat.title??void 0,D=B.chat.agentId??void 0,I=B.modelId;let te=e.agentId||e.model||D||I||l;!te&&!e.interactive&&(await b(),te=e.agentId||e.model||D||I||l),!te&&!e.interactive&&(i||console.log(`Continuing chat: ${B.chat.title||"Untitled"}`),console.error(`
|
|
171
|
+
Could not determine model for this chat. Please specify --model or -a.`),console.error('Example: entrydesk chat -c 1 -m "message" --model gemini-2.5-flash-lite'),process.exit(1)),!i&&!e.interactive&&console.log(`Continuing chat: ${B.chat.title||"Untitled"}
|
|
172
|
+
`)}let P=e.agentId||D,$=e.model||I||l||void 0;!P&&!$&&(await b(),$=e.model||I||l||void 0),yo(e.sandbox,e.noSandbox,"--sandbox","--no-sandbox"),yo(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let x=ge.getCapabilities(),v=e.noSandbox?!1:e.sandbox?!0:x?.sandbox??!0,M=e.webSearch??x?.webSearch??!1,J=e.imageGen??x?.imageGeneration??!1,X=e.chart??x?.chart??!1,oe=ge.getDefaultConnectorIds(),Y=e.connectors??oe??void 0,xe=ge.getLocalTools(),O=e.noFileSystem?!1:e.fileSystem?!0:xe?.fileSystem??!0;if(e.interactive){Tr(Sr(xo,{agentId:P,model:$,message:e.message,chatId:g,chatTitle:U??void 0,connectorIds:Y,enableSandbox:v,enableWebSearch:M,enableImageGeneration:J,enableChart:X,enableFileSystem:O}),{exitOnCtrlC:!1});return}let T=!e.continue&&!$&&!P;(!f||T)&&(console.error("Usage: entrydesk chat -m <message> --model <model>"),console.error(" entrydesk chat -m <message> -a <agent>"),console.error(" entrydesk chat -c <number> -m <message>"),console.error(' echo "message" | entrydesk chat --model <model>'),console.error(" entrydesk chat -i (interactive mode)"),console.error(""),console.error("Options:"),console.error(" -m, --message Message to send (or pipe via stdin)"),console.error(" --model Model ID to use (required if no agent and no default)"),console.error(" -a, --agent Agent ID to use (required if no model)"),console.error(" -c, --continue Continue recent chat by number (1 = most recent)"),console.error(" -i Interactive mode"),console.error(" --plain Plain text output (no colors/formatting)"),console.error(" --output stream-json Stream JSON events (for scripting)"),console.error(" --full-output Show full tool results without truncation"),console.error(" --dangerously-auto-approve-tools"),console.error(" Auto-approve all server-side tool calls (required for"),console.error(" non-interactive use with connectors/MCP tools)"),console.error(""),console.error("List available models: entrydesk models"),console.error("List available agents: entrydesk agents"),console.error("List recent chats: entrydesk chats"),process.exit(1));let S=e.fullOutput??!1,R=e.dangerouslyAutoApproveTools??!1,G=g||Ut(),_=O?Pt():void 0,ue=O?_t():void 0,N=[],c=Ut(),ne=(B,te,$e)=>{let W={id:G,...R&&{toolApprovalMode:"allow_always"}};return B&&(W.message={id:B.id,createdAt:new Date,role:"user",parts:[{type:"text",text:B.text}]}),P?W.agentId=P:($&&(W.model=$),W.connectorIds=Y??[],W.enableSandbox=v,W.enableWebSearch=M,W.enableImageGeneration=J,W.enableChart=X),_&&(W.clientTools=_),ue&&(W.clientToolSystemPrompt=ue),te&&te.length>0&&(W.clientToolResults=te),$e&&$e.length>0&&(W.previousMessages=$e),W},de=async B=>{if(!B.body)throw new Error("No response body");let te=B.body.getReader(),$e=new TextDecoder,W="",H=new Map,L=[],fe=[];for(;;){let{done:pe,value:j}=await te.read();if(pe)break;W+=$e.decode(j,{stream:!0});let Z=W.split(`
|
|
173
|
+
`);W=Z.pop()||"";for(let F of Z){let h=F.trimEnd();if(h==="data: [DONE]"){s&&Gt("done");continue}if(h.startsWith("data: "))try{let a=JSON.parse(h.slice(6));if(a.type&&fe.push(a),s){a.type==="text-delta"&&a.delta!==void 0?Gt("text-delta",a.delta):a.type==="reasoning-delta"&&a.delta!==void 0?Gt("reasoning-delta",a.delta):Gt(a.type||"event",a);continue}if(i){if(a.type==="text-delta"&&a.delta&&process.stdout.write(a.delta),O&&(a.type==="tool-input-available"||a.type==="tool-call")&&a.toolCallId&&a.toolName&&je(a.toolName)){let y=a.args||a.input||{};L.push({toolCallId:a.toolCallId,toolName:a.toolName,args:y})}continue}switch(a.type){case"reasoning-delta":a.delta&&process.stdout.write(`${ut}${a.delta}${Se}`);break;case"reasoning-end":process.stdout.write(`
|
|
174
|
+
|
|
175
|
+
`);break;case"text-delta":a.delta&&process.stdout.write(a.delta);break;case"tool-call-streaming-start":case"tool-input-start":if(a.toolCallId&&a.toolName){H.set(a.toolCallId,{toolName:a.toolName});let Q=O&&je(a.toolName)?`${Mt}[LOCAL]${Se} `:"";console.log(`
|
|
176
|
+
${hn}\u250C\u2500 ${Q}Tool Call: ${a.toolName}${Se}`)}break;case"tool-call":case"tool-input-available":if(a.toolCallId&&a.toolName){let y=a.args||a.input||{},Q=Ir(y);console.log(`${Co}\u2502 Arguments:${Se}`);for(let A of Q.split(`
|
|
177
|
+
`))console.log(`${ut}\u2502 ${A}${Se}`);O&&je(a.toolName)&&(H.set(a.toolCallId,{toolName:a.toolName,args:y}),L.push({toolCallId:a.toolCallId,toolName:a.toolName,args:y}))}break;case"tool-result":if(a.toolCallId){let y=H.get(a.toolCallId),Q=wo(a.result,S);console.log(`${Mt}\u2502 Result:${Se}`);for(let A of Q.split(`
|
|
178
|
+
`))console.log(`${ut}\u2502 ${A}${Se}`);console.log(`${hn}\u2514\u2500 ${y?.toolName||"Tool"} completed${Se}
|
|
179
|
+
`),H.delete(a.toolCallId)}break;case"error":a.errorText&&console.error(`${ut}Error: ${a.errorText}${Se}`);break}}catch{}}}return{pendingClientTools:L,messageParts:fe}},V=ne({id:Ut(),text:f}),k=await m.chat(t,n,V),ye=await de(k);for(N=ye.messageParts;ye.pendingClientTools.length>0;){let B=[];for(let H of ye.pendingClientTools){!i&&!s&&console.log(`${Mt}\u2502 Executing locally...${Se}`);let L=await Et(H.toolName,H.args),fe=L.success?JSON.stringify(L.result):L.error||"Unknown error";if(B.push({toolCallId:H.toolCallId,toolName:H.toolName,content:[{type:"text",text:fe}],isError:!L.success}),!i&&!s){let pe=wo(L.success?L.result:{error:L.error},S);console.log(`${Mt}\u2502 Result:${Se}`);for(let j of pe.split(`
|
|
180
|
+
`))console.log(`${ut}\u2502 ${j}${Se}`);console.log(`${hn}\u2514\u2500 ${H.toolName} completed${Se}
|
|
181
|
+
`)}}let te=N.map(H=>{if(H.type==="tool-call"){let L=B.find(pe=>pe.toolCallId===H.toolCallId),fe=L?.content.filter(pe=>pe.type==="text").map(pe=>pe.text).join(`
|
|
182
|
+
`);return{type:"tool-invocation",toolCallId:H.toolCallId,toolName:H.toolName,args:H.args,state:L?.isError?"output-error":"output-available",output:fe}}return H}),$e=[{id:c,role:"assistant",parts:te}];c=Ut();let W=ne(void 0,B,$e);k=await m.chat(t,n,W),ye=await de(k),N=ye.messageParts}s||console.log("")}export{Gi as runChat};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{i as I,o as k,p as T,r as b}from"./chunk-
|
|
2
|
+
import{i as I,o as k,p as T,r as b}from"./chunk-GIUYIB5E.js";var $="\x1B[2m",l="\x1B[0m",g="\x1B[36m",x="\x1B[33m",O="\x1B[32m",R="stream-json";function f(e,n){let o=n===void 0?{event:e}:{event:e,data:n};process.stdout.write(`${JSON.stringify(o)}
|
|
3
3
|
`)}function N(e){let n=new Date(e),t=new Date().getTime()-n.getTime(),s=Math.floor(t/(1e3*60*60*24));return s===0?n.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit"}):s===1?"Yesterday":s<7?`${s} days ago`:n.toLocaleDateString("en-US",{month:"short",day:"numeric"})}function S(e,n){if(n)return e;let o=e.split(`
|
|
4
4
|
`);if(o.length<=15)return e;let t=o.slice(0,6),s=o.slice(-4),i=o.length-10;return[...t,`... (${i} lines omitted, use --full-output to see all) ...`,...s].join(`
|
|
5
5
|
`)}function C(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(C);let n={};for(let[o,t]of Object.entries(e))typeof t=="string"&&t.length>200?n[o]=t.slice(0,150)+"... (truncated)":typeof t=="object"&&t!==null?n[o]=C(t):n[o]=t;return n}function v(e){if(!e||typeof e!="object")return String(e);try{return JSON.stringify(e,null,2)}catch{return String(e)}}function j(e,n){if(!e)return"(no result)";if(typeof e!="object")return S(String(e),n);let o=n?e:C(e);if("structuredContent"in o&&o.structuredContent){let t=o.structuredContent,s=[];if(t.stdout&&typeof t.stdout=="string"&&t.stdout.trim()&&s.push(t.stdout.trim()),t.stderr&&typeof t.stderr=="string"&&t.stderr.trim()&&s.push(`${x}[stderr]${l} ${t.stderr.trim()}`),t.urls&&Array.isArray(t.urls)){let i=t.urls;for(let r of i)r.path&&r.url&&s.push(`${r.path}: ${r.url}`)}return s.length===0&&s.push(JSON.stringify(t,null,2)),S(s.join(`
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import F from"fs";import p from"fs";import Te from"os";import E from"path";import{HTTPError as Re,TimeoutError as xe}from"ky";import he,{TimeoutError as ye}from"ky";import x from"crypto";import u from"fs";import le from"path";var ge="ENTRYDESK_FORCE_FILE_STORAGE",A="EntryDesk CLI",de="__entrydesk_keychain_test__",ue="profile:",fe=".credentials.key",Z={keychain:!1,permissions:!1,corruptFile:!1,windowsFile:!1};function v(r,e){Z[r]||(Z[r]=!0,console.error(e))}function Q(r){if(!r||typeof r!="object")return!1;let e=r;return!(!("accessToken"in e||"refreshToken"in e||"email"in e||"workspaceId"in e)||"accessToken"in e&&typeof e.accessToken!="string"||"refreshToken"in e&&typeof e.refreshToken!="string"||"email"in e&&typeof e.email!="string"||"workspaceId"in e&&typeof e.workspaceId!="string")}function pe(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.getPassword=="function"&&typeof e.setPassword=="function"&&typeof e.deletePassword=="function"}function O(r){return o.getProfileCredentialsFile(r)}var N=class{getKeyFilePath(e){return le.join(o.getProfileDir(e),fe)}loadEncryptionKey(e){let t=this.getKeyFilePath(e);try{if(!u.existsSync(t))return null;let n=u.readFileSync(t);return n.length!==32?null:(this.ensureSecureFilePermissions(t),n)}catch{return null}}createEncryptionKey(e){o.ensureProfileDir(e);let t=this.getKeyFilePath(e),n=x.randomBytes(32);return u.writeFileSync(t,n,{mode:384}),this.ensureSecureFilePermissions(t),n}getOrCreateEncryptionKey(e){let t=this.loadEncryptionKey(e);return t||this.createEncryptionKey(e)}encrypt(e,t){let n=x.randomBytes(16),s=x.createCipheriv("aes-256-gcm",t,n),i=s.update(e,"utf8","hex");i+=s.final("hex");let c=s.getAuthTag();return`${n.toString("hex")}:${c.toString("hex")}:${i}`}decrypt(e,t){let n=e.split(":");if(n.length!==3)throw new Error("Invalid encrypted data format");let s=Buffer.from(n[0],"hex"),i=Buffer.from(n[1],"hex"),c=n[2],S=x.createDecipheriv("aes-256-gcm",t,s,{authTagLength:16});S.setAuthTag(i);let d=S.update(c,"hex","utf8");return d+=S.final("utf8"),d}tryDecrypt(e,t){try{return this.decrypt(e,t)}catch{return null}}tryParseCredentials(e){try{let t=JSON.parse(e);return Q(t)?t:null}catch{return null}}ensureSecureFilePermissions(e){if(process.platform!=="win32"){try{u.chmodSync(e,384)}catch{v("permissions","Warning: Failed to set secure permissions on credentials file.");return}try{(u.statSync(e).mode&511)!==384&&v("permissions","Warning: Credentials file permissions are too permissive.")}catch{v("permissions","Warning: Failed to verify credentials file permissions.")}}}async getCredentials(e){let t=O(e);try{if(!u.existsSync(t))return null;let n=u.readFileSync(t,"utf-8").trim();if(!n)return null;let s=this.loadEncryptionKey(e),i=s?this.tryDecrypt(n,s):null;if(i){let c=this.tryParseCredentials(i);if(c)return c}return v("corruptFile","Warning: Credentials file is unreadable. Please run `entrydesk login` again."),null}catch{return null}}async setCredentials(e,t){o.ensureProfileDir(e);let n=O(e),s=this.getOrCreateEncryptionKey(e),i=this.encrypt(JSON.stringify(t),s);u.writeFileSync(n,i,{mode:384}),this.ensureSecureFilePermissions(n)}async deleteCredentials(e){let t=O(e);try{u.existsSync(t)&&u.unlinkSync(t)}catch{}}},M=class{keytarModule=null;keytarLoadAttempted=!1;keychainAvailable=null;async getKeytar(){if(this.keytarLoadAttempted)return this.keytarModule;this.keytarLoadAttempted=!0;try{let t=await import("keytar"),n=t&&typeof t=="object"&&"default"in t?t.default:t;this.keytarModule=pe(n)?n:null}catch{this.keytarModule=null}return this.keytarModule}getAccount(e){return`${ue}${e}`}async checkKeychainAvailability(){if(this.keychainAvailable!==null)return this.keychainAvailable;try{let e=await this.getKeytar();if(!e)return this.keychainAvailable=!1,!1;let t=`${de}${x.randomBytes(8).toString("hex")}`,n="test";await e.setPassword(A,t,n);let s=await e.getPassword(A,t),i=await e.deletePassword(A,t);return this.keychainAvailable=!!(i&&s===n),this.keychainAvailable}catch{return this.keychainAvailable=!1,!1}}async isAvailable(){return this.checkKeychainAvailability()}async getCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");let n=await t.getPassword(A,this.getAccount(e));if(!n)return null;let s=this.tryParseKeychainPayload(n);return s||v("corruptFile",`Warning: Keychain entry for profile "${e}" is unreadable.`),s}async setCredentials(e,t){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let n=await this.getKeytar();if(!n)throw new Error("Keytar module not available");let s=JSON.stringify(t);await n.setPassword(A,this.getAccount(e),s)}async deleteCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");await t.deletePassword(A,this.getAccount(e))}tryParseKeychainPayload(e){try{let t=JSON.parse(e);return Q(t)?t:null}catch{return null}}},j=class{keychainStorage=null;fileStorage=new N;keychainAvailable=null;initPromise=null;shouldForceFileStorage(){return process.env[ge]?.toLowerCase()==="true"}async initializeStorage(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}try{let e=new M,t=await e.isAvailable();this.keychainAvailable=t,this.keychainStorage=t?e:null}catch{this.keychainAvailable=!1,this.keychainStorage=null}!this.keychainAvailable&&!this.shouldForceFileStorage()&&(v("keychain","Keychain unavailable. Falling back to file-based credentials."),process.platform==="win32"&&v("windowsFile","Warning: File-based credentials on Windows may be readable by other users."))}async ensureInitialized(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}this.keychainAvailable===null&&(this.initPromise??=this.initializeStorage(),await this.initPromise)}disableKeychain(){this.shouldForceFileStorage()||v("keychain","Keychain error encountered. Falling back to file-based credentials."),this.keychainAvailable=!1,this.keychainStorage=null}async getKeychainStorage(){return await this.ensureInitialized(),this.shouldForceFileStorage()?null:this.keychainAvailable?this.keychainStorage:null}async getCredentials(e){let t=await this.getKeychainStorage();if(!t)return this.fileStorage.getCredentials(e);try{let s=await t.getCredentials(e);if(s)return s}catch{return this.disableKeychain(),this.fileStorage.getCredentials(e)}let n=await this.fileStorage.getCredentials(e);if(n)try{await t.setCredentials(e,n),await this.fileStorage.deleteCredentials(e)}catch{}return n}async setCredentials(e,t){let n=await this.getKeychainStorage();if(!n){await this.fileStorage.setCredentials(e,t);return}try{await n.setCredentials(e,t),await this.fileStorage.deleteCredentials(e)}catch{this.disableKeychain(),await this.fileStorage.setCredentials(e,t)}}async deleteCredentials(e){let t=await this.getKeychainStorage();if(t)try{await t.deleteCredentials(e)}catch{this.disableKeychain()}await this.fileStorage.deleteCredentials(e)}},g=new j,y={async saveAccessToken(r,e){let t=o.getEffectiveProfileName(e),n=await g.getCredentials(t)??{};n.accessToken=r,await g.setCredentials(t,n)},async getAccessToken(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.accessToken??null},async saveRefreshToken(r,e){let t=o.getEffectiveProfileName(e),n=await g.getCredentials(t)??{};n.refreshToken=r,await g.setCredentials(t,n)},async getRefreshToken(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.refreshToken??null},async saveEmail(r,e){let t=o.getEffectiveProfileName(e),n=await g.getCredentials(t)??{};n.email=r,await g.setCredentials(t,n)},async getEmail(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.email??null},async saveWorkspaceId(r,e){let t=o.getEffectiveProfileName(e),n=await g.getCredentials(t)??{};n.workspaceId=r,await g.setCredentials(t,n)},async getWorkspaceId(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.workspaceId??null},async saveAll(r,e){let t=o.getEffectiveProfileName(e);await g.setCredentials(t,r)},async getAll(r){let e=o.getEffectiveProfileName(r);return g.getCredentials(e)},async clear(r){let e=o.getEffectiveProfileName(r);await g.deleteCredentials(e)},async isLoggedIn(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.accessToken!=null}};var K=class r{client;baseUrl;constructor(e,t){this.baseUrl=e||U(t),I().ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",process.env.DEBUG&&console.log("[DEBUG] ApiClient: SSL certificate validation disabled")),this.client=he.create({prefixUrl:this.baseUrl,timeout:3e4,retry:{limit:3,methods:["get","put","head","delete","options","trace"],statusCodes:[408,413,429,500,502,503,504]},hooks:{beforeError:[s=>(s.request?.headers&&(s.request.headers.delete("authorization"),s.request.headers.delete("Authorization")),s)]}})}getBaseUrl(){return this.baseUrl}async refreshOAuthToken(e){return this.client.post("v1/oauth/token",{json:{grant_type:"refresh_token",refresh_token:e.refreshToken,client_id:e.clientId}}).json()}async revokeOAuthToken(e){await this.client.post("v1/oauth/revoke",{json:{token:e.token,token_type_hint:"refresh_token",client_id:e.clientId}})}async getWorkspaces(e){try{return process.env.DEBUG&&console.log(`[DEBUG] Calling getWorkspaces API: ${this.baseUrl}/v1/workspaces`),await this.client.get("v1/workspaces",{headers:{Authorization:`Bearer ${e}`}}).json()}catch(t){throw process.env.DEBUG&&(console.error("[DEBUG] getWorkspaces error:",t),t instanceof Error&&"cause"in t&&console.error("[DEBUG] Error cause:",t.cause)),t}}async getAgents(e,t,n){let s={limit:n?.limit??100};return n?.nextKey&&(s.nextKey=n.nextKey),n?.search&&(s.search=n.search),await this.client.get(`v1/workspaces/${t}/availableAgents`,{headers:{Authorization:`Bearer ${e}`},searchParams:s}).json()}async createAgent(e,t,n){return await this.client.post(`v1/workspaces/${t}/agents`,{headers:{Authorization:`Bearer ${e}`},json:n}).json()}async updateAgent(e,t,n,s){await this.client.put(`v1/workspaces/${t}/agents/${n}`,{headers:{Authorization:`Bearer ${e}`},json:s})}async deleteAgent(e,t,n){await this.client.delete(`v1/workspaces/${t}/agents/${n}`,{headers:{Authorization:`Bearer ${e}`}})}async getModels(e,t){return await this.client.get(`v1/workspaces/${t}/models`,{headers:{Authorization:`Bearer ${e}`}}).json()}async getConnectors(e,t){return await this.client.get(`v1/workspaces/${t}/availableConnectors`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:100,connectionStatus:"connected"}}).json()}async getChats(e,t,n=20){return await this.client.get(`v1/workspaces/${t}/chats`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:n}}).json()}async getMessages(e,t,n,s=50){return await this.client.get(`v1/workspaces/${t}/chats/${n}/messages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:s}}).json()}async getAgent(e,t,n){return await this.client.get(`v1/workspaces/${t}/agents/${n}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async listAvailableSkills(e,t,n){return await this.client.get(`v1/workspaces/${t}/availableSkills`,{headers:{Authorization:`Bearer ${e}`},searchParams:{createdBy:n?.createdBy,nextKey:n?.nextKey,limit:n?.limit??20}}).json()}async uploadSkill(e,t,n){return await this.client.post(`v1/workspaces/${t}/skills`,{headers:{Authorization:`Bearer ${e}`},body:n}).json()}async deleteSkill(e,t,n){await this.client.delete(`v1/workspaces/${t}/skills/${n}`,{headers:{Authorization:`Bearer ${e}`}})}async downloadSkillCurrent(e,t,n){return await this.client.get(`v1/workspaces/${t}/skills/${n}/download`,{headers:{Authorization:`Bearer ${e}`}}).json()}async chat(e,t,n){try{let s=await this.client.post(`v1/workspaces/${t}/chats`,{headers:{Authorization:`Bearer ${e}`},json:n,timeout:6e4,throwHttpErrors:!1});if(!s.ok){let i=await s.text();throw new Error(`Chat API failed (${s.status}): ${i}`)}return s}catch(s){throw s instanceof ye?new TypeError("Request timed out. Please check your connection and try again.",{cause:s}):s}}async getBudget(e,t){return await this.client.get(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`}}).json()}async updateBudget(e,t,n){return await this.client.put(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`},json:{budget:n}}).json()}async getMonthlyUsages(e,t,n){return await this.client.get(`v1/workspaces/${t}/monthlyUsages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{nextKey:n?.nextKey,limit:n?.limit??20}}).json()}async createChatShare(e,t,n,s="public"){return await this.client.post(`v1/workspaces/${t}/chats/${n}/shares`,{headers:{Authorization:`Bearer ${e}`},json:{visibility:s}}).json()}async getSharedChat(e,t){let n={};return t&&(n.Authorization=`Bearer ${t}`),await this.client.get(`v1/shares/${e}`,{headers:n}).json()}async getSharedMessages(e,t=50,n){let s={};return n&&(s.Authorization=`Bearer ${n}`),await this.client.get(`v1/shares/${e}/messages`,{headers:s,searchParams:{limit:t}}).json()}async deleteChat(e,t,n){await this.client.delete(`v1/workspaces/${t}/chats/${n}`,{headers:{Authorization:`Bearer ${e}`}})}async getModelProviders(e,t){return await this.client.get(`v1/workspaces/${t}/modelProviders`,{headers:{Authorization:`Bearer ${e}`}}).json()}async uploadFile(e,t,n,s){let i=new FormData,c=new Blob([n.buffer],{type:n.mimeType});return i.append("file",c,n.filename),i.append("modelProviderId",s),await this.client.post(`v1/workspaces/${t}/files`,{headers:{Authorization:`Bearer ${e}`},body:i,timeout:12e4}).json()}async getSchedules(e,t,n){let s={limit:n?.limit??20};return n?.nextKey&&(s.nextKey=n.nextKey),n?.search&&(s.search=n.search),await this.client.get(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},searchParams:s}).json()}async getSchedule(e,t,n){return await this.client.get(`v1/workspaces/${t}/schedules/${n}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async createSchedule(e,t,n){return await this.client.post(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},json:n}).json()}async updateSchedule(e,t,n,s){await this.client.put(`v1/workspaces/${t}/schedules/${n}`,{headers:{Authorization:`Bearer ${e}`},json:s})}async deleteSchedule(e,t,n){await this.client.delete(`v1/workspaces/${t}/schedules/${n}`,{headers:{Authorization:`Bearer ${e}`}})}static async getAuthenticatedClient(e){let t=await y.getAll(e);return t?{client:new r(void 0,e),accessToken:t.accessToken,workspaceId:t.workspaceId??null}:null}};function me(){return process.env.ENTRYDESK_SANDBOX==="true"}function z(){if(!me())return null;let r=process.env.ENTRYDESK_SANDBOX_ACCESS_TOKEN?.trim(),e=process.env.ENTRYDESK_SANDBOX_WORKSPACE_ID?.trim();if(!r||!e){let t=[];throw r||t.push("ENTRYDESK_SANDBOX_ACCESS_TOKEN"),e||t.push("ENTRYDESK_SANDBOX_WORKSPACE_ID"),new Error(`Sandbox mode enabled but missing credentials: ${t.join(", ")}`)}return{accessToken:r,workspaceId:e}}function ee(){let r=process.env.ENTRYDESK_TOKEN?.trim();if(!r)return null;let e=process.env.ENTRYDESK_WORKSPACE_ID?.trim();if(!e)throw new Error("ENTRYDESK_TOKEN is set but ENTRYDESK_WORKSPACE_ID is missing. Both are required for PAT authentication.");return{accessToken:r,workspaceId:e}}import{execFile as we}from"child_process";import{setTimeout as ve}from"timers/promises";import{decodeJwt as ke}from"jose";import Pe,{HTTPError as Se}from"ky";var D="entrydesk-cli",Ce="offline_access workspaces:read chats:read chats:write chats:delete agents:read agents:write connectors:read connectors:write tools:read tools:execute skills:read skills:write meetings:read meetings:write publishes:read publishes:write calendar:read calendar:write schedules:read schedules:write user:read user:write";function Ae(r){return new Promise((e,t)=>{let n=process.platform,s,i;switch(n){case"darwin":s="open",i=[r];break;case"win32":s="cmd",i=["/c","start","",r];break;default:s="xdg-open",i=[r];break}we(s,i,c=>{c?t(new Error(`Failed to open browser. Please manually visit: ${r}`,{cause:c})):e()})})}async function tt(r){let e=U(),t=te(),n=I(),s=process.env.NODE_TLS_REJECT_UNAUTHORIZED;n.ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",console.error("WARNING: SSL certificate validation is disabled globally for this process during the login flow. All connections in this process will skip TLS verification. Only use ENTRYDESK_IGNORE_SSL_ERRORS for local development."));try{let i=Pe.create({prefixUrl:e,timeout:3e4,hooks:{beforeError:[a=>(a.request?.headers&&(a.request.headers.delete("authorization"),a.request.headers.delete("Authorization")),a)]}}),c;try{c=await i.post("v1/oauth/device/code",{json:{client_id:D,scope:Ce}}).json()}catch(a){let w=a instanceof Error?a:new Error("Failed to request device code");throw r?.onError?.(w),w}let{device_code:S,user_code:d,expires_in:oe,interval:ae}=c,J=new URL("/oauth/device",t);J.searchParams.set("user_code",d);let q=J.toString();r?.onDeviceCodeReceived?.(d,q),r?.onBrowserOpening?.();try{await Ae(q)}catch(a){process.env.DEBUG&&console.error("[DEBUG] Failed to open browser:",a)}r?.onWaitingForAuthorization?.();let V=Math.max(ae,5)*1e3,ce=Date.now()+oe*1e3;for(;Date.now()<ce;){await ve(V);try{let a=await i.post("v1/oauth/token",{json:{grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:S,client_id:D}}).json();r?.onAuthorized?.();let w={};try{w=ke(a.access_token)}catch{}return{accessToken:a.access_token,refreshToken:a.refresh_token??void 0,email:w.email||"",scopes:a.scope.split(" ").filter(R=>R.length>0)}}catch(a){if(a instanceof Se){let R;try{let X=await a.response.json();R=X.code||X.error}catch{continue}switch(R){case"authorization_pending":continue;case"slow_down":V+=5e3;continue;case"access_denied":throw new Error("Authorization denied by user",{cause:a});case"expired_token":throw new Error("Device code expired. Please try again.",{cause:a});default:throw new Error(`Authorization failed: ${R||"Unknown error"}`,{cause:a})}}let w=a instanceof Error?a:new Error("Unknown error during authorization");throw r?.onError?.(w),w}}throw new Error("Device code expired. Please try again.")}finally{s===void 0?delete process.env.NODE_TLS_REJECT_UNAUTHORIZED:process.env.NODE_TLS_REJECT_UNAUTHORIZED=s}}var m=class extends Error{code;constructor(e,t){super(t),this.code=e}};function be(r){try{let e=r.split(".");if(e.length<2)return null;let t=e[1].replace(/-/g,"+").replace(/_/g,"/"),n=(4-t.length%4)%4,s=t.padEnd(t.length+n,"="),i=Buffer.from(s,"base64").toString("utf8");return JSON.parse(i)}catch{return null}}function Ee(r,e=300){let n=be(r)?.exp;if(typeof n!="number")return!1;let s=Math.floor(Date.now()/1e3);return n-s<=e}async function re(r){let e=r.accessToken;if(!Ee(e))return e;if(!r.refreshToken)throw await y.clear(),new m("session-expired","Session expired. Please run `entrydesk login` again.");try{let n=await new K().refreshOAuthToken({refreshToken:r.refreshToken,clientId:D});return await y.saveAccessToken(n.access_token),n.refresh_token&&await y.saveRefreshToken(n.refresh_token),n.access_token}catch{throw await y.clear(),new m("session-expired","Session expired. Please run `entrydesk login` again.")}}async function at(){let r=z();if(r)return r.accessToken;let e=await y.getAll();if(!e?.accessToken)throw new m("not-logged-in","Not logged in. Run `entrydesk login` first.");return re(e)}async function ct(){let r=z();if(r)return{accessToken:r.accessToken,workspaceId:r.workspaceId};let e=ee();if(e)return e;let t=await y.getAll();if(!t?.accessToken)throw new m("not-logged-in","Not logged in. Run `entrydesk login` first.");if(!t.workspaceId)throw new m("no-workspace","No workspace selected. Run `entrydesk workspaces` first.");return{accessToken:await re(t),workspaceId:t.workspaceId}}var f=class extends Error{constructor(t,n=1,s){super(t);this.exitCode=n;this.cause=s;this.name="CLIError"}};function ut(r){let e=!!process.env.DEBUG;r instanceof f&&(console.error(`Error: ${r.message}`),r.cause&&(console.error(`Cause: ${r.cause.message}`),e&&r.cause.stack&&console.error(r.cause.stack)),process.exit(r.exitCode)),r instanceof m&&(console.error(r.message),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof xe&&(console.error("Request timed out. Please check your connection and try again."),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Re&&(console.error(`Request failed (${r.response.status}): ${r.response.statusText}`),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Error&&(console.error(`Unexpected error: ${r.message}`),e&&r.stack&&console.error(r.stack),process.exit(1)),console.error("An unknown error occurred"),process.exit(1)}var P="default",_e=/^[A-Za-z0-9_-]+$/,L=null;function H(){return E.join(Te.homedir(),".entrydesk")}function se(){return E.join(H(),"profiles")}function ie(){return E.join(H(),"profiles.json")}function $(r){return E.join(se(),r)}function G(r){if(!p.existsSync(r))p.mkdirSync(r,{mode:448,recursive:!0});else try{p.chmodSync(r,448)}catch{}}function Ke(){G(H())}function W(){G(se())}function Ue(){let r=ie();try{if(!p.existsSync(r))return null;let e=p.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}function b(r){Ke();let e=ie();p.writeFileSync(e,JSON.stringify(r,null,2),{mode:384});try{p.chmodSync(e,384)}catch{}}function Ie(r){let e=r.profiles?.length?Array.from(new Set(r.profiles)):[],t=r.currentProfile&&e.includes(r.currentProfile)?r.currentProfile:e[0]||P;return e.length===0&&e.push(P),e.includes(t)||e.unshift(t),{currentProfile:t,profiles:e}}function k(){let r=Ue();if(!r){let t={currentProfile:P,profiles:[P]};return b(t),W(),_(P),t}let e=Ie(r);return(e.currentProfile!==r.currentProfile||e.profiles.length!==r.profiles.length)&&b(e),W(),e}function C(r){if(!r)throw new f("Profile name is required.");if(!_e.test(r))throw new f("Invalid profile name. Use letters, numbers, dash, or underscore.")}function T(r,e){if(!r.profiles.includes(e))throw new f(`Profile not found: ${e}`)}function ne(r,e){if(r.profiles.includes(e))throw new f(`Profile already exists: ${e}`)}function _(r){W(),G($(r))}var o={DEFAULT_PROFILE:P,setOverrideProfile(r){L=r},getOverrideProfile(){return L},getProfileDir(r){return $(r)},getProfileConfigFile(r){return E.join(o.getProfileDir(r),"config.json")},getProfileCredentialsFile(r){return E.join(o.getProfileDir(r),"credentials.json")},getProfileNames(){return[...k().profiles]},getProfileCount(){return o.getProfileNames().length},getCurrentProfileName(){return k().currentProfile},getEffectiveProfileName(r){let e=k(),t=r||L||e.currentProfile;return C(t),T(e,t),t},ensureProfileExists(r){let e=k();C(r),T(e,r)},createProfile(r){C(r);let e=k();ne(e,r);let t={currentProfile:e.currentProfile,profiles:[...e.profiles,r]};b(t),_(r)},deleteProfile(r){C(r);let e=k();if(T(e,r),e.profiles.length===1)throw new f("Cannot delete the last profile.");let t=e.profiles.filter(i=>i!==r),n=e.currentProfile;n===r&&(n=t.includes(P)?P:t[0]),b({currentProfile:n,profiles:t});try{p.rmSync(o.getProfileDir(r),{recursive:!0,force:!0})}catch{}return{currentProfile:n}},renameProfile(r,e){C(r),C(e);let t=k();T(t,r),ne(t,e);let n=$(r),s=$(e);if(p.existsSync(n))try{p.renameSync(n,s)}catch(d){throw new f("Failed to rename profile directory.",1,d)}else _(e);let i=t.profiles.map(d=>d===r?e:d),c=t.currentProfile===r?e:t.currentProfile;return b({currentProfile:c,profiles:i}),{currentProfile:c}},setCurrentProfile(r){C(r);let e=k();T(e,r);let t={currentProfile:r,profiles:e.profiles};b(t),_(r)},ensureProfileDir:_};function De(r){let e=o.getEffectiveProfileName(r);return o.getProfileConfigFile(e)}function l(r){let e=De(r);try{if(!F.existsSync(e))return{};let t=F.readFileSync(e,"utf-8");return JSON.parse(t)}catch{return{}}}function h(r,e){let t=o.getEffectiveProfileName(e);o.ensureProfileDir(t);let n=o.getProfileConfigFile(t);F.writeFileSync(n,JSON.stringify(r,null,2),{mode:384});try{F.chmodSync(n,384)}catch{}}var Y={getApiUrl(r){return l(r).apiUrl??null},setApiUrl(r,e){let t=l(e);t.apiUrl=r,h(t,e)},clearApiUrl(r){let e=l(r);delete e.apiUrl,h(e,r)},getHubUrl(r){return l(r).hubUrl??null},setHubUrl(r,e){let t=l(e);t.hubUrl=r,h(t,e)},getAll(r){return l(r)},setAll(r,e){h(r,e)},set(r,e,t){let n=l(t);n[r]=e,h(n,t)},get(r,e){return l(e)[r]},unset(r,e){let t=l(e);delete t[r],h(t,e)},getDefaultModel(r){return l(r).model?.default??null},setDefaultModel(r,e){let t=l(e);t.model={...t.model,default:r},h(t,e)},getDefaultConnectorIds(r){return l(r).connectors?.defaults??null},setDefaultConnectorIds(r,e){let t=l(e);t.connectors={...t.connectors,defaults:r},h(t,e)},getCapabilities(r){return l(r).capabilities??null},setCapabilities(r,e){let t=l(e);t.capabilities={...t.capabilities,...r},h(t,e)},getLocalTools(r){return l(r).localTools??null},setLocalTools(r,e){let t=l(e);t.localTools={...t.localTools,...r},h(t,e)}};var $e="https://api.entrydesk.com",Fe="https://app.entrydesk.com",Be=3100,Oe=300*1e3;function B(r){return{apiUrl:Y.getApiUrl(r)||process.env.ENTRYDESK_API_URL||$e,hubUrl:Y.getHubUrl(r)||process.env.ENTRYDESK_HUB_URL||Fe,mcp:{httpPort:Be},auth:{loginTimeout:Oe,ignoreSslErrors:process.env.ENTRYDESK_IGNORE_SSL_ERRORS==="true"||!1}}}function U(r){return B(r).apiUrl}function te(r){return B(r).hubUrl}function Ct(){return B().mcp}function I(){return B().auth}export{o as a,Y as b,B as c,U as d,te as e,Ct as f,I as g,y as h,K as i,D as j,tt as k,m as l,Ee as m,re as n,at as o,ct as p,f as q,ut as r};
|
|
2
|
+
import F from"fs";import p from"fs";import Te from"os";import E from"path";import{HTTPError as Re,TimeoutError as xe}from"ky";import he,{TimeoutError as ye}from"ky";import x from"crypto";import u from"fs";import le from"path";var ge="ENTRYDESK_FORCE_FILE_STORAGE",A="EntryDesk CLI",de="__entrydesk_keychain_test__",ue="profile:",fe=".credentials.key",Z={keychain:!1,permissions:!1,corruptFile:!1,windowsFile:!1};function v(r,e){Z[r]||(Z[r]=!0,console.error(e))}function Q(r){if(!r||typeof r!="object")return!1;let e=r;return!(!("accessToken"in e||"refreshToken"in e||"email"in e||"workspaceId"in e)||"accessToken"in e&&typeof e.accessToken!="string"||"refreshToken"in e&&typeof e.refreshToken!="string"||"email"in e&&typeof e.email!="string"||"workspaceId"in e&&typeof e.workspaceId!="string")}function pe(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.getPassword=="function"&&typeof e.setPassword=="function"&&typeof e.deletePassword=="function"}function O(r){return o.getProfileCredentialsFile(r)}var N=class{getKeyFilePath(e){return le.join(o.getProfileDir(e),fe)}loadEncryptionKey(e){let t=this.getKeyFilePath(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t);return s.length!==32?null:(this.ensureSecureFilePermissions(t),s)}catch{return null}}createEncryptionKey(e){o.ensureProfileDir(e);let t=this.getKeyFilePath(e),s=x.randomBytes(32);return u.writeFileSync(t,s,{mode:384}),this.ensureSecureFilePermissions(t),s}getOrCreateEncryptionKey(e){let t=this.loadEncryptionKey(e);return t||this.createEncryptionKey(e)}encrypt(e,t){let s=x.randomBytes(16),n=x.createCipheriv("aes-256-gcm",t,s),i=n.update(e,"utf8","hex");i+=n.final("hex");let c=n.getAuthTag();return`${s.toString("hex")}:${c.toString("hex")}:${i}`}decrypt(e,t){let s=e.split(":");if(s.length!==3)throw new Error("Invalid encrypted data format");let n=Buffer.from(s[0],"hex"),i=Buffer.from(s[1],"hex"),c=s[2],S=x.createDecipheriv("aes-256-gcm",t,n,{authTagLength:16});S.setAuthTag(i);let d=S.update(c,"hex","utf8");return d+=S.final("utf8"),d}tryDecrypt(e,t){try{return this.decrypt(e,t)}catch{return null}}tryParseCredentials(e){try{let t=JSON.parse(e);return Q(t)?t:null}catch{return null}}ensureSecureFilePermissions(e){if(process.platform!=="win32"){try{u.chmodSync(e,384)}catch{v("permissions","Warning: Failed to set secure permissions on credentials file.");return}try{(u.statSync(e).mode&511)!==384&&v("permissions","Warning: Credentials file permissions are too permissive.")}catch{v("permissions","Warning: Failed to verify credentials file permissions.")}}}async getCredentials(e){let t=O(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t,"utf-8").trim();if(!s)return null;let n=this.loadEncryptionKey(e),i=n?this.tryDecrypt(s,n):null;if(i){let c=this.tryParseCredentials(i);if(c)return c}return v("corruptFile","Warning: Credentials file is unreadable. Please run `entrydesk login` again."),null}catch{return null}}async setCredentials(e,t){o.ensureProfileDir(e);let s=O(e),n=this.getOrCreateEncryptionKey(e),i=this.encrypt(JSON.stringify(t),n);u.writeFileSync(s,i,{mode:384}),this.ensureSecureFilePermissions(s)}async deleteCredentials(e){let t=O(e);try{u.existsSync(t)&&u.unlinkSync(t)}catch{}}},M=class{keytarModule=null;keytarLoadAttempted=!1;keychainAvailable=null;async getKeytar(){if(this.keytarLoadAttempted)return this.keytarModule;this.keytarLoadAttempted=!0;try{let t=await import("keytar"),s=t&&typeof t=="object"&&"default"in t?t.default:t;this.keytarModule=pe(s)?s:null}catch{this.keytarModule=null}return this.keytarModule}getAccount(e){return`${ue}${e}`}async checkKeychainAvailability(){if(this.keychainAvailable!==null)return this.keychainAvailable;try{let e=await this.getKeytar();if(!e)return this.keychainAvailable=!1,!1;let t=`${de}${x.randomBytes(8).toString("hex")}`,s="test";await e.setPassword(A,t,s);let n=await e.getPassword(A,t),i=await e.deletePassword(A,t);return this.keychainAvailable=!!(i&&n===s),this.keychainAvailable}catch{return this.keychainAvailable=!1,!1}}async isAvailable(){return this.checkKeychainAvailability()}async getCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");let s=await t.getPassword(A,this.getAccount(e));if(!s)return null;let n=this.tryParseKeychainPayload(s);return n||v("corruptFile",`Warning: Keychain entry for profile "${e}" is unreadable.`),n}async setCredentials(e,t){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let s=await this.getKeytar();if(!s)throw new Error("Keytar module not available");let n=JSON.stringify(t);await s.setPassword(A,this.getAccount(e),n)}async deleteCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");await t.deletePassword(A,this.getAccount(e))}tryParseKeychainPayload(e){try{let t=JSON.parse(e);return Q(t)?t:null}catch{return null}}},j=class{keychainStorage=null;fileStorage=new N;keychainAvailable=null;initPromise=null;shouldForceFileStorage(){return process.env[ge]?.toLowerCase()==="true"}async initializeStorage(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}try{let e=new M,t=await e.isAvailable();this.keychainAvailable=t,this.keychainStorage=t?e:null}catch{this.keychainAvailable=!1,this.keychainStorage=null}!this.keychainAvailable&&!this.shouldForceFileStorage()&&(v("keychain","Keychain unavailable. Falling back to file-based credentials."),process.platform==="win32"&&v("windowsFile","Warning: File-based credentials on Windows may be readable by other users."))}async ensureInitialized(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}this.keychainAvailable===null&&(this.initPromise??=this.initializeStorage(),await this.initPromise)}disableKeychain(){this.shouldForceFileStorage()||v("keychain","Keychain error encountered. Falling back to file-based credentials."),this.keychainAvailable=!1,this.keychainStorage=null}async getKeychainStorage(){return await this.ensureInitialized(),this.shouldForceFileStorage()?null:this.keychainAvailable?this.keychainStorage:null}async getCredentials(e){let t=await this.getKeychainStorage();if(!t)return this.fileStorage.getCredentials(e);try{let n=await t.getCredentials(e);if(n)return n}catch{return this.disableKeychain(),this.fileStorage.getCredentials(e)}let s=await this.fileStorage.getCredentials(e);if(s)try{await t.setCredentials(e,s),await this.fileStorage.deleteCredentials(e)}catch{}return s}async setCredentials(e,t){let s=await this.getKeychainStorage();if(!s){await this.fileStorage.setCredentials(e,t);return}try{await s.setCredentials(e,t),await this.fileStorage.deleteCredentials(e)}catch{this.disableKeychain(),await this.fileStorage.setCredentials(e,t)}}async deleteCredentials(e){let t=await this.getKeychainStorage();if(t)try{await t.deleteCredentials(e)}catch{this.disableKeychain()}await this.fileStorage.deleteCredentials(e)}},g=new j,y={async saveAccessToken(r,e){let t=o.getEffectiveProfileName(e),s=await g.getCredentials(t)??{};s.accessToken=r,await g.setCredentials(t,s)},async getAccessToken(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.accessToken??null},async saveRefreshToken(r,e){let t=o.getEffectiveProfileName(e),s=await g.getCredentials(t)??{};s.refreshToken=r,await g.setCredentials(t,s)},async getRefreshToken(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.refreshToken??null},async saveEmail(r,e){let t=o.getEffectiveProfileName(e),s=await g.getCredentials(t)??{};s.email=r,await g.setCredentials(t,s)},async getEmail(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.email??null},async saveWorkspaceId(r,e){let t=o.getEffectiveProfileName(e),s=await g.getCredentials(t)??{};s.workspaceId=r,await g.setCredentials(t,s)},async getWorkspaceId(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.workspaceId??null},async saveAll(r,e){let t=o.getEffectiveProfileName(e);await g.setCredentials(t,r)},async getAll(r){let e=o.getEffectiveProfileName(r);return g.getCredentials(e)},async clear(r){let e=o.getEffectiveProfileName(r);await g.deleteCredentials(e)},async isLoggedIn(r){let e=o.getEffectiveProfileName(r);return(await g.getCredentials(e))?.accessToken!=null}};var K=class r{client;baseUrl;constructor(e,t){this.baseUrl=e||U(t),I().ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",process.env.DEBUG&&console.log("[DEBUG] ApiClient: SSL certificate validation disabled")),this.client=he.create({prefixUrl:this.baseUrl,timeout:3e4,retry:{limit:3,methods:["get","put","head","delete","options","trace"],statusCodes:[408,413,429,500,502,503,504]},hooks:{beforeError:[n=>(n.request?.headers&&(n.request.headers.delete("authorization"),n.request.headers.delete("Authorization")),n)]}})}getBaseUrl(){return this.baseUrl}async refreshOAuthToken(e){return this.client.post("v1/oauth/token",{json:{grant_type:"refresh_token",refresh_token:e.refreshToken,client_id:e.clientId}}).json()}async revokeOAuthToken(e){await this.client.post("v1/oauth/revoke",{json:{token:e.token,token_type_hint:"refresh_token",client_id:e.clientId}})}async getWorkspaces(e){try{return process.env.DEBUG&&console.log(`[DEBUG] Calling getWorkspaces API: ${this.baseUrl}/v1/workspaces`),await this.client.get("v1/workspaces",{headers:{Authorization:`Bearer ${e}`}}).json()}catch(t){throw process.env.DEBUG&&(console.error("[DEBUG] getWorkspaces error:",t),t instanceof Error&&"cause"in t&&console.error("[DEBUG] Error cause:",t.cause)),t}}async getAgents(e,t,s){let n={limit:s?.limit??100};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/availableAgents`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async createAgent(e,t,s){return await this.client.post(`v1/workspaces/${t}/agents`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateAgent(e,t,s,n){await this.client.put(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteAgent(e,t,s){await this.client.delete(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModels(e,t){return await this.client.get(`v1/workspaces/${t}/models`,{headers:{Authorization:`Bearer ${e}`}}).json()}async getConnectors(e,t){return await this.client.get(`v1/workspaces/${t}/availableConnectors`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:100,connectionStatus:"connected"}}).json()}async getChats(e,t,s=20){return await this.client.get(`v1/workspaces/${t}/chats`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:s}}).json()}async getMessages(e,t,s,n=50){return await this.client.get(`v1/workspaces/${t}/chats/${s}/messages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:n}}).json()}async getAgent(e,t,s){return await this.client.get(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async listAvailableSkills(e,t,s){return await this.client.get(`v1/workspaces/${t}/availableSkills`,{headers:{Authorization:`Bearer ${e}`},searchParams:{createdBy:s?.createdBy,nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async uploadSkill(e,t,s){return await this.client.post(`v1/workspaces/${t}/skills`,{headers:{Authorization:`Bearer ${e}`},body:s}).json()}async deleteSkill(e,t,s){await this.client.delete(`v1/workspaces/${t}/skills/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async downloadSkillCurrent(e,t,s){return await this.client.get(`v1/workspaces/${t}/skills/${s}/download`,{headers:{Authorization:`Bearer ${e}`}}).json()}async chat(e,t,s){try{let n=await this.client.post(`v1/workspaces/${t}/chats`,{headers:{Authorization:`Bearer ${e}`},json:s,timeout:6e4,throwHttpErrors:!1});if(!n.ok){let i=await n.text();throw new Error(`Chat API failed (${n.status}): ${i}`)}return n}catch(n){throw n instanceof ye?new TypeError("Request timed out. Please check your connection and try again.",{cause:n}):n}}async getBudget(e,t){return await this.client.get(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`}}).json()}async updateBudget(e,t,s){return await this.client.put(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`},json:{budget:s}}).json()}async getMonthlyUsages(e,t,s){return await this.client.get(`v1/workspaces/${t}/monthlyUsages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async createChatShare(e,t,s,n="public"){return await this.client.post(`v1/workspaces/${t}/chats/${s}/shares`,{headers:{Authorization:`Bearer ${e}`},json:{visibility:n}}).json()}async getSharedChat(e,t){let s={};return t&&(s.Authorization=`Bearer ${t}`),await this.client.get(`v1/shares/${e}`,{headers:s}).json()}async getSharedMessages(e,t=50,s){let n={};return s&&(n.Authorization=`Bearer ${s}`),await this.client.get(`v1/shares/${e}/messages`,{headers:n,searchParams:{limit:t}}).json()}async deleteChat(e,t,s){await this.client.delete(`v1/workspaces/${t}/chats/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModelProviders(e,t){return await this.client.get(`v1/workspaces/${t}/modelProviders`,{headers:{Authorization:`Bearer ${e}`}}).json()}async uploadFile(e,t,s,n){let i=new FormData,c=new Blob([s.buffer],{type:s.mimeType});return i.append("file",c,s.filename),i.append("modelProviderId",n),await this.client.post(`v1/workspaces/${t}/files`,{headers:{Authorization:`Bearer ${e}`},body:i,timeout:12e4}).json()}async getSchedules(e,t,s){let n={limit:s?.limit??20};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async getSchedule(e,t,s){return await this.client.get(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async createSchedule(e,t,s){return await this.client.post(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateSchedule(e,t,s,n){await this.client.put(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteSchedule(e,t,s){await this.client.delete(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}})}static async getAuthenticatedClient(e){let t=await y.getAll(e);return t?{client:new r(void 0,e),accessToken:t.accessToken,workspaceId:t.workspaceId??null}:null}};function me(){return process.env.ENTRYDESK_SANDBOX==="true"}function z(){if(!me())return null;let r=process.env.ENTRYDESK_SANDBOX_ACCESS_TOKEN?.trim(),e=process.env.ENTRYDESK_SANDBOX_WORKSPACE_ID?.trim();if(!r||!e){let t=[];throw r||t.push("ENTRYDESK_SANDBOX_ACCESS_TOKEN"),e||t.push("ENTRYDESK_SANDBOX_WORKSPACE_ID"),new Error(`Sandbox mode enabled but missing credentials: ${t.join(", ")}`)}return{accessToken:r,workspaceId:e}}function ee(){let r=process.env.ENTRYDESK_TOKEN?.trim();if(!r)return null;let e=process.env.ENTRYDESK_WORKSPACE_ID?.trim();if(!e)throw new Error("ENTRYDESK_TOKEN is set but ENTRYDESK_WORKSPACE_ID is missing. Both are required for PAT authentication.");return{accessToken:r,workspaceId:e}}import{execFile as we}from"child_process";import{setTimeout as ve}from"timers/promises";import{decodeJwt as ke}from"jose";import Pe,{HTTPError as Se}from"ky";var D="entrydesk-cli",Ce="offline_access workspaces:read chats:read chats:write chats:delete agents:read agents:write connectors:read connectors:write tools:read tools:execute skills:read skills:write meetings:read meetings:write publishes:read publishes:write calendar:read calendar:write schedules:read schedules:write user:read user:write";function Ae(r){return new Promise((e,t)=>{let s=process.platform,n,i;switch(s){case"darwin":n="open",i=[r];break;case"win32":n="cmd",i=["/c","start","",r];break;default:n="xdg-open",i=[r];break}we(n,i,c=>{c?t(new Error(`Failed to open browser. Please manually visit: ${r}`,{cause:c})):e()})})}async function tt(r){let e=U(),t=te(),s=I(),n=process.env.NODE_TLS_REJECT_UNAUTHORIZED;s.ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",console.error("WARNING: SSL certificate validation is disabled globally for this process during the login flow. All connections in this process will skip TLS verification. Only use ENTRYDESK_IGNORE_SSL_ERRORS for local development."));try{let i=Pe.create({prefixUrl:e,timeout:3e4,hooks:{beforeError:[a=>(a.request?.headers&&(a.request.headers.delete("authorization"),a.request.headers.delete("Authorization")),a)]}}),c;try{c=await i.post("v1/oauth/device/code",{json:{client_id:D,scope:Ce}}).json()}catch(a){let w=a instanceof Error?a:new Error("Failed to request device code");throw r?.onError?.(w),w}let{device_code:S,user_code:d,expires_in:oe,interval:ae}=c,J=new URL("/oauth/device",t);J.searchParams.set("user_code",d);let q=J.toString();r?.onDeviceCodeReceived?.(d,q),r?.onBrowserOpening?.();try{await Ae(q)}catch(a){process.env.DEBUG&&console.error("[DEBUG] Failed to open browser:",a)}r?.onWaitingForAuthorization?.();let V=Math.max(ae,5)*1e3,ce=Date.now()+oe*1e3;for(;Date.now()<ce;){await ve(V);try{let a=await i.post("v1/oauth/token",{json:{grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:S,client_id:D}}).json();r?.onAuthorized?.();let w={};try{w=ke(a.access_token)}catch{}return{accessToken:a.access_token,refreshToken:a.refresh_token??void 0,email:w.email||"",scopes:a.scope.split(" ").filter(R=>R.length>0)}}catch(a){if(a instanceof Se){let R;try{let X=await a.response.json();R=X.code||X.error}catch{continue}switch(R){case"authorization_pending":continue;case"slow_down":V+=5e3;continue;case"access_denied":throw new Error("Authorization denied by user",{cause:a});case"expired_token":throw new Error("Device code expired. Please try again.",{cause:a});default:throw new Error(`Authorization failed: ${R||"Unknown error"}`,{cause:a})}}let w=a instanceof Error?a:new Error("Unknown error during authorization");throw r?.onError?.(w),w}}throw new Error("Device code expired. Please try again.")}finally{n===void 0?delete process.env.NODE_TLS_REJECT_UNAUTHORIZED:process.env.NODE_TLS_REJECT_UNAUTHORIZED=n}}var m=class extends Error{code;constructor(e,t){super(t),this.code=e}};function be(r){try{let e=r.split(".");if(e.length<2)return null;let t=e[1].replace(/-/g,"+").replace(/_/g,"/"),s=(4-t.length%4)%4,n=t.padEnd(t.length+s,"="),i=Buffer.from(n,"base64").toString("utf8");return JSON.parse(i)}catch{return null}}function Ee(r,e=300){let s=be(r)?.exp;if(typeof s!="number")return!1;let n=Math.floor(Date.now()/1e3);return s-n<=e}async function re(r){let e=r.accessToken;if(!Ee(e))return e;if(!r.refreshToken)throw await y.clear(),new m("session-expired","Session expired. Please run `entrydesk login` again.");try{let s=await new K().refreshOAuthToken({refreshToken:r.refreshToken,clientId:D});return await y.saveAccessToken(s.access_token),s.refresh_token&&await y.saveRefreshToken(s.refresh_token),s.access_token}catch{throw await y.clear(),new m("session-expired","Session expired. Please run `entrydesk login` again.")}}async function at(){let r=z();if(r)return r.accessToken;let e=await y.getAll();if(!e?.accessToken)throw new m("not-logged-in","Not logged in. Run `entrydesk login` first.");return re(e)}async function ct(){let r=z();if(r)return{accessToken:r.accessToken,workspaceId:r.workspaceId};let e=ee();if(e)return e;let t=await y.getAll();if(!t?.accessToken)throw new m("not-logged-in","Not logged in. Run `entrydesk login` first.");if(!t.workspaceId)throw new m("no-workspace","No workspace selected. Run `entrydesk workspaces` first.");return{accessToken:await re(t),workspaceId:t.workspaceId}}var f=class extends Error{constructor(t,s=1,n){super(t);this.exitCode=s;this.cause=n;this.name="CLIError"}};function ut(r){let e=!!process.env.DEBUG;r instanceof f&&(console.error(`Error: ${r.message}`),r.cause&&(console.error(`Cause: ${r.cause.message}`),e&&r.cause.stack&&console.error(r.cause.stack)),process.exit(r.exitCode)),r instanceof m&&(console.error(r.message),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof xe&&(console.error("Request timed out. Please check your connection and try again."),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Re&&(console.error(`Request failed (${r.response.status}): ${r.response.statusText}`),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Error&&(console.error(`Unexpected error: ${r.message}`),e&&r.stack&&console.error(r.stack),process.exit(1)),console.error("An unknown error occurred"),process.exit(1)}var P="default",_e=/^[A-Za-z0-9_-]+$/,L=null;function H(){return E.join(Te.homedir(),".entrydesk")}function ne(){return E.join(H(),"profiles")}function ie(){return E.join(H(),"profiles.json")}function $(r){return E.join(ne(),r)}function G(r){if(!p.existsSync(r))p.mkdirSync(r,{mode:448,recursive:!0});else try{p.chmodSync(r,448)}catch{}}function Ke(){G(H())}function W(){G(ne())}function Ue(){let r=ie();try{if(!p.existsSync(r))return null;let e=p.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}function b(r){Ke();let e=ie();p.writeFileSync(e,JSON.stringify(r,null,2),{mode:384});try{p.chmodSync(e,384)}catch{}}function Ie(r){let e=r.profiles?.length?Array.from(new Set(r.profiles)):[],t=r.currentProfile&&e.includes(r.currentProfile)?r.currentProfile:e[0]||P;return e.length===0&&e.push(P),e.includes(t)||e.unshift(t),{currentProfile:t,profiles:e}}function k(){let r=Ue();if(!r){let t={currentProfile:P,profiles:[P]};return b(t),W(),_(P),t}let e=Ie(r);return(e.currentProfile!==r.currentProfile||e.profiles.length!==r.profiles.length)&&b(e),W(),e}function C(r){if(!r)throw new f("Profile name is required.");if(!_e.test(r))throw new f("Invalid profile name. Use letters, numbers, dash, or underscore.")}function T(r,e){if(!r.profiles.includes(e))throw new f(`Profile not found: ${e}`)}function se(r,e){if(r.profiles.includes(e))throw new f(`Profile already exists: ${e}`)}function _(r){W(),G($(r))}var o={DEFAULT_PROFILE:P,setOverrideProfile(r){L=r},getOverrideProfile(){return L},getProfileDir(r){return $(r)},getProfileConfigFile(r){return E.join(o.getProfileDir(r),"config.json")},getProfileCredentialsFile(r){return E.join(o.getProfileDir(r),"credentials.json")},getProfileNames(){return[...k().profiles]},getProfileCount(){return o.getProfileNames().length},getCurrentProfileName(){return k().currentProfile},getEffectiveProfileName(r){let e=k(),t=r||L||e.currentProfile;return C(t),T(e,t),t},ensureProfileExists(r){let e=k();C(r),T(e,r)},createProfile(r){C(r);let e=k();se(e,r);let t={currentProfile:e.currentProfile,profiles:[...e.profiles,r]};b(t),_(r)},deleteProfile(r){C(r);let e=k();if(T(e,r),e.profiles.length===1)throw new f("Cannot delete the last profile.");let t=e.profiles.filter(i=>i!==r),s=e.currentProfile;s===r&&(s=t.includes(P)?P:t[0]),b({currentProfile:s,profiles:t});try{p.rmSync(o.getProfileDir(r),{recursive:!0,force:!0})}catch{}return{currentProfile:s}},renameProfile(r,e){C(r),C(e);let t=k();T(t,r),se(t,e);let s=$(r),n=$(e);if(p.existsSync(s))try{p.renameSync(s,n)}catch(d){throw new f("Failed to rename profile directory.",1,d)}else _(e);let i=t.profiles.map(d=>d===r?e:d),c=t.currentProfile===r?e:t.currentProfile;return b({currentProfile:c,profiles:i}),{currentProfile:c}},setCurrentProfile(r){C(r);let e=k();T(e,r);let t={currentProfile:r,profiles:e.profiles};b(t),_(r)},ensureProfileDir:_};function De(r){let e=o.getEffectiveProfileName(r);return o.getProfileConfigFile(e)}function l(r){let e=De(r);try{if(!F.existsSync(e))return{};let t=F.readFileSync(e,"utf-8");return JSON.parse(t)}catch{return{}}}function h(r,e){let t=o.getEffectiveProfileName(e);o.ensureProfileDir(t);let s=o.getProfileConfigFile(t);F.writeFileSync(s,JSON.stringify(r,null,2),{mode:384});try{F.chmodSync(s,384)}catch{}}var Y={getApiUrl(r){return l(r).apiUrl??null},setApiUrl(r,e){let t=l(e);t.apiUrl=r,h(t,e)},clearApiUrl(r){let e=l(r);delete e.apiUrl,h(e,r)},getHubUrl(r){return l(r).hubUrl??null},setHubUrl(r,e){let t=l(e);t.hubUrl=r,h(t,e)},getAll(r){return l(r)},setAll(r,e){h(r,e)},set(r,e,t){let s=l(t);s[r]=e,h(s,t)},get(r,e){return l(e)[r]},unset(r,e){let t=l(e);delete t[r],h(t,e)},getDefaultModel(r){return l(r).model?.default??null},setDefaultModel(r,e){let t=l(e);t.model={...t.model,default:r},h(t,e)},getDefaultConnectorIds(r){return l(r).connectors?.defaults??null},setDefaultConnectorIds(r,e){let t=l(e);t.connectors={...t.connectors,defaults:r},h(t,e)},getCapabilities(r){return l(r).capabilities??null},setCapabilities(r,e){let t=l(e);t.capabilities={...t.capabilities,...r},h(t,e)},getLocalTools(r){return l(r).localTools??null},setLocalTools(r,e){let t=l(e);t.localTools={...t.localTools,...r},h(t,e)}};var $e="https://api.entrydesk.com",Fe="https://app.entrydesk.com",Be=3100,Oe=300*1e3;function B(r){return{apiUrl:Y.getApiUrl(r)||process.env.ENTRYDESK_API_URL||$e,hubUrl:Y.getHubUrl(r)||process.env.ENTRYDESK_HUB_URL||Fe,mcp:{httpPort:Be},auth:{loginTimeout:Oe,ignoreSslErrors:process.env.ENTRYDESK_IGNORE_SSL_ERRORS==="true"||!1}}}function U(r){return B(r).apiUrl}function te(r){return B(r).hubUrl}function Ct(){return B().mcp}function I(){return B().auth}export{o as a,Y as b,B as c,U as d,te as e,Ct as f,I as g,y as h,K as i,D as j,tt as k,m as l,Ee as m,re as n,at as o,ct as p,f as q,ut as r};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as f,b as s}from"./chunk-
|
|
2
|
+
import{a as f,b as s}from"./chunk-GIUYIB5E.js";var i=["apiUrl","hubUrl"];function l(e){return i.includes(e)}async function d(e){let n=e.action||"list",o=e.configKey,t=e.value,a=f.getEffectiveProfileName();if(n==="list"){let r=s.getAll(),c=Object.entries(r);if(e.json){console.log(JSON.stringify(r));return}if(console.log(`Profile: ${a}`),c.length===0){console.log("No configuration set."),console.log(`Available keys: ${i.join(", ")}`);return}console.log(`Configuration:
|
|
3
3
|
`);for(let[g,u]of c)console.log(` ${g}=${u}`);console.log(`
|
|
4
4
|
Available keys: ${i.join(", ")}`);return}if(n==="get"){o||(console.error("Error: key is required for get action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1));let r=s.get(o);e.json?console.log(JSON.stringify({[o]:r??null})):console.log(r||"Not set");return}if(n==="set"){o||(console.error("Error: key is required for set action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),t||(console.error("Error: value is required for set action"),process.exit(1)),s.set(o,t),console.log(`Set ${o}=${t}`);return}if(n==="unset"){o||(console.error("Error: key is required for unset action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),s.unset(o),console.log(`Unset ${o}`);return}console.error(`Unknown action: ${n}`),process.exit(1)}export{d as runConfig};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as a,d as b,e as c,f as d,g as e}from"./chunk-
|
|
2
|
+
import{c as a,d as b,e as c,f as d,g as e}from"./chunk-GIUYIB5E.js";export{b as getApiUrl,e as getAuthConfig,a as getConfig,c as getHubUrl,d as getMcpConfig};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as r}from"./chunk-
|
|
2
|
+
import{c as r}from"./chunk-GIUYIB5E.js";import{Box as i,Text as e,render as l}from"ink";import{jsx as t,jsxs as n}from"react/jsx-runtime";function g(){l(t(a,{}))}function a(){let o=r();return n(i,{flexDirection:"column",children:[t(e,{bold:!0,children:"entrydesk config"}),t(e,{children:" "}),t(e,{children:"Manage CLI configuration"}),t(e,{children:" "}),t(e,{bold:!0,children:"Usage:"}),t(e,{children:" entrydesk config List all configuration"}),n(e,{children:[" entrydesk config get ","<key>"," Get a configuration value"]}),n(e,{children:[" ","entrydesk config set ","<key>"," ","<value>"," Set a configuration value"]}),n(e,{children:[" ","entrydesk config unset ","<key>"," Remove a configuration value"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Available keys:"}),n(e,{children:[" apiUrl API server URL (default: ",o.apiUrl,")"]}),n(e,{children:[" hubUrl Hub server URL (default: ",o.hubUrl,")"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Examples:"}),t(e,{children:" entrydesk config set apiUrl http://localhost:3200"}),t(e,{children:" entrydesk config get apiUrl"}),t(e,{children:" entrydesk config unset apiUrl"})]})}export{a as ConfigHelp,g as renderConfigHelp};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{i as c,p as s,r as i}from"./chunk-
|
|
2
|
+
import{i as c,p as s,r as i}from"./chunk-GIUYIB5E.js";async function p(l){try{let n,t;try{let o=await s();n=o.accessToken,t=o.workspaceId}catch(o){let r=o instanceof Error?o.message:"Authentication failed";console.error(r),process.exit(1)}let a=new c,{connectors:e}=await a.getConnectors(n,t);if(l.json){console.log(JSON.stringify(e));return}if(e.length===0){console.log("No connectors found in this workspace.");return}console.log(`Connected Connectors (${e.length}):
|
|
3
3
|
`);for(let o of e){let r=o.connected?"connected":"disconnected";console.log(` ${o.name} (${r})`),console.log(` Provider: ${o.provider}`),console.log(` ID: ${o.id}`),console.log("")}}catch(n){i(n)}}export{p as runConnectors};
|
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as l,r as p}from"./chunk-
|
|
2
|
+
import{a as l,r as p}from"./chunk-GIUYIB5E.js";function u(s,f,d=!1){let r={},e={};for(let a=d?0:1;a<s.length;a++){let t=s[a];if(t==="--json")r.json=!0;else if(t==="--help"||t==="-h")r.help=!0;else if(t==="--profile")r.profile=s[++a];else switch(f){case"login":break;case"chat":if(t==="-m"||t==="--message")e.message=s[++a];else if(t==="-a"||t==="--agent")e.agentId=s[++a];else if(t==="--model")e.model=s[++a];else if(t==="--connectors"){let i=s[++a];e.connectors=i?.split(",").map(n=>n.trim())}else t==="-i"||t==="--interactive"?e.interactive=!0:t==="--full-output"?e.fullOutput=!0:t==="-c"||t==="--continue"?e.continue=parseInt(s[++a],10):t==="--plain"?e.plain=!0:t==="--output"?e.output=s[++a]:t==="--sandbox"?e.sandbox=!0:t==="--no-sandbox"?e.noSandbox=!0:t==="--web-search"?e.webSearch=!0:t==="--image-gen"?e.imageGen=!0:t==="--chart"?e.chart=!0:t==="--file-system"?e.fileSystem=!0:t==="--no-file-system"?e.noFileSystem=!0:t==="--dangerously-auto-approve-tools"&&(e.dangerouslyAutoApproveTools=!0);break;case"agents":if(t==="--name")e.name=s[++a];else if(t==="--description")e.description=s[++a];else if(t==="--system-prompt")e.systemPrompt=s[++a];else if(t==="--model-id")e.modelId=s[++a];else if(t==="--connector-ids"){let i=s[++a];e.connectorIds=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--capabilities"){let i=s[++a];e.capabilities=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--conversation-starters"){let i=s[++a];e.conversationStarters=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--tools"){let i=s[++a];e.tools=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--icon-id")e.iconId=s[++a];else if(t==="--limit"){let i=parseInt(s[++a],10);(isNaN(i)||i<1||i>100)&&(console.error("--limit must be an integer between 1 and 100"),process.exit(1)),e.limit=i}else if(t==="--next-key"){let i=s[++a];i||(console.error("--next-key requires a value"),process.exit(1)),e.nextKey=i}else t==="--all"?e.all=!0:t.startsWith("-")||(e.action?e.agentId=t:e.action=t);break;case"skills":t==="--force"?e.force=!0:t==="--me"||t==="--mine"?e.createdBy="me":t.startsWith("-")||(e.action?e.configKey=t:e.action=t);break;case"schedules":if(t==="--name")e.name=s[++a];else if(t==="--prompt")e.prompt=s[++a];else if(t==="--agent-id")e.agentId=s[++a];else if(t==="--starts-at")e.startsAt=s[++a];else if(t==="--utc-offset")e.utcOffset=s[++a];else if(t==="--repeat-type")e.repeatType=s[++a];else if(t==="--every")e.every=parseInt(s[++a],10);else if(t==="--time")e.time=s[++a];else if(t==="--days-of-week"){let i=s[++a];e.daysOfWeek=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else if(t==="--days-of-month"){let i=s[++a];e.daysOfMonth=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else t==="--last-day-of-month"?e.lastDayOfMonth=!0:t.startsWith("-")||(e.action?e.scheduleId=t:e.action=t);break;case"config":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")?e.configKey=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"profile":!e.action&&!t.startsWith("-")?e.action=t:!e.name&&!t.startsWith("-")?e.name=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"chats":t==="--share"||t==="-s"?e.shareId=s[++a]:t==="--full-output"?e.fullOutput=!0:t==="--output"?e.output=s[++a]:!e.chatId&&!t.startsWith("-")&&(e.chatId=t);break;case"budget":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")&&(e.configKey=t);break;case"usage":if(t==="--limit")e.limit=parseInt(s[++a],10);else if(t==="--sort-by"){let i=s[++a];(i==="cost"||i==="operations")&&(e.sortBy=i)}break;case"mcp-server":t==="--http"?e.http=!0:(t==="-p"||t==="--port")&&(e.port=parseInt(s[++a],10));break;case"tool":t==="-i"||t==="--input"?e.input=s[++a]:t==="-f"||t==="--input-file"?e.inputFile=s[++a]:t==="-p"||t==="--prefix"?e.prefix=s[++a]:t.startsWith("-")||(e.action?e.name||(e.name=t):e.action=t);break;case"workspaces":!e.action&&!t.startsWith("-")&&(e.action=t);break;default:break}}switch(f){case"login":return{command:"login",...r,...e};case"logout":return{command:"logout",...r,...e};case"status":return{command:"status",...r,...e};case"workspaces":return{command:"workspaces",...r,...e};case"agents":return{command:"agents",...r,...e};case"models":return{command:"models",...r,...e};case"connectors":return{command:"connectors",...r,...e};case"skills":return{command:"skills",...r,...e};case"schedules":return{command:"schedules",...r,...e};case"config":return{command:"config",...r,...e};case"profile":return{command:"profile",...r,...e};case"chat":return{command:"chat",...r,...e};case"chats":return{command:"chats",...r,...e};case"budget":return{command:"budget",...r,...e};case"usage":return{command:"usage",...r,...e};case"mcp-server":return{command:"mcp-server",...r,...e};case"tool":return{command:"tool",...r,...e};case"version":return{command:"version",...r,...e};default:return{command:"help",...r,...e}}}var c=process.argv.slice(2);if(c[0]==="--help"||c[0]==="-h"){let{printHelp:s}=await import("./help-Z5YLPTUZ.js");s(),process.exit(0)}if(c[0]==="--version"||c[0]==="-v"){let{printVersion:s}=await import("./version-3ARCFM7W.js");s(),process.exit(0)}var m=!c[0]||c[0].startsWith("-"),h=m?"chat":c[0],o=u(c,h,m);m&&o.command==="chat"&&(o.interactive=!0);async function g(){try{if(o.command!=="profile"){let s=o.profile||l.getCurrentProfileName();l.ensureProfileExists(s),l.setOverrideProfile(s)}switch(o.command){case"login":{let{runLogin:s}=await import("./login-I2YZBF3J.js");await s(o);break}case"logout":{let{runLogout:s}=await import("./logout-SXTN4T2O.js");await s(o);break}case"status":{let{runStatus:s}=await import("./status-56L4JVYX.js");await s(o);break}case"workspaces":{let{runWorkspaces:s}=await import("./workspaces-JO4RT6UA.js");await s(o);break}case"agents":{let{runAgents:s}=await import("./agents-VXW275KJ.js");await s(o);break}case"models":{let{runModels:s}=await import("./models-4TPZZCHY.js");await s(o);break}case"connectors":{let{runConnectors:s}=await import("./connectors-NU4CMNGK.js");await s(o);break}case"skills":{let{runSkills:s}=await import("./skills-5OI5GFCZ.js");await s(o);break}case"schedules":{let{runSchedules:s}=await import("./schedules-YBMVIND4.js");await s(o);break}case"chats":{let{runChats:s}=await import("./chats-RSDRD5DF.js");await s(o);break}case"budget":{let{runBudget:s}=await import("./budget-3M4AZTD7.js");await s(o);break}case"usage":{let{runUsage:s}=await import("./usage-VZ5VJVTO.js");await s(o);break}case"config":{if(o.action==="help"||c[1]==="--help"){let{renderConfigHelp:s}=await import("./config-help-TKBWLL6J.js");s()}else{let{runConfig:s}=await import("./config-DNYBZSPQ.js");await s(o)}break}case"profile":{let{runProfile:s}=await import("./profile-J6L7MJWK.js");await s(o);break}case"chat":{if(c[1]==="--help"||c[1]==="-h"){let{printHelp:s}=await import("./help-Z5YLPTUZ.js");s()}else{let{runChat:s}=await import("./chat-DOV7VJMR.js");await s(o)}break}case"mcp-server":{let{startMcpServer:s}=await import("./mcp-GU4IRQE2.js");await s({mode:o.http?"http":"stdio",port:o.port});break}case"tool":{let{runTool:s}=await import("./tool-B6Y4W75M.js");await s(o);break}case"version":{let{printVersion:s}=await import("./version-3ARCFM7W.js");s();break}default:{let{printHelp:s}=await import("./help-Z5YLPTUZ.js");s();break}}}catch(s){p(s)}}g();
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{h as l,i as c,k as t}from"./chunk-
|
|
2
|
+
import{h as l,i as c,k as t}from"./chunk-GIUYIB5E.js";async function m(e){if(process.env.DEBUG){let{getApiUrl:i,getHubUrl:s}=await import("./config-GB3HY2CY.js");console.log(`[DEBUG] Hub URL: ${s()}`),console.log(`[DEBUG] API URL: ${i()}`)}let o=await t({onDeviceCodeReceived:(i,s)=>{e.json||(console.log(""),console.log("To authenticate, please:"),console.log(""),console.log(` 1. Visit: ${s}`),console.log(` 2. Enter code: ${i}`),console.log(""))},onBrowserOpening:()=>{e.json||console.log("Opening browser...")},onWaitingForAuthorization:()=>{e.json||console.log("Waiting for authorization...")},onAuthorized:()=>{e.json||console.log("Authorization successful!")}}),r=new c,{workspaces:a}=await r.getWorkspaces(o.accessToken),n=a[0];await l.saveAll({accessToken:o.accessToken,refreshToken:o.refreshToken,email:o.email,workspaceId:n?.id}),e.json?console.log(JSON.stringify({email:o.email,workspaceId:n?.id,workspaceName:n?.name})):(console.log(`Logged in as ${o.email}`),n&&console.log(`Workspace: ${n.name}`))}export{m as runLogin};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{h as r,i as e,j as t,r as n}from"./chunk-
|
|
2
|
+
import{h as r,i as e,j as t,r as n}from"./chunk-GIUYIB5E.js";async function f(i){try{let o=await r.getAll();if(!o){console.log("Not logged in");return}try{o.refreshToken&&await new e().revokeOAuthToken({token:o.refreshToken,clientId:t})}catch{}await r.clear(),console.log("Logged out successfully")}catch(o){n(o)}}export{f as runLogout};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as m,h as u,m as y,n as w,p as f}from"./chunk-
|
|
2
|
+
import{c as m,h as u,m as y,n as w,p as f}from"./chunk-GIUYIB5E.js";import h from"http";import{stderr as T}from"process";import{Client as k}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as C}from"@modelcontextprotocol/sdk/client/streamableHttp.js";import{Server as v}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as P}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as A}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{CallToolRequestSchema as O,ListToolsRequestSchema as E}from"@modelcontextprotocol/sdk/types.js";function a(c){T.write(`${c}
|
|
3
3
|
`)}async function g(c,e,o){let r=new k({name:"entrydesk-cli-proxy",version:"1.0.0"}),i=new URL(`${c}/v1/workspaces/${o}/mcp`),t=new C(i,{requestInit:{headers:{Authorization:`Bearer ${e}`}}});return await r.connect(t),r}function S(c){let e=new v({name:"entrydesk-cli",version:"1.0.0"},{capabilities:{tools:{}}});return e.setRequestHandler(E,async()=>({tools:(await(await c()).listTools()).tools})),e.setRequestHandler(O,async o=>{let{name:r,arguments:i}=o.params,n=await(await c()).callTool({name:r,arguments:i}),l=Array.isArray(n.content)?[...n.content]:[];return n.structuredContent&&l.push({type:"text",text:JSON.stringify(n.structuredContent,null,2)}),{content:l,structuredContent:n.structuredContent,isError:n.isError}}),e}async function H(c,e,o){let r=h.createServer(async(i,t)=>{if(i.method==="OPTIONS"){t.setHeader("Access-Control-Allow-Origin","*"),t.setHeader("Access-Control-Allow-Methods","GET, POST, DELETE, OPTIONS"),t.setHeader("Access-Control-Allow-Headers","Content-Type, Accept"),t.writeHead(204),t.end();return}if(i.url!=="/mcp"){t.writeHead(404,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Not found"}));return}let n=S(c),l=new A({sessionIdGenerator:void 0});if(t.setHeader("Access-Control-Allow-Origin","*"),t.on("close",()=>{l.close(),n.close()}),await n.connect(l),i.method==="POST"){let p="";i.on("data",s=>{p+=s.toString()}),i.on("end",async()=>{try{let s=JSON.parse(p);await l.handleRequest(i,t,s)}catch{t.writeHead(400,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Invalid JSON"}))}})}else await l.handleRequest(i,t)});r.listen(o,()=>{a(`EntryDesk MCP server running at http://localhost:${o}/mcp`),a("Press Ctrl+C to stop")}),process.on("SIGINT",async()=>{a(`
|
|
4
4
|
Shutting down...`),r.close(),await e(),process.exit(0)}),process.on("SIGTERM",async()=>{r.close(),await e(),process.exit(0)})}async function x(c,e){let o=S(c),r=new P;r.onclose=async()=>{await e()},await o.connect(r)}async function L(c={mode:"stdio"}){process.on("unhandledRejection",e=>{console.error("[entrydesk-mcp] Unhandled rejection:",e)}),process.on("uncaughtException",e=>{console.error("[entrydesk-mcp] Uncaught exception:",e)});try{a("[entrydesk-mcp] Starting MCP server...");let e,o;try{let s=await f();e=s.accessToken,o=s.workspaceId}catch(s){let d=s instanceof Error?s.message:"Authentication failed";console.error(d),process.exit(1)}let{apiUrl:r,mcp:i}=m();a(`[entrydesk-mcp] Connecting to ${r}...`),a(`[entrydesk-mcp] Workspace: ${o}`);let t=await g(r,e,o);a("[entrydesk-mcp] Connected to EntryDesk API");let n=null,l=async()=>y(e)?n||(n=(async()=>{a("[entrydesk-mcp] Token expiring soon, refreshing...");let s=await u.getAll();if(!s?.accessToken)throw new Error("Not logged in. Please run `entrydesk login` again.");let d=await w(s);if(d!==e){e=d;try{await t.close()}catch{}t=await g(r,e,o),a("[entrydesk-mcp] Token refreshed, reconnected")}return t})().finally(()=>{n=null}),n):t,p=async()=>{try{await t.close()}catch{}};if(c.mode==="http"){let s=c.port??i.httpPort;await H(l,p,s)}else a("[entrydesk-mcp] Starting stdio server..."),await x(l,p),a("[entrydesk-mcp] Stdio server started")}catch(e){console.error("[entrydesk-mcp] Fatal error:",e),process.exit(1)}}export{L as startMcpServer};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{i as n,p as t,r as l}from"./chunk-
|
|
2
|
+
import{i as n,p as t,r as l}from"./chunk-GIUYIB5E.js";async function p(c){try{let e,r;try{let o=await t();e=o.accessToken,r=o.workspaceId}catch(o){let a=o instanceof Error?o.message:"Authentication failed";console.error(a),process.exit(1)}let i=new n,{models:s}=await i.getModels(e,r);if(c.json){console.log(JSON.stringify(s));return}if(s.length===0){console.log("No models available in this workspace.");return}console.log(`Available Models (${s.length}):
|
|
3
3
|
`);for(let o of s)console.log(` ${o.name}`),o.description&&console.log(` ${o.description.slice(0,80)}`),console.log(` ID: ${o.id}`),console.log("")}catch(e){l(e)}}export{p as runModels};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as t,b as u,h as m,q as f,r as d}from"./chunk-
|
|
2
|
+
import{a as t,b as u,h as m,q as f,r as d}from"./chunk-GIUYIB5E.js";function h(){console.log(`
|
|
3
3
|
Usage: entrydesk profile [list|show|current|create|use|delete|rename|clone] [args]
|
|
4
4
|
|
|
5
5
|
Commands:
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{i as S,p as z,r as I}from"./chunk-
|
|
2
|
+
import{i as S,p as z,r as I}from"./chunk-GIUYIB5E.js";import U from"crypto";import g from"fs";import i from"fs/promises";import b from"os";import o from"path";import{Readable as A}from"stream";import{pipeline as E}from"stream/promises";import j from"adm-zip";import N from"archiver";function D(){console.log(`
|
|
3
3
|
Usage: entrydesk skills [list|upload|delete|download] [options]
|
|
4
4
|
|
|
5
5
|
Commands:
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as i,b as r,h as c,i as a,l as g,o as f,r as p}from"./chunk-
|
|
2
|
+
import{a as i,b as r,h as c,i as a,l as g,o as f,r as p}from"./chunk-GIUYIB5E.js";async function A(s){try{let o=i.getEffectiveProfileName(),e=await c.getAll(),n={model:r.getDefaultModel(),connectors:r.getDefaultConnectorIds(),capabilities:r.getCapabilities()};if(!e){s.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let t;if(e.workspaceId)try{let l=new a,d=await f(),{workspaces:m}=await l.getWorkspaces(d);t=m.find(k=>k.id===e.workspaceId)?.name}catch(l){if(l instanceof g){s.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}}s.json?console.log(JSON.stringify({loggedIn:!0,profile:o,email:e.email,workspaceId:e.workspaceId,workspaceName:t,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Logged in as ${e.email}`),t&&console.log(`Workspace: ${t}`),e.workspaceId&&console.log(`Workspace ID: ${e.workspaceId}`))}catch(o){p(o)}}export{A as runStatus};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as S,p as _}from"./chunk-
|
|
2
|
+
import{c as S,p as _}from"./chunk-GIUYIB5E.js";import B from"fs";import{Client as E}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as L}from"@modelcontextprotocol/sdk/client/streamableHttp.js";async function A(e={}){let t=e.apiUrl,n=e.accessToken,o=e.workspaceId;if(!n||!o){let l=await _();n=n||l.accessToken,o=o||l.workspaceId}t||(t=S().apiUrl);let s=new E({name:"entrydesk-cli",version:"1.0.0"}),i=new URL(`${t}/v1/workspaces/${o}/mcp`),r=new L(i,{requestInit:{headers:{Authorization:`Bearer ${n}`}}});return await s.connect(r),s}async function T(){return A()}import h from"fs/promises";import v from"os";import d from"path";var y=!process.env.NO_COLOR&&!!process.stdout.isTTY,p={green:y?"\x1B[32m":"",yellow:y?"\x1B[33m":"",reset:y?"\x1B[0m":""},D=10*1024,O=8*1024,I=2*1024,P=100,b=100;function M(){return d.join(v.homedir(),".entrydesk","tool-results")}function F(e){let t=e.trim().replace(/[/\\:*?"<>|\s]/g,"_").replace(/_+/g,"_").replace(/^[._]+|[._]+$/g,"").slice(0,P);return!t||t==="."||t===".."?"unnamed_tool":t}function J(e){try{return JSON.stringify(e,(t,n)=>typeof n=="bigint"?`${n}n`:typeof n=="function"?"[Function]":typeof n=="symbol"?n.toString():n,2)}catch{return String(e)}}function U(e){let t=new Date,n=[t.getFullYear(),String(t.getMonth()+1).padStart(2,"0"),String(t.getDate()).padStart(2,"0")].join("-")+"_"+[String(t.getHours()).padStart(2,"0"),String(t.getMinutes()).padStart(2,"0"),String(t.getSeconds()).padStart(2,"0")].join("-"),o=F(e);return`${n}_${o}.json`}async function N(e,t){try{return await h.writeFile(e,t,{encoding:"utf8",flag:"wx"}),!0}catch(n){if(n instanceof Error&&"code"in n&&n.code==="EEXIST")return!1;throw n}}async function C(e,t){try{let n=M();await h.mkdir(n,{recursive:!0});let o=U(e),s=d.extname(o),i=o.slice(0,-s.length),r=J(t),l=d.join(n,o);if(await N(l,r))return l;for(let u=1;u<=b;u++){let w=d.join(n,`${i}-${u}${s}`);if(await N(w,r))return w}let c=Math.random().toString(36).slice(2,10),a=d.join(n,`${i}-${c}${s}`);return await h.writeFile(a,r,{encoding:"utf8",flag:"wx"}),a}catch(n){let o=n instanceof Error?n.message:"unknown error";return console.error(`${p.yellow}Warning: Could not save result to file: ${o}${p.reset}`),null}}function k(e,t){let n=Buffer.byteLength(e,"utf8");if(n<=D)return e;let o=e.slice(0,O),s=e.slice(-I),r=((n-O-I)/1024).toFixed(1),l=(n/1024).toFixed(1),c=` ... (skipped ${r}KB of ${l}KB) ...`;return t&&(c+=`
|
|
3
3
|
Tip: jq -r '.structuredContent.field' <file> | grep/head/tail`),`${o}
|
|
4
4
|
|
|
5
5
|
${c}
|
package/package.json
CHANGED
package/dist/chat-4JHCW4MC.js
DELETED
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import{a as pe,b as he,c as Yt,h as ft,i as ye,l as Qe,o as xn,p as Ve,r as bn}from"./chunk-JB5ASFUE.js";import{render as Tr}from"ink";import{v4 as Ut}from"uuid";import{exec as ko}from"child_process";import Io from"fs";import We from"fs/promises";import yn from"os";import Vt from"path";import{promisify as So}from"util";import{glob as vo}from"glob";var Po=So(ko),_o=`## Filesystem Tool Instructions
|
|
3
|
-
|
|
4
|
-
You have access to filesystem tools that allow you to interact with the user's local filesystem.
|
|
5
|
-
|
|
6
|
-
### Available Operations
|
|
7
|
-
|
|
8
|
-
- **Read File**: Read the contents of a file
|
|
9
|
-
- **Read Multiple Files**: Read multiple files at once (max 10)
|
|
10
|
-
- **Write File**: Create or overwrite a file
|
|
11
|
-
- **Create Directory**: Create a new directory (including parent directories)
|
|
12
|
-
- **List Directory**: List files and subdirectories
|
|
13
|
-
- **Search Files**: Search for files matching a glob pattern
|
|
14
|
-
- **Get File Info**: Get metadata about a file or directory
|
|
15
|
-
- **Move File**: Move or rename a file or directory
|
|
16
|
-
- **Execute Command**: Run shell commands on the user's machine
|
|
17
|
-
|
|
18
|
-
### Important Notes
|
|
19
|
-
|
|
20
|
-
- Always use absolute paths when possible
|
|
21
|
-
- Be mindful of file permissions and access restrictions
|
|
22
|
-
- Large files will be truncated in responses
|
|
23
|
-
- Search results are limited to prevent overwhelming responses
|
|
24
|
-
- Execute Command has a default timeout of 30 seconds (max 5 minutes)
|
|
25
|
-
- The current working directory is: ${process.cwd()}
|
|
26
|
-
- The user's home directory is: ${yn.homedir()}
|
|
27
|
-
`,Eo=[{name:"filesystem__read_file",description:"Read the contents of a file from the local filesystem.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to the file to read."}},required:["path"]}},{name:"filesystem__read_multiple_files",description:"Read multiple files at once (max 10 files).",inputSchema:{type:"object",properties:{paths:{type:"array",items:{type:"string"},description:"Array of absolute file paths to read."}},required:["paths"]}},{name:"filesystem__write_file",description:"Create or overwrite a file with the given content.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to the file to write."},content:{type:"string",description:"The content to write to the file."}},required:["path","content"]}},{name:"filesystem__create_directory",description:"Create a new directory (including parent directories if needed).",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path of the directory to create."}},required:["path"]}},{name:"filesystem__list_directory",description:"List files and subdirectories in a directory.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path of the directory to list."}},required:["path"]}},{name:"filesystem__search_files",description:"Search for files matching a glob pattern.",inputSchema:{type:"object",properties:{pattern:{type:"string",description:'Glob pattern to match files (e.g., "**/*.ts").'},cwd:{type:"string",description:"Base directory to search in (optional)."}},required:["pattern"]}},{name:"filesystem__get_file_info",description:"Get metadata about a file or directory.",inputSchema:{type:"object",properties:{path:{type:"string",description:"The absolute path to get info for."}},required:["path"]}},{name:"filesystem__move_file",description:"Move or rename a file or directory.",inputSchema:{type:"object",properties:{source:{type:"string",description:"The source path."},destination:{type:"string",description:"The destination path."}},required:["source","destination"]}},{name:"filesystem__execute_command",description:"Execute a shell command on the local machine.",inputSchema:{type:"object",properties:{command:{type:"string",description:"The command to execute."},cwd:{type:"string",description:"Working directory for the command (optional)."},timeout:{type:"number",description:"Timeout in milliseconds (default: 30000, max: 300000)."}},required:["command"]}}];function wn(){return{name:"filesystem",systemPrompt:_o,tools:Eo}}function Re(e){return e.startsWith("~/")?Vt.join(yn.homedir(),e.slice(2)):e}function vt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
|
|
28
|
-
|
|
29
|
-
... (truncated, ${e.length-t} more characters)`}async function Cn(e,t){try{switch(e){case"filesystem__read_file":{let n=Re(t.path),s=await We.readFile(n,"utf-8");return{success:!0,result:vt(s)}}case"filesystem__read_multiple_files":{let n=t.paths.slice(0,10),s={};for(let i of n){let a=Re(i);try{let p=await We.readFile(a,"utf-8");s[i]=vt(p,5e4)}catch(p){s[i]={error:p instanceof Error?p.message:String(p)}}}return{success:!0,result:s}}case"filesystem__write_file":{let n=Re(t.path),s=t.content;return await We.mkdir(Vt.dirname(n),{recursive:!0}),await We.writeFile(n,s,"utf-8"),{success:!0,result:{written:n}}}case"filesystem__create_directory":{let n=Re(t.path);return await We.mkdir(n,{recursive:!0}),{success:!0,result:{created:n}}}case"filesystem__list_directory":{let n=Re(t.path);return{success:!0,result:(await We.readdir(n,{withFileTypes:!0})).map(a=>({name:a.name,type:a.isDirectory()?"directory":a.isFile()?"file":a.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let n=t.pattern,s=t.cwd?Re(t.cwd):process.cwd(),i=await vo(n,{cwd:s,nodir:!0,maxDepth:10});return{success:!0,result:{files:i.slice(0,100),total:i.length,truncated:i.length>100}}}case"filesystem__get_file_info":{let n=Re(t.path),s=await We.stat(n);return{success:!0,result:{path:n,type:s.isDirectory()?"directory":s.isFile()?"file":"other",size:s.size,created:s.birthtime.toISOString(),modified:s.mtime.toISOString(),accessed:s.atime.toISOString(),mode:s.mode.toString(8)}}}case"filesystem__move_file":{let n=Re(t.source),s=Re(t.destination);return await We.mkdir(Vt.dirname(s),{recursive:!0}),await We.rename(n,s),{success:!0,result:{moved:{from:n,to:s}}}}case"filesystem__execute_command":{let n=t.command,s=t.cwd?Re(t.cwd):process.cwd(),i=Math.min(t.timeout||3e4,3e5);if(!Io.existsSync(s))return{success:!1,error:`Working directory does not exist: ${s}`};let{stdout:a,stderr:p}=await Po(n,{cwd:s,timeout:i,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:vt(a,5e4),stderr:vt(p,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(n){return{success:!1,error:n instanceof Error?n.message:String(n)}}}function zt(e){return e.startsWith("filesystem__")}function Tn(){return[wn()]}function Pt(){return Tn().flatMap(e=>e.tools)}function _t(){return Tn().map(e=>e.systemPrompt).filter(Boolean).join(`
|
|
30
|
-
|
|
31
|
-
`)}function je(e){return zt(e)}async function Et(e,t){return zt(e)?Cn(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as $e,Text as G,useInput as pn}from"ink";import mn from"ink-spinner";import{useCallback as gn,useEffect as jt,useRef as go,useState as mr}from"react";import{Box as Nt,Text as pt}from"ink";import{jsx as At,jsxs as mt}from"react/jsx-runtime";function $n(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function kn({items:e,activeIndex:t,selectedIds:n,multiSelect:s=!1,visible:i,title:a,pageSize:p=10}){if(!i||e.length===0)return null;let g=process.stdout.columns??80,b=s?4:0,h=Math.max(20,g-2-2-b),B=Math.max(1,p),A=Math.floor(t/B)*B,I=Math.min(e.length,A+B),P=e.slice(A,I);return mt(Nt,{flexDirection:"column",marginBottom:1,children:[At(pt,{bold:!0,color:"cyan",children:a}),At(Nt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:P.map((k,x)=>{let W=A+x===t,H=n?.has(k.id),V=$n(k.name,h),oe=k.description?$n(k.description,Math.max(0,h-b)):"",J=s?" ".repeat(b):"";return mt(Nt,{paddingX:1,flexDirection:"column",children:[mt(Nt,{children:[s&&At(pt,{color:H?"green":"gray",children:H?"[\u2713] ":"[ ] "}),At(pt,{backgroundColor:W?"cyan":void 0,color:W?"black":H?"green":"white",bold:!0,children:V})]}),oe&&mt(pt,{dimColor:!0,children:[J,"\xB7 ",oe]})]},k.id)})}),mt(pt,{dimColor:!0,children:[s?"\u2191\u2193 Navigate \xB7 Space Toggle \xB7 a All \xB7 n None \xB7 Enter Confirm \xB7 Esc Cancel":"\u2191\u2193 Navigate \xB7 Enter Select \xB7 Esc Cancel",e.length>B?` \xB7 Showing ${A+1}-${I} of ${e.length}`:""]})]})}import{Box as Xt,Text as gt}from"ink";import{jsx as ht,jsxs as Qt}from"react/jsx-runtime";function In({suggestions:e,activeIndex:t,visible:n}){return!n||e.length===0?null:Qt(Xt,{flexDirection:"column",marginBottom:1,children:[ht(Xt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((s,i)=>{let a=i===t,p=s.aliases.length>0?` (${s.aliases.join(", ")})`:"";return Qt(Xt,{paddingX:1,children:[Qt(gt,{backgroundColor:a?"cyan":void 0,color:a?"black":"cyan",bold:a,children:["/",s.name]}),ht(gt,{dimColor:!0,children:p}),ht(gt,{children:" - "}),ht(gt,{color:a?"white":"gray",children:s.description})]},s.name)})}),ht(gt,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as No,Text as Sn,useInput as Ao,useStdout as Do}from"ink";import{useCallback as vn,useEffect as Pn,useMemo as Zt,useRef as _n,useState as En}from"react";import{jsx as nn}from"react/jsx-runtime";function Dt(e,t){return e<0?0:e>t?t:e}function en(e){return Array.from(e)}function Rt(e){return/\s/.test(e)}function tn(e,t){let n=t;for(;n>0&&Rt(e[n-1]??"");)n-=1;for(;n>0&&!Rt(e[n-1]??"");)n-=1;return n}function Nn(e,t){let n=t;for(;n<e.length&&Rt(e[n]??"");)n+=1;for(;n<e.length&&!Rt(e[n]??"");)n+=1;return n}function Ro(e){let t=[],n=[],s=[],i=0;n.push(0),e.forEach((p,g)=>{if(p===`
|
|
32
|
-
`){t.push(s),s=[],i=g+1,n.push(i);return}s.push(p)}),t.push(s);let a=t.map(p=>p.length);return{lines:t,lineStarts:n,lineLengths:a}}function An(e,t,n){for(let i=0;i<t.length;i+=1){let a=t[i]??0,p=n[i]??0,g=a+p;if(e<=g)return{row:i,col:e-a}}let s=Math.max(0,t.length-1);return{row:s,col:n[s]??0}}var Lo=2;function Dn({value:e,onChange:t,onSubmit:n,onPaste:s,focus:i=!0,leadingOffset:a=0,multiline:p=!1}){let[g,b]=En(()=>en(e).length),h=_n(null),[B,A]=En(0),I=_n(null),{stdout:P}=Do(),k=Zt(()=>en(e),[e]),{lines:x,lineStarts:v,lineLengths:W}=Zt(()=>Ro(k),[k]),{row:H,col:V}=Zt(()=>An(g,v,W),[g,v,W]),oe=Math.max(1,(P?.columns??80)-a);Pn(()=>{h.current!==e?(b(k.length),I.current=null):b(F=>Dt(F,k.length)),h.current=e},[e,k.length]),Pn(()=>{A(F=>{let $=F;V<$?$=V:V>=$+oe&&($=V-oe+1);let S=W[H]??0,R=V===S?S+1:S,j=Math.max(0,R-oe);return $>j&&($=j),$<0&&($=0),$})},[oe,V,H,W]);let J=vn((F,$)=>{h.current=F,t(F),b($),I.current=null},[t]),be=vn(async(F,$)=>{if(!i)return;let{row:S,col:R}=An(g,v,W),j=x[S]??[],_=W[S]??0,de=x.length>1;if(p&&($.meta&&$.return||$.ctrl&&F==="j"||$.shift&&$.return)){let N=[...k.slice(0,g),`
|
|
33
|
-
`,...k.slice(g)].join("");J(N,g+1);return}if($.return){n(e);return}if($.leftArrow){$.ctrl||$.meta?(R===0&&S>0?b(v[S]-1):b(v[S]+tn(j,R)),I.current=null):(R===0&&S>0?b(v[S]-1):b(N=>Dt(N-1,k.length)),I.current=null);return}if($.rightArrow){$.ctrl||$.meta?(R>=_&&S<x.length-1?b(v[S+1]):b(v[S]+Nn(j,R)),I.current=null):(R>=_&&S<x.length-1?b(v[S+1]):b(N=>Dt(N+1,k.length)),I.current=null);return}if(p&&de&&$.upArrow){let N=I.current??R,c=Math.max(0,S-1),ne=Math.min(N,W[c]??0);b((v[c]??0)+ne),I.current=N;return}if(p&&de&&$.downArrow){let N=I.current??R,c=Math.min(x.length-1,S+1),ne=Math.min(N,W[c]??0);b((v[c]??0)+ne),I.current=N;return}if($.ctrl){if(F==="a"){b(v[S]??0),I.current=null;return}if(F==="e"){b((v[S]??0)+_),I.current=null;return}if(F==="u"){if(R>0){let N=v[S]??0,c=[...k.slice(0,N),...k.slice(g)].join("");J(c,N)}return}if(F==="k"){if(R<_){let N=(v[S]??0)+_,c=[...k.slice(0,g),...k.slice(N)].join("");J(c,g)}return}if(F==="w"){if(R===0&&S>0){let c=[...k.slice(0,g-1),...k.slice(g)].join("");J(c,g-1);return}let N=tn(j,R);if(N!==R){let c=(v[S]??0)+N,ne=[...k.slice(0,c),...k.slice(g)].join("");J(ne,c)}return}if(F==="d"){if(g<k.length){let N=[...k.slice(0,g),...k.slice(g+1)].join("");J(N,g)}return}return}if($.meta){F==="b"?(R===0&&S>0?b(v[S]-1):b(v[S]+tn(j,R)),I.current=null):F==="f"&&(R>=_&&S<x.length-1?b(v[S+1]):b(v[S]+Nn(j,R)),I.current=null);return}if($.backspace||$.delete){if(g<=0)return;let N=[...k.slice(0,g-1),...k.slice(g)].join("");J(N,g-1);return}if(!($.tab||$.escape)&&F.length>0){let N=p?F.replace(/\r\n/g,`
|
|
34
|
-
`).replace(/\r/g,`
|
|
35
|
-
`):F.replace(/\r?\n/g,"");if(!N||(N=N.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!N))return;if((N.length>=Lo||N.includes(`
|
|
36
|
-
`))&&s){let q=!1,T={text:N,preventDefault:()=>{q=!0}};if(await Promise.resolve(s(T)),q)return}let ne=en(N),ge=[...k.slice(0,g),...ne,...k.slice(g)].join("");J(ge,g+ne.length)}},[k,g,i,W,v,x,p,s,n,J,e]);return Ao(be,{isActive:i}),nn(No,{flexDirection:"column",children:x.map((F,$)=>{let S=$===H,j=(S&&V===F.length?[...F," "]:F).slice(B,B+oe),_=j.join("");if(!S)return nn(Sn,{children:_||" "},$);let de=Dt(V-B,Math.max(0,j.length-1)),N=j.slice(0,de).join(""),c=j[de]??" ",ne=j.slice(de+1).join(""),T=`${N}\x1B[7m${c}\x1B[27m${ne}`;return nn(Sn,{children:T},$)})})}import{Box as Le,Text as ze}from"ink";import an from"react";import{Text as _e}from"ink";import Fo from"react";import{Fragment as Wo,jsx as Ae,jsxs as Fn}from"react/jsx-runtime";var on=2,rn=1,sn=2,Oo=1,Rn=3,Ln=4,Bo=({text:e,defaultColor:t,linkColor:n,codeColor:s})=>{let i=t;if(!/[*_~`<[https?:]/.test(e))return Ae(_e,{color:i,children:e});let a=[],p=0,g=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,b;for(;(b=g.exec(e))!==null;){b.index>p&&a.push(Ae(_e,{color:i,children:e.slice(p,b.index)},`t-${p}`));let h=b[0],B=null,A=`m-${b.index}`;try{if(h.startsWith("**")&&h.endsWith("**")&&h.length>on*2)B=Ae(_e,{bold:!0,color:i,children:h.slice(on,-on)},A);else if(h.length>rn*2&&(h.startsWith("*")&&h.endsWith("*")||h.startsWith("_")&&h.endsWith("_"))&&!/\w/.test(e.substring(b.index-1,b.index))&&!/\w/.test(e.substring(g.lastIndex,g.lastIndex+1))&&!/\S[./\\]/.test(e.substring(b.index-2,b.index))&&!/[./\\]\S/.test(e.substring(g.lastIndex,g.lastIndex+2)))B=Ae(_e,{italic:!0,color:i,children:h.slice(rn,-rn)},A);else if(h.startsWith("~~")&&h.endsWith("~~")&&h.length>sn*2)B=Ae(_e,{strikethrough:!0,color:i,children:h.slice(sn,-sn)},A);else if(h.startsWith("`")&&h.endsWith("`")&&h.length>Oo){let I=h.match(/^(`+)(.+?)\1$/s);I&&I[2]&&(B=Ae(_e,{color:s,children:I[2]},A))}else if(h.startsWith("[")&&h.includes("](")&&h.endsWith(")")){let I=h.match(/\[(.*?)\]\((.*?)\)/);if(I){let P=I[1],k=I[2];B=Fn(_e,{color:i,children:[P,Fn(_e,{color:n,children:[" (",k,")"]})]},A)}}else h.startsWith("<u>")&&h.endsWith("</u>")&&h.length>Rn+Ln-1?B=Ae(_e,{underline:!0,color:i,children:h.slice(Rn,-Ln)},A):h.match(/^https?:\/\//)&&(B=Ae(_e,{color:n,children:h},A))}catch{B=null}a.push(B??Ae(_e,{color:i,children:h},A)),p=g.lastIndex}return p<e.length&&a.push(Ae(_e,{color:i,children:e.slice(p)},`t-${p}`)),Ae(Wo,{children:a.filter(h=>h!==null)})},xt=Fo.memo(Bo);import{Fragment as Ho,jsx as me,jsxs as jn}from"react/jsx-runtime";var jo=1,Wn=1,Uo=1,Mo=1,Go=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return me(Le,{paddingLeft:Wn,flexDirection:"column",children:me(ze,{wrap:"wrap",children:e})});let n=e.split(/\r?\n/),s=/^ *(#{1,4}) +(.*)/,i=/^ *(`{3,}|~{3,}) *(\w*?) *$/,a=/^([ \t]*)([-*+]) +(.*)/,p=/^([ \t]*)(\d+)\. +(.*)/,g=/^ *([-*_] *){3,} *$/,b=/^ *> ?(.*)/,h=[],B=!1,A=!0,I=[],P="";function k(x){x&&(h.push(x),A=!1)}return n.forEach((x,v)=>{let W=`line-${v}`;if(B){let $=x.match(i);$&&$[1].startsWith(P[0])&&$[1].length>=P.length?(k(me(On,{content:I},W)),B=!1,I=[],P=""):I.push(x);return}let H=x.match(i),V=x.match(s),oe=x.match(a),J=x.match(p),be=x.match(g),F=x.match(b);if(H)B=!0,P=H[1];else if(be)k(me(Le,{children:me(ze,{dimColor:!0,children:"---"})},W));else if(V){let $=V[1].length,S=V[2],R=$<=2?"cyan":"blue";k(me(Le,{children:me(ze,{color:R,...($===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:me(xt,{text:S,defaultColor:R,linkColor:"cyan",codeColor:"yellow"})})},W))}else if(F){let $=F[1];k(me(Le,{paddingLeft:1,children:jn(ze,{dimColor:!0,children:["> ",me(xt,{text:$,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},W))}else if(oe){let $=oe[1],S=oe[2],R=oe[3];k(me(Bn,{itemText:R,type:"ul",marker:S,leadingWhitespace:$},W))}else if(J){let $=J[1],S=J[2],R=J[3];k(me(Bn,{itemText:R,type:"ol",marker:S,leadingWhitespace:$},W))}else x.trim().length===0?A||(h.push(me(Le,{height:jo},`spacer-${v}`)),A=!0):k(me(Le,{children:me(ze,{wrap:"wrap",children:me(xt,{text:x,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},W))}),B&&k(me(On,{content:I},"line-eof")),me(Ho,{children:h})},qo=({content:e})=>{let t=e.join(`
|
|
37
|
-
`);return me(Le,{paddingLeft:Wn,flexDirection:"column",children:me(ze,{color:"yellow",children:t})})},On=an.memo(qo),Ko=({itemText:e,type:t,marker:n,leadingWhitespace:s=""})=>{let i=t==="ol"?`${n}. `:`${n} `,a=i.length,p=s.length;return jn(Le,{paddingLeft:p+Uo,flexDirection:"row",children:[me(Le,{width:a,children:me(ze,{children:i})}),me(Le,{flexGrow:Mo,children:me(ze,{wrap:"wrap",children:me(xt,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},Bn=an.memo(Ko),ln=an.memo(Go);import{execFile as Jo}from"child_process";import Yo from"fs";import at from"fs/promises";import Un from"os";import Ft from"path";import{promisify as Vo}from"util";var Lt=Vo(Jo);async function zo(){let e=Ft.join(Un.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
|
|
38
|
-
set imageData to the clipboard as "PNGf"
|
|
39
|
-
set fileRef to open for access POSIX file "${e}" with write permission
|
|
40
|
-
set eof fileRef to 0
|
|
41
|
-
write imageData to fileRef
|
|
42
|
-
close access fileRef
|
|
43
|
-
`;return await Lt("osascript",["-e",t]),(await at.stat(e)).size===0?void 0:{buffer:await at.readFile(e),mime:"image/png"}}catch{return}finally{try{Yo.existsSync(e)&&await at.unlink(e)}catch{}}}async function Xo(){try{let e=`
|
|
44
|
-
Add-Type -AssemblyName System.Windows.Forms
|
|
45
|
-
$img = [System.Windows.Forms.Clipboard]::GetImage()
|
|
46
|
-
if ($img) {
|
|
47
|
-
$ms = New-Object System.IO.MemoryStream
|
|
48
|
-
$img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png)
|
|
49
|
-
[System.Convert]::ToBase64String($ms.ToArray())
|
|
50
|
-
}
|
|
51
|
-
`,{stdout:t}=await Lt("powershell.exe",["-command",e]),n=t.trim();if(!n)return;let s=Buffer.from(n,"base64");return s.length===0?void 0:{buffer:s,mime:"image/png"}}catch{return}}async function Qo(){try{let{stdout:e}=await Lt("wl-paste",["-t","image/png"],{encoding:"buffer",maxBuffer:52428800});if(e&&e.length>0)return{buffer:e,mime:"image/png"}}catch{}try{let{stdout:e}=await Lt("xclip",["-selection","clipboard","-t","image/png","-o"],{encoding:"buffer",maxBuffer:52428800});if(e&&e.length>0)return{buffer:e,mime:"image/png"}}catch{}}async function Mn(){let e=Un.platform();if(e==="darwin")return zo();if(e==="win32")return Xo();if(e==="linux")return Qo()}var Zo=new Set([".png",".jpg",".jpeg",".gif",".webp",".bmp",".ico",".heic",".heif",".pdf",".txt",".md",".rtf",".csv",".doc",".docx",".xls",".xlsx",".ppt",".pptx",".key",".pages",".numbers",".odt",".ods",".odp",".json",".xml",".yaml",".yml"]);function Gn(e){let t=Ft.extname(e).toLowerCase();return Zo.has(t)}function er(e){let t=Ft.extname(e).toLowerCase();return{".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp",".bmp":"image/bmp",".ico":"image/x-icon",".heic":"image/heic",".heif":"image/heif",".txt":"text/plain",".md":"text/markdown",".pdf":"application/pdf",".csv":"text/csv",".rtf":"application/rtf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".key":"application/vnd.apple.keynote",".pages":"application/vnd.apple.pages",".numbers":"application/vnd.apple.numbers",".odt":"application/vnd.oasis.opendocument.text",".ods":"application/vnd.oasis.opendocument.spreadsheet",".odp":"application/vnd.oasis.opendocument.presentation",".json":"application/json",".xml":"application/xml",".yaml":"text/yaml",".yml":"text/yaml"}[t]||"application/octet-stream"}function Ot(e){let t=e.trim();return t.startsWith("file://")&&(t=decodeURIComponent(t.slice(7))),(t.startsWith("'")&&t.endsWith("'")||t.startsWith('"')&&t.endsWith('"'))&&(t=t.slice(1,-1)),t=t.replace(/\\(.)/g,"$1"),t}async function qn(e){let t=Ot(e);if(/^https?:\/\//.test(t))return!1;try{return await at.access(t),!0}catch{return!1}}async function Kn(e){let t=Ot(e);try{if(!(await at.stat(t)).isFile())return;let s=await at.readFile(t),i=er(t),a=Ft.basename(t);return{buffer:s,mimeType:i,filename:a}}catch{return}}var Ee="\x1B[2m",te="\x1B[0m",Te="\x1B[36m",lt="\x1B[32m",Hn="\x1B[31m",Ze="\x1B[38;2;59;91;204m",cn="\x1B[38;2;126;200;248m",un="\x1B[38;2;244;196;78m";import{useState as Ue}from"react";import{v4 as Jn}from"uuid";function Yn(e,t){let[n,s]=Ue({status:"loading"}),[i,a]=Ue([]),[p,g]=Ue(""),[b,h]=Ue(()=>e||Jn()),[B,A]=Ue(t),[I,P]=Ue(!!e),[k,x]=Ue(null),[v,W]=Ue(""),[H,V]=Ue(!1),oe=be=>{a(F=>[...F,{role:"system",content:be}])};return{state:n,setState:s,messages:i,setMessages:a,input:p,setInput:g,chatId:b,setChatId:h,currentChatTitle:B,setCurrentChatTitle:A,hasPersistedChat:I,setHasPersistedChat:P,credentials:k,setCredentials:x,currentResponse:v,setCurrentResponse:W,fullOutput:H,setFullOutput:V,addSystemMessage:oe,startNewChat:be=>{let F=Jn();h(F),A(void 0),P(!1),a([]),be&&oe(be)}}}import{useEffect as tr,useState as Vn}from"react";function zn(e){let[t,n]=Vn(null),[s,i]=Vn(!0);return tr(()=>{let a=!1;async function p(){try{let g=await Ve();if(a)return;n({accessToken:g.accessToken,workspaceId:g.workspaceId}),i(!1)}catch(g){if(a)return;if(g instanceof Qe){if(g.code==="not-logged-in"){e({status:"not-logged-in"}),i(!1);return}if(g.code==="no-workspace"){e({status:"no-workspace"}),i(!1);return}}let b=g instanceof Error?g.message:"Failed to authenticate";e({status:"error",message:b}),i(!1)}}return p(),()=>{a=!0}},[e]),{credentials:t,loading:s}}import{useEffect as nr,useState as bt}from"react";function Xn(e){let[t,n]=bt([]),[s,i]=bt([]),[a,p]=bt([]),[g,b]=bt([]),[h,B]=bt(!1);return nr(()=>{if(!e)return;let A=!1;B(!0);async function I(){if(e)try{let P=new ye,[k,x,v,W]=await Promise.all([P.getConnectors(e.accessToken,e.workspaceId),P.getModels(e.accessToken,e.workspaceId),P.getAgents(e.accessToken,e.workspaceId),P.getModelProviders(e.accessToken,e.workspaceId)]);if(A)return;n(k.connectors),i(x.models),p(v.agents),b(W.providers??[])}catch{}finally{A||B(!1)}}return I(),()=>{A=!0}},[e]),{availableConnectors:t,availableModels:s,availableAgents:a,modelProviders:g,loading:h}}import ct from"fs";import Zn from"path";import{useCallback as or}from"react";import{v4 as rr}from"uuid";function Qn(e,t){if(!e)return"(no result)";if(typeof e!="object"){let i=String(e);return t||i.length<=200?i:i.slice(0,200)+"..."}let n=e;if("structuredContent"in n&&n.structuredContent){let i=n.structuredContent;if(i.stdout&&typeof i.stdout=="string"){let a=i.stdout.trim();return t||a.length<=200?a:a.slice(0,200)+"..."}}if("content"in n&&Array.isArray(n.content)){let i=n.content.filter(a=>a.type==="text"&&a.text).map(a=>a.text).join(`
|
|
52
|
-
`);return i?t||i.length<=200?i:i.slice(0,200)+"...":"(result)"}let s=JSON.stringify(e,null,t?2:void 0);return t||s.length<=200?s:s.slice(0,200)+"..."}function et(e,t=!1){let n=[];for(let s of e)if(s.type==="text"&&s.text)n.push(s.text);else if(s.type==="reasoning"&&s.text)t?n.push(`${Ee}[Thinking]
|
|
53
|
-
${s.text}${te}`):n.push(`${Ee}[Thinking...]${te}`);else if(s.type==="tool-call"&&s.toolName){let i=[];if(i.push(`${Te}\u250C\u2500 Tool: ${s.toolName}${te}`),s.args){let a=JSON.stringify(s.args,null,t?2:void 0),p=t||a.length<=100?a:a.slice(0,100)+"...";i.push(`${Ee}\u2502 Args: ${p}${te}`)}s.result!==void 0?(i.push(`${lt}\u2502 Result: ${Qn(s.result,t)}${te}`),i.push(`${Te}\u2514\u2500 completed${te}`)):i.push(`${Te}\u2514\u2500${te}`),n.push(i.join(`
|
|
54
|
-
`))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let i=s.title||s.type.slice(5).replace(/__/g," "),a=[];if(a.push(`${Te}\u250C\u2500 Tool: ${i}${te}`),s.input){let p=JSON.stringify(s.input,null,t?2:void 0),g=t||p.length<=100?p:p.slice(0,100)+"...";a.push(`${Ee}\u2502 Input: ${g}${te}`)}s.output!==void 0&&s.state==="output-available"?(a.push(`${lt}\u2502 Output: ${Qn(s.output,t)}${te}`),a.push(`${Te}\u2514\u2500 completed${te}`)):s.state==="error"?a.push(`${Te}\u2514\u2500 failed${te}`):a.push(`${Te}\u2514\u2500${te}`),n.push(a.join(`
|
|
55
|
-
`))}return n.join(`
|
|
56
|
-
|
|
57
|
-
`).trim()}var Bt=class{pendingToolCalls=new Map;hasPending(){return this.pendingToolCalls.size>0}hasExecuting(){for(let t of this.pendingToolCalls.values())if(t.status==="executing")return!0;return!1}clear(t){this.pendingToolCalls.delete(t)}buildToolDisplay(){if(this.pendingToolCalls.size===0)return"";let t=[];for(let[,n]of this.pendingToolCalls){let s=n.toolName.replace(/__/g," "),i=`
|
|
58
|
-
|
|
59
|
-
${Te}\u250C\u2500 Tool: ${s}${te}`;if(n.args){let a=n.args.length>100?n.args.slice(0,100)+"...":n.args;i+=`
|
|
60
|
-
${Ee}\u2502 Input: ${a}${te}`}if(n.output){let a=n.output.length>150?n.output.slice(0,150)+"...":n.output;i+=`
|
|
61
|
-
${lt}\u2502 Output: ${a}${te}`}else if(n.status==="executing"){let a=n.startedAt??Date.now(),p=Math.floor((Date.now()-a)/1e3);i+=`
|
|
62
|
-
${Te}\u2502${te} (executing... ${p}s)`}else n.status==="preparing"&&(i+=`
|
|
63
|
-
${Te}\u2502${te} (preparing...)`);t.push(i)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[n,s]of this.pendingToolCalls){let i=s.toolName.replace(/__/g," "),a=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"";t+=`
|
|
64
|
-
|
|
65
|
-
${Te}\u250C\u2500 Tool: ${i}${te}`,a&&(t+=`
|
|
66
|
-
${Ee}\u2502 Input: ${a}${te}`),t+=`
|
|
67
|
-
${Te}\u2514\u2500 completed${te}
|
|
68
|
-
`,this.pendingToolCalls.delete(n)}return t}handleToolInputStart(t){return t.toolCallId&&t.toolName?(this.pendingToolCalls.set(t.toolCallId,{toolName:t.toolName,args:"",status:"preparing"}),this.buildToolDisplay()):null}handleToolInputDelta(t){if(t.toolCallId&&t.inputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.args=(n.args||"")+t.inputTextDelta,n.status="executing",n.startedAt??=Date.now(),this.buildToolDisplay()}return null}handleToolOutputStart(t){if(t.toolCallId){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output="",n.status="output",this.buildToolDisplay()}return null}handleToolOutputDelta(t){if(t.toolCallId&&t.outputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output=(n.output||"")+t.outputTextDelta,this.buildToolDisplay()}return null}handleToolOutputEnd(t,n){if(!t.toolCallId)return null;let s=this.pendingToolCalls.get(t.toolCallId);if(!s)return null;let i=s.toolName.replace(/__/g," "),a=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"",p=(s.output||"").length>200?(s.output||"").slice(0,200)+"...":s.output||"";return n+=`
|
|
69
|
-
|
|
70
|
-
${Te}\u250C\u2500 Tool: ${i}${te}`,a&&(n+=`
|
|
71
|
-
${Ee}\u2502 Input: ${a}${te}`),n+=`
|
|
72
|
-
${lt}\u2502 Output: ${p}${te}`,n+=`
|
|
73
|
-
${Te}\u2514\u2500 completed${te}
|
|
74
|
-
`,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}handleToolError(t,n){if(!t.toolCallId)return null;let i=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),a=t.errorText||"Unknown error",p=a.length>200?a.slice(0,200)+"...":a;return n+=`
|
|
75
|
-
|
|
76
|
-
${Te}\u250C\u2500 Tool: ${i}${te}`,n+=`
|
|
77
|
-
${Hn}\u2502 Error: ${p}${te}`,n+=`
|
|
78
|
-
${Te}\u2514\u2500 failed${te}
|
|
79
|
-
`,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}};var yt=Zn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function re(e,t){if(!process.env.DEBUG)return;let s=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(s+=`
|
|
80
|
-
DATA: ${JSON.stringify(t,null,2)}`),s+=`
|
|
81
|
-
`;try{ct.appendFileSync(yt,s)}catch{}}function sr(){try{if(ct.existsSync(yt)&&ct.unlinkSync(yt),process.env.DEBUG){let e=Zn.dirname(yt);ct.existsSync(e)||ct.mkdirSync(e,{recursive:!0}),ct.writeFileSync(yt,`=== Debug session started at ${new Date().toISOString()} ===
|
|
82
|
-
`)}}catch{}}function Wt(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function eo({chatId:e,credentials:t,currentAgentId:n,currentModel:s,activeConnectorIds:i,sandbox:a,webSearch:p,imageGeneration:g,chart:b,localTools:h,fullOutput:B,setMessages:A,setState:I,setCurrentResponse:P,setCredentials:k,setHasPersistedChat:x,getFileIds:v,clearFiles:W}){let H=h?Pt():void 0,V=h?_t():void 0;return{sendMessage:or(async(J,be,F)=>{sr(),re("=== sendMessage called ===",{text:J,localTools:h,clientToolsCount:H?.length});let $=be||t?.accessToken,S=F||t?.workspaceId;if(!$||!S)try{let _=await Ve();$=_.accessToken,S=_.workspaceId,k(_)}catch(_){if(_ instanceof Qe){if(_.code==="not-logged-in"){I({status:"not-logged-in"});return}if(_.code==="no-workspace"){I({status:"no-workspace"});return}}let de=_ instanceof Error?_.message:"Authentication failed";I({status:"error",message:de});return}else try{let _=await xn();_!==$&&($=_,k({accessToken:_,workspaceId:S}))}catch(_){if(_ instanceof Qe&&_.code==="not-logged-in"){I({status:"not-logged-in"});return}let de=_ instanceof Error?_.message:"Authentication failed";I({status:"error",message:de});return}A(_=>[..._,{role:"user",content:J}]),I({status:"sending"}),P("");let R=null,j=null;try{let _=new ye,de=v?.()??[],N={id:e,message:{id:rr(),createdAt:new Date,role:"user",parts:[{type:"text",text:J}]}};de.length>0&&(N.fileIds=de),n?N.agentId=n:(s&&(N.model=s),N.connectorIds=i??[],N.enableSandbox=a,N.enableWebSearch=p,N.enableImageGeneration=g,N.enableChart=b),H&&(N.clientTools=H),V&&(N.clientToolSystemPrompt=V);let c=await _.chat($,S,N);if(!c.ok){let O=await c.text();throw new Error(`API error ${c.status}: ${O}`)}if(!c.body)throw new Error("No response body from server");R=c.body.getReader();let ne=new TextDecoder,ge="",q="",T="",Q="",X="",ce="",se="",U=new Bt,z=[],K=[],le=[],we=()=>{let O=U.hasExecuting();O&&!j?j=setInterval(()=>{if(!U.hasExecuting()){j&&(clearInterval(j),j=null);return}P(q+U.buildToolDisplay())},1e3):!O&&j&&(clearInterval(j),j=null)};for(;;){let{done:O,value:ee}=await R.read();if(O)break;ge+=ne.decode(ee,{stream:!0});let D=ge.split(`
|
|
83
|
-
`);ge=D.pop()||"";for(let l of D)if(l.trim()!=="data: [DONE]"&&l.startsWith("data: "))try{let f=JSON.parse(l.slice(6));switch(re(`SSE event received: ${f.type}`,f),f.type){case"reasoning-start":Q=f.id||"0",T="";break;case"reasoning-delta":f.delta&&(T+=f.delta,P(`${Ee}[Thinking...]${te}
|
|
84
|
-
${T}`)),f.providerMetadata?.anthropic?.signature&&(X=f.providerMetadata.anthropic.signature);break;case"reasoning-end":if(T){let y={type:"reasoning",id:Q,text:T,state:"done"};X&&(y.providerMetadata={anthropic:{signature:X}}),K.push(y),re("Added reasoning to messageParts",{reasoningLength:T.length,hasSignature:!!X,messagePartsCount:K.length})}T="",X="",P("");break;case"text-delta":f.delta&&(U.hasPending()&&(q=U.flushPending(q)),q+=f.delta,ce+=f.delta,P(q));break;case"tool-input-start":{let y=U.handleToolInputStart(f);y&&P(q+y),we();break}case"tool-input-delta":{let y=U.handleToolInputDelta(f);y&&P(q+y),we();break}case"tool-call":case"tool-input-available":{if(re(`=== Tool event: ${f.type} ===`,{toolCallId:f.toolCallId,toolName:f.toolName,localTools:h,isClientToolResult:f.toolName?je(f.toolName):"no toolName",args:f.args,input:f.input}),f.toolCallId&&f.toolName){let y=Wt(f.args??f.input);K.push({type:f.type,toolCallId:f.toolCallId,toolName:f.toolName,args:y}),re("Added tool to messageParts",{messagePartsCount:K.length})}if(h&&f.toolCallId&&f.toolName&&je(f.toolName)){let y=Wt(f.args??f.input);z.push({toolCallId:f.toolCallId,toolName:f.toolName,args:y}),re("Added to pendingClientTools",{pendingCount:z.length,pendingClientTools:z}),P(q+U.buildToolDisplay()+`
|
|
85
|
-
[Executing ${f.toolName} locally...]`)}else re("NOT added to pendingClientTools - conditions not met",{localTools:h,hasToolCallId:!!f.toolCallId,hasToolName:!!f.toolName,isClientTool:f.toolName?je(f.toolName):!1});break}case"tool-output-start":{let y=U.handleToolOutputStart(f);y&&P(q+y),we();break}case"tool-output-delta":{let y=U.handleToolOutputDelta(f);y&&P(q+y),we();break}case"tool-output-end":{let y=U.handleToolOutputEnd(f,q);y&&(q=y.fullResponse,P(q+y.toolDisplay)),we();break}case"tool-input-error":case"tool-output-error":{let y=U.handleToolError(f,q);y&&(q=y.fullResponse,P(q+y.toolDisplay)),we();break}case"start":f.messageId&&(se=f.messageId,re("Captured messageId from start event",{messageId:se}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":f.errorText&&console.error("Stream error:",f.errorText);break}}catch{}}if(ce){let O=K.findIndex(D=>D.type!=="reasoning"),ee=O===-1?K.length:O;K.splice(ee,0,{type:"text",text:ce}),re("Added accumulated text to messageParts",{textLength:ce.length,insertIndex:ee})}for(re("=== Initial stream ended ===",{pendingClientToolsCount:z.length,pendingClientTools:z,messagePartsCount:K.length,messageParts:K.map(O=>({type:O.type,toolCallId:O.toolCallId,toolName:O.toolName}))});z.length>0;){re("=== Starting pending tools execution loop ===",{pendingCount:z.length});let O=[];for(let l of z){re(`Executing tool: ${l.toolName}`,{toolCallId:l.toolCallId,args:l.args}),U.handleToolInputStart({toolCallId:l.toolCallId,toolName:l.toolName}),U.handleToolInputDelta({toolCallId:l.toolCallId,inputTextDelta:JSON.stringify(l.args)}),P(q+U.buildToolDisplay()),we();let f=await Et(l.toolName,l.args);re(`Tool execution result: ${l.toolName}`,{success:f.success,resultPreview:f.success?JSON.stringify(f.result).slice(0,200):f.error});let y=f.success?JSON.stringify(f.result):f.error||"Unknown error";if(O.push({toolCallId:l.toolCallId,toolName:l.toolName,content:[{type:"text",text:y}],isError:!f.success}),f.success){U.handleToolOutputStart({toolCallId:l.toolCallId}),U.handleToolOutputDelta({toolCallId:l.toolCallId,outputTextDelta:JSON.stringify(f.result).slice(0,200)});let Z=U.handleToolOutputEnd({toolCallId:l.toolCallId},q);Z&&(q=Z.fullResponse)}else{let Z=U.handleToolError({toolCallId:l.toolCallId,errorText:f.error},q);Z&&(q=Z.fullResponse)}P(q+U.buildToolDisplay()),we()}z.length=0;for(let l of O){let f=K.find(y=>(y.type==="tool-input-available"||y.type==="tool-call")&&y.toolCallId===l.toolCallId);if(f){let y=[];for(let L of l.content)L.type==="text"?y.push(L.text):L.type==="image"?y.push("[Image]"):L.type==="audio"?y.push("[Audio]"):(L.type==="resource"||L.type==="resource_link")&&y.push("[Resource]");let Z=y.join(`
|
|
86
|
-
`);le.push({type:`tool-${f.toolName}`,toolName:f.toolName,toolCallId:f.toolCallId,input:f.args,output:Z,isError:l.isError})}}if(re("=== Sending clientToolResults for continuation ===",{toolResultsCount:O.length,toolResults:O.map(l=>({toolCallId:l.toolCallId,toolName:l.toolName,isError:l.isError}))}),R)try{R.releaseLock()}catch{}let ee={id:e,clientToolResults:O};n?ee.agentId=n:(s&&(ee.model=s),ee.connectorIds=i??[],ee.enableSandbox=a,ee.enableWebSearch=p,ee.enableImageGeneration=g,ee.enableChart=b),H&&(ee.clientTools=H),V&&(ee.clientToolSystemPrompt=V),re("=== Sending continuation request ===",{chatId:e,hasAgentId:!!ee.agentId,hasModel:!!ee.model,clientToolResultsCount:O.length});let D=await _.chat($,S,ee);if(re("=== Continuation response received ===",{ok:D.ok,status:D.status}),!D.ok){let l=await D.text();throw new Error(`Continuation failed: ${D.status}: ${l}`)}if(!D.body)break;for(re("=== Processing continuation stream ==="),R=D.body.getReader(),K.length=0,ce="",T="",Q="",X="";;){let{done:l,value:f}=await R.read();if(l){re("=== Continuation stream done ===");break}ge+=ne.decode(f,{stream:!0});let y=ge.split(`
|
|
87
|
-
`);ge=y.pop()||"";for(let Z of y)if(Z.trim()!=="data: [DONE]"&&Z.startsWith("data: "))try{let L=JSON.parse(Z.slice(6));switch(re(`Continuation SSE: ${L.type}`,L),L.type){case"reasoning-start":Q=L.id||"0",T="";break;case"reasoning-delta":L.delta&&(T+=L.delta,P(`${Ee}[Thinking...]${te}
|
|
88
|
-
${T}`)),L.providerMetadata?.anthropic?.signature&&(X=L.providerMetadata.anthropic.signature);break;case"reasoning-end":if(T){let xe={type:"reasoning",id:Q,text:T,state:"done"};X&&(xe.providerMetadata={anthropic:{signature:X}}),K.push(xe),re("Continuation: Added reasoning to messageParts",{reasoningLength:T.length,hasSignature:!!X,messagePartsCount:K.length})}T="",X="",P(q);break;case"text-delta":L.delta&&(q+=L.delta,ce+=L.delta,P(q));break;case"tool-call":case"tool-input-available":if(L.toolCallId&&L.toolName){let xe=Wt(L.args??L.input);K.push({type:L.type,toolCallId:L.toolCallId,toolName:L.toolName,args:xe})}if(h&&L.toolCallId&&L.toolName&&je(L.toolName)){let xe=Wt(L.args??L.input);z.push({toolCallId:L.toolCallId,toolName:L.toolName,args:xe}),re("Continuation: Added to pendingClientTools",{pendingCount:z.length})}break;case"finish":re("Continuation finish event",L);break}}catch{}}if(ce){let l=K.findIndex(y=>y.type!=="reasoning"),f=l===-1?K.length:l;K.splice(f,0,{type:"text",text:ce})}re("=== Continuation stream processing complete ===",{pendingClientToolsCount:z.length,messagePartsCount:K.length,fullResponseLength:q.length})}if(h&&H&&H.length>0){let O=[];for(let D of le)O.push({type:String(D.type),title:String(D.toolName).replace(/__/g," "),input:D.input,output:D.output,state:D.isError?"error":"output-available"});for(let D of K)D.type==="text"&&D.text&&O.push({type:"text",text:D.text});let ee=et(O,B);re("=== Using formatted parts for local tools ===",{executedToolsCount:le.length,textPartsCount:K.filter(D=>D.type==="text").length,contentLength:ee.length}),A(D=>[...D,{role:"assistant",content:ee,parts:O}])}else{re("=== Fetching message from API ===",{fullResponseLength:q.length,fullResponsePreview:q.slice(0,200)});try{let{messages:O}=await _.getMessages($,S,e,10);re("=== API messages received ===",{count:O.length,roles:O.map(D=>D.role)});let ee=O.find(D=>D.role==="assistant");if(ee){let D=ee.parts,l=et(D,B);re("=== Setting message from API ===",{partsCount:D.length,partTypes:D.map(f=>f.type),contentLength:l.length,contentPreview:l.slice(0,200)}),A(f=>[...f,{role:"assistant",content:l,parts:D}])}else re("=== No assistant message found, using fallback ==="),A(D=>[...D,{role:"assistant",content:q}])}catch(O){re("=== API fetch failed, using fallback ===",{error:O instanceof Error?O.message:String(O)}),A(ee=>[...ee,{role:"assistant",content:q}])}}re("=== Message handling complete ==="),P(""),I({status:"ready"}),x(!0),de.length>0&&W?.()}catch(_){re("=== ERROR ===",{message:_ instanceof Error?_.message:String(_),stack:_ instanceof Error?_.stack:void 0});let de=_ instanceof Error?_.message:"Failed to send message";I({status:"error",message:de})}finally{if(j&&(clearInterval(j),j=null),R)try{R.releaseLock()}catch{}}},[t,e,n,s,i,a,p,g,b,h,H,V,B,A,I,P,k,x,v,W])}}import{useState as wt}from"react";var to={sandbox:{id:"sandbox",apiKey:"sandbox",name:"Sandbox",description:"Code execution",type:"server"},webSearch:{id:"webSearch",apiKey:"web_search",name:"Web Search",description:"Search the web",type:"server"},imageGeneration:{id:"imageGeneration",apiKey:"image_generation",name:"Image Generation",description:"Generate images",type:"server"},chart:{id:"chart",apiKey:"chart",name:"Chart",description:"Create charts",type:"server"},fileSystem:{id:"fileSystem",apiKey:"file_system",name:"FileSystem",description:"Local file operations",type:"client"}},no=new Map(Object.values(to).map(e=>[e.apiKey,e.name]));function oo(){return Object.values(to)}function ro(e,t,n,s,i){let[a,p]=wt(e),[g,b]=wt(t),[h,B]=wt(n),[A,I]=wt(s),[P,k]=wt(i);return{sandbox:a,setSandbox:p,webSearch:g,setWebSearch:b,imageGeneration:h,setImageGeneration:B,chart:A,setChart:I,fileSystem:P,setFileSystem:k,capabilityLabelMap:no}}import{useEffect as ir,useState as ar}from"react";function so(e,t){let[n,s]=ar(null);return ir(()=>{let i=!1;async function a(){if(!e||!t){s(null);return}try{let g=await new ye().getAgent(t.accessToken,t.workspaceId,e);i||s(g)}catch{i||s(null)}}return a(),()=>{i=!0}},[e,t]),{currentAgentDetails:n}}import{useState as dn}from"react";function io(e,t,n){let[s,i]=dn(e),[a,p]=dn(t),[g,b]=dn(n);return{currentModel:s,setCurrentModel:i,currentAgentId:a,setCurrentAgentId:p,activeConnectorIds:g,setActiveConnectorIds:b}}import{useApp as cr,useInput as ur}from"ink";import{useCallback as Me,useRef as dr,useState as Ie}from"react";import{spawn as lr}from"child_process";function ao(e){return new Promise((t,n)=>{let s,i;process.platform==="darwin"?(s="open",i=[e]):process.platform==="win32"?(s="cmd",i=["/c","start","",e]):(s="xdg-open",i=[e]);let a=lr(s,i,{stdio:"ignore",detached:!0});a.once("error",p=>{n(p)}),a.once("spawn",()=>{a.unref(),t()})})}var lo=[{name:"help",aliases:["h","?"],description:"Show available commands"},{name:"clear",aliases:["cls","new"],description:"Start a new chat"},{name:"model",aliases:["m"],description:"Show/switch model",hasArgs:!0},{name:"agent",aliases:["a"],description:"Show/switch agent",hasArgs:!0},{name:"skills",aliases:["sk"],description:"List skills",hasArgs:!0},{name:"schedules",aliases:["sch"],description:"List schedules",hasArgs:!0},{name:"connectors",aliases:["conn"],description:"Select connectors"},{name:"capabilities",aliases:["cap"],description:"Select capabilities"},{name:"chats",aliases:["c"],description:"Switch to another chat"},{name:"workspace",aliases:["ws"],description:"List/switch workspace",hasArgs:!0},{name:"budget",aliases:["bg"],description:"View/set workspace budget",hasArgs:!0},{name:"usage",aliases:["u"],description:"View current month usage"},{name:"status",aliases:["s"],description:"Show session status"},{name:"profile",aliases:["p"],description:"Manage profiles",hasArgs:!0},{name:"open-in-browser",aliases:[],description:"Open current chat in browser"},{name:"share",aliases:[],description:"Get share link for current chat"},{name:"delete",aliases:["del"],description:"Delete current chat"},{name:"quit",aliases:["exit","q"],description:"Exit chat"}];function co(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?lo.filter(n=>n.name.startsWith(t)||n.aliases.some(s=>s.startsWith(t))):lo}function uo(e){let t=e.trim();if(!t.startsWith("/"))return null;let n=t.slice(1).split(/\s+/),s=n[0]?.toLowerCase(),i=n.slice(1).join(" ");switch(s){case"help":case"h":case"?":return{type:"help"};case"clear":case"cls":case"new":return{type:"clear"};case"model":case"m":return{type:"model",value:i||void 0};case"agent":case"a":return{type:"agent",value:i||void 0};case"skills":case"sk":return{type:"skills",value:i||void 0};case"schedules":case"sch":return{type:"schedules",value:i||void 0};case"connectors":case"conn":return{type:"connectors"};case"capabilities":case"cap":return{type:"capabilities"};case"chats":case"c":return{type:"chats"};case"workspace":case"ws":return{type:"workspace",value:i||void 0};case"budget":case"bg":return{type:"budget",value:i||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:i||void 0};case"open-in-browser":return{type:"open-in-browser"};case"share":return{type:"share"};case"delete":case"del":return{type:"delete"};case"quit":case"exit":case"q":return{type:"quit"};default:return{type:"unknown",input:t}}}var fo=`Available commands:
|
|
89
|
-
/help, /h, /? Show this help message
|
|
90
|
-
/clear, /cls, /new Start a new chat
|
|
91
|
-
/model [name], /m Show current model or switch to [name]
|
|
92
|
-
/agent [name], /a Show current agent or switch to [name]
|
|
93
|
-
/skills [name], /sk List skills or show details for [name]
|
|
94
|
-
/schedules [id], /sch List schedules or show details for [id]
|
|
95
|
-
/connectors, /conn Select active connectors
|
|
96
|
-
/capabilities, /cap Select capabilities (sandbox, web, etc.)
|
|
97
|
-
/chats, /c Switch to another chat
|
|
98
|
-
/workspace [id], /ws List or switch workspace
|
|
99
|
-
/budget [amount], /bg View or set workspace budget
|
|
100
|
-
/usage, /u View current month usage (top 10 by cost)
|
|
101
|
-
/status, /s Show current session status
|
|
102
|
-
/profile [args], /p Manage profiles (list/show/use/create/delete/rename/clone)
|
|
103
|
-
/open-in-browser Open current chat in browser
|
|
104
|
-
/share Get share link for current chat
|
|
105
|
-
/delete, /del Delete current chat
|
|
106
|
-
/quit, /exit, /q Exit interactive mode
|
|
107
|
-
|
|
108
|
-
Note: For detailed usage with sorting/limits, use: entrydesk usage --help
|
|
109
|
-
|
|
110
|
-
Keyboard shortcuts:
|
|
111
|
-
Ctrl+O Toggle full output mode
|
|
112
|
-
Ctrl+C Exit`;function fn(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} min`;case"hours":return`Every ${t.every} hr`;case"days":return`Every ${t.every} day at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${t.every} week`;case"months":return`Every ${t.every} month`;default:return"Unknown"}}function po({input:e,setInput:t,chatId:n,setChatId:s,currentChatTitle:i,setCurrentChatTitle:a,currentModel:p,setCurrentModel:g,currentAgentId:b,setCurrentAgentId:h,currentAgentDetails:B,setCurrentAgentDetails:A,activeConnectorIds:I,setActiveConnectorIds:P,sandbox:k,setSandbox:x,webSearch:v,setWebSearch:W,imageGeneration:H,setImageGeneration:V,chart:oe,setChart:J,fileSystem:be,setFileSystem:F,availableModels:$,availableAgents:S,availableConnectors:R,messages:j,hasPersistedChat:_,setHasPersistedChat:de,setMessages:N,addSystemMessage:c,startNewChat:ne,sendMessage:ge,setFullOutput:q,credentials:T,setCredentials:Q,setState:X,defaultCapabilities:ce,capabilityLabelMap:se,hasUploadingFiles:U=!1}){let{exit:z}=cr(),[K,le]=Ie([]),[we,O]=Ie(0),[ee,D]=Ie(!1),[l,f]=Ie(null),[y,Z]=Ie([]),[L,xe]=Ie(0),[Ge,qe]=Ie(new Set),[ve,Ke]=Ie(new Set),[Kt,Tt]=Ie([]),[Ne,tt]=Ie([]),[Fe,$t]=Ie([]),[He,Ht]=Ie([]),[De,Oe]=Ie(null),[kt,nt]=Ie(""),Xe=dr(!1),[Je,ot]=Ie(!1),rt=Me(async()=>{if(!T)return[];let w=new ye,d=[],o;do{let r=await w.listAvailableSkills(T.accessToken,T.workspaceId,{limit:100,nextKey:o});d.push(...r.skills),o=r.nextKey}while(o);return tt(d),d},[T]),st=Me(async()=>{if(!T)return[];let w=new ye,d=[],o;do{let r=await w.getSchedules(T.accessToken,T.workspaceId,{limit:100,nextKey:o});d.push(...r.schedules),o=r.nextKey}while(o);return $t(d),d},[T]),ke=Me(async w=>{if(w==="model"){if($.length===0){c("No models available.");return}let d=$.map(r=>({id:r.id,name:r.name,description:r.description}));Z(d);let o=p?d.findIndex(r=>r.id===p):-1;xe(Math.max(o,0)),f("model")}else if(w==="agent"){if(S.length===0){c("No agents available.");return}let d=S.map(r=>({id:r.id,name:r.name,description:r.description}));Z(d);let o=b?d.findIndex(r=>r.id===b):-1;xe(Math.max(o,0)),f("agent")}else if(w==="skills"){let d=Ne;if(d.length===0)try{d=await rt()}catch{c("Failed to load skills.");return}if(d.length===0){c("No skills available.");return}let o=d.map(r=>({id:r.id,name:r.name,description:r.description}));Z(o),xe(0),f("skills")}else if(w==="schedules"){let d=Fe;if(d.length===0)try{d=await st()}catch{c("Failed to load schedules.");return}if(d.length===0){c("No schedules found.");return}let o=d.map(r=>({id:r.id,name:r.name,description:`${r.agent.name} - ${r.isActive?"Active":"Paused"}`}));Z(o),xe(0),f("schedules")}else if(w==="connectors"){if(R.length===0){c("No connectors available.");return}let d=R.map(o=>({id:o.id,name:o.name}));Z(d),xe(0),qe(new Set(I??[])),f("connectors")}else if(w==="capabilities"){let d=oo().map(r=>({id:r.id,name:r.name,description:r.description}));Z(d),xe(0);let o=new Set;k&&o.add("sandbox"),v&&o.add("webSearch"),H&&o.add("imageGeneration"),oe&&o.add("chart"),be&&o.add("fileSystem"),Ke(o),f("capabilities")}else if(w==="chats"){if(!T){c("Not authenticated.");return}try{let d=new ye,{chats:o}=await d.getChats(T.accessToken,T.workspaceId,20);if(o.length===0){c("No chats available.");return}Tt(o);let r=o.map(C=>({id:C.id,name:C.title||"Untitled",description:new Date(C.createdAt).toLocaleDateString()}));Z(r);let u=r.findIndex(C=>C.id===n);xe(Math.max(u,0)),f("chats")}catch{c("Failed to load chats.")}}else if(w==="profile"){let d=pe.getProfileNames(),o=pe.getCurrentProfileName(),r=d.map(C=>({id:C,name:C,description:C===o?"(current)":void 0}));Z(r);let u=r.findIndex(C=>C.id===o);xe(Math.max(u,0)),f("profile")}D(!1),le([])},[$,S,Ne,Fe,R,I,p,b,rt,st,k,v,H,oe,be,T,n,c]),fe=Me(w=>{let d=he.getAll(w);g(d.model?.default),h(void 0),A(null);let o=d.connectors?.defaults;P(o&&o.length>0?o:void 0);let r=d.capabilities;x(r?.sandbox??ce.sandbox),W(r?.webSearch??ce.webSearch),V(r?.imageGeneration??ce.imageGeneration),J(r?.chart??ce.chart);let u=d.localTools;F(u?.fileSystem??ce.fileSystem)},[g,h,A,P,x,W,V,J,F,ce]),Be=Me(async()=>{try{let w=await Ve();Q({accessToken:w.accessToken,workspaceId:w.workspaceId}),X({status:"ready"})}catch(w){if(Q(null),w instanceof Qe){if(w.code==="not-logged-in"){X({status:"not-logged-in"});return}if(w.code==="no-workspace"){X({status:"no-workspace"});return}}let d=w instanceof Error?w.message:"Failed to authenticate";X({status:"error",message:d})}},[Q,X]),it=Me(async w=>{switch(w.type){case"help":return c(fo),!0;case"clear":return ne("Started a new chat."),!0;case"model":{if(w.value){let d=w.value.toLowerCase(),o=$.find(r=>r.id.toLowerCase()===d||r.name.toLowerCase().includes(d));if(o)b?ne(`Switched to model: ${o.name} (new chat)`):c(`Switched to model: ${o.name}`),g(o.id),h(void 0),A(null),he.setDefaultModel(o.id);else{let r=$.map(u=>u.name).join(", ");c(`Model "${w.value}" not found.
|
|
113
|
-
Available: ${r||"none"}`)}}else{let d=$.find(o=>o.id===p)?.name||p;c(p?`Current model: ${d}`:"No model selected. Using agent mode.")}return!0}case"agent":{if(!w.value)return S.length===0?(c("No agents available."),!0):(ke("agent"),!0);let d=w.value.toLowerCase(),o=S.find(r=>r.id.toLowerCase()===d||r.name.toLowerCase().includes(d));if(o)o.id!==b?ne(`Switched to agent: ${o.name} (new chat)`):c(`Switched to agent: ${o.name}`),h(o.id),g(void 0);else{let r=S.map(u=>u.name).join(", ");c(`Agent "${w.value}" not found.
|
|
114
|
-
Available: ${r||"none"}`)}return!0}case"skills":{if(!w.value)return ke("skills"),!0;let d=w.value.toLowerCase();return(Ne.length>0?Promise.resolve(Ne):rt().catch(()=>[])).then(r=>{let u=r.find(C=>C.id.toLowerCase()===d||C.name.toLowerCase().includes(d));c(u?`Skill: ${u.name}
|
|
115
|
-
${u.description}
|
|
116
|
-
Provider: ${u.provider}
|
|
117
|
-
Author: ${u.author.name}
|
|
118
|
-
ID: ${u.id}`:`Skill "${w.value}" not found.`)}),!0}case"schedules":{if(!w.value)return ke("schedules"),!0;let d=w.value.toLowerCase();return(Fe.length>0?Promise.resolve(Fe):st().catch(()=>[])).then(r=>{let u=r.find(C=>C.id.toLowerCase()===d||C.name.toLowerCase().includes(d));if(u){let C=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";c(`Schedule: ${u.name}
|
|
119
|
-
Agent: ${u.agent.name}
|
|
120
|
-
Status: ${u.isActive?"Active":"Paused"}
|
|
121
|
-
Repeat: ${fn(u.config)}
|
|
122
|
-
Next Run: ${C}
|
|
123
|
-
ID: ${u.id}`)}else c(`Schedule "${w.value}" not found.`)}),!0}case"connectors":{if(b){let o=B?.connectors??[];if(o.length===0)c("No agent connectors.");else{let r=o.map(u=>` - ${u.name}`).join(`
|
|
124
|
-
`);c(`Agent connectors:
|
|
125
|
-
${r}`)}return!0}let d=R.filter(o=>I?.includes(o.id));if(d.length===0)c("No active connectors.");else{let o=d.map(r=>` - ${r.name}`).join(`
|
|
126
|
-
`);c(`Active connectors:
|
|
127
|
-
${o}`)}return!0}case"capabilities":{if(b){let r=(B?.capabilities??[]).map(u=>se.get(u)??u);return c(r.length>0?`Agent capabilities:
|
|
128
|
-
${r.map(u=>` - ${u}`).join(`
|
|
129
|
-
`)}`:"No agent capabilities."),!0}let d=[];return k&&d.push("Sandbox"),v&&d.push("Web Search"),H&&d.push("Image Generation"),oe&&d.push("Chart"),be&&d.push("FileSystem"),c(d.length>0?`Active capabilities:
|
|
130
|
-
${d.map(o=>` - ${o}`).join(`
|
|
131
|
-
`)}`:"No capabilities enabled."),!0}case"chats":return c(i?`Current chat: ${i}`:`Current chat: ${n.slice(0,8)}...`),!0;case"workspace":{if(!T)return c("Not authenticated."),!0;let d=new ye;if(!w.value){try{let{workspaces:r}=await d.getWorkspaces(T.accessToken);if(r.length===0)c("No workspaces found.");else{let u=r.map(C=>` ${C.id===T.workspaceId?"* ":" "}${C.name}
|
|
132
|
-
ID: ${C.id}`);c(`Workspaces:
|
|
133
|
-
${u.join(`
|
|
134
|
-
`)}`)}}catch(r){c(`Failed to load workspaces: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}let o=w.value;try{let{workspaces:r}=await d.getWorkspaces(T.accessToken),u=r.find(C=>C.id===o);if(!u)return c(`Workspace not found: ${o}`),!0;await ft.saveWorkspaceId(o),c(`Switched to workspace: ${u.name}`),c("Please restart the chat to apply changes.")}catch(r){c(`Failed to switch workspace: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}case"budget":{if(!T)return c("Not authenticated."),!0;let d=new ye;if(!w.value){try{let u=await d.getBudget(T.accessToken,T.workspaceId);u.budget===null?c("No budget set for this workspace."):c(`Current budget: $${u.budget}`)}catch(u){c(`Failed to get budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let o=w.value.toLowerCase();if(o==="clear"||o==="null"){try{await d.updateBudget(T.accessToken,T.workspaceId,null),c("Budget cleared.")}catch(u){c(`Failed to clear budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let r=parseFloat(o);if(isNaN(r)||r<0)return c("Invalid budget amount. Must be a positive number."),!0;try{await d.updateBudget(T.accessToken,T.workspaceId,o),c(`Budget set to: $${o}`)}catch(u){c(`Failed to set budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}case"usage":{if(!T)return c("Not authenticated."),!0;let d=new ye;try{let o=[],r,u=0,C=10;do{let Ce=await d.getMonthlyUsages(T.accessToken,T.workspaceId,{nextKey:r,limit:20});if(o.push(...Ce.monthlyUsages),r=Ce.nextKey,u++,u>=C){c(`Warning: Showing first ${o.length} entries (pagination limit reached)`);break}}while(r);if(o.length===0)return c("No usage data found for this workspace."),!0;let m=0,E=0;for(let Ce of o)m+=parseFloat(Ce.totalCost),E+=Ce.operationCount;let ue=[...o].toSorted((Ce,Ye)=>parseFloat(Ye.totalCost)-parseFloat(Ce.totalCost)),M=10,ie=ue.slice(0,M),Pe=[`Total Cost: $${m.toFixed(2)}`,`Total Operations: ${E.toLocaleString()}`,`Users: ${o.length}`,"",`Top ${ie.length} Users by Cost:`,...ie.map(Ce=>` ${Ce.user.name}: $${parseFloat(Ce.totalCost).toFixed(2)} (${Ce.operationCount.toLocaleString()} ops)`)];o.length>M&&(Pe.push("",`... and ${o.length-M} more users`),Pe.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),c(Pe.join(`
|
|
135
|
-
`))}catch(o){c(`Failed to get usage: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"status":{let d=pe.getCurrentProfileName(),o=p?$.find(m=>m.id===p)?.name||p:null,r=b?S.find(m=>m.id===b)?.name||b:null,u=I?R.filter(m=>I.includes(m.id)).map(m=>m.name):[],C=[];return k&&C.push("Sandbox"),v&&C.push("Web Search"),H&&C.push("Image Gen"),oe&&C.push("Chart"),be&&C.push("FileSystem"),ft.getEmail().then(m=>{let E=[`Profile: ${d}${d!=="default"?" (non-default)":""}`,m?`Logged in as: ${m}`:"Not logged in",T?.workspaceId?`Workspace: ${T.workspaceId}`:null,_?`Chat ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${C.length>0?C.join(", "):"none"}`].filter(Boolean);c(E.join(`
|
|
136
|
-
`))}).catch(()=>{let m=[`Profile: ${d}`,"Not logged in",_?`Chat ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${C.length>0?C.join(", "):"none"}`].filter(Boolean);c(m.join(`
|
|
137
|
-
`))}),!0}case"profile":{let d=w.value?w.value.split(/\s+/).filter(Boolean):[];if(d.length===0)return ke("profile"),!0;let o=d[0]?.toLowerCase()||"list",r=d[1],u=d[2],C=pe.getProfileNames(),m=pe.getCurrentProfileName(),E=pe.getOverrideProfile(),ue=(M,ie=!1)=>{if(M)return M;if(ie&&C.length===1)return C[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(o==="list"){let M=[`Profiles (${C.length}):`];for(let ie of C){let Pe=ie===m?" (current)":"";M.push(` ${ie}${Pe}`)}return c(M.join(`
|
|
138
|
-
`)),!0}if(o==="current")return c(`Current profile: ${m}`),!0;if(o==="show"){let M=ue(r,!0),ie=he.getAll(M),Pe=await ft.getAll(M),Ce=!!Pe?.accessToken,Ye=ie.capabilities?Object.entries(ie.capabilities).filter(([,Jt])=>Jt).map(([Jt])=>Jt):[],To=ie.connectors?.defaults&&ie.connectors.defaults.length>0?ie.connectors.defaults.join(", "):"unset",$o=[`Profile: ${M}${M===m?" (current)":""}`,`API URL: ${ie.apiUrl??"default"}`,`Hub URL: ${ie.hubUrl??"default"}`,`Model: ${ie.model?.default??"unset"}`,`Connectors: ${To}`,`Capabilities: ${Ye.length>0?Ye.join(", "):"none"}`,Ce?`Logged in as: ${Pe?.email??"unknown"}`:"Not logged in",Ce&&Pe?.workspaceId?`Workspace ID: ${Pe.workspaceId}`:null].filter(Boolean);return c($o.join(`
|
|
139
|
-
`)),!0}if(o==="create"){let M=r||pe.DEFAULT_PROFILE;return pe.createProfile(M),c(`Profile created: ${M}`),!0}if(o==="use"||o==="switch"){let M=ue(r,!0);return pe.setOverrideProfile(M),pe.setCurrentProfile(M),fe(M),await Be(),ne(`Switched to profile: ${M} (new chat)`),!0}if(o==="delete"||o==="remove"||o==="rm"){let M=ue(r,!0),ie=M===m,Pe=pe.deleteProfile(M),Ce=`Profile deleted: ${M}`;if(ie)pe.setOverrideProfile(Pe.currentProfile),fe(Pe.currentProfile),await Be(),ne(`${Ce}
|
|
140
|
-
Switched to profile: ${Pe.currentProfile} (new chat)`);else if(E===M){let Ye=pe.getCurrentProfileName();pe.setOverrideProfile(Ye),fe(Ye),await Be(),ne(`${Ce}
|
|
141
|
-
Switched to profile: ${Ye} (new chat)`)}else c(Ce);return!0}if(o==="rename"||o==="move"||o==="mv"){let M=ue(r,!0);if(!u)throw new Error("New profile name is required.");let ie=pe.renameProfile(M,u);return c(`Profile renamed: ${M} -> ${u}`),E===M?(pe.setOverrideProfile(u),fe(u)):ie.currentProfile===u&&fe(u),!0}if(o==="clone"||o==="copy"){let M=ue(r,!0);if(!u)throw new Error("Target profile name is required.");let ie=he.getAll(M);return pe.createProfile(u),he.setAll(ie,u),await ft.clear(u),c(`Profile cloned: ${M} -> ${u}`),!0}c(`Unknown profile command: ${o}`)}catch(M){let ie=M instanceof Error?M.message:"Unknown error";c(`Profile error: ${ie}`)}return!0}case"open-in-browser":{let d=Yt().hubUrl.replace(/\/$/,""),o=_||j.some(E=>E.role!=="system"),r=T?`/${T.workspaceId}`:"",u=o?`${r}/chat/${n}`:`${r}/chat/new`,C=b?`?agentId=${encodeURIComponent(b)}`:"",m=`${d}${u}${C}`;try{await ao(m),c(`Opened in browser: ${m}`)}catch(E){c(`Failed to open browser: ${E instanceof Error?E.message:"Unknown error"}
|
|
142
|
-
URL: ${m}`)}return!0}case"share":{if(!T)return c("Not authenticated."),!0;if(!(_||j.some(o=>o.role!=="system")))return c("No conversation to share. Start a chat first."),!0;try{let r=await new ye().createChatShare(T.accessToken,T.workspaceId,n,"public"),C=`${Yt().hubUrl.replace(/\/$/,"")}/share/${r.id}`;c(`Share link: ${C}`)}catch(o){c(`Failed to create share link: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"delete":return T?_?(ot(!0),c("Delete this chat? (y/N)"),!0):(c("No chat to delete."),!0):(c("Not authenticated."),!0);case"quit":return z(),!0;case"unknown":return c(`Unknown command: ${w.input}
|
|
143
|
-
Type /help for available commands.`),!0;default:return!1}},[c,$,S,R,Ne,Fe,p,b,I,k,v,H,oe,be,n,i,z,ke,ne,se,B,_,j,rt,st,N,g,h,A,g,fe,Be]),It=Me(w=>{if(Xe.current=!1,Je){(w===""||w.startsWith("/"))&&(t(w),w.startsWith("/")&&ot(!1));return}if(t(w),nt(w),De!==null&&Oe(null),l&&(f(null),Z([])),w.startsWith("/")&&!w.includes(" ")){let d=co(w);le(d),O(0),D(d.length>0)}else D(!1),le([])},[l,De,Je,t]),dt=Me((w,d=!1)=>{if(w>=0&&w<K.length){let o=K[w];D(!1),le([]),o.name==="model"?(t("/model "),ke("model")):o.name==="agent"?(t("/agent "),ke("agent")):o.name==="skills"?(t("/skills "),ke("skills")):o.name==="schedules"?(t("/schedules "),ke("schedules")):o.name==="connectors"?(t("/connectors "),ke("connectors")):o.name==="capabilities"?(t("/capabilities "),ke("capabilities")):o.name==="chats"?(t("/chats "),ke("chats")):o.name==="profile"?(t("/profile "),ke("profile")):d?(t(""),it({type:o.name})):t(`/${o.name}`)}},[K,ke,t,it]),St=Me(async w=>{Xe.current=!1;let d=w.trim();if(!d||Je)return;if(l==="model"&&y.length>0){let r=y[L];r&&(b?ne(`Switched to model: ${r.name} (new chat)`):c(`Switched to model: ${r.name}`),g(r.id),h(void 0),A(null)),f(null),Z([]),t("");return}if(l==="agent"&&y.length>0){let r=y[L];r&&(r.id!==b?ne(`Switched to agent: ${r.name} (new chat)`):c(`Switched to agent: ${r.name}`),h(r.id),g(void 0)),f(null),Z([]),t("");return}if(l==="skills"&&y.length>0){let r=y[L];if(r){let u=Ne.find(C=>C.id===r.id);u&&c(`Skill: ${u.name}
|
|
144
|
-
${u.description}
|
|
145
|
-
Provider: ${u.provider}
|
|
146
|
-
Author: ${u.author.name}
|
|
147
|
-
ID: ${u.id}`)}f(null),Z([]),t("");return}if(l==="schedules"&&y.length>0){let r=y[L];if(r){let u=Fe.find(C=>C.id===r.id);if(u){let C=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";c(`Schedule: ${u.name}
|
|
148
|
-
Agent: ${u.agent.name}
|
|
149
|
-
Status: ${u.isActive?"Active":"Paused"}
|
|
150
|
-
Repeat: ${fn(u.config)}
|
|
151
|
-
Next Run: ${C}
|
|
152
|
-
ID: ${u.id}`)}}f(null),Z([]),t("");return}if(l==="connectors"){let r=Array.from(Ge);P(r.length>0?r:void 0),he.setDefaultConnectorIds(r);let u=R.filter(C=>Ge.has(C.id)).map(C=>C.name);c(u.length>0?`Active connectors: ${u.join(", ")}`:"All connectors disabled."),f(null),Z([]),t("");return}if(l==="capabilities"){let r=ve.has("sandbox"),u=ve.has("webSearch"),C=ve.has("imageGeneration"),m=ve.has("chart"),E=ve.has("fileSystem");x(r),W(u),V(C),J(m),F(E),he.setCapabilities({sandbox:r,webSearch:u,imageGeneration:C,chart:m}),he.setLocalTools({fileSystem:E});let ue=[];r&&ue.push("Sandbox"),u&&ue.push("Web Search"),C&&ue.push("Image Generation"),m&&ue.push("Chart"),E&&ue.push("FileSystem"),c(ue.length>0?`Active capabilities: ${ue.join(", ")}`:"All capabilities disabled."),f(null),Z([]),t("");return}if(l==="profile"&&y.length>0){let r=y[L];if(r){let u=pe.getCurrentProfileName();r.id!==u?(pe.setOverrideProfile(r.id),pe.setCurrentProfile(r.id),fe(r.id),Be(),ne(`Switched to profile: ${r.name}`)):c(`Already using profile: ${r.name}`)}f(null),Z([]),t("");return}if(ee&&K.length>0){dt(we,!0);return}Oe(null),nt(""),Ht(r=>r.length>0&&r.at(-1)===d?r:[...r,d]);let o=uo(d);if(o){await it(o),t(""),D(!1);return}if(U){c("Please wait for file uploads to complete.");return}t(""),D(!1),ge(d)},[ge,it,ee,K,we,dt,l,y,L,Ge,ve,R,Ne,Fe,c,t,b,ne,g,h,A,P,x,W,V,J,F,U,fe,Be,Je,T,_,n]);return ur((w,d)=>{if(d.ctrl&&w==="c"){if(e.length>0){It(""),Xe.current=!0,c("Press Ctrl+C again to exit.");return}if(Xe.current){z();return}z();return}if(d.ctrl&&w==="o"){q(o=>!o);return}if(Je){if(d.escape||d.return||w==="n"||w==="N"){ot(!1),t(""),c("Chat deletion cancelled.");return}if(w==="y"||w==="Y"){ot(!1),t(""),T&&_&&new ye().deleteChat(T.accessToken,T.workspaceId,n).then(()=>{ne("Chat deleted. Started a new chat.")}).catch(r=>{c(`Failed to delete chat: ${r.message||"Unknown error"}`)});return}return}if(l&&y.length>0){if(d.upArrow){xe(o=>o<=0?y.length-1:o-1);return}if(d.downArrow){xe(o=>o>=y.length-1?0:o+1);return}if(d.escape){f(null),Z([]),t("");return}if(d.return){if(l==="model"){let o=y[L];o&&(b?ne(`Switched to model: ${o.name} (new chat)`):c(`Switched to model: ${o.name}`),g(o.id),h(void 0),A(null),he.setDefaultModel(o.id))}else if(l==="agent"){let o=y[L];o&&(o.id!==b?ne(`Switched to agent: ${o.name} (new chat)`):c(`Switched to agent: ${o.name}`),h(o.id),g(void 0))}else if(l==="skills"){let o=y[L];if(o){let r=Ne.find(u=>u.id===o.id);r&&c(`Skill: ${r.name}
|
|
153
|
-
${r.description}
|
|
154
|
-
Provider: ${r.provider}
|
|
155
|
-
Author: ${r.author.name}
|
|
156
|
-
ID: ${r.id}`)}}else if(l==="schedules"){let o=y[L];if(o){let r=Fe.find(u=>u.id===o.id);if(r){let u=r.nextRunAt?new Date(r.nextRunAt).toLocaleString():"-";c(`Schedule: ${r.name}
|
|
157
|
-
Agent: ${r.agent.name}
|
|
158
|
-
Status: ${r.isActive?"Active":"Paused"}
|
|
159
|
-
Repeat: ${fn(r.config)}
|
|
160
|
-
Next Run: ${u}
|
|
161
|
-
ID: ${r.id}`)}}}else if(l==="connectors"){let o=Array.from(Ge);P(o.length>0?o:void 0),he.setDefaultConnectorIds(o);let r=R.filter(u=>Ge.has(u.id)).map(u=>u.name);c(r.length>0?`Active connectors: ${r.join(", ")}`:"All connectors disabled.")}else if(l==="capabilities"){let o=ve.has("sandbox"),r=ve.has("webSearch"),u=ve.has("imageGeneration"),C=ve.has("chart"),m=ve.has("fileSystem");x(o),W(r),V(u),J(C),F(m),he.setCapabilities({sandbox:o,webSearch:r,imageGeneration:u,chart:C}),he.setLocalTools({fileSystem:m});let E=[];o&&E.push("Sandbox"),r&&E.push("Web Search"),u&&E.push("Image Generation"),C&&E.push("Chart"),m&&E.push("FileSystem"),c(E.length>0?`Active capabilities: ${E.join(", ")}`:"All capabilities disabled.")}else if(l==="chats"){let o=y[L];if(o){let r=Kt.find(u=>u.id===o.id);r&&T&&(s(r.id),a(r.title||void 0),de(!0),new ye().getMessages(T.accessToken,T.workspaceId,r.id,20).then(({messages:C})=>{let m=C.filter(E=>E.role==="user"||E.role==="assistant").map(E=>({role:E.role,content:et(E.parts,!1),parts:E.parts})).filter(E=>E.content).toReversed();N(m),c(`Switched to: ${r.title||"Untitled"}`)}).catch(()=>{c("Failed to load chat messages.")}))}}else if(l==="profile"){let o=y[L];if(o){let r=pe.getCurrentProfileName();o.id!==r?(pe.setOverrideProfile(o.id),pe.setCurrentProfile(o.id),fe(o.id),Be(),ne(`Switched to profile: ${o.name}`)):c(`Already using profile: ${o.name}`)}}f(null),Z([]),t("");return}if(w===" "&&(l==="connectors"||l==="capabilities")){let o=y[L];o&&(l==="connectors"?qe:Ke)(u=>{let C=new Set(u);return C.has(o.id)?C.delete(o.id):C.add(o.id),C});return}if(w==="a"&&(l==="connectors"||l==="capabilities")){(l==="connectors"?qe:Ke)(new Set(y.map(r=>r.id)));return}if(w==="n"&&(l==="connectors"||l==="capabilities")){(l==="connectors"?qe:Ke)(new Set);return}return}if(ee&&K.length>0){if(d.upArrow){O(o=>o<=0?K.length-1:o-1);return}if(d.downArrow){O(o=>o>=K.length-1?0:o+1);return}if(d.escape){D(!1),le([]);return}if(d.tab){dt(we);return}}if(d.upArrow){if(e.includes(`
|
|
162
|
-
`)||He.length===0)return;if(De===null){nt(e);let r=He.length-1;Oe(r),t(He[r]);return}let o=Math.max(0,De-1);Oe(o),t(He[o]);return}if(d.downArrow){if(e.includes(`
|
|
163
|
-
`)||De===null)return;if(De>=He.length-1){Oe(null),t(kt);return}let o=De+1;Oe(o),t(He[o])}}),{suggestions:K,suggestionIndex:we,showSuggestions:ee,argMode:l,argItems:y,argIndex:L,selectedConnectorIds:Ge,selectedCapabilities:ve,deleteConfirmMode:Je,handleInputChange:It,handleSubmit:St}}import{useCallback as Ct,useRef as fr,useState as pr}from"react";function mo({credentials:e,currentModel:t,modelProviders:n,onUploadSuccess:s,onUploadError:i}){let[a,p]=pr([]),g=fr(0),b=Ct(x=>{if(!(!Array.isArray(n)||n.length===0)){for(let v of n)if(v.models.some(H=>H.id===x))return v.id;return n[0]?.id}},[n]),h=Ct(async x=>{if(!e){i?.(x.filename,"Not logged in");return}if(!Array.isArray(n)||n.length===0){i?.(x.filename,"Model providers not loaded yet. Please wait and try again.");return}let v=t?b(t):n[0]?.id;if(!v){i?.(x.filename,"No model provider available");return}let W=`file-${++g.current}`;p(H=>[...H,{id:W,filename:x.filename,mimeType:x.mimeType,status:"uploading"}]);try{let V=await new ye().uploadFile(e.accessToken,e.workspaceId,x,v);p(oe=>oe.map(J=>J.id===W?{...J,status:"uploaded",fileId:V.id}:J)),s?.(x.filename)}catch(H){let V=H instanceof Error?H.message:"Upload failed";p(oe=>oe.map(J=>J.id===W?{...J,status:"error",error:V}:J)),i?.(x.filename,V)}},[e,t,b,n,s,i]),B=Ct(x=>{p(v=>v.filter(W=>W.id!==x))},[]),A=Ct(()=>{p([])},[]),I=Ct(()=>a.filter(x=>x.status==="uploaded"&&x.fileId).map(x=>x.fileId),[a]),P=a.some(x=>x.status==="uploading"),k=a.length>0;return{pendingFiles:a,addFile:h,removeFile:B,clearFiles:A,getUploadedFileIds:I,hasUploadingFiles:P,hasFiles:k}}import{jsx as Y,jsxs as ae}from"react/jsx-runtime";var gr=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],hr=[un,un,cn,cn,Ze,Ze,Ze,Ze],ho=gr.map((e,t)=>`${hr[t]??Ze}${e}${te}`).join(`
|
|
164
|
-
`),xr=`${Ze}EntryDesk${te}`,br=500;function yr(e){let t="",n=0;for(;n<e.length;){if(e.charCodeAt(n)===27&&e[n+1]==="["){for(n+=2;n<e.length;){let s=e.charCodeAt(n);if(s>=64&&s<=126){n+=1;break}n+=1}continue}t+=e[n],n+=1}return t}function wr(e){let t=yr(e);return Math.max(...t.split(`
|
|
165
|
-
`).map(n=>n.length))}function Cr(e){let t=wr(ho);return e>=t?ho:xr}function xo({agentId:e,model:t,message:n,chatId:s,chatTitle:i,connectorIds:a,enableSandbox:p=!0,enableWebSearch:g=!1,enableImageGeneration:b=!1,enableChart:h=!1,enableFileSystem:B=!0}){let A=process.stdout.columns??80,I=Cr(A),P=go(null),k=Yn(s,i),{state:x,setState:v,messages:W,setMessages:H,input:V,setInput:oe,chatId:J,setChatId:be,currentChatTitle:F,setCurrentChatTitle:$,hasPersistedChat:S,setHasPersistedChat:R,credentials:j,setCredentials:_,currentResponse:de,setCurrentResponse:N,fullOutput:c,setFullOutput:ne,addSystemMessage:ge,startNewChat:q}=k,{credentials:T}=zn(v);jt(()=>{T&&!j&&_(T)},[T,j,_]);let{availableConnectors:Q,availableModels:X,availableAgents:ce,modelProviders:se,loading:U}=Xn(j),{currentModel:z,setCurrentModel:K,currentAgentId:le,setCurrentAgentId:we,activeConnectorIds:O,setActiveConnectorIds:ee}=io(t,e,a),D=go(!1);jt(()=>{if(!D.current){if(D.current=!0,!t&&!e){let m=he.getDefaultModel();m&&K(m)}if(!a&&!e){let m=he.getDefaultConnectorIds();m&&ee(m.length>0?m:void 0)}}},[t,e,a,K,ee]);let{currentAgentDetails:l}=so(le,j),{sandbox:f,setSandbox:y,webSearch:Z,setWebSearch:L,imageGeneration:xe,setImageGeneration:Ge,chart:qe,setChart:ve,fileSystem:Ke,setFileSystem:Kt,capabilityLabelMap:Tt}=ro(p,g,b,h,B),{pendingFiles:Ne,addFile:tt,removeFile:Fe,clearFiles:$t,getUploadedFileIds:He,hasUploadingFiles:Ht,hasFiles:De}=mo({credentials:j,currentModel:z,modelProviders:se,onUploadSuccess:m=>{ge(`\u2713 Attached: ${m}`)},onUploadError:(m,E)=>{ge(`\u2717 Failed to upload ${m}: ${E}`)}}),{sendMessage:Oe}=eo({chatId:J,credentials:j,currentAgentId:le,currentModel:z,activeConnectorIds:O,sandbox:f,webSearch:Z,imageGeneration:xe,chart:qe,localTools:Ke,fullOutput:c,setMessages:H,setState:v,setCurrentResponse:N,setCredentials:_,setHasPersistedChat:R,getFileIds:He,clearFiles:$t}),kt=gn(m=>{q(m),N("")},[q]),[nt,Xe]=mr(!1),Je=gn(async m=>{let E=m.text.trim(),ue=Ot(E);if(/^https?:\/\//.test(ue))return;if(await qn(E)&&Gn(ue)){let ie=await Kn(E);ie&&(m.preventDefault(),await tt(ie))}},[tt]),ot=gn(async()=>{if(!(nt||x.status!=="ready")){if(U||se.length===0){ge("Please wait for resources to load before pasting images.");return}ge("Reading clipboard..."),Xe(!0);try{let m=await Mn();if(m){let E=`clipboard-${Date.now()}.png`;ge(`Uploading: ${E} (${Math.round(m.buffer.length/1024)}KB)`),await tt({buffer:m.buffer,filename:E,mimeType:m.mime})}else ge("No image found in clipboard. Copy an image first.")}catch(m){let E=m instanceof Error?m.message:"Failed to read clipboard";ge(`Clipboard error: ${E}`)}finally{Xe(!1)}}},[tt,ge,nt,x.status,U,se.length]),{suggestions:rt,suggestionIndex:st,showSuggestions:ke,argMode:fe,argItems:Be,argIndex:it,selectedConnectorIds:It,selectedCapabilities:dt,deleteConfirmMode:St,handleInputChange:w,handleSubmit:d}=po({input:V,setInput:oe,chatId:J,setChatId:be,currentChatTitle:F,setCurrentChatTitle:$,currentModel:z,setCurrentModel:K,currentAgentId:le,setCurrentAgentId:we,currentAgentDetails:l,setCurrentAgentDetails:()=>{},activeConnectorIds:O,setActiveConnectorIds:ee,sandbox:f,setSandbox:y,webSearch:Z,setWebSearch:L,imageGeneration:xe,setImageGeneration:Ge,chart:qe,setChart:ve,fileSystem:Ke,setFileSystem:Kt,availableModels:X,availableAgents:ce,availableConnectors:Q,messages:W,hasPersistedChat:S,setHasPersistedChat:R,setMessages:H,addSystemMessage:ge,startNewChat:kt,sendMessage:Oe,setFullOutput:ne,credentials:j,setCredentials:_,setState:v,defaultCapabilities:{sandbox:p,webSearch:g,imageGeneration:b,chart:h,fileSystem:B},capabilityLabelMap:Tt,hasUploadingFiles:Ht});if(pn((m,E)=>{(E.ctrl||E.meta)&&m==="v"&&ot()},{isActive:x.status==="ready"&&!fe}),pn((m,E)=>{if(!E.escape)return;let ue=Date.now(),M=P.current;P.current=ue,!(!M||ue-M>br)&&(fe||ke||(P.current=null,De&&$t(),V.length>0&&w("")))},{isActive:x.status==="ready"}),pn((m,E)=>{E.return&&(kt("Started a new chat."),v({status:"ready"}))},{isActive:x.status==="error"}),jt(()=>{if(j&&!U&&x.status==="loading")if(!z&&!le){let m=he.getDefaultModel(),E=m&&X.some(M=>M.id===m),ue=E?m:X[0]?.id;ue?(E||he.setDefaultModel(ue),K(ue),v({status:"ready"})):ce.length===0?v({status:"no-model"}):v({status:"ready"})}else v({status:"ready"})},[j,U,z,le,X,ce,x.status,K,v]),jt(()=>{n&&j&&x.status==="ready"&&Oe(n)},[j,n]),x.status==="loading")return ae($e,{flexDirection:"column",children:[Y(G,{children:I}),ae($e,{children:[Y(G,{color:"cyan",children:Y(mn,{type:"dots"})}),Y(G,{children:" Initializing chat..."})]})]});if(x.status==="not-logged-in")return ae($e,{flexDirection:"column",children:[Y(G,{children:I}),Y(G,{color:"yellow",children:"Not logged in"}),Y(G,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if(x.status==="no-workspace")return ae($e,{flexDirection:"column",children:[Y(G,{children:I}),Y(G,{color:"yellow",children:"No workspace selected"}),Y(G,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if(x.status==="no-model")return ae($e,{flexDirection:"column",children:[Y(G,{children:I}),Y(G,{color:"yellow",children:"No model or agent specified"}),s&&Y(G,{dimColor:!0,children:"Could not determine the model used in this chat."}),Y(G,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),Y(G,{dimColor:!0,children:"Example: entrydesk chat -c 1 -i --model gemini-2.5-flash-lite"})]});if(x.status==="error")return ae($e,{flexDirection:"column",children:[Y(G,{children:I}),ae(G,{color:"red",children:["Error: ",x.message]}),Y(G,{dimColor:!0,children:"Press Enter to start a new chat, or Ctrl+C to exit"})]});let o=le?l?l.connectors&&l.connectors.length>0?l.connectors.map(m=>m.name).join(", "):"none":"loading...":O&&O.length>0?Q.filter(m=>O.includes(m.id)).map(m=>m.name).join(", ")||`${O.length} connector(s)`:"none",r=[];if(le)if(l?.capabilities)for(let m of l.capabilities)r.push(Tt.get(m)??m);else r.push("loading...");else f&&r.push("Sandbox"),Z&&r.push("Web"),xe&&r.push("Image"),qe&&r.push("Chart");Ke&&r.push("FileSystem");let u=pe.getCurrentProfileName(),C=u!=="default";return ae($e,{flexDirection:"column",children:[ae($e,{marginBottom:1,flexDirection:"column",children:[Y(G,{children:I}),ae($e,{children:[Y(G,{bold:!0,color:"cyan",children:F?`Continuing: ${F}`:"EntryDesk CLI"}),ae(G,{dimColor:!0,children:[" v","1.11.9"]}),C&&ae(G,{color:"magenta",children:[" [",u,"]"]}),Y(G,{dimColor:!0,children:" (type /help for commands)"})]})]}),W.map((m,E)=>{let ue=m.parts&&c?et(m.parts,!0):m.content,M=m.role==="user"?"green":m.role==="system"?"yellow":"blue",ie=m.role==="user"?"You":m.role==="system"?"System":"Assistant";return ae($e,{flexDirection:"column",marginBottom:1,children:[ae(G,{bold:!0,color:M,children:[ie,":"]}),Y(ln,{text:ue})]},E)}),de&&ae($e,{flexDirection:"column",marginBottom:1,children:[Y(G,{bold:!0,color:"blue",children:"Assistant:"}),Y(ln,{text:de})]}),x.status==="ready"&&Y(In,{suggestions:rt,activeIndex:st,visible:ke}),x.status==="ready"&&fe&&Y(kn,{items:Be,activeIndex:it,pageSize:fe==="agent"||fe==="skills"||fe==="model"?5:10,selectedIds:fe==="connectors"?It:fe==="capabilities"?dt:void 0,multiSelect:fe==="connectors"||fe==="capabilities",visible:!0,title:fe==="model"?"Select model:":fe==="agent"?"Select agent:":fe==="skills"?"Select skill:":fe==="connectors"?"Select connectors:":fe==="capabilities"?"Select capabilities:":"Select chat:"}),x.status==="sending"&&!de?ae($e,{children:[Y(G,{color:"cyan",children:Y(mn,{type:"dots"})}),Y(G,{children:" Thinking..."})]}):x.status==="ready"&&!fe?ae($e,{flexDirection:"column",children:[St&&Y($e,{marginBottom:1,children:Y(G,{color:"yellow",children:"\u26A0\uFE0F Delete this chat? (y/N) "})}),De&&!St&&ae($e,{marginBottom:1,flexDirection:"row",gap:1,children:[Y(G,{dimColor:!0,children:"Attachments:"}),Ne.map((m,E)=>ae(G,{children:[m.status==="uploading"?ae(G,{color:"yellow",children:[Y(mn,{type:"dots"})," ",m.filename]}):m.status==="error"?ae(G,{color:"red",children:["\u2717 ",m.filename]}):ae(G,{color:"green",children:["\u2713 ",m.filename]}),E<Ne.length-1&&Y(G,{children:", "})]},m.id))]}),ae($e,{children:[Y(G,{color:"green",children:"> "}),Y(Dn,{value:V,onChange:w,onSubmit:d,onPaste:Je,leadingOffset:2,multiline:!0})]})]}):null,ae($e,{marginTop:1,flexDirection:"column",children:[ae($e,{gap:2,children:[ae(G,{children:[Y(G,{dimColor:!0,children:"Model: "}),Y(G,{color:"magenta",children:le?l?.model?.name||"loading...":X.find(m=>m.id===z)?.name||z||"none"})]}),ae(G,{children:[Y(G,{dimColor:!0,children:"Connectors: "}),Y(G,{color:"cyan",children:o})]}),ae(G,{children:[Y(G,{dimColor:!0,children:"Capabilities: "}),Y(G,{color:"green",children:r.length>0?r.join(", "):"none"})]})]}),ae(G,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",c?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as Sr}from"react/jsx-runtime";async function $r(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function kr(e,t,n,s){if(s<1)return console.error("Chat number must be 1 or greater"),null;let{chats:i}=await e.getChats(t,n,20);if(i.length===0)return console.error("No chats found. Start a new chat first."),null;if(s>i.length)return console.error(`Chat number ${s} not found. You have ${i.length} recent chats.`),console.error("Use `entrydesk chats` to see available chats."),null;let a=i[s-1],p;if(!a.agentId){let{messages:g}=await e.getMessages(t,n,a.id,10);p=g.find(h=>h.role==="assistant"&&h.modelId)?.modelId}return{chat:a,modelId:p}}var ut="\x1B[2m",Se="\x1B[0m",hn="\x1B[36m",Co="\x1B[33m",Mt="\x1B[32m",bo="stream-json";function yo(e,t,n,s){e&&t&&(console.error(`Error: Cannot use both ${n} and ${s}`),process.exit(1))}function Gt(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
|
|
166
|
-
`)}function qt(e,t){if(t)return e;let n=e.split(`
|
|
167
|
-
`);if(n.length<=20)return e;let s=n.slice(0,5),i=n.slice(-5),a=n.length-10;return[...s,`${ut}... (${a} lines omitted, use --full-output to see all) ...${Se}`,...i].join(`
|
|
168
|
-
`)}function Ir(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function wo(e,t){if(!e)return"(no result)";if(typeof e!="object")return qt(String(e),t);let n=e;if("structuredContent"in n&&n.structuredContent){let s=n.structuredContent,i=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&i.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&i.push(`${Co}[stderr]${Se} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let a=s.urls;for(let p of a)p.path&&p.url&&i.push(`${p.path}: ${p.url}`)}return i.length===0&&i.push(JSON.stringify(s,null,2)),qt(i.join(`
|
|
169
|
-
`),t)}if("content"in n&&Array.isArray(n.content)){let i=n.content.filter(a=>a.type==="text"&&a.text).map(a=>a.text).join(`
|
|
170
|
-
`);return qt(i||JSON.stringify(e,null,2),t)}return qt(JSON.stringify(e,null,2),t)}async function Gi(e){let t,n;try{let Q=await Ve();t=Q.accessToken,n=Q.workspaceId}catch(Q){bn(Q)}let s=e.output===bo;e.output&&!s&&(console.error(`Invalid --output value. Supported: ${bo}`),process.exit(1));let i=!s&&(e.plain||!process.stdout.isTTY),a=he.getDefaultModel(),p=e.message;!p&&!process.stdin.isTTY&&(p=await $r());let g=new ye;async function b(){if(!a)try{let{models:Q}=await g.getModels(t,n),X=Q[0]?.id;if(!X)return;he.setDefaultModel(X),a=X}catch{}}let h,B,A,I;if(e.continue){let Q=await kr(g,t,n,e.continue);Q||process.exit(1),h=Q.chat.id,B=Q.chat.title??void 0,A=Q.chat.agentId??void 0,I=Q.modelId;let X=e.agentId||e.model||A||I||a;!X&&!e.interactive&&(await b(),X=e.agentId||e.model||A||I||a),!X&&!e.interactive&&(i||console.log(`Continuing chat: ${Q.chat.title||"Untitled"}`),console.error(`
|
|
171
|
-
Could not determine model for this chat. Please specify --model or -a.`),console.error('Example: entrydesk chat -c 1 -m "message" --model gemini-2.5-flash-lite'),process.exit(1)),!i&&!e.interactive&&console.log(`Continuing chat: ${Q.chat.title||"Untitled"}
|
|
172
|
-
`)}let P=e.agentId||A,k=e.model||I||a||void 0;!P&&!k&&(await b(),k=e.model||I||a||void 0),yo(e.sandbox,e.noSandbox,"--sandbox","--no-sandbox"),yo(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let x=he.getCapabilities(),v=e.noSandbox?!1:e.sandbox?!0:x?.sandbox??!0,W=e.webSearch??x?.webSearch??!1,H=e.imageGen??x?.imageGeneration??!1,V=e.chart??x?.chart??!1,oe=he.getDefaultConnectorIds(),J=e.connectors??oe??void 0,be=he.getLocalTools(),F=e.noFileSystem?!1:e.fileSystem?!0:be?.fileSystem??!0;if(e.interactive){Tr(Sr(xo,{agentId:P,model:k,message:e.message,chatId:h,chatTitle:B??void 0,connectorIds:J,enableSandbox:v,enableWebSearch:W,enableImageGeneration:H,enableChart:V,enableFileSystem:F}),{exitOnCtrlC:!1});return}let $=!e.continue&&!k&&!P;(!p||$)&&(console.error("Usage: entrydesk chat -m <message> --model <model>"),console.error(" entrydesk chat -m <message> -a <agent>"),console.error(" entrydesk chat -c <number> -m <message>"),console.error(' echo "message" | entrydesk chat --model <model>'),console.error(" entrydesk chat -i (interactive mode)"),console.error(""),console.error("Options:"),console.error(" -m, --message Message to send (or pipe via stdin)"),console.error(" --model Model ID to use (required if no agent and no default)"),console.error(" -a, --agent Agent ID to use (required if no model)"),console.error(" -c, --continue Continue recent chat by number (1 = most recent)"),console.error(" -i Interactive mode"),console.error(" --plain Plain text output (no colors/formatting)"),console.error(" --output stream-json Stream JSON events (for scripting)"),console.error(" --full-output Show full tool results without truncation"),console.error(""),console.error("List available models: entrydesk models"),console.error("List available agents: entrydesk agents"),console.error("List recent chats: entrydesk chats"),process.exit(1));let S=e.fullOutput??!1,R=h||Ut(),j=F?Pt():void 0,_=F?_t():void 0,de=[],N=Ut(),c=(Q,X,ce)=>{let se={id:R};return Q&&(se.message={id:Q.id,createdAt:new Date,role:"user",parts:[{type:"text",text:Q.text}]}),P?se.agentId=P:(k&&(se.model=k),se.connectorIds=J??[],se.enableSandbox=v,se.enableWebSearch=W,se.enableImageGeneration=H,se.enableChart=V),j&&(se.clientTools=j),_&&(se.clientToolSystemPrompt=_),X&&X.length>0&&(se.clientToolResults=X),ce&&ce.length>0&&(se.previousMessages=ce),se},ne=async Q=>{if(!Q.body)throw new Error("No response body");let X=Q.body.getReader(),ce=new TextDecoder,se="",U=new Map,z=[],K=[];for(;;){let{done:le,value:we}=await X.read();if(le)break;se+=ce.decode(we,{stream:!0});let O=se.split(`
|
|
173
|
-
`);se=O.pop()||"";for(let ee of O){let D=ee.trimEnd();if(D==="data: [DONE]"){s&&Gt("done");continue}if(D.startsWith("data: "))try{let l=JSON.parse(D.slice(6));if(l.type&&K.push(l),s){l.type==="text-delta"&&l.delta!==void 0?Gt("text-delta",l.delta):l.type==="reasoning-delta"&&l.delta!==void 0?Gt("reasoning-delta",l.delta):Gt(l.type||"event",l);continue}if(i){if(l.type==="text-delta"&&l.delta&&process.stdout.write(l.delta),F&&(l.type==="tool-input-available"||l.type==="tool-call")&&l.toolCallId&&l.toolName&&je(l.toolName)){let f=l.args||l.input||{};z.push({toolCallId:l.toolCallId,toolName:l.toolName,args:f})}continue}switch(l.type){case"reasoning-delta":l.delta&&process.stdout.write(`${ut}${l.delta}${Se}`);break;case"reasoning-end":process.stdout.write(`
|
|
174
|
-
|
|
175
|
-
`);break;case"text-delta":l.delta&&process.stdout.write(l.delta);break;case"tool-call-streaming-start":case"tool-input-start":if(l.toolCallId&&l.toolName){U.set(l.toolCallId,{toolName:l.toolName});let y=F&&je(l.toolName)?`${Mt}[LOCAL]${Se} `:"";console.log(`
|
|
176
|
-
${hn}\u250C\u2500 ${y}Tool Call: ${l.toolName}${Se}`)}break;case"tool-call":case"tool-input-available":if(l.toolCallId&&l.toolName){let f=l.args||l.input||{},y=Ir(f);console.log(`${Co}\u2502 Arguments:${Se}`);for(let Z of y.split(`
|
|
177
|
-
`))console.log(`${ut}\u2502 ${Z}${Se}`);F&&je(l.toolName)&&(U.set(l.toolCallId,{toolName:l.toolName,args:f}),z.push({toolCallId:l.toolCallId,toolName:l.toolName,args:f}))}break;case"tool-result":if(l.toolCallId){let f=U.get(l.toolCallId),y=wo(l.result,S);console.log(`${Mt}\u2502 Result:${Se}`);for(let Z of y.split(`
|
|
178
|
-
`))console.log(`${ut}\u2502 ${Z}${Se}`);console.log(`${hn}\u2514\u2500 ${f?.toolName||"Tool"} completed${Se}
|
|
179
|
-
`),U.delete(l.toolCallId)}break;case"error":l.errorText&&console.error(`${ut}Error: ${l.errorText}${Se}`);break}}catch{}}}return{pendingClientTools:z,messageParts:K}},ge=c({id:Ut(),text:p}),q=await g.chat(t,n,ge),T=await ne(q);for(de=T.messageParts;T.pendingClientTools.length>0;){let Q=[];for(let U of T.pendingClientTools){!i&&!s&&console.log(`${Mt}\u2502 Executing locally...${Se}`);let z=await Et(U.toolName,U.args),K=z.success?JSON.stringify(z.result):z.error||"Unknown error";if(Q.push({toolCallId:U.toolCallId,toolName:U.toolName,content:[{type:"text",text:K}],isError:!z.success}),!i&&!s){let le=wo(z.success?z.result:{error:z.error},S);console.log(`${Mt}\u2502 Result:${Se}`);for(let we of le.split(`
|
|
180
|
-
`))console.log(`${ut}\u2502 ${we}${Se}`);console.log(`${hn}\u2514\u2500 ${U.toolName} completed${Se}
|
|
181
|
-
`)}}let X=de.map(U=>{if(U.type==="tool-call"){let z=Q.find(le=>le.toolCallId===U.toolCallId),K=z?.content.filter(le=>le.type==="text").map(le=>le.text).join(`
|
|
182
|
-
`);return{type:"tool-invocation",toolCallId:U.toolCallId,toolName:U.toolName,args:U.args,state:z?.isError?"output-error":"output-available",output:K}}return U}),ce=[{id:N,role:"assistant",parts:X}];N=Ut();let se=c(void 0,Q,ce);q=await g.chat(t,n,se),T=await ne(q),de=T.messageParts}s||console.log("")}export{Gi as runChat};
|
package/dist/version-TI2ROJQT.js
DELETED