@entrydesk/cli 1.12.12 → 1.12.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as f,q as u,s as y}from"./chunk-6A4DXLDW.js";function g(){console.log(`
2
+ import{h as f,q as u,s as y}from"./chunk-JTCLYSZY.js";function g(){console.log(`
3
3
  Usage: entrydesk agents [list|create|update|delete] [options]
4
4
 
5
5
  Commands:
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as c,q as a,s as d}from"./chunk-6A4DXLDW.js";function p(){console.log(`
2
+ import{h as c,q as a,s as d}from"./chunk-JTCLYSZY.js";function p(){console.log(`
3
3
  Usage: entrydesk budget [get|set|clear] [options]
4
4
 
5
5
  Commands:
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env node
2
+ import F from"fs";import p from"fs";import Ue from"os";import T from"path";import{HTTPError as De,TimeoutError as Ke}from"ky";import ke,{TimeoutError as we,isHTTPError as ve}from"ky";import b from"crypto";import u from"fs";import de from"path";var ue="ENTRYDESK_FORCE_FILE_STORAGE",E="EntryDesk CLI",fe="__entrydesk_keychain_test__",pe="profile:",he=".credentials.key",Q={keychain:!1,permissions:!1,corruptFile:!1,windowsFile:!1};function w(r,e){Q[r]||(Q[r]=!0,console.error(e))}function ye(){return process.env.ENTRYDESK_DEBUG?.toLowerCase()==="true"}function ee(r){if(!r||typeof r!="object")return!1;let e=r;return!(!("accessToken"in e||"refreshToken"in e||"email"in e||"workspaceId"in e)||"accessToken"in e&&typeof e.accessToken!="string"||"refreshToken"in e&&typeof e.refreshToken!="string"||"email"in e&&typeof e.email!="string"||"workspaceId"in e&&typeof e.workspaceId!="string")}function me(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.getPassword=="function"&&typeof e.setPassword=="function"&&typeof e.deletePassword=="function"}function N(r){return o.getProfileCredentialsFile(r)}var M=class{getKeyFilePath(e){return de.join(o.getProfileDir(e),he)}loadEncryptionKey(e){let t=this.getKeyFilePath(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t);return s.length!==32?null:(this.ensureSecureFilePermissions(t),s)}catch{return null}}createEncryptionKey(e){o.ensureProfileDir(e);let t=this.getKeyFilePath(e),s=b.randomBytes(32);return u.writeFileSync(t,s,{mode:384}),this.ensureSecureFilePermissions(t),s}getOrCreateEncryptionKey(e){let t=this.loadEncryptionKey(e);return t||this.createEncryptionKey(e)}encrypt(e,t){let s=b.randomBytes(16),n=b.createCipheriv("aes-256-gcm",t,s),i=n.update(e,"utf8","hex");i+=n.final("hex");let c=n.getAuthTag();return`${s.toString("hex")}:${c.toString("hex")}:${i}`}decrypt(e,t){let s=e.split(":");if(s.length!==3)throw new Error("Invalid encrypted data format");let n=Buffer.from(s[0],"hex"),i=Buffer.from(s[1],"hex"),c=s[2],S=b.createDecipheriv("aes-256-gcm",t,n,{authTagLength:16});S.setAuthTag(i);let d=S.update(c,"hex","utf8");return d+=S.final("utf8"),d}tryDecrypt(e,t){try{return this.decrypt(e,t)}catch{return null}}tryParseCredentials(e){try{let t=JSON.parse(e);return ee(t)?t:null}catch{return null}}ensureSecureFilePermissions(e){if(process.platform!=="win32"){try{u.chmodSync(e,384)}catch{w("permissions","Warning: Failed to set secure permissions on credentials file.");return}try{(u.statSync(e).mode&511)!==384&&w("permissions","Warning: Credentials file permissions are too permissive.")}catch{w("permissions","Warning: Failed to verify credentials file permissions.")}}}async getCredentials(e){let t=N(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t,"utf-8").trim();if(!s)return null;let n=this.loadEncryptionKey(e),i=n?this.tryDecrypt(s,n):null;if(i){let c=this.tryParseCredentials(i);if(c)return c}return w("corruptFile","Warning: Credentials file is unreadable. Please run `entrydesk login` again."),null}catch{return null}}async setCredentials(e,t){o.ensureProfileDir(e);let s=N(e),n=this.getOrCreateEncryptionKey(e),i=this.encrypt(JSON.stringify(t),n);u.writeFileSync(s,i,{mode:384}),this.ensureSecureFilePermissions(s)}async deleteCredentials(e){let t=N(e);try{u.existsSync(t)&&u.unlinkSync(t)}catch{}}},j=class{keytarModule=null;keytarLoadAttempted=!1;keychainAvailable=null;async getKeytar(){if(this.keytarLoadAttempted)return this.keytarModule;this.keytarLoadAttempted=!0;try{let t=await import("keytar"),s=t&&typeof t=="object"&&"default"in t?t.default:t;this.keytarModule=me(s)?s:null}catch{this.keytarModule=null}return this.keytarModule}getAccount(e){return`${pe}${e}`}async checkKeychainAvailability(){if(this.keychainAvailable!==null)return this.keychainAvailable;try{let e=await this.getKeytar();if(!e)return this.keychainAvailable=!1,!1;let t=`${fe}${b.randomBytes(8).toString("hex")}`,s="test";await e.setPassword(E,t,s);let n=await e.getPassword(E,t),i=await e.deletePassword(E,t);return this.keychainAvailable=!!(i&&n===s),this.keychainAvailable}catch{return this.keychainAvailable=!1,!1}}async isAvailable(){return this.checkKeychainAvailability()}async getCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");let s=await t.getPassword(E,this.getAccount(e));if(!s)return null;let n=this.tryParseKeychainPayload(s);return n||w("corruptFile",`Warning: Keychain entry for profile "${e}" is unreadable.`),n}async setCredentials(e,t){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let s=await this.getKeytar();if(!s)throw new Error("Keytar module not available");let n=JSON.stringify(t);await s.setPassword(E,this.getAccount(e),n)}async deleteCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");await t.deletePassword(E,this.getAccount(e))}tryParseKeychainPayload(e){try{let t=JSON.parse(e);return ee(t)?t:null}catch{return null}}},z=class{keychainStorage=null;fileStorage=new M;keychainAvailable=null;initPromise=null;shouldForceFileStorage(){return process.env[ue]?.toLowerCase()==="true"}async initializeStorage(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}try{let e=new j,t=await e.isAvailable();this.keychainAvailable=t,this.keychainStorage=t?e:null}catch{this.keychainAvailable=!1,this.keychainStorage=null}!this.keychainAvailable&&!this.shouldForceFileStorage()&&(ye()&&w("keychain","Keychain unavailable. Falling back to file-based credentials."),process.platform==="win32"&&w("windowsFile","Warning: File-based credentials on Windows may be readable by other users."))}async ensureInitialized(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}this.keychainAvailable===null&&(this.initPromise??=this.initializeStorage(),await this.initPromise)}disableKeychain(){this.shouldForceFileStorage()||w("keychain","Keychain error encountered. Falling back to file-based credentials."),this.keychainAvailable=!1,this.keychainStorage=null}async getKeychainStorage(){return await this.ensureInitialized(),this.shouldForceFileStorage()?null:this.keychainAvailable?this.keychainStorage:null}async getCredentials(e){let t=await this.getKeychainStorage();if(!t)return this.fileStorage.getCredentials(e);try{let n=await t.getCredentials(e);if(n)return n}catch{return this.disableKeychain(),this.fileStorage.getCredentials(e)}let s=await this.fileStorage.getCredentials(e);if(s)try{await t.setCredentials(e,s),await this.fileStorage.deleteCredentials(e)}catch{}return s}async setCredentials(e,t){let s=await this.getKeychainStorage();if(!s){await this.fileStorage.setCredentials(e,t);return}try{await s.setCredentials(e,t),await this.fileStorage.deleteCredentials(e)}catch{this.disableKeychain(),await this.fileStorage.setCredentials(e,t)}}async deleteCredentials(e){let t=await this.getKeychainStorage();if(t)try{await t.deleteCredentials(e)}catch{this.disableKeychain()}await this.fileStorage.deleteCredentials(e)}},l=new z,h={async saveAccessToken(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.accessToken=r,await l.setCredentials(t,s)},async getAccessToken(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.accessToken??null},async saveRefreshToken(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.refreshToken=r,await l.setCredentials(t,s)},async getRefreshToken(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.refreshToken??null},async saveEmail(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.email=r,await l.setCredentials(t,s)},async getEmail(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.email??null},async saveWorkspaceId(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.workspaceId=r,await l.setCredentials(t,s)},async getWorkspaceId(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.workspaceId??null},async saveAll(r,e){let t=o.getEffectiveProfileName(e);await l.setCredentials(t,r)},async getAll(r){let e=o.getEffectiveProfileName(r);return l.getCredentials(e)},async clear(r){let e=o.getEffectiveProfileName(r);await l.deleteCredentials(e)},async isLoggedIn(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.accessToken!=null}};var _=class r{client;baseUrl;constructor(e,t){this.baseUrl=e||I(t),D().ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",process.env.DEBUG&&console.log("[DEBUG] ApiClient: SSL certificate validation disabled")),this.client=ke.create({baseUrl:this.baseUrl.replace(/\/?$/,"/"),timeout:3e4,retry:{limit:3,methods:["get","put","head","delete","options","trace"],statusCodes:[408,413,429,500,502,503,504]},hooks:{beforeError:[({error:n})=>(ve(n)&&(n.request.headers.delete("authorization"),n.request.headers.delete("Authorization")),n)]}})}getBaseUrl(){return this.baseUrl}async refreshOAuthToken(e){return this.client.post("v1/oauth/token",{json:{grant_type:"refresh_token",refresh_token:e.refreshToken,client_id:e.clientId}}).json()}async revokeOAuthToken(e){await this.client.post("v1/oauth/revoke",{json:{token:e.token,token_type_hint:"refresh_token",client_id:e.clientId}})}async getWorkspaces(e){try{return process.env.DEBUG&&console.log(`[DEBUG] Calling getWorkspaces API: ${this.baseUrl}/v1/workspaces`),await this.client.get("v1/workspaces",{headers:{Authorization:`Bearer ${e}`}}).json()}catch(t){throw process.env.DEBUG&&(console.error("[DEBUG] getWorkspaces error:",t),t instanceof Error&&"cause"in t&&console.error("[DEBUG] Error cause:",t.cause)),t}}async getAgents(e,t,s){let n={limit:s?.limit??100};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/availableAgents`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async createAgent(e,t,s){return await this.client.post(`v1/workspaces/${t}/agents`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateAgent(e,t,s,n){await this.client.put(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteAgent(e,t,s){await this.client.delete(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModels(e,t){return await this.client.get(`v1/workspaces/${t}/models`,{headers:{Authorization:`Bearer ${e}`}}).json()}async getConnectors(e,t){return await this.client.get(`v1/workspaces/${t}/availableConnectors`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:100,connectionStatus:"connected"}}).json()}async getTasks(e,t,s=20){return await this.client.get(`v1/workspaces/${t}/tasks`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:s}}).json()}async getMessages(e,t,s,n=50){return await this.client.get(`v1/workspaces/${t}/tasks/${s}/messages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:n}}).json()}async getAgent(e,t,s){return await this.client.get(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async listAvailableSkills(e,t,s){return await this.client.get(`v1/workspaces/${t}/availableSkills`,{headers:{Authorization:`Bearer ${e}`},searchParams:{createdBy:s?.createdBy,nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async uploadSkill(e,t,s){return await this.client.post(`v1/workspaces/${t}/skills`,{headers:{Authorization:`Bearer ${e}`},body:s}).json()}async deleteSkill(e,t,s){await this.client.delete(`v1/workspaces/${t}/skills/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async downloadSkillCurrent(e,t,s){return await this.client.get(`v1/workspaces/${t}/skills/${s}/download`,{headers:{Authorization:`Bearer ${e}`}}).json()}async task(e,t,s){try{let n=await this.client.post(`v1/workspaces/${t}/tasks`,{headers:{Authorization:`Bearer ${e}`},json:s,timeout:6e4,throwHttpErrors:!1});if(!n.ok){let c=await n.text();throw new Error(`Task API failed (${n.status}): ${c}`)}let i=await n.json();return i.noop||!i.streamId?new Response(`data: [DONE]
3
+
4
+ `,{headers:{"Content-Type":"text/event-stream"}}):await this.taskStream(e,t,i.taskId)}catch(n){throw n instanceof we?new TypeError("Request timed out. Please check your connection and try again.",{cause:n}):n}}async taskStream(e,t,s){let n=await this.client.get(`v1/workspaces/${t}/tasks/${s}/stream`,{headers:{Authorization:`Bearer ${e}`,Accept:"text/event-stream"},timeout:!1,throwHttpErrors:!1});if(!n.ok){let i=await n.text();throw new Error(`Task stream failed (${n.status}): ${i}`)}return n}async getBudget(e,t){return await this.client.get(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`}}).json()}async updateBudget(e,t,s){await this.client.put(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`},json:{budget:s}})}async getMonthlyUsages(e,t,s){return await this.client.get(`v1/workspaces/${t}/monthlyUsages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async createTaskShare(e,t,s,n="public"){return await this.client.post(`v1/workspaces/${t}/tasks/${s}/shares`,{headers:{Authorization:`Bearer ${e}`},json:{visibility:n}}).json()}async getSharedTask(e,t){let s={};return t&&(s.Authorization=`Bearer ${t}`),await this.client.get(`v1/shares/${e}`,{headers:s}).json()}async getSharedMessages(e,t=50,s){let n={};return s&&(n.Authorization=`Bearer ${s}`),await this.client.get(`v1/shares/${e}/messages`,{headers:n,searchParams:{limit:t}}).json()}async deleteTask(e,t,s){await this.client.delete(`v1/workspaces/${t}/tasks/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModelProviders(e,t){return await this.client.get(`v1/workspaces/${t}/modelProviders`,{headers:{Authorization:`Bearer ${e}`}}).json()}async uploadFile(e,t,s,n){let i=new FormData,c=new Blob([s.buffer],{type:s.mimeType});return i.append("file",c,s.filename),i.append("modelProviderId",n),await this.client.post(`v1/workspaces/${t}/files`,{headers:{Authorization:`Bearer ${e}`},body:i,timeout:12e4}).json()}async getSchedules(e,t,s){let n={limit:s?.limit??20};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async getSchedule(e,t,s){return await this.client.get(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async createSchedule(e,t,s){return await this.client.post(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateSchedule(e,t,s,n){await this.client.put(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteSchedule(e,t,s){await this.client.delete(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}})}static async getAuthenticatedClient(e){let t=await h.getAll(e);return t?{client:new r(void 0,e),accessToken:t.accessToken,workspaceId:t.workspaceId??null}:null}};function Pe(){return process.env.ENTRYDESK_SANDBOX==="true"}function K(){if(!Pe())return null;let r=process.env.ENTRYDESK_SANDBOX_ACCESS_TOKEN?.trim(),e=process.env.ENTRYDESK_SANDBOX_WORKSPACE_ID?.trim();if(!r||!e){let t=[];throw r||t.push("ENTRYDESK_SANDBOX_ACCESS_TOKEN"),e||t.push("ENTRYDESK_SANDBOX_WORKSPACE_ID"),new Error(`Sandbox mode enabled but missing credentials: ${t.join(", ")}`)}return{accessToken:r,workspaceId:e}}function L(){let r=process.env.ENTRYDESK_TOKEN?.trim();if(!r)return null;let e=process.env.ENTRYDESK_WORKSPACE_ID?.trim();if(!e)throw new Error("ENTRYDESK_TOKEN is set but ENTRYDESK_WORKSPACE_ID is missing. Both are required for PAT authentication.");return{accessToken:r,workspaceId:e}}function et(){let r=K();if(r)return{authSource:"sandbox-env",label:"sandbox environment (ENTRYDESK_SANDBOX)",workspaceId:r.workspaceId};let e=L();return e?{authSource:"pat-env",label:"personal access token (ENTRYDESK_TOKEN)",workspaceId:e.workspaceId}:null}import{execFile as Se}from"child_process";import{setTimeout as Ae}from"timers/promises";import{decodeJwt as Ee}from"jose";import Ce,{HTTPError as Te,isHTTPError as be}from"ky";function te(r){if(r===null||typeof r!="object")return{error:""};let e=r;return{code:typeof e.code=="string"?e.code:void 0,error:typeof e.error=="string"?e.error:""}}var U="entrydesk-cli",Re="offline_access workspaces:read tasks:read tasks:write tasks:delete agents:read agents:write connectors:read connectors:write tools:read tools:execute skills:read skills:write meetings:read meetings:write publishes:read publishes:write calendar:read calendar:write schedules:read schedules:write user:read user:write";function xe(r){return new Promise((e,t)=>{let s=process.platform,n,i;switch(s){case"darwin":n="open",i=[r];break;case"win32":n="cmd",i=["/c","start","",r];break;default:n="xdg-open",i=[r];break}Se(n,i,c=>{c?t(new Error(`Failed to open browser. Please manually visit: ${r}`,{cause:c})):e()})})}async function lt(r){let e=I(),t=re(),s=D(),n=process.env.NODE_TLS_REJECT_UNAUTHORIZED;s.ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",console.error("WARNING: SSL certificate validation is disabled globally for this process during the login flow. All connections in this process will skip TLS verification. Only use ENTRYDESK_IGNORE_SSL_ERRORS for local development."));try{let i=Ce.create({baseUrl:e.replace(/\/?$/,"/"),timeout:3e4,hooks:{beforeError:[({error:a})=>(be(a)&&(a.request.headers.delete("authorization"),a.request.headers.delete("Authorization")),a)]}}),c;try{c=await i.post("v1/oauth/device/code",{json:{client_id:U,scope:Re}}).json()}catch(a){let k=a instanceof Error?a:new Error("Failed to request device code");throw r?.onError?.(k),k}let{device_code:S,user_code:d,expires_in:ae,interval:ce}=c,X=new URL("/oauth/device",t);X.searchParams.set("user_code",d);let V=X.toString();r?.onDeviceCodeReceived?.(d,V),r?.onBrowserOpening?.();try{await xe(V)}catch(a){process.env.DEBUG&&console.error("[DEBUG] Failed to open browser:",a)}r?.onWaitingForAuthorization?.();let Z=Math.max(ce,5)*1e3,le=Date.now()+ae*1e3;for(;Date.now()<le;){await Ae(Z);try{let a=await i.post("v1/oauth/token",{json:{grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:S,client_id:U}}).json();r?.onAuthorized?.();let k={};try{k=Ee(a.access_token)}catch{}return{accessToken:a.access_token,refreshToken:a.refresh_token??void 0,email:k.email||"",scopes:a.scope.split(" ").filter(B=>B.length>0)}}catch(a){if(a instanceof Te){let{code:B,error:ge}=te(a.data),O=B||ge;if(!O)continue;switch(O){case"authorization_pending":continue;case"slow_down":Z+=5e3;continue;case"access_denied":throw new Error("Authorization denied by user",{cause:a});case"expired_token":throw new Error("Device code expired. Please try again.",{cause:a});default:throw new Error(`Authorization failed: ${O||"Unknown error"}`,{cause:a})}}let k=a instanceof Error?a:new Error("Unknown error during authorization");throw r?.onError?.(k),k}}throw new Error("Device code expired. Please try again.")}finally{n===void 0?delete process.env.NODE_TLS_REJECT_UNAUTHORIZED:process.env.NODE_TLS_REJECT_UNAUTHORIZED=n}}var y=class extends Error{code;constructor(e,t){super(t),this.code=e}};function _e(r){try{let e=r.split(".");if(e.length<2)return null;let t=e[1].replace(/-/g,"+").replace(/_/g,"/"),s=(4-t.length%4)%4,n=t.padEnd(t.length+s,"="),i=Buffer.from(n,"base64").toString("utf8");return JSON.parse(i)}catch{return null}}function Ie(r,e=300){let s=_e(r)?.exp;if(typeof s!="number")return!1;let n=Math.floor(Date.now()/1e3);return s-n<=e}async function se(r){let e=r.accessToken;if(!Ie(e))return e;if(!r.refreshToken)throw await h.clear(),new y("session-expired","Session expired. Please run `entrydesk login` again.");try{let s=await new _().refreshOAuthToken({refreshToken:r.refreshToken,clientId:U});return await h.saveAccessToken(s.access_token),s.refresh_token&&await h.saveRefreshToken(s.refresh_token),s.access_token}catch{throw await h.clear(),new y("session-expired","Session expired. Please run `entrydesk login` again.")}}async function ht(){let r=K();if(r)return r.accessToken;let e=await h.getAll();if(!e?.accessToken)throw new y("not-logged-in","Not logged in. Run `entrydesk login` first.");return se(e)}async function yt(){let r=K();if(r)return{accessToken:r.accessToken,workspaceId:r.workspaceId};let e=L();if(e)return e;let t=await h.getAll();if(!t?.accessToken)throw new y("not-logged-in","Not logged in. Run `entrydesk login` first.");if(!t.workspaceId)throw new y("no-workspace","No workspace selected. Run `entrydesk workspaces` first.");return{accessToken:await se(t),workspaceId:t.workspaceId}}var f=class extends Error{constructor(t,s=1,n){super(t);this.exitCode=s;this.cause=n;this.name="CLIError"}exitCode;cause};function vt(r){let e=!!process.env.DEBUG;r instanceof f&&(console.error(`Error: ${r.message}`),r.cause&&(console.error(`Cause: ${r.cause.message}`),e&&r.cause.stack&&console.error(r.cause.stack)),process.exit(r.exitCode)),r instanceof y&&(console.error(r.message),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Ke&&(console.error("Request timed out. Please check your connection and try again."),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof De&&(console.error(`Request failed (${r.response.status}): ${r.response.statusText}`),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Error&&(console.error(`Unexpected error: ${r.message}`),e&&r.stack&&console.error(r.stack),process.exit(1)),console.error("An unknown error occurred"),process.exit(1)}var P="default",$e=/^[A-Za-z0-9_-]+$/,W=null;function Y(){return T.join(Ue.homedir(),".entrydesk")}function ie(){return T.join(Y(),"profiles")}function oe(){return T.join(Y(),"profiles.json")}function $(r){return T.join(ie(),r)}function G(r){if(!p.existsSync(r))p.mkdirSync(r,{mode:448,recursive:!0});else try{p.chmodSync(r,448)}catch{}}function Fe(){G(Y())}function H(){G(ie())}function Be(){let r=oe();try{if(!p.existsSync(r))return null;let e=p.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}function C(r){Fe();let e=oe();p.writeFileSync(e,JSON.stringify(r,null,2),{mode:384});try{p.chmodSync(e,384)}catch{}}function Oe(r){let e=r.profiles?.length?Array.from(new Set(r.profiles)):[],t=r.currentProfile&&e.includes(r.currentProfile)?r.currentProfile:e[0]||P;return e.length===0&&e.push(P),e.includes(t)||e.unshift(t),{currentProfile:t,profiles:e}}function x(r){H(),G($(r))}function v(){let r=Be();if(!r){let t={currentProfile:P,profiles:[P]};return C(t),H(),x(P),t}let e=Oe(r);return(e.currentProfile!==r.currentProfile||e.profiles.length!==r.profiles.length)&&C(e),H(),e}function A(r){if(!r)throw new f("Profile name is required.");if(!$e.test(r))throw new f("Invalid profile name. Use letters, numbers, dash, or underscore.")}function R(r,e){if(!r.profiles.includes(e))throw new f(`Profile not found: ${e}`)}function ne(r,e){if(r.profiles.includes(e))throw new f(`Profile already exists: ${e}`)}var o={DEFAULT_PROFILE:P,setOverrideProfile(r){W=r},getOverrideProfile(){return W},getProfileDir(r){return $(r)},getProfileConfigFile(r){return T.join(o.getProfileDir(r),"config.json")},getProfileCredentialsFile(r){return T.join(o.getProfileDir(r),"credentials.json")},getProfileNames(){return[...v().profiles]},getProfileCount(){return o.getProfileNames().length},getCurrentProfileName(){return v().currentProfile},getEffectiveProfileName(r){let e=v(),t=r||W||e.currentProfile;return A(t),R(e,t),t},ensureProfileExists(r){let e=v();A(r),R(e,r)},createProfile(r){A(r);let e=v();ne(e,r);let t={currentProfile:e.currentProfile,profiles:[...e.profiles,r]};C(t),x(r)},deleteProfile(r){A(r);let e=v();if(R(e,r),e.profiles.length===1)throw new f("Cannot delete the last profile.");let t=e.profiles.filter(i=>i!==r),s=e.currentProfile;s===r&&(s=t.includes(P)?P:t[0]),C({currentProfile:s,profiles:t});try{p.rmSync(o.getProfileDir(r),{recursive:!0,force:!0})}catch{}return{currentProfile:s}},renameProfile(r,e){A(r),A(e);let t=v();R(t,r),ne(t,e);let s=$(r),n=$(e);if(p.existsSync(s))try{p.renameSync(s,n)}catch(d){throw new f("Failed to rename profile directory.",1,d)}else x(e);let i=t.profiles.map(d=>d===r?e:d),c=t.currentProfile===r?e:t.currentProfile;return C({currentProfile:c,profiles:i}),{currentProfile:c}},setCurrentProfile(r){A(r);let e=v();R(e,r);let t={currentProfile:r,profiles:e.profiles};C(t),x(r)},ensureProfileDir:x};function Ne(r){let e=o.getEffectiveProfileName(r);return o.getProfileConfigFile(e)}function g(r){let e=Ne(r);try{if(!F.existsSync(e))return{};let t=F.readFileSync(e,"utf-8");return JSON.parse(t)}catch{return{}}}function m(r,e){let t=o.getEffectiveProfileName(e);o.ensureProfileDir(t);let s=o.getProfileConfigFile(t);F.writeFileSync(s,JSON.stringify(r,null,2),{mode:384});try{F.chmodSync(s,384)}catch{}}var J={getApiUrl(r){return g(r).apiUrl??null},setApiUrl(r,e){let t=g(e);t.apiUrl=r,m(t,e)},clearApiUrl(r){let e=g(r);delete e.apiUrl,m(e,r)},getHubUrl(r){return g(r).hubUrl??null},setHubUrl(r,e){let t=g(e);t.hubUrl=r,m(t,e)},getAll(r){return g(r)},setAll(r,e){m(r,e)},set(r,e,t){let s=g(t);s[r]=e,m(s,t)},get(r,e){return g(e)[r]},unset(r,e){let t=g(e);delete t[r],m(t,e)},getDefaultModel(r){return g(r).model?.default??null},setDefaultModel(r,e){let t=g(e);t.model={...t.model,default:r},m(t,e)},getDefaultConnectorIds(r){return g(r).connectors?.defaults??null},setDefaultConnectorIds(r,e){let t=g(e);t.connectors={...t.connectors,defaults:r},m(t,e)},getLocalTools(r){return g(r).localTools??null},setLocalTools(r,e){let t=g(e);t.localTools={...t.localTools,...r},m(t,e)}};var Me="https://api.entrydesk.com",je="https://app.entrydesk.com",ze=3100,Le=300*1e3;function q(r){return{apiUrl:J.getApiUrl(r)||process.env.ENTRYDESK_API_URL||Me,hubUrl:J.getHubUrl(r)||process.env.ENTRYDESK_HUB_URL||je,mcp:{httpPort:ze},auth:{loginTimeout:Le,ignoreSslErrors:process.env.ENTRYDESK_IGNORE_SSL_ERRORS==="true"||!1}}}function I(r){return q(r).apiUrl}function re(r){return q(r).hubUrl}function D(){return q().auth}export{o as a,J as b,q as c,I as d,re as e,D as f,h as g,_ as h,et as i,te as j,U as k,lt as l,y as m,Ie as n,se as o,ht as p,yt as q,f as r,vt as s};
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{c as a,d as b,e as c,f as d}from"./chunk-6A4DXLDW.js";export{b as getApiUrl,d as getAuthConfig,a as getConfig,c as getHubUrl};
2
+ import{c as a,d as b,e as c,f as d}from"./chunk-JTCLYSZY.js";export{b as getApiUrl,d as getAuthConfig,a as getConfig,c as getHubUrl};
@@ -1,4 +1,4 @@
1
1
  #!/usr/bin/env node
2
- import{a as f,b as s}from"./chunk-6A4DXLDW.js";var i=["apiUrl","hubUrl"];function l(e){return i.includes(e)}async function d(e){let n=e.action||"list",o=e.configKey,t=e.value,a=f.getEffectiveProfileName();if(n==="list"){let r=s.getAll(),c=Object.entries(r);if(e.json){console.log(JSON.stringify(r));return}if(console.log(`Profile: ${a}`),c.length===0){console.log("No configuration set."),console.log(`Available keys: ${i.join(", ")}`);return}console.log(`Configuration:
2
+ import{a as f,b as s}from"./chunk-JTCLYSZY.js";var i=["apiUrl","hubUrl"];function l(e){return i.includes(e)}async function d(e){let n=e.action||"list",o=e.configKey,t=e.value,a=f.getEffectiveProfileName();if(n==="list"){let r=s.getAll(),c=Object.entries(r);if(e.json){console.log(JSON.stringify(r));return}if(console.log(`Profile: ${a}`),c.length===0){console.log("No configuration set."),console.log(`Available keys: ${i.join(", ")}`);return}console.log(`Configuration:
3
3
  `);for(let[g,u]of c)console.log(` ${g}=${u}`);console.log(`
4
4
  Available keys: ${i.join(", ")}`);return}if(n==="get"){o||(console.error("Error: key is required for get action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1));let r=s.get(o);e.json?console.log(JSON.stringify({[o]:r??null})):console.log(r||"Not set");return}if(n==="set"){o||(console.error("Error: key is required for set action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),t||(console.error("Error: value is required for set action"),process.exit(1)),s.set(o,t),console.log(`Set ${o}=${t}`);return}if(n==="unset"){o||(console.error("Error: key is required for unset action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),s.unset(o),console.log(`Unset ${o}`);return}console.error(`Unknown action: ${n}`),process.exit(1)}export{d as runConfig};
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{c as i}from"./chunk-6A4DXLDW.js";import{Box as r,Text as e,render as l}from"ink";import{jsx as t,jsxs as n}from"react/jsx-runtime";function a(){let o=i();return n(r,{flexDirection:"column",children:[t(e,{bold:!0,children:"entrydesk config"}),t(e,{children:" "}),t(e,{children:"Manage CLI configuration"}),t(e,{children:" "}),t(e,{bold:!0,children:"Usage:"}),t(e,{children:" entrydesk config List all configuration"}),n(e,{children:[" entrydesk config get ","<key>"," Get a configuration value"]}),n(e,{children:[" ","entrydesk config set ","<key>"," ","<value>"," Set a configuration value"]}),n(e,{children:[" ","entrydesk config unset ","<key>"," Remove a configuration value"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Available keys:"}),n(e,{children:[" apiUrl API server URL (default: ",o.apiUrl,")"]}),n(e,{children:[" hubUrl Hub server URL (default: ",o.hubUrl,")"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Examples:"}),t(e,{children:" entrydesk config set apiUrl http://localhost:3200"}),t(e,{children:" entrydesk config get apiUrl"}),t(e,{children:" entrydesk config unset apiUrl"})]})}function g(){l(t(a,{}))}export{g as renderConfigHelp};
2
+ import{c as i}from"./chunk-JTCLYSZY.js";import{Box as r,Text as e,render as l}from"ink";import{jsx as t,jsxs as n}from"react/jsx-runtime";function a(){let o=i();return n(r,{flexDirection:"column",children:[t(e,{bold:!0,children:"entrydesk config"}),t(e,{children:" "}),t(e,{children:"Manage CLI configuration"}),t(e,{children:" "}),t(e,{bold:!0,children:"Usage:"}),t(e,{children:" entrydesk config List all configuration"}),n(e,{children:[" entrydesk config get ","<key>"," Get a configuration value"]}),n(e,{children:[" ","entrydesk config set ","<key>"," ","<value>"," Set a configuration value"]}),n(e,{children:[" ","entrydesk config unset ","<key>"," Remove a configuration value"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Available keys:"}),n(e,{children:[" apiUrl API server URL (default: ",o.apiUrl,")"]}),n(e,{children:[" hubUrl Hub server URL (default: ",o.hubUrl,")"]}),t(e,{children:" "}),t(e,{bold:!0,children:"Examples:"}),t(e,{children:" entrydesk config set apiUrl http://localhost:3200"}),t(e,{children:" entrydesk config get apiUrl"}),t(e,{children:" entrydesk config unset apiUrl"})]})}function g(){l(t(a,{}))}export{g as renderConfigHelp};
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
- import{h as c,q as s,s as i}from"./chunk-6A4DXLDW.js";async function p(l){try{let n,t;try{let o=await s();n=o.accessToken,t=o.workspaceId}catch(o){let r=o instanceof Error?o.message:"Authentication failed";console.error(r),process.exit(1)}let a=new c,{connectors:e}=await a.getConnectors(n,t);if(l.json){console.log(JSON.stringify(e));return}if(e.length===0){console.log("No connectors found in this workspace.");return}console.log(`Connected Connectors (${e.length}):
2
+ import{h as c,q as s,s as i}from"./chunk-JTCLYSZY.js";async function p(l){try{let n,t;try{let o=await s();n=o.accessToken,t=o.workspaceId}catch(o){let r=o instanceof Error?o.message:"Authentication failed";console.error(r),process.exit(1)}let a=new c,{connectors:e}=await a.getConnectors(n,t);if(l.json){console.log(JSON.stringify(e));return}if(e.length===0){console.log("No connectors found in this workspace.");return}console.log(`Connected Connectors (${e.length}):
3
3
  `);for(let o of e){let r=o.connected?"connected":"disconnected";console.log(` ${o.name} (${r})`),console.log(` Provider: ${o.provider}`),console.log(` ID: ${o.id}`),console.log("")}}catch(n){i(n)}}export{p as runConnectors};
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{a as l,s as f}from"./chunk-6A4DXLDW.js";function u(s,p,d=!1){let r={},e={};for(let a=d?0:1;a<s.length;a++){let t=s[a];if(t==="--json")r.json=!0;else if(t==="--help"||t==="-h")r.help=!0;else if(t==="--profile")r.profile=s[++a];else switch(p){case"login":break;case"task":if(t==="-m"||t==="--message")e.message=s[++a];else if(t==="-a"||t==="--agent")e.agentId=s[++a];else if(t==="--model")e.model=s[++a];else if(t==="--connectors"){let i=s[++a];e.connectors=i?.split(",").map(n=>n.trim())}else t==="-i"||t==="--interactive"?e.interactive=!0:t==="--full-output"?e.fullOutput=!0:t==="-c"||t==="--continue"?e.continue=parseInt(s[++a],10):t==="--plain"?e.plain=!0:t==="--output"?e.output=s[++a]:t==="--file-system"?e.fileSystem=!0:t==="--no-file-system"?e.noFileSystem=!0:t==="--dangerously-auto-approve-tools"&&(e.dangerouslyAutoApproveTools=!0);break;case"agents":if(t==="--name")e.name=s[++a];else if(t==="--description")e.description=s[++a];else if(t==="--system-prompt")e.systemPrompt=s[++a];else if(t==="--model-id")e.modelId=s[++a];else if(t==="--connector-ids"){let i=s[++a];e.connectorIds=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--capabilities"){let i=s[++a];e.capabilities=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--conversation-starters"){let i=s[++a];e.conversationStarters=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--tools"){let i=s[++a];e.tools=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--icon-id")e.iconId=s[++a];else if(t==="--limit"){let i=parseInt(s[++a],10);(isNaN(i)||i<1||i>100)&&(console.error("--limit must be an integer between 1 and 100"),process.exit(1)),e.limit=i}else if(t==="--next-key"){let i=s[++a];i||(console.error("--next-key requires a value"),process.exit(1)),e.nextKey=i}else t==="--all"?e.all=!0:t.startsWith("-")||(e.action?e.agentId=t:e.action=t);break;case"skills":t==="--force"?e.force=!0:t==="--me"||t==="--mine"?e.createdBy="me":t.startsWith("-")||(e.action?e.configKey=t:e.action=t);break;case"schedules":if(t==="--name")e.name=s[++a];else if(t==="--prompt")e.prompt=s[++a];else if(t==="--agent-id")e.agentId=s[++a];else if(t==="--starts-at")e.startsAt=s[++a];else if(t==="--utc-offset")e.utcOffset=s[++a];else if(t==="--repeat-type")e.repeatType=s[++a];else if(t==="--every")e.every=parseInt(s[++a],10);else if(t==="--time")e.time=s[++a];else if(t==="--days-of-week"){let i=s[++a];e.daysOfWeek=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else if(t==="--days-of-month"){let i=s[++a];e.daysOfMonth=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else t==="--last-day-of-month"?e.lastDayOfMonth=!0:t.startsWith("-")||(e.action?e.scheduleId=t:e.action=t);break;case"config":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")?e.configKey=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"profile":!e.action&&!t.startsWith("-")?e.action=t:!e.name&&!t.startsWith("-")?e.name=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"tasks":t==="--share"||t==="-s"?e.shareId=s[++a]:t==="--full-output"?e.fullOutput=!0:t==="--output"?e.output=s[++a]:!e.taskId&&!t.startsWith("-")&&(e.taskId=t);break;case"budget":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")&&(e.configKey=t);break;case"usage":if(t==="--limit")e.limit=parseInt(s[++a],10);else if(t==="--sort-by"){let i=s[++a];(i==="cost"||i==="operations")&&(e.sortBy=i)}break;case"mcp-server":t==="--http"?e.http=!0:(t==="-p"||t==="--port")&&(e.port=parseInt(s[++a],10));break;case"tool":t==="-i"||t==="--input"?e.input=s[++a]:t==="-f"||t==="--input-file"?e.inputFile=s[++a]:t==="-p"||t==="--prefix"?e.prefix=s[++a]:t.startsWith("-")||(e.action?e.name||(e.name=t):e.action=t);break;case"workspaces":!e.action&&!t.startsWith("-")&&(e.action=t);break;default:break}}switch(p){case"login":return{command:"login",...r,...e};case"logout":return{command:"logout",...r,...e};case"status":return{command:"status",...r,...e};case"workspaces":return{command:"workspaces",...r,...e};case"agents":return{command:"agents",...r,...e};case"models":return{command:"models",...r,...e};case"connectors":return{command:"connectors",...r,...e};case"skills":return{command:"skills",...r,...e};case"schedules":return{command:"schedules",...r,...e};case"config":return{command:"config",...r,...e};case"profile":return{command:"profile",...r,...e};case"task":return{command:"task",...r,...e};case"tasks":return{command:"tasks",...r,...e};case"budget":return{command:"budget",...r,...e};case"usage":return{command:"usage",...r,...e};case"mcp-server":return{command:"mcp-server",...r,...e};case"tool":return{command:"tool",...r,...e};case"version":return{command:"version",...r,...e};default:return{command:"help",...r,...e}}}var c=process.argv.slice(2);if(c[0]==="--help"||c[0]==="-h"){let{printHelp:s}=await import("./help-GFQ2C2W7.js");s(),process.exit(0)}if(c[0]==="--version"||c[0]==="-v"){let{printVersion:s}=await import("./version-S2OVXULD.js");s(),process.exit(0)}var m=!c[0]||c[0].startsWith("-"),k=m?"task":c[0],o=u(c,k,m);m&&o.command==="task"&&(o.interactive=!0);async function h(){try{if(o.command!=="profile"){let s=o.profile||l.getCurrentProfileName();l.ensureProfileExists(s),l.setOverrideProfile(s)}switch(o.command){case"login":{let{runLogin:s}=await import("./login-XTZVZRUS.js");await s(o);break}case"logout":{let{runLogout:s}=await import("./logout-5JLCRCFI.js");await s(o);break}case"status":{let{runStatus:s}=await import("./status-55CKVYTS.js");await s(o);break}case"workspaces":{let{runWorkspaces:s}=await import("./workspaces-H4RBN3TB.js");await s(o);break}case"agents":{let{runAgents:s}=await import("./agents-54AYFONZ.js");await s(o);break}case"models":{let{runModels:s}=await import("./models-2UVRAIOT.js");await s(o);break}case"connectors":{let{runConnectors:s}=await import("./connectors-FBIGY7P4.js");await s(o);break}case"skills":{let{runSkills:s}=await import("./skills-EIODYDTC.js");await s(o);break}case"schedules":{let{runSchedules:s}=await import("./schedules-4WWXQIGY.js");await s(o);break}case"tasks":{let{runTasks:s}=await import("./tasks-BZYMJWPS.js");await s(o);break}case"budget":{let{runBudget:s}=await import("./budget-U7PCUVLC.js");await s(o);break}case"usage":{let{runUsage:s}=await import("./usage-5H6DM7VO.js");await s(o);break}case"config":{if(o.action==="help"||c[1]==="--help"){let{renderConfigHelp:s}=await import("./config-help-WSX3YYVB.js");s()}else{let{runConfig:s}=await import("./config-D5TRCK7Z.js");await s(o)}break}case"profile":{let{runProfile:s}=await import("./profile-JOW6Z7HB.js");await s(o);break}case"task":{if(c[1]==="--help"||c[1]==="-h"){let{printHelp:s}=await import("./help-GFQ2C2W7.js");s()}else{let{runTask:s}=await import("./task-DGCXP6LE.js");await s(o)}break}case"mcp-server":{let{startMcpServer:s}=await import("./mcp-ZBXLO5XO.js");await s({mode:o.http?"http":"stdio",port:o.port});break}case"tool":{let{runTool:s}=await import("./tool-O3EZWZRD.js");await s(o);break}case"version":{let{printVersion:s}=await import("./version-S2OVXULD.js");s();break}default:{let{printHelp:s}=await import("./help-GFQ2C2W7.js");s();break}}}catch(s){f(s)}}h();
2
+ import{a as l,s as f}from"./chunk-JTCLYSZY.js";function u(s,p,d=!1){let r={},e={};for(let a=d?0:1;a<s.length;a++){let t=s[a];if(t==="--json")r.json=!0;else if(t==="--help"||t==="-h")r.help=!0;else if(t==="--profile")r.profile=s[++a];else switch(p){case"login":break;case"task":if(t==="-m"||t==="--message")e.message=s[++a];else if(t==="-a"||t==="--agent")e.agentId=s[++a];else if(t==="--model")e.model=s[++a];else if(t==="--connectors"){let i=s[++a];e.connectors=i?.split(",").map(n=>n.trim())}else t==="-i"||t==="--interactive"?e.interactive=!0:t==="--full-output"?e.fullOutput=!0:t==="-c"||t==="--continue"?e.continue=parseInt(s[++a],10):t==="--plain"?e.plain=!0:t==="--output"?e.output=s[++a]:t==="--file-system"?e.fileSystem=!0:t==="--no-file-system"?e.noFileSystem=!0:t==="--dangerously-auto-approve-tools"&&(e.dangerouslyAutoApproveTools=!0);break;case"agents":if(t==="--name")e.name=s[++a];else if(t==="--description")e.description=s[++a];else if(t==="--system-prompt")e.systemPrompt=s[++a];else if(t==="--model-id")e.modelId=s[++a];else if(t==="--connector-ids"){let i=s[++a];e.connectorIds=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--capabilities"){let i=s[++a];e.capabilities=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--conversation-starters"){let i=s[++a];e.conversationStarters=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--tools"){let i=s[++a];e.tools=i?.split(",").map(n=>n.trim()).filter(Boolean)}else if(t==="--icon-id")e.iconId=s[++a];else if(t==="--limit"){let i=parseInt(s[++a],10);(isNaN(i)||i<1||i>100)&&(console.error("--limit must be an integer between 1 and 100"),process.exit(1)),e.limit=i}else if(t==="--next-key"){let i=s[++a];i||(console.error("--next-key requires a value"),process.exit(1)),e.nextKey=i}else t==="--all"?e.all=!0:t.startsWith("-")||(e.action?e.agentId=t:e.action=t);break;case"skills":t==="--force"?e.force=!0:t==="--me"||t==="--mine"?e.createdBy="me":t.startsWith("-")||(e.action?e.configKey=t:e.action=t);break;case"schedules":if(t==="--name")e.name=s[++a];else if(t==="--prompt")e.prompt=s[++a];else if(t==="--agent-id")e.agentId=s[++a];else if(t==="--starts-at")e.startsAt=s[++a];else if(t==="--utc-offset")e.utcOffset=s[++a];else if(t==="--repeat-type")e.repeatType=s[++a];else if(t==="--every")e.every=parseInt(s[++a],10);else if(t==="--time")e.time=s[++a];else if(t==="--days-of-week"){let i=s[++a];e.daysOfWeek=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else if(t==="--days-of-month"){let i=s[++a];e.daysOfMonth=i?.split(",").map(n=>parseInt(n.trim(),10)).filter(n=>!isNaN(n))}else t==="--last-day-of-month"?e.lastDayOfMonth=!0:t.startsWith("-")||(e.action?e.scheduleId=t:e.action=t);break;case"config":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")?e.configKey=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"profile":!e.action&&!t.startsWith("-")?e.action=t:!e.name&&!t.startsWith("-")?e.name=t:!e.value&&!t.startsWith("-")&&(e.value=t);break;case"tasks":t==="--share"||t==="-s"?e.shareId=s[++a]:t==="--full-output"?e.fullOutput=!0:t==="--output"?e.output=s[++a]:!e.taskId&&!t.startsWith("-")&&(e.taskId=t);break;case"budget":!e.action&&!t.startsWith("-")?e.action=t:!e.configKey&&!t.startsWith("-")&&(e.configKey=t);break;case"usage":if(t==="--limit")e.limit=parseInt(s[++a],10);else if(t==="--sort-by"){let i=s[++a];(i==="cost"||i==="operations")&&(e.sortBy=i)}break;case"mcp-server":t==="--http"?e.http=!0:(t==="-p"||t==="--port")&&(e.port=parseInt(s[++a],10));break;case"tool":t==="-i"||t==="--input"?e.input=s[++a]:t==="-f"||t==="--input-file"?e.inputFile=s[++a]:t==="-p"||t==="--prefix"?e.prefix=s[++a]:t.startsWith("-")||(e.action?e.name||(e.name=t):e.action=t);break;case"workspaces":!e.action&&!t.startsWith("-")&&(e.action=t);break;default:break}}switch(p){case"login":return{command:"login",...r,...e};case"logout":return{command:"logout",...r,...e};case"status":return{command:"status",...r,...e};case"workspaces":return{command:"workspaces",...r,...e};case"agents":return{command:"agents",...r,...e};case"models":return{command:"models",...r,...e};case"connectors":return{command:"connectors",...r,...e};case"skills":return{command:"skills",...r,...e};case"schedules":return{command:"schedules",...r,...e};case"config":return{command:"config",...r,...e};case"profile":return{command:"profile",...r,...e};case"task":return{command:"task",...r,...e};case"tasks":return{command:"tasks",...r,...e};case"budget":return{command:"budget",...r,...e};case"usage":return{command:"usage",...r,...e};case"mcp-server":return{command:"mcp-server",...r,...e};case"tool":return{command:"tool",...r,...e};case"version":return{command:"version",...r,...e};default:return{command:"help",...r,...e}}}var c=process.argv.slice(2);if(c[0]==="--help"||c[0]==="-h"){let{printHelp:s}=await import("./help-GFQ2C2W7.js");s(),process.exit(0)}if(c[0]==="--version"||c[0]==="-v"){let{printVersion:s}=await import("./version-5IAC3BB3.js");s(),process.exit(0)}var m=!c[0]||c[0].startsWith("-"),k=m?"task":c[0],o=u(c,k,m);m&&o.command==="task"&&(o.interactive=!0);async function h(){try{if(o.command!=="profile"){let s=o.profile||l.getCurrentProfileName();l.ensureProfileExists(s),l.setOverrideProfile(s)}switch(o.command){case"login":{let{runLogin:s}=await import("./login-VGPCYAW2.js");await s(o);break}case"logout":{let{runLogout:s}=await import("./logout-WDQ5ZZH2.js");await s(o);break}case"status":{let{runStatus:s}=await import("./status-2YOTI6DI.js");await s(o);break}case"workspaces":{let{runWorkspaces:s}=await import("./workspaces-DWQJOVPH.js");await s(o);break}case"agents":{let{runAgents:s}=await import("./agents-ZR66NNSY.js");await s(o);break}case"models":{let{runModels:s}=await import("./models-V4OAT2JA.js");await s(o);break}case"connectors":{let{runConnectors:s}=await import("./connectors-EKR3476E.js");await s(o);break}case"skills":{let{runSkills:s}=await import("./skills-YLNX66WZ.js");await s(o);break}case"schedules":{let{runSchedules:s}=await import("./schedules-MQ3EOUY3.js");await s(o);break}case"tasks":{let{runTasks:s}=await import("./tasks-SL45DMX5.js");await s(o);break}case"budget":{let{runBudget:s}=await import("./budget-EGS3V6HN.js");await s(o);break}case"usage":{let{runUsage:s}=await import("./usage-G3AVDMRT.js");await s(o);break}case"config":{if(o.action==="help"||c[1]==="--help"){let{renderConfigHelp:s}=await import("./config-help-YO4QSRCK.js");s()}else{let{runConfig:s}=await import("./config-4RVJN66P.js");await s(o)}break}case"profile":{let{runProfile:s}=await import("./profile-ILE2CZXU.js");await s(o);break}case"task":{if(c[1]==="--help"||c[1]==="-h"){let{printHelp:s}=await import("./help-GFQ2C2W7.js");s()}else{let{runTask:s}=await import("./task-ZOGTKVTY.js");await s(o)}break}case"mcp-server":{let{startMcpServer:s}=await import("./mcp-ULOVG4WA.js");await s({mode:o.http?"http":"stdio",port:o.port});break}case"tool":{let{runTool:s}=await import("./tool-M7CAZ2AI.js");await s(o);break}case"version":{let{printVersion:s}=await import("./version-5IAC3BB3.js");s();break}default:{let{printHelp:s}=await import("./help-GFQ2C2W7.js");s();break}}}catch(s){f(s)}}h();
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{g as l,h as c,i as r,l as a}from"./chunk-6A4DXLDW.js";async function h(o){let i=r();if(i?.authSource==="sandbox-env"){o.json?console.log(JSON.stringify({alreadyAuthenticated:!0,authSource:i.authSource,workspaceId:i.workspaceId})):(console.log(`Already authenticated via ${i.label}.`),console.log("No login required \u2014 environment credentials are active."));return}if(process.env.DEBUG){let{getApiUrl:s,getHubUrl:t}=await import("./config-LJMAX7PD.js");console.log(`[DEBUG] Hub URL: ${t()}`),console.log(`[DEBUG] API URL: ${s()}`)}let e=await a({onDeviceCodeReceived:(s,t)=>{o.json||(console.log(""),console.log("To authenticate, please:"),console.log(""),console.log(` 1. Visit: ${t}`),console.log(` 2. Enter code: ${s}`),console.log(""))},onBrowserOpening:()=>{o.json||console.log("Opening browser...")},onWaitingForAuthorization:()=>{o.json||console.log("Waiting for authorization...")},onAuthorized:()=>{o.json||console.log("Authorization successful!")}}),g=new c,{workspaces:u}=await g.getWorkspaces(e.accessToken),n=u[0];await l.saveAll({accessToken:e.accessToken,refreshToken:e.refreshToken,email:e.email,workspaceId:n?.id}),o.json?console.log(JSON.stringify({email:e.email,workspaceId:n?.id,workspaceName:n?.name})):(console.log(`Logged in as ${e.email}`),n&&console.log(`Workspace: ${n.name}`))}export{h as runLogin};
2
+ import{g as l,h as c,i as r,l as a}from"./chunk-JTCLYSZY.js";async function h(o){let i=r();if(i?.authSource==="sandbox-env"){o.json?console.log(JSON.stringify({alreadyAuthenticated:!0,authSource:i.authSource,workspaceId:i.workspaceId})):(console.log(`Already authenticated via ${i.label}.`),console.log("No login required \u2014 environment credentials are active."));return}if(process.env.DEBUG){let{getApiUrl:s,getHubUrl:t}=await import("./config-25E5B67E.js");console.log(`[DEBUG] Hub URL: ${t()}`),console.log(`[DEBUG] API URL: ${s()}`)}let e=await a({onDeviceCodeReceived:(s,t)=>{o.json||(console.log(""),console.log("To authenticate, please:"),console.log(""),console.log(` 1. Visit: ${t}`),console.log(` 2. Enter code: ${s}`),console.log(""))},onBrowserOpening:()=>{o.json||console.log("Opening browser...")},onWaitingForAuthorization:()=>{o.json||console.log("Waiting for authorization...")},onAuthorized:()=>{o.json||console.log("Authorization successful!")}}),g=new c,{workspaces:u}=await g.getWorkspaces(e.accessToken),n=u[0];await l.saveAll({accessToken:e.accessToken,refreshToken:e.refreshToken,email:e.email,workspaceId:n?.id}),o.json?console.log(JSON.stringify({email:e.email,workspaceId:n?.id,workspaceName:n?.name})):(console.log(`Logged in as ${e.email}`),n&&console.log(`Workspace: ${n.name}`))}export{h as runLogin};
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{g as r,h as e,k as t,s as n}from"./chunk-6A4DXLDW.js";async function f(i){try{let o=await r.getAll();if(!o){console.log("Not logged in");return}try{o.refreshToken&&await new e().revokeOAuthToken({token:o.refreshToken,clientId:t})}catch{}await r.clear(),console.log("Logged out successfully")}catch(o){n(o)}}export{f as runLogout};
2
+ import{g as r,h as e,k as t,s as n}from"./chunk-JTCLYSZY.js";async function f(i){try{let o=await r.getAll();if(!o){console.log("Not logged in");return}try{o.refreshToken&&await new e().revokeOAuthToken({token:o.refreshToken,clientId:t})}catch{}await r.clear(),console.log("Logged out successfully")}catch(o){n(o)}}export{f as runLogout};
@@ -1,4 +1,4 @@
1
1
  #!/usr/bin/env node
2
- import{c as m,g as u,n as y,o as w,q as f}from"./chunk-6A4DXLDW.js";import h from"http";import{stderr as T}from"process";import{Client as k}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as C}from"@modelcontextprotocol/sdk/client/streamableHttp.js";import{Server as v}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as P}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as A}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{CallToolRequestSchema as O,ListToolsRequestSchema as E}from"@modelcontextprotocol/sdk/types.js";function a(c){T.write(`${c}
2
+ import{c as m,g as u,n as y,o as w,q as f}from"./chunk-JTCLYSZY.js";import h from"http";import{stderr as T}from"process";import{Client as k}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as C}from"@modelcontextprotocol/sdk/client/streamableHttp.js";import{Server as v}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as P}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as A}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{CallToolRequestSchema as O,ListToolsRequestSchema as E}from"@modelcontextprotocol/sdk/types.js";function a(c){T.write(`${c}
3
3
  `)}async function g(c,e,o){let r=new k({name:"entrydesk-cli-proxy",version:"1.0.0"}),i=new URL(`${c}/v1/workspaces/${o}/mcp`),t=new C(i,{requestInit:{headers:{Authorization:`Bearer ${e}`}}});return await r.connect(t),r}function S(c){let e=new v({name:"entrydesk-cli",version:"1.0.0"},{capabilities:{tools:{}}});return e.setRequestHandler(E,async()=>({tools:(await(await c()).listTools()).tools})),e.setRequestHandler(O,async o=>{let{name:r,arguments:i}=o.params,n=await(await c()).callTool({name:r,arguments:i}),l=Array.isArray(n.content)?[...n.content]:[];return n.structuredContent&&l.push({type:"text",text:JSON.stringify(n.structuredContent,null,2)}),{content:l,structuredContent:n.structuredContent,isError:n.isError}}),e}async function H(c,e,o){let r=h.createServer(async(i,t)=>{if(i.method==="OPTIONS"){t.setHeader("Access-Control-Allow-Origin","*"),t.setHeader("Access-Control-Allow-Methods","GET, POST, DELETE, OPTIONS"),t.setHeader("Access-Control-Allow-Headers","Content-Type, Accept"),t.writeHead(204),t.end();return}if(i.url!=="/mcp"){t.writeHead(404,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Not found"}));return}let n=S(c),l=new A({sessionIdGenerator:void 0});if(t.setHeader("Access-Control-Allow-Origin","*"),t.on("close",()=>{l.close(),n.close()}),await n.connect(l),i.method==="POST"){let p="";i.on("data",s=>{p+=s.toString()}),i.on("end",async()=>{try{let s=JSON.parse(p);await l.handleRequest(i,t,s)}catch{t.writeHead(400,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:"Invalid JSON"}))}})}else await l.handleRequest(i,t)});r.listen(o,()=>{a(`EntryDesk MCP server running at http://localhost:${o}/mcp`),a("Press Ctrl+C to stop")}),process.on("SIGINT",async()=>{a(`
4
4
  Shutting down...`),r.close(),await e(),process.exit(0)}),process.on("SIGTERM",async()=>{r.close(),await e(),process.exit(0)})}async function x(c,e){let o=S(c),r=new P;r.onclose=async()=>{await e()},await o.connect(r)}async function L(c={mode:"stdio"}){process.on("unhandledRejection",e=>{console.error("[entrydesk-mcp] Unhandled rejection:",e)}),process.on("uncaughtException",e=>{console.error("[entrydesk-mcp] Uncaught exception:",e)});try{a("[entrydesk-mcp] Starting MCP server...");let e,o;try{let s=await f();e=s.accessToken,o=s.workspaceId}catch(s){let d=s instanceof Error?s.message:"Authentication failed";console.error(d),process.exit(1)}let{apiUrl:r,mcp:i}=m();a(`[entrydesk-mcp] Connecting to ${r}...`),a(`[entrydesk-mcp] Workspace: ${o}`);let t=await g(r,e,o);a("[entrydesk-mcp] Connected to EntryDesk API");let n=null,l=async()=>y(e)?n||(n=(async()=>{a("[entrydesk-mcp] Token expiring soon, refreshing...");let s=await u.getAll();if(!s?.accessToken)throw new Error("Not logged in. Please run `entrydesk login` again.");let d=await w(s);if(d!==e){e=d;try{await t.close()}catch{}t=await g(r,e,o),a("[entrydesk-mcp] Token refreshed, reconnected")}return t})().finally(()=>{n=null}),n):t,p=async()=>{try{await t.close()}catch{}};if(c.mode==="http"){let s=c.port??i.httpPort;await H(l,p,s)}else a("[entrydesk-mcp] Starting stdio server..."),await x(l,p),a("[entrydesk-mcp] Stdio server started")}catch(e){console.error("[entrydesk-mcp] Fatal error:",e),process.exit(1)}}export{L as startMcpServer};
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
- import{h as n,q as t,s as l}from"./chunk-6A4DXLDW.js";async function p(c){try{let e,r;try{let o=await t();e=o.accessToken,r=o.workspaceId}catch(o){let a=o instanceof Error?o.message:"Authentication failed";console.error(a),process.exit(1)}let i=new n,{models:s}=await i.getModels(e,r);if(c.json){console.log(JSON.stringify(s));return}if(s.length===0){console.log("No models available in this workspace.");return}console.log(`Available Models (${s.length}):
2
+ import{h as n,q as t,s as l}from"./chunk-JTCLYSZY.js";async function p(c){try{let e,r;try{let o=await t();e=o.accessToken,r=o.workspaceId}catch(o){let a=o instanceof Error?o.message:"Authentication failed";console.error(a),process.exit(1)}let i=new n,{models:s}=await i.getModels(e,r);if(c.json){console.log(JSON.stringify(s));return}if(s.length===0){console.log("No models available in this workspace.");return}console.log(`Available Models (${s.length}):
3
3
  `);for(let o of s)console.log(` ${o.name}`),o.description&&console.log(` ${o.description.slice(0,80)}`),console.log(` ID: ${o.id}`),console.log("")}catch(e){l(e)}}export{p as runModels};
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{a as t,b as a,g as m,r as f,s as d}from"./chunk-6A4DXLDW.js";function P(){console.log(`
2
+ import{a as t,b as a,g as m,r as f,s as d}from"./chunk-JTCLYSZY.js";function P(){console.log(`
3
3
  Usage: entrydesk profile [list|show|current|create|use|delete|rename|clone] [args]
4
4
 
5
5
  Commands:
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as f,q as m,s as p}from"./chunk-6A4DXLDW.js";function d(){console.log(`
2
+ import{h as f,q as m,s as p}from"./chunk-JTCLYSZY.js";function d(){console.log(`
3
3
  Usage: entrydesk schedules [list|get|create|delete] [options]
4
4
 
5
5
  Commands:
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as S,j as z,q as I,s as P}from"./chunk-6A4DXLDW.js";import A from"crypto";import g from"fs";import i from"fs/promises";import b from"os";import o from"path";import{Readable as j}from"stream";import{pipeline as E}from"stream/promises";import N from"adm-zip";import O from"archiver";import{isHTTPError as T}from"ky";function x(){console.log(`
2
+ import{h as S,j as z,q as I,s as P}from"./chunk-JTCLYSZY.js";import A from"crypto";import g from"fs";import i from"fs/promises";import b from"os";import o from"path";import{Readable as j}from"stream";import{pipeline as E}from"stream/promises";import N from"adm-zip";import O from"archiver";import{isHTTPError as T}from"ky";function x(){console.log(`
3
3
  Usage: entrydesk skills [list|upload|delete|download] [options]
4
4
 
5
5
  Commands:
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{a as c,b as i,g as a,h as g,i as f,m as p,p as d,s as u}from"./chunk-6A4DXLDW.js";async function W(t){try{let o=c.getEffectiveProfileName(),n={model:i.getDefaultModel(),connectors:i.getDefaultConnectorIds()},r=f();if(r){t.json?console.log(JSON.stringify({loggedIn:!0,authSource:r.authSource,profile:o,workspaceId:r.workspaceId,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Authenticated via ${r.label} (no login required)`),console.log(`Workspace ID: ${r.workspaceId}`));return}let e=await a.getAll();if(!e){t.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let l;if(e.workspaceId)try{let s=new g,m=await d(),{workspaces:k}=await s.getWorkspaces(m);l=k.find(I=>I.id===e.workspaceId)?.name}catch(s){if(s instanceof p){t.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}}t.json?console.log(JSON.stringify({loggedIn:!0,authSource:"file",profile:o,email:e.email,workspaceId:e.workspaceId,workspaceName:l,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Logged in as ${e.email}`),l&&console.log(`Workspace: ${l}`),e.workspaceId&&console.log(`Workspace ID: ${e.workspaceId}`))}catch(o){u(o)}}export{W as runStatus};
2
+ import{a as c,b as i,g as a,h as g,i as f,m as p,p as d,s as u}from"./chunk-JTCLYSZY.js";async function W(t){try{let o=c.getEffectiveProfileName(),n={model:i.getDefaultModel(),connectors:i.getDefaultConnectorIds()},r=f();if(r){t.json?console.log(JSON.stringify({loggedIn:!0,authSource:r.authSource,profile:o,workspaceId:r.workspaceId,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Authenticated via ${r.label} (no login required)`),console.log(`Workspace ID: ${r.workspaceId}`));return}let e=await a.getAll();if(!e){t.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let l;if(e.workspaceId)try{let s=new g,m=await d(),{workspaces:k}=await s.getWorkspaces(m);l=k.find(I=>I.id===e.workspaceId)?.name}catch(s){if(s instanceof p){t.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}}t.json?console.log(JSON.stringify({loggedIn:!0,authSource:"file",profile:o,email:e.email,workspaceId:e.workspaceId,workspaceName:l,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Logged in as ${e.email}`),l&&console.log(`Workspace: ${l}`),e.workspaceId&&console.log(`Workspace ID: ${e.workspaceId}`))}catch(o){u(o)}}export{W as runStatus};
@@ -0,0 +1,185 @@
1
+ #!/usr/bin/env node
2
+ import{a as ie,b as fe,c as Bt,g as rt,h as pe,m as Je,p as an,q as Me,s as cn}from"./chunk-JTCLYSZY.js";import{render as ds}from"ink";import{v4 as io}from"uuid";import{exec as fo}from"child_process";import po from"fs";import Oe from"fs/promises";import dn from"os";import Ut from"path";import{promisify as mo}from"util";import{glob as go}from"glob";var ho=mo(fo),yo=`## Filesystem Tool Instructions
3
+
4
+ You have access to filesystem tools that allow you to interact with the user's local filesystem.
5
+
6
+ ### Available Operations
7
+
8
+ - **Read File**: Read the contents of a file
9
+ - **Read Multiple Files**: Read multiple files at once (max 10)
10
+ - **Write File**: Create or overwrite a file
11
+ - **Create Directory**: Create a new directory (including parent directories)
12
+ - **List Directory**: List files and subdirectories
13
+ - **Search Files**: Search for files matching a glob pattern
14
+ - **Get File Info**: Get metadata about a file or directory
15
+ - **Move File**: Move or rename a file or directory
16
+ - **Execute Command**: Run shell commands on the user's machine
17
+
18
+ ### Important Notes
19
+
20
+ - Always use absolute paths when possible
21
+ - Be mindful of file permissions and access restrictions
22
+ - Large files will be truncated in responses
23
+ - Search results are limited to prevent overwhelming responses
24
+ - Execute Command has a default timeout of 30 seconds (max 5 minutes)
25
+ - The current working directory is: ${process.cwd()}
26
+ - The user's home directory is: ${dn.homedir()}
27
+ `,wo=[{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 fn(){return{name:"filesystem",systemPrompt:yo,tools:wo}}function Ae(e){return e.startsWith("~/")?Ut.join(dn.homedir(),e.slice(2)):e}function yt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
28
+
29
+ ... (truncated, ${e.length-t} more characters)`}function un(e){let t=e&&typeof e=="object"&&"code"in e?String(e.code):void 0,n=e instanceof Error?e.message:String(e);switch(t){case"EACCES":case"EPERM":return`${n}
30
+ Permission denied by the operating system. On macOS this is usually a privacy restriction \u2014 access can be granted under System Settings \u2192 Privacy & Security \u2192 Files and Folders (or Full Disk Access).`;case"ENOENT":return`${n}
31
+ The path does not exist.`;case"ENOTDIR":return`${n}
32
+ A component of the path is not a directory.`;case"EISDIR":return`${n}
33
+ The path is a directory, not a file.`;default:return n}}async function pn(e,t){try{switch(e){case"filesystem__read_file":{let n=Ae(t.path),s=await Oe.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 l of n){let a=Ae(l);try{let g=await Oe.readFile(a,"utf-8");s[l]=yt(g,5e4)}catch(g){s[l]={error:un(g)}}}return{success:!0,result:s}}case"filesystem__write_file":{let n=Ae(t.path),s=t.content;return await Oe.mkdir(Ut.dirname(n),{recursive:!0}),await Oe.writeFile(n,s,"utf-8"),{success:!0,result:{written:n}}}case"filesystem__create_directory":{let n=Ae(t.path);return await Oe.mkdir(n,{recursive:!0}),{success:!0,result:{created:n}}}case"filesystem__list_directory":{let n=Ae(t.path);return{success:!0,result:(await Oe.readdir(n,{withFileTypes:!0})).map(a=>({name:a.name,type:a.isDirectory()?"directory":a.isFile()?"file":a.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let n=t.pattern,s=t.cwd?Ae(t.cwd):process.cwd(),l=await go(n,{cwd:s,nodir:!0,maxDepth:10});return{success:!0,result:{files:l.slice(0,100),total:l.length,truncated:l.length>100}}}case"filesystem__get_file_info":{let n=Ae(t.path),s=await Oe.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=Ae(t.source),s=Ae(t.destination);return await Oe.mkdir(Ut.dirname(s),{recursive:!0}),await Oe.rename(n,s),{success:!0,result:{moved:{from:n,to:s}}}}case"filesystem__execute_command":{let n=t.command,s=t.cwd?Ae(t.cwd):process.cwd(),l=Math.min(t.timeout||3e4,3e5);if(!po.existsSync(s))return{success:!1,error:`Working directory does not exist: ${s}`};let{stdout:a,stderr:g}=await ho(n,{cwd:s,timeout:l,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:yt(a,5e4),stderr:yt(g,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(n){return{success:!1,error:un(n)}}}function jt(e){return e.startsWith("filesystem__")}function mn(){return[fn()]}function wt(){return mn().flatMap(e=>e.tools)}function xt(){return mn().map(e=>e.systemPrompt).filter(Boolean).join(`
34
+
35
+ `)}function Be(e){return jt(e)}async function Tt(e,t){return jt(e)?pn(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as ye,Text as F,useInput as nn}from"ink";import on from"ink-spinner";import{useCallback as sn,useEffect as Et,useRef as rn,useState as os}from"react";import{Box as kt,Text as it}from"ink";import{jsx as Ct,jsxs as lt}from"react/jsx-runtime";function gn(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function hn({items:e,activeIndex:t,selectedIds:n,multiSelect:s=!1,visible:l,title:a,pageSize:g=10}){if(!l||e.length===0)return null;let y=process.stdout.columns??80,w=s?4:0,h=Math.max(20,y-2-2-w),O=Math.max(1,g),$=Math.floor(t/O)*O,P=Math.min(e.length,$+O),H=e.slice($,P);return lt(kt,{flexDirection:"column",marginBottom:1,children:[Ct(it,{bold:!0,color:"cyan",children:a}),Ct(kt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:H.map((k,b)=>{let D=$+b===t,G=n?.has(k.id),Q=gn(k.name,h),j=k.description?gn(k.description,Math.max(0,h-w)):"",J=s?" ".repeat(w):"";return lt(kt,{paddingX:1,flexDirection:"column",children:[lt(kt,{children:[s&&Ct(it,{color:G?"green":"gray",children:G?"[\u2713] ":"[ ] "}),Ct(it,{backgroundColor:D?"cyan":void 0,color:D?"black":G?"green":"white",bold:!0,children:Q})]}),j&&lt(it,{dimColor:!0,children:[J,"\xB7 ",j]})]},k.id)})}),lt(it,{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>O?` \xB7 Showing ${$+1}-${P} of ${e.length}`:""]})]})}import{Box as Wt,Text as at}from"ink";import{jsx as ct,jsxs as Mt}from"react/jsx-runtime";function yn({suggestions:e,activeIndex:t,visible:n}){return!n||e.length===0?null:Mt(Wt,{flexDirection:"column",marginBottom:1,children:[ct(Wt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((s,l)=>{let a=l===t,g=s.aliases.length>0?` (${s.aliases.join(", ")})`:"";return Mt(Wt,{paddingX:1,children:[Mt(at,{backgroundColor:a?"cyan":void 0,color:a?"black":"cyan",bold:a,children:["/",s.name]}),ct(at,{dimColor:!0,children:g}),ct(at,{children:" - "}),ct(at,{color:a?"white":"gray",children:s.description})]},s.name)})}),ct(at,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as xo,Text as wn,useInput as To,useStdout as ko}from"ink";import{useCallback as xn,useEffect as Tn,useMemo as Gt,useRef as kn,useState as Cn}from"react";import{jsx as Jt}from"react/jsx-runtime";function bt(e,t){return e<0?0:e>t?t:e}function qt(e){return Array.from(e)}function $t(e){return/\s/.test(e)}function Ht(e,t){let n=t;for(;n>0&&$t(e[n-1]??"");)n-=1;for(;n>0&&!$t(e[n-1]??"");)n-=1;return n}function bn(e,t){let n=t;for(;n<e.length&&$t(e[n]??"");)n+=1;for(;n<e.length&&!$t(e[n]??"");)n+=1;return n}function Co(e){let t=[],n=[],s=[],l=0;n.push(0),e.forEach((g,y)=>{if(g===`
36
+ `){t.push(s),s=[],l=y+1,n.push(l);return}s.push(g)}),t.push(s);let a=t.map(g=>g.length);return{lines:t,lineStarts:n,lineLengths:a}}function $n(e,t,n){for(let l=0;l<t.length;l+=1){let a=t[l]??0,g=n[l]??0,y=a+g;if(e<=y)return{row:l,col:e-a}}let s=Math.max(0,t.length-1);return{row:s,col:n[s]??0}}var bo=2;function In({value:e,onChange:t,onSubmit:n,onPaste:s,focus:l=!0,leadingOffset:a=0,multiline:g=!1}){let[y,w]=Cn(()=>qt(e).length),h=kn(null),[O,$]=Cn(0),P=kn(null),{stdout:H}=ko(),k=Gt(()=>qt(e),[e]),{lines:b,lineStarts:N,lineLengths:D}=Gt(()=>Co(k),[k]),{row:G,col:Q}=Gt(()=>$n(y,N,D),[y,N,D]),j=Math.max(1,(H?.columns??80)-a);Tn(()=>{h.current!==e?(w(k.length),P.current=null):w(i=>bt(i,k.length)),h.current=e},[e,k.length]),Tn(()=>{$(i=>{let p=i;Q<p?p=Q:Q>=p+j&&(p=Q-j+1);let E=D[G]??0,B=Q===E?E+1:E,C=Math.max(0,B-j);return p>C&&(p=C),p<0&&(p=0),p})},[j,Q,G,D]);let J=xn((i,p)=>{h.current=i,t(i),w(p),P.current=null},[t]),le=xn(async(i,p)=>{if(!l)return;let{row:E,col:B}=$n(y,N,D),C=b[E]??[],de=D[E]??0,Y=b.length>1;if(g&&(p.meta&&p.return||p.ctrl&&i==="j"||p.shift&&p.return)){let T=[...k.slice(0,y),`
37
+ `,...k.slice(y)].join("");J(T,y+1);return}if(p.return){n(e);return}if(p.leftArrow){p.ctrl||p.meta?(B===0&&E>0?w(N[E]-1):w(N[E]+Ht(C,B)),P.current=null):(B===0&&E>0?w(N[E]-1):w(T=>bt(T-1,k.length)),P.current=null);return}if(p.rightArrow){p.ctrl||p.meta?(B>=de&&E<b.length-1?w(N[E+1]):w(N[E]+bn(C,B)),P.current=null):(B>=de&&E<b.length-1?w(N[E+1]):w(T=>bt(T+1,k.length)),P.current=null);return}if(g&&Y&&p.upArrow){let T=P.current??B,I=Math.max(0,E-1),U=Math.min(T,D[I]??0);w((N[I]??0)+U),P.current=T;return}if(g&&Y&&p.downArrow){let T=P.current??B,I=Math.min(b.length-1,E+1),U=Math.min(T,D[I]??0);w((N[I]??0)+U),P.current=T;return}if(p.ctrl){if(i==="a"){w(N[E]??0),P.current=null;return}if(i==="e"){w((N[E]??0)+de),P.current=null;return}if(i==="u"){if(B>0){let T=N[E]??0,I=[...k.slice(0,T),...k.slice(y)].join("");J(I,T)}return}if(i==="k"){if(B<de){let T=(N[E]??0)+de,I=[...k.slice(0,y),...k.slice(T)].join("");J(I,y)}return}if(i==="w"){if(B===0&&E>0){let I=[...k.slice(0,y-1),...k.slice(y)].join("");J(I,y-1);return}let T=Ht(C,B);if(T!==B){let I=(N[E]??0)+T,U=[...k.slice(0,I),...k.slice(y)].join("");J(U,I)}return}if(i==="d"){if(y<k.length){let T=[...k.slice(0,y),...k.slice(y+1)].join("");J(T,y)}return}return}if(p.meta){i==="b"?(B===0&&E>0?w(N[E]-1):w(N[E]+Ht(C,B)),P.current=null):i==="f"&&(B>=de&&E<b.length-1?w(N[E+1]):w(N[E]+bn(C,B)),P.current=null);return}if(p.backspace||p.delete){if(y<=0)return;let T=[...k.slice(0,y-1),...k.slice(y)].join("");J(T,y-1);return}if(!(p.tab||p.escape)&&i.length>0){let T=g?i.replace(/\r\n/g,`
38
+ `).replace(/\r/g,`
39
+ `):i.replace(/\r?\n/g,"");if(!T||(T=T.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!T))return;if((T.length>=bo||T.includes(`
40
+ `))&&s){let K=!1,ee={text:T,preventDefault:()=>{K=!0}};if(await Promise.resolve(s(ee)),K)return}let U=qt(T),ne=[...k.slice(0,y),...U,...k.slice(y)].join("");J(ne,y+U.length)}},[k,y,l,D,N,b,g,s,n,J,e]);return To(le,{isActive:l}),Jt(xo,{flexDirection:"column",children:b.map((i,p)=>{let E=p===G,C=(E&&Q===i.length?[...i," "]:i).slice(O,O+j),de=C.join("");if(!E)return Jt(wn,{children:de||" "},p);let Y=bt(Q-O,Math.max(0,C.length-1)),T=C.slice(0,Y).join(""),I=C[Y]??" ",U=C.slice(Y+1).join(""),ee=`${T}\x1B[7m${I}\x1B[27m${U}`;return Jt(wn,{children:ee},p)})})}import{Box as De,Text as Ge}from"ink";import zt from"react";import{Text as $e}from"ink";import $o from"react";import{Fragment as So,jsx as Pe,jsxs as Pn}from"react/jsx-runtime";var Yt=2,Kt=1,Vt=2,Io=1,vn=3,Sn=4,vo=({text:e,defaultColor:t,linkColor:n,codeColor:s})=>{let l=t;if(!/[*_~`<[https?:]/.test(e))return Pe($e,{color:l,children:e});let a=[],g=0,y=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,w;for(;(w=y.exec(e))!==null;){w.index>g&&a.push(Pe($e,{color:l,children:e.slice(g,w.index)},`t-${g}`));let h=w[0],O=null,$=`m-${w.index}`;try{if(h.startsWith("**")&&h.endsWith("**")&&h.length>Yt*2)O=Pe($e,{bold:!0,color:l,children:h.slice(Yt,-Yt)},$);else if(h.length>Kt*2&&(h.startsWith("*")&&h.endsWith("*")||h.startsWith("_")&&h.endsWith("_"))&&!/\w/.test(e.substring(w.index-1,w.index))&&!/\w/.test(e.substring(y.lastIndex,y.lastIndex+1))&&!/\S[./\\]/.test(e.substring(w.index-2,w.index))&&!/[./\\]\S/.test(e.substring(y.lastIndex,y.lastIndex+2)))O=Pe($e,{italic:!0,color:l,children:h.slice(Kt,-Kt)},$);else if(h.startsWith("~~")&&h.endsWith("~~")&&h.length>Vt*2)O=Pe($e,{strikethrough:!0,color:l,children:h.slice(Vt,-Vt)},$);else if(h.startsWith("`")&&h.endsWith("`")&&h.length>Io){let P=h.match(/^(`+)(.+?)\1$/s);P&&P[2]&&(O=Pe($e,{color:s,children:P[2]},$))}else if(h.startsWith("[")&&h.includes("](")&&h.endsWith(")")){let P=h.match(/\[(.*?)\]\((.*?)\)/);if(P){let H=P[1],k=P[2];O=Pn($e,{color:l,children:[H,Pn($e,{color:n,children:[" (",k,")"]})]},$)}}else h.startsWith("<u>")&&h.endsWith("</u>")&&h.length>vn+Sn-1?O=Pe($e,{underline:!0,color:l,children:h.slice(vn,-Sn)},$):h.match(/^https?:\/\//)&&(O=Pe($e,{color:n,children:h},$))}catch{O=null}a.push(O??Pe($e,{color:l,children:h},$)),g=y.lastIndex}return g<e.length&&a.push(Pe($e,{color:l,children:e.slice(g)},`t-${g}`)),Pe(So,{children:a.filter(h=>h!==null)})},ut=$o.memo(vo);import{Fragment as Ro,jsx as ae,jsxs as An}from"react/jsx-runtime";var Po=1,Nn=1,_o=1,Eo=1,No=({content:e})=>{let t=e.join(`
41
+ `);return ae(De,{paddingLeft:Nn,flexDirection:"column",children:ae(Ge,{color:"yellow",children:t})})},_n=zt.memo(No),Ao=({itemText:e,type:t,marker:n,leadingWhitespace:s=""})=>{let l=t==="ol"?`${n}. `:`${n} `,a=l.length,g=s.length;return An(De,{paddingLeft:g+_o,flexDirection:"row",children:[ae(De,{width:a,children:ae(Ge,{children:l})}),ae(De,{flexGrow:Eo,children:ae(Ge,{wrap:"wrap",children:ae(ut,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},En=zt.memo(Ao),Do=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return ae(De,{paddingLeft:Nn,flexDirection:"column",children:ae(Ge,{wrap:"wrap",children:e})});let n=e.split(/\r?\n/),s=/^ *(#{1,4}) +(.*)/,l=/^ *(`{3,}|~{3,}) *(\w*?) *$/,a=/^([ \t]*)([-*+]) +(.*)/,g=/^([ \t]*)(\d+)\. +(.*)/,y=/^ *([-*_] *){3,} *$/,w=/^ *> ?(.*)/,h=[],O=!1,$=!0,P=[],H="";function k(b){b&&(h.push(b),$=!1)}return n.forEach((b,N)=>{let D=`line-${N}`;if(O){let p=b.match(l);p&&p[1].startsWith(H[0])&&p[1].length>=H.length?(k(ae(_n,{content:P},D)),O=!1,P=[],H=""):P.push(b);return}let G=b.match(l),Q=b.match(s),j=b.match(a),J=b.match(g),le=b.match(y),i=b.match(w);if(G)O=!0,H=G[1];else if(le)k(ae(De,{children:ae(Ge,{dimColor:!0,children:"---"})},D));else if(Q){let p=Q[1].length,E=Q[2],B=p<=2?"cyan":"blue";k(ae(De,{children:ae(Ge,{color:B,...(p===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:ae(ut,{text:E,defaultColor:B,linkColor:"cyan",codeColor:"yellow"})})},D))}else if(i){let p=i[1];k(ae(De,{paddingLeft:1,children:An(Ge,{dimColor:!0,children:["> ",ae(ut,{text:p,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},D))}else if(j){let p=j[1],E=j[2],B=j[3];k(ae(En,{itemText:B,type:"ul",marker:E,leadingWhitespace:p},D))}else if(J){let p=J[1],E=J[2],B=J[3];k(ae(En,{itemText:B,type:"ol",marker:E,leadingWhitespace:p},D))}else b.trim().length===0?$||(h.push(ae(De,{height:Po},`spacer-${N}`)),$=!0):k(ae(De,{children:ae(Ge,{wrap:"wrap",children:ae(ut,{text:b,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},D))}),O&&k(ae(_n,{content:P},"line-eof")),ae(Ro,{children:h})},Xt=zt.memo(Do);import{execFile as Lo}from"child_process";import Fo from"fs";import et from"fs/promises";import Dn from"os";import vt from"path";import{promisify as Oo}from"util";var It=Oo(Lo);async function Bo(){let e=vt.join(Dn.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
42
+ set imageData to the clipboard as "PNGf"
43
+ set fileRef to open for access POSIX file "${e}" with write permission
44
+ set eof fileRef to 0
45
+ write imageData to fileRef
46
+ close access fileRef
47
+ `;return await It("osascript",["-e",t]),(await et.stat(e)).size===0?void 0:{buffer:await et.readFile(e),mime:"image/png"}}catch{return}finally{try{Fo.existsSync(e)&&await et.unlink(e)}catch{}}}async function Uo(){try{let e=`
48
+ Add-Type -AssemblyName System.Windows.Forms
49
+ $img = [System.Windows.Forms.Clipboard]::GetImage()
50
+ if ($img) {
51
+ $ms = New-Object System.IO.MemoryStream
52
+ $img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png)
53
+ [System.Convert]::ToBase64String($ms.ToArray())
54
+ }
55
+ `,{stdout:t}=await It("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 jo(){try{let{stdout:e}=await It("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 It("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 Rn(){let e=Dn.platform();if(e==="darwin")return Bo();if(e==="win32")return Uo();if(e==="linux")return jo()}var Wo=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 Ln(e){let t=vt.extname(e).toLowerCase();return Wo.has(t)}function Mo(e){let t=vt.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 St(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 Fn(e){let t=St(e);if(/^https?:\/\//.test(t))return!1;try{return await et.access(t),!0}catch{return!1}}async function On(e){let t=St(e);try{if(!(await et.stat(t)).isFile())return;let s=await et.readFile(t),l=Mo(t),a=vt.basename(t);return{buffer:s,mimeType:l,filename:a}}catch{return}}var Ie="\x1B[2m",z="\x1B[0m",he="\x1B[36m",tt="\x1B[32m",Bn="\x1B[31m",Ye="\x1B[38;2;59;91;204m",Qt="\x1B[38;2;126;200;248m",Zt="\x1B[38;2;244;196;78m";import{useState as Ue}from"react";import{v4 as Un}from"uuid";function jn(e,t){let[n,s]=Ue({status:"loading"}),[l,a]=Ue([]),[g,y]=Ue(""),[w,h]=Ue(()=>e||Un()),[O,$]=Ue(t),[P,H]=Ue(!!e),[k,b]=Ue(null),[N,D]=Ue(""),[G,Q]=Ue(!1),j=le=>{a(i=>[...i,{role:"system",content:le}])};return{state:n,setState:s,messages:l,setMessages:a,input:g,setInput:y,taskId:w,setTaskId:h,currentTaskTitle:O,setCurrentTaskTitle:$,hasPersistedTask:P,setHasPersistedTask:H,credentials:k,setCredentials:b,currentResponse:N,setCurrentResponse:D,fullOutput:G,setFullOutput:Q,addSystemMessage:j,startNewTask:le=>{let i=Un();h(i),$(void 0),H(!1),a([]),le&&j(le)}}}import{useEffect as Go,useState as Wn}from"react";function Mn(e){let[t,n]=Wn(null),[s,l]=Wn(!0);return Go(()=>{let a=!1;async function g(){try{let y=await Me();if(a)return;n({accessToken:y.accessToken,workspaceId:y.workspaceId}),l(!1)}catch(y){if(a)return;if(y instanceof Je){if(y.code==="not-logged-in"){e({status:"not-logged-in"}),l(!1);return}if(y.code==="no-workspace"){e({status:"no-workspace"}),l(!1);return}}let w=y instanceof Error?y.message:"Failed to authenticate";e({status:"error",message:w}),l(!1)}}return g(),()=>{a=!0}},[e]),{credentials:t,loading:s}}import{useEffect as qo,useState as dt}from"react";function Gn(e){let[t,n]=dt([]),[s,l]=dt([]),[a,g]=dt([]),[y,w]=dt([]),[h,O]=dt(!1);return qo(()=>{if(!e)return;let $=!1;O(!0);async function P(){if(e)try{let H=new pe,[k,b,N,D]=await Promise.all([H.getConnectors(e.accessToken,e.workspaceId),H.getModels(e.accessToken,e.workspaceId),H.getAgents(e.accessToken,e.workspaceId),H.getModelProviders(e.accessToken,e.workspaceId)]);if($)return;n(k.connectors),l(b.models),g(N.agents),w(D.providers??[])}catch{}finally{$||O(!1)}}return P(),()=>{$=!0}},[e]),{availableConnectors:t,availableModels:s,availableAgents:a,modelProviders:y,loading:h}}import nt from"fs";import Hn from"path";import{useCallback as Ho}from"react";import{v4 as Jo}from"uuid";function qn(e,t){if(!e)return"(no result)";if(typeof e!="object"){let l=String(e);return t||l.length<=200?l:l.slice(0,200)+"..."}let n=e;if("structuredContent"in n&&n.structuredContent){let l=n.structuredContent;if(l.stdout&&typeof l.stdout=="string"){let a=l.stdout.trim();return t||a.length<=200?a:a.slice(0,200)+"..."}}if("content"in n&&Array.isArray(n.content)){let l=n.content.filter(a=>a.type==="text"&&a.text).map(a=>a.text).join(`
56
+ `);return l?t||l.length<=200?l:l.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 Ke(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(`${Ie}[Thinking]
57
+ ${s.text}${z}`):n.push(`${Ie}[Thinking...]${z}`);else if(s.type==="tool-call"&&s.toolName){let l=[];if(l.push(`${he}\u250C\u2500 Tool: ${s.toolName}${z}`),s.args){let a=JSON.stringify(s.args,null,t?2:void 0),g=t||a.length<=100?a:a.slice(0,100)+"...";l.push(`${Ie}\u2502 Args: ${g}${z}`)}s.result!==void 0?(l.push(`${tt}\u2502 Result: ${qn(s.result,t)}${z}`),l.push(`${he}\u2514\u2500 completed${z}`)):l.push(`${he}\u2514\u2500${z}`),n.push(l.join(`
58
+ `))}else if(s.type.startsWith("tool-")&&s.type!=="tool-call"){let l=s.title||s.type.slice(5).replace(/__/g," "),a=[];if(a.push(`${he}\u250C\u2500 Tool: ${l}${z}`),s.input){let g=JSON.stringify(s.input,null,t?2:void 0),y=t||g.length<=100?g:g.slice(0,100)+"...";a.push(`${Ie}\u2502 Input: ${y}${z}`)}s.output!==void 0&&s.state==="output-available"?(a.push(`${tt}\u2502 Output: ${qn(s.output,t)}${z}`),a.push(`${he}\u2514\u2500 completed${z}`)):s.state==="error"?a.push(`${he}\u2514\u2500 failed${z}`):a.push(`${he}\u2514\u2500${z}`),n.push(a.join(`
59
+ `))}return n.join(`
60
+
61
+ `).trim()}var Pt=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," "),l=`
62
+
63
+ ${he}\u250C\u2500 Tool: ${s}${z}`;if(n.args){let a=n.args.length>100?n.args.slice(0,100)+"...":n.args;l+=`
64
+ ${Ie}\u2502 Input: ${a}${z}`}if(n.output){let a=n.output.length>150?n.output.slice(0,150)+"...":n.output;l+=`
65
+ ${tt}\u2502 Output: ${a}${z}`}else if(n.status==="executing"){let a=n.startedAt??Date.now(),g=Math.floor((Date.now()-a)/1e3);l+=`
66
+ ${he}\u2502${z} (executing... ${g}s)`}else n.status==="preparing"&&(l+=`
67
+ ${he}\u2502${z} (preparing...)`);t.push(l)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[n,s]of this.pendingToolCalls){let l=s.toolName.replace(/__/g," "),a=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"";t+=`
68
+
69
+ ${he}\u250C\u2500 Tool: ${l}${z}`,a&&(t+=`
70
+ ${Ie}\u2502 Input: ${a}${z}`),t+=`
71
+ ${he}\u2514\u2500 completed${z}
72
+ `,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 l=s.toolName.replace(/__/g," "),a=typeof s.args=="string"&&s.args.length>100?s.args.slice(0,100)+"...":s.args||"",g=(s.output||"").length>200?(s.output||"").slice(0,200)+"...":s.output||"";return n+=`
73
+
74
+ ${he}\u250C\u2500 Tool: ${l}${z}`,a&&(n+=`
75
+ ${Ie}\u2502 Input: ${a}${z}`),n+=`
76
+ ${tt}\u2502 Output: ${g}${z}`,n+=`
77
+ ${he}\u2514\u2500 completed${z}
78
+ `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}handleToolError(t,n){if(!t.toolCallId)return null;let l=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),a=t.errorText||"Unknown error",g=a.length>200?a.slice(0,200)+"...":a;return n+=`
79
+
80
+ ${he}\u250C\u2500 Tool: ${l}${z}`,n+=`
81
+ ${Bn}\u2502 Error: ${g}${z}`,n+=`
82
+ ${he}\u2514\u2500 failed${z}
83
+ `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}};var ft=Hn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function te(e,t){if(!process.env.DEBUG)return;let s=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(s+=`
84
+ DATA: ${JSON.stringify(t,null,2)}`),s+=`
85
+ `;try{nt.appendFileSync(ft,s)}catch{}}function Yo(){try{if(nt.existsSync(ft)&&nt.unlinkSync(ft),process.env.DEBUG){let e=Hn.dirname(ft);nt.existsSync(e)||nt.mkdirSync(e,{recursive:!0}),nt.writeFileSync(ft,`=== Debug session started at ${new Date().toISOString()} ===
86
+ `)}}catch{}}function _t(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function Jn({taskId:e,credentials:t,currentAgentId:n,currentModel:s,activeConnectorIds:l,localTools:a,fullOutput:g,setMessages:y,setState:w,setCurrentResponse:h,setCredentials:O,setHasPersistedTask:$,getFileIds:P,clearFiles:H}){let k=a?wt():void 0,b=a?xt():void 0;return{sendMessage:Ho(async(D,G,Q)=>{Yo(),te("=== sendMessage called ===",{text:D,localTools:a,clientToolsCount:k?.length});let j=G||t?.accessToken,J=Q||t?.workspaceId;if(!j||!J)try{let p=await Me();j=p.accessToken,J=p.workspaceId,O(p)}catch(p){if(p instanceof Je){if(p.code==="not-logged-in"){w({status:"not-logged-in"});return}if(p.code==="no-workspace"){w({status:"no-workspace"});return}}let E=p instanceof Error?p.message:"Authentication failed";w({status:"error",message:E});return}else try{let p=await an();p!==j&&(j=p,O({accessToken:p,workspaceId:J}))}catch(p){if(p instanceof Je&&p.code==="not-logged-in"){w({status:"not-logged-in"});return}let E=p instanceof Error?p.message:"Authentication failed";w({status:"error",message:E});return}y(p=>[...p,{role:"user",content:D}]),w({status:"sending"}),h("");let le=null,i=null;try{let p=new pe,E=P?.()??[],B={id:e,message:{id:Jo(),createdAt:new Date,role:"user",parts:[{type:"text",text:D}]}};E.length>0&&(B.fileIds=E),n?B.agentId=n:(s&&(B.model=s),B.connectorIds=l??[]),k&&(B.clientTools=k),b&&(B.clientToolSystemPrompt=b);let C=await p.task(j,J,B);if(!C.ok){let _=await C.text();throw new Error(`API error ${C.status}: ${_}`)}if(!C.body)throw new Error("No response body from server");le=C.body.getReader();let de=new TextDecoder,Y="",T="",I="",U="",ne="",K="",ee="",V=new Pt,oe=[],X=[],ce=[],W=()=>{let _=V.hasExecuting();_&&!i?i=setInterval(()=>{if(!V.hasExecuting()){i&&(clearInterval(i),i=null);return}h(T+V.buildToolDisplay())},1e3):!_&&i&&(clearInterval(i),i=null)};for(;;){let{done:_,value:L}=await le.read();if(_)break;Y+=de.decode(L,{stream:!0});let v=Y.split(`
87
+ `);Y=v.pop()||"";for(let m of v)if(m.trim()!=="data: [DONE]"&&m.startsWith("data: "))try{let d=JSON.parse(m.slice(6));switch(te(`SSE event received: ${d.type}`,d),d.type){case"reasoning-start":U=d.id||"0",I="";break;case"reasoning-delta":d.delta&&(I+=d.delta,h(`${Ie}[Thinking...]${z}
88
+ ${I}`)),d.providerMetadata?.anthropic?.signature&&(ne=d.providerMetadata.anthropic.signature);break;case"reasoning-end":if(I){let S={type:"reasoning",id:U,text:I,state:"done"};ne&&(S.providerMetadata={anthropic:{signature:ne}}),X.push(S),te("Added reasoning to messageParts",{reasoningLength:I.length,hasSignature:!!ne,messagePartsCount:X.length})}I="",ne="",h("");break;case"text-delta":d.delta&&(V.hasPending()&&(T=V.flushPending(T)),T+=d.delta,K+=d.delta,h(T));break;case"tool-input-start":{let S=V.handleToolInputStart(d);S&&h(T+S),W();break}case"tool-input-delta":{let S=V.handleToolInputDelta(d);S&&h(T+S),W();break}case"tool-call":case"tool-input-available":{if(te(`=== Tool event: ${d.type} ===`,{toolCallId:d.toolCallId,toolName:d.toolName,localTools:a,isClientToolResult:d.toolName?Be(d.toolName):"no toolName",args:d.args,input:d.input}),d.toolCallId&&d.toolName){let S=_t(d.args??d.input);X.push({type:d.type,toolCallId:d.toolCallId,toolName:d.toolName,args:S}),te("Added tool to messageParts",{messagePartsCount:X.length})}if(a&&d.toolCallId&&d.toolName&&Be(d.toolName)){let S=_t(d.args??d.input);oe.push({toolCallId:d.toolCallId,toolName:d.toolName,args:S}),te("Added to pendingClientTools",{pendingCount:oe.length,pendingClientTools:oe}),h(T+V.buildToolDisplay()+`
89
+ [Executing ${d.toolName} locally...]`)}else te("NOT added to pendingClientTools - conditions not met",{localTools:a,hasToolCallId:!!d.toolCallId,hasToolName:!!d.toolName,isClientTool:d.toolName?Be(d.toolName):!1});break}case"tool-output-start":{let S=V.handleToolOutputStart(d);S&&h(T+S),W();break}case"tool-output-delta":{let S=V.handleToolOutputDelta(d);S&&h(T+S),W();break}case"tool-output-end":{let S=V.handleToolOutputEnd(d,T);S&&(T=S.fullResponse,h(T+S.toolDisplay)),W();break}case"tool-input-error":case"tool-output-error":{let S=V.handleToolError(d,T);S&&(T=S.fullResponse,h(T+S.toolDisplay)),W();break}case"start":d.messageId&&(ee=d.messageId,te("Captured messageId from start event",{messageId:ee}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":d.errorText&&console.error("Stream error:",d.errorText);break}}catch{}}if(K){let _=X.findIndex(v=>v.type!=="reasoning"),L=_===-1?X.length:_;X.splice(L,0,{type:"text",text:K}),te("Added accumulated text to messageParts",{textLength:K.length,insertIndex:L})}for(te("=== Initial stream ended ===",{pendingClientToolsCount:oe.length,pendingClientTools:oe,messagePartsCount:X.length,messageParts:X.map(_=>({type:_.type,toolCallId:_.toolCallId,toolName:_.toolName}))});oe.length>0;){te("=== Starting pending tools execution loop ===",{pendingCount:oe.length});let _=[];for(let d of oe){te(`Executing tool: ${d.toolName}`,{toolCallId:d.toolCallId,args:d.args}),V.handleToolInputStart({toolCallId:d.toolCallId,toolName:d.toolName}),V.handleToolInputDelta({toolCallId:d.toolCallId,inputTextDelta:JSON.stringify(d.args)}),h(T+V.buildToolDisplay()),W();let S=await Tt(d.toolName,d.args);te(`Tool execution result: ${d.toolName}`,{success:S.success,resultPreview:S.success?JSON.stringify(S.result).slice(0,200):S.error});let re=S.success?JSON.stringify(S.result):S.error||"Unknown error";if(_.push({toolCallId:d.toolCallId,toolName:d.toolName,content:[{type:"text",text:re}],isError:!S.success}),S.success){V.handleToolOutputStart({toolCallId:d.toolCallId}),V.handleToolOutputDelta({toolCallId:d.toolCallId,outputTextDelta:JSON.stringify(S.result).slice(0,200)});let me=V.handleToolOutputEnd({toolCallId:d.toolCallId},T);me&&(T=me.fullResponse)}else{let me=V.handleToolError({toolCallId:d.toolCallId,errorText:S.error},T);me&&(T=me.fullResponse)}h(T+V.buildToolDisplay()),W()}oe.length=0;for(let d of _){let S=X.find(re=>(re.type==="tool-input-available"||re.type==="tool-call")&&re.toolCallId===d.toolCallId);if(S){let re=[];for(let R of d.content)R.type==="text"?re.push(R.text):R.type==="image"?re.push("[Image]"):R.type==="audio"?re.push("[Audio]"):(R.type==="resource"||R.type==="resource_link")&&re.push("[Resource]");let me=re.join(`
90
+ `);ce.push({type:`tool-${S.toolName}`,toolName:S.toolName,toolCallId:S.toolCallId,input:S.args,output:me,isError:d.isError})}}if(te("=== Sending clientToolResults for continuation ===",{toolResultsCount:_.length,toolResults:_.map(d=>({toolCallId:d.toolCallId,toolName:d.toolName,isError:d.isError}))}),le)try{le.releaseLock()}catch{}let L=_.map(d=>({type:`tool-${d.toolName}`,toolCallId:d.toolCallId,state:"output-available",output:{content:d.content,isError:d.isError}}));if(!ee)throw new Error("Cannot continue: missing assistant message id for tool results.");let v={id:e,message:{id:ee,role:"assistant",parts:L}};n?v.agentId=n:(s&&(v.model=s),v.connectorIds=l??[]),k&&(v.clientTools=k),b&&(v.clientToolSystemPrompt=b),te("=== Sending continuation request ===",{taskId:e,hasAgentId:!!v.agentId,hasModel:!!v.model,clientToolResultsCount:_.length});let m=await p.task(j,J,v);if(te("=== Continuation response received ===",{ok:m.ok,status:m.status}),!m.ok){let d=await m.text();throw new Error(`Continuation failed: ${m.status}: ${d}`)}if(!m.body)break;for(te("=== Processing continuation stream ==="),le=m.body.getReader(),X.length=0,K="",I="",U="",ne="";;){let{done:d,value:S}=await le.read();if(d){te("=== Continuation stream done ===");break}Y+=de.decode(S,{stream:!0});let re=Y.split(`
91
+ `);Y=re.pop()||"";for(let me of re)if(me.trim()!=="data: [DONE]"&&me.startsWith("data: "))try{let R=JSON.parse(me.slice(6));switch(te(`Continuation SSE: ${R.type}`,R),R.type){case"start":R.messageId&&(ee=R.messageId);break;case"reasoning-start":U=R.id||"0",I="";break;case"reasoning-delta":R.delta&&(I+=R.delta,h(`${Ie}[Thinking...]${z}
92
+ ${I}`)),R.providerMetadata?.anthropic?.signature&&(ne=R.providerMetadata.anthropic.signature);break;case"reasoning-end":if(I){let Re={type:"reasoning",id:U,text:I,state:"done"};ne&&(Re.providerMetadata={anthropic:{signature:ne}}),X.push(Re),te("Continuation: Added reasoning to messageParts",{reasoningLength:I.length,hasSignature:!!ne,messagePartsCount:X.length})}I="",ne="",h(T);break;case"text-delta":R.delta&&(T+=R.delta,K+=R.delta,h(T));break;case"tool-call":case"tool-input-available":if(R.toolCallId&&R.toolName){let Re=_t(R.args??R.input);X.push({type:R.type,toolCallId:R.toolCallId,toolName:R.toolName,args:Re})}if(a&&R.toolCallId&&R.toolName&&Be(R.toolName)){let Re=_t(R.args??R.input);oe.push({toolCallId:R.toolCallId,toolName:R.toolName,args:Re}),te("Continuation: Added to pendingClientTools",{pendingCount:oe.length})}break;case"finish":te("Continuation finish event",R);break}}catch{}}if(K){let d=X.findIndex(re=>re.type!=="reasoning"),S=d===-1?X.length:d;X.splice(S,0,{type:"text",text:K})}te("=== Continuation stream processing complete ===",{pendingClientToolsCount:oe.length,messagePartsCount:X.length,fullResponseLength:T.length})}if(a&&k&&k.length>0){let _=[];for(let v of ce)_.push({type:String(v.type),title:String(v.toolName).replace(/__/g," "),input:v.input,output:v.output,state:v.isError?"error":"output-available"});for(let v of X)v.type==="text"&&v.text&&_.push({type:"text",text:v.text});let L=Ke(_,g);te("=== Using formatted parts for local tools ===",{executedToolsCount:ce.length,textPartsCount:X.filter(v=>v.type==="text").length,contentLength:L.length}),y(v=>[...v,{role:"assistant",content:L,parts:_}])}else{te("=== Fetching message from API ===",{fullResponseLength:T.length,fullResponsePreview:T.slice(0,200)});try{let{messages:_}=await p.getMessages(j,J,e,10);te("=== API messages received ===",{count:_.length,roles:_.map(v=>v.role)});let L=_.find(v=>v.role==="assistant");if(L){let v=L.parts,m=Ke(v,g);te("=== Setting message from API ===",{partsCount:v.length,partTypes:v.map(d=>d.type),contentLength:m.length,contentPreview:m.slice(0,200)}),y(d=>[...d,{role:"assistant",content:m,parts:v}])}else te("=== No assistant message found, using fallback ==="),y(v=>[...v,{role:"assistant",content:T}])}catch(_){te("=== API fetch failed, using fallback ===",{error:_ instanceof Error?_.message:String(_)}),y(L=>[...L,{role:"assistant",content:T}])}}te("=== Message handling complete ==="),h(""),w({status:"ready"}),$(!0),E.length>0&&H?.()}catch(p){te("=== ERROR ===",{message:p instanceof Error?p.message:String(p),stack:p instanceof Error?p.stack:void 0});let E=p instanceof Error?p.message:"Failed to send message";w({status:"error",message:E})}finally{if(i&&(clearInterval(i),i=null),le)try{le.releaseLock()}catch{}}},[t,e,n,s,l,a,k,b,g,y,w,h,O,$,P,H])}}import{useState as Ko}from"react";var Yn=new Map([["sandbox","Sandbox"],["web_search","Web Search"],["image_generation","Image Generation"],["chart","Chart"],["file_system","FileSystem"]]);function Kn(e){let[t,n]=Ko(e);return{fileSystem:t,setFileSystem:n,capabilityLabelMap:Yn}}import{useEffect as Vo,useState as zo}from"react";function Vn(e,t){let[n,s]=zo(null);return Vo(()=>{let l=!1;async function a(){if(!e||!t){s(null);return}try{let y=await new pe().getAgent(t.accessToken,t.workspaceId,e);l||s(y)}catch{l||s(null)}}return a(),()=>{l=!0}},[e,t]),{currentAgentDetails:n}}import{useState as en}from"react";function zn(e,t,n){let[s,l]=en(e),[a,g]=en(t),[y,w]=en(n);return{currentModel:s,setCurrentModel:l,currentAgentId:a,setCurrentAgentId:g,activeConnectorIds:y,setActiveConnectorIds:w}}import{useApp as Qo,useInput as Zo}from"ink";import{useCallback as je,useRef as es,useState as Ce}from"react";import{spawn as Xo}from"child_process";function Xn(e){return new Promise((t,n)=>{let s,l;process.platform==="darwin"?(s="open",l=[e]):process.platform==="win32"?(s="cmd",l=["/c","start","",e]):(s="xdg-open",l=[e]);let a=Xo(s,l,{stdio:"ignore",detached:!0});a.once("error",g=>{n(g)}),a.once("spawn",()=>{a.unref(),t()})})}var Qn=[{name:"help",aliases:["h","?"],description:"Show available commands"},{name:"clear",aliases:["cls","new"],description:"Start a new task"},{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:"Toggle client capabilities"},{name:"tasks",aliases:["c"],description:"Switch to another task"},{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 task in browser"},{name:"share",aliases:[],description:"Get share link for current task"},{name:"delete",aliases:["del"],description:"Delete current task"},{name:"quit",aliases:["exit","q"],description:"Exit task"}];function Zn(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?Qn.filter(n=>n.name.startsWith(t)||n.aliases.some(s=>s.startsWith(t))):Qn}function eo(e){let t=e.trim();if(!t.startsWith("/"))return null;let n=t.slice(1).split(/\s+/),s=n[0]?.toLowerCase(),l=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:l||void 0};case"agent":case"a":return{type:"agent",value:l||void 0};case"skills":case"sk":return{type:"skills",value:l||void 0};case"schedules":case"sch":return{type:"schedules",value:l||void 0};case"connectors":case"conn":return{type:"connectors"};case"capabilities":case"cap":return{type:"capabilities"};case"tasks":case"c":return{type:"tasks"};case"workspace":case"ws":return{type:"workspace",value:l||void 0};case"budget":case"bg":return{type:"budget",value:l||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:l||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 to=`Available commands:
93
+ /help, /h, /? Show this help message
94
+ /clear, /cls, /new Start a new task
95
+ /model [name], /m Show current model or switch to [name]
96
+ /agent [name], /a Show current agent or switch to [name]
97
+ /skills [name], /sk List skills or show details for [name]
98
+ /schedules [id], /sch List schedules or show details for [id]
99
+ /connectors, /conn Select active connectors
100
+ /capabilities, /cap Toggle client capabilities (FileSystem)
101
+ /tasks, /c Switch to another task
102
+ /workspace [id], /ws List or switch workspace
103
+ /budget [amount], /bg View or set workspace budget
104
+ /usage, /u View current month usage (top 10 by cost)
105
+ /status, /s Show current session status
106
+ /profile [args], /p Manage profiles (list/show/use/create/delete/rename/clone)
107
+ /open-in-browser Open current task in browser
108
+ /share Get share link for current task
109
+ /delete, /del Delete current task
110
+ /quit, /exit, /q Exit interactive mode
111
+
112
+ Note: For detailed usage with sorting/limits, use: entrydesk usage --help
113
+
114
+ Keyboard shortcuts:
115
+ Ctrl+O Toggle full output mode
116
+ Ctrl+C Exit`;function tn(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} min`;case"hours":return`Every ${t.every} hr`;case"days":return`Every ${t.every} day at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${t.every} week`;case"months":return`Every ${t.every} month`;default:return"Unknown"}}function no({input:e,setInput:t,taskId:n,setTaskId:s,currentTaskTitle:l,setCurrentTaskTitle:a,currentModel:g,setCurrentModel:y,currentAgentId:w,setCurrentAgentId:h,currentAgentDetails:O,setCurrentAgentDetails:$,activeConnectorIds:P,setActiveConnectorIds:H,fileSystem:k,setFileSystem:b,availableModels:N,availableAgents:D,availableConnectors:G,messages:Q,hasPersistedTask:j,setHasPersistedTask:J,setMessages:le,addSystemMessage:i,startNewTask:p,sendMessage:E,setFullOutput:B,credentials:C,setCredentials:de,setState:Y,defaultCapabilities:T,capabilityLabelMap:I,hasUploadingFiles:U=!1}){let{exit:ne}=Qo(),[K,ee]=Ce([]),[V,oe]=Ce(0),[X,ce]=Ce(!1),[W,_]=Ce(null),[L,v]=Ce([]),[m,d]=Ce(0),[S,re]=Ce(new Set),[me,R]=Ce(new Set),[Re,mt]=Ce([]),[_e,Lt]=Ce([]),[ve,ot]=Ce([]),[Le,gt]=Ce([]),[Ee,We]=Ce(null),[Ft,st]=Ce(""),ze=es(!1),[Fe,xe]=Ce(!1),Xe=je(async()=>{if(!C)return[];let x=new pe,f=[],o;do{let r=await x.listAvailableSkills(C.accessToken,C.workspaceId,{limit:100,nextKey:o});f.push(...r.skills),o=r.nextKey}while(o);return Lt(f),f},[C]),Qe=je(async()=>{if(!C)return[];let x=new pe,f=[],o;do{let r=await x.getSchedules(C.accessToken,C.workspaceId,{limit:100,nextKey:o});f.push(...r.schedules),o=r.nextKey}while(o);return ot(f),f},[C]),Te=je(async x=>{if(x==="model"){if(N.length===0){i("No models available.");return}let f=N.map(r=>({id:r.id,name:r.name,description:r.description}));v(f);let o=g?f.findIndex(r=>r.id===g):-1;d(Math.max(o,0)),_("model")}else if(x==="agent"){if(D.length===0){i("No agents available.");return}let f=D.map(r=>({id:r.id,name:r.name,description:r.description}));v(f);let o=w?f.findIndex(r=>r.id===w):-1;d(Math.max(o,0)),_("agent")}else if(x==="skills"){let f=_e;if(f.length===0)try{f=await Xe()}catch{i("Failed to load skills.");return}if(f.length===0){i("No skills available.");return}let o=f.map(r=>({id:r.id,name:r.name,description:r.description}));v(o),d(0),_("skills")}else if(x==="schedules"){let f=ve;if(f.length===0)try{f=await Qe()}catch{i("Failed to load schedules.");return}if(f.length===0){i("No schedules found.");return}let o=f.map(r=>({id:r.id,name:r.name,description:`${r.agent.name} - ${r.isActive?"Active":"Paused"}`}));v(o),d(0),_("schedules")}else if(x==="connectors"){if(G.length===0){i("No connectors available.");return}let f=G.map(o=>({id:o.id,name:o.name}));v(f),d(0),re(new Set(P??[])),_("connectors")}else if(x==="capabilities"){v([{id:"fileSystem",name:"FileSystem",description:"Local file operations"}]),d(0);let o=new Set;k&&o.add("fileSystem"),R(o),_("capabilities")}else if(x==="tasks"){if(!C){i("Not authenticated.");return}try{let f=new pe,{tasks:o}=await f.getTasks(C.accessToken,C.workspaceId,20);if(o.length===0){i("No tasks available.");return}mt(o);let r=o.map(c=>({id:c.id,name:c.title||"Untitled",description:new Date(c.createdAt).toLocaleDateString()}));v(r);let u=r.findIndex(c=>c.id===n);d(Math.max(u,0)),_("tasks")}catch{i("Failed to load tasks.")}}else if(x==="profile"){let f=ie.getProfileNames(),o=ie.getCurrentProfileName(),r=f.map(c=>({id:c,name:c,description:c===o?"(current)":void 0}));v(r);let u=r.findIndex(c=>c.id===o);d(Math.max(u,0)),_("profile")}ce(!1),ee([])},[N,D,_e,ve,G,P,g,w,k,Xe,Qe,C,n,i]),Se=je(x=>{let f=fe.getAll(x);y(f.model?.default),h(void 0),$(null);let o=f.connectors?.defaults;H(o&&o.length>0?o:void 0);let r=f.localTools;b(r?.fileSystem??T.fileSystem)},[y,h,$,H,b,T]),Ne=je(async()=>{try{let x=await Me();de({accessToken:x.accessToken,workspaceId:x.workspaceId}),Y({status:"ready"})}catch(x){if(de(null),x instanceof Je){if(x.code==="not-logged-in"){Y({status:"not-logged-in"});return}if(x.code==="no-workspace"){Y({status:"no-workspace"});return}}let f=x instanceof Error?x.message:"Failed to authenticate";Y({status:"error",message:f})}},[de,Y]),qe=je(async x=>{switch(x.type){case"help":return i(to),!0;case"clear":return p("Started a new task."),!0;case"model":{if(x.value){let f=x.value.toLowerCase(),o=N.find(r=>r.id.toLowerCase()===f||r.name.toLowerCase().includes(f));if(o)w?p(`Switched to model: ${o.name} (new task)`):i(`Switched to model: ${o.name}`),y(o.id),h(void 0),$(null),fe.setDefaultModel(o.id);else{let r=N.map(u=>u.name).join(", ");i(`Model "${x.value}" not found.
117
+ Available: ${r||"none"}`)}}else{let f=N.find(o=>o.id===g)?.name||g;i(g?`Current model: ${f}`:"No model selected. Using agent mode.")}return!0}case"agent":{if(!x.value)return D.length===0?(i("No agents available."),!0):(Te("agent"),!0);let f=x.value.toLowerCase(),o=D.find(r=>r.id.toLowerCase()===f||r.name.toLowerCase().includes(f));if(o)o.id!==w?p(`Switched to agent: ${o.name} (new task)`):i(`Switched to agent: ${o.name}`),h(o.id),y(void 0);else{let r=D.map(u=>u.name).join(", ");i(`Agent "${x.value}" not found.
118
+ Available: ${r||"none"}`)}return!0}case"skills":{if(!x.value)return Te("skills"),!0;let f=x.value.toLowerCase();return(_e.length>0?Promise.resolve(_e):Xe().catch(()=>[])).then(r=>{let u=r.find(c=>c.id.toLowerCase()===f||c.name.toLowerCase().includes(f));i(u?`Skill: ${u.name}
119
+ ${u.description}
120
+ Provider: ${u.provider}
121
+ Author: ${u.author.name}
122
+ ID: ${u.id}`:`Skill "${x.value}" not found.`)}),!0}case"schedules":{if(!x.value)return Te("schedules"),!0;let f=x.value.toLowerCase();return(ve.length>0?Promise.resolve(ve):Qe().catch(()=>[])).then(r=>{let u=r.find(c=>c.id.toLowerCase()===f||c.name.toLowerCase().includes(f));if(u){let c=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";i(`Schedule: ${u.name}
123
+ Agent: ${u.agent.name}
124
+ Status: ${u.isActive?"Active":"Paused"}
125
+ Repeat: ${tn(u.config)}
126
+ Next Run: ${c}
127
+ ID: ${u.id}`)}else i(`Schedule "${x.value}" not found.`)}),!0}case"connectors":{if(w){let o=O?.connectors??[];if(o.length===0)i("No agent connectors.");else{let r=o.map(u=>` - ${u.name}`).join(`
128
+ `);i(`Agent connectors:
129
+ ${r}`)}return!0}let f=G.filter(o=>P?.includes(o.id));if(f.length===0)i("No active connectors.");else{let o=f.map(r=>` - ${r.name}`).join(`
130
+ `);i(`Active connectors:
131
+ ${o}`)}return!0}case"capabilities":{if(w){let r=(O?.capabilities??[]).map(u=>I.get(u)??u);return i(r.length>0?`Agent capabilities:
132
+ ${r.map(u=>` - ${u}`).join(`
133
+ `)}`:"No agent capabilities."),!0}let f=[];return k&&f.push("FileSystem"),i(f.length>0?`Active capabilities:
134
+ ${f.map(o=>` - ${o}`).join(`
135
+ `)}`:"No capabilities enabled."),!0}case"tasks":return i(l?`Current task: ${l}`:`Current task: ${n.slice(0,8)}...`),!0;case"workspace":{if(!C)return i("Not authenticated."),!0;let f=new pe;if(!x.value){try{let{workspaces:r}=await f.getWorkspaces(C.accessToken);if(r.length===0)i("No workspaces found.");else{let u=r.map(c=>` ${c.id===C.workspaceId?"* ":" "}${c.name}
136
+ ID: ${c.id}`);i(`Workspaces:
137
+ ${u.join(`
138
+ `)}`)}}catch(r){i(`Failed to load workspaces: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}let o=x.value;try{let{workspaces:r}=await f.getWorkspaces(C.accessToken),u=r.find(c=>c.id===o);if(!u)return i(`Workspace not found: ${o}`),!0;await rt.saveWorkspaceId(o),i(`Switched to workspace: ${u.name}`),i("Please restart the task to apply changes.")}catch(r){i(`Failed to switch workspace: ${r instanceof Error?r.message:"Unknown error"}`)}return!0}case"budget":{if(!C)return i("Not authenticated."),!0;let f=new pe;if(!x.value){try{let u=await f.getBudget(C.accessToken,C.workspaceId);u.budget===null?i("No budget set for this workspace."):i(`Current budget: $${u.budget}`)}catch(u){i(`Failed to get budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let o=x.value.toLowerCase();if(o==="clear"||o==="null"){try{await f.updateBudget(C.accessToken,C.workspaceId,null),i("Budget cleared.")}catch(u){i(`Failed to clear budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}let r=parseFloat(o);if(isNaN(r)||r<0)return i("Invalid budget amount. Must be a positive number."),!0;try{await f.updateBudget(C.accessToken,C.workspaceId,o),i(`Budget set to: $${o}`)}catch(u){i(`Failed to set budget: ${u instanceof Error?u.message:"Unknown error"}`)}return!0}case"usage":{if(!C)return i("Not authenticated."),!0;let f=new pe;try{let o=[],r,u=0,c=10;do{let ge=await f.getMonthlyUsages(C.accessToken,C.workspaceId,{nextKey:r,limit:20});if(o.push(...ge.monthlyUsages),r=ge.nextKey,u++,u>=c){i(`Warning: Showing first ${o.length} entries (pagination limit reached)`);break}}while(r);if(o.length===0)return i("No usage data found for this workspace."),!0;let A=0,Z=0;for(let ge of o)A+=parseFloat(ge.totalCost),Z+=ge.operationCount;let ke=[...o].toSorted((ge,He)=>parseFloat(He.totalCost)-parseFloat(ge.totalCost)),M=10,ue=ke.slice(0,M),be=[`Total Cost: $${A.toFixed(2)}`,`Total Operations: ${Z.toLocaleString()}`,`Users: ${o.length}`,"",`Top ${ue.length} Users by Cost:`,...ue.map(ge=>` ${ge.user.name}: $${parseFloat(ge.totalCost).toFixed(2)} (${ge.operationCount.toLocaleString()} ops)`)];o.length>M&&(be.push("",`... and ${o.length-M} more users`),be.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),i(be.join(`
139
+ `))}catch(o){i(`Failed to get usage: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"status":{let f=ie.getCurrentProfileName(),o=g?N.find(A=>A.id===g)?.name||g:null,r=w?D.find(A=>A.id===w)?.name||w:null,u=P?G.filter(A=>P.includes(A.id)).map(A=>A.name):[],c=[];return k&&c.push("FileSystem"),rt.getEmail().then(A=>{let Z=[`Profile: ${f}${f!=="default"?" (non-default)":""}`,A?`Logged in as: ${A}`:"Not logged in",C?.workspaceId?`Workspace: ${C.workspaceId}`:null,j?`Task ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${c.length>0?c.join(", "):"none"}`].filter(Boolean);i(Z.join(`
140
+ `))}).catch(()=>{let A=[`Profile: ${f}`,"Not logged in",j?`Task ID: ${n}`:null,o?`Model: ${o}`:null,r?`Agent: ${r}`:null,`Connectors: ${u.length>0?u.join(", "):"none"}`,`Capabilities: ${c.length>0?c.join(", "):"none"}`].filter(Boolean);i(A.join(`
141
+ `))}),!0}case"profile":{let f=x.value?x.value.split(/\s+/).filter(Boolean):[];if(f.length===0)return Te("profile"),!0;let o=f[0]?.toLowerCase()||"list",r=f[1],u=f[2],c=ie.getProfileNames(),A=ie.getCurrentProfileName(),Z=ie.getOverrideProfile(),ke=(M,ue=!1)=>{if(M)return M;if(ue&&c.length===1)return c[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(o==="list"){let M=[`Profiles (${c.length}):`];for(let ue of c){let be=ue===A?" (current)":"";M.push(` ${ue}${be}`)}return i(M.join(`
142
+ `)),!0}if(o==="current")return i(`Current profile: ${A}`),!0;if(o==="show"){let M=ke(r,!0),ue=fe.getAll(M),be=await rt.getAll(M),ge=!!be?.accessToken,He=ue.connectors?.defaults&&ue.connectors.defaults.length>0?ue.connectors.defaults.join(", "):"unset",uo=[`Profile: ${M}${M===A?" (current)":""}`,`API URL: ${ue.apiUrl??"default"}`,`Hub URL: ${ue.hubUrl??"default"}`,`Model: ${ue.model?.default??"unset"}`,`Connectors: ${He}`,ge?`Logged in as: ${be?.email??"unknown"}`:"Not logged in",ge&&be?.workspaceId?`Workspace ID: ${be.workspaceId}`:null].filter(Boolean);return i(uo.join(`
143
+ `)),!0}if(o==="create"){let M=r||ie.DEFAULT_PROFILE;return ie.createProfile(M),i(`Profile created: ${M}`),!0}if(o==="use"||o==="switch"){let M=ke(r,!0);return ie.setOverrideProfile(M),ie.setCurrentProfile(M),Se(M),await Ne(),p(`Switched to profile: ${M} (new task)`),!0}if(o==="delete"||o==="remove"||o==="rm"){let M=ke(r,!0),ue=M===A,be=ie.deleteProfile(M),ge=`Profile deleted: ${M}`;if(ue)ie.setOverrideProfile(be.currentProfile),Se(be.currentProfile),await Ne(),p(`${ge}
144
+ Switched to profile: ${be.currentProfile} (new task)`);else if(Z===M){let He=ie.getCurrentProfileName();ie.setOverrideProfile(He),Se(He),await Ne(),p(`${ge}
145
+ Switched to profile: ${He} (new task)`)}else i(ge);return!0}if(o==="rename"||o==="move"||o==="mv"){let M=ke(r,!0);if(!u)throw new Error("New profile name is required.");let ue=ie.renameProfile(M,u);return i(`Profile renamed: ${M} -> ${u}`),Z===M?(ie.setOverrideProfile(u),Se(u)):ue.currentProfile===u&&Se(u),!0}if(o==="clone"||o==="copy"){let M=ke(r,!0);if(!u)throw new Error("Target profile name is required.");let ue=fe.getAll(M);return ie.createProfile(u),fe.setAll(ue,u),await rt.clear(u),i(`Profile cloned: ${M} -> ${u}`),!0}i(`Unknown profile command: ${o}`)}catch(M){let ue=M instanceof Error?M.message:"Unknown error";i(`Profile error: ${ue}`)}return!0}case"open-in-browser":{let f=Bt().hubUrl.replace(/\/$/,""),o=j||Q.some(Z=>Z.role!=="system"),r=C?`/${C.workspaceId}`:"",u=o?`${r}/task/${n}`:`${r}/task/new`,c=w?`?agentId=${encodeURIComponent(w)}`:"",A=`${f}${u}${c}`;try{await Xn(A),i(`Opened in browser: ${A}`)}catch(Z){i(`Failed to open browser: ${Z instanceof Error?Z.message:"Unknown error"}
146
+ URL: ${A}`)}return!0}case"share":{if(!C)return i("Not authenticated."),!0;if(!(j||Q.some(o=>o.role!=="system")))return i("No conversation to share. Start a task first."),!0;try{let r=await new pe().createTaskShare(C.accessToken,C.workspaceId,n,"public"),c=`${Bt().hubUrl.replace(/\/$/,"")}/share/${r.id}`;i(`Share link: ${c}`)}catch(o){i(`Failed to create share link: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"delete":return C?j?(xe(!0),i("Delete this task? (y/N)"),!0):(i("No task to delete."),!0):(i("Not authenticated."),!0);case"quit":return ne(),!0;case"unknown":return i(`Unknown command: ${x.input}
147
+ Type /help for available commands.`),!0;default:return!1}},[i,N,D,G,_e,ve,g,w,P,k,n,l,ne,Te,p,I,O,j,Q,Xe,Qe,le,y,h,$,y,Se,Ne]),ht=je(x=>{if(ze.current=!1,Fe){(x===""||x.startsWith("/"))&&(t(x),x.startsWith("/")&&xe(!1));return}if(t(x),st(x),Ee!==null&&We(null),W&&(_(null),v([])),x.startsWith("/")&&!x.includes(" ")){let f=Zn(x);ee(f),oe(0),ce(f.length>0)}else ce(!1),ee([])},[W,Ee,Fe,t]),Ze=je((x,f=!1)=>{if(x>=0&&x<K.length){let o=K[x];ce(!1),ee([]),o.name==="model"?(t("/model "),Te("model")):o.name==="agent"?(t("/agent "),Te("agent")):o.name==="skills"?(t("/skills "),Te("skills")):o.name==="schedules"?(t("/schedules "),Te("schedules")):o.name==="connectors"?(t("/connectors "),Te("connectors")):o.name==="capabilities"?(t("/capabilities "),Te("capabilities")):o.name==="tasks"?(t("/tasks "),Te("tasks")):o.name==="profile"?(t("/profile "),Te("profile")):f?(t(""),qe({type:o.name})):t(`/${o.name}`)}},[K,Te,t,qe]),Ot=je(async x=>{ze.current=!1;let f=x.trim();if(!f||Fe)return;if(W==="model"&&L.length>0){let r=L[m];r&&(w?p(`Switched to model: ${r.name} (new task)`):i(`Switched to model: ${r.name}`),y(r.id),h(void 0),$(null)),_(null),v([]),t("");return}if(W==="agent"&&L.length>0){let r=L[m];r&&(r.id!==w?p(`Switched to agent: ${r.name} (new task)`):i(`Switched to agent: ${r.name}`),h(r.id),y(void 0)),_(null),v([]),t("");return}if(W==="skills"&&L.length>0){let r=L[m];if(r){let u=_e.find(c=>c.id===r.id);u&&i(`Skill: ${u.name}
148
+ ${u.description}
149
+ Provider: ${u.provider}
150
+ Author: ${u.author.name}
151
+ ID: ${u.id}`)}_(null),v([]),t("");return}if(W==="schedules"&&L.length>0){let r=L[m];if(r){let u=ve.find(c=>c.id===r.id);if(u){let c=u.nextRunAt?new Date(u.nextRunAt).toLocaleString():"-";i(`Schedule: ${u.name}
152
+ Agent: ${u.agent.name}
153
+ Status: ${u.isActive?"Active":"Paused"}
154
+ Repeat: ${tn(u.config)}
155
+ Next Run: ${c}
156
+ ID: ${u.id}`)}}_(null),v([]),t("");return}if(W==="connectors"){let r=Array.from(S);H(r.length>0?r:void 0),fe.setDefaultConnectorIds(r);let u=G.filter(c=>S.has(c.id)).map(c=>c.name);i(u.length>0?`Active connectors: ${u.join(", ")}`:"All connectors disabled."),_(null),v([]),t("");return}if(W==="capabilities"){let r=me.has("fileSystem");b(r),fe.setLocalTools({fileSystem:r});let u=[];r&&u.push("FileSystem"),i(u.length>0?`Active capabilities: ${u.join(", ")}`:"All capabilities disabled."),_(null),v([]),t("");return}if(W==="profile"&&L.length>0){let r=L[m];if(r){let u=ie.getCurrentProfileName();r.id!==u?(ie.setOverrideProfile(r.id),ie.setCurrentProfile(r.id),Se(r.id),Ne(),p(`Switched to profile: ${r.name}`)):i(`Already using profile: ${r.name}`)}_(null),v([]),t("");return}if(X&&K.length>0){Ze(V,!0);return}We(null),st(""),gt(r=>r.length>0&&r.at(-1)===f?r:[...r,f]);let o=eo(f);if(o){await qe(o),t(""),ce(!1);return}if(U){i("Please wait for file uploads to complete.");return}t(""),ce(!1),E(f)},[E,qe,X,K,V,Ze,W,L,m,S,me,G,_e,ve,i,t,w,p,y,h,$,H,b,U,Se,Ne,Fe,C,j,n]);return Zo((x,f)=>{if(f.ctrl&&x==="c"){if(e.length>0){ht(""),ze.current=!0,i("Press Ctrl+C again to exit.");return}if(ze.current){ne();return}ne();return}if(f.ctrl&&x==="o"){B(o=>!o);return}if(Fe){if(f.escape||f.return||x==="n"||x==="N"){xe(!1),t(""),i("Task deletion cancelled.");return}if(x==="y"||x==="Y"){xe(!1),t(""),C&&j&&new pe().deleteTask(C.accessToken,C.workspaceId,n).then(()=>{p("Task deleted. Started a new task.")}).catch(r=>{i(`Failed to delete task: ${r.message||"Unknown error"}`)});return}return}if(W&&L.length>0){if(f.upArrow){d(o=>o<=0?L.length-1:o-1);return}if(f.downArrow){d(o=>o>=L.length-1?0:o+1);return}if(f.escape){_(null),v([]),t("");return}if(f.return){if(W==="model"){let o=L[m];o&&(w?p(`Switched to model: ${o.name} (new task)`):i(`Switched to model: ${o.name}`),y(o.id),h(void 0),$(null),fe.setDefaultModel(o.id))}else if(W==="agent"){let o=L[m];o&&(o.id!==w?p(`Switched to agent: ${o.name} (new task)`):i(`Switched to agent: ${o.name}`),h(o.id),y(void 0))}else if(W==="skills"){let o=L[m];if(o){let r=_e.find(u=>u.id===o.id);r&&i(`Skill: ${r.name}
157
+ ${r.description}
158
+ Provider: ${r.provider}
159
+ Author: ${r.author.name}
160
+ ID: ${r.id}`)}}else if(W==="schedules"){let o=L[m];if(o){let r=ve.find(u=>u.id===o.id);if(r){let u=r.nextRunAt?new Date(r.nextRunAt).toLocaleString():"-";i(`Schedule: ${r.name}
161
+ Agent: ${r.agent.name}
162
+ Status: ${r.isActive?"Active":"Paused"}
163
+ Repeat: ${tn(r.config)}
164
+ Next Run: ${u}
165
+ ID: ${r.id}`)}}}else if(W==="connectors"){let o=Array.from(S);H(o.length>0?o:void 0),fe.setDefaultConnectorIds(o);let r=G.filter(u=>S.has(u.id)).map(u=>u.name);i(r.length>0?`Active connectors: ${r.join(", ")}`:"All connectors disabled.")}else if(W==="capabilities"){let o=me.has("fileSystem");b(o),fe.setLocalTools({fileSystem:o});let r=[];o&&r.push("FileSystem"),i(r.length>0?`Active capabilities: ${r.join(", ")}`:"All capabilities disabled.")}else if(W==="tasks"){let o=L[m];if(o){let r=Re.find(u=>u.id===o.id);r&&C&&(s(r.id),a(r.title||void 0),J(!0),new pe().getMessages(C.accessToken,C.workspaceId,r.id,20).then(({messages:c})=>{let A=c.filter(Z=>Z.role==="user"||Z.role==="assistant").map(Z=>({role:Z.role,content:Ke(Z.parts,!1),parts:Z.parts})).filter(Z=>Z.content).toReversed();le(A),i(`Switched to: ${r.title||"Untitled"}`)}).catch(()=>{i("Failed to load task messages.")}))}}else if(W==="profile"){let o=L[m];if(o){let r=ie.getCurrentProfileName();o.id!==r?(ie.setOverrideProfile(o.id),ie.setCurrentProfile(o.id),Se(o.id),Ne(),p(`Switched to profile: ${o.name}`)):i(`Already using profile: ${o.name}`)}}_(null),v([]),t("");return}if(x===" "&&(W==="connectors"||W==="capabilities")){let o=L[m];o&&(W==="connectors"?re:R)(u=>{let c=new Set(u);return c.has(o.id)?c.delete(o.id):c.add(o.id),c});return}if(x==="a"&&(W==="connectors"||W==="capabilities")){(W==="connectors"?re:R)(new Set(L.map(r=>r.id)));return}if(x==="n"&&(W==="connectors"||W==="capabilities")){(W==="connectors"?re:R)(new Set);return}return}if(X&&K.length>0){if(f.upArrow){oe(o=>o<=0?K.length-1:o-1);return}if(f.downArrow){oe(o=>o>=K.length-1?0:o+1);return}if(f.escape){ce(!1),ee([]);return}if(f.tab){Ze(V);return}}if(f.upArrow){if(e.includes(`
166
+ `)||Le.length===0)return;if(Ee===null){st(e);let r=Le.length-1;We(r),t(Le[r]);return}let o=Math.max(0,Ee-1);We(o),t(Le[o]);return}if(f.downArrow){if(e.includes(`
167
+ `)||Ee===null)return;if(Ee>=Le.length-1){We(null),t(Ft);return}let o=Ee+1;We(o),t(Le[o])}}),{suggestions:K,suggestionIndex:V,showSuggestions:X,argMode:W,argItems:L,argIndex:m,selectedConnectorIds:S,selectedCapabilities:me,deleteConfirmMode:Fe,handleInputChange:ht,handleSubmit:Ot}}import{useCallback as pt,useRef as ts,useState as ns}from"react";function oo({credentials:e,currentModel:t,modelProviders:n,onUploadSuccess:s,onUploadError:l}){let[a,g]=ns([]),y=ts(0),w=pt(b=>{if(!(!Array.isArray(n)||n.length===0)){for(let N of n)if(N.models.some(G=>G.id===b))return N.id;return n[0]?.id}},[n]),h=pt(async b=>{if(!e){l?.(b.filename,"Not logged in");return}if(!Array.isArray(n)||n.length===0){l?.(b.filename,"Model providers not loaded yet. Please wait and try again.");return}let N=t?w(t):n[0]?.id;if(!N){l?.(b.filename,"No model provider available");return}let D=`file-${++y.current}`;g(G=>[...G,{id:D,filename:b.filename,mimeType:b.mimeType,status:"uploading"}]);try{let Q=await new pe().uploadFile(e.accessToken,e.workspaceId,b,N);g(j=>j.map(J=>J.id===D?{...J,status:"uploaded",fileId:Q.id}:J)),s?.(b.filename)}catch(G){let Q=G instanceof Error?G.message:"Upload failed";g(j=>j.map(J=>J.id===D?{...J,status:"error",error:Q}:J)),l?.(b.filename,Q)}},[e,t,w,n,s,l]),O=pt(b=>{g(N=>N.filter(D=>D.id!==b))},[]),$=pt(()=>{g([])},[]),P=pt(()=>a.filter(b=>b.status==="uploaded"&&b.fileId).map(b=>b.fileId),[a]),H=a.some(b=>b.status==="uploading"),k=a.length>0;return{pendingFiles:a,addFile:h,removeFile:O,clearFiles:$,getUploadedFileIds:P,hasUploadingFiles:H,hasFiles:k}}import{jsx as q,jsxs as se}from"react/jsx-runtime";var ss=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],rs=[Zt,Zt,Qt,Qt,Ye,Ye,Ye,Ye],so=ss.map((e,t)=>`${rs[t]??Ye}${e}${z}`).join(`
168
+ `),is=`${Ye}EntryDesk${z}`,ls=500;function as(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 cs(e){let t=as(e);return Math.max(...t.split(`
169
+ `).map(n=>n.length))}function us(e){let t=cs(so);return e>=t?so:is}function ro({agentId:e,model:t,message:n,taskId:s,taskTitle:l,connectorIds:a,enableFileSystem:g=!0}){let y=process.stdout.columns??80,w=us(y),h=rn(null),O=jn(s,l),{state:$,setState:P,messages:H,setMessages:k,input:b,setInput:N,taskId:D,setTaskId:G,currentTaskTitle:Q,setCurrentTaskTitle:j,hasPersistedTask:J,setHasPersistedTask:le,credentials:i,setCredentials:p,currentResponse:E,setCurrentResponse:B,fullOutput:C,setFullOutput:de,addSystemMessage:Y,startNewTask:T}=O,{credentials:I}=Mn(P);Et(()=>{I&&!i&&p(I)},[I,i,p]);let{availableConnectors:U,availableModels:ne,availableAgents:K,modelProviders:ee,loading:V}=Gn(i),{currentModel:oe,setCurrentModel:X,currentAgentId:ce,setCurrentAgentId:W,activeConnectorIds:_,setActiveConnectorIds:L}=zn(t,e,a),v=rn(!1);Et(()=>{if(!v.current){if(v.current=!0,!t&&!e){let c=fe.getDefaultModel();c&&X(c)}if(!a&&!e){let c=fe.getDefaultConnectorIds();c&&L(c.length>0?c:void 0)}}},[t,e,a,X,L]);let{currentAgentDetails:m}=Vn(ce,i),{fileSystem:d,setFileSystem:S,capabilityLabelMap:re}=Kn(g),{pendingFiles:me,addFile:R,removeFile:Re,clearFiles:mt,getUploadedFileIds:_e,hasUploadingFiles:Lt,hasFiles:ve}=oo({credentials:i,currentModel:oe,modelProviders:ee,onUploadSuccess:c=>{Y(`\u2713 Attached: ${c}`)},onUploadError:(c,A)=>{Y(`\u2717 Failed to upload ${c}: ${A}`)}}),{sendMessage:ot}=Jn({taskId:D,credentials:i,currentAgentId:ce,currentModel:oe,activeConnectorIds:_,localTools:d,fullOutput:C,setMessages:k,setState:P,setCurrentResponse:B,setCredentials:p,setHasPersistedTask:le,getFileIds:_e,clearFiles:mt}),Le=sn(c=>{T(c),B("")},[T]),[gt,Ee]=os(!1),We=sn(async c=>{let A=c.text.trim(),Z=St(A);if(/^https?:\/\//.test(Z))return;if(await Fn(A)&&Ln(Z)){let M=await On(A);M&&(c.preventDefault(),await R(M))}},[R]),Ft=sn(async()=>{if(!(gt||$.status!=="ready")){if(V||ee.length===0){Y("Please wait for resources to load before pasting images.");return}Y("Reading clipboard..."),Ee(!0);try{let c=await Rn();if(c){let A=`clipboard-${Date.now()}.png`;Y(`Uploading: ${A} (${Math.round(c.buffer.length/1024)}KB)`),await R({buffer:c.buffer,filename:A,mimeType:c.mime})}else Y("No image found in clipboard. Copy an image first.")}catch(c){let A=c instanceof Error?c.message:"Failed to read clipboard";Y(`Clipboard error: ${A}`)}finally{Ee(!1)}}},[R,Y,gt,$.status,V,ee.length]),{suggestions:st,suggestionIndex:ze,showSuggestions:Fe,argMode:xe,argItems:Xe,argIndex:Qe,selectedConnectorIds:Te,selectedCapabilities:Se,deleteConfirmMode:Ne,handleInputChange:qe,handleSubmit:ht}=no({input:b,setInput:N,taskId:D,setTaskId:G,currentTaskTitle:Q,setCurrentTaskTitle:j,currentModel:oe,setCurrentModel:X,currentAgentId:ce,setCurrentAgentId:W,currentAgentDetails:m,setCurrentAgentDetails:()=>{},activeConnectorIds:_,setActiveConnectorIds:L,fileSystem:d,setFileSystem:S,availableModels:ne,availableAgents:K,availableConnectors:U,messages:H,hasPersistedTask:J,setHasPersistedTask:le,setMessages:k,addSystemMessage:Y,startNewTask:Le,sendMessage:ot,setFullOutput:de,credentials:i,setCredentials:p,setState:P,defaultCapabilities:{fileSystem:g},capabilityLabelMap:re,hasUploadingFiles:Lt});nn((c,A)=>{(A.ctrl||A.meta)&&c==="v"&&Ft()},{isActive:$.status==="ready"&&!xe}),nn((c,A)=>{if(!A.escape)return;let Z=Date.now(),ke=h.current;h.current=Z,!(!ke||Z-ke>ls)&&(xe||Fe||(h.current=null,ve&&mt(),b.length>0&&qe("")))},{isActive:$.status==="ready"}),nn((c,A)=>{A.return&&(Le("Started a new task."),P({status:"ready"}))},{isActive:$.status==="error"}),Et(()=>{if(i&&!V&&$.status==="loading")if(!oe&&!ce){let c=fe.getDefaultModel(),A=c&&ne.some(ke=>ke.id===c),Z=A?c:ne[0]?.id;Z?(A||fe.setDefaultModel(Z),X(Z),P({status:"ready"})):K.length===0?P({status:"no-model"}):P({status:"ready"})}else P({status:"ready"})},[i,V,oe,ce,ne,K,$.status,X,P]);let Ze=rn(!1);if(Et(()=>{Ze.current||n&&i&&$.status==="ready"&&(Ze.current=!0,ot(n))},[i,n,$.status,ot]),$.status==="loading")return se(ye,{flexDirection:"column",children:[q(F,{children:w}),se(ye,{children:[q(F,{color:"cyan",children:q(on,{type:"dots"})}),q(F,{children:" Initializing task..."})]})]});if($.status==="not-logged-in")return se(ye,{flexDirection:"column",children:[q(F,{children:w}),q(F,{color:"yellow",children:"Not logged in"}),q(F,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if($.status==="no-workspace")return se(ye,{flexDirection:"column",children:[q(F,{children:w}),q(F,{color:"yellow",children:"No workspace selected"}),q(F,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if($.status==="no-model")return se(ye,{flexDirection:"column",children:[q(F,{children:w}),q(F,{color:"yellow",children:"No model or agent specified"}),s&&q(F,{dimColor:!0,children:"Could not determine the model used in this task."}),q(F,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),q(F,{dimColor:!0,children:"Example: entrydesk task -c 1 -i --model gemini-2.5-flash-lite"})]});if($.status==="error")return se(ye,{flexDirection:"column",children:[q(F,{children:w}),se(F,{color:"red",children:["Error: ",$.message]}),q(F,{dimColor:!0,children:"Press Enter to start a new task, or Ctrl+C to exit"})]});let Ot=ce?m?m.connectors&&m.connectors.length>0?m.connectors.map(c=>c.name).join(", "):"none":"loading...":_&&_.length>0?U.filter(c=>_.includes(c.id)).map(c=>c.name).join(", ")||`${_.length} connector(s)`:"none",x=[];if(ce)if(m?.capabilities)for(let c of m.capabilities)x.push(re.get(c)??c);else x.push("loading...");d&&x.push("FileSystem");let f=ie.getCurrentProfileName(),o=f!=="default",r=(()=>{switch(xe){case"model":return"Select model:";case"agent":return"Select agent:";case"skills":return"Select skill:";case"connectors":return"Select connectors:";case"capabilities":return"Select capabilities:";default:return"Select task:"}})(),u=(()=>{if(xe==="connectors")return Te;if(xe==="capabilities")return Se})();return se(ye,{flexDirection:"column",children:[se(ye,{marginBottom:1,flexDirection:"column",children:[q(F,{children:w}),se(ye,{children:[q(F,{bold:!0,color:"cyan",children:Q?`Continuing: ${Q}`:"EntryDesk CLI"}),se(F,{dimColor:!0,children:[" v","1.12.14"]}),o&&se(F,{color:"magenta",children:[" [",f,"]"]}),q(F,{dimColor:!0,children:" (type /help for commands)"})]})]}),H.map((c,A)=>{let Z=c.parts&&C?Ke(c.parts,!0):c.content,ke=c.role==="user"?"green":c.role==="system"?"yellow":"blue",M=c.role==="user"?"You":c.role==="system"?"System":"Assistant";return se(ye,{flexDirection:"column",marginBottom:1,children:[se(F,{bold:!0,color:ke,children:[M,":"]}),q(Xt,{text:Z})]},A)}),E&&se(ye,{flexDirection:"column",marginBottom:1,children:[q(F,{bold:!0,color:"blue",children:"Assistant:"}),q(Xt,{text:E})]}),$.status==="ready"&&q(yn,{suggestions:st,activeIndex:ze,visible:Fe}),$.status==="ready"&&xe&&q(hn,{items:Xe,activeIndex:Qe,pageSize:xe==="agent"||xe==="skills"||xe==="model"?5:10,selectedIds:u,multiSelect:xe==="connectors"||xe==="capabilities",visible:!0,title:r}),$.status==="sending"&&!E?se(ye,{children:[q(F,{color:"cyan",children:q(on,{type:"dots"})}),q(F,{children:" Thinking..."})]}):$.status==="ready"&&!xe?se(ye,{flexDirection:"column",children:[Ne&&q(ye,{marginBottom:1,children:q(F,{color:"yellow",children:"\u26A0\uFE0F Delete this task? (y/N) "})}),ve&&!Ne&&se(ye,{marginBottom:1,flexDirection:"row",gap:1,children:[q(F,{dimColor:!0,children:"Attachments:"}),me.map((c,A)=>se(F,{children:[c.status==="uploading"?se(F,{color:"yellow",children:[q(on,{type:"dots"})," ",c.filename]}):c.status==="error"?se(F,{color:"red",children:["\u2717 ",c.filename]}):se(F,{color:"green",children:["\u2713 ",c.filename]}),A<me.length-1&&q(F,{children:", "})]},c.id))]}),se(ye,{children:[q(F,{color:"green",children:"> "}),q(In,{value:b,onChange:qe,onSubmit:ht,onPaste:We,leadingOffset:2,multiline:!0})]})]}):null,se(ye,{marginTop:1,flexDirection:"column",children:[se(ye,{gap:2,children:[se(F,{children:[q(F,{dimColor:!0,children:"Model: "}),q(F,{color:"magenta",children:ce?m?.model?.name||"loading...":ne.find(c=>c.id===oe)?.name||oe||"none"})]}),se(F,{children:[q(F,{dimColor:!0,children:"Connectors: "}),q(F,{color:"cyan",children:Ot})]}),se(F,{children:[q(F,{dimColor:!0,children:"Capabilities: "}),q(F,{color:"green",children:x.length>0?x.join(", "):"none"})]})]}),se(F,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",C?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as hs}from"react/jsx-runtime";async function fs(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function ps(e,t,n,s){if(s<1)return console.error("Task number must be 1 or greater"),null;let{tasks:l}=await e.getTasks(t,n,20);if(l.length===0)return console.error("No tasks found. Start a new task first."),null;if(s>l.length)return console.error(`Task number ${s} not found. You have ${l.length} recent tasks.`),console.error("Use `entrydesk tasks` to see available tasks."),null;let a=l[s-1],g;if(!a.agentId){let{messages:y}=await e.getMessages(t,n,a.id,10);g=y.find(h=>h.role==="assistant"&&h.modelId)?.modelId}return{task:a,modelId:g}}var Ve="\x1B[2m",we="\x1B[0m",ln="\x1B[36m",Rt="\x1B[33m",Nt="\x1B[32m",lo="stream-json";function ms(e,t,n,s){e&&t&&(console.error(`Error: Cannot use both ${n} and ${s}`),process.exit(1))}function At(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
170
+ `)}function Dt(e,t){if(t)return e;let n=e.split(`
171
+ `);if(n.length<=20)return e;let s=n.slice(0,5),l=n.slice(-5),a=n.length-10;return[...s,`${Ve}... (${a} lines omitted, use --full-output to see all) ...${we}`,...l].join(`
172
+ `)}function gs(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function ao(e,t){if(!e)return"(no result)";if(typeof e!="object")return Dt(String(e),t);let n=e;if("structuredContent"in n&&n.structuredContent){let s=n.structuredContent,l=[];if(s.stdout&&typeof s.stdout=="string"&&s.stdout.trim()&&l.push(s.stdout.trim()),s.stderr&&typeof s.stderr=="string"&&s.stderr.trim()&&l.push(`${Rt}[stderr]${we} ${s.stderr.trim()}`),s.urls&&Array.isArray(s.urls)){let a=s.urls;for(let g of a)g.path&&g.url&&l.push(`${g.path}: ${g.url}`)}return l.length===0&&l.push(JSON.stringify(s,null,2)),Dt(l.join(`
173
+ `),t)}if("content"in n&&Array.isArray(n.content)){let l=n.content.filter(a=>a.type==="text"&&a.text).map(a=>a.text).join(`
174
+ `);return Dt(l||JSON.stringify(e,null,2),t)}return Dt(JSON.stringify(e,null,2),t)}function co(e){try{let n=(typeof e.data=="string"?JSON.parse(e.data):e.data)?.parts;return Array.isArray(n)?n.filter(s=>typeof s=="object"&&s!==null&&s.type==="text"&&typeof s.text=="string").map(s=>s.text).join(""):""}catch{return""}}async function Ni(e){let t,n;try{let I=await Me();t=I.accessToken,n=I.workspaceId}catch(I){cn(I)}let s=e.output===lo;e.output&&!s&&(console.error(`Invalid --output value. Supported: ${lo}`),process.exit(1));let l=!s&&(e.plain||!process.stdout.isTTY),a=fe.getDefaultModel(),g=e.message;!g&&!process.stdin.isTTY&&(g=await fs());let y=new pe;async function w(){if(!a)try{let{models:I}=await y.getModels(t,n),U=I[0]?.id;if(!U)return;fe.setDefaultModel(U),a=U}catch{}}let h,O,$,P;if(e.continue){let I=await ps(y,t,n,e.continue);I||process.exit(1),h=I.task.id,O=I.task.title??void 0,$=I.task.agentId??void 0,P=I.modelId;let U=e.agentId||e.model||$||P||a;!U&&!e.interactive&&(await w(),U=e.agentId||e.model||$||P||a),!U&&!e.interactive&&(l||console.log(`Continuing task: ${I.task.title||"Untitled"}`),console.error(`
175
+ Could not determine model for this task. Please specify --model or -a.`),console.error('Example: entrydesk task -c 1 -m "message" --model gemini-2.5-flash-lite'),process.exit(1)),!l&&!e.interactive&&console.log(`Continuing task: ${I.task.title||"Untitled"}
176
+ `)}let H=e.agentId||$,k=e.model||P||a||void 0;!H&&!k&&(await w(),k=e.model||P||a||void 0),ms(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let b=fe.getDefaultConnectorIds(),N=e.connectors??b??void 0,D=fe.getLocalTools(),G=e.noFileSystem?!1:e.fileSystem?!0:D?.fileSystem??!0;if(e.interactive){ds(hs(ro,{agentId:H,model:k,message:e.message,taskId:h,taskTitle:O??void 0,connectorIds:N,enableFileSystem:G}),{exitOnCtrlC:!1});return}let Q=!e.continue&&!k&&!H;(!g||Q)&&(console.error("Usage: entrydesk task -m <message> --model <model>"),console.error(" entrydesk task -m <message> -a <agent>"),console.error(" entrydesk task -c <number> -m <message>"),console.error(' echo "message" | entrydesk task --model <model>'),console.error(" entrydesk task -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 task by number (1 = most recent)"),console.error(" -i Interactive mode"),console.error(" --plain Plain text output (no colors/formatting)"),console.error(" --output stream-json Stream JSON events (for scripting)"),console.error(" --full-output Show full tool results without truncation"),console.error(" --dangerously-auto-approve-tools"),console.error(" Auto-approve all server-side tool calls (required for"),console.error(" non-interactive use with connectors/MCP tools)"),console.error(""),console.error("List available models: entrydesk models"),console.error("List available agents: entrydesk agents"),console.error("List recent tasks: entrydesk tasks"),process.exit(1));let j=e.fullOutput??!1,J=e.dangerouslyAutoApproveTools??!1,le=h||io(),i=G?wt():void 0,p=G?xt():void 0,E=I=>{let U={id:le,...J&&{toolApprovalMode:"allow_always"}};return I&&(U.message=I),H?U.agentId=H:(k&&(U.model=k),U.connectorIds=N??[]),i&&(U.clientTools=i),p&&(U.clientToolSystemPrompt=p),U},B=async I=>{if(!I.body)throw new Error("No response body");let U=I.body.getReader(),ne=new TextDecoder,K="",ee=new Map,V=[],oe=!1,X="";for(;;){let{done:ce,value:W}=await U.read();if(ce)break;K+=ne.decode(W,{stream:!0});let _=K.split(`
177
+ `);K=_.pop()||"";for(let L of _){let v=L.trimEnd();if(v==="data: [DONE]"){s&&At("done");continue}if(v.startsWith("data: "))try{let m=JSON.parse(v.slice(6));if((m.type==="text-delta"||m.type==="reasoning-delta"||m.type==="tool-call"||m.type==="tool-input-available"||m.type==="tool-result"||m.type==="data-appendMessage")&&(oe=!0),m.type==="start"&&typeof m.messageId=="string"&&(X=m.messageId),s){m.type==="text-delta"&&m.delta!==void 0?At("text-delta",m.delta):m.type==="reasoning-delta"&&m.delta!==void 0?At("reasoning-delta",m.delta):At(m.type||"event",m);continue}if(l){if(m.type==="text-delta"&&m.delta&&process.stdout.write(m.delta),m.type==="data-appendMessage"&&process.stdout.write(co(m)),G&&(m.type==="tool-input-available"||m.type==="tool-call")&&m.toolCallId&&m.toolName&&Be(m.toolName)){let d=m.args||m.input||{};V.push({toolCallId:m.toolCallId,toolName:m.toolName,args:d})}continue}switch(m.type){case"reasoning-delta":m.delta&&process.stdout.write(`${Ve}${m.delta}${we}`);break;case"reasoning-end":process.stdout.write(`
178
+
179
+ `);break;case"text-delta":m.delta&&process.stdout.write(m.delta);break;case"data-appendMessage":process.stdout.write(co(m));break;case"tool-call-streaming-start":case"tool-input-start":if(m.toolCallId&&m.toolName){ee.set(m.toolCallId,{toolName:m.toolName});let S=G&&Be(m.toolName)?`${Nt}[LOCAL]${we} `:"";console.log(`
180
+ ${ln}\u250C\u2500 ${S}Tool Call: ${m.toolName}${we}`)}break;case"tool-call":case"tool-input-available":if(m.toolCallId&&m.toolName){let d=m.args||m.input||{},S=gs(d);console.log(`${Rt}\u2502 Arguments:${we}`);for(let re of S.split(`
181
+ `))console.log(`${Ve}\u2502 ${re}${we}`);G&&Be(m.toolName)&&(ee.set(m.toolCallId,{toolName:m.toolName,args:d}),V.push({toolCallId:m.toolCallId,toolName:m.toolName,args:d}))}break;case"tool-result":if(m.toolCallId){let d=ee.get(m.toolCallId),S=ao(m.result,j);console.log(`${Nt}\u2502 Result:${we}`);for(let re of S.split(`
182
+ `))console.log(`${Ve}\u2502 ${re}${we}`);console.log(`${ln}\u2514\u2500 ${d?.toolName||"Tool"} completed${we}
183
+ `),ee.delete(m.toolCallId)}break;case"error":m.errorText&&console.error(`${Ve}Error: ${m.errorText}${we}`);break}}catch{}}}return{pendingClientTools:V,hadContent:oe,messageId:X}},C=E({id:io(),createdAt:new Date,role:"user",parts:[{type:"text",text:g}]}),de=await y.task(t,n,C),Y=await B(de),T=Y.hadContent;for(;Y.pendingClientTools.length>0;){let I=Y.messageId,U=[];for(let K of Y.pendingClientTools){!l&&!s&&console.log(`${Nt}\u2502 Executing locally...${we}`);let ee=await Tt(K.toolName,K.args);if(U.push({type:`tool-${K.toolName}`,toolCallId:K.toolCallId,state:"output-available",output:{content:[{type:"text",text:ee.success?JSON.stringify(ee.result):ee.error||"Unknown error"}],isError:!ee.success}}),!l&&!s){let V=ao(ee.success?ee.result:{error:ee.error},j);console.log(`${Nt}\u2502 Result:${we}`);for(let oe of V.split(`
184
+ `))console.log(`${Ve}\u2502 ${oe}${we}`);console.log(`${ln}\u2514\u2500 ${K.toolName} completed${we}
185
+ `)}}I||(console.error(`${Rt}Cannot continue: missing assistant message id for tool results.${we}`),process.exit(1));let ne=E({id:I,role:"assistant",parts:U});de=await y.task(t,n,ne),Y=await B(de),T=T||Y.hadContent}T||(console.error(`${Rt}No response received from the server (empty stream).${we}`),console.error(`${Ve}The task may have failed server-side. Re-run with DEBUG=1 for details.${we}`),process.exit(1)),s||console.log("")}export{Ni as runTask};
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as A,p as I,q as b,s as O}from"./chunk-6A4DXLDW.js";var $="\x1B[2m",a="\x1B[0m",d="\x1B[36m",w="\x1B[33m",R="\x1B[32m",v="stream-json";function f(e,s){let o=s===void 0?{event:e}:{event:e,data:s};process.stdout.write(`${JSON.stringify(o)}
2
+ import{h as A,p as I,q as b,s as O}from"./chunk-JTCLYSZY.js";var $="\x1B[2m",a="\x1B[0m",d="\x1B[36m",w="\x1B[33m",R="\x1B[32m",v="stream-json";function f(e,s){let o=s===void 0?{event:e}:{event:e,data:s};process.stdout.write(`${JSON.stringify(o)}
3
3
  `)}function S(e){let s=new Date(e),t=new Date().getTime()-s.getTime(),n=Math.floor(t/(1e3*60*60*24));return n===0?s.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit"}):n===1?"Yesterday":n<7?`${n} days ago`:s.toLocaleDateString("en-US",{month:"short",day:"numeric"})}function y(e,s){if(s)return e;let o=e.split(`
4
4
  `);if(o.length<=15)return e;let t=o.slice(0,6),n=o.slice(-4),i=o.length-10;return[...t,`... (${i} lines omitted, use --full-output to see all) ...`,...n].join(`
5
5
  `)}function N(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(N);let s={};for(let[o,t]of Object.entries(e))typeof t=="string"&&t.length>200?s[o]=t.slice(0,150)+"... (truncated)":typeof t=="object"&&t!==null?s[o]=N(t):s[o]=t;return s}function j(e){if(!e||typeof e!="object")return String(e);try{return JSON.stringify(e,null,2)}catch{return String(e)}}function E(e,s){if(!e)return"(no result)";if(typeof e!="object")return y(String(e),s);let o=s?e:N(e);if("structuredContent"in o&&o.structuredContent){let t=o.structuredContent,n=[];if(t.stdout&&typeof t.stdout=="string"&&t.stdout.trim()&&n.push(t.stdout.trim()),t.stderr&&typeof t.stderr=="string"&&t.stderr.trim()&&n.push(`${w}[stderr]${a} ${t.stderr.trim()}`),t.urls&&Array.isArray(t.urls)){let i=t.urls;for(let r of i)r.path&&r.url&&n.push(`${r.path}: ${r.url}`)}return n.length===0&&n.push(JSON.stringify(t,null,2)),y(n.join(`
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{c as S,q as _}from"./chunk-6A4DXLDW.js";import B from"fs";import{Client as L}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as x}from"@modelcontextprotocol/sdk/client/streamableHttp.js";async function A(e={}){let t=e.apiUrl,n=e.accessToken,o=e.workspaceId;if(!n||!o){let l=await _();n=n||l.accessToken,o=o||l.workspaceId}t||(t=S().apiUrl);let i=new L({name:"entrydesk-cli",version:"1.0.0"}),s=new URL(`${t}/v1/workspaces/${o}/mcp`),r=new x(s,{requestInit:{headers:{Authorization:`Bearer ${n}`}}});return await i.connect(r),i}async function T(){return A()}import h from"fs/promises";import v from"os";import d from"path";var y=!process.env.NO_COLOR&&!!process.stdout.isTTY,p={green:y?"\x1B[32m":"",yellow:y?"\x1B[33m":"",reset:y?"\x1B[0m":""},D=10*1024,O=8*1024,I=2*1024,P=100,b=100;function M(){return d.join(v.homedir(),".entrydesk","tool-results")}function F(e){let t=e.trim().replace(/[/\\:*?"<>|\s]/g,"_").replace(/_+/g,"_").replace(/^[._]+|[._]+$/g,"").slice(0,P);return!t||t==="."||t===".."?"unnamed_tool":t}function J(e){try{return JSON.stringify(e,(t,n)=>typeof n=="bigint"?`${n}n`:typeof n=="function"?"[Function]":typeof n=="symbol"?n.toString():n,2)}catch{return String(e)}}function U(e){let t=new Date,n=[t.getFullYear(),String(t.getMonth()+1).padStart(2,"0"),String(t.getDate()).padStart(2,"0")].join("-")+"_"+[String(t.getHours()).padStart(2,"0"),String(t.getMinutes()).padStart(2,"0"),String(t.getSeconds()).padStart(2,"0")].join("-"),o=F(e);return`${n}_${o}.json`}async function N(e,t){try{return await h.writeFile(e,t,{encoding:"utf8",flag:"wx"}),!0}catch(n){if(n instanceof Error&&"code"in n&&n.code==="EEXIST")return!1;throw n}}async function C(e,t){try{let n=M();await h.mkdir(n,{recursive:!0});let o=U(e),i=d.extname(o),s=o.slice(0,-i.length),r=J(t),l=d.join(n,o);if(await N(l,r))return l;for(let c=1;c<=b;c++){let w=d.join(n,`${s}-${c}${i}`);if(await N(w,r))return w}let u=Math.random().toString(36).slice(2,10),a=d.join(n,`${s}-${u}${i}`);return await h.writeFile(a,r,{encoding:"utf8",flag:"wx"}),a}catch(n){let o=n instanceof Error?n.message:"unknown error";return console.error(`${p.yellow}Warning: Could not save result to file: ${o}${p.reset}`),null}}function k(e,t){let n=Buffer.byteLength(e,"utf8");if(n<=D)return e;let o=e.slice(0,O),i=e.slice(-I),r=((n-O-I)/1024).toFixed(1),l=(n/1024).toFixed(1),u=` ... (skipped ${r}KB of ${l}KB) ...`;return t&&(u+=`
2
+ import{c as S,q as _}from"./chunk-JTCLYSZY.js";import B from"fs";import{Client as L}from"@modelcontextprotocol/sdk/client/index.js";import{StreamableHTTPClientTransport as x}from"@modelcontextprotocol/sdk/client/streamableHttp.js";async function A(e={}){let t=e.apiUrl,n=e.accessToken,o=e.workspaceId;if(!n||!o){let l=await _();n=n||l.accessToken,o=o||l.workspaceId}t||(t=S().apiUrl);let i=new L({name:"entrydesk-cli",version:"1.0.0"}),s=new URL(`${t}/v1/workspaces/${o}/mcp`),r=new x(s,{requestInit:{headers:{Authorization:`Bearer ${n}`}}});return await i.connect(r),i}async function T(){return A()}import h from"fs/promises";import v from"os";import d from"path";var y=!process.env.NO_COLOR&&!!process.stdout.isTTY,p={green:y?"\x1B[32m":"",yellow:y?"\x1B[33m":"",reset:y?"\x1B[0m":""},D=10*1024,O=8*1024,I=2*1024,P=100,b=100;function M(){return d.join(v.homedir(),".entrydesk","tool-results")}function F(e){let t=e.trim().replace(/[/\\:*?"<>|\s]/g,"_").replace(/_+/g,"_").replace(/^[._]+|[._]+$/g,"").slice(0,P);return!t||t==="."||t===".."?"unnamed_tool":t}function J(e){try{return JSON.stringify(e,(t,n)=>typeof n=="bigint"?`${n}n`:typeof n=="function"?"[Function]":typeof n=="symbol"?n.toString():n,2)}catch{return String(e)}}function U(e){let t=new Date,n=[t.getFullYear(),String(t.getMonth()+1).padStart(2,"0"),String(t.getDate()).padStart(2,"0")].join("-")+"_"+[String(t.getHours()).padStart(2,"0"),String(t.getMinutes()).padStart(2,"0"),String(t.getSeconds()).padStart(2,"0")].join("-"),o=F(e);return`${n}_${o}.json`}async function N(e,t){try{return await h.writeFile(e,t,{encoding:"utf8",flag:"wx"}),!0}catch(n){if(n instanceof Error&&"code"in n&&n.code==="EEXIST")return!1;throw n}}async function C(e,t){try{let n=M();await h.mkdir(n,{recursive:!0});let o=U(e),i=d.extname(o),s=o.slice(0,-i.length),r=J(t),l=d.join(n,o);if(await N(l,r))return l;for(let c=1;c<=b;c++){let w=d.join(n,`${s}-${c}${i}`);if(await N(w,r))return w}let u=Math.random().toString(36).slice(2,10),a=d.join(n,`${s}-${u}${i}`);return await h.writeFile(a,r,{encoding:"utf8",flag:"wx"}),a}catch(n){let o=n instanceof Error?n.message:"unknown error";return console.error(`${p.yellow}Warning: Could not save result to file: ${o}${p.reset}`),null}}function k(e,t){let n=Buffer.byteLength(e,"utf8");if(n<=D)return e;let o=e.slice(0,O),i=e.slice(-I),r=((n-O-I)/1024).toFixed(1),l=(n/1024).toFixed(1),u=` ... (skipped ${r}KB of ${l}KB) ...`;return t&&(u+=`
3
3
  Tip: jq -r '.structuredContent.field' <file> | grep/head/tail`),`${o}
4
4
 
5
5
  ${u}
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{h as d,q as f}from"./chunk-6A4DXLDW.js";function U(){console.log(`
2
+ import{h as d,q as f}from"./chunk-JTCLYSZY.js";function U(){console.log(`
3
3
  Usage: entrydesk usage [options]
4
4
 
5
5
  Options:
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ function n(){console.log("entrydesk 1.12.14")}export{n as printVersion};
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{g as a,h as w,p as k}from"./chunk-6A4DXLDW.js";function l(){console.log(`
2
+ import{g as a,h as w,p as k}from"./chunk-JTCLYSZY.js";function l(){console.log(`
3
3
  Usage: entrydesk workspaces [list|switch|use] [options]
4
4
 
5
5
  Commands:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@entrydesk/cli",
3
- "version": "1.12.12",
3
+ "version": "1.12.14",
4
4
  "description": "EntryDesk CLI - Interact with EntryDesk from your terminal",
5
5
  "type": "module",
6
6
  "bin": {
@@ -31,7 +31,7 @@
31
31
  "@types/react": "^19.2.14",
32
32
  "@vitest/coverage-v8": "^4.1.1",
33
33
  "happy-dom": "^20.8.9",
34
- "oxlint": "^1.64.0",
34
+ "oxlint": "^1.69.0",
35
35
  "strip-ansi": "^7.1.2",
36
36
  "tsup": "^8.5.0",
37
37
  "typescript": "^6.0.3",
@@ -1,2 +0,0 @@
1
- #!/usr/bin/env node
2
- import F from"fs";import p from"fs";import Ue from"os";import T from"path";import{HTTPError as Ke,TimeoutError as De}from"ky";import ke,{TimeoutError as ve,isHTTPError as we}from"ky";import b from"crypto";import u from"fs";import de from"path";var ue="ENTRYDESK_FORCE_FILE_STORAGE",E="EntryDesk CLI",fe="__entrydesk_keychain_test__",pe="profile:",he=".credentials.key",Q={keychain:!1,permissions:!1,corruptFile:!1,windowsFile:!1};function v(r,e){Q[r]||(Q[r]=!0,console.error(e))}function ye(){return process.env.ENTRYDESK_DEBUG?.toLowerCase()==="true"}function ee(r){if(!r||typeof r!="object")return!1;let e=r;return!(!("accessToken"in e||"refreshToken"in e||"email"in e||"workspaceId"in e)||"accessToken"in e&&typeof e.accessToken!="string"||"refreshToken"in e&&typeof e.refreshToken!="string"||"email"in e&&typeof e.email!="string"||"workspaceId"in e&&typeof e.workspaceId!="string")}function me(r){if(!r||typeof r!="object")return!1;let e=r;return typeof e.getPassword=="function"&&typeof e.setPassword=="function"&&typeof e.deletePassword=="function"}function N(r){return o.getProfileCredentialsFile(r)}var M=class{getKeyFilePath(e){return de.join(o.getProfileDir(e),he)}loadEncryptionKey(e){let t=this.getKeyFilePath(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t);return s.length!==32?null:(this.ensureSecureFilePermissions(t),s)}catch{return null}}createEncryptionKey(e){o.ensureProfileDir(e);let t=this.getKeyFilePath(e),s=b.randomBytes(32);return u.writeFileSync(t,s,{mode:384}),this.ensureSecureFilePermissions(t),s}getOrCreateEncryptionKey(e){let t=this.loadEncryptionKey(e);return t||this.createEncryptionKey(e)}encrypt(e,t){let s=b.randomBytes(16),n=b.createCipheriv("aes-256-gcm",t,s),i=n.update(e,"utf8","hex");i+=n.final("hex");let c=n.getAuthTag();return`${s.toString("hex")}:${c.toString("hex")}:${i}`}decrypt(e,t){let s=e.split(":");if(s.length!==3)throw new Error("Invalid encrypted data format");let n=Buffer.from(s[0],"hex"),i=Buffer.from(s[1],"hex"),c=s[2],S=b.createDecipheriv("aes-256-gcm",t,n,{authTagLength:16});S.setAuthTag(i);let d=S.update(c,"hex","utf8");return d+=S.final("utf8"),d}tryDecrypt(e,t){try{return this.decrypt(e,t)}catch{return null}}tryParseCredentials(e){try{let t=JSON.parse(e);return ee(t)?t:null}catch{return null}}ensureSecureFilePermissions(e){if(process.platform!=="win32"){try{u.chmodSync(e,384)}catch{v("permissions","Warning: Failed to set secure permissions on credentials file.");return}try{(u.statSync(e).mode&511)!==384&&v("permissions","Warning: Credentials file permissions are too permissive.")}catch{v("permissions","Warning: Failed to verify credentials file permissions.")}}}async getCredentials(e){let t=N(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t,"utf-8").trim();if(!s)return null;let n=this.loadEncryptionKey(e),i=n?this.tryDecrypt(s,n):null;if(i){let c=this.tryParseCredentials(i);if(c)return c}return v("corruptFile","Warning: Credentials file is unreadable. Please run `entrydesk login` again."),null}catch{return null}}async setCredentials(e,t){o.ensureProfileDir(e);let s=N(e),n=this.getOrCreateEncryptionKey(e),i=this.encrypt(JSON.stringify(t),n);u.writeFileSync(s,i,{mode:384}),this.ensureSecureFilePermissions(s)}async deleteCredentials(e){let t=N(e);try{u.existsSync(t)&&u.unlinkSync(t)}catch{}}},j=class{keytarModule=null;keytarLoadAttempted=!1;keychainAvailable=null;async getKeytar(){if(this.keytarLoadAttempted)return this.keytarModule;this.keytarLoadAttempted=!0;try{let t=await import("keytar"),s=t&&typeof t=="object"&&"default"in t?t.default:t;this.keytarModule=me(s)?s:null}catch{this.keytarModule=null}return this.keytarModule}getAccount(e){return`${pe}${e}`}async checkKeychainAvailability(){if(this.keychainAvailable!==null)return this.keychainAvailable;try{let e=await this.getKeytar();if(!e)return this.keychainAvailable=!1,!1;let t=`${fe}${b.randomBytes(8).toString("hex")}`,s="test";await e.setPassword(E,t,s);let n=await e.getPassword(E,t),i=await e.deletePassword(E,t);return this.keychainAvailable=!!(i&&n===s),this.keychainAvailable}catch{return this.keychainAvailable=!1,!1}}async isAvailable(){return this.checkKeychainAvailability()}async getCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");let s=await t.getPassword(E,this.getAccount(e));if(!s)return null;let n=this.tryParseKeychainPayload(s);return n||v("corruptFile",`Warning: Keychain entry for profile "${e}" is unreadable.`),n}async setCredentials(e,t){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let s=await this.getKeytar();if(!s)throw new Error("Keytar module not available");let n=JSON.stringify(t);await s.setPassword(E,this.getAccount(e),n)}async deleteCredentials(e){if(!await this.checkKeychainAvailability())throw new Error("Keychain is not available");let t=await this.getKeytar();if(!t)throw new Error("Keytar module not available");await t.deletePassword(E,this.getAccount(e))}tryParseKeychainPayload(e){try{let t=JSON.parse(e);return ee(t)?t:null}catch{return null}}},z=class{keychainStorage=null;fileStorage=new M;keychainAvailable=null;initPromise=null;shouldForceFileStorage(){return process.env[ue]?.toLowerCase()==="true"}async initializeStorage(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}try{let e=new j,t=await e.isAvailable();this.keychainAvailable=t,this.keychainStorage=t?e:null}catch{this.keychainAvailable=!1,this.keychainStorage=null}!this.keychainAvailable&&!this.shouldForceFileStorage()&&(ye()&&v("keychain","Keychain unavailable. Falling back to file-based credentials."),process.platform==="win32"&&v("windowsFile","Warning: File-based credentials on Windows may be readable by other users."))}async ensureInitialized(){if(this.shouldForceFileStorage()){this.keychainAvailable=!1,this.keychainStorage=null;return}this.keychainAvailable===null&&(this.initPromise??=this.initializeStorage(),await this.initPromise)}disableKeychain(){this.shouldForceFileStorage()||v("keychain","Keychain error encountered. Falling back to file-based credentials."),this.keychainAvailable=!1,this.keychainStorage=null}async getKeychainStorage(){return await this.ensureInitialized(),this.shouldForceFileStorage()?null:this.keychainAvailable?this.keychainStorage:null}async getCredentials(e){let t=await this.getKeychainStorage();if(!t)return this.fileStorage.getCredentials(e);try{let n=await t.getCredentials(e);if(n)return n}catch{return this.disableKeychain(),this.fileStorage.getCredentials(e)}let s=await this.fileStorage.getCredentials(e);if(s)try{await t.setCredentials(e,s),await this.fileStorage.deleteCredentials(e)}catch{}return s}async setCredentials(e,t){let s=await this.getKeychainStorage();if(!s){await this.fileStorage.setCredentials(e,t);return}try{await s.setCredentials(e,t),await this.fileStorage.deleteCredentials(e)}catch{this.disableKeychain(),await this.fileStorage.setCredentials(e,t)}}async deleteCredentials(e){let t=await this.getKeychainStorage();if(t)try{await t.deleteCredentials(e)}catch{this.disableKeychain()}await this.fileStorage.deleteCredentials(e)}},l=new z,h={async saveAccessToken(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.accessToken=r,await l.setCredentials(t,s)},async getAccessToken(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.accessToken??null},async saveRefreshToken(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.refreshToken=r,await l.setCredentials(t,s)},async getRefreshToken(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.refreshToken??null},async saveEmail(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.email=r,await l.setCredentials(t,s)},async getEmail(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.email??null},async saveWorkspaceId(r,e){let t=o.getEffectiveProfileName(e),s=await l.getCredentials(t)??{};s.workspaceId=r,await l.setCredentials(t,s)},async getWorkspaceId(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.workspaceId??null},async saveAll(r,e){let t=o.getEffectiveProfileName(e);await l.setCredentials(t,r)},async getAll(r){let e=o.getEffectiveProfileName(r);return l.getCredentials(e)},async clear(r){let e=o.getEffectiveProfileName(r);await l.deleteCredentials(e)},async isLoggedIn(r){let e=o.getEffectiveProfileName(r);return(await l.getCredentials(e))?.accessToken!=null}};var _=class r{client;baseUrl;constructor(e,t){this.baseUrl=e||I(t),K().ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",process.env.DEBUG&&console.log("[DEBUG] ApiClient: SSL certificate validation disabled")),this.client=ke.create({baseUrl:this.baseUrl.replace(/\/?$/,"/"),timeout:3e4,retry:{limit:3,methods:["get","put","head","delete","options","trace"],statusCodes:[408,413,429,500,502,503,504]},hooks:{beforeError:[({error:n})=>(we(n)&&(n.request.headers.delete("authorization"),n.request.headers.delete("Authorization")),n)]}})}getBaseUrl(){return this.baseUrl}async refreshOAuthToken(e){return this.client.post("v1/oauth/token",{json:{grant_type:"refresh_token",refresh_token:e.refreshToken,client_id:e.clientId}}).json()}async revokeOAuthToken(e){await this.client.post("v1/oauth/revoke",{json:{token:e.token,token_type_hint:"refresh_token",client_id:e.clientId}})}async getWorkspaces(e){try{return process.env.DEBUG&&console.log(`[DEBUG] Calling getWorkspaces API: ${this.baseUrl}/v1/workspaces`),await this.client.get("v1/workspaces",{headers:{Authorization:`Bearer ${e}`}}).json()}catch(t){throw process.env.DEBUG&&(console.error("[DEBUG] getWorkspaces error:",t),t instanceof Error&&"cause"in t&&console.error("[DEBUG] Error cause:",t.cause)),t}}async getAgents(e,t,s){let n={limit:s?.limit??100};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/availableAgents`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async createAgent(e,t,s){return await this.client.post(`v1/workspaces/${t}/agents`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateAgent(e,t,s,n){await this.client.put(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteAgent(e,t,s){await this.client.delete(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModels(e,t){return await this.client.get(`v1/workspaces/${t}/models`,{headers:{Authorization:`Bearer ${e}`}}).json()}async getConnectors(e,t){return await this.client.get(`v1/workspaces/${t}/availableConnectors`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:100,connectionStatus:"connected"}}).json()}async getTasks(e,t,s=20){return await this.client.get(`v1/workspaces/${t}/tasks`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:s}}).json()}async getMessages(e,t,s,n=50){return await this.client.get(`v1/workspaces/${t}/tasks/${s}/messages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{limit:n}}).json()}async getAgent(e,t,s){return await this.client.get(`v1/workspaces/${t}/agents/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async listAvailableSkills(e,t,s){return await this.client.get(`v1/workspaces/${t}/availableSkills`,{headers:{Authorization:`Bearer ${e}`},searchParams:{createdBy:s?.createdBy,nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async uploadSkill(e,t,s){return await this.client.post(`v1/workspaces/${t}/skills`,{headers:{Authorization:`Bearer ${e}`},body:s}).json()}async deleteSkill(e,t,s){await this.client.delete(`v1/workspaces/${t}/skills/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async downloadSkillCurrent(e,t,s){return await this.client.get(`v1/workspaces/${t}/skills/${s}/download`,{headers:{Authorization:`Bearer ${e}`}}).json()}async task(e,t,s){try{let n=await this.client.post(`v1/workspaces/${t}/tasks`,{headers:{Authorization:`Bearer ${e}`},json:s,timeout:6e4,throwHttpErrors:!1});if(!n.ok){let i=await n.text();throw new Error(`Task API failed (${n.status}): ${i}`)}return n}catch(n){throw n instanceof ve?new TypeError("Request timed out. Please check your connection and try again.",{cause:n}):n}}async getBudget(e,t){return await this.client.get(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`}}).json()}async updateBudget(e,t,s){await this.client.put(`v1/workspaces/${t}/budget`,{headers:{Authorization:`Bearer ${e}`},json:{budget:s}})}async getMonthlyUsages(e,t,s){return await this.client.get(`v1/workspaces/${t}/monthlyUsages`,{headers:{Authorization:`Bearer ${e}`},searchParams:{nextKey:s?.nextKey,limit:s?.limit??20}}).json()}async createTaskShare(e,t,s,n="public"){return await this.client.post(`v1/workspaces/${t}/tasks/${s}/shares`,{headers:{Authorization:`Bearer ${e}`},json:{visibility:n}}).json()}async getSharedTask(e,t){let s={};return t&&(s.Authorization=`Bearer ${t}`),await this.client.get(`v1/shares/${e}`,{headers:s}).json()}async getSharedMessages(e,t=50,s){let n={};return s&&(n.Authorization=`Bearer ${s}`),await this.client.get(`v1/shares/${e}/messages`,{headers:n,searchParams:{limit:t}}).json()}async deleteTask(e,t,s){await this.client.delete(`v1/workspaces/${t}/tasks/${s}`,{headers:{Authorization:`Bearer ${e}`}})}async getModelProviders(e,t){return await this.client.get(`v1/workspaces/${t}/modelProviders`,{headers:{Authorization:`Bearer ${e}`}}).json()}async uploadFile(e,t,s,n){let i=new FormData,c=new Blob([s.buffer],{type:s.mimeType});return i.append("file",c,s.filename),i.append("modelProviderId",n),await this.client.post(`v1/workspaces/${t}/files`,{headers:{Authorization:`Bearer ${e}`},body:i,timeout:12e4}).json()}async getSchedules(e,t,s){let n={limit:s?.limit??20};return s?.nextKey&&(n.nextKey=s.nextKey),s?.search&&(n.search=s.search),await this.client.get(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},searchParams:n}).json()}async getSchedule(e,t,s){return await this.client.get(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}}).json()}async createSchedule(e,t,s){return await this.client.post(`v1/workspaces/${t}/schedules`,{headers:{Authorization:`Bearer ${e}`},json:s}).json()}async updateSchedule(e,t,s,n){await this.client.put(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`},json:n})}async deleteSchedule(e,t,s){await this.client.delete(`v1/workspaces/${t}/schedules/${s}`,{headers:{Authorization:`Bearer ${e}`}})}static async getAuthenticatedClient(e){let t=await h.getAll(e);return t?{client:new r(void 0,e),accessToken:t.accessToken,workspaceId:t.workspaceId??null}:null}};function Pe(){return process.env.ENTRYDESK_SANDBOX==="true"}function D(){if(!Pe())return null;let r=process.env.ENTRYDESK_SANDBOX_ACCESS_TOKEN?.trim(),e=process.env.ENTRYDESK_SANDBOX_WORKSPACE_ID?.trim();if(!r||!e){let t=[];throw r||t.push("ENTRYDESK_SANDBOX_ACCESS_TOKEN"),e||t.push("ENTRYDESK_SANDBOX_WORKSPACE_ID"),new Error(`Sandbox mode enabled but missing credentials: ${t.join(", ")}`)}return{accessToken:r,workspaceId:e}}function L(){let r=process.env.ENTRYDESK_TOKEN?.trim();if(!r)return null;let e=process.env.ENTRYDESK_WORKSPACE_ID?.trim();if(!e)throw new Error("ENTRYDESK_TOKEN is set but ENTRYDESK_WORKSPACE_ID is missing. Both are required for PAT authentication.");return{accessToken:r,workspaceId:e}}function et(){let r=D();if(r)return{authSource:"sandbox-env",label:"sandbox environment (ENTRYDESK_SANDBOX)",workspaceId:r.workspaceId};let e=L();return e?{authSource:"pat-env",label:"personal access token (ENTRYDESK_TOKEN)",workspaceId:e.workspaceId}:null}import{execFile as Se}from"child_process";import{setTimeout as Ae}from"timers/promises";import{decodeJwt as Ee}from"jose";import Ce,{HTTPError as Te,isHTTPError as be}from"ky";function te(r){if(r===null||typeof r!="object")return{error:""};let e=r;return{code:typeof e.code=="string"?e.code:void 0,error:typeof e.error=="string"?e.error:""}}var U="entrydesk-cli",Re="offline_access workspaces:read tasks:read tasks:write tasks:delete agents:read agents:write connectors:read connectors:write tools:read tools:execute skills:read skills:write meetings:read meetings:write publishes:read publishes:write calendar:read calendar:write schedules:read schedules:write user:read user:write";function xe(r){return new Promise((e,t)=>{let s=process.platform,n,i;switch(s){case"darwin":n="open",i=[r];break;case"win32":n="cmd",i=["/c","start","",r];break;default:n="xdg-open",i=[r];break}Se(n,i,c=>{c?t(new Error(`Failed to open browser. Please manually visit: ${r}`,{cause:c})):e()})})}async function lt(r){let e=I(),t=re(),s=K(),n=process.env.NODE_TLS_REJECT_UNAUTHORIZED;s.ignoreSslErrors&&(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0",console.error("WARNING: SSL certificate validation is disabled globally for this process during the login flow. All connections in this process will skip TLS verification. Only use ENTRYDESK_IGNORE_SSL_ERRORS for local development."));try{let i=Ce.create({baseUrl:e.replace(/\/?$/,"/"),timeout:3e4,hooks:{beforeError:[({error:a})=>(be(a)&&(a.request.headers.delete("authorization"),a.request.headers.delete("Authorization")),a)]}}),c;try{c=await i.post("v1/oauth/device/code",{json:{client_id:U,scope:Re}}).json()}catch(a){let k=a instanceof Error?a:new Error("Failed to request device code");throw r?.onError?.(k),k}let{device_code:S,user_code:d,expires_in:ae,interval:ce}=c,X=new URL("/oauth/device",t);X.searchParams.set("user_code",d);let V=X.toString();r?.onDeviceCodeReceived?.(d,V),r?.onBrowserOpening?.();try{await xe(V)}catch(a){process.env.DEBUG&&console.error("[DEBUG] Failed to open browser:",a)}r?.onWaitingForAuthorization?.();let Z=Math.max(ce,5)*1e3,le=Date.now()+ae*1e3;for(;Date.now()<le;){await Ae(Z);try{let a=await i.post("v1/oauth/token",{json:{grant_type:"urn:ietf:params:oauth:grant-type:device_code",device_code:S,client_id:U}}).json();r?.onAuthorized?.();let k={};try{k=Ee(a.access_token)}catch{}return{accessToken:a.access_token,refreshToken:a.refresh_token??void 0,email:k.email||"",scopes:a.scope.split(" ").filter(B=>B.length>0)}}catch(a){if(a instanceof Te){let{code:B,error:ge}=te(a.data),O=B||ge;if(!O)continue;switch(O){case"authorization_pending":continue;case"slow_down":Z+=5e3;continue;case"access_denied":throw new Error("Authorization denied by user",{cause:a});case"expired_token":throw new Error("Device code expired. Please try again.",{cause:a});default:throw new Error(`Authorization failed: ${O||"Unknown error"}`,{cause:a})}}let k=a instanceof Error?a:new Error("Unknown error during authorization");throw r?.onError?.(k),k}}throw new Error("Device code expired. Please try again.")}finally{n===void 0?delete process.env.NODE_TLS_REJECT_UNAUTHORIZED:process.env.NODE_TLS_REJECT_UNAUTHORIZED=n}}var y=class extends Error{code;constructor(e,t){super(t),this.code=e}};function _e(r){try{let e=r.split(".");if(e.length<2)return null;let t=e[1].replace(/-/g,"+").replace(/_/g,"/"),s=(4-t.length%4)%4,n=t.padEnd(t.length+s,"="),i=Buffer.from(n,"base64").toString("utf8");return JSON.parse(i)}catch{return null}}function Ie(r,e=300){let s=_e(r)?.exp;if(typeof s!="number")return!1;let n=Math.floor(Date.now()/1e3);return s-n<=e}async function se(r){let e=r.accessToken;if(!Ie(e))return e;if(!r.refreshToken)throw await h.clear(),new y("session-expired","Session expired. Please run `entrydesk login` again.");try{let s=await new _().refreshOAuthToken({refreshToken:r.refreshToken,clientId:U});return await h.saveAccessToken(s.access_token),s.refresh_token&&await h.saveRefreshToken(s.refresh_token),s.access_token}catch{throw await h.clear(),new y("session-expired","Session expired. Please run `entrydesk login` again.")}}async function ht(){let r=D();if(r)return r.accessToken;let e=await h.getAll();if(!e?.accessToken)throw new y("not-logged-in","Not logged in. Run `entrydesk login` first.");return se(e)}async function yt(){let r=D();if(r)return{accessToken:r.accessToken,workspaceId:r.workspaceId};let e=L();if(e)return e;let t=await h.getAll();if(!t?.accessToken)throw new y("not-logged-in","Not logged in. Run `entrydesk login` first.");if(!t.workspaceId)throw new y("no-workspace","No workspace selected. Run `entrydesk workspaces` first.");return{accessToken:await se(t),workspaceId:t.workspaceId}}var f=class extends Error{constructor(t,s=1,n){super(t);this.exitCode=s;this.cause=n;this.name="CLIError"}exitCode;cause};function wt(r){let e=!!process.env.DEBUG;r instanceof f&&(console.error(`Error: ${r.message}`),r.cause&&(console.error(`Cause: ${r.cause.message}`),e&&r.cause.stack&&console.error(r.cause.stack)),process.exit(r.exitCode)),r instanceof y&&(console.error(r.message),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof De&&(console.error("Request timed out. Please check your connection and try again."),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Ke&&(console.error(`Request failed (${r.response.status}): ${r.response.statusText}`),e&&r.stack&&console.error(r.stack),process.exit(1)),r instanceof Error&&(console.error(`Unexpected error: ${r.message}`),e&&r.stack&&console.error(r.stack),process.exit(1)),console.error("An unknown error occurred"),process.exit(1)}var P="default",$e=/^[A-Za-z0-9_-]+$/,W=null;function Y(){return T.join(Ue.homedir(),".entrydesk")}function ie(){return T.join(Y(),"profiles")}function oe(){return T.join(Y(),"profiles.json")}function $(r){return T.join(ie(),r)}function G(r){if(!p.existsSync(r))p.mkdirSync(r,{mode:448,recursive:!0});else try{p.chmodSync(r,448)}catch{}}function Fe(){G(Y())}function H(){G(ie())}function Be(){let r=oe();try{if(!p.existsSync(r))return null;let e=p.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}function C(r){Fe();let e=oe();p.writeFileSync(e,JSON.stringify(r,null,2),{mode:384});try{p.chmodSync(e,384)}catch{}}function Oe(r){let e=r.profiles?.length?Array.from(new Set(r.profiles)):[],t=r.currentProfile&&e.includes(r.currentProfile)?r.currentProfile:e[0]||P;return e.length===0&&e.push(P),e.includes(t)||e.unshift(t),{currentProfile:t,profiles:e}}function x(r){H(),G($(r))}function w(){let r=Be();if(!r){let t={currentProfile:P,profiles:[P]};return C(t),H(),x(P),t}let e=Oe(r);return(e.currentProfile!==r.currentProfile||e.profiles.length!==r.profiles.length)&&C(e),H(),e}function A(r){if(!r)throw new f("Profile name is required.");if(!$e.test(r))throw new f("Invalid profile name. Use letters, numbers, dash, or underscore.")}function R(r,e){if(!r.profiles.includes(e))throw new f(`Profile not found: ${e}`)}function ne(r,e){if(r.profiles.includes(e))throw new f(`Profile already exists: ${e}`)}var o={DEFAULT_PROFILE:P,setOverrideProfile(r){W=r},getOverrideProfile(){return W},getProfileDir(r){return $(r)},getProfileConfigFile(r){return T.join(o.getProfileDir(r),"config.json")},getProfileCredentialsFile(r){return T.join(o.getProfileDir(r),"credentials.json")},getProfileNames(){return[...w().profiles]},getProfileCount(){return o.getProfileNames().length},getCurrentProfileName(){return w().currentProfile},getEffectiveProfileName(r){let e=w(),t=r||W||e.currentProfile;return A(t),R(e,t),t},ensureProfileExists(r){let e=w();A(r),R(e,r)},createProfile(r){A(r);let e=w();ne(e,r);let t={currentProfile:e.currentProfile,profiles:[...e.profiles,r]};C(t),x(r)},deleteProfile(r){A(r);let e=w();if(R(e,r),e.profiles.length===1)throw new f("Cannot delete the last profile.");let t=e.profiles.filter(i=>i!==r),s=e.currentProfile;s===r&&(s=t.includes(P)?P:t[0]),C({currentProfile:s,profiles:t});try{p.rmSync(o.getProfileDir(r),{recursive:!0,force:!0})}catch{}return{currentProfile:s}},renameProfile(r,e){A(r),A(e);let t=w();R(t,r),ne(t,e);let s=$(r),n=$(e);if(p.existsSync(s))try{p.renameSync(s,n)}catch(d){throw new f("Failed to rename profile directory.",1,d)}else x(e);let i=t.profiles.map(d=>d===r?e:d),c=t.currentProfile===r?e:t.currentProfile;return C({currentProfile:c,profiles:i}),{currentProfile:c}},setCurrentProfile(r){A(r);let e=w();R(e,r);let t={currentProfile:r,profiles:e.profiles};C(t),x(r)},ensureProfileDir:x};function Ne(r){let e=o.getEffectiveProfileName(r);return o.getProfileConfigFile(e)}function g(r){let e=Ne(r);try{if(!F.existsSync(e))return{};let t=F.readFileSync(e,"utf-8");return JSON.parse(t)}catch{return{}}}function m(r,e){let t=o.getEffectiveProfileName(e);o.ensureProfileDir(t);let s=o.getProfileConfigFile(t);F.writeFileSync(s,JSON.stringify(r,null,2),{mode:384});try{F.chmodSync(s,384)}catch{}}var J={getApiUrl(r){return g(r).apiUrl??null},setApiUrl(r,e){let t=g(e);t.apiUrl=r,m(t,e)},clearApiUrl(r){let e=g(r);delete e.apiUrl,m(e,r)},getHubUrl(r){return g(r).hubUrl??null},setHubUrl(r,e){let t=g(e);t.hubUrl=r,m(t,e)},getAll(r){return g(r)},setAll(r,e){m(r,e)},set(r,e,t){let s=g(t);s[r]=e,m(s,t)},get(r,e){return g(e)[r]},unset(r,e){let t=g(e);delete t[r],m(t,e)},getDefaultModel(r){return g(r).model?.default??null},setDefaultModel(r,e){let t=g(e);t.model={...t.model,default:r},m(t,e)},getDefaultConnectorIds(r){return g(r).connectors?.defaults??null},setDefaultConnectorIds(r,e){let t=g(e);t.connectors={...t.connectors,defaults:r},m(t,e)},getLocalTools(r){return g(r).localTools??null},setLocalTools(r,e){let t=g(e);t.localTools={...t.localTools,...r},m(t,e)}};var Me="https://api.entrydesk.com",je="https://app.entrydesk.com",ze=3100,Le=300*1e3;function q(r){return{apiUrl:J.getApiUrl(r)||process.env.ENTRYDESK_API_URL||Me,hubUrl:J.getHubUrl(r)||process.env.ENTRYDESK_HUB_URL||je,mcp:{httpPort:ze},auth:{loginTimeout:Le,ignoreSslErrors:process.env.ENTRYDESK_IGNORE_SSL_ERRORS==="true"||!1}}}function I(r){return q(r).apiUrl}function re(r){return q(r).hubUrl}function K(){return q().auth}export{o as a,J as b,q as c,I as d,re as e,K as f,h as g,_ as h,et as i,te as j,U as k,lt as l,y as m,Ie as n,se as o,ht as p,yt as q,f as r,wt as s};
@@ -1,182 +0,0 @@
1
- #!/usr/bin/env node
2
- import{a as ie,b as de,c as Bt,g as rt,h as pe,m as Je,p as ln,q as We,s as an}from"./chunk-6A4DXLDW.js";import{render as cr}from"ink";import{v4 as Nt}from"uuid";import{exec as co}from"child_process";import uo from"fs";import Fe from"fs/promises";import cn from"os";import Ot from"path";import{promisify as fo}from"util";import{glob as po}from"glob";var mo=fo(co),go=`## Filesystem Tool Instructions
3
-
4
- You have access to filesystem tools that allow you to interact with the user's local filesystem.
5
-
6
- ### Available Operations
7
-
8
- - **Read File**: Read the contents of a file
9
- - **Read Multiple Files**: Read multiple files at once (max 10)
10
- - **Write File**: Create or overwrite a file
11
- - **Create Directory**: Create a new directory (including parent directories)
12
- - **List Directory**: List files and subdirectories
13
- - **Search Files**: Search for files matching a glob pattern
14
- - **Get File Info**: Get metadata about a file or directory
15
- - **Move File**: Move or rename a file or directory
16
- - **Execute Command**: Run shell commands on the user's machine
17
-
18
- ### Important Notes
19
-
20
- - Always use absolute paths when possible
21
- - Be mindful of file permissions and access restrictions
22
- - Large files will be truncated in responses
23
- - Search results are limited to prevent overwhelming responses
24
- - Execute Command has a default timeout of 30 seconds (max 5 minutes)
25
- - The current working directory is: ${process.cwd()}
26
- - The user's home directory is: ${cn.homedir()}
27
- `,ho=[{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 un(){return{name:"filesystem",systemPrompt:go,tools:ho}}function Ae(e){return e.startsWith("~/")?Ot.join(cn.homedir(),e.slice(2)):e}function yt(e,t=1e5){return e.length<=t?e:e.slice(0,t)+`
28
-
29
- ... (truncated, ${e.length-t} more characters)`}async function dn(e,t){try{switch(e){case"filesystem__read_file":{let n=Ae(t.path),r=await Fe.readFile(n,"utf-8");return{success:!0,result:yt(r)}}case"filesystem__read_multiple_files":{let n=t.paths.slice(0,10),r={};for(let a of n){let c=Ae(a);try{let p=await Fe.readFile(c,"utf-8");r[a]=yt(p,5e4)}catch(p){r[a]={error:p instanceof Error?p.message:String(p)}}}return{success:!0,result:r}}case"filesystem__write_file":{let n=Ae(t.path),r=t.content;return await Fe.mkdir(Ot.dirname(n),{recursive:!0}),await Fe.writeFile(n,r,"utf-8"),{success:!0,result:{written:n}}}case"filesystem__create_directory":{let n=Ae(t.path);return await Fe.mkdir(n,{recursive:!0}),{success:!0,result:{created:n}}}case"filesystem__list_directory":{let n=Ae(t.path);return{success:!0,result:(await Fe.readdir(n,{withFileTypes:!0})).map(c=>({name:c.name,type:c.isDirectory()?"directory":c.isFile()?"file":c.isSymbolicLink()?"symlink":"other"}))}}case"filesystem__search_files":{let n=t.pattern,r=t.cwd?Ae(t.cwd):process.cwd(),a=await po(n,{cwd:r,nodir:!0,maxDepth:10});return{success:!0,result:{files:a.slice(0,100),total:a.length,truncated:a.length>100}}}case"filesystem__get_file_info":{let n=Ae(t.path),r=await Fe.stat(n);return{success:!0,result:{path:n,type:r.isDirectory()?"directory":r.isFile()?"file":"other",size:r.size,created:r.birthtime.toISOString(),modified:r.mtime.toISOString(),accessed:r.atime.toISOString(),mode:r.mode.toString(8)}}}case"filesystem__move_file":{let n=Ae(t.source),r=Ae(t.destination);return await Fe.mkdir(Ot.dirname(r),{recursive:!0}),await Fe.rename(n,r),{success:!0,result:{moved:{from:n,to:r}}}}case"filesystem__execute_command":{let n=t.command,r=t.cwd?Ae(t.cwd):process.cwd(),a=Math.min(t.timeout||3e4,3e5);if(!uo.existsSync(r))return{success:!1,error:`Working directory does not exist: ${r}`};let{stdout:c,stderr:p}=await mo(n,{cwd:r,timeout:a,maxBuffer:10*1024*1024});return{success:!0,result:{stdout:yt(c,5e4),stderr:yt(p,5e4)}}}default:return{success:!1,error:`Unknown tool: ${e}`}}}catch(n){return{success:!1,error:n instanceof Error?n.message:String(n)}}}function Ut(e){return e.startsWith("filesystem__")}function fn(){return[un()]}function xt(){return fn().flatMap(e=>e.tools)}function wt(){return fn().map(e=>e.systemPrompt).filter(Boolean).join(`
30
-
31
- `)}function Be(e){return Ut(e)}async function Tt(e,t){return Ut(e)?dn(e,t):{success:!1,error:`Unknown client tool: ${e}`}}import{Box as he,Text as B,useInput as tn}from"ink";import nn from"ink-spinner";import{useCallback as on,useEffect as Et,useRef as no,useState as tr}from"react";import{Box as kt,Text as st}from"ink";import{jsx as Ct,jsxs as it}from"react/jsx-runtime";function pn(e,t){return e.length<=t?e:t<=3?".".repeat(t):e.slice(0,t-3)+"..."}function mn({items:e,activeIndex:t,selectedIds:n,multiSelect:r=!1,visible:a,title:c,pageSize:p=10}){if(!a||e.length===0)return null;let h=process.stdout.columns??80,y=r?4:0,g=Math.max(20,h-2-2-y),O=Math.max(1,p),$=Math.floor(t/O)*O,v=Math.min(e.length,$+O),Y=e.slice($,v);return it(kt,{flexDirection:"column",marginBottom:1,children:[Ct(st,{bold:!0,color:"cyan",children:c}),Ct(kt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:Y.map((T,b)=>{let A=$+b===t,W=n?.has(T.id),Z=pn(T.name,g),j=T.description?pn(T.description,Math.max(0,g-y)):"",K=r?" ".repeat(y):"";return it(kt,{paddingX:1,flexDirection:"column",children:[it(kt,{children:[r&&Ct(st,{color:W?"green":"gray",children:W?"[\u2713] ":"[ ] "}),Ct(st,{backgroundColor:A?"cyan":void 0,color:A?"black":W?"green":"white",bold:!0,children:Z})]}),j&&it(st,{dimColor:!0,children:[K,"\xB7 ",j]})]},T.id)})}),it(st,{dimColor:!0,children:[r?"\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>O?` \xB7 Showing ${$+1}-${v} of ${e.length}`:""]})]})}import{Box as jt,Text as lt}from"ink";import{jsx as at,jsxs as Wt}from"react/jsx-runtime";function gn({suggestions:e,activeIndex:t,visible:n}){return!n||e.length===0?null:Wt(jt,{flexDirection:"column",marginBottom:1,children:[at(jt,{borderStyle:"single",borderColor:"gray",flexDirection:"column",children:e.map((r,a)=>{let c=a===t,p=r.aliases.length>0?` (${r.aliases.join(", ")})`:"";return Wt(jt,{paddingX:1,children:[Wt(lt,{backgroundColor:c?"cyan":void 0,color:c?"black":"cyan",bold:c,children:["/",r.name]}),at(lt,{dimColor:!0,children:p}),at(lt,{children:" - "}),at(lt,{color:c?"white":"gray",children:r.description})]},r.name)})}),at(lt,{dimColor:!0,children:"\u2191\u2193 Navigate \xB7 Tab/Enter Select \xB7 Esc Cancel"})]})}import{Box as yo,Text as hn,useInput as xo,useStdout as wo}from"ink";import{useCallback as yn,useEffect as xn,useMemo as Mt,useRef as wn,useState as Tn}from"react";import{jsx as Ht}from"react/jsx-runtime";function bt(e,t){return e<0?0:e>t?t:e}function Gt(e){return Array.from(e)}function $t(e){return/\s/.test(e)}function qt(e,t){let n=t;for(;n>0&&$t(e[n-1]??"");)n-=1;for(;n>0&&!$t(e[n-1]??"");)n-=1;return n}function kn(e,t){let n=t;for(;n<e.length&&$t(e[n]??"");)n+=1;for(;n<e.length&&!$t(e[n]??"");)n+=1;return n}function To(e){let t=[],n=[],r=[],a=0;n.push(0),e.forEach((p,h)=>{if(p===`
32
- `){t.push(r),r=[],a=h+1,n.push(a);return}r.push(p)}),t.push(r);let c=t.map(p=>p.length);return{lines:t,lineStarts:n,lineLengths:c}}function Cn(e,t,n){for(let a=0;a<t.length;a+=1){let c=t[a]??0,p=n[a]??0,h=c+p;if(e<=h)return{row:a,col:e-c}}let r=Math.max(0,t.length-1);return{row:r,col:n[r]??0}}var ko=2;function bn({value:e,onChange:t,onSubmit:n,onPaste:r,focus:a=!0,leadingOffset:c=0,multiline:p=!1}){let[h,y]=Tn(()=>Gt(e).length),g=wn(null),[O,$]=Tn(0),v=wn(null),{stdout:Y}=wo(),T=Mt(()=>Gt(e),[e]),{lines:b,lineStarts:E,lineLengths:A}=Mt(()=>To(T),[T]),{row:W,col:Z}=Mt(()=>Cn(h,E,A),[h,E,A]),j=Math.max(1,(Y?.columns??80)-c);xn(()=>{g.current!==e?(y(T.length),v.current=null):y(l=>bt(l,T.length)),g.current=e},[e,T.length]),xn(()=>{$(l=>{let d=l;Z<d?d=Z:Z>=d+j&&(d=Z-j+1);let P=A[W]??0,U=Z===P?P+1:P,C=Math.max(0,U-j);return d>C&&(d=C),d<0&&(d=0),d})},[j,Z,W,A]);let K=yn((l,d)=>{g.current=l,t(l),y(d),v.current=null},[t]),le=yn(async(l,d)=>{if(!a)return;let{row:P,col:U}=Cn(h,E,A),C=b[P]??[],fe=A[P]??0,te=b.length>1;if(p&&(d.meta&&d.return||d.ctrl&&l==="j"||d.shift&&d.return)){let w=[...T.slice(0,h),`
33
- `,...T.slice(h)].join("");K(w,h+1);return}if(d.return){n(e);return}if(d.leftArrow){d.ctrl||d.meta?(U===0&&P>0?y(E[P]-1):y(E[P]+qt(C,U)),v.current=null):(U===0&&P>0?y(E[P]-1):y(w=>bt(w-1,T.length)),v.current=null);return}if(d.rightArrow){d.ctrl||d.meta?(U>=fe&&P<b.length-1?y(E[P+1]):y(E[P]+kn(C,U)),v.current=null):(U>=fe&&P<b.length-1?y(E[P+1]):y(w=>bt(w+1,T.length)),v.current=null);return}if(p&&te&&d.upArrow){let w=v.current??U,L=Math.max(0,P-1),D=Math.min(w,A[L]??0);y((E[L]??0)+D),v.current=w;return}if(p&&te&&d.downArrow){let w=v.current??U,L=Math.min(b.length-1,P+1),D=Math.min(w,A[L]??0);y((E[L]??0)+D),v.current=w;return}if(d.ctrl){if(l==="a"){y(E[P]??0),v.current=null;return}if(l==="e"){y((E[P]??0)+fe),v.current=null;return}if(l==="u"){if(U>0){let w=E[P]??0,L=[...T.slice(0,w),...T.slice(h)].join("");K(L,w)}return}if(l==="k"){if(U<fe){let w=(E[P]??0)+fe,L=[...T.slice(0,h),...T.slice(w)].join("");K(L,h)}return}if(l==="w"){if(U===0&&P>0){let L=[...T.slice(0,h-1),...T.slice(h)].join("");K(L,h-1);return}let w=qt(C,U);if(w!==U){let L=(E[P]??0)+w,D=[...T.slice(0,L),...T.slice(h)].join("");K(D,L)}return}if(l==="d"){if(h<T.length){let w=[...T.slice(0,h),...T.slice(h+1)].join("");K(w,h)}return}return}if(d.meta){l==="b"?(U===0&&P>0?y(E[P]-1):y(E[P]+qt(C,U)),v.current=null):l==="f"&&(U>=fe&&P<b.length-1?y(E[P+1]):y(E[P]+kn(C,U)),v.current=null);return}if(d.backspace||d.delete){if(h<=0)return;let w=[...T.slice(0,h-1),...T.slice(h)].join("");K(w,h-1);return}if(!(d.tab||d.escape)&&l.length>0){let w=p?l.replace(/\r\n/g,`
34
- `).replace(/\r/g,`
35
- `):l.replace(/\r?\n/g,"");if(!w||(w=w.replace(/^\x1b?\[200~/,"").replace(/\x1b?\[201~$/,""),!w))return;if((w.length>=ko||w.includes(`
36
- `))&&r){let Q=!1,ee={text:w,preventDefault:()=>{Q=!0}};if(await Promise.resolve(r(ee)),Q)return}let D=Gt(w),M=[...T.slice(0,h),...D,...T.slice(h)].join("");K(M,h+D.length)}},[T,h,a,A,E,b,p,r,n,K,e]);return xo(le,{isActive:a}),Ht(yo,{flexDirection:"column",children:b.map((l,d)=>{let P=d===W,C=(P&&Z===l.length?[...l," "]:l).slice(O,O+j),fe=C.join("");if(!P)return Ht(hn,{children:fe||" "},d);let te=bt(Z-O,Math.max(0,C.length-1)),w=C.slice(0,te).join(""),L=C[te]??" ",D=C.slice(te+1).join(""),ee=`${w}\x1B[7m${L}\x1B[27m${D}`;return Ht(hn,{children:ee},d)})})}import{Box as De,Text as Me}from"ink";import Vt from"react";import{Text as $e}from"ink";import Co from"react";import{Fragment as Io,jsx as Pe,jsxs as vn}from"react/jsx-runtime";var Jt=2,Yt=1,Kt=2,bo=1,$n=3,In=4,$o=({text:e,defaultColor:t,linkColor:n,codeColor:r})=>{let a=t;if(!/[*_~`<[https?:]/.test(e))return Pe($e,{color:a,children:e});let c=[],p=0,h=/(\*\*.*?\*\*|\*.*?\*|_.*?_|~~.*?~~|\[.*?\]\(.*?\)|`+.+?`+|<u>.*?<\/u>|https?:\/\/\S+)/g,y;for(;(y=h.exec(e))!==null;){y.index>p&&c.push(Pe($e,{color:a,children:e.slice(p,y.index)},`t-${p}`));let g=y[0],O=null,$=`m-${y.index}`;try{if(g.startsWith("**")&&g.endsWith("**")&&g.length>Jt*2)O=Pe($e,{bold:!0,color:a,children:g.slice(Jt,-Jt)},$);else if(g.length>Yt*2&&(g.startsWith("*")&&g.endsWith("*")||g.startsWith("_")&&g.endsWith("_"))&&!/\w/.test(e.substring(y.index-1,y.index))&&!/\w/.test(e.substring(h.lastIndex,h.lastIndex+1))&&!/\S[./\\]/.test(e.substring(y.index-2,y.index))&&!/[./\\]\S/.test(e.substring(h.lastIndex,h.lastIndex+2)))O=Pe($e,{italic:!0,color:a,children:g.slice(Yt,-Yt)},$);else if(g.startsWith("~~")&&g.endsWith("~~")&&g.length>Kt*2)O=Pe($e,{strikethrough:!0,color:a,children:g.slice(Kt,-Kt)},$);else if(g.startsWith("`")&&g.endsWith("`")&&g.length>bo){let v=g.match(/^(`+)(.+?)\1$/s);v&&v[2]&&(O=Pe($e,{color:r,children:v[2]},$))}else if(g.startsWith("[")&&g.includes("](")&&g.endsWith(")")){let v=g.match(/\[(.*?)\]\((.*?)\)/);if(v){let Y=v[1],T=v[2];O=vn($e,{color:a,children:[Y,vn($e,{color:n,children:[" (",T,")"]})]},$)}}else g.startsWith("<u>")&&g.endsWith("</u>")&&g.length>$n+In-1?O=Pe($e,{underline:!0,color:a,children:g.slice($n,-In)},$):g.match(/^https?:\/\//)&&(O=Pe($e,{color:n,children:g},$))}catch{O=null}c.push(O??Pe($e,{color:a,children:g},$)),p=h.lastIndex}return p<e.length&&c.push(Pe($e,{color:a,children:e.slice(p)},`t-${p}`)),Pe(Io,{children:c.filter(g=>g!==null)})},ct=Co.memo($o);import{Fragment as Ao,jsx as ae,jsxs as En}from"react/jsx-runtime";var vo=1,_n=1,So=1,Po=1,_o=({content:e})=>{let t=e.join(`
37
- `);return ae(De,{paddingLeft:_n,flexDirection:"column",children:ae(Me,{color:"yellow",children:t})})},Sn=Vt.memo(_o),Eo=({itemText:e,type:t,marker:n,leadingWhitespace:r=""})=>{let a=t==="ol"?`${n}. `:`${n} `,c=a.length,p=r.length;return En(De,{paddingLeft:p+So,flexDirection:"row",children:[ae(De,{width:c,children:ae(Me,{children:a})}),ae(De,{flexGrow:Po,children:ae(Me,{wrap:"wrap",children:ae(ct,{text:e,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})})]})},Pn=Vt.memo(Eo),No=({text:e,renderMarkdown:t=!0})=>{if(!e)return null;if(!t)return ae(De,{paddingLeft:_n,flexDirection:"column",children:ae(Me,{wrap:"wrap",children:e})});let n=e.split(/\r?\n/),r=/^ *(#{1,4}) +(.*)/,a=/^ *(`{3,}|~{3,}) *(\w*?) *$/,c=/^([ \t]*)([-*+]) +(.*)/,p=/^([ \t]*)(\d+)\. +(.*)/,h=/^ *([-*_] *){3,} *$/,y=/^ *> ?(.*)/,g=[],O=!1,$=!0,v=[],Y="";function T(b){b&&(g.push(b),$=!1)}return n.forEach((b,E)=>{let A=`line-${E}`;if(O){let d=b.match(a);d&&d[1].startsWith(Y[0])&&d[1].length>=Y.length?(T(ae(Sn,{content:v},A)),O=!1,v=[],Y=""):v.push(b);return}let W=b.match(a),Z=b.match(r),j=b.match(c),K=b.match(p),le=b.match(h),l=b.match(y);if(W)O=!0,Y=W[1];else if(le)T(ae(De,{children:ae(Me,{dimColor:!0,children:"---"})},A));else if(Z){let d=Z[1].length,P=Z[2],U=d<=2?"cyan":"blue";T(ae(De,{children:ae(Me,{color:U,...(d===4?"italic":"bold")==="italic"?{italic:!0}:{bold:!0},children:ae(ct,{text:P,defaultColor:U,linkColor:"cyan",codeColor:"yellow"})})},A))}else if(l){let d=l[1];T(ae(De,{paddingLeft:1,children:En(Me,{dimColor:!0,children:["> ",ae(ct,{text:d,defaultColor:"gray",linkColor:"cyan",codeColor:"yellow"})]})},A))}else if(j){let d=j[1],P=j[2],U=j[3];T(ae(Pn,{itemText:U,type:"ul",marker:P,leadingWhitespace:d},A))}else if(K){let d=K[1],P=K[2],U=K[3];T(ae(Pn,{itemText:U,type:"ol",marker:P,leadingWhitespace:d},A))}else b.trim().length===0?$||(g.push(ae(De,{height:vo},`spacer-${E}`)),$=!0):T(ae(De,{children:ae(Me,{wrap:"wrap",children:ae(ct,{text:b,defaultColor:void 0,linkColor:"cyan",codeColor:"yellow"})})},A))}),O&&T(ae(Sn,{content:v},"line-eof")),ae(Ao,{children:g})},zt=Vt.memo(No);import{execFile as Do}from"child_process";import Ro from"fs";import Qe from"fs/promises";import Nn from"os";import vt from"path";import{promisify as Lo}from"util";var It=Lo(Do);async function Fo(){let e=vt.join(Nn.tmpdir(),`entrydesk-clipboard-${Date.now()}.png`);try{let t=`
38
- set imageData to the clipboard as "PNGf"
39
- set fileRef to open for access POSIX file "${e}" with write permission
40
- set eof fileRef to 0
41
- write imageData to fileRef
42
- close access fileRef
43
- `;return await It("osascript",["-e",t]),(await Qe.stat(e)).size===0?void 0:{buffer:await Qe.readFile(e),mime:"image/png"}}catch{return}finally{try{Ro.existsSync(e)&&await Qe.unlink(e)}catch{}}}async function Bo(){try{let e=`
44
- Add-Type -AssemblyName System.Windows.Forms
45
- $img = [System.Windows.Forms.Clipboard]::GetImage()
46
- if ($img) {
47
- $ms = New-Object System.IO.MemoryStream
48
- $img.Save($ms, [System.Drawing.Imaging.ImageFormat]::Png)
49
- [System.Convert]::ToBase64String($ms.ToArray())
50
- }
51
- `,{stdout:t}=await It("powershell.exe",["-command",e]),n=t.trim();if(!n)return;let r=Buffer.from(n,"base64");return r.length===0?void 0:{buffer:r,mime:"image/png"}}catch{return}}async function Oo(){try{let{stdout:e}=await It("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 It("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 An(){let e=Nn.platform();if(e==="darwin")return Fo();if(e==="win32")return Bo();if(e==="linux")return Oo()}var Uo=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 Dn(e){let t=vt.extname(e).toLowerCase();return Uo.has(t)}function jo(e){let t=vt.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 St(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 Rn(e){let t=St(e);if(/^https?:\/\//.test(t))return!1;try{return await Qe.access(t),!0}catch{return!1}}async function Ln(e){let t=St(e);try{if(!(await Qe.stat(t)).isFile())return;let r=await Qe.readFile(t),a=jo(t),c=vt.basename(t);return{buffer:r,mimeType:a,filename:c}}catch{return}}var Ie="\x1B[2m",X="\x1B[0m",ge="\x1B[36m",Ze="\x1B[32m",Fn="\x1B[31m",Ye="\x1B[38;2;59;91;204m",Xt="\x1B[38;2;126;200;248m",Qt="\x1B[38;2;244;196;78m";import{useState as Oe}from"react";import{v4 as Bn}from"uuid";function On(e,t){let[n,r]=Oe({status:"loading"}),[a,c]=Oe([]),[p,h]=Oe(""),[y,g]=Oe(()=>e||Bn()),[O,$]=Oe(t),[v,Y]=Oe(!!e),[T,b]=Oe(null),[E,A]=Oe(""),[W,Z]=Oe(!1),j=le=>{c(l=>[...l,{role:"system",content:le}])};return{state:n,setState:r,messages:a,setMessages:c,input:p,setInput:h,taskId:y,setTaskId:g,currentTaskTitle:O,setCurrentTaskTitle:$,hasPersistedTask:v,setHasPersistedTask:Y,credentials:T,setCredentials:b,currentResponse:E,setCurrentResponse:A,fullOutput:W,setFullOutput:Z,addSystemMessage:j,startNewTask:le=>{let l=Bn();g(l),$(void 0),Y(!1),c([]),le&&j(le)}}}import{useEffect as Wo,useState as Un}from"react";function jn(e){let[t,n]=Un(null),[r,a]=Un(!0);return Wo(()=>{let c=!1;async function p(){try{let h=await We();if(c)return;n({accessToken:h.accessToken,workspaceId:h.workspaceId}),a(!1)}catch(h){if(c)return;if(h instanceof Je){if(h.code==="not-logged-in"){e({status:"not-logged-in"}),a(!1);return}if(h.code==="no-workspace"){e({status:"no-workspace"}),a(!1);return}}let y=h instanceof Error?h.message:"Failed to authenticate";e({status:"error",message:y}),a(!1)}}return p(),()=>{c=!0}},[e]),{credentials:t,loading:r}}import{useEffect as Mo,useState as ut}from"react";function Wn(e){let[t,n]=ut([]),[r,a]=ut([]),[c,p]=ut([]),[h,y]=ut([]),[g,O]=ut(!1);return Mo(()=>{if(!e)return;let $=!1;O(!0);async function v(){if(e)try{let Y=new pe,[T,b,E,A]=await Promise.all([Y.getConnectors(e.accessToken,e.workspaceId),Y.getModels(e.accessToken,e.workspaceId),Y.getAgents(e.accessToken,e.workspaceId),Y.getModelProviders(e.accessToken,e.workspaceId)]);if($)return;n(T.connectors),a(b.models),p(E.agents),y(A.providers??[])}catch{}finally{$||O(!1)}}return v(),()=>{$=!0}},[e]),{availableConnectors:t,availableModels:r,availableAgents:c,modelProviders:h,loading:g}}import et from"fs";import Gn from"path";import{useCallback as Go}from"react";import{v4 as qo}from"uuid";function Mn(e,t){if(!e)return"(no result)";if(typeof e!="object"){let a=String(e);return t||a.length<=200?a:a.slice(0,200)+"..."}let n=e;if("structuredContent"in n&&n.structuredContent){let a=n.structuredContent;if(a.stdout&&typeof a.stdout=="string"){let c=a.stdout.trim();return t||c.length<=200?c:c.slice(0,200)+"..."}}if("content"in n&&Array.isArray(n.content)){let a=n.content.filter(c=>c.type==="text"&&c.text).map(c=>c.text).join(`
52
- `);return a?t||a.length<=200?a:a.slice(0,200)+"...":"(result)"}let r=JSON.stringify(e,null,t?2:void 0);return t||r.length<=200?r:r.slice(0,200)+"..."}function Ke(e,t=!1){let n=[];for(let r of e)if(r.type==="text"&&r.text)n.push(r.text);else if(r.type==="reasoning"&&r.text)t?n.push(`${Ie}[Thinking]
53
- ${r.text}${X}`):n.push(`${Ie}[Thinking...]${X}`);else if(r.type==="tool-call"&&r.toolName){let a=[];if(a.push(`${ge}\u250C\u2500 Tool: ${r.toolName}${X}`),r.args){let c=JSON.stringify(r.args,null,t?2:void 0),p=t||c.length<=100?c:c.slice(0,100)+"...";a.push(`${Ie}\u2502 Args: ${p}${X}`)}r.result!==void 0?(a.push(`${Ze}\u2502 Result: ${Mn(r.result,t)}${X}`),a.push(`${ge}\u2514\u2500 completed${X}`)):a.push(`${ge}\u2514\u2500${X}`),n.push(a.join(`
54
- `))}else if(r.type.startsWith("tool-")&&r.type!=="tool-call"){let a=r.title||r.type.slice(5).replace(/__/g," "),c=[];if(c.push(`${ge}\u250C\u2500 Tool: ${a}${X}`),r.input){let p=JSON.stringify(r.input,null,t?2:void 0),h=t||p.length<=100?p:p.slice(0,100)+"...";c.push(`${Ie}\u2502 Input: ${h}${X}`)}r.output!==void 0&&r.state==="output-available"?(c.push(`${Ze}\u2502 Output: ${Mn(r.output,t)}${X}`),c.push(`${ge}\u2514\u2500 completed${X}`)):r.state==="error"?c.push(`${ge}\u2514\u2500 failed${X}`):c.push(`${ge}\u2514\u2500${X}`),n.push(c.join(`
55
- `))}return n.join(`
56
-
57
- `).trim()}var Pt=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 r=n.toolName.replace(/__/g," "),a=`
58
-
59
- ${ge}\u250C\u2500 Tool: ${r}${X}`;if(n.args){let c=n.args.length>100?n.args.slice(0,100)+"...":n.args;a+=`
60
- ${Ie}\u2502 Input: ${c}${X}`}if(n.output){let c=n.output.length>150?n.output.slice(0,150)+"...":n.output;a+=`
61
- ${Ze}\u2502 Output: ${c}${X}`}else if(n.status==="executing"){let c=n.startedAt??Date.now(),p=Math.floor((Date.now()-c)/1e3);a+=`
62
- ${ge}\u2502${X} (executing... ${p}s)`}else n.status==="preparing"&&(a+=`
63
- ${ge}\u2502${X} (preparing...)`);t.push(a)}return t.join("")}flushPending(t){if(this.pendingToolCalls.size===0)return t;for(let[n,r]of this.pendingToolCalls){let a=r.toolName.replace(/__/g," "),c=typeof r.args=="string"&&r.args.length>100?r.args.slice(0,100)+"...":r.args||"";t+=`
64
-
65
- ${ge}\u250C\u2500 Tool: ${a}${X}`,c&&(t+=`
66
- ${Ie}\u2502 Input: ${c}${X}`),t+=`
67
- ${ge}\u2514\u2500 completed${X}
68
- `,this.pendingToolCalls.delete(n)}return t}handleToolInputStart(t){return t.toolCallId&&t.toolName?(this.pendingToolCalls.set(t.toolCallId,{toolName:t.toolName,args:"",status:"preparing"}),this.buildToolDisplay()):null}handleToolInputDelta(t){if(t.toolCallId&&t.inputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.args=(n.args||"")+t.inputTextDelta,n.status="executing",n.startedAt??=Date.now(),this.buildToolDisplay()}return null}handleToolOutputStart(t){if(t.toolCallId){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output="",n.status="output",this.buildToolDisplay()}return null}handleToolOutputDelta(t){if(t.toolCallId&&t.outputTextDelta){let n=this.pendingToolCalls.get(t.toolCallId);if(n)return n.output=(n.output||"")+t.outputTextDelta,this.buildToolDisplay()}return null}handleToolOutputEnd(t,n){if(!t.toolCallId)return null;let r=this.pendingToolCalls.get(t.toolCallId);if(!r)return null;let a=r.toolName.replace(/__/g," "),c=typeof r.args=="string"&&r.args.length>100?r.args.slice(0,100)+"...":r.args||"",p=(r.output||"").length>200?(r.output||"").slice(0,200)+"...":r.output||"";return n+=`
69
-
70
- ${ge}\u250C\u2500 Tool: ${a}${X}`,c&&(n+=`
71
- ${Ie}\u2502 Input: ${c}${X}`),n+=`
72
- ${Ze}\u2502 Output: ${p}${X}`,n+=`
73
- ${ge}\u2514\u2500 completed${X}
74
- `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}handleToolError(t,n){if(!t.toolCallId)return null;let a=(this.pendingToolCalls.get(t.toolCallId)?.toolName||t.toolName||"Tool").replace(/__/g," "),c=t.errorText||"Unknown error",p=c.length>200?c.slice(0,200)+"...":c;return n+=`
75
-
76
- ${ge}\u250C\u2500 Tool: ${a}${X}`,n+=`
77
- ${Fn}\u2502 Error: ${p}${X}`,n+=`
78
- ${ge}\u2514\u2500 failed${X}
79
- `,this.pendingToolCalls.delete(t.toolCallId),{fullResponse:n,toolDisplay:this.buildToolDisplay()}}};var dt=Gn.join(process.env.HOME||"/tmp",".entrydesk","stream-debug.log");function ne(e,t){if(!process.env.DEBUG)return;let r=`[${new Date().toISOString()}] ${e}`;t!==void 0&&(r+=`
80
- DATA: ${JSON.stringify(t,null,2)}`),r+=`
81
- `;try{et.appendFileSync(dt,r)}catch{}}function Ho(){try{if(et.existsSync(dt)&&et.unlinkSync(dt),process.env.DEBUG){let e=Gn.dirname(dt);et.existsSync(e)||et.mkdirSync(e,{recursive:!0}),et.writeFileSync(dt,`=== Debug session started at ${new Date().toISOString()} ===
82
- `)}}catch{}}function _t(e){if(!e)return{};if(typeof e=="string")try{return JSON.parse(e)}catch{return{}}return typeof e=="object"?e:{}}function qn({taskId:e,credentials:t,currentAgentId:n,currentModel:r,activeConnectorIds:a,localTools:c,fullOutput:p,setMessages:h,setState:y,setCurrentResponse:g,setCredentials:O,setHasPersistedTask:$,getFileIds:v,clearFiles:Y}){let T=c?xt():void 0,b=c?wt():void 0;return{sendMessage:Go(async(A,W,Z)=>{Ho(),ne("=== sendMessage called ===",{text:A,localTools:c,clientToolsCount:T?.length});let j=W||t?.accessToken,K=Z||t?.workspaceId;if(!j||!K)try{let d=await We();j=d.accessToken,K=d.workspaceId,O(d)}catch(d){if(d instanceof Je){if(d.code==="not-logged-in"){y({status:"not-logged-in"});return}if(d.code==="no-workspace"){y({status:"no-workspace"});return}}let P=d instanceof Error?d.message:"Authentication failed";y({status:"error",message:P});return}else try{let d=await ln();d!==j&&(j=d,O({accessToken:d,workspaceId:K}))}catch(d){if(d instanceof Je&&d.code==="not-logged-in"){y({status:"not-logged-in"});return}let P=d instanceof Error?d.message:"Authentication failed";y({status:"error",message:P});return}h(d=>[...d,{role:"user",content:A}]),y({status:"sending"}),g("");let le=null,l=null;try{let d=new pe,P=v?.()??[],U={id:e,message:{id:qo(),createdAt:new Date,role:"user",parts:[{type:"text",text:A}]}};P.length>0&&(U.fileIds=P),n?U.agentId=n:(r&&(U.model=r),U.connectorIds=a??[]),T&&(U.clientTools=T),b&&(U.clientToolSystemPrompt=b);let C=await d.task(j,K,U);if(!C.ok){let S=await C.text();throw new Error(`API error ${C.status}: ${S}`)}if(!C.body)throw new Error("No response body from server");le=C.body.getReader();let fe=new TextDecoder,te="",w="",L="",D="",M="",Q="",ee="",R=new Pt,H=[],V=[],oe=[],F=()=>{let S=R.hasExecuting();S&&!l?l=setInterval(()=>{if(!R.hasExecuting()){l&&(clearInterval(l),l=null);return}g(w+R.buildToolDisplay())},1e3):!S&&l&&(clearInterval(l),l=null)};for(;;){let{done:S,value:N}=await le.read();if(S)break;te+=fe.decode(N,{stream:!0});let I=te.split(`
83
- `);te=I.pop()||"";for(let u of I)if(u.trim()!=="data: [DONE]"&&u.startsWith("data: "))try{let m=JSON.parse(u.slice(6));switch(ne(`SSE event received: ${m.type}`,m),m.type){case"reasoning-start":D=m.id||"0",L="";break;case"reasoning-delta":m.delta&&(L+=m.delta,g(`${Ie}[Thinking...]${X}
84
- ${L}`)),m.providerMetadata?.anthropic?.signature&&(M=m.providerMetadata.anthropic.signature);break;case"reasoning-end":if(L){let _={type:"reasoning",id:D,text:L,state:"done"};M&&(_.providerMetadata={anthropic:{signature:M}}),V.push(_),ne("Added reasoning to messageParts",{reasoningLength:L.length,hasSignature:!!M,messagePartsCount:V.length})}L="",M="",g("");break;case"text-delta":m.delta&&(R.hasPending()&&(w=R.flushPending(w)),w+=m.delta,Q+=m.delta,g(w));break;case"tool-input-start":{let _=R.handleToolInputStart(m);_&&g(w+_),F();break}case"tool-input-delta":{let _=R.handleToolInputDelta(m);_&&g(w+_),F();break}case"tool-call":case"tool-input-available":{if(ne(`=== Tool event: ${m.type} ===`,{toolCallId:m.toolCallId,toolName:m.toolName,localTools:c,isClientToolResult:m.toolName?Be(m.toolName):"no toolName",args:m.args,input:m.input}),m.toolCallId&&m.toolName){let _=_t(m.args??m.input);V.push({type:m.type,toolCallId:m.toolCallId,toolName:m.toolName,args:_}),ne("Added tool to messageParts",{messagePartsCount:V.length})}if(c&&m.toolCallId&&m.toolName&&Be(m.toolName)){let _=_t(m.args??m.input);H.push({toolCallId:m.toolCallId,toolName:m.toolName,args:_}),ne("Added to pendingClientTools",{pendingCount:H.length,pendingClientTools:H}),g(w+R.buildToolDisplay()+`
85
- [Executing ${m.toolName} locally...]`)}else ne("NOT added to pendingClientTools - conditions not met",{localTools:c,hasToolCallId:!!m.toolCallId,hasToolName:!!m.toolName,isClientTool:m.toolName?Be(m.toolName):!1});break}case"tool-output-start":{let _=R.handleToolOutputStart(m);_&&g(w+_),F();break}case"tool-output-delta":{let _=R.handleToolOutputDelta(m);_&&g(w+_),F();break}case"tool-output-end":{let _=R.handleToolOutputEnd(m,w);_&&(w=_.fullResponse,g(w+_.toolDisplay)),F();break}case"tool-input-error":case"tool-output-error":{let _=R.handleToolError(m,w);_&&(w=_.fullResponse,g(w+_.toolDisplay)),F();break}case"start":m.messageId&&(ee=m.messageId,ne("Captured messageId from start event",{messageId:ee}));break;case"start-step":case"text-start":case"text-end":case"finish-step":case"message-metadata":case"finish":break;case"error":m.errorText&&console.error("Stream error:",m.errorText);break}}catch{}}if(Q){let S=V.findIndex(I=>I.type!=="reasoning"),N=S===-1?V.length:S;V.splice(N,0,{type:"text",text:Q}),ne("Added accumulated text to messageParts",{textLength:Q.length,insertIndex:N})}for(ne("=== Initial stream ended ===",{pendingClientToolsCount:H.length,pendingClientTools:H,messagePartsCount:V.length,messageParts:V.map(S=>({type:S.type,toolCallId:S.toolCallId,toolName:S.toolName}))});H.length>0;){ne("=== Starting pending tools execution loop ===",{pendingCount:H.length});let S=[];for(let u of H){ne(`Executing tool: ${u.toolName}`,{toolCallId:u.toolCallId,args:u.args}),R.handleToolInputStart({toolCallId:u.toolCallId,toolName:u.toolName}),R.handleToolInputDelta({toolCallId:u.toolCallId,inputTextDelta:JSON.stringify(u.args)}),g(w+R.buildToolDisplay()),F();let m=await Tt(u.toolName,u.args);ne(`Tool execution result: ${u.toolName}`,{success:m.success,resultPreview:m.success?JSON.stringify(m.result).slice(0,200):m.error});let _=m.success?JSON.stringify(m.result):m.error||"Unknown error";if(S.push({toolCallId:u.toolCallId,toolName:u.toolName,content:[{type:"text",text:_}],isError:!m.success}),m.success){R.handleToolOutputStart({toolCallId:u.toolCallId}),R.handleToolOutputDelta({toolCallId:u.toolCallId,outputTextDelta:JSON.stringify(m.result).slice(0,200)});let ce=R.handleToolOutputEnd({toolCallId:u.toolCallId},w);ce&&(w=ce.fullResponse)}else{let ce=R.handleToolError({toolCallId:u.toolCallId,errorText:m.error},w);ce&&(w=ce.fullResponse)}g(w+R.buildToolDisplay()),F()}H.length=0;for(let u of S){let m=V.find(_=>(_.type==="tool-input-available"||_.type==="tool-call")&&_.toolCallId===u.toolCallId);if(m){let _=[];for(let G of u.content)G.type==="text"?_.push(G.text):G.type==="image"?_.push("[Image]"):G.type==="audio"?_.push("[Audio]"):(G.type==="resource"||G.type==="resource_link")&&_.push("[Resource]");let ce=_.join(`
86
- `);oe.push({type:`tool-${m.toolName}`,toolName:m.toolName,toolCallId:m.toolCallId,input:m.args,output:ce,isError:u.isError})}}if(ne("=== Sending clientToolResults for continuation ===",{toolResultsCount:S.length,toolResults:S.map(u=>({toolCallId:u.toolCallId,toolName:u.toolName,isError:u.isError}))}),le)try{le.releaseLock()}catch{}let N={id:e,clientToolResults:S};n?N.agentId=n:(r&&(N.model=r),N.connectorIds=a??[]),T&&(N.clientTools=T),b&&(N.clientToolSystemPrompt=b),ne("=== Sending continuation request ===",{taskId:e,hasAgentId:!!N.agentId,hasModel:!!N.model,clientToolResultsCount:S.length});let I=await d.task(j,K,N);if(ne("=== Continuation response received ===",{ok:I.ok,status:I.status}),!I.ok){let u=await I.text();throw new Error(`Continuation failed: ${I.status}: ${u}`)}if(!I.body)break;for(ne("=== Processing continuation stream ==="),le=I.body.getReader(),V.length=0,Q="",L="",D="",M="";;){let{done:u,value:m}=await le.read();if(u){ne("=== Continuation stream done ===");break}te+=fe.decode(m,{stream:!0});let _=te.split(`
87
- `);te=_.pop()||"";for(let ce of _)if(ce.trim()!=="data: [DONE]"&&ce.startsWith("data: "))try{let G=JSON.parse(ce.slice(6));switch(ne(`Continuation SSE: ${G.type}`,G),G.type){case"reasoning-start":D=G.id||"0",L="";break;case"reasoning-delta":G.delta&&(L+=G.delta,g(`${Ie}[Thinking...]${X}
88
- ${L}`)),G.providerMetadata?.anthropic?.signature&&(M=G.providerMetadata.anthropic.signature);break;case"reasoning-end":if(L){let xe={type:"reasoning",id:D,text:L,state:"done"};M&&(xe.providerMetadata={anthropic:{signature:M}}),V.push(xe),ne("Continuation: Added reasoning to messageParts",{reasoningLength:L.length,hasSignature:!!M,messagePartsCount:V.length})}L="",M="",g(w);break;case"text-delta":G.delta&&(w+=G.delta,Q+=G.delta,g(w));break;case"tool-call":case"tool-input-available":if(G.toolCallId&&G.toolName){let xe=_t(G.args??G.input);V.push({type:G.type,toolCallId:G.toolCallId,toolName:G.toolName,args:xe})}if(c&&G.toolCallId&&G.toolName&&Be(G.toolName)){let xe=_t(G.args??G.input);H.push({toolCallId:G.toolCallId,toolName:G.toolName,args:xe}),ne("Continuation: Added to pendingClientTools",{pendingCount:H.length})}break;case"finish":ne("Continuation finish event",G);break}}catch{}}if(Q){let u=V.findIndex(_=>_.type!=="reasoning"),m=u===-1?V.length:u;V.splice(m,0,{type:"text",text:Q})}ne("=== Continuation stream processing complete ===",{pendingClientToolsCount:H.length,messagePartsCount:V.length,fullResponseLength:w.length})}if(c&&T&&T.length>0){let S=[];for(let I of oe)S.push({type:String(I.type),title:String(I.toolName).replace(/__/g," "),input:I.input,output:I.output,state:I.isError?"error":"output-available"});for(let I of V)I.type==="text"&&I.text&&S.push({type:"text",text:I.text});let N=Ke(S,p);ne("=== Using formatted parts for local tools ===",{executedToolsCount:oe.length,textPartsCount:V.filter(I=>I.type==="text").length,contentLength:N.length}),h(I=>[...I,{role:"assistant",content:N,parts:S}])}else{ne("=== Fetching message from API ===",{fullResponseLength:w.length,fullResponsePreview:w.slice(0,200)});try{let{messages:S}=await d.getMessages(j,K,e,10);ne("=== API messages received ===",{count:S.length,roles:S.map(I=>I.role)});let N=S.find(I=>I.role==="assistant");if(N){let I=N.parts,u=Ke(I,p);ne("=== Setting message from API ===",{partsCount:I.length,partTypes:I.map(m=>m.type),contentLength:u.length,contentPreview:u.slice(0,200)}),h(m=>[...m,{role:"assistant",content:u,parts:I}])}else ne("=== No assistant message found, using fallback ==="),h(I=>[...I,{role:"assistant",content:w}])}catch(S){ne("=== API fetch failed, using fallback ===",{error:S instanceof Error?S.message:String(S)}),h(N=>[...N,{role:"assistant",content:w}])}}ne("=== Message handling complete ==="),g(""),y({status:"ready"}),$(!0),P.length>0&&Y?.()}catch(d){ne("=== ERROR ===",{message:d instanceof Error?d.message:String(d),stack:d instanceof Error?d.stack:void 0});let P=d instanceof Error?d.message:"Failed to send message";y({status:"error",message:P})}finally{if(l&&(clearInterval(l),l=null),le)try{le.releaseLock()}catch{}}},[t,e,n,r,a,c,T,b,p,h,y,g,O,$,v,Y])}}import{useState as Jo}from"react";var Hn=new Map([["sandbox","Sandbox"],["web_search","Web Search"],["image_generation","Image Generation"],["chart","Chart"],["file_system","FileSystem"]]);function Jn(e){let[t,n]=Jo(e);return{fileSystem:t,setFileSystem:n,capabilityLabelMap:Hn}}import{useEffect as Yo,useState as Ko}from"react";function Yn(e,t){let[n,r]=Ko(null);return Yo(()=>{let a=!1;async function c(){if(!e||!t){r(null);return}try{let h=await new pe().getAgent(t.accessToken,t.workspaceId,e);a||r(h)}catch{a||r(null)}}return c(),()=>{a=!0}},[e,t]),{currentAgentDetails:n}}import{useState as Zt}from"react";function Kn(e,t,n){let[r,a]=Zt(e),[c,p]=Zt(t),[h,y]=Zt(n);return{currentModel:r,setCurrentModel:a,currentAgentId:c,setCurrentAgentId:p,activeConnectorIds:h,setActiveConnectorIds:y}}import{useApp as zo,useInput as Xo}from"ink";import{useCallback as Ue,useRef as Qo,useState as Te}from"react";import{spawn as Vo}from"child_process";function Vn(e){return new Promise((t,n)=>{let r,a;process.platform==="darwin"?(r="open",a=[e]):process.platform==="win32"?(r="cmd",a=["/c","start","",e]):(r="xdg-open",a=[e]);let c=Vo(r,a,{stdio:"ignore",detached:!0});c.once("error",p=>{n(p)}),c.once("spawn",()=>{c.unref(),t()})})}var zn=[{name:"help",aliases:["h","?"],description:"Show available commands"},{name:"clear",aliases:["cls","new"],description:"Start a new task"},{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:"Toggle client capabilities"},{name:"tasks",aliases:["c"],description:"Switch to another task"},{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 task in browser"},{name:"share",aliases:[],description:"Get share link for current task"},{name:"delete",aliases:["del"],description:"Delete current task"},{name:"quit",aliases:["exit","q"],description:"Exit task"}];function Xn(e){if(!e.startsWith("/"))return[];let t=e.slice(1).toLowerCase();return t?zn.filter(n=>n.name.startsWith(t)||n.aliases.some(r=>r.startsWith(t))):zn}function Qn(e){let t=e.trim();if(!t.startsWith("/"))return null;let n=t.slice(1).split(/\s+/),r=n[0]?.toLowerCase(),a=n.slice(1).join(" ");switch(r){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:a||void 0};case"agent":case"a":return{type:"agent",value:a||void 0};case"skills":case"sk":return{type:"skills",value:a||void 0};case"schedules":case"sch":return{type:"schedules",value:a||void 0};case"connectors":case"conn":return{type:"connectors"};case"capabilities":case"cap":return{type:"capabilities"};case"tasks":case"c":return{type:"tasks"};case"workspace":case"ws":return{type:"workspace",value:a||void 0};case"budget":case"bg":return{type:"budget",value:a||void 0};case"usage":case"u":return{type:"usage"};case"status":case"s":return{type:"status"};case"profile":case"p":return{type:"profile",value:a||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 Zn=`Available commands:
89
- /help, /h, /? Show this help message
90
- /clear, /cls, /new Start a new task
91
- /model [name], /m Show current model or switch to [name]
92
- /agent [name], /a Show current agent or switch to [name]
93
- /skills [name], /sk List skills or show details for [name]
94
- /schedules [id], /sch List schedules or show details for [id]
95
- /connectors, /conn Select active connectors
96
- /capabilities, /cap Toggle client capabilities (FileSystem)
97
- /tasks, /c Switch to another task
98
- /workspace [id], /ws List or switch workspace
99
- /budget [amount], /bg View or set workspace budget
100
- /usage, /u View current month usage (top 10 by cost)
101
- /status, /s Show current session status
102
- /profile [args], /p Manage profiles (list/show/use/create/delete/rename/clone)
103
- /open-in-browser Open current task in browser
104
- /share Get share link for current task
105
- /delete, /del Delete current task
106
- /quit, /exit, /q Exit interactive mode
107
-
108
- Note: For detailed usage with sorting/limits, use: entrydesk usage --help
109
-
110
- Keyboard shortcuts:
111
- Ctrl+O Toggle full output mode
112
- Ctrl+C Exit`;function en(e){if(e.type==="no-repeat")return"No repeat";let{interval:t}=e;switch(t.unit){case"minutes":return`Every ${t.every} min`;case"hours":return`Every ${t.every} hr`;case"days":return`Every ${t.every} day at ${String(t.time.hour).padStart(2,"0")}:${String(t.time.minute).padStart(2,"0")}`;case"weeks":return`Every ${t.every} week`;case"months":return`Every ${t.every} month`;default:return"Unknown"}}function eo({input:e,setInput:t,taskId:n,setTaskId:r,currentTaskTitle:a,setCurrentTaskTitle:c,currentModel:p,setCurrentModel:h,currentAgentId:y,setCurrentAgentId:g,currentAgentDetails:O,setCurrentAgentDetails:$,activeConnectorIds:v,setActiveConnectorIds:Y,fileSystem:T,setFileSystem:b,availableModels:E,availableAgents:A,availableConnectors:W,messages:Z,hasPersistedTask:j,setHasPersistedTask:K,setMessages:le,addSystemMessage:l,startNewTask:d,sendMessage:P,setFullOutput:U,credentials:C,setCredentials:fe,setState:te,defaultCapabilities:w,capabilityLabelMap:L,hasUploadingFiles:D=!1}){let{exit:M}=zo(),[Q,ee]=Te([]),[R,H]=Te(0),[V,oe]=Te(!1),[F,S]=Te(null),[N,I]=Te([]),[u,m]=Te(0),[_,ce]=Te(new Set),[G,xe]=Te(new Set),[sn,pt]=Te([]),[_e,Lt]=Te([]),[ve,mt]=Te([]),[Re,gt]=Te([]),[Ee,je]=Te(null),[Ft,nt]=Te(""),Ve=Qo(!1),[Le,ye]=Te(!1),ze=Ue(async()=>{if(!C)return[];let k=new pe,f=[],o;do{let s=await k.listAvailableSkills(C.accessToken,C.workspaceId,{limit:100,nextKey:o});f.push(...s.skills),o=s.nextKey}while(o);return Lt(f),f},[C]),Xe=Ue(async()=>{if(!C)return[];let k=new pe,f=[],o;do{let s=await k.getSchedules(C.accessToken,C.workspaceId,{limit:100,nextKey:o});f.push(...s.schedules),o=s.nextKey}while(o);return mt(f),f},[C]),we=Ue(async k=>{if(k==="model"){if(E.length===0){l("No models available.");return}let f=E.map(s=>({id:s.id,name:s.name,description:s.description}));I(f);let o=p?f.findIndex(s=>s.id===p):-1;m(Math.max(o,0)),S("model")}else if(k==="agent"){if(A.length===0){l("No agents available.");return}let f=A.map(s=>({id:s.id,name:s.name,description:s.description}));I(f);let o=y?f.findIndex(s=>s.id===y):-1;m(Math.max(o,0)),S("agent")}else if(k==="skills"){let f=_e;if(f.length===0)try{f=await ze()}catch{l("Failed to load skills.");return}if(f.length===0){l("No skills available.");return}let o=f.map(s=>({id:s.id,name:s.name,description:s.description}));I(o),m(0),S("skills")}else if(k==="schedules"){let f=ve;if(f.length===0)try{f=await Xe()}catch{l("Failed to load schedules.");return}if(f.length===0){l("No schedules found.");return}let o=f.map(s=>({id:s.id,name:s.name,description:`${s.agent.name} - ${s.isActive?"Active":"Paused"}`}));I(o),m(0),S("schedules")}else if(k==="connectors"){if(W.length===0){l("No connectors available.");return}let f=W.map(o=>({id:o.id,name:o.name}));I(f),m(0),ce(new Set(v??[])),S("connectors")}else if(k==="capabilities"){I([{id:"fileSystem",name:"FileSystem",description:"Local file operations"}]),m(0);let o=new Set;T&&o.add("fileSystem"),xe(o),S("capabilities")}else if(k==="tasks"){if(!C){l("Not authenticated.");return}try{let f=new pe,{tasks:o}=await f.getTasks(C.accessToken,C.workspaceId,20);if(o.length===0){l("No tasks available.");return}pt(o);let s=o.map(x=>({id:x.id,name:x.title||"Untitled",description:new Date(x.createdAt).toLocaleDateString()}));I(s);let i=s.findIndex(x=>x.id===n);m(Math.max(i,0)),S("tasks")}catch{l("Failed to load tasks.")}}else if(k==="profile"){let f=ie.getProfileNames(),o=ie.getCurrentProfileName(),s=f.map(x=>({id:x,name:x,description:x===o?"(current)":void 0}));I(s);let i=s.findIndex(x=>x.id===o);m(Math.max(i,0)),S("profile")}oe(!1),ee([])},[E,A,_e,ve,W,v,p,y,T,ze,Xe,C,n,l]),Se=Ue(k=>{let f=de.getAll(k);h(f.model?.default),g(void 0),$(null);let o=f.connectors?.defaults;Y(o&&o.length>0?o:void 0);let s=f.localTools;b(s?.fileSystem??w.fileSystem)},[h,g,$,Y,b,w]),Ne=Ue(async()=>{try{let k=await We();fe({accessToken:k.accessToken,workspaceId:k.workspaceId}),te({status:"ready"})}catch(k){if(fe(null),k instanceof Je){if(k.code==="not-logged-in"){te({status:"not-logged-in"});return}if(k.code==="no-workspace"){te({status:"no-workspace"});return}}let f=k instanceof Error?k.message:"Failed to authenticate";te({status:"error",message:f})}},[fe,te]),Ge=Ue(async k=>{switch(k.type){case"help":return l(Zn),!0;case"clear":return d("Started a new task."),!0;case"model":{if(k.value){let f=k.value.toLowerCase(),o=E.find(s=>s.id.toLowerCase()===f||s.name.toLowerCase().includes(f));if(o)y?d(`Switched to model: ${o.name} (new task)`):l(`Switched to model: ${o.name}`),h(o.id),g(void 0),$(null),de.setDefaultModel(o.id);else{let s=E.map(i=>i.name).join(", ");l(`Model "${k.value}" not found.
113
- Available: ${s||"none"}`)}}else{let f=E.find(o=>o.id===p)?.name||p;l(p?`Current model: ${f}`:"No model selected. Using agent mode.")}return!0}case"agent":{if(!k.value)return A.length===0?(l("No agents available."),!0):(we("agent"),!0);let f=k.value.toLowerCase(),o=A.find(s=>s.id.toLowerCase()===f||s.name.toLowerCase().includes(f));if(o)o.id!==y?d(`Switched to agent: ${o.name} (new task)`):l(`Switched to agent: ${o.name}`),g(o.id),h(void 0);else{let s=A.map(i=>i.name).join(", ");l(`Agent "${k.value}" not found.
114
- Available: ${s||"none"}`)}return!0}case"skills":{if(!k.value)return we("skills"),!0;let f=k.value.toLowerCase();return(_e.length>0?Promise.resolve(_e):ze().catch(()=>[])).then(s=>{let i=s.find(x=>x.id.toLowerCase()===f||x.name.toLowerCase().includes(f));l(i?`Skill: ${i.name}
115
- ${i.description}
116
- Provider: ${i.provider}
117
- Author: ${i.author.name}
118
- ID: ${i.id}`:`Skill "${k.value}" not found.`)}),!0}case"schedules":{if(!k.value)return we("schedules"),!0;let f=k.value.toLowerCase();return(ve.length>0?Promise.resolve(ve):Xe().catch(()=>[])).then(s=>{let i=s.find(x=>x.id.toLowerCase()===f||x.name.toLowerCase().includes(f));if(i){let x=i.nextRunAt?new Date(i.nextRunAt).toLocaleString():"-";l(`Schedule: ${i.name}
119
- Agent: ${i.agent.name}
120
- Status: ${i.isActive?"Active":"Paused"}
121
- Repeat: ${en(i.config)}
122
- Next Run: ${x}
123
- ID: ${i.id}`)}else l(`Schedule "${k.value}" not found.`)}),!0}case"connectors":{if(y){let o=O?.connectors??[];if(o.length===0)l("No agent connectors.");else{let s=o.map(i=>` - ${i.name}`).join(`
124
- `);l(`Agent connectors:
125
- ${s}`)}return!0}let f=W.filter(o=>v?.includes(o.id));if(f.length===0)l("No active connectors.");else{let o=f.map(s=>` - ${s.name}`).join(`
126
- `);l(`Active connectors:
127
- ${o}`)}return!0}case"capabilities":{if(y){let s=(O?.capabilities??[]).map(i=>L.get(i)??i);return l(s.length>0?`Agent capabilities:
128
- ${s.map(i=>` - ${i}`).join(`
129
- `)}`:"No agent capabilities."),!0}let f=[];return T&&f.push("FileSystem"),l(f.length>0?`Active capabilities:
130
- ${f.map(o=>` - ${o}`).join(`
131
- `)}`:"No capabilities enabled."),!0}case"tasks":return l(a?`Current task: ${a}`:`Current task: ${n.slice(0,8)}...`),!0;case"workspace":{if(!C)return l("Not authenticated."),!0;let f=new pe;if(!k.value){try{let{workspaces:s}=await f.getWorkspaces(C.accessToken);if(s.length===0)l("No workspaces found.");else{let i=s.map(x=>` ${x.id===C.workspaceId?"* ":" "}${x.name}
132
- ID: ${x.id}`);l(`Workspaces:
133
- ${i.join(`
134
- `)}`)}}catch(s){l(`Failed to load workspaces: ${s instanceof Error?s.message:"Unknown error"}`)}return!0}let o=k.value;try{let{workspaces:s}=await f.getWorkspaces(C.accessToken),i=s.find(x=>x.id===o);if(!i)return l(`Workspace not found: ${o}`),!0;await rt.saveWorkspaceId(o),l(`Switched to workspace: ${i.name}`),l("Please restart the task to apply changes.")}catch(s){l(`Failed to switch workspace: ${s instanceof Error?s.message:"Unknown error"}`)}return!0}case"budget":{if(!C)return l("Not authenticated."),!0;let f=new pe;if(!k.value){try{let i=await f.getBudget(C.accessToken,C.workspaceId);i.budget===null?l("No budget set for this workspace."):l(`Current budget: $${i.budget}`)}catch(i){l(`Failed to get budget: ${i instanceof Error?i.message:"Unknown error"}`)}return!0}let o=k.value.toLowerCase();if(o==="clear"||o==="null"){try{await f.updateBudget(C.accessToken,C.workspaceId,null),l("Budget cleared.")}catch(i){l(`Failed to clear budget: ${i instanceof Error?i.message:"Unknown error"}`)}return!0}let s=parseFloat(o);if(isNaN(s)||s<0)return l("Invalid budget amount. Must be a positive number."),!0;try{await f.updateBudget(C.accessToken,C.workspaceId,o),l(`Budget set to: $${o}`)}catch(i){l(`Failed to set budget: ${i instanceof Error?i.message:"Unknown error"}`)}return!0}case"usage":{if(!C)return l("Not authenticated."),!0;let f=new pe;try{let o=[],s,i=0,x=10;do{let me=await f.getMonthlyUsages(C.accessToken,C.workspaceId,{nextKey:s,limit:20});if(o.push(...me.monthlyUsages),s=me.nextKey,i++,i>=x){l(`Warning: Showing first ${o.length} entries (pagination limit reached)`);break}}while(s);if(o.length===0)return l("No usage data found for this workspace."),!0;let J=0,re=0;for(let me of o)J+=parseFloat(me.totalCost),re+=me.operationCount;let be=[...o].toSorted((me,He)=>parseFloat(He.totalCost)-parseFloat(me.totalCost)),z=10,ue=be.slice(0,z),Ce=[`Total Cost: $${J.toFixed(2)}`,`Total Operations: ${re.toLocaleString()}`,`Users: ${o.length}`,"",`Top ${ue.length} Users by Cost:`,...ue.map(me=>` ${me.user.name}: $${parseFloat(me.totalCost).toFixed(2)} (${me.operationCount.toLocaleString()} ops)`)];o.length>z&&(Ce.push("",`... and ${o.length-z} more users`),Ce.push("Use CLI command for full list: entrydesk usage --limit <n> --sort-by <cost|operations>")),l(Ce.join(`
135
- `))}catch(o){l(`Failed to get usage: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"status":{let f=ie.getCurrentProfileName(),o=p?E.find(J=>J.id===p)?.name||p:null,s=y?A.find(J=>J.id===y)?.name||y:null,i=v?W.filter(J=>v.includes(J.id)).map(J=>J.name):[],x=[];return T&&x.push("FileSystem"),rt.getEmail().then(J=>{let re=[`Profile: ${f}${f!=="default"?" (non-default)":""}`,J?`Logged in as: ${J}`:"Not logged in",C?.workspaceId?`Workspace: ${C.workspaceId}`:null,j?`Task ID: ${n}`:null,o?`Model: ${o}`:null,s?`Agent: ${s}`:null,`Connectors: ${i.length>0?i.join(", "):"none"}`,`Capabilities: ${x.length>0?x.join(", "):"none"}`].filter(Boolean);l(re.join(`
136
- `))}).catch(()=>{let J=[`Profile: ${f}`,"Not logged in",j?`Task ID: ${n}`:null,o?`Model: ${o}`:null,s?`Agent: ${s}`:null,`Connectors: ${i.length>0?i.join(", "):"none"}`,`Capabilities: ${x.length>0?x.join(", "):"none"}`].filter(Boolean);l(J.join(`
137
- `))}),!0}case"profile":{let f=k.value?k.value.split(/\s+/).filter(Boolean):[];if(f.length===0)return we("profile"),!0;let o=f[0]?.toLowerCase()||"list",s=f[1],i=f[2],x=ie.getProfileNames(),J=ie.getCurrentProfileName(),re=ie.getOverrideProfile(),be=(z,ue=!1)=>{if(z)return z;if(ue&&x.length===1)return x[0];throw new Error("Profile name is required when multiple profiles exist.")};try{if(o==="list"){let z=[`Profiles (${x.length}):`];for(let ue of x){let Ce=ue===J?" (current)":"";z.push(` ${ue}${Ce}`)}return l(z.join(`
138
- `)),!0}if(o==="current")return l(`Current profile: ${J}`),!0;if(o==="show"){let z=be(s,!0),ue=de.getAll(z),Ce=await rt.getAll(z),me=!!Ce?.accessToken,He=ue.connectors?.defaults&&ue.connectors.defaults.length>0?ue.connectors.defaults.join(", "):"unset",ao=[`Profile: ${z}${z===J?" (current)":""}`,`API URL: ${ue.apiUrl??"default"}`,`Hub URL: ${ue.hubUrl??"default"}`,`Model: ${ue.model?.default??"unset"}`,`Connectors: ${He}`,me?`Logged in as: ${Ce?.email??"unknown"}`:"Not logged in",me&&Ce?.workspaceId?`Workspace ID: ${Ce.workspaceId}`:null].filter(Boolean);return l(ao.join(`
139
- `)),!0}if(o==="create"){let z=s||ie.DEFAULT_PROFILE;return ie.createProfile(z),l(`Profile created: ${z}`),!0}if(o==="use"||o==="switch"){let z=be(s,!0);return ie.setOverrideProfile(z),ie.setCurrentProfile(z),Se(z),await Ne(),d(`Switched to profile: ${z} (new task)`),!0}if(o==="delete"||o==="remove"||o==="rm"){let z=be(s,!0),ue=z===J,Ce=ie.deleteProfile(z),me=`Profile deleted: ${z}`;if(ue)ie.setOverrideProfile(Ce.currentProfile),Se(Ce.currentProfile),await Ne(),d(`${me}
140
- Switched to profile: ${Ce.currentProfile} (new task)`);else if(re===z){let He=ie.getCurrentProfileName();ie.setOverrideProfile(He),Se(He),await Ne(),d(`${me}
141
- Switched to profile: ${He} (new task)`)}else l(me);return!0}if(o==="rename"||o==="move"||o==="mv"){let z=be(s,!0);if(!i)throw new Error("New profile name is required.");let ue=ie.renameProfile(z,i);return l(`Profile renamed: ${z} -> ${i}`),re===z?(ie.setOverrideProfile(i),Se(i)):ue.currentProfile===i&&Se(i),!0}if(o==="clone"||o==="copy"){let z=be(s,!0);if(!i)throw new Error("Target profile name is required.");let ue=de.getAll(z);return ie.createProfile(i),de.setAll(ue,i),await rt.clear(i),l(`Profile cloned: ${z} -> ${i}`),!0}l(`Unknown profile command: ${o}`)}catch(z){let ue=z instanceof Error?z.message:"Unknown error";l(`Profile error: ${ue}`)}return!0}case"open-in-browser":{let f=Bt().hubUrl.replace(/\/$/,""),o=j||Z.some(re=>re.role!=="system"),s=C?`/${C.workspaceId}`:"",i=o?`${s}/task/${n}`:`${s}/task/new`,x=y?`?agentId=${encodeURIComponent(y)}`:"",J=`${f}${i}${x}`;try{await Vn(J),l(`Opened in browser: ${J}`)}catch(re){l(`Failed to open browser: ${re instanceof Error?re.message:"Unknown error"}
142
- URL: ${J}`)}return!0}case"share":{if(!C)return l("Not authenticated."),!0;if(!(j||Z.some(o=>o.role!=="system")))return l("No conversation to share. Start a task first."),!0;try{let s=await new pe().createTaskShare(C.accessToken,C.workspaceId,n,"public"),x=`${Bt().hubUrl.replace(/\/$/,"")}/share/${s.id}`;l(`Share link: ${x}`)}catch(o){l(`Failed to create share link: ${o instanceof Error?o.message:"Unknown error"}`)}return!0}case"delete":return C?j?(ye(!0),l("Delete this task? (y/N)"),!0):(l("No task to delete."),!0):(l("Not authenticated."),!0);case"quit":return M(),!0;case"unknown":return l(`Unknown command: ${k.input}
143
- Type /help for available commands.`),!0;default:return!1}},[l,E,A,W,_e,ve,p,y,v,T,n,a,M,we,d,L,O,j,Z,ze,Xe,le,h,g,$,h,Se,Ne]),ht=Ue(k=>{if(Ve.current=!1,Le){(k===""||k.startsWith("/"))&&(t(k),k.startsWith("/")&&ye(!1));return}if(t(k),nt(k),Ee!==null&&je(null),F&&(S(null),I([])),k.startsWith("/")&&!k.includes(" ")){let f=Xn(k);ee(f),H(0),oe(f.length>0)}else oe(!1),ee([])},[F,Ee,Le,t]),ot=Ue((k,f=!1)=>{if(k>=0&&k<Q.length){let o=Q[k];oe(!1),ee([]),o.name==="model"?(t("/model "),we("model")):o.name==="agent"?(t("/agent "),we("agent")):o.name==="skills"?(t("/skills "),we("skills")):o.name==="schedules"?(t("/schedules "),we("schedules")):o.name==="connectors"?(t("/connectors "),we("connectors")):o.name==="capabilities"?(t("/capabilities "),we("capabilities")):o.name==="tasks"?(t("/tasks "),we("tasks")):o.name==="profile"?(t("/profile "),we("profile")):f?(t(""),Ge({type:o.name})):t(`/${o.name}`)}},[Q,we,t,Ge]),qe=Ue(async k=>{Ve.current=!1;let f=k.trim();if(!f||Le)return;if(F==="model"&&N.length>0){let s=N[u];s&&(y?d(`Switched to model: ${s.name} (new task)`):l(`Switched to model: ${s.name}`),h(s.id),g(void 0),$(null)),S(null),I([]),t("");return}if(F==="agent"&&N.length>0){let s=N[u];s&&(s.id!==y?d(`Switched to agent: ${s.name} (new task)`):l(`Switched to agent: ${s.name}`),g(s.id),h(void 0)),S(null),I([]),t("");return}if(F==="skills"&&N.length>0){let s=N[u];if(s){let i=_e.find(x=>x.id===s.id);i&&l(`Skill: ${i.name}
144
- ${i.description}
145
- Provider: ${i.provider}
146
- Author: ${i.author.name}
147
- ID: ${i.id}`)}S(null),I([]),t("");return}if(F==="schedules"&&N.length>0){let s=N[u];if(s){let i=ve.find(x=>x.id===s.id);if(i){let x=i.nextRunAt?new Date(i.nextRunAt).toLocaleString():"-";l(`Schedule: ${i.name}
148
- Agent: ${i.agent.name}
149
- Status: ${i.isActive?"Active":"Paused"}
150
- Repeat: ${en(i.config)}
151
- Next Run: ${x}
152
- ID: ${i.id}`)}}S(null),I([]),t("");return}if(F==="connectors"){let s=Array.from(_);Y(s.length>0?s:void 0),de.setDefaultConnectorIds(s);let i=W.filter(x=>_.has(x.id)).map(x=>x.name);l(i.length>0?`Active connectors: ${i.join(", ")}`:"All connectors disabled."),S(null),I([]),t("");return}if(F==="capabilities"){let s=G.has("fileSystem");b(s),de.setLocalTools({fileSystem:s});let i=[];s&&i.push("FileSystem"),l(i.length>0?`Active capabilities: ${i.join(", ")}`:"All capabilities disabled."),S(null),I([]),t("");return}if(F==="profile"&&N.length>0){let s=N[u];if(s){let i=ie.getCurrentProfileName();s.id!==i?(ie.setOverrideProfile(s.id),ie.setCurrentProfile(s.id),Se(s.id),Ne(),d(`Switched to profile: ${s.name}`)):l(`Already using profile: ${s.name}`)}S(null),I([]),t("");return}if(V&&Q.length>0){ot(R,!0);return}je(null),nt(""),gt(s=>s.length>0&&s.at(-1)===f?s:[...s,f]);let o=Qn(f);if(o){await Ge(o),t(""),oe(!1);return}if(D){l("Please wait for file uploads to complete.");return}t(""),oe(!1),P(f)},[P,Ge,V,Q,R,ot,F,N,u,_,G,W,_e,ve,l,t,y,d,h,g,$,Y,b,D,Se,Ne,Le,C,j,n]);return Xo((k,f)=>{if(f.ctrl&&k==="c"){if(e.length>0){ht(""),Ve.current=!0,l("Press Ctrl+C again to exit.");return}if(Ve.current){M();return}M();return}if(f.ctrl&&k==="o"){U(o=>!o);return}if(Le){if(f.escape||f.return||k==="n"||k==="N"){ye(!1),t(""),l("Task deletion cancelled.");return}if(k==="y"||k==="Y"){ye(!1),t(""),C&&j&&new pe().deleteTask(C.accessToken,C.workspaceId,n).then(()=>{d("Task deleted. Started a new task.")}).catch(s=>{l(`Failed to delete task: ${s.message||"Unknown error"}`)});return}return}if(F&&N.length>0){if(f.upArrow){m(o=>o<=0?N.length-1:o-1);return}if(f.downArrow){m(o=>o>=N.length-1?0:o+1);return}if(f.escape){S(null),I([]),t("");return}if(f.return){if(F==="model"){let o=N[u];o&&(y?d(`Switched to model: ${o.name} (new task)`):l(`Switched to model: ${o.name}`),h(o.id),g(void 0),$(null),de.setDefaultModel(o.id))}else if(F==="agent"){let o=N[u];o&&(o.id!==y?d(`Switched to agent: ${o.name} (new task)`):l(`Switched to agent: ${o.name}`),g(o.id),h(void 0))}else if(F==="skills"){let o=N[u];if(o){let s=_e.find(i=>i.id===o.id);s&&l(`Skill: ${s.name}
153
- ${s.description}
154
- Provider: ${s.provider}
155
- Author: ${s.author.name}
156
- ID: ${s.id}`)}}else if(F==="schedules"){let o=N[u];if(o){let s=ve.find(i=>i.id===o.id);if(s){let i=s.nextRunAt?new Date(s.nextRunAt).toLocaleString():"-";l(`Schedule: ${s.name}
157
- Agent: ${s.agent.name}
158
- Status: ${s.isActive?"Active":"Paused"}
159
- Repeat: ${en(s.config)}
160
- Next Run: ${i}
161
- ID: ${s.id}`)}}}else if(F==="connectors"){let o=Array.from(_);Y(o.length>0?o:void 0),de.setDefaultConnectorIds(o);let s=W.filter(i=>_.has(i.id)).map(i=>i.name);l(s.length>0?`Active connectors: ${s.join(", ")}`:"All connectors disabled.")}else if(F==="capabilities"){let o=G.has("fileSystem");b(o),de.setLocalTools({fileSystem:o});let s=[];o&&s.push("FileSystem"),l(s.length>0?`Active capabilities: ${s.join(", ")}`:"All capabilities disabled.")}else if(F==="tasks"){let o=N[u];if(o){let s=sn.find(i=>i.id===o.id);s&&C&&(r(s.id),c(s.title||void 0),K(!0),new pe().getMessages(C.accessToken,C.workspaceId,s.id,20).then(({messages:x})=>{let J=x.filter(re=>re.role==="user"||re.role==="assistant").map(re=>({role:re.role,content:Ke(re.parts,!1),parts:re.parts})).filter(re=>re.content).toReversed();le(J),l(`Switched to: ${s.title||"Untitled"}`)}).catch(()=>{l("Failed to load task messages.")}))}}else if(F==="profile"){let o=N[u];if(o){let s=ie.getCurrentProfileName();o.id!==s?(ie.setOverrideProfile(o.id),ie.setCurrentProfile(o.id),Se(o.id),Ne(),d(`Switched to profile: ${o.name}`)):l(`Already using profile: ${o.name}`)}}S(null),I([]),t("");return}if(k===" "&&(F==="connectors"||F==="capabilities")){let o=N[u];o&&(F==="connectors"?ce:xe)(i=>{let x=new Set(i);return x.has(o.id)?x.delete(o.id):x.add(o.id),x});return}if(k==="a"&&(F==="connectors"||F==="capabilities")){(F==="connectors"?ce:xe)(new Set(N.map(s=>s.id)));return}if(k==="n"&&(F==="connectors"||F==="capabilities")){(F==="connectors"?ce:xe)(new Set);return}return}if(V&&Q.length>0){if(f.upArrow){H(o=>o<=0?Q.length-1:o-1);return}if(f.downArrow){H(o=>o>=Q.length-1?0:o+1);return}if(f.escape){oe(!1),ee([]);return}if(f.tab){ot(R);return}}if(f.upArrow){if(e.includes(`
162
- `)||Re.length===0)return;if(Ee===null){nt(e);let s=Re.length-1;je(s),t(Re[s]);return}let o=Math.max(0,Ee-1);je(o),t(Re[o]);return}if(f.downArrow){if(e.includes(`
163
- `)||Ee===null)return;if(Ee>=Re.length-1){je(null),t(Ft);return}let o=Ee+1;je(o),t(Re[o])}}),{suggestions:Q,suggestionIndex:R,showSuggestions:V,argMode:F,argItems:N,argIndex:u,selectedConnectorIds:_,selectedCapabilities:G,deleteConfirmMode:Le,handleInputChange:ht,handleSubmit:qe}}import{useCallback as ft,useRef as Zo,useState as er}from"react";function to({credentials:e,currentModel:t,modelProviders:n,onUploadSuccess:r,onUploadError:a}){let[c,p]=er([]),h=Zo(0),y=ft(b=>{if(!(!Array.isArray(n)||n.length===0)){for(let E of n)if(E.models.some(W=>W.id===b))return E.id;return n[0]?.id}},[n]),g=ft(async b=>{if(!e){a?.(b.filename,"Not logged in");return}if(!Array.isArray(n)||n.length===0){a?.(b.filename,"Model providers not loaded yet. Please wait and try again.");return}let E=t?y(t):n[0]?.id;if(!E){a?.(b.filename,"No model provider available");return}let A=`file-${++h.current}`;p(W=>[...W,{id:A,filename:b.filename,mimeType:b.mimeType,status:"uploading"}]);try{let Z=await new pe().uploadFile(e.accessToken,e.workspaceId,b,E);p(j=>j.map(K=>K.id===A?{...K,status:"uploaded",fileId:Z.id}:K)),r?.(b.filename)}catch(W){let Z=W instanceof Error?W.message:"Upload failed";p(j=>j.map(K=>K.id===A?{...K,status:"error",error:Z}:K)),a?.(b.filename,Z)}},[e,t,y,n,r,a]),O=ft(b=>{p(E=>E.filter(A=>A.id!==b))},[]),$=ft(()=>{p([])},[]),v=ft(()=>c.filter(b=>b.status==="uploaded"&&b.fileId).map(b=>b.fileId),[c]),Y=c.some(b=>b.status==="uploading"),T=c.length>0;return{pendingFiles:c,addFile:g,removeFile:O,clearFiles:$,getUploadedFileIds:v,hasUploadingFiles:Y,hasFiles:T}}import{jsx as q,jsxs as se}from"react/jsx-runtime";var nr=[" ______ _ ____ _","| ____| | | | _ \\ | |","| |__ _ __ | |_ _ __ _ _ | | | | ___ ___| | __","| __| | '_ \\| __| '__| | | || | | |/ _ \\/ __| |/ /","| |____| | | | |_| | | |_| || |_| | __/\\__ \\ <","|______|_| |_|\\__|_| \\__, ||____/ \\___||___/_|\\_\\"," __/ |"," |___/"],or=[Qt,Qt,Xt,Xt,Ye,Ye,Ye,Ye],oo=nr.map((e,t)=>`${or[t]??Ye}${e}${X}`).join(`
164
- `),rr=`${Ye}EntryDesk${X}`,sr=500;function ir(e){let t="",n=0;for(;n<e.length;){if(e.charCodeAt(n)===27&&e[n+1]==="["){for(n+=2;n<e.length;){let r=e.charCodeAt(n);if(r>=64&&r<=126){n+=1;break}n+=1}continue}t+=e[n],n+=1}return t}function lr(e){let t=ir(e);return Math.max(...t.split(`
165
- `).map(n=>n.length))}function ar(e){let t=lr(oo);return e>=t?oo:rr}function ro({agentId:e,model:t,message:n,taskId:r,taskTitle:a,connectorIds:c,enableFileSystem:p=!0}){let h=process.stdout.columns??80,y=ar(h),g=no(null),O=On(r,a),{state:$,setState:v,messages:Y,setMessages:T,input:b,setInput:E,taskId:A,setTaskId:W,currentTaskTitle:Z,setCurrentTaskTitle:j,hasPersistedTask:K,setHasPersistedTask:le,credentials:l,setCredentials:d,currentResponse:P,setCurrentResponse:U,fullOutput:C,setFullOutput:fe,addSystemMessage:te,startNewTask:w}=O,{credentials:L}=jn(v);Et(()=>{L&&!l&&d(L)},[L,l,d]);let{availableConnectors:D,availableModels:M,availableAgents:Q,modelProviders:ee,loading:R}=Wn(l),{currentModel:H,setCurrentModel:V,currentAgentId:oe,setCurrentAgentId:F,activeConnectorIds:S,setActiveConnectorIds:N}=Kn(t,e,c),I=no(!1);Et(()=>{if(!I.current){if(I.current=!0,!t&&!e){let i=de.getDefaultModel();i&&V(i)}if(!c&&!e){let i=de.getDefaultConnectorIds();i&&N(i.length>0?i:void 0)}}},[t,e,c,V,N]);let{currentAgentDetails:u}=Yn(oe,l),{fileSystem:m,setFileSystem:_,capabilityLabelMap:ce}=Jn(p),{pendingFiles:G,addFile:xe,removeFile:sn,clearFiles:pt,getUploadedFileIds:_e,hasUploadingFiles:Lt,hasFiles:ve}=to({credentials:l,currentModel:H,modelProviders:ee,onUploadSuccess:i=>{te(`\u2713 Attached: ${i}`)},onUploadError:(i,x)=>{te(`\u2717 Failed to upload ${i}: ${x}`)}}),{sendMessage:mt}=qn({taskId:A,credentials:l,currentAgentId:oe,currentModel:H,activeConnectorIds:S,localTools:m,fullOutput:C,setMessages:T,setState:v,setCurrentResponse:U,setCredentials:d,setHasPersistedTask:le,getFileIds:_e,clearFiles:pt}),Re=on(i=>{w(i),U("")},[w]),[gt,Ee]=tr(!1),je=on(async i=>{let x=i.text.trim(),J=St(x);if(/^https?:\/\//.test(J))return;if(await Rn(x)&&Dn(J)){let be=await Ln(x);be&&(i.preventDefault(),await xe(be))}},[xe]),Ft=on(async()=>{if(!(gt||$.status!=="ready")){if(R||ee.length===0){te("Please wait for resources to load before pasting images.");return}te("Reading clipboard..."),Ee(!0);try{let i=await An();if(i){let x=`clipboard-${Date.now()}.png`;te(`Uploading: ${x} (${Math.round(i.buffer.length/1024)}KB)`),await xe({buffer:i.buffer,filename:x,mimeType:i.mime})}else te("No image found in clipboard. Copy an image first.")}catch(i){let x=i instanceof Error?i.message:"Failed to read clipboard";te(`Clipboard error: ${x}`)}finally{Ee(!1)}}},[xe,te,gt,$.status,R,ee.length]),{suggestions:nt,suggestionIndex:Ve,showSuggestions:Le,argMode:ye,argItems:ze,argIndex:Xe,selectedConnectorIds:we,selectedCapabilities:Se,deleteConfirmMode:Ne,handleInputChange:Ge,handleSubmit:ht}=eo({input:b,setInput:E,taskId:A,setTaskId:W,currentTaskTitle:Z,setCurrentTaskTitle:j,currentModel:H,setCurrentModel:V,currentAgentId:oe,setCurrentAgentId:F,currentAgentDetails:u,setCurrentAgentDetails:()=>{},activeConnectorIds:S,setActiveConnectorIds:N,fileSystem:m,setFileSystem:_,availableModels:M,availableAgents:Q,availableConnectors:D,messages:Y,hasPersistedTask:K,setHasPersistedTask:le,setMessages:T,addSystemMessage:te,startNewTask:Re,sendMessage:mt,setFullOutput:fe,credentials:l,setCredentials:d,setState:v,defaultCapabilities:{fileSystem:p},capabilityLabelMap:ce,hasUploadingFiles:Lt});if(tn((i,x)=>{(x.ctrl||x.meta)&&i==="v"&&Ft()},{isActive:$.status==="ready"&&!ye}),tn((i,x)=>{if(!x.escape)return;let J=Date.now(),re=g.current;g.current=J,!(!re||J-re>sr)&&(ye||Le||(g.current=null,ve&&pt(),b.length>0&&Ge("")))},{isActive:$.status==="ready"}),tn((i,x)=>{x.return&&(Re("Started a new task."),v({status:"ready"}))},{isActive:$.status==="error"}),Et(()=>{if(l&&!R&&$.status==="loading")if(!H&&!oe){let i=de.getDefaultModel(),x=i&&M.some(re=>re.id===i),J=x?i:M[0]?.id;J?(x||de.setDefaultModel(J),V(J),v({status:"ready"})):Q.length===0?v({status:"no-model"}):v({status:"ready"})}else v({status:"ready"})},[l,R,H,oe,M,Q,$.status,V,v]),Et(()=>{n&&l&&$.status==="ready"&&mt(n)},[l,n]),$.status==="loading")return se(he,{flexDirection:"column",children:[q(B,{children:y}),se(he,{children:[q(B,{color:"cyan",children:q(nn,{type:"dots"})}),q(B,{children:" Initializing task..."})]})]});if($.status==="not-logged-in")return se(he,{flexDirection:"column",children:[q(B,{children:y}),q(B,{color:"yellow",children:"Not logged in"}),q(B,{dimColor:!0,children:"Run `entrydesk login` to authenticate first."})]});if($.status==="no-workspace")return se(he,{flexDirection:"column",children:[q(B,{children:y}),q(B,{color:"yellow",children:"No workspace selected"}),q(B,{dimColor:!0,children:"Run `entrydesk workspaces` to select a workspace first."})]});if($.status==="no-model")return se(he,{flexDirection:"column",children:[q(B,{children:y}),q(B,{color:"yellow",children:"No model or agent specified"}),r&&q(B,{dimColor:!0,children:"Could not determine the model used in this task."}),q(B,{dimColor:!0,children:"Please specify a model with --model or use an agent with -a."}),q(B,{dimColor:!0,children:"Example: entrydesk task -c 1 -i --model gemini-2.5-flash-lite"})]});if($.status==="error")return se(he,{flexDirection:"column",children:[q(B,{children:y}),se(B,{color:"red",children:["Error: ",$.message]}),q(B,{dimColor:!0,children:"Press Enter to start a new task, or Ctrl+C to exit"})]});let ot=oe?u?u.connectors&&u.connectors.length>0?u.connectors.map(i=>i.name).join(", "):"none":"loading...":S&&S.length>0?D.filter(i=>S.includes(i.id)).map(i=>i.name).join(", ")||`${S.length} connector(s)`:"none",qe=[];if(oe)if(u?.capabilities)for(let i of u.capabilities)qe.push(ce.get(i)??i);else qe.push("loading...");m&&qe.push("FileSystem");let k=ie.getCurrentProfileName(),f=k!=="default",o=(()=>{switch(ye){case"model":return"Select model:";case"agent":return"Select agent:";case"skills":return"Select skill:";case"connectors":return"Select connectors:";case"capabilities":return"Select capabilities:";default:return"Select task:"}})(),s=(()=>{if(ye==="connectors")return we;if(ye==="capabilities")return Se})();return se(he,{flexDirection:"column",children:[se(he,{marginBottom:1,flexDirection:"column",children:[q(B,{children:y}),se(he,{children:[q(B,{bold:!0,color:"cyan",children:Z?`Continuing: ${Z}`:"EntryDesk CLI"}),se(B,{dimColor:!0,children:[" v","1.12.12"]}),f&&se(B,{color:"magenta",children:[" [",k,"]"]}),q(B,{dimColor:!0,children:" (type /help for commands)"})]})]}),Y.map((i,x)=>{let J=i.parts&&C?Ke(i.parts,!0):i.content,re=i.role==="user"?"green":i.role==="system"?"yellow":"blue",be=i.role==="user"?"You":i.role==="system"?"System":"Assistant";return se(he,{flexDirection:"column",marginBottom:1,children:[se(B,{bold:!0,color:re,children:[be,":"]}),q(zt,{text:J})]},x)}),P&&se(he,{flexDirection:"column",marginBottom:1,children:[q(B,{bold:!0,color:"blue",children:"Assistant:"}),q(zt,{text:P})]}),$.status==="ready"&&q(gn,{suggestions:nt,activeIndex:Ve,visible:Le}),$.status==="ready"&&ye&&q(mn,{items:ze,activeIndex:Xe,pageSize:ye==="agent"||ye==="skills"||ye==="model"?5:10,selectedIds:s,multiSelect:ye==="connectors"||ye==="capabilities",visible:!0,title:o}),$.status==="sending"&&!P?se(he,{children:[q(B,{color:"cyan",children:q(nn,{type:"dots"})}),q(B,{children:" Thinking..."})]}):$.status==="ready"&&!ye?se(he,{flexDirection:"column",children:[Ne&&q(he,{marginBottom:1,children:q(B,{color:"yellow",children:"\u26A0\uFE0F Delete this task? (y/N) "})}),ve&&!Ne&&se(he,{marginBottom:1,flexDirection:"row",gap:1,children:[q(B,{dimColor:!0,children:"Attachments:"}),G.map((i,x)=>se(B,{children:[i.status==="uploading"?se(B,{color:"yellow",children:[q(nn,{type:"dots"})," ",i.filename]}):i.status==="error"?se(B,{color:"red",children:["\u2717 ",i.filename]}):se(B,{color:"green",children:["\u2713 ",i.filename]}),x<G.length-1&&q(B,{children:", "})]},i.id))]}),se(he,{children:[q(B,{color:"green",children:"> "}),q(bn,{value:b,onChange:Ge,onSubmit:ht,onPaste:je,leadingOffset:2,multiline:!0})]})]}):null,se(he,{marginTop:1,flexDirection:"column",children:[se(he,{gap:2,children:[se(B,{children:[q(B,{dimColor:!0,children:"Model: "}),q(B,{color:"magenta",children:oe?u?.model?.name||"loading...":M.find(i=>i.id===H)?.name||H||"none"})]}),se(B,{children:[q(B,{dimColor:!0,children:"Connectors: "}),q(B,{color:"cyan",children:ot})]}),se(B,{children:[q(B,{dimColor:!0,children:"Capabilities: "}),q(B,{color:"green",children:qe.length>0?qe.join(", "):"none"})]})]}),se(B,{dimColor:!0,children:["Esc Esc: Clear input & attachments | Ctrl+V: Paste image | Ctrl+O: Toggle full output ",C?"(ON)":"(OFF)"," | Ctrl+C: Exit"]})]})]})}import{jsx as mr}from"react/jsx-runtime";async function ur(){let e=[];for await(let t of process.stdin)e.push(t);return Buffer.concat(e).toString("utf8").trim()}async function dr(e,t,n,r){if(r<1)return console.error("Task number must be 1 or greater"),null;let{tasks:a}=await e.getTasks(t,n,20);if(a.length===0)return console.error("No tasks found. Start a new task first."),null;if(r>a.length)return console.error(`Task number ${r} not found. You have ${a.length} recent tasks.`),console.error("Use `entrydesk tasks` to see available tasks."),null;let c=a[r-1],p;if(!c.agentId){let{messages:h}=await e.getMessages(t,n,c.id,10);p=h.find(g=>g.role==="assistant"&&g.modelId)?.modelId}return{task:c,modelId:p}}var tt="\x1B[2m",ke="\x1B[0m",rn="\x1B[36m",lo="\x1B[33m",At="\x1B[32m",so="stream-json";function fr(e,t,n,r){e&&t&&(console.error(`Error: Cannot use both ${n} and ${r}`),process.exit(1))}function Dt(e,t){let n=t===void 0?{event:e}:{event:e,data:t};process.stdout.write(`${JSON.stringify(n)}
166
- `)}function Rt(e,t){if(t)return e;let n=e.split(`
167
- `);if(n.length<=20)return e;let r=n.slice(0,5),a=n.slice(-5),c=n.length-10;return[...r,`${tt}... (${c} lines omitted, use --full-output to see all) ...${ke}`,...a].join(`
168
- `)}function pr(e){try{return JSON.stringify(e,null,2)}catch{return String(e)}}function io(e,t){if(!e)return"(no result)";if(typeof e!="object")return Rt(String(e),t);let n=e;if("structuredContent"in n&&n.structuredContent){let r=n.structuredContent,a=[];if(r.stdout&&typeof r.stdout=="string"&&r.stdout.trim()&&a.push(r.stdout.trim()),r.stderr&&typeof r.stderr=="string"&&r.stderr.trim()&&a.push(`${lo}[stderr]${ke} ${r.stderr.trim()}`),r.urls&&Array.isArray(r.urls)){let c=r.urls;for(let p of c)p.path&&p.url&&a.push(`${p.path}: ${p.url}`)}return a.length===0&&a.push(JSON.stringify(r,null,2)),Rt(a.join(`
169
- `),t)}if("content"in n&&Array.isArray(n.content)){let a=n.content.filter(c=>c.type==="text"&&c.text).map(c=>c.text).join(`
170
- `);return Rt(a||JSON.stringify(e,null,2),t)}return Rt(JSON.stringify(e,null,2),t)}async function _i(e){let t,n;try{let D=await We();t=D.accessToken,n=D.workspaceId}catch(D){an(D)}let r=e.output===so;e.output&&!r&&(console.error(`Invalid --output value. Supported: ${so}`),process.exit(1));let a=!r&&(e.plain||!process.stdout.isTTY),c=de.getDefaultModel(),p=e.message;!p&&!process.stdin.isTTY&&(p=await ur());let h=new pe;async function y(){if(!c)try{let{models:D}=await h.getModels(t,n),M=D[0]?.id;if(!M)return;de.setDefaultModel(M),c=M}catch{}}let g,O,$,v;if(e.continue){let D=await dr(h,t,n,e.continue);D||process.exit(1),g=D.task.id,O=D.task.title??void 0,$=D.task.agentId??void 0,v=D.modelId;let M=e.agentId||e.model||$||v||c;!M&&!e.interactive&&(await y(),M=e.agentId||e.model||$||v||c),!M&&!e.interactive&&(a||console.log(`Continuing task: ${D.task.title||"Untitled"}`),console.error(`
171
- Could not determine model for this task. Please specify --model or -a.`),console.error('Example: entrydesk task -c 1 -m "message" --model gemini-2.5-flash-lite'),process.exit(1)),!a&&!e.interactive&&console.log(`Continuing task: ${D.task.title||"Untitled"}
172
- `)}let Y=e.agentId||$,T=e.model||v||c||void 0;!Y&&!T&&(await y(),T=e.model||v||c||void 0),fr(e.fileSystem,e.noFileSystem,"--file-system","--no-file-system");let b=de.getDefaultConnectorIds(),E=e.connectors??b??void 0,A=de.getLocalTools(),W=e.noFileSystem?!1:e.fileSystem?!0:A?.fileSystem??!0;if(e.interactive){cr(mr(ro,{agentId:Y,model:T,message:e.message,taskId:g,taskTitle:O??void 0,connectorIds:E,enableFileSystem:W}),{exitOnCtrlC:!1});return}let Z=!e.continue&&!T&&!Y;(!p||Z)&&(console.error("Usage: entrydesk task -m <message> --model <model>"),console.error(" entrydesk task -m <message> -a <agent>"),console.error(" entrydesk task -c <number> -m <message>"),console.error(' echo "message" | entrydesk task --model <model>'),console.error(" entrydesk task -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 task by number (1 = most recent)"),console.error(" -i Interactive mode"),console.error(" --plain Plain text output (no colors/formatting)"),console.error(" --output stream-json Stream JSON events (for scripting)"),console.error(" --full-output Show full tool results without truncation"),console.error(" --dangerously-auto-approve-tools"),console.error(" Auto-approve all server-side tool calls (required for"),console.error(" non-interactive use with connectors/MCP tools)"),console.error(""),console.error("List available models: entrydesk models"),console.error("List available agents: entrydesk agents"),console.error("List recent tasks: entrydesk tasks"),process.exit(1));let j=e.fullOutput??!1,K=e.dangerouslyAutoApproveTools??!1,le=g||Nt(),l=W?xt():void 0,d=W?wt():void 0,P=[],U=Nt(),C=(D,M,Q)=>{let ee={id:le,...K&&{toolApprovalMode:"allow_always"}};return D&&(ee.message={id:D.id,createdAt:new Date,role:"user",parts:[{type:"text",text:D.text}]}),Y?ee.agentId=Y:(T&&(ee.model=T),ee.connectorIds=E??[]),l&&(ee.clientTools=l),d&&(ee.clientToolSystemPrompt=d),M&&M.length>0&&(ee.clientToolResults=M),Q&&Q.length>0&&(ee.previousMessages=Q),ee},fe=async D=>{if(!D.body)throw new Error("No response body");let M=D.body.getReader(),Q=new TextDecoder,ee="",R=new Map,H=[],V=[];for(;;){let{done:oe,value:F}=await M.read();if(oe)break;ee+=Q.decode(F,{stream:!0});let S=ee.split(`
173
- `);ee=S.pop()||"";for(let N of S){let I=N.trimEnd();if(I==="data: [DONE]"){r&&Dt("done");continue}if(I.startsWith("data: "))try{let u=JSON.parse(I.slice(6));if(u.type&&V.push(u),r){u.type==="text-delta"&&u.delta!==void 0?Dt("text-delta",u.delta):u.type==="reasoning-delta"&&u.delta!==void 0?Dt("reasoning-delta",u.delta):Dt(u.type||"event",u);continue}if(a){if(u.type==="text-delta"&&u.delta&&process.stdout.write(u.delta),W&&(u.type==="tool-input-available"||u.type==="tool-call")&&u.toolCallId&&u.toolName&&Be(u.toolName)){let m=u.args||u.input||{};H.push({toolCallId:u.toolCallId,toolName:u.toolName,args:m})}continue}switch(u.type){case"reasoning-delta":u.delta&&process.stdout.write(`${tt}${u.delta}${ke}`);break;case"reasoning-end":process.stdout.write(`
174
-
175
- `);break;case"text-delta":u.delta&&process.stdout.write(u.delta);break;case"tool-call-streaming-start":case"tool-input-start":if(u.toolCallId&&u.toolName){R.set(u.toolCallId,{toolName:u.toolName});let _=W&&Be(u.toolName)?`${At}[LOCAL]${ke} `:"";console.log(`
176
- ${rn}\u250C\u2500 ${_}Tool Call: ${u.toolName}${ke}`)}break;case"tool-call":case"tool-input-available":if(u.toolCallId&&u.toolName){let m=u.args||u.input||{},_=pr(m);console.log(`${lo}\u2502 Arguments:${ke}`);for(let ce of _.split(`
177
- `))console.log(`${tt}\u2502 ${ce}${ke}`);W&&Be(u.toolName)&&(R.set(u.toolCallId,{toolName:u.toolName,args:m}),H.push({toolCallId:u.toolCallId,toolName:u.toolName,args:m}))}break;case"tool-result":if(u.toolCallId){let m=R.get(u.toolCallId),_=io(u.result,j);console.log(`${At}\u2502 Result:${ke}`);for(let ce of _.split(`
178
- `))console.log(`${tt}\u2502 ${ce}${ke}`);console.log(`${rn}\u2514\u2500 ${m?.toolName||"Tool"} completed${ke}
179
- `),R.delete(u.toolCallId)}break;case"error":u.errorText&&console.error(`${tt}Error: ${u.errorText}${ke}`);break}}catch{}}}return{pendingClientTools:H,messageParts:V}},te=C({id:Nt(),text:p}),w=await h.task(t,n,te),L=await fe(w);for(P=L.messageParts;L.pendingClientTools.length>0;){let D=[];for(let R of L.pendingClientTools){!a&&!r&&console.log(`${At}\u2502 Executing locally...${ke}`);let H=await Tt(R.toolName,R.args),V=H.success?JSON.stringify(H.result):H.error||"Unknown error";if(D.push({toolCallId:R.toolCallId,toolName:R.toolName,content:[{type:"text",text:V}],isError:!H.success}),!a&&!r){let oe=io(H.success?H.result:{error:H.error},j);console.log(`${At}\u2502 Result:${ke}`);for(let F of oe.split(`
180
- `))console.log(`${tt}\u2502 ${F}${ke}`);console.log(`${rn}\u2514\u2500 ${R.toolName} completed${ke}
181
- `)}}let M=P.map(R=>{if(R.type==="tool-call"){let H=D.find(oe=>oe.toolCallId===R.toolCallId),V=H?.content.filter(oe=>oe.type==="text").map(oe=>oe.text).join(`
182
- `);return{type:"tool-invocation",toolCallId:R.toolCallId,toolName:R.toolName,args:R.args,state:H?.isError?"output-error":"output-available",output:V}}return R}),Q=[{id:U,role:"assistant",parts:M}];U=Nt();let ee=C(void 0,D,Q);w=await h.task(t,n,ee),L=await fe(w),P=L.messageParts}r||console.log("")}export{_i as runTask};
@@ -1,2 +0,0 @@
1
- #!/usr/bin/env node
2
- function n(){console.log("entrydesk 1.12.12")}export{n as printVersion};