@ecodrix/erix-api 1.0.5 → 1.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +1 -1
- package/dist/index.d.ts +10 -0
- package/dist/ts/browser/index.global.js +1 -1
- package/dist/ts/browser/index.global.js.map +1 -1
- package/dist/ts/cjs/index.cjs +1 -1
- package/dist/ts/cjs/index.cjs.map +1 -1
- package/dist/ts/cjs/index.d.cts +10 -0
- package/dist/ts/esm/index.d.ts +10 -0
- package/dist/ts/esm/index.js +1 -1
- package/dist/ts/esm/index.js.map +1 -1
- package/package.json +1 -1
- package/src/core.ts +14 -0
package/dist/cli.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import ae from"repl";import{Command as ne}from"commander";import re from"dotenv";import o from"picocolors";import se from"axios";import Q from"axios-retry";import{io as te}from"socket.io-client";var V=class extends Error{constructor(e){super(e),this.name="EcodrixError"}},u=class extends V{status;code;constructor(e,s,n){super(e),this.name="APIError",this.status=s,this.code=n}},T=class extends u{constructor(e="Invalid API Key or Client Code"){super(e,401,"AUTH_FAILED"),this.name="AuthenticationError"}};var r=class{constructor(e){this.client=e}async post(e,s,n){try{let t=this.buildConfig(n);return(await this.client.post(e,s,t)).data}catch(t){this.handleError(t)}}async get(e,s){try{let n=this.buildConfig(s);return(await this.client.get(e,n)).data}catch(n){this.handleError(n)}}async patch(e,s,n){try{let t=this.buildConfig(n);return(await this.client.patch(e,s,t)).data}catch(t){this.handleError(t)}}async put(e,s,n){try{let t=this.buildConfig(n);return(await this.client.put(e,s,t)).data}catch(t){this.handleError(t)}}async deleteRequest(e,s){try{let n=this.buildConfig(s);return(await this.client.delete(e,n)).data}catch(n){this.handleError(n)}}buildConfig(e){if(!e)return;let s={...e};return e.idempotencyKey&&(s.headers={...s.headers,"Idempotency-Key":e.idempotencyKey}),s}handleError(e){throw e.response?new u(e.response.data?.message||e.response.data?.error||"API Request Failed",e.response.status,e.response.data?.code):new u(e.message||"Network Error")}};var H=class extends r{async list(e){return this.get(`/api/saas/crm/leads/${e}/notes`)}async create(e,s){return this.post(`/api/saas/crm/leads/${e}/notes`,s)}async update(e,s){return this.patch(`/api/saas/crm/notes/${e}`,{content:s})}async pin(e,s=!0){return this.patch(`/api/saas/crm/notes/${e}/pin`,{isPinned:s})}async delete(e){return this.deleteRequest(`/api/saas/crm/notes/${e}`)}},f=class extends r{notes;constructor(e){super(e),this.notes=new H(e)}async timeline(e,s){return this.get(`/api/saas/crm/leads/${e}/timeline`,{params:s})}async list(e,s){return this.get("/api/saas/crm/activities",{params:{leadId:e,...s}})}async log(e){return this.post("/api/saas/crm/activities",e)}async logCall(e,s){return this.post(`/api/saas/crm/leads/${e}/calls`,s)}};var b=class extends r{async overview(e){return this.get("/api/saas/crm/analytics/overview",{params:e})}async funnel(e){return this.get("/api/saas/crm/analytics/funnel",{params:{pipelineId:e}})}async forecast(e){return this.get("/api/saas/crm/analytics/forecast",{params:{pipelineId:e}})}async sources(e){return this.get("/api/saas/crm/analytics/sources",{params:e})}async team(e){return this.get("/api/saas/crm/analytics/team",{params:e})}async heatmap(e){return this.get("/api/saas/crm/analytics/heatmap",{params:e})}async scores(){return this.get("/api/saas/crm/analytics/scores")}async stageTime(e){return this.get("/api/saas/crm/analytics/stage-time",{params:{pipelineId:e}})}async tiered(e){return this.get("/api/saas/crm/analytics/tiered",{params:e})}async summary(e){return this.get("/api/saas/crm/analytics/summary",{params:e})}async whatsapp(e){return this.get("/api/saas/crm/analytics/whatsapp",{params:e})}};var x=class extends r{async stats(){return this.get("/api/saas/crm/automation/stats")}async logs(e){return this.get("/api/saas/crm/automation/logs",{params:e})}async retryFailedEvent(e){return this.post(`/api/saas/crm/automation/logs/${e}/retry`,{})}};var v=class extends r{async list(){return this.get("/api/saas/crm/automations")}async create(e){return this.post("/api/saas/crm/automations",e)}async update(e,s){return this.patch(`/api/saas/crm/automations/${e}`,s)}async toggle(e){return this.patch(`/api/saas/crm/automations/${e}/toggle`)}async deleteRule(e){return this.deleteRequest(`/api/saas/crm/automations/${e}`)}async bulkDelete(e){return this.post("/api/saas/crm/automations/bulk-delete",{ids:e})}async test(e,s){return this.post(`/api/saas/crm/automations/${e}/test`,{leadId:s})}async getAvailableEvents(){return this.post("/api/saas/crm/automations/events",{})}async enrollments(e,s){return this.get(`/api/saas/crm/automations/${e}/enrollments`,{params:s})}async getEnrollment(e){return this.get(`/api/saas/crm/automations/enrollments/${e}`)}async pauseEnrollment(e,s){return this.post(`/api/saas/crm/automations/${e}/enrollments/${s}/pause`,{})}async resumeEnrollment(e,s){return this.post(`/api/saas/crm/automations/${e}/enrollments/${s}/resume`,{})}async runs(e){return this.get(`/api/saas/crm/automations/${e}/runs`)}async getRun(e){return this.get(`/api/saas/crm/automations/runs/${e}`)}async resumeRun(e){return this.post(`/api/saas/crm/automations/runs/${e}/resume`,{})}async abortRun(e){return this.post(`/api/saas/crm/automations/runs/${e}/abort`,{})}async webhookEvent(e,s,n){return this.post("/api/saas/crm/webhook-event",{ruleId:e,eventName:s,payload:n})}};var w=class extends r{async create(e){return this.post("/api/services/leads",e)}async upsert(e){return this.post("/api/services/leads/upsert",e)}async createMany(e,s=50){let n=[];for(let t=0;t<e.length;t+=s){let l=e.slice(t,t+s).map(g=>this.create(g)),m=await Promise.allSettled(l);for(let g of m)if(g.status==="fulfilled")n.push(g.value);else throw g.reason}return n}async import(e){return this.post("/api/services/leads/import",{leads:e})}async list(e){let s={...e};return Array.isArray(s.tags)&&(s.tags=s.tags.join(",")),this.get("/api/services/leads",{params:s})}async*listAutoPaging(e){let s=e?.page||1,n=!0;for(;n;){let t=await this.list({...e,page:s}),i=Array.isArray(t.data)?t.data:t||[];if(i.length===0){n=!1;break}for(let l of i)yield l;t.pagination&&s<t.pagination.pages||!t.pagination&&i.length>0?s++:n=!1}}async retrieve(e){return this.get(`/api/services/leads/${e}`)}async retrieveByPhone(e){return this.get(`/api/services/leads/phone/${encodeURIComponent(e)}`)}async retrieveByRef(e,s){return this.get(`/api/services/leads/ref/${encodeURIComponent(e)}/${encodeURIComponent(s)}`)}async update(e,s){return this.post(`/api/services/leads/${e}`,s)}async move(e,s){return this.patch(`/api/services/leads/${e}/move`,{stageId:s})}async convert(e,s,n){return this.post(`/api/services/leads/${e}/convert`,{outcome:s,reason:n})}async tags(e,s){return this.patch(`/api/services/leads/${e}/tags`,s)}async recalculateScore(e){return this.post(`/api/services/leads/${e}/score`,{})}async updateMetadata(e,s){return this.patch(`/api/services/leads/${e}/metadata`,s)}async fields(){return this.get("/api/services/leads/fields")}async delete(e){return this.deleteRequest(`/api/services/leads/${e}`)}async bulkDelete(e){return this.deleteRequest("/api/services/leads",{data:{ids:e}})}};var P=class extends r{async capture(e){return this.post("/api/saas/crm/payments/capture",e)}};var R=class extends r{async list(e){return this.get("/api/saas/crm/pipelines",{params:e})}async create(e){return this.post("/api/saas/crm/pipelines",e)}async retrieve(e){return this.get(`/api/saas/crm/pipelines/${e}`)}async update(e,s){return this.patch(`/api/saas/crm/pipelines/${e}`,s)}async setDefault(e){return this.post(`/api/saas/crm/pipelines/${e}/default`,{})}async duplicate(e,s){return this.post(`/api/saas/crm/pipelines/${e}/duplicate`,{newName:s})}async archive(e){return this.post(`/api/saas/crm/pipelines/${e}/archive`,{})}async delete(e){return this.deleteRequest(`/api/saas/crm/pipelines/${e}`)}async board(e){return this.get(`/api/saas/crm/pipelines/${e}/board`)}async forecast(e){return this.get(`/api/saas/crm/pipelines/${e}/forecast`)}async addStage(e,s){return this.post(`/api/saas/crm/pipelines/${e}/stages`,s)}async reorderStages(e,s){return this.put(`/api/saas/crm/pipelines/${e}/stages/reorder`,{order:s})}async updateStage(e,s){return this.patch(`/api/saas/crm/stages/${e}`,s)}async deleteStage(e,s){return this.deleteRequest(`/api/saas/crm/stages/${e}`,{data:s?{moveLeadsToStageId:s}:void 0})}};var $=class extends r{async getConfig(){return this.get("/api/saas/crm/scoring")}async updateConfig(e){return this.patch("/api/saas/crm/scoring",e)}async recalculate(e){return this.post(`/api/saas/crm/scoring/${e}/recalculate`,{})}};var I=class extends r{async enroll(e){return this.post("/api/saas/crm/sequences/enroll",e)}async unenroll(e){return this.deleteRequest(`/api/saas/crm/sequences/unenroll/${e}`)}async listForLead(e){return this.get(`/api/saas/crm/sequences/lead/${e}`)}};var C=class{leads;pipelines;activities;analytics;automations;sequences;scoring;payments;automationDashboard;constructor(e){this.leads=new w(e),this.pipelines=new R(e),this.activities=new f(e),this.analytics=new b(e),this.automations=new v(e),this.sequences=new I(e),this.scoring=new $(e),this.payments=new P(e),this.automationDashboard=new x(e)}};var A=class extends r{async sendEmailCampaign(e){return this.post("/api/saas/emails/campaign",e)}async sendTestEmail(e){return this.post("/api/saas/emails/test",{to:e})}};var S=class extends r{async list(){return this.get("/api/saas/events")}async assign(e){return this.post("/api/saas/events/assign",e)}async unassign(e){return this.post("/api/saas/events/unassign",{name:e})}async unassignBulk(e){return this.post("/api/saas/events/unassign/bulk",{names:e})}async trigger(e){return this.post("/api/saas/workflows/trigger",e)}async listCustomEvents(){return this.get("/api/saas/crm/custom-events")}async createCustomEvent(e){return this.post("/api/saas/crm/custom-events",e)}async deleteCustomEvent(e){return this.deleteRequest(`/api/saas/crm/custom-events/${e}`)}async emit(e){return this.post("/api/saas/crm/events/emit",e)}};var k=class extends r{async system(){return(await this.get("/api/saas/health",{headers:{accept:"application/json"}})).data}async clientHealth(){return(await this.get("/api/saas/health/client")).data}async jobStatus(e){return(await this.get(`/api/saas/jobs/status/${e}`)).data}};var j=class extends r{async sendCampaign(e){return this.post("/api/saas/marketing/emails/campaign",e)}async sendTest(e){return this.post("/api/saas/marketing/emails/test",{to:e})}},J=class extends r{async list(e){return this.get("/api/saas/marketing/campaigns",{params:e})}async create(e){return this.post("/api/saas/marketing/campaigns",e)}async retrieve(e){return this.get(`/api/saas/marketing/campaigns/${e}`)}async update(e,s){return this.patch(`/api/saas/marketing/campaigns/${e}`,s)}async delete(e){return this.deleteRequest(`/api/saas/marketing/campaigns/${e}`)}async send(e,s){return this.post(`/api/saas/marketing/campaigns/${e}/send`,s||{})}async stats(e){return this.get(`/api/saas/marketing/campaigns/${e}/stats`)}},Y=class extends r{async sendTemplate(e){return this.post("/api/saas/marketing/whatsapp/send-template",e)}},E=class extends r{emails;campaigns;whatsapp;constructor(e){super(e),this.emails=new j(e),this.campaigns=new J(e),this.whatsapp=new Y(e)}};import ee from"axios";var D=class extends r{async getUsage(){return this.get("/api/saas/storage/usage")}async createFolder(e){return this.post("/api/saas/storage/folders",{name:e})}async list(e,s){return this.get(`/api/saas/storage/files/${e}`,{params:s})}async delete(e){return this.deleteRequest("/api/saas/storage/files",{params:{key:e}})}async getDownloadUrl(e){return this.post("/api/saas/storage/download-url",{key:e})}async upload(e,s){let{data:n}=await this.client.post("/api/saas/storage/upload-url",s),{uploadUrl:t,key:i}=n;await ee.put(t,e,{headers:{"Content-Type":s.contentType}});let l=e.size||e.byteLength||0;return this.post("/api/saas/storage/confirm-upload",{key:i,sizeBytes:l})}};var L=class extends r{async create(e){return this.post("/api/saas/meet",e)}async list(e){return this.get("/api/saas/meet",{params:e})}async retrieve(e){return this.get(`/api/saas/meet/${e}`)}async update(e,s){return this.patch(`/api/saas/meet/${e}`,s)}async reschedule(e,s){return this.patch(`/api/saas/meet/${e}`,s)}async delete(e){return this.update(e,{status:"cancelled"})}};var q=class extends r{async listLogs(e){return this.get("/api/saas/events/logs",{params:e})}async retrieveLog(e){return this.get(`/api/saas/events/logs/${e}`)}async getStats(e){return this.get("/api/saas/events/stats",{params:e})}async listCallbacks(e){return this.get("/api/saas/callbacks/logs",{params:e})}async listAlerts(e){return this.get("/api/saas/crm/notifications",{params:e})}async dismissAlert(e){return this.patch(`/api/saas/crm/notifications/${e}/dismiss`)}async clearAllAlerts(){return this.deleteRequest("/api/saas/crm/notifications/clear-all")}async retryAction(e){return this.post(`/api/saas/crm/notifications/${e}/retry`,{})}};var O=class extends r{async listFailed(){return this.get("/api/saas/queue/failed")}async getStats(){return this.get("/api/saas/queue/stats")}async retryJob(e){return this.post(`/api/saas/queue/${e}/retry`,{})}async deleteJob(e){return this.deleteRequest(`/api/saas/queue/${e}`)}};var G=class extends r{async create(e){return this.post("/api/saas/storage/folders",{name:e})}async delete(e){return this.deleteRequest(`/api/saas/storage/folders/${encodeURIComponent(e)}`)}},z=class extends r{async list(e,s){return this.get(`/api/saas/storage/files/${e}`,{params:s})}async getUploadUrl(e){return this.post("/api/saas/storage/upload-url",e)}async confirmUpload(e){return this.post("/api/saas/storage/confirm-upload",e)}async getDownloadUrl(e){return this.post("/api/saas/storage/download-url",{key:e})}async delete(e){return this.deleteRequest("/api/saas/storage/files",{params:{key:e}})}},U=class extends r{folders;files;constructor(e){super(e),this.folders=new G(e),this.files=new z(e)}async usage(){return this.get("/api/saas/storage/usage")}};var h=class extends u{constructor(e){super(e,400,"invalid_signature"),this.name="WebhookSignatureError"}},M=class{async constructEvent(e,s,n){if(!s)throw new h("No webhook signature provided");let t=Array.isArray(s)?s[0]:s;t.startsWith("sha256=")&&(t=t.slice(7));try{let i=await import("crypto"),m=i.createHmac("sha256",n).update(e).digest("hex");if(!i.timingSafeEqual(Buffer.from(m),Buffer.from(t)))throw new h("Invalid webhook signature provided");return JSON.parse(e.toString("utf8"))}catch(i){throw i instanceof h?i:new h(`Webhook payload parsing failed: ${i.message}`)}}};var N=class extends r{async list(e){return this.get("/api/saas/chat/broadcasts",{params:e})}async create(e){return this.post("/api/saas/chat/broadcast",e)}};var _=class extends r{async list(e){return this.get("/api/saas/chat/conversations",{params:e})}async create(e){return this.post("/api/saas/chat/conversations",e)}async retrieve(e){return this.get(`/api/saas/chat/conversations/${e}`)}async messages(e,s){return this.get(`/api/saas/chat/conversations/${e}/messages`,{params:s})}async linkLead(e,s,n){return this.post(`/api/saas/chat/conversations/${e}/link-lead`,{leadId:s,leadData:n})}async markRead(e){return this.post(`/api/saas/chat/conversations/${e}/read`,{})}async delete(e){return this.deleteRequest(`/api/saas/chat/conversations/${e}`)}async bulkDelete(e){return this.post("/api/saas/chat/conversations/bulk-delete",{ids:e})}};var F=class extends r{async send(e){return this.post("/api/saas/chat/send",e)}async sendTemplate(e){return this.post("/api/saas/chat/send",{...e,templateLanguage:e.language||"en_US"})}async star(e,s){return this.post(`/api/saas/chat/messages/${e}/star`,{isStarred:s})}async react(e,s){return this.post(`/api/saas/chat/messages/${e}/react`,{reaction:s})}async markRead(e){return this.post(`/api/saas/chat/conversations/${e}/read`)}};var K=class extends r{async list(e){return this.get("/api/saas/whatsapp/templates",{params:e})}async sync(){return this.post("/api/saas/whatsapp/templates/sync",{})}async retrieve(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}`)}async create(e){return this.post("/api/saas/whatsapp/templates",e)}async update(e,s){return this.put(`/api/saas/whatsapp/templates/${e}`,s)}async deleteTemplate(e,s){return this.deleteRequest(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}${s?"?force=true":""}`)}async mappingConfig(){return this.get("/api/saas/whatsapp/templates/mapping/config")}async collections(){return this.get("/api/saas/whatsapp/templates/collections")}async collectionFields(e){return this.get(`/api/saas/whatsapp/templates/collections/${encodeURIComponent(e)}/fields`)}async updateMapping(e,s){return this.put(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/mapping`,s)}async validate(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/validate`)}async preview(e,s){return this.post(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/preview`,{context:s})}async checkUsage(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/usage`)}};var B=class extends r{messages;conversations;broadcasts;templates;constructor(e){super(e),this.messages=new F(e),this.conversations=new _(e),this.broadcasts=new N(e),this.templates=new K(e)}async upload(e,s){let n=new FormData;return n.append("file",e,s),this.post("/api/saas/whatsapp/upload",n,{headers:typeof n.getHeaders=="function"?n.getHeaders():void 0})}async sendTemplate(e){return this.post("/api/saas/whatsapp/send-template",e)}};var W=class{client;socket;whatsapp;crm;media;meet;notifications;email;events;webhooks;storage;marketing;health;queue;constructor(e){if(!e.apiKey)throw new T("API Key is required");let s=e.baseUrl||"https://api.ecodrix.com",n=e.socketUrl||s,t=typeof window<"u"&&typeof window.document<"u",i=t?"browser":typeof process<"u"?`node ${process.version}`:"unknown",l=t?globalThis.navigator?.userAgent||"browser":typeof process<"u"?process.platform:"unknown";this.client=se.create({baseURL:s,headers:{"x-api-key":e.apiKey,"x-client-code":e.clientCode?.toUpperCase(),"Content-Type":"application/json","x-ecodrix-client-agent":JSON.stringify({sdk_version:"1.0.0",runtime:i,os:l})}}),Q(this.client,{retries:3,retryDelay:Q.exponentialDelay,retryCondition:m=>Q.isNetworkOrIdempotentRequestError(m)||m.response?.status===429}),this.whatsapp=new B(this.client),this.crm=new C(this.client),this.media=new D(this.client),this.meet=new L(this.client),this.notifications=new q(this.client),this.email=new A(this.client),this.events=new S(this.client),this.webhooks=new M,this.storage=new U(this.client),this.marketing=new E(this.client),this.health=new k(this.client),this.queue=new O(this.client),this.socket=te(n,{extraHeaders:{"x-api-key":e.apiKey,"x-client-code":e.clientCode?.toUpperCase()||""}}),this.setupSocket(e.clientCode)}setupSocket(e){this.socket.on("connect",()=>{e&&this.socket.emit("join-room",e.toUpperCase())})}on(e,s){return this.socket.on(e,s),this}disconnect(){this.socket.disconnect()}async request(e,s,n,t){try{return(await this.client.request({method:e,url:s,data:n,params:t})).data}catch(i){throw i.response?new u(i.response.data?.message||i.response.data?.error||"Raw Execution Failed",i.response.status,i.response.data?.code):new u(i.message||"Network Error")}}};re.config();var X="1.0.5";var ie="Official Isomorphic SDK for the ECODrIx platform. Native support for WhatsApp, CRM, Storage, and Meetings across TS, JS, Python, and Java.",d=new ne;d.name("erix").description(ie).version(X);function y(a){let e=a.key||process.env.ECOD_API_KEY,s=a.client||process.env.ECOD_CLIENT_CODE;return e||(console.error(o.red("Error: API Key is missing.")),console.log(o.yellow("Set ECOD_API_KEY environment variable or use --key <key>")),process.exit(1)),new W({apiKey:e,clientCode:s,baseUrl:a.baseUrl||process.env.ECOD_BASE_URL})}d.option("-k, --key <key>","ECODrIx API Key").option("-c, --client <code...","Tenant Client Code").option("--base-url <url>","API Base URL override");d.command("whoami").description("Verify current authentication and tenant status").action(async(a,e)=>{let s=e.parent.opts(),n=y(s);console.log(o.cyan("Checking connection to ECODrIx Platform..."));try{let t=await n.request("GET","/api/saas/me/profile");console.log(o.green("\u2714 Authenticated successfully!")),console.log(`${o.bold("User ID:")} ${t.id}`),console.log(`${o.bold("Organisation:")} ${t.organisation?.name||"N/A"}`),s.client&&console.log(`${o.bold("Tenant Code:")} ${o.magenta(s.client)}`)}catch(t){console.error(o.red("\u2716 Authentication failed")),console.error(o.dim(t.message)),process.exit(1)}});var oe=d.command("whatsapp").description("WhatsApp Business API operations");oe.command("send-template").description("Send a WhatsApp template message").argument("<phone>","Recipient phone number").argument("<template>","Template name").option("-v, --vars <json>","Template variables as JSON string","[]").action(async(a,e,s,n)=>{let t=n.parent.parent.opts(),i=y(t);try{let l=JSON.parse(s.vars);console.log(o.cyan(`Sending template '${e}' to ${a}...`));let m=await i.whatsapp.messages.sendTemplate({to:a,templateName:e,language:"en_US",variables:l});console.log(o.green("\u2714 Message sent successfully!")),console.log(o.dim(`ID: ${m?.id||"N/A"}`))}catch(l){console.error(o.red("\u2716 Failed to send message")),console.error(o.dim(l.message))}});var Z=d.command("crm").description("CRM and Lead management");Z.command("leads").description("List recent leads").option("-l, --limit <number>","Number of leads to fetch","10").option("-s, --status <status>","Filter by lead status").option("-p, --pipeline <id>","Filter by pipeline ID").option("-q, --search <query>","Search by name or email").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{let t=Number.parseInt(a.limit);console.log(o.cyan(`Fetching last ${t} leads...`));let i={limit:t};a.status&&(i.status=a.status),a.pipeline&&(i.pipelineId=a.pipeline),a.search&&(i.search=a.search);let l=await n.crm.leads.list(i),m=Array.isArray(l.data)?l.data:Array.isArray(l)?l:[];if(m.length===0){console.log(o.yellow("No leads found."));return}console.table(m.map(g=>({ID:g.id||g._id,Name:`${g.firstName} ${g.lastName||""}`.trim(),Phone:g.phone,Status:g.status,Score:g.score||0,Created:new Date(g.createdAt).toLocaleDateString()})))}catch(t){console.error(o.red("\u2716 Failed to fetch leads")),console.error(o.dim(t.message))}});Z.command("pipelines").description("List all CRM pipelines").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{console.log(o.cyan("Fetching pipelines..."));let t=await n.crm.pipelines.list(),i=t.data||t||[];if(i.length===0){console.log(o.yellow("No pipelines found."));return}console.table(i.map(l=>({ID:l.id||l._id,Name:l.name,Default:l.isDefault?"Yes":"No",Stages:l.stages?.length||0})))}catch(t){console.error(o.red("\u2716 Failed to fetch pipelines")),console.error(o.dim(t.message))}});var ce=d.command("analytics").description("Business Intelligence Analytics");ce.command("overview").description("Get high-level CRM KPIs").option("-r, --range <range>","Date range (e.g., 24h, 7d, 30d, 365d)","30d").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{console.log(o.cyan(`Fetching overview metrics for last ${a.range}...`));let t=await n.crm.analytics.overview({range:a.range}),i=t.data||t;console.log(`
|
|
2
|
+
import ae from"repl";import{Command as ne}from"commander";import re from"dotenv";import o from"picocolors";import se from"axios";import Q from"axios-retry";import{io as te}from"socket.io-client";var V=class extends Error{constructor(e){super(e),this.name="EcodrixError"}},u=class extends V{status;code;constructor(e,s,n){super(e),this.name="APIError",this.status=s,this.code=n}},T=class extends u{constructor(e="Invalid API Key or Client Code"){super(e,401,"AUTH_FAILED"),this.name="AuthenticationError"}};var r=class{constructor(e){this.client=e}async post(e,s,n){try{let t=this.buildConfig(n);return(await this.client.post(e,s,t)).data}catch(t){this.handleError(t)}}async get(e,s){try{let n=this.buildConfig(s);return(await this.client.get(e,n)).data}catch(n){this.handleError(n)}}async patch(e,s,n){try{let t=this.buildConfig(n);return(await this.client.patch(e,s,t)).data}catch(t){this.handleError(t)}}async put(e,s,n){try{let t=this.buildConfig(n);return(await this.client.put(e,s,t)).data}catch(t){this.handleError(t)}}async deleteRequest(e,s){try{let n=this.buildConfig(s);return(await this.client.delete(e,n)).data}catch(n){this.handleError(n)}}buildConfig(e){if(!e)return;let s={...e};return e.idempotencyKey&&(s.headers={...s.headers,"Idempotency-Key":e.idempotencyKey}),s}handleError(e){throw e.response?new u(e.response.data?.message||e.response.data?.error||"API Request Failed",e.response.status,e.response.data?.code):new u(e.message||"Network Error")}};var H=class extends r{async list(e){return this.get(`/api/saas/crm/leads/${e}/notes`)}async create(e,s){return this.post(`/api/saas/crm/leads/${e}/notes`,s)}async update(e,s){return this.patch(`/api/saas/crm/notes/${e}`,{content:s})}async pin(e,s=!0){return this.patch(`/api/saas/crm/notes/${e}/pin`,{isPinned:s})}async delete(e){return this.deleteRequest(`/api/saas/crm/notes/${e}`)}},f=class extends r{notes;constructor(e){super(e),this.notes=new H(e)}async timeline(e,s){return this.get(`/api/saas/crm/leads/${e}/timeline`,{params:s})}async list(e,s){return this.get("/api/saas/crm/activities",{params:{leadId:e,...s}})}async log(e){return this.post("/api/saas/crm/activities",e)}async logCall(e,s){return this.post(`/api/saas/crm/leads/${e}/calls`,s)}};var b=class extends r{async overview(e){return this.get("/api/saas/crm/analytics/overview",{params:e})}async funnel(e){return this.get("/api/saas/crm/analytics/funnel",{params:{pipelineId:e}})}async forecast(e){return this.get("/api/saas/crm/analytics/forecast",{params:{pipelineId:e}})}async sources(e){return this.get("/api/saas/crm/analytics/sources",{params:e})}async team(e){return this.get("/api/saas/crm/analytics/team",{params:e})}async heatmap(e){return this.get("/api/saas/crm/analytics/heatmap",{params:e})}async scores(){return this.get("/api/saas/crm/analytics/scores")}async stageTime(e){return this.get("/api/saas/crm/analytics/stage-time",{params:{pipelineId:e}})}async tiered(e){return this.get("/api/saas/crm/analytics/tiered",{params:e})}async summary(e){return this.get("/api/saas/crm/analytics/summary",{params:e})}async whatsapp(e){return this.get("/api/saas/crm/analytics/whatsapp",{params:e})}};var x=class extends r{async stats(){return this.get("/api/saas/crm/automation/stats")}async logs(e){return this.get("/api/saas/crm/automation/logs",{params:e})}async retryFailedEvent(e){return this.post(`/api/saas/crm/automation/logs/${e}/retry`,{})}};var v=class extends r{async list(){return this.get("/api/saas/crm/automations")}async create(e){return this.post("/api/saas/crm/automations",e)}async update(e,s){return this.patch(`/api/saas/crm/automations/${e}`,s)}async toggle(e){return this.patch(`/api/saas/crm/automations/${e}/toggle`)}async deleteRule(e){return this.deleteRequest(`/api/saas/crm/automations/${e}`)}async bulkDelete(e){return this.post("/api/saas/crm/automations/bulk-delete",{ids:e})}async test(e,s){return this.post(`/api/saas/crm/automations/${e}/test`,{leadId:s})}async getAvailableEvents(){return this.post("/api/saas/crm/automations/events",{})}async enrollments(e,s){return this.get(`/api/saas/crm/automations/${e}/enrollments`,{params:s})}async getEnrollment(e){return this.get(`/api/saas/crm/automations/enrollments/${e}`)}async pauseEnrollment(e,s){return this.post(`/api/saas/crm/automations/${e}/enrollments/${s}/pause`,{})}async resumeEnrollment(e,s){return this.post(`/api/saas/crm/automations/${e}/enrollments/${s}/resume`,{})}async runs(e){return this.get(`/api/saas/crm/automations/${e}/runs`)}async getRun(e){return this.get(`/api/saas/crm/automations/runs/${e}`)}async resumeRun(e){return this.post(`/api/saas/crm/automations/runs/${e}/resume`,{})}async abortRun(e){return this.post(`/api/saas/crm/automations/runs/${e}/abort`,{})}async webhookEvent(e,s,n){return this.post("/api/saas/crm/webhook-event",{ruleId:e,eventName:s,payload:n})}};var w=class extends r{async create(e){return this.post("/api/services/leads",e)}async upsert(e){return this.post("/api/services/leads/upsert",e)}async createMany(e,s=50){let n=[];for(let t=0;t<e.length;t+=s){let l=e.slice(t,t+s).map(g=>this.create(g)),m=await Promise.allSettled(l);for(let g of m)if(g.status==="fulfilled")n.push(g.value);else throw g.reason}return n}async import(e){return this.post("/api/services/leads/import",{leads:e})}async list(e){let s={...e};return Array.isArray(s.tags)&&(s.tags=s.tags.join(",")),this.get("/api/services/leads",{params:s})}async*listAutoPaging(e){let s=e?.page||1,n=!0;for(;n;){let t=await this.list({...e,page:s}),i=Array.isArray(t.data)?t.data:t||[];if(i.length===0){n=!1;break}for(let l of i)yield l;t.pagination&&s<t.pagination.pages||!t.pagination&&i.length>0?s++:n=!1}}async retrieve(e){return this.get(`/api/services/leads/${e}`)}async retrieveByPhone(e){return this.get(`/api/services/leads/phone/${encodeURIComponent(e)}`)}async retrieveByRef(e,s){return this.get(`/api/services/leads/ref/${encodeURIComponent(e)}/${encodeURIComponent(s)}`)}async update(e,s){return this.post(`/api/services/leads/${e}`,s)}async move(e,s){return this.patch(`/api/services/leads/${e}/move`,{stageId:s})}async convert(e,s,n){return this.post(`/api/services/leads/${e}/convert`,{outcome:s,reason:n})}async tags(e,s){return this.patch(`/api/services/leads/${e}/tags`,s)}async recalculateScore(e){return this.post(`/api/services/leads/${e}/score`,{})}async updateMetadata(e,s){return this.patch(`/api/services/leads/${e}/metadata`,s)}async fields(){return this.get("/api/services/leads/fields")}async delete(e){return this.deleteRequest(`/api/services/leads/${e}`)}async bulkDelete(e){return this.deleteRequest("/api/services/leads",{data:{ids:e}})}};var P=class extends r{async capture(e){return this.post("/api/saas/crm/payments/capture",e)}};var R=class extends r{async list(e){return this.get("/api/saas/crm/pipelines",{params:e})}async create(e){return this.post("/api/saas/crm/pipelines",e)}async retrieve(e){return this.get(`/api/saas/crm/pipelines/${e}`)}async update(e,s){return this.patch(`/api/saas/crm/pipelines/${e}`,s)}async setDefault(e){return this.post(`/api/saas/crm/pipelines/${e}/default`,{})}async duplicate(e,s){return this.post(`/api/saas/crm/pipelines/${e}/duplicate`,{newName:s})}async archive(e){return this.post(`/api/saas/crm/pipelines/${e}/archive`,{})}async delete(e){return this.deleteRequest(`/api/saas/crm/pipelines/${e}`)}async board(e){return this.get(`/api/saas/crm/pipelines/${e}/board`)}async forecast(e){return this.get(`/api/saas/crm/pipelines/${e}/forecast`)}async addStage(e,s){return this.post(`/api/saas/crm/pipelines/${e}/stages`,s)}async reorderStages(e,s){return this.put(`/api/saas/crm/pipelines/${e}/stages/reorder`,{order:s})}async updateStage(e,s){return this.patch(`/api/saas/crm/stages/${e}`,s)}async deleteStage(e,s){return this.deleteRequest(`/api/saas/crm/stages/${e}`,{data:s?{moveLeadsToStageId:s}:void 0})}};var $=class extends r{async getConfig(){return this.get("/api/saas/crm/scoring")}async updateConfig(e){return this.patch("/api/saas/crm/scoring",e)}async recalculate(e){return this.post(`/api/saas/crm/scoring/${e}/recalculate`,{})}};var I=class extends r{async enroll(e){return this.post("/api/saas/crm/sequences/enroll",e)}async unenroll(e){return this.deleteRequest(`/api/saas/crm/sequences/unenroll/${e}`)}async listForLead(e){return this.get(`/api/saas/crm/sequences/lead/${e}`)}};var C=class{leads;pipelines;activities;analytics;automations;sequences;scoring;payments;automationDashboard;constructor(e){this.leads=new w(e),this.pipelines=new R(e),this.activities=new f(e),this.analytics=new b(e),this.automations=new v(e),this.sequences=new I(e),this.scoring=new $(e),this.payments=new P(e),this.automationDashboard=new x(e)}};var A=class extends r{async sendEmailCampaign(e){return this.post("/api/saas/emails/campaign",e)}async sendTestEmail(e){return this.post("/api/saas/emails/test",{to:e})}};var k=class extends r{async list(){return this.get("/api/saas/events")}async assign(e){return this.post("/api/saas/events/assign",e)}async unassign(e){return this.post("/api/saas/events/unassign",{name:e})}async unassignBulk(e){return this.post("/api/saas/events/unassign/bulk",{names:e})}async trigger(e){return this.post("/api/saas/workflows/trigger",e)}async listCustomEvents(){return this.get("/api/saas/crm/custom-events")}async createCustomEvent(e){return this.post("/api/saas/crm/custom-events",e)}async deleteCustomEvent(e){return this.deleteRequest(`/api/saas/crm/custom-events/${e}`)}async emit(e){return this.post("/api/saas/crm/events/emit",e)}};var S=class extends r{async system(){return(await this.get("/api/saas/health",{headers:{accept:"application/json"}})).data}async clientHealth(){return(await this.get("/api/saas/health/client")).data}async jobStatus(e){return(await this.get(`/api/saas/jobs/status/${e}`)).data}};var j=class extends r{async sendCampaign(e){return this.post("/api/saas/marketing/emails/campaign",e)}async sendTest(e){return this.post("/api/saas/marketing/emails/test",{to:e})}},J=class extends r{async list(e){return this.get("/api/saas/marketing/campaigns",{params:e})}async create(e){return this.post("/api/saas/marketing/campaigns",e)}async retrieve(e){return this.get(`/api/saas/marketing/campaigns/${e}`)}async update(e,s){return this.patch(`/api/saas/marketing/campaigns/${e}`,s)}async delete(e){return this.deleteRequest(`/api/saas/marketing/campaigns/${e}`)}async send(e,s){return this.post(`/api/saas/marketing/campaigns/${e}/send`,s||{})}async stats(e){return this.get(`/api/saas/marketing/campaigns/${e}/stats`)}},Y=class extends r{async sendTemplate(e){return this.post("/api/saas/marketing/whatsapp/send-template",e)}},E=class extends r{emails;campaigns;whatsapp;constructor(e){super(e),this.emails=new j(e),this.campaigns=new J(e),this.whatsapp=new Y(e)}};import ee from"axios";var D=class extends r{async getUsage(){return this.get("/api/saas/storage/usage")}async createFolder(e){return this.post("/api/saas/storage/folders",{name:e})}async list(e,s){return this.get(`/api/saas/storage/files/${e}`,{params:s})}async delete(e){return this.deleteRequest("/api/saas/storage/files",{params:{key:e}})}async getDownloadUrl(e){return this.post("/api/saas/storage/download-url",{key:e})}async upload(e,s){let{data:n}=await this.client.post("/api/saas/storage/upload-url",s),{uploadUrl:t,key:i}=n;await ee.put(t,e,{headers:{"Content-Type":s.contentType}});let l=e.size||e.byteLength||0;return this.post("/api/saas/storage/confirm-upload",{key:i,sizeBytes:l})}};var L=class extends r{async create(e){return this.post("/api/saas/meet",e)}async list(e){return this.get("/api/saas/meet",{params:e})}async retrieve(e){return this.get(`/api/saas/meet/${e}`)}async update(e,s){return this.patch(`/api/saas/meet/${e}`,s)}async reschedule(e,s){return this.patch(`/api/saas/meet/${e}`,s)}async delete(e){return this.update(e,{status:"cancelled"})}};var q=class extends r{async listLogs(e){return this.get("/api/saas/events/logs",{params:e})}async retrieveLog(e){return this.get(`/api/saas/events/logs/${e}`)}async getStats(e){return this.get("/api/saas/events/stats",{params:e})}async listCallbacks(e){return this.get("/api/saas/callbacks/logs",{params:e})}async listAlerts(e){return this.get("/api/saas/crm/notifications",{params:e})}async dismissAlert(e){return this.patch(`/api/saas/crm/notifications/${e}/dismiss`)}async clearAllAlerts(){return this.deleteRequest("/api/saas/crm/notifications/clear-all")}async retryAction(e){return this.post(`/api/saas/crm/notifications/${e}/retry`,{})}};var O=class extends r{async listFailed(){return this.get("/api/saas/queue/failed")}async getStats(){return this.get("/api/saas/queue/stats")}async retryJob(e){return this.post(`/api/saas/queue/${e}/retry`,{})}async deleteJob(e){return this.deleteRequest(`/api/saas/queue/${e}`)}};var G=class extends r{async create(e){return this.post("/api/saas/storage/folders",{name:e})}async delete(e){return this.deleteRequest(`/api/saas/storage/folders/${encodeURIComponent(e)}`)}},z=class extends r{async list(e,s){return this.get(`/api/saas/storage/files/${e}`,{params:s})}async getUploadUrl(e){return this.post("/api/saas/storage/upload-url",e)}async confirmUpload(e){return this.post("/api/saas/storage/confirm-upload",e)}async getDownloadUrl(e){return this.post("/api/saas/storage/download-url",{key:e})}async delete(e){return this.deleteRequest("/api/saas/storage/files",{params:{key:e}})}},U=class extends r{folders;files;constructor(e){super(e),this.folders=new G(e),this.files=new z(e)}async usage(){return this.get("/api/saas/storage/usage")}};var h=class extends u{constructor(e){super(e,400,"invalid_signature"),this.name="WebhookSignatureError"}},M=class{async constructEvent(e,s,n){if(!s)throw new h("No webhook signature provided");let t=Array.isArray(s)?s[0]:s;t.startsWith("sha256=")&&(t=t.slice(7));try{let i=await import("crypto"),m=i.createHmac("sha256",n).update(e).digest("hex");if(!i.timingSafeEqual(Buffer.from(m),Buffer.from(t)))throw new h("Invalid webhook signature provided");return JSON.parse(e.toString("utf8"))}catch(i){throw i instanceof h?i:new h(`Webhook payload parsing failed: ${i.message}`)}}};var N=class extends r{async list(e){return this.get("/api/saas/chat/broadcasts",{params:e})}async create(e){return this.post("/api/saas/chat/broadcast",e)}};var _=class extends r{async list(e){return this.get("/api/saas/chat/conversations",{params:e})}async create(e){return this.post("/api/saas/chat/conversations",e)}async retrieve(e){return this.get(`/api/saas/chat/conversations/${e}`)}async messages(e,s){return this.get(`/api/saas/chat/conversations/${e}/messages`,{params:s})}async linkLead(e,s,n){return this.post(`/api/saas/chat/conversations/${e}/link-lead`,{leadId:s,leadData:n})}async markRead(e){return this.post(`/api/saas/chat/conversations/${e}/read`,{})}async delete(e){return this.deleteRequest(`/api/saas/chat/conversations/${e}`)}async bulkDelete(e){return this.post("/api/saas/chat/conversations/bulk-delete",{ids:e})}};var F=class extends r{async send(e){return this.post("/api/saas/chat/send",e)}async sendTemplate(e){return this.post("/api/saas/chat/send",{...e,templateLanguage:e.language||"en_US"})}async star(e,s){return this.post(`/api/saas/chat/messages/${e}/star`,{isStarred:s})}async react(e,s){return this.post(`/api/saas/chat/messages/${e}/react`,{reaction:s})}async markRead(e){return this.post(`/api/saas/chat/conversations/${e}/read`)}};var K=class extends r{async list(e){return this.get("/api/saas/whatsapp/templates",{params:e})}async sync(){return this.post("/api/saas/whatsapp/templates/sync",{})}async retrieve(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}`)}async create(e){return this.post("/api/saas/whatsapp/templates",e)}async update(e,s){return this.put(`/api/saas/whatsapp/templates/${e}`,s)}async deleteTemplate(e,s){return this.deleteRequest(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}${s?"?force=true":""}`)}async mappingConfig(){return this.get("/api/saas/whatsapp/templates/mapping/config")}async collections(){return this.get("/api/saas/whatsapp/templates/collections")}async collectionFields(e){return this.get(`/api/saas/whatsapp/templates/collections/${encodeURIComponent(e)}/fields`)}async updateMapping(e,s){return this.put(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/mapping`,s)}async validate(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/validate`)}async preview(e,s){return this.post(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/preview`,{context:s})}async checkUsage(e){return this.get(`/api/saas/whatsapp/templates/${encodeURIComponent(e)}/usage`)}};var B=class extends r{messages;conversations;broadcasts;templates;constructor(e){super(e),this.messages=new F(e),this.conversations=new _(e),this.broadcasts=new N(e),this.templates=new K(e)}async upload(e,s){let n=new FormData;return n.append("file",e,s),this.post("/api/saas/whatsapp/upload",n,{headers:typeof n.getHeaders=="function"?n.getHeaders():void 0})}async sendTemplate(e){return this.post("/api/saas/whatsapp/send-template",e)}};var W=class{client;socket;whatsapp;crm;media;meet;notifications;email;events;webhooks;storage;marketing;health;queue;constructor(e){if(!e.apiKey)throw new T("API Key is required");let s=e.baseUrl||"https://api.ecodrix.com",n=e.socketUrl||s,t=typeof window<"u"&&typeof window.document<"u",i=t?"browser":typeof process<"u"?`node ${process.version}`:"unknown",l=t?globalThis.navigator?.userAgent||"browser":typeof process<"u"?process.platform:"unknown";this.client=se.create({baseURL:s,headers:{"x-api-key":e.apiKey,"x-client-code":e.clientCode?.toUpperCase(),"Content-Type":"application/json","x-ecodrix-client-agent":JSON.stringify({sdk_version:"1.0.0",runtime:i,os:l})}}),Q(this.client,{retries:3,retryDelay:Q.exponentialDelay,retryCondition:m=>Q.isNetworkOrIdempotentRequestError(m)||m.response?.status===429}),this.whatsapp=new B(this.client),this.crm=new C(this.client),this.media=new D(this.client),this.meet=new L(this.client),this.notifications=new q(this.client),this.email=new A(this.client),this.events=new k(this.client),this.webhooks=new M,this.storage=new U(this.client),this.marketing=new E(this.client),this.health=new S(this.client),this.queue=new O(this.client),this.socket=te(n,{extraHeaders:{"x-api-key":e.apiKey,"x-client-code":e.clientCode?.toUpperCase()||""}}),this.setupSocket(e.clientCode)}setupSocket(e){this.socket.on("connect",()=>{e&&this.socket.emit("join-room",e.toUpperCase())})}on(e,s){return this.socket.on(e,s),this}disconnect(){this.socket.disconnect()}off(e,s){return this.socket.off(e,s),this}async request(e,s,n,t){try{return(await this.client.request({method:e,url:s,data:n,params:t})).data}catch(i){throw i.response?new u(i.response.data?.message||i.response.data?.error||"Raw Execution Failed",i.response.status,i.response.data?.code):new u(i.message||"Network Error")}}};re.config();var X="1.0.6";var ie="Official Isomorphic SDK for the ECODrIx platform. Native support for WhatsApp, CRM, Storage, and Meetings across TS, JS, Python, and Java.",d=new ne;d.name("erix").description(ie).version(X);function y(a){let e=a.key||process.env.ECOD_API_KEY,s=a.client||process.env.ECOD_CLIENT_CODE;return e||(console.error(o.red("Error: API Key is missing.")),console.log(o.yellow("Set ECOD_API_KEY environment variable or use --key <key>")),process.exit(1)),new W({apiKey:e,clientCode:s,baseUrl:a.baseUrl||process.env.ECOD_BASE_URL})}d.option("-k, --key <key>","ECODrIx API Key").option("-c, --client <code...","Tenant Client Code").option("--base-url <url>","API Base URL override");d.command("whoami").description("Verify current authentication and tenant status").action(async(a,e)=>{let s=e.parent.opts(),n=y(s);console.log(o.cyan("Checking connection to ECODrIx Platform..."));try{let t=await n.request("GET","/api/saas/me/profile");console.log(o.green("\u2714 Authenticated successfully!")),console.log(`${o.bold("User ID:")} ${t.id}`),console.log(`${o.bold("Organisation:")} ${t.organisation?.name||"N/A"}`),s.client&&console.log(`${o.bold("Tenant Code:")} ${o.magenta(s.client)}`)}catch(t){console.error(o.red("\u2716 Authentication failed")),console.error(o.dim(t.message)),process.exit(1)}});var oe=d.command("whatsapp").description("WhatsApp Business API operations");oe.command("send-template").description("Send a WhatsApp template message").argument("<phone>","Recipient phone number").argument("<template>","Template name").option("-v, --vars <json>","Template variables as JSON string","[]").action(async(a,e,s,n)=>{let t=n.parent.parent.opts(),i=y(t);try{let l=JSON.parse(s.vars);console.log(o.cyan(`Sending template '${e}' to ${a}...`));let m=await i.whatsapp.messages.sendTemplate({to:a,templateName:e,language:"en_US",variables:l});console.log(o.green("\u2714 Message sent successfully!")),console.log(o.dim(`ID: ${m?.id||"N/A"}`))}catch(l){console.error(o.red("\u2716 Failed to send message")),console.error(o.dim(l.message))}});var Z=d.command("crm").description("CRM and Lead management");Z.command("leads").description("List recent leads").option("-l, --limit <number>","Number of leads to fetch","10").option("-s, --status <status>","Filter by lead status").option("-p, --pipeline <id>","Filter by pipeline ID").option("-q, --search <query>","Search by name or email").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{let t=Number.parseInt(a.limit);console.log(o.cyan(`Fetching last ${t} leads...`));let i={limit:t};a.status&&(i.status=a.status),a.pipeline&&(i.pipelineId=a.pipeline),a.search&&(i.search=a.search);let l=await n.crm.leads.list(i),m=Array.isArray(l.data)?l.data:Array.isArray(l)?l:[];if(m.length===0){console.log(o.yellow("No leads found."));return}console.table(m.map(g=>({ID:g.id||g._id,Name:`${g.firstName} ${g.lastName||""}`.trim(),Phone:g.phone,Status:g.status,Score:g.score||0,Created:new Date(g.createdAt).toLocaleDateString()})))}catch(t){console.error(o.red("\u2716 Failed to fetch leads")),console.error(o.dim(t.message))}});Z.command("pipelines").description("List all CRM pipelines").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{console.log(o.cyan("Fetching pipelines..."));let t=await n.crm.pipelines.list(),i=t.data||t||[];if(i.length===0){console.log(o.yellow("No pipelines found."));return}console.table(i.map(l=>({ID:l.id||l._id,Name:l.name,Default:l.isDefault?"Yes":"No",Stages:l.stages?.length||0})))}catch(t){console.error(o.red("\u2716 Failed to fetch pipelines")),console.error(o.dim(t.message))}});var ce=d.command("analytics").description("Business Intelligence Analytics");ce.command("overview").description("Get high-level CRM KPIs").option("-r, --range <range>","Date range (e.g., 24h, 7d, 30d, 365d)","30d").action(async(a,e)=>{let s=e.parent.parent.opts(),n=y(s);try{console.log(o.cyan(`Fetching overview metrics for last ${a.range}...`));let t=await n.crm.analytics.overview({range:a.range}),i=t.data||t;console.log(`
|
|
3
3
|
${o.bold("OVERVIEW KPIs:")}`),console.log(`Total Leads: ${o.green(i.totalLeads||0)}`),console.log(`Open Value: ${o.yellow(`$${(i.openValue||0).toLocaleString()}`)}`),console.log(`Won Revenue: ${o.green(`$${(i.wonRevenue||0).toLocaleString()}`)}`),console.log(`Avg Score: ${o.blue(i.avgScore?.toFixed(1)||0)}`),console.log(`Conversion: ${o.magenta(`${(i.conversionRate||0).toFixed(2)}%`)}
|
|
4
4
|
`)}catch(t){console.error(o.red("\u2716 Failed to fetch analytics overview")),console.error(o.dim(t.message))}});var pe=d.command("webhooks").description("Webhook utility tools");pe.command("verify").description("Verify a cryptographic webhook signature").argument("<payload>","The raw request body string").argument("<signature>","The 'x-ecodrix-signature' header value").argument("<secret>","Your webhook signing secret").action(async(a,e,s,n,t)=>{let i=t.parent.parent.opts(),l=y(i);try{await l.webhooks.constructEvent(a,e,s),console.log(o.green("\u2714 Signature is VALID"))}catch(m){console.error(o.red("\u2716 Error during verification")),console.error(o.dim(m.message))}});d.command("shell").alias("repl").description("Start an interactive SDK shell").action(async(a,e)=>{let s=e.parent.opts(),n=y(s);console.log(o.magenta(o.bold(`
|
|
5
5
|
Welcome to the Erix Interactive Shell`))),console.log(o.dim(`SDK Version: ${X}`)),console.log(o.dim(`The 'ecod' client is pre-initialized and ready.
|
package/dist/index.d.ts
CHANGED
|
@@ -1936,6 +1936,16 @@ declare class Ecodrix {
|
|
|
1936
1936
|
* ```
|
|
1937
1937
|
*/
|
|
1938
1938
|
disconnect(): void;
|
|
1939
|
+
/**
|
|
1940
|
+
* Remove a previously registered event listener.
|
|
1941
|
+
* Always call this in cleanup (e.g. React `useEffect` return) to prevent
|
|
1942
|
+
* memory leaks and duplicate handlers after reconnections.
|
|
1943
|
+
*
|
|
1944
|
+
* @param event - The event name to unsubscribe from.
|
|
1945
|
+
* @param callback - The exact handler reference passed to `.on()`.
|
|
1946
|
+
* @returns `this` for method chaining.
|
|
1947
|
+
*/
|
|
1948
|
+
off(event: string, callback: (...args: any[]) => void): this;
|
|
1939
1949
|
/**
|
|
1940
1950
|
* Raw Execution Escape-Hatch.
|
|
1941
1951
|
* Send an authenticated HTTP request directly to the ECODrIx backend from ANY external project.
|