@entrydesk/cli 1.12.10 → 1.12.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{agents-JIUI3AMN.js → agents-54AYFONZ.js} +1 -1
- package/dist/{budget-ZS62YFLV.js → budget-U7PCUVLC.js} +1 -1
- package/dist/chunk-6A4DXLDW.js +2 -0
- package/dist/{config-SRMFYUWZ.js → config-D5TRCK7Z.js} +1 -1
- package/dist/{config-656Q2CYI.js → config-LJMAX7PD.js} +1 -1
- package/dist/{config-help-A3SFYA5J.js → config-help-WSX3YYVB.js} +1 -1
- package/dist/{connectors-7MAJRU23.js → connectors-FBIGY7P4.js} +1 -1
- package/dist/index.js +1 -1
- package/dist/login-XTZVZRUS.js +2 -0
- package/dist/{logout-5RYWVJB7.js → logout-5JLCRCFI.js} +1 -1
- package/dist/{mcp-TEQ5OG54.js → mcp-ZBXLO5XO.js} +1 -1
- package/dist/{models-RAY2SDIG.js → models-2UVRAIOT.js} +1 -1
- package/dist/{profile-GIMVZVTN.js → profile-JOW6Z7HB.js} +1 -1
- package/dist/{schedules-V4GZMIQH.js → schedules-4WWXQIGY.js} +1 -1
- package/dist/{skills-S4BUOM6W.js → skills-EIODYDTC.js} +1 -1
- package/dist/status-55CKVYTS.js +2 -0
- package/dist/{task-QEJKOL2J.js → task-SGPVI3GJ.js} +2 -2
- package/dist/{tasks-IQ2ROLNI.js → tasks-BZYMJWPS.js} +1 -1
- package/dist/{tool-QE6Z7JSM.js → tool-O3EZWZRD.js} +1 -1
- package/dist/{usage-HTEP7M6I.js → usage-5H6DM7VO.js} +1 -1
- package/dist/version-EYTN3MAV.js +2 -0
- package/dist/{workspaces-N2BAAA6Y.js → workspaces-H4RBN3TB.js} +1 -1
- package/package.json +2 -2
- package/dist/chunk-J4SE76WA.js +0 -2
- package/dist/login-LQCQLVLQ.js +0 -2
- package/dist/status-MV5E37GY.js +0 -2
- package/dist/version-X7JPRPHE.js +0 -2
|
@@ -0,0 +1,2 @@
|
|
|
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,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as f,b as s}from"./chunk-
|
|
2
|
+
import{a as f,b as s}from"./chunk-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:
|
|
3
3
|
`);for(let[g,u]of c)console.log(` ${g}=${u}`);console.log(`
|
|
4
4
|
Available keys: ${i.join(", ")}`);return}if(n==="get"){o||(console.error("Error: key is required for get action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1));let r=s.get(o);e.json?console.log(JSON.stringify({[o]:r??null})):console.log(r||"Not set");return}if(n==="set"){o||(console.error("Error: key is required for set action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),t||(console.error("Error: value is required for set action"),process.exit(1)),s.set(o,t),console.log(`Set ${o}=${t}`);return}if(n==="unset"){o||(console.error("Error: key is required for unset action"),process.exit(1)),l(o)||(console.error(`Error: Invalid key '${o}'. Valid keys: ${i.join(", ")}`),process.exit(1)),s.unset(o),console.log(`Unset ${o}`);return}console.error(`Unknown action: ${n}`),process.exit(1)}export{d as runConfig};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as a,d as b,e as c,f as d}from"./chunk-
|
|
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};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as i}from"./chunk-
|
|
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};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{h as c,
|
|
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}):
|
|
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,
|
|
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-EYTN3MAV.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-SGPVI3GJ.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-EYTN3MAV.js");s();break}default:{let{printHelp:s}=await import("./help-GFQ2C2W7.js");s();break}}}catch(s){f(s)}}h();
|
|
@@ -0,0 +1,2 @@
|
|
|
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};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{g as r,h as e,
|
|
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};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{c as m,g as u,
|
|
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}
|
|
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,
|
|
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}):
|
|
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,
|
|
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(`
|
|
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 S,
|
|
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(`
|
|
3
3
|
Usage: entrydesk skills [list|upload|delete|download] [options]
|
|
4
4
|
|
|
5
5
|
Commands:
|
|
@@ -0,0 +1,2 @@
|
|
|
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};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{a as ie,b as de,c as Bt,g as rt,h as pe,
|
|
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
3
|
|
|
4
4
|
You have access to filesystem tools that allow you to interact with the user's local filesystem.
|
|
5
5
|
|
|
@@ -162,7 +162,7 @@ ID: ${s.id}`)}}}else if(F==="connectors"){let o=Array.from(_);Y(o.length>0?o:voi
|
|
|
162
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
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
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.
|
|
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.11"]}),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
166
|
`)}function Rt(e,t){if(t)return e;let n=e.split(`
|
|
167
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
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(`
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{h as A,
|
|
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)}
|
|
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,
|
|
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+=`
|
|
3
3
|
Tip: jq -r '.structuredContent.field' <file> | grep/head/tail`),`${o}
|
|
4
4
|
|
|
5
5
|
${u}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@entrydesk/cli",
|
|
3
|
-
"version": "1.12.
|
|
3
|
+
"version": "1.12.11",
|
|
4
4
|
"description": "EntryDesk CLI - Interact with EntryDesk from your terminal",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -19,7 +19,7 @@
|
|
|
19
19
|
"ink-spinner": "^5.0.0",
|
|
20
20
|
"jose": "^6.1.3",
|
|
21
21
|
"ky": "^2.0.2",
|
|
22
|
-
"react": "^19.2.
|
|
22
|
+
"react": "^19.2.7",
|
|
23
23
|
"uuid": "^14.0.0"
|
|
24
24
|
},
|
|
25
25
|
"devDependencies": {
|
package/dist/chunk-J4SE76WA.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import $ from"fs";import p from"fs";import Ie from"os";import T from"path";import{HTTPError as De,TimeoutError as Ue}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",Z={keychain:!1,permissions:!1,corruptFile:!1,windowsFile:!1};function w(r,e){Z[r]||(Z[r]=!0,console.error(e))}function ye(){return process.env.ENTRYDESK_DEBUG?.toLowerCase()==="true"}function Q(r){if(!r||typeof r!="object")return!1;let e=r;return!(!("accessToken"in e||"refreshToken"in e||"email"in e||"workspaceId"in e)||"accessToken"in e&&typeof e.accessToken!="string"||"refreshToken"in e&&typeof e.refreshToken!="string"||"email"in e&&typeof e.email!="string"||"workspaceId"in e&&typeof e.workspaceId!="string")}function 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 O(r){return o.getProfileCredentialsFile(r)}var N=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 Q(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=O(e);try{if(!u.existsSync(t))return null;let s=u.readFileSync(t,"utf-8").trim();if(!s)return null;let n=this.loadEncryptionKey(e),i=n?this.tryDecrypt(s,n):null;if(i){let c=this.tryParseCredentials(i);if(c)return c}return 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=O(e),n=this.getOrCreateEncryptionKey(e),i=this.encrypt(JSON.stringify(t),n);u.writeFileSync(s,i,{mode:384}),this.ensureSecureFilePermissions(s)}async deleteCredentials(e){let t=O(e);try{u.existsSync(t)&&u.unlinkSync(t)}catch{}}},M=class{keytarModule=null;keytarLoadAttempted=!1;keychainAvailable=null;async getKeytar(){if(this.keytarLoadAttempted)return this.keytarModule;this.keytarLoadAttempted=!0;try{let t=await import("keytar"),s=t&&typeof t=="object"&&"default"in t?t.default:t;this.keytarModule=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 Q(t)?t:null}catch{return null}}},j=class{keychainStorage=null;fileStorage=new N;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 M,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 j,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||K(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 i=await n.text();throw new Error(`Task API failed (${n.status}): ${i}`)}return n}catch(n){throw n instanceof we?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 z(){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 ee(){let r=process.env.ENTRYDESK_TOKEN?.trim();if(!r)return null;let e=process.env.ENTRYDESK_WORKSPACE_ID?.trim();if(!e)throw new Error("ENTRYDESK_TOKEN is set but ENTRYDESK_WORKSPACE_ID is missing. Both are required for PAT authentication.");return{accessToken:r,workspaceId:e}}import{execFile as 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 ct(r){let e=K(),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,q=new URL("/oauth/device",t);q.searchParams.set("user_code",d);let V=q.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 X=Math.max(ce,5)*1e3,le=Date.now()+ae*1e3;for(;Date.now()<le;){await Ae(X);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(F=>F.length>0)}}catch(a){if(a instanceof Te){let{code:F,error:ge}=te(a.data),B=F||ge;if(!B)continue;switch(B){case"authorization_pending":continue;case"slow_down":X+=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: ${B||"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 Ke(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(!Ke(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 pt(){let r=z();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 ht(){let r=z();if(r)return{accessToken:r.accessToken,workspaceId:r.workspaceId};let e=ee();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 Ue&&(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_-]+$/,L=null;function H(){return T.join(Ie.homedir(),".entrydesk")}function ie(){return T.join(H(),"profiles")}function oe(){return T.join(H(),"profiles.json")}function I(r){return T.join(ie(),r)}function Y(r){if(!p.existsSync(r))p.mkdirSync(r,{mode:448,recursive:!0});else try{p.chmodSync(r,448)}catch{}}function Fe(){Y(H())}function W(){Y(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){W(),Y(I(r))}function v(){let r=Be();if(!r){let t={currentProfile:P,profiles:[P]};return C(t),W(),x(P),t}let e=Oe(r);return(e.currentProfile!==r.currentProfile||e.profiles.length!==r.profiles.length)&&C(e),W(),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){L=r},getOverrideProfile(){return L},getProfileDir(r){return I(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||L||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=I(r),n=I(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(!$.existsSync(e))return{};let t=$.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);$.writeFileSync(s,JSON.stringify(r,null,2),{mode:384});try{$.chmodSync(s,384)}catch{}}var G={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 J(r){return{apiUrl:G.getApiUrl(r)||process.env.ENTRYDESK_API_URL||Me,hubUrl:G.getHubUrl(r)||process.env.ENTRYDESK_HUB_URL||je,mcp:{httpPort:ze},auth:{loginTimeout:Le,ignoreSslErrors:process.env.ENTRYDESK_IGNORE_SSL_ERRORS==="true"||!1}}}function K(r){return J(r).apiUrl}function re(r){return J(r).hubUrl}function D(){return J().auth}export{o as a,G as b,J as c,K as d,re as e,D as f,h as g,_ as h,te as i,U as j,ct as k,y as l,Ke as m,se as n,pt as o,ht as p,f as q,wt as r};
|
package/dist/login-LQCQLVLQ.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import{g as l,h as c,k as t}from"./chunk-J4SE76WA.js";async function m(e){if(process.env.DEBUG){let{getApiUrl:i,getHubUrl:s}=await import("./config-656Q2CYI.js");console.log(`[DEBUG] Hub URL: ${s()}`),console.log(`[DEBUG] API URL: ${i()}`)}let o=await t({onDeviceCodeReceived:(i,s)=>{e.json||(console.log(""),console.log("To authenticate, please:"),console.log(""),console.log(` 1. Visit: ${s}`),console.log(` 2. Enter code: ${i}`),console.log(""))},onBrowserOpening:()=>{e.json||console.log("Opening browser...")},onWaitingForAuthorization:()=>{e.json||console.log("Waiting for authorization...")},onAuthorized:()=>{e.json||console.log("Authorization successful!")}}),r=new c,{workspaces:a}=await r.getWorkspaces(o.accessToken),n=a[0];await l.saveAll({accessToken:o.accessToken,refreshToken:o.refreshToken,email:o.email,workspaceId:n?.id}),e.json?console.log(JSON.stringify({email:o.email,workspaceId:n?.id,workspaceName:n?.name})):(console.log(`Logged in as ${o.email}`),n&&console.log(`Workspace: ${n.name}`))}export{m as runLogin};
|
package/dist/status-MV5E37GY.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
import{a as i,b as l,g as c,h as a,l as g,o as f,r as p}from"./chunk-J4SE76WA.js";async function A(r){try{let o=i.getEffectiveProfileName(),e=await c.getAll(),n={model:l.getDefaultModel(),connectors:l.getDefaultConnectorIds()};if(!e){r.json?console.log(JSON.stringify({loggedIn:!1,profile:o,defaults:n})):(console.log(`Profile: ${o}`),console.log("Not logged in"),console.log("Run `entrydesk login` to authenticate"));return}let t;if(e.workspaceId)try{let s=new a,d=await f(),{workspaces:m}=await s.getWorkspaces(d);t=m.find(k=>k.id===e.workspaceId)?.name}catch(s){if(s instanceof g){r.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}}r.json?console.log(JSON.stringify({loggedIn:!0,profile:o,email:e.email,workspaceId:e.workspaceId,workspaceName:t,defaults:n})):(console.log(`Profile: ${o}`),console.log(`Logged in as ${e.email}`),t&&console.log(`Workspace: ${t}`),e.workspaceId&&console.log(`Workspace ID: ${e.workspaceId}`))}catch(o){p(o)}}export{A as runStatus};
|
package/dist/version-X7JPRPHE.js
DELETED