@crewx/sdk 0.8.8-rc.23 → 0.8.8-rc.25
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/esm/index.js +36 -36
- package/dist/esm/plugins/index.js +2 -2
- package/dist/events/types.d.ts +3 -0
- package/dist/facade/trace-context.d.ts +4 -0
- package/dist/index.browser.js +2 -2
- package/dist/index.d.ts +1 -1
- package/dist/index.js +36 -36
- package/dist/plugins/index.js +2 -2
- package/dist/types/index.d.ts +7 -0
- package/package.json +1 -1
- package/templates/agents/default.yaml +10 -4
|
@@ -8,7 +8,7 @@ Message: ${e.message}
|
|
|
8
8
|
`;writeFileSync(n,r,{encoding:"utf8",mode:384});}catch{}}),t.on("task:output",e=>{try{let s=this.logFiles.get(e.traceId);if(!s)return;let n=new Date().toISOString();appendFileSync(s,`[${n}] STDOUT: ${e.output}
|
|
9
9
|
`,"utf8");}catch{}}),t.on("task:end",e=>{try{let s=this.logFiles.get(e.traceId);if(!s)return;let n=new Date().toLocaleString(),r=e.error?`failed: ${e.error.message}`:"completed successfully",i=`[${n}] INFO: Task ${r} in ${e.durationMs}ms
|
|
10
10
|
[${n}] INFO: Process closed with exit code: ${e.error?1:0}
|
|
11
|
-
`;appendFileSync(s,i,"utf8"),this.logFiles.delete(e.traceId);}catch{}}));}detach(t){this.unsubs.forEach(e=>e()),this.unsubs=[],this.logFiles.clear();}};function Lt(d){let t=M.resolve(d);return process.platform==="win32"&&(t=t.replace(/\\/g,"/"),t=t.replace(/^([A-Z]):/,(e,s)=>`${s.toLowerCase()}:`)),t.length>1&&!/^[a-zA-Z]:\/$/.test(t)&&(t=t.replace(/\/+$/,"")),t}function ft(d){let t=Lt(d);return createHash("sha256").update(t).digest("hex")}var B=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:join(Ut.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(t){return t instanceof Error&&/no such table:/i.test(t.message)}dbExists(t){return existsSync(t??this.resolveDbPath())}};function b(d){let t=j("better-sqlite3"),{drizzle:e}=j("drizzle-orm/better-sqlite3"),s=new t(d);return s.exec("PRAGMA journal_mode = WAL"),s.exec("PRAGMA busy_timeout = 5000"),s.exec("PRAGMA foreign_keys = ON"),{db:e(s),runRaw:(n,r=[])=>s.prepare(n).run(...r),close:()=>s.close()}}var gt=new Set,Ft={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Bt(d,t){return (d.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${t}'`)?.cnt??0)>0}function zt(d,t){if(t>0||!Bt(d,"tasks"))return;let e=d.all("PRAGMA table_info(tasks)"),s=new Set(e.map(n=>n.name));for(let[n,r]of Object.entries(Ft))s.has(n)||d.run(`ALTER TABLE tasks ADD COLUMN ${n} ${r}`);}function qt(d,t,e){let s=d.all(e`SELECT hash FROM __drizzle_migrations`),n=new Set(s.map(i=>i.hash)),r=JSON.parse(readFileSync(M__default.join(t,"meta/_journal.json"),"utf-8"));for(let i of r.entries){let a=M__default.join(t,`${i.tag}.sql`);if(!existsSync(a))continue;let c=readFileSync(a,"utf-8"),p=createHash("sha256").update(c).digest("hex");if(n.has(p))continue;let m=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,f=[],T;for(;(T=m.exec(c))!==null;)f.push({table:T[1],column:T[2]});if(f.length===0||!c.split(/-->\s*statement-breakpoint/).map(L=>L.trim()).filter(Boolean).every(L=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(L)))continue;f.every(({table:L,column:et})=>d.all(`PRAGMA table_info("${L}")`).some(
|
|
11
|
+
`;appendFileSync(s,i,"utf8"),this.logFiles.delete(e.traceId);}catch{}}));}detach(t){this.unsubs.forEach(e=>e()),this.unsubs=[],this.logFiles.clear();}};function Lt(d){let t=M.resolve(d);return process.platform==="win32"&&(t=t.replace(/\\/g,"/"),t=t.replace(/^([A-Z]):/,(e,s)=>`${s.toLowerCase()}:`)),t.length>1&&!/^[a-zA-Z]:\/$/.test(t)&&(t=t.replace(/\/+$/,"")),t}function ft(d){let t=Lt(d);return createHash("sha256").update(t).digest("hex")}var B=class{resolveDbPath(){return process.env.CREWX_DB?process.env.CREWX_DB:process.env.CREWX_TRACES_DB?process.env.CREWX_TRACES_DB:join(Ut.homedir(),".crewx","crewx.db")}resolveDbPaths(){return [this.resolveDbPath()]}isMissingTableError(t){return t instanceof Error&&/no such table:/i.test(t.message)}dbExists(t){return existsSync(t??this.resolveDbPath())}};function b(d){let t=j("better-sqlite3"),{drizzle:e}=j("drizzle-orm/better-sqlite3"),s=new t(d);return s.exec("PRAGMA journal_mode = WAL"),s.exec("PRAGMA busy_timeout = 5000"),s.exec("PRAGMA foreign_keys = ON"),{db:e(s),runRaw:(n,r=[])=>s.prepare(n).run(...r),close:()=>s.close()}}var gt=new Set,Ft={agent_id:"TEXT",status:"TEXT DEFAULT 'running'",started_at:"TEXT",trace_id:"TEXT",parent_task_id:"TEXT",crewx_version:"TEXT",pid:"INTEGER",thread_id:"TEXT",workspace_id:"TEXT",workspace_ref:"TEXT",workspace_name:"TEXT",project_id:"TEXT",project_name:"TEXT"};function Bt(d,t){return (d.get(`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='${t}'`)?.cnt??0)>0}function zt(d,t){if(t>0||!Bt(d,"tasks"))return;let e=d.all("PRAGMA table_info(tasks)"),s=new Set(e.map(n=>n.name));for(let[n,r]of Object.entries(Ft))s.has(n)||d.run(`ALTER TABLE tasks ADD COLUMN ${n} ${r}`);}function qt(d,t,e){let s=d.all(e`SELECT hash FROM __drizzle_migrations`),n=new Set(s.map(i=>i.hash)),r=JSON.parse(readFileSync(M__default.join(t,"meta/_journal.json"),"utf-8"));for(let i of r.entries){let a=M__default.join(t,`${i.tag}.sql`);if(!existsSync(a))continue;let c=readFileSync(a,"utf-8"),p=createHash("sha256").update(c).digest("hex");if(n.has(p))continue;let m=/ALTER\s+TABLE\s+[`"]?(\w+)[`"]?\s+ADD\s+[`"]?(\w+)[`"]?/gi,f=[],T;for(;(T=m.exec(c))!==null;)f.push({table:T[1],column:T[2]});if(f.length===0||!c.split(/-->\s*statement-breakpoint/).map(L=>L.trim()).filter(Boolean).every(L=>/^ALTER\s+TABLE\s+.+\s+ADD\s+/i.test(L)))continue;f.every(({table:L,column:et})=>d.all(`PRAGMA table_info("${L}")`).some(Rt=>Rt.name===et))&&d.run(e`INSERT INTO __drizzle_migrations (hash, created_at) VALUES (${p}, ${i.when})`);}}function Ht(d){let{migrate:t}=j("drizzle-orm/better-sqlite3/migrator"),{sql:e}=j("drizzle-orm"),s=[M__default.join(k,"../migrations"),M__default.join(k,"migrations"),M__default.join(k,"../../../../drizzle/migrations"),M__default.join(process.cwd(),"drizzle/migrations")],n=s.find(p=>existsSync(M__default.join(p,"meta/_journal.json")));if(!n)throw new Error(`migrations folder not found. Searched:
|
|
12
12
|
${s.join(`
|
|
13
13
|
`)}`);let r=d.get(e`SELECT count(*) as cnt FROM sqlite_master WHERE type='table' AND name='__drizzle_migrations'`),i=0;r?.cnt&&(i=d.get(e`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0),zt(d,i),r?.cnt&&qt(d,n,e),t(d,{migrationsFolder:n});let c=(d.get(e`SELECT count(*) as cnt FROM __drizzle_migrations`)?.cnt??0)-i;if(c>0){let p=r?.cnt?"Database migrated":"Database initialized";console.log(`[crewx] ${p} (${c} migration${c>1?"s":""} applied).`);}}function W(d,t){gt.has(t)||(Ht(d),gt.add(t));}var u=class extends Error{code;cause;constructor(t,e,s){super(e),this.name="RepositoryError",this.code=t,this.cause=s,Object.setPrototypeOf(this,new.target.prototype);}};var z=sqliteTable("workspaces",{id:text("id").primaryKey(),slug:text("slug").notNull().unique(),name:text("name").notNull(),workspace_path:text("workspace_path"),description:text("description"),is_active:integer("is_active").notNull().default(1),created_at:text("created_at").notNull(),updated_at:text("updated_at").notNull()});var o=sqliteTable("tasks",{id:text("id").primaryKey(),agent_id:text("agent_id").notNull(),user_id:text("user_id"),prompt:text("prompt").notNull(),mode:text("mode").notNull().default("execute"),status:text("status").notNull().default("running"),result:text("result"),error:text("error"),started_at:text("started_at").notNull(),completed_at:text("completed_at"),duration_ms:integer("duration_ms"),metadata:text("metadata"),workspace_id:text("workspace_id"),trace_id:text("trace_id"),parent_task_id:text("parent_task_id"),caller_agent_id:text("caller_agent_id"),model:text("model"),platform:text("platform").default("cli"),crewx_version:text("crewx_version"),input_tokens:integer("input_tokens").default(0),output_tokens:integer("output_tokens").default(0),cost_usd:real("cost_usd").default(0),pid:integer("pid"),rendered_prompt:text("rendered_prompt"),command:text("command"),coding_agent_command:text("coding_agent_command"),exit_code:integer("exit_code"),logs:text("logs"),thread_id:text("thread_id"),workspace_ref:text("workspace_ref"),project_id:text("project_id"),project_ref:text("project_ref"),cached_input_tokens:integer("cached_input_tokens").default(0)},d=>({idx_tasks_agent_id:index("idx_tasks_agent_id").on(d.agent_id),idx_tasks_status:index("idx_tasks_status").on(d.status),idx_tasks_started_at:index("idx_tasks_started_at").on(d.started_at),idx_tasks_trace_id:index("idx_tasks_trace_id").on(d.trace_id),idx_tasks_parent_task_id:index("idx_tasks_parent_task_id").on(d.parent_task_id),idx_tasks_crewx_version:index("idx_tasks_crewx_version").on(d.crewx_version),idx_tasks_pid:index("idx_tasks_pid").on(d.pid),idx_tasks_thread_id:index("idx_tasks_thread_id").on(d.thread_id),idx_tasks_workspace_id:index("idx_tasks_workspace_id").on(d.workspace_id),idx_tasks_workspace_ref:index("idx_tasks_workspace_ref").on(d.workspace_ref),idx_tasks_project_id:index("idx_tasks_project_id").on(d.project_id),idx_tasks_ws_started:index("idx_tasks_ws_started").on(d.workspace_id,d.started_at)}));var l=sqliteTable("threads",{id:text("id").primaryKey(),workspace_id:text("workspace_id").references(()=>z.id,{onDelete:"set null"}),platform:text("platform").notNull().default("cli"),title:text("title"),first_message:text("first_message"),last_message:text("last_message"),message_count:integer("message_count").notNull().default(0),created_at:text("created_at").notNull(),updated_at:text("updated_at").notNull(),metadata:text("metadata"),title_locked:integer("title_locked").notNull().default(0),pinned:integer("pinned").notNull().default(0),starred:integer("starred").notNull().default(0)},d=>({idx_threads_updated_at:index("idx_threads_updated_at").on(d.updated_at),idx_threads_workspace_id:index("idx_threads_workspace_id").on(d.workspace_id)}));var Vt=sqliteTable("spans",{id:text("id").primaryKey(),task_id:text("task_id").references(()=>o.id,{onDelete:"set null"}),parent_span_id:text("parent_span_id").references(()=>Vt.id,{onDelete:"set null"}),name:text("name").notNull(),kind:text("kind").notNull().default("internal"),status:text("status").notNull().default("ok"),started_at:text("started_at").notNull(),completed_at:text("completed_at"),duration_ms:integer("duration_ms"),input:text("input"),output:text("output"),error:text("error"),attributes:text("attributes")},d=>({idx_spans_task_id:index("idx_spans_task_id").on(d.task_id),idx_spans_parent_span_id:index("idx_spans_parent_span_id").on(d.parent_span_id)}));sqliteTable("tool_calls",{id:text("id").primaryKey(),task_id:text("task_id").references(()=>o.id,{onDelete:"cascade"}),session_id:text("session_id"),tool_name:text("tool_name").notNull(),files:text("files"),input:text("input"),output:text("output"),duration_ms:integer("duration_ms"),timestamp:text("timestamp").notNull()},d=>({idx_tool_calls_task_id:index("idx_tool_calls_task_id").on(d.task_id),idx_tool_calls_tool_name:index("idx_tool_calls_tool_name").on(d.tool_name),idx_tool_calls_timestamp:index("idx_tool_calls_timestamp").on(d.timestamp)}));sqliteTable("thread_boxes",{id:text("id").primaryKey(),thread_id:text("thread_id").notNull().references(()=>l.id,{onDelete:"cascade"}),seq:integer("seq").notNull(),first_task_id:text("first_task_id").notNull(),mid_task_id:text("mid_task_id").notNull(),last_task_id:text("last_task_id").notNull(),task_count:integer("task_count").notNull(),summary:text("summary"),source_tokens:integer("source_tokens").notNull(),summary_tokens:integer("summary_tokens"),created_at:text("created_at").notNull()},d=>({idx_thread_boxes_thread_id:index("idx_thread_boxes_thread_id").on(d.thread_id),idx_thread_boxes_seq:index("idx_thread_boxes_seq").on(d.thread_id,d.seq),uniq_thread_boxes_thread_seq:unique().on(d.thread_id,d.seq)}));sqliteTable("request_logs",{id:text("id").primaryKey(),path:text("path").notNull(),method:text("method").notNull(),status_code:integer("status_code").notNull(),duration_ms:integer("duration_ms").notNull(),ip:text("ip"),request_headers:text("request_headers"),response_headers:text("response_headers"),request_body:text("request_body"),response_body:text("response_body"),query:text("query"),user_id:text("user_id"),project_id:text("project_id"),partition_key:text("partition_key").notNull(),timestamp:text("timestamp").notNull().default(sql`(datetime('now'))`),metadata:text("metadata")},d=>({idx_request_logs_timestamp:index("idx_request_logs_timestamp").on(d.timestamp),idx_request_logs_path:index("idx_request_logs_path").on(d.path),idx_request_logs_status_code:index("idx_request_logs_status_code").on(d.status_code),idx_request_logs_partition_key:index("idx_request_logs_partition_key").on(d.partition_key)}));var V=class extends B{dbPath;constructor(t={}){super(),t.dbPath?this.dbPath=t.dbPath:t.dbRoot&&(this.dbPath=join(t.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(t){let e=this.resolveDbPath();if(t){let n=dirname(e);existsSync(n)||mkdirSync(n,{recursive:true});}else if(!existsSync(e))throw new u("NOT_FOUND","Database not found");let s=b(e);if(t)try{W(s.db,e);}catch(n){throw s.close(),n}return s}startTask(t){let e=this.openHandle(true);try{e.db.insert(o).values({id:t.id,agent_id:t.agentId,prompt:t.prompt,mode:t.mode,status:t.status,started_at:t.startedAt,pid:t.pid??null,parent_task_id:t.parentTaskId??null,caller_agent_id:t.callerAgentId??null,trace_id:t.traceId??null,command:t.command??null,metadata:t.metadata??null,workspace_id:t.workspaceId??null,platform:t.platform??"cli",crewx_version:t.crewxVersion??null,thread_id:t.threadId??null,model:t.model??null,rendered_prompt:t.renderedPrompt??null,coding_agent_command:t.codingAgentCommand??null}).onConflictDoNothing().run();}catch(s){throw s instanceof u?s:new u("DB_ERROR","Failed to start task",s)}finally{e.close();}}finishTask(t){let e=this.openHandle(true);try{e.runRaw(`UPDATE tasks SET status=?, result=?, error=?, completed_at=?, duration_ms=?,
|
|
14
14
|
exit_code=?, input_tokens=?, output_tokens=?, cached_input_tokens=?, cost_usd=?,
|
|
@@ -93,7 +93,7 @@ ${s.join(`
|
|
|
93
93
|
AND t.started_at < ${e}
|
|
94
94
|
GROUP BY date(t.started_at), t.agent_id
|
|
95
95
|
ORDER BY date(t.started_at) ASC
|
|
96
|
-
`).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(r){throw new u("DB_ERROR","Failed to get agent usage trend",r)}finally{n.close();}}findTaskForStop(t,e){if(!this.dbExists())return;let s=this.openHandle(false);try{return s.db.select().from(o).where(and(eq(o.id,t),eq(o.workspace_id,e))).limit(1).get()??void 0}catch(n){throw new u("DB_ERROR","Failed to find task for stop",n)}finally{s.close();}}markTaskFailed(t,e,s){if(!this.dbExists())return;let n=this.openHandle(true);try{let r=new Date().toISOString(),i=s?and(eq(o.id,t),eq(o.status,"running"),eq(o.workspace_id,s)):and(eq(o.id,t),eq(o.status,"running"));n.db.update(o).set({status:"failed",error:e,completed_at:r}).where(i).run();}catch(r){throw r instanceof u?r:new u("DB_ERROR","Failed to mark task failed",r)}finally{n.close();}}findTasksByPromptHint(t,e){let s=this.resolveDbPaths(),n=new Set,r=[];for(let i of s){if(!existsSync(i))continue;let a=b(i);try{let c=e?and(like(o.prompt,`%${t}%`),eq(o.workspace_id,e)):like(o.prompt,`%${t}%`),p=a.db.select().from(o).where(c).orderBy(asc(o.started_at)).all();for(let m of p)n.has(m.id)||(n.add(m.id),r.push(m));}catch(c){throw new u("DB_ERROR","Failed to find tasks by prompt hint",c)}finally{a.close();}}return r}};var at=class extends v{name="sqlite-tracing";unsubs=[];dbPath;version;constructor(t){super(),this.dbPath=join(t?.dbRoot??homedir(),".crewx","crewx.db"),this.version=t?.version??"unknown";}attach(t){let e=new V({dbPath:this.dbPath}),s=process.cwd(),r=existsSync(join(s,"crewx.yaml"))||existsSync(join(s,"crewx.yml"))?ft(s):null,i=process.argv.join(" ");this.unsubs.push(t.on("task:start",a=>{try{let c=
|
|
96
|
+
`).map(i=>({date:i.date,agentId:i.agent_id,inputTokens:i.input_tokens,outputTokens:i.output_tokens,cachedInputTokens:i.cached_input_tokens,costUsd:i.cost_usd}))}catch(r){throw new u("DB_ERROR","Failed to get agent usage trend",r)}finally{n.close();}}findTaskForStop(t,e){if(!this.dbExists())return;let s=this.openHandle(false);try{return s.db.select().from(o).where(and(eq(o.id,t),eq(o.workspace_id,e))).limit(1).get()??void 0}catch(n){throw new u("DB_ERROR","Failed to find task for stop",n)}finally{s.close();}}markTaskFailed(t,e,s){if(!this.dbExists())return;let n=this.openHandle(true);try{let r=new Date().toISOString(),i=s?and(eq(o.id,t),eq(o.status,"running"),eq(o.workspace_id,s)):and(eq(o.id,t),eq(o.status,"running"));n.db.update(o).set({status:"failed",error:e,completed_at:r}).where(i).run();}catch(r){throw r instanceof u?r:new u("DB_ERROR","Failed to mark task failed",r)}finally{n.close();}}findTasksByPromptHint(t,e){let s=this.resolveDbPaths(),n=new Set,r=[];for(let i of s){if(!existsSync(i))continue;let a=b(i);try{let c=e?and(like(o.prompt,`%${t}%`),eq(o.workspace_id,e)):like(o.prompt,`%${t}%`),p=a.db.select().from(o).where(c).orderBy(asc(o.started_at)).all();for(let m of p)n.has(m.id)||(n.add(m.id),r.push(m));}catch(c){throw new u("DB_ERROR","Failed to find tasks by prompt hint",c)}finally{a.close();}}return r}};var at=class extends v{name="sqlite-tracing";unsubs=[];dbPath;version;constructor(t){super(),this.dbPath=join(t?.dbRoot??homedir(),".crewx","crewx.db"),this.version=t?.version??"unknown";}attach(t){let e=new V({dbPath:this.dbPath}),s=process.cwd(),r=existsSync(join(s,"crewx.yaml"))||existsSync(join(s,"crewx.yml"))?ft(s):null,i=process.argv.join(" ");this.unsubs.push(t.on("task:start",a=>{try{let c=a.callerAgentId??null,p=a.parentTaskId??null,m=a.rootTraceId??a.traceId,f=a.metadata?JSON.stringify(a.metadata):JSON.stringify({provider:a.provider??"cli/claude"});e.startTask({id:a.traceId,agentId:a.agentRef.replace(/^@/,""),prompt:a.message,mode:a.mode,status:"running",pid:a.pid??null,startedAt:a.timestamp.toISOString(),crewxVersion:this.version,platform:a.platform??"cli",model:a.model??null,renderedPrompt:a.renderedPrompt??null,command:i,codingAgentCommand:a.codingAgentCommand??null,workspaceId:a.workspaceId??r,callerAgentId:c,parentTaskId:p,traceId:m,metadata:f,threadId:a.threadId??null});}catch{}}),t.on("task:output",a=>{try{e.appendLog(a.traceId,{timestamp:a.timestamp.toISOString(),level:a.level??"stdout",message:a.output});}catch{}}),t.on("task:end",a=>{try{e.finishTask({id:a.traceId,status:a.error?"failed":"success",result:a.result??null,error:a.error?JSON.stringify(a.error):null,completedAt:a.timestamp.toISOString(),durationMs:a.durationMs,exitCode:a.exitCode??null,inputTokens:a.inputTokens??0,outputTokens:a.outputTokens??0,cachedInputTokens:a.cachedInputTokens??0,costUsd:a.costUsd??0,model:a.model??null});}catch{}}));}detach(t){this.unsubs.forEach(e=>e()),this.unsubs=[];}};var Z=class extends B{dbPath;constructor(t={}){super(),t.dbPath?this.dbPath=t.dbPath:t.dbRoot&&(this.dbPath=join(t.dbRoot,".crewx","crewx.db"));}resolveDbPath(){return this.dbPath?this.dbPath:super.resolveDbPath()}openHandle(t){let e=this.resolveDbPath();if(t){let n=dirname(e);existsSync(n)||mkdirSync(n,{recursive:true});}else if(!existsSync(e))throw new u("NOT_FOUND","Database not found");let s=b(e);if(t)try{W(s.db,e);}catch(n){throw s.close(),n}return s}validateWorkspaceId(t,e){return t.db.select({id:z.id}).from(z).where(eq(z.id,e)).limit(1).get()?e:null}findAllThreads(t){let e=this.resolveDbPaths(),s=new Set,n=[];for(let r of e){if(!existsSync(r))continue;let i=b(r);try{let a=t?eq(l.workspace_id,t):void 0,c=i.db.select().from(l).where(a).orderBy(desc(l.updated_at)).all();for(let p of c)s.has(p.id)||(s.add(p.id),n.push(p));}catch(a){throw new u("DB_ERROR","Failed to find all threads",a)}finally{i.close();}}return n}findThreadById(t,e){let s=this.resolveDbPaths();for(let n of s){if(!existsSync(n))continue;let r=b(n);try{let i=eq(l.id,t),a=e?and(i,eq(l.workspace_id,e)):i,c=r.db.select().from(l).where(a).limit(1).get()??void 0;if(c)return c}catch(i){throw new u("DB_ERROR","Failed to find thread by id",i)}finally{r.close();}}}threadExists(t,e){let s=this.resolveDbPaths();for(let n of s){if(!existsSync(n))continue;let r=b(n);try{let i=eq(l.id,t),a=e?and(i,eq(l.workspace_id,e)):i;if(r.db.select({id:l.id}).from(l).where(a).limit(1).get())return !0}catch(i){throw new u("DB_ERROR","Failed to check thread existence",i)}finally{r.close();}}return false}aggregateTaskStats(t,e){let s=this.resolveDbPaths(),n=0,r=0,i=0,a=0,c=0,p=new Set;for(let m of s){if(!existsSync(m))continue;let f=b(m);try{let T=and(eq(o.thread_id,t),or(isNull(o.parent_task_id),eq(o.parent_task_id,""))),A=e?and(T,eq(o.workspace_id,e)):T,N=f.db.select({cnt:sql`count(*)`,total_input:sql`COALESCE(SUM(input_tokens), 0)`,total_output:sql`COALESCE(SUM(output_tokens), 0)`,total_cached:sql`COALESCE(SUM(cached_input_tokens), 0)`,total_cost:sql`COALESCE(SUM(cost_usd), 0)`}).from(o).where(A).get();N&&(n+=N.cnt,r+=N.total_input,i+=N.total_output,a+=N.total_cached,c+=N.total_cost);let L=f.db.all(sql`
|
|
97
97
|
SELECT DISTINCT agent_id FROM tasks
|
|
98
98
|
WHERE thread_id = ${t}
|
|
99
99
|
AND agent_id IS NOT NULL AND agent_id != ''
|
package/dist/events/types.d.ts
CHANGED
|
@@ -17,6 +17,9 @@ export interface TaskStartEvent extends BaseEvent {
|
|
|
17
17
|
platform?: Platform;
|
|
18
18
|
workspaceId?: string;
|
|
19
19
|
workspaceName?: string;
|
|
20
|
+
parentTaskId?: string | null;
|
|
21
|
+
rootTraceId?: string;
|
|
22
|
+
callerAgentId?: string | null;
|
|
20
23
|
}
|
|
21
24
|
export interface TaskEndEvent extends BaseEvent {
|
|
22
25
|
agentRef: string;
|
package/dist/index.browser.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {load}from'js-yaml';import {z}from'zod';var m=class extends Error{constructor(e,n){let
|
|
2
|
-
`);y=k.pop();for(let M of k){let h=M.trim();if(!h||!h.startsWith("data: "))continue;let b=h.slice(6);if(b!=="[DONE]")try{let R=JSON.parse(b).choices?.[0]?.delta?.content??"";u+=R,R&&c?.onOutput&&c.onOutput(u,"stdout");}catch{}}}return s.push({role:"user",content:
|
|
1
|
+
import {load}from'js-yaml';import {z}from'zod';var m=class extends Error{constructor(e,n){let t=n.length>0?` Available: ${n.join(", ")}`:"";super(`Agent not found: "${e}".${t}`),this.name="AgentNotFoundError";}},_={claude:{id:"claude",provider:"cli/claude"},gemini:{id:"gemini",provider:"cli/gemini"},copilot:{id:"copilot",provider:"cli/copilot"},codex:{id:"codex",provider:"cli/codex"}};function x(p,e){let n=p.startsWith("@")?p.slice(1):p,t=e.find(r=>r.id===n);if(t)return t;let s=_[n];if(s)return s;throw new m(p,e.map(r=>r.id))}var l=class extends Error{constructor(n,t){super(n);this.providerStr=t;this.name="ProviderError";}providerStr};var O=new Map;function P(p,e){O.set(p,e);}function w(p){let e=p.split("/");if(e.length!==2)throw new l(`Invalid provider format: "${p}". Expected namespace/id (e.g., api/webllm)`,p);let[n,t]=e,s=O.get(n);if(s)return s(t,p);throw new l(`Unsupported provider namespace: "${n}". Register a factory with registerProviderFactory('${n}', factory).`,p)}var j=new Function("u","return import(u)"),C=class p{_agents;_config;_tools=new Map;_apiProviders=new Map;constructor(e,n){this._agents=new Map(e.map(t=>[t.id,t])),this._config=n;}static async fromConfig(e,n){let t=new p(e.agents??[],e),s=e.agents??[],r=i=>Array.isArray(i.provider)?i.provider[0]:i.provider,c=s.filter(i=>r(i)==="api/webllm"),a=s.filter(i=>r(i)==="api/openrouter");if(c.length>0&&await t._initWebLLM(c,n?.onProgress),a.length>0){if(!n?.openrouterApiKey)throw new Error("openrouterApiKey is required when using api/openrouter provider");t._initOpenRouter(a,n.openrouterApiKey);}return t._apiProviders.size>0&&P("api",(i,d)=>{let g=t._apiProviders.get(i);if(!g)throw new l(`Unknown api provider: ${i}`,d);return g}),t}async _initWebLLM(e,n){if(typeof navigator>"u"||!navigator.gpu)throw new Error("WebGPU is not available. Chrome 113+ or Edge 113+ required.");let t=await j("https://esm.run/@mlc-ai/web-llm"),s=e[0]?.inline?.model??"gemma-2-2b-it-q4f16_1-MLC",r=await t.CreateMLCEngine(s,{initProgressCallback:n?a=>n(a):void 0}),c=[];this._apiProviders.set("webllm",{async query(a,i){let d=[];i?.systemPrompt&&d.push({role:"system",content:i.systemPrompt}),d.push(...c),d.push({role:"user",content:a});let g="",u=await r.chat.completions.create({messages:d,stream:true,temperature:.7,max_tokens:4096});for await(let y of u){let v=y.choices?.[0]?.delta?.content??"";g+=v,i?.onOutput&&i.onOutput(g,"stdout");}return c.push({role:"user",content:a}),c.push({role:"assistant",content:g}),g},async execute(a,i){return this.query(a,i)}});}_initOpenRouter(e,n){let t=e[0]?.inline?.model??"google/gemma-2-2b-it",s=[];this._apiProviders.set("openrouter",{async query(r,c){let a=[];c?.systemPrompt&&a.push({role:"system",content:c.systemPrompt}),a.push(...s),a.push({role:"user",content:r});let i=await fetch("https://openrouter.ai/api/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${n}`,"Content-Type":"application/json"},body:JSON.stringify({model:c?.model||t,messages:a,stream:true})});if(!i.ok){let v=await i.text();throw new Error(`OpenRouter API error (${i.status}): ${v}`)}let d=i.body.getReader(),g=new TextDecoder,u="",y="";for(;;){let{done:v,value:I}=await d.read();if(v)break;y+=g.decode(I,{stream:true});let k=y.split(`
|
|
2
|
+
`);y=k.pop();for(let M of k){let h=M.trim();if(!h||!h.startsWith("data: "))continue;let b=h.slice(6);if(b!=="[DONE]")try{let R=JSON.parse(b).choices?.[0]?.delta?.content??"";u+=R,R&&c?.onOutput&&c.onOutput(u,"stdout");}catch{}}}return s.push({role:"user",content:r}),s.push({role:"assistant",content:u}),u},async execute(r,c){return this.query(r,c)}});}get agents(){return this._agents}get config(){return this._config}get tools(){return this._tools}registerTool(e,n){this._tools.set(e,{name:e,...n});}async query(e,n,t){let s=Date.now(),r;try{r=x(e,Array.from(this._agents.values()));}catch(g){if(g instanceof m)return {ok:false,data:"",error:{code:"AGENT_NOT_FOUND",message:g.message},meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:Date.now()-s}};throw g}let c=Array.isArray(r.provider)?r.provider[0]??"api/default":r.provider,a=t?.provider??c,i=t?.model??r.inline?.model,d;try{d=w(a);}catch(g){return {ok:false,data:"",error:{code:"PROVIDER_ERROR",message:g.message},meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}try{return {ok:!0,data:await d.query(n,{model:i,context:t?.context,systemPrompt:r.inline?.system_prompt??r.inline?.prompt,onOutput:t?.onOutput?u=>t.onOutput(u):void 0}),meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}catch(g){return {ok:false,data:"",error:{code:"QUERY_FAILED",message:g.message},meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}}async execute(e,n,t){let s=Date.now(),r;try{r=x(e,Array.from(this._agents.values()));}catch(g){if(g instanceof m)return {ok:false,data:"",error:{code:"AGENT_NOT_FOUND",message:g.message},meta:{agentId:e.replace(/^@/,""),provider:"",durationMs:Date.now()-s}};throw g}let c=Array.isArray(r.provider)?r.provider[0]??"api/default":r.provider,a=t?.provider??c,i=t?.model??r.inline?.model,d;try{d=w(a);}catch(g){return {ok:false,data:"",error:{code:"PROVIDER_ERROR",message:g.message},meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}try{return {ok:!0,data:await d.execute(n,{model:i,context:t?.context,systemPrompt:r.inline?.system_prompt??r.inline?.prompt}),meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}catch(g){return {ok:false,data:"",error:{code:"EXECUTE_FAILED",message:g.message},meta:{agentId:r.id,provider:a,model:i,durationMs:Date.now()-s}}}}};var F=z.object({model:z.string().optional(),system_prompt:z.string().optional(),prompt:z.string().optional(),layout:z.union([z.string(),z.object({id:z.string(),props:z.record(z.unknown()).optional()}),z.object({props:z.record(z.unknown())}),z.object({template:z.string()})]).optional()}).catchall(z.unknown()),T=z.object({include:z.array(z.string()).optional()}).optional(),D=z.object({id:z.string(),name:z.string().optional(),role:z.string().optional(),team:z.string().optional(),provider:z.union([z.string(),z.array(z.string())]),working_directory:z.string().optional(),description:z.string().optional(),tags:z.array(z.string()).optional(),inline:F.optional(),skills:T}).catchall(z.unknown()),E=z.object({agents:z.array(D).optional(),hooks:z.array(z.unknown()).optional(),settings:z.record(z.unknown()).optional(),skills:z.unknown().optional(),layouts:z.record(z.unknown()).optional(),documents:z.record(z.unknown()).optional()}).catchall(z.unknown());var f=class extends Error{constructor(n,t){super(n);this.cause=t;this.name="ConfigLoadError";}cause};function $(p){if(!p||typeof p!="string"||!p.trim())throw new f("YAML content must be a non-empty string");let e;try{e=load(p);}catch(s){throw new f(`YAML parse error: ${s.message}`,s)}let n=S(e),t=E.safeParse(n);if(!t.success)throw new f(`Config validation error: ${t.error.message}`);return t.data}function S(p){if(!p||typeof p!="object")return {agents:[]};let e=p;if(e.agents&&typeof e.agents=="object"&&!Array.isArray(e.agents)){let n=e.agents,t=Object.entries(n).map(([s,r])=>({id:s,...r&&typeof r=="object"?r:{}}));return {...e,agents:t}}return e.agents?e:{...e,agents:[]}}var B="crewx:fs:",A=class{prefix;store;constructor(e){this.prefix=e?.prefix??B,this.store=e?.storage??new Map;}async readFile(e){let n=this.toKey(e),t=this.store.get(n);if(t===void 0)throw new Error(`BrowserFsAdapter: file not found: ${e}`);return t}async exists(e){return this.store.has(this.toKey(e))}resolvePath(...e){let n=e.map(c=>c.replace(/\\/g,"/")).join("/").replace(/\/+/g,"/"),t=n.split("/"),s=[];for(let c of t)c==="."||c===""||(c===".."?s.pop():s.push(c));let r=s.join("/");return n.startsWith("/")?`/${r}`:r}isAbsolute(e){return e.startsWith("/")}setItem(e,n){this.store.set(this.toKey(e),n);}removeItem(e){this.store.delete(this.toKey(e));}keys(){return Array.from(this.store.keys()).filter(e=>e.startsWith(this.prefix)).map(e=>e.slice(this.prefix.length))}async readdir(e){let n=e.replace(/\\/g,"/").replace(/\/$/,""),t=this.toKey(n+"/"),s=[];for(let r of this.store.keys())if(r.startsWith(t)){let a=r.slice(t.length).split("/")[0];a&&!s.includes(a)&&s.push(a);}return s}toKey(e){return `${this.prefix}${e.replace(/\\/g,"/")}`}};export{A as BrowserFsAdapter,f as ConfigLoadError,C as Crewx,l as ProviderError,w as createProvider,$ as parseYamlContent,P as registerProviderFactory};
|
package/dist/index.d.ts
CHANGED
|
@@ -18,7 +18,7 @@ export { NodeFsAdapter, defaultFsAdapter } from './platform/NodeFsAdapter';
|
|
|
18
18
|
export { BrowserFsAdapter } from './platform/BrowserFsAdapter';
|
|
19
19
|
export { truncateHelper, lengthHelper, escapeHandlebarsHelper, formatFileSizeHelper, formatTimestampHelper, } from './template/helpers/p1p2';
|
|
20
20
|
export { setAuditVerbose } from './template/helpers/exec';
|
|
21
|
-
export type { AgentConfig, CrewxProjectConfig, CrewxOptions, QueryOptions, QueryResult, ExecuteOptions, ExecuteResult, YamlHookEntry, GuideRule, } from './types';
|
|
21
|
+
export type { AgentConfig, CrewxProjectConfig, CrewxOptions, QueryOptions, QueryResult, ExecuteOptions, ExecuteResult, TraceContext, YamlHookEntry, GuideRule, } from './types';
|
|
22
22
|
export { AgentSkillsSchema } from './types';
|
|
23
23
|
export { loadYamlFile, parseYamlContent, ConfigLoadError } from './config/loader';
|
|
24
24
|
export { resolveAgent, AgentNotFoundError } from './agent/resolver';
|