@entrydesk/cli 1.4.0 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +132 -127
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{a as $e,b as Qe,c as dt,d as pe,e as Et,f as xe,g as H,h as ne,i as Me,n as B}from"./chunk-J6ER4MMT.js";import{render as Pi}from"ink";function Co(){console.log(`
2
+ import{a as $e,b as Qe,c as dt,d as pe,e as _t,f as xe,g as H,h as ne,i as Me,n as B}from"./chunk-J6ER4MMT.js";import{render as Ki}from"ink";function So(){console.log(`
3
3
  Usage: entrydesk agents [list|create|update|delete] [options]
4
4
 
5
5
  Commands:
@@ -21,8 +21,8 @@ Create/Update Options:
21
21
 
22
22
  Flags:
23
23
  --json Output JSON
24
- `)}function Os(e){if(!e)return[];let t=new Map([["sandbox","sandbox"],["web","web_search"],["web-search","web_search"],["web_search","web_search"],["image","image_generation"],["image-gen","image_generation"],["image_generation","image_generation"],["chart","chart"]]);return e.map(n=>t.get(n)??n)}function en(e){return(!e.name||!e.description||!e.systemPrompt||!e.modelId)&&(console.error("Missing required fields for agent create/update."),Co(),process.exit(1)),{name:e.name,description:e.description,systemPrompt:e.systemPrompt,modelId:e.modelId,connectorIds:e.connectorIds??[],capabilities:Os(e.capabilities),conversationStarters:e.conversationStarters??[],tools:e.tools,iconId:e.iconId}}async function tn(e){try{if(e.help){Co();return}let t=await pe(),{accessToken:n,workspaceId:s}=t,o=e.action||"list",i=new B;if(o==="create"){let a=en(e),l=await i.createAgent(n,s,a);if(e.json){console.log(JSON.stringify(l));return}console.log(`Created agent: ${l.name}`),console.log(` ID: ${l.id}`);return}if(o==="update"){let a=e.agentId;if(!a)throw new Error("Missing agentId for update command");let l=en(e);await i.updateAgent(n,s,a,l),console.log(`Updated agent: ${a}`);return}if(o==="delete"){let a=e.agentId;if(!a)throw new Error("Missing agentId for delete command");await i.deleteAgent(n,s,a),console.log(`Deleted agent: ${a}`);return}o!=="list"&&(console.error(`Unknown agents command: ${o}`),Co(),process.exit(1));let{agents:r}=await i.getAgents(n,s);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No agents found in this workspace.");return}console.log(`Available Agents (${r.length}):
25
- `);for(let a of r)console.log(` ${a.name} (${a.visibility})`),a.description&&console.log(` ${a.description.slice(0,80)}`),console.log(` ID: ${a.id}`),console.log("")}catch(t){xe(t)}}function Rs(){console.log(`
24
+ `)}function Vs(e){if(!e)return[];let t=new Map([["sandbox","sandbox"],["web","web_search"],["web-search","web_search"],["web_search","web_search"],["image","image_generation"],["image-gen","image_generation"],["image_generation","image_generation"],["chart","chart"]]);return e.map(o=>t.get(o)??o)}function sn(e){return(!e.name||!e.description||!e.systemPrompt||!e.modelId)&&(console.error("Missing required fields for agent create/update."),So(),process.exit(1)),{name:e.name,description:e.description,systemPrompt:e.systemPrompt,modelId:e.modelId,connectorIds:e.connectorIds??[],capabilities:Vs(e.capabilities),conversationStarters:e.conversationStarters??[],tools:e.tools,iconId:e.iconId}}async function rn(e){try{if(e.help){So();return}let t=await pe(),{accessToken:o,workspaceId:s}=t,n=e.action||"list",i=new B;if(n==="create"){let a=sn(e),l=await i.createAgent(o,s,a);if(e.json){console.log(JSON.stringify(l));return}console.log(`Created agent: ${l.name}`),console.log(` ID: ${l.id}`);return}if(n==="update"){let a=e.agentId;if(!a)throw new Error("Missing agentId for update command");let l=sn(e);await i.updateAgent(o,s,a,l),console.log(`Updated agent: ${a}`);return}if(n==="delete"){let a=e.agentId;if(!a)throw new Error("Missing agentId for delete command");await i.deleteAgent(o,s,a),console.log(`Deleted agent: ${a}`);return}n!=="list"&&(console.error(`Unknown agents command: ${n}`),So(),process.exit(1));let{agents:r}=await i.getAgents(o,s);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No agents found in this workspace.");return}console.log(`Available Agents (${r.length}):
25
+ `);for(let a of r)console.log(` ${a.name} (${a.visibility})`),a.description&&console.log(` ${a.description.slice(0,80)}`),console.log(` ID: ${a.id}`),console.log("")}catch(t){xe(t)}}function Ks(){console.log(`
26
26
  Usage: entrydesk budget [get|set|clear] [options]
27
27
 
28
28
  Commands:
@@ -32,7 +32,7 @@ Commands:
32
32
 
33
33
  Flags:
34
34
  --json Output JSON
35
- `)}async function on(e){try{if(e.help){Rs();return}let t=await pe(),{accessToken:n,workspaceId:s}=t,o=e.action||"get",i=new B;if(o==="set"){let a=e.configKey;if(!a)throw new Error("Missing budget amount for set command");let l=parseFloat(a);if(isNaN(l)||l<0)throw new Error("Budget must be a positive number");let d=await i.updateBudget(n,s,a);if(e.json){console.log(JSON.stringify(d));return}console.log(`Budget updated: $${a}`);return}if(o==="clear"){let a=await i.updateBudget(n,s,null);if(e.json){console.log(JSON.stringify(a));return}console.log("Budget cleared.");return}if(o!=="get")throw new Error(`Unknown budget command: ${o}`);let r=await i.getBudget(n,s);if(e.json){console.log(JSON.stringify(r));return}if(r.budget===null){console.log("No budget set for this workspace.");return}console.log(`Current workspace budget: $${r.budget}`)}catch(t){xe(t)}}import{render as Or}from"ink";import{v4 as fo}from"uuid";import{exec as Us}from"child_process";import js from"fs";import et from"fs/promises";import nn from"os";import $o from"path";import{promisify as Bs}from"util";import{glob as Fs}from"glob";var Ws=Bs(Us),Ms=`## Filesystem Tool Instructions
35
+ `)}async function an(e){try{if(e.help){Ks();return}let t=await pe(),{accessToken:o,workspaceId:s}=t,n=e.action||"get",i=new B;if(n==="set"){let a=e.configKey;if(!a)throw new Error("Missing budget amount for set command");let l=parseFloat(a);if(isNaN(l)||l<0)throw new Error("Budget must be a positive number");let d=await i.updateBudget(o,s,a);if(e.json){console.log(JSON.stringify(d));return}console.log(`Budget updated: $${a}`);return}if(n==="clear"){let a=await i.updateBudget(o,s,null);if(e.json){console.log(JSON.stringify(a));return}console.log("Budget cleared.");return}if(n!=="get")throw new Error(`Unknown budget command: ${n}`);let r=await i.getBudget(o,s);if(e.json){console.log(JSON.stringify(r));return}if(r.budget===null){console.log("No budget set for this workspace.");return}console.log(`Current workspace budget: $${r.budget}`)}catch(t){xe(t)}}import{render as Vr}from"ink";import{v4 as mo}from"uuid";import{exec as qs}from"child_process";import zs from"fs";import et from"fs/promises";import ln from"os";import To from"path";import{promisify as Ys}from"util";import{glob as Xs}from"glob";var Zs=Ys(qs),Qs=`## Filesystem Tool Instructions
36
36
 
37
37
  You have access to filesystem tools that allow you to interact with the user's local filesystem.
38
38
 
@@ -56,24 +56,24 @@ You have access to filesystem tools that allow you to interact with the user's l
56
56
  - Search results are limited to prevent overwhelming responses
57
57
  - Execute Command has a default timeout of 30 seconds (max 5 minutes)
58
58
  - The current working directory is: ${process.cwd()}
59
- - The user's home directory is: ${nn.homedir()}
60
- `,Js=[{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 sn(){return{name:"filesystem",systemPrompt:Ms,tools:Js}}function Ke(e){return e.startsWith("~/")?$o.join(nn.homedir(),e.slice(2)):e}function Yt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
59
+ - The user's home directory is: ${ln.homedir()}
60
+ `,er=[{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 cn(){return{name:"filesystem",systemPrompt:Qs,tools:er}}function Ke(e){return e.startsWith("~/")?To.join(ln.homedir(),e.slice(2)):e}function Zt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
61
61
 
62
- ... (truncated, ${e.length-t} more characters)`}async function rn(e,t){try{switch(e){case"filesystem__read_file":{let n=Ke(t.path),s=await et.readFile(n,"utf-8");return{success:!0,result:Yt(s)}}case"filesystem__read_multiple_files":{let n=t.paths.slice(0,10),s={};for(let o of n){let i=Ke(o);try{let r=await et.readFile(i,"utf-8");s[o]=Yt(r,5e4)}catch(r){s[o]={error:r instanceof Error?r.message:String(r)}}}return{success:!0,result:s}}case"filesystem__write_file":{let n=Ke(t.path),s=t.content;return await et.mkdir($o.dirname(n),{recursive:!0}),await et.writeFile(n,s,"utf-8"),{success:!0,result:{written:n}}}case"filesystem__create_directory":{let n=Ke(t.path);return await et.mkdir(n,{recursive:!0}),{success:!0,result:{created:n}}}case"filesystem__list_directory":{let n=Ke(t.path);return{success:!0,result:(await et.readdir(n,{withFileTypes:!0})).map(i=>({name:i.name,type:i.isDirectory()?"directory":i.isFile()?"file":i.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let n=t.pattern,s=t.cwd?Ke(t.cwd):process.cwd(),o=await Fs(n,{cwd:s,nodir:!0,maxDepth:10});return{success:!0,result:{files:o.slice(0,100),total:o.length,truncated:o.length>100}}}case"filesystem__get_file_info":{let n=Ke(t.path),s=await et.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=Ke(t.source),s=Ke(t.destination);return await et.mkdir($o.dirname(s),{recursive:!0}),await et.rename(n,s),{success:!0,result:{moved:{from:n,to:s}}}}case"filesystem__execute_command":{let n=t.command,s=t.cwd?Ke(t.cwd):process.cwd(),o=Math.min(t.timeout||3e4,3e5);if(!js.existsSync(s))return{success:!1,error:`Working directory does not exist: ${s}`};let{stdout:i,stderr:r}=await Ws(n,{cwd:s,timeout:o,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:Yt(i,5e4),stderr:Yt(r,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(n){return{success:!1,error:n instanceof Error?n.message:String(n)}}}function So(e){return e.startsWith("filesystem__")}function an(){return[sn()]}function Xt(){return an().flatMap(e=>e.tools)}function Zt(){return an().map(e=>e.systemPrompt).filter(Boolean).join(`
62
+ ... (truncated, ${e.length-t} more characters)`}async function un(e,t){try{switch(e){case"filesystem__read_file":{let o=Ke(t.path),s=await et.readFile(o,"utf-8");return{success:!0,result:Zt(s)}}case"filesystem__read_multiple_files":{let o=t.paths.slice(0,10),s={};for(let n of o){let i=Ke(n);try{let r=await et.readFile(i,"utf-8");s[n]=Zt(r,5e4)}catch(r){s[n]={error:r instanceof Error?r.message:String(r)}}}return{success:!0,result:s}}case"filesystem__write_file":{let o=Ke(t.path),s=t.content;return await et.mkdir(To.dirname(o),{recursive:!0}),await et.writeFile(o,s,"utf-8"),{success:!0,result:{written:o}}}case"filesystem__create_directory":{let o=Ke(t.path);return await et.mkdir(o,{recursive:!0}),{success:!0,result:{created:o}}}case"filesystem__list_directory":{let o=Ke(t.path);return{success:!0,result:(await et.readdir(o,{withFileTypes:!0})).map(i=>({name:i.name,type:i.isDirectory()?"directory":i.isFile()?"file":i.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let o=t.pattern,s=t.cwd?Ke(t.cwd):process.cwd(),n=await Xs(o,{cwd:s,nodir:!0,maxDepth:10});return{success:!0,result:{files:n.slice(0,100),total:n.length,truncated:n.length>100}}}case"filesystem__get_file_info":{let o=Ke(t.path),s=await et.stat(o);return{success:!0,result:{path:o,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 o=Ke(t.source),s=Ke(t.destination);return await et.mkdir(To.dirname(s),{recursive:!0}),await et.rename(o,s),{success:!0,result:{moved:{from:o,to:s}}}}case"filesystem__execute_command":{let o=t.command,s=t.cwd?Ke(t.cwd):process.cwd(),n=Math.min(t.timeout||3e4,3e5);if(!zs.existsSync(s))return{success:!1,error:`Working directory does not exist: ${s}`};let{stdout:i,stderr:r}=await Zs(o,{cwd:s,timeout:n,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:Zt(i,5e4),stderr:Zt(r,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(o){return{success:!1,error:o instanceof Error?o.message:String(o)}}}function Io(e){return e.startsWith("filesystem__")}function dn(){return[cn()]}function Qt(){return dn().flatMap(e=>e.tools)}function eo(){return dn().map(e=>e.systemPrompt).filter(Boolean).join(`
63
63
 
64
- `)}function tt(e){return So(e)}async function Qt(e,t){return So(e)?rn(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as Pe,Text as K,useInput as Fo}from"ink";import Wo from"ink-spinner";import{useCallback as Mo,useEffect as uo,useRef as Qn,useState as vr}from"react";import{Box as eo,Text as _t}from"ink";import{jsx as to,jsxs as Lt}from"react/jsx-runtime";function ln(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function cn({items:e,activeIndex:t,selectedIds:n,multiSelect:s=!1,visible:o,title:i,pageSize:r=10}){if(!o||e.length===0)return null;let a=process.stdout.columns??80,l=s?4:0,d=Math.max(20,a-2-2-l),I=Math.max(1,r),x=Math.floor(t/I)*I,b=Math.min(e.length,x+I),C=e.slice(x,b);return Lt(eo,{flexDirection:"column",marginBottom:1,children:[to(_t,{bold:!0,color:"cyan",children:i}),to(eo,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:C.map((m,h)=>{let O=x+h===t,V=n?.has(m.id),Z=ln(m.name,d),ae=m.description?ln(m.description,Math.max(0,d-l)):"",Y=s?" ".repeat(l):"";return Lt(eo,{paddingX:1,flexDirection:"column",children:[Lt(eo,{children:[s&&to(_t,{color:V?"green":"gray",children:V?"[\u2713] ":"[ ] "}),to(_t,{backgroundColor:O?"cyan":void 0,color:O?"black":V?"green":"white",bold:!0,children:Z})]}),ae&&Lt(_t,{dimColor:!0,children:[Y,"\xB7 ",ae]})]},m.id)})}),Lt(_t,{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>I?` \xB7 Showing ${x+1}-${b} of ${e.length}`:""]})]})}import{Box as To,Text as Dt}from"ink";import{jsx as Ot,jsxs as Io}from"react/jsx-runtime";function un({suggestions:e,activeIndex:t,visible:n}){return!n||e.length===0?null:Io(To,{flexDirection:"column",marginBottom:1,children:[Ot(To,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((s,o)=>{let i=o===t,r=s.aliases.length>0?` (${s.aliases.join(", ")})`:"";return Io(To,{paddingX:1,children:[Io(Dt,{backgroundColor:i?"cyan":void 0,color:i?"black":"cyan",bold:i,children:["/",s.name]}),Ot(Dt,{dimColor:!0,children:r}),Ot(Dt,{children:" - "}),Ot(Dt,{color:i?"white":"gray",children:s.description})]},s.name)})}),Ot(Dt,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as Gs,Text as dn,useInput as Hs,useStdout as Vs}from"ink";import{useCallback as fn,useEffect as pn,useMemo as vo,useRef as mn,useState as gn}from"react";import{jsx as No}from"react/jsx-runtime";function oo(e,t){return e<0?0:e>t?t:e}function Po(e){return Array.from(e)}function no(e){return/\s/.test(e)}function Ao(e,t){let n=t;for(;n>0&&no(e[n-1]??"");)n-=1;for(;n>0&&!no(e[n-1]??"");)n-=1;return n}function hn(e,t){let n=t;for(;n<e.length&&no(e[n]??"");)n+=1;for(;n<e.length&&!no(e[n]??"");)n+=1;return n}function Ks(e){let t=[],n=[],s=[],o=0;n.push(0),e.forEach((r,a)=>{if(r===`
65
- `){t.push(s),s=[],o=a+1,n.push(o);return}s.push(r)}),t.push(s);let i=t.map(r=>r.length);return{lines:t,lineStarts:n,lineLengths:i}}function yn(e,t,n){for(let o=0;o<t.length;o+=1){let i=t[o]??0,r=n[o]??0,a=i+r;if(e<=a)return{row:o,col:e-i}}let s=Math.max(0,t.length-1);return{row:s,col:n[s]??0}}var qs=2;function wn({value:e,onChange:t,onSubmit:n,onPaste:s,focus:o=!0,leadingOffset:i=0,multiline:r=!1}){let[a,l]=gn(()=>Po(e).length),d=mn(null),[I,x]=gn(0),b=mn(null),{stdout:C}=Vs(),m=vo(()=>Po(e),[e]),{lines:h,lineStarts:S,lineLengths:O}=vo(()=>Ks(m),[m]),{row:V,col:Z}=vo(()=>yn(a,S,O),[a,S,O]),ae=Math.max(1,(C?.columns??80)-i);pn(()=>{d.current!==e?(l(m.length),b.current=null):l(j=>oo(j,m.length)),d.current=e},[e,m.length]),pn(()=>{x(j=>{let P=j;Z<P?P=Z:Z>=P+ae&&(P=Z-ae+1);let E=O[V]??0,R=Z===E?E+1:E,W=Math.max(0,R-ae);return P>W&&(P=W),P<0&&(P=0),P})},[ae,Z,V,O]);let Y=fn((j,P)=>{d.current=j,t(j),l(P),b.current=null},[t]),Se=fn(async(j,P)=>{if(!o)return;let{row:E,col:R}=yn(a,S,O),W=h[E]??[],_=O[E]??0,he=h.length>1;if(r&&(P.meta&&P.return||P.ctrl&&j==="j"||P.shift&&P.return)){let L=[...m.slice(0,a),`
66
- `,...m.slice(a)].join("");Y(L,a+1);return}if(P.return){n(e);return}if(P.leftArrow){P.ctrl||P.meta?(R===0&&E>0?l(S[E]-1):l(S[E]+Ao(W,R)),b.current=null):(R===0&&E>0?l(S[E]-1):l(L=>oo(L-1,m.length)),b.current=null);return}if(P.rightArrow){P.ctrl||P.meta?(R>=_&&E<h.length-1?l(S[E+1]):l(S[E]+hn(W,R)),b.current=null):(R>=_&&E<h.length-1?l(S[E+1]):l(L=>oo(L+1,m.length)),b.current=null);return}if(r&&he&&P.upArrow){let L=b.current??R,p=Math.max(0,E-1),ie=Math.min(L,O[p]??0);l((S[p]??0)+ie),b.current=L;return}if(r&&he&&P.downArrow){let L=b.current??R,p=Math.min(h.length-1,E+1),ie=Math.min(L,O[p]??0);l((S[p]??0)+ie),b.current=L;return}if(P.ctrl){if(j==="a"){l(S[E]??0),b.current=null;return}if(j==="e"){l((S[E]??0)+_),b.current=null;return}if(j==="u"){if(R>0){let L=S[E]??0,p=[...m.slice(0,L),...m.slice(a)].join("");Y(p,L)}return}if(j==="k"){if(R<_){let L=(S[E]??0)+_,p=[...m.slice(0,a),...m.slice(L)].join("");Y(p,a)}return}if(j==="w"){if(R===0&&E>0){let p=[...m.slice(0,a-1),...m.slice(a)].join("");Y(p,a-1);return}let L=Ao(W,R);if(L!==R){let p=(S[E]??0)+L,ie=[...m.slice(0,p),...m.slice(a)].join("");Y(ie,p)}return}if(j==="d"){if(a<m.length){let L=[...m.slice(0,a),...m.slice(a+1)].join("");Y(L,a)}return}return}if(P.meta){j==="b"?(R===0&&E>0?l(S[E]-1):l(S[E]+Ao(W,R)),b.current=null):j==="f"&&(R>=_&&E<h.length-1?l(S[E+1]):l(S[E]+hn(W,R)),b.current=null);return}if(P.backspace||P.delete){if(a<=0)return;let L=[...m.slice(0,a-1),...m.slice(a)].join("");Y(L,a-1);return}if(!(P.tab||P.escape)&&j.length>0){let L=r?j.replace(/\r\n/g,`
64
+ `)}function tt(e){return Io(e)}async function to(e,t){return Io(e)?un(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as Pe,Text as K,useInput as Mo}from"ink";import Jo from"ink-spinner";import{useCallback as Go,useEffect as po,useRef as ns,useState as jr}from"react";import{Box as oo,Text as Lt}from"ink";import{jsx as no,jsxs as Dt}from"react/jsx-runtime";function fn(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function pn({items:e,activeIndex:t,selectedIds:o,multiSelect:s=!1,visible:n,title:i,pageSize:r=10}){if(!n||e.length===0)return null;let a=process.stdout.columns??80,l=s?4:0,d=Math.max(20,a-2-2-l),$=Math.max(1,r),x=Math.floor(t/$)*$,b=Math.min(e.length,x+$),C=e.slice(x,b);return Dt(oo,{flexDirection:"column",marginBottom:1,children:[no(Lt,{bold:!0,color:"cyan",children:i}),no(oo,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:C.map((m,h)=>{let O=x+h===t,V=o?.has(m.id),Z=fn(m.name,d),ae=m.description?fn(m.description,Math.max(0,d-l)):"",Y=s?" ".repeat(l):"";return Dt(oo,{paddingX:1,flexDirection:"column",children:[Dt(oo,{children:[s&&no(Lt,{color:V?"green":"gray",children:V?"[\u2713] ":"[ ] "}),no(Lt,{backgroundColor:O?"cyan":void 0,color:O?"black":V?"green":"white",bold:!0,children:Z})]}),ae&&Dt(Lt,{dimColor:!0,children:[Y,"\xB7 ",ae]})]},m.id)})}),Dt(Lt,{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>$?` \xB7 Showing ${x+1}-${b} of ${e.length}`:""]})]})}import{Box as vo,Text as Ot}from"ink";import{jsx as Rt,jsxs as Po}from"react/jsx-runtime";function mn({suggestions:e,activeIndex:t,visible:o}){return!o||e.length===0?null:Po(vo,{flexDirection:"column",marginBottom:1,children:[Rt(vo,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((s,n)=>{let i=n===t,r=s.aliases.length>0?` (${s.aliases.join(", ")})`:"";return Po(vo,{paddingX:1,children:[Po(Ot,{backgroundColor:i?"cyan":void 0,color:i?"black":"cyan",bold:i,children:["/",s.name]}),Rt(Ot,{dimColor:!0,children:r}),Rt(Ot,{children:" - "}),Rt(Ot,{color:i?"white":"gray",children:s.description})]},s.name)})}),Rt(Ot,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as tr,Text as gn,useInput as or,useStdout as nr}from"ink";import{useCallback as hn,useEffect as yn,useMemo as Ao,useRef as wn,useState as kn}from"react";import{jsx as _o}from"react/jsx-runtime";function so(e,t){return e<0?0:e>t?t:e}function No(e){return Array.from(e)}function ro(e){return/\s/.test(e)}function Eo(e,t){let o=t;for(;o>0&&ro(e[o-1]??"");)o-=1;for(;o>0&&!ro(e[o-1]??"");)o-=1;return o}function xn(e,t){let o=t;for(;o<e.length&&ro(e[o]??"");)o+=1;for(;o<e.length&&!ro(e[o]??"");)o+=1;return o}function sr(e){let t=[],o=[],s=[],n=0;o.push(0),e.forEach((r,a)=>{if(r===`
65
+ `){t.push(s),s=[],n=a+1,o.push(n);return}s.push(r)}),t.push(s);let i=t.map(r=>r.length);return{lines:t,lineStarts:o,lineLengths:i}}function bn(e,t,o){for(let n=0;n<t.length;n+=1){let i=t[n]??0,r=o[n]??0,a=i+r;if(e<=a)return{row:n,col:e-i}}let s=Math.max(0,t.length-1);return{row:s,col:o[s]??0}}var rr=2;function Cn({value:e,onChange:t,onSubmit:o,onPaste:s,focus:n=!0,leadingOffset:i=0,multiline:r=!1}){let[a,l]=kn(()=>No(e).length),d=wn(null),[$,x]=kn(0),b=wn(null),{stdout:C}=nr(),m=Ao(()=>No(e),[e]),{lines:h,lineStarts:T,lineLengths:O}=Ao(()=>sr(m),[m]),{row:V,col:Z}=Ao(()=>bn(a,T,O),[a,T,O]),ae=Math.max(1,(C?.columns??80)-i);yn(()=>{d.current!==e?(l(m.length),b.current=null):l(j=>so(j,m.length)),d.current=e},[e,m.length]),yn(()=>{x(j=>{let P=j;Z<P?P=Z:Z>=P+ae&&(P=Z-ae+1);let E=O[V]??0,R=Z===E?E+1:E,W=Math.max(0,R-ae);return P>W&&(P=W),P<0&&(P=0),P})},[ae,Z,V,O]);let Y=hn((j,P)=>{d.current=j,t(j),l(P),b.current=null},[t]),Se=hn(async(j,P)=>{if(!n)return;let{row:E,col:R}=bn(a,T,O),W=h[E]??[],_=O[E]??0,he=h.length>1;if(r&&(P.meta&&P.return||P.ctrl&&j==="j"||P.shift&&P.return)){let L=[...m.slice(0,a),`
66
+ `,...m.slice(a)].join("");Y(L,a+1);return}if(P.return){o(e);return}if(P.leftArrow){P.ctrl||P.meta?(R===0&&E>0?l(T[E]-1):l(T[E]+Eo(W,R)),b.current=null):(R===0&&E>0?l(T[E]-1):l(L=>so(L-1,m.length)),b.current=null);return}if(P.rightArrow){P.ctrl||P.meta?(R>=_&&E<h.length-1?l(T[E+1]):l(T[E]+xn(W,R)),b.current=null):(R>=_&&E<h.length-1?l(T[E+1]):l(L=>so(L+1,m.length)),b.current=null);return}if(r&&he&&P.upArrow){let L=b.current??R,p=Math.max(0,E-1),ie=Math.min(L,O[p]??0);l((T[p]??0)+ie),b.current=L;return}if(r&&he&&P.downArrow){let L=b.current??R,p=Math.min(h.length-1,E+1),ie=Math.min(L,O[p]??0);l((T[p]??0)+ie),b.current=L;return}if(P.ctrl){if(j==="a"){l(T[E]??0),b.current=null;return}if(j==="e"){l((T[E]??0)+_),b.current=null;return}if(j==="u"){if(R>0){let L=T[E]??0,p=[...m.slice(0,L),...m.slice(a)].join("");Y(p,L)}return}if(j==="k"){if(R<_){let L=(T[E]??0)+_,p=[...m.slice(0,a),...m.slice(L)].join("");Y(p,a)}return}if(j==="w"){if(R===0&&E>0){let p=[...m.slice(0,a-1),...m.slice(a)].join("");Y(p,a-1);return}let L=Eo(W,R);if(L!==R){let p=(T[E]??0)+L,ie=[...m.slice(0,p),...m.slice(a)].join("");Y(ie,p)}return}if(j==="d"){if(a<m.length){let L=[...m.slice(0,a),...m.slice(a+1)].join("");Y(L,a)}return}return}if(P.meta){j==="b"?(R===0&&E>0?l(T[E]-1):l(T[E]+Eo(W,R)),b.current=null):j==="f"&&(R>=_&&E<h.length-1?l(T[E+1]):l(T[E]+xn(W,R)),b.current=null);return}if(P.backspace||P.delete){if(a<=0)return;let L=[...m.slice(0,a-1),...m.slice(a)].join("");Y(L,a-1);return}if(!(P.tab||P.escape)&&j.length>0){let L=r?j.replace(/\r\n/g,`
67
67
  `).replace(/\r/g,`
68
- `):j.replace(/\r?\n/g,"");if(!L||(L=L.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!L))return;if((L.length>=qs||L.includes(`
69
- `))&&s){let q=!1,A={text:L,preventDefault:()=>{q=!0}};if(await Promise.resolve(s(A)),q)return}let ie=Po(L),ke=[...m.slice(0,a),...ie,...m.slice(a)].join("");Y(ke,a+ie.length)}},[m,a,o,O,S,h,r,s,n,Y,e]);return Hs(Se,{isActive:o}),No(Gs,{flexDirection:"column",children:h.map((j,P)=>{let E=P===V,W=(E&&Z===j.length?[...j," "]:j).slice(I,I+ae),_=W.join("");if(!E)return No(dn,{children:_||" "},P);let he=oo(Z-I,Math.max(0,W.length-1)),L=W.slice(0,he).join(""),p=W[he]??" ",ie=W.slice(he+1).join(""),A=`${L}\x1B[7m${p}\x1B[27m${ie}`;return No(dn,{children:A},P)})})}import{Box as qe,Text as ft}from"ink";import Do from"react";import{Text as Be}from"ink";import zs from"react";import{Fragment as Zs,jsx as Je,jsxs as bn}from"react/jsx-runtime";var Eo=2,_o=1,Lo=2,Ys=1,kn=3,xn=4,Xs=({text:e,defaultColor:t,linkColor:n,codeColor:s})=>{let o=t;if(!/[*_~`<[https?:]/.test(e))return Je(Be,{color:o,children:e});let i=[],r=0,a=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,l;for(;(l=a.exec(e))!==null;){l.index>r&&i.push(Je(Be,{color:o,children:e.slice(r,l.index)},`t-${r}`));let d=l[0],I=null,x=`m-${l.index}`;try{if(d.startsWith("**")&&d.endsWith("**")&&d.length>Eo*2)I=Je(Be,{bold:!0,color:o,children:d.slice(Eo,-Eo)},x);else if(d.length>_o*2&&(d.startsWith("*")&&d.endsWith("*")||d.startsWith("_")&&d.endsWith("_"))&&!/\w/.test(e.substring(l.index-1,l.index))&&!/\w/.test(e.substring(a.lastIndex,a.lastIndex+1))&&!/\S[./\\]/.test(e.substring(l.index-2,l.index))&&!/[./\\]\S/.test(e.substring(a.lastIndex,a.lastIndex+2)))I=Je(Be,{italic:!0,color:o,children:d.slice(_o,-_o)},x);else if(d.startsWith("~~")&&d.endsWith("~~")&&d.length>Lo*2)I=Je(Be,{strikethrough:!0,color:o,children:d.slice(Lo,-Lo)},x);else if(d.startsWith("`")&&d.endsWith("`")&&d.length>Ys){let b=d.match(/^(`+)(.+?)\1$/s);b&&b[2]&&(I=Je(Be,{color:s,children:b[2]},x))}else if(d.startsWith("[")&&d.includes("](")&&d.endsWith(")")){let b=d.match(/\[(.*?)\]\((.*?)\)/);if(b){let C=b[1],m=b[2];I=bn(Be,{color:o,children:[C,bn(Be,{color:n,children:[" (",m,")"]})]},x)}}else d.startsWith("<u>")&&d.endsWith("</u>")&&d.length>kn+xn-1?I=Je(Be,{underline:!0,color:o,children:d.slice(kn,-xn)},x):d.match(/^https?:\/\//)&&(I=Je(Be,{color:n,children:d},x))}catch{I=null}i.push(I??Je(Be,{color:o,children:d},x)),r=a.lastIndex}return r<e.length&&i.push(Je(Be,{color:o,children:e.slice(r)},`t-${r}`)),Je(Zs,{children:i.filter(d=>d!==null)})},Rt=zs.memo(Xs);import{Fragment as rr,jsx as we,jsxs as Tn}from"react/jsx-runtime";var Qs=1,Sn=1,er=1,tr=1,or=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return we(qe,{paddingLeft:Sn,flexDirection:"column",children:we(ft,{wrap:"wrap",children:e})});let n=e.split(/\r?\n/),s=/^ *(#{1,4}) +(.*)/,o=/^ *(`{3,}|~{3,}) *(\w*?) *$/,i=/^([ \t]*)([-*+]) +(.*)/,r=/^([ \t]*)(\d+)\. +(.*)/,a=/^ *([-*_] *){3,} *$/,l=/^ *> ?(.*)/,d=[],I=!1,x=!0,b=[],C="";function m(h){h&&(d.push(h),x=!1)}return n.forEach((h,S)=>{let O=`line-${S}`;if(I){let P=h.match(o);P&&P[1].startsWith(C[0])&&P[1].length>=C.length?(m(we(Cn,{content:b},O)),I=!1,b=[],C=""):b.push(h);return}let V=h.match(o),Z=h.match(s),ae=h.match(i),Y=h.match(r),Se=h.match(a),j=h.match(l);if(V)I=!0,C=V[1];else if(Se)m(we(qe,{children:we(ft,{dimColor:!0,children:"---"})},O));else if(Z){let P=Z[1].length,E=Z[2],R=P<=2?"cyan":"blue";m(we(qe,{children:we(ft,{color:R,...(P===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:we(Rt,{text:E,defaultColor:R,linkColor:"cyan",codeColor:"yellow"})})},O))}else if(j){let P=j[1];m(we(qe,{paddingLeft:1,children:Tn(ft,{dimColor:!0,children:["> ",we(Rt,{text:P,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},O))}else if(ae){let P=ae[1],E=ae[2],R=ae[3];m(we($n,{itemText:R,type:"ul",marker:E,leadingWhitespace:P},O))}else if(Y){let P=Y[1],E=Y[2],R=Y[3];m(we($n,{itemText:R,type:"ol",marker:E,leadingWhitespace:P},O))}else h.trim().length===0?x||(d.push(we(qe,{height:Qs},`spacer-${S}`)),x=!0):m(we(qe,{children:we(ft,{wrap:"wrap",children:we(Rt,{text:h,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},O))}),I&&m(we(Cn,{content:b},"line-eof")),we(rr,{children:d})},nr=({content:e})=>{let t=e.join(`
70
- `);return we(qe,{paddingLeft:Sn,flexDirection:"column",children:we(ft,{color:"yellow",children:t})})},Cn=Do.memo(nr),sr=({itemText:e,type:t,marker:n,leadingWhitespace:s=""})=>{let o=t==="ol"?`${n}. `:`${n} `,i=o.length,r=s.length;return Tn(qe,{paddingLeft:r+er,flexDirection:"row",children:[we(qe,{width:i,children:we(ft,{children:o})}),we(qe,{flexGrow:tr,children:we(ft,{wrap:"wrap",children:we(Rt,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},$n=Do.memo(sr),Oo=Do.memo(or);import{execFile as ir}from"child_process";import ar from"fs";import St from"fs/promises";import In from"os";import ro from"path";import{promisify as lr}from"util";var so=lr(ir);async function cr(){let e=ro.join(In.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
68
+ `):j.replace(/\r?\n/g,"");if(!L||(L=L.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!L))return;if((L.length>=rr||L.includes(`
69
+ `))&&s){let q=!1,A={text:L,preventDefault:()=>{q=!0}};if(await Promise.resolve(s(A)),q)return}let ie=No(L),ke=[...m.slice(0,a),...ie,...m.slice(a)].join("");Y(ke,a+ie.length)}},[m,a,n,O,T,h,r,s,o,Y,e]);return or(Se,{isActive:n}),_o(tr,{flexDirection:"column",children:h.map((j,P)=>{let E=P===V,W=(E&&Z===j.length?[...j," "]:j).slice($,$+ae),_=W.join("");if(!E)return _o(gn,{children:_||" "},P);let he=so(Z-$,Math.max(0,W.length-1)),L=W.slice(0,he).join(""),p=W[he]??" ",ie=W.slice(he+1).join(""),A=`${L}\x1B[7m${p}\x1B[27m${ie}`;return _o(gn,{children:A},P)})})}import{Box as qe,Text as ft}from"ink";import Ro from"react";import{Text as Be}from"ink";import ir from"react";import{Fragment as cr,jsx as Je,jsxs as Tn}from"react/jsx-runtime";var Lo=2,Do=1,Oo=2,ar=1,$n=3,Sn=4,lr=({text:e,defaultColor:t,linkColor:o,codeColor:s})=>{let n=t;if(!/[*_~`<[https?:]/.test(e))return Je(Be,{color:n,children:e});let i=[],r=0,a=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,l;for(;(l=a.exec(e))!==null;){l.index>r&&i.push(Je(Be,{color:n,children:e.slice(r,l.index)},`t-${r}`));let d=l[0],$=null,x=`m-${l.index}`;try{if(d.startsWith("**")&&d.endsWith("**")&&d.length>Lo*2)$=Je(Be,{bold:!0,color:n,children:d.slice(Lo,-Lo)},x);else if(d.length>Do*2&&(d.startsWith("*")&&d.endsWith("*")||d.startsWith("_")&&d.endsWith("_"))&&!/\w/.test(e.substring(l.index-1,l.index))&&!/\w/.test(e.substring(a.lastIndex,a.lastIndex+1))&&!/\S[./\\]/.test(e.substring(l.index-2,l.index))&&!/[./\\]\S/.test(e.substring(a.lastIndex,a.lastIndex+2)))$=Je(Be,{italic:!0,color:n,children:d.slice(Do,-Do)},x);else if(d.startsWith("~~")&&d.endsWith("~~")&&d.length>Oo*2)$=Je(Be,{strikethrough:!0,color:n,children:d.slice(Oo,-Oo)},x);else if(d.startsWith("`")&&d.endsWith("`")&&d.length>ar){let b=d.match(/^(`+)(.+?)\1$/s);b&&b[2]&&($=Je(Be,{color:s,children:b[2]},x))}else if(d.startsWith("[")&&d.includes("](")&&d.endsWith(")")){let b=d.match(/\[(.*?)\]\((.*?)\)/);if(b){let C=b[1],m=b[2];$=Tn(Be,{color:n,children:[C,Tn(Be,{color:o,children:[" (",m,")"]})]},x)}}else d.startsWith("<u>")&&d.endsWith("</u>")&&d.length>$n+Sn-1?$=Je(Be,{underline:!0,color:n,children:d.slice($n,-Sn)},x):d.match(/^https?:\/\//)&&($=Je(Be,{color:o,children:d},x))}catch{$=null}i.push($??Je(Be,{color:n,children:d},x)),r=a.lastIndex}return r<e.length&&i.push(Je(Be,{color:n,children:e.slice(r)},`t-${r}`)),Je(cr,{children:i.filter(d=>d!==null)})},Ut=ir.memo(lr);import{Fragment as hr,jsx as we,jsxs as An}from"react/jsx-runtime";var ur=1,Pn=1,dr=1,fr=1,pr=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return we(qe,{paddingLeft:Pn,flexDirection:"column",children:we(ft,{wrap:"wrap",children:e})});let o=e.split(/\r?\n/),s=/^ *(#{1,4}) +(.*)/,n=/^ *(`{3,}|~{3,}) *(\w*?) *$/,i=/^([ \t]*)([-*+]) +(.*)/,r=/^([ \t]*)(\d+)\. +(.*)/,a=/^ *([-*_] *){3,} *$/,l=/^ *> ?(.*)/,d=[],$=!1,x=!0,b=[],C="";function m(h){h&&(d.push(h),x=!1)}return o.forEach((h,T)=>{let O=`line-${T}`;if($){let P=h.match(n);P&&P[1].startsWith(C[0])&&P[1].length>=C.length?(m(we(In,{content:b},O)),$=!1,b=[],C=""):b.push(h);return}let V=h.match(n),Z=h.match(s),ae=h.match(i),Y=h.match(r),Se=h.match(a),j=h.match(l);if(V)$=!0,C=V[1];else if(Se)m(we(qe,{children:we(ft,{dimColor:!0,children:"---"})},O));else if(Z){let P=Z[1].length,E=Z[2],R=P<=2?"cyan":"blue";m(we(qe,{children:we(ft,{color:R,...(P===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:we(Ut,{text:E,defaultColor:R,linkColor:"cyan",codeColor:"yellow"})})},O))}else if(j){let P=j[1];m(we(qe,{paddingLeft:1,children:An(ft,{dimColor:!0,children:["> ",we(Ut,{text:P,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},O))}else if(ae){let P=ae[1],E=ae[2],R=ae[3];m(we(vn,{itemText:R,type:"ul",marker:E,leadingWhitespace:P},O))}else if(Y){let P=Y[1],E=Y[2],R=Y[3];m(we(vn,{itemText:R,type:"ol",marker:E,leadingWhitespace:P},O))}else h.trim().length===0?x||(d.push(we(qe,{height:ur},`spacer-${T}`)),x=!0):m(we(qe,{children:we(ft,{wrap:"wrap",children:we(Ut,{text:h,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},O))}),$&&m(we(In,{content:b},"line-eof")),we(hr,{children:d})},mr=({content:e})=>{let t=e.join(`
70
+ `);return we(qe,{paddingLeft:Pn,flexDirection:"column",children:we(ft,{color:"yellow",children:t})})},In=Ro.memo(mr),gr=({itemText:e,type:t,marker:o,leadingWhitespace:s=""})=>{let n=t==="ol"?`${o}. `:`${o} `,i=n.length,r=s.length;return An(qe,{paddingLeft:r+dr,flexDirection:"row",children:[we(qe,{width:i,children:we(ft,{children:n})}),we(qe,{flexGrow:fr,children:we(ft,{wrap:"wrap",children:we(Ut,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},vn=Ro.memo(gr),Uo=Ro.memo(pr);import{execFile as yr}from"child_process";import wr from"fs";import St from"fs/promises";import Nn from"os";import ao from"path";import{promisify as kr}from"util";var io=kr(yr);async function xr(){let e=ao.join(Nn.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
71
71
  set imageData to the clipboard as "PNGf"
72
72
  set fileRef to open for access POSIX file "${e}" with write permission
73
73
  set eof fileRef to 0
74
74
  write imageData to fileRef
75
75
  close access fileRef
76
- `;return await so("osascript",["-e",t]),(await St.stat(e)).size===0?void 0:{buffer:await St.readFile(e),mime:"image/png"}}catch{return}finally{try{ar.existsSync(e)&&await St.unlink(e)}catch{}}}async function ur(){try{let e=`
76
+ `;return await io("osascript",["-e",t]),(await St.stat(e)).size===0?void 0:{buffer:await St.readFile(e),mime:"image/png"}}catch{return}finally{try{wr.existsSync(e)&&await St.unlink(e)}catch{}}}async function br(){try{let e=`
77
77
  Add-Type -AssemblyName System.Windows.Forms
78
78
  $img = [System.Windows.Forms.Clipboard]::GetImage()
79
79
  if ($img) {
@@ -81,44 +81,44 @@ You have access to filesystem tools that allow you to interact with the user's l
81
81
  $img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png)
82
82
  [System.Convert]::ToBase64String($ms.ToArray())
83
83
  }
84
- `,{stdout:t}=await so("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 dr(){try{let{stdout:e}=await so("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 so("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 vn(){let e=In.platform();if(e==="darwin")return cr();if(e==="win32")return ur();if(e==="linux")return dr()}var fr=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 Pn(e){let t=ro.extname(e).toLowerCase();return fr.has(t)}function pr(e){let t=ro.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 io(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 An(e){let t=io(e);if(/^https?:\/\//.test(t))return!1;try{return await St.access(t),!0}catch{return!1}}async function Nn(e){let t=io(e);try{if(!(await St.stat(t)).isFile())return;let s=await St.readFile(t),o=pr(t),i=ro.basename(t);return{buffer:s,mimeType:o,filename:i}}catch{return}}var Fe="\x1B[2m",re="\x1B[0m",ve="\x1B[36m",Tt="\x1B[32m",En="\x1B[31m",gt="\x1B[38;2;59;91;204m",Ro="\x1B[38;2;126;200;248m",Uo="\x1B[38;2;244;196;78m";import{useState as ot}from"react";import{v4 as _n}from"uuid";function Ln(e,t){let[n,s]=ot({status:"loading"}),[o,i]=ot([]),[r,a]=ot(""),[l,d]=ot(()=>e||_n()),[I,x]=ot(t),[b,C]=ot(!!e),[m,h]=ot(null),[S,O]=ot(""),[V,Z]=ot(!1),ae=Se=>{i(j=>[...j,{role:"system",content:Se}])};return{state:n,setState:s,messages:o,setMessages:i,input:r,setInput:a,chatId:l,setChatId:d,currentChatTitle:I,setCurrentChatTitle:x,hasPersistedChat:b,setHasPersistedChat:C,credentials:m,setCredentials:h,currentResponse:S,setCurrentResponse:O,fullOutput:V,setFullOutput:Z,addSystemMessage:ae,startNewChat:Se=>{let j=_n();d(j),x(void 0),C(!1),i([]),Se&&ae(Se)}}}import{useEffect as mr,useState as Dn}from"react";function On(e){let[t,n]=Dn(null),[s,o]=Dn(!0);return mr(()=>{let i=!1;async function r(){try{let a=await pe();if(i)return;n({accessToken:a.accessToken,workspaceId:a.workspaceId}),o(!1)}catch(a){if(i)return;if(a instanceof Qe){if(a.code==="not-logged-in"){e({status:"not-logged-in"}),o(!1);return}if(a.code==="no-workspace"){e({status:"no-workspace"}),o(!1);return}}let l=a instanceof Error?a.message:"Failed to authenticate";e({status:"error",message:l}),o(!1)}}return r(),()=>{i=!0}},[e]),{credentials:t,loading:s}}import{useEffect as gr,useState as Ut}from"react";function Rn(e){let[t,n]=Ut([]),[s,o]=Ut([]),[i,r]=Ut([]),[a,l]=Ut([]),[d,I]=Ut(!1);return gr(()=>{if(!e)return;let x=!1;I(!0);async function b(){if(e)try{let C=new B,[m,h,S,O]=await Promise.all([C.getConnectors(e.accessToken,e.workspaceId),C.getModels(e.accessToken,e.workspaceId),C.getAgents(e.accessToken,e.workspaceId),C.getModelProviders(e.accessToken,e.workspaceId)]);if(x)return;n(m.connectors),o(h.models),r(S.agents),l(O.providers??[])}catch{}finally{x||I(!1)}}return b(),()=>{x=!0}},[e]),{availableConnectors:t,availableModels:s,availableAgents:i,modelProviders:a,loading:d}}import co from"fs";import jn from"path";import{useCallback as hr}from"react";import{v4 as yr}from"uuid";function Un(e,t){if(!e)return"(no result)";if(typeof e!="object"){let o=String(e);return t||o.length<=200?o:o.slice(0,200)+"..."}let n=e;if("structuredContent"in n&&n.structuredContent){let o=n.structuredContent;if(o.stdout&&typeof o.stdout=="string"){let i=o.stdout.trim();return t||i.length<=200?i:i.slice(0,200)+"..."}}if("content"in n&&Array.isArray(n.content)){let o=n.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
85
- `);return o?t||o.length<=200?o:o.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 ht(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(`${Fe}[Thinking]
86
- ${s.text}${re}`):n.push(`${Fe}[Thinking...]${re}`);else if(s.type==="tool-call"&&s.toolName){let o=[];if(o.push(`${ve}\u250C\u2500 Tool: ${s.toolName}${re}`),s.args){let i=JSON.stringify(s.args,null,t?2:void 0),r=t||i.length<=100?i:i.slice(0,100)+"...";o.push(`${Fe}\u2502 Args: ${r}${re}`)}s.result!==void 0?(o.push(`${Tt}\u2502 Result: ${Un(s.result,t)}${re}`),o.push(`${ve}\u2514\u2500 completed${re}`)):o.push(`${ve}\u2514\u2500${re}`),n.push(o.join(`
87
- `))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let o=s.title||s.type.slice(5).replace(/__/g," "),i=[];if(i.push(`${ve}\u250C\u2500 Tool: ${o}${re}`),s.input){let r=JSON.stringify(s.input,null,t?2:void 0),a=t||r.length<=100?r:r.slice(0,100)+"...";i.push(`${Fe}\u2502 Input: ${a}${re}`)}s.output!==void 0&&s.state==="output-available"?(i.push(`${Tt}\u2502 Output: ${Un(s.output,t)}${re}`),i.push(`${ve}\u2514\u2500 completed${re}`)):s.state==="error"?i.push(`${ve}\u2514\u2500 failed${re}`):i.push(`${ve}\u2514\u2500${re}`),n.push(i.join(`
88
- `))}return n.join(`
84
+ `,{stdout:t}=await io("powershell.exe",["-command",e]),o=t.trim();if(!o)return;let s=Buffer.from(o,"base64");return s.length===0?void 0:{buffer:s,mime:"image/png"}}catch{return}}async function Cr(){try{let{stdout:e}=await io("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 io("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 En(){let e=Nn.platform();if(e==="darwin")return xr();if(e==="win32")return br();if(e==="linux")return Cr()}var $r=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 _n(e){let t=ao.extname(e).toLowerCase();return $r.has(t)}function Sr(e){let t=ao.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 lo(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 Ln(e){let t=lo(e);if(/^https?:\/\//.test(t))return!1;try{return await St.access(t),!0}catch{return!1}}async function Dn(e){let t=lo(e);try{if(!(await St.stat(t)).isFile())return;let s=await St.readFile(t),n=Sr(t),i=ao.basename(t);return{buffer:s,mimeType:n,filename:i}}catch{return}}var Fe="\x1B[2m",re="\x1B[0m",ve="\x1B[36m",Tt="\x1B[32m",On="\x1B[31m",gt="\x1B[38;2;59;91;204m",jo="\x1B[38;2;126;200;248m",Bo="\x1B[38;2;244;196;78m";import{useState as ot}from"react";import{v4 as Rn}from"uuid";function Un(e,t){let[o,s]=ot({status:"loading"}),[n,i]=ot([]),[r,a]=ot(""),[l,d]=ot(()=>e||Rn()),[$,x]=ot(t),[b,C]=ot(!!e),[m,h]=ot(null),[T,O]=ot(""),[V,Z]=ot(!1),ae=Se=>{i(j=>[...j,{role:"system",content:Se}])};return{state:o,setState:s,messages:n,setMessages:i,input:r,setInput:a,chatId:l,setChatId:d,currentChatTitle:$,setCurrentChatTitle:x,hasPersistedChat:b,setHasPersistedChat:C,credentials:m,setCredentials:h,currentResponse:T,setCurrentResponse:O,fullOutput:V,setFullOutput:Z,addSystemMessage:ae,startNewChat:Se=>{let j=Rn();d(j),x(void 0),C(!1),i([]),Se&&ae(Se)}}}import{useEffect as Tr,useState as jn}from"react";function Bn(e){let[t,o]=jn(null),[s,n]=jn(!0);return Tr(()=>{let i=!1;async function r(){try{let a=await pe();if(i)return;o({accessToken:a.accessToken,workspaceId:a.workspaceId}),n(!1)}catch(a){if(i)return;if(a instanceof Qe){if(a.code==="not-logged-in"){e({status:"not-logged-in"}),n(!1);return}if(a.code==="no-workspace"){e({status:"no-workspace"}),n(!1);return}}let l=a instanceof Error?a.message:"Failed to authenticate";e({status:"error",message:l}),n(!1)}}return r(),()=>{i=!0}},[e]),{credentials:t,loading:s}}import{useEffect as Ir,useState as jt}from"react";function Fn(e){let[t,o]=jt([]),[s,n]=jt([]),[i,r]=jt([]),[a,l]=jt([]),[d,$]=jt(!1);return Ir(()=>{if(!e)return;let x=!1;$(!0);async function b(){if(e)try{let C=new B,[m,h,T,O]=await Promise.all([C.getConnectors(e.accessToken,e.workspaceId),C.getModels(e.accessToken,e.workspaceId),C.getAgents(e.accessToken,e.workspaceId),C.getModelProviders(e.accessToken,e.workspaceId)]);if(x)return;o(m.connectors),n(h.models),r(T.agents),l(O.providers??[])}catch{}finally{x||$(!1)}}return b(),()=>{x=!0}},[e]),{availableConnectors:t,availableModels:s,availableAgents:i,modelProviders:a,loading:d}}import fo from"fs";import Mn from"path";import{useCallback as vr}from"react";import{v4 as Pr}from"uuid";function Wn(e,t){if(!e)return"(no result)";if(typeof e!="object"){let n=String(e);return t||n.length<=200?n:n.slice(0,200)+"..."}let o=e;if("structuredContent"in o&&o.structuredContent){let n=o.structuredContent;if(n.stdout&&typeof n.stdout=="string"){let i=n.stdout.trim();return t||i.length<=200?i:i.slice(0,200)+"..."}}if("content"in o&&Array.isArray(o.content)){let n=o.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
85
+ `);return n?t||n.length<=200?n:n.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 ht(e,t=!1){let o=[];for(let s of e)if(s.type==="text"&&s.text)o.push(s.text);else if(s.type==="reasoning"&&s.text)t?o.push(`${Fe}[Thinking]
86
+ ${s.text}${re}`):o.push(`${Fe}[Thinking...]${re}`);else if(s.type==="tool-call"&&s.toolName){let n=[];if(n.push(`${ve}\u250C\u2500 Tool: ${s.toolName}${re}`),s.args){let i=JSON.stringify(s.args,null,t?2:void 0),r=t||i.length<=100?i:i.slice(0,100)+"...";n.push(`${Fe}\u2502 Args: ${r}${re}`)}s.result!==void 0?(n.push(`${Tt}\u2502 Result: ${Wn(s.result,t)}${re}`),n.push(`${ve}\u2514\u2500 completed${re}`)):n.push(`${ve}\u2514\u2500${re}`),o.push(n.join(`
87
+ `))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let n=s.title||s.type.slice(5).replace(/__/g," "),i=[];if(i.push(`${ve}\u250C\u2500 Tool: ${n}${re}`),s.input){let r=JSON.stringify(s.input,null,t?2:void 0),a=t||r.length<=100?r:r.slice(0,100)+"...";i.push(`${Fe}\u2502 Input: ${a}${re}`)}s.output!==void 0&&s.state==="output-available"?(i.push(`${Tt}\u2502 Output: ${Wn(s.output,t)}${re}`),i.push(`${ve}\u2514\u2500 completed${re}`)):s.state==="error"?i.push(`${ve}\u2514\u2500 failed${re}`):i.push(`${ve}\u2514\u2500${re}`),o.push(i.join(`
88
+ `))}return o.join(`
89
89
 
90
- `).trim()}var ao=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," "),o=`
90
+ `).trim()}var co=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[,o]of this.pendingToolCalls){let s=o.toolName.replace(/__/g," "),n=`
91
91
 
92
- ${ve}\u250C\u2500 Tool: ${s}${re}`;if(n.args){let i=n.args.length>100?n.args.slice(0,100)+"...":n.args;o+=`
93
- ${Fe}\u2502 Input: ${i}${re}`}if(n.output){let i=n.output.length>150?n.output.slice(0,150)+"...":n.output;o+=`
94
- ${Tt}\u2502 Output: ${i}${re}`}else if(n.status==="executing"){let i=n.startedAt??Date.now(),r=Math.floor((Date.now()-i)/1e3);o+=`
95
- ${ve}\u2502${re} (executing... ${r}s)`}else n.status==="preparing"&&(o+=`
96
- ${ve}\u2502${re} (preparing...)`);t.push(o)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[n,s]of this.pendingToolCalls){let o=s.toolName.replace(/__/g," "),i=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"";t+=`
92
+ ${ve}\u250C\u2500 Tool: ${s}${re}`;if(o.args){let i=o.args.length>100?o.args.slice(0,100)+"...":o.args;n+=`
93
+ ${Fe}\u2502 Input: ${i}${re}`}if(o.output){let i=o.output.length>150?o.output.slice(0,150)+"...":o.output;n+=`
94
+ ${Tt}\u2502 Output: ${i}${re}`}else if(o.status==="executing"){let i=o.startedAt??Date.now(),r=Math.floor((Date.now()-i)/1e3);n+=`
95
+ ${ve}\u2502${re} (executing... ${r}s)`}else o.status==="preparing"&&(n+=`
96
+ ${ve}\u2502${re} (preparing...)`);t.push(n)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[o,s]of this.pendingToolCalls){let n=s.toolName.replace(/__/g," "),i=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"";t+=`
97
97
 
98
- ${ve}\u250C\u2500 Tool: ${o}${re}`,i&&(t+=`
98
+ ${ve}\u250C\u2500 Tool: ${n}${re}`,i&&(t+=`
99
99
  ${Fe}\u2502 Input: ${i}${re}`),t+=`
100
100
  ${ve}\u2514\u2500 completed${re}
101
- `,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 o=s.toolName.replace(/__/g," "),i=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"",r=(s.output||"").length>200?(s.output||"").slice(0,200)+"...":s.output||"";return n+=`
101
+ `,this.pendingToolCalls.delete(o)}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 o=this.pendingToolCalls.get(t.toolCallId);if(o)return o.args=(o.args||"")+t.inputTextDelta,o.status="executing",o.startedAt??=Date.now(),this.buildToolDisplay()}return null}handleToolOutputStart(t){if(t.toolCallId){let o=this.pendingToolCalls.get(t.toolCallId);if(o)return o.output="",o.status="output",this.buildToolDisplay()}return null}handleToolOutputDelta(t){if(t.toolCallId&&t.outputTextDelta){let o=this.pendingToolCalls.get(t.toolCallId);if(o)return o.output=(o.output||"")+t.outputTextDelta,this.buildToolDisplay()}return null}handleToolOutputEnd(t,o){if(!t.toolCallId)return null;let s=this.pendingToolCalls.get(t.toolCallId);if(!s)return null;let n=s.toolName.replace(/__/g," "),i=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"",r=(s.output||"").length>200?(s.output||"").slice(0,200)+"...":s.output||"";return o+=`
102
102
 
103
- ${ve}\u250C\u2500 Tool: ${o}${re}`,i&&(n+=`
104
- ${Fe}\u2502 Input: ${i}${re}`),n+=`
105
- ${Tt}\u2502 Output: ${r}${re}`,n+=`
103
+ ${ve}\u250C\u2500 Tool: ${n}${re}`,i&&(o+=`
104
+ ${Fe}\u2502 Input: ${i}${re}`),o+=`
105
+ ${Tt}\u2502 Output: ${r}${re}`,o+=`
106
106
  ${ve}\u2514\u2500 completed${re}
107
- `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}handleToolError(t,n){if(!t.toolCallId)return null;let o=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),i=t.errorText||"Unknown error",r=i.length>200?i.slice(0,200)+"...":i;return n+=`
107
+ `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:o,toolDisplay:this.buildToolDisplay()}}handleToolError(t,o){if(!t.toolCallId)return null;let n=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),i=t.errorText||"Unknown error",r=i.length>200?i.slice(0,200)+"...":i;return o+=`
108
108
 
109
- ${ve}\u250C\u2500 Tool: ${o}${re}`,n+=`
110
- ${En}\u2502 Error: ${r}${re}`,n+=`
109
+ ${ve}\u250C\u2500 Tool: ${n}${re}`,o+=`
110
+ ${On}\u2502 Error: ${r}${re}`,o+=`
111
111
  ${ve}\u2514\u2500 failed${re}
112
- `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}};var jo=jn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function le(e,t){let s=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(s+=`
112
+ `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:o,toolDisplay:this.buildToolDisplay()}}};var Fo=Mn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function le(e,t){let s=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(s+=`
113
113
  DATA: ${JSON.stringify(t,null,2)}`),s+=`
114
- `;try{co.appendFileSync(jo,s)}catch{}}function wr(){try{let e=jn.dirname(jo);co.existsSync(e)||co.mkdirSync(e,{recursive:!0}),co.writeFileSync(jo,`=== Debug session started at ${new Date().toISOString()} ===
115
- `)}catch{}}function lo(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function Bn({chatId:e,credentials:t,currentAgentId:n,currentModel:s,activeConnectorIds:o,sandbox:i,webSearch:r,imageGeneration:a,chart:l,localTools:d,fullOutput:I,setMessages:x,setState:b,setCurrentResponse:C,setCredentials:m,setHasPersistedChat:h,getFileIds:S,clearFiles:O}){let V=d?Xt():void 0,Z=d?Zt():void 0;return{sendMessage:hr(async(Y,Se,j)=>{wr(),le("=== sendMessage called ===",{text:Y,localTools:d,clientToolsCount:V?.length});let P=Se||t?.accessToken,E=j||t?.workspaceId;if(!P||!E)try{let _=await pe();P=_.accessToken,E=_.workspaceId,m(_)}catch(_){if(_ instanceof Qe){if(_.code==="not-logged-in"){b({status:"not-logged-in"});return}if(_.code==="no-workspace"){b({status:"no-workspace"});return}}let he=_ instanceof Error?_.message:"Authentication failed";b({status:"error",message:he});return}else try{let _=await dt();_!==P&&(P=_,m({accessToken:_,workspaceId:E}))}catch(_){if(_ instanceof Qe&&_.code==="not-logged-in"){b({status:"not-logged-in"});return}let he=_ instanceof Error?_.message:"Authentication failed";b({status:"error",message:he});return}x(_=>[..._,{role:"user",content:Y}]),b({status:"sending"}),C("");let R=null,W=null;try{let _=new B,he=S?.()??[],L={id:e,message:{id:yr(),createdAt:new Date,role:"user",parts:[{type:"text",text:Y}]}};he.length>0&&(L.fileIds=he),n?L.agentId=n:(s&&(L.model=s),L.connectorIds=o??[],L.enableSandbox=i,L.enableWebSearch=r,L.enableImageGeneration=a,L.enableChart=l),V&&(L.clientTools=V),Z&&(L.clientToolSystemPrompt=Z);let p=await _.chat(P,E,L);if(!p.ok){let F=await p.text();throw new Error(`API error ${p.status}: ${F}`)}if(!p.body)throw new Error("No response body from server");R=p.body.getReader();let ie=new TextDecoder,ke="",q="",A="",te="",ee="",me="",ce="",M=new ao,Q=[],z=[],fe=[],Te=()=>{let F=M.hasExecuting();F&&!W?W=setInterval(()=>{if(!M.hasExecuting()){W&&(clearInterval(W),W=null);return}C(q+M.buildToolDisplay())},1e3):!F&&W&&(clearInterval(W),W=null)};for(;;){let{done:F,value:se}=await R.read();if(F)break;ke+=ie.decode(se,{stream:!0});let D=ke.split(`
114
+ `;try{fo.appendFileSync(Fo,s)}catch{}}function Ar(){try{let e=Mn.dirname(Fo);fo.existsSync(e)||fo.mkdirSync(e,{recursive:!0}),fo.writeFileSync(Fo,`=== Debug session started at ${new Date().toISOString()} ===
115
+ `)}catch{}}function uo(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function Jn({chatId:e,credentials:t,currentAgentId:o,currentModel:s,activeConnectorIds:n,sandbox:i,webSearch:r,imageGeneration:a,chart:l,localTools:d,fullOutput:$,setMessages:x,setState:b,setCurrentResponse:C,setCredentials:m,setHasPersistedChat:h,getFileIds:T,clearFiles:O}){let V=d?Qt():void 0,Z=d?eo():void 0;return{sendMessage:vr(async(Y,Se,j)=>{Ar(),le("=== sendMessage called ===",{text:Y,localTools:d,clientToolsCount:V?.length});let P=Se||t?.accessToken,E=j||t?.workspaceId;if(!P||!E)try{let _=await pe();P=_.accessToken,E=_.workspaceId,m(_)}catch(_){if(_ instanceof Qe){if(_.code==="not-logged-in"){b({status:"not-logged-in"});return}if(_.code==="no-workspace"){b({status:"no-workspace"});return}}let he=_ instanceof Error?_.message:"Authentication failed";b({status:"error",message:he});return}else try{let _=await dt();_!==P&&(P=_,m({accessToken:_,workspaceId:E}))}catch(_){if(_ instanceof Qe&&_.code==="not-logged-in"){b({status:"not-logged-in"});return}let he=_ instanceof Error?_.message:"Authentication failed";b({status:"error",message:he});return}x(_=>[..._,{role:"user",content:Y}]),b({status:"sending"}),C("");let R=null,W=null;try{let _=new B,he=T?.()??[],L={id:e,message:{id:Pr(),createdAt:new Date,role:"user",parts:[{type:"text",text:Y}]}};he.length>0&&(L.fileIds=he),o?L.agentId=o:(s&&(L.model=s),L.connectorIds=n??[],L.enableSandbox=i,L.enableWebSearch=r,L.enableImageGeneration=a,L.enableChart=l),V&&(L.clientTools=V),Z&&(L.clientToolSystemPrompt=Z);let p=await _.chat(P,E,L);if(!p.ok){let F=await p.text();throw new Error(`API error ${p.status}: ${F}`)}if(!p.body)throw new Error("No response body from server");R=p.body.getReader();let ie=new TextDecoder,ke="",q="",A="",te="",ee="",me="",ce="",M=new co,Q=[],z=[],fe=[],Te=()=>{let F=M.hasExecuting();F&&!W?W=setInterval(()=>{if(!M.hasExecuting()){W&&(clearInterval(W),W=null);return}C(q+M.buildToolDisplay())},1e3):!F&&W&&(clearInterval(W),W=null)};for(;;){let{done:F,value:se}=await R.read();if(F)break;ke+=ie.decode(se,{stream:!0});let D=ke.split(`
116
116
  `);ke=D.pop()||"";for(let f of D)if(f.trim()!=="data: [DONE]"&&f.startsWith("data: "))try{let w=JSON.parse(f.slice(6));switch(le(`SSE event received: ${w.type}`,w),w.type){case"reasoning-start":te=w.id||"0",A="";break;case"reasoning-delta":w.delta&&(A+=w.delta,C(`${Fe}[Thinking...]${re}
117
- ${A}`)),w.providerMetadata?.anthropic?.signature&&(ee=w.providerMetadata.anthropic.signature);break;case"reasoning-end":if(A){let T={type:"reasoning",id:te,text:A,state:"done"};ee&&(T.providerMetadata={anthropic:{signature:ee}}),z.push(T),le("Added reasoning to messageParts",{reasoningLength:A.length,hasSignature:!!ee,messagePartsCount:z.length})}A="",ee="",C("");break;case"text-delta":w.delta&&(M.hasPending()&&(q=M.flushPending(q)),q+=w.delta,me+=w.delta,C(q));break;case"tool-input-start":{let T=M.handleToolInputStart(w);T&&C(q+T),Te();break}case"tool-input-delta":{let T=M.handleToolInputDelta(w);T&&C(q+T),Te();break}case"tool-call":case"tool-input-available":{if(le(`=== Tool event: ${w.type} ===`,{toolCallId:w.toolCallId,toolName:w.toolName,localTools:d,isClientToolResult:w.toolName?tt(w.toolName):"no toolName",args:w.args,input:w.input}),w.toolCallId&&w.toolName){let T=lo(w.args??w.input);z.push({type:w.type,toolCallId:w.toolCallId,toolName:w.toolName,args:T}),le("Added tool to messageParts",{messagePartsCount:z.length})}if(d&&w.toolCallId&&w.toolName&&tt(w.toolName)){let T=lo(w.args??w.input);Q.push({toolCallId:w.toolCallId,toolName:w.toolName,args:T}),le("Added to pendingClientTools",{pendingCount:Q.length,pendingClientTools:Q}),C(q+M.buildToolDisplay()+`
118
- [Executing ${w.toolName} locally...]`)}else le("NOT added to pendingClientTools - conditions not met",{localTools:d,hasToolCallId:!!w.toolCallId,hasToolName:!!w.toolName,isClientTool:w.toolName?tt(w.toolName):!1});break}case"tool-output-start":{let T=M.handleToolOutputStart(w);T&&C(q+T),Te();break}case"tool-output-delta":{let T=M.handleToolOutputDelta(w);T&&C(q+T),Te();break}case"tool-output-end":{let T=M.handleToolOutputEnd(w,q);T&&(q=T.fullResponse,C(q+T.toolDisplay)),Te();break}case"tool-input-error":case"tool-output-error":{let T=M.handleToolError(w,q);T&&(q=T.fullResponse,C(q+T.toolDisplay)),Te();break}case"start":w.messageId&&(ce=w.messageId,le("Captured messageId from start event",{messageId:ce}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":w.errorText&&console.error("Stream error:",w.errorText);break}}catch{}}if(me){let F=z.findIndex(D=>D.type!=="reasoning"),se=F===-1?z.length:F;z.splice(se,0,{type:"text",text:me}),le("Added accumulated text to messageParts",{textLength:me.length,insertIndex:se})}for(le("=== Initial stream ended ===",{pendingClientToolsCount:Q.length,pendingClientTools:Q,messagePartsCount:z.length,messageParts:z.map(F=>({type:F.type,toolCallId:F.toolCallId,toolName:F.toolName}))});Q.length>0;){le("=== Starting pending tools execution loop ===",{pendingCount:Q.length});let F=[];for(let f of Q){le(`Executing tool: ${f.toolName}`,{toolCallId:f.toolCallId,args:f.args}),M.handleToolInputStart({toolCallId:f.toolCallId,toolName:f.toolName}),M.handleToolInputDelta({toolCallId:f.toolCallId,inputTextDelta:JSON.stringify(f.args)}),C(q+M.buildToolDisplay()),Te();let w=await Qt(f.toolName,f.args);le(`Tool execution result: ${f.toolName}`,{success:w.success,resultPreview:w.success?JSON.stringify(w.result).slice(0,200):w.error});let T=w.success?JSON.stringify(w.result):w.error||"Unknown error";if(F.push({toolCallId:f.toolCallId,toolName:f.toolName,content:[{type:"text",text:T}],isError:!w.success}),w.success){M.handleToolOutputStart({toolCallId:f.toolCallId}),M.handleToolOutputDelta({toolCallId:f.toolCallId,outputTextDelta:JSON.stringify(w.result).slice(0,200)});let oe=M.handleToolOutputEnd({toolCallId:f.toolCallId},q);oe&&(q=oe.fullResponse)}else{let oe=M.handleToolError({toolCallId:f.toolCallId,errorText:w.error},q);oe&&(q=oe.fullResponse)}C(q+M.buildToolDisplay()),Te()}Q.length=0;for(let f of F){let w=z.find(T=>(T.type==="tool-input-available"||T.type==="tool-call")&&T.toolCallId===f.toolCallId);if(w){let T=[];for(let U of f.content)U.type==="text"?T.push(U.text):U.type==="image"?T.push("[Image]"):U.type==="audio"?T.push("[Audio]"):(U.type==="resource"||U.type==="resource_link")&&T.push("[Resource]");let oe=T.join(`
119
- `);fe.push({type:`tool-${w.toolName}`,toolName:w.toolName,toolCallId:w.toolCallId,input:w.args,output:oe,isError:f.isError})}}if(le("=== Sending clientToolResults for continuation ===",{toolResultsCount:F.length,toolResults:F.map(f=>({toolCallId:f.toolCallId,toolName:f.toolName,isError:f.isError}))}),R)try{R.releaseLock()}catch{}let se={id:e,clientToolResults:F};n?se.agentId=n:(s&&(se.model=s),se.connectorIds=o??[],se.enableSandbox=i,se.enableWebSearch=r,se.enableImageGeneration=a,se.enableChart=l),V&&(se.clientTools=V),Z&&(se.clientToolSystemPrompt=Z),le("=== Sending continuation request ===",{chatId:e,hasAgentId:!!se.agentId,hasModel:!!se.model,clientToolResultsCount:F.length});let D=await _.chat(P,E,se);if(le("=== Continuation response received ===",{ok:D.ok,status:D.status}),!D.ok){let f=await D.text();throw new Error(`Continuation failed: ${D.status}: ${f}`)}if(!D.body)break;for(le("=== Processing continuation stream ==="),R=D.body.getReader(),z.length=0,me="",A="",te="",ee="";;){let{done:f,value:w}=await R.read();if(f){le("=== Continuation stream done ===");break}ke+=ie.decode(w,{stream:!0});let T=ke.split(`
120
- `);ke=T.pop()||"";for(let oe of T)if(oe.trim()!=="data: [DONE]"&&oe.startsWith("data: "))try{let U=JSON.parse(oe.slice(6));switch(le(`Continuation SSE: ${U.type}`,U),U.type){case"reasoning-start":te=U.id||"0",A="";break;case"reasoning-delta":U.delta&&(A+=U.delta,C(`${Fe}[Thinking...]${re}
121
- ${A}`)),U.providerMetadata?.anthropic?.signature&&(ee=U.providerMetadata.anthropic.signature);break;case"reasoning-end":if(A){let Ce={type:"reasoning",id:te,text:A,state:"done"};ee&&(Ce.providerMetadata={anthropic:{signature:ee}}),z.push(Ce),le("Continuation: Added reasoning to messageParts",{reasoningLength:A.length,hasSignature:!!ee,messagePartsCount:z.length})}A="",ee="",C(q);break;case"text-delta":U.delta&&(q+=U.delta,me+=U.delta,C(q));break;case"tool-call":case"tool-input-available":if(U.toolCallId&&U.toolName){let Ce=lo(U.args??U.input);z.push({type:U.type,toolCallId:U.toolCallId,toolName:U.toolName,args:Ce})}if(d&&U.toolCallId&&U.toolName&&tt(U.toolName)){let Ce=lo(U.args??U.input);Q.push({toolCallId:U.toolCallId,toolName:U.toolName,args:Ce}),le("Continuation: Added to pendingClientTools",{pendingCount:Q.length})}break;case"finish":le("Continuation finish event",U);break}}catch{}}if(me){let f=z.findIndex(T=>T.type!=="reasoning"),w=f===-1?z.length:f;z.splice(w,0,{type:"text",text:me})}le("=== Continuation stream processing complete ===",{pendingClientToolsCount:Q.length,messagePartsCount:z.length,fullResponseLength:q.length})}if(d&&V&&V.length>0){let F=[];for(let D of fe)F.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 z)D.type==="text"&&D.text&&F.push({type:"text",text:D.text});let se=ht(F,I);le("=== Using formatted parts for local tools ===",{executedToolsCount:fe.length,textPartsCount:z.filter(D=>D.type==="text").length,contentLength:se.length}),x(D=>[...D,{role:"assistant",content:se,parts:F}])}else{le("=== Fetching message from API ===",{fullResponseLength:q.length,fullResponsePreview:q.slice(0,200)});try{let{messages:F}=await _.getMessages(P,E,e,10);le("=== API messages received ===",{count:F.length,roles:F.map(D=>D.role)});let se=F.find(D=>D.role==="assistant");if(se){let D=se.parts,f=ht(D,I);le("=== Setting message from API ===",{partsCount:D.length,partTypes:D.map(w=>w.type),contentLength:f.length,contentPreview:f.slice(0,200)}),x(w=>[...w,{role:"assistant",content:f,parts:D}])}else le("=== No assistant message found, using fallback ==="),x(D=>[...D,{role:"assistant",content:q}])}catch(F){le("=== API fetch failed, using fallback ===",{error:F instanceof Error?F.message:String(F)}),x(se=>[...se,{role:"assistant",content:q}])}}le("=== Message handling complete ==="),C(""),b({status:"ready"}),h(!0),he.length>0&&O?.()}catch(_){le("=== ERROR ===",{message:_ instanceof Error?_.message:String(_),stack:_ instanceof Error?_.stack:void 0});let he=_ instanceof Error?_.message:"Failed to send message";b({status:"error",message:he})}finally{if(W&&(clearInterval(W),W=null),R)try{R.releaseLock()}catch{}}},[t,e,n,s,o,i,r,a,l,d,V,Z,I,x,b,C,m,h,S,O])}}import{useState as jt}from"react";var Fn={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"}},Wn=new Map(Object.values(Fn).map(e=>[e.apiKey,e.name]));function Mn(){return Object.values(Fn)}function Jn(e,t,n,s,o){let[i,r]=jt(e),[a,l]=jt(t),[d,I]=jt(n),[x,b]=jt(s),[C,m]=jt(o);return{sandbox:i,setSandbox:r,webSearch:a,setWebSearch:l,imageGeneration:d,setImageGeneration:I,chart:x,setChart:b,fileSystem:C,setFileSystem:m,capabilityLabelMap:Wn}}import{useEffect as kr,useState as xr}from"react";function Gn(e,t){let[n,s]=xr(null);return kr(()=>{let o=!1;async function i(){if(!e||!t){s(null);return}try{let a=await new B().getAgent(t.accessToken,t.workspaceId,e);o||s(a)}catch{o||s(null)}}return i(),()=>{o=!0}},[e,t]),{currentAgentDetails:n}}import{useState as Bo}from"react";function Hn(e,t,n){let[s,o]=Bo(e),[i,r]=Bo(t),[a,l]=Bo(n);return{currentModel:s,setCurrentModel:o,currentAgentId:i,setCurrentAgentId:r,activeConnectorIds:a,setActiveConnectorIds:l}}import{useApp as Cr,useInput as $r}from"ink";import{useCallback as nt,useRef as Sr,useState as De}from"react";import{spawn as br}from"child_process";function Vn(e){return new Promise((t,n)=>{let s,o;process.platform==="darwin"?(s="open",o=[e]):process.platform==="win32"?(s="cmd",o=["/c","start","",e]):(s="xdg-open",o=[e]);let i=br(s,o,{stdio:"ignore",detached:!0});i.once("error",r=>{n(r)}),i.once("spawn",()=>{i.unref(),t()})})}var Kn=[{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 qn(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?Kn.filter(n=>n.name.startsWith(t)||n.aliases.some(s=>s.startsWith(t))):Kn}function zn(e){let t=e.trim();if(!t.startsWith("/"))return null;let n=t.slice(1).split(/\s+/),s=n[0]?.toLowerCase(),o=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:o||void 0};case"agent":case"a":return{type:"agent",value:o||void 0};case"skills":case"sk":return{type:"skills",value:o||void 0};case"schedules":case"sch":return{type:"schedules",value:o||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:o||void 0};case"budget":case"bg":return{type:"budget",value:o||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:o||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 Yn=`Available commands:
117
+ ${A}`)),w.providerMetadata?.anthropic?.signature&&(ee=w.providerMetadata.anthropic.signature);break;case"reasoning-end":if(A){let I={type:"reasoning",id:te,text:A,state:"done"};ee&&(I.providerMetadata={anthropic:{signature:ee}}),z.push(I),le("Added reasoning to messageParts",{reasoningLength:A.length,hasSignature:!!ee,messagePartsCount:z.length})}A="",ee="",C("");break;case"text-delta":w.delta&&(M.hasPending()&&(q=M.flushPending(q)),q+=w.delta,me+=w.delta,C(q));break;case"tool-input-start":{let I=M.handleToolInputStart(w);I&&C(q+I),Te();break}case"tool-input-delta":{let I=M.handleToolInputDelta(w);I&&C(q+I),Te();break}case"tool-call":case"tool-input-available":{if(le(`=== Tool event: ${w.type} ===`,{toolCallId:w.toolCallId,toolName:w.toolName,localTools:d,isClientToolResult:w.toolName?tt(w.toolName):"no toolName",args:w.args,input:w.input}),w.toolCallId&&w.toolName){let I=uo(w.args??w.input);z.push({type:w.type,toolCallId:w.toolCallId,toolName:w.toolName,args:I}),le("Added tool to messageParts",{messagePartsCount:z.length})}if(d&&w.toolCallId&&w.toolName&&tt(w.toolName)){let I=uo(w.args??w.input);Q.push({toolCallId:w.toolCallId,toolName:w.toolName,args:I}),le("Added to pendingClientTools",{pendingCount:Q.length,pendingClientTools:Q}),C(q+M.buildToolDisplay()+`
118
+ [Executing ${w.toolName} locally...]`)}else le("NOT added to pendingClientTools - conditions not met",{localTools:d,hasToolCallId:!!w.toolCallId,hasToolName:!!w.toolName,isClientTool:w.toolName?tt(w.toolName):!1});break}case"tool-output-start":{let I=M.handleToolOutputStart(w);I&&C(q+I),Te();break}case"tool-output-delta":{let I=M.handleToolOutputDelta(w);I&&C(q+I),Te();break}case"tool-output-end":{let I=M.handleToolOutputEnd(w,q);I&&(q=I.fullResponse,C(q+I.toolDisplay)),Te();break}case"tool-input-error":case"tool-output-error":{let I=M.handleToolError(w,q);I&&(q=I.fullResponse,C(q+I.toolDisplay)),Te();break}case"start":w.messageId&&(ce=w.messageId,le("Captured messageId from start event",{messageId:ce}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":w.errorText&&console.error("Stream error:",w.errorText);break}}catch{}}if(me){let F=z.findIndex(D=>D.type!=="reasoning"),se=F===-1?z.length:F;z.splice(se,0,{type:"text",text:me}),le("Added accumulated text to messageParts",{textLength:me.length,insertIndex:se})}for(le("=== Initial stream ended ===",{pendingClientToolsCount:Q.length,pendingClientTools:Q,messagePartsCount:z.length,messageParts:z.map(F=>({type:F.type,toolCallId:F.toolCallId,toolName:F.toolName}))});Q.length>0;){le("=== Starting pending tools execution loop ===",{pendingCount:Q.length});let F=[];for(let f of Q){le(`Executing tool: ${f.toolName}`,{toolCallId:f.toolCallId,args:f.args}),M.handleToolInputStart({toolCallId:f.toolCallId,toolName:f.toolName}),M.handleToolInputDelta({toolCallId:f.toolCallId,inputTextDelta:JSON.stringify(f.args)}),C(q+M.buildToolDisplay()),Te();let w=await to(f.toolName,f.args);le(`Tool execution result: ${f.toolName}`,{success:w.success,resultPreview:w.success?JSON.stringify(w.result).slice(0,200):w.error});let I=w.success?JSON.stringify(w.result):w.error||"Unknown error";if(F.push({toolCallId:f.toolCallId,toolName:f.toolName,content:[{type:"text",text:I}],isError:!w.success}),w.success){M.handleToolOutputStart({toolCallId:f.toolCallId}),M.handleToolOutputDelta({toolCallId:f.toolCallId,outputTextDelta:JSON.stringify(w.result).slice(0,200)});let oe=M.handleToolOutputEnd({toolCallId:f.toolCallId},q);oe&&(q=oe.fullResponse)}else{let oe=M.handleToolError({toolCallId:f.toolCallId,errorText:w.error},q);oe&&(q=oe.fullResponse)}C(q+M.buildToolDisplay()),Te()}Q.length=0;for(let f of F){let w=z.find(I=>(I.type==="tool-input-available"||I.type==="tool-call")&&I.toolCallId===f.toolCallId);if(w){let I=[];for(let U of f.content)U.type==="text"?I.push(U.text):U.type==="image"?I.push("[Image]"):U.type==="audio"?I.push("[Audio]"):(U.type==="resource"||U.type==="resource_link")&&I.push("[Resource]");let oe=I.join(`
119
+ `);fe.push({type:`tool-${w.toolName}`,toolName:w.toolName,toolCallId:w.toolCallId,input:w.args,output:oe,isError:f.isError})}}if(le("=== Sending clientToolResults for continuation ===",{toolResultsCount:F.length,toolResults:F.map(f=>({toolCallId:f.toolCallId,toolName:f.toolName,isError:f.isError}))}),R)try{R.releaseLock()}catch{}let se={id:e,clientToolResults:F};o?se.agentId=o:(s&&(se.model=s),se.connectorIds=n??[],se.enableSandbox=i,se.enableWebSearch=r,se.enableImageGeneration=a,se.enableChart=l),V&&(se.clientTools=V),Z&&(se.clientToolSystemPrompt=Z),le("=== Sending continuation request ===",{chatId:e,hasAgentId:!!se.agentId,hasModel:!!se.model,clientToolResultsCount:F.length});let D=await _.chat(P,E,se);if(le("=== Continuation response received ===",{ok:D.ok,status:D.status}),!D.ok){let f=await D.text();throw new Error(`Continuation failed: ${D.status}: ${f}`)}if(!D.body)break;for(le("=== Processing continuation stream ==="),R=D.body.getReader(),z.length=0,me="",A="",te="",ee="";;){let{done:f,value:w}=await R.read();if(f){le("=== Continuation stream done ===");break}ke+=ie.decode(w,{stream:!0});let I=ke.split(`
120
+ `);ke=I.pop()||"";for(let oe of I)if(oe.trim()!=="data: [DONE]"&&oe.startsWith("data: "))try{let U=JSON.parse(oe.slice(6));switch(le(`Continuation SSE: ${U.type}`,U),U.type){case"reasoning-start":te=U.id||"0",A="";break;case"reasoning-delta":U.delta&&(A+=U.delta,C(`${Fe}[Thinking...]${re}
121
+ ${A}`)),U.providerMetadata?.anthropic?.signature&&(ee=U.providerMetadata.anthropic.signature);break;case"reasoning-end":if(A){let Ce={type:"reasoning",id:te,text:A,state:"done"};ee&&(Ce.providerMetadata={anthropic:{signature:ee}}),z.push(Ce),le("Continuation: Added reasoning to messageParts",{reasoningLength:A.length,hasSignature:!!ee,messagePartsCount:z.length})}A="",ee="",C(q);break;case"text-delta":U.delta&&(q+=U.delta,me+=U.delta,C(q));break;case"tool-call":case"tool-input-available":if(U.toolCallId&&U.toolName){let Ce=uo(U.args??U.input);z.push({type:U.type,toolCallId:U.toolCallId,toolName:U.toolName,args:Ce})}if(d&&U.toolCallId&&U.toolName&&tt(U.toolName)){let Ce=uo(U.args??U.input);Q.push({toolCallId:U.toolCallId,toolName:U.toolName,args:Ce}),le("Continuation: Added to pendingClientTools",{pendingCount:Q.length})}break;case"finish":le("Continuation finish event",U);break}}catch{}}if(me){let f=z.findIndex(I=>I.type!=="reasoning"),w=f===-1?z.length:f;z.splice(w,0,{type:"text",text:me})}le("=== Continuation stream processing complete ===",{pendingClientToolsCount:Q.length,messagePartsCount:z.length,fullResponseLength:q.length})}if(d&&V&&V.length>0){let F=[];for(let D of fe)F.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 z)D.type==="text"&&D.text&&F.push({type:"text",text:D.text});let se=ht(F,$);le("=== Using formatted parts for local tools ===",{executedToolsCount:fe.length,textPartsCount:z.filter(D=>D.type==="text").length,contentLength:se.length}),x(D=>[...D,{role:"assistant",content:se,parts:F}])}else{le("=== Fetching message from API ===",{fullResponseLength:q.length,fullResponsePreview:q.slice(0,200)});try{let{messages:F}=await _.getMessages(P,E,e,10);le("=== API messages received ===",{count:F.length,roles:F.map(D=>D.role)});let se=F.find(D=>D.role==="assistant");if(se){let D=se.parts,f=ht(D,$);le("=== Setting message from API ===",{partsCount:D.length,partTypes:D.map(w=>w.type),contentLength:f.length,contentPreview:f.slice(0,200)}),x(w=>[...w,{role:"assistant",content:f,parts:D}])}else le("=== No assistant message found, using fallback ==="),x(D=>[...D,{role:"assistant",content:q}])}catch(F){le("=== API fetch failed, using fallback ===",{error:F instanceof Error?F.message:String(F)}),x(se=>[...se,{role:"assistant",content:q}])}}le("=== Message handling complete ==="),C(""),b({status:"ready"}),h(!0),he.length>0&&O?.()}catch(_){le("=== ERROR ===",{message:_ instanceof Error?_.message:String(_),stack:_ instanceof Error?_.stack:void 0});let he=_ instanceof Error?_.message:"Failed to send message";b({status:"error",message:he})}finally{if(W&&(clearInterval(W),W=null),R)try{R.releaseLock()}catch{}}},[t,e,o,s,n,i,r,a,l,d,V,Z,$,x,b,C,m,h,T,O])}}import{useState as Bt}from"react";var Gn={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"}},Hn=new Map(Object.values(Gn).map(e=>[e.apiKey,e.name]));function Vn(){return Object.values(Gn)}function Kn(e,t,o,s,n){let[i,r]=Bt(e),[a,l]=Bt(t),[d,$]=Bt(o),[x,b]=Bt(s),[C,m]=Bt(n);return{sandbox:i,setSandbox:r,webSearch:a,setWebSearch:l,imageGeneration:d,setImageGeneration:$,chart:x,setChart:b,fileSystem:C,setFileSystem:m,capabilityLabelMap:Hn}}import{useEffect as Nr,useState as Er}from"react";function qn(e,t){let[o,s]=Er(null);return Nr(()=>{let n=!1;async function i(){if(!e||!t){s(null);return}try{let a=await new B().getAgent(t.accessToken,t.workspaceId,e);n||s(a)}catch{n||s(null)}}return i(),()=>{n=!0}},[e,t]),{currentAgentDetails:o}}import{useState as Wo}from"react";function zn(e,t,o){let[s,n]=Wo(e),[i,r]=Wo(t),[a,l]=Wo(o);return{currentModel:s,setCurrentModel:n,currentAgentId:i,setCurrentAgentId:r,activeConnectorIds:a,setActiveConnectorIds:l}}import{useApp as Lr,useInput as Dr}from"ink";import{useCallback as nt,useRef as Or,useState as De}from"react";import{spawn as _r}from"child_process";function Yn(e){return new Promise((t,o)=>{let s,n;process.platform==="darwin"?(s="open",n=[e]):process.platform==="win32"?(s="cmd",n=["/c","start","",e]):(s="xdg-open",n=[e]);let i=_r(s,n,{stdio:"ignore",detached:!0});i.once("error",r=>{o(r)}),i.once("spawn",()=>{i.unref(),t()})})}var Xn=[{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 Zn(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?Xn.filter(o=>o.name.startsWith(t)||o.aliases.some(s=>s.startsWith(t))):Xn}function Qn(e){let t=e.trim();if(!t.startsWith("/"))return null;let o=t.slice(1).split(/\s+/),s=o[0]?.toLowerCase(),n=o.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:n||void 0};case"agent":case"a":return{type:"agent",value:n||void 0};case"skills":case"sk":return{type:"skills",value:n||void 0};case"schedules":case"sch":return{type:"schedules",value:n||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:n||void 0};case"budget":case"bg":return{type:"budget",value:n||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:n||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 es=`Available commands:
122
122
  /help, /h, /? Show this help message
123
123
  /clear, /cls, /new Start a new chat
124
124
  /model [name], /m Show current model or switch to [name]
@@ -142,97 +142,97 @@ Note: For detailed usage with sorting/limits, use: entrydesk usage --help
142
142
 
143
143
  Keyboard shortcuts:
144
144
  Ctrl+O Toggle full output mode
145
- Ctrl+C Exit`;function Xn({input:e,setInput:t,chatId:n,setChatId:s,currentChatTitle:o,setCurrentChatTitle:i,currentModel:r,setCurrentModel:a,currentAgentId:l,setCurrentAgentId:d,currentAgentDetails:I,setCurrentAgentDetails:x,activeConnectorIds:b,setActiveConnectorIds:C,sandbox:m,setSandbox:h,webSearch:S,setWebSearch:O,imageGeneration:V,setImageGeneration:Z,chart:ae,setChart:Y,fileSystem:Se,setFileSystem:j,availableModels:P,availableAgents:E,availableConnectors:R,messages:W,hasPersistedChat:_,setHasPersistedChat:he,setMessages:L,addSystemMessage:p,startNewChat:ie,sendMessage:ke,setFullOutput:q,credentials:A,setCredentials:te,setState:ee,defaultCapabilities:me,capabilityLabelMap:ce,hasUploadingFiles:M=!1}){let{exit:Q}=Cr(),[z,fe]=De([]),[Te,F]=De(0),[se,D]=De(!1),[f,w]=De(null),[T,oe]=De([]),[U,Ce]=De(0),[rt,it]=De(new Set),[Re,at]=De(new Set),[ko,Ht]=De([]),[We,wt]=De([]),[Ye,Vt]=De([]),[lt,xo]=De([]),[Ve,Xe]=De(null),[Kt,kt]=De(""),mt=Sr(!1),[ct,xt]=De(!1),bt=nt(async()=>{if(!A)return[];let v=new B,y=[],c;do{let u=await v.listAvailableSkills(A.accessToken,A.workspaceId,{limit:100,nextKey:c});y.push(...u.skills),c=u.nextKey}while(c);return wt(y),y},[A]),Ct=nt(async()=>{if(!A)return[];let v=new B,y=[],c;do{let u=await v.getSchedules(A.accessToken,A.workspaceId,{limit:100,nextKey:c});y.push(...u.schedules),c=u.nextKey}while(c);return Vt(y),y},[A]),_e=nt(async v=>{if(v==="model"){if(P.length===0){p("No models available.");return}let y=P.map(u=>({id:u.id,name:u.name,description:u.description}));oe(y);let c=r?y.findIndex(u=>u.id===r):-1;Ce(c>=0?c:0),w("model")}else if(v==="agent"){if(E.length===0){p("No agents available.");return}let y=E.map(u=>({id:u.id,name:u.name,description:u.description}));oe(y);let c=l?y.findIndex(u=>u.id===l):-1;Ce(c>=0?c:0),w("agent")}else if(v==="skills"){let y=We;if(y.length===0)try{y=await bt()}catch{p("Failed to load skills.");return}if(y.length===0){p("No skills available.");return}let c=y.map(u=>({id:u.id,name:u.name,description:u.description}));oe(c),Ce(0),w("skills")}else if(v==="schedules"){let y=Ye;if(y.length===0)try{y=await Ct()}catch{p("Failed to load schedules.");return}if(y.length===0){p("No schedules found.");return}let c=y.map(u=>({id:u.id,name:u.name,description:`${u.agent.name} - ${u.isActive?"Active":"Paused"}`}));oe(c),Ce(0),w("schedules")}else if(v==="connectors"){if(R.length===0){p("No connectors available.");return}let y=R.map(c=>({id:c.id,name:c.name}));oe(y),Ce(0),it(new Set(b||[])),w("connectors")}else if(v==="capabilities"){let y=Mn().map(u=>({id:u.id,name:u.name,description:u.description}));oe(y),Ce(0);let c=new Set;m&&c.add("sandbox"),S&&c.add("webSearch"),V&&c.add("imageGeneration"),ae&&c.add("chart"),Se&&c.add("fileSystem"),at(c),w("capabilities")}else if(v==="chats"){if(!A){p("Not authenticated.");return}try{let y=new B,{chats:c}=await y.getChats(A.accessToken,A.workspaceId,20);if(c.length===0){p("No chats available.");return}Ht(c);let u=c.map($=>({id:$.id,name:$.title||"Untitled",description:new Date($.createdAt).toLocaleDateString()}));oe(u);let g=u.findIndex($=>$.id===n);Ce(g>=0?g:0),w("chats")}catch{p("Failed to load chats.")}}else if(v==="profile"){let y=H.getProfileNames(),c=H.getCurrentProfileName(),u=y.map($=>({id:$,name:$,description:$===c?"(current)":void 0}));oe(u);let g=u.findIndex($=>$.id===c);Ce(g>=0?g:0),w("profile")}D(!1),fe([])},[P,E,We,Ye,R,b,r,l,bt,Ct,m,S,V,ae,Se,A,n,p]),ye=nt(v=>{let y=ne.getAll(v);a(y.model?.default),d(void 0),x(null);let c=y.connectors?.defaults;C(c&&c.length>0?c:void 0);let u=y.capabilities;h(u?.sandbox??me.sandbox),O(u?.webSearch??me.webSearch),Z(u?.imageGeneration??me.imageGeneration),Y(u?.chart??me.chart);let g=y.localTools;j(g?.fileSystem??me.fileSystem)},[a,d,x,C,h,O,Z,Y,j,me]),Ze=nt(async()=>{try{let v=await pe();te({accessToken:v.accessToken,workspaceId:v.workspaceId}),ee({status:"ready"})}catch(v){if(te(null),v instanceof Qe){if(v.code==="not-logged-in"){ee({status:"not-logged-in"});return}if(v.code==="no-workspace"){ee({status:"no-workspace"});return}}let y=v instanceof Error?v.message:"Failed to authenticate";ee({status:"error",message:y})}},[te,ee]),$t=nt(async v=>{switch(v.type){case"help":return p(Yn),!0;case"clear":return ie("Started a new chat."),!0;case"model":{if(v.value){let y=v.value.toLowerCase(),c=P.find(u=>u.id.toLowerCase()===y||u.name.toLowerCase().includes(y));if(c)l?ie(`Switched to model: ${c.name} (new chat)`):p(`Switched to model: ${c.name}`),a(c.id),d(void 0),x(null),ne.setDefaultModel(c.id);else{let u=P.map(g=>g.name).join(", ");p(`Model "${v.value}" not found.
145
+ Ctrl+C Exit`;function ts({input:e,setInput:t,chatId:o,setChatId:s,currentChatTitle:n,setCurrentChatTitle:i,currentModel:r,setCurrentModel:a,currentAgentId:l,setCurrentAgentId:d,currentAgentDetails:$,setCurrentAgentDetails:x,activeConnectorIds:b,setActiveConnectorIds:C,sandbox:m,setSandbox:h,webSearch:T,setWebSearch:O,imageGeneration:V,setImageGeneration:Z,chart:ae,setChart:Y,fileSystem:Se,setFileSystem:j,availableModels:P,availableAgents:E,availableConnectors:R,messages:W,hasPersistedChat:_,setHasPersistedChat:he,setMessages:L,addSystemMessage:p,startNewChat:ie,sendMessage:ke,setFullOutput:q,credentials:A,setCredentials:te,setState:ee,defaultCapabilities:me,capabilityLabelMap:ce,hasUploadingFiles:M=!1}){let{exit:Q}=Lr(),[z,fe]=De([]),[Te,F]=De(0),[se,D]=De(!1),[f,w]=De(null),[I,oe]=De([]),[U,Ce]=De(0),[rt,it]=De(new Set),[Re,at]=De(new Set),[bo,Kt]=De([]),[We,wt]=De([]),[Ye,qt]=De([]),[lt,Co]=De([]),[Ve,Xe]=De(null),[zt,kt]=De(""),mt=Or(!1),[ct,xt]=De(!1),bt=nt(async()=>{if(!A)return[];let v=new B,y=[],c;do{let u=await v.listAvailableSkills(A.accessToken,A.workspaceId,{limit:100,nextKey:c});y.push(...u.skills),c=u.nextKey}while(c);return wt(y),y},[A]),Ct=nt(async()=>{if(!A)return[];let v=new B,y=[],c;do{let u=await v.getSchedules(A.accessToken,A.workspaceId,{limit:100,nextKey:c});y.push(...u.schedules),c=u.nextKey}while(c);return qt(y),y},[A]),_e=nt(async v=>{if(v==="model"){if(P.length===0){p("No models available.");return}let y=P.map(u=>({id:u.id,name:u.name,description:u.description}));oe(y);let c=r?y.findIndex(u=>u.id===r):-1;Ce(c>=0?c:0),w("model")}else if(v==="agent"){if(E.length===0){p("No agents available.");return}let y=E.map(u=>({id:u.id,name:u.name,description:u.description}));oe(y);let c=l?y.findIndex(u=>u.id===l):-1;Ce(c>=0?c:0),w("agent")}else if(v==="skills"){let y=We;if(y.length===0)try{y=await bt()}catch{p("Failed to load skills.");return}if(y.length===0){p("No skills available.");return}let c=y.map(u=>({id:u.id,name:u.name,description:u.description}));oe(c),Ce(0),w("skills")}else if(v==="schedules"){let y=Ye;if(y.length===0)try{y=await Ct()}catch{p("Failed to load schedules.");return}if(y.length===0){p("No schedules found.");return}let c=y.map(u=>({id:u.id,name:u.name,description:`${u.agent.name} - ${u.isActive?"Active":"Paused"}`}));oe(c),Ce(0),w("schedules")}else if(v==="connectors"){if(R.length===0){p("No connectors available.");return}let y=R.map(c=>({id:c.id,name:c.name}));oe(y),Ce(0),it(new Set(b||[])),w("connectors")}else if(v==="capabilities"){let y=Vn().map(u=>({id:u.id,name:u.name,description:u.description}));oe(y),Ce(0);let c=new Set;m&&c.add("sandbox"),T&&c.add("webSearch"),V&&c.add("imageGeneration"),ae&&c.add("chart"),Se&&c.add("fileSystem"),at(c),w("capabilities")}else if(v==="chats"){if(!A){p("Not authenticated.");return}try{let y=new B,{chats:c}=await y.getChats(A.accessToken,A.workspaceId,20);if(c.length===0){p("No chats available.");return}Kt(c);let u=c.map(S=>({id:S.id,name:S.title||"Untitled",description:new Date(S.createdAt).toLocaleDateString()}));oe(u);let g=u.findIndex(S=>S.id===o);Ce(g>=0?g:0),w("chats")}catch{p("Failed to load chats.")}}else if(v==="profile"){let y=H.getProfileNames(),c=H.getCurrentProfileName(),u=y.map(S=>({id:S,name:S,description:S===c?"(current)":void 0}));oe(u);let g=u.findIndex(S=>S.id===c);Ce(g>=0?g:0),w("profile")}D(!1),fe([])},[P,E,We,Ye,R,b,r,l,bt,Ct,m,T,V,ae,Se,A,o,p]),ye=nt(v=>{let y=ne.getAll(v);a(y.model?.default),d(void 0),x(null);let c=y.connectors?.defaults;C(c&&c.length>0?c:void 0);let u=y.capabilities;h(u?.sandbox??me.sandbox),O(u?.webSearch??me.webSearch),Z(u?.imageGeneration??me.imageGeneration),Y(u?.chart??me.chart);let g=y.localTools;j(g?.fileSystem??me.fileSystem)},[a,d,x,C,h,O,Z,Y,j,me]),Ze=nt(async()=>{try{let v=await pe();te({accessToken:v.accessToken,workspaceId:v.workspaceId}),ee({status:"ready"})}catch(v){if(te(null),v instanceof Qe){if(v.code==="not-logged-in"){ee({status:"not-logged-in"});return}if(v.code==="no-workspace"){ee({status:"no-workspace"});return}}let y=v instanceof Error?v.message:"Failed to authenticate";ee({status:"error",message:y})}},[te,ee]),$t=nt(async v=>{switch(v.type){case"help":return p(es),!0;case"clear":return ie("Started a new chat."),!0;case"model":{if(v.value){let y=v.value.toLowerCase(),c=P.find(u=>u.id.toLowerCase()===y||u.name.toLowerCase().includes(y));if(c)l?ie(`Switched to model: ${c.name} (new chat)`):p(`Switched to model: ${c.name}`),a(c.id),d(void 0),x(null),ne.setDefaultModel(c.id);else{let u=P.map(g=>g.name).join(", ");p(`Model "${v.value}" not found.
146
146
  Available: ${u||"none"}`)}}else{let y=P.find(c=>c.id===r)?.name||r;p(r?`Current model: ${y}`:"No model selected. Using agent mode.")}return!0}case"agent":{if(!v.value)return E.length===0?(p("No agents available."),!0):(_e("agent"),!0);let y=v.value.toLowerCase(),c=E.find(u=>u.id.toLowerCase()===y||u.name.toLowerCase().includes(y));if(c)c.id!==l?ie(`Switched to agent: ${c.name} (new chat)`):p(`Switched to agent: ${c.name}`),d(c.id),a(void 0);else{let u=E.map(g=>g.name).join(", ");p(`Agent "${v.value}" not found.
147
- Available: ${u||"none"}`)}return!0}case"skills":{if(!v.value)return _e("skills"),!0;let y=v.value.toLowerCase();return(We.length?Promise.resolve(We):bt().catch(()=>[])).then(u=>{let g=u.find($=>$.id.toLowerCase()===y||$.name.toLowerCase().includes(y));p(g?`Skill: ${g.name}
147
+ Available: ${u||"none"}`)}return!0}case"skills":{if(!v.value)return _e("skills"),!0;let y=v.value.toLowerCase();return(We.length?Promise.resolve(We):bt().catch(()=>[])).then(u=>{let g=u.find(S=>S.id.toLowerCase()===y||S.name.toLowerCase().includes(y));p(g?`Skill: ${g.name}
148
148
  ${g.description}
149
149
  Provider: ${g.provider}
150
150
  Author: ${g.author.name}
151
- ID: ${g.id}`:`Skill "${v.value}" not found.`)}),!0}case"schedules":{if(!v.value)return _e("schedules"),!0;let y=v.value.toLowerCase();return(Ye.length?Promise.resolve(Ye):Ct().catch(()=>[])).then(u=>{let g=u.find($=>$.id.toLowerCase()===y||$.name.toLowerCase().includes(y));if(g){let $=N=>{if(N.type==="no-repeat")return"No repeat";let{interval:J}=N;switch(J.unit){case"minutes":return`Every ${J.every} min`;case"hours":return`Every ${J.every} hr`;case"days":return`Every ${J.every} day at ${String(J.time.hour).padStart(2,"0")}:${String(J.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${J.every} week`;case"months":return`Every ${J.every} month`;default:return"Unknown"}},k=g.nextRunAt?new Date(g.nextRunAt).toLocaleString():"-";p(`Schedule: ${g.name}
151
+ ID: ${g.id}`:`Skill "${v.value}" not found.`)}),!0}case"schedules":{if(!v.value)return _e("schedules"),!0;let y=v.value.toLowerCase();return(Ye.length?Promise.resolve(Ye):Ct().catch(()=>[])).then(u=>{let g=u.find(S=>S.id.toLowerCase()===y||S.name.toLowerCase().includes(y));if(g){let S=N=>{if(N.type==="no-repeat")return"No repeat";let{interval:J}=N;switch(J.unit){case"minutes":return`Every ${J.every} min`;case"hours":return`Every ${J.every} hr`;case"days":return`Every ${J.every} day at ${String(J.time.hour).padStart(2,"0")}:${String(J.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${J.every} week`;case"months":return`Every ${J.every} month`;default:return"Unknown"}},k=g.nextRunAt?new Date(g.nextRunAt).toLocaleString():"-";p(`Schedule: ${g.name}
152
152
  Agent: ${g.agent.name}
153
153
  Status: ${g.isActive?"Active":"Paused"}
154
- Repeat: ${$(g.config)}
154
+ Repeat: ${S(g.config)}
155
155
  Next Run: ${k}
156
- ID: ${g.id}`)}else p(`Schedule "${v.value}" not found.`)}),!0}case"connectors":{if(l){let c=I?.connectors||[];if(c.length===0)p("No agent connectors.");else{let u=c.map(g=>` - ${g.name}`).join(`
156
+ ID: ${g.id}`)}else p(`Schedule "${v.value}" not found.`)}),!0}case"connectors":{if(l){let c=$?.connectors||[];if(c.length===0)p("No agent connectors.");else{let u=c.map(g=>` - ${g.name}`).join(`
157
157
  `);p(`Agent connectors:
158
158
  ${u}`)}return!0}let y=R.filter(c=>b?.includes(c.id));if(y.length===0)p("No active connectors.");else{let c=y.map(u=>` - ${u.name}`).join(`
159
159
  `);p(`Active connectors:
160
- ${c}`)}return!0}case"capabilities":{if(l){let u=(I?.capabilities||[]).map(g=>ce.get(g)??g);return p(u.length>0?`Agent capabilities:
160
+ ${c}`)}return!0}case"capabilities":{if(l){let u=($?.capabilities||[]).map(g=>ce.get(g)??g);return p(u.length>0?`Agent capabilities:
161
161
  ${u.map(g=>` - ${g}`).join(`
162
- `)}`:"No agent capabilities."),!0}let y=[];return m&&y.push("Sandbox"),S&&y.push("Web Search"),V&&y.push("Image Generation"),ae&&y.push("Chart"),Se&&y.push("FileSystem"),p(y.length>0?`Active capabilities:
162
+ `)}`:"No agent capabilities."),!0}let y=[];return m&&y.push("Sandbox"),T&&y.push("Web Search"),V&&y.push("Image Generation"),ae&&y.push("Chart"),Se&&y.push("FileSystem"),p(y.length>0?`Active capabilities:
163
163
  ${y.map(c=>` - ${c}`).join(`
164
- `)}`:"No capabilities enabled."),!0}case"chats":return p(o?`Current chat: ${o}`:`Current chat: ${n.slice(0,8)}...`),!0;case"workspace":{if(!A)return p("Not authenticated."),!0;let y=new B;if(!v.value){try{let{workspaces:u}=await y.getWorkspaces(A.accessToken);if(u.length===0)p("No workspaces found.");else{let g=u.map($=>` ${$.id===A.workspaceId?"* ":" "}${$.name}
165
- ID: ${$.id}`);p(`Workspaces:
164
+ `)}`:"No capabilities enabled."),!0}case"chats":return p(n?`Current chat: ${n}`:`Current chat: ${o.slice(0,8)}...`),!0;case"workspace":{if(!A)return p("Not authenticated."),!0;let y=new B;if(!v.value){try{let{workspaces:u}=await y.getWorkspaces(A.accessToken);if(u.length===0)p("No workspaces found.");else{let g=u.map(S=>` ${S.id===A.workspaceId?"* ":" "}${S.name}
165
+ ID: ${S.id}`);p(`Workspaces:
166
166
  ${g.join(`
167
- `)}`)}}catch(u){p(`Failed to load workspaces: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let c=v.value;try{let{workspaces:u}=await y.getWorkspaces(A.accessToken),g=u.find(k=>k.id===c);if(!g)return p(`Workspace not found: ${c}`),!0;let{TokenStorage:$}=await import("./token-storage-JKKVPVG3.js");await $.saveWorkspaceId(c),p(`Switched to workspace: ${g.name}`),p("Please restart the chat to apply changes.")}catch(u){p(`Failed to switch workspace: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}case"budget":{if(!A)return p("Not authenticated."),!0;let y=new B;if(!v.value){try{let g=await y.getBudget(A.accessToken,A.workspaceId);g.budget===null?p("No budget set for this workspace."):p(`Current budget: $${g.budget}`)}catch(g){p(`Failed to get budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}let c=v.value.toLowerCase();if(c==="clear"||c==="null"){try{await y.updateBudget(A.accessToken,A.workspaceId,null),p("Budget cleared.")}catch(g){p(`Failed to clear budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}let u=parseFloat(c);if(isNaN(u)||u<0)return p("Invalid budget amount. Must be a positive number."),!0;try{await y.updateBudget(A.accessToken,A.workspaceId,c),p(`Budget set to: $${c}`)}catch(g){p(`Failed to set budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}case"usage":{if(!A)return p("Not authenticated."),!0;let y=new B;try{let c=[],u,g=0,$=10;do{let Ie=await y.getMonthlyUsages(A.accessToken,A.workspaceId,{nextKey:u,limit:20});if(c.push(...Ie.monthlyUsages),u=Ie.nextKey,g++,g>=$){p(`Warning: Showing first ${c.length} entries (pagination limit reached)`);break}}while(u);if(c.length===0)return p("No usage data found for this workspace."),!0;let k=0,N=0;for(let Ie of c)k+=parseFloat(Ie.totalCost),N+=Ie.operationCount;let J=[...c].toSorted((Ie,ut)=>parseFloat(ut.totalCost)-parseFloat(Ie.totalCost)),G=10,ue=J.slice(0,G),Ue=[`Total Cost: $${k.toFixed(2)}`,`Total Operations: ${N.toLocaleString()}`,`Users: ${c.length}`,"",`Top ${ue.length} Users by Cost:`,...ue.map(Ie=>` ${Ie.user.name}: $${parseFloat(Ie.totalCost).toFixed(2)} (${Ie.operationCount.toLocaleString()} ops)`)];c.length>G&&(Ue.push("",`... and ${c.length-G} more users`),Ue.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),p(Ue.join(`
168
- `))}catch(c){p(`Failed to get usage: ${c instanceof Error?c.message:"Unknown error"}`)}return!0}case"status":{let y=H.getCurrentProfileName(),c=r?P.find(k=>k.id===r)?.name||r:null,u=l?E.find(k=>k.id===l)?.name||l:null,g=b?R.filter(k=>b.includes(k.id)).map(k=>k.name):[],$=[];return m&&$.push("Sandbox"),S&&$.push("Web Search"),V&&$.push("Image Gen"),ae&&$.push("Chart"),Se&&$.push("FileSystem"),$e.getEmail().then(k=>{let N=[`Profile: ${y}${y!=="default"?" (non-default)":""}`,k?`Logged in as: ${k}`:"Not logged in",A?.workspaceId?`Workspace: ${A.workspaceId}`:null,_?`Chat ID: ${n}`:null,c?`Model: ${c}`:null,u?`Agent: ${u}`:null,`Connectors: ${g.length>0?g.join(", "):"none"}`,`Capabilities: ${$.length>0?$.join(", "):"none"}`].filter(Boolean);p(N.join(`
169
- `))}).catch(()=>{let k=[`Profile: ${y}`,"Not logged in",_?`Chat ID: ${n}`:null,c?`Model: ${c}`:null,u?`Agent: ${u}`:null,`Connectors: ${g.length>0?g.join(", "):"none"}`,`Capabilities: ${$.length>0?$.join(", "):"none"}`].filter(Boolean);p(k.join(`
170
- `))}),!0}case"profile":{let y=v.value?v.value.split(/\s+/).filter(Boolean):[];if(y.length===0)return _e("profile"),!0;let c=y[0]?.toLowerCase()||"list",u=y[1],g=y[2],$=H.getProfileNames(),k=H.getCurrentProfileName(),N=H.getOverrideProfile(),J=(G,ue=!1)=>{if(G)return G;if(ue&&$.length===1)return $[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(c==="list"){let G=[`Profiles (${$.length}):`];for(let ue of $){let Ue=ue===k?" (current)":"";G.push(` ${ue}${Ue}`)}return p(G.join(`
171
- `)),!0}if(c==="current")return p(`Current profile: ${k}`),!0;if(c==="show"){let G=J(u,!0),ue=ne.getAll(G),Ue=await $e.getAll(G),Ie=!!Ue?.accessToken,ut=ue.capabilities?Object.entries(ue.capabilities).filter(([,bo])=>bo).map(([bo])=>bo):[],Ls=ue.connectors?.defaults&&ue.connectors.defaults.length>0?ue.connectors.defaults.join(", "):"unset",Ds=[`Profile: ${G}${G===k?" (current)":""}`,`API URL: ${ue.apiUrl??"default"}`,`Hub URL: ${ue.hubUrl??"default"}`,`Model: ${ue.model?.default??"unset"}`,`Connectors: ${Ls}`,`Capabilities: ${ut.length>0?ut.join(", "):"none"}`,Ie?`Logged in as: ${Ue?.email??"unknown"}`:"Not logged in",Ie&&Ue?.workspaceId?`Workspace ID: ${Ue.workspaceId}`:null].filter(Boolean);return p(Ds.join(`
167
+ `)}`)}}catch(u){p(`Failed to load workspaces: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let c=v.value;try{let{workspaces:u}=await y.getWorkspaces(A.accessToken),g=u.find(k=>k.id===c);if(!g)return p(`Workspace not found: ${c}`),!0;let{TokenStorage:S}=await import("./token-storage-JKKVPVG3.js");await S.saveWorkspaceId(c),p(`Switched to workspace: ${g.name}`),p("Please restart the chat to apply changes.")}catch(u){p(`Failed to switch workspace: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}case"budget":{if(!A)return p("Not authenticated."),!0;let y=new B;if(!v.value){try{let g=await y.getBudget(A.accessToken,A.workspaceId);g.budget===null?p("No budget set for this workspace."):p(`Current budget: $${g.budget}`)}catch(g){p(`Failed to get budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}let c=v.value.toLowerCase();if(c==="clear"||c==="null"){try{await y.updateBudget(A.accessToken,A.workspaceId,null),p("Budget cleared.")}catch(g){p(`Failed to clear budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}let u=parseFloat(c);if(isNaN(u)||u<0)return p("Invalid budget amount. Must be a positive number."),!0;try{await y.updateBudget(A.accessToken,A.workspaceId,c),p(`Budget set to: $${c}`)}catch(g){p(`Failed to set budget: ${g instanceof Error?g.message:"Unknown error"}`)}return!0}case"usage":{if(!A)return p("Not authenticated."),!0;let y=new B;try{let c=[],u,g=0,S=10;do{let Ie=await y.getMonthlyUsages(A.accessToken,A.workspaceId,{nextKey:u,limit:20});if(c.push(...Ie.monthlyUsages),u=Ie.nextKey,g++,g>=S){p(`Warning: Showing first ${c.length} entries (pagination limit reached)`);break}}while(u);if(c.length===0)return p("No usage data found for this workspace."),!0;let k=0,N=0;for(let Ie of c)k+=parseFloat(Ie.totalCost),N+=Ie.operationCount;let J=[...c].toSorted((Ie,ut)=>parseFloat(ut.totalCost)-parseFloat(Ie.totalCost)),G=10,ue=J.slice(0,G),Ue=[`Total Cost: $${k.toFixed(2)}`,`Total Operations: ${N.toLocaleString()}`,`Users: ${c.length}`,"",`Top ${ue.length} Users by Cost:`,...ue.map(Ie=>` ${Ie.user.name}: $${parseFloat(Ie.totalCost).toFixed(2)} (${Ie.operationCount.toLocaleString()} ops)`)];c.length>G&&(Ue.push("",`... and ${c.length-G} more users`),Ue.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),p(Ue.join(`
168
+ `))}catch(c){p(`Failed to get usage: ${c instanceof Error?c.message:"Unknown error"}`)}return!0}case"status":{let y=H.getCurrentProfileName(),c=r?P.find(k=>k.id===r)?.name||r:null,u=l?E.find(k=>k.id===l)?.name||l:null,g=b?R.filter(k=>b.includes(k.id)).map(k=>k.name):[],S=[];return m&&S.push("Sandbox"),T&&S.push("Web Search"),V&&S.push("Image Gen"),ae&&S.push("Chart"),Se&&S.push("FileSystem"),$e.getEmail().then(k=>{let N=[`Profile: ${y}${y!=="default"?" (non-default)":""}`,k?`Logged in as: ${k}`:"Not logged in",A?.workspaceId?`Workspace: ${A.workspaceId}`:null,_?`Chat ID: ${o}`:null,c?`Model: ${c}`:null,u?`Agent: ${u}`:null,`Connectors: ${g.length>0?g.join(", "):"none"}`,`Capabilities: ${S.length>0?S.join(", "):"none"}`].filter(Boolean);p(N.join(`
169
+ `))}).catch(()=>{let k=[`Profile: ${y}`,"Not logged in",_?`Chat ID: ${o}`:null,c?`Model: ${c}`:null,u?`Agent: ${u}`:null,`Connectors: ${g.length>0?g.join(", "):"none"}`,`Capabilities: ${S.length>0?S.join(", "):"none"}`].filter(Boolean);p(k.join(`
170
+ `))}),!0}case"profile":{let y=v.value?v.value.split(/\s+/).filter(Boolean):[];if(y.length===0)return _e("profile"),!0;let c=y[0]?.toLowerCase()||"list",u=y[1],g=y[2],S=H.getProfileNames(),k=H.getCurrentProfileName(),N=H.getOverrideProfile(),J=(G,ue=!1)=>{if(G)return G;if(ue&&S.length===1)return S[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(c==="list"){let G=[`Profiles (${S.length}):`];for(let ue of S){let Ue=ue===k?" (current)":"";G.push(` ${ue}${Ue}`)}return p(G.join(`
171
+ `)),!0}if(c==="current")return p(`Current profile: ${k}`),!0;if(c==="show"){let G=J(u,!0),ue=ne.getAll(G),Ue=await $e.getAll(G),Ie=!!Ue?.accessToken,ut=ue.capabilities?Object.entries(ue.capabilities).filter(([,$o])=>$o).map(([$o])=>$o):[],Gs=ue.connectors?.defaults&&ue.connectors.defaults.length>0?ue.connectors.defaults.join(", "):"unset",Hs=[`Profile: ${G}${G===k?" (current)":""}`,`API URL: ${ue.apiUrl??"default"}`,`Hub URL: ${ue.hubUrl??"default"}`,`Model: ${ue.model?.default??"unset"}`,`Connectors: ${Gs}`,`Capabilities: ${ut.length>0?ut.join(", "):"none"}`,Ie?`Logged in as: ${Ue?.email??"unknown"}`:"Not logged in",Ie&&Ue?.workspaceId?`Workspace ID: ${Ue.workspaceId}`:null].filter(Boolean);return p(Hs.join(`
172
172
  `)),!0}if(c==="create"){let G=u||H.DEFAULT_PROFILE;return H.createProfile(G),p(`Profile created: ${G}`),!0}if(c==="use"||c==="switch"){let G=J(u,!0);return H.setOverrideProfile(G),H.setCurrentProfile(G),ye(G),await Ze(),ie(`Switched to profile: ${G} (new chat)`),!0}if(c==="delete"||c==="remove"||c==="rm"){let G=J(u,!0),ue=G===k,Ue=H.deleteProfile(G),Ie=`Profile deleted: ${G}`;if(ue)H.setOverrideProfile(Ue.currentProfile),ye(Ue.currentProfile),await Ze(),ie(`${Ie}
173
173
  Switched to profile: ${Ue.currentProfile} (new chat)`);else if(N===G){let ut=H.getCurrentProfileName();H.setOverrideProfile(ut),ye(ut),await Ze(),ie(`${Ie}
174
- Switched to profile: ${ut} (new chat)`)}else p(Ie);return!0}if(c==="rename"||c==="move"||c==="mv"){let G=J(u,!0);if(!g)throw new Error("New profile name is required.");let ue=H.renameProfile(G,g);return p(`Profile renamed: ${G} -> ${g}`),N===G?(H.setOverrideProfile(g),ye(g)):ue.currentProfile===g&&ye(g),!0}if(c==="clone"||c==="copy"){let G=J(u,!0);if(!g)throw new Error("Target profile name is required.");let ue=ne.getAll(G);return H.createProfile(g),ne.setAll(ue,g),await $e.clear(g),p(`Profile cloned: ${G} -> ${g}`),!0}p(`Unknown profile command: ${c}`)}catch(G){let ue=G instanceof Error?G.message:"Unknown error";p(`Profile error: ${ue}`)}return!0}case"open-in-browser":{let y=Me().hubUrl.replace(/\/$/,""),u=_||W.some(k=>k.role!=="system")?`/chat/${n}`:"/chat/new",g=l?`?agentId=${encodeURIComponent(l)}`:"",$=`${y}${u}${g}`;try{await Vn($),p(`Opened in browser: ${$}`)}catch(k){p(`Failed to open browser: ${k instanceof Error?k.message:"Unknown error"}
175
- URL: ${$}`)}return!0}case"share":{if(!A)return p("Not authenticated."),!0;if(!(_||W.some(c=>c.role!=="system")))return p("No conversation to share. Start a chat first."),!0;try{let u=await new B().createChatShare(A.accessToken,A.workspaceId,n,"public"),$=`${Me().hubUrl.replace(/\/$/,"")}/share/${u.id}`;p(`Share link: ${$}`)}catch(c){p(`Failed to create share link: ${c instanceof Error?c.message:"Unknown error"}`)}return!0}case"delete":return A?_?(xt(!0),p("Delete this chat? (y/N)"),!0):(p("No chat to delete."),!0):(p("Not authenticated."),!0);case"quit":return Q(),!0;case"unknown":return p(`Unknown command: ${v.input}
176
- Type /help for available commands.`),!0;default:return!1}},[p,P,E,R,We,Ye,r,l,b,m,S,V,ae,Se,n,o,Q,_e,ie,ce,I,_,W,bt,Ct,L,a,d,x,a,ye,Ze]),qt=nt(v=>{if(mt.current=!1,ct){(v===""||v.startsWith("/"))&&(t(v),v.startsWith("/")&&xt(!1));return}if(t(v),kt(v),Ve!==null&&Xe(null),f&&(w(null),oe([])),v.startsWith("/")&&!v.includes(" ")){let y=qn(v);fe(y),F(0),D(y.length>0)}else D(!1),fe([])},[f,Ve,ct,t]),Nt=nt((v,y=!1)=>{if(v>=0&&v<z.length){let c=z[v];D(!1),fe([]),c.name==="model"?(t("/model "),_e("model")):c.name==="agent"?(t("/agent "),_e("agent")):c.name==="skills"?(t("/skills "),_e("skills")):c.name==="schedules"?(t("/schedules "),_e("schedules")):c.name==="connectors"?(t("/connectors "),_e("connectors")):c.name==="capabilities"?(t("/capabilities "),_e("capabilities")):c.name==="chats"?(t("/chats "),_e("chats")):c.name==="profile"?(t("/profile "),_e("profile")):y?(t(""),$t({type:c.name})):t(`/${c.name}`)}},[z,_e,t,$t]),zt=nt(async v=>{mt.current=!1;let y=v.trim();if(!y||ct)return;if(f==="model"&&T.length>0){let u=T[U];u&&(l?ie(`Switched to model: ${u.name} (new chat)`):p(`Switched to model: ${u.name}`),a(u.id),d(void 0),x(null)),w(null),oe([]),t("");return}if(f==="agent"&&T.length>0){let u=T[U];u&&(u.id!==l?ie(`Switched to agent: ${u.name} (new chat)`):p(`Switched to agent: ${u.name}`),d(u.id),a(void 0)),w(null),oe([]),t("");return}if(f==="skills"&&T.length>0){let u=T[U];if(u){let g=We.find($=>$.id===u.id);g&&p(`Skill: ${g.name}
174
+ Switched to profile: ${ut} (new chat)`)}else p(Ie);return!0}if(c==="rename"||c==="move"||c==="mv"){let G=J(u,!0);if(!g)throw new Error("New profile name is required.");let ue=H.renameProfile(G,g);return p(`Profile renamed: ${G} -> ${g}`),N===G?(H.setOverrideProfile(g),ye(g)):ue.currentProfile===g&&ye(g),!0}if(c==="clone"||c==="copy"){let G=J(u,!0);if(!g)throw new Error("Target profile name is required.");let ue=ne.getAll(G);return H.createProfile(g),ne.setAll(ue,g),await $e.clear(g),p(`Profile cloned: ${G} -> ${g}`),!0}p(`Unknown profile command: ${c}`)}catch(G){let ue=G instanceof Error?G.message:"Unknown error";p(`Profile error: ${ue}`)}return!0}case"open-in-browser":{let y=Me().hubUrl.replace(/\/$/,""),u=_||W.some(k=>k.role!=="system")?`/chat/${o}`:"/chat/new",g=l?`?agentId=${encodeURIComponent(l)}`:"",S=`${y}${u}${g}`;try{await Yn(S),p(`Opened in browser: ${S}`)}catch(k){p(`Failed to open browser: ${k instanceof Error?k.message:"Unknown error"}
175
+ URL: ${S}`)}return!0}case"share":{if(!A)return p("Not authenticated."),!0;if(!(_||W.some(c=>c.role!=="system")))return p("No conversation to share. Start a chat first."),!0;try{let u=await new B().createChatShare(A.accessToken,A.workspaceId,o,"public"),S=`${Me().hubUrl.replace(/\/$/,"")}/share/${u.id}`;p(`Share link: ${S}`)}catch(c){p(`Failed to create share link: ${c instanceof Error?c.message:"Unknown error"}`)}return!0}case"delete":return A?_?(xt(!0),p("Delete this chat? (y/N)"),!0):(p("No chat to delete."),!0):(p("Not authenticated."),!0);case"quit":return Q(),!0;case"unknown":return p(`Unknown command: ${v.input}
176
+ Type /help for available commands.`),!0;default:return!1}},[p,P,E,R,We,Ye,r,l,b,m,T,V,ae,Se,o,n,Q,_e,ie,ce,$,_,W,bt,Ct,L,a,d,x,a,ye,Ze]),Yt=nt(v=>{if(mt.current=!1,ct){(v===""||v.startsWith("/"))&&(t(v),v.startsWith("/")&&xt(!1));return}if(t(v),kt(v),Ve!==null&&Xe(null),f&&(w(null),oe([])),v.startsWith("/")&&!v.includes(" ")){let y=Zn(v);fe(y),F(0),D(y.length>0)}else D(!1),fe([])},[f,Ve,ct,t]),Et=nt((v,y=!1)=>{if(v>=0&&v<z.length){let c=z[v];D(!1),fe([]),c.name==="model"?(t("/model "),_e("model")):c.name==="agent"?(t("/agent "),_e("agent")):c.name==="skills"?(t("/skills "),_e("skills")):c.name==="schedules"?(t("/schedules "),_e("schedules")):c.name==="connectors"?(t("/connectors "),_e("connectors")):c.name==="capabilities"?(t("/capabilities "),_e("capabilities")):c.name==="chats"?(t("/chats "),_e("chats")):c.name==="profile"?(t("/profile "),_e("profile")):y?(t(""),$t({type:c.name})):t(`/${c.name}`)}},[z,_e,t,$t]),Xt=nt(async v=>{mt.current=!1;let y=v.trim();if(!y||ct)return;if(f==="model"&&I.length>0){let u=I[U];u&&(l?ie(`Switched to model: ${u.name} (new chat)`):p(`Switched to model: ${u.name}`),a(u.id),d(void 0),x(null)),w(null),oe([]),t("");return}if(f==="agent"&&I.length>0){let u=I[U];u&&(u.id!==l?ie(`Switched to agent: ${u.name} (new chat)`):p(`Switched to agent: ${u.name}`),d(u.id),a(void 0)),w(null),oe([]),t("");return}if(f==="skills"&&I.length>0){let u=I[U];if(u){let g=We.find(S=>S.id===u.id);g&&p(`Skill: ${g.name}
177
177
  ${g.description}
178
178
  Provider: ${g.provider}
179
179
  Author: ${g.author.name}
180
- ID: ${g.id}`)}w(null),oe([]),t("");return}if(f==="schedules"&&T.length>0){let u=T[U];if(u){let g=Ye.find($=>$.id===u.id);if(g){let $=N=>{if(N.type==="no-repeat")return"No repeat";let{interval:J}=N;switch(J.unit){case"minutes":return`Every ${J.every} min`;case"hours":return`Every ${J.every} hr`;case"days":return`Every ${J.every} day at ${String(J.time.hour).padStart(2,"0")}:${String(J.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${J.every} week`;case"months":return`Every ${J.every} month`;default:return"Unknown"}},k=g.nextRunAt?new Date(g.nextRunAt).toLocaleString():"-";p(`Schedule: ${g.name}
180
+ ID: ${g.id}`)}w(null),oe([]),t("");return}if(f==="schedules"&&I.length>0){let u=I[U];if(u){let g=Ye.find(S=>S.id===u.id);if(g){let S=N=>{if(N.type==="no-repeat")return"No repeat";let{interval:J}=N;switch(J.unit){case"minutes":return`Every ${J.every} min`;case"hours":return`Every ${J.every} hr`;case"days":return`Every ${J.every} day at ${String(J.time.hour).padStart(2,"0")}:${String(J.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${J.every} week`;case"months":return`Every ${J.every} month`;default:return"Unknown"}},k=g.nextRunAt?new Date(g.nextRunAt).toLocaleString():"-";p(`Schedule: ${g.name}
181
181
  Agent: ${g.agent.name}
182
182
  Status: ${g.isActive?"Active":"Paused"}
183
- Repeat: ${$(g.config)}
183
+ Repeat: ${S(g.config)}
184
184
  Next Run: ${k}
185
- ID: ${g.id}`)}}w(null),oe([]),t("");return}if(f==="connectors"){let u=Array.from(rt);C(u.length>0?u:void 0),ne.setDefaultConnectorIds(u);let g=R.filter($=>rt.has($.id)).map($=>$.name);p(g.length>0?`Active connectors: ${g.join(", ")}`:"All connectors disabled."),w(null),oe([]),t("");return}if(f==="capabilities"){let u=Re.has("sandbox"),g=Re.has("webSearch"),$=Re.has("imageGeneration"),k=Re.has("chart"),N=Re.has("fileSystem");h(u),O(g),Z($),Y(k),j(N),ne.setCapabilities({sandbox:u,webSearch:g,imageGeneration:$,chart:k}),ne.setLocalTools({fileSystem:N});let J=[];u&&J.push("Sandbox"),g&&J.push("Web Search"),$&&J.push("Image Generation"),k&&J.push("Chart"),N&&J.push("FileSystem"),p(J.length>0?`Active capabilities: ${J.join(", ")}`:"All capabilities disabled."),w(null),oe([]),t("");return}if(f==="profile"&&T.length>0){let u=T[U];if(u){let g=H.getCurrentProfileName();u.id!==g?(H.setOverrideProfile(u.id),H.setCurrentProfile(u.id),ye(u.id),Ze(),ie(`Switched to profile: ${u.name}`)):p(`Already using profile: ${u.name}`)}w(null),oe([]),t("");return}if(se&&z.length>0){Nt(Te,!0);return}Xe(null),kt(""),xo(u=>u.length>0&&u[u.length-1]===y?u:[...u,y]);let c=zn(y);if(c){await $t(c),t(""),D(!1);return}if(M){p("Please wait for file uploads to complete.");return}t(""),D(!1),ke(y)},[ke,$t,se,z,Te,Nt,f,T,U,rt,Re,R,We,Ye,p,t,l,ie,a,d,x,C,h,O,Z,Y,j,M,ye,Ze,ct,A,_,n]);return $r((v,y)=>{if(y.ctrl&&v==="c"){if(e.length>0){qt(""),mt.current=!0,p("Press Ctrl+C again to exit.");return}if(mt.current){Q();return}Q();return}if(y.ctrl&&v==="o"){q(c=>!c);return}if(ct){if(y.escape||y.return||v==="n"||v==="N"){xt(!1),t(""),p("Chat deletion cancelled.");return}if(v==="y"||v==="Y"){xt(!1),t(""),A&&_&&new B().deleteChat(A.accessToken,A.workspaceId,n).then(()=>{ie("Chat deleted. Started a new chat.")}).catch(u=>{p(`Failed to delete chat: ${u.message||"Unknown error"}`)});return}return}if(f&&T.length>0){if(y.upArrow){Ce(c=>c<=0?T.length-1:c-1);return}if(y.downArrow){Ce(c=>c>=T.length-1?0:c+1);return}if(y.escape){w(null),oe([]),t("");return}if(y.return){if(f==="model"){let c=T[U];c&&(l?ie(`Switched to model: ${c.name} (new chat)`):p(`Switched to model: ${c.name}`),a(c.id),d(void 0),x(null),ne.setDefaultModel(c.id))}else if(f==="agent"){let c=T[U];c&&(c.id!==l?ie(`Switched to agent: ${c.name} (new chat)`):p(`Switched to agent: ${c.name}`),d(c.id),a(void 0))}else if(f==="skills"){let c=T[U];if(c){let u=We.find(g=>g.id===c.id);u&&p(`Skill: ${u.name}
185
+ ID: ${g.id}`)}}w(null),oe([]),t("");return}if(f==="connectors"){let u=Array.from(rt);C(u.length>0?u:void 0),ne.setDefaultConnectorIds(u);let g=R.filter(S=>rt.has(S.id)).map(S=>S.name);p(g.length>0?`Active connectors: ${g.join(", ")}`:"All connectors disabled."),w(null),oe([]),t("");return}if(f==="capabilities"){let u=Re.has("sandbox"),g=Re.has("webSearch"),S=Re.has("imageGeneration"),k=Re.has("chart"),N=Re.has("fileSystem");h(u),O(g),Z(S),Y(k),j(N),ne.setCapabilities({sandbox:u,webSearch:g,imageGeneration:S,chart:k}),ne.setLocalTools({fileSystem:N});let J=[];u&&J.push("Sandbox"),g&&J.push("Web Search"),S&&J.push("Image Generation"),k&&J.push("Chart"),N&&J.push("FileSystem"),p(J.length>0?`Active capabilities: ${J.join(", ")}`:"All capabilities disabled."),w(null),oe([]),t("");return}if(f==="profile"&&I.length>0){let u=I[U];if(u){let g=H.getCurrentProfileName();u.id!==g?(H.setOverrideProfile(u.id),H.setCurrentProfile(u.id),ye(u.id),Ze(),ie(`Switched to profile: ${u.name}`)):p(`Already using profile: ${u.name}`)}w(null),oe([]),t("");return}if(se&&z.length>0){Et(Te,!0);return}Xe(null),kt(""),Co(u=>u.length>0&&u[u.length-1]===y?u:[...u,y]);let c=Qn(y);if(c){await $t(c),t(""),D(!1);return}if(M){p("Please wait for file uploads to complete.");return}t(""),D(!1),ke(y)},[ke,$t,se,z,Te,Et,f,I,U,rt,Re,R,We,Ye,p,t,l,ie,a,d,x,C,h,O,Z,Y,j,M,ye,Ze,ct,A,_,o]);return Dr((v,y)=>{if(y.ctrl&&v==="c"){if(e.length>0){Yt(""),mt.current=!0,p("Press Ctrl+C again to exit.");return}if(mt.current){Q();return}Q();return}if(y.ctrl&&v==="o"){q(c=>!c);return}if(ct){if(y.escape||y.return||v==="n"||v==="N"){xt(!1),t(""),p("Chat deletion cancelled.");return}if(v==="y"||v==="Y"){xt(!1),t(""),A&&_&&new B().deleteChat(A.accessToken,A.workspaceId,o).then(()=>{ie("Chat deleted. Started a new chat.")}).catch(u=>{p(`Failed to delete chat: ${u.message||"Unknown error"}`)});return}return}if(f&&I.length>0){if(y.upArrow){Ce(c=>c<=0?I.length-1:c-1);return}if(y.downArrow){Ce(c=>c>=I.length-1?0:c+1);return}if(y.escape){w(null),oe([]),t("");return}if(y.return){if(f==="model"){let c=I[U];c&&(l?ie(`Switched to model: ${c.name} (new chat)`):p(`Switched to model: ${c.name}`),a(c.id),d(void 0),x(null),ne.setDefaultModel(c.id))}else if(f==="agent"){let c=I[U];c&&(c.id!==l?ie(`Switched to agent: ${c.name} (new chat)`):p(`Switched to agent: ${c.name}`),d(c.id),a(void 0))}else if(f==="skills"){let c=I[U];if(c){let u=We.find(g=>g.id===c.id);u&&p(`Skill: ${u.name}
186
186
  ${u.description}
187
187
  Provider: ${u.provider}
188
188
  Author: ${u.author.name}
189
- ID: ${u.id}`)}}else if(f==="schedules"){let c=T[U];if(c){let u=Ye.find(g=>g.id===c.id);if(u){let g=k=>{if(k.type==="no-repeat")return"No repeat";let{interval:N}=k;switch(N.unit){case"minutes":return`Every ${N.every} min`;case"hours":return`Every ${N.every} hr`;case"days":return`Every ${N.every} day at ${String(N.time.hour).padStart(2,"0")}:${String(N.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${N.every} week`;case"months":return`Every ${N.every} month`;default:return"Unknown"}},$=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";p(`Schedule: ${u.name}
189
+ ID: ${u.id}`)}}else if(f==="schedules"){let c=I[U];if(c){let u=Ye.find(g=>g.id===c.id);if(u){let g=k=>{if(k.type==="no-repeat")return"No repeat";let{interval:N}=k;switch(N.unit){case"minutes":return`Every ${N.every} min`;case"hours":return`Every ${N.every} hr`;case"days":return`Every ${N.every} day at ${String(N.time.hour).padStart(2,"0")}:${String(N.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${N.every} week`;case"months":return`Every ${N.every} month`;default:return"Unknown"}},S=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";p(`Schedule: ${u.name}
190
190
  Agent: ${u.agent.name}
191
191
  Status: ${u.isActive?"Active":"Paused"}
192
192
  Repeat: ${g(u.config)}
193
- Next Run: ${$}
194
- ID: ${u.id}`)}}}else if(f==="connectors"){let c=Array.from(rt);C(c.length>0?c:void 0),ne.setDefaultConnectorIds(c);let u=R.filter(g=>rt.has(g.id)).map(g=>g.name);p(u.length>0?`Active connectors: ${u.join(", ")}`:"All connectors disabled.")}else if(f==="capabilities"){let c=Re.has("sandbox"),u=Re.has("webSearch"),g=Re.has("imageGeneration"),$=Re.has("chart"),k=Re.has("fileSystem");h(c),O(u),Z(g),Y($),j(k),ne.setCapabilities({sandbox:c,webSearch:u,imageGeneration:g,chart:$}),ne.setLocalTools({fileSystem:k});let N=[];c&&N.push("Sandbox"),u&&N.push("Web Search"),g&&N.push("Image Generation"),$&&N.push("Chart"),k&&N.push("FileSystem"),p(N.length>0?`Active capabilities: ${N.join(", ")}`:"All capabilities disabled.")}else if(f==="chats"){let c=T[U];if(c){let u=ko.find(g=>g.id===c.id);u&&A&&(s(u.id),i(u.title||void 0),he(!0),new B().getMessages(A.accessToken,A.workspaceId,u.id,20).then(({messages:$})=>{let k=$.filter(N=>N.role==="user"||N.role==="assistant").map(N=>({role:N.role,content:ht(N.parts,!1),parts:N.parts})).filter(N=>N.content).toReversed();L(k),p(`Switched to: ${u.title||"Untitled"}`)}).catch(()=>{p("Failed to load chat messages.")}))}}else if(f==="profile"){let c=T[U];if(c){let u=H.getCurrentProfileName();c.id!==u?(H.setOverrideProfile(c.id),H.setCurrentProfile(c.id),ye(c.id),Ze(),ie(`Switched to profile: ${c.name}`)):p(`Already using profile: ${c.name}`)}}w(null),oe([]),t("");return}if(v===" "&&(f==="connectors"||f==="capabilities")){let c=T[U];c&&(f==="connectors"?it:at)(g=>{let $=new Set(g);return $.has(c.id)?$.delete(c.id):$.add(c.id),$});return}if(v==="a"&&(f==="connectors"||f==="capabilities")){(f==="connectors"?it:at)(new Set(T.map(u=>u.id)));return}if(v==="n"&&(f==="connectors"||f==="capabilities")){(f==="connectors"?it:at)(new Set);return}return}if(se&&z.length>0){if(y.upArrow){F(c=>c<=0?z.length-1:c-1);return}if(y.downArrow){F(c=>c>=z.length-1?0:c+1);return}if(y.escape){D(!1),fe([]);return}if(y.tab){Nt(Te);return}}if(y.upArrow){if(e.includes(`
193
+ Next Run: ${S}
194
+ ID: ${u.id}`)}}}else if(f==="connectors"){let c=Array.from(rt);C(c.length>0?c:void 0),ne.setDefaultConnectorIds(c);let u=R.filter(g=>rt.has(g.id)).map(g=>g.name);p(u.length>0?`Active connectors: ${u.join(", ")}`:"All connectors disabled.")}else if(f==="capabilities"){let c=Re.has("sandbox"),u=Re.has("webSearch"),g=Re.has("imageGeneration"),S=Re.has("chart"),k=Re.has("fileSystem");h(c),O(u),Z(g),Y(S),j(k),ne.setCapabilities({sandbox:c,webSearch:u,imageGeneration:g,chart:S}),ne.setLocalTools({fileSystem:k});let N=[];c&&N.push("Sandbox"),u&&N.push("Web Search"),g&&N.push("Image Generation"),S&&N.push("Chart"),k&&N.push("FileSystem"),p(N.length>0?`Active capabilities: ${N.join(", ")}`:"All capabilities disabled.")}else if(f==="chats"){let c=I[U];if(c){let u=bo.find(g=>g.id===c.id);u&&A&&(s(u.id),i(u.title||void 0),he(!0),new B().getMessages(A.accessToken,A.workspaceId,u.id,20).then(({messages:S})=>{let k=S.filter(N=>N.role==="user"||N.role==="assistant").map(N=>({role:N.role,content:ht(N.parts,!1),parts:N.parts})).filter(N=>N.content).toReversed();L(k),p(`Switched to: ${u.title||"Untitled"}`)}).catch(()=>{p("Failed to load chat messages.")}))}}else if(f==="profile"){let c=I[U];if(c){let u=H.getCurrentProfileName();c.id!==u?(H.setOverrideProfile(c.id),H.setCurrentProfile(c.id),ye(c.id),Ze(),ie(`Switched to profile: ${c.name}`)):p(`Already using profile: ${c.name}`)}}w(null),oe([]),t("");return}if(v===" "&&(f==="connectors"||f==="capabilities")){let c=I[U];c&&(f==="connectors"?it:at)(g=>{let S=new Set(g);return S.has(c.id)?S.delete(c.id):S.add(c.id),S});return}if(v==="a"&&(f==="connectors"||f==="capabilities")){(f==="connectors"?it:at)(new Set(I.map(u=>u.id)));return}if(v==="n"&&(f==="connectors"||f==="capabilities")){(f==="connectors"?it:at)(new Set);return}return}if(se&&z.length>0){if(y.upArrow){F(c=>c<=0?z.length-1:c-1);return}if(y.downArrow){F(c=>c>=z.length-1?0:c+1);return}if(y.escape){D(!1),fe([]);return}if(y.tab){Et(Te);return}}if(y.upArrow){if(e.includes(`
195
195
  `)||lt.length===0)return;if(Ve===null){kt(e);let u=lt.length-1;Xe(u),t(lt[u]);return}let c=Math.max(0,Ve-1);Xe(c),t(lt[c]);return}if(y.downArrow){if(e.includes(`
196
- `)||Ve===null)return;if(Ve>=lt.length-1){Xe(null),t(Kt);return}let c=Ve+1;Xe(c),t(lt[c])}}),{suggestions:z,suggestionIndex:Te,showSuggestions:se,argMode:f,argItems:T,argIndex:U,selectedConnectorIds:rt,selectedCapabilities:Re,deleteConfirmMode:ct,handleInputChange:qt,handleSubmit:zt}}import{useCallback as Bt,useRef as Tr,useState as Ir}from"react";function Zn({credentials:e,currentModel:t,modelProviders:n,onUploadSuccess:s,onUploadError:o}){let[i,r]=Ir([]),a=Tr(0),l=Bt(h=>{if(!(!Array.isArray(n)||n.length===0)){for(let S of n)if(S.models.some(V=>V.id===h))return S.id;return n[0]?.id}},[n]),d=Bt(async h=>{if(!e){o?.(h.filename,"Not logged in");return}if(!Array.isArray(n)||n.length===0){o?.(h.filename,"Model providers not loaded yet. Please wait and try again.");return}let S=t?l(t):n[0]?.id;if(!S){o?.(h.filename,"No model provider available");return}let O=`file-${++a.current}`;r(V=>[...V,{id:O,filename:h.filename,mimeType:h.mimeType,status:"uploading"}]);try{let Z=await new B().uploadFile(e.accessToken,e.workspaceId,h,S);r(ae=>ae.map(Y=>Y.id===O?{...Y,status:"uploaded",fileId:Z.id}:Y)),s?.(h.filename)}catch(V){let Z=V instanceof Error?V.message:"Upload failed";r(ae=>ae.map(Y=>Y.id===O?{...Y,status:"error",error:Z}:Y)),o?.(h.filename,Z)}},[e,t,l,n,s,o]),I=Bt(h=>{r(S=>S.filter(O=>O.id!==h))},[]),x=Bt(()=>{r([])},[]),b=Bt(()=>i.filter(h=>h.status==="uploaded"&&h.fileId).map(h=>h.fileId),[i]),C=i.some(h=>h.status==="uploading"),m=i.length>0;return{pendingFiles:i,addFile:d,removeFile:I,clearFiles:x,getUploadedFileIds:b,hasUploadingFiles:C,hasFiles:m}}import{jsx as X,jsxs as de}from"react/jsx-runtime";var Pr=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],Ar=[Uo,Uo,Ro,Ro,gt,gt,gt,gt],es=Pr.map((e,t)=>`${Ar[t]??gt}${e}${re}`).join(`
197
- `),Nr=`${gt}EntryDesk${re}`,Er=500;function _r(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 Lr(e){let t=_r(e);return Math.max(...t.split(`
198
- `).map(n=>n.length))}function Dr(e){let t=Lr(es);return e>=t?es:Nr}function ts({agentId:e,model:t,message:n,chatId:s,chatTitle:o,connectorIds:i,enableSandbox:r=!0,enableWebSearch:a=!1,enableImageGeneration:l=!1,enableChart:d=!1,enableFileSystem:I=!0}){let x=process.stdout.columns??80,b=Dr(x),C=Qn(null),m=Ln(s,o),{state:h,setState:S,messages:O,setMessages:V,input:Z,setInput:ae,chatId:Y,setChatId:Se,currentChatTitle:j,setCurrentChatTitle:P,hasPersistedChat:E,setHasPersistedChat:R,credentials:W,setCredentials:_,currentResponse:he,setCurrentResponse:L,fullOutput:p,setFullOutput:ie,addSystemMessage:ke,startNewChat:q}=m,{credentials:A}=On(S);uo(()=>{A&&!W&&_(A)},[A,W,_]);let{availableConnectors:te,availableModels:ee,availableAgents:me,modelProviders:ce,loading:M}=Rn(W),{currentModel:Q,setCurrentModel:z,currentAgentId:fe,setCurrentAgentId:Te,activeConnectorIds:F,setActiveConnectorIds:se}=Hn(t,e,i),D=Qn(!1);uo(()=>{if(!D.current){if(D.current=!0,!t&&!e){let k=ne.getDefaultModel();k&&z(k)}if(!i&&!e){let k=ne.getDefaultConnectorIds();k&&se(k.length>0?k:void 0)}}},[t,e,i,z,se]);let{currentAgentDetails:f}=Gn(fe,W),{sandbox:w,setSandbox:T,webSearch:oe,setWebSearch:U,imageGeneration:Ce,setImageGeneration:rt,chart:it,setChart:Re,fileSystem:at,setFileSystem:ko,capabilityLabelMap:Ht}=Jn(r,a,l,d,I),{pendingFiles:We,addFile:wt,removeFile:Ye,clearFiles:Vt,getUploadedFileIds:lt,hasUploadingFiles:xo,hasFiles:Ve}=Zn({credentials:W,currentModel:Q,modelProviders:ce,onUploadSuccess:k=>{ke(`\u2713 Attached: ${k}`)},onUploadError:(k,N)=>{ke(`\u2717 Failed to upload ${k}: ${N}`)}}),{sendMessage:Xe}=Bn({chatId:Y,credentials:W,currentAgentId:fe,currentModel:Q,activeConnectorIds:F,sandbox:w,webSearch:oe,imageGeneration:Ce,chart:it,localTools:at,fullOutput:p,setMessages:V,setState:S,setCurrentResponse:L,setCredentials:_,setHasPersistedChat:R,getFileIds:lt,clearFiles:Vt}),Kt=Mo(k=>{q(k),L("")},[q]),[kt,mt]=vr(!1),ct=Mo(async k=>{let N=k.text.trim(),J=io(N);if(/^https?:\/\//.test(J))return;if(await An(N)&&Pn(J)){let ue=await Nn(N);ue&&(k.preventDefault(),await wt(ue))}},[wt]),xt=Mo(async()=>{if(!(kt||h.status!=="ready")){if(M||ce.length===0){ke("Please wait for resources to load before pasting images.");return}ke("Reading clipboard..."),mt(!0);try{let k=await vn();if(k){let N=`clipboard-${Date.now()}.png`;ke(`Uploading: ${N} (${Math.round(k.buffer.length/1024)}KB)`),await wt({buffer:k.buffer,filename:N,mimeType:k.mime})}else ke("No image found in clipboard. Copy an image first.")}catch(k){let N=k instanceof Error?k.message:"Failed to read clipboard";ke(`Clipboard error: ${N}`)}finally{mt(!1)}}},[wt,ke,kt,h.status,M,ce.length]),{suggestions:bt,suggestionIndex:Ct,showSuggestions:_e,argMode:ye,argItems:Ze,argIndex:$t,selectedConnectorIds:qt,selectedCapabilities:Nt,deleteConfirmMode:zt,handleInputChange:v,handleSubmit:y}=Xn({input:Z,setInput:ae,chatId:Y,setChatId:Se,currentChatTitle:j,setCurrentChatTitle:P,currentModel:Q,setCurrentModel:z,currentAgentId:fe,setCurrentAgentId:Te,currentAgentDetails:f,setCurrentAgentDetails:()=>{},activeConnectorIds:F,setActiveConnectorIds:se,sandbox:w,setSandbox:T,webSearch:oe,setWebSearch:U,imageGeneration:Ce,setImageGeneration:rt,chart:it,setChart:Re,fileSystem:at,setFileSystem:ko,availableModels:ee,availableAgents:me,availableConnectors:te,messages:O,hasPersistedChat:E,setHasPersistedChat:R,setMessages:V,addSystemMessage:ke,startNewChat:Kt,sendMessage:Xe,setFullOutput:ie,credentials:W,setCredentials:_,setState:S,defaultCapabilities:{sandbox:r,webSearch:a,imageGeneration:l,chart:d,fileSystem:I},capabilityLabelMap:Ht,hasUploadingFiles:xo});if(Fo((k,N)=>{(N.ctrl||N.meta)&&k==="v"&&xt()},{isActive:h.status==="ready"&&!ye}),Fo((k,N)=>{if(!N.escape)return;let J=Date.now(),G=C.current;C.current=J,!(!G||J-G>Er)&&(ye||_e||(C.current=null,Ve&&Vt(),Z.length>0&&v("")))},{isActive:h.status==="ready"}),Fo((k,N)=>{N.return&&(Kt("Started a new chat."),S({status:"ready"}))},{isActive:h.status==="error"}),uo(()=>{if(W&&!M&&h.status==="loading")if(!Q&&!fe){let k=ne.getDefaultModel(),N=k&&ee.some(G=>G.id===k),J=N?k:ee[0]?.id;J?(N||ne.setDefaultModel(J),z(J),S({status:"ready"})):me.length===0?S({status:"no-model"}):S({status:"ready"})}else S({status:"ready"})},[W,M,Q,fe,ee,me,h.status,z,S]),uo(()=>{n&&W&&h.status==="ready"&&Xe(n)},[W,n]),h.status==="loading")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),de(Pe,{children:[X(K,{color:"cyan",children:X(Wo,{type:"dots"})}),X(K,{children:" Initializing chat..."})]})]});if(h.status==="not-logged-in")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"Not logged in"}),X(K,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if(h.status==="no-workspace")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"No workspace selected"}),X(K,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if(h.status==="no-model")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"No model or agent specified"}),s&&X(K,{dimColor:!0,children:"Could not determine the model used in this chat."}),X(K,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),X(K,{dimColor:!0,children:"Example: entrydesk chat -c 1 -i --model gemini-2.5-flash-lite"})]});if(h.status==="error")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),de(K,{color:"red",children:["Error: ",h.message]}),X(K,{dimColor:!0,children:"Press Enter to start a new chat, or Ctrl+C to exit"})]});let c=fe?f?f.connectors&&f.connectors.length>0?f.connectors.map(k=>k.name).join(", "):"none":"loading...":F&&F.length>0?te.filter(k=>F.includes(k.id)).map(k=>k.name).join(", ")||`${F.length} connector(s)`:"none",u=[];if(fe)if(f?.capabilities)for(let k of f.capabilities)u.push(Ht.get(k)??k);else u.push("loading...");else w&&u.push("Sandbox"),oe&&u.push("Web"),Ce&&u.push("Image"),it&&u.push("Chart");at&&u.push("FileSystem");let g=H.getCurrentProfileName(),$=g!=="default";return de(Pe,{flexDirection:"column",children:[de(Pe,{marginBottom:1,flexDirection:"column",children:[X(K,{children:b}),de(Pe,{children:[X(K,{bold:!0,color:"cyan",children:j?`Continuing: ${j}`:"EntryDesk CLI"}),de(K,{dimColor:!0,children:[" v","1.4.0"]}),$&&de(K,{color:"magenta",children:[" [",g,"]"]}),X(K,{dimColor:!0,children:" (type /help for commands)"})]})]}),O.map((k,N)=>{let J=k.parts&&p?ht(k.parts,!0):k.content,G=k.role==="user"?"green":k.role==="system"?"yellow":"blue",ue=k.role==="user"?"You":k.role==="system"?"System":"Assistant";return de(Pe,{flexDirection:"column",marginBottom:1,children:[de(K,{bold:!0,color:G,children:[ue,":"]}),X(Oo,{text:J})]},N)}),he&&de(Pe,{flexDirection:"column",marginBottom:1,children:[X(K,{bold:!0,color:"blue",children:"Assistant:"}),X(Oo,{text:he})]}),h.status==="ready"&&X(un,{suggestions:bt,activeIndex:Ct,visible:_e}),h.status==="ready"&&ye&&X(cn,{items:Ze,activeIndex:$t,pageSize:ye==="agent"||ye==="skills"||ye==="model"?5:10,selectedIds:ye==="connectors"?qt:ye==="capabilities"?Nt:void 0,multiSelect:ye==="connectors"||ye==="capabilities",visible:!0,title:ye==="model"?"Select model:":ye==="agent"?"Select agent:":ye==="skills"?"Select skill:":ye==="connectors"?"Select connectors:":ye==="capabilities"?"Select capabilities:":"Select chat:"}),h.status==="sending"&&!he?de(Pe,{children:[X(K,{color:"cyan",children:X(Wo,{type:"dots"})}),X(K,{children:" Thinking..."})]}):h.status==="ready"&&!ye?de(Pe,{flexDirection:"column",children:[zt&&X(Pe,{marginBottom:1,children:X(K,{color:"yellow",children:"\u26A0\uFE0F Delete this chat? (y/N) "})}),Ve&&!zt&&de(Pe,{marginBottom:1,flexDirection:"row",gap:1,children:[X(K,{dimColor:!0,children:"Attachments:"}),We.map((k,N)=>de(K,{children:[k.status==="uploading"?de(K,{color:"yellow",children:[X(Wo,{type:"dots"})," ",k.filename]}):k.status==="error"?de(K,{color:"red",children:["\u2717 ",k.filename]}):de(K,{color:"green",children:["\u2713 ",k.filename]}),N<We.length-1&&X(K,{children:", "})]},k.id))]}),de(Pe,{children:[X(K,{color:"green",children:"> "}),X(wn,{value:Z,onChange:v,onSubmit:y,onPaste:ct,leadingOffset:2,multiline:!0})]})]}):null,de(Pe,{marginTop:1,flexDirection:"column",children:[de(Pe,{gap:2,children:[de(K,{children:[X(K,{dimColor:!0,children:"Model: "}),X(K,{color:"magenta",children:fe?f?.model?.name||"loading...":ee.find(k=>k.id===Q)?.name||Q||"none"})]}),de(K,{children:[X(K,{dimColor:!0,children:"Connectors: "}),X(K,{color:"cyan",children:c})]}),de(K,{children:[X(K,{dimColor:!0,children:"Capabilities: "}),X(K,{color:"green",children:u.length>0?u.join(", "):"none"})]})]}),de(K,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",p?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as Br}from"react/jsx-runtime";async function Rr(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function Ur(e,t,n,s){if(s<1)return console.error("Chat number must be 1 or greater"),null;let{chats:o}=await e.getChats(t,n,20);if(o.length===0)return console.error("No chats found. Start a new chat first."),null;if(s>o.length)return console.error(`Chat number ${s} not found. You have ${o.length} recent chats.`),console.error("Use `entrydesk chats` to see available chats."),null;let i=o[s-1],r;if(!i.agentId){let{messages:a}=await e.getMessages(t,n,i.id,10);r=a.find(d=>d.role==="assistant"&&d.modelId)?.modelId}return{chat:i,modelId:r}}var It="\x1B[2m",Oe="\x1B[0m",Jo="\x1B[36m",rs="\x1B[33m",po="\x1B[32m",os="stream-json";function ns(e,t,n,s){e&&t&&(console.error(`Error: Cannot use both ${n} and ${s}`),process.exit(1))}function mo(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
199
- `)}function go(e,t){if(t)return e;let n=e.split(`
200
- `);if(n.length<=20)return e;let s=n.slice(0,5),o=n.slice(-5),i=n.length-10;return[...s,`${It}... (${i} lines omitted, use --full-output to see all) ...${Oe}`,...o].join(`
201
- `)}function jr(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function ss(e,t){if(!e)return"(no result)";if(typeof e!="object")return go(String(e),t);let n=e;if("structuredContent"in n&&n.structuredContent){let s=n.structuredContent,o=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&o.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&o.push(`${rs}[stderr]${Oe} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let i=s.urls;for(let r of i)r.path&&r.url&&o.push(`${r.path}: ${r.url}`)}return o.length===0&&o.push(JSON.stringify(s,null,2)),go(o.join(`
202
- `),t)}if("content"in n&&Array.isArray(n.content)){let o=n.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
203
- `);return go(o||JSON.stringify(e,null,2),t)}return go(JSON.stringify(e,null,2),t)}async function is(e){let t,n;try{let te=await pe();t=te.accessToken,n=te.workspaceId}catch(te){xe(te)}let s=e.output===os;e.output&&!s&&(console.error(`Invalid --output value. Supported: ${os}`),process.exit(1));let o=!s&&(e.plain||!process.stdout.isTTY),i=ne.getDefaultModel(),r=e.message;!r&&!process.stdin.isTTY&&(r=await Rr());let a=new B;async function l(){if(!i)try{let{models:te}=await a.getModels(t,n),ee=te[0]?.id;if(!ee)return;ne.setDefaultModel(ee),i=ee}catch{}}let d,I,x,b;if(e.continue){let te=await Ur(a,t,n,e.continue);te||process.exit(1),d=te.chat.id,I=te.chat.title??void 0,x=te.chat.agentId??void 0,b=te.modelId;let ee=e.agentId||e.model||x||b||i;!ee&&!e.interactive&&(await l(),ee=e.agentId||e.model||x||b||i),!ee&&!e.interactive&&(o||console.log(`Continuing chat: ${te.chat.title||"Untitled"}`),console.error(`
204
- 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)),!o&&!e.interactive&&console.log(`Continuing chat: ${te.chat.title||"Untitled"}
205
- `)}let C=e.agentId||x,m=e.model||b||i||void 0;!C&&!m&&(await l(),m=e.model||b||i||void 0),ns(e.sandbox,e.noSandbox,"--sandbox","--no-sandbox"),ns(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let h=ne.getCapabilities(),S=e.noSandbox?!1:e.sandbox?!0:h?.sandbox??!0,O=e.webSearch??h?.webSearch??!1,V=e.imageGen??h?.imageGeneration??!1,Z=e.chart??h?.chart??!1,ae=ne.getDefaultConnectorIds(),Y=e.connectors??ae??void 0,Se=ne.getLocalTools(),j=e.noFileSystem?!1:e.fileSystem?!0:Se?.fileSystem??!0;if(e.interactive){Or(Br(ts,{agentId:C,model:m,message:e.message,chatId:d,chatTitle:I??void 0,connectorIds:Y,enableSandbox:S,enableWebSearch:O,enableImageGeneration:V,enableChart:Z,enableFileSystem:j}),{exitOnCtrlC:!1});return}let P=!e.continue&&!m&&!C;(!r||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 E=e.fullOutput??!1,R=d||fo(),W=j?Xt():void 0,_=j?Zt():void 0,he=[],L=fo(),p=(te,ee,me)=>{let ce={id:R};return te&&(ce.message={id:te.id,createdAt:new Date,role:"user",parts:[{type:"text",text:te.text}]}),C?ce.agentId=C:(m&&(ce.model=m),ce.connectorIds=Y??[],ce.enableSandbox=S,ce.enableWebSearch=O,ce.enableImageGeneration=V,ce.enableChart=Z),W&&(ce.clientTools=W),_&&(ce.clientToolSystemPrompt=_),ee&&ee.length>0&&(ce.clientToolResults=ee),me&&me.length>0&&(ce.previousMessages=me),ce},ie=async te=>{if(!te.body)throw new Error("No response body");let ee=te.body.getReader(),me=new TextDecoder,ce="",M=new Map,Q=[],z=[];for(;;){let{done:fe,value:Te}=await ee.read();if(fe)break;ce+=me.decode(Te,{stream:!0});let F=ce.split(`
206
- `);ce=F.pop()||"";for(let se of F){let D=se.trimEnd();if(D==="data: [DONE]"){s&&mo("done");continue}if(D.startsWith("data: "))try{let f=JSON.parse(D.slice(6));if(f.type&&z.push(f),s){f.type==="text-delta"&&f.delta!==void 0?mo("text-delta",f.delta):f.type==="reasoning-delta"&&f.delta!==void 0?mo("reasoning-delta",f.delta):mo(f.type||"event",f);continue}if(o){if(f.type==="text-delta"&&f.delta&&process.stdout.write(f.delta),j&&(f.type==="tool-input-available"||f.type==="tool-call")&&f.toolCallId&&f.toolName&&tt(f.toolName)){let w=f.args||f.input||{};Q.push({toolCallId:f.toolCallId,toolName:f.toolName,args:w})}continue}switch(f.type){case"reasoning-delta":f.delta&&process.stdout.write(`${It}${f.delta}${Oe}`);break;case"reasoning-end":process.stdout.write(`
207
-
208
- `);break;case"text-delta":f.delta&&process.stdout.write(f.delta);break;case"tool-call-streaming-start":case"tool-input-start":if(f.toolCallId&&f.toolName){M.set(f.toolCallId,{toolName:f.toolName});let T=j&&tt(f.toolName)?`${po}[LOCAL]${Oe} `:"";console.log(`
209
- ${Jo}\u250C\u2500 ${T}Tool Call: ${f.toolName}${Oe}`)}break;case"tool-call":case"tool-input-available":if(f.toolCallId&&f.toolName){let w=f.args||f.input||{},T=jr(w);console.log(`${rs}\u2502 Arguments:${Oe}`);for(let oe of T.split(`
210
- `))console.log(`${It}\u2502 ${oe}${Oe}`);j&&tt(f.toolName)&&(M.set(f.toolCallId,{toolName:f.toolName,args:w}),Q.push({toolCallId:f.toolCallId,toolName:f.toolName,args:w}))}break;case"tool-result":if(f.toolCallId){let w=M.get(f.toolCallId),T=ss(f.result,E);console.log(`${po}\u2502 Result:${Oe}`);for(let oe of T.split(`
211
- `))console.log(`${It}\u2502 ${oe}${Oe}`);console.log(`${Jo}\u2514\u2500 ${w?.toolName||"Tool"} completed${Oe}
212
- `),M.delete(f.toolCallId)}break;case"error":f.errorText&&console.error(`${It}Error: ${f.errorText}${Oe}`);break}}catch{}}}return{pendingClientTools:Q,messageParts:z}},ke=p({id:fo(),text:r}),q=await a.chat(t,n,ke),A=await ie(q);for(he=A.messageParts;A.pendingClientTools.length>0;){let te=[];for(let M of A.pendingClientTools){!o&&!s&&console.log(`${po}\u2502 Executing locally...${Oe}`);let Q=await Qt(M.toolName,M.args),z=Q.success?JSON.stringify(Q.result):Q.error||"Unknown error";if(te.push({toolCallId:M.toolCallId,toolName:M.toolName,content:[{type:"text",text:z}],isError:!Q.success}),!o&&!s){let fe=ss(Q.success?Q.result:{error:Q.error},E);console.log(`${po}\u2502 Result:${Oe}`);for(let Te of fe.split(`
213
- `))console.log(`${It}\u2502 ${Te}${Oe}`);console.log(`${Jo}\u2514\u2500 ${M.toolName} completed${Oe}
196
+ `)||Ve===null)return;if(Ve>=lt.length-1){Xe(null),t(zt);return}let c=Ve+1;Xe(c),t(lt[c])}}),{suggestions:z,suggestionIndex:Te,showSuggestions:se,argMode:f,argItems:I,argIndex:U,selectedConnectorIds:rt,selectedCapabilities:Re,deleteConfirmMode:ct,handleInputChange:Yt,handleSubmit:Xt}}import{useCallback as Ft,useRef as Rr,useState as Ur}from"react";function os({credentials:e,currentModel:t,modelProviders:o,onUploadSuccess:s,onUploadError:n}){let[i,r]=Ur([]),a=Rr(0),l=Ft(h=>{if(!(!Array.isArray(o)||o.length===0)){for(let T of o)if(T.models.some(V=>V.id===h))return T.id;return o[0]?.id}},[o]),d=Ft(async h=>{if(!e){n?.(h.filename,"Not logged in");return}if(!Array.isArray(o)||o.length===0){n?.(h.filename,"Model providers not loaded yet. Please wait and try again.");return}let T=t?l(t):o[0]?.id;if(!T){n?.(h.filename,"No model provider available");return}let O=`file-${++a.current}`;r(V=>[...V,{id:O,filename:h.filename,mimeType:h.mimeType,status:"uploading"}]);try{let Z=await new B().uploadFile(e.accessToken,e.workspaceId,h,T);r(ae=>ae.map(Y=>Y.id===O?{...Y,status:"uploaded",fileId:Z.id}:Y)),s?.(h.filename)}catch(V){let Z=V instanceof Error?V.message:"Upload failed";r(ae=>ae.map(Y=>Y.id===O?{...Y,status:"error",error:Z}:Y)),n?.(h.filename,Z)}},[e,t,l,o,s,n]),$=Ft(h=>{r(T=>T.filter(O=>O.id!==h))},[]),x=Ft(()=>{r([])},[]),b=Ft(()=>i.filter(h=>h.status==="uploaded"&&h.fileId).map(h=>h.fileId),[i]),C=i.some(h=>h.status==="uploading"),m=i.length>0;return{pendingFiles:i,addFile:d,removeFile:$,clearFiles:x,getUploadedFileIds:b,hasUploadingFiles:C,hasFiles:m}}import{jsx as X,jsxs as de}from"react/jsx-runtime";var Br=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],Fr=[Bo,Bo,jo,jo,gt,gt,gt,gt],ss=Br.map((e,t)=>`${Fr[t]??gt}${e}${re}`).join(`
197
+ `),Wr=`${gt}EntryDesk${re}`,Mr=500;function Jr(e){let t="",o=0;for(;o<e.length;){if(e.charCodeAt(o)===27&&e[o+1]==="["){for(o+=2;o<e.length;){let s=e.charCodeAt(o);if(s>=64&&s<=126){o+=1;break}o+=1}continue}t+=e[o],o+=1}return t}function Gr(e){let t=Jr(e);return Math.max(...t.split(`
198
+ `).map(o=>o.length))}function Hr(e){let t=Gr(ss);return e>=t?ss:Wr}function rs({agentId:e,model:t,message:o,chatId:s,chatTitle:n,connectorIds:i,enableSandbox:r=!0,enableWebSearch:a=!1,enableImageGeneration:l=!1,enableChart:d=!1,enableFileSystem:$=!0}){let x=process.stdout.columns??80,b=Hr(x),C=ns(null),m=Un(s,n),{state:h,setState:T,messages:O,setMessages:V,input:Z,setInput:ae,chatId:Y,setChatId:Se,currentChatTitle:j,setCurrentChatTitle:P,hasPersistedChat:E,setHasPersistedChat:R,credentials:W,setCredentials:_,currentResponse:he,setCurrentResponse:L,fullOutput:p,setFullOutput:ie,addSystemMessage:ke,startNewChat:q}=m,{credentials:A}=Bn(T);po(()=>{A&&!W&&_(A)},[A,W,_]);let{availableConnectors:te,availableModels:ee,availableAgents:me,modelProviders:ce,loading:M}=Fn(W),{currentModel:Q,setCurrentModel:z,currentAgentId:fe,setCurrentAgentId:Te,activeConnectorIds:F,setActiveConnectorIds:se}=zn(t,e,i),D=ns(!1);po(()=>{if(!D.current){if(D.current=!0,!t&&!e){let k=ne.getDefaultModel();k&&z(k)}if(!i&&!e){let k=ne.getDefaultConnectorIds();k&&se(k.length>0?k:void 0)}}},[t,e,i,z,se]);let{currentAgentDetails:f}=qn(fe,W),{sandbox:w,setSandbox:I,webSearch:oe,setWebSearch:U,imageGeneration:Ce,setImageGeneration:rt,chart:it,setChart:Re,fileSystem:at,setFileSystem:bo,capabilityLabelMap:Kt}=Kn(r,a,l,d,$),{pendingFiles:We,addFile:wt,removeFile:Ye,clearFiles:qt,getUploadedFileIds:lt,hasUploadingFiles:Co,hasFiles:Ve}=os({credentials:W,currentModel:Q,modelProviders:ce,onUploadSuccess:k=>{ke(`\u2713 Attached: ${k}`)},onUploadError:(k,N)=>{ke(`\u2717 Failed to upload ${k}: ${N}`)}}),{sendMessage:Xe}=Jn({chatId:Y,credentials:W,currentAgentId:fe,currentModel:Q,activeConnectorIds:F,sandbox:w,webSearch:oe,imageGeneration:Ce,chart:it,localTools:at,fullOutput:p,setMessages:V,setState:T,setCurrentResponse:L,setCredentials:_,setHasPersistedChat:R,getFileIds:lt,clearFiles:qt}),zt=Go(k=>{q(k),L("")},[q]),[kt,mt]=jr(!1),ct=Go(async k=>{let N=k.text.trim(),J=lo(N);if(/^https?:\/\//.test(J))return;if(await Ln(N)&&_n(J)){let ue=await Dn(N);ue&&(k.preventDefault(),await wt(ue))}},[wt]),xt=Go(async()=>{if(!(kt||h.status!=="ready")){if(M||ce.length===0){ke("Please wait for resources to load before pasting images.");return}ke("Reading clipboard..."),mt(!0);try{let k=await En();if(k){let N=`clipboard-${Date.now()}.png`;ke(`Uploading: ${N} (${Math.round(k.buffer.length/1024)}KB)`),await wt({buffer:k.buffer,filename:N,mimeType:k.mime})}else ke("No image found in clipboard. Copy an image first.")}catch(k){let N=k instanceof Error?k.message:"Failed to read clipboard";ke(`Clipboard error: ${N}`)}finally{mt(!1)}}},[wt,ke,kt,h.status,M,ce.length]),{suggestions:bt,suggestionIndex:Ct,showSuggestions:_e,argMode:ye,argItems:Ze,argIndex:$t,selectedConnectorIds:Yt,selectedCapabilities:Et,deleteConfirmMode:Xt,handleInputChange:v,handleSubmit:y}=ts({input:Z,setInput:ae,chatId:Y,setChatId:Se,currentChatTitle:j,setCurrentChatTitle:P,currentModel:Q,setCurrentModel:z,currentAgentId:fe,setCurrentAgentId:Te,currentAgentDetails:f,setCurrentAgentDetails:()=>{},activeConnectorIds:F,setActiveConnectorIds:se,sandbox:w,setSandbox:I,webSearch:oe,setWebSearch:U,imageGeneration:Ce,setImageGeneration:rt,chart:it,setChart:Re,fileSystem:at,setFileSystem:bo,availableModels:ee,availableAgents:me,availableConnectors:te,messages:O,hasPersistedChat:E,setHasPersistedChat:R,setMessages:V,addSystemMessage:ke,startNewChat:zt,sendMessage:Xe,setFullOutput:ie,credentials:W,setCredentials:_,setState:T,defaultCapabilities:{sandbox:r,webSearch:a,imageGeneration:l,chart:d,fileSystem:$},capabilityLabelMap:Kt,hasUploadingFiles:Co});if(Mo((k,N)=>{(N.ctrl||N.meta)&&k==="v"&&xt()},{isActive:h.status==="ready"&&!ye}),Mo((k,N)=>{if(!N.escape)return;let J=Date.now(),G=C.current;C.current=J,!(!G||J-G>Mr)&&(ye||_e||(C.current=null,Ve&&qt(),Z.length>0&&v("")))},{isActive:h.status==="ready"}),Mo((k,N)=>{N.return&&(zt("Started a new chat."),T({status:"ready"}))},{isActive:h.status==="error"}),po(()=>{if(W&&!M&&h.status==="loading")if(!Q&&!fe){let k=ne.getDefaultModel(),N=k&&ee.some(G=>G.id===k),J=N?k:ee[0]?.id;J?(N||ne.setDefaultModel(J),z(J),T({status:"ready"})):me.length===0?T({status:"no-model"}):T({status:"ready"})}else T({status:"ready"})},[W,M,Q,fe,ee,me,h.status,z,T]),po(()=>{o&&W&&h.status==="ready"&&Xe(o)},[W,o]),h.status==="loading")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),de(Pe,{children:[X(K,{color:"cyan",children:X(Jo,{type:"dots"})}),X(K,{children:" Initializing chat..."})]})]});if(h.status==="not-logged-in")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"Not logged in"}),X(K,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if(h.status==="no-workspace")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"No workspace selected"}),X(K,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if(h.status==="no-model")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),X(K,{color:"yellow",children:"No model or agent specified"}),s&&X(K,{dimColor:!0,children:"Could not determine the model used in this chat."}),X(K,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),X(K,{dimColor:!0,children:"Example: entrydesk chat -c 1 -i --model gemini-2.5-flash-lite"})]});if(h.status==="error")return de(Pe,{flexDirection:"column",children:[X(K,{children:b}),de(K,{color:"red",children:["Error: ",h.message]}),X(K,{dimColor:!0,children:"Press Enter to start a new chat, or Ctrl+C to exit"})]});let c=fe?f?f.connectors&&f.connectors.length>0?f.connectors.map(k=>k.name).join(", "):"none":"loading...":F&&F.length>0?te.filter(k=>F.includes(k.id)).map(k=>k.name).join(", ")||`${F.length} connector(s)`:"none",u=[];if(fe)if(f?.capabilities)for(let k of f.capabilities)u.push(Kt.get(k)??k);else u.push("loading...");else w&&u.push("Sandbox"),oe&&u.push("Web"),Ce&&u.push("Image"),it&&u.push("Chart");at&&u.push("FileSystem");let g=H.getCurrentProfileName(),S=g!=="default";return de(Pe,{flexDirection:"column",children:[de(Pe,{marginBottom:1,flexDirection:"column",children:[X(K,{children:b}),de(Pe,{children:[X(K,{bold:!0,color:"cyan",children:j?`Continuing: ${j}`:"EntryDesk CLI"}),de(K,{dimColor:!0,children:[" v","1.5.0"]}),S&&de(K,{color:"magenta",children:[" [",g,"]"]}),X(K,{dimColor:!0,children:" (type /help for commands)"})]})]}),O.map((k,N)=>{let J=k.parts&&p?ht(k.parts,!0):k.content,G=k.role==="user"?"green":k.role==="system"?"yellow":"blue",ue=k.role==="user"?"You":k.role==="system"?"System":"Assistant";return de(Pe,{flexDirection:"column",marginBottom:1,children:[de(K,{bold:!0,color:G,children:[ue,":"]}),X(Uo,{text:J})]},N)}),he&&de(Pe,{flexDirection:"column",marginBottom:1,children:[X(K,{bold:!0,color:"blue",children:"Assistant:"}),X(Uo,{text:he})]}),h.status==="ready"&&X(mn,{suggestions:bt,activeIndex:Ct,visible:_e}),h.status==="ready"&&ye&&X(pn,{items:Ze,activeIndex:$t,pageSize:ye==="agent"||ye==="skills"||ye==="model"?5:10,selectedIds:ye==="connectors"?Yt:ye==="capabilities"?Et:void 0,multiSelect:ye==="connectors"||ye==="capabilities",visible:!0,title:ye==="model"?"Select model:":ye==="agent"?"Select agent:":ye==="skills"?"Select skill:":ye==="connectors"?"Select connectors:":ye==="capabilities"?"Select capabilities:":"Select chat:"}),h.status==="sending"&&!he?de(Pe,{children:[X(K,{color:"cyan",children:X(Jo,{type:"dots"})}),X(K,{children:" Thinking..."})]}):h.status==="ready"&&!ye?de(Pe,{flexDirection:"column",children:[Xt&&X(Pe,{marginBottom:1,children:X(K,{color:"yellow",children:"\u26A0\uFE0F Delete this chat? (y/N) "})}),Ve&&!Xt&&de(Pe,{marginBottom:1,flexDirection:"row",gap:1,children:[X(K,{dimColor:!0,children:"Attachments:"}),We.map((k,N)=>de(K,{children:[k.status==="uploading"?de(K,{color:"yellow",children:[X(Jo,{type:"dots"})," ",k.filename]}):k.status==="error"?de(K,{color:"red",children:["\u2717 ",k.filename]}):de(K,{color:"green",children:["\u2713 ",k.filename]}),N<We.length-1&&X(K,{children:", "})]},k.id))]}),de(Pe,{children:[X(K,{color:"green",children:"> "}),X(Cn,{value:Z,onChange:v,onSubmit:y,onPaste:ct,leadingOffset:2,multiline:!0})]})]}):null,de(Pe,{marginTop:1,flexDirection:"column",children:[de(Pe,{gap:2,children:[de(K,{children:[X(K,{dimColor:!0,children:"Model: "}),X(K,{color:"magenta",children:fe?f?.model?.name||"loading...":ee.find(k=>k.id===Q)?.name||Q||"none"})]}),de(K,{children:[X(K,{dimColor:!0,children:"Connectors: "}),X(K,{color:"cyan",children:c})]}),de(K,{children:[X(K,{dimColor:!0,children:"Capabilities: "}),X(K,{color:"green",children:u.length>0?u.join(", "):"none"})]})]}),de(K,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",p?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as Yr}from"react/jsx-runtime";async function Kr(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function qr(e,t,o,s){if(s<1)return console.error("Chat number must be 1 or greater"),null;let{chats:n}=await e.getChats(t,o,20);if(n.length===0)return console.error("No chats found. Start a new chat first."),null;if(s>n.length)return console.error(`Chat number ${s} not found. You have ${n.length} recent chats.`),console.error("Use `entrydesk chats` to see available chats."),null;let i=n[s-1],r;if(!i.agentId){let{messages:a}=await e.getMessages(t,o,i.id,10);r=a.find(d=>d.role==="assistant"&&d.modelId)?.modelId}return{chat:i,modelId:r}}var It="\x1B[2m",Oe="\x1B[0m",Ho="\x1B[36m",cs="\x1B[33m",go="\x1B[32m",is="stream-json";function as(e,t,o,s){e&&t&&(console.error(`Error: Cannot use both ${o} and ${s}`),process.exit(1))}function ho(e,t){let o=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(o)}
199
+ `)}function yo(e,t){if(t)return e;let o=e.split(`
200
+ `);if(o.length<=20)return e;let s=o.slice(0,5),n=o.slice(-5),i=o.length-10;return[...s,`${It}... (${i} lines omitted, use --full-output to see all) ...${Oe}`,...n].join(`
201
+ `)}function zr(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function ls(e,t){if(!e)return"(no result)";if(typeof e!="object")return yo(String(e),t);let o=e;if("structuredContent"in o&&o.structuredContent){let s=o.structuredContent,n=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&n.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&n.push(`${cs}[stderr]${Oe} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let i=s.urls;for(let r of i)r.path&&r.url&&n.push(`${r.path}: ${r.url}`)}return n.length===0&&n.push(JSON.stringify(s,null,2)),yo(n.join(`
202
+ `),t)}if("content"in o&&Array.isArray(o.content)){let n=o.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
203
+ `);return yo(n||JSON.stringify(e,null,2),t)}return yo(JSON.stringify(e,null,2),t)}async function us(e){let t,o;try{let te=await pe();t=te.accessToken,o=te.workspaceId}catch(te){xe(te)}let s=e.output===is;e.output&&!s&&(console.error(`Invalid --output value. Supported: ${is}`),process.exit(1));let n=!s&&(e.plain||!process.stdout.isTTY),i=ne.getDefaultModel(),r=e.message;!r&&!process.stdin.isTTY&&(r=await Kr());let a=new B;async function l(){if(!i)try{let{models:te}=await a.getModels(t,o),ee=te[0]?.id;if(!ee)return;ne.setDefaultModel(ee),i=ee}catch{}}let d,$,x,b;if(e.continue){let te=await qr(a,t,o,e.continue);te||process.exit(1),d=te.chat.id,$=te.chat.title??void 0,x=te.chat.agentId??void 0,b=te.modelId;let ee=e.agentId||e.model||x||b||i;!ee&&!e.interactive&&(await l(),ee=e.agentId||e.model||x||b||i),!ee&&!e.interactive&&(n||console.log(`Continuing chat: ${te.chat.title||"Untitled"}`),console.error(`
204
+ 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)),!n&&!e.interactive&&console.log(`Continuing chat: ${te.chat.title||"Untitled"}
205
+ `)}let C=e.agentId||x,m=e.model||b||i||void 0;!C&&!m&&(await l(),m=e.model||b||i||void 0),as(e.sandbox,e.noSandbox,"--sandbox","--no-sandbox"),as(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let h=ne.getCapabilities(),T=e.noSandbox?!1:e.sandbox?!0:h?.sandbox??!0,O=e.webSearch??h?.webSearch??!1,V=e.imageGen??h?.imageGeneration??!1,Z=e.chart??h?.chart??!1,ae=ne.getDefaultConnectorIds(),Y=e.connectors??ae??void 0,Se=ne.getLocalTools(),j=e.noFileSystem?!1:e.fileSystem?!0:Se?.fileSystem??!0;if(e.interactive){Vr(Yr(rs,{agentId:C,model:m,message:e.message,chatId:d,chatTitle:$??void 0,connectorIds:Y,enableSandbox:T,enableWebSearch:O,enableImageGeneration:V,enableChart:Z,enableFileSystem:j}),{exitOnCtrlC:!1});return}let P=!e.continue&&!m&&!C;(!r||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 E=e.fullOutput??!1,R=d||mo(),W=j?Qt():void 0,_=j?eo():void 0,he=[],L=mo(),p=(te,ee,me)=>{let ce={id:R};return te&&(ce.message={id:te.id,createdAt:new Date,role:"user",parts:[{type:"text",text:te.text}]}),C?ce.agentId=C:(m&&(ce.model=m),ce.connectorIds=Y??[],ce.enableSandbox=T,ce.enableWebSearch=O,ce.enableImageGeneration=V,ce.enableChart=Z),W&&(ce.clientTools=W),_&&(ce.clientToolSystemPrompt=_),ee&&ee.length>0&&(ce.clientToolResults=ee),me&&me.length>0&&(ce.previousMessages=me),ce},ie=async te=>{if(!te.body)throw new Error("No response body");let ee=te.body.getReader(),me=new TextDecoder,ce="",M=new Map,Q=[],z=[];for(;;){let{done:fe,value:Te}=await ee.read();if(fe)break;ce+=me.decode(Te,{stream:!0});let F=ce.split(`
206
+ `);ce=F.pop()||"";for(let se of F){let D=se.trimEnd();if(D==="data: [DONE]"){s&&ho("done");continue}if(D.startsWith("data: "))try{let f=JSON.parse(D.slice(6));if(f.type&&z.push(f),s){f.type==="text-delta"&&f.delta!==void 0?ho("text-delta",f.delta):f.type==="reasoning-delta"&&f.delta!==void 0?ho("reasoning-delta",f.delta):ho(f.type||"event",f);continue}if(n){if(f.type==="text-delta"&&f.delta&&process.stdout.write(f.delta),j&&(f.type==="tool-input-available"||f.type==="tool-call")&&f.toolCallId&&f.toolName&&tt(f.toolName)){let w=f.args||f.input||{};Q.push({toolCallId:f.toolCallId,toolName:f.toolName,args:w})}continue}switch(f.type){case"reasoning-delta":f.delta&&process.stdout.write(`${It}${f.delta}${Oe}`);break;case"reasoning-end":process.stdout.write(`
207
+
208
+ `);break;case"text-delta":f.delta&&process.stdout.write(f.delta);break;case"tool-call-streaming-start":case"tool-input-start":if(f.toolCallId&&f.toolName){M.set(f.toolCallId,{toolName:f.toolName});let I=j&&tt(f.toolName)?`${go}[LOCAL]${Oe} `:"";console.log(`
209
+ ${Ho}\u250C\u2500 ${I}Tool Call: ${f.toolName}${Oe}`)}break;case"tool-call":case"tool-input-available":if(f.toolCallId&&f.toolName){let w=f.args||f.input||{},I=zr(w);console.log(`${cs}\u2502 Arguments:${Oe}`);for(let oe of I.split(`
210
+ `))console.log(`${It}\u2502 ${oe}${Oe}`);j&&tt(f.toolName)&&(M.set(f.toolCallId,{toolName:f.toolName,args:w}),Q.push({toolCallId:f.toolCallId,toolName:f.toolName,args:w}))}break;case"tool-result":if(f.toolCallId){let w=M.get(f.toolCallId),I=ls(f.result,E);console.log(`${go}\u2502 Result:${Oe}`);for(let oe of I.split(`
211
+ `))console.log(`${It}\u2502 ${oe}${Oe}`);console.log(`${Ho}\u2514\u2500 ${w?.toolName||"Tool"} completed${Oe}
212
+ `),M.delete(f.toolCallId)}break;case"error":f.errorText&&console.error(`${It}Error: ${f.errorText}${Oe}`);break}}catch{}}}return{pendingClientTools:Q,messageParts:z}},ke=p({id:mo(),text:r}),q=await a.chat(t,o,ke),A=await ie(q);for(he=A.messageParts;A.pendingClientTools.length>0;){let te=[];for(let M of A.pendingClientTools){!n&&!s&&console.log(`${go}\u2502 Executing locally...${Oe}`);let Q=await to(M.toolName,M.args),z=Q.success?JSON.stringify(Q.result):Q.error||"Unknown error";if(te.push({toolCallId:M.toolCallId,toolName:M.toolName,content:[{type:"text",text:z}],isError:!Q.success}),!n&&!s){let fe=ls(Q.success?Q.result:{error:Q.error},E);console.log(`${go}\u2502 Result:${Oe}`);for(let Te of fe.split(`
213
+ `))console.log(`${It}\u2502 ${Te}${Oe}`);console.log(`${Ho}\u2514\u2500 ${M.toolName} completed${Oe}
214
214
  `)}}let ee=he.map(M=>{if(M.type==="tool-call"){let Q=te.find(fe=>fe.toolCallId===M.toolCallId),z=Q?.content.filter(fe=>fe.type==="text").map(fe=>fe.text).join(`
215
- `);return{type:"tool-invocation",toolCallId:M.toolCallId,toolName:M.toolName,args:M.args,state:Q?.isError?"output-error":"output-available",output:z}}return M}),me=[{id:L,role:"assistant",parts:ee}];L=fo();let ce=p(void 0,te,me);q=await a.chat(t,n,ce),A=await ie(q),he=A.messageParts}s||console.log("")}var Ft="\x1B[2m",Ae="\x1B[0m",pt="\x1B[36m",Ho="\x1B[33m",as="\x1B[32m",ls="stream-json";function ze(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
216
- `)}function Go(e){let t=new Date(e),s=new Date().getTime()-t.getTime(),o=Math.floor(s/(1e3*60*60*24));return o===0?t.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit"}):o===1?"Yesterday":o<7?`${o} days ago`:t.toLocaleDateString("en-US",{month:"short",day:"numeric"})}function ho(e,t){if(t)return e;let n=e.split(`
217
- `);if(n.length<=15)return e;let s=n.slice(0,6),o=n.slice(-4),i=n.length-10;return[...s,`... (${i} lines omitted, use --full-output to see all) ...`,...o].join(`
218
- `)}function Vo(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(Vo);let t={};for(let[n,s]of Object.entries(e))typeof s=="string"&&s.length>200?t[n]=s.slice(0,150)+"... (truncated)":typeof s=="object"&&s!==null?t[n]=Vo(s):t[n]=s;return t}function cs(e){if(!e||typeof e!="object")return String(e);try{return JSON.stringify(e,null,2)}catch{return String(e)}}function us(e,t){if(!e)return"(no result)";if(typeof e!="object")return ho(String(e),t);let n=t?e:Vo(e);if("structuredContent"in n&&n.structuredContent){let s=n.structuredContent,o=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&o.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&o.push(`${Ho}[stderr]${Ae} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let i=s.urls;for(let r of i)r.path&&r.url&&o.push(`${r.path}: ${r.url}`)}return o.length===0&&o.push(JSON.stringify(s,null,2)),ho(o.join(`
219
- `),t)}if("content"in n&&Array.isArray(n.content)){let o=n.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
220
- `);return ho(o||JSON.stringify(e,null,2),t)}return ho(JSON.stringify(e,null,2),t)}function Fr(e){if(typeof e.title=="string")return e.title;if(typeof e.toolName=="string")return e.toolName;let t=e.type;return t.startsWith("tool-")?t.slice(5).replace(/__/g," ").replace(/_/g," "):t}function ds(e,t){let n=[];for(let s of e)if(s.type==="reasoning"&&s.text)n.push(`${Ft}${s.text}${Ae}`);else if(s.type==="text"&&s.text)n.push(s.text);else if(s.type==="tool-call"&&s.toolName){let o=[];if(o.push(`${pt}\u250C\u2500 Tool Call: ${s.toolName}${Ae}`),s.args){o.push(`${Ho}\u2502 Arguments:${Ae}`);let i=cs(s.args);for(let r of i.split(`
221
- `))o.push(`${Ft}\u2502 ${r}${Ae}`)}if(s.result!==void 0){o.push(`${as}\u2502 Result:${Ae}`);let i=us(s.result,t);for(let r of i.split(`
222
- `))o.push(`${Ft}\u2502 ${r}${Ae}`);o.push(`${pt}\u2514\u2500 ${s.toolName} completed${Ae}`)}else s.state==="call"?o.push(`${pt}\u2514\u2500 (awaiting result)${Ae}`):o.push(`${pt}\u2514\u2500${Ae}`);n.push(o.join(`
223
- `))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let o=Fr(s),i=[];if(i.push(`${pt}\u250C\u2500 Tool: ${o}${Ae}`),s.input){i.push(`${Ho}\u2502 Input:${Ae}`);let r=cs(s.input);for(let a of r.split(`
224
- `))i.push(`${Ft}\u2502 ${a}${Ae}`)}if(s.output!==void 0&&s.state==="output-available"){i.push(`${as}\u2502 Output:${Ae}`);let r=us(s.output,t);for(let a of r.split(`
225
- `))i.push(`${Ft}\u2502 ${a}${Ae}`);i.push(`${pt}\u2514\u2500 completed${Ae}`)}else s.state==="call"||s.state==="partial-call"?i.push(`${pt}\u2514\u2500 (in progress)${Ae}`):i.push(`${pt}\u2514\u2500${Ae}`);n.push(i.join(`
226
- `))}return n.join(`
227
-
228
- `).trim()}async function fs(e){let t=e.output===ls;e.output&&!t&&(console.error(`Invalid --output value. Supported: ${ls}`),process.exit(1));let n=new B;if(e.shareId){let r;try{r=await dt()}catch{}try{let a=await n.getSharedChat(e.shareId,r),{messages:l}=await n.getSharedMessages(e.shareId,50,r);if(e.json){console.log(JSON.stringify({chat:a,messages:l}));return}if(t){if(ze("chat",a),l.length===0)ze("info","No messages in this shared chat.");else for(let x of l.toReversed())ze("message",x);ze("done");return}if(console.log(`Shared Chat: ${a.title||"Untitled"}`),console.log(`Visibility: ${a.visibility}`),a.agent&&console.log(`Agent: ${a.agent.name}`),console.log(`${l.length} messages
229
- `),l.length===0){console.log("No messages in this shared chat.");return}let d=l.toReversed(),I=e.fullOutput??!1;for(let x of d){let b=ds(x.parts,I);if(!b)continue;let C=x.role==="user"?"You":"Assistant";console.log(`[${C}] ${Go(x.createdAt)}`),console.log(b),console.log("")}return}catch(a){if(a instanceof Error){let l=a.message.toLowerCase();l.includes("401")||l.includes("unauthorized")?console.error("Access denied. This shared chat requires authentication or is not accessible to you."):l.includes("404")||l.includes("not found")?console.error("Shared chat not found. The share ID may be invalid or the chat was deleted."):console.error(`Failed to fetch shared chat: ${a.message}`)}else console.error("Failed to fetch shared chat");process.exit(1)}}let s,o;try{let r=await pe();s=r.accessToken,o=r.workspaceId}catch(r){xe(r)}if(e.chatId){let r=e.chatId,a=!1,l=null,d=parseInt(e.chatId,10);if(!isNaN(d)&&d>=0&&/^\d+$/.test(e.chatId)){let m=d===0?1:d,{chats:h}=await n.getChats(s,o,20);m>h.length&&(console.error(`Chat number ${m} not found. You have ${h.length} recent chats.`),process.exit(1));let S=h[m-1];r=S.id,a=!0,l=S,t||console.log(`Chat: ${S.title||"Untitled"}
230
- `)}let{messages:x}=await n.getMessages(s,o,r,50);if(e.json){console.log(JSON.stringify(x));return}if(t){if(l&&ze("chat",l),x.length===0)ze("info","No messages in this chat.");else for(let m of x.toReversed())ze("message",m);ze("done");return}if(x.length===0){console.log("No messages in this chat.");return}let b=x.toReversed(),C=e.fullOutput??!1;a||console.log(`Chat: ${e.chatId.slice(0,8)}...`),console.log(`${x.length} messages
231
- `);for(let m of b){let h=ds(m.parts,C);if(!h)continue;let S=m.role==="user"?"You":"Assistant";console.log(`[${S}] ${Go(m.createdAt)}`),console.log(h),console.log("")}return}let{chats:i}=await n.getChats(s,o,20);if(t){for(let r of i)ze("chat",r);ze("done");return}if(e.json){console.log(JSON.stringify(i));return}if(i.length===0){console.log("No chats found.");return}console.log(`Recent Chats (${i.length}):
232
- `),i.forEach((r,a)=>{let l=(a+1).toString().padStart(2," ");console.log(` ${l}. ${Go(r.createdAt).padEnd(12)} ${r.title||"Untitled"}`)}),console.log(""),console.log("Use `entrydesk chats 1` to view the most recent chat"),console.log('Use `entrydesk chat -c 1 -m "message"` to continue it')}import{Box as Wr,Text as Ne}from"ink";import{jsx as je,jsxs as vt}from"react/jsx-runtime";var Pt=["apiUrl","hubUrl"];function Ko(e){return Pt.includes(e)}async function ps(e){let t=e.action||"list",n=e.configKey,s=e.value,o=H.getEffectiveProfileName();if(t==="list"){let i=ne.getAll(),r=Object.entries(i);if(e.json){console.log(JSON.stringify(i));return}if(console.log(`Profile: ${o}`),r.length===0){console.log("No configuration set."),console.log(`Available keys: ${Pt.join(", ")}`);return}console.log(`Configuration:
215
+ `);return{type:"tool-invocation",toolCallId:M.toolCallId,toolName:M.toolName,args:M.args,state:Q?.isError?"output-error":"output-available",output:z}}return M}),me=[{id:L,role:"assistant",parts:ee}];L=mo();let ce=p(void 0,te,me);q=await a.chat(t,o,ce),A=await ie(q),he=A.messageParts}s||console.log("")}var Wt="\x1B[2m",Ae="\x1B[0m",pt="\x1B[36m",Ko="\x1B[33m",ds="\x1B[32m",fs="stream-json";function ze(e,t){let o=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(o)}
216
+ `)}function Vo(e){let t=new Date(e),s=new Date().getTime()-t.getTime(),n=Math.floor(s/(1e3*60*60*24));return n===0?t.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit"}):n===1?"Yesterday":n<7?`${n} days ago`:t.toLocaleDateString("en-US",{month:"short",day:"numeric"})}function wo(e,t){if(t)return e;let o=e.split(`
217
+ `);if(o.length<=15)return e;let s=o.slice(0,6),n=o.slice(-4),i=o.length-10;return[...s,`... (${i} lines omitted, use --full-output to see all) ...`,...n].join(`
218
+ `)}function qo(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(qo);let t={};for(let[o,s]of Object.entries(e))typeof s=="string"&&s.length>200?t[o]=s.slice(0,150)+"... (truncated)":typeof s=="object"&&s!==null?t[o]=qo(s):t[o]=s;return t}function ps(e){if(!e||typeof e!="object")return String(e);try{return JSON.stringify(e,null,2)}catch{return String(e)}}function ms(e,t){if(!e)return"(no result)";if(typeof e!="object")return wo(String(e),t);let o=t?e:qo(e);if("structuredContent"in o&&o.structuredContent){let s=o.structuredContent,n=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&n.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&n.push(`${Ko}[stderr]${Ae} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let i=s.urls;for(let r of i)r.path&&r.url&&n.push(`${r.path}: ${r.url}`)}return n.length===0&&n.push(JSON.stringify(s,null,2)),wo(n.join(`
219
+ `),t)}if("content"in o&&Array.isArray(o.content)){let n=o.content.filter(i=>i.type==="text"&&i.text).map(i=>i.text).join(`
220
+ `);return wo(n||JSON.stringify(e,null,2),t)}return wo(JSON.stringify(e,null,2),t)}function Xr(e){if(typeof e.title=="string")return e.title;if(typeof e.toolName=="string")return e.toolName;let t=e.type;return t.startsWith("tool-")?t.slice(5).replace(/__/g," ").replace(/_/g," "):t}function gs(e,t){let o=[];for(let s of e)if(s.type==="reasoning"&&s.text)o.push(`${Wt}${s.text}${Ae}`);else if(s.type==="text"&&s.text)o.push(s.text);else if(s.type==="tool-call"&&s.toolName){let n=[];if(n.push(`${pt}\u250C\u2500 Tool Call: ${s.toolName}${Ae}`),s.args){n.push(`${Ko}\u2502 Arguments:${Ae}`);let i=ps(s.args);for(let r of i.split(`
221
+ `))n.push(`${Wt}\u2502 ${r}${Ae}`)}if(s.result!==void 0){n.push(`${ds}\u2502 Result:${Ae}`);let i=ms(s.result,t);for(let r of i.split(`
222
+ `))n.push(`${Wt}\u2502 ${r}${Ae}`);n.push(`${pt}\u2514\u2500 ${s.toolName} completed${Ae}`)}else s.state==="call"?n.push(`${pt}\u2514\u2500 (awaiting result)${Ae}`):n.push(`${pt}\u2514\u2500${Ae}`);o.push(n.join(`
223
+ `))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let n=Xr(s),i=[];if(i.push(`${pt}\u250C\u2500 Tool: ${n}${Ae}`),s.input){i.push(`${Ko}\u2502 Input:${Ae}`);let r=ps(s.input);for(let a of r.split(`
224
+ `))i.push(`${Wt}\u2502 ${a}${Ae}`)}if(s.output!==void 0&&s.state==="output-available"){i.push(`${ds}\u2502 Output:${Ae}`);let r=ms(s.output,t);for(let a of r.split(`
225
+ `))i.push(`${Wt}\u2502 ${a}${Ae}`);i.push(`${pt}\u2514\u2500 completed${Ae}`)}else s.state==="call"||s.state==="partial-call"?i.push(`${pt}\u2514\u2500 (in progress)${Ae}`):i.push(`${pt}\u2514\u2500${Ae}`);o.push(i.join(`
226
+ `))}return o.join(`
227
+
228
+ `).trim()}async function hs(e){let t=e.output===fs;e.output&&!t&&(console.error(`Invalid --output value. Supported: ${fs}`),process.exit(1));let o=new B;if(e.shareId){let r;try{r=await dt()}catch{}try{let a=await o.getSharedChat(e.shareId,r),{messages:l}=await o.getSharedMessages(e.shareId,50,r);if(e.json){console.log(JSON.stringify({chat:a,messages:l}));return}if(t){if(ze("chat",a),l.length===0)ze("info","No messages in this shared chat.");else for(let x of l.toReversed())ze("message",x);ze("done");return}if(console.log(`Shared Chat: ${a.title||"Untitled"}`),console.log(`Visibility: ${a.visibility}`),a.agent&&console.log(`Agent: ${a.agent.name}`),console.log(`${l.length} messages
229
+ `),l.length===0){console.log("No messages in this shared chat.");return}let d=l.toReversed(),$=e.fullOutput??!1;for(let x of d){let b=gs(x.parts,$);if(!b)continue;let C=x.role==="user"?"You":"Assistant";console.log(`[${C}] ${Vo(x.createdAt)}`),console.log(b),console.log("")}return}catch(a){if(a instanceof Error){let l=a.message.toLowerCase();l.includes("401")||l.includes("unauthorized")?console.error("Access denied. This shared chat requires authentication or is not accessible to you."):l.includes("404")||l.includes("not found")?console.error("Shared chat not found. The share ID may be invalid or the chat was deleted."):console.error(`Failed to fetch shared chat: ${a.message}`)}else console.error("Failed to fetch shared chat");process.exit(1)}}let s,n;try{let r=await pe();s=r.accessToken,n=r.workspaceId}catch(r){xe(r)}if(e.chatId){let r=e.chatId,a=!1,l=null,d=parseInt(e.chatId,10);if(!isNaN(d)&&d>=0&&/^\d+$/.test(e.chatId)){let m=d===0?1:d,{chats:h}=await o.getChats(s,n,20);m>h.length&&(console.error(`Chat number ${m} not found. You have ${h.length} recent chats.`),process.exit(1));let T=h[m-1];r=T.id,a=!0,l=T,t||console.log(`Chat: ${T.title||"Untitled"}
230
+ `)}let{messages:x}=await o.getMessages(s,n,r,50);if(e.json){console.log(JSON.stringify(x));return}if(t){if(l&&ze("chat",l),x.length===0)ze("info","No messages in this chat.");else for(let m of x.toReversed())ze("message",m);ze("done");return}if(x.length===0){console.log("No messages in this chat.");return}let b=x.toReversed(),C=e.fullOutput??!1;a||console.log(`Chat: ${e.chatId.slice(0,8)}...`),console.log(`${x.length} messages
231
+ `);for(let m of b){let h=gs(m.parts,C);if(!h)continue;let T=m.role==="user"?"You":"Assistant";console.log(`[${T}] ${Vo(m.createdAt)}`),console.log(h),console.log("")}return}let{chats:i}=await o.getChats(s,n,20);if(t){for(let r of i)ze("chat",r);ze("done");return}if(e.json){console.log(JSON.stringify(i));return}if(i.length===0){console.log("No chats found.");return}console.log(`Recent Chats (${i.length}):
232
+ `),i.forEach((r,a)=>{let l=(a+1).toString().padStart(2," ");console.log(` ${l}. ${Vo(r.createdAt).padEnd(12)} ${r.title||"Untitled"}`)}),console.log(""),console.log("Use `entrydesk chats 1` to view the most recent chat"),console.log('Use `entrydesk chat -c 1 -m "message"` to continue it')}import{Box as Zr,Text as Ne}from"ink";import{jsx as je,jsxs as vt}from"react/jsx-runtime";var Pt=["apiUrl","hubUrl"];function zo(e){return Pt.includes(e)}async function ys(e){let t=e.action||"list",o=e.configKey,s=e.value,n=H.getEffectiveProfileName();if(t==="list"){let i=ne.getAll(),r=Object.entries(i);if(e.json){console.log(JSON.stringify(i));return}if(console.log(`Profile: ${n}`),r.length===0){console.log("No configuration set."),console.log(`Available keys: ${Pt.join(", ")}`);return}console.log(`Configuration:
233
233
  `);for(let[a,l]of r)console.log(` ${a}=${l}`);console.log(`
234
- Available keys: ${Pt.join(", ")}`);return}if(t==="get"){n||(console.error("Error: key is required for get action"),process.exit(1)),Ko(n)||(console.error(`Error: Invalid key '${n}'. Valid keys: ${Pt.join(", ")}`),process.exit(1));let i=ne.get(n);e.json?console.log(JSON.stringify({[n]:i??null})):console.log(i||"Not set");return}if(t==="set"){n||(console.error("Error: key is required for set action"),process.exit(1)),Ko(n)||(console.error(`Error: Invalid key '${n}'. Valid keys: ${Pt.join(", ")}`),process.exit(1)),s||(console.error("Error: value is required for set action"),process.exit(1)),ne.set(n,s),console.log(`Set ${n}=${s}`);return}if(t==="unset"){n||(console.error("Error: key is required for unset action"),process.exit(1)),Ko(n)||(console.error(`Error: Invalid key '${n}'. Valid keys: ${Pt.join(", ")}`),process.exit(1)),ne.unset(n),console.log(`Unset ${n}`);return}console.error(`Unknown action: ${t}`),process.exit(1)}function ms(){let e=Me();return vt(Wr,{flexDirection:"column",children:[je(Ne,{bold:!0,children:"entrydesk config"}),je(Ne,{children:" "}),je(Ne,{children:"Manage CLI configuration"}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Usage:"}),je(Ne,{children:" entrydesk config List all configuration"}),vt(Ne,{children:[" entrydesk config get ","<key>"," Get a configuration value"]}),vt(Ne,{children:[" ","entrydesk config set ","<key>"," ","<value>"," Set a configuration value"]}),vt(Ne,{children:[" ","entrydesk config unset ","<key>"," Remove a configuration value"]}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Available keys:"}),vt(Ne,{children:[" apiUrl API server URL (default: ",e.apiUrl,")"]}),vt(Ne,{children:[" hubUrl Hub server URL (default: ",e.hubUrl,")"]}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Examples:"}),je(Ne,{children:" entrydesk config set apiUrl http://localhost:3200"}),je(Ne,{children:" entrydesk config get apiUrl"}),je(Ne,{children:" entrydesk config unset apiUrl"})]})}async function gs(e){try{let t,n;try{let i=await pe();t=i.accessToken,n=i.workspaceId}catch(i){let r=i instanceof Error?i.message:"Authentication failed";console.error(r),process.exit(1)}let s=new B,{connectors:o}=await s.getConnectors(t,n);if(e.json){console.log(JSON.stringify(o));return}if(o.length===0){console.log("No connectors found in this workspace.");return}console.log(`Connected Connectors (${o.length}):
235
- `);for(let i of o){let r=i.connected?"connected":"disconnected";console.log(` ${i.name} (${r})`),console.log(` Provider: ${i.provider}`),console.log(` ID: ${i.id}`),console.log("")}}catch(t){xe(t)}}function yo(){console.log(`
234
+ Available keys: ${Pt.join(", ")}`);return}if(t==="get"){o||(console.error("Error: key is required for get action"),process.exit(1)),zo(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${Pt.join(", ")}`),process.exit(1));let i=ne.get(o);e.json?console.log(JSON.stringify({[o]:i??null})):console.log(i||"Not set");return}if(t==="set"){o||(console.error("Error: key is required for set action"),process.exit(1)),zo(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${Pt.join(", ")}`),process.exit(1)),s||(console.error("Error: value is required for set action"),process.exit(1)),ne.set(o,s),console.log(`Set ${o}=${s}`);return}if(t==="unset"){o||(console.error("Error: key is required for unset action"),process.exit(1)),zo(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${Pt.join(", ")}`),process.exit(1)),ne.unset(o),console.log(`Unset ${o}`);return}console.error(`Unknown action: ${t}`),process.exit(1)}function ws(){let e=Me();return vt(Zr,{flexDirection:"column",children:[je(Ne,{bold:!0,children:"entrydesk config"}),je(Ne,{children:" "}),je(Ne,{children:"Manage CLI configuration"}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Usage:"}),je(Ne,{children:" entrydesk config List all configuration"}),vt(Ne,{children:[" entrydesk config get ","<key>"," Get a configuration value"]}),vt(Ne,{children:[" ","entrydesk config set ","<key>"," ","<value>"," Set a configuration value"]}),vt(Ne,{children:[" ","entrydesk config unset ","<key>"," Remove a configuration value"]}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Available keys:"}),vt(Ne,{children:[" apiUrl API server URL (default: ",e.apiUrl,")"]}),vt(Ne,{children:[" hubUrl Hub server URL (default: ",e.hubUrl,")"]}),je(Ne,{children:" "}),je(Ne,{bold:!0,children:"Examples:"}),je(Ne,{children:" entrydesk config set apiUrl http://localhost:3200"}),je(Ne,{children:" entrydesk config get apiUrl"}),je(Ne,{children:" entrydesk config unset apiUrl"})]})}async function ks(e){try{let t,o;try{let i=await pe();t=i.accessToken,o=i.workspaceId}catch(i){let r=i instanceof Error?i.message:"Authentication failed";console.error(r),process.exit(1)}let s=new B,{connectors:n}=await s.getConnectors(t,o);if(e.json){console.log(JSON.stringify(n));return}if(n.length===0){console.log("No connectors found in this workspace.");return}console.log(`Connected Connectors (${n.length}):
235
+ `);for(let i of n){let r=i.connected?"connected":"disconnected";console.log(` ${i.name} (${r})`),console.log(` Provider: ${i.provider}`),console.log(` ID: ${i.id}`),console.log("")}}catch(t){xe(t)}}function ko(){console.log(`
236
236
  EntryDesk CLI - Interact with EntryDesk from your terminal
237
237
 
238
238
  Usage: entrydesk <command> [options]
@@ -400,11 +400,11 @@ Local Development:
400
400
  $ entrydesk config set hubUrl http://localhost:3000
401
401
 
402
402
  For more information, visit https://entrydesk.com/docs/cli
403
- `)}import{render as Yr}from"ink";import{randomUUID as Mr}from"crypto";import{chromium as Jr}from"playwright";function Gr(e){return e==="localhost"||e==="127.0.0.1"||e==="::1"||e==="0.0.0.0"}function Hr(e){let t;try{t=new URL(e)}catch{throw new Error("Invalid hub URL. Please check ENTRYDESK_HUB_URL.")}if(t.protocol!=="https:"&&t.protocol!=="http:")throw new Error("Hub URL must use http or https.");if(t.username||t.password)throw new Error("Hub URL must not include credentials.");if(!t.hostname)throw new Error("Hub URL must include a hostname.");if(t.protocol==="http:"&&!Gr(t.hostname))throw new Error("Hub URL must use https unless running on localhost.");return t}function Vr(e){try{let t=e.split(".");if(t.length<2)return null;let n=t[1].replace(/-/g,"+").replace(/_/g,"/"),s=(4-n.length%4)%4,o=n.padEnd(n.length+s,"="),i=Buffer.from(o,"base64").toString("utf8");return JSON.parse(i).exp??null}catch{return null}}async function qo(e){let{hubUrl:t,auth:n}=Me(),s=Hr(t),o=new URL("/login",s),i=Mr();o.searchParams.set("cli","true"),o.searchParams.set("state",i);let r;try{r=await Jr.launch({headless:!1,args:["--disable-blink-features=AutomationControlled"]})}catch(a){throw a instanceof Error&&a.message.includes("Executable")?new Error(`Chromium browser is not installed. Please run:
403
+ `)}import{render as ai}from"ink";import{randomUUID as Qr}from"crypto";import{chromium as ei}from"playwright";function ti(e){return e==="localhost"||e==="127.0.0.1"||e==="::1"||e==="0.0.0.0"}function oi(e){let t;try{t=new URL(e)}catch{throw new Error("Invalid hub URL. Please check ENTRYDESK_HUB_URL.")}if(t.protocol!=="https:"&&t.protocol!=="http:")throw new Error("Hub URL must use http or https.");if(t.username||t.password)throw new Error("Hub URL must not include credentials.");if(!t.hostname)throw new Error("Hub URL must include a hostname.");if(t.protocol==="http:"&&!ti(t.hostname))throw new Error("Hub URL must use https unless running on localhost.");return t}function ni(e){try{let t=e.split(".");if(t.length<2)return null;let o=t[1].replace(/-/g,"+").replace(/_/g,"/"),s=(4-o.length%4)%4,n=o.padEnd(o.length+s,"="),i=Buffer.from(n,"base64").toString("utf8");return JSON.parse(i).exp??null}catch{return null}}async function Yo(e){let{hubUrl:t,auth:o}=Me(),s=oi(t),n=new URL("/login",s),i=Qr();n.searchParams.set("cli","true"),n.searchParams.set("state",i);let r;try{r=await ei.launch({headless:!1,args:["--disable-blink-features=AutomationControlled"]})}catch(a){throw a instanceof Error&&a.message.includes("Executable")?new Error(`Chromium browser is not installed. Please run:
404
404
  npm install -g playwright
405
- npx playwright install chromium --with-deps`,{cause:a}):a}try{let l=await(await r.newContext({viewport:{width:1280,height:800},ignoreHTTPSErrors:n.ignoreSslErrors})).newPage();process.env.DEBUG&&l.on("console",m=>{console.log(`[Browser Console] ${m.type()}: ${m.text()}`)}),e?.onBrowserOpen?.(),await l.goto(o.toString(),{waitUntil:"networkidle"}),e?.onWaitingForLogin?.();let d=s.host;await l.waitForURL(m=>{let h=new URL(m);if(h.host!==d)return!1;let S=h.pathname;if(S==="/login"||S.startsWith("/auth/"))return!1;let O=h.searchParams.get("state");return!(O&&O!==i)},{timeout:n.loginTimeout});let I=new URL("/api/auth/session",s).toString();process.env.DEBUG&&(console.log(`[DEBUG] Fetching session from: ${I}`),console.log(`[DEBUG] Current page URL: ${l.url()}`),console.log(`[DEBUG] SSL ignore enabled: ${n.ignoreSslErrors}`));let x=await l.evaluate(async m=>{try{let h=await fetch(m);if(!h.ok)throw new Error(`Failed to fetch session: ${h.status} ${h.statusText}`);return h.json()}catch(h){throw console.error("[Browser Context] Fetch error:",h),h}},I);if(!x?.accessToken)throw new Error("Failed to get access token from session");let b=Vr(x.accessToken);if(b&&b*1e3<=Date.now())throw new Error("Access token is expired. Please log in again.");let C=x.user?.email||"";return e?.onLoginSuccess?.(C||"unknown"),{accessToken:x.accessToken,email:C,workspaceId:x.currentWorkspaceId}}catch(a){let l;throw a instanceof Error?(l=a,l.message.includes("fetch failed")&&(l=new Error(`Network request failed. This might be due to SSL certificate issues. Current SSL ignore setting: ${n.ignoreSslErrors}. Original error: ${l.message}`))):l=new Error("Browser authentication failed."),e?.onError?.(l),l}finally{await r.close()}}import{Box as Ee,Text as Le,useApp as Kr,useInput as qr}from"ink";import zr from"ink-spinner";import hs from"ink-text-input";import{useState as Wt}from"react";import{jsx as ge,jsxs as Ge}from"react/jsx-runtime";function ys(){let{exit:e}=Kr(),[t,n]=Wt("email"),[s,o]=Wt(""),[i,r]=Wt(""),[a,l]=Wt(null),[d,I]=Wt(null);return qr((C,m)=>{m.escape&&e()}),Ge(Ee,{flexDirection:"column",padding:1,children:[ge(Ee,{marginBottom:1,children:ge(Le,{bold:!0,color:"cyan",children:"EntryDesk Login"})}),t==="email"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{children:"Email: "}),ge(hs,{value:s,onChange:o,onSubmit:C=>{if(!C.includes("@")){l("Please enter a valid email address");return}o(C),l(null),n("password")},placeholder:"user@example.com"})]}),a&&ge(Ee,{marginTop:1,children:ge(Le,{color:"red",children:a})}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Press Enter to continue, Esc to cancel"})})]}),t==="password"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{children:"Email: "}),ge(Le,{color:"green",children:s})]}),Ge(Ee,{children:[ge(Le,{children:"Password: "}),ge(hs,{value:i,onChange:r,onSubmit:async C=>{r(C),n("loading"),l(null);try{let m=new B,{token:h,refreshToken:S}=await m.login(s,C),{workspaces:O}=await m.getWorkspaces(h),V=O[0];await $e.saveAll({accessToken:h,refreshToken:S,email:s,workspaceId:V?.id}),I(V?.name??null),n("success"),setTimeout(()=>{e()},1500)}catch(m){n("error"),m instanceof Error?m.message.includes("403")||m.message.includes("Invalid")?l("Invalid email or password"):l(m.message):l("Login failed. Please try again.")}},mask:"*",placeholder:"Enter password"})]}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Press Enter to login, Esc to cancel"})})]}),t==="loading"&&Ge(Ee,{children:[ge(Le,{color:"cyan",children:ge(zr,{type:"dots"})}),ge(Le,{children:" Logging in..."})]}),t==="success"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{color:"green",children:"\u2713"}),ge(Le,{children:" Logged in as "}),ge(Le,{bold:!0,children:s})]}),d&&ge(Ee,{children:Ge(Le,{dimColor:!0,children:["Workspace: ",d]})})]}),t==="error"&&Ge(Ee,{flexDirection:"column",children:[ge(Ee,{children:ge(Le,{color:"red",children:"\u2717 Login failed"})}),a&&ge(Ee,{children:ge(Le,{color:"red",children:a})}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Run `entrydesk login` to try again"})})]})]})}import{jsx as Xr}from"react/jsx-runtime";async function ws(e){if(!!(e.email||e.password)){(!e.email||!e.password)&&(console.error("Usage: entrydesk login --email <email> --password <password>"),console.error(" entrydesk login"),console.error(" entrydesk login --google"),console.error(" entrydesk login -i (interactive mode)"),process.exit(1));let a=new B,{token:l,refreshToken:d}=await a.login(e.email,e.password),{workspaces:I}=await a.getWorkspaces(l),x=I[0];await $e.saveAll({accessToken:l,refreshToken:d,email:e.email,workspaceId:x?.id}),e.json?console.log(JSON.stringify({email:e.email,workspaceId:x?.id,workspaceName:x?.name})):(console.log(`Logged in as ${e.email}`),x&&console.log(`Workspace: ${x.name}`));return}if(e.google){console.log("Opening browser for Google OAuth...");let a=await qo(),l=new B,{workspaces:d}=await l.getWorkspaces(a.accessToken),I=d[0],x=a.workspaceId||I?.id;await $e.saveAll({accessToken:a.accessToken,refreshToken:"",email:a.email,workspaceId:x}),e.json?console.log(JSON.stringify({email:a.email,workspaceId:x,workspaceName:I?.name})):(console.log(`Logged in as ${a.email}`),I&&console.log(`Workspace: ${I.name}`));return}if(e.interactive){Yr(Xr(ys,{}));return}if(console.log("Opening browser for login..."),process.env.DEBUG){let{getApiUrl:a,getHubUrl:l}=await import("./config-LX73PV6D.js");console.log(`[DEBUG] Hub URL: ${l()}`),console.log(`[DEBUG] API URL: ${a()}`)}let n=await qo(),s=new B,{workspaces:o}=await s.getWorkspaces(n.accessToken),i=o[0],r=n.workspaceId||i?.id;await $e.saveAll({accessToken:n.accessToken,refreshToken:"",email:n.email,workspaceId:r}),e.json?console.log(JSON.stringify({email:n.email,workspaceId:r,workspaceName:i?.name})):(console.log(`Logged in as ${n.email}`),i&&console.log(`Workspace: ${i.name}`))}async function ks(e){try{let t=await $e.getAll();if(!t){console.log("Not logged in");return}try{await new B().revokeToken(t.refreshToken)}catch{}await $e.clear(),console.log("Logged out successfully")}catch(t){xe(t)}}import Zr from"http";import{Client as Qr}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as ei}from"@modelcontextprotocol/sdk/client/streamableHttp.js";import{Server as ti}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as oi}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as ni}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{CallToolRequestSchema as si,ListToolsRequestSchema as ri}from"@modelcontextprotocol/sdk/types.js";async function ii(e,t,n){let s=new Qr({name:"entrydesk-cli-proxy",version:"1.0.0"}),o=new URL(`${e}/v1/workspaces/${n}/mcp`),i=new ei(o,{requestInit:{headers:{Authorization:`Bearer ${t}`}}});return await s.connect(i),s}function xs(e){let t=new ti({name:"entrydesk-cli",version:"1.0.0"},{capabilities:{tools:{}}});return t.setRequestHandler(ri,async()=>({tools:(await e.listTools()).tools})),t.setRequestHandler(si,async n=>{let{name:s,arguments:o}=n.params,i=await e.callTool({name:s,arguments:o});return{content:i.content,isError:i.isError}}),t}async function ai(e,t){let n=Zr.createServer(async(s,o)=>{if(s.method==="OPTIONS"){o.setHeader("Access-Control-Allow-Origin","*"),o.setHeader("Access-Control-Allow-Methods","GET, POST, DELETE, OPTIONS"),o.setHeader("Access-Control-Allow-Headers","Content-Type, Accept"),o.writeHead(204),o.end();return}if(s.url!=="/mcp"){o.writeHead(404,{"Content-Type":"application/json"}),o.end(JSON.stringify({error:"Not found"}));return}let i=xs(e),r=new ni({sessionIdGenerator:void 0});if(o.setHeader("Access-Control-Allow-Origin","*"),o.on("close",()=>{r.close(),i.close()}),await i.connect(r),s.method==="POST"){let a="";s.on("data",l=>{a+=l.toString()}),s.on("end",async()=>{try{let l=JSON.parse(a);await r.handleRequest(s,o,l)}catch{o.writeHead(400,{"Content-Type":"application/json"}),o.end(JSON.stringify({error:"Invalid JSON"}))}})}else await r.handleRequest(s,o)});n.listen(t,()=>{console.error(`EntryDesk MCP server running at http://localhost:${t}/mcp`),console.error("Press Ctrl+C to stop")}),process.on("SIGINT",async()=>{console.error(`
406
- Shutting down...`),n.close(),await e.close(),process.exit(0)}),process.on("SIGTERM",async()=>{n.close(),await e.close(),process.exit(0)})}async function li(e){let t=xs(e),n=new oi;n.onclose=async()=>{await e.close()},await t.connect(n)}async function bs(e={mode:"stdio"}){process.on("unhandledRejection",t=>{console.error("[entrydesk-mcp] Unhandled rejection:",t)}),process.on("uncaughtException",t=>{console.error("[entrydesk-mcp] Uncaught exception:",t)});try{console.error("[entrydesk-mcp] Starting MCP server...");let t,n;try{let r=await pe();t=r.accessToken,n=r.workspaceId}catch(r){let a=r instanceof Error?r.message:"Authentication failed";console.error(a),process.exit(1)}let{apiUrl:s,mcp:o}=Me();console.error(`[entrydesk-mcp] Connecting to ${s}...`),console.error(`[entrydesk-mcp] Workspace: ${n}`);let i=await ii(s,t,n);if(console.error("[entrydesk-mcp] Connected to EntryDesk API"),e.mode==="http"){let r=e.port||o.httpPort;await ai(i,r)}else console.error("[entrydesk-mcp] Starting stdio server..."),await li(i),console.error("[entrydesk-mcp] Stdio server started")}catch(t){console.error("[entrydesk-mcp] Fatal error:",t),process.exit(1)}}async function Cs(e){try{let t,n;try{let i=await pe();t=i.accessToken,n=i.workspaceId}catch(i){let r=i instanceof Error?i.message:"Authentication failed";console.error(r),process.exit(1)}let s=new B,{models:o}=await s.getModels(t,n);if(e.json){console.log(JSON.stringify(o));return}if(o.length===0){console.log("No models available in this workspace.");return}console.log(`Available Models (${o.length}):
407
- `);for(let i of o)console.log(` ${i.name}`),i.description&&console.log(` ${i.description.slice(0,80)}`),console.log(` ID: ${i.id}`),console.log("")}catch(t){xe(t)}}function ci(){console.log(`
405
+ npx playwright install chromium --with-deps`,{cause:a}):a}try{let l=await(await r.newContext({viewport:{width:1280,height:800},ignoreHTTPSErrors:o.ignoreSslErrors})).newPage();process.env.DEBUG&&l.on("console",m=>{console.log(`[Browser Console] ${m.type()}: ${m.text()}`)}),e?.onBrowserOpen?.(),await l.goto(n.toString(),{waitUntil:"networkidle"}),e?.onWaitingForLogin?.();let d=s.host;await l.waitForURL(m=>{let h=new URL(m);if(h.host!==d)return!1;let T=h.pathname;if(T==="/login"||T.startsWith("/auth/"))return!1;let O=h.searchParams.get("state");return!(O&&O!==i)},{timeout:o.loginTimeout});let $=new URL("/api/auth/session",s).toString();process.env.DEBUG&&(console.log(`[DEBUG] Fetching session from: ${$}`),console.log(`[DEBUG] Current page URL: ${l.url()}`),console.log(`[DEBUG] SSL ignore enabled: ${o.ignoreSslErrors}`));let x=await l.evaluate(async m=>{try{let h=await fetch(m);if(!h.ok)throw new Error(`Failed to fetch session: ${h.status} ${h.statusText}`);return h.json()}catch(h){throw console.error("[Browser Context] Fetch error:",h),h}},$);if(!x?.accessToken)throw new Error("Failed to get access token from session");let b=ni(x.accessToken);if(b&&b*1e3<=Date.now())throw new Error("Access token is expired. Please log in again.");let C=x.user?.email||"";return e?.onLoginSuccess?.(C||"unknown"),{accessToken:x.accessToken,email:C,workspaceId:x.currentWorkspaceId}}catch(a){let l;throw a instanceof Error?(l=a,l.message.includes("fetch failed")&&(l=new Error(`Network request failed. This might be due to SSL certificate issues. Current SSL ignore setting: ${o.ignoreSslErrors}. Original error: ${l.message}`))):l=new Error("Browser authentication failed."),e?.onError?.(l),l}finally{await r.close()}}import{Box as Ee,Text as Le,useApp as si,useInput as ri}from"ink";import ii from"ink-spinner";import xs from"ink-text-input";import{useState as Mt}from"react";import{jsx as ge,jsxs as Ge}from"react/jsx-runtime";function bs(){let{exit:e}=si(),[t,o]=Mt("email"),[s,n]=Mt(""),[i,r]=Mt(""),[a,l]=Mt(null),[d,$]=Mt(null);return ri((C,m)=>{m.escape&&e()}),Ge(Ee,{flexDirection:"column",padding:1,children:[ge(Ee,{marginBottom:1,children:ge(Le,{bold:!0,color:"cyan",children:"EntryDesk Login"})}),t==="email"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{children:"Email: "}),ge(xs,{value:s,onChange:n,onSubmit:C=>{if(!C.includes("@")){l("Please enter a valid email address");return}n(C),l(null),o("password")},placeholder:"user@example.com"})]}),a&&ge(Ee,{marginTop:1,children:ge(Le,{color:"red",children:a})}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Press Enter to continue, Esc to cancel"})})]}),t==="password"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{children:"Email: "}),ge(Le,{color:"green",children:s})]}),Ge(Ee,{children:[ge(Le,{children:"Password: "}),ge(xs,{value:i,onChange:r,onSubmit:async C=>{r(C),o("loading"),l(null);try{let m=new B,{token:h,refreshToken:T}=await m.login(s,C),{workspaces:O}=await m.getWorkspaces(h),V=O[0];await $e.saveAll({accessToken:h,refreshToken:T,email:s,workspaceId:V?.id}),$(V?.name??null),o("success"),setTimeout(()=>{e()},1500)}catch(m){o("error"),m instanceof Error?m.message.includes("403")||m.message.includes("Invalid")?l("Invalid email or password"):l(m.message):l("Login failed. Please try again.")}},mask:"*",placeholder:"Enter password"})]}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Press Enter to login, Esc to cancel"})})]}),t==="loading"&&Ge(Ee,{children:[ge(Le,{color:"cyan",children:ge(ii,{type:"dots"})}),ge(Le,{children:" Logging in..."})]}),t==="success"&&Ge(Ee,{flexDirection:"column",children:[Ge(Ee,{children:[ge(Le,{color:"green",children:"\u2713"}),ge(Le,{children:" Logged in as "}),ge(Le,{bold:!0,children:s})]}),d&&ge(Ee,{children:Ge(Le,{dimColor:!0,children:["Workspace: ",d]})})]}),t==="error"&&Ge(Ee,{flexDirection:"column",children:[ge(Ee,{children:ge(Le,{color:"red",children:"\u2717 Login failed"})}),a&&ge(Ee,{children:ge(Le,{color:"red",children:a})}),ge(Ee,{marginTop:1,children:ge(Le,{dimColor:!0,children:"Run `entrydesk login` to try again"})})]})]})}import{jsx as li}from"react/jsx-runtime";async function Cs(e){if(!!(e.email||e.password)){(!e.email||!e.password)&&(console.error("Usage: entrydesk login --email <email> --password <password>"),console.error(" entrydesk login"),console.error(" entrydesk login --google"),console.error(" entrydesk login -i (interactive mode)"),process.exit(1));let a=new B,{token:l,refreshToken:d}=await a.login(e.email,e.password),{workspaces:$}=await a.getWorkspaces(l),x=$[0];await $e.saveAll({accessToken:l,refreshToken:d,email:e.email,workspaceId:x?.id}),e.json?console.log(JSON.stringify({email:e.email,workspaceId:x?.id,workspaceName:x?.name})):(console.log(`Logged in as ${e.email}`),x&&console.log(`Workspace: ${x.name}`));return}if(e.google){console.log("Opening browser for Google OAuth...");let a=await Yo(),l=new B,{workspaces:d}=await l.getWorkspaces(a.accessToken),$=d[0],x=a.workspaceId||$?.id;await $e.saveAll({accessToken:a.accessToken,refreshToken:"",email:a.email,workspaceId:x}),e.json?console.log(JSON.stringify({email:a.email,workspaceId:x,workspaceName:$?.name})):(console.log(`Logged in as ${a.email}`),$&&console.log(`Workspace: ${$.name}`));return}if(e.interactive){ai(li(bs,{}));return}if(console.log("Opening browser for login..."),process.env.DEBUG){let{getApiUrl:a,getHubUrl:l}=await import("./config-LX73PV6D.js");console.log(`[DEBUG] Hub URL: ${l()}`),console.log(`[DEBUG] API URL: ${a()}`)}let o=await Yo(),s=new B,{workspaces:n}=await s.getWorkspaces(o.accessToken),i=n[0],r=o.workspaceId||i?.id;await $e.saveAll({accessToken:o.accessToken,refreshToken:"",email:o.email,workspaceId:r}),e.json?console.log(JSON.stringify({email:o.email,workspaceId:r,workspaceName:i?.name})):(console.log(`Logged in as ${o.email}`),i&&console.log(`Workspace: ${i.name}`))}async function $s(e){try{let t=await $e.getAll();if(!t){console.log("Not logged in");return}try{await new B().revokeToken(t.refreshToken)}catch{}await $e.clear(),console.log("Logged out successfully")}catch(t){xe(t)}}import ci from"http";import{Client as ui}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as di}from"@modelcontextprotocol/sdk/client/streamableHttp.js";import{Server as fi}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as pi}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as mi}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{CallToolRequestSchema as gi,ListToolsRequestSchema as hi}from"@modelcontextprotocol/sdk/types.js";async function yi(e,t,o){let s=new ui({name:"entrydesk-cli-proxy",version:"1.0.0"}),n=new URL(`${e}/v1/workspaces/${o}/mcp`),i=new di(n,{requestInit:{headers:{Authorization:`Bearer ${t}`}}});return await s.connect(i),s}function Ss(e){let t=new fi({name:"entrydesk-cli",version:"1.0.0"},{capabilities:{tools:{}}});return t.setRequestHandler(hi,async()=>({tools:(await e.listTools()).tools})),t.setRequestHandler(gi,async o=>{let{name:s,arguments:n}=o.params,i=await e.callTool({name:s,arguments:n});return{content:i.content,isError:i.isError}}),t}async function wi(e,t){let o=ci.createServer(async(s,n)=>{if(s.method==="OPTIONS"){n.setHeader("Access-Control-Allow-Origin","*"),n.setHeader("Access-Control-Allow-Methods","GET, POST, DELETE, OPTIONS"),n.setHeader("Access-Control-Allow-Headers","Content-Type, Accept"),n.writeHead(204),n.end();return}if(s.url!=="/mcp"){n.writeHead(404,{"Content-Type":"application/json"}),n.end(JSON.stringify({error:"Not found"}));return}let i=Ss(e),r=new mi({sessionIdGenerator:void 0});if(n.setHeader("Access-Control-Allow-Origin","*"),n.on("close",()=>{r.close(),i.close()}),await i.connect(r),s.method==="POST"){let a="";s.on("data",l=>{a+=l.toString()}),s.on("end",async()=>{try{let l=JSON.parse(a);await r.handleRequest(s,n,l)}catch{n.writeHead(400,{"Content-Type":"application/json"}),n.end(JSON.stringify({error:"Invalid JSON"}))}})}else await r.handleRequest(s,n)});o.listen(t,()=>{console.error(`EntryDesk MCP server running at http://localhost:${t}/mcp`),console.error("Press Ctrl+C to stop")}),process.on("SIGINT",async()=>{console.error(`
406
+ Shutting down...`),o.close(),await e.close(),process.exit(0)}),process.on("SIGTERM",async()=>{o.close(),await e.close(),process.exit(0)})}async function ki(e){let t=Ss(e),o=new pi;o.onclose=async()=>{await e.close()},await t.connect(o)}async function Ts(e={mode:"stdio"}){process.on("unhandledRejection",t=>{console.error("[entrydesk-mcp] Unhandled rejection:",t)}),process.on("uncaughtException",t=>{console.error("[entrydesk-mcp] Uncaught exception:",t)});try{console.error("[entrydesk-mcp] Starting MCP server...");let t,o;try{let r=await pe();t=r.accessToken,o=r.workspaceId}catch(r){let a=r instanceof Error?r.message:"Authentication failed";console.error(a),process.exit(1)}let{apiUrl:s,mcp:n}=Me();console.error(`[entrydesk-mcp] Connecting to ${s}...`),console.error(`[entrydesk-mcp] Workspace: ${o}`);let i=await yi(s,t,o);if(console.error("[entrydesk-mcp] Connected to EntryDesk API"),e.mode==="http"){let r=e.port||n.httpPort;await wi(i,r)}else console.error("[entrydesk-mcp] Starting stdio server..."),await ki(i),console.error("[entrydesk-mcp] Stdio server started")}catch(t){console.error("[entrydesk-mcp] Fatal error:",t),process.exit(1)}}async function Is(e){try{let t,o;try{let i=await pe();t=i.accessToken,o=i.workspaceId}catch(i){let r=i instanceof Error?i.message:"Authentication failed";console.error(r),process.exit(1)}let s=new B,{models:n}=await s.getModels(t,o);if(e.json){console.log(JSON.stringify(n));return}if(n.length===0){console.log("No models available in this workspace.");return}console.log(`Available Models (${n.length}):
407
+ `);for(let i of n)console.log(` ${i.name}`),i.description&&console.log(` ${i.description.slice(0,80)}`),console.log(` ID: ${i.id}`),console.log("")}catch(t){xe(t)}}function xi(){console.log(`
408
408
  Usage: entrydesk profile [list|show|current|create|use|delete|rename|clone] [args]
409
409
 
410
410
  Commands:
@@ -419,7 +419,7 @@ Commands:
419
419
 
420
420
  Flags:
421
421
  --json Output JSON
422
- `)}function Mt(e,t){if(e)return e;if(t&&H.getProfileCount()===1)return H.getProfileNames()[0];throw new Et("Profile name is required when multiple profiles exist.")}function ui(e){if(!e)return"none";let t=[];return e.sandbox&&t.push("sandbox"),e.webSearch&&t.push("webSearch"),e.imageGeneration&&t.push("imageGeneration"),e.chart&&t.push("chart"),t.length>0?t.join(", "):"none"}async function $s(e){try{let t=e.action||"list",n=H.getCurrentProfileName(),s=e.name??e.profile,o=e.value;if(e.help||t==="help"){ci();return}if(t==="list"){let i=H.getProfileNames();if(e.json){console.log(JSON.stringify({currentProfile:n,profiles:i.map(r=>({name:r,isCurrent:r===n}))}));return}console.log(`Profiles (${i.length}):`);for(let r of i)console.log(` ${r}${r===n?" (current)":""}`);return}if(t==="current"){if(e.json){console.log(JSON.stringify({name:n,isCurrent:!0}));return}console.log(`Current profile: ${n}`);return}if(t==="show"){let i=Mt(s,!0),r=ne.getAll(i),a=await $e.getAll(i),l=!!a?.accessToken;if(e.json){console.log(JSON.stringify({name:i,isCurrent:i===n,config:r,auth:l?{loggedIn:!0,email:a?.email??null,workspaceId:a?.workspaceId??null}:{loggedIn:!1}}));return}console.log(`Profile: ${i}${i===n?" (current)":""}`),console.log(` API URL: ${r.apiUrl??"default"}`),console.log(` Hub URL: ${r.hubUrl??"default"}`),console.log(` Model: ${r.model?.default??"unset"}`);let d=r.connectors?.defaults&&r.connectors.defaults.length>0?r.connectors.defaults.join(", "):"unset";console.log(` Connectors: ${d}`),console.log(` Capabilities: ${ui(r.capabilities)}`),console.log(l?` Logged in as: ${a?.email??"unknown"}`:" Not logged in"),l&&a?.workspaceId&&console.log(` Workspace ID: ${a.workspaceId}`);return}if(t==="create"){let i=s||H.DEFAULT_PROFILE;if(H.createProfile(i),e.json){console.log(JSON.stringify({name:i,created:!0}));return}console.log(`Profile created: ${i}`);return}if(t==="use"||t==="switch"){let i=Mt(s,!0);if(H.setCurrentProfile(i),e.json){console.log(JSON.stringify({name:i,current:!0}));return}console.log(`Switched to profile: ${i}`);return}if(t==="delete"||t==="remove"||t==="rm"){let i=Mt(s,!0),r=H.deleteProfile(i);if(e.json){console.log(JSON.stringify({deleted:i,currentProfile:r.currentProfile}));return}console.log(`Profile deleted: ${i}`),console.log(`Current profile: ${r.currentProfile}`);return}if(t==="rename"||t==="move"||t==="mv"){let i=Mt(s,!0);if(!o)throw new Et("New profile name is required.");let r=H.renameProfile(i,o);if(e.json){console.log(JSON.stringify({renamed:i,name:o,currentProfile:r.currentProfile}));return}console.log(`Profile renamed: ${i} -> ${o}`),console.log(`Current profile: ${r.currentProfile}`);return}if(t==="clone"||t==="copy"){let i=Mt(s,!0);if(!o)throw new Et("Target profile name is required.");let r=ne.getAll(i);if(H.createProfile(o),ne.setAll(r,o),await $e.clear(o),e.json){console.log(JSON.stringify({source:i,name:o,cloned:!0}));return}console.log(`Profile cloned: ${i} -> ${o}`);return}throw new Et(`Unknown profile command: ${t}`)}catch(t){xe(t)}}function Jt(){console.log(`
422
+ `)}function Jt(e,t){if(e)return e;if(t&&H.getProfileCount()===1)return H.getProfileNames()[0];throw new _t("Profile name is required when multiple profiles exist.")}function bi(e){if(!e)return"none";let t=[];return e.sandbox&&t.push("sandbox"),e.webSearch&&t.push("webSearch"),e.imageGeneration&&t.push("imageGeneration"),e.chart&&t.push("chart"),t.length>0?t.join(", "):"none"}async function vs(e){try{let t=e.action||"list",o=H.getCurrentProfileName(),s=e.name??e.profile,n=e.value;if(e.help||t==="help"){xi();return}if(t==="list"){let i=H.getProfileNames();if(e.json){console.log(JSON.stringify({currentProfile:o,profiles:i.map(r=>({name:r,isCurrent:r===o}))}));return}console.log(`Profiles (${i.length}):`);for(let r of i)console.log(` ${r}${r===o?" (current)":""}`);return}if(t==="current"){if(e.json){console.log(JSON.stringify({name:o,isCurrent:!0}));return}console.log(`Current profile: ${o}`);return}if(t==="show"){let i=Jt(s,!0),r=ne.getAll(i),a=await $e.getAll(i),l=!!a?.accessToken;if(e.json){console.log(JSON.stringify({name:i,isCurrent:i===o,config:r,auth:l?{loggedIn:!0,email:a?.email??null,workspaceId:a?.workspaceId??null}:{loggedIn:!1}}));return}console.log(`Profile: ${i}${i===o?" (current)":""}`),console.log(` API URL: ${r.apiUrl??"default"}`),console.log(` Hub URL: ${r.hubUrl??"default"}`),console.log(` Model: ${r.model?.default??"unset"}`);let d=r.connectors?.defaults&&r.connectors.defaults.length>0?r.connectors.defaults.join(", "):"unset";console.log(` Connectors: ${d}`),console.log(` Capabilities: ${bi(r.capabilities)}`),console.log(l?` Logged in as: ${a?.email??"unknown"}`:" Not logged in"),l&&a?.workspaceId&&console.log(` Workspace ID: ${a.workspaceId}`);return}if(t==="create"){let i=s||H.DEFAULT_PROFILE;if(H.createProfile(i),e.json){console.log(JSON.stringify({name:i,created:!0}));return}console.log(`Profile created: ${i}`);return}if(t==="use"||t==="switch"){let i=Jt(s,!0);if(H.setCurrentProfile(i),e.json){console.log(JSON.stringify({name:i,current:!0}));return}console.log(`Switched to profile: ${i}`);return}if(t==="delete"||t==="remove"||t==="rm"){let i=Jt(s,!0),r=H.deleteProfile(i);if(e.json){console.log(JSON.stringify({deleted:i,currentProfile:r.currentProfile}));return}console.log(`Profile deleted: ${i}`),console.log(`Current profile: ${r.currentProfile}`);return}if(t==="rename"||t==="move"||t==="mv"){let i=Jt(s,!0);if(!n)throw new _t("New profile name is required.");let r=H.renameProfile(i,n);if(e.json){console.log(JSON.stringify({renamed:i,name:n,currentProfile:r.currentProfile}));return}console.log(`Profile renamed: ${i} -> ${n}`),console.log(`Current profile: ${r.currentProfile}`);return}if(t==="clone"||t==="copy"){let i=Jt(s,!0);if(!n)throw new _t("Target profile name is required.");let r=ne.getAll(i);if(H.createProfile(n),ne.setAll(r,n),await $e.clear(n),e.json){console.log(JSON.stringify({source:i,name:n,cloned:!0}));return}console.log(`Profile cloned: ${i} -> ${n}`);return}throw new _t(`Unknown profile command: ${t}`)}catch(t){xe(t)}}function Gt(){console.log(`
423
423
  Usage: entrydesk schedules [list|get|create|delete] [options]
424
424
 
425
425
  Commands:
@@ -445,7 +445,7 @@ Create Options:
445
445
 
446
446
  Flags:
447
447
  --json Output JSON
448
- `)}function Ss(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} minute${t.every>1?"s":""}`;case"hours":return`Every ${t.every} hour${t.every>1?"s":""} at :${String(t.minute).padStart(2,"0")}`;case"days":return`Every ${t.every} day${t.every>1?"s":""} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":{let n=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],s=t.daysOfWeek.map(o=>n[o]).join(", ");return`Every ${t.every} week${t.every>1?"s":""} on ${s} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`}case"months":{let n=t.lastDayOfMonth?t.daysOfMonth.length>0?`${t.daysOfMonth.join(", ")} and last day`:"last day":t.daysOfMonth.join(", ");return`Every ${t.every} month${t.every>1?"s":""} on day ${n} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`}default:return"Unknown"}}function Gt(e,t){let n=new Date(e),s=t.match(/^([+-])(\d{2}):(\d{2})$/);if(!s)return n.toISOString();let o=s[1]==="+"?1:-1,i=parseInt(s[2],10),r=parseInt(s[3],10),a=o*(i*60+r)*60*1e3;return`${new Date(n.getTime()+a).toISOString().replace("T"," ").slice(0,19)} (${t})`}function di(e){console.log(`
448
+ `)}function Ps(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} minute${t.every>1?"s":""}`;case"hours":return`Every ${t.every} hour${t.every>1?"s":""} at :${String(t.minute).padStart(2,"0")}`;case"days":return`Every ${t.every} day${t.every>1?"s":""} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":{let o=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],s=t.daysOfWeek.map(n=>o[n]).join(", ");return`Every ${t.every} week${t.every>1?"s":""} on ${s} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`}case"months":{let o=t.lastDayOfMonth?t.daysOfMonth.length>0?`${t.daysOfMonth.join(", ")} and last day`:"last day":t.daysOfMonth.join(", ");return`Every ${t.every} month${t.every>1?"s":""} on day ${o} at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`}default:return"Unknown"}}function Ht(e,t){let o=new Date(e),s=t.match(/^([+-])(\d{2}):(\d{2})$/);if(!s)return o.toISOString();let n=s[1]==="+"?1:-1,i=parseInt(s[2],10),r=parseInt(s[3],10),a=n*(i*60+r)*60*1e3;return`${new Date(o.getTime()+a).toISOString().replace("T"," ").slice(0,19)} (${t})`}function Ci(e){console.log(`
449
449
  Schedule: ${e.name}
450
450
  ${"\u2501".repeat(50)}
451
451
  ID: ${e.id}
@@ -457,13 +457,13 @@ Prompt:
457
457
  ${e.prompt.slice(0,200)}${e.prompt.length>200?"...":""}
458
458
 
459
459
  Schedule:
460
- ${Ss(e.config)}
460
+ ${Ps(e.config)}
461
461
 
462
- Next Run: ${e.nextRunAt?Gt(e.nextRunAt,e.utcOffset):"-"}
463
- Created: ${Gt(e.createdAt,e.utcOffset)}
464
- Updated: ${Gt(e.updatedAt,e.utcOffset)}
465
- `)}function fi(e){let t=e.repeatType||"no-repeat";if(t==="no-repeat")return{type:"no-repeat"};let n=e.every||1,s=e.time||"09:00",[o,i]=s.split(":"),r={hour:parseInt(o,10),minute:parseInt(i,10)};switch(t){case"minutes":return{type:"repeat",interval:{unit:"minutes",every:n}};case"hours":return{type:"repeat",interval:{unit:"hours",every:n,minute:r.minute}};case"days":return{type:"repeat",interval:{unit:"days",every:n,time:r}};case"weeks":return{type:"repeat",interval:{unit:"weeks",every:n,daysOfWeek:e.daysOfWeek||[1],time:r}};case"months":return{type:"repeat",interval:{unit:"months",every:n,daysOfMonth:e.daysOfMonth||[1],lastDayOfMonth:e.lastDayOfMonth||!1,time:r}};default:return{type:"no-repeat"}}}async function Ts(e){try{if(e.help){Jt();return}let t=await pe(),{accessToken:n,workspaceId:s}=t,o=e.action||"list",i=new B;if(o==="get"){let l=e.scheduleId;l||(console.error("Missing schedule ID."),Jt(),process.exit(1));let d=await i.getSchedule(n,s,l);if(e.json){console.log(JSON.stringify(d));return}di(d);return}if(o==="create"){(!e.name||!e.prompt||!e.agentId||!e.startsAt)&&(console.error("Missing required fields for schedule creation."),console.error("Required: --name, --prompt, --agent-id, --starts-at"),Jt(),process.exit(1));let l={name:e.name,prompt:e.prompt,agentId:e.agentId,startsAt:e.startsAt,config:fi(e),utcOffset:e.utcOffset||"+00:00"},d=await i.createSchedule(n,s,l);if(e.json){console.log(JSON.stringify(d));return}console.log(`Created schedule: ${d.name}`),console.log(` ID: ${d.id}`),console.log(` Next Run: ${d.nextRunAt?Gt(d.nextRunAt,d.utcOffset):"-"}`);return}if(o==="delete"){let l=e.scheduleId;l||(console.error("Missing schedule ID."),Jt(),process.exit(1)),await i.deleteSchedule(n,s,l),console.log(`Deleted schedule: ${l}`);return}o!=="list"&&(console.error(`Unknown schedules command: ${o}`),Jt(),process.exit(1));let r=[],a;do{let l=await i.getSchedules(n,s,{nextKey:a,limit:100});r.push(...l.schedules),a=l.nextKey}while(a);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No schedules found in this workspace.");return}console.log(`Schedules (${r.length}):
466
- `);for(let l of r){let d=l.isActive?"\x1B[32mActive\x1B[0m":"\x1B[33mPaused\x1B[0m";console.log(` ${l.name}`),console.log(` Agent: ${l.agent.name}`),console.log(` Repeat: ${Ss(l.config)}`),console.log(` Status: ${d}`),console.log(` Next Run: ${l.nextRunAt?Gt(l.nextRunAt,l.utcOffset):"-"}`),console.log(` ID: ${l.id}`),console.log("")}}catch(t){xe(t)}}import pi from"fs";import At from"fs/promises";import Is from"os";import st from"path";import mi from"archiver";function zo(){console.log(`
462
+ Next Run: ${e.nextRunAt?Ht(e.nextRunAt,e.utcOffset):"-"}
463
+ Created: ${Ht(e.createdAt,e.utcOffset)}
464
+ Updated: ${Ht(e.updatedAt,e.utcOffset)}
465
+ `)}function $i(e){let t=e.repeatType||"no-repeat";if(t==="no-repeat")return{type:"no-repeat"};let o=e.every||1,s=e.time||"09:00",[n,i]=s.split(":"),r={hour:parseInt(n,10),minute:parseInt(i,10)};switch(t){case"minutes":return{type:"repeat",interval:{unit:"minutes",every:o}};case"hours":return{type:"repeat",interval:{unit:"hours",every:o,minute:r.minute}};case"days":return{type:"repeat",interval:{unit:"days",every:o,time:r}};case"weeks":return{type:"repeat",interval:{unit:"weeks",every:o,daysOfWeek:e.daysOfWeek||[1],time:r}};case"months":return{type:"repeat",interval:{unit:"months",every:o,daysOfMonth:e.daysOfMonth||[1],lastDayOfMonth:e.lastDayOfMonth||!1,time:r}};default:return{type:"no-repeat"}}}async function As(e){try{if(e.help){Gt();return}let t=await pe(),{accessToken:o,workspaceId:s}=t,n=e.action||"list",i=new B;if(n==="get"){let l=e.scheduleId;l||(console.error("Missing schedule ID."),Gt(),process.exit(1));let d=await i.getSchedule(o,s,l);if(e.json){console.log(JSON.stringify(d));return}Ci(d);return}if(n==="create"){(!e.name||!e.prompt||!e.agentId||!e.startsAt)&&(console.error("Missing required fields for schedule creation."),console.error("Required: --name, --prompt, --agent-id, --starts-at"),Gt(),process.exit(1));let l={name:e.name,prompt:e.prompt,agentId:e.agentId,startsAt:e.startsAt,config:$i(e),utcOffset:e.utcOffset||"+00:00"},d=await i.createSchedule(o,s,l);if(e.json){console.log(JSON.stringify(d));return}console.log(`Created schedule: ${d.name}`),console.log(` ID: ${d.id}`),console.log(` Next Run: ${d.nextRunAt?Ht(d.nextRunAt,d.utcOffset):"-"}`);return}if(n==="delete"){let l=e.scheduleId;l||(console.error("Missing schedule ID."),Gt(),process.exit(1)),await i.deleteSchedule(o,s,l),console.log(`Deleted schedule: ${l}`);return}n!=="list"&&(console.error(`Unknown schedules command: ${n}`),Gt(),process.exit(1));let r=[],a;do{let l=await i.getSchedules(o,s,{nextKey:a,limit:100});r.push(...l.schedules),a=l.nextKey}while(a);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No schedules found in this workspace.");return}console.log(`Schedules (${r.length}):
466
+ `);for(let l of r){let d=l.isActive?"\x1B[32mActive\x1B[0m":"\x1B[33mPaused\x1B[0m";console.log(` ${l.name}`),console.log(` Agent: ${l.agent.name}`),console.log(` Repeat: ${Ps(l.config)}`),console.log(` Status: ${d}`),console.log(` Next Run: ${l.nextRunAt?Ht(l.nextRunAt,l.utcOffset):"-"}`),console.log(` ID: ${l.id}`),console.log("")}}catch(t){xe(t)}}import Si from"fs";import At from"fs/promises";import Ns from"os";import st from"path";import Ti from"archiver";function Xo(){console.log(`
467
467
  Usage: entrydesk skills [list|upload|delete] [options]
468
468
 
469
469
  Commands:
@@ -476,11 +476,16 @@ Options:
476
476
  --me Only list skills created by me
477
477
  --force Overwrite an existing skill with the same name
478
478
  --json Output JSON (for list/upload)
479
- `)}function gi(e,t){let n=st.relative(e,t);return n===""||!n.startsWith("..")&&!st.isAbsolute(n)}async function hi(e){let t=await At.realpath(e),n=[process.cwd(),Is.homedir()];if(!(await Promise.all(n.map(async i=>{try{return await At.realpath(i)}catch{return st.resolve(i)}}))).some(i=>gi(i,t)))throw new Error("Invalid upload path: must be within the current directory or your home directory.")}async function yi(e){let t=await At.mkdtemp(st.join(Is.tmpdir(),"entrydesk-skill-")),n=st.join(t,`${st.basename(e)}.zip`);return await new Promise((s,o)=>{let i=pi.createWriteStream(n),r=mi("zip",{zlib:{level:9}});i.on("close",()=>s()),i.on("error",o),r.on("error",o),r.pipe(i),r.directory(e,!1),r.finalize()}),{zipPath:n,cleanupDir:t}}async function vs(e){let t,n;try{let a=await pe();t=a.accessToken,n=a.workspaceId}catch(a){xe(a)}let s=e.action||"list",o=new B;if(s==="upload"){let a=e.configKey;a||(console.error("Missing file path."),zo(),process.exit(1));let l=st.resolve(a),d;try{d=await At.stat(l)}catch{console.error(`File not found: ${l}`),process.exit(1)}let I=l,x=null;try{try{await hi(l)}catch(h){let S=h instanceof Error?h.message:"Invalid upload path.";console.error(S),process.exit(1)}if(d.isDirectory()){let h=await yi(l);I=h.zipPath,x=h.cleanupDir}else d.isFile()||(console.error(`Not a file or directory: ${l}`),process.exit(1));st.extname(I).toLowerCase()!==".zip"&&(console.error("Only .zip files are supported for upload."),process.exit(1));let b=await At.readFile(I),C=new FormData;C.append("file",new Blob([b],{type:"application/zip"}),st.basename(I)),e.force&&C.append("force","true");let m;try{m=await o.uploadSkill(t,n,C)}catch(h){if(h instanceof Error&&h.name==="HTTPError"){let S=h;S.response&&S.response.status===409&&(console.error("Upload failed: A skill with this name already exists."),console.error("Use --force to overwrite the existing skill."),process.exit(1))}throw h}if(e.json){console.log(JSON.stringify(m));return}console.log(`Uploaded skill: ${m.name}`),console.log(` ID: ${m.id}`),console.log(` Description: ${m.description}`);return}finally{x&&await At.rm(x,{recursive:!0,force:!0})}}if(s==="delete"){let a=e.configKey;a||(console.error("Missing skill ID."),zo(),process.exit(1)),await o.deleteSkill(t,n,a),console.log(`Deleted skill: ${a}`);return}s!=="list"&&(console.error(`Unknown skills command: ${s}`),zo(),process.exit(1));let i=[],r;do{let a=await o.listAvailableSkills(t,n,{createdBy:e.createdBy,nextKey:r,limit:100});i.push(...a.skills),r=a.nextKey}while(r);if(e.json){console.log(JSON.stringify(i));return}if(i.length===0){console.log("No skills found in this workspace.");return}console.log(`Available Skills (${i.length}):
480
- `);for(let a of i)console.log(` ${a.name} (${a.provider})`),console.log(` ${a.description.slice(0,120)}`),console.log(` ID: ${a.id}`),console.log(` Author: ${a.author.name}`),console.log("")}async function Ps(e){try{let t=H.getEffectiveProfileName(),n=await $e.getAll(),s={model:ne.getDefaultModel(),connectors:ne.getDefaultConnectorIds(),capabilities:ne.getCapabilities()};if(!n){e.json?console.log(JSON.stringify({loggedIn:!1,profile:t,defaults:s})):(console.log(`Profile: ${t}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let o;if(n.workspaceId)try{let i=new B,r=await dt(),{workspaces:a}=await i.getWorkspaces(r);o=a.find(d=>d.id===n.workspaceId)?.name}catch(i){if(i instanceof Qe){e.json?console.log(JSON.stringify({loggedIn:!1,profile:t,defaults:s})):(console.log(`Profile: ${t}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}}e.json?console.log(JSON.stringify({loggedIn:!0,profile:t,email:n.email,workspaceId:n.workspaceId,workspaceName:o,defaults:s})):(console.log(`Profile: ${t}`),console.log(`Logged in as ${n.email}`),o&&console.log(`Workspace: ${o}`),n.workspaceId&&console.log(`Workspace ID: ${n.workspaceId}`))}catch(t){xe(t)}}import{Client as wi}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as ki}from"@modelcontextprotocol/sdk/client/streamableHttp.js";async function xi(e={}){let t=e.apiUrl,n=e.accessToken,s=e.workspaceId;if(!n||!s){let a=await pe();n=n||a.accessToken,s=s||a.workspaceId}t||(t=Me().apiUrl);let o=new wi({name:"entrydesk-cli",version:"1.0.0"}),i=new URL(`${t}/v1/workspaces/${s}/mcp`),r=new ki(i,{requestInit:{headers:{Authorization:`Bearer ${n}`}}});return await o.connect(r),o}async function wo(){return xi()}function bi(e){return e.split("__")[0]??e}function yt(e,t,n){console.error(n?JSON.stringify({error:{code:e,message:t}}):`Error [${e}]: ${t}`),process.exit(1)}function Yo(e,t,n="CONNECTION_FAILED"){let s=e instanceof Error?e.message:"Unknown error";s.includes("Not logged in")||s.includes("not-logged-in")?yt("AUTH_MISSING",s,t):yt(n,s,t)}function Ci(e){let t=[];return t.push(`Tool: ${e.name}`),e.description&&t.push(` Description: ${e.description}`),t.join(`
481
- `)}function $i(e){let t=[];return t.push(`Tool: ${e.name}`),e.description&&(t.push("Description:"),t.push(` ${e.description}`)),t.push("Input Schema:"),t.push(JSON.stringify(e.inputSchema,null,2)),t.join(`
482
- `)}async function Si(e,t){let n;try{n=await wo();let o=(await n.listTools()).tools;if(t){let i=t.toLowerCase();o=o.filter(r=>bi(r.name).toLowerCase().startsWith(i))}if(e)console.log(JSON.stringify(o,null,2));else{let i=t?` (prefix: ${t})`:"";console.log(`Available Tools (${o.length})${i}:
483
- `);for(let r of o)console.log(Ci(r)),console.log()}}catch(s){await n?.close().catch(()=>{}),Yo(s,e)}finally{await n?.close().catch(()=>{})}}async function Ti(e,t){let n;try{n=await wo();let o=(await n.listTools()).tools.find(i=>i.name===e);o||yt("TOOL_NOT_FOUND",`Tool not found: ${e}`,t),console.log(t?JSON.stringify(o,null,2):$i(o))}catch(s){await n?.close().catch(()=>{}),Yo(s,t)}finally{await n?.close().catch(()=>{})}}async function Ii(e,t,n){let s;try{s=JSON.parse(t)}catch(r){let a=r instanceof Error?`Invalid JSON input: ${r.message}`:"Invalid JSON input";yt("INVALID_INPUT",a,n)}let o,i=!1;try{o=await wo();let r=await o.callTool({name:e,arguments:s});if(n)console.log(JSON.stringify(r,null,2));else{let a=r.content;for(let l of a)l.type==="text"?console.log(l.text):l.type==="image"?console.log(`[Image: ${l.mimeType}]`):l.type==="resource"?console.log(`[Resource: ${l.resource?.uri??"unknown"}]`):console.log(JSON.stringify(l,null,2))}r.isError&&(i=!0)}catch(r){await o?.close().catch(()=>{}),Yo(r,n,"TOOL_CALL_FAILED")}finally{await o?.close().catch(()=>{})}i&&process.exit(1)}async function As(e){let t=e.json??!1;switch(e.action){case"list":await Si(t,e.prefix);break;case"get":if(!e.name){yt("INVALID_INPUT","Tool name is required",t);return}await Ti(e.name,t);break;case"call":if(!e.name){yt("INVALID_INPUT","Tool name is required",t);return}if(!e.input){yt("INVALID_INPUT","Input JSON is required (--input)",t);return}await Ii(e.name,e.input,t);break;default:console.log(`Usage: entrydesk tool <action> [options]
479
+ `)}function Ii(e,t){let o=st.relative(e,t);return o===""||!o.startsWith("..")&&!st.isAbsolute(o)}async function vi(e){let t=await At.realpath(e),o=[process.cwd(),Ns.homedir()];if(!(await Promise.all(o.map(async i=>{try{return await At.realpath(i)}catch{return st.resolve(i)}}))).some(i=>Ii(i,t)))throw new Error("Invalid upload path: must be within the current directory or your home directory.")}async function Pi(e){let t=await At.mkdtemp(st.join(Ns.tmpdir(),"entrydesk-skill-")),o=st.join(t,`${st.basename(e)}.zip`);return await new Promise((s,n)=>{let i=Si.createWriteStream(o),r=Ti("zip",{zlib:{level:9}});i.on("close",()=>s()),i.on("error",n),r.on("error",n),r.pipe(i),r.directory(e,!1),r.finalize()}),{zipPath:o,cleanupDir:t}}async function Es(e){let t,o;try{let a=await pe();t=a.accessToken,o=a.workspaceId}catch(a){xe(a)}let s=e.action||"list",n=new B;if(s==="upload"){let a=e.configKey;a||(console.error("Missing file path."),Xo(),process.exit(1));let l=st.resolve(a),d;try{d=await At.stat(l)}catch{console.error(`File not found: ${l}`),process.exit(1)}let $=l,x=null;try{try{await vi(l)}catch(h){let T=h instanceof Error?h.message:"Invalid upload path.";console.error(T),process.exit(1)}if(d.isDirectory()){let h=await Pi(l);$=h.zipPath,x=h.cleanupDir}else d.isFile()||(console.error(`Not a file or directory: ${l}`),process.exit(1));st.extname($).toLowerCase()!==".zip"&&(console.error("Only .zip files are supported for upload."),process.exit(1));let b=await At.readFile($),C=new FormData;C.append("file",new Blob([b],{type:"application/zip"}),st.basename($)),e.force&&C.append("force","true");let m;try{m=await n.uploadSkill(t,o,C)}catch(h){if(h instanceof Error&&h.name==="HTTPError"){let T=h;T.response&&T.response.status===409&&(console.error("Upload failed: A skill with this name already exists."),console.error("Use --force to overwrite the existing skill."),process.exit(1))}throw h}if(e.json){console.log(JSON.stringify(m));return}console.log(`Uploaded skill: ${m.name}`),console.log(` ID: ${m.id}`),console.log(` Description: ${m.description}`);return}finally{x&&await At.rm(x,{recursive:!0,force:!0})}}if(s==="delete"){let a=e.configKey;a||(console.error("Missing skill ID."),Xo(),process.exit(1)),await n.deleteSkill(t,o,a),console.log(`Deleted skill: ${a}`);return}s!=="list"&&(console.error(`Unknown skills command: ${s}`),Xo(),process.exit(1));let i=[],r;do{let a=await n.listAvailableSkills(t,o,{createdBy:e.createdBy,nextKey:r,limit:100});i.push(...a.skills),r=a.nextKey}while(r);if(e.json){console.log(JSON.stringify(i));return}if(i.length===0){console.log("No skills found in this workspace.");return}console.log(`Available Skills (${i.length}):
480
+ `);for(let a of i)console.log(` ${a.name} (${a.provider})`),console.log(` ${a.description.slice(0,120)}`),console.log(` ID: ${a.id}`),console.log(` Author: ${a.author.name}`),console.log("")}async function _s(e){try{let t=H.getEffectiveProfileName(),o=await $e.getAll(),s={model:ne.getDefaultModel(),connectors:ne.getDefaultConnectorIds(),capabilities:ne.getCapabilities()};if(!o){e.json?console.log(JSON.stringify({loggedIn:!1,profile:t,defaults:s})):(console.log(`Profile: ${t}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let n;if(o.workspaceId)try{let i=new B,r=await dt(),{workspaces:a}=await i.getWorkspaces(r);n=a.find(d=>d.id===o.workspaceId)?.name}catch(i){if(i instanceof Qe){e.json?console.log(JSON.stringify({loggedIn:!1,profile:t,defaults:s})):(console.log(`Profile: ${t}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}}e.json?console.log(JSON.stringify({loggedIn:!0,profile:t,email:o.email,workspaceId:o.workspaceId,workspaceName:n,defaults:s})):(console.log(`Profile: ${t}`),console.log(`Logged in as ${o.email}`),n&&console.log(`Workspace: ${n}`),o.workspaceId&&console.log(`Workspace ID: ${o.workspaceId}`))}catch(t){xe(t)}}import{Client as Ai}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as Ni}from"@modelcontextprotocol/sdk/client/streamableHttp.js";async function Ei(e={}){let t=e.apiUrl,o=e.accessToken,s=e.workspaceId;if(!o||!s){let a=await pe();o=o||a.accessToken,s=s||a.workspaceId}t||(t=Me().apiUrl);let n=new Ai({name:"entrydesk-cli",version:"1.0.0"}),i=new URL(`${t}/v1/workspaces/${s}/mcp`),r=new Ni(i,{requestInit:{headers:{Authorization:`Bearer ${o}`}}});return await n.connect(r),n}async function xo(){return Ei()}import Qo from"fs/promises";import _i from"os";import Vt from"path";var Zo=!process.env.NO_COLOR&&process.stdout.isTTY!==!1,Nt={green:Zo?"\x1B[32m":"",yellow:Zo?"\x1B[33m":"",reset:Zo?"\x1B[0m":""},Li=10*1024,Ls=8*1024,Ds=2*1024,Di=100,Oi=100;function Ri(){return Vt.join(_i.homedir(),".entrydesk","tool-results")}function Ui(e){let t=e.trim().replace(/[/\\:*?"<>|\s]/g,"_").replace(/_+/g,"_").replace(/^[._]+|[._]+$/g,"").slice(0,Di);return!t||t==="."||t===".."?"unnamed_tool":t}function ji(e){try{return JSON.stringify(e,(t,o)=>typeof o=="bigint"?`${o}n`:typeof o=="function"?"[Function]":typeof o=="symbol"?o.toString():o,2)}catch{return String(e)}}function Bi(e){let t=new Date,o=[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("-"),s=Ui(e);return`${o}_${s}.json`}async function Os(e,t){try{return await Qo.writeFile(e,t,{encoding:"utf8",flag:"wx"}),!0}catch(o){if(o instanceof Error&&"code"in o&&o.code==="EEXIST")return!1;throw o}}async function Rs(e,t){try{let o=Ri();await Qo.mkdir(o,{recursive:!0});let s=Bi(e),n=Vt.extname(s),i=s.slice(0,-n.length),r=ji(t),a=Vt.join(o,s);if(await Os(a,r))return a;for(let $=1;$<=Oi;$++){let x=Vt.join(o,`${i}-${$}${n}`);if(await Os(x,r))return x}let l=Math.random().toString(36).slice(2,10),d=Vt.join(o,`${i}-${l}${n}`);return await Qo.writeFile(d,r,{encoding:"utf8",flag:"wx"}),d}catch(o){let s=o instanceof Error?o.message:"unknown error";return console.error(`${Nt.yellow}Warning: Could not save result to file: ${s}${Nt.reset}`),null}}function Us(e,t){let o=Buffer.byteLength(e,"utf8");if(o<=Li)return e;let s=e.slice(0,Ls),n=e.slice(-Ds),r=((o-Ls-Ds)/1024).toFixed(1),a=(o/1024).toFixed(1),l=` ... (skipped ${r}KB of ${a}KB) ...`;return t&&(l+=`
481
+ Tip: jq -r '.structuredContent.field' <file> | grep/head/tail`),`${s}
482
+
483
+ ${l}
484
+
485
+ ${n}`}function js(e){console.log(`${Nt.green}Tool execution result saved to: ${e}${Nt.reset}`),console.log()}function Bs(){console.log(`${Nt.green}Tool execution result:${Nt.reset}`)}function Fi(e){return e.split("__")[0]??e}function yt(e,t,o){console.error(o?JSON.stringify({error:{code:e,message:t}}):`Error [${e}]: ${t}`),process.exit(1)}function en(e,t,o="CONNECTION_FAILED"){let s=e instanceof Error?e.message:"Unknown error";s.includes("Not logged in")||s.includes("not-logged-in")?yt("AUTH_MISSING",s,t):yt(o,s,t)}function Wi(e){let t=[];return t.push(`Tool: ${e.name}`),e.description&&t.push(` Description: ${e.description}`),t.join(`
486
+ `)}function Mi(e){let t=[];return t.push(`Tool: ${e.name}`),e.description&&(t.push("Description:"),t.push(` ${e.description}`)),t.push("Input Schema:"),t.push(JSON.stringify(e.inputSchema,null,2)),t.join(`
487
+ `)}async function Ji(e,t){let o;try{o=await xo();let n=(await o.listTools()).tools;if(t){let i=t.toLowerCase();n=n.filter(r=>Fi(r.name).toLowerCase().startsWith(i))}if(e)console.log(JSON.stringify(n,null,2));else{let i=t?` (prefix: ${t})`:"";console.log(`Available Tools (${n.length})${i}:
488
+ `);for(let r of n)console.log(Wi(r)),console.log()}}catch(s){await o?.close().catch(()=>{}),en(s,e)}finally{await o?.close().catch(()=>{})}}async function Gi(e,t){let o;try{o=await xo();let n=(await o.listTools()).tools.find(i=>i.name===e);n||yt("TOOL_NOT_FOUND",`Tool not found: ${e}`,t),console.log(t?JSON.stringify(n,null,2):Mi(n))}catch(s){await o?.close().catch(()=>{}),en(s,t)}finally{await o?.close().catch(()=>{})}}async function Hi(e,t,o){let s;try{s=JSON.parse(t)}catch(r){let a=r instanceof Error?`Invalid JSON input: ${r.message}`:"Invalid JSON input";yt("INVALID_INPUT",a,o)}let n,i=!1;try{n=await xo();let r=await n.callTool({name:e,arguments:s});if(o)console.log(JSON.stringify(r,null,2));else{let a=await Rs(e,r);a&&js(a),Bs();let l=r.content;for(let d of l)d.type==="text"?console.log(d.text):d.type==="image"?console.log(`[Image: ${d.mimeType}]`):d.type==="resource"?console.log(`[Resource: ${d.resource?.uri??"unknown"}]`):console.log(JSON.stringify(d,null,2));if(r.structuredContent){let d=JSON.stringify(r.structuredContent,null,2),$=Us(d,a);console.log($)}}r.isError&&(i=!0)}catch(r){await n?.close().catch(()=>{}),en(r,o,"TOOL_CALL_FAILED")}finally{await n?.close().catch(()=>{})}i&&process.exit(1)}async function Fs(e){let t=e.json??!1;switch(e.action){case"list":await Ji(t,e.prefix);break;case"get":if(!e.name){yt("INVALID_INPUT","Tool name is required",t);return}await Gi(e.name,t);break;case"call":if(!e.name){yt("INVALID_INPUT","Tool name is required",t);return}if(!e.input){yt("INVALID_INPUT","Input JSON is required (--input)",t);return}await Hi(e.name,e.input,t);break;default:console.log(`Usage: entrydesk tool <action> [options]
484
489
 
485
490
  Actions:
486
491
  list List all available tools
@@ -497,7 +502,7 @@ Examples:
497
502
  entrydesk tool list --prefix agent
498
503
  entrydesk tool get agent__search_agents
499
504
  entrydesk tool call agent__search_agents --input '{"limit": 5}'
500
- `);break}}function vi(){console.log(`
505
+ `);break}}function Vi(){console.log(`
501
506
  Usage: entrydesk usage [options]
502
507
 
503
508
  Options:
@@ -510,10 +515,10 @@ Examples:
510
515
  entrydesk usage --limit 10 # Show top 10 users
511
516
  entrydesk usage --sort-by operations # Sort by operation count
512
517
  entrydesk usage --json # JSON output
513
- `)}async function Ns(e){if(e.help){vi();return}let t,n;try{let m=await pe();t=m.accessToken,n=m.workspaceId}catch(m){let h=m instanceof Error?m.message:"Authentication failed";console.error(h),process.exit(1)}let s=new B,o=[],i,r=0,a=100;do{let m=await s.getMonthlyUsages(t,n,{nextKey:i,limit:100});if(o.push(...m.monthlyUsages),i=m.nextKey,r++,r>=a){console.error(`Warning: Showing first ${o.length} entries (pagination limit reached)`);break}}while(i);if(e.json){console.log(JSON.stringify(o));return}if(o.length===0){console.log("No usage data found for this workspace.");return}console.log(`Current Month Usage:
514
- `);let l=0,d=0;for(let m of o)l+=parseFloat(m.totalCost),d+=m.operationCount;console.log(`Total Cost: $${l.toFixed(2)}`),console.log(`Total Operations: ${d.toLocaleString()}`),console.log(`Users: ${o.length}
515
- `);let I=e.sortBy||"cost",x=[...o].toSorted((m,h)=>I==="cost"?parseFloat(h.totalCost)-parseFloat(m.totalCost):h.operationCount-m.operationCount),b=e.limit&&e.limit>0?e.limit:x.length,C=x.slice(0,b);console.log(`Usage by User (sorted by ${I}, showing ${C.length} of ${o.length}):
516
- `);for(let m of C){let h=parseFloat(m.totalCost);console.log(` ${m.user.name} (${m.user.email})`),console.log(` Cost: $${h.toFixed(2)}`),console.log(` Operations: ${m.operationCount.toLocaleString()}`),console.log("")}C.length<o.length&&console.log(`... and ${o.length-C.length} more users`)}function Xo(){console.log("entrydesk 1.4.0")}function Zo(){console.log(`
518
+ `)}async function Ws(e){if(e.help){Vi();return}let t,o;try{let m=await pe();t=m.accessToken,o=m.workspaceId}catch(m){let h=m instanceof Error?m.message:"Authentication failed";console.error(h),process.exit(1)}let s=new B,n=[],i,r=0,a=100;do{let m=await s.getMonthlyUsages(t,o,{nextKey:i,limit:100});if(n.push(...m.monthlyUsages),i=m.nextKey,r++,r>=a){console.error(`Warning: Showing first ${n.length} entries (pagination limit reached)`);break}}while(i);if(e.json){console.log(JSON.stringify(n));return}if(n.length===0){console.log("No usage data found for this workspace.");return}console.log(`Current Month Usage:
519
+ `);let l=0,d=0;for(let m of n)l+=parseFloat(m.totalCost),d+=m.operationCount;console.log(`Total Cost: $${l.toFixed(2)}`),console.log(`Total Operations: ${d.toLocaleString()}`),console.log(`Users: ${n.length}
520
+ `);let $=e.sortBy||"cost",x=[...n].toSorted((m,h)=>$==="cost"?parseFloat(h.totalCost)-parseFloat(m.totalCost):h.operationCount-m.operationCount),b=e.limit&&e.limit>0?e.limit:x.length,C=x.slice(0,b);console.log(`Usage by User (sorted by ${$}, showing ${C.length} of ${n.length}):
521
+ `);for(let m of C){let h=parseFloat(m.totalCost);console.log(` ${m.user.name} (${m.user.email})`),console.log(` Cost: $${h.toFixed(2)}`),console.log(` Operations: ${m.operationCount.toLocaleString()}`),console.log("")}C.length<n.length&&console.log(`... and ${n.length-C.length} more users`)}function tn(){console.log("entrydesk 1.5.0")}function on(){console.log(`
517
522
  Usage: entrydesk workspaces [list|switch|use] [options]
518
523
 
519
524
  Commands:
@@ -523,6 +528,6 @@ Commands:
523
528
 
524
529
  Flags:
525
530
  --json Output JSON
526
- `)}async function Es(e){if(e.help){Zo();return}let t,s=(await $e.getAll())?.workspaceId;try{t=await dt()}catch(a){let l=a instanceof Error?a.message:"Authentication failed";console.error(l),process.exit(1)}let o=e.action||"list",i=new B;if(o==="switch"||o==="use"){let a=e.configKey;a||(console.error("Missing workspaceId for switch."),Zo(),process.exit(1));let{workspaces:l}=await i.getWorkspaces(t),d=l.find(I=>I.id===a);if(!d){console.error(`Workspace not found: ${a}`),console.error(`
527
- Available workspaces:`);for(let I of l)console.error(` ${I.name}: ${I.id}`);process.exit(1)}if(await $e.saveWorkspaceId(a),e.json){console.log(JSON.stringify({workspaceId:a,workspaceName:d.name}));return}console.log(`Switched to workspace: ${d.name}`),console.log(` ID: ${a}`);return}o!=="list"&&(console.error(`Unknown workspaces command: ${o}`),Zo(),process.exit(1));let{workspaces:r}=await i.getWorkspaces(t);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No workspaces found.");return}console.log(`Workspaces (${r.length}):
528
- `);for(let a of r){let l=a.id===s?" (current)":"";console.log(` ${a.name}${l}`),console.log(` ID: ${a.id}`),console.log("")}}function _s(e,t,n=!1){let s={},o={};for(let i=n?0:1;i<e.length;i++){let r=e[i];if(r==="--json")s.json=!0;else if(r==="--help"||r==="-h")s.help=!0;else if(r==="--profile")s.profile=e[++i];else switch(t){case"login":r==="--google"||r==="-g"?o.google=!0:r==="-i"||r==="--interactive"?o.interactive=!0:r==="--email"?o.email=e[++i]:r==="--password"&&(o.password=e[++i]);break;case"chat":if(r==="-m"||r==="--message")o.message=e[++i];else if(r==="-a"||r==="--agent")o.agentId=e[++i];else if(r==="--model")o.model=e[++i];else if(r==="--connectors"){let a=e[++i];o.connectors=a?.split(",").map(l=>l.trim())}else r==="-i"||r==="--interactive"?o.interactive=!0:r==="--full-output"?o.fullOutput=!0:r==="-c"||r==="--continue"?o.continue=parseInt(e[++i],10):r==="--plain"?o.plain=!0:r==="--output"?o.output=e[++i]:r==="--sandbox"?o.sandbox=!0:r==="--no-sandbox"?o.noSandbox=!0:r==="--web-search"?o.webSearch=!0:r==="--image-gen"?o.imageGen=!0:r==="--chart"?o.chart=!0:r==="--file-system"?o.fileSystem=!0:r==="--no-file-system"&&(o.noFileSystem=!0);break;case"agents":if(r==="--name")o.name=e[++i];else if(r==="--description")o.description=e[++i];else if(r==="--system-prompt")o.systemPrompt=e[++i];else if(r==="--model-id")o.modelId=e[++i];else if(r==="--connector-ids"){let a=e[++i];o.connectorIds=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--capabilities"){let a=e[++i];o.capabilities=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--conversation-starters"){let a=e[++i];o.conversationStarters=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--tools"){let a=e[++i];o.tools=a?.split(",").map(l=>l.trim()).filter(Boolean)}else r==="--icon-id"?o.iconId=e[++i]:r.startsWith("-")||(o.action?o.agentId=r:o.action=r);break;case"skills":r==="--force"?o.force=!0:r==="--me"||r==="--mine"?o.createdBy="me":r.startsWith("-")||(o.action?o.configKey=r:o.action=r);break;case"schedules":if(r==="--name")o.name=e[++i];else if(r==="--prompt")o.prompt=e[++i];else if(r==="--agent-id")o.agentId=e[++i];else if(r==="--starts-at")o.startsAt=e[++i];else if(r==="--utc-offset")o.utcOffset=e[++i];else if(r==="--repeat-type")o.repeatType=e[++i];else if(r==="--every")o.every=parseInt(e[++i],10);else if(r==="--time")o.time=e[++i];else if(r==="--days-of-week"){let a=e[++i];o.daysOfWeek=a?.split(",").map(l=>parseInt(l.trim(),10)).filter(l=>!isNaN(l))}else if(r==="--days-of-month"){let a=e[++i];o.daysOfMonth=a?.split(",").map(l=>parseInt(l.trim(),10)).filter(l=>!isNaN(l))}else r==="--last-day-of-month"?o.lastDayOfMonth=!0:r.startsWith("-")||(o.action?o.scheduleId=r:o.action=r);break;case"config":!o.action&&!r.startsWith("-")?o.action=r:!o.configKey&&!r.startsWith("-")?o.configKey=r:!o.value&&!r.startsWith("-")&&(o.value=r);break;case"profile":!o.action&&!r.startsWith("-")?o.action=r:!o.name&&!r.startsWith("-")?o.name=r:!o.value&&!r.startsWith("-")&&(o.value=r);break;case"chats":r==="--share"||r==="-s"?o.shareId=e[++i]:r==="--full-output"?o.fullOutput=!0:r==="--output"?o.output=e[++i]:!o.chatId&&!r.startsWith("-")&&(o.chatId=r);break;case"budget":!o.action&&!r.startsWith("-")?o.action=r:!o.configKey&&!r.startsWith("-")&&(o.configKey=r);break;case"usage":if(r==="--limit")o.limit=parseInt(e[++i],10);else if(r==="--sort-by"){let a=e[++i];(a==="cost"||a==="operations")&&(o.sortBy=a)}break;case"mcp-server":r==="--http"?o.http=!0:(r==="-p"||r==="--port")&&(o.port=parseInt(e[++i],10));break;case"tool":r==="-i"||r==="--input"?o.input=e[++i]:r==="-p"||r==="--prefix"?o.prefix=e[++i]:r.startsWith("-")||(o.action?o.name||(o.name=r):o.action=r);break;case"workspaces":!o.action&&!r.startsWith("-")&&(o.action=r);break;default:break}}switch(t){case"login":return{command:"login",...s,...o};case"logout":return{command:"logout",...s,...o};case"status":return{command:"status",...s,...o};case"workspaces":return{command:"workspaces",...s,...o};case"agents":return{command:"agents",...s,...o};case"models":return{command:"models",...s,...o};case"connectors":return{command:"connectors",...s,...o};case"skills":return{command:"skills",...s,...o};case"schedules":return{command:"schedules",...s,...o};case"config":return{command:"config",...s,...o};case"profile":return{command:"profile",...s,...o};case"chat":return{command:"chat",...s,...o};case"chats":return{command:"chats",...s,...o};case"budget":return{command:"budget",...s,...o};case"usage":return{command:"usage",...s,...o};case"mcp-server":return{command:"mcp-server",...s,...o};case"tool":return{command:"tool",...s,...o};case"version":return{command:"version",...s,...o};default:return{command:"help",...s,...o}}}import{jsx as Ei}from"react/jsx-runtime";var He=process.argv.slice(2);(He[0]==="--help"||He[0]==="-h")&&(yo(),process.exit(0));(He[0]==="--version"||He[0]==="-v")&&(Xo(),process.exit(0));var Qo=!He[0]||He[0].startsWith("-"),Ai=Qo?"chat":He[0],be=_s(He,Ai,Qo);Qo&&be.command==="chat"&&(be.interactive=!0);async function Ni(){try{if(be.command!=="profile"){let e=be.profile||H.getCurrentProfileName();H.ensureProfileExists(e),H.setOverrideProfile(e)}switch(be.command){case"login":await ws(be);break;case"logout":await ks(be);break;case"status":await Ps(be);break;case"workspaces":await Es(be);break;case"agents":await tn(be);break;case"models":await Cs(be);break;case"connectors":await gs(be);break;case"skills":await vs(be);break;case"schedules":await Ts(be);break;case"chats":await fs(be);break;case"budget":await on(be);break;case"usage":await Ns(be);break;case"config":be.action==="help"||He[1]==="--help"?Pi(Ei(ms,{})):await ps(be);break;case"profile":await $s(be);break;case"chat":He[1]==="--help"||He[1]==="-h"?yo():await is(be);break;case"mcp-server":await bs({mode:be.http?"http":"stdio",port:be.port});break;case"tool":await As(be);break;case"version":Xo();break;default:yo();break}}catch(e){xe(e)}}Ni();
531
+ `)}async function Ms(e){if(e.help){on();return}let t,s=(await $e.getAll())?.workspaceId;try{t=await dt()}catch(a){let l=a instanceof Error?a.message:"Authentication failed";console.error(l),process.exit(1)}let n=e.action||"list",i=new B;if(n==="switch"||n==="use"){let a=e.configKey;a||(console.error("Missing workspaceId for switch."),on(),process.exit(1));let{workspaces:l}=await i.getWorkspaces(t),d=l.find($=>$.id===a);if(!d){console.error(`Workspace not found: ${a}`),console.error(`
532
+ Available workspaces:`);for(let $ of l)console.error(` ${$.name}: ${$.id}`);process.exit(1)}if(await $e.saveWorkspaceId(a),e.json){console.log(JSON.stringify({workspaceId:a,workspaceName:d.name}));return}console.log(`Switched to workspace: ${d.name}`),console.log(` ID: ${a}`);return}n!=="list"&&(console.error(`Unknown workspaces command: ${n}`),on(),process.exit(1));let{workspaces:r}=await i.getWorkspaces(t);if(e.json){console.log(JSON.stringify(r));return}if(r.length===0){console.log("No workspaces found.");return}console.log(`Workspaces (${r.length}):
533
+ `);for(let a of r){let l=a.id===s?" (current)":"";console.log(` ${a.name}${l}`),console.log(` ID: ${a.id}`),console.log("")}}function Js(e,t,o=!1){let s={},n={};for(let i=o?0:1;i<e.length;i++){let r=e[i];if(r==="--json")s.json=!0;else if(r==="--help"||r==="-h")s.help=!0;else if(r==="--profile")s.profile=e[++i];else switch(t){case"login":r==="--google"||r==="-g"?n.google=!0:r==="-i"||r==="--interactive"?n.interactive=!0:r==="--email"?n.email=e[++i]:r==="--password"&&(n.password=e[++i]);break;case"chat":if(r==="-m"||r==="--message")n.message=e[++i];else if(r==="-a"||r==="--agent")n.agentId=e[++i];else if(r==="--model")n.model=e[++i];else if(r==="--connectors"){let a=e[++i];n.connectors=a?.split(",").map(l=>l.trim())}else r==="-i"||r==="--interactive"?n.interactive=!0:r==="--full-output"?n.fullOutput=!0:r==="-c"||r==="--continue"?n.continue=parseInt(e[++i],10):r==="--plain"?n.plain=!0:r==="--output"?n.output=e[++i]:r==="--sandbox"?n.sandbox=!0:r==="--no-sandbox"?n.noSandbox=!0:r==="--web-search"?n.webSearch=!0:r==="--image-gen"?n.imageGen=!0:r==="--chart"?n.chart=!0:r==="--file-system"?n.fileSystem=!0:r==="--no-file-system"&&(n.noFileSystem=!0);break;case"agents":if(r==="--name")n.name=e[++i];else if(r==="--description")n.description=e[++i];else if(r==="--system-prompt")n.systemPrompt=e[++i];else if(r==="--model-id")n.modelId=e[++i];else if(r==="--connector-ids"){let a=e[++i];n.connectorIds=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--capabilities"){let a=e[++i];n.capabilities=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--conversation-starters"){let a=e[++i];n.conversationStarters=a?.split(",").map(l=>l.trim()).filter(Boolean)}else if(r==="--tools"){let a=e[++i];n.tools=a?.split(",").map(l=>l.trim()).filter(Boolean)}else r==="--icon-id"?n.iconId=e[++i]:r.startsWith("-")||(n.action?n.agentId=r:n.action=r);break;case"skills":r==="--force"?n.force=!0:r==="--me"||r==="--mine"?n.createdBy="me":r.startsWith("-")||(n.action?n.configKey=r:n.action=r);break;case"schedules":if(r==="--name")n.name=e[++i];else if(r==="--prompt")n.prompt=e[++i];else if(r==="--agent-id")n.agentId=e[++i];else if(r==="--starts-at")n.startsAt=e[++i];else if(r==="--utc-offset")n.utcOffset=e[++i];else if(r==="--repeat-type")n.repeatType=e[++i];else if(r==="--every")n.every=parseInt(e[++i],10);else if(r==="--time")n.time=e[++i];else if(r==="--days-of-week"){let a=e[++i];n.daysOfWeek=a?.split(",").map(l=>parseInt(l.trim(),10)).filter(l=>!isNaN(l))}else if(r==="--days-of-month"){let a=e[++i];n.daysOfMonth=a?.split(",").map(l=>parseInt(l.trim(),10)).filter(l=>!isNaN(l))}else r==="--last-day-of-month"?n.lastDayOfMonth=!0:r.startsWith("-")||(n.action?n.scheduleId=r:n.action=r);break;case"config":!n.action&&!r.startsWith("-")?n.action=r:!n.configKey&&!r.startsWith("-")?n.configKey=r:!n.value&&!r.startsWith("-")&&(n.value=r);break;case"profile":!n.action&&!r.startsWith("-")?n.action=r:!n.name&&!r.startsWith("-")?n.name=r:!n.value&&!r.startsWith("-")&&(n.value=r);break;case"chats":r==="--share"||r==="-s"?n.shareId=e[++i]:r==="--full-output"?n.fullOutput=!0:r==="--output"?n.output=e[++i]:!n.chatId&&!r.startsWith("-")&&(n.chatId=r);break;case"budget":!n.action&&!r.startsWith("-")?n.action=r:!n.configKey&&!r.startsWith("-")&&(n.configKey=r);break;case"usage":if(r==="--limit")n.limit=parseInt(e[++i],10);else if(r==="--sort-by"){let a=e[++i];(a==="cost"||a==="operations")&&(n.sortBy=a)}break;case"mcp-server":r==="--http"?n.http=!0:(r==="-p"||r==="--port")&&(n.port=parseInt(e[++i],10));break;case"tool":r==="-i"||r==="--input"?n.input=e[++i]:r==="-p"||r==="--prefix"?n.prefix=e[++i]:r.startsWith("-")||(n.action?n.name||(n.name=r):n.action=r);break;case"workspaces":!n.action&&!r.startsWith("-")&&(n.action=r);break;default:break}}switch(t){case"login":return{command:"login",...s,...n};case"logout":return{command:"logout",...s,...n};case"status":return{command:"status",...s,...n};case"workspaces":return{command:"workspaces",...s,...n};case"agents":return{command:"agents",...s,...n};case"models":return{command:"models",...s,...n};case"connectors":return{command:"connectors",...s,...n};case"skills":return{command:"skills",...s,...n};case"schedules":return{command:"schedules",...s,...n};case"config":return{command:"config",...s,...n};case"profile":return{command:"profile",...s,...n};case"chat":return{command:"chat",...s,...n};case"chats":return{command:"chats",...s,...n};case"budget":return{command:"budget",...s,...n};case"usage":return{command:"usage",...s,...n};case"mcp-server":return{command:"mcp-server",...s,...n};case"tool":return{command:"tool",...s,...n};case"version":return{command:"version",...s,...n};default:return{command:"help",...s,...n}}}import{jsx as Yi}from"react/jsx-runtime";var He=process.argv.slice(2);(He[0]==="--help"||He[0]==="-h")&&(ko(),process.exit(0));(He[0]==="--version"||He[0]==="-v")&&(tn(),process.exit(0));var nn=!He[0]||He[0].startsWith("-"),qi=nn?"chat":He[0],be=Js(He,qi,nn);nn&&be.command==="chat"&&(be.interactive=!0);async function zi(){try{if(be.command!=="profile"){let e=be.profile||H.getCurrentProfileName();H.ensureProfileExists(e),H.setOverrideProfile(e)}switch(be.command){case"login":await Cs(be);break;case"logout":await $s(be);break;case"status":await _s(be);break;case"workspaces":await Ms(be);break;case"agents":await rn(be);break;case"models":await Is(be);break;case"connectors":await ks(be);break;case"skills":await Es(be);break;case"schedules":await As(be);break;case"chats":await hs(be);break;case"budget":await an(be);break;case"usage":await Ws(be);break;case"config":be.action==="help"||He[1]==="--help"?Ki(Yi(ws,{})):await ys(be);break;case"profile":await vs(be);break;case"chat":He[1]==="--help"||He[1]==="-h"?ko():await us(be);break;case"mcp-server":await Ts({mode:be.http?"http":"stdio",port:be.port});break;case"tool":await Fs(be);break;case"version":tn();break;default:ko();break}}catch(e){xe(e)}}zi();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@entrydesk/cli",
3
- "version": "1.4.0",
3
+ "version": "1.5.0",
4
4
  "description": "EntryDesk CLI - Interact with EntryDesk from your terminal",
5
5
  "type": "module",
6
6
  "bin": {