@kelceyp/caw-server 1.0.204 → 1.0.205

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/main.js CHANGED
@@ -1174,5 +1174,5 @@ Populated:
1174
1174
  Errors:
1175
1175
  `;for(let G of H.slice(0,10))T+=` - Version PK ${G.versionPk}: ${G.error}
1176
1176
  `;if(H.length>10)T+=` ... and ${H.length-10} more errors
1177
- `}return{content:[{type:"text",text:T}]}}catch(W){return s1(W)}},qA8={name:"backfill_content_refs",title:"Backfill Content Refs",description:"Backfill content reference fields (attachments, includes, hyperlinks) on existing version entities. If confirm=false, returns preview. If confirm=true, performs backfill.",schema:Hz4,execute:wz4};var YA8=[qA8];a8();var Gz4=f.object({store:f.string().optional().describe('Store code (default: "A")'),limit:f.coerce.number().optional().describe("Maximum number of events to return (default: 50)"),offset:f.coerce.number().optional().describe("Pagination offset (default: 0)")}),Tz4=async({core:$,projectId:K},{store:q,limit:Y,offset:z})=>{try{let J=await $.listDeletedEvents(K,{store:q??"A",limit:Y??50,offset:z??0});return{content:[{type:"text",text:JSON.stringify(J,null,2)}]}}catch(J){return s1(J)}},zA8={name:"list_deleted_events",title:"List Deletion Events",description:"List deletion events. Each event represents a single delete action (e.g. deleting a folder and all its contents), identified by a root entity ID. Returns events with root entity ID, root entity info, item count, deletedAt timestamp (for display), and days until purge.",schema:Gz4,execute:Tz4};a8();var Pz4=f.object({root_entity_id:f.string().describe('Root entity ID of the deletion event (e.g. "Ad131")'),store:f.string().optional().describe('Store code (default: "A")'),limit:f.coerce.number().optional().describe("Maximum number of items to return (default: 50)"),offset:f.coerce.number().optional().describe("Pagination offset (default: 0)")}),Az4=async({core:$,projectId:K},{root_entity_id:q,store:Y,limit:z,offset:J})=>{try{let W=await $.getDeletedEvent(K,{rootEntityId:q,store:Y??"A",limit:z??50,offset:J??0});return{content:[{type:"text",text:JSON.stringify(W,null,2)}]}}catch(W){return s1(W)}},JA8={name:"get_deleted_event",title:"Get Deletion Event",description:"Get the items in a specific deletion event identified by its root entity ID. Returns root entity info and a paginated list of all entities deleted in that event.",schema:Pz4,execute:Az4};a8();var vz4=f.object({root_entity_id:f.string().describe('Root entity ID of the deletion event (e.g. "Ad131")'),store:f.string().optional().describe('Store code (default: "A")')}),Vz4=async({core:$,projectId:K},{root_entity_id:q,store:Y})=>{try{let z=await $.restoreDeletedEvent(K,{rootEntityId:q,store:Y??"A"});return{content:[{type:"text",text:JSON.stringify(z,null,2)}]}}catch(z){return s1(z)}},WA8={name:"restore_deleted_event",title:"Restore Deletion Event",description:'Restore all entities in a deletion event (identified by its root entity ID). All entities deleted in the same action are restored together. If the root entity has a name collision, it is renamed with a "-restored" suffix.',schema:vz4,execute:Vz4};var ZA8=[zA8,JA8,WA8];a8();var Mz4=f.object({}),Nz4=async({core:$,projectId:K})=>{try{let q=await $.getSystemSettings(K);return{content:[{type:"text",text:JSON.stringify(q,null,2)}]}}catch(q){return s1(q)}},OA8={name:"get_system_settings",title:"Get System Settings",description:"Returns all system settings for the project (autoArchiveDelayDays, maxConcurrentJobs, trashRetentionDays, maxResumeAttempts, defaultResumePromptRef, scratchDocDelayDays, jobDelayDays, indexingMode, batchIntervalMinutes, claudeStrategy)",schema:Mz4,execute:Nz4};a8();var jz4=f.object({settings:R0(f.object({autoArchiveDelayDays:f.number().int().optional(),maxConcurrentJobs:f.number().int().optional(),trashRetentionDays:f.number().int().optional(),maxResumeAttempts:f.number().int().optional(),defaultResumePromptRef:f.string().nullable().optional(),scratchDocDelayDays:f.number().int().optional(),jobDelayDays:f.number().int().optional(),indexingMode:f.enum(["batch","constant"]).optional(),batchIntervalMinutes:f.number().int().positive().optional(),claudeStrategy:f.enum(["pty","headless"]).optional()})).describe("Partial settings object. Only provided keys are updated.")}),fz4=async({core:$,projectId:K},{settings:q})=>{try{let Y=await $.updateSystemSettings(K,{settings:q});return{content:[{type:"text",text:JSON.stringify(Y,null,2)}]}}catch(Y){return s1(Y)}},XA8={name:"update_system_settings",title:"Update System Settings",description:'Update system settings for the project. Accepts partial updates — only provided keys are changed. Settings: autoArchiveDelayDays, maxConcurrentJobs, trashRetentionDays, maxResumeAttempts, defaultResumePromptRef, scratchDocDelayDays, jobDelayDays, indexingMode, batchIntervalMinutes, claudeStrategy. Validates values: integer fields must be positive integers; defaultResumePromptRef must be a template ID string or null (to clear); indexingMode must be "batch" or "constant"; batchIntervalMinutes must be a positive integer; claudeStrategy must be "pty" or "headless".',schema:jz4,execute:fz4};var HA8=[OA8,XA8];var wA8=T8.create({namespace:"caw:mcp"}),kz4=({core:$,projectId:K})=>{let q=new r41({name:"caw-server",version:"1.0.204"},{capabilities:{tools:{}}}),Y=[...UT8,...cT8,...tT8,...wP8,...vP8,...SP8,...yP8,...BP8,...tP8,..._A8,...YA8,...ZA8,...HA8];for(let z of Y)q.registerTool(z.name,{title:z.title,description:z.description,inputSchema:z.schema},async(J,W)=>{try{let Z=W?.sessionId||W?.requestInfo?.headers?.["mcp-session-id"];return await z.execute({core:$,projectId:K,sessionId:Z,extra:W},J)}catch(Z){if(Z.isDomainError)wA8.debug("Tool %s domain error: %o",z.name,Z);else wA8.error(`Tool ${z.name} failed:`,Z);return s1(Z)}});return q},GA8=Object.freeze({createMcpServer:kz4});var zy=T8.create({namespace:"caw:mcp"}),QK=T8.create({namespace:"caw:mcp:session"}),Rz4=({core:$})=>{let K=new Map;return Object.freeze({handleRequest:async(W,Z,{projectId:O})=>{let X=W.headers["mcp-session-id"];if(X){let P=K.get(X);if(!P)return QK.debug("Session not found: %s",X),Z.status(404).json({jsonrpc:"2.0",error:{code:-32001,message:"Session not found. Server may have been restarted. If so, ask user to reconnect"},id:null});if(P.projectId!==O)return QK.debug("Session %s belongs to project %s, not %s",X,P.projectId,O),Z.status(404).json({jsonrpc:"2.0",error:{code:-32001,message:"Session not found. Server may have been restarted. If so, ask user to reconnect"},id:null});QK.debug("Routing request to existing session: %s",X),P.lastActivity=Date.now();try{return await P.transport.handleRequest(W,Z,W.body)}catch(A){zy.error("MCP transport request failed:",A)}}QK.debug("Creating new MCP session for project: %s",O);let H=null,w=new b61({sessionIdGenerator:()=>{return H=Dz4(),QK.debug("Generated session ID: %s",H),H},onsessioninitialized:(P)=>{QK.debug("Session initialized: %s",P),Z.setHeader("Mcp-Session-Id",P),G.sessionId=P,K.set(P,G),QK.debug("Session stored: %s",P)}});QK.debug("Creating new server for session");let T=GA8.createMcpServer({core:$,projectId:O});try{await T.connect(w)}catch(P){return zy.error("MCP server connect failed:",P),w.close?.(),T.close?.(),Z.status(500).json({jsonrpc:"2.0",error:{code:-32603,message:"Internal server error"},id:null})}let G={sessionId:null,transport:w,server:T,projectId:O,createdAt:Date.now(),lastActivity:Date.now()};Z.on("finish",()=>{if(Z.statusCode!==200&&H&&K.has(H))QK.debug("Request failed (status %d), cleaning up session: %s",Z.statusCode,H),K.delete(H),w.close?.(),T.close?.()});try{await w.handleRequest(W,Z,W.body)}catch(P){zy.error("MCP transport request failed:",P)}},getSession:(W)=>{return K.get(W)},closeSession:(W)=>{let Z=K.get(W);if(!Z){QK.debug("Cannot close session - not found: %s",W);return}QK.debug("Closing session: %s",W),Z.transport.close?.(),Z.server.close?.(),K.delete(W)},cleanupIdle:(W)=>{let Z=Date.now(),O=0;for(let[X,H]of K.entries())if(Z-H.lastActivity>W)QK.debug("Cleaning up idle session: %s (idle for %dms)",X,Z-H.lastActivity),H.transport.close?.(),H.server.close?.(),K.delete(X),O++;if(O>0)zy.debug("Cleaned up %d idle sessions",O)}})},TA8=Object.freeze({create:Rz4});var Cz4=86400000,Ez4=300000,Lz4=({mcpSessionManager:$})=>{let{jobFns:K,controlFns:q}=Q3.create({name:"cleanup-idle-mcp-sessions",interval:Ez4,execute:async()=>{$.cleanupIdle(Cz4)}});return{job:Object.freeze(K),control:q}},PA8=Object.freeze({create:Lz4});var jy=T8.create({namespace:"caw:server"}),XJ4=async({port:$,envDir:K,databaseFilepath:q,assetsDir:Y,lazilyCreateDb:z,enableRest:J,enableSse:W,enableStatic:Z,enableCrons:O,enableMcp:X=!0,enableCli:H=!0,staticPath:w,kyselyFactory:T})=>{let G=await vY8.create({envDir:K,databaseFilepath:q,assetsDir:Y,lazilyCreateDb:z,kyselyFactory:T}),P=G21.default();if(P.use(G21.default.json({limit:"5mb"})),P.get("/health",(N,D)=>{D.json({status:"ok"})}),P.get("/api/info",(N,D)=>{D.json({version:"1.0.204",hookFailureCount:bF1()})}),J)P.use("/api",HW8),NY8.create(P,{core:G}),fY8.create(P,{core:G}),kY8.create(P,{core:G}),DY8.create(P,{core:G}),CY8.create(P,{core:G}),LY8.create(P,{core:G}),SY8.create(P,{core:G}),hY8.create(P,{core:G}),IY8.create(P,{core:G}),xY8.create(P,{core:G}),_W8.create(P,{core:G}),qW8.create(P,{core:G}),YW8.create(P,{core:G}),zW8.create(P,{core:G}),JW8.create(P,{core:G}),WW8.create(P,{core:G}),ZW8.create(P,{core:G});if(W)OW8.create(P,{core:G}),XW8.create(P,{core:G});if(X){jy.debug("Initializing MCP subsystem...");let N=TA8.create({core:G});G.registerCronJob(PA8,{mcpSessionManager:N}),wW8.create(P,{core:G,mcpSessionManager:N}),jy.debug("MCP subsystem initialized")}if(H){jy.debug("Initializing CLI Adapter subsystem...");let N=(await Promise.resolve().then(() => (mA8(),BA8))).default,D=(await Promise.resolve().then(() => (pA8(),QA8))).default,R=(await Promise.resolve().then(() => (dA8(),nA8))).default,L=(await Promise.resolve().then(() => (oA8(),aA8))).default,S=R.create({mcpClientFactory:N.create(),aliasGenerator:D.create(),core:G});await S.init(),G.subscribeServerEvents({onProjectCreated:(I)=>S.addProject({objectId:I.id,name:I.name,path:I.path})}),L.create(P,{cliSessionManager:S}),jy.debug("CLI Adapter subsystem initialized")}if(Z&&w)MY8.create(P,{staticPath:w});if(O)G.startAllCrons();P.use((N,D,R,L)=>{R.status(N.status||N.statusCode||500).json({error:N.message,type:N.type})});let A=null,v=new Set;return Object.freeze({app:P,core:G,start:async()=>{return new Promise((N)=>{A=P.listen($,()=>{let D=A.address().port;N(D)}),A.on("connection",(D)=>{v.add(D),D.on("close",()=>{v.delete(D)})})})},stop:async()=>{if(await G.shutdownEmbeddingPipeline(),G.stopAllCrons(),A){for(let N of v)N.destroy();return v.clear(),new Promise((N)=>{A.close(()=>{N()})})}}})},rA8=Object.freeze({create:XJ4});M6();var fy=T8.create({namespace:"caw:main"}),wJ4=2229,GJ4=ky.join(ky.dirname(HJ4(import.meta.url)),"public_html"),TJ4=!0,PJ4=!0,AJ4=!0,vJ4=!0,VJ4=!1,MJ4=!0,NJ4=!0,jJ4=!0,fJ4="debug",TW=($,K)=>$!==void 0?$==="true":K,kJ4=()=>{let $=process.env.CAW_ENV_DIR;if(!$)fy.error("ERROR: CAW_ENV_DIR environment variable is required"),fy.error("Set it to the path of your environment folder, e.g.:"),fy.error(' export CAW_ENV_DIR="$HOME/.caw/dev"'),process.exit(1);return{envDir:$,databaseFilepath:ky.join($,"caw.db"),assetsDir:ky.join($,"assets")}},DJ4=async($)=>{let K=await rA8.create($),q=await K.start();process.stdout.write(`Server listening on port ${q}
1177
+ `}return{content:[{type:"text",text:T}]}}catch(W){return s1(W)}},qA8={name:"backfill_content_refs",title:"Backfill Content Refs",description:"Backfill content reference fields (attachments, includes, hyperlinks) on existing version entities. If confirm=false, returns preview. If confirm=true, performs backfill.",schema:Hz4,execute:wz4};var YA8=[qA8];a8();var Gz4=f.object({store:f.string().optional().describe('Store code (default: "A")'),limit:f.coerce.number().optional().describe("Maximum number of events to return (default: 50)"),offset:f.coerce.number().optional().describe("Pagination offset (default: 0)")}),Tz4=async({core:$,projectId:K},{store:q,limit:Y,offset:z})=>{try{let J=await $.listDeletedEvents(K,{store:q??"A",limit:Y??50,offset:z??0});return{content:[{type:"text",text:JSON.stringify(J,null,2)}]}}catch(J){return s1(J)}},zA8={name:"list_deleted_events",title:"List Deletion Events",description:"List deletion events. Each event represents a single delete action (e.g. deleting a folder and all its contents), identified by a root entity ID. Returns events with root entity ID, root entity info, item count, deletedAt timestamp (for display), and days until purge.",schema:Gz4,execute:Tz4};a8();var Pz4=f.object({root_entity_id:f.string().describe('Root entity ID of the deletion event (e.g. "Ad131")'),store:f.string().optional().describe('Store code (default: "A")'),limit:f.coerce.number().optional().describe("Maximum number of items to return (default: 50)"),offset:f.coerce.number().optional().describe("Pagination offset (default: 0)")}),Az4=async({core:$,projectId:K},{root_entity_id:q,store:Y,limit:z,offset:J})=>{try{let W=await $.getDeletedEvent(K,{rootEntityId:q,store:Y??"A",limit:z??50,offset:J??0});return{content:[{type:"text",text:JSON.stringify(W,null,2)}]}}catch(W){return s1(W)}},JA8={name:"get_deleted_event",title:"Get Deletion Event",description:"Get the items in a specific deletion event identified by its root entity ID. Returns root entity info and a paginated list of all entities deleted in that event.",schema:Pz4,execute:Az4};a8();var vz4=f.object({root_entity_id:f.string().describe('Root entity ID of the deletion event (e.g. "Ad131")'),store:f.string().optional().describe('Store code (default: "A")')}),Vz4=async({core:$,projectId:K},{root_entity_id:q,store:Y})=>{try{let z=await $.restoreDeletedEvent(K,{rootEntityId:q,store:Y??"A"});return{content:[{type:"text",text:JSON.stringify(z,null,2)}]}}catch(z){return s1(z)}},WA8={name:"restore_deleted_event",title:"Restore Deletion Event",description:'Restore all entities in a deletion event (identified by its root entity ID). All entities deleted in the same action are restored together. If the root entity has a name collision, it is renamed with a "-restored" suffix.',schema:vz4,execute:Vz4};var ZA8=[zA8,JA8,WA8];a8();var Mz4=f.object({}),Nz4=async({core:$,projectId:K})=>{try{let q=await $.getSystemSettings(K);return{content:[{type:"text",text:JSON.stringify(q,null,2)}]}}catch(q){return s1(q)}},OA8={name:"get_system_settings",title:"Get System Settings",description:"Returns all system settings for the project (autoArchiveDelayDays, maxConcurrentJobs, trashRetentionDays, maxResumeAttempts, defaultResumePromptRef, scratchDocDelayDays, jobDelayDays, indexingMode, batchIntervalMinutes, claudeStrategy)",schema:Mz4,execute:Nz4};a8();var jz4=f.object({settings:R0(f.object({autoArchiveDelayDays:f.number().int().optional(),maxConcurrentJobs:f.number().int().optional(),trashRetentionDays:f.number().int().optional(),maxResumeAttempts:f.number().int().optional(),defaultResumePromptRef:f.string().nullable().optional(),scratchDocDelayDays:f.number().int().optional(),jobDelayDays:f.number().int().optional(),indexingMode:f.enum(["batch","constant"]).optional(),batchIntervalMinutes:f.number().int().positive().optional(),claudeStrategy:f.enum(["pty","headless"]).optional()})).describe("Partial settings object. Only provided keys are updated.")}),fz4=async({core:$,projectId:K},{settings:q})=>{try{let Y=await $.updateSystemSettings(K,{settings:q});return{content:[{type:"text",text:JSON.stringify(Y,null,2)}]}}catch(Y){return s1(Y)}},XA8={name:"update_system_settings",title:"Update System Settings",description:'Update system settings for the project. Accepts partial updates — only provided keys are changed. Settings: autoArchiveDelayDays, maxConcurrentJobs, trashRetentionDays, maxResumeAttempts, defaultResumePromptRef, scratchDocDelayDays, jobDelayDays, indexingMode, batchIntervalMinutes, claudeStrategy. Validates values: integer fields must be positive integers; defaultResumePromptRef must be a template ID string or null (to clear); indexingMode must be "batch" or "constant"; batchIntervalMinutes must be a positive integer; claudeStrategy must be "pty" or "headless".',schema:jz4,execute:fz4};var HA8=[OA8,XA8];var wA8=T8.create({namespace:"caw:mcp"}),kz4=({core:$,projectId:K})=>{let q=new r41({name:"caw-server",version:"1.0.205"},{capabilities:{tools:{}}}),Y=[...UT8,...cT8,...tT8,...wP8,...vP8,...SP8,...yP8,...BP8,...tP8,..._A8,...YA8,...ZA8,...HA8];for(let z of Y)q.registerTool(z.name,{title:z.title,description:z.description,inputSchema:z.schema},async(J,W)=>{try{let Z=W?.sessionId||W?.requestInfo?.headers?.["mcp-session-id"];return await z.execute({core:$,projectId:K,sessionId:Z,extra:W},J)}catch(Z){if(Z.isDomainError)wA8.debug("Tool %s domain error: %o",z.name,Z);else wA8.error(`Tool ${z.name} failed:`,Z);return s1(Z)}});return q},GA8=Object.freeze({createMcpServer:kz4});var zy=T8.create({namespace:"caw:mcp"}),QK=T8.create({namespace:"caw:mcp:session"}),Rz4=({core:$})=>{let K=new Map;return Object.freeze({handleRequest:async(W,Z,{projectId:O})=>{let X=W.headers["mcp-session-id"];if(X){let P=K.get(X);if(!P)return QK.debug("Session not found: %s",X),Z.status(404).json({jsonrpc:"2.0",error:{code:-32001,message:"Session not found. Server may have been restarted. If so, ask user to reconnect"},id:null});if(P.projectId!==O)return QK.debug("Session %s belongs to project %s, not %s",X,P.projectId,O),Z.status(404).json({jsonrpc:"2.0",error:{code:-32001,message:"Session not found. Server may have been restarted. If so, ask user to reconnect"},id:null});QK.debug("Routing request to existing session: %s",X),P.lastActivity=Date.now();try{return await P.transport.handleRequest(W,Z,W.body)}catch(A){zy.error("MCP transport request failed:",A)}}QK.debug("Creating new MCP session for project: %s",O);let H=null,w=new b61({sessionIdGenerator:()=>{return H=Dz4(),QK.debug("Generated session ID: %s",H),H},onsessioninitialized:(P)=>{QK.debug("Session initialized: %s",P),Z.setHeader("Mcp-Session-Id",P),G.sessionId=P,K.set(P,G),QK.debug("Session stored: %s",P)}});QK.debug("Creating new server for session");let T=GA8.createMcpServer({core:$,projectId:O});try{await T.connect(w)}catch(P){return zy.error("MCP server connect failed:",P),w.close?.(),T.close?.(),Z.status(500).json({jsonrpc:"2.0",error:{code:-32603,message:"Internal server error"},id:null})}let G={sessionId:null,transport:w,server:T,projectId:O,createdAt:Date.now(),lastActivity:Date.now()};Z.on("finish",()=>{if(Z.statusCode!==200&&H&&K.has(H))QK.debug("Request failed (status %d), cleaning up session: %s",Z.statusCode,H),K.delete(H),w.close?.(),T.close?.()});try{await w.handleRequest(W,Z,W.body)}catch(P){zy.error("MCP transport request failed:",P)}},getSession:(W)=>{return K.get(W)},closeSession:(W)=>{let Z=K.get(W);if(!Z){QK.debug("Cannot close session - not found: %s",W);return}QK.debug("Closing session: %s",W),Z.transport.close?.(),Z.server.close?.(),K.delete(W)},cleanupIdle:(W)=>{let Z=Date.now(),O=0;for(let[X,H]of K.entries())if(Z-H.lastActivity>W)QK.debug("Cleaning up idle session: %s (idle for %dms)",X,Z-H.lastActivity),H.transport.close?.(),H.server.close?.(),K.delete(X),O++;if(O>0)zy.debug("Cleaned up %d idle sessions",O)}})},TA8=Object.freeze({create:Rz4});var Cz4=86400000,Ez4=300000,Lz4=({mcpSessionManager:$})=>{let{jobFns:K,controlFns:q}=Q3.create({name:"cleanup-idle-mcp-sessions",interval:Ez4,execute:async()=>{$.cleanupIdle(Cz4)}});return{job:Object.freeze(K),control:q}},PA8=Object.freeze({create:Lz4});var jy=T8.create({namespace:"caw:server"}),XJ4=async({port:$,envDir:K,databaseFilepath:q,assetsDir:Y,lazilyCreateDb:z,enableRest:J,enableSse:W,enableStatic:Z,enableCrons:O,enableMcp:X=!0,enableCli:H=!0,staticPath:w,kyselyFactory:T})=>{let G=await vY8.create({envDir:K,databaseFilepath:q,assetsDir:Y,lazilyCreateDb:z,kyselyFactory:T}),P=G21.default();if(P.use(G21.default.json({limit:"5mb"})),P.get("/health",(N,D)=>{D.json({status:"ok"})}),P.get("/api/info",(N,D)=>{D.json({version:"1.0.205",hookFailureCount:bF1()})}),J)P.use("/api",HW8),NY8.create(P,{core:G}),fY8.create(P,{core:G}),kY8.create(P,{core:G}),DY8.create(P,{core:G}),CY8.create(P,{core:G}),LY8.create(P,{core:G}),SY8.create(P,{core:G}),hY8.create(P,{core:G}),IY8.create(P,{core:G}),xY8.create(P,{core:G}),_W8.create(P,{core:G}),qW8.create(P,{core:G}),YW8.create(P,{core:G}),zW8.create(P,{core:G}),JW8.create(P,{core:G}),WW8.create(P,{core:G}),ZW8.create(P,{core:G});if(W)OW8.create(P,{core:G}),XW8.create(P,{core:G});if(X){jy.debug("Initializing MCP subsystem...");let N=TA8.create({core:G});G.registerCronJob(PA8,{mcpSessionManager:N}),wW8.create(P,{core:G,mcpSessionManager:N}),jy.debug("MCP subsystem initialized")}if(H){jy.debug("Initializing CLI Adapter subsystem...");let N=(await Promise.resolve().then(() => (mA8(),BA8))).default,D=(await Promise.resolve().then(() => (pA8(),QA8))).default,R=(await Promise.resolve().then(() => (dA8(),nA8))).default,L=(await Promise.resolve().then(() => (oA8(),aA8))).default,S=R.create({mcpClientFactory:N.create(),aliasGenerator:D.create(),core:G});await S.init(),G.subscribeServerEvents({onProjectCreated:(I)=>S.addProject({objectId:I.id,name:I.name,path:I.path})}),L.create(P,{cliSessionManager:S}),jy.debug("CLI Adapter subsystem initialized")}if(Z&&w)MY8.create(P,{staticPath:w});if(O)G.startAllCrons();P.use((N,D,R,L)=>{R.status(N.status||N.statusCode||500).json({error:N.message,type:N.type})});let A=null,v=new Set;return Object.freeze({app:P,core:G,start:async()=>{return new Promise((N)=>{A=P.listen($,()=>{let D=A.address().port;N(D)}),A.on("connection",(D)=>{v.add(D),D.on("close",()=>{v.delete(D)})})})},stop:async()=>{if(await G.shutdownEmbeddingPipeline(),G.stopAllCrons(),A){for(let N of v)N.destroy();return v.clear(),new Promise((N)=>{A.close(()=>{N()})})}}})},rA8=Object.freeze({create:XJ4});M6();var fy=T8.create({namespace:"caw:main"}),wJ4=2229,GJ4=ky.join(ky.dirname(HJ4(import.meta.url)),"public_html"),TJ4=!0,PJ4=!0,AJ4=!0,vJ4=!0,VJ4=!1,MJ4=!0,NJ4=!0,jJ4=!0,fJ4="debug",TW=($,K)=>$!==void 0?$==="true":K,kJ4=()=>{let $=process.env.CAW_ENV_DIR;if(!$)fy.error("ERROR: CAW_ENV_DIR environment variable is required"),fy.error("Set it to the path of your environment folder, e.g.:"),fy.error(' export CAW_ENV_DIR="$HOME/.caw/dev"'),process.exit(1);return{envDir:$,databaseFilepath:ky.join($,"caw.db"),assetsDir:ky.join($,"assets")}},DJ4=async($)=>{let K=await rA8.create($),q=await K.start();process.stdout.write(`Server listening on port ${q}
1178
1178
  `),process.on("SIGINT",()=>K.stop("SIGINT")),process.on("SIGTERM",()=>K.stop("SIGTERM"))},RJ4=()=>{let{envDir:$,databaseFilepath:K,assetsDir:q}=kJ4(),Y=process.env.CAW_PORT?Number(process.env.CAW_PORT):wJ4,z=process.env.STATIC_PATH||GJ4,J=TW(process.env.LAZY_CREATE_DB,TJ4),W=TW(process.env.ENABLE_REST,PJ4),Z=TW(process.env.ENABLE_MCP,AJ4),O=TW(process.env.ENABLE_CLI,vJ4),X=TW(process.env.ENABLE_WEBLLM_WSS,VJ4),H=TW(process.env.ENABLE_SSE,MJ4),w=TW(process.env.ENABLE_STATIC,NJ4),T=TW(process.env.ENABLE_CRONS,jJ4),G=process.env.LOG_LEVEL||fJ4;return Object.freeze({port:Y,staticPath:z,envDir:$,databaseFilepath:K,assetsDir:q,lazilyCreateDb:J,enableRest:W,enableMcp:Z,enableCli:O,enableWebllmWss:X,enableSse:H,enableStatic:w,enableCrons:T,logLevel:G})},sA8=RJ4();T8.setLevel(sA8.logLevel);await DJ4(sA8).catch(($)=>{fy.error("ERROR: Failed to start server:",$),process.exit(1)});