toolpack-sdk 2.2.0 → 2.3.0
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/index.cjs +137 -137
- package/dist/index.d.cts +364 -329
- package/dist/index.d.ts +364 -329
- package/dist/index.js +138 -138
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var Fw=Object.defineProperty;var h=(r,e)=>()=>(r&&(e=r(r=0)),e);var ee=(r,e)=>{for(var t in e)Fw(r,t,{get:e[t],enumerable:!0})};import qw from"path";import{fileURLToPath as Ww}from"url";var Uw,Gw,u,c=h(()=>{"use strict";Uw=()=>Ww(import.meta.url),Gw=()=>qw.dirname(Uw()),u=Gw()});function gS(r){return!r||typeof r!="object"?!1:["CONTEXT_WINDOW_EXCEEDED","INSUFFICIENT_CONTEXT","SUMMARIZATION_ERROR","CONTEXT_WINDOW_CONFIG_ERROR","CONVERSATION_NOT_FOUND"].includes(r.code)}function hS(r,e){return r instanceof Kr?{shouldRetry:r.isRetryable(),shouldFallback:!0,action:r.isRetryable()?"prune":"fail",message:r.getSuggestedRecovery()}:r instanceof zr?{shouldRetry:!1,shouldFallback:!0,action:r.strategy==="fail"?"prune":"none",message:`Context window exceeded. Strategy: ${r.strategy}`}:r instanceof Hr?{shouldRetry:!1,shouldFallback:!0,action:"fail",message:"Insufficient context after recovery attempts"}:{shouldRetry:!1,shouldFallback:!1,action:"none",message:"Unknown context window error"}}var N,ve,fe,L,W,Xe,pa,ma,zr,Hr,Kr,da,ua,le=h(()=>{"use strict";c();N=class extends Error{constructor(t,o,n,s){super(t);this.code=o;this.statusCode=n;this.cause=s;this.name="SDKError"}code;statusCode;cause},ve=class extends N{constructor(e,t){super(e,"AUTHENTICATION_ERROR",401,t),this.name="AuthenticationError"}},fe=class extends N{constructor(t,o,n){super(t,"RATE_LIMIT_ERROR",429,n);this.retryAfter=o;this.name="RateLimitError"}retryAfter},L=class extends N{constructor(e,t){super(e,"INVALID_REQUEST_ERROR",400,t),this.name="InvalidRequestError"}},W=class extends N{constructor(e,t="PROVIDER_ERROR",o=500,n){super(e,t,o,n),this.name="ProviderError"}},Xe=class extends N{constructor(e,t){super(e,"CONNECTION_ERROR",503,t),this.name="ConnectionError"}},pa=class extends N{constructor(t,o,n){super(t,"PAGE_ERROR",502,n);this.pageUrl=o;this.name="PageError"}pageUrl},ma=class extends N{constructor(t,o,n){super(t,"TIMEOUT_ERROR",504,n);this.phase=o;this.name="TimeoutError"}phase},zr=class extends N{constructor(t,o,n,s,i,a){super(t,"CONTEXT_WINDOW_EXCEEDED",400,a);this.conversationId=o;this.currentTokens=n;this.contextWindowLimit=s;this.strategy=i;this.name="ContextWindowExceededError"}conversationId;currentTokens;contextWindowLimit;strategy;getOverageTokens(){return Math.max(0,this.currentTokens-this.contextWindowLimit)}getUsagePercentage(){return Math.round(this.currentTokens/this.contextWindowLimit*100)}getDetailedReport(){return`
|
|
2
2
|
Context Window Exceeded
|
|
3
3
|
=======================
|
|
4
4
|
Conversation ID: ${this.conversationId}
|
|
@@ -9,7 +9,7 @@ Usage: ${this.getUsagePercentage()}%
|
|
|
9
9
|
Strategy: ${this.strategy}
|
|
10
10
|
|
|
11
11
|
Message: ${this.message}
|
|
12
|
-
`.trim()}},
|
|
12
|
+
`.trim()}},Hr=class extends N{constructor(t,o,n,s,i,a){super(t,"INSUFFICIENT_CONTEXT",400,a);this.conversationId=o;this.requiredTokens=n;this.availableTokens=s;this.minimumRequiredTokens=i;this.name="InsufficientContextError"}conversationId;requiredTokens;availableTokens;minimumRequiredTokens;getDeficit(){return Math.max(0,this.requiredTokens-this.availableTokens)}isRecoverable(){return this.availableTokens>=this.minimumRequiredTokens*.5}getDetailedReport(){return`
|
|
13
13
|
Insufficient Context
|
|
14
14
|
====================
|
|
15
15
|
Conversation ID: ${this.conversationId}
|
|
@@ -20,7 +20,7 @@ Minimum Required: ${this.minimumRequiredTokens}
|
|
|
20
20
|
Recoverable: ${this.isRecoverable()?"Yes":"No"}
|
|
21
21
|
|
|
22
22
|
Message: ${this.message}
|
|
23
|
-
`.trim()}},
|
|
23
|
+
`.trim()}},Kr=class extends N{constructor(t,o,n,s,i,a){super(t,"SUMMARIZATION_ERROR",500,a);this.conversationId=o;this.messageCount=n;this.failureReason=s;this.summaryAttempt=i;this.name="SummarizationError"}conversationId;messageCount;failureReason;summaryAttempt;isRetryable(){return this.failureReason==="provider_error"||this.failureReason==="insufficient_tokens"}getSuggestedRecovery(){switch(this.failureReason){case"provider_error":return"Retry the summarization request or switch to a different summarizer model";case"invalid_response":return"Review the summarizer prompt or use a different model";case"insufficient_tokens":return"Reduce the number of messages to summarize or increase the summary token budget";case"invalid_quality":return"Adjust summarization parameters or use a more capable model";default:return"Manual intervention required"}}getDetailedReport(){let t=`
|
|
24
24
|
Summarization Error
|
|
25
25
|
===================
|
|
26
26
|
Conversation ID: ${this.conversationId}
|
|
@@ -32,7 +32,7 @@ Recovery Action: ${this.getSuggestedRecovery()}
|
|
|
32
32
|
Message: ${this.message}`;return this.summaryAttempt?t+`
|
|
33
33
|
|
|
34
34
|
Partial Summary:
|
|
35
|
-
${this.summaryAttempt.substring(0,500)}${this.summaryAttempt.length>500?"...":""}`:t.trim()}},
|
|
35
|
+
${this.summaryAttempt.substring(0,500)}${this.summaryAttempt.length>500?"...":""}`:t.trim()}},da=class extends N{constructor(t,o,n,s,i){super(t,"CONTEXT_WINDOW_CONFIG_ERROR",400,i);this.configField=o;this.providedValue=n;this.constraint=s;this.name="ContextWindowConfigError"}configField;providedValue;constraint;getDetailedReport(){return`
|
|
36
36
|
Context Window Configuration Error
|
|
37
37
|
===================================
|
|
38
38
|
Field: ${this.configField}
|
|
@@ -40,58 +40,58 @@ Provided Value: ${JSON.stringify(this.providedValue)}
|
|
|
40
40
|
Constraint: ${this.constraint}
|
|
41
41
|
|
|
42
42
|
Message: ${this.message}
|
|
43
|
-
`.trim()}},
|
|
43
|
+
`.trim()}},ua=class extends N{constructor(t,o,n){super(t,"CONVERSATION_NOT_FOUND",404,n);this.conversationId=o;this.name="ConversationNotFoundError"}conversationId}});var gt,Wt,Yw,Ca=h(()=>{"use strict";c();gt={name:3,displayName:2.5,description:2,category:1.5,parameterNames:1,parameterDescriptions:.5},Wt=class{documents=[];avgDocLength=0;idf=new Map;totalDocs=0;docFrequencies=new Map;k1=1.2;b=.75;index(e){this.documents=[],this.docFrequencies.clear(),this.idf.clear();for(let t of e){let o=this.createDocument(t);this.documents.push(o);let n=new Set(o.tokens);for(let s of n)this.docFrequencies.set(s,(this.docFrequencies.get(s)||0)+1)}this.totalDocs=this.documents.length,this.computeIDF(),this.avgDocLength=this.computeAvgDocLength()}search(e,t){let o=t?.limit??5,n=t?.category,s=t?.minScore??0,i=this.tokenize(e.toLowerCase());if(i.length===0)return[];let a=[];for(let l of this.documents){if(n&&l.tool.category!==n)continue;let p=this.computeBM25Score(i,l);p>s&&a.push({toolName:l.toolName,score:p,tool:l.tool})}return a.sort((l,p)=>p.score-l.score).slice(0,o).map(({toolName:l,score:p,tool:m})=>({toolName:l,score:p,tool:this.toSchema(m)}))}getIndexedCount(){return this.documents.length}isIndexed(e){return this.documents.some(t=>t.toolName===e)}createDocument(e){let t=[];for(let i=0;i<gt.name;i++)t.push(e.name);for(let i=0;i<gt.displayName;i++)t.push(e.displayName);for(let i=0;i<gt.description;i++)t.push(e.description);for(let i=0;i<gt.category;i++)t.push(e.category);if(e.parameters?.properties)for(let[i,a]of Object.entries(e.parameters.properties)){for(let l=0;l<gt.parameterNames;l++)t.push(i);if(a.description)for(let l=0;l<gt.parameterDescriptions;l++)t.push(a.description)}let o=t.join(" ").toLowerCase(),n=this.tokenize(o),s=this.computeTermFrequencies(n);return{toolName:e.name,tool:e,text:o,tokens:n,length:n.length,termFrequencies:s}}tokenize(e){return e.toLowerCase().split(/[^a-z0-9]+/).filter(t=>t.length>1).filter(t=>!Yw.has(t))}computeTermFrequencies(e){let t=new Map;for(let o of e)t.set(o,(t.get(o)||0)+1);return t}computeIDF(){this.idf.clear();for(let[e,t]of this.docFrequencies){let o=Math.log((this.totalDocs-t+.5)/(t+.5)+1);this.idf.set(e,o)}}computeAvgDocLength(){return this.documents.length===0?0:this.documents.reduce((t,o)=>t+o.length,0)/this.documents.length}computeBM25Score(e,t){let o=0;for(let n of e){let s=t.termFrequencies.get(n)||0;if(s===0)continue;let i=this.idf.get(n)||0,a=t.length,l=s*(this.k1+1),p=s+this.k1*(1-this.b+this.b*(a/this.avgDocLength));o+=i*(l/p)}return o}toSchema(e){return{name:e.name,displayName:e.displayName,description:e.description,parameters:e.parameters,category:e.category}}},Yw=new Set(["a","an","the","and","or","but","in","on","at","to","for","of","with","by","from","as","is","was","are","were","been","be","have","has","had","do","does","did","will","would","could","should","may","might","must","shall","can","need","it","its","this","that","these","those","i","you","he","she","we","they","what","which","who","whom","when","where","why","how","all","each","every","both","few","more","most","other","some","such","no","nor","not","only","own","same","so","than","too","very","just","also","now","here","there"])});var ht,Sa=h(()=>{"use strict";c();ht=class r{discoveredTools=new Set;searchHistory=[];recordDiscovery(e,t){for(let o of t)this.discoveredTools.add(o);this.searchHistory.push({query:e,tools:t,timestamp:Date.now()})}getDiscoveredTools(){return Array.from(this.discoveredTools)}isDiscovered(e){return this.discoveredTools.has(e)}getDiscoveredCount(){return this.discoveredTools.size}getSearchHistory(){return[...this.searchHistory]}static fromMessages(e){let t=new r;for(let o of e)if(o.role==="tool"){let n=o;if(typeof n.content=="string")try{let s=JSON.parse(n.content);if(s.query&&s.tools&&Array.isArray(s.tools)){let i=s.tools.map(a=>typeof a=="string"?a:a.name).filter(Boolean);i.length>0&&t.recordDiscovery(s.query,i)}}catch{}}return t}clear(){this.discoveredTools.clear(),this.searchHistory=[]}merge(e){for(let t of e.getDiscoveredTools())this.discoveredTools.add(t);this.searchHistory.push(...e.getSearchHistory())}}});function Ze(){return{name:yt.name,displayName:yt.displayName,description:yt.description,parameters:yt.parameters,category:yt.category}}function bt(r){return r===Ye}var Ye,yt,ka=h(()=>{"use strict";c();Ye="tool.search",yt={name:Ye,displayName:"Search Tools",category:"meta",description:`Search for available tools by keyword or natural language query.
|
|
44
44
|
Use this to discover tools before using them.
|
|
45
45
|
Examples: "file operations", "web scraping", "run command", "http request"
|
|
46
46
|
|
|
47
47
|
Returns a list of matching tools with their names, descriptions, and parameters.
|
|
48
|
-
After discovering tools, you can call them directly by name.`,parameters:{type:"object",properties:{query:{type:"string",description:'Natural language search query (e.g., "read files", "web scraping", "execute shell commands")'},category:{type:"string",description:"Optional: filter by category",enum:["filesystem","network","execution","system","meta"]}},required:["query"]},execute:async()=>{throw new Error("tool.search execution must be handled by AIClient")}}});function
|
|
49
|
-
`)}var
|
|
50
|
-
`)}catch(e){console.warn(`[Toolpack Warning] Failed to initialize log file "${
|
|
51
|
-
`),es&&(r==="error"?console.error:r==="warn"?console.warn:console.log)(o)}function pe(r){zt("error",r)}function I(r){zt("warn",r)}function P(r){zt("info",r)}function y(r){zt("debug",r)}function Ie(r){zt("trace",r)}function Ea(r){return r.replace(/\bsk-[A-Za-z0-9_-]{10,}\b/g,"[REDACTED]").replace(/\bsk-proj-[A-Za-z0-9_-]{10,}\b/g,"[REDACTED]").replace(/\bAIza[0-9A-Za-z_-]{10,}\b/g,"[REDACTED]").replace(/\bBearer\s+[A-Za-z0-9._-]{10,}\b/g,"Bearer [REDACTED]").replace(/\bghs_[A-Za-z0-9]{10,}\b/g,"ghs_[REDACTED]").replace(/\bghp_[A-Za-z0-9]{10,}\b/g,"ghp_[REDACTED]").replace(/\bghu_[A-Za-z0-9]{10,}\b/g,"ghu_[REDACTED]").replace(/\bghr_[A-Za-z0-9]{10,}\b/g,"ghr_[REDACTED]")}function O(r,e=200){try{let t=typeof r=="string"?r:JSON.stringify(r),o=Ea(t);return o.length<=e?o:`${o.slice(0,e)}\u2026`}catch{return"[Unserializable]"}}function te(r,e,t){et("debug")&&(y(`[${e}][${r}] Messages (${t.length}):`),t.forEach((o,n)=>{y(`[${e}][${r}] #${n} role=${o?.role} content=${O(o?.content,300)}`)}))}var Zr,wt,Bt,ve,es,k=h(()=>{"use strict";c();Zr={error:0,warn:1,info:2,debug:3,trace:4},wt=!1,Bt="info",ve=nT(process.cwd(),"toolpack-sdk.log"),es=!1});var Ht={};ee(Ht,{fetchUrlAsBase64:()=>Wa,getMimeType:()=>La,isDataUri:()=>ja,normalizeImagePart:()=>lT,parseDataUri:()=>Fa,readFileAsBase64:()=>qa,toDataUri:()=>aT});import*as Na from"fs/promises";import*as Ia from"path";function La(r){let e=Ia.extname(r).toLowerCase();return iT[e]||"application/octet-stream"}function ja(r){return r.startsWith("data:")}function Fa(r){let e=r.match(/^data:(.*?);base64,(.+)$/);return e?{mimeType:e[1],data:e[2]}:null}function aT(r,e){return`data:${e};base64,${r}`}async function qa(r){try{return{data:(await Na.readFile(r)).toString("base64"),mimeType:La(r)}}catch(e){throw new L(`Failed to read image file: ${r}`,e)}}async function Wa(r){try{let e=await fetch(r);if(!e.ok)throw new Error(`HTTP ${e.status} ${e.statusText}`);let t=await e.arrayBuffer(),o=Buffer.from(t),n=e.headers.get("content-type")||"application/octet-stream";return n=n.split(";")[0].trim(),{data:o.toString("base64"),mimeType:n}}catch(e){throw new q(`Failed to download image from URL: ${r}`,"FETCH_ERROR",500,e)}}async function lT(r){if(r.type==="image_data")return{data:r.image_data.data,mimeType:r.image_data.mimeType};if(r.type==="image_file")return await qa(r.image_file.path);if(r.type==="image_url"){let e=r.image_url.url;if(ja(e)){let t=Fa(e);if(!t)throw new L(`Malformed data URI provided in image_url: ${e.substring(0,50)}...`);return t}return await Wa(e)}throw new L(`Unknown ImagePart type: ${r.type}`)}var iT,Tt=h(()=>{"use strict";c();le();iT={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".webp":"image/webp",".gif":"image/gif",".heic":"image/heic",".heif":"image/heif"}});var Xa,Ya,Za,el,tl,ol=h(()=>{"use strict";c();Xa="fs.read_file",Ya="Read File",Za="Read the contents of a file at the given path. Returns the file content as a string.",el="filesystem",tl={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to read"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path"]}});import*as vt from"fs";async function wT(r){let e=r.path,t=r.encoding||"utf-8";if(y(`[fs.read-file] execute path="${e}" encoding=${t}`),!e)throw new Error("path is required");if(!vt.existsSync(e))throw new Error(`File not found: ${e}`);if(vt.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}`);return vt.readFileSync(e,t)}var Qt,is=h(()=>{"use strict";c();ol();k();Qt={name:Xa,displayName:Ya,description:Za,parameters:tl,category:el,execute:wT}});var nl,rl,sl,il,al,ll=h(()=>{"use strict";c();nl="fs.write_file",rl="Write File",sl="Write content to a file. Creates parent directories if they do not exist. Overwrites existing files. IMPORTANT: Do NOT use this to delete/remove files - use fs.delete_file for that.",il="filesystem",al={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to write"},content:{type:"string",description:"Content to write to the file"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path","content"]}});import*as Ct from"fs";import*as cl from"path";async function TT(r){let e=r.path,t=r.content,o=r.encoding||"utf-8";if(y(`[fs.write-file] execute path="${e}" encoding=${o} content_len=${t?.length??0}`),!e)throw new Error("path is required");if(t==null)throw new Error("content is required");let n=cl.dirname(e);return Ct.existsSync(n)||Ct.mkdirSync(n,{recursive:!0}),Ct.writeFileSync(e,t,o),`File written successfully: ${e} (${Buffer.byteLength(t,o)} bytes)`}var Xt,as=h(()=>{"use strict";c();ll();k();Xt={name:nl,displayName:rl,description:sl,parameters:al,category:il,execute:TT,confirmation:{level:"high",reason:"This will overwrite the entire file contents.",showArgs:["path"]}}});var pl,ml,dl,ul,fl,gl=h(()=>{"use strict";c();pl="fs.append_file",ml="Append File",dl="Append content to the end of a file. Creates the file if it does not exist.",ul="filesystem",fl={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to append to"},content:{type:"string",description:"Content to append to the file"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path","content"]}});import*as St from"fs";import*as hl from"path";async function xT(r){let e=r.path,t=r.content,o=r.encoding||"utf-8";if(!e)throw new Error("path is required");if(t==null)throw new Error("content is required");let n=hl.dirname(e);return St.existsSync(n)||St.mkdirSync(n,{recursive:!0}),St.appendFileSync(e,t,o),`Content appended to: ${e} (${Buffer.byteLength(t,o)} bytes appended)`}var Yt,ls=h(()=>{"use strict";c();gl();Yt={name:pl,displayName:ml,description:dl,parameters:fl,category:ul,execute:xT,confirmation:{level:"medium",reason:"This will modify the file by appending content.",showArgs:["path"]}}});var yl,bl,wl,Tl,xl,vl=h(()=>{"use strict";c();yl="fs.delete_file",bl="Delete File",wl="Remove/delete a file from the filesystem. Does not delete directories.",Tl="filesystem",xl={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to delete"}},required:["path"]}});import*as kt from"fs";async function vT(r){let e=r.path;if(y(`[fs.delete-file] execute path="${e}"`),!e)throw new Error("path is required");if(!kt.existsSync(e))throw new Error(`File not found: ${e}`);if(kt.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}. Use a different tool to remove directories.`);return kt.unlinkSync(e),`File deleted successfully: ${e}`}var Zt,cs=h(()=>{"use strict";c();vl();k();Zt={name:yl,displayName:bl,description:wl,parameters:xl,category:Tl,execute:vT,confirmation:{level:"high",reason:"This will permanently delete the file. This action cannot be undone.",showArgs:["path"]}}});var Cl,Sl,kl,Pl,_l,Rl=h(()=>{"use strict";c();Cl="fs.exists",Sl="Exists",kl="Check if a file or directory exists at the given path. Returns true or false.",Pl="filesystem",_l={type:"object",properties:{path:{type:"string",description:"Absolute or relative path to check"}},required:["path"]}});import*as $l from"fs";async function CT(r){let e=r.path;if(!e)throw new Error("path is required");let t=$l.existsSync(e);return JSON.stringify({exists:t,path:e})}var eo,ps=h(()=>{"use strict";c();Rl();eo={name:Cl,displayName:Sl,description:kl,parameters:_l,category:Pl,execute:CT}});var El,Dl,Ml,Ol,Al,Nl=h(()=>{"use strict";c();El="fs.stat",Dl="Stat",Ml="Get file or directory information including size, type, and modification date.",Ol="filesystem",Al={type:"object",properties:{path:{type:"string",description:"Absolute or relative path to get info for"}},required:["path"]}});import*as An from"fs";async function ST(r){let e=r.path;if(!e)throw new Error("path is required");if(!An.existsSync(e))throw new Error(`Path not found: ${e}`);let t=An.statSync(e);return JSON.stringify({path:e,type:t.isDirectory()?"directory":t.isFile()?"file":"other",size:t.size,created:t.birthtime.toISOString(),modified:t.mtime.toISOString(),accessed:t.atime.toISOString(),permissions:t.mode.toString(8)})}var to,ms=h(()=>{"use strict";c();Nl();to={name:El,displayName:Dl,description:Ml,parameters:Al,category:Ol,execute:ST}});var Il,Ll,jl,Fl,ql,Wl=h(()=>{"use strict";c();Il="fs.list_dir",Ll="List Directory",jl="List files and directories at the given path. Optionally recurse into subdirectories.",Fl="filesystem",ql={type:"object",properties:{path:{type:"string",description:"Absolute or relative directory path to list"},recursive:{type:"boolean",description:"Whether to list recursively (default: false)",default:!1}},required:["path"]}});import*as nt from"fs";import*as Ul from"path";function Gl(r,e,t,o=""){let n=nt.readdirSync(r,{withFileTypes:!0});for(let s of n){let i=Ul.join(r,s.name),a=o?`${o}/${s.name}`:s.name;if(s.isDirectory())t.push({name:a,type:"directory",size:0}),e&&Gl(i,!0,t,a);else if(s.isFile()){let l=nt.statSync(i);t.push({name:a,type:"file",size:l.size})}}}async function kT(r){let e=r.path,t=r.recursive===!0;if(!e)throw new Error("path is required");if(!nt.existsSync(e))throw new Error(`Directory not found: ${e}`);if(!nt.statSync(e).isDirectory())throw new Error(`Path is not a directory: ${e}`);let n=[];return Gl(e,t,n),JSON.stringify(n,null,2)}var oo,ds=h(()=>{"use strict";c();Wl();oo={name:Il,displayName:Ll,description:jl,parameters:ql,category:Fl,execute:kT}});var Bl,zl,Hl,Kl,Jl,Vl=h(()=>{"use strict";c();Bl="fs.create_dir",zl="Create Directory",Hl="Create a directory at the given path. Creates parent directories recursively if they do not exist.",Kl="filesystem",Jl={type:"object",properties:{path:{type:"string",description:"Absolute or relative directory path to create"},recursive:{type:"boolean",description:"Create parent directories if they do not exist (default: true)",default:!0}},required:["path"]}});import*as Pt from"fs";async function PT(r){let e=r.path,t=r.recursive!==!1;if(!e)throw new Error("path is required");if(Pt.existsSync(e)){if(Pt.statSync(e).isDirectory())return`Directory already exists: ${e}`;throw new Error(`Path exists but is not a directory: ${e}`)}return Pt.mkdirSync(e,{recursive:t}),`Directory created: ${e}`}var no,us=h(()=>{"use strict";c();Vl();no={name:Bl,displayName:zl,description:Hl,parameters:Jl,category:Kl,execute:PT}});var Ql,Xl,Yl,Zl,ec,tc=h(()=>{"use strict";c();Ql="fs.move",Xl="Move",Yl="Move or rename a file or directory from one path to another.",Zl="filesystem",ec={type:"object",properties:{path:{type:"string",description:"Source path (file or directory)"},new_path:{type:"string",description:"Destination path"}},required:["path","new_path"]}});import*as rt from"fs";import*as oc from"path";async function _T(r){let e=r.path,t=r.new_path;if(!e)throw new Error("path is required");if(!t)throw new Error("new_path is required");if(!rt.existsSync(e))throw new Error(`Source not found: ${e}`);let o=oc.dirname(t);return rt.existsSync(o)||rt.mkdirSync(o,{recursive:!0}),rt.renameSync(e,t),`Moved: ${e} \u2192 ${t}`}var ro,fs=h(()=>{"use strict";c();tc();ro={name:Ql,displayName:Xl,description:Yl,parameters:ec,category:Zl,execute:_T,confirmation:{level:"high",reason:"This will move/rename the file or directory, potentially overwriting the destination.",showArgs:["path","new_path"]}}});var nc,rc,sc,ic,ac,lc=h(()=>{"use strict";c();nc="fs.copy",rc="Copy",sc="Copy a file or directory from one path to another. Recursively copies directories.",ic="filesystem",ac={type:"object",properties:{path:{type:"string",description:"Source path (file or directory)"},new_path:{type:"string",description:"Destination path"}},required:["path","new_path"]}});import*as me from"fs";import*as so from"path";function cc(r,e){if(me.statSync(r).isDirectory()){me.existsSync(e)||me.mkdirSync(e,{recursive:!0});let o=me.readdirSync(r);for(let n of o)cc(so.join(r,n),so.join(e,n))}else me.copyFileSync(r,e)}async function RT(r){let e=r.path,t=r.new_path;if(!e)throw new Error("path is required");if(!t)throw new Error("new_path is required");if(!me.existsSync(e))throw new Error(`Source not found: ${e}`);let o=so.dirname(t);return me.existsSync(o)||me.mkdirSync(o,{recursive:!0}),cc(e,t),`Copied ${me.statSync(e).isDirectory()?"directory":"file"}: ${e} \u2192 ${t}`}var io,gs=h(()=>{"use strict";c();lc();io={name:nc,displayName:rc,description:sc,parameters:ac,category:ic,execute:RT,confirmation:{level:"medium",reason:"This will copy files or directories, potentially overwriting the destination.",showArgs:["path","new_path"]}}});var pc,mc,dc,uc,fc,gc=h(()=>{"use strict";c();pc="fs.read_file_range",mc="Read File Range",dc="Read a specific range of lines from a file. Useful for reading portions of large files without loading the entire content.",uc="filesystem",fc={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to read"},start_line:{type:"integer",description:"Start line number (1-indexed)"},end_line:{type:"integer",description:"End line number (1-indexed, inclusive)"}},required:["path","start_line","end_line"]}});import*as _t from"fs";async function $T(r){let e=r.path,t=r.start_line,o=r.end_line;if(!e)throw new Error("path is required");if(t==null)throw new Error("start_line is required");if(o==null)throw new Error("end_line is required");if(t<1)throw new Error("start_line must be >= 1");if(o<t)throw new Error("end_line must be >= start_line");if(!_t.existsSync(e))throw new Error(`File not found: ${e}`);if(_t.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}`);let i=_t.readFileSync(e,"utf-8").split(`
|
|
52
|
-
`),a=i.length,l=Math.min(t,a),p=Math.min(o,a),d=i.slice(l-1,p).map((g,
|
|
48
|
+
After discovering tools, you can call them directly by name.`,parameters:{type:"object",properties:{query:{type:"string",description:'Natural language search query (e.g., "read files", "web scraping", "execute shell commands")'},category:{type:"string",description:"Optional: filter by category",enum:["filesystem","network","execution","system","meta"]}},required:["query"]},execute:async()=>{throw new Error("tool.search execution must be handled by AIClient")}}});function Zr(r){let e=r.getCategories();if(e.length===0)return"No tools are currently available.";let t=["You have access to tools in the following categories:",""];for(let o of e){let s=r.getByCategory(o).length,i=Zw[o]||o;t.push(`- **${o}** (${s} tools): ${i}`)}return t.push(""),t.push("Use `tool.search` to discover specific tools when needed."),t.push('Example: tool.search({ query: "read file" }) to find file reading tools.'),t.join(`
|
|
49
|
+
`)}var Zw,Pa=h(()=>{"use strict";c();Zw={filesystem:"File operations (read, write, delete, list, search files)",network:"HTTP requests and web scraping (GET, POST, fetch pages, extract data)",execution:"Run shell commands and manage processes",system:"System information, environment variables, disk usage",meta:"Tool discovery and management"}});var Ut=h(()=>{"use strict";c();Ca();Sa();ka();Pa()});var eT,ce,Bt=h(()=>{"use strict";c();eT={enabled:!1,alwaysLoadedTools:[],alwaysLoadedCategories:[],searchResultLimit:5,cacheDiscoveredTools:!0},ce={enabled:!0,autoExecute:!0,maxToolRounds:5,toolChoicePolicy:"auto",resultMaxChars:2e4,enabledTools:[],enabledToolCategories:[],toolSearch:eT}});import{appendFileSync as $a,mkdirSync as tT}from"fs";import{dirname as oT,isAbsolute as nT,join as rT,resolve as sT}from"path";function _a(r){if(!r)return;let e=r.toLowerCase();if(e in es)return e;console.warn(`[Toolpack Warning] Invalid log level "${r}". Falling back to "info".`)}function Ea(r){if(r?.enabled!==void 0&&(Tt=r.enabled),r?.filePath&&(Ce=r.filePath),r?.level&&(zt=_a(r.level)||"info"),process.env.TOOLPACK_SDK_LOG_ENABLED!==void 0&&(Tt=process.env.TOOLPACK_SDK_LOG_ENABLED==="true"),process.env.TOOLPACK_SDK_LOG_FILE&&(Ce=process.env.TOOLPACK_SDK_LOG_FILE,Tt=!0),process.env.TOOLPACK_SDK_LOG_LEVEL&&(zt=_a(process.env.TOOLPACK_SDK_LOG_LEVEL)||zt),process.env.TOOLPACK_SDK_LOG_CONSOLE!==void 0&&(ts=process.env.TOOLPACK_SDK_LOG_CONSOLE==="true"),r?.console!==void 0&&process.env.TOOLPACK_SDK_LOG_CONSOLE===void 0&&(ts=r.console),Tt)try{Ce=nT(Ce)?Ce:sT(process.cwd(),Ce),tT(oT(Ce),{recursive:!0}),$a(Ce,`[${new Date().toISOString()}] [INFO] [Logger] initialized level=${zt} file=${Ce}
|
|
50
|
+
`)}catch(e){console.warn(`[Toolpack Warning] Failed to initialize log file "${Ce}": ${e.message}`),Tt=!1}}function tt(r){return Tt?es[r]<=es[zt]:!1}function Ht(r,e){if(!tt(r))return;let o=`[${new Date().toISOString()}] [${r.toUpperCase()}] ${Da(e)}`;$a(Ce,o+`
|
|
51
|
+
`),ts&&(r==="error"?console.error:r==="warn"?console.warn:console.log)(o)}function pe(r){Ht("error",r)}function I(r){Ht("warn",r)}function P(r){Ht("info",r)}function y(r){Ht("debug",r)}function je(r){Ht("trace",r)}function Da(r){return r.replace(/\bsk-[A-Za-z0-9_-]{10,}\b/g,"[REDACTED]").replace(/\bsk-proj-[A-Za-z0-9_-]{10,}\b/g,"[REDACTED]").replace(/\bAIza[0-9A-Za-z_-]{10,}\b/g,"[REDACTED]").replace(/\bBearer\s+[A-Za-z0-9._-]{10,}\b/g,"Bearer [REDACTED]").replace(/\bghs_[A-Za-z0-9]{10,}\b/g,"ghs_[REDACTED]").replace(/\bghp_[A-Za-z0-9]{10,}\b/g,"ghp_[REDACTED]").replace(/\bghu_[A-Za-z0-9]{10,}\b/g,"ghu_[REDACTED]").replace(/\bghr_[A-Za-z0-9]{10,}\b/g,"ghr_[REDACTED]")}function A(r,e=200){try{let t=typeof r=="string"?r:JSON.stringify(r),o=Da(t);return o.length<=e?o:`${o.slice(0,e)}\u2026`}catch{return"[Unserializable]"}}function te(r,e,t){tt("debug")&&(y(`[${e}][${r}] Messages (${t.length}):`),t.forEach((o,n)=>{y(`[${e}][${r}] #${n} role=${o?.role} content=${A(o?.content,300)}`)}))}var es,Tt,zt,Ce,ts,S=h(()=>{"use strict";c();es={error:0,warn:1,info:2,debug:3,trace:4},Tt=!1,zt="info",Ce=rT(process.cwd(),"toolpack-sdk.log"),ts=!1});var Kt={};ee(Kt,{fetchUrlAsBase64:()=>Ua,getMimeType:()=>La,isDataUri:()=>Fa,normalizeImagePart:()=>cT,parseDataUri:()=>qa,readFileAsBase64:()=>Wa,toDataUri:()=>lT});import*as Ia from"fs/promises";import*as ja from"path";function La(r){let e=ja.extname(r).toLowerCase();return aT[e]||"application/octet-stream"}function Fa(r){return r.startsWith("data:")}function qa(r){let e=r.match(/^data:(.*?);base64,(.+)$/);return e?{mimeType:e[1],data:e[2]}:null}function lT(r,e){return`data:${e};base64,${r}`}async function Wa(r){try{return{data:(await Ia.readFile(r)).toString("base64"),mimeType:La(r)}}catch(e){throw new L(`Failed to read image file: ${r}`,e)}}async function Ua(r){try{let e=await fetch(r);if(!e.ok)throw new Error(`HTTP ${e.status} ${e.statusText}`);let t=await e.arrayBuffer(),o=Buffer.from(t),n=e.headers.get("content-type")||"application/octet-stream";return n=n.split(";")[0].trim(),{data:o.toString("base64"),mimeType:n}}catch(e){throw new W(`Failed to download image from URL: ${r}`,"FETCH_ERROR",500,e)}}async function cT(r){if(r.type==="image_data")return{data:r.image_data.data,mimeType:r.image_data.mimeType};if(r.type==="image_file")return await Wa(r.image_file.path);if(r.type==="image_url"){let e=r.image_url.url;if(Fa(e)){let t=qa(e);if(!t)throw new L(`Malformed data URI provided in image_url: ${e.substring(0,50)}...`);return t}return await Ua(e)}throw new L(`Unknown ImagePart type: ${r.type}`)}var aT,xt=h(()=>{"use strict";c();le();aT={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".webp":"image/webp",".gif":"image/gif",".heic":"image/heic",".heif":"image/heif"}});var Ya,Za,el,tl,ol,nl=h(()=>{"use strict";c();Ya="fs.read_file",Za="Read File",el="Read the contents of a file at the given path. Returns the file content as a string.",tl="filesystem",ol={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to read"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path"]}});import*as Ct from"fs";async function TT(r){let e=r.path,t=r.encoding||"utf-8";if(y(`[fs.read-file] execute path="${e}" encoding=${t}`),!e)throw new Error("path is required");if(!Ct.existsSync(e))throw new Error(`File not found: ${e}`);if(Ct.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}`);return Ct.readFileSync(e,t)}var Xt,as=h(()=>{"use strict";c();nl();S();Xt={name:Ya,displayName:Za,description:el,parameters:ol,category:tl,execute:TT}});var rl,sl,il,al,ll,cl=h(()=>{"use strict";c();rl="fs.write_file",sl="Write File",il="Write content to a file. Creates parent directories if they do not exist. Overwrites existing files. IMPORTANT: Do NOT use this to delete/remove files - use fs.delete_file for that.",al="filesystem",ll={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to write"},content:{type:"string",description:"Content to write to the file"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path","content"]}});import*as St from"fs";import*as pl from"path";async function xT(r){let e=r.path,t=r.content,o=r.encoding||"utf-8";if(y(`[fs.write-file] execute path="${e}" encoding=${o} content_len=${t?.length??0}`),!e)throw new Error("path is required");if(t==null)throw new Error("content is required");let n=pl.dirname(e);return St.existsSync(n)||St.mkdirSync(n,{recursive:!0}),St.writeFileSync(e,t,o),`File written successfully: ${e} (${Buffer.byteLength(t,o)} bytes)`}var Yt,ls=h(()=>{"use strict";c();cl();S();Yt={name:rl,displayName:sl,description:il,parameters:ll,category:al,execute:xT,confirmation:{level:"high",reason:"This will overwrite the entire file contents.",showArgs:["path"]}}});var ml,dl,ul,fl,gl,hl=h(()=>{"use strict";c();ml="fs.append_file",dl="Append File",ul="Append content to the end of a file. Creates the file if it does not exist.",fl="filesystem",gl={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to append to"},content:{type:"string",description:"Content to append to the file"},encoding:{type:"string",description:"File encoding (default: utf-8)",default:"utf-8"}},required:["path","content"]}});import*as kt from"fs";import*as yl from"path";async function vT(r){let e=r.path,t=r.content,o=r.encoding||"utf-8";if(!e)throw new Error("path is required");if(t==null)throw new Error("content is required");let n=yl.dirname(e);return kt.existsSync(n)||kt.mkdirSync(n,{recursive:!0}),kt.appendFileSync(e,t,o),`Content appended to: ${e} (${Buffer.byteLength(t,o)} bytes appended)`}var Zt,cs=h(()=>{"use strict";c();hl();Zt={name:ml,displayName:dl,description:ul,parameters:gl,category:fl,execute:vT,confirmation:{level:"medium",reason:"This will modify the file by appending content.",showArgs:["path"]}}});var bl,wl,Tl,xl,vl,Cl=h(()=>{"use strict";c();bl="fs.delete_file",wl="Delete File",Tl="Remove/delete a file from the filesystem. Does not delete directories.",xl="filesystem",vl={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to delete"}},required:["path"]}});import*as Pt from"fs";async function CT(r){let e=r.path;if(y(`[fs.delete-file] execute path="${e}"`),!e)throw new Error("path is required");if(!Pt.existsSync(e))throw new Error(`File not found: ${e}`);if(Pt.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}. Use a different tool to remove directories.`);return Pt.unlinkSync(e),`File deleted successfully: ${e}`}var eo,ps=h(()=>{"use strict";c();Cl();S();eo={name:bl,displayName:wl,description:Tl,parameters:vl,category:xl,execute:CT,confirmation:{level:"high",reason:"This will permanently delete the file. This action cannot be undone.",showArgs:["path"]}}});var Sl,kl,Pl,Rl,_l,$l=h(()=>{"use strict";c();Sl="fs.exists",kl="Exists",Pl="Check if a file or directory exists at the given path. Returns true or false.",Rl="filesystem",_l={type:"object",properties:{path:{type:"string",description:"Absolute or relative path to check"}},required:["path"]}});import*as El from"fs";async function ST(r){let e=r.path;if(!e)throw new Error("path is required");let t=El.existsSync(e);return JSON.stringify({exists:t,path:e})}var to,ms=h(()=>{"use strict";c();$l();to={name:Sl,displayName:kl,description:Pl,parameters:_l,category:Rl,execute:ST}});var Dl,Ml,Al,Ol,Nl,Il=h(()=>{"use strict";c();Dl="fs.stat",Ml="Stat",Al="Get file or directory information including size, type, and modification date.",Ol="filesystem",Nl={type:"object",properties:{path:{type:"string",description:"Absolute or relative path to get info for"}},required:["path"]}});import*as Nn from"fs";async function kT(r){let e=r.path;if(!e)throw new Error("path is required");if(!Nn.existsSync(e))throw new Error(`Path not found: ${e}`);let t=Nn.statSync(e);return JSON.stringify({path:e,type:t.isDirectory()?"directory":t.isFile()?"file":"other",size:t.size,created:t.birthtime.toISOString(),modified:t.mtime.toISOString(),accessed:t.atime.toISOString(),permissions:t.mode.toString(8)})}var oo,ds=h(()=>{"use strict";c();Il();oo={name:Dl,displayName:Ml,description:Al,parameters:Nl,category:Ol,execute:kT}});var jl,Ll,Fl,ql,Wl,Ul=h(()=>{"use strict";c();jl="fs.list_dir",Ll="List Directory",Fl="List files and directories at the given path. Optionally recurse into subdirectories.",ql="filesystem",Wl={type:"object",properties:{path:{type:"string",description:"Absolute or relative directory path to list"},recursive:{type:"boolean",description:"Whether to list recursively (default: false)",default:!1}},required:["path"]}});import*as rt from"fs";import*as Gl from"path";function Bl(r,e,t,o=""){let n=rt.readdirSync(r,{withFileTypes:!0});for(let s of n){let i=Gl.join(r,s.name),a=o?`${o}/${s.name}`:s.name;if(s.isDirectory())t.push({name:a,type:"directory",size:0}),e&&Bl(i,!0,t,a);else if(s.isFile()){let l=rt.statSync(i);t.push({name:a,type:"file",size:l.size})}}}async function PT(r){let e=r.path,t=r.recursive===!0;if(!e)throw new Error("path is required");if(!rt.existsSync(e))throw new Error(`Directory not found: ${e}`);if(!rt.statSync(e).isDirectory())throw new Error(`Path is not a directory: ${e}`);let n=[];return Bl(e,t,n),JSON.stringify(n,null,2)}var no,us=h(()=>{"use strict";c();Ul();no={name:jl,displayName:Ll,description:Fl,parameters:Wl,category:ql,execute:PT}});var zl,Hl,Kl,Jl,Vl,Ql=h(()=>{"use strict";c();zl="fs.create_dir",Hl="Create Directory",Kl="Create a directory at the given path. Creates parent directories recursively if they do not exist.",Jl="filesystem",Vl={type:"object",properties:{path:{type:"string",description:"Absolute or relative directory path to create"},recursive:{type:"boolean",description:"Create parent directories if they do not exist (default: true)",default:!0}},required:["path"]}});import*as Rt from"fs";async function RT(r){let e=r.path,t=r.recursive!==!1;if(!e)throw new Error("path is required");if(Rt.existsSync(e)){if(Rt.statSync(e).isDirectory())return`Directory already exists: ${e}`;throw new Error(`Path exists but is not a directory: ${e}`)}return Rt.mkdirSync(e,{recursive:t}),`Directory created: ${e}`}var ro,fs=h(()=>{"use strict";c();Ql();ro={name:zl,displayName:Hl,description:Kl,parameters:Vl,category:Jl,execute:RT}});var Xl,Yl,Zl,ec,tc,oc=h(()=>{"use strict";c();Xl="fs.move",Yl="Move",Zl="Move or rename a file or directory from one path to another.",ec="filesystem",tc={type:"object",properties:{path:{type:"string",description:"Source path (file or directory)"},new_path:{type:"string",description:"Destination path"}},required:["path","new_path"]}});import*as st from"fs";import*as nc from"path";async function _T(r){let e=r.path,t=r.new_path;if(!e)throw new Error("path is required");if(!t)throw new Error("new_path is required");if(!st.existsSync(e))throw new Error(`Source not found: ${e}`);let o=nc.dirname(t);return st.existsSync(o)||st.mkdirSync(o,{recursive:!0}),st.renameSync(e,t),`Moved: ${e} \u2192 ${t}`}var so,gs=h(()=>{"use strict";c();oc();so={name:Xl,displayName:Yl,description:Zl,parameters:tc,category:ec,execute:_T,confirmation:{level:"high",reason:"This will move/rename the file or directory, potentially overwriting the destination.",showArgs:["path","new_path"]}}});var rc,sc,ic,ac,lc,cc=h(()=>{"use strict";c();rc="fs.copy",sc="Copy",ic="Copy a file or directory from one path to another. Recursively copies directories.",ac="filesystem",lc={type:"object",properties:{path:{type:"string",description:"Source path (file or directory)"},new_path:{type:"string",description:"Destination path"}},required:["path","new_path"]}});import*as me from"fs";import*as io from"path";function pc(r,e){if(me.statSync(r).isDirectory()){me.existsSync(e)||me.mkdirSync(e,{recursive:!0});let o=me.readdirSync(r);for(let n of o)pc(io.join(r,n),io.join(e,n))}else me.copyFileSync(r,e)}async function $T(r){let e=r.path,t=r.new_path;if(!e)throw new Error("path is required");if(!t)throw new Error("new_path is required");if(!me.existsSync(e))throw new Error(`Source not found: ${e}`);let o=io.dirname(t);return me.existsSync(o)||me.mkdirSync(o,{recursive:!0}),pc(e,t),`Copied ${me.statSync(e).isDirectory()?"directory":"file"}: ${e} \u2192 ${t}`}var ao,hs=h(()=>{"use strict";c();cc();ao={name:rc,displayName:sc,description:ic,parameters:lc,category:ac,execute:$T,confirmation:{level:"medium",reason:"This will copy files or directories, potentially overwriting the destination.",showArgs:["path","new_path"]}}});var mc,dc,uc,fc,gc,hc=h(()=>{"use strict";c();mc="fs.read_file_range",dc="Read File Range",uc="Read a specific range of lines from a file. Useful for reading portions of large files without loading the entire content.",fc="filesystem",gc={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path to read"},start_line:{type:"integer",description:"Start line number (1-indexed)"},end_line:{type:"integer",description:"End line number (1-indexed, inclusive)"}},required:["path","start_line","end_line"]}});import*as _t from"fs";async function ET(r){let e=r.path,t=r.start_line,o=r.end_line;if(!e)throw new Error("path is required");if(t==null)throw new Error("start_line is required");if(o==null)throw new Error("end_line is required");if(t<1)throw new Error("start_line must be >= 1");if(o<t)throw new Error("end_line must be >= start_line");if(!_t.existsSync(e))throw new Error(`File not found: ${e}`);if(_t.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}`);let i=_t.readFileSync(e,"utf-8").split(`
|
|
52
|
+
`),a=i.length,l=Math.min(t,a),p=Math.min(o,a),d=i.slice(l-1,p).map((g,b)=>`${l+b}: ${g}`).join(`
|
|
53
53
|
`);return`Lines ${l}-${p} of ${a} total:
|
|
54
|
-
${d}`}var
|
|
55
|
-
`);for(let i=0;i<s.length&&t.length<o;i++){let a=s[i];(typeof e=="string"?a.includes(e):e.test(a))&&t.push({file:r,line:i+1,content:a.trim()})}}catch{}}function
|
|
56
|
-
(results capped at ${n})`:"";return JSON.stringify(p,null,2)+m}var
|
|
57
|
-
`)}var
|
|
54
|
+
${d}`}var lo,ys=h(()=>{"use strict";c();hc();lo={name:mc,displayName:dc,description:uc,parameters:gc,category:fc,execute:ET}});var yc,bc,wc,Tc,xc,vc=h(()=>{"use strict";c();yc="fs.search",bc="Search",wc="Search for text in files within a directory. Returns matching lines with file paths and line numbers.",Tc="filesystem",xc={type:"object",properties:{path:{type:"string",description:"Directory path to search in"},query:{type:"string",description:"Text or pattern to search for"},recursive:{type:"boolean",description:"Search recursively in subdirectories (default: true)",default:!0},max_results:{type:"integer",description:"Maximum number of matching lines to return (default: 50)",default:50},regex:{type:"boolean",description:"Treat query as a regular expression (default: false)",default:!1},case_sensitive:{type:"boolean",description:"Perform case-sensitive search. If false, search is case-insensitive (default: false)",default:!1}},required:["path","query"]}});import*as Fe from"fs";import*as Cc from"path";function DT(r,e,t,o){try{let s=Fe.readFileSync(r,"utf-8").split(`
|
|
55
|
+
`);for(let i=0;i<s.length&&t.length<o;i++){let a=s[i];(typeof e=="string"?a.includes(e):e.test(a))&&t.push({file:r,line:i+1,content:a.trim()})}}catch{}}function Sc(r,e,t,o,n){let s=Fe.readdirSync(r,{withFileTypes:!0});for(let i of s){if(o.length>=n)break;let a=Cc.join(r,i.name);i.isDirectory()&&t?Sc(a,e,!0,o,n):i.isFile()&&DT(a,e,o,n)}}async function MT(r){let e=r.path,t=r.query,o=r.recursive!==!1,n=r.max_results||50,s=!!r.regex,i=!!r.case_sensitive;if(y(`[fs.search] execute path="${e}" query="${t}" recursive=${o} regex=${s} caseSensitive=${i}`),!e)throw new Error("path is required");if(!t)throw new Error("query is required");let a=t;if(s||!i){let d=t;s||(d=d.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"));let g=i?"":"i";a=new RegExp(d,g)}if(!Fe.existsSync(e))throw new Error(`Directory not found: ${e}`);if(!Fe.statSync(e).isDirectory())throw new Error(`Path is not a directory: ${e}`);let p=[];if(Sc(e,a,o,p,n),p.length===0)return`No matches found for "${t}" in ${e}`;let m=p.length>=n?`
|
|
56
|
+
(results capped at ${n})`:"";return JSON.stringify(p,null,2)+m}var co,bs=h(()=>{"use strict";c();vc();S();co={name:yc,displayName:bc,description:wc,parameters:xc,category:Tc,execute:MT}});var kc,Pc,Rc,_c,$c,Ec=h(()=>{"use strict";c();kc="fs.replace_in_file",Pc="Replace In File",Rc="Find and replace text in a file. Returns the number of replacements made.",_c="filesystem",$c={type:"object",properties:{path:{type:"string",description:"Absolute or relative file path"},search:{type:"string",description:"Text to search for"},replace:{type:"string",description:"Text to replace with"}},required:["path","search","replace"]}});import*as qe from"fs";async function AT(r){let e=r.path,t=r.search,o=r.replace;if(!e)throw new Error("path is required");if(!t)throw new Error("search is required");if(o==null)throw new Error("replace is required");if(!qe.existsSync(e))throw new Error(`File not found: ${e}`);if(qe.statSync(e).isDirectory())throw new Error(`Path is a directory, not a file: ${e}`);let s=qe.readFileSync(e,"utf-8"),i=0,a=0;for(;(a=s.indexOf(t,a))!==-1;)i++,a+=t.length;if(i===0)return`No occurrences of "${t}" found in ${e}`;let l=s.split(t).join(o);return qe.writeFileSync(e,l,"utf-8"),`Replaced ${i} occurrence(s) in ${e}`}var po,ws=h(()=>{"use strict";c();Ec();po={name:kc,displayName:Pc,description:Rc,parameters:$c,category:_c,execute:AT,confirmation:{level:"high",reason:"This will perform a global find-and-replace operation that may corrupt the file if the pattern is incorrect.",showArgs:["path","search","replace"]}}});var Dc,Mc,Ac,Oc,Nc,Ic=h(()=>{"use strict";c();Dc="fs.tree",Mc="Tree",Ac="Get a tree representation of a directory structure. Useful for understanding project layout at a glance.",Oc="filesystem",Nc={type:"object",properties:{path:{type:"string",description:"Absolute or relative directory path"},depth:{type:"integer",description:"Maximum depth to traverse (default: 3)",default:3}},required:["path"]}});import*as $t from"fs";import*as In from"path";function jc(r,e,t,o,n){if(t>o)return;let i=$t.readdirSync(r,{withFileTypes:!0}).sort((a,l)=>a.isDirectory()&&!l.isDirectory()?-1:!a.isDirectory()&&l.isDirectory()?1:a.name.localeCompare(l.name));for(let a=0;a<i.length;a++){let l=i[a],p=a===i.length-1,m=p?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",d=p?" ":"\u2502 ";l.isDirectory()?(n.push(`${e}${m}${l.name}/`),jc(In.join(r,l.name),e+d,t+1,o,n)):n.push(`${e}${m}${l.name}`)}}async function OT(r){let e=r.path,t=r.depth||3;if(!e)throw new Error("path is required");if(!$t.existsSync(e))throw new Error(`Directory not found: ${e}`);if(!$t.statSync(e).isDirectory())throw new Error(`Path is not a directory: ${e}`);let s=[`${In.basename(e)}/`];return jc(e,"",1,t,s),s.join(`
|
|
57
|
+
`)}var mo,Ts=h(()=>{"use strict";c();Ic();mo={name:Dc,displayName:Mc,description:Ac,parameters:Nc,category:Oc,execute:OT}});var Lc,Fc,qc,Wc,Uc,Gc=h(()=>{"use strict";c();Lc="fs.glob",Fc="Glob Pattern Match",qc='Find files matching glob patterns (e.g., "**/*.ts", "src/**/*.test.js")',Wc="filesystem",Uc={type:"object",properties:{pattern:{type:"string",description:'Glob pattern to match files (e.g., "**/*.ts", "src/**/*.json")'},cwd:{type:"string",description:"Root directory to search from (defaults to current working directory)"},ignore:{type:"array",items:{type:"string"},description:'Patterns to ignore (e.g., ["node_modules/**", "dist/**"])'},onlyFiles:{type:"boolean",description:"Return only files, not directories (default: true)"},onlyDirectories:{type:"boolean",description:"Return only directories, not files (default: false)"},absolute:{type:"boolean",description:"Return absolute paths instead of relative (default: false)"}},required:["pattern"]}});import NT from"fast-glob";async function IT(r){let e=r.pattern,t=r.cwd,o=r.ignore,n=r.onlyFiles!==!1,s=r.onlyDirectories===!0,i=r.absolute===!0;if(!e)throw new Error("pattern is required");let a=e.replace(/\\/g,"/");try{let l=await NT(a,{cwd:t||process.cwd(),ignore:o||["node_modules/**",".git/**"],onlyFiles:n,onlyDirectories:s,absolute:i,dot:!0});return JSON.stringify({pattern:e,files:l,count:l.length},null,2)}catch(l){throw new Error(`Failed to glob pattern "${e}": ${l.message}`)}}var uo,xs=h(()=>{"use strict";c();Gc();uo={name:Lc,displayName:Fc,description:qc,parameters:Uc,category:Wc,execute:IT}});var Bc,zc,Hc,Kc,Jc,Vc=h(()=>{"use strict";c();Bc="fs.delete_dir",zc="Delete Directory",Hc="Delete a directory and all its contents recursively",Kc="filesystem",Jc={type:"object",properties:{path:{type:"string",description:"Absolute or relative path to the directory to delete"},force:{type:"boolean",description:"Force deletion even if directory is not empty (default: true)"}},required:["path"]}});import{rm as jT}from"fs/promises";import{existsSync as LT,statSync as FT}from"fs";async function qT(r){let e=r.path,t=r.force!==!1;if(!e)throw new Error("path is required");if(!LT(e))throw new Error(`Directory does not exist: ${e}`);if(!FT(e).isDirectory())throw new Error(`Path is not a directory: ${e}`);try{return await jT(e,{recursive:!0,force:t}),`Directory deleted successfully: ${e}`}catch(n){throw new Error(`Failed to delete directory "${e}": ${n.message}`)}}var fo,vs=h(()=>{"use strict";c();Vc();fo={name:Bc,displayName:zc,description:Hc,parameters:Jc,category:Kc,execute:qT,confirmation:{level:"high",reason:"This will recursively delete the directory and all its contents. This action cannot be undone.",showArgs:["path"]}}});var Qc,Xc,Yc,Zc,ep,tp=h(()=>{"use strict";c();Qc="fs.batch_read",Xc="Batch Read Files",Yc="Read multiple files efficiently in one operation. Returns content for each file or error if read fails.",Zc="filesystem",ep={type:"object",properties:{paths:{type:"array",items:{type:"string"},description:"Array of file paths to read"},encoding:{type:"string",description:"File encoding (default: utf-8)"},continueOnError:{type:"boolean",description:"Continue reading other files if one fails (default: true)"}},required:["paths"]}});import{readFile as WT}from"fs/promises";async function UT(r){let e=r.paths,t=r.encoding||"utf-8",o=r.continueOnError!==!1;if(!e||!Array.isArray(e)||e.length===0)throw new Error("paths array is required and must not be empty");let n=[],s=0,i=0;for(let a of e)try{let l=await WT(a,t);n.push({path:a,content:l,success:!0}),s++}catch(l){let p=l.message;if(n.push({path:a,error:p,success:!1}),i++,!o)throw new Error(`Failed to read file "${a}": ${p}`)}return JSON.stringify({total:e.length,success:s,failed:i,results:n},null,2)}var go,Cs=h(()=>{"use strict";c();tp();go={name:Qc,displayName:Xc,description:Yc,parameters:ep,category:Zc,execute:UT}});var op,np,rp,sp,ip,ap=h(()=>{"use strict";c();op="fs.batch_write",np="Batch Write Files",rp="Write multiple files atomically in one operation. If atomic mode is enabled, all writes succeed or all are rolled back on failure.",sp="filesystem",ip={type:"object",properties:{files:{type:"array",items:{type:"object",properties:{path:{type:"string"},content:{type:"string"}}},description:"Array of files to write, each with path and content"},encoding:{type:"string",description:"File encoding (default: utf-8)"},atomic:{type:"boolean",description:"Atomic mode: rollback all writes if any fails (default: true)"},createDirs:{type:"boolean",description:"Create parent directories if they don't exist (default: true)"}},required:["files"]}});import{writeFile as lp,mkdir as GT,readFile as BT,unlink as zT}from"fs/promises";import{dirname as HT,resolve as KT}from"path";import{existsSync as cp}from"fs";async function JT(r){let e=r.files,t=r.encoding||"utf-8",o=r.atomic!==!1,n=r.createDirs!==!1;if(!e||!Array.isArray(e)||e.length===0)throw new Error("files array is required and must not be empty");for(let a of e)if(!a.path||a.content===void 0)throw new Error("Each file must have path and content properties");let s=[],i=[];try{for(let a of e){let l=KT(a.path);if(o){let p=cp(l),m={path:l,existed:p};p&&(m.originalContent=await BT(l,t)),s.push(m)}if(n){let p=HT(l);await GT(p,{recursive:!0})}await lp(l,a.content,t),i.push(l)}return JSON.stringify({success:!0,written:i.length,files:i},null,2)}catch(a){if(o&&s.length>0){for(let l of s)try{l.existed&&l.originalContent!==void 0?await lp(l.path,l.originalContent,t):!l.existed&&cp(l.path)&&await zT(l.path)}catch{}throw new Error(`Batch write failed and rolled back: ${a.message}`)}throw new Error(`Batch write failed: ${a.message}`)}}var ho,Ss=h(()=>{"use strict";c();ap();ho={name:op,displayName:np,description:rp,parameters:ip,category:sp,execute:JT,confirmation:{level:"high",reason:"This will overwrite multiple files at once.",showArgs:["files"]}}});var mp={};ee(mp,{fsAppendFileTool:()=>Zt,fsBatchReadTool:()=>go,fsBatchWriteTool:()=>ho,fsCopyTool:()=>ao,fsCreateDirTool:()=>ro,fsDeleteDirTool:()=>fo,fsDeleteFileTool:()=>eo,fsExistsTool:()=>to,fsGlobTool:()=>uo,fsListDirTool:()=>no,fsMoveTool:()=>so,fsReadFileRangeTool:()=>lo,fsReadFileTool:()=>Xt,fsReplaceInFileTool:()=>po,fsSearchTool:()=>co,fsStatTool:()=>oo,fsToolsProject:()=>pp,fsTreeTool:()=>mo,fsWriteFileTool:()=>Yt});var pp,ks=h(()=>{"use strict";c();as();ls();cs();ps();ms();ds();us();fs();gs();hs();ys();bs();ws();Ts();xs();vs();Cs();Ss();as();ls();cs();ps();ms();ds();us();fs();gs();hs();ys();bs();ws();Ts();xs();vs();Cs();Ss();pp={manifest:{key:"fs",name:"fs-tools",displayName:"File System",version:"1.0.0",description:"File system tools for reading, writing, searching, and managing files and directories.",author:"Sajeer",tools:["fs.read_file","fs.write_file","fs.append_file","fs.delete_file","fs.exists","fs.stat","fs.list_dir","fs.create_dir","fs.move","fs.copy","fs.read_file_range","fs.search","fs.replace_in_file","fs.tree","fs.glob","fs.delete_dir","fs.batch_read","fs.batch_write"],category:"filesystem"},tools:[Xt,Yt,Zt,eo,to,oo,no,ro,so,ao,lo,co,po,mo,uo,fo,go,ho],dependencies:{"fast-glob":"^3.3.2"}}});var dp,up,fp,gp,hp,yp=h(()=>{"use strict";c();dp="exec.run",up="Run",fp="Execute a command directly (without shell) and return its output. Use exec.run_shell for pipes, redirects, or shell features.",gp="execution",hp={type:"object",properties:{command:{type:"string",description:"The command to execute"},cwd:{type:"string",description:"Working directory for the command (optional)"},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["command"]}});import{execSync as VT}from"child_process";async function QT(r){let e=r.command,t=r.cwd,o=r.timeout||3e4;if(!e)throw new Error("command is required");y(`[exec.run] execute command="${e.substring(0,100)}" cwd=${t??"default"} timeout=${o}ms`);try{return VT(e,{cwd:t,timeout:o,encoding:"utf-8",maxBuffer:10485760,stdio:["pipe","pipe","pipe"]})||"(command completed with no output)"}catch(n){let s=n.stdout||"",i=n.stderr||"";return`Command failed (exit code ${n.status??"unknown"}):
|
|
58
58
|
STDOUT:
|
|
59
59
|
${s}
|
|
60
60
|
STDERR:
|
|
61
|
-
${i}`}}var
|
|
61
|
+
${i}`}}var yo,Ps=h(()=>{"use strict";c();yp();S();yo={name:dp,displayName:up,description:fp,parameters:hp,category:gp,execute:QT,confirmation:{level:"high",reason:"This will execute a shell command on the host system.",showArgs:["command"]}}});var bp,wp,Tp,xp,vp,Cp=h(()=>{"use strict";c();bp="exec.run_shell",wp="Run Shell",Tp="Execute a command through the system shell. Supports pipes, redirects, environment variable expansion, and other shell features.",xp="execution",vp={type:"object",properties:{command:{type:"string",description:"The shell command to execute (supports pipes, redirects, etc.)"},cwd:{type:"string",description:"Working directory for the command (optional)"},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["command"]}});import{execSync as XT}from"child_process";function YT(){return process.platform==="win32"?"powershell.exe":process.env.SHELL||"/bin/sh"}async function ZT(r){let e=r.command,t=r.cwd,o=r.timeout||3e4;if(!e)throw new Error("command is required");y(`[exec.run-shell] execute command="${e.substring(0,100)}" cwd=${t??"default"} timeout=${o}ms`);try{return XT(e,{cwd:t,timeout:o,encoding:"utf-8",maxBuffer:10485760,stdio:["pipe","pipe","pipe"],shell:YT()})||"(command completed with no output)"}catch(n){let s=n.stdout||"",i=n.stderr||"";return`Command failed (exit code ${n.status??"unknown"}):
|
|
62
62
|
STDOUT:
|
|
63
63
|
${s}
|
|
64
64
|
STDERR:
|
|
65
|
-
${i}`}}var
|
|
65
|
+
${i}`}}var bo,Rs=h(()=>{"use strict";c();Cp();S();bo={name:bp,displayName:wp,description:Tp,parameters:vp,category:xp,execute:ZT,confirmation:{level:"high",reason:"This will execute a shell command with explicit shell context.",showArgs:["command"]}}});function Sp(r,e,t){let o=`proc_${ex++}`,n={id:o,command:r,cwd:e,process:t,startedAt:new Date().toISOString(),stdout:"",stderr:""};return t.stdout?.on("data",s=>{n.stdout+=s.toString(),n.stdout.length>1e6&&(n.stdout=n.stdout.slice(-5e5))}),t.stderr?.on("data",s=>{n.stderr+=s.toString(),n.stderr.length>1e6&&(n.stderr=n.stderr.slice(-5e5))}),t.on("exit",()=>{}),jn.set(o,n),o}function Et(r){return jn.get(r)}function kp(r){let e=jn.get(r);if(!e)return!1;let t=e.process.exitCode===null;return t&&e.process.kill("SIGTERM"),t}function Pp(){return Array.from(jn.values()).map(r=>({id:r.id,command:r.command,cwd:r.cwd,startedAt:r.startedAt,alive:r.process.exitCode===null,pid:r.process.pid}))}var jn,ex,Dt=h(()=>{"use strict";c();jn=new Map,ex=1});var Rp,_p,$p,Ep,Dp,Mp=h(()=>{"use strict";c();Rp="exec.run_background",_p="Run Background",$p="Start a command as a background process. Returns a process ID that can be used with exec.read_output, exec.kill, and exec.list_processes.",Ep="execution",Dp={type:"object",properties:{command:{type:"string",description:"The command to run in the background"},cwd:{type:"string",description:"Working directory for the command (optional)"}},required:["command"]}});import{spawn as tx}from"child_process";async function ox(r){let e=r.command,t=r.cwd;if(!e)throw new Error("command is required");if(y(`[exec.run-background] execute command="${e.substring(0,100)}" cwd=${t??"default"}`),!e)throw new Error("command is required");let o=tx(e,[],{cwd:t,shell:!0,stdio:["ignore","pipe","pipe"],detached:!1}),n=Sp(e,t,o);return JSON.stringify({id:n,pid:o.pid,command:e,message:`Background process started. Use exec.read_output("${n}") to read output, exec.kill("${n}") to stop.`})}var wo,_s=h(()=>{"use strict";c();Dt();Mp();S();wo={name:Rp,displayName:_p,description:$p,parameters:Dp,category:Ep,execute:ox,confirmation:{level:"medium",reason:"This will spawn a background process that runs unsupervised.",showArgs:["command"]}}});var Ap,Op,Np,Ip,jp,Lp=h(()=>{"use strict";c();Ap="exec.run_blocking",Op="Run Blocking",Np="Execute a shell command and wait for it to finish naturally \u2014 no timeout. Use this for commands that take variable or unknown time (e.g. npm install, builds, tests). Returns exit code, stdout, and stderr when the process exits. For processes that never exit (servers, watchers), use exec.run_background instead.",Ip="execution",jp={type:"object",properties:{command:{type:"string",description:"The shell command to execute. Supports pipes, redirects, and shell features."},cwd:{type:"string",description:"Working directory for the command (optional). Defaults to the current working directory."}},required:["command"]}});import{spawn as nx}from"child_process";function rx(){return process.platform==="win32"?"powershell.exe":process.env.SHELL||"/bin/sh"}async function sx(r){let e=r.command,t=r.cwd;if(!e)throw new Error("command is required");return y(`[exec.run-blocking] execute command="${e.substring(0,100)}" cwd=${t??"default"} (no timeout)`),new Promise(o=>{let n="",s="",i=nx(e,[],{cwd:t,shell:rx(),stdio:["ignore","pipe","pipe"]});i.stdout?.on("data",a=>{n+=a.toString(),n.length>2e6&&(n=n.slice(-1e6))}),i.stderr?.on("data",a=>{s+=a.toString(),s.length>2e6&&(s=s.slice(-1e6))}),i.on("close",a=>{let l=a??0;y(`[exec.run-blocking] finished exitCode=${l} stdout_len=${n.length} stderr_len=${s.length}`),o(JSON.stringify({exitCode:l,stdout:n||"(no output)",stderr:s||"",success:l===0}))}),i.on("error",a=>{y(`[exec.run-blocking] spawn error: ${a.message}`),o(JSON.stringify({exitCode:1,stdout:"",stderr:a.message,success:!1}))})})}var To,$s=h(()=>{"use strict";c();Lp();S();To={name:Ap,displayName:Op,description:Np,parameters:jp,category:Ip,execute:sx,confirmation:{level:"medium",reason:"This will execute a shell command and block until it completes.",showArgs:["command"]}}});var Fp,qp,Wp,Up,Gp,Bp=h(()=>{"use strict";c();Fp="exec.read_output",qp="Read Output",Wp="Read stdout and stderr from a background process started with exec.run_background.",Up="execution",Gp={type:"object",properties:{process_id:{type:"string",description:"The process ID returned by exec.run_background"}},required:["process_id"]}});async function ix(r){let e=r.process_id;if(!e)throw new Error("process_id is required");let t=Et(e);if(!t)throw new Error(`Process not found: ${e}`);let o=t.process.exitCode===null;return JSON.stringify({id:t.id,alive:o,exitCode:t.process.exitCode,stdout:t.stdout,stderr:t.stderr})}var xo,Es=h(()=>{"use strict";c();Dt();Bp();xo={name:Fp,displayName:qp,description:Wp,parameters:Gp,category:Up,execute:ix}});var zp,Hp,Kp,Jp,Vp,Qp=h(()=>{"use strict";c();zp="exec.tail_output",Hp="Tail Process Output",Kp="Read the last N lines of output from a background process started with exec.run_background. Use this to monitor long-running or non-exiting processes (e.g. dev servers, watchers) to detect ready signals, errors, or progress without reading all accumulated output. Returns alive status, exit code, and the most recent lines of stdout and stderr.",Jp="execution",Vp={type:"object",properties:{process_id:{type:"string",description:"The process ID returned by exec.run_background."},lines:{type:"integer",description:"Number of lines to return from the end of stdout (default: 20).",default:20}},required:["process_id"]}});async function ax(r){let e=r.process_id,t=typeof r.lines=="number"?Math.max(1,Math.floor(r.lines)):20;if(!e)throw new Error("process_id is required");let o=Et(e);if(!o)return JSON.stringify({error:`Process not found: ${e}`,hint:"Use exec.run_background to start a process first, then pass its id here."});let n=o.process.exitCode===null,s=o.process.exitCode,i=o.stdout.split(`
|
|
66
66
|
`),a=i.slice(-t).join(`
|
|
67
67
|
`).trim(),p=o.stderr.split(`
|
|
68
68
|
`).filter(m=>m.trim()).slice(-3).join(`
|
|
69
|
-
`).trim();return JSON.stringify({id:e,alive:n,exitCode:s,lastLines:a||"(no output yet)",lastStderr:p||"",totalStdoutLines:i.length})}var
|
|
70
|
-
`);if(i.length<2)return s;let a=i[1].split(/\s+/);return JSON.stringify({path:t,filesystem:a[0]||"unknown",size:a[1]||"unknown",used:a[2]||"unknown",available:a[3]||"unknown",usePercent:a[4]||"unknown",mountedOn:a[5]||"unknown"},null,2)}catch(s){throw new Error(`Failed to get disk usage for ${t}: ${n?.message||n}; fallback error: ${s.message}`)}}}var
|
|
71
|
-
${n.substring(0,
|
|
69
|
+
`).trim();return JSON.stringify({id:e,alive:n,exitCode:s,lastLines:a||"(no output yet)",lastStderr:p||"",totalStdoutLines:i.length})}var vo,Ds=h(()=>{"use strict";c();Dt();Qp();vo={name:zp,displayName:Hp,description:Kp,parameters:Vp,category:Jp,execute:ax}});var Xp,Yp,Zp,em,tm,om=h(()=>{"use strict";c();Xp="exec.kill",Yp="Kill",Zp="Kill a background process started with exec.run_background.",em="execution",tm={type:"object",properties:{process_id:{type:"string",description:"The process ID returned by exec.run_background"}},required:["process_id"]}});async function lx(r){let e=r.process_id;if(!e)throw new Error("process_id is required");let t=Et(e);if(!t)throw new Error(`Process not found: ${e}`);return kp(e)?`Process ${e} (${t.command}) killed successfully.`:`Process ${e} (${t.command}) was already terminated (exit code: ${t.process.exitCode}).`}var Co,Ms=h(()=>{"use strict";c();Dt();om();Co={name:Xp,displayName:Yp,description:Zp,parameters:tm,category:em,execute:lx,confirmation:{level:"medium",reason:"This will terminate a running process.",showArgs:["process_id"]}}});var nm,rm,sm,im,am,lm=h(()=>{"use strict";c();nm="exec.list_processes",rm="List Processes",sm="List all managed background processes started with exec.run_background, including their status.",im="execution",am={type:"object",properties:{}}});async function cx(r){let e=Pp();return e.length===0?"No managed background processes.":JSON.stringify(e,null,2)}var So,As=h(()=>{"use strict";c();Dt();lm();So={name:nm,displayName:rm,description:sm,parameters:am,category:im,execute:cx}});var pm={};ee(pm,{execKillTool:()=>Co,execListProcessesTool:()=>So,execReadOutputTool:()=>xo,execRunBackgroundTool:()=>wo,execRunBlockingTool:()=>To,execRunShellTool:()=>bo,execRunTool:()=>yo,execTailOutputTool:()=>vo,execToolsProject:()=>cm});var cm,Os=h(()=>{"use strict";c();Ps();Rs();_s();$s();Es();Ds();Ms();As();Ps();Rs();_s();$s();Es();Ds();Ms();As();cm={manifest:{key:"exec",name:"exec-tools",displayName:"Execution",version:"1.0.0",description:"Code execution tools for running commands, managing background processes, and automation.",author:"Sajeer",tools:["exec.run","exec.run_shell","exec.run_background","exec.run_blocking","exec.read_output","exec.tail_output","exec.kill","exec.list_processes"],category:"execution"},tools:[yo,bo,wo,To,xo,vo,Co,So],dependencies:{}}});var mm,dm,um,fm,gm,hm=h(()=>{"use strict";c();mm="system.info",dm="Info",um="Get system information including OS, CPU, memory, and architecture.",fm="system",gm={type:"object",properties:{}}});import*as F from"os";async function px(r){return y("[system.info] execute"),JSON.stringify({platform:F.platform(),arch:F.arch(),release:F.release(),hostname:F.hostname(),uptime:F.uptime(),cpus:{model:F.cpus()[0]?.model||"unknown",count:F.cpus().length},memory:{total:F.totalmem(),free:F.freemem(),used:F.totalmem()-F.freemem()},homedir:F.homedir(),tmpdir:F.tmpdir(),nodeVersion:process.version},null,2)}var ko,Ns=h(()=>{"use strict";c();hm();S();ko={name:mm,displayName:dm,description:um,parameters:gm,category:fm,execute:px}});var ym,bm,wm,Tm,xm,vm=h(()=>{"use strict";c();ym="system.env",bm="Environment",wm="Get environment variable(s). If key is provided, returns that specific variable. Otherwise returns all environment variables.",Tm="system",xm={type:"object",properties:{key:{type:"string",description:"Specific environment variable name to get (optional, returns all if omitted)"}}}});async function mx(r){let e=r.key;if(y(`[system.env] execute key=${e??"all"}`),e){let n=process.env[e];return n===void 0?`Environment variable "${e}" is not set.`:JSON.stringify({[e]:n})}let t={},o=Object.keys(process.env).sort();for(let n of o)process.env[n]!==void 0&&(t[n]=process.env[n]);return JSON.stringify(t,null,2)}var Po,Is=h(()=>{"use strict";c();vm();S();Po={name:ym,displayName:bm,description:wm,parameters:xm,category:Tm,execute:mx}});var Cm,Sm,km,Pm,Rm,_m=h(()=>{"use strict";c();Cm="system.set_env",Sm="Set Environment",km="Set an environment variable for the current session. Does not persist across restarts.",Pm="system",Rm={type:"object",properties:{key:{type:"string",description:"Environment variable name"},value:{type:"string",description:"Value to set"}},required:["key","value"]}});async function dx(r){let e=r.key,t=r.value;if(!e)throw new Error("key is required");if(t==null)throw new Error("value is required");let o=process.env[e];return process.env[e]=t,o!==void 0?`Environment variable "${e}" updated (was: "${o}", now: "${t}")`:`Environment variable "${e}" set to "${t}"`}var Ro,js=h(()=>{"use strict";c();_m();Ro={name:Cm,displayName:Sm,description:km,parameters:Rm,category:Pm,execute:dx,confirmation:{level:"medium",reason:"This will modify the process environment, affecting all subsequent operations.",showArgs:["key","value"]}}});var $m,Em,Dm,Mm,Am,Om=h(()=>{"use strict";c();$m="system.cwd",Em="Current Directory",Dm="Get the current working directory of the process.",Mm="system",Am={type:"object",properties:{}}});async function ux(r){return y("[system.cwd] execute"),JSON.stringify({cwd:process.cwd()})}var _o,Ls=h(()=>{"use strict";c();Om();S();_o={name:$m,displayName:Em,description:Dm,parameters:Am,category:Mm,execute:ux}});var Nm,Im,jm,Lm,Fm,qm=h(()=>{"use strict";c();Nm="system.disk_usage",Im="Disk Usage",jm="Get disk usage information for a given path or the root filesystem.",Lm="system",Fm={type:"object",properties:{path:{type:"string",description:"Path to check disk usage for (default: /)",default:"/"}}}});import*as Um from"fs";import*as Gm from"os";import*as Ln from"path";import{execSync as Wm}from"child_process";function Fs(r){let e=["B","KB","MB","GB","TB","PB"],t=r,o=0;for(;t>=1024&&o<e.length-1;)t/=1024,o++;return`${t.toFixed(1)}${e[o]}`}async function fx(r){let t=r.path||(process.platform==="win32"?Gm.tmpdir():"/");t=Ln.resolve(t);let o=process.platform==="win32";try{let n=Um.statfsSync(t),s=BigInt(n.blocks)*BigInt(n.bsize),i=BigInt(n.bavail)*BigInt(n.bsize),a=BigInt(n.bfree)*BigInt(n.bsize),l=s-a,p=s>0?Number(l*BigInt(100)/s):0;return JSON.stringify({path:t,filesystem:"statfs",size:Fs(Number(s)),used:Fs(Number(l)),available:Fs(Number(i)),usePercent:`${p}%`,mountedOn:t},null,2)}catch(n){try{if(o){let l=Ln.parse(t).root.replace(/\\$/,"")||"C:",p=`Get-PSDrive -Name ${l.replace(":","")} | Select-Object @{n='Drive';e={$_.Name+':'}},@{n='Used';e={$_.Used}},@{n='Free';e={$_.Free}},@{n='Total';e={$_.Used+$_.Free}} | ConvertTo-Json`,m=Wm(p,{encoding:"utf-8",timeout:5e3,shell:"powershell.exe"}),d=JSON.parse(m.trim()),g=d.Total||0,b=d.Free||0,w=d.Used||0,T=g>0?Math.round(w/g*100):0;return JSON.stringify({path:t,filesystem:d.Name||"NTFS",size:`${(g/1024**3).toFixed(1)}G`,used:`${(w/1024**3).toFixed(1)}G`,available:`${(b/1024**3).toFixed(1)}G`,usePercent:`${T}%`,mountedOn:d.Drive||`${l}`},null,2)}let s=Wm(`df -h "${t}"`,{encoding:"utf-8",timeout:5e3}),i=s.trim().split(`
|
|
70
|
+
`);if(i.length<2)return s;let a=i[1].split(/\s+/);return JSON.stringify({path:t,filesystem:a[0]||"unknown",size:a[1]||"unknown",used:a[2]||"unknown",available:a[3]||"unknown",usePercent:a[4]||"unknown",mountedOn:a[5]||"unknown"},null,2)}catch(s){throw new Error(`Failed to get disk usage for ${t}: ${n?.message||n}; fallback error: ${s.message}`)}}}var $o,qs=h(()=>{"use strict";c();qm();$o={name:Nm,displayName:Im,description:jm,parameters:Fm,category:Lm,execute:fx}});var zm={};ee(zm,{systemCwdTool:()=>_o,systemDiskUsageTool:()=>$o,systemEnvTool:()=>Po,systemInfoTool:()=>ko,systemSetEnvTool:()=>Ro,systemToolsProject:()=>Bm});var Bm,Ws=h(()=>{"use strict";c();Ns();Is();js();Ls();qs();Ns();Is();js();Ls();qs();Bm={manifest:{key:"system",name:"system-tools",displayName:"System",version:"1.0.0",description:"System tools for querying OS info, environment variables, working directory, and disk usage.",author:"Sajeer",tools:["system.info","system.env","system.set_env","system.cwd","system.disk_usage"],category:"system"},tools:[ko,Po,Ro,_o,$o],dependencies:{}}});var Hm,Km,Jm,Vm,Qm,Xm=h(()=>{"use strict";c();Hm="http.get",Km="GET",Jm="Make an HTTP GET request to a URL and return the response body.",Vm="network",Qm={type:"object",properties:{url:{type:"string",description:"The URL to request"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"}},required:["url"]}});async function gx(r){let e=r.url,t=r.headers;if(y(`[http.get] execute url="${e}"`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let o=await fetch(e,{method:"GET",headers:t||{}}),n=await o.text(),s=`HTTP ${o.status} ${o.statusText}`;return o.ok?n.length>Ym?`${s}
|
|
71
|
+
${n.substring(0,Ym)}
|
|
72
72
|
|
|
73
73
|
... (truncated, total ${n.length} characters)`:`${s}
|
|
74
74
|
${n}`:`${s}
|
|
75
|
-
${n}`}var
|
|
76
|
-
${s.substring(0,
|
|
75
|
+
${n}`}var Ym,Eo,Us=h(()=>{"use strict";c();Xm();S();Ym=1e5;Eo={name:Hm,displayName:Km,description:Jm,parameters:Qm,category:Vm,execute:gx}});var Zm,ed,td,od,nd,rd=h(()=>{"use strict";c();Zm="http.post",ed="POST",td="Make an HTTP POST request to a URL with an optional body and return the response.",od="network",nd={type:"object",properties:{url:{type:"string",description:"The URL to request"},body:{type:"string",description:"Request body (JSON string or plain text)"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"}},required:["url"]}});async function hx(r){let e=r.url,t=r.body,o=r.headers||{};if(y(`[http.post] execute url="${e}" body_len=${t?.length??0}`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");if(t&&!o["Content-Type"]&&!o["content-type"])try{JSON.parse(t),o["Content-Type"]="application/json"}catch{o["Content-Type"]="text/plain"}let n=await fetch(e,{method:"POST",headers:o,body:t||void 0}),s=await n.text(),i=`HTTP ${n.status} ${n.statusText}`;return s.length>sd?`${i}
|
|
76
|
+
${s.substring(0,sd)}
|
|
77
77
|
|
|
78
78
|
... (truncated, total ${s.length} characters)`:`${i}
|
|
79
|
-
${s}`}var
|
|
80
|
-
${s.substring(0,
|
|
79
|
+
${s}`}var sd,Do,Gs=h(()=>{"use strict";c();rd();S();sd=1e5;Do={name:Zm,displayName:ed,description:td,parameters:nd,category:od,execute:hx,confirmation:{level:"high",reason:"This will send an HTTP POST request with arbitrary payload.",showArgs:["url","body"]}}});var id,ad,ld,cd,pd,md=h(()=>{"use strict";c();id="http.put",ad="PUT",ld="Make an HTTP PUT request to a URL with an optional body and return the response.",cd="network",pd={type:"object",properties:{url:{type:"string",description:"The URL to request"},body:{type:"string",description:"Request body (JSON string or plain text)"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"}},required:["url"]}});async function yx(r){let e=r.url,t=r.body,o=r.headers||{};if(y(`[http.put] execute url="${e}" body_len=${t?.length??0}`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");if(t&&!o["Content-Type"]&&!o["content-type"])try{JSON.parse(t),o["Content-Type"]="application/json"}catch{o["Content-Type"]="text/plain"}let n=await fetch(e,{method:"PUT",headers:o,body:t||void 0}),s=await n.text(),i=`HTTP ${n.status} ${n.statusText}`;return s.length>dd?`${i}
|
|
80
|
+
${s.substring(0,dd)}
|
|
81
81
|
|
|
82
82
|
... (truncated)`:`${i}
|
|
83
|
-
${s}`}var
|
|
84
|
-
${n.substring(0,
|
|
83
|
+
${s}`}var dd,Mo,Bs=h(()=>{"use strict";c();md();S();dd=1e5;Mo={name:id,displayName:ad,description:ld,parameters:pd,category:cd,execute:yx,confirmation:{level:"high",reason:"This will send an HTTP PUT request to overwrite remote resources.",showArgs:["url","body"]}}});var ud,fd,gd,hd,yd,bd=h(()=>{"use strict";c();ud="http.delete",fd="DELETE",gd="Make an HTTP DELETE request to a URL and return the response.",hd="network",yd={type:"object",properties:{url:{type:"string",description:"The URL to request"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"}},required:["url"]}});async function bx(r){let e=r.url,t=r.headers;if(y(`[http.delete] execute url="${e}"`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let o=await fetch(e,{method:"DELETE",headers:t||{}}),n=await o.text(),s=`HTTP ${o.status} ${o.statusText}`;return n.length>wd?`${s}
|
|
84
|
+
${n.substring(0,wd)}
|
|
85
85
|
|
|
86
86
|
... (truncated)`:`${s}
|
|
87
|
-
${n}`}var
|
|
88
|
-
`);if(!o||!n)throw new Error("No GitHub token available. Set GITHUB_PAT, or GITHUB_APP_ID + GITHUB_APP_PRIVATE_KEY.");let s=await
|
|
89
|
-
${s}`}var
|
|
90
|
-
${p}`;try{let d=JSON.parse(p)?.content;if(typeof d=="string"){let g=
|
|
91
|
-
\u2026 [truncated, ${s} of ${
|
|
92
|
-
${
|
|
87
|
+
${n}`}var wd,Ao,zs=h(()=>{"use strict";c();bd();S();wd=1e5;Ao={name:ud,displayName:fd,description:gd,parameters:yd,category:hd,execute:bx,confirmation:{level:"high",reason:"This will send an HTTP DELETE request to destroy remote resources.",showArgs:["url"]}}});var Td,xd,vd,Cd,Sd,kd=h(()=>{"use strict";c();Td="http.download",xd="Download",vd="Download a file from a URL and save it to a local path.",Cd="network",Sd={type:"object",properties:{url:{type:"string",description:"The URL to download from"},path:{type:"string",description:"Local file path to save the downloaded file"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"}},required:["url","path"]}});import*as Mt from"fs";import*as Pd from"path";async function wx(r){let e=r.url,t=r.path,o=r.headers;if(y(`[http.download] execute url="${e}" path="${t}"`),!e)throw new Error("url is required");if(!t)throw new Error("path is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let n=await fetch(e,{method:"GET",headers:o||{}});if(!n.ok)throw new Error(`Download failed: HTTP ${n.status} ${n.statusText}`);let s=Buffer.from(await n.arrayBuffer()),i=Pd.dirname(t);return Mt.existsSync(i)||Mt.mkdirSync(i,{recursive:!0}),Mt.writeFileSync(t,s),`Downloaded ${e} \u2192 ${t} (${s.length} bytes)`}var Oo,Hs=h(()=>{"use strict";c();kd();S();Oo={name:Td,displayName:xd,description:vd,parameters:Sd,category:Cd,execute:wx}});var _d={};ee(_d,{httpDeleteTool:()=>Ao,httpDownloadTool:()=>Oo,httpGetTool:()=>Eo,httpPostTool:()=>Do,httpPutTool:()=>Mo,httpToolsProject:()=>Rd});var Rd,Ks=h(()=>{"use strict";c();Us();Gs();Bs();zs();Hs();Us();Gs();Bs();zs();Hs();Rd={manifest:{key:"http",name:"http-tools",displayName:"HTTP",version:"1.0.0",description:"HTTP tools for making GET, POST, PUT, DELETE requests and downloading files.",author:"Sajeer",tools:["http.get","http.post","http.put","http.delete","http.download"],category:"network"},tools:[Eo,Do,Mo,Ao,Oo],dependencies:{}}});var $d,Ed,Dd,Md,Ad,Od=h(()=>{"use strict";c();$d="github.graphql.execute",Ed="GitHub GraphQL",Dd=["Execute a GitHub GraphQL query or mutation with standard headers.","NOTE: GitHub App installation tokens (ghs_*) cannot call certain write mutations.","The following mutations require a PAT and will return FORBIDDEN with an App token:","resolveReviewThread, unresolveReviewThread.","If using an App token, avoid these mutations and use fallback strategies (replies, new comments)."].join(" "),Md="github",Ad={type:"object",properties:{query:{type:"string",description:"GraphQL query string"},variables:{type:"object",description:"Optional GraphQL variables"},repo:{type:"string",description:"owner/name \u2014 used for token resolution when no explicit token is provided"},token:{type:"string",description:"GitHub token (App installation or PAT). Optional \u2014 omit to auto-resolve from server credentials."}},required:["query"]}});function K(r,e){let t={Accept:"application/vnd.github+json","X-GitHub-Api-Version":"2022-11-28",...e||{}};return r&&(t.Authorization=`Bearer ${r}`),t}var $e=h(()=>{"use strict";c()});import*as jd from"crypto";async function B(r,e){if(e)return e;let t=process.env.GITHUB_PAT;if(t)return t;let o=process.env.GITHUB_APP_ID,n=process.env.GITHUB_APP_PRIVATE_KEY?.replace(/\\n/g,`
|
|
88
|
+
`);if(!o||!n)throw new Error("No GitHub token available. Set GITHUB_PAT, or GITHUB_APP_ID + GITHUB_APP_PRIVATE_KEY.");let s=await Tx(o,n,r);return xx(o,n,s)}async function Tx(r,e,t){if(!t)throw new Error("Cannot resolve GitHub App installation token without a repo name. Pass args.repo or set GITHUB_PAT.");let o=Id.get(t);if(o!==void 0)return o;let n=Ld(r,e),s=await fetch(`https://api.github.com/repos/${t}/installation`,{headers:{Authorization:`Bearer ${n}`,Accept:"application/vnd.github+json","X-GitHub-Api-Version":"2022-11-28"}});if(!s.ok){let a=await s.text();throw new Error(`Failed to look up installation for ${t} (${s.status}): ${a}`)}let i=await s.json();return Id.set(t,i.id),i.id}async function xx(r,e,t){let o=Nd.get(t);if(o&&o.expiresAt>Date.now()+6e4)return o.token;let n=Ld(r,e),s=await fetch(`https://api.github.com/app/installations/${t}/access_tokens`,{method:"POST",headers:{Authorization:`Bearer ${n}`,Accept:"application/vnd.github+json","X-GitHub-Api-Version":"2022-11-28"}});if(!s.ok){let a=await s.text();throw new Error(`Failed to mint installation token (${s.status}): ${a}`)}let i=await s.json();return Nd.set(t,{token:i.token,expiresAt:new Date(i.expires_at).getTime()}),i.token}function Ld(r,e){let t=Math.floor(Date.now()/1e3),o={alg:"RS256",typ:"JWT"},n={iat:t-30,exp:t+540,iss:r},s=l=>Buffer.from(JSON.stringify(l)).toString("base64").replace(/=+$/,"").replace(/\+/g,"-").replace(/\//g,"_"),i=`${s(o)}.${s(n)}`,a=jd.createSign("RSA-SHA256");return a.update(i),a.end(),`${i}.`+a.sign(e).toString("base64").replace(/=+$/,"").replace(/\+/g,"-").replace(/\//g,"_")}var Nd,Id,Se=h(()=>{"use strict";c();Nd=new Map,Id=new Map});async function vx(r){let e=r.query,t=r.variables??{},o=await B(r.repo,r.token);y(`[github.graphql.execute] query_len=${e?.length??0}`);let n=await fetch("https://api.github.com/graphql",{method:"POST",headers:K(o,{"Content-Type":"application/json"}),body:JSON.stringify({query:e,variables:t})}),s=await n.text();try{let i=JSON.parse(s);i&&Array.isArray(i.errors)&&i.errors.length>0&&y(`[github.graphql.execute] errors=${i.errors.length}`)}catch{}return`HTTP ${n.status} ${n.statusText}
|
|
89
|
+
${s}`}var No,Js=h(()=>{"use strict";c();Od();S();$e();Se();No={name:$d,displayName:Ed,description:Dd,parameters:Ad,category:Md,execute:vx}});var Fd,qd,Wd,Ud,Gd,Bd=h(()=>{"use strict";c();Fd="github.contents.getText",qd="Get Repo File (Text)",Wd="Fetch file content (decoded text) via the GitHub Contents API.",Ud="github",Gd={type:"object",properties:{repo:{type:"string",description:"owner/name (e.g. octo/repo)"},path:{type:"string",description:"File path within the repo"},ref:{type:"string",description:"Branch, tag, or commit sha"},token:{type:"string",description:"GitHub token (App installation or PAT)"},maxBytes:{type:"integer",description:"Optional max bytes of decoded text to return; if exceeded, result is truncated with a footer."}},required:["repo","path"]}});import{Buffer as Fn}from"buffer";async function Cx(r){let e=r.repo,t=r.path,o=r.ref,n=await B(e,r.token),s=r.maxBytes?Number(r.maxBytes):void 0,i=t.split("/").map(m=>encodeURIComponent(m)).join("/"),a=`https://api.github.com/repos/${e}/contents/${i}${o?`?ref=${encodeURIComponent(o)}`:""}`;y(`[github.contents.getText] repo=${e} path=${t} ref=${o??""}`);let l=await fetch(a,{method:"GET",headers:K(n)}),p=await l.text();if(!l.ok)return`HTTP ${l.status} ${l.statusText}
|
|
90
|
+
${p}`;try{let d=JSON.parse(p)?.content;if(typeof d=="string"){let g=Fn.from(d.replace(/\n/g,""),"base64").toString("utf8");if(s&&Fn.byteLength(g,"utf8")>s){let b=Fn.from(g,"utf8").subarray(0,s).toString("utf8"),w=`
|
|
91
|
+
\u2026 [truncated, ${s} of ${Fn.byteLength(g,"utf8")} bytes]`;return`HTTP ${l.status} ${l.statusText}
|
|
92
|
+
${b}${w}`}return`HTTP ${l.status} ${l.statusText}
|
|
93
93
|
${g}`}}catch{}return`HTTP ${l.status} ${l.statusText}
|
|
94
|
-
${p}`}var
|
|
94
|
+
${p}`}var Io,Vs=h(()=>{"use strict";c();Bd();S();$e();Se();Io={name:Fd,displayName:qd,description:Wd,parameters:Gd,category:Ud,execute:Cx}});var zd,Hd,Kd,Jd,Vd,Qd=h(()=>{"use strict";c();zd="github.pr.reviewThreads.list",Hd="List PR Review Threads",Kd="List PR review threads via GraphQL (optionally unresolved only).",Jd="github",Vd={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"PR number"},token:{type:"string",description:"GitHub token (App installation or PAT)"},unresolvedOnly:{type:"boolean",description:"If true, filter unresolved threads only"},first:{type:"integer",description:"Threads page size (max 100). Default 100."},after:{type:"string",description:"Cursor for pagination (GraphQL pageInfo.endCursor)."},commentsFirst:{type:"integer",description:"Comments per thread (max 100). Default 20."},includeMeta:{type:"boolean",description:"If true, return { headRefOid, threads, pageInfo } instead of array."}},required:["repo","number"]}});async function Sx(r){let[e,t]=String(r.repo).split("/"),o=Number(r.number),n=await B(r.repo,r.token),s=!!r.unresolvedOnly,i=r.first?Number(r.first):100,a=r.after?String(r.after):void 0,l=r.commentsFirst?Number(r.commentsFirst):20,p=!!r.includeMeta;y(`[github.pr.reviewThreads.list] repo=${e}/${t} pr=${o} unresolvedOnly=${s} first=${i} after=${a??""} commentsFirst=${l} includeMeta=${p}`);let d=await fetch("https://api.github.com/graphql",{method:"POST",headers:K(n,{"Content-Type":"application/json"}),body:JSON.stringify({query:`query($owner:String!,$name:String!,$number:Int!,$first:Int!,$after:String,$commentsFirst:Int!){
|
|
95
95
|
repository(owner:$owner,name:$name){
|
|
96
96
|
pullRequest(number:$number){
|
|
97
97
|
headRefOid
|
|
@@ -102,28 +102,28 @@ ${p}`}var No,Js=h(()=>{"use strict";c();Gd();k();Re();Ce();No={name:jd,displayNa
|
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
104
|
}`,variables:{owner:e,name:t,number:o,first:i,after:a,commentsFirst:l}})}),g=await d.text();if(!d.ok)return`HTTP ${d.status} ${d.statusText}
|
|
105
|
-
${g}`;try{let
|
|
106
|
-
${JSON.stringify(
|
|
107
|
-
${JSON.stringify(
|
|
108
|
-
${g}`}}var
|
|
109
|
-
${s}`}var Lo,
|
|
110
|
-
${l}`}var
|
|
111
|
-
\u2026 [truncated, ${n} of ${
|
|
105
|
+
${g}`;try{let b=JSON.parse(g);b&&Array.isArray(b.errors)&&b.errors.length>0&&y(`[github.pr.reviewThreads.list] errors=${b.errors.length}`);let w=b?.data?.repository?.pullRequest,T=w?.reviewThreads?.pageInfo??{hasNextPage:!1,endCursor:null},v=w?.reviewThreads?.nodes??[];if(s&&(v=v.filter(k=>k?.isResolved===!1)),p){let k={headRefOid:w?.headRefOid,threads:v,pageInfo:T};return`HTTP 200 OK
|
|
106
|
+
${JSON.stringify(k)}`}return`HTTP 200 OK
|
|
107
|
+
${JSON.stringify(v)}`}catch{return`HTTP ${d.status} ${d.statusText}
|
|
108
|
+
${g}`}}var jo,Qs=h(()=>{"use strict";c();Qd();$e();S();Se();jo={name:zd,displayName:Hd,description:Kd,parameters:Vd,category:Jd,execute:Sx}});var Xd,Yd,Zd,eu,tu,ou=h(()=>{"use strict";c();Xd="github.pr.reviewThreads.resolve",Yd="Resolve Review Thread",Zd=["Resolve a PR review thread via GraphQL resolveReviewThread mutation.","IMPORTANT: GitHub App installation tokens (ghs_*) cannot call this mutation \u2014 GitHub returns FORBIDDEN.","This tool only works with a Personal Access Token (PAT) that has repo scope.","If you are using a GitHub App installation token, do NOT call this tool.","Instead, post a reply on the thread acknowledging the fix and ask the author to resolve it manually."].join(" "),eu="github",tu={type:"object",properties:{threadId:{type:"string",description:"GraphQL node ID of the review thread"},repo:{type:"string",description:"owner/name \u2014 used for token resolution when no explicit token is provided"},token:{type:"string",description:"GitHub token \u2014 MUST be a PAT with repo scope. App installation tokens (ghs_*) will receive FORBIDDEN."}},required:["threadId"]}});async function kx(r){let e=String(r.threadId),t=await B(r.repo,r.token);y(`[github.pr.reviewThreads.resolve] threadId=${e}`);let n=await fetch("https://api.github.com/graphql",{method:"POST",headers:K(t,{"Content-Type":"application/json"}),body:JSON.stringify({query:"mutation($id:ID!){ resolveReviewThread(input:{threadId:$id}) { thread { id isResolved } } }",variables:{id:e}})}),s=await n.text();if(n.ok)try{if(JSON.parse(s).errors?.find(l=>l.type==="FORBIDDEN"))return["TOOL_UNSUPPORTED_FOR_TOKEN_TYPE: resolveReviewThread is not available for GitHub App installation tokens (ghs_*).","GitHub requires a user identity (PAT with repo scope) for this operation.","Fallback action: post a reply on the thread acknowledging the fix and ask the author to resolve it manually."].join(" ")}catch{}return`HTTP ${n.status} ${n.statusText}
|
|
109
|
+
${s}`}var Lo,Xs=h(()=>{"use strict";c();ou();$e();S();Se();Lo={name:Xd,displayName:Yd,description:Zd,parameters:tu,category:eu,execute:kx}});var nu,ru,su,iu,au,lu=h(()=>{"use strict";c();nu="github.pr.reviewComments.reply",ru="Reply to Review Comment",su="Reply within an existing PR review thread to maintain continuity.",iu="github",au={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"PR number"},inReplyTo:{type:"integer",description:"databaseId of the review comment to reply to"},body:{type:"string",description:"Reply body"},token:{type:"string",description:"GitHub token (App installation or PAT)"}},required:["repo","number","inReplyTo","body"]}});async function Px(r){let e=String(r.repo),t=Number(r.number),o=Number(r.inReplyTo),n=String(r.body),s=await B(e,r.token),i=`https://api.github.com/repos/${e}/pulls/${t}/comments/${o}/replies`;y(`[github.pr.reviewComments.reply] repo=${e} inReplyTo=${o}`);let a=await fetch(i,{method:"POST",headers:K(s,{"Content-Type":"application/json"}),body:JSON.stringify({body:n})}),l=await a.text();return`HTTP ${a.status} ${a.statusText}
|
|
110
|
+
${l}`}var Fo,Ys=h(()=>{"use strict";c();lu();S();$e();Se();Fo={name:nu,displayName:ru,description:su,parameters:au,category:iu,execute:Px}});var cu,pu,mu,du,uu,fu=h(()=>{"use strict";c();cu="github.pr.diff.get",pu="Get PR Diff",mu="Fetch the unified diff for a pull request (text/patch).",du="github",uu={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"PR number"},token:{type:"string",description:"GitHub token (App installation or PAT)"},maxBytes:{type:"integer",description:"Optional max bytes of diff to return; if exceeded, result is truncated with a footer."}},required:["repo","number"]}});import{Buffer as Zs}from"buffer";async function Rx(r){let e=String(r.repo),t=Number(r.number),o=await B(e,r.token),n=r.maxBytes?Number(r.maxBytes):void 0,s=`https://api.github.com/repos/${e}/pulls/${t}`;y(`[github.pr.diff.get] repo=${e} pr=${t}`);let i=await fetch(s,{method:"GET",headers:K(o,{Accept:"application/vnd.github.v3.diff"})}),a=await i.text();if(n&&Zs.byteLength(a,"utf8")>n){let l=Zs.from(a,"utf8").subarray(0,n).toString("utf8"),p=`
|
|
111
|
+
\u2026 [truncated, ${n} of ${Zs.byteLength(a,"utf8")} bytes]`;return`HTTP ${i.status} ${i.statusText}
|
|
112
112
|
${l}${p}`}return`HTTP ${i.status} ${i.statusText}
|
|
113
|
-
${a}`}var
|
|
114
|
-
${p}`}var
|
|
115
|
-
${m}`}var
|
|
116
|
-
${a}`}var
|
|
113
|
+
${a}`}var qo,ei=h(()=>{"use strict";c();fu();$e();S();Se();qo={name:cu,displayName:pu,description:mu,parameters:uu,category:du,execute:Rx}});var gu,hu,yu,bu,wu,Tu=h(()=>{"use strict";c();gu="github.pr.files.list",hu="List PR Files",yu="List files changed in a PR with positions metadata.",bu="github",wu={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"PR number"},token:{type:"string",description:"GitHub token (App installation or PAT)"},perPage:{type:"integer",description:"Results per page (max 100)"},page:{type:"integer",description:"Page number"}},required:["repo","number"]}});async function _x(r){let e=String(r.repo),t=Number(r.number),o=await B(e,r.token),n=r.perPage?Number(r.perPage):void 0,s=r.page?Number(r.page):void 0,i=new URLSearchParams;n&&i.set("per_page",String(n)),s&&i.set("page",String(s));let a=`https://api.github.com/repos/${e}/pulls/${t}/files${i.toString()?`?${i.toString()}`:""}`;y(`[github.pr.files.list] repo=${e} pr=${t} perPage=${n??""} page=${s??""}`);let l=await fetch(a,{method:"GET",headers:K(o)}),p=await l.text();return`HTTP ${l.status} ${l.statusText}
|
|
114
|
+
${p}`}var Wo,ti=h(()=>{"use strict";c();Tu();$e();S();Se();Wo={name:gu,displayName:hu,description:yu,parameters:wu,category:bu,execute:_x}});var xu,vu,Cu,Su,ku,Pu=h(()=>{"use strict";c();xu="github.pr.reviews.submit",vu="Submit PR Review",Cu="Submit a PR review (APPROVE, REQUEST_CHANGES, or COMMENT), optionally with inline comments.",Su="github",ku={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"PR number"},event:{type:"string",description:"Review event",enum:["APPROVE","REQUEST_CHANGES","COMMENT"]},body:{type:"string",description:"Top-level review body"},comments:{type:"array",description:"Optional inline comments array",items:{type:"object",properties:{path:{type:"string",description:"File path"},position:{type:"integer",description:"Position in the diff"},body:{type:"string",description:"Comment body"}},required:["path","position","body"]}},token:{type:"string",description:"GitHub token (App installation or PAT)"}},required:["repo","number","event"]}});async function $x(r){let e=String(r.repo),t=Number(r.number),o=String(r.event),n=r.body?String(r.body):void 0,s=Array.isArray(r.comments)?r.comments:void 0,i=await B(e,r.token),a=`https://api.github.com/repos/${e}/pulls/${t}/reviews`;y(`[github.pr.reviews.submit] repo=${e} pr=${t} event=${o} comments=${s?.length??0}`);let l={event:o};n&&(l.body=n),s&&s.length>0&&(l.comments=s);let p=await fetch(a,{method:"POST",headers:K(i,{"Content-Type":"application/json"}),body:JSON.stringify(l)}),m=await p.text();return`HTTP ${p.status} ${p.statusText}
|
|
115
|
+
${m}`}var Uo,oi=h(()=>{"use strict";c();Pu();$e();S();Se();Uo={name:xu,displayName:vu,description:Cu,parameters:ku,category:Su,execute:$x}});var Ru,_u,$u,Eu,Du,Mu=h(()=>{"use strict";c();Ru="github.issues.comments.create",_u="Create Issue/PR Comment",$u="Create a comment on an issue or pull request (conversation tab).",Eu="github",Du={type:"object",properties:{repo:{type:"string",description:"owner/name"},number:{type:"integer",description:"Issue or PR number"},body:{type:"string",description:"Comment body"},token:{type:"string",description:"GitHub token (App installation or PAT)"}},required:["repo","number","body"]}});async function Ex(r){let e=String(r.repo),t=Number(r.number),o=String(r.body),n=await B(e,r.token),s=`https://api.github.com/repos/${e}/issues/${t}/comments`;y(`[github.issues.comments.create] repo=${e} number=${t}`);let i=await fetch(s,{method:"POST",headers:K(n,{"Content-Type":"application/json"}),body:JSON.stringify({body:o})}),a=await i.text();return`HTTP ${i.status} ${i.statusText}
|
|
116
|
+
${a}`}var Go,ni=h(()=>{"use strict";c();Mu();$e();S();Se();Go={name:Ru,displayName:_u,description:$u,parameters:Du,category:Eu,execute:Ex}});var Ou={};ee(Ou,{githubContentsGetTextTool:()=>Io,githubGraphqlExecuteTool:()=>No,githubIssuesCommentsCreateTool:()=>Go,githubPrDiffGetTool:()=>qo,githubPrFilesListTool:()=>Wo,githubPrReviewCommentsReplyTool:()=>Fo,githubPrReviewThreadsListTool:()=>jo,githubPrReviewThreadsResolveTool:()=>Lo,githubPrReviewsSubmitTool:()=>Uo,githubToolsProject:()=>Au});var Au,ri=h(()=>{"use strict";c();Js();Vs();Qs();Xs();Ys();ei();ti();oi();ni();Js();Vs();Qs();Xs();Ys();ei();ti();oi();ni();Au={manifest:{key:"github",name:"github-tools",displayName:"GitHub",version:"1.0.0",description:"GitHub GraphQL/REST tools for PR threads, comments, and contents.",author:"Toolpack",tools:["github.graphql.execute","github.contents.getText","github.pr.reviewThreads.list","github.pr.reviewThreads.resolve","github.pr.reviewComments.reply","github.pr.diff.get","github.pr.files.list","github.pr.reviews.submit","github.issues.comments.create"],category:"network"},tools:[No,Io,jo,Lo,Fo,qo,Wo,Uo,Go],dependencies:{}}});var Nu,Iu,ju,Lu,Fu,qu=h(()=>{"use strict";c();Nu="web.fetch",Iu="Fetch",ju="Fetch content from a URL. Supports multiple extraction modes: full (raw HTML up to 15K chars), structured (title, excerpt, key points), or minimal (title + snippet).",Lu="network",Fu={type:"object",properties:{url:{type:"string",description:"The URL to fetch"},extractionMode:{type:"string",description:'Content extraction mode: "full" (raw HTML, 15K limit), "structured" (title, excerpt, key points, main content), or "minimal" (title + 500 char snippet). Default: "full"',enum:["full","structured","minimal"],default:"full"},headers:{type:"object",description:"Optional HTTP headers as key-value pairs"},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as si from"cheerio";function Wu(r,e){let t=si.load(r);t("script, style, nav, header, footer, aside, .advertisement, .ad, .sidebar").remove();let o=t("title").text().trim()||t("h1").first().text().trim()||t('meta[property="og:title"]').attr("content")||"Untitled",n=t('meta[name="author"]').attr("content")||t('meta[property="article:author"]').attr("content")||t(".author").first().text().trim()||void 0,s=t('meta[property="article:published_time"]').attr("content")||t("time").first().attr("datetime")||t(".date, .published").first().text().trim()||void 0,i=["article","main",'[role="main"]',".content",".article-content",".post-content","#content"],a="";for(let b of i){let w=t(b).first();if(w.length>0&&(a=w.text().trim(),a.length>200))break}(!a||a.length<200)&&(a=t("body").text().trim()),a=a.replace(/\s+/g," ").trim();let l=[];t("p").each((b,w)=>{let T=t(w).text().trim();T.length>50&&l.length<3&&l.push(T)});let p=l.join(`
|
|
117
117
|
|
|
118
|
-
`)||a.substring(0,500),m=[];t("h2, h3").each((w
|
|
119
|
-
`)}function
|
|
118
|
+
`)||a.substring(0,500),m=[];t("h2, h3").each((b,w)=>{let T=t(w).text().trim();T&&T.length>5&&T.length<200&&m.length<10&&m.push(T)});let d=a.split(/\s+/).length,g=a.split(/\s+/);return g.length>2e3&&(a=g.slice(0,2e3).join(" ")+"..."),{title:o,url:e,author:n,publishDate:s,excerpt:p.substring(0,1e3),mainContent:a.substring(0,1e4),keyPoints:m,wordCount:d}}function Uu(r,e){let t=si.load(r);t("script, style, nav, header, footer").remove();let o=t("title").text().trim()||t("h1").first().text().trim()||"Untitled",n=t('meta[name="description"]').attr("content")||t('meta[property="og:description"]').attr("content")||"";return n||t("p").each((s,i)=>{let a=t(i).text().trim();a.length>50&&!n&&(n=a)}),n||(n=t("body").text().trim().replace(/\s+/g," ")),{title:o,url:e,snippet:n.substring(0,500)}}function Gu(r){let e=[];return e.push(`# ${r.title}`),e.push(`URL: ${r.url}`),r.author&&e.push(`Author: ${r.author}`),r.publishDate&&e.push(`Published: ${r.publishDate}`),e.push(`Word Count: ${r.wordCount}`),e.push(""),r.keyPoints.length>0&&(e.push("## Key Points"),r.keyPoints.forEach(t=>{e.push(`- ${t}`)}),e.push("")),e.push("## Excerpt"),e.push(r.excerpt),e.push(""),e.push("## Main Content"),e.push(r.mainContent),e.join(`
|
|
119
|
+
`)}function Bu(r){return`# ${r.title}
|
|
120
120
|
URL: ${r.url}
|
|
121
121
|
|
|
122
|
-
${r.snippet}`}var
|
|
123
|
-
${await a.text()}`;let l=await a.text();if(t==="structured"){let p=
|
|
122
|
+
${r.snippet}`}var zu=h(()=>{"use strict";c()});async function Dx(r){let e=r.url,t=r.extractionMode||"full",o=r.headers,n=r.timeout||3e4;if(y(`[web.fetch] execute url="${e}" mode=${t} timeout=${n}ms`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let s=new AbortController,i=setTimeout(()=>s.abort(),n),a;try{a=await fetch(e,{method:"GET",headers:o||{},signal:s.signal})}catch(p){throw p.name==="AbortError"?new Error(`Request timed out after ${n}ms`):p}finally{clearTimeout(i)}if(!a.ok)return`HTTP ${a.status} ${a.statusText}
|
|
123
|
+
${await a.text()}`;let l=await a.text();if(t==="structured"){let p=Wu(l,e);return Gu(p)}else if(t==="minimal"){let p=Uu(l,e);return Bu(p)}else return l.length>15e3?l.substring(0,15e3)+`
|
|
124
124
|
|
|
125
|
-
[TRUNCATED: showing 15K of ${l.length} total characters]`:l}var
|
|
126
|
-
`)||
|
|
125
|
+
[TRUNCATED: showing 15K of ${l.length} total characters]`:l}var Bo,ii=h(()=>{"use strict";c();qu();zu();S();Bo={name:Nu,displayName:Iu,description:ju,parameters:Fu,category:Lu,execute:Dx}});var Hu,Ku,Ju,Vu,Qu,Xu=h(()=>{"use strict";c();Hu="web.search",Ku="Search",Ju="Search the web using multiple providers (Tavily, Brave, DuckDuckGo Lite) with automatic fallback. Supports real-time results via freshness parameter and AI-generated answers. Configure API keys via environment variables (TOOLPACK_TAVILY_API_KEY, TOOLPACK_BRAVE_API_KEY) or toolpack.config.json for best results.",Vu="network",Qu={type:"object",properties:{query:{type:"string",description:"The search query"},max_results:{type:"integer",description:"Maximum number of results to return (default: 5)",default:5},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4},include_answer:{type:"boolean",description:"Include AI-generated answer summary (works with Tavily and Brave APIs). Default: false",default:!1},freshness:{type:"string",description:'Time range for fresh/recent results: "day" (last 24h), "week" (last 7 days), "month" (last 31 days), "year" (last 365 days). Ensures latest real-time data. Supported by Tavily and Brave APIs; DuckDuckGo returns general results.',enum:["day","week","month","year"]}},required:["query"]}});import*as We from"fs";import*as qn from"path";function Wn(r){let e=Zu(r);if(!We.existsSync(e))return{};try{let t=We.readFileSync(e,"utf-8");return JSON.parse(t)}catch{return{}}}function zo(r){let e=Wn(r),t=Ax(e.tools||e);return y(JSON.stringify(t??{})),t}function Mx(r,e){let t=Zu(e),o={};try{We.existsSync(t)&&(o=JSON.parse(We.readFileSync(t,"utf-8")))}catch{o={}}o.tools=r,We.writeFileSync(t,JSON.stringify(o,null,4),"utf-8")}function Ax(r){let e=r.additionalConfigurations||{};return e.webSearch||(e.webSearch={}),!e.webSearch.tavilyApiKey&&process.env.TOOLPACK_TAVILY_API_KEY&&(e.webSearch.tavilyApiKey=process.env.TOOLPACK_TAVILY_API_KEY),!e.webSearch.braveApiKey&&process.env.TOOLPACK_BRAVE_API_KEY&&(e.webSearch.braveApiKey=process.env.TOOLPACK_BRAVE_API_KEY),{enabled:r.enabled??ce.enabled,autoExecute:r.autoExecute??ce.autoExecute,maxToolRounds:r.maxToolRounds??ce.maxToolRounds,toolChoicePolicy:r.toolChoicePolicy??ce.toolChoicePolicy,resultMaxChars:r.resultMaxChars??ce.resultMaxChars,enabledTools:r.enabledTools??ce.enabledTools,enabledToolCategories:r.enabledToolCategories??ce.enabledToolCategories,toolSearch:r.toolSearch??ce.toolSearch,additionalConfigurations:e}}function Zu(r){return r?r.endsWith(".json")?qn.resolve(r):qn.resolve(r,Yu):qn.resolve(process.cwd(),Yu)}var Yu,ai=h(()=>{"use strict";c();Bt();S();Yu="toolpack.config.json"});import*as tf from"cheerio";function Ix(r,e){y("[web.search] Parsing DuckDuckGo Lite response");let t=tf.load(r),o=[];return t("a.result-link").each((s,i)=>{if(o.length>=e)return;let a=t(i),l=a.text().trim(),p=a.attr("href"),m=a.siblings(".result-snippet").text().trim();m||(m=a.parent().text().replace(l,"").trim()),l&&p&&o.push({title:l,link:p,snippet:m.slice(0,200)})}),o}function jx(r){if(r)switch(r){case"day":return 1;case"week":return 7;case"month":return 31;case"year":return 365;default:return}}function ef(r){if(!r)return"";switch(r){case"day":return"pd";case"week":return"pw";case"month":return"pm";case"year":return"py";default:return""}}async function Lx(r){let e=r.query,t=r.max_results||5,o=r.include_answer||!1,n=r.freshness;y(`[web.search] execute query="${e}" max_results=${t} includeAnswer=${o} freshness=${n??"none"}`);let s=`Request timed out after ${r.timeout||3e4}ms`,i=()=>{let d=new AbortController,g=setTimeout(()=>d.abort(),r.timeout||3e4);return{signal:d.signal,clear:()=>clearTimeout(g)}};if(!e)throw new Error("query is required");let a=zo();if(y(`[web.search] config=${JSON.stringify(a)}`),a.additionalConfigurations?.webSearch?.tavilyApiKey){y("[web.search] using Tavily API");try{let{signal:d,clear:g}=i(),b=jx(n),w={method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({api_key:a.additionalConfigurations.webSearch.tavilyApiKey,query:e,max_results:t,include_answer:o,...b&&{days:b}}),signal:d};y(`[web.search] Tavily request=${JSON.stringify(w)}`);let T=await fetch("https://api.tavily.com/search",w).finally(g);if(T.ok){let v=await T.json();if(v.results&&v.results.length>0){let k=v.results.map(x=>({title:x.title,link:x.url,snippet:x.content}));return o&&v.answer?JSON.stringify({answer:v.answer,results:k},null,2):JSON.stringify(k,null,2)}}else pe(`[web.search] Tavily search failed with status ${T.status}`)}catch(d){pe(`[web.search] Tavily search failed, falling back: ${d}`)}}if(a.additionalConfigurations?.webSearch?.braveApiKey)try{let{signal:d,clear:g}=i();if(o){let b=ef(n),w=b?`&freshness=${b}`:"",T=await fetch(`https://api.search.brave.com/res/v1/web/search?q=${encodeURIComponent(e)}&count=${Math.min(t,20)}&summary=1${w}`,{headers:{Accept:"application/json","Accept-Encoding":"gzip","X-Subscription-Token":a.additionalConfigurations.webSearch.braveApiKey},signal:d}).finally(g);if(T.ok){let v=await T.json(),k=v.summarizer?.key;if(k&&v.web?.results){let{signal:x,clear:D}=i(),M=await fetch(`https://api.search.brave.com/res/v1/summarizer/search?key=${k}`,{headers:{Accept:"application/json","X-Subscription-Token":a.additionalConfigurations.webSearch.braveApiKey},signal:x}).finally(D);if(M.ok){let C=await M.json(),R=v.web.results.slice(0,t).map(E=>({title:E.title,link:E.url,snippet:E.description})),$=C.summary?.map(E=>E.data).join(`
|
|
126
|
+
`)||C.title;return JSON.stringify({answer:$,results:R},null,2)}}if(v.web?.results){let x=v.web.results.slice(0,t).map(D=>({title:D.title,link:D.url,snippet:D.description}));return JSON.stringify(x,null,2)}}}else{let b=ef(n),w=b?`&freshness=${b}`:"",T=await fetch(`https://api.search.brave.com/res/v1/web/search?q=${encodeURIComponent(e)}&count=${Math.min(t,20)}${w}`,{headers:{Accept:"application/json","Accept-Encoding":"gzip","X-Subscription-Token":a.additionalConfigurations.webSearch.braveApiKey},signal:d}).finally(g);if(T.ok){let v=await T.json();if(v.web?.results&&v.web.results.length>0){let k=v.web.results.slice(0,t).map(x=>({title:x.title,link:x.url,snippet:x.description}));return JSON.stringify(k,null,2)}}}}catch(d){I(`[web.search] Brave search failed, falling back: ${d}`)}let{signal:l,clear:p}=i(),m;try{m=await fetch(Ox,{method:"POST",headers:{"User-Agent":Nx,"Content-Type":"application/x-www-form-urlencoded",Origin:"https://lite.duckduckgo.com",Referer:"https://lite.duckduckgo.com/"},body:new URLSearchParams({q:e}).toString(),signal:l})}catch(d){throw d.name==="AbortError"?new Error(s):d}finally{p()}if(m.ok){let d=await m.text(),g=Ix(d,t);if(g.length>0)return JSON.stringify(g,null,2)}return JSON.stringify({error:"search_unavailable",message:`Search failed to find results for "${e}" across all providers.`,suggestion:"Please configure a search provider API key (tavilyApiKey or braveApiKey) in toolpack.config.json under tools.additionalConfigurations.webSearch."})}var Ox,Nx,Ho,li=h(()=>{"use strict";c();Xu();ai();S();Ox="https://lite.duckduckgo.com/lite/",Nx="Mozilla/5.0 (iPhone; CPU iPhone OS 14_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0 Mobile/15E148 Safari/604.1";Ho={name:Hu,displayName:Ku,description:Ju,parameters:Qu,category:Vu,execute:Lx}});var of,nf,rf,sf,af,lf=h(()=>{"use strict";c();of="web.scrape",nf="Scrape",rf="Extract clean text content from a webpage. RECOMMENDED WORKFLOW: Use web.map first to see page structure, then use section parameter to extract specific sections. Strips scripts, styles, navigation, and other junk. By default, auto-detects and extracts the main article/content area.",sf="network",af={type:"object",properties:{url:{type:"string",description:"The URL to scrape"},section:{type:"string",description:'Optional section name to extract (e.g., "talks", "about", "experience"). Finds the heading containing this text and extracts content until the next same-level heading. Use web.map first to discover available sections.'},format:{type:"string",description:'Output format: "text" (clean readable text) or "tables" (extract table data as JSON array). Default: "text"',enum:["text","tables"],default:"text"},selector:{type:"string",description:"Optional CSS selector to target a specific element. Only use if you know the exact selector exists."},max_length:{type:"integer",description:"Maximum characters to return (default: 6000). Keep small (3000-6000) to avoid context limits.",default:6e3},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as mf from"cheerio";async function Wx(r){let e=r.url,t=r.selector,o=r.section,n=r.format||"text",s=r.max_length||6e3,i=r.timeout||3e4;if(y(`[web.scrape] execute url="${e}" format=${n} selector=${t??"none"} section=${o??"none"} timeout=${i}ms`),!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let a=new AbortController,l=setTimeout(()=>a.abort(),i),p;try{p=await fetch(e,{method:"GET",headers:{"User-Agent":Fx},signal:a.signal})}catch(w){throw w.name==="AbortError"?new Error(`Request timed out after ${i}ms`):w}finally{clearTimeout(l)}if(!p.ok)throw new Error(`Failed to fetch ${e}: HTTP ${p.status} ${p.statusText}`);let m=await p.text(),d=mf.load(m);for(let w of qx)d(w).remove();if(n==="tables"){let w=[];return d("table").each((T,v)=>{let k=[],x=[];d(v).find("th").each((D,M)=>{x.push(d(M).text().trim())}),d(v).find("tr").each((D,M)=>{let C=x.length>0?{}:[],R=d(M).find("td");R.length>0&&(R.each(($,E)=>{let j=d(E).text().trim();x.length>0&&x[$]?C[x[$]]=j:C.push(j)}),k.push(C))}),k.length>0&&w.push({id:`Table ${T+1}`,headers:x.length>0?x:void 0,rows:k})}),w.length===0?`No tables found on ${e}`:JSON.stringify(w,null,2)}let g="";if(o){let w=o.toLowerCase(),T=null,v=0;if(d("h1, h2, h3, h4, h5, h6").each((k,x)=>{if(d(x).text().toLowerCase().includes(w))return T=x,v=parseInt(x.tagName.charAt(1)),!1}),T){let k=d(T),x=[],D=k.next();for(;D.length>0;){let M=D.prop("tagName")?.toLowerCase();if(M&&/^h[1-6]$/.test(M)&&parseInt(M.charAt(1))<=v)break;let C=D.text().trim();C&&x.push(C),D=D.next()}x.length>0?(g=x.join(`
|
|
127
127
|
|
|
128
128
|
`).replace(/\s+/g," ").trim(),g=`[Section: "${o}"]
|
|
129
129
|
|
|
@@ -131,32 +131,32 @@ ${g}`):g=`[Note: Found heading "${o}" but no content below it. Falling back to f
|
|
|
131
131
|
|
|
132
132
|
`}else g=`[Note: Section "${o}" not found. Falling back to full page.]
|
|
133
133
|
|
|
134
|
-
`}if(!g||g.includes("Falling back to full page"))if(g&&g.includes("Falling back to full page")&&(g=""),t){let
|
|
134
|
+
`}if(!g||g.includes("Falling back to full page"))if(g&&g.includes("Falling back to full page")&&(g=""),t){let w=d(t);if(w.length>0)g=w.text().replace(/\s+/g," ").trim();else{for(let T of cf){let v=d(T);if(v.length>0){let k=v.text().replace(/\s+/g," ").trim();if(k.length>pf){g=k;break}}}if(g)g=`[Note: Selector "${t}" not found. Showing auto-detected main content instead.]
|
|
135
135
|
|
|
136
|
-
${g}`;else return`No element found matching selector "${t}" and could not auto-detect main content from ${e}`}}else for(let
|
|
136
|
+
${g}`;else return`No element found matching selector "${t}" and could not auto-detect main content from ${e}`}}else for(let w of cf){let T=d(w);if(T.length>0){let v=T.text().replace(/\s+/g," ").trim();if(v.length>pf){g=v;break}}}if(g||(g=d("body").text().replace(/\s+/g," ").trim(),g&&(g=`[Note: Could not detect main content area. Showing full page text (may include navigation).]
|
|
137
137
|
|
|
138
|
-
${g}`)),!g)return`Could not extract any content from ${e}`;if(g.length>s){let
|
|
138
|
+
${g}`)),!g)return`Could not extract any content from ${e}`;if(g.length>s){let w=g.substring(0,s);return`[Warning: Content exceeds ${s} chars (actual: ${g.length} chars). Showing first ${s} chars only.]
|
|
139
139
|
|
|
140
140
|
RECOMMENDATION: Use web.map to see page structure, then use web.scrape with section parameter to extract specific sections.
|
|
141
141
|
|
|
142
142
|
Page content from ${e}:
|
|
143
143
|
|
|
144
|
-
${
|
|
144
|
+
${w}
|
|
145
145
|
|
|
146
146
|
... [Content truncated. ${g.length-s} chars remaining. Use section parameter to extract specific sections.]`}return`Page content from ${e}:
|
|
147
147
|
|
|
148
|
-
${g}`}var
|
|
148
|
+
${g}`}var Fx,qx,cf,pf,Ko,ci=h(()=>{"use strict";c();lf();S();Fx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36",qx=["script","style","nav","footer","header","iframe",".ads",".sidebar","noscript"],cf=["article","main",".content","#content",'[role="main"]',"body"],pf=200;Ko={name:of,displayName:nf,description:rf,parameters:af,category:sf,execute:Wx}});var df,uf,ff,gf,hf,yf=h(()=>{"use strict";c();df="web.extract_links",uf="Extract Links",ff="Extract all links from a webpage. Returns an array of objects with text and URL. Optionally filter by pattern.",gf="network",hf={type:"object",properties:{url:{type:"string",description:"The URL to extract links from"},filter:{type:"string",description:'Optional filter: "same-domain" to only include links from the same domain, or a substring to match against URLs'},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as bf from"cheerio";async function Gx(r){let e=r.url,t=r.filter,o=r.timeout||3e4;if(!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let n=new AbortController,s=setTimeout(()=>n.abort(),o),i;try{i=await fetch(e,{method:"GET",headers:{"User-Agent":Ux},signal:n.signal})}catch(d){throw d.name==="AbortError"?new Error(`Request timed out after ${o}ms`):d}finally{clearTimeout(s)}if(!i.ok)throw new Error(`Failed to fetch ${e}: HTTP ${i.status} ${i.statusText}`);let a=await i.text(),l=bf.load(a),p=new URL(e),m=[];return l("a[href]").each((d,g)=>{let b=l(g),w=b.attr("href");if(!w)return;let T;try{T=new URL(w,e).toString()}catch{return}if(T.startsWith("javascript:")||T.startsWith("mailto:")||T.startsWith("tel:"))return;let v=b.text().trim()||"[no text]";if(t){if(t==="same-domain")try{if(new URL(T).hostname!==p.hostname)return}catch{return}else if(!T.includes(t))return}m.push({text:v,url:T})}),m.length===0?`No links found on ${e}${t?` matching filter "${t}"`:""}`:JSON.stringify(m,null,2)}var Ux,Jo,pi=h(()=>{"use strict";c();yf();Ux="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Jo={name:df,displayName:uf,description:ff,parameters:hf,category:gf,execute:Gx}});var wf,Tf,xf,vf,Cf,Sf=h(()=>{"use strict";c();wf="web.map",Tf="Map",xf="Extract the structure/outline of a webpage by returning all headings (h1-h6). Use this FIRST when you need to understand what sections exist on a page before scraping specific content. Returns a lightweight outline showing the page hierarchy.",vf="network",Cf={type:"object",properties:{url:{type:"string",description:"The URL to map"},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as kf from"cheerio";async function zx(r){let e=r.url,t=r.timeout||3e4;if(!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let o=new AbortController,n=setTimeout(()=>o.abort(),t),s;try{s=await fetch(e,{method:"GET",headers:{"User-Agent":Bx},signal:o.signal})}catch(m){throw m.name==="AbortError"?new Error(`Request timed out after ${t}ms`):m}finally{clearTimeout(n)}if(!s.ok)throw new Error(`Failed to fetch ${e}: HTTP ${s.status} ${s.statusText}`);let i=await s.text(),a=kf.load(i),l=[];if(a("h1, h2, h3, h4, h5, h6").each((m,d)=>{let g=d.tagName.toLowerCase(),b=parseInt(g.charAt(1)),w=a(d).text().trim();w&&l.push({level:b,text:w})}),l.length===0)return`No headings found on ${e}. The page may not have a clear structure.`;let p=`Page outline for ${e}:
|
|
149
149
|
|
|
150
150
|
`;for(let m of l){let d=" ".repeat(m.level-1);p+=`${d}${"#".repeat(m.level)} ${m.text}
|
|
151
|
-
`}return p}var
|
|
152
|
-
`);for(let m of p){if(l.length>=t)break;let d=m.trim();if(d.toLowerCase().startsWith("sitemap:"))l.push({loc:d.substring(8).trim()});else if(d.toLowerCase().startsWith("allow:")){let g=d.substring(6).trim();l.push({loc:new URL(g,n).toString()})}}}return JSON.stringify(l,null,2)}var Kx,Qo,ui=h(()=>{"use strict";c();Lf();Kx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Qo={name:Mf,displayName:Of,description:Af,parameters:If,category:Nf,execute:Jx}});var Ff,qf,Wf,Uf,Gf,Bf=h(()=>{"use strict";c();Ff="web.feed",qf="Extract Feed",Wf="Parse RSS/Atom feeds and return structured entries. Requires rss-parser library to be installed.",Uf="network",Gf={type:"object",properties:{url:{type:"string",description:"The URL of the RSS/Atom feed"},max_entries:{type:"integer",description:"Maximum number of entries to return (default: 10)",default:10},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});async function zf(){try{let r=await import("rss-parser");return new(r.default||r)}catch{throw new Error("rss-parser is not installed. Please install it using `npm install rss-parser` to use this feature.")}}var Hf=h(()=>{"use strict";c()});async function Vx(r){let e=r.url,t=r.max_entries||10,o=r.timeout||3e4;if(!e)throw new Error("url is required");let n=await zf();n.options={...n.options,timeout:o};try{let s=await n.parseURL(e),i=s.items.slice(0,t).map(a=>({title:a.title,link:a.link,published:a.pubDate||a.isoDate,summary:a.contentSnippet||a.content}));return JSON.stringify({feedTitle:s.title,feedDescription:s.description,entries:i},null,2)}catch(s){throw new Error(`Failed to parse feed from ${e}: ${s.message}`)}}var Xo,fi=h(()=>{"use strict";c();Bf();Hf();Xo={name:Ff,displayName:qf,description:Wf,parameters:Gf,category:Uf,execute:Vx}});var Kf,Jf,Vf,Qf,Xf,Yf=h(()=>{"use strict";c();Kf="web.screenshot",Jf="Screenshot",Vf="Render a page with headless browser and return screenshot Base64 PNG or rendered HTML.",Qf="network",Xf={type:"object",properties:{url:{type:"string",description:"The URL to capture"},format:{type:"string",description:'Output format: "html" or "png" (default: "html")',enum:["html","png"],default:"html"},viewport:{type:"object",description:"Optional viewport { width, height } (default: { width: 1280, height: 800 })",properties:{width:{type:"integer"},height:{type:"integer"}}},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});async function Zf(){try{let r=await import("puppeteer");return r.default||r}catch{throw new Error("Puppeteer is not installed. Please install it using `npm install puppeteer` to use this feature.")}}var eg=h(()=>{"use strict";c()});async function Xx(r){let e=r.url,t=r.format||"html",o=r.viewport,n=r.timeout||3e4;if(!e)throw new Error("url is required");let i=await(await Zf()).launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox"]});try{let a=await i.newPage();if(await a.setUserAgent(Qx),await a.setViewport({width:o?.width||1280,height:o?.height||800}),await a.goto(e,{waitUntil:"networkidle2",timeout:n}),t==="png"){let l=await a.screenshot({type:"png",fullPage:!0}),p;return Buffer.isBuffer(l)?p=l.toString("base64"):p=Buffer.from(l).toString("base64"),`data:image/png;base64,${p}`}else return await a.content()}finally{await i.close()}}var Qx,Yo,gi=h(()=>{"use strict";c();Yf();eg();Qx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Yo={name:Kf,displayName:Jf,description:Vf,parameters:Xf,category:Qf,execute:Xx}});var og={};ee(og,{webExtractLinksTool:()=>Ko,webFeedTool:()=>Xo,webFetchTool:()=>Go,webMapTool:()=>Jo,webMetadataTool:()=>Vo,webScrapeTool:()=>Ho,webScreenshotTool:()=>Yo,webSearchTool:()=>zo,webSitemapTool:()=>Qo,webToolsProject:()=>tg});var tg,hi=h(()=>{"use strict";c();si();ai();li();ci();pi();mi();ui();fi();gi();si();ai();li();ci();pi();mi();ui();fi();gi();tg={manifest:{key:"web",name:"web-tools",displayName:"Web",version:"1.0.0",description:"Web intelligence tools for fetching, searching, scraping, and extracting content from the web.",author:"Sajeer",tools:["web.fetch","web.search","web.scrape","web.extract_links","web.map","web.metadata","web.sitemap","web.feed","web.screenshot"],category:"network"},tools:[Go,zo,Ho,Ko,Jo,Vo,Qo,Xo,Yo],dependencies:{cheerio:"^1.0.0-rc.12"}}});var ng,rg,sg,ig,ag,lg=h(()=>{"use strict";c();ng="coding.find_symbol",rg="Find Symbol",sg="Find function, class, or variable definitions in JavaScript/TypeScript files using AST parsing",ig="coding",ag={type:"object",properties:{symbol:{type:"string",description:"Name of the symbol to find (function, class, variable, etc.)"},path:{type:"string",description:"File or directory path to search in (searches recursively if directory)"},kind:{type:"string",description:"Optional: filter by symbol kind (function, class, variable, const, let, interface, type)"}},required:["symbol","path"]}});import{extname as Yx}from"path";function Wn(r){let e=Yx(r).toLowerCase();return Zx[e]||"unknown"}var Zx,yi=h(()=>{"use strict";c();Zx={".js":"javascript",".mjs":"javascript",".cjs":"javascript",".jsx":"jsx",".ts":"typescript",".tsx":"tsx",".py":"python",".go":"go",".rs":"rust",".java":"java",".c":"c",".h":"c",".cpp":"cpp",".hpp":"cpp",".cc":"cpp",".rb":"ruby",".php":"php",".swift":"swift",".kt":"kotlin",".kts":"kotlin",".hs":"haskell",".ex":"elixir",".exs":"elixir",".html":"html",".htm":"html",".css":"css",".json":"json",".yaml":"yaml",".yml":"yaml",".md":"markdown",".sh":"bash",".bash":"bash"}});import*as st from"web-tree-sitter";import*as Me from"fs";import*as We from"path";import*as pg from"os";var cg,bi,ev,Un,mg=h(()=>{"use strict";c();cg=st.default||st.Parser||st,bi=We.join(pg.homedir(),".toolpack-sdk","grammars"),ev=We.resolve(u,"../../grammars"),Un=class{grammars=new Map;isInitialized=!1;async init(){this.isInitialized||(await cg.init({locateFile(e,t){return We.join(u,"../../../../../../node_modules/web-tree-sitter",e)}}),this.isInitialized=!0)}async ensureGrammar(e){await this.init();let t=this.grammars.get(e);if(t)return t;let o=await this.resolveGrammarPath(e),s=await(st.Language||cg.Language).load(o);return this.grammars.set(e,s),s}async resolveGrammarPath(e){let t=`tree-sitter-${e}.wasm`,o=We.resolve(u,"../../../../../../node_modules/tree-sitter-wasms/out",t);if(Me.existsSync(o))return o;let n=We.join(ev,t);if(Me.existsSync(n))return n;let s=We.join(bi,t);return Me.existsSync(s)||await this.downloadGrammar(e,s),s}async downloadGrammar(e,t){Me.existsSync(bi)||Me.mkdirSync(bi,{recursive:!0});let o=`https://unpkg.com/tree-sitter-wasms@latest/out/tree-sitter-${e}.wasm`,n=await fetch(o);if(!n.ok)throw new Error(`Failed to download grammar for ${e}: ${n.statusText}`);let s=await n.arrayBuffer(),i=Buffer.from(s);Me.writeFileSync(t,i)}}});import*as Zo from"web-tree-sitter";import*as dg from"fs";import*as ug from"crypto";var tv,Gn,fg=h(()=>{"use strict";c();yi();mg();tv=Zo.default||Zo.Parser||Zo,Gn=class{treeCache=new Map;maxCacheSize=50;parser=null;grammarManager;constructor(){this.grammarManager=new Un}hash(e){return ug.createHash("md5").update(e).digest("hex")}async getTree(e,t){let o=t!==void 0?t:dg.readFileSync(e,"utf-8"),n=this.hash(o),s=this.treeCache.get(e),i=Wn(e);if(i==="unknown")throw new Error(`Unsupported file type for ${e}`);let a=await this.grammarManager.ensureGrammar(i);if(s&&s.contentHash===n)return s.lastAccessed=Date.now(),{tree:s.tree,language:s.language,grammar:a};this.parser||(await this.grammarManager.init(),this.parser=new tv),this.parser.setLanguage(a);let l;return s?(s.tree&&s.tree.delete(),l=this.parser.parse(o)):l=this.parser.parse(o),this.treeCache.set(e,{tree:l,language:i,contentHash:n,lastAccessed:Date.now()}),this.evictIfNeeded(),{tree:l,language:i,grammar:a}}evictIfNeeded(){if(this.treeCache.size<=this.maxCacheSize)return;let e="",t=1/0;for(let[o,n]of this.treeCache.entries())n.lastAccessed<t&&(t=n.lastAccessed,e=o);if(e){let o=this.treeCache.get(e);o&&o.tree.delete(),this.treeCache.delete(e)}}}});import{parse as ov}from"@babel/parser";import*as wi from"@babel/traverse";var $e,Bn,gg=h(()=>{"use strict";c();$e=wi.default||wi,Bn=class{parseCode(e){return ov(e,{sourceType:"module",plugins:["jsx","typescript","decorators-legacy","classProperties","objectRestSpread","optionalChaining","nullishCoalescingOperator"]})}async findSymbols(e,t,o){let n=[];try{let s=this.parseCode(e.content),i=e.filePath;$e(s,{FunctionDeclaration(a){a.node.id?.name===t&&(!o||o==="function")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"function",name:t})},ClassDeclaration(a){a.node.id?.name===t&&(!o||o==="class")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"class",name:t})},VariableDeclarator(a){if(a.node.id.type==="Identifier"&&a.node.id.name===t){let l=a.parent,p=l.type==="VariableDeclaration"?l.kind:"variable";(!o||o===p||o==="variable")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:p,name:t})}},TSInterfaceDeclaration(a){a.node.id.name===t&&(!o||o==="interface")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"interface",name:t})},TSTypeAliasDeclaration(a){a.node.id.name===t&&(!o||o==="type")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"type",name:t})}})}catch{}return n}async getSymbols(e,t){let o=[];try{let n=this.parseCode(e.content);$e(n,{FunctionDeclaration(s){s.node.id?.name&&(!t||t==="function")&&o.push({name:s.node.id.name,kind:"function",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},ClassDeclaration(s){s.node.id?.name&&(!t||t==="class")&&o.push({name:s.node.id.name,kind:"class",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},VariableDeclarator(s){if(s.node.id.type==="Identifier"){let i=s.parent,a=i.type==="VariableDeclaration"?i.kind:"variable";(!t||t===a||t==="variable")&&o.push({name:s.node.id.name,kind:a,line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})}},TSInterfaceDeclaration(s){(!t||t==="interface")&&o.push({name:s.node.id.name,kind:"interface",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},TSTypeAliasDeclaration(s){(!t||t==="type")&&o.push({name:s.node.id.name,kind:"type",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})}})}catch(n){throw new Error(`Failed to parse file "${e.filePath}": ${n.message}`)}return o}async getImports(e){let t=[];try{let o=this.parseCode(e.content);$e(o,{ImportDeclaration(n){let s=n.node.source.value,i=[],a="side-effect";for(let l of n.node.specifiers)if(l.type==="ImportDefaultSpecifier")i.push(l.local.name),a="default";else if(l.type==="ImportNamespaceSpecifier")i.push(`* as ${l.local.name}`),a="namespace";else if(l.type==="ImportSpecifier"){let p=l.imported.type==="Identifier"?l.imported.name:l.imported.value,m=l.local.name;i.push(p===m?p:`${p} as ${m}`),a="named"}t.push({source:s,imports:i,line:n.node.loc?.start.line||0,type:a})}})}catch(o){throw new Error(`Failed to parse file "${e.filePath}": ${o.message}`)}return t}async findReferences(e,t,o){let n=[];try{let s=e.content,i=s.split(`
|
|
153
|
-
`),a=this.parseCode(s)
|
|
151
|
+
`}return p}var Bx,Vo,mi=h(()=>{"use strict";c();Sf();Bx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Vo={name:wf,displayName:Tf,description:xf,parameters:Cf,category:vf,execute:zx}});var Pf,Rf,_f,$f,Ef,Df=h(()=>{"use strict";c();Pf="web.metadata",Rf="Extract Metadata",_f="Extract Open Graph, Twitter Cards, JSON-LD, and meta tags from a URL.",$f="network",Ef={type:"object",properties:{url:{type:"string",description:"The URL to extract metadata from"},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as Mf from"cheerio";async function Kx(r){let e=r.url,t=r.timeout||3e4;if(!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let o=new AbortController,n=setTimeout(()=>o.abort(),t),s;try{s=await fetch(e,{method:"GET",headers:{"User-Agent":Hx},signal:o.signal})}catch(p){throw p.name==="AbortError"?new Error(`Request timed out after ${t}ms`):p}finally{clearTimeout(n)}if(!s.ok)throw new Error(`Failed to fetch ${e}: HTTP ${s.status} ${s.statusText}`);let i=await s.text(),a=Mf.load(i),l={title:a("title").text()||"",description:a('meta[name="description"]').attr("content")||a('meta[property="og:description"]').attr("content")||"",author:a('meta[name="author"]').attr("content")||"",openGraph:{},twitter:{},jsonLd:[]};return a('meta[property^="og:"]').each((p,m)=>{let d=a(m).attr("property")?.replace("og:",""),g=a(m).attr("content");d&&g&&(l.openGraph[d]=g)}),a('meta[name^="twitter:"]').each((p,m)=>{let d=a(m).attr("name")?.replace("twitter:",""),g=a(m).attr("content");d&&g&&(l.twitter[d]=g)}),a('script[type="application/ld+json"]').each((p,m)=>{let d=a(m).html();if(d)try{l.jsonLd.push(JSON.parse(d))}catch{}}),JSON.stringify(l,null,2)}var Hx,Qo,di=h(()=>{"use strict";c();Df();Hx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Qo={name:Pf,displayName:Rf,description:_f,parameters:Ef,category:$f,execute:Kx}});var Af,Of,Nf,If,jf,Lf=h(()=>{"use strict";c();Af="web.sitemap",Of="Extract Sitemap",Nf="Parse sitemap.xml or robots.txt to discover all pages on a site. Returns an array of URLs with lastmod/priority if available.",If="network",jf={type:"object",properties:{url:{type:"string",description:"The base URL or direct sitemap.xml / robots.txt URL"},max_urls:{type:"integer",description:"Maximum number of URLs to return (default: 100)",default:100},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});import*as Ff from"cheerio";async function ui(r,e){let t=new AbortController,o=setTimeout(()=>t.abort(),e);try{return await fetch(r,{method:"GET",headers:{"User-Agent":Jx},signal:t.signal})}catch(n){throw n.name==="AbortError"?new Error(`Request timed out after ${e}ms`):n}finally{clearTimeout(o)}}async function Vx(r){let e=r.url,t=r.max_urls||100,o=r.timeout||3e4;if(!e)throw new Error("url is required");if(!e.startsWith("http://")&&!e.startsWith("https://"))throw new Error("url must start with http:// or https://");let n=e,s=!1;!e.endsWith(".xml")&&!e.endsWith(".txt")&&(n=new URL(e.endsWith("/")?"sitemap.xml":"/sitemap.xml",e).toString(),s=!0);let i;try{i=await ui(n,o),!i.ok&&s&&(n=new URL(e.endsWith("/")?"robots.txt":"/robots.txt",e).toString(),i=await ui(n,o))}catch(p){if(s)n=new URL(e.endsWith("/")?"robots.txt":"/robots.txt",e).toString(),i=await ui(n,o);else throw p}if(!i||!i.ok)throw new Error(`Failed to fetch sitemap or robots.txt from ${e}`);let a=await i.text(),l=[];if(n.endsWith(".xml")||a.trim().startsWith("<")){let p=Ff.load(a,{xmlMode:!0}),m=p("sitemap > loc");if(m.length>0)return m.each((g,b)=>{l.length>=t||l.push({loc:p(b).text()})}),JSON.stringify({type:"sitemapindex",urls:l},null,2);p("urlset > url").each((g,b)=>{if(l.length>=t)return;let w=p(b);l.push({loc:w.children("loc").text(),lastmod:w.children("lastmod").text()||void 0,priority:w.children("priority").text()||void 0})})}else{let p=a.split(`
|
|
152
|
+
`);for(let m of p){if(l.length>=t)break;let d=m.trim();if(d.toLowerCase().startsWith("sitemap:"))l.push({loc:d.substring(8).trim()});else if(d.toLowerCase().startsWith("allow:")){let g=d.substring(6).trim();l.push({loc:new URL(g,n).toString()})}}}return JSON.stringify(l,null,2)}var Jx,Xo,fi=h(()=>{"use strict";c();Lf();Jx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Xo={name:Af,displayName:Of,description:Nf,parameters:jf,category:If,execute:Vx}});var qf,Wf,Uf,Gf,Bf,zf=h(()=>{"use strict";c();qf="web.feed",Wf="Extract Feed",Uf="Parse RSS/Atom feeds and return structured entries. Requires rss-parser library to be installed.",Gf="network",Bf={type:"object",properties:{url:{type:"string",description:"The URL of the RSS/Atom feed"},max_entries:{type:"integer",description:"Maximum number of entries to return (default: 10)",default:10},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});async function Hf(){try{let r=await import("rss-parser");return new(r.default||r)}catch{throw new Error("rss-parser is not installed. Please install it using `npm install rss-parser` to use this feature.")}}var Kf=h(()=>{"use strict";c()});async function Qx(r){let e=r.url,t=r.max_entries||10,o=r.timeout||3e4;if(!e)throw new Error("url is required");let n=await Hf();n.options={...n.options,timeout:o};try{let s=await n.parseURL(e),i=s.items.slice(0,t).map(a=>({title:a.title,link:a.link,published:a.pubDate||a.isoDate,summary:a.contentSnippet||a.content}));return JSON.stringify({feedTitle:s.title,feedDescription:s.description,entries:i},null,2)}catch(s){throw new Error(`Failed to parse feed from ${e}: ${s.message}`)}}var Yo,gi=h(()=>{"use strict";c();zf();Kf();Yo={name:qf,displayName:Wf,description:Uf,parameters:Bf,category:Gf,execute:Qx}});var Jf,Vf,Qf,Xf,Yf,Zf=h(()=>{"use strict";c();Jf="web.screenshot",Vf="Screenshot",Qf="Render a page with headless browser and return screenshot Base64 PNG or rendered HTML.",Xf="network",Yf={type:"object",properties:{url:{type:"string",description:"The URL to capture"},format:{type:"string",description:'Output format: "html" or "png" (default: "html")',enum:["html","png"],default:"html"},viewport:{type:"object",description:"Optional viewport { width, height } (default: { width: 1280, height: 800 })",properties:{width:{type:"integer"},height:{type:"integer"}}},timeout:{type:"integer",description:"Timeout in milliseconds (default: 30000)",default:3e4}},required:["url"]}});async function eg(){try{let r=await import("puppeteer");return r.default||r}catch{throw new Error("Puppeteer is not installed. Please install it using `npm install puppeteer` to use this feature.")}}var tg=h(()=>{"use strict";c()});async function Yx(r){let e=r.url,t=r.format||"html",o=r.viewport,n=r.timeout||3e4;if(!e)throw new Error("url is required");let i=await(await eg()).launch({headless:!0,args:["--no-sandbox","--disable-setuid-sandbox"]});try{let a=await i.newPage();if(await a.setUserAgent(Xx),await a.setViewport({width:o?.width||1280,height:o?.height||800}),await a.goto(e,{waitUntil:"networkidle2",timeout:n}),t==="png"){let l=await a.screenshot({type:"png",fullPage:!0}),p;return Buffer.isBuffer(l)?p=l.toString("base64"):p=Buffer.from(l).toString("base64"),`data:image/png;base64,${p}`}else return await a.content()}finally{await i.close()}}var Xx,Zo,hi=h(()=>{"use strict";c();Zf();tg();Xx="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36";Zo={name:Jf,displayName:Vf,description:Qf,parameters:Yf,category:Xf,execute:Yx}});var ng={};ee(ng,{webExtractLinksTool:()=>Jo,webFeedTool:()=>Yo,webFetchTool:()=>Bo,webMapTool:()=>Vo,webMetadataTool:()=>Qo,webScrapeTool:()=>Ko,webScreenshotTool:()=>Zo,webSearchTool:()=>Ho,webSitemapTool:()=>Xo,webToolsProject:()=>og});var og,yi=h(()=>{"use strict";c();ii();li();ci();pi();mi();di();fi();gi();hi();ii();li();ci();pi();mi();di();fi();gi();hi();og={manifest:{key:"web",name:"web-tools",displayName:"Web",version:"1.0.0",description:"Web intelligence tools for fetching, searching, scraping, and extracting content from the web.",author:"Sajeer",tools:["web.fetch","web.search","web.scrape","web.extract_links","web.map","web.metadata","web.sitemap","web.feed","web.screenshot"],category:"network"},tools:[Bo,Ho,Ko,Jo,Vo,Qo,Xo,Yo,Zo],dependencies:{cheerio:"^1.0.0-rc.12"}}});var rg,sg,ig,ag,lg,cg=h(()=>{"use strict";c();rg="coding.find_symbol",sg="Find Symbol",ig="Find function, class, or variable definitions in JavaScript/TypeScript files using AST parsing",ag="coding",lg={type:"object",properties:{symbol:{type:"string",description:"Name of the symbol to find (function, class, variable, etc.)"},path:{type:"string",description:"File or directory path to search in (searches recursively if directory)"},kind:{type:"string",description:"Optional: filter by symbol kind (function, class, variable, const, let, interface, type)"}},required:["symbol","path"]}});import{extname as Zx}from"path";function Un(r){let e=Zx(r).toLowerCase();return ev[e]||"unknown"}var ev,bi=h(()=>{"use strict";c();ev={".js":"javascript",".mjs":"javascript",".cjs":"javascript",".jsx":"jsx",".ts":"typescript",".tsx":"tsx",".py":"python",".go":"go",".rs":"rust",".java":"java",".c":"c",".h":"c",".cpp":"cpp",".hpp":"cpp",".cc":"cpp",".rb":"ruby",".php":"php",".swift":"swift",".kt":"kotlin",".kts":"kotlin",".hs":"haskell",".ex":"elixir",".exs":"elixir",".html":"html",".htm":"html",".css":"css",".json":"json",".yaml":"yaml",".yml":"yaml",".md":"markdown",".sh":"bash",".bash":"bash"}});import*as it from"web-tree-sitter";import*as Ae from"fs";import*as Ue from"path";import*as mg from"os";var pg,wi,tv,Gn,dg=h(()=>{"use strict";c();pg=it.default||it.Parser||it,wi=Ue.join(mg.homedir(),".toolpack-sdk","grammars"),tv=Ue.resolve(u,"../../grammars"),Gn=class{grammars=new Map;isInitialized=!1;async init(){this.isInitialized||(await pg.init({locateFile(e,t){return Ue.join(u,"../../../../../../node_modules/web-tree-sitter",e)}}),this.isInitialized=!0)}async ensureGrammar(e){await this.init();let t=this.grammars.get(e);if(t)return t;let o=await this.resolveGrammarPath(e),s=await(it.Language||pg.Language).load(o);return this.grammars.set(e,s),s}async resolveGrammarPath(e){let t=`tree-sitter-${e}.wasm`,o=Ue.resolve(u,"../../../../../../node_modules/tree-sitter-wasms/out",t);if(Ae.existsSync(o))return o;let n=Ue.join(tv,t);if(Ae.existsSync(n))return n;let s=Ue.join(wi,t);return Ae.existsSync(s)||await this.downloadGrammar(e,s),s}async downloadGrammar(e,t){Ae.existsSync(wi)||Ae.mkdirSync(wi,{recursive:!0});let o=`https://unpkg.com/tree-sitter-wasms@latest/out/tree-sitter-${e}.wasm`,n=await fetch(o);if(!n.ok)throw new Error(`Failed to download grammar for ${e}: ${n.statusText}`);let s=await n.arrayBuffer(),i=Buffer.from(s);Ae.writeFileSync(t,i)}}});import*as en from"web-tree-sitter";import*as ug from"fs";import*as fg from"crypto";var ov,Bn,gg=h(()=>{"use strict";c();bi();dg();ov=en.default||en.Parser||en,Bn=class{treeCache=new Map;maxCacheSize=50;parser=null;grammarManager;constructor(){this.grammarManager=new Gn}hash(e){return fg.createHash("md5").update(e).digest("hex")}async getTree(e,t){let o=t!==void 0?t:ug.readFileSync(e,"utf-8"),n=this.hash(o),s=this.treeCache.get(e),i=Un(e);if(i==="unknown")throw new Error(`Unsupported file type for ${e}`);let a=await this.grammarManager.ensureGrammar(i);if(s&&s.contentHash===n)return s.lastAccessed=Date.now(),{tree:s.tree,language:s.language,grammar:a};this.parser||(await this.grammarManager.init(),this.parser=new ov),this.parser.setLanguage(a);let l;return s?(s.tree&&s.tree.delete(),l=this.parser.parse(o)):l=this.parser.parse(o),this.treeCache.set(e,{tree:l,language:i,contentHash:n,lastAccessed:Date.now()}),this.evictIfNeeded(),{tree:l,language:i,grammar:a}}evictIfNeeded(){if(this.treeCache.size<=this.maxCacheSize)return;let e="",t=1/0;for(let[o,n]of this.treeCache.entries())n.lastAccessed<t&&(t=n.lastAccessed,e=o);if(e){let o=this.treeCache.get(e);o&&o.tree.delete(),this.treeCache.delete(e)}}}});import{parse as nv}from"@babel/parser";import*as Ti from"@babel/traverse";var Ee,zn,hg=h(()=>{"use strict";c();Ee=Ti.default||Ti,zn=class{parseCode(e){return nv(e,{sourceType:"module",plugins:["jsx","typescript","decorators-legacy","classProperties","objectRestSpread","optionalChaining","nullishCoalescingOperator"]})}async findSymbols(e,t,o){let n=[];try{let s=this.parseCode(e.content),i=e.filePath;Ee(s,{FunctionDeclaration(a){a.node.id?.name===t&&(!o||o==="function")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"function",name:t})},ClassDeclaration(a){a.node.id?.name===t&&(!o||o==="class")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"class",name:t})},VariableDeclarator(a){if(a.node.id.type==="Identifier"&&a.node.id.name===t){let l=a.parent,p=l.type==="VariableDeclaration"?l.kind:"variable";(!o||o===p||o==="variable")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:p,name:t})}},TSInterfaceDeclaration(a){a.node.id.name===t&&(!o||o==="interface")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"interface",name:t})},TSTypeAliasDeclaration(a){a.node.id.name===t&&(!o||o==="type")&&n.push({file:i,line:a.node.loc?.start.line||0,column:a.node.loc?.start.column||0,kind:"type",name:t})}})}catch{}return n}async getSymbols(e,t){let o=[];try{let n=this.parseCode(e.content);Ee(n,{FunctionDeclaration(s){s.node.id?.name&&(!t||t==="function")&&o.push({name:s.node.id.name,kind:"function",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},ClassDeclaration(s){s.node.id?.name&&(!t||t==="class")&&o.push({name:s.node.id.name,kind:"class",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},VariableDeclarator(s){if(s.node.id.type==="Identifier"){let i=s.parent,a=i.type==="VariableDeclaration"?i.kind:"variable";(!t||t===a||t==="variable")&&o.push({name:s.node.id.name,kind:a,line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})}},TSInterfaceDeclaration(s){(!t||t==="interface")&&o.push({name:s.node.id.name,kind:"interface",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})},TSTypeAliasDeclaration(s){(!t||t==="type")&&o.push({name:s.node.id.name,kind:"type",line:s.node.loc?.start.line||0,column:s.node.loc?.start.column||0})}})}catch(n){throw new Error(`Failed to parse file "${e.filePath}": ${n.message}`)}return o}async getImports(e){let t=[];try{let o=this.parseCode(e.content);Ee(o,{ImportDeclaration(n){let s=n.node.source.value,i=[],a="side-effect";for(let l of n.node.specifiers)if(l.type==="ImportDefaultSpecifier")i.push(l.local.name),a="default";else if(l.type==="ImportNamespaceSpecifier")i.push(`* as ${l.local.name}`),a="namespace";else if(l.type==="ImportSpecifier"){let p=l.imported.type==="Identifier"?l.imported.name:l.imported.value,m=l.local.name;i.push(p===m?p:`${p} as ${m}`),a="named"}t.push({source:s,imports:i,line:n.node.loc?.start.line||0,type:a})}})}catch(o){throw new Error(`Failed to parse file "${e.filePath}": ${o.message}`)}return t}async findReferences(e,t,o){let n=[];try{let s=e.content,i=s.split(`
|
|
153
|
+
`),a=this.parseCode(s);Ee(a,{Identifier(l){if(l.node.name===t){let p=l.isFunctionDeclaration()||l.isClassDeclaration()||l.parent.type==="VariableDeclarator"&&l.parent.id===l.node||l.parent.type==="TSInterfaceDeclaration"&&l.parent.id===l.node||l.parent.type==="TSTypeAliasDeclaration"&&l.parent.id===l.node;if(!p||o){let m=l.node.loc?.start.line||0,d=l.node.loc?.start.column||0,g=i[m-1]||"";n.push({file:e.filePath,line:m,column:d,context:g.trim(),isDeclaration:p})}}}})}catch{}return n}async getSymbolAtPosition(e,t,o){try{let n=this.parseCode(e.content),s=null;return Ee(n,{Identifier(i){let a=i.node.loc;a&&a.start.line===t&&a.start.column===o&&(s=i.node.name,i.stop())}}),s}catch{return null}}async getDefinition(e,t){try{let o=this.parseCode(e.content),n=e.filePath,s=null;return Ee(o,{FunctionDeclaration(i){i.node.id?.name===t&&(s={file:n,line:i.node.loc?.start.line||0,column:i.node.loc?.start.column||0,kind:"function",name:t},i.stop())},ClassDeclaration(i){i.node.id?.name===t&&(s={file:n,line:i.node.loc?.start.line||0,column:i.node.loc?.start.column||0,kind:"class",name:t},i.stop())},VariableDeclarator(i){if(i.node.id.type==="Identifier"&&i.node.id.name===t){let a=i.parent,l=a.type==="VariableDeclaration"?a.kind:"variable";s={file:n,line:i.node.loc?.start.line||0,column:i.node.loc?.start.column||0,kind:l,name:t},i.stop()}},TSInterfaceDeclaration(i){i.node.id.name===t&&(s={file:n,line:i.node.loc?.start.line||0,column:i.node.loc?.start.column||0,kind:"interface",name:t},i.stop())},TSTypeAliasDeclaration(i){i.node.id.name===t&&(s={file:n,line:i.node.loc?.start.line||0,column:i.node.loc?.start.column||0,kind:"type",name:t},i.stop())}}),s}catch{return null}}async getDiagnostics(e){try{return this.parseCode(e.content),[]}catch(t){return[{message:t.message,line:t.loc?.line||0,column:t.loc?.column||0,severity:"error"}]}}async getExports(e){let t=[];try{let o=this.parseCode(e.content);Ee(o,{ExportNamedDeclaration(n){if(n.node.declaration)if(n.node.declaration.type==="VariableDeclaration")for(let s of n.node.declaration.declarations)s.id.type==="Identifier"&&t.push({name:s.id.name,kind:"variable",line:s.loc?.start.line||0,column:s.loc?.start.column||0});else n.node.declaration.type==="FunctionDeclaration"&&n.node.declaration.id?t.push({name:n.node.declaration.id.name,kind:"function",line:n.node.declaration.loc?.start.line||0,column:n.node.declaration.loc?.start.column||0}):n.node.declaration.type==="ClassDeclaration"&&n.node.declaration.id&&t.push({name:n.node.declaration.id.name,kind:"class",line:n.node.declaration.loc?.start.line||0,column:n.node.declaration.loc?.start.column||0});else if(n.node.specifiers)for(let s of n.node.specifiers)s.exported.type==="Identifier"&&t.push({name:s.exported.name,kind:"export",line:s.loc?.start.line||0,column:s.loc?.start.column||0})},ExportDefaultDeclaration(n){let s="default",i="default";n.node.declaration.type==="ClassDeclaration"&&n.node.declaration.id?(s=n.node.declaration.id.name,i="class"):n.node.declaration.type==="FunctionDeclaration"&&n.node.declaration.id?(s=n.node.declaration.id.name,i="function"):n.node.declaration.type==="Identifier"&&(s=n.node.declaration.name,i="variable"),t.push({name:s,kind:i,line:n.node.loc?.start.line||0,column:n.node.loc?.start.column||0})}})}catch{}return t}async getOutline(e){let t=[];try{return(await this.getSymbols(e)).map(n=>({name:n.name,kind:n.kind,line:n.line,column:n.column,children:[]}))}catch{}return t}async extractFunction(e,t,o,n,s,i){let a=e.content.split(`
|
|
154
154
|
`),l=Math.max(0,t-1),p=Math.min(a.length,n),m=a.slice(l,p).join(`
|
|
155
155
|
`),d=`
|
|
156
156
|
function ${i}() {
|
|
157
157
|
${m}
|
|
158
158
|
}
|
|
159
|
-
`,g=`${i}();`;return{newFunction:d,replacementCall:g}}async getCallHierarchy(e,t,o){try{let n=this.parseCode(e.content),s=e.filePath,i=null,a="",l=0,p=0;if(
|
|
159
|
+
`,g=`${i}();`;return{newFunction:d,replacementCall:g}}async getCallHierarchy(e,t,o){try{let n=this.parseCode(e.content),s=e.filePath,i=null,a="",l=0,p=0;if(Ee(n,{Function(w){let T=w.node.loc;T&&T.start.line<=t&&T.end&&T.end.line>=t&&(i=w,l=T.start.line,p=T.start.column,w.node.type==="FunctionDeclaration"&&w.node.id?a=w.node.id.name:w.parent.type==="VariableDeclarator"&&w.parent.id.type==="Identifier"?a=w.parent.id.name:w.parent.type==="ClassMethod"||w.parent.type==="ObjectMethod"?w.parent.key.type==="Identifier"&&(a=w.parent.key.name):a="<anonymous>")}}),!i||a==="<anonymous>")return null;let m=[],d=[];Ee(n,{CallExpression(w){let T=w.node.loc;if(!T||T.start.line<l||T.end&&T.end.line>l+1e3)return;let v=!1,k=w;for(;k;){if(k.isFunction()&&k.node.type==="FunctionDeclaration"&&k.node.id?.name===a){v=!0;break}k=k.parentPath}if(!v)return;let x=w.node.callee,D="<unknown>";x.type==="Identifier"?D=x.name:x.type==="MemberExpression"&&x.property.type==="Identifier"&&(D=x.property.name),D!=="<unknown>"&&d.push({file:s,name:D,line:w.node.loc?.start.line||0,column:w.node.loc?.start.column||0})}}),Ee(n,{CallExpression(w){let T=w.node.callee,v=!1;if((T.type==="Identifier"&&T.name===a||T.type==="MemberExpression"&&T.property.type==="Identifier"&&T.property.name===a)&&(v=!0),v){let k="<global>",x=w;for(;x;){if(x.isFunction()){x.node.type==="FunctionDeclaration"&&x.node.id?k=x.node.id.name:x.parent.type==="VariableDeclarator"&&x.parent.id.type==="Identifier"?k=x.parent.id.name:(x.parent.type==="ClassMethod"||x.parent.type==="ObjectMethod")&&x.parent.key.type==="Identifier"&&(k=x.parent.key.name);break}x=x.parentPath}m.push({file:s,name:k,line:w.node.loc?.start.line||0,column:w.node.loc?.start.column||0})}}});let g=[...new Map(m.map(w=>[`${w.name}:${w.line}`,w])).values()],b=[...new Map(d.map(w=>[`${w.name}:${w.line}`,w])).values()];return{file:s,name:a,line:l,column:p,callers:g,callees:b}}catch{return null}}}});function ke(r,e){xi[r]=e}var xi,at=h(()=>{"use strict";c();xi={}});var rv,yg=h(()=>{"use strict";c();at();rv={symbols:`
|
|
160
160
|
(function_definition
|
|
161
161
|
name: (identifier) @name.function) @definition.function
|
|
162
162
|
|
|
@@ -174,7 +174,7 @@ ${m}
|
|
|
174
174
|
name: (dotted_name) @name) @import
|
|
175
175
|
`,references:`
|
|
176
176
|
(identifier) @reference
|
|
177
|
-
`};
|
|
177
|
+
`};ke("python",rv)});var sv,bg=h(()=>{"use strict";c();at();sv={symbols:`
|
|
178
178
|
(function_declaration
|
|
179
179
|
name: (identifier) @name.function) @definition.function
|
|
180
180
|
|
|
@@ -202,7 +202,7 @@ ${m}
|
|
|
202
202
|
(identifier) @reference
|
|
203
203
|
(field_identifier) @reference
|
|
204
204
|
(type_identifier) @reference
|
|
205
|
-
`};
|
|
205
|
+
`};ke("go",sv)});var iv,wg=h(()=>{"use strict";c();at();iv={symbols:`
|
|
206
206
|
(function_item
|
|
207
207
|
name: (identifier) @name.function) @definition.function
|
|
208
208
|
|
|
@@ -224,7 +224,7 @@ ${m}
|
|
|
224
224
|
(identifier) @reference
|
|
225
225
|
(type_identifier) @reference
|
|
226
226
|
(field_identifier) @reference
|
|
227
|
-
`};
|
|
227
|
+
`};ke("rust",iv)});var av,Tg=h(()=>{"use strict";c();at();av={symbols:`
|
|
228
228
|
(method_declaration
|
|
229
229
|
name: (identifier) @name.method) @definition.method
|
|
230
230
|
|
|
@@ -245,7 +245,7 @@ ${m}
|
|
|
245
245
|
`,references:`
|
|
246
246
|
(identifier) @reference
|
|
247
247
|
(type_identifier) @reference
|
|
248
|
-
`};
|
|
248
|
+
`};ke("java",av)});var xg,vg=h(()=>{"use strict";c();at();xg={symbols:`
|
|
249
249
|
(function_definition
|
|
250
250
|
declarator: (function_declarator
|
|
251
251
|
declarator: (identifier) @name.function)) @definition.function
|
|
@@ -266,23 +266,23 @@ ${m}
|
|
|
266
266
|
(identifier) @reference
|
|
267
267
|
(type_identifier) @reference
|
|
268
268
|
(field_identifier) @reference
|
|
269
|
-
`};
|
|
269
|
+
`};ke("cpp",xg);ke("c",xg)});var Hn,Cg=h(()=>{"use strict";c();at();yg();bg();wg();Tg();vg();Hn=class{constructor(e){this.context=e}context;async executeQuery(e,t){let{tree:o,language:n,grammar:s}=await this.context.getTree(e.filePath,e.content),i=xi[n];if(!i||!i[t])throw new Error(`Query ${t} not found for language ${n}`);let a=i[t],l=s.query(a);return{tree:o,captures:l.captures(o.rootNode)}}async findSymbols(e,t,o){return(await this.getSymbols(e,o)).filter(s=>s.name===t).map(s=>({file:e.filePath,line:s.line,column:s.column,kind:s.kind,name:s.name}))}async getSymbols(e,t){let{captures:o}=await this.executeQuery(e,"symbols"),n=[];for(let s of o)if(s.name.startsWith("name.")){let i=s.name.split(".")[1];(!t||t===i)&&n.push({name:s.node.text,kind:i,line:s.node.startPosition.row+1,column:s.node.startPosition.column})}return n}async getImports(e){let{captures:t}=await this.executeQuery(e,"imports"),o=t.filter(s=>s.name==="import").map(s=>s.node),n=[];for(let s of o)n.push({source:s.text,imports:[s.text],line:s.startPosition.row+1,type:"side-effect"});return n}async findReferences(e,t,o){let{captures:n}=await this.executeQuery(e,"references"),s=e.content.split(`
|
|
270
270
|
`),i=[];for(let a of n)if(a.node.text===t){let l=a.node.parent?.type.includes("definition")||a.node.parent?.type.includes("declaration");if(!l||o){let p=a.node.startPosition.row+1;i.push({file:e.filePath,line:p,column:a.node.startPosition.column,context:s[p-1].trim(),isDeclaration:!!l})}}return i}async getSymbolAtPosition(e,t,o){let{tree:n}=await this.context.getTree(e.filePath,e.content),s=n.rootNode.descendantForPosition({row:t-1,column:o});return s&&s.type==="identifier"?s.text:null}async getDefinition(e,t){let o=await this.findSymbols(e,t);return o.length>0?o[0]:null}async getDiagnostics(e){let{tree:t}=await this.context.getTree(e.filePath,e.content),o=[];function n(s){if(s.hasError()){s.type==="ERROR"&&o.push({message:`Syntax error at line ${s.startPosition.row+1}`,line:s.startPosition.row+1,column:s.startPosition.column,severity:"error"});for(let i of s.children)n(i)}else s.isMissing&&s.isMissing()&&o.push({message:`Missing ${s.type} at line ${s.startPosition.row+1}`,line:s.startPosition.row+1,column:s.startPosition.column,severity:"error"})}return n(t.rootNode),o}async getExports(e){return[]}async getOutline(e){return(await this.getSymbols(e)).map(o=>({name:o.name,kind:o.kind,line:o.line,column:o.column,children:[]}))}async extractFunction(e,t,o,n,s,i){let a=e.content.split(`
|
|
271
271
|
`),l=Math.max(0,t-1),p=Math.min(a.length,n),m=a.slice(l,p).join(`
|
|
272
|
-
`),d="",g="",
|
|
272
|
+
`),d="",g="",b=e.filePath.split(".").pop()?.toLowerCase();return b==="py"||b==="pyi"?(d=`
|
|
273
273
|
def ${i}():
|
|
274
274
|
${m.split(`
|
|
275
|
-
`).map(
|
|
275
|
+
`).map(w=>" "+w).join(`
|
|
276
276
|
`)}
|
|
277
|
-
`,g=`${i}()`):
|
|
277
|
+
`,g=`${i}()`):b==="go"?(d=`
|
|
278
278
|
func ${i}() {
|
|
279
279
|
${m}
|
|
280
280
|
}
|
|
281
|
-
`,g=`${i}()`):
|
|
281
|
+
`,g=`${i}()`):b==="rs"?(d=`
|
|
282
282
|
fn ${i}() {
|
|
283
283
|
${m}
|
|
284
284
|
}
|
|
285
|
-
`,g=`${i}();`):
|
|
285
|
+
`,g=`${i}();`):b==="sh"||b==="bash"?(d=`
|
|
286
286
|
${i}() {
|
|
287
287
|
${m}
|
|
288
288
|
}
|
|
@@ -290,24 +290,24 @@ ${m}
|
|
|
290
290
|
void ${i}() {
|
|
291
291
|
${m}
|
|
292
292
|
}
|
|
293
|
-
`,g=`${i}();`),{newFunction:d,replacementCall:g}}async getCallHierarchy(e,t,o){let n=await this.getSymbolAtPosition(e,t,o);if(!n)return null;let i=(await this.findReferences(e,n,!1)).map(a=>({file:a.file,name:a.context.trim()||"<anonymous>",line:a.line,column:a.column}));return{file:e.filePath,name:n,line:t,column:o,callers:i,callees:[]}}}});var Hn,Cg=h(()=>{"use strict";c();yi();gg();vg();Hn=class{constructor(e){this.context=e;this.babelParser=new Bn,this.treeSitterParser=new zn(this.context)}context;babelParser;treeSitterParser;getParser(e){switch(Wn(e)){case"javascript":case"typescript":case"tsx":case"jsx":return this.babelParser;case"python":case"go":case"rust":case"java":case"c":case"cpp":return this.treeSitterParser;default:throw new Error(`Unsupported or unknown language for file: ${e}`)}}}});import{readFileSync as av,statSync as lv,readdirSync as cv}from"fs";import{join as pv,extname as mv}from"path";var Kn,Sg=h(()=>{"use strict";c();he();Kn=class{isBuilt=!1;isBuilding=!1;data={symbolLocations:new Map};fileMtimes=new Map;supportedExtensions=[".js",".jsx",".ts",".tsx",".mjs",".cjs",".py",".go",".rs",".java",".c",".cpp",".h",".hpp"];async getAllSupportedFiles(e){let t=[];try{let o=cv(e,{withFileTypes:!0});for(let n of o){let s=pv(e,n.name);n.name==="node_modules"||n.name===".git"||n.name==="dist"||n.name==="build"||(n.isDirectory()?t.push(...await this.getAllSupportedFiles(s)):n.isFile()&&this.supportedExtensions.includes(mv(n.name).toLowerCase())&&t.push(s))}}catch{}return t}async buildIndex(e){if(!(this.isBuilt||this.isBuilding)){this.isBuilding=!0;try{let t=await this.getAllSupportedFiles(e);for(let o of t)await this.updateFile(o);this.isBuilt=!0}finally{this.isBuilding=!1}}}async updateFile(e){try{let o=lv(e).mtimeMs;if(this.fileMtimes.get(e)===o)return;let n=av(e,"utf-8"),s=F.getParser(e);this.removeFileFromIndex(e);let i=await s.getSymbols({filePath:e,content:n});for(let a of i){let l=this.data.symbolLocations.get(a.name);l?l.add(e):this.data.symbolLocations.set(a.name,new Set([e]))}this.fileMtimes.set(e,o)}catch{this.removeFileFromIndex(e)}}removeFileFromIndex(e){for(let[t,o]of this.data.symbolLocations.entries())o.delete(e),o.size===0&&this.data.symbolLocations.delete(t);this.fileMtimes.delete(e)}async getDefinitionFiles(e,t){await this.buildIndex(t);let o=this.data.symbolLocations.get(e);return o?Array.from(o):[]}}});var dv,F,Mt,he=h(()=>{"use strict";c();fg();Cg();Sg();dv=new Gn,F=new Hn(dv),Mt=new Kn});import{readFileSync as uv,statSync as fv,readdirSync as gv}from"fs";import{join as hv,extname as yv}from"path";async function kg(r,e,t){try{let o=uv(r,"utf-8");return await F.getParser(r).findSymbols({filePath:r,content:o},e,t)}catch{return[]}}async function Pg(r,e,t){let o=[];try{let n=gv(r,{withFileTypes:!0});for(let s of n){let i=hv(r,s.name);if(!(s.name==="node_modules"||s.name===".git"||s.name==="dist")){if(s.isDirectory()){let a=await Pg(i,e,t);o.push(...a)}else if(s.isFile()&&bv.includes(yv(s.name))){let a=await kg(i,e,t);o.push(...a)}}}}catch{}return o}async function wv(r){let e=r.symbol,t=r.path,o=r.kind;if(y(`[coding.find-symbol] execute symbol="${e}" path="${t}" kind=${o??"all"}`),!e)throw new Error("symbol is required");if(!t)throw new Error("path is required");let n=fv(t),s;if(n.isDirectory())s=await Pg(t,e,o);else if(n.isFile())s=await kg(t,e,o);else throw new Error(`Path is neither a file nor directory: ${t}`);return JSON.stringify({symbol:e,found:s.length,locations:s},null,2)}var bv,en,xi=h(()=>{"use strict";c();lg();he();k();bv=[".js",".jsx",".ts",".tsx",".mjs",".cjs",".py",".go",".rs",".java",".c",".cpp",".h",".hpp"];en={name:ng,displayName:rg,description:sg,parameters:ag,category:ig,execute:wv}});var _g,Rg,$g,Eg,Dg,Mg=h(()=>{"use strict";c();_g="coding.get_symbols",Rg="Get Symbols",$g="List all symbols (functions, classes, variables, etc.) in a JavaScript/TypeScript file",Eg="coding",Dg={type:"object",properties:{file:{type:"string",description:"Path to the file to analyze"},kind:{type:"string",description:"Optional: filter by symbol kind (function, class, variable, const, let, interface, type)"}},required:["file"]}});import{readFileSync as Tv}from"fs";async function xv(r){let e=r.file,t=r.kind;if(y(`[coding.get-symbols] execute file="${e}" kind=${t??"all"}`),!e)throw new Error("file is required");try{let o=Tv(e,"utf-8"),s=await F.getParser(e).getSymbols({filePath:e,content:o},t);return JSON.stringify({file:e,count:s.length,symbols:s},null,2)}catch(o){throw new Error(`Failed to parse file "${e}": ${o.message}`)}}var tn,vi=h(()=>{"use strict";c();Mg();he();k();tn={name:_g,displayName:Rg,description:$g,parameters:Dg,category:Eg,execute:xv}});var Og,Ag,Ng,Ig,Lg,jg=h(()=>{"use strict";c();Og="coding.get_imports",Ag="Get Imports",Ng="List all import statements in a JavaScript/TypeScript file",Ig="coding",Lg={type:"object",properties:{file:{type:"string",description:"Path to the file to analyze"}},required:["file"]}});import{readFileSync as vv}from"fs";async function Cv(r){let e=r.file;if(y(`[coding.get-imports] execute file="${e}"`),!e)throw new Error("file is required");try{let t=vv(e,"utf-8"),n=await F.getParser(e).getImports({filePath:e,content:t});return JSON.stringify({file:e,count:n.length,imports:n},null,2)}catch(t){throw new Error(`Failed to map explicit imports in file "${e}": ${t.message}`)}}var on,Ci=h(()=>{"use strict";c();jg();he();k();on={name:Og,displayName:Ag,description:Ng,parameters:Lg,category:Ig,execute:Cv}});var Fg,qg,Wg,Ug,Gg,Bg=h(()=>{"use strict";c();Fg="coding.find_references",qg="Find References",Wg="Find all references to a symbol across JavaScript/TypeScript files",Ug="coding",Gg={type:"object",properties:{symbol:{type:"string",description:"Name of the symbol to find references for"},path:{type:"string",description:"File or directory path to search in (searches recursively if directory)"},includeDeclaration:{type:"boolean",description:"Include the symbol declaration in results (default: false)"}},required:["symbol","path"]}});import{readFileSync as Sv,statSync as kv}from"fs";async function zg(r,e,t){try{let o=Sv(r,"utf-8");return await F.getParser(r).findReferences({filePath:r,content:o},e,t)}catch{return[]}}async function Pv(r,e,t){let o=[];await Mt.buildIndex(r);let n=await Mt.getDefinitionFiles(e,r);for(let s of n)if(s.startsWith(r)){let i=await zg(s,e,t);o.push(...i)}return o}async function _v(r){let e=r.symbol,t=r.path,o=r.includeDeclaration===!0;if(y(`[coding.find-references] execute symbol="${e}" path="${t}" includeDecl=${o}`),!e)throw new Error("symbol is required");if(!t)throw new Error("path is required");let n=kv(t),s;if(n.isDirectory())s=await Pv(t,e,o);else if(n.isFile())s=await zg(t,e,o);else throw new Error(`Path is neither a file nor directory: ${t}`);return JSON.stringify({symbol:e,found:s.length,references:s},null,2)}var nn,Si=h(()=>{"use strict";c();Bg();he();k();nn={name:Fg,displayName:qg,description:Wg,parameters:Gg,category:Ug,execute:_v}});var Hg,Kg,Jg,Vg,Qg,Xg=h(()=>{"use strict";c();Hg="coding.go_to_definition",Kg="Go To Definition",Jg="Jump to the definition of a symbol at a specific location in a file",Vg="coding",Qg={type:"object",properties:{file:{type:"string",description:"Path to the file containing the symbol reference"},line:{type:"integer",description:"Line number where the symbol is referenced (1-indexed)"},column:{type:"integer",description:"Column number where the symbol is referenced (0-indexed)"},searchPath:{type:"string",description:"Optional: directory to search for the definition (defaults to file directory)"}},required:["file","line","column"]}});import{readFileSync as Yg,statSync as Rv}from"fs";import{dirname as $v}from"path";async function Ev(r,e,t){try{let o=Yg(r,"utf-8");return await F.getParser(r).getSymbolAtPosition({filePath:r,content:o},e,t)}catch{return null}}async function Zg(r,e){try{let t=Yg(r,"utf-8");return await F.getParser(r).getDefinition({filePath:r,content:t},e)}catch{return null}}async function Dv(r,e){await Mt.buildIndex(r);let t=await Mt.getDefinitionFiles(e,r);for(let o of t)if(o.startsWith(r)){let n=await Zg(o,e);if(n)return n}return null}async function Mv(r){let e=r.file,t=r.line,o=r.column,n=r.searchPath;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("line is required");if(o===void 0)throw new Error("column is required");let s=await Ev(e,t,o);if(!s)return JSON.stringify({found:!1,message:`No symbol found at ${e}:${t}:${o}`},null,2);let i=await Zg(e,s);if(!i){let a=n||$v(e);Rv(a).isDirectory()&&(i=await Dv(a,s))}return JSON.stringify(i?{found:!0,symbol:s,definition:i}:{found:!1,symbol:s,message:`Definition not found for symbol "${s}"`},null,2)}var rn,ki=h(()=>{"use strict";c();Xg();he();rn={name:Hg,displayName:Kg,description:Jg,parameters:Qg,category:Vg,execute:Mv}});var eh,th,oh,nh,rh,sh=h(()=>{"use strict";c();eh="coding.multi_file_edit",th="Multi-File Edit",oh="Edit multiple files atomically with rollback on failure",nh="coding",rh={type:"object",properties:{edits:{type:"array",items:{type:"object",properties:{file:{type:"string"},changes:{type:"array",items:{type:"object",properties:{oldText:{type:"string"},newText:{type:"string"}}}}}},description:"Array of file edits, each with file path and array of text replacements"},atomic:{type:"boolean",description:"Atomic mode: rollback all edits if any fails (default: true)"}},required:["edits"]}});import{readFileSync as Ov,writeFileSync as ih,existsSync as Av}from"fs";async function Nv(r){let e=r.edits,t=r.atomic!==!1;if(!e||!Array.isArray(e)||e.length===0)throw new Error("edits array is required and must not be empty");for(let s of e){if(!s.file)throw new Error("Each edit must have a file property");if(!s.changes||!Array.isArray(s.changes))throw new Error("Each edit must have a changes array");if(!Av(s.file))throw new Error(`File does not exist: ${s.file}`)}let o=[],n=[];try{for(let s of e){let i=Ov(s.file,"utf-8");t&&o.push({file:s.file,content:i});let a=i;for(let l of s.changes){if(!l.oldText)throw new Error("Each change must have oldText property");if(l.newText===void 0)throw new Error("Each change must have newText property");let p=(a.match(new RegExp(Iv(l.oldText),"g"))||[]).length;if(p===0)throw new Error(`Text not found in ${s.file}: "${l.oldText.substring(0,50)}..."`);if(p>1)throw new Error(`Ambiguous replacement in ${s.file}: "${l.oldText.substring(0,50)}..." appears ${p} times`);a=a.replace(l.oldText,l.newText)}ih(s.file,a,"utf-8"),n.push(s.file)}return JSON.stringify({success:!0,filesModified:n.length,files:n},null,2)}catch(s){if(t&&o.length>0){for(let i of o)try{ih(i.file,i.content,"utf-8")}catch{}throw new Error(`Multi-file edit failed and rolled back: ${s.message}`)}throw new Error(`Multi-file edit failed: ${s.message}`)}}function Iv(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var sn,Pi=h(()=>{"use strict";c();sh();sn={name:eh,displayName:th,description:oh,parameters:rh,category:nh,execute:Nv,confirmation:{level:"high",reason:"This will modify multiple source code files atomically.",showArgs:["edits"]}}});var ah,lh,ch,ph,mh,dh=h(()=>{"use strict";c();ah="coding.refactor_rename",lh="Refactor Rename",ch="Rename a symbol across the entire codebase intelligently",ph="coding",mh={type:"object",properties:{symbol:{type:"string",description:"Current name of the symbol to rename"},newName:{type:"string",description:"New name for the symbol"},path:{type:"string",description:"Directory path to search and rename in"},dryRun:{type:"boolean",description:"Preview changes without applying them (default: false)"}},required:["symbol","newName","path"]}});import{readFileSync as Lv,writeFileSync as jv,readdirSync as Fv}from"fs";import{join as qv,extname as Wv}from"path";import{parse as Uv}from"@babel/parser";import*as _i from"@babel/traverse";function zv(r,e,t,o){let n=[];try{let s=Lv(r,"utf-8"),i=s.split(`
|
|
294
|
-
`),a=
|
|
295
|
-
`),"utf-8")}}catch{}return{file:r,occurrences:n.length,changes:n}}function uh(r,e,t,o){let n=[];try{let s=Fv(r,{withFileTypes:!0});for(let i of s){let a=qv(r,i.name);if(!(i.name==="node_modules"||i.name===".git"||i.name==="dist")){if(i.isDirectory())n.push(...uh(a,e,t,o));else if(i.isFile()&&Bv.includes(Wv(i.name))){let l=zv(a,e,t,o);l.occurrences>0&&n.push(l)}}}}catch{}return n}async function Hv(r){let e=r.symbol,t=r.newName,o=r.path,n=r.dryRun===!0;if(!e)throw new Error("symbol is required");if(!t)throw new Error("newName is required");if(!o)throw new Error("path is required");if(e===t)throw new Error("New name must be different from old name");let s=uh(o,e,t,n),i=s.reduce((l,p)=>l+p.occurrences,0),a=s.length;return JSON.stringify({success:!0,dryRun:n,oldName:e,newName:t,filesAffected:a,totalOccurrences:i,changes:s},null,2)}var Gv,Bv,an,Ri=h(()=>{"use strict";c();dh();Gv=_i.default||_i,Bv=[".js",".jsx",".ts",".tsx",".mjs",".cjs"];an={name:ah,displayName:lh,description:ch,parameters:mh,category:ph,execute:Hv,confirmation:{level:"high",reason:"This will rename a symbol across multiple files, rewriting source code without backup.",showArgs:["symbol","newName"]}}});var fh,gh,hh,yh,bh,wh=h(()=>{"use strict";c();fh="coding.get_outline",gh="Get File Outline",hh="Gets a hierarchical outline of symbols (classes, functions, methods) in a specified file.",yh="coding",bh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file to outline"}},required:["file"]}});import{readFileSync as Kv,statSync as Jv}from"fs";async function Vv(r){let e=r.file;if(y(`[coding.get-outline] execute file="${e}"`),!e)throw new Error("file is required");try{if(!Jv(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=Kv(e,"utf-8"),o=F.getParser(e);if(!o.getOutline)return JSON.stringify({file:e,error:"Outline extraction is not specifically implemented for this language yet."});let n=await o.getOutline({filePath:e,content:t});return JSON.stringify({file:e,outline:n},null,2)}catch(t){throw new Error(`Failed to safely extract outline from file "${e}": ${t.message}`)}}var ln,$i=h(()=>{"use strict";c();wh();he();k();ln={name:fh,displayName:gh,description:hh,parameters:bh,category:yh,execute:Vv}});var Th,xh,vh,Ch,Sh,kh=h(()=>{"use strict";c();Th="coding.get_diagnostics",xh="Get File Diagnostics",vh="Gets syntax errors and warnings for a file utilizing AST parsing.",Ch="coding",Sh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file to check for diagnostics"}},required:["file"]}});import{readFileSync as Qv,statSync as Xv}from"fs";async function Yv(r){let e=r.file;if(!e)throw new Error("file is required");try{if(!Xv(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=Qv(e,"utf-8"),o=F.getParser(e);if(!o.getDiagnostics)return JSON.stringify({file:e,error:"Diagnostics extraction is not specifically implemented for this language yet."});let n=await o.getDiagnostics({filePath:e,content:t});return JSON.stringify({file:e,diagnostics:n},null,2)}catch(t){throw new Error(`Failed to get diagnostics from file "${e}": ${t.message}`)}}var cn,Ei=h(()=>{"use strict";c();kh();he();cn={name:Th,displayName:xh,description:vh,parameters:Sh,category:Ch,execute:Yv}});var Ph,_h,Rh,$h,Eh,Dh=h(()=>{"use strict";c();Ph="coding.get_exports",_h="Get File Exports",Rh="Lists all symbols exported by a file.",$h="coding",Eh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file"}},required:["file"]}});import{readFileSync as Zv,statSync as eC}from"fs";async function tC(r){let e=r.file;if(y(`[coding.get-exports] execute file="${e}"`),!e)throw new Error("file is required");try{if(!eC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=Zv(e,"utf-8"),o=F.getParser(e);if(!o.getExports)return JSON.stringify({file:e,error:"Exports extraction is not specifically implemented for this language yet."});let n=await o.getExports({filePath:e,content:t});return JSON.stringify({file:e,exports:n},null,2)}catch(t){throw new Error(`Failed to extract exports from file "${e}": ${t.message}`)}}var pn,Di=h(()=>{"use strict";c();Dh();he();k();pn={name:Ph,displayName:_h,description:Rh,parameters:Eh,category:$h,execute:tC}});var Mh,Oh,Ah,Nh,Ih,Lh=h(()=>{"use strict";c();Mh="coding.extract_function",Oh="Extract Function",Ah="Extracts a selected code region into a new function, automatically detecting required parameters and return values.",Nh="coding",Ih={type:"object",properties:{file:{type:"string",description:"The absolute path to the file"},startLine:{type:"number",description:"1-indexed start line of the code to extract"},startColumn:{type:"number",description:"0-indexed start column of the code to extract"},endLine:{type:"number",description:"1-indexed end line of the code to extract"},endColumn:{type:"number",description:"0-indexed end column of the code to extract"},newFunctionName:{type:"string",description:"The name for the newly extracted function"}},required:["file","startLine","startColumn","endLine","endColumn","newFunctionName"]}});import{readFileSync as oC,statSync as nC}from"fs";async function rC(r){let e=r.file,t=r.startLine,o=r.startColumn,n=r.endLine,s=r.endColumn,i=r.newFunctionName;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("startLine is required");if(o===void 0)throw new Error("startColumn is required");if(n===void 0)throw new Error("endLine is required");if(s===void 0)throw new Error("endColumn is required");if(!i)throw new Error("newFunctionName is required");try{if(!nC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let a=oC(e,"utf-8"),l=F.getParser(e);if(!l.extractFunction)return JSON.stringify({file:e,error:"Function extraction is not specifically implemented for this language yet."});let p=await l.extractFunction({filePath:e,content:a},t,o,n,s,i);return JSON.stringify({file:e,result:p},null,2)}catch(a){throw new Error(`Failed to extract function from file "${e}": ${a.message}`)}}var mn,Mi=h(()=>{"use strict";c();Lh();he();mn={name:Mh,displayName:Oh,description:Ah,parameters:Ih,category:Nh,execute:rC}});var jh,Fh,qh,Wh,Uh,Gh=h(()=>{"use strict";c();jh="coding.get_call_hierarchy",Fh="Get Call Hierarchy",qh="Shows callers and callees of a specific function or method.",Wh="coding",Uh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file containing the function"},line:{type:"number",description:"1-indexed line number where the function is defined or called"},column:{type:"number",description:"0-indexed column number where the function is defined or called"}},required:["file","line","column"]}});import{readFileSync as sC,statSync as iC}from"fs";async function aC(r){let e=r.file,t=r.line,o=r.column;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("line is required");if(o===void 0)throw new Error("column is required");try{if(!iC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let n=sC(e,"utf-8"),s=F.getParser(e);if(!s.getCallHierarchy)return JSON.stringify({file:e,error:"Call hierarchy is not specifically implemented for this language yet."});let i=await s.getCallHierarchy({filePath:e,content:n},t,o);return JSON.stringify({file:e,hierarchy:i},null,2)}catch(n){throw new Error(`Failed to get call hierarchy from file "${e}": ${n.message}`)}}var dn,Oi=h(()=>{"use strict";c();Gh();he();dn={name:jh,displayName:Fh,description:qh,parameters:Uh,category:Wh,execute:aC}});var zh={};ee(zh,{codingExtractFunctionTool:()=>mn,codingFindReferencesTool:()=>nn,codingFindSymbolTool:()=>en,codingGetCallHierarchyTool:()=>dn,codingGetDiagnosticsTool:()=>cn,codingGetExportsTool:()=>pn,codingGetImportsTool:()=>on,codingGetOutlineTool:()=>ln,codingGetSymbolsTool:()=>tn,codingGoToDefinitionTool:()=>rn,codingMultiFileEditTool:()=>sn,codingRefactorRenameTool:()=>an,codingToolsProject:()=>Bh});var Bh,Ai=h(()=>{"use strict";c();xi();vi();Ci();Si();ki();Pi();Ri();$i();Ei();Di();Mi();Oi();xi();vi();Ci();Si();ki();Pi();Ri();$i();Ei();Di();Mi();Oi();Bh={manifest:{key:"coding",name:"coding-tools",displayName:"Code Intelligence",version:"1.0.0",description:"AST-aware code intelligence tools for finding symbols, references, and analyzing code structure.",author:"Sajeer",tools:["coding.find_symbol","coding.get_symbols","coding.get_imports","coding.find_references","coding.go_to_definition","coding.get_outline","coding.get_diagnostics","coding.get_exports","coding.extract_function","coding.get_call_hierarchy","coding.multi_file_edit","coding.refactor_rename"],category:"coding"},tools:[en,tn,on,nn,rn,ln,cn,pn,mn,dn,sn,an],dependencies:{"@babel/parser":"^7.24.0","@babel/traverse":"^7.24.0","@babel/types":"^7.24.0"}}});var Hh,Kh=h(()=>{"use strict";c();Hh={type:"object",properties:{path:{type:"string",description:"Optional path or directory to check the status for. If omitted, checks the entire repository."}}}});import{simpleGit as lC}from"simple-git";function G(r){let e={baseDir:r||process.cwd(),binary:"git",maxConcurrentProcesses:6};return lC(e)}var ke=h(()=>{"use strict";c()});var Jn,Jh=h(()=>{"use strict";c();Kh();ke();Jn={name:"git.status",displayName:"Git Status",description:"Get the working tree status, including modified, staged, and untracked files.",category:"version-control",parameters:Hh,execute:async r=>{let e=r.path;try{let o=await G().status(e?[e]:[]);if(o.isClean())return"Working tree clean";let n=[];return n.push(`Branch: ${o.current}`),o.tracking&&n.push(`Tracking: ${o.tracking}`),o.ahead>0&&n.push(`Ahead: ${o.ahead}`),o.behind>0&&n.push(`Behind: ${o.behind}`),n.push("---"),o.conflicted.length>0&&n.push(`Conflicted: ${o.conflicted.join(", ")}`),o.created.length>0&&n.push(`Created: ${o.created.join(", ")}`),o.deleted.length>0&&n.push(`Deleted: ${o.deleted.join(", ")}`),o.modified.length>0&&n.push(`Modified: ${o.modified.join(", ")}`),o.renamed.length>0&&n.push(`Renamed: ${o.renamed.map(s=>`${s.from} -> ${s.to}`).join(", ")}`),o.staged.length>0&&n.push(`Staged: ${o.staged.join(", ")}`),o.not_added.length>0&&n.push(`Untracked: ${o.not_added.join(", ")}`),n.join(`
|
|
296
|
-
`)}catch(t){return`Error getting git status: ${t instanceof Error?t.message:String(t)}`}}}});var
|
|
293
|
+
`,g=`${i}();`),{newFunction:d,replacementCall:g}}async getCallHierarchy(e,t,o){let n=await this.getSymbolAtPosition(e,t,o);if(!n)return null;let i=(await this.findReferences(e,n,!1)).map(a=>({file:a.file,name:a.context.trim()||"<anonymous>",line:a.line,column:a.column}));return{file:e.filePath,name:n,line:t,column:o,callers:i,callees:[]}}}});var Kn,Sg=h(()=>{"use strict";c();bi();hg();Cg();Kn=class{constructor(e){this.context=e;this.babelParser=new zn,this.treeSitterParser=new Hn(this.context)}context;babelParser;treeSitterParser;getParser(e){switch(Un(e)){case"javascript":case"typescript":case"tsx":case"jsx":return this.babelParser;case"python":case"go":case"rust":case"java":case"c":case"cpp":return this.treeSitterParser;default:throw new Error(`Unsupported or unknown language for file: ${e}`)}}}});import{readFileSync as lv,statSync as cv,readdirSync as pv}from"fs";import{join as mv,extname as dv}from"path";var Jn,kg=h(()=>{"use strict";c();he();Jn=class{isBuilt=!1;isBuilding=!1;data={symbolLocations:new Map};fileMtimes=new Map;supportedExtensions=[".js",".jsx",".ts",".tsx",".mjs",".cjs",".py",".go",".rs",".java",".c",".cpp",".h",".hpp"];async getAllSupportedFiles(e){let t=[];try{let o=pv(e,{withFileTypes:!0});for(let n of o){let s=mv(e,n.name);n.name==="node_modules"||n.name===".git"||n.name==="dist"||n.name==="build"||(n.isDirectory()?t.push(...await this.getAllSupportedFiles(s)):n.isFile()&&this.supportedExtensions.includes(dv(n.name).toLowerCase())&&t.push(s))}}catch{}return t}async buildIndex(e){if(!(this.isBuilt||this.isBuilding)){this.isBuilding=!0;try{let t=await this.getAllSupportedFiles(e);for(let o of t)await this.updateFile(o);this.isBuilt=!0}finally{this.isBuilding=!1}}}async updateFile(e){try{let o=cv(e).mtimeMs;if(this.fileMtimes.get(e)===o)return;let n=lv(e,"utf-8"),s=q.getParser(e);this.removeFileFromIndex(e);let i=await s.getSymbols({filePath:e,content:n});for(let a of i){let l=this.data.symbolLocations.get(a.name);l?l.add(e):this.data.symbolLocations.set(a.name,new Set([e]))}this.fileMtimes.set(e,o)}catch{this.removeFileFromIndex(e)}}removeFileFromIndex(e){for(let[t,o]of this.data.symbolLocations.entries())o.delete(e),o.size===0&&this.data.symbolLocations.delete(t);this.fileMtimes.delete(e)}async getDefinitionFiles(e,t){await this.buildIndex(t);let o=this.data.symbolLocations.get(e);return o?Array.from(o):[]}}});var uv,q,At,he=h(()=>{"use strict";c();gg();Sg();kg();uv=new Bn,q=new Kn(uv),At=new Jn});import{readFileSync as fv,statSync as gv,readdirSync as hv}from"fs";import{join as yv,extname as bv}from"path";async function Pg(r,e,t){try{let o=fv(r,"utf-8");return await q.getParser(r).findSymbols({filePath:r,content:o},e,t)}catch{return[]}}async function Rg(r,e,t){let o=[];try{let n=hv(r,{withFileTypes:!0});for(let s of n){let i=yv(r,s.name);if(!(s.name==="node_modules"||s.name===".git"||s.name==="dist")){if(s.isDirectory()){let a=await Rg(i,e,t);o.push(...a)}else if(s.isFile()&&wv.includes(bv(s.name))){let a=await Pg(i,e,t);o.push(...a)}}}}catch{}return o}async function Tv(r){let e=r.symbol,t=r.path,o=r.kind;if(y(`[coding.find-symbol] execute symbol="${e}" path="${t}" kind=${o??"all"}`),!e)throw new Error("symbol is required");if(!t)throw new Error("path is required");let n=gv(t),s;if(n.isDirectory())s=await Rg(t,e,o);else if(n.isFile())s=await Pg(t,e,o);else throw new Error(`Path is neither a file nor directory: ${t}`);return JSON.stringify({symbol:e,found:s.length,locations:s},null,2)}var wv,tn,vi=h(()=>{"use strict";c();cg();he();S();wv=[".js",".jsx",".ts",".tsx",".mjs",".cjs",".py",".go",".rs",".java",".c",".cpp",".h",".hpp"];tn={name:rg,displayName:sg,description:ig,parameters:lg,category:ag,execute:Tv}});var _g,$g,Eg,Dg,Mg,Ag=h(()=>{"use strict";c();_g="coding.get_symbols",$g="Get Symbols",Eg="List all symbols (functions, classes, variables, etc.) in a JavaScript/TypeScript file",Dg="coding",Mg={type:"object",properties:{file:{type:"string",description:"Path to the file to analyze"},kind:{type:"string",description:"Optional: filter by symbol kind (function, class, variable, const, let, interface, type)"}},required:["file"]}});import{readFileSync as xv}from"fs";async function vv(r){let e=r.file,t=r.kind;if(y(`[coding.get-symbols] execute file="${e}" kind=${t??"all"}`),!e)throw new Error("file is required");try{let o=xv(e,"utf-8"),s=await q.getParser(e).getSymbols({filePath:e,content:o},t);return JSON.stringify({file:e,count:s.length,symbols:s},null,2)}catch(o){throw new Error(`Failed to parse file "${e}": ${o.message}`)}}var on,Ci=h(()=>{"use strict";c();Ag();he();S();on={name:_g,displayName:$g,description:Eg,parameters:Mg,category:Dg,execute:vv}});var Og,Ng,Ig,jg,Lg,Fg=h(()=>{"use strict";c();Og="coding.get_imports",Ng="Get Imports",Ig="List all import statements in a JavaScript/TypeScript file",jg="coding",Lg={type:"object",properties:{file:{type:"string",description:"Path to the file to analyze"}},required:["file"]}});import{readFileSync as Cv}from"fs";async function Sv(r){let e=r.file;if(y(`[coding.get-imports] execute file="${e}"`),!e)throw new Error("file is required");try{let t=Cv(e,"utf-8"),n=await q.getParser(e).getImports({filePath:e,content:t});return JSON.stringify({file:e,count:n.length,imports:n},null,2)}catch(t){throw new Error(`Failed to map explicit imports in file "${e}": ${t.message}`)}}var nn,Si=h(()=>{"use strict";c();Fg();he();S();nn={name:Og,displayName:Ng,description:Ig,parameters:Lg,category:jg,execute:Sv}});var qg,Wg,Ug,Gg,Bg,zg=h(()=>{"use strict";c();qg="coding.find_references",Wg="Find References",Ug="Find all references to a symbol across JavaScript/TypeScript files",Gg="coding",Bg={type:"object",properties:{symbol:{type:"string",description:"Name of the symbol to find references for"},path:{type:"string",description:"File or directory path to search in (searches recursively if directory)"},includeDeclaration:{type:"boolean",description:"Include the symbol declaration in results (default: false)"}},required:["symbol","path"]}});import{readFileSync as kv,statSync as Pv}from"fs";async function Hg(r,e,t){try{let o=kv(r,"utf-8");return await q.getParser(r).findReferences({filePath:r,content:o},e,t)}catch{return[]}}async function Rv(r,e,t){let o=[];await At.buildIndex(r);let n=await At.getDefinitionFiles(e,r);for(let s of n)if(s.startsWith(r)){let i=await Hg(s,e,t);o.push(...i)}return o}async function _v(r){let e=r.symbol,t=r.path,o=r.includeDeclaration===!0;if(y(`[coding.find-references] execute symbol="${e}" path="${t}" includeDecl=${o}`),!e)throw new Error("symbol is required");if(!t)throw new Error("path is required");let n=Pv(t),s;if(n.isDirectory())s=await Rv(t,e,o);else if(n.isFile())s=await Hg(t,e,o);else throw new Error(`Path is neither a file nor directory: ${t}`);return JSON.stringify({symbol:e,found:s.length,references:s},null,2)}var rn,ki=h(()=>{"use strict";c();zg();he();S();rn={name:qg,displayName:Wg,description:Ug,parameters:Bg,category:Gg,execute:_v}});var Kg,Jg,Vg,Qg,Xg,Yg=h(()=>{"use strict";c();Kg="coding.go_to_definition",Jg="Go To Definition",Vg="Jump to the definition of a symbol at a specific location in a file",Qg="coding",Xg={type:"object",properties:{file:{type:"string",description:"Path to the file containing the symbol reference"},line:{type:"integer",description:"Line number where the symbol is referenced (1-indexed)"},column:{type:"integer",description:"Column number where the symbol is referenced (0-indexed)"},searchPath:{type:"string",description:"Optional: directory to search for the definition (defaults to file directory)"}},required:["file","line","column"]}});import{readFileSync as Zg,statSync as $v}from"fs";import{dirname as Ev}from"path";async function Dv(r,e,t){try{let o=Zg(r,"utf-8");return await q.getParser(r).getSymbolAtPosition({filePath:r,content:o},e,t)}catch{return null}}async function eh(r,e){try{let t=Zg(r,"utf-8");return await q.getParser(r).getDefinition({filePath:r,content:t},e)}catch{return null}}async function Mv(r,e){await At.buildIndex(r);let t=await At.getDefinitionFiles(e,r);for(let o of t)if(o.startsWith(r)){let n=await eh(o,e);if(n)return n}return null}async function Av(r){let e=r.file,t=r.line,o=r.column,n=r.searchPath;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("line is required");if(o===void 0)throw new Error("column is required");let s=await Dv(e,t,o);if(!s)return JSON.stringify({found:!1,message:`No symbol found at ${e}:${t}:${o}`},null,2);let i=await eh(e,s);if(!i){let a=n||Ev(e);$v(a).isDirectory()&&(i=await Mv(a,s))}return JSON.stringify(i?{found:!0,symbol:s,definition:i}:{found:!1,symbol:s,message:`Definition not found for symbol "${s}"`},null,2)}var sn,Pi=h(()=>{"use strict";c();Yg();he();sn={name:Kg,displayName:Jg,description:Vg,parameters:Xg,category:Qg,execute:Av}});var th,oh,nh,rh,sh,ih=h(()=>{"use strict";c();th="coding.multi_file_edit",oh="Multi-File Edit",nh="Edit multiple files atomically with rollback on failure",rh="coding",sh={type:"object",properties:{edits:{type:"array",items:{type:"object",properties:{file:{type:"string"},changes:{type:"array",items:{type:"object",properties:{oldText:{type:"string"},newText:{type:"string"}}}}}},description:"Array of file edits, each with file path and array of text replacements"},atomic:{type:"boolean",description:"Atomic mode: rollback all edits if any fails (default: true)"}},required:["edits"]}});import{readFileSync as Ov,writeFileSync as ah,existsSync as Nv}from"fs";async function Iv(r){let e=r.edits,t=r.atomic!==!1;if(!e||!Array.isArray(e)||e.length===0)throw new Error("edits array is required and must not be empty");for(let s of e){if(!s.file)throw new Error("Each edit must have a file property");if(!s.changes||!Array.isArray(s.changes))throw new Error("Each edit must have a changes array");if(!Nv(s.file))throw new Error(`File does not exist: ${s.file}`)}let o=[],n=[];try{for(let s of e){let i=Ov(s.file,"utf-8");t&&o.push({file:s.file,content:i});let a=i;for(let l of s.changes){if(!l.oldText)throw new Error("Each change must have oldText property");if(l.newText===void 0)throw new Error("Each change must have newText property");let p=(a.match(new RegExp(jv(l.oldText),"g"))||[]).length;if(p===0)throw new Error(`Text not found in ${s.file}: "${l.oldText.substring(0,50)}..."`);if(p>1)throw new Error(`Ambiguous replacement in ${s.file}: "${l.oldText.substring(0,50)}..." appears ${p} times`);a=a.replace(l.oldText,l.newText)}ah(s.file,a,"utf-8"),n.push(s.file)}return JSON.stringify({success:!0,filesModified:n.length,files:n},null,2)}catch(s){if(t&&o.length>0){for(let i of o)try{ah(i.file,i.content,"utf-8")}catch{}throw new Error(`Multi-file edit failed and rolled back: ${s.message}`)}throw new Error(`Multi-file edit failed: ${s.message}`)}}function jv(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var an,Ri=h(()=>{"use strict";c();ih();an={name:th,displayName:oh,description:nh,parameters:sh,category:rh,execute:Iv,confirmation:{level:"high",reason:"This will modify multiple source code files atomically.",showArgs:["edits"]}}});var lh,ch,ph,mh,dh,uh=h(()=>{"use strict";c();lh="coding.refactor_rename",ch="Refactor Rename",ph="Rename a symbol across the entire codebase intelligently",mh="coding",dh={type:"object",properties:{symbol:{type:"string",description:"Current name of the symbol to rename"},newName:{type:"string",description:"New name for the symbol"},path:{type:"string",description:"Directory path to search and rename in"},dryRun:{type:"boolean",description:"Preview changes without applying them (default: false)"}},required:["symbol","newName","path"]}});import{readFileSync as Lv,writeFileSync as Fv,readdirSync as qv}from"fs";import{join as Wv,extname as Uv}from"path";import{parse as Gv}from"@babel/parser";import*as _i from"@babel/traverse";function Hv(r,e,t,o){let n=[];try{let s=Lv(r,"utf-8"),i=s.split(`
|
|
294
|
+
`),a=Gv(s,{sourceType:"module",plugins:["jsx","typescript","decorators-legacy","classProperties","objectRestSpread","optionalChaining","nullishCoalescingOperator"]}),l=[];if(Bv(a,{Identifier(p){if(p.node.name===e){let m=p.node.loc?.start.line||0,d=p.node.loc?.start.column||0;l.push({line:m,column:d,length:e.length}),n.push({file:r,line:m,column:d,oldName:e,newName:t})}}}),!o&&l.length>0){l.sort((m,d)=>m.line!==d.line?d.line-m.line:d.column-m.column);let p=[...i];for(let m of l){let d=m.line-1;if(d>=0&&d<p.length){let g=p[d],b=g.substring(0,m.column),w=g.substring(m.column+m.length);p[d]=b+t+w}}Fv(r,p.join(`
|
|
295
|
+
`),"utf-8")}}catch{}return{file:r,occurrences:n.length,changes:n}}function fh(r,e,t,o){let n=[];try{let s=qv(r,{withFileTypes:!0});for(let i of s){let a=Wv(r,i.name);if(!(i.name==="node_modules"||i.name===".git"||i.name==="dist")){if(i.isDirectory())n.push(...fh(a,e,t,o));else if(i.isFile()&&zv.includes(Uv(i.name))){let l=Hv(a,e,t,o);l.occurrences>0&&n.push(l)}}}}catch{}return n}async function Kv(r){let e=r.symbol,t=r.newName,o=r.path,n=r.dryRun===!0;if(!e)throw new Error("symbol is required");if(!t)throw new Error("newName is required");if(!o)throw new Error("path is required");if(e===t)throw new Error("New name must be different from old name");let s=fh(o,e,t,n),i=s.reduce((l,p)=>l+p.occurrences,0),a=s.length;return JSON.stringify({success:!0,dryRun:n,oldName:e,newName:t,filesAffected:a,totalOccurrences:i,changes:s},null,2)}var Bv,zv,ln,$i=h(()=>{"use strict";c();uh();Bv=_i.default||_i,zv=[".js",".jsx",".ts",".tsx",".mjs",".cjs"];ln={name:lh,displayName:ch,description:ph,parameters:dh,category:mh,execute:Kv,confirmation:{level:"high",reason:"This will rename a symbol across multiple files, rewriting source code without backup.",showArgs:["symbol","newName"]}}});var gh,hh,yh,bh,wh,Th=h(()=>{"use strict";c();gh="coding.get_outline",hh="Get File Outline",yh="Gets a hierarchical outline of symbols (classes, functions, methods) in a specified file.",bh="coding",wh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file to outline"}},required:["file"]}});import{readFileSync as Jv,statSync as Vv}from"fs";async function Qv(r){let e=r.file;if(y(`[coding.get-outline] execute file="${e}"`),!e)throw new Error("file is required");try{if(!Vv(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=Jv(e,"utf-8"),o=q.getParser(e);if(!o.getOutline)return JSON.stringify({file:e,error:"Outline extraction is not specifically implemented for this language yet."});let n=await o.getOutline({filePath:e,content:t});return JSON.stringify({file:e,outline:n},null,2)}catch(t){throw new Error(`Failed to safely extract outline from file "${e}": ${t.message}`)}}var cn,Ei=h(()=>{"use strict";c();Th();he();S();cn={name:gh,displayName:hh,description:yh,parameters:wh,category:bh,execute:Qv}});var xh,vh,Ch,Sh,kh,Ph=h(()=>{"use strict";c();xh="coding.get_diagnostics",vh="Get File Diagnostics",Ch="Gets syntax errors and warnings for a file utilizing AST parsing.",Sh="coding",kh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file to check for diagnostics"}},required:["file"]}});import{readFileSync as Xv,statSync as Yv}from"fs";async function Zv(r){let e=r.file;if(!e)throw new Error("file is required");try{if(!Yv(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=Xv(e,"utf-8"),o=q.getParser(e);if(!o.getDiagnostics)return JSON.stringify({file:e,error:"Diagnostics extraction is not specifically implemented for this language yet."});let n=await o.getDiagnostics({filePath:e,content:t});return JSON.stringify({file:e,diagnostics:n},null,2)}catch(t){throw new Error(`Failed to get diagnostics from file "${e}": ${t.message}`)}}var pn,Di=h(()=>{"use strict";c();Ph();he();pn={name:xh,displayName:vh,description:Ch,parameters:kh,category:Sh,execute:Zv}});var Rh,_h,$h,Eh,Dh,Mh=h(()=>{"use strict";c();Rh="coding.get_exports",_h="Get File Exports",$h="Lists all symbols exported by a file.",Eh="coding",Dh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file"}},required:["file"]}});import{readFileSync as eC,statSync as tC}from"fs";async function oC(r){let e=r.file;if(y(`[coding.get-exports] execute file="${e}"`),!e)throw new Error("file is required");try{if(!tC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let t=eC(e,"utf-8"),o=q.getParser(e);if(!o.getExports)return JSON.stringify({file:e,error:"Exports extraction is not specifically implemented for this language yet."});let n=await o.getExports({filePath:e,content:t});return JSON.stringify({file:e,exports:n},null,2)}catch(t){throw new Error(`Failed to extract exports from file "${e}": ${t.message}`)}}var mn,Mi=h(()=>{"use strict";c();Mh();he();S();mn={name:Rh,displayName:_h,description:$h,parameters:Dh,category:Eh,execute:oC}});var Ah,Oh,Nh,Ih,jh,Lh=h(()=>{"use strict";c();Ah="coding.extract_function",Oh="Extract Function",Nh="Extracts a selected code region into a new function, automatically detecting required parameters and return values.",Ih="coding",jh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file"},startLine:{type:"number",description:"1-indexed start line of the code to extract"},startColumn:{type:"number",description:"0-indexed start column of the code to extract"},endLine:{type:"number",description:"1-indexed end line of the code to extract"},endColumn:{type:"number",description:"0-indexed end column of the code to extract"},newFunctionName:{type:"string",description:"The name for the newly extracted function"}},required:["file","startLine","startColumn","endLine","endColumn","newFunctionName"]}});import{readFileSync as nC,statSync as rC}from"fs";async function sC(r){let e=r.file,t=r.startLine,o=r.startColumn,n=r.endLine,s=r.endColumn,i=r.newFunctionName;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("startLine is required");if(o===void 0)throw new Error("startColumn is required");if(n===void 0)throw new Error("endLine is required");if(s===void 0)throw new Error("endColumn is required");if(!i)throw new Error("newFunctionName is required");try{if(!rC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let a=nC(e,"utf-8"),l=q.getParser(e);if(!l.extractFunction)return JSON.stringify({file:e,error:"Function extraction is not specifically implemented for this language yet."});let p=await l.extractFunction({filePath:e,content:a},t,o,n,s,i);return JSON.stringify({file:e,result:p},null,2)}catch(a){throw new Error(`Failed to extract function from file "${e}": ${a.message}`)}}var dn,Ai=h(()=>{"use strict";c();Lh();he();dn={name:Ah,displayName:Oh,description:Nh,parameters:jh,category:Ih,execute:sC}});var Fh,qh,Wh,Uh,Gh,Bh=h(()=>{"use strict";c();Fh="coding.get_call_hierarchy",qh="Get Call Hierarchy",Wh="Shows callers and callees of a specific function or method.",Uh="coding",Gh={type:"object",properties:{file:{type:"string",description:"The absolute path to the file containing the function"},line:{type:"number",description:"1-indexed line number where the function is defined or called"},column:{type:"number",description:"0-indexed column number where the function is defined or called"}},required:["file","line","column"]}});import{readFileSync as iC,statSync as aC}from"fs";async function lC(r){let e=r.file,t=r.line,o=r.column;if(!e)throw new Error("file is required");if(t===void 0)throw new Error("line is required");if(o===void 0)throw new Error("column is required");try{if(!aC(e).isFile())throw new Error(`Path is not a file: ${e}`)}catch{throw new Error(`File not found: ${e}`)}try{let n=iC(e,"utf-8"),s=q.getParser(e);if(!s.getCallHierarchy)return JSON.stringify({file:e,error:"Call hierarchy is not specifically implemented for this language yet."});let i=await s.getCallHierarchy({filePath:e,content:n},t,o);return JSON.stringify({file:e,hierarchy:i},null,2)}catch(n){throw new Error(`Failed to get call hierarchy from file "${e}": ${n.message}`)}}var un,Oi=h(()=>{"use strict";c();Bh();he();un={name:Fh,displayName:qh,description:Wh,parameters:Gh,category:Uh,execute:lC}});var Hh={};ee(Hh,{codingExtractFunctionTool:()=>dn,codingFindReferencesTool:()=>rn,codingFindSymbolTool:()=>tn,codingGetCallHierarchyTool:()=>un,codingGetDiagnosticsTool:()=>pn,codingGetExportsTool:()=>mn,codingGetImportsTool:()=>nn,codingGetOutlineTool:()=>cn,codingGetSymbolsTool:()=>on,codingGoToDefinitionTool:()=>sn,codingMultiFileEditTool:()=>an,codingRefactorRenameTool:()=>ln,codingToolsProject:()=>zh});var zh,Ni=h(()=>{"use strict";c();vi();Ci();Si();ki();Pi();Ri();$i();Ei();Di();Mi();Ai();Oi();vi();Ci();Si();ki();Pi();Ri();$i();Ei();Di();Mi();Ai();Oi();zh={manifest:{key:"coding",name:"coding-tools",displayName:"Code Intelligence",version:"1.0.0",description:"AST-aware code intelligence tools for finding symbols, references, and analyzing code structure.",author:"Sajeer",tools:["coding.find_symbol","coding.get_symbols","coding.get_imports","coding.find_references","coding.go_to_definition","coding.get_outline","coding.get_diagnostics","coding.get_exports","coding.extract_function","coding.get_call_hierarchy","coding.multi_file_edit","coding.refactor_rename"],category:"coding"},tools:[tn,on,nn,rn,sn,cn,pn,mn,dn,un,an,ln],dependencies:{"@babel/parser":"^7.24.0","@babel/traverse":"^7.24.0","@babel/types":"^7.24.0"}}});var Kh,Jh=h(()=>{"use strict";c();Kh={type:"object",properties:{path:{type:"string",description:"Optional path or directory to check the status for. If omitted, checks the entire repository."}}}});import{simpleGit as cC}from"simple-git";function G(r){let e={baseDir:r||process.cwd(),binary:"git",maxConcurrentProcesses:6};return cC(e)}var Pe=h(()=>{"use strict";c()});var Vn,Vh=h(()=>{"use strict";c();Jh();Pe();Vn={name:"git.status",displayName:"Git Status",description:"Get the working tree status, including modified, staged, and untracked files.",category:"version-control",parameters:Kh,execute:async r=>{let e=r.path;try{let o=await G().status(e?[e]:[]);if(o.isClean())return"Working tree clean";let n=[];return n.push(`Branch: ${o.current}`),o.tracking&&n.push(`Tracking: ${o.tracking}`),o.ahead>0&&n.push(`Ahead: ${o.ahead}`),o.behind>0&&n.push(`Behind: ${o.behind}`),n.push("---"),o.conflicted.length>0&&n.push(`Conflicted: ${o.conflicted.join(", ")}`),o.created.length>0&&n.push(`Created: ${o.created.join(", ")}`),o.deleted.length>0&&n.push(`Deleted: ${o.deleted.join(", ")}`),o.modified.length>0&&n.push(`Modified: ${o.modified.join(", ")}`),o.renamed.length>0&&n.push(`Renamed: ${o.renamed.map(s=>`${s.from} -> ${s.to}`).join(", ")}`),o.staged.length>0&&n.push(`Staged: ${o.staged.join(", ")}`),o.not_added.length>0&&n.push(`Untracked: ${o.not_added.join(", ")}`),n.join(`
|
|
296
|
+
`)}catch(t){return`Error getting git status: ${t instanceof Error?t.message:String(t)}`}}}});var Qh,Xh=h(()=>{"use strict";c();Qh={type:"object",properties:{path:{type:"string",description:"Optional path to get the diff for. If omitted, gets the diff for the entire repository."},base:{type:"string",description:"Optional base commit/ref for comparing two revisions. When used with head, runs git diff base...head."},head:{type:"string",description:"Optional head commit/ref for comparing two revisions. When used with base, runs git diff base...head."},staged:{type:"boolean",description:"If true, gets the diff of staged changes instead of unstaged changes.",default:!1},cloneDir:{type:"string",description:"Optional local repository directory, typically the cloneDir returned by git.clone. When provided, this tool runs in that repository instead of the current working directory."}}}});var Qn,Yh=h(()=>{"use strict";c();Xh();Pe();Qn={name:"git.diff",displayName:"Git Diff",description:"Show changes between commits, commit and working tree, etc.",category:"version-control",parameters:Qh,execute:async r=>{let e=r.path,t=r.base,o=r.head,n=r.staged,s=r.cloneDir;try{let i=G(s),a=[];if(t||o){if(!t||!o)return"Error getting git diff: both base and head are required when comparing revisions.";a.push(`${t}...${o}`)}n&&a.push("--cached"),e&&a.push("--",e);let l=await i.diff(a);return l||"No changes found."}catch(i){return`Error getting git diff: ${i instanceof Error?i.message:String(i)}`}}}});var Zh,ey=h(()=>{"use strict";c();Zh={type:"object",properties:{maxCount:{type:"number",description:"Maximum number of commits to return. Defaults to 10 to prevent large outputs.",default:10},path:{type:"string",description:"Optional path to get the log for specific file or directory."},cloneDir:{type:"string",description:"Optional local repository directory, typically the cloneDir returned by git.clone. When provided, this tool runs in that repository instead of the current working directory."}}}});var Xn,ty=h(()=>{"use strict";c();ey();Pe();Xn={name:"git.log",displayName:"Git Log",description:"Show commit logs.",category:"version-control",parameters:Zh,execute:async r=>{let e=r.maxCount||10,t=r.path,o=r.cloneDir;try{let n=G(o),s={maxCount:e};t&&(s.file=t);let i=await n.log(s);return i.all.length===0?"No commits found.":i.all.map(a=>`Commit: ${a.hash}
|
|
297
297
|
Author: ${a.author_name} <${a.author_email}>
|
|
298
298
|
Date: ${a.date}
|
|
299
299
|
Message: ${a.message}
|
|
300
300
|
`).join(`---
|
|
301
|
-
`)}catch(n){return`Error getting git log: ${n instanceof Error?n.message:String(n)}`}}}});var
|
|
301
|
+
`)}catch(n){return`Error getting git log: ${n instanceof Error?n.message:String(n)}`}}}});var oy,ny=h(()=>{"use strict";c();oy={type:"object",properties:{path:{type:"string",description:"Path to the file or directory to stage. To stage all changes, use '.'."}},required:["path"]}});var Yn,ry=h(()=>{"use strict";c();ny();Pe();Yn={name:"git.add",displayName:"Git Add",description:"Add file contents to the index (stage changes).",category:"version-control",parameters:oy,execute:async r=>{let e=r.path;try{return await G().add(e),`Successfully staged changes for: ${e}`}catch(t){return`Error staging changes: ${t instanceof Error?t.message:String(t)}`}}}});var sy,iy=h(()=>{"use strict";c();sy={type:"object",properties:{message:{type:"string",description:"The commit message."}},required:["message"]}});var Zn,ay=h(()=>{"use strict";c();iy();Pe();Zn={name:"git.commit",displayName:"Git Commit",description:"Record changes to the repository.",category:"version-control",parameters:sy,execute:async r=>{let e=r.message;try{let o=await G().commit(e);return o.commit?`Successfully committed changes.
|
|
302
302
|
Commit: ${o.commit}
|
|
303
303
|
Branch: ${o.branch}
|
|
304
|
-
Summary: ${o.summary.changes} changes, ${o.summary.insertions} insertions, ${o.summary.deletions} deletions.`:"Nothing to commit."}catch(t){return`Error committing changes: ${t instanceof Error?t.message:String(t)}`}},confirmation:{level:"medium",reason:"This will create a permanent commit in the repository history.",showArgs:["message"]}}});var
|
|
304
|
+
Summary: ${o.summary.changes} changes, ${o.summary.insertions} insertions, ${o.summary.deletions} deletions.`:"Nothing to commit."}catch(t){return`Error committing changes: ${t instanceof Error?t.message:String(t)}`}},confirmation:{level:"medium",reason:"This will create a permanent commit in the repository history.",showArgs:["message"]}}});var ly,cy=h(()=>{"use strict";c();ly={type:"object",properties:{path:{type:"string",description:"Path to the file to blame."},sha:{type:"string",description:"Optional commit SHA or ref to blame at. If omitted, blames the current checkout."},cloneDir:{type:"string",description:"Optional local repository directory, typically the cloneDir returned by git.clone. When provided, this tool runs in that repository instead of the current working directory."}},required:["path"]}});var er,py=h(()=>{"use strict";c();cy();Pe();er={name:"git.blame",displayName:"Git Blame",description:"Show what revision and author last modified each line of a file.",category:"version-control",parameters:ly,execute:async r=>{let e=r.path,t=r.sha,o=r.cloneDir;try{let n=G(o),s=["blame"];return t&&s.push(t),s.push("--",e),await n.raw(s)}catch(n){return`Error running git blame: ${n instanceof Error?n.message:String(n)}`}}}});var my,dy=h(()=>{"use strict";c();my={type:"object",properties:{remote:{type:"boolean",description:"List remote branches as well.",default:!1}}}});var tr,uy=h(()=>{"use strict";c();dy();Pe();tr={name:"git.branch_list",displayName:"Git Branch List",description:"List all branches.",category:"version-control",parameters:my,execute:async r=>{let e=r.remote;try{let t=G(),o=e?["-a"]:[],n=await t.branch(o);return`Current Branch: ${n.current}
|
|
305
305
|
|
|
306
306
|
Branches:
|
|
307
307
|
${n.all.join(`
|
|
308
|
-
`)}`}catch(t){return`Error listing branches: ${t instanceof Error?t.message:String(t)}`}}}});var
|
|
308
|
+
`)}`}catch(t){return`Error listing branches: ${t instanceof Error?t.message:String(t)}`}}}});var fy,gy=h(()=>{"use strict";c();fy={type:"object",properties:{name:{type:"string",description:"Name of the new branch."},checkout:{type:"boolean",description:"Whether to checkout the new branch after creating it.",default:!1},startPoint:{type:"string",description:"Optional start point (commit hash or branch name) for the new branch."}},required:["name"]}});var or,hy=h(()=>{"use strict";c();gy();Pe();or={name:"git.branch_create",displayName:"Git Branch Create",description:"Create a new branch.",category:"version-control",parameters:fy,execute:async r=>{let e=r.name,t=r.checkout,o=r.startPoint;try{let n=G();return t?(o?await n.checkoutBranch(e,o):await n.checkoutLocalBranch(e),`Successfully created and switched to branch: ${e}`):(o?await n.branch([e,o]):await n.branch([e]),`Successfully created branch: ${e}`)}catch(n){return`Error creating branch: ${n instanceof Error?n.message:String(n)}`}}}});var yy,by=h(()=>{"use strict";c();yy={type:"object",properties:{branch:{type:"string",description:"Name of the branch or commit to checkout."}},required:["branch"]}});var nr,wy=h(()=>{"use strict";c();by();Pe();nr={name:"git.checkout",displayName:"Git Checkout",description:"Switch branches or restore working tree files.",category:"version-control",parameters:yy,execute:async r=>{let e=r.branch;try{return await G().checkout(e),`Successfully checked out: ${e}`}catch(t){return`Error checking out branch: ${t instanceof Error?t.message:String(t)}`}},confirmation:{level:"medium",reason:"This will switch branches, potentially losing uncommitted changes.",showArgs:["branch"]}}});var Ty,xy=h(()=>{"use strict";c();Ty={type:"object",properties:{repo:{type:"string",description:'The repository to clone in "owner/repo" format (e.g., "microsoft/typescript").'},sha:{type:"string",description:"The commit SHA to checkout (always use SHAs, never branch names \u2014 handles force-pushes correctly)."},filter:{type:"string",description:'Git partial clone filter. "blob:none" (default) skips file blobs for a fast clone \u2014 blobs are fetched on demand when you read files or run git blame. Use "none" when you need immediate access to all file contents without extra fetches (e.g. heavy blame across many files).',default:"blob:none"},depth:{type:"number",description:"Commit history depth. Default 50 is enough for most PR reviews. Use 0 for full history when you need complete git log or blame across a long-lived file.",default:50},cloneRoot:{type:"string",description:"Override the local directory where clones are stored. Leave unset in almost all cases \u2014 the default is managed automatically."}},required:["repo","sha"]}});import*as de from"fs/promises";import*as sr from"path";async function dC(r){for(;rr.has(r);)await rr.get(r);let e,t=new Promise(o=>{e=o});return rr.set(r,t),()=>{rr.delete(r),e()}}async function vy(r){let e=0,t=await de.readdir(r,{withFileTypes:!0});for(let o of t){let n=sr.join(r,o.name);if(o.isDirectory())e+=await vy(n);else if(o.isFile()){let s=await de.stat(n);e+=s.size}}return e}async function uC(r,e){let t=e-r;for(;Ge>t&&Be.size>0;){let o=null,n=null;for(let[s,i]of Be)(!o||i.lastAccessedAt<o.lastAccessedAt)&&(o=i,n=s);if(!n||!o)break;try{await de.rm(o.cloneDir,{recursive:!0,force:!0}),Ge=Math.max(0,Ge-o.sizeBytes),Be.delete(n)}catch{break}}}async function fC(r,e,t,o,n){let i=`https://x-access-token:${await B(r)}@github.com/${r}.git`,a=r.replace("/","_"),l=sr.resolve(n,a),p=G(n),m=Be.get(r);if(m)try{if(await de.access(l),m.sha===e)return m.lastAccessedAt=Date.now(),l;await de.rm(l,{recursive:!0,force:!0}),Ge=Math.max(0,Ge-m.sizeBytes),Be.delete(r)}catch{Ge=Math.max(0,Ge-m.sizeBytes),Be.delete(r)}else try{await de.access(l),await de.rm(l,{recursive:!0,force:!0})}catch{}let d=["--no-checkout"];o>0&&d.push("--depth",o.toString()),t&&t!=="none"&&d.push("--filter",t);try{await p.clone(i,a,d);let g=G(l);try{let w=["origin",e];o>0&&w.push("--depth",o.toString()),await g.fetch(w)}catch{}await g.checkout(["--force",e]);let b=await vy(l);return Ge+=b,Be.set(r,{cloneDir:l,repo:r,sha:e,sizeBytes:b,lastAccessedAt:Date.now()}),l}catch(g){try{await de.rm(l,{recursive:!0,force:!0})}catch{}throw g}}function gC(r){return(r instanceof Error?r.message:String(r)).replace(/x-access-token:[^@]+@/g,"x-access-token:***@")}var pC,mC,Be,rr,Ge,ir,Cy=h(()=>{"use strict";c();xy();Pe();Se();pC=".toolpack/clones",mC=5e9,Be=new Map,rr=new Map,Ge=0;ir={name:"git.clone",displayName:"Git Clone",description:"Clone a GitHub repository at a specific commit SHA for local inspection. Call this before using git.diff, git.blame, git.log, fs.*, or coding.* tools \u2014 those tools accept the returned cloneDir to operate locally instead of through the GitHub API. Repeated calls with the same repo+sha are instant (cached). Disk is managed automatically with LRU eviction.",category:"version-control",parameters:Ty,execute:async r=>{let e=r.repo,t=r.sha,o=r.filter??"blob:none",n=r.depth??50,s=r.cloneRoot??process.env.SENTINEL_CLONE_ROOT??pC,i=parseInt(process.env.SENTINEL_CLONE_MAX_BYTES??"0",10)||mC;if(!/^[a-zA-Z0-9_.-]+\/[a-zA-Z0-9_.-]+$/.test(e))return'Error: repo must be in "owner/repo" format with alphanumeric, hyphens, underscores, or dots only (e.g., "microsoft/typescript")';if(!/^[a-f0-9]{7,40}$/i.test(t))return"Error: sha must be a valid commit SHA (7-40 hex characters)";await de.mkdir(s,{recursive:!0});let l=await dC(e);try{let p=Be.get(e);if(p&&p.sha===t)return p.lastAccessedAt=Date.now(),JSON.stringify({cloneDir:p.cloneDir,next:"Pass cloneDir to compatible git, filesystem, or coding tools to inspect this checkout."});await uC(1e8,i);let m=await fC(e,t,o,n,s);return JSON.stringify({cloneDir:m,next:"Pass cloneDir to compatible git, filesystem, or coding tools to inspect this checkout."})}catch(p){return`Error cloning repository: ${gC(p)}`}finally{l()}}}});var ky={};ee(ky,{gitAddTool:()=>Yn,gitBlameTool:()=>er,gitBranchCreateTool:()=>or,gitBranchListTool:()=>tr,gitCheckoutTool:()=>nr,gitCloneTool:()=>ir,gitCommitTool:()=>Zn,gitDiffTool:()=>Qn,gitLogTool:()=>Xn,gitStatusTool:()=>Vn,gitToolsProject:()=>Sy});var Sy,Ii=h(()=>{"use strict";c();Vh();Yh();ty();ry();ay();py();uy();hy();wy();Cy();Sy={manifest:{key:"git",name:"git-tools",displayName:"Git Version Control",version:"1.0.0",description:"Git operations for reading repository state, checking diffs, creating commits, and managing branches.",author:"Sajeer",tools:["git.status","git.diff","git.log","git.add","git.commit","git.blame","git.branch_list","git.branch_create","git.checkout","git.clone"],category:"version-control"},tools:[Vn,Qn,Xn,Yn,Zn,er,tr,or,nr,ir],dependencies:{"simple-git":"^3.27.0"}}});var Py,Ry=h(()=>{"use strict";c();Py={type:"object",properties:{oldContent:{type:"string",description:"The original text content."},newContent:{type:"string",description:"The new text content."},fileName:{type:"string",description:"Optional filename to include in the patch header."},contextLines:{type:"number",description:"Number of context lines to include around differences. Default is 4.",default:4}},required:["oldContent","newContent"]}});import*as _y from"diff";var ar,$y=h(()=>{"use strict";c();Ry();S();ar={name:"diff.create",displayName:"Create Diff",description:"Generate a unified diff from two text contents.",category:"diff",parameters:Py,execute:async r=>{let e=r.oldContent,t=r.newContent,o=r.fileName||"file",n=r.contextLines??4;y(`[diff.create] execute fileName="${o}" contextLines=${n}`);try{return _y.createPatch(o,e,t,"","",{context:n})}catch(s){return`Error creating diff: ${s instanceof Error?s.message:String(s)}`}}}});var Ey,Dy=h(()=>{"use strict";c();Ey={type:"object",properties:{path:{type:"string",description:"Path to the file to patch."},patch:{type:"string",description:"Unified diff string to apply."}},required:["path","patch"]}});import*as Ay from"diff";import{promises as My}from"fs";var lr,Oy=h(()=>{"use strict";c();Dy();S();lr={name:"diff.apply",displayName:"Apply Diff",description:"Apply a unified diff patch to a file.",category:"diff",parameters:Ey,execute:async r=>{let e=r.path,t=r.patch;y(`[diff.apply] execute path="${e}"`);try{let o=await My.readFile(e,"utf8"),n=Ay.applyPatch(o,t);return n===!1?"Failed to apply patch. The patch may be malformed or conflicting with the current file content.":(await My.writeFile(e,n,"utf8"),`Successfully applied patch to ${e}`)}catch(o){return`Error applying patch: ${o instanceof Error?o.message:String(o)}`}},confirmation:{level:"high",reason:"This will apply a patch to files, which may corrupt them if the patch doesn't match.",showArgs:["path"]}}});var Ny,Iy=h(()=>{"use strict";c();Ny={type:"object",properties:{path:{type:"string",description:"Path to the file to apply the patch against for preview."},patch:{type:"string",description:"Unified diff string to preview."}},required:["path","patch"]}});import*as jy from"diff";import{promises as hC}from"fs";var cr,Ly=h(()=>{"use strict";c();Iy();cr={name:"diff.preview",displayName:"Preview Diff",description:"Preview the result of applying a patch to a file without modifying it.",category:"diff",parameters:Ny,execute:async r=>{let e=r.path,t=r.patch;try{let o=await hC.readFile(e,"utf8"),n=jy.applyPatch(o,t);return n===!1?"Patch preview failed. The patch would not apply cleanly.":`Preview of ${e} after patch:
|
|
309
309
|
|
|
310
|
-
${n}`}catch(o){return`Error previewing patch: ${o instanceof Error?o.message:String(o)}`}}}});var
|
|
310
|
+
${n}`}catch(o){return`Error previewing patch: ${o instanceof Error?o.message:String(o)}`}}}});var qy={};ee(qy,{diffApplyTool:()=>lr,diffCreateTool:()=>ar,diffPreviewTool:()=>cr,diffToolsProject:()=>Fy});var Fy,ji=h(()=>{"use strict";c();$y();Oy();Ly();Fy={manifest:{key:"diff",name:"diff-tools",displayName:"Diff and Patch",version:"1.0.0",description:"Tools to create and apply unified diff changes to files safely.",author:"Sajeer",tools:["diff.create","diff.apply","diff.preview"],category:"diff"},tools:[ar,lr,cr],dependencies:{diff:"^7.0.0"}}});var Wy,Uy=h(()=>{"use strict";c();Wy={type:"object",properties:{db:{type:"string",description:"Database connection URI (e.g. postgres://user:pass@host/db, mysql://...) or local SQLite file path (.sqlite, .db)"},sql:{type:"string",description:"The SQL query to execute"},params:{type:"array",description:"Optional array of parameters for parameterized queries (to prevent SQL injection)",items:{},default:[]}},required:["db","sql"]}});var ze,pr=h(()=>{"use strict";c();ze=class{connectionString;constructor(e){this.connectionString=e}}});import Gy from"better-sqlite3";import*as Li from"fs";var fn,By=h(()=>{"use strict";c();pr();fn=class extends ze{getDb(){if(!Li.existsSync(this.connectionString))throw new Error(`Database file not found: ${this.connectionString}`);return new Gy(this.connectionString,{readonly:!1})}async query(e,t=[]){let o=this.getDb();try{let n=o.prepare(e);return n.reader?n.all(t):(n.run(t),[])}finally{o.close()}}async execute(e,t=[]){let o=this.getDb();try{let s=o.prepare(e).run(t);return{changes:s.changes,lastInsertRowid:s.lastInsertRowid,raw:s}}finally{o.close()}}async getTables(){return(await this.query("SELECT name FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'")).map(o=>o.name)}async getSchema(e){return e?await this.query(`PRAGMA table_info("${e}")`):await this.query("SELECT name, sql FROM sqlite_master WHERE type='table' AND name NOT LIKE 'sqlite_%'")}static executeSession(e,t,o=[]){if(!Li.existsSync(e))throw new Error(`Database file not found: ${e}`);let n=new Gy(e,{readonly:!1});try{let s=n.prepare(t);return s.reader?s.all(o):s.run(o)}finally{n.close()}}}});import yC from"pg";var mr,zy=h(()=>{"use strict";c();pr();mr=class extends ze{async getClient(){let e=new yC.Client({connectionString:this.connectionString});return await e.connect(),e}convertSql(e){let t=1;return e.replace(/\?/g,()=>`$${t++}`)}async query(e,t=[]){let o=await this.getClient();try{let n=this.convertSql(e);return(await o.query(n,t)).rows}finally{await o.end()}}async execute(e,t=[]){let o=await this.getClient();try{let n=this.convertSql(e),s=await o.query(n,t);return{changes:s.rowCount??0,raw:s}}finally{await o.end()}}async getTables(){return(await this.query("SELECT tablename as name FROM pg_catalog.pg_tables WHERE schemaname != 'pg_catalog' AND schemaname != 'information_schema'")).map(o=>o.name)}async getSchema(e){return e?await this.query(`
|
|
311
311
|
SELECT column_name, data_type, is_nullable, column_default
|
|
312
312
|
FROM information_schema.columns
|
|
313
313
|
WHERE table_name = $1
|
|
@@ -315,14 +315,14 @@ ${n}`}catch(o){return`Error previewing patch: ${o instanceof Error?o.message:Str
|
|
|
315
315
|
SELECT table_name as name, table_type
|
|
316
316
|
FROM information_schema.tables
|
|
317
317
|
WHERE table_schema = 'public'
|
|
318
|
-
`)}}});import yC from"mysql2/promise";var mr,zy=h(()=>{"use strict";c();cr();mr=class extends Be{async getConnection(){return await yC.createConnection(this.connectionString)}async query(e,t=[]){let o=await this.getConnection();try{let[n]=await o.execute(e,t);return n}finally{await o.end()}}async execute(e,t=[]){let o=await this.getConnection();try{let[n]=await o.execute(e,t);return{changes:n.affectedRows,lastInsertRowid:n.insertId,raw:n}}finally{await o.end()}}async getTables(){let t=await this.query("SHOW TABLES");if(!t||t.length===0)return[];let o=Object.keys(t[0]);return t.map(n=>n[o[0]])}async getSchema(e){if(e){let t=await this.getConnection();try{let[o]=await t.query("DESCRIBE ??",[e]);return o}finally{await t.end()}}else return await this.query("SHOW TABLES")}}});var X,ze=h(()=>{"use strict";c();Gy();By();zy();X=class{static getAdapter(e){return e.startsWith("postgres://")||e.startsWith("postgresql://")?new pr(e):e.startsWith("mysql://")?new mr(e):e.startsWith("sqlite://")?new un(e.replace("sqlite://","")):new un(e)}}});var dr,Hy=h(()=>{"use strict";c();Wy();ze();k();dr={name:"db.query",displayName:"Database Query",description:"Execute raw SQL queries against an SQLite, PostgreSQL, or MySQL database.",category:"database",parameters:qy,execute:async r=>{let e=r.db,t=r.sql,o=r.params||[];y(`[db.query] execute db="${e}" sql="${t.substring(0,80)}..." params=${o.length}`);try{let s=await X.getAdapter(e).query(t,o);return JSON.stringify(s,null,2)}catch(n){return`Database query error: ${n instanceof Error?n.message:String(n)}`}}}});var Ky,Jy=h(()=>{"use strict";c();Ky={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Optional specific table name to inspect. If omitted, returns structural summary of all tables."}},required:["db"]}});var ur,Vy=h(()=>{"use strict";c();Jy();ze();ur={name:"db.schema",displayName:"Database Schema",description:"Get the structural schema of a database or a specific table.",category:"database",parameters:Ky,execute:async r=>{let e=r.db,t=r.table;try{let n=await X.getAdapter(e).getSchema(t);return JSON.stringify(n,null,2)}catch(o){return`Database schema error: ${o instanceof Error?o.message:String(o)}`}}}});var Qy,Xy=h(()=>{"use strict";c();Qy={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"}},required:["db"]}});var fr,Yy=h(()=>{"use strict";c();Xy();ze();fr={name:"db.tables",displayName:"Database Tables",description:"List all user tables in the database.",category:"database",parameters:Qy,execute:async r=>{let e=r.db;try{let o=await X.getAdapter(e).getTables();return JSON.stringify(o,null,2)}catch(t){return`Database tables error: ${t instanceof Error?t.message:String(t)}`}}}});var Zy,eb=h(()=>{"use strict";c();Zy={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to insert into"},data:{type:"object",description:"Key-value pairs of column names and values to insert"}},required:["db","table","data"]}});var gr,tb=h(()=>{"use strict";c();eb();ze();gr={name:"db.insert",displayName:"Database Insert",description:"Insert a new row into an SQLite table safely.",category:"database",parameters:Zy,execute:async r=>{let e=r.db,t=r.table,o=r.data;if(Object.keys(o).length===0)return"Error: No data provided to insert.";try{let n=Object.keys(o).join(", "),s=Object.keys(o).map(()=>"?").join(", "),i=Object.values(o),a=`INSERT INTO ${t} (${n}) VALUES (${s})`,p=await X.getAdapter(e).execute(a,i);return JSON.stringify(p,null,2)}catch(n){return`Database insert error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"medium",reason:"This will insert rows into the database, creating permanent records.",showArgs:["table","data"]}}});var ob,nb=h(()=>{"use strict";c();ob={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to update"},data:{type:"object",description:"Key-value pairs of column names and new values"},where:{type:"string",description:'WHERE clause condition (e.g. "id = 5"). DO NOT INCLUDE the word WHERE.'}},required:["db","table","data","where"]}});var hr,rb=h(()=>{"use strict";c();nb();ze();hr={name:"db.update",displayName:"Database Update",description:"Update existing rows in a database table.",category:"database",parameters:ob,execute:async r=>{let e=r.db,t=r.table,o=r.data,n=r.where;if(Object.keys(o).length===0)return"Error: No data provided to update.";try{let s=Object.keys(o).map(m=>`${m} = ?`).join(", "),i=Object.values(o),a=`UPDATE ${t} SET ${s} WHERE ${n}`,p=await X.getAdapter(e).execute(a,i);return JSON.stringify(p,null,2)}catch(s){return`Database update error: ${s instanceof Error?s.message:String(s)}`}},confirmation:{level:"high",reason:"This will update database rows, potentially affecting multiple records.",showArgs:["table","data","where"]}}});var sb,ib=h(()=>{"use strict";c();sb={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to delete from"},where:{type:"string",description:'WHERE clause condition (e.g. "id = 5"). DO NOT INCLUDE the word WHERE.'}},required:["db","table","where"]}});var yr,ab=h(()=>{"use strict";c();ib();ze();yr={name:"db.delete",displayName:"Database Delete",description:"Delete rows from a database table.",category:"database",parameters:sb,execute:async r=>{let e=r.db,t=r.table,o=r.where;try{let n=`DELETE FROM ${t} WHERE ${o}`,i=await X.getAdapter(e).execute(n);return JSON.stringify(i,null,2)}catch(n){return`Database delete error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"high",reason:"This will permanently delete rows from the database.",showArgs:["table","where"]}}});var lb,cb=h(()=>{"use strict";c();lb={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to count rows from"},where:{type:"string",description:"Optional WHERE clause condition"}},required:["db","table"]}});var br,pb=h(()=>{"use strict";c();cb();ze();br={name:"db.count",displayName:"Database Count",description:"Count rows in a database table.",category:"database",parameters:lb,execute:async r=>{let e=r.db,t=r.table,o=r.where;try{let n=o?`WHERE ${o}`:"",s=`SELECT COUNT(*) as count FROM ${t} ${n}`,a=await X.getAdapter(e).query(s);return Array.isArray(a)&&a.length>0?`Rows: ${a[0].count}`:"Count: 0"}catch(n){return`Database count error: ${n instanceof Error?n.message:String(n)}`}}}});var db={};ee(db,{dbCountTool:()=>br,dbDeleteTool:()=>yr,dbInsertTool:()=>gr,dbQueryTool:()=>dr,dbSchemaTool:()=>ur,dbTablesTool:()=>fr,dbToolsProject:()=>mb,dbUpdateTool:()=>hr});var mb,ji=h(()=>{"use strict";c();Hy();Vy();Yy();tb();rb();ab();pb();mb={manifest:{key:"db",name:"db-tools",displayName:"Database Tools",version:"1.0.0",description:"Stateless database operations enabling the AI to interact with local databases.",author:"Sajeer",tools:["db.query","db.schema","db.tables","db.insert","db.update","db.delete","db.count"],category:"database"},tools:[dr,ur,fr,gr,hr,yr,br],dependencies:{"better-sqlite3":"^11.3.0"}}});var ub,fb=h(()=>{"use strict";c();ub={type:"object",properties:{siteId:{type:"string",description:'The Netlify Site ID to deploy to (e.g. "api_id" from Netlify UI)'},dir:{type:"string",description:'The local directory path to deploy (e.g. "./dist" or "./public")'},message:{type:"string",description:"Optional deployment message/commit note"}},required:["siteId","dir"]}});import{NetlifyAPI as bC}from"netlify";var He,wr=h(()=>{"use strict";c();He=class{static getClient(){let e=process.env.NETLIFY_AUTH_TOKEN;if(!e)throw new Error("NETLIFY_AUTH_TOKEN environment variable is required to use Netlify cloud tools.");return new bC(e)}}});var Tr,gb=h(()=>{"use strict";c();fb();wr();k();Tr={name:"cloud.deploy",displayName:"Cloud Deploy",description:"Deploy a static directory to Netlify.",category:"cloud",parameters:ub,execute:async r=>{let e=r.siteId,t=r.dir,o=r.message;y(`[cloud.deploy] execute siteId="${e}" dir="${t}" message="${o??"none"}"`);try{let s=await He.getClient().deploy(e,t,{message:o||"Deployed via Toolpack SDK",draft:!1});return JSON.stringify({id:s.deployId,url:s.deploy.url,admin_url:s.deploy.admin_url,state:s.deploy.state},null,2)}catch(n){return`Cloud deployment error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"high",reason:"This will deploy to production (live site).",showArgs:["siteId","dir"]}}});var hb,yb=h(()=>{"use strict";c();hb={type:"object",properties:{siteId:{type:"string",description:"The Netlify Site ID"},deployId:{type:"string",description:"The specific Deployment ID to check"}},required:["siteId","deployId"]}});var xr,bb=h(()=>{"use strict";c();yb();wr();xr={name:"cloud.status",displayName:"Cloud Status",description:"Check the status of a specific Netlify deployment.",category:"cloud",parameters:hb,execute:async r=>{let e=r.siteId,t=r.deployId;try{let n=await He.getClient().getSiteDeploy({site_id:e,deploy_id:t});return JSON.stringify({id:n.id,state:n.state,error_message:n.error_message,created_at:n.created_at,updated_at:n.updated_at,url:n.url},null,2)}catch(o){return`Cloud status error: ${o instanceof Error?o.message:String(o)}`}}}});var wb,Tb=h(()=>{"use strict";c();wb={type:"object",properties:{siteId:{type:"string",description:"The Netlify Site ID"},limit:{type:"number",description:"Number of recent deployments to return. Defaults to 5.",default:5}},required:["siteId"]}});var vr,xb=h(()=>{"use strict";c();Tb();wr();k();vr={name:"cloud.list",displayName:"Cloud Deployments List",description:"List recent deployments for a Netlify site.",category:"cloud",parameters:wb,execute:async r=>{let e=r.siteId,t=r.limit||5;y(`[cloud.list] execute siteId="${e}" limit=${t}`);try{let n=await He.getClient().listSiteDeploys({site_id:e,page:1,per_page:t});if(!Array.isArray(n))return"Unexpected response format from Netlify API";let s=n.map(i=>({id:i.id,state:i.state,created_at:i.created_at,url:i.url,branch:i.branch,title:i.title}));return JSON.stringify(s,null,2)}catch(o){return`Cloud list error: ${o instanceof Error?o.message:String(o)}`}}}});var Cb={};ee(Cb,{cloudDeployTool:()=>Tr,cloudListTool:()=>vr,cloudStatusTool:()=>xr,cloudToolsProject:()=>vb});var vb,Fi=h(()=>{"use strict";c();gb();bb();xb();vb={manifest:{key:"cloud",name:"cloud-tools",displayName:"Cloud Deployment",version:"1.0.0",description:"Cloud deployment operations allowing the AI to publish directories directly to the internet.",author:"Sajeer",tools:["cloud.deploy","cloud.status","cloud.list"],category:"cloud"},tools:[Tr,xr,vr],dependencies:{netlify:"^13.1.20"}}});var Sb,kb,Pb,_b,Rb,$b=h(()=>{"use strict";c();Sb="slack.chat.postMessage",kb="Post Slack Message",Pb="Post a message to a Slack channel or thread. Supports plain mrkdwn text and optional Block Kit blocks for rich formatting. Use thread_ts to reply inside an existing thread.",_b="slack",Rb={type:"object",properties:{channel:{type:"string",description:"Channel ID or channel name (e.g. #general) to post to."},text:{type:"string",description:"Message text in Slack mrkdwn format. Always required \u2014 used as fallback when blocks are provided."},thread_ts:{type:"string",description:"Timestamp of the parent message to reply in a thread. Omit to post at top level."},blocks:{type:"string",description:"Optional Block Kit layout as a JSON string. When provided, text is used only as the notification fallback."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","text"]}});function ye(r){if(r)return r;let e=process.env.TOOLPACK_SLACK_BOT_TOKEN;if(e)return e;throw new Error("No Slack token available. Set TOOLPACK_SLACK_BOT_TOKEN or pass token in tool args.")}var at=h(()=>{"use strict";c()});function wC(r){return{Authorization:`Bearer ${r}`,"Content-Type":"application/json; charset=utf-8"}}async function be(r,e,t){let o=await fetch(`https://slack.com/api/${r}`,{method:"POST",headers:wC(e),body:JSON.stringify(t)});if(!o.ok)throw new Error(`Slack HTTP error ${o.status} ${o.statusText}`);let n=await o.json();if(!n.ok)throw new Error(`Slack API error: ${n.error??"unknown"}`);return n}var lt=h(()=>{"use strict";c()});async function TC(r){let e=String(r.channel),t=String(r.text),o=r.thread_ts?String(r.thread_ts):void 0,n=r.blocks?String(r.blocks):void 0,s=ye(r.token),i={channel:e,text:t};if(o&&(i.thread_ts=o),n)try{i.blocks=JSON.parse(n)}catch{return"Error: blocks is not valid JSON."}let a=await be("chat.postMessage",s,i),l=a.ts??"";return`Message posted. channel=${a.channel??e} ts=${l}`}var fn,qi=h(()=>{"use strict";c();$b();at();lt();fn={name:Sb,displayName:kb,description:Pb,parameters:Rb,category:_b,execute:TC}});var Eb,Db,Mb,Ob,Ab,Nb=h(()=>{"use strict";c();Eb="slack.chat.postEphemeral",Db="Post Ephemeral Slack Message",Mb="Post a temporary message visible only to a specific user in a Slack channel. Useful for private confirmations, status updates, or error messages that should not be seen by others.",Ob="slack",Ab={type:"object",properties:{channel:{type:"string",description:"Channel ID where the ephemeral message will appear."},user:{type:"string",description:"Slack user ID of the person who will see the message."},text:{type:"string",description:"Message text in Slack mrkdwn format."},thread_ts:{type:"string",description:"Timestamp of the parent message to show the ephemeral reply inside a thread."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","user","text"]}});async function xC(r){let e=String(r.channel),t=String(r.user),o=String(r.text),n=r.thread_ts?String(r.thread_ts):void 0,s=ye(r.token),i={channel:e,user:t,text:o};return n&&(i.thread_ts=n),await be("chat.postEphemeral",s,i),`Ephemeral message sent to user=${t} in channel=${e}.`}var gn,Wi=h(()=>{"use strict";c();Nb();at();lt();gn={name:Eb,displayName:Db,description:Mb,parameters:Ab,category:Ob,execute:xC}});var Ib,Lb,jb,Fb,qb,Wb=h(()=>{"use strict";c();Ib="slack.reactions.add",Lb="Add Slack Reaction",jb="Add an emoji reaction to a Slack message. Useful for acknowledging receipt (\u{1F440} eyes), signalling completion (\u2705 white_check_mark), or flagging issues (\u26A0\uFE0F warning). Requires the reactions:write OAuth scope on the Slack app.",Fb="slack",qb={type:"object",properties:{channel:{type:"string",description:"Channel ID containing the message to react to."},timestamp:{type:"string",description:"Timestamp of the message to react to."},name:{type:"string",description:'Emoji name without colons (e.g. "eyes", "white_check_mark", "warning", "x").'},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","timestamp","name"]}});async function vC(r){let e=String(r.channel),t=String(r.timestamp),o=String(r.name),n=ye(r.token);try{await be("reactions.add",n,{channel:e,timestamp:t,name:o})}catch(s){if(s instanceof Error&&s.message.includes("already_reacted"))return`Reaction :${o}: already present on message ts=${t}.`;throw s}return`Reaction :${o}: added to message ts=${t} in channel=${e}.`}var hn,Ui=h(()=>{"use strict";c();Wb();at();lt();hn={name:Ib,displayName:Lb,description:jb,parameters:qb,category:Fb,execute:vC}});var Ub,Gb,Bb,zb,Hb,Kb=h(()=>{"use strict";c();Ub="slack.conversations.history",Gb="Get Slack Channel History",Bb="Fetch recent messages from a Slack channel. Useful for reading conversation context, checking what was discussed, or finding a specific message timestamp to react to or thread-reply into.",zb="slack",Hb={type:"object",properties:{channel:{type:"string",description:"Channel ID to fetch history from."},limit:{type:"integer",description:"Maximum number of messages to return. Defaults to 10, max 100."},oldest:{type:"string",description:"Only return messages after this Unix timestamp (inclusive)."},latest:{type:"string",description:"Only return messages before this Unix timestamp (exclusive)."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel"]}});async function CC(r){let e=String(r.channel),t=typeof r.limit=="number"?Math.min(r.limit,100):10,o=ye(r.token),n={channel:e,limit:t};r.oldest&&(n.oldest=String(r.oldest)),r.latest&&(n.latest=String(r.latest));let i=(await be("conversations.history",o,n)).messages??[];return i.length===0?"No messages found.":[...i].reverse().map(l=>{let p=l.user?`user:${l.user}`:l.bot_id?`bot:${l.bot_id}`:"unknown",m=l.reply_count?` [thread: ${l.reply_count} replies]`:"",d=(l.text??"").replace(/\n/g," ").slice(0,200);return`[${l.ts}] ${p}${m}: ${d}`}).join(`
|
|
319
|
-
`)}var
|
|
320
|
-
`)}var
|
|
318
|
+
`)}}});import bC from"mysql2/promise";var dr,Hy=h(()=>{"use strict";c();pr();dr=class extends ze{async getConnection(){return await bC.createConnection(this.connectionString)}async query(e,t=[]){let o=await this.getConnection();try{let[n]=await o.execute(e,t);return n}finally{await o.end()}}async execute(e,t=[]){let o=await this.getConnection();try{let[n]=await o.execute(e,t);return{changes:n.affectedRows,lastInsertRowid:n.insertId,raw:n}}finally{await o.end()}}async getTables(){let t=await this.query("SHOW TABLES");if(!t||t.length===0)return[];let o=Object.keys(t[0]);return t.map(n=>n[o[0]])}async getSchema(e){if(e){let t=await this.getConnection();try{let[o]=await t.query("DESCRIBE ??",[e]);return o}finally{await t.end()}}else return await this.query("SHOW TABLES")}}});var X,He=h(()=>{"use strict";c();By();zy();Hy();X=class{static getAdapter(e){return e.startsWith("postgres://")||e.startsWith("postgresql://")?new mr(e):e.startsWith("mysql://")?new dr(e):e.startsWith("sqlite://")?new fn(e.replace("sqlite://","")):new fn(e)}}});var ur,Ky=h(()=>{"use strict";c();Uy();He();S();ur={name:"db.query",displayName:"Database Query",description:"Execute raw SQL queries against an SQLite, PostgreSQL, or MySQL database.",category:"database",parameters:Wy,execute:async r=>{let e=r.db,t=r.sql,o=r.params||[];y(`[db.query] execute db="${e}" sql="${t.substring(0,80)}..." params=${o.length}`);try{let s=await X.getAdapter(e).query(t,o);return JSON.stringify(s,null,2)}catch(n){return`Database query error: ${n instanceof Error?n.message:String(n)}`}}}});var Jy,Vy=h(()=>{"use strict";c();Jy={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Optional specific table name to inspect. If omitted, returns structural summary of all tables."}},required:["db"]}});var fr,Qy=h(()=>{"use strict";c();Vy();He();fr={name:"db.schema",displayName:"Database Schema",description:"Get the structural schema of a database or a specific table.",category:"database",parameters:Jy,execute:async r=>{let e=r.db,t=r.table;try{let n=await X.getAdapter(e).getSchema(t);return JSON.stringify(n,null,2)}catch(o){return`Database schema error: ${o instanceof Error?o.message:String(o)}`}}}});var Xy,Yy=h(()=>{"use strict";c();Xy={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"}},required:["db"]}});var gr,Zy=h(()=>{"use strict";c();Yy();He();gr={name:"db.tables",displayName:"Database Tables",description:"List all user tables in the database.",category:"database",parameters:Xy,execute:async r=>{let e=r.db;try{let o=await X.getAdapter(e).getTables();return JSON.stringify(o,null,2)}catch(t){return`Database tables error: ${t instanceof Error?t.message:String(t)}`}}}});var eb,tb=h(()=>{"use strict";c();eb={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to insert into"},data:{type:"object",description:"Key-value pairs of column names and values to insert"}},required:["db","table","data"]}});var hr,ob=h(()=>{"use strict";c();tb();He();hr={name:"db.insert",displayName:"Database Insert",description:"Insert a new row into an SQLite table safely.",category:"database",parameters:eb,execute:async r=>{let e=r.db,t=r.table,o=r.data;if(Object.keys(o).length===0)return"Error: No data provided to insert.";try{let n=Object.keys(o).join(", "),s=Object.keys(o).map(()=>"?").join(", "),i=Object.values(o),a=`INSERT INTO ${t} (${n}) VALUES (${s})`,p=await X.getAdapter(e).execute(a,i);return JSON.stringify(p,null,2)}catch(n){return`Database insert error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"medium",reason:"This will insert rows into the database, creating permanent records.",showArgs:["table","data"]}}});var nb,rb=h(()=>{"use strict";c();nb={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to update"},data:{type:"object",description:"Key-value pairs of column names and new values"},where:{type:"string",description:'WHERE clause condition (e.g. "id = 5"). DO NOT INCLUDE the word WHERE.'}},required:["db","table","data","where"]}});var yr,sb=h(()=>{"use strict";c();rb();He();yr={name:"db.update",displayName:"Database Update",description:"Update existing rows in a database table.",category:"database",parameters:nb,execute:async r=>{let e=r.db,t=r.table,o=r.data,n=r.where;if(Object.keys(o).length===0)return"Error: No data provided to update.";try{let s=Object.keys(o).map(m=>`${m} = ?`).join(", "),i=Object.values(o),a=`UPDATE ${t} SET ${s} WHERE ${n}`,p=await X.getAdapter(e).execute(a,i);return JSON.stringify(p,null,2)}catch(s){return`Database update error: ${s instanceof Error?s.message:String(s)}`}},confirmation:{level:"high",reason:"This will update database rows, potentially affecting multiple records.",showArgs:["table","data","where"]}}});var ib,ab=h(()=>{"use strict";c();ib={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to delete from"},where:{type:"string",description:'WHERE clause condition (e.g. "id = 5"). DO NOT INCLUDE the word WHERE.'}},required:["db","table","where"]}});var br,lb=h(()=>{"use strict";c();ab();He();br={name:"db.delete",displayName:"Database Delete",description:"Delete rows from a database table.",category:"database",parameters:ib,execute:async r=>{let e=r.db,t=r.table,o=r.where;try{let n=`DELETE FROM ${t} WHERE ${o}`,i=await X.getAdapter(e).execute(n);return JSON.stringify(i,null,2)}catch(n){return`Database delete error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"high",reason:"This will permanently delete rows from the database.",showArgs:["table","where"]}}});var cb,pb=h(()=>{"use strict";c();cb={type:"object",properties:{db:{type:"string",description:"Database connection URI or SQLite file path"},table:{type:"string",description:"Name of the table to count rows from"},where:{type:"string",description:"Optional WHERE clause condition"}},required:["db","table"]}});var wr,mb=h(()=>{"use strict";c();pb();He();wr={name:"db.count",displayName:"Database Count",description:"Count rows in a database table.",category:"database",parameters:cb,execute:async r=>{let e=r.db,t=r.table,o=r.where;try{let n=o?`WHERE ${o}`:"",s=`SELECT COUNT(*) as count FROM ${t} ${n}`,a=await X.getAdapter(e).query(s);return Array.isArray(a)&&a.length>0?`Rows: ${a[0].count}`:"Count: 0"}catch(n){return`Database count error: ${n instanceof Error?n.message:String(n)}`}}}});var ub={};ee(ub,{dbCountTool:()=>wr,dbDeleteTool:()=>br,dbInsertTool:()=>hr,dbQueryTool:()=>ur,dbSchemaTool:()=>fr,dbTablesTool:()=>gr,dbToolsProject:()=>db,dbUpdateTool:()=>yr});var db,Fi=h(()=>{"use strict";c();Ky();Qy();Zy();ob();sb();lb();mb();db={manifest:{key:"db",name:"db-tools",displayName:"Database Tools",version:"1.0.0",description:"Stateless database operations enabling the AI to interact with local databases.",author:"Sajeer",tools:["db.query","db.schema","db.tables","db.insert","db.update","db.delete","db.count"],category:"database"},tools:[ur,fr,gr,hr,yr,br,wr],dependencies:{"better-sqlite3":"^11.3.0"}}});var fb,gb=h(()=>{"use strict";c();fb={type:"object",properties:{siteId:{type:"string",description:'The Netlify Site ID to deploy to (e.g. "api_id" from Netlify UI)'},dir:{type:"string",description:'The local directory path to deploy (e.g. "./dist" or "./public")'},message:{type:"string",description:"Optional deployment message/commit note"}},required:["siteId","dir"]}});import{NetlifyAPI as wC}from"netlify";var Ke,Tr=h(()=>{"use strict";c();Ke=class{static getClient(){let e=process.env.NETLIFY_AUTH_TOKEN;if(!e)throw new Error("NETLIFY_AUTH_TOKEN environment variable is required to use Netlify cloud tools.");return new wC(e)}}});var xr,hb=h(()=>{"use strict";c();gb();Tr();S();xr={name:"cloud.deploy",displayName:"Cloud Deploy",description:"Deploy a static directory to Netlify.",category:"cloud",parameters:fb,execute:async r=>{let e=r.siteId,t=r.dir,o=r.message;y(`[cloud.deploy] execute siteId="${e}" dir="${t}" message="${o??"none"}"`);try{let s=await Ke.getClient().deploy(e,t,{message:o||"Deployed via Toolpack SDK",draft:!1});return JSON.stringify({id:s.deployId,url:s.deploy.url,admin_url:s.deploy.admin_url,state:s.deploy.state},null,2)}catch(n){return`Cloud deployment error: ${n instanceof Error?n.message:String(n)}`}},confirmation:{level:"high",reason:"This will deploy to production (live site).",showArgs:["siteId","dir"]}}});var yb,bb=h(()=>{"use strict";c();yb={type:"object",properties:{siteId:{type:"string",description:"The Netlify Site ID"},deployId:{type:"string",description:"The specific Deployment ID to check"}},required:["siteId","deployId"]}});var vr,wb=h(()=>{"use strict";c();bb();Tr();vr={name:"cloud.status",displayName:"Cloud Status",description:"Check the status of a specific Netlify deployment.",category:"cloud",parameters:yb,execute:async r=>{let e=r.siteId,t=r.deployId;try{let n=await Ke.getClient().getSiteDeploy({site_id:e,deploy_id:t});return JSON.stringify({id:n.id,state:n.state,error_message:n.error_message,created_at:n.created_at,updated_at:n.updated_at,url:n.url},null,2)}catch(o){return`Cloud status error: ${o instanceof Error?o.message:String(o)}`}}}});var Tb,xb=h(()=>{"use strict";c();Tb={type:"object",properties:{siteId:{type:"string",description:"The Netlify Site ID"},limit:{type:"number",description:"Number of recent deployments to return. Defaults to 5.",default:5}},required:["siteId"]}});var Cr,vb=h(()=>{"use strict";c();xb();Tr();S();Cr={name:"cloud.list",displayName:"Cloud Deployments List",description:"List recent deployments for a Netlify site.",category:"cloud",parameters:Tb,execute:async r=>{let e=r.siteId,t=r.limit||5;y(`[cloud.list] execute siteId="${e}" limit=${t}`);try{let n=await Ke.getClient().listSiteDeploys({site_id:e,page:1,per_page:t});if(!Array.isArray(n))return"Unexpected response format from Netlify API";let s=n.map(i=>({id:i.id,state:i.state,created_at:i.created_at,url:i.url,branch:i.branch,title:i.title}));return JSON.stringify(s,null,2)}catch(o){return`Cloud list error: ${o instanceof Error?o.message:String(o)}`}}}});var Sb={};ee(Sb,{cloudDeployTool:()=>xr,cloudListTool:()=>Cr,cloudStatusTool:()=>vr,cloudToolsProject:()=>Cb});var Cb,qi=h(()=>{"use strict";c();hb();wb();vb();Cb={manifest:{key:"cloud",name:"cloud-tools",displayName:"Cloud Deployment",version:"1.0.0",description:"Cloud deployment operations allowing the AI to publish directories directly to the internet.",author:"Sajeer",tools:["cloud.deploy","cloud.status","cloud.list"],category:"cloud"},tools:[xr,vr,Cr],dependencies:{netlify:"^13.1.20"}}});var kb,Pb,Rb,_b,$b,Eb=h(()=>{"use strict";c();kb="slack.chat.postMessage",Pb="Post Slack Message",Rb="Post a message to a Slack channel or thread. Supports plain mrkdwn text and optional Block Kit blocks for rich formatting. Use thread_ts to reply inside an existing thread.",_b="slack",$b={type:"object",properties:{channel:{type:"string",description:"Channel ID or channel name (e.g. #general) to post to."},text:{type:"string",description:"Message text in Slack mrkdwn format. Always required \u2014 used as fallback when blocks are provided."},thread_ts:{type:"string",description:"Timestamp of the parent message to reply in a thread. Omit to post at top level."},blocks:{type:"string",description:"Optional Block Kit layout as a JSON string. When provided, text is used only as the notification fallback."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","text"]}});function ye(r){if(r)return r;let e=process.env.TOOLPACK_SLACK_BOT_TOKEN;if(e)return e;throw new Error("No Slack token available. Set TOOLPACK_SLACK_BOT_TOKEN or pass token in tool args.")}var lt=h(()=>{"use strict";c()});function TC(r){return{Authorization:`Bearer ${r}`,"Content-Type":"application/json; charset=utf-8"}}async function be(r,e,t){let o=await fetch(`https://slack.com/api/${r}`,{method:"POST",headers:TC(e),body:JSON.stringify(t)});if(!o.ok)throw new Error(`Slack HTTP error ${o.status} ${o.statusText}`);let n=await o.json();if(!n.ok)throw new Error(`Slack API error: ${n.error??"unknown"}`);return n}var ct=h(()=>{"use strict";c()});async function xC(r){let e=String(r.channel),t=String(r.text),o=r.thread_ts?String(r.thread_ts):void 0,n=r.blocks?String(r.blocks):void 0,s=ye(r.token),i={channel:e,text:t};if(o&&(i.thread_ts=o),n)try{i.blocks=JSON.parse(n)}catch{return"Error: blocks is not valid JSON."}let a=await be("chat.postMessage",s,i),l=a.ts??"";return`Message posted. channel=${a.channel??e} ts=${l}`}var gn,Wi=h(()=>{"use strict";c();Eb();lt();ct();gn={name:kb,displayName:Pb,description:Rb,parameters:$b,category:_b,execute:xC}});var Db,Mb,Ab,Ob,Nb,Ib=h(()=>{"use strict";c();Db="slack.chat.postEphemeral",Mb="Post Ephemeral Slack Message",Ab="Post a temporary message visible only to a specific user in a Slack channel. Useful for private confirmations, status updates, or error messages that should not be seen by others.",Ob="slack",Nb={type:"object",properties:{channel:{type:"string",description:"Channel ID where the ephemeral message will appear."},user:{type:"string",description:"Slack user ID of the person who will see the message."},text:{type:"string",description:"Message text in Slack mrkdwn format."},thread_ts:{type:"string",description:"Timestamp of the parent message to show the ephemeral reply inside a thread."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","user","text"]}});async function vC(r){let e=String(r.channel),t=String(r.user),o=String(r.text),n=r.thread_ts?String(r.thread_ts):void 0,s=ye(r.token),i={channel:e,user:t,text:o};return n&&(i.thread_ts=n),await be("chat.postEphemeral",s,i),`Ephemeral message sent to user=${t} in channel=${e}.`}var hn,Ui=h(()=>{"use strict";c();Ib();lt();ct();hn={name:Db,displayName:Mb,description:Ab,parameters:Nb,category:Ob,execute:vC}});var jb,Lb,Fb,qb,Wb,Ub=h(()=>{"use strict";c();jb="slack.reactions.add",Lb="Add Slack Reaction",Fb="Add an emoji reaction to a Slack message. Useful for acknowledging receipt (\u{1F440} eyes), signalling completion (\u2705 white_check_mark), or flagging issues (\u26A0\uFE0F warning). Requires the reactions:write OAuth scope on the Slack app.",qb="slack",Wb={type:"object",properties:{channel:{type:"string",description:"Channel ID containing the message to react to."},timestamp:{type:"string",description:"Timestamp of the message to react to."},name:{type:"string",description:'Emoji name without colons (e.g. "eyes", "white_check_mark", "warning", "x").'},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","timestamp","name"]}});async function CC(r){let e=String(r.channel),t=String(r.timestamp),o=String(r.name),n=ye(r.token);try{await be("reactions.add",n,{channel:e,timestamp:t,name:o})}catch(s){if(s instanceof Error&&s.message.includes("already_reacted"))return`Reaction :${o}: already present on message ts=${t}.`;throw s}return`Reaction :${o}: added to message ts=${t} in channel=${e}.`}var yn,Gi=h(()=>{"use strict";c();Ub();lt();ct();yn={name:jb,displayName:Lb,description:Fb,parameters:Wb,category:qb,execute:CC}});var Gb,Bb,zb,Hb,Kb,Jb=h(()=>{"use strict";c();Gb="slack.conversations.history",Bb="Get Slack Channel History",zb="Fetch recent messages from a Slack channel. Useful for reading conversation context, checking what was discussed, or finding a specific message timestamp to react to or thread-reply into.",Hb="slack",Kb={type:"object",properties:{channel:{type:"string",description:"Channel ID to fetch history from."},limit:{type:"integer",description:"Maximum number of messages to return. Defaults to 10, max 100."},oldest:{type:"string",description:"Only return messages after this Unix timestamp (inclusive)."},latest:{type:"string",description:"Only return messages before this Unix timestamp (exclusive)."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel"]}});async function SC(r){let e=String(r.channel),t=typeof r.limit=="number"?Math.min(r.limit,100):10,o=ye(r.token),n={channel:e,limit:t};r.oldest&&(n.oldest=String(r.oldest)),r.latest&&(n.latest=String(r.latest));let i=(await be("conversations.history",o,n)).messages??[];return i.length===0?"No messages found.":[...i].reverse().map(l=>{let p=l.user?`user:${l.user}`:l.bot_id?`bot:${l.bot_id}`:"unknown",m=l.reply_count?` [thread: ${l.reply_count} replies]`:"",d=(l.text??"").replace(/\n/g," ").slice(0,200);return`[${l.ts}] ${p}${m}: ${d}`}).join(`
|
|
319
|
+
`)}var bn,Bi=h(()=>{"use strict";c();Jb();lt();ct();bn={name:Gb,displayName:Bb,description:zb,parameters:Kb,category:Hb,execute:SC}});var Vb,Qb,Xb,Yb,Zb,ew=h(()=>{"use strict";c();Vb="slack.conversations.replies",Qb="Get Slack Thread Replies",Xb="Fetch all replies in a Slack thread. Use this to read the full conversation history of a thread, including who replied and when. Requires the channel ID and the timestamp (ts) of the parent message that started the thread.",Yb="slack",Zb={type:"object",properties:{channel:{type:"string",description:"Channel ID that contains the thread."},ts:{type:"string",description:"Timestamp of the parent message that started the thread."},limit:{type:"integer",description:"Maximum number of replies to return. Defaults to 20, max 100."},oldest:{type:"string",description:"Only return replies after this Unix timestamp (inclusive)."},latest:{type:"string",description:"Only return replies before this Unix timestamp (exclusive)."},token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:["channel","ts"]}});async function kC(r){let e=String(r.channel),t=String(r.ts),o=typeof r.limit=="number"?Math.min(r.limit,100):20,n=ye(r.token),s={channel:e,ts:t,limit:o};r.oldest&&(s.oldest=String(r.oldest)),r.latest&&(s.latest=String(r.latest));let a=(await be("conversations.replies",n,s)).messages??[];return a.length===0?"No replies found.":a.map((p,m)=>{let d=p.user?`user:${p.user}`:p.bot_id?`bot:${p.bot_id}`:"unknown",g=m===0?" [parent]":"",b=(p.text??"").replace(/\n/g," ").slice(0,200);return`[${p.ts}] ${d}${g}: ${b}`}).join(`
|
|
320
|
+
`)}var wn,zi=h(()=>{"use strict";c();ew();lt();ct();wn={name:Vb,displayName:Qb,description:Xb,parameters:Zb,category:Yb,execute:kC}});var tw,ow,nw,rw,sw,iw=h(()=>{"use strict";c();tw="slack.auth.test",ow="Slack Auth Test",nw="Verify the bot token and retrieve the identity of the calling app. Returns the bot_id, user_id, team, and workspace URL. Use this when the bot_id is not configured and is needed for self-suppression or other identity checks.",rw="slack",sw={type:"object",properties:{token:{type:"string",description:"Slack bot token. Defaults to TOOLPACK_SLACK_BOT_TOKEN env var."}},required:[]}});async function PC(r){let e=ye(r.token),t=await be("auth.test",e,{});return JSON.stringify({bot_id:t.bot_id,user_id:t.user_id,user:t.user,team:t.team,team_id:t.team_id,url:t.url},null,2)}var Tn,Hi=h(()=>{"use strict";c();iw();lt();ct();Tn={name:tw,displayName:ow,description:nw,parameters:sw,category:rw,execute:PC}});var lw={};ee(lw,{slackAuthTestTool:()=>Tn,slackChatPostEphemeralTool:()=>hn,slackChatPostMessageTool:()=>gn,slackConversationsHistoryTool:()=>bn,slackConversationsRepliesTool:()=>wn,slackReactionsAddTool:()=>yn,slackToolsProject:()=>aw});var aw,Ki=h(()=>{"use strict";c();Wi();Ui();Gi();Bi();zi();Hi();Wi();Ui();Gi();Bi();zi();Hi();aw={manifest:{key:"slack",name:"slack-tools",displayName:"Slack",version:"1.0.0",description:"Slack Web API tools \u2014 post messages, reply in threads, react to messages, read channel history, read thread replies, and verify bot identity.",author:"Toolpack",tools:["slack.chat.postMessage","slack.chat.postEphemeral","slack.reactions.add","slack.conversations.history","slack.conversations.replies","slack.auth.test"],category:"network"},tools:[gn,hn,yn,bn,wn,Tn]}});import{execFileSync as RC}from"child_process";function O(r,e){if(r.includes("\0")||r.includes(`
|
|
321
321
|
`)||r.includes("\r"))throw new Error(`Invalid ${e}: contains disallowed characters.`);return r}function _C(r){let e=typeof r.stdout=="string"?r.stdout:"",t=typeof r.stderr=="string"?r.stderr:"",o=r.status??"unknown",n=t.split(/\r?\n/).filter(i=>i.trim().length>0),s=n.find(i=>i.toLowerCase().startsWith("error:"))||n[0]||r.message||"";return`kubectl failed (exit code ${o})${s?`: ${s.trim()}`:""}
|
|
322
322
|
STDOUT:
|
|
323
323
|
${e}
|
|
324
324
|
STDERR:
|
|
325
|
-
${t}`}function ge(r,e,t=3e4){r.forEach((o,n)=>A(o,`kubectl argument #${n}`)),y(`[k8s-tools] execute: kubectl ${r.join(" ")}`);try{return PC("kubectl",r,{input:e,encoding:"utf-8",maxBuffer:10485760,stdio:["pipe","pipe","pipe"],timeout:t})||"(kubectl completed with no output)"}catch(o){return _C(o)}}function RC(r){if(!r)return 3e5;let e=r.trim().toLowerCase(),t=/^([0-9]+)(s|m|h)?$/.exec(e);if(!t)return 3e5;let o=Number(t[1]);switch(t[2]){case"h":return o*60*60*1e3;case"m":return o*60*1e3;default:return o*1e3}}function lw(r){if(!r)return;if(typeof r=="string")return r;let e=Object.entries(r).filter(([,t])=>t!==void 0&&t!=="");if(e.length)return e.map(([t,o])=>`${A(t,"label key")}=${A(o,"label value")}`).join(",")}var Pe,Cr,Sr,kr,Pr,_r,Rr,$r,Er,Dr,Mr,Or,cw=h(()=>{"use strict";c();k();Pe="kubernetes";Cr={name:"k8s.list_pods",displayName:"Kubernetes List Pods",description:"List pods in the current or a specific Kubernetes namespace.",category:Pe,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},labels:{type:"string",description:"Label selector to filter pods."},labelSelector:{type:"object",description:"Map of label key/value pairs to filter pods.",additionalProperties:{type:"string"}},output:{type:"string",description:"Output format for the pod list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"If true, list pods across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","pods"],t=r.output;t?e.push("-o",t):e.push("-o","wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",A(r.namespace,"namespace"));let o=lw(r.labelSelector)??r.labels;return o&&e.push("-l",A(o,"labels")),ge(e)}},Sr={name:"k8s.describe",displayName:"Kubernetes Describe Resource",description:"Describe a Kubernetes resource or resource instance.",category:Pe,parameters:{type:"object",properties:{resource:{type:"string",description:"Resource type to describe, such as pod, service, deployment."},name:{type:"string",description:"Resource name. Optional for cluster-wide descriptions."},namespace:{type:"string",description:"Namespace containing the resource."}},required:["resource"]},execute:async r=>{let t=["describe",A(r.resource,"resource")];return r.name&&t.push(A(r.name,"name")),r.namespace&&t.push("-n",A(r.namespace,"namespace")),ge(t)}},kr={name:"k8s.get_logs",displayName:"Kubernetes Get Pod Logs",description:"Fetch logs from a Kubernetes pod, optionally from a specific container.",category:Pe,parameters:{type:"object",properties:{podName:{type:"string",description:"The name of the pod to fetch logs from."},namespace:{type:"string",description:"Namespace of the pod."},container:{type:"string",description:"Container name inside the pod."},tailLines:{type:"number",description:"Number of log lines to show from the end.",default:100},since:{type:"string",description:"Return logs newer than a relative duration like 5m or 1h."}},required:["podName"]},execute:async r=>{let e=["logs",A(r.podName,"podName")];return r.container&&e.push("-c",A(r.container,"container")),r.namespace&&e.push("-n",A(r.namespace,"namespace")),typeof r.tailLines=="number"&&e.push("--tail",`${r.tailLines}`),r.since&&e.push("--since",A(r.since,"since")),ge(e)}},Pr={name:"k8s.apply_manifest",displayName:"Kubernetes Apply Manifest",description:"Apply a Kubernetes manifest from a file path or inline YAML content.",category:Pe,parameters:{type:"object",properties:{path:{type:"string",description:"Path to the manifest file to apply."},manifest:{type:"string",description:"Inline YAML manifest to apply if no path is provided."},namespace:{type:"string",description:"Namespace to apply the manifest into, if supported by the manifest."},dryRun:{type:"boolean",description:"If true, perform a client-side dry run without applying changes.",default:!1}},required:[]},confirmation:{level:"high",reason:"This will change cluster state by applying a Kubernetes manifest.",showArgs:["path","namespace"]},execute:async r=>{let e=r.path,t=r.manifest,o=["apply"];if(r.dryRun&&o.push("--dry-run=client"),o.push("-f"),e)return o.push(A(e,"path")),r.namespace&&o.push("-n",A(r.namespace,"namespace")),ge(o);if(!t)throw new Error("Either path or manifest is required to apply a Kubernetes manifest.");return r.namespace&&o.push("-n",A(r.namespace,"namespace")),o.push("-"),ge(o,t)}},_r={name:"k8s.delete_resource",displayName:"Kubernetes Delete Resource",description:"Delete a Kubernetes resource by type and name, or delete resources from a manifest file.",category:Pe,parameters:{type:"object",properties:{resource:{type:"string",description:"Resource type to delete, such as pod, service, deployment."},name:{type:"string",description:"Name of the resource to delete."},namespace:{type:"string",description:"Namespace containing the resource."},path:{type:"string",description:"Path to a manifest file that contains the resources to delete."},force:{type:"boolean",description:"Force deletion of the resource.",default:!1},dryRun:{type:"boolean",description:"If true, perform a client-side dry run without deleting resources.",default:!1}},required:[]},confirmation:{level:"high",reason:"This will delete resources from the Kubernetes cluster.",showArgs:["resource","name","path"]},execute:async r=>{let e=r.path,t=r.resource,o=r.name;if(e){let s=["delete"];return r.dryRun&&s.push("--dry-run=client"),s.push("-f",A(e,"path")),r.namespace&&s.push("-n",A(r.namespace,"namespace")),ge(s)}if(!t||!o)throw new Error("resource and name are required unless a manifest path is provided.");let n=["delete",A(t,"resource"),A(o,"name")];return r.namespace&&n.push("-n",A(r.namespace,"namespace")),r.force&&n.push("--force","--grace-period=0"),r.dryRun&&n.push("--dry-run=client"),ge(n)}},Rr={name:"k8s.list_services",displayName:"Kubernetes List Services",description:"List services in the current or a specific Kubernetes namespace.",category:Pe,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},output:{type:"string",description:"Output format for the service list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"List services across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","services"],t=r.output;return e.push("-o",t||"wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",A(r.namespace,"namespace")),ge(e)}},$r={name:"k8s.list_deployments",displayName:"Kubernetes List Deployments",description:"List deployments in the current or a specific Kubernetes namespace.",category:Pe,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},labels:{type:"string",description:"Label selector to filter deployments."},labelSelector:{type:"object",description:"Map of label key/value pairs to filter deployments.",additionalProperties:{type:"string"}},output:{type:"string",description:"Output format for the deployment list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"List deployments across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","deployments"],t=r.output;e.push("-o",t||"wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",A(r.namespace,"namespace"));let o=lw(r.labelSelector)??r.labels;return o&&e.push("-l",A(o,"labels")),ge(e)}},Er={name:"k8s.get_config_map",displayName:"Kubernetes Get ConfigMap",description:"Retrieve a ConfigMap from a Kubernetes namespace.",category:Pe,parameters:{type:"object",properties:{name:{type:"string",description:"ConfigMap name."},namespace:{type:"string",description:"Namespace containing the ConfigMap."},output:{type:"string",description:"Output format, such as yaml or json.",enum:["yaml","json"],default:"yaml"}},required:["name"]},execute:async r=>{let e=["get","configmap",A(r.name,"name"),"-o",r.output||"yaml"];return r.namespace&&e.push("-n",A(r.namespace,"namespace")),ge(e)}},Dr={name:"k8s.switch_context",displayName:"Kubernetes Switch Context",description:"Switch the active kubectl context to a different Kubernetes cluster or namespace configuration.",category:Pe,parameters:{type:"object",properties:{context:{type:"string",description:"The kubeconfig context to switch to."}},required:["context"]},execute:async r=>ge(["config","use-context",A(r.context,"context")])},Mr={name:"k8s.get_namespaces",displayName:"Kubernetes Get Namespaces",description:"List namespaces in the current Kubernetes context.",category:Pe,parameters:{type:"object",properties:{output:{type:"string",description:"Output format for the namespace list.",enum:["wide","name","json","yaml"],default:"wide"}},required:[]},execute:async r=>ge(["get","namespaces","-o",r.output||"wide"])},Or={name:"k8s.wait_for_deployment",displayName:"Kubernetes Wait For Deployment",description:"Wait for a Kubernetes deployment to complete its rollout.",category:Pe,parameters:{type:"object",properties:{name:{type:"string",description:"Deployment name to wait for."},namespace:{type:"string",description:"Namespace containing the deployment."},timeout:{type:"string",description:"Timeout duration, e.g. 300s or 5m.",default:"300s"}},required:["name"]},execute:async r=>{let e=r.timeout,t=["rollout","status",`deployment/${A(r.name,"name")}`,"--timeout",e||"300s"];return r.namespace&&t.push("-n",A(r.namespace,"namespace")),ge(t,void 0,RC(e))}}});var mw={};ee(mw,{k8sApplyManifestTool:()=>Pr,k8sDeleteResourceTool:()=>_r,k8sDescribeTool:()=>Sr,k8sGetConfigMapTool:()=>Er,k8sGetLogsTool:()=>kr,k8sGetNamespacesTool:()=>Mr,k8sListDeploymentsTool:()=>$r,k8sListPodsTool:()=>Cr,k8sListServicesTool:()=>Rr,k8sSwitchContextTool:()=>Dr,k8sToolsProject:()=>pw,k8sWaitForDeploymentTool:()=>Or});var pw,Ki=h(()=>{"use strict";c();cw();pw={manifest:{key:"k8s",name:"k8s-tools",displayName:"Kubernetes",version:"1.0.0",description:"Kubernetes command and cluster inspection tools for working with kubectl and manifests.",author:"toolpack-sdk",tools:["k8s.list_pods","k8s.describe","k8s.get_logs","k8s.apply_manifest","k8s.delete_resource","k8s.list_services","k8s.list_deployments","k8s.get_config_map","k8s.switch_context","k8s.get_namespaces","k8s.wait_for_deployment"],category:"kubernetes"},tools:[Cr,Sr,kr,Pr,_r,Rr,$r,Er,Dr,Mr,Or]}});import{createRemoteJWKSet as GC,jwtVerify as BC}from"jose";function ww(r){switch(r.mode){case"static":return new ta(r.tokens);case"jwt":return new oa(r);case"custom":return{verifyAccessToken:r.verifyAccessToken}}}async function Tw(r,e,t,o){let n=r.headers.authorization,s=typeof n=="string"&&n.startsWith("Bearer ")?n.slice(7):null;if(!s)return e.writeHead(401,{"WWW-Authenticate":"Bearer"}).end(),!1;let i;try{i=await o.verifyAccessToken(s)}catch{return e.writeHead(401,{"WWW-Authenticate":"Bearer"}).end(),!1}let a="requiredScopes"in t?t.requiredScopes:void 0;if(a?.length){let l=new Set(i.scopes),p=a.filter(m=>!l.has(m));if(p.length>0)return e.writeHead(403).end(`Missing required scopes: ${p.join(", ")}`),!1}return r.auth=i,!0}var ta,oa,xw=h(()=>{"use strict";c();ta=class{tokenSet;constructor(e){if(e.length===0)throw new Error('McpAuthConfig static mode: tokens array must not be empty. Generate a token with: crypto.randomBytes(32).toString("hex")');this.tokenSet=new Set(e)}async verifyAccessToken(e){if(!this.tokenSet.has(e))throw new Error("Invalid bearer token.");return{token:e,clientId:"static-client",scopes:[]}}},oa=class{JWKS;audience;issuer;constructor(e){this.JWKS=GC(new URL(e.jwksUrl)),this.audience=e.audience,this.issuer=e.issuer}async verifyAccessToken(e){let{payload:t}=await BC(e,this.JWKS,{audience:this.audience,issuer:this.issuer}),o=t.scope??t.scp,n=Array.isArray(o)?o.filter(i=>typeof i=="string"):typeof o=="string"?o.split(" ").filter(Boolean):[],s=typeof t.client_id=="string"?t.client_id:typeof t.sub=="string"?t.sub:"unknown";return{token:e,clientId:s,scopes:n,expiresAt:t.exp}}}});var Sw={};ee(Sw,{startMcpServer:()=>YC});import{createServer as zC}from"http";import{randomUUID as HC}from"crypto";import{Server as KC}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as JC}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as VC}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{ListToolsRequestSchema as QC,CallToolRequestSchema as XC}from"@modelcontextprotocol/sdk/types.js";async function YC(r,e,t){let o=new KC({name:e.serverName??"Toolpack SDK",version:e.serverVersion??"2.0.0"},{capabilities:{tools:{}}});if(o.setRequestHandler(QC,async()=>{if(e.searchMode){let i=tS(r,e),a=Ye(),l=i.map(p=>{let m=Cw(p);return{name:p.name,description:p.description??"",inputSchema:p.parameters??{type:"object",properties:{}},...m!==void 0&&{annotations:m}}});return{tools:[{name:a.name,description:a.description??"",inputSchema:a.parameters,annotations:{readOnlyHint:!0}},...l,...vw(e)]}}return{tools:[...na(r,e.expose).map(i=>{let a=Cw(i);return{name:i.name,description:i.description??"",inputSchema:i.parameters??{type:"object",properties:{}},...a!==void 0&&{annotations:a}}}),...vw(e)]}}),o.setRequestHandler(XC,async n=>{let{name:s,arguments:i}=n.params;if(e.searchMode&&yt(s)){if(!t)return Ae("tool.search is not available: searchFn was not provided to startMcpServer.",!0);try{let l=t(i??{});return Ae(l)}catch(l){let p=l instanceof Error?l.message:String(l);return Ae(`tool.search error: ${p}`,!0)}}if(s.startsWith("agent.")){let l=s.slice(6),p=(e.agents??[]).find(m=>m.name===l);if(!p)return Ae(`Agent not found: ${l}`,!0);try{let m=await p.invoke(i??{});return Ae(m)}catch(m){let d=m instanceof Error?m.message:String(m);return Ae(`Agent error (${l}): ${d}`,!0)}}let a=ZC(r,s,e.expose);if(!a)return Ae(`Tool not found: ${s}`,!0);try{let l={workspaceRoot:process.cwd(),config:r.getConfig().additionalConfigurations??{},log:m=>P(`[MCP Tool] ${m}`)},p=await a.execute(i??{},l);return Ae(p)}catch(l){let p=l instanceof Error?l.message:String(l);return Ae(`Error executing ${s}: ${p}`,!0)}}),e.transport==="stdio"){let n=new JC;return await o.connect(n),{get toolCount(){return na(r,e.expose).length},port:0,stop:async()=>{await o.close()}}}if(e.transport==="http"){let n=e.port??3e3;e.auth||P("[MCP Server] Warning: HTTP transport started without authentication. Safe for localhost only. Set `auth` in startMcpServer() before exposing this server to a network.");let s=new VC({sessionIdGenerator:()=>HC()}),i=e.auth?ww(e.auth):null,a=zC(async(p,m)=>{if(e.auth?.mode==="jwt"&&e.serverUrl&&p.url==="/.well-known/oauth-protected-resource"){let d={resource:e.serverUrl};e.auth.issuer&&(d.authorization_servers=[e.auth.issuer]),m.writeHead(200,{"Content-Type":"application/json"}).end(JSON.stringify(d));return}i&&!await Tw(p,m,e.auth,i).catch(g=>(P(`[MCP Server] Auth error: ${g instanceof Error?g.message:String(g)}`),m.headersSent||m.writeHead(500).end("Internal Server Error"),!1))||s.handleRequest(p,m).catch(d=>{P(`[MCP Server] HTTP request handler error: ${d instanceof Error?d.message:String(d)}`),m.headersSent||m.writeHead(500).end("Internal Server Error")})});await o.connect(s);try{await new Promise((p,m)=>{let d=g=>{m(g.code==="EADDRINUSE"?new Error(`MCP HTTP server failed to start: port ${n} is already in use.`):g)};a.once("error",d),a.listen(n,()=>{a.off("error",d),p()})})}catch(p){throw await o.close().catch(()=>{}),p}let l=a.address().port;return{get toolCount(){return na(r,e.expose).length},port:l,stop:async()=>{try{await o.close()}finally{await new Promise((p,m)=>{a.close(d=>d?m(d):p())})}}}}throw new Error(`Unknown MCP transport: "${e.transport}". Use 'stdio' or 'http'.`)}function na(r,e){return e?e.categories?.length?r.getByCategories(e.categories):e.tools?.length?r.getByNames(e.tools):r.getEnabled():r.getEnabled()}function ZC(r,e,t){let o=r.get(e);if(o)return t?.categories?.length?new Set(t.categories).has(o.category)?o:void 0:t?.tools?.length?t.tools.includes(e)?o:void 0:eS(r,o,e)?o:void 0}function eS(r,e,t){let{enabledTools:o,enabledToolCategories:n}=r.getConfig();return o.length===0&&n.length===0?!0:o.includes(t)||n.includes(e.category)}function vw(r){return(r.agents??[]).map(e=>({name:`agent.${e.name}`,description:e.description,inputSchema:e.inputSchema??{type:"object",properties:{}}}))}function tS(r,e){let t=r.getConfig().toolSearch;if(!t)return[];let o=r.getByNames(t.alwaysLoadedTools),n=r.getByCategories(t.alwaysLoadedCategories),s=new Set([Xe]),i=[...o,...n].filter(a=>s.has(a.name)?!1:(s.add(a.name),!0));if(e.expose?.categories?.length){let a=new Set(e.expose.categories);return i.filter(l=>a.has(l.category))}if(e.expose?.tools?.length){let a=new Set(e.expose.tools);return i.filter(l=>a.has(l.name))}return i}function Cw(r){if(r.annotations)return r.annotations;if(r.confirmation)return{destructiveHint:!0}}function Ae(r,e=!1){return{content:[{type:"text",text:typeof r=="string"?r:JSON.stringify(r,null,2)}],isError:e}}var kw=h(()=>{"use strict";c();k();xw();Wt()});c();le();c();le();import{EventEmitter as sT}from"events";c();le();async function ua(r,e={}){let{maxRetries:t=3,backoffMs:o=[1e4,3e4,6e4],isRetryable:n=i=>i instanceof fe,onRetry:s}=e;for(let i=0;i<=t;i++)try{return await r()}catch(a){if(n(a)&&i<t){let l=a?.retryAfter!=null?a.retryAfter*1e3:o[i]??o[o.length-1]??6e4;s?.(i+1,l,a),await new Promise(p=>setTimeout(p,l));continue}throw a}throw new fe("Rate limit retries exhausted")}c();le();var jt=class extends N{constructor(t,o,n,s,i,a){super(t,"CONTEXT_WINDOW_EXCEEDED",400,a);this.conversationId=o;this.currentTokens=n;this.contextWindowLimit=s;this.strategy=i;this.name="ContextWindowExceededError"}conversationId;currentTokens;contextWindowLimit;strategy;getOverageTokens(){return Math.max(0,this.currentTokens-this.contextWindowLimit)}getUsagePercentage(){return Math.round(this.currentTokens/this.contextWindowLimit*100)}getDetailedReport(){return`
|
|
325
|
+
${t}`}function ge(r,e,t=3e4){r.forEach((o,n)=>O(o,`kubectl argument #${n}`)),y(`[k8s-tools] execute: kubectl ${r.join(" ")}`);try{return RC("kubectl",r,{input:e,encoding:"utf-8",maxBuffer:10485760,stdio:["pipe","pipe","pipe"],timeout:t})||"(kubectl completed with no output)"}catch(o){return _C(o)}}function $C(r){if(!r)return 3e5;let e=r.trim().toLowerCase(),t=/^([0-9]+)(s|m|h)?$/.exec(e);if(!t)return 3e5;let o=Number(t[1]);switch(t[2]){case"h":return o*60*60*1e3;case"m":return o*60*1e3;default:return o*1e3}}function cw(r){if(!r)return;if(typeof r=="string")return r;let e=Object.entries(r).filter(([,t])=>t!==void 0&&t!=="");if(e.length)return e.map(([t,o])=>`${O(t,"label key")}=${O(o,"label value")}`).join(",")}var Re,Sr,kr,Pr,Rr,_r,$r,Er,Dr,Mr,Ar,Or,pw=h(()=>{"use strict";c();S();Re="kubernetes";Sr={name:"k8s.list_pods",displayName:"Kubernetes List Pods",description:"List pods in the current or a specific Kubernetes namespace.",category:Re,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},labels:{type:"string",description:"Label selector to filter pods."},labelSelector:{type:"object",description:"Map of label key/value pairs to filter pods.",additionalProperties:{type:"string"}},output:{type:"string",description:"Output format for the pod list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"If true, list pods across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","pods"],t=r.output;t?e.push("-o",t):e.push("-o","wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",O(r.namespace,"namespace"));let o=cw(r.labelSelector)??r.labels;return o&&e.push("-l",O(o,"labels")),ge(e)}},kr={name:"k8s.describe",displayName:"Kubernetes Describe Resource",description:"Describe a Kubernetes resource or resource instance.",category:Re,parameters:{type:"object",properties:{resource:{type:"string",description:"Resource type to describe, such as pod, service, deployment."},name:{type:"string",description:"Resource name. Optional for cluster-wide descriptions."},namespace:{type:"string",description:"Namespace containing the resource."}},required:["resource"]},execute:async r=>{let t=["describe",O(r.resource,"resource")];return r.name&&t.push(O(r.name,"name")),r.namespace&&t.push("-n",O(r.namespace,"namespace")),ge(t)}},Pr={name:"k8s.get_logs",displayName:"Kubernetes Get Pod Logs",description:"Fetch logs from a Kubernetes pod, optionally from a specific container.",category:Re,parameters:{type:"object",properties:{podName:{type:"string",description:"The name of the pod to fetch logs from."},namespace:{type:"string",description:"Namespace of the pod."},container:{type:"string",description:"Container name inside the pod."},tailLines:{type:"number",description:"Number of log lines to show from the end.",default:100},since:{type:"string",description:"Return logs newer than a relative duration like 5m or 1h."}},required:["podName"]},execute:async r=>{let e=["logs",O(r.podName,"podName")];return r.container&&e.push("-c",O(r.container,"container")),r.namespace&&e.push("-n",O(r.namespace,"namespace")),typeof r.tailLines=="number"&&e.push("--tail",`${r.tailLines}`),r.since&&e.push("--since",O(r.since,"since")),ge(e)}},Rr={name:"k8s.apply_manifest",displayName:"Kubernetes Apply Manifest",description:"Apply a Kubernetes manifest from a file path or inline YAML content.",category:Re,parameters:{type:"object",properties:{path:{type:"string",description:"Path to the manifest file to apply."},manifest:{type:"string",description:"Inline YAML manifest to apply if no path is provided."},namespace:{type:"string",description:"Namespace to apply the manifest into, if supported by the manifest."},dryRun:{type:"boolean",description:"If true, perform a client-side dry run without applying changes.",default:!1}},required:[]},confirmation:{level:"high",reason:"This will change cluster state by applying a Kubernetes manifest.",showArgs:["path","namespace"]},execute:async r=>{let e=r.path,t=r.manifest,o=["apply"];if(r.dryRun&&o.push("--dry-run=client"),o.push("-f"),e)return o.push(O(e,"path")),r.namespace&&o.push("-n",O(r.namespace,"namespace")),ge(o);if(!t)throw new Error("Either path or manifest is required to apply a Kubernetes manifest.");return r.namespace&&o.push("-n",O(r.namespace,"namespace")),o.push("-"),ge(o,t)}},_r={name:"k8s.delete_resource",displayName:"Kubernetes Delete Resource",description:"Delete a Kubernetes resource by type and name, or delete resources from a manifest file.",category:Re,parameters:{type:"object",properties:{resource:{type:"string",description:"Resource type to delete, such as pod, service, deployment."},name:{type:"string",description:"Name of the resource to delete."},namespace:{type:"string",description:"Namespace containing the resource."},path:{type:"string",description:"Path to a manifest file that contains the resources to delete."},force:{type:"boolean",description:"Force deletion of the resource.",default:!1},dryRun:{type:"boolean",description:"If true, perform a client-side dry run without deleting resources.",default:!1}},required:[]},confirmation:{level:"high",reason:"This will delete resources from the Kubernetes cluster.",showArgs:["resource","name","path"]},execute:async r=>{let e=r.path,t=r.resource,o=r.name;if(e){let s=["delete"];return r.dryRun&&s.push("--dry-run=client"),s.push("-f",O(e,"path")),r.namespace&&s.push("-n",O(r.namespace,"namespace")),ge(s)}if(!t||!o)throw new Error("resource and name are required unless a manifest path is provided.");let n=["delete",O(t,"resource"),O(o,"name")];return r.namespace&&n.push("-n",O(r.namespace,"namespace")),r.force&&n.push("--force","--grace-period=0"),r.dryRun&&n.push("--dry-run=client"),ge(n)}},$r={name:"k8s.list_services",displayName:"Kubernetes List Services",description:"List services in the current or a specific Kubernetes namespace.",category:Re,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},output:{type:"string",description:"Output format for the service list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"List services across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","services"],t=r.output;return e.push("-o",t||"wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",O(r.namespace,"namespace")),ge(e)}},Er={name:"k8s.list_deployments",displayName:"Kubernetes List Deployments",description:"List deployments in the current or a specific Kubernetes namespace.",category:Re,parameters:{type:"object",properties:{namespace:{type:"string",description:"Namespace to query. If omitted, uses the current namespace."},labels:{type:"string",description:"Label selector to filter deployments."},labelSelector:{type:"object",description:"Map of label key/value pairs to filter deployments.",additionalProperties:{type:"string"}},output:{type:"string",description:"Output format for the deployment list.",enum:["wide","name","json","yaml"],default:"wide"},allNamespaces:{type:"boolean",description:"List deployments across all namespaces.",default:!1}},required:[]},execute:async r=>{let e=["get","deployments"],t=r.output;e.push("-o",t||"wide"),r.allNamespaces&&e.push("--all-namespaces"),r.namespace&&!r.allNamespaces&&e.push("-n",O(r.namespace,"namespace"));let o=cw(r.labelSelector)??r.labels;return o&&e.push("-l",O(o,"labels")),ge(e)}},Dr={name:"k8s.get_config_map",displayName:"Kubernetes Get ConfigMap",description:"Retrieve a ConfigMap from a Kubernetes namespace.",category:Re,parameters:{type:"object",properties:{name:{type:"string",description:"ConfigMap name."},namespace:{type:"string",description:"Namespace containing the ConfigMap."},output:{type:"string",description:"Output format, such as yaml or json.",enum:["yaml","json"],default:"yaml"}},required:["name"]},execute:async r=>{let e=["get","configmap",O(r.name,"name"),"-o",r.output||"yaml"];return r.namespace&&e.push("-n",O(r.namespace,"namespace")),ge(e)}},Mr={name:"k8s.switch_context",displayName:"Kubernetes Switch Context",description:"Switch the active kubectl context to a different Kubernetes cluster or namespace configuration.",category:Re,parameters:{type:"object",properties:{context:{type:"string",description:"The kubeconfig context to switch to."}},required:["context"]},execute:async r=>ge(["config","use-context",O(r.context,"context")])},Ar={name:"k8s.get_namespaces",displayName:"Kubernetes Get Namespaces",description:"List namespaces in the current Kubernetes context.",category:Re,parameters:{type:"object",properties:{output:{type:"string",description:"Output format for the namespace list.",enum:["wide","name","json","yaml"],default:"wide"}},required:[]},execute:async r=>ge(["get","namespaces","-o",r.output||"wide"])},Or={name:"k8s.wait_for_deployment",displayName:"Kubernetes Wait For Deployment",description:"Wait for a Kubernetes deployment to complete its rollout.",category:Re,parameters:{type:"object",properties:{name:{type:"string",description:"Deployment name to wait for."},namespace:{type:"string",description:"Namespace containing the deployment."},timeout:{type:"string",description:"Timeout duration, e.g. 300s or 5m.",default:"300s"}},required:["name"]},execute:async r=>{let e=r.timeout,t=["rollout","status",`deployment/${O(r.name,"name")}`,"--timeout",e||"300s"];return r.namespace&&t.push("-n",O(r.namespace,"namespace")),ge(t,void 0,$C(e))}}});var dw={};ee(dw,{k8sApplyManifestTool:()=>Rr,k8sDeleteResourceTool:()=>_r,k8sDescribeTool:()=>kr,k8sGetConfigMapTool:()=>Dr,k8sGetLogsTool:()=>Pr,k8sGetNamespacesTool:()=>Ar,k8sListDeploymentsTool:()=>Er,k8sListPodsTool:()=>Sr,k8sListServicesTool:()=>$r,k8sSwitchContextTool:()=>Mr,k8sToolsProject:()=>mw,k8sWaitForDeploymentTool:()=>Or});var mw,Ji=h(()=>{"use strict";c();pw();mw={manifest:{key:"k8s",name:"k8s-tools",displayName:"Kubernetes",version:"1.0.0",description:"Kubernetes command and cluster inspection tools for working with kubectl and manifests.",author:"toolpack-sdk",tools:["k8s.list_pods","k8s.describe","k8s.get_logs","k8s.apply_manifest","k8s.delete_resource","k8s.list_services","k8s.list_deployments","k8s.get_config_map","k8s.switch_context","k8s.get_namespaces","k8s.wait_for_deployment"],category:"kubernetes"},tools:[Sr,kr,Pr,Rr,_r,$r,Er,Dr,Mr,Ar,Or]}});import{createRemoteJWKSet as BC,jwtVerify as zC}from"jose";function Tw(r){switch(r.mode){case"static":return new oa(r.tokens);case"jwt":return new na(r);case"custom":return{verifyAccessToken:r.verifyAccessToken}}}async function xw(r,e,t,o){let n=r.headers.authorization,s=typeof n=="string"&&n.startsWith("Bearer ")?n.slice(7):null;if(!s)return e.writeHead(401,{"WWW-Authenticate":"Bearer"}).end(),!1;let i;try{i=await o.verifyAccessToken(s)}catch{return e.writeHead(401,{"WWW-Authenticate":"Bearer"}).end(),!1}let a="requiredScopes"in t?t.requiredScopes:void 0;if(a?.length){let l=new Set(i.scopes),p=a.filter(m=>!l.has(m));if(p.length>0)return e.writeHead(403).end(`Missing required scopes: ${p.join(", ")}`),!1}return r.auth=i,!0}var oa,na,vw=h(()=>{"use strict";c();oa=class{tokenSet;constructor(e){if(e.length===0)throw new Error('McpAuthConfig static mode: tokens array must not be empty. Generate a token with: crypto.randomBytes(32).toString("hex")');this.tokenSet=new Set(e)}async verifyAccessToken(e){if(!this.tokenSet.has(e))throw new Error("Invalid bearer token.");return{token:e,clientId:"static-client",scopes:[]}}},na=class{JWKS;audience;issuer;constructor(e){this.JWKS=BC(new URL(e.jwksUrl)),this.audience=e.audience,this.issuer=e.issuer}async verifyAccessToken(e){let{payload:t}=await zC(e,this.JWKS,{audience:this.audience,issuer:this.issuer}),o=t.scope??t.scp,n=Array.isArray(o)?o.filter(i=>typeof i=="string"):typeof o=="string"?o.split(" ").filter(Boolean):[],s=typeof t.client_id=="string"?t.client_id:typeof t.sub=="string"?t.sub:"unknown";return{token:e,clientId:s,scopes:n,expiresAt:t.exp}}}});var kw={};ee(kw,{startMcpServer:()=>ZC});import{createServer as HC}from"http";import{randomUUID as KC}from"crypto";import{Server as JC}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as VC}from"@modelcontextprotocol/sdk/server/stdio.js";import{StreamableHTTPServerTransport as QC}from"@modelcontextprotocol/sdk/server/streamableHttp.js";import{ListToolsRequestSchema as XC,CallToolRequestSchema as YC}from"@modelcontextprotocol/sdk/types.js";async function ZC(r,e,t){let o=new JC({name:e.serverName??"Toolpack SDK",version:e.serverVersion??"2.0.0"},{capabilities:{tools:{}}});if(o.setRequestHandler(XC,async()=>{if(e.searchMode){let i=oS(r,e),a=Ze(),l=i.map(p=>{let m=Sw(p);return{name:p.name,description:p.description??"",inputSchema:p.parameters??{type:"object",properties:{}},...m!==void 0&&{annotations:m}}});return{tools:[{name:a.name,description:a.description??"",inputSchema:a.parameters,annotations:{readOnlyHint:!0}},...l,...Cw(e)]}}return{tools:[...ra(r,e.expose).map(i=>{let a=Sw(i);return{name:i.name,description:i.description??"",inputSchema:i.parameters??{type:"object",properties:{}},...a!==void 0&&{annotations:a}}}),...Cw(e)]}}),o.setRequestHandler(YC,async n=>{let{name:s,arguments:i}=n.params;if(e.searchMode&&bt(s)){if(!t)return Ne("tool.search is not available: searchFn was not provided to startMcpServer.",!0);try{let l=t(i??{});return Ne(l)}catch(l){let p=l instanceof Error?l.message:String(l);return Ne(`tool.search error: ${p}`,!0)}}if(s.startsWith("agent.")){let l=s.slice(6),p=(e.agents??[]).find(m=>m.name===l);if(!p)return Ne(`Agent not found: ${l}`,!0);try{let m=await p.invoke(i??{});return Ne(m)}catch(m){let d=m instanceof Error?m.message:String(m);return Ne(`Agent error (${l}): ${d}`,!0)}}let a=eS(r,s,e.expose);if(!a)return Ne(`Tool not found: ${s}`,!0);try{let l={workspaceRoot:process.cwd(),config:r.getConfig().additionalConfigurations??{},log:m=>P(`[MCP Tool] ${m}`)},p=await a.execute(i??{},l);return Ne(p)}catch(l){let p=l instanceof Error?l.message:String(l);return Ne(`Error executing ${s}: ${p}`,!0)}}),e.transport==="stdio"){let n=new VC;return await o.connect(n),{get toolCount(){return ra(r,e.expose).length},port:0,stop:async()=>{await o.close()}}}if(e.transport==="http"){let n=e.port??3e3;e.auth||P("[MCP Server] Warning: HTTP transport started without authentication. Safe for localhost only. Set `auth` in startMcpServer() before exposing this server to a network.");let s=new QC({sessionIdGenerator:()=>KC()}),i=e.auth?Tw(e.auth):null,a=HC(async(p,m)=>{if(e.auth?.mode==="jwt"&&e.serverUrl&&p.url==="/.well-known/oauth-protected-resource"){let d={resource:e.serverUrl};e.auth.issuer&&(d.authorization_servers=[e.auth.issuer]),m.writeHead(200,{"Content-Type":"application/json"}).end(JSON.stringify(d));return}i&&!await xw(p,m,e.auth,i).catch(g=>(P(`[MCP Server] Auth error: ${g instanceof Error?g.message:String(g)}`),m.headersSent||m.writeHead(500).end("Internal Server Error"),!1))||s.handleRequest(p,m).catch(d=>{P(`[MCP Server] HTTP request handler error: ${d instanceof Error?d.message:String(d)}`),m.headersSent||m.writeHead(500).end("Internal Server Error")})});await o.connect(s);try{await new Promise((p,m)=>{let d=g=>{m(g.code==="EADDRINUSE"?new Error(`MCP HTTP server failed to start: port ${n} is already in use.`):g)};a.once("error",d),a.listen(n,()=>{a.off("error",d),p()})})}catch(p){throw await o.close().catch(()=>{}),p}let l=a.address().port;return{get toolCount(){return ra(r,e.expose).length},port:l,stop:async()=>{try{await o.close()}finally{await new Promise((p,m)=>{a.close(d=>d?m(d):p())})}}}}throw new Error(`Unknown MCP transport: "${e.transport}". Use 'stdio' or 'http'.`)}function ra(r,e){return e?e.categories?.length?r.getByCategories(e.categories):e.tools?.length?r.getByNames(e.tools):r.getEnabled():r.getEnabled()}function eS(r,e,t){let o=r.get(e);if(o)return t?.categories?.length?new Set(t.categories).has(o.category)?o:void 0:t?.tools?.length?t.tools.includes(e)?o:void 0:tS(r,o,e)?o:void 0}function tS(r,e,t){let{enabledTools:o,enabledToolCategories:n}=r.getConfig();return o.length===0&&n.length===0?!0:o.includes(t)||n.includes(e.category)}function Cw(r){return(r.agents??[]).map(e=>({name:`agent.${e.name}`,description:e.description,inputSchema:e.inputSchema??{type:"object",properties:{}}}))}function oS(r,e){let t=r.getConfig().toolSearch;if(!t)return[];let o=r.getByNames(t.alwaysLoadedTools),n=r.getByCategories(t.alwaysLoadedCategories),s=new Set([Ye]),i=[...o,...n].filter(a=>s.has(a.name)?!1:(s.add(a.name),!0));if(e.expose?.categories?.length){let a=new Set(e.expose.categories);return i.filter(l=>a.has(l.category))}if(e.expose?.tools?.length){let a=new Set(e.expose.tools);return i.filter(l=>a.has(l.name))}return i}function Sw(r){if(r.annotations)return r.annotations;if(r.confirmation)return{destructiveHint:!0}}function Ne(r,e=!1){return{content:[{type:"text",text:typeof r=="string"?r:JSON.stringify(r,null,2)}],isError:e}}var Pw=h(()=>{"use strict";c();S();vw();Ut()});c();le();c();le();import{EventEmitter as iT}from"events";c();le();async function fa(r,e={}){let{maxRetries:t=3,backoffMs:o=[1e4,3e4,6e4],isRetryable:n=i=>i instanceof fe,onRetry:s}=e;for(let i=0;i<=t;i++)try{return await r()}catch(a){if(n(a)&&i<t){let l=a?.retryAfter!=null?a.retryAfter*1e3:o[i]??o[o.length-1]??6e4;s?.(i+1,l,a),await new Promise(p=>setTimeout(p,l));continue}throw a}throw new fe("Rate limit retries exhausted")}c();le();var Ft=class extends N{constructor(t,o,n,s,i,a){super(t,"CONTEXT_WINDOW_EXCEEDED",400,a);this.conversationId=o;this.currentTokens=n;this.contextWindowLimit=s;this.strategy=i;this.name="ContextWindowExceededError"}conversationId;currentTokens;contextWindowLimit;strategy;getOverageTokens(){return Math.max(0,this.currentTokens-this.contextWindowLimit)}getUsagePercentage(){return Math.round(this.currentTokens/this.contextWindowLimit*100)}getDetailedReport(){return`
|
|
326
326
|
Context Window Exceeded
|
|
327
327
|
=======================
|
|
328
328
|
Conversation ID: ${this.conversationId}
|
|
@@ -333,7 +333,7 @@ Usage: ${this.getUsagePercentage()}%
|
|
|
333
333
|
Strategy: ${this.strategy}
|
|
334
334
|
|
|
335
335
|
Message: ${this.message}
|
|
336
|
-
`.trim()}};var
|
|
336
|
+
`.trim()}};var qt=class extends N{constructor(t,o,n,s,i,a){super(t,"SUMMARIZATION_ERROR",500,a);this.conversationId=o;this.messageCount=n;this.failureReason=s;this.summaryAttempt=i;this.name="SummarizationError"}conversationId;messageCount;failureReason;summaryAttempt;isRetryable(){return this.failureReason==="provider_error"||this.failureReason==="insufficient_tokens"}getSuggestedRecovery(){switch(this.failureReason){case"provider_error":return"Retry the summarization request or switch to a different summarizer model";case"invalid_response":return"Review the summarizer prompt or use a different model";case"insufficient_tokens":return"Reduce the number of messages to summarize or increase the summary token budget";case"invalid_quality":return"Adjust summarization parameters or use a more capable model";default:return"Manual intervention required"}}getDetailedReport(){let t=`
|
|
337
337
|
Summarization Error
|
|
338
338
|
===================
|
|
339
339
|
Conversation ID: ${this.conversationId}
|
|
@@ -345,11 +345,11 @@ Recovery Action: ${this.getSuggestedRecovery()}
|
|
|
345
345
|
Message: ${this.message}`;return this.summaryAttempt?t+`
|
|
346
346
|
|
|
347
347
|
Partial Summary:
|
|
348
|
-
${this.summaryAttempt.substring(0,500)}${this.summaryAttempt.length>500?"...":""}`:t.trim()}};c();var
|
|
348
|
+
${this.summaryAttempt.substring(0,500)}${this.summaryAttempt.length>500?"...":""}`:t.trim()}};c();var Jr=null;async function Bw(){if(!Jr)try{Jr=await import("js-tiktoken")}catch{}return Jr}var ga={"gpt-4.1":3,"gpt-4.1-mini":3,"gpt-5.1":3,"gpt-5.2":3,"gpt-5.4":3,"gpt-5.4-pro":3,__default__:4},zw=2;async function Hw(r,e){try{let t=await Bw();if(!t)return Ie(r);let o=t.encoding_for_model(e),n=0,s=ga[e]??ga.__default__;for(let i of r){if(n+=s,typeof i.content=="string")n+=o.encode(i.content).length;else if(Array.isArray(i.content))for(let a of i.content)a.type==="text"?n+=o.encode(a.text).length:(a.type==="image_data"||a.type==="image_url"||a.type==="image_file")&&(n+=256);if(i.tool_calls?.length)for(let a of i.tool_calls)n+=o.encode(a.function.name).length,n+=o.encode(a.function.arguments).length;i.name&&(n+=o.encode(i.name).length)}return n+=zw,n}catch{return Ie(r)}}async function Kw(r,e){try{let t=Ie(r);return Math.ceil(t*1.1)}catch{return Ie(r)}}async function Jw(r,e){try{let t=Ie(r);return Math.ceil(t*1.05)}catch{return Ie(r)}}async function Vw(r,e){let t=Ie(r);return Math.ceil(t*1.05)}function Ie(r){let e=0;for(let t of r){if(e+=50,typeof t.content=="string")e+=t.content.length;else if(Array.isArray(t.content))for(let o of t.content)o.type==="text"?e+=o.text.length:(o.type==="image_data"||o.type==="image_url"||o.type==="image_file")&&(e+=1e3);if(t.tool_calls?.length)for(let o of t.tool_calls)e+=o.function.name.length,e+=o.function.arguments.length;t.name&&(e+=t.name.length)}return Math.ceil(e/4)}async function ha(r,e,t){let o=t.toLowerCase();return o==="openai"||o==="openai-gpt"?Hw(r,e):o==="anthropic"||o==="claude"?Kw(r,e):o==="gemini"||o==="google"?Jw(r,e):o==="ollama"?Vw(r,e):Ie(r)}function kS(r,e,t){let o=e-t;return r>o}function PS(r,e){return Math.round(r/e*100)}function ya(r,e=1.15){return Math.ceil(r*e)}c();function ba(r,e,t=!0){let o=r.length,n=[],s=0,i=[];r.forEach((p,m)=>{t&&p.role==="system"||p.role!=="tool"&&i.push({index:m,message:p})});for(let{message:p}of i){if(s>=e)break;let m=Vr(p);if(s+=m,n.push(p),p.role==="assistant"&&p.tool_calls?.length){let d=new Set(p.tool_calls.map(g=>g.id));for(let g of r)g.role==="tool"&&g.tool_call_id&&d.has(g.tool_call_id)&&(s+=Vr(g),n.push(g))}}let a=new Set(n),l=r.filter(p=>!a.has(p));return{removed:n.length,tokensReclaimed:s,newTotal:l.length,pruneInfo:{beforeCount:o,afterCount:l.length,removedMessages:n}}}function $S(r,e){if(typeof r.content=="string"){let t=e*4;if(r.content.length<=t)return r;let o=r.content.substring(0,t),n=Math.ceil((r.content.length-t)/4);return{...r,content:`${o}
|
|
349
349
|
|
|
350
350
|
[...truncated ${n} tokens]`}}else if(Array.isArray(r.content)){let t=r.content.filter(a=>a.type==="text"),o=t.reduce((a,l)=>a+(l.text?.length||0),0),n=e*4;if(o<=n)return r;let s=0,i=[];for(let a of t)if(a.type==="text"){let l=n-s;if(l<=0)break;let p=a.text;if(p.length<=l)i.push(a),s+=p.length;else{let m=p.substring(0,l),d=Math.ceil((p.length-l)/4);i.push({type:"text",text:`${m}
|
|
351
351
|
|
|
352
|
-
[...truncated ${d} tokens]`});break}}return{...r,content:i.length>0?i:r.content}}return r}function
|
|
352
|
+
[...truncated ${d} tokens]`});break}}return{...r,content:i.length>0?i:r.content}}return r}function Vr(r){let e=4;if(typeof r.content=="string")e+=Math.ceil(r.content.length/4);else if(Array.isArray(r.content))for(let t of r.content)t.type==="text"?e+=Math.ceil((t.text?.length||0)/4):(t.type==="image_data"||t.type==="image_url"||t.type==="image_file")&&(e+=256);if(r.tool_calls?.length)for(let t of r.tool_calls)e+=Math.ceil(t.function.name.length/4),e+=Math.ceil(t.function.arguments.length/4);return r.name&&(e+=Math.ceil(r.name.length/4)),e}function ES(r){let e={system:[],user:[],assistant:[],tool:[]};return r.forEach(t=>{e[t.role]??=[],e[t.role].push(t)}),e}function DS(r){let e=0,t={},o=0;for(let n of r){let s=Vr(n);e+=s,o=Math.max(o,s),t[n.role]??=0,t[n.role]++}return{totalMessages:r.length,totalTokens:e,byRole:t,largestMessageTokens:o}}c();le();function Qr(r){return r.content==null?"":typeof r.content=="string"?r.content:r.content.map(e=>e.type==="text"?e.text:e.type==="image_url"?`[image: ${e.image_url.url}]`:e.type==="image_file"?`[image-file: ${e.image_file.path}]`:e.type==="image_data"?`[image-data: ${e.image_data.mimeType}]`:"").filter(Boolean).join(" ")}function Qw(r,e){if(e)return e;let t=r.filter(l=>l.role==="user"),o=r.filter(l=>l.role==="assistant"),n=r.filter(l=>l.role==="tool"),s=r.length,i=t.length,a=o.length;return`Please provide a concise summary of the following conversation history. The conversation contains ${s} messages (${i} user messages, ${a} assistant responses${n.length>0?`, and ${n.length} tool responses`:""}).
|
|
353
353
|
|
|
354
354
|
Focus on:
|
|
355
355
|
1. Key topics discussed
|
|
@@ -361,22 +361,22 @@ The summary should be comprehensive yet concise, preserving all critical informa
|
|
|
361
361
|
|
|
362
362
|
---
|
|
363
363
|
CONVERSATION:
|
|
364
|
-
${r.map((l,p)=>{let m=
|
|
364
|
+
${r.map((l,p)=>{let m=Qr(l);return`[Message ${p+1}] ${l.role.toUpperCase()}: ${m.substring(0,200)}${m.length>200?"...":""}`}).join(`
|
|
365
365
|
`)}
|
|
366
366
|
---
|
|
367
367
|
|
|
368
|
-
SUMMARY:`}function
|
|
368
|
+
SUMMARY:`}function Xr(r,e){return{role:"system",content:`[Context Summary]
|
|
369
369
|
This conversation has been summarized to manage context window. The following is a summary of the first ${e} messages:
|
|
370
370
|
|
|
371
371
|
${r}
|
|
372
372
|
|
|
373
373
|
[End Summary]
|
|
374
374
|
|
|
375
|
-
Use this summary to understand the conversation context. When responding, acknowledge that you're aware of the previous conversation and continue naturally.`}}function
|
|
376
|
-
`)[0]);let a=i.match(/\b[A-Z][a-z]+(?:\s+[A-Z][a-z]+)*\b/g);a&&a.forEach(l=>e.add(l))}else if(s.role==="assistant"){let i=
|
|
375
|
+
Use this summary to understand the conversation context. When responding, acknowledge that you're aware of the previous conversation and continue naturally.`}}function NS(r){let e=new Set,t=[],o=[],n="";for(let s of r)if(s.role==="user"){let i=Qr(s);n=i,i.includes("?")&&o.push(i.split(`
|
|
376
|
+
`)[0]);let a=i.match(/\b[A-Z][a-z]+(?:\s+[A-Z][a-z]+)*\b/g);a&&a.forEach(l=>e.add(l))}else if(s.role==="assistant"){let i=Qr(s);if(i.includes("decided")||i.includes("concluded")||i.includes("determined")){let a=i.split(/[.!?]+/);for(let l of a)(l.includes("decided")||l.includes("concluded")||l.includes("determined"))&&t.push(l.trim())}}return{topics:Array.from(e).slice(0,10),decisions:t.slice(0,5),userGoals:o.slice(0,5),context:n.substring(0,200)}}function Xw(r){return Math.ceil(r.length/4)}function wa(r){let e=[];return(!r.summary||r.summary.length<10)&&e.push("Summary is too short"),r.summary.length>5e3&&e.push("Summary is excessively long"),r.messageCount<2&&e.push("Must summarize at least 2 messages"),r.summaryTokens>=r.originalTokens*.8&&e.push("Summary is not significantly shorter than original messages"),r.tokensSaved<0&&e.push("Token calculation error: saved tokens is negative"),{valid:e.length===0,issues:e}}function Ta(r,e){let t=Qw(r,e.summaryPrompt);return[{role:"system",content:`You are a conversation summarizer. Your task is to create a clear, concise summary of the provided conversation that preserves all critical information.
|
|
377
377
|
|
|
378
378
|
Maximum summary length: ${e.maxSummaryTokens||500} tokens.
|
|
379
|
-
Format: Write only the summary without any additional commentary.`},{role:"user",content:t}]}function
|
|
379
|
+
Format: Write only the summary without any additional commentary.`},{role:"user",content:t}]}function xa(r,e,t){let o=Xw(r),n=Math.max(0,t-o);return{summary:r.trim(),messageCount:e.length,originalTokens:t,summaryTokens:o,tokensSaved:n,timestamp:new Date}}function IS(r,e,t){let o=[...r];return o.push(Xr(e.summary,e.messageCount)),o.push(...t),o}function jS(r,e,t){let o=Math.round(r.tokensSaved/r.originalTokens*100);return`
|
|
380
380
|
Summarization Report
|
|
381
381
|
====================
|
|
382
382
|
Timestamp: ${r.timestamp.toISOString()}
|
|
@@ -397,31 +397,31 @@ Summary Preview:
|
|
|
397
397
|
${r.summary.substring(0,300)}${r.summary.length>300?"...":""}
|
|
398
398
|
`.trim()}function LS(r){if(r.length===0)throw new N("Cannot merge empty summarization results","CONTEXT_WINDOW_ERROR");return{summary:r.map(t=>`[Round ${r.indexOf(t)+1}] ${t.summary}`).join(`
|
|
399
399
|
|
|
400
|
-
`),messageCount:r.reduce((t,o)=>t+o.messageCount,0),originalTokens:r.reduce((t,o)=>t+o.originalTokens,0),summaryTokens:r.reduce((t,o)=>t+o.summaryTokens,0),tokensSaved:r.reduce((t,o)=>t+o.tokensSaved,0),timestamp:new Date}}c();var
|
|
401
|
-
`)}export(){let e={};for(let[t,o]of this.states.entries())e[t]={...o,lastUpdated:o.lastUpdated,lastPrunedAt:o.lastPrunedAt};return e}import(e){for(let[t,o]of Object.entries(e))this.states.set(t,{...o,lastUpdated:typeof o.lastUpdated=="number"?o.lastUpdated:new Date(o.lastUpdated).getTime(),lastPrunedAt:o.lastPrunedAt&&typeof o.lastPrunedAt!="number"?new Date(o.lastPrunedAt).getTime():o.lastPrunedAt})}pruneInactiveConversations(e=60){let t=Date.now()-e*60*1e3,o=[];for(let[n,s]of this.states.entries())s.lastUpdated<t&&o.push(n);return o.forEach(n=>this.states.delete(n)),o}getMemoryUsage(){let e=this.states.size,t=e*500;return{conversationCount:e,approximateByteSize:t}}validateIntegrity(){let e=[];for(let[t,o]of this.states.entries())(!t||typeof t!="string")&&e.push(`Invalid conversation ID: ${t}`),o.estimatedTokens<0&&e.push(`Negative token count for ${t}: ${o.estimatedTokens}`),o.pruneCount<0&&e.push(`Negative prune count for ${t}: ${o.pruneCount}`),o.summarizationCount<0&&e.push(`Negative summarization count for ${t}: ${o.summarizationCount}`),o.warningsSent<0&&e.push(`Negative warning count for ${t}: ${o.warningsSent}`),(typeof o.lastUpdated!="number"||o.lastUpdated<=0)&&e.push(`Invalid lastUpdated timestamp for ${t}`),o.lastPrunedAt!==void 0&&(typeof o.lastPrunedAt!="number"||o.lastPrunedAt<=0)&&e.push(`Invalid lastPrunedAt timestamp for ${t}`);return{isValid:e.length===0,issues:e}}};function
|
|
400
|
+
`),messageCount:r.reduce((t,o)=>t+o.messageCount,0),originalTokens:r.reduce((t,o)=>t+o.originalTokens,0),summaryTokens:r.reduce((t,o)=>t+o.summaryTokens,0),tokensSaved:r.reduce((t,o)=>t+o.tokensSaved,0),timestamp:new Date}}c();var Yr=class{states=new Map;config;maxTokens=1e5;constructor(e){this.config=e}getOrCreateState(e){return this.states.has(e)||this.states.set(e,{conversationId:e,estimatedTokens:0,lastUpdated:Date.now(),pruneCount:0,lastPrunedAt:void 0,warningsSent:0,summarizationCount:0}),this.states.get(e)}updateTokenCount(e,t){let o=this.getOrCreateState(e);return o.estimatedTokens=t,o.lastUpdated=Date.now(),o}recordPruneOperation(e,t){let o=this.getOrCreateState(e);return o.pruneCount++,o.lastPrunedAt=Date.now(),o.estimatedTokens=Math.max(0,o.estimatedTokens-t),o.lastUpdated=Date.now(),o}recordWarning(e){let t=this.getOrCreateState(e);return t.warningsSent++,t.lastUpdated=Date.now(),t}recordSummarization(e,t){let o=this.getOrCreateState(e);return o.summarizationCount++,o.estimatedTokens=Math.max(0,o.estimatedTokens-t),o.lastUpdated=Date.now(),o}getState(e){return this.states.get(e)}getAllStates(){return Array.from(this.states.values())}deleteState(e){return this.states.delete(e)}clearAllStates(){this.states.clear()}getStatistics(e){let t=this.states.get(e);if(!t)return null;let o=this.config.pruneThreshold||1e5,n=Math.round(t.estimatedTokens/o*100);return{conversationId:e,currentTokens:t.estimatedTokens,pruneCount:t.pruneCount,summarizationCount:t.summarizationCount,warningsSent:t.warningsSent,lastActivity:new Date(t.lastUpdated),contextWindowPercentage:n}}getExceedingThreshold(e){let t=e||this.maxTokens*(this.config.pruneThreshold||85)/100;return Array.from(this.states.values()).filter(o=>o.estimatedTokens>t)}getAtRiskConversations(e=80){let t=this.maxTokens,o=t*e/100;return Array.from(this.states.values()).filter(n=>n.estimatedTokens>o&&n.estimatedTokens<=t)}generateReport(){let e=this.getAllStates();if(e.length===0)return"No conversations tracked yet.";let t=this.config.pruneThreshold||1e5,o=["Context Window State Report","==========================",`Report Generated: ${new Date().toISOString()}`,`Context Window Limit: ${t} tokens`,`Total Conversations: ${e.length}`,""],n=e.reduce((d,g)=>d+g.estimatedTokens,0),s=e.reduce((d,g)=>d+g.pruneCount,0),i=e.reduce((d,g)=>d+g.summarizationCount,0),a=Math.round(n/e.length);o.push("Summary:"),o.push(`- Total tokens across all conversations: ${n}`),o.push(`- Average tokens per conversation: ${a}`),o.push(`- Total prune operations: ${s}`),o.push(`- Total summarizations: ${i}`),o.push("");let l=this.getAtRiskConversations();l.length>0&&(o.push(`At-Risk Conversations (80%+ threshold): ${l.length}`),l.forEach(d=>{let g=Math.round(d.estimatedTokens/t*100);o.push(`- ${d.conversationId}: ${d.estimatedTokens}/${t} tokens (${g}%)`)}),o.push(""));let p=this.getExceedingThreshold();return p.length>0&&(o.push(`Exceeded Conversations: ${p.length}`),p.forEach(d=>{let g=d.estimatedTokens-t;o.push(`- ${d.conversationId}: ${d.estimatedTokens}/${t} tokens (+${g} over)`)}),o.push("")),o.push("Most Active Conversations (by operations):"),[...e].sort((d,g)=>{let b=d.pruneCount+d.summarizationCount;return g.pruneCount+g.summarizationCount-b}).slice(0,5).forEach(d=>{let g=d.pruneCount+d.summarizationCount;o.push(`- ${d.conversationId}: ${d.pruneCount} prunes, ${d.summarizationCount} summarizations (${g} operations)`)}),o.join(`
|
|
401
|
+
`)}export(){let e={};for(let[t,o]of this.states.entries())e[t]={...o,lastUpdated:o.lastUpdated,lastPrunedAt:o.lastPrunedAt};return e}import(e){for(let[t,o]of Object.entries(e))this.states.set(t,{...o,lastUpdated:typeof o.lastUpdated=="number"?o.lastUpdated:new Date(o.lastUpdated).getTime(),lastPrunedAt:o.lastPrunedAt&&typeof o.lastPrunedAt!="number"?new Date(o.lastPrunedAt).getTime():o.lastPrunedAt})}pruneInactiveConversations(e=60){let t=Date.now()-e*60*1e3,o=[];for(let[n,s]of this.states.entries())s.lastUpdated<t&&o.push(n);return o.forEach(n=>this.states.delete(n)),o}getMemoryUsage(){let e=this.states.size,t=e*500;return{conversationCount:e,approximateByteSize:t}}validateIntegrity(){let e=[];for(let[t,o]of this.states.entries())(!t||typeof t!="string")&&e.push(`Invalid conversation ID: ${t}`),o.estimatedTokens<0&&e.push(`Negative token count for ${t}: ${o.estimatedTokens}`),o.pruneCount<0&&e.push(`Negative prune count for ${t}: ${o.pruneCount}`),o.summarizationCount<0&&e.push(`Negative summarization count for ${t}: ${o.summarizationCount}`),o.warningsSent<0&&e.push(`Negative warning count for ${t}: ${o.warningsSent}`),(typeof o.lastUpdated!="number"||o.lastUpdated<=0)&&e.push(`Invalid lastUpdated timestamp for ${t}`),o.lastPrunedAt!==void 0&&(typeof o.lastPrunedAt!="number"||o.lastPrunedAt<=0)&&e.push(`Invalid lastPrunedAt timestamp for ${t}`);return{isValid:e.length===0,issues:e}}};function va(r){return new Yr(r)}c();Ut();var Gt=class{discoveryCache=new ht;async resolve(e,t,o){return o.enabled?o.toolSearch?.enabled?this.resolveWithToolSearch(e,t,o):this.resolveLegacy(t,o):[]}getDiscoveryCache(){return this.discoveryCache}clearDiscoveryCache(){this.discoveryCache.clear()}resolveWithToolSearch(e,t,o){let n=[],s=new Set;n.push(Ze()),s.add(Ye);let i=o.toolSearch?.alwaysLoadedTools??[];for(let l of i){let p=t.get(l);p&&!s.has(l)&&(n.push(this.toSchema(p)),s.add(l))}let a=o.toolSearch?.alwaysLoadedCategories??[];for(let l of a)for(let p of t.getByCategory(l))s.has(p.name)||(n.push(this.toSchema(p)),s.add(p.name));if(o.toolSearch?.cacheDiscoveredTools!==!1){let l=ht.fromMessages(e);this.discoveryCache.merge(l);let p=this.discoveryCache.getDiscoveredTools();for(let m of p){let d=t.get(m);d&&!s.has(m)&&d.cacheable!==!1&&(n.push(this.toSchema(d)),s.add(m))}}return n}resolveLegacy(e,t){let o;if(t.enabledTools.length===0&&t.enabledToolCategories.length===0)o=e.getEnabled();else{let n=e.getByNames(t.enabledTools),s=e.getByCategories(t.enabledToolCategories),i=new Set;o=[];for(let a of[...n,...s])i.has(a.name)||(i.add(a.name),o.push(a))}return o.map(n=>this.toSchema(n))}toSchema(e){return{name:e.name,displayName:e.displayName,description:e.description,parameters:e.parameters,category:e.category}}};Bt();Ut();c();function Ra(r){if(r.disabled)return"";let e=r.includeWorkingDirectory!==!1,t=r.includeToolCategories!==!1,o=e?`
|
|
402
402
|
Working directory: ${r.workingDirectory}`:"",n=t&&r.toolCategories.length>0?`
|
|
403
403
|
Available tool categories: ${r.toolCategories.join(", ")}`:"";return`You are an AI assistant with access to tools that let you interact with the user's system.${o}${n}
|
|
404
404
|
|
|
405
405
|
When the user asks you to do something, be proactive:
|
|
406
406
|
- Use your tools to find information rather than asking the user for details you can discover yourself
|
|
407
407
|
- Read files, list directories, and explore the codebase when asked to analyze or understand a project
|
|
408
|
-
- Only ask the user for clarification when you genuinely cannot determine their intent or lack the required tools`}c();var
|
|
409
|
-
`):""}return""}k();var Da=0;function Ma(){return Da+=1,`${Date.now()}-${Da}`}function Pn(r,e){et("debug")&&(y(`[AIClient][${r}] Messages (${e.length}):`),e.forEach((t,o)=>{let n=O(t.content,300);y(`[AIClient][${r}] #${o} role=${t.role} content=${n}`)}))}function Oa(r){let e=Ze(r).toLowerCase();return e?[/\b(list|show|print|display)\b.*\b(files|folders|directory|dir)\b/,/\b(current|this)\b.*\b(directory|folder|repo|repository)\b/,/\b(read|open|view)\b.*\b(file|log|config|json|yaml|env)\b/,/\b(write|create|update|modify|edit|patch|delete|remove|rename|move|copy)\b.*\b(file|folder|directory)\b/,/\b(run|execute)\b.*\b(command|shell|script|tests?)\b/,/\b(http|get|post|put|delete|download|fetch|curl)\b/,/\b(web|search|scrape|crawl|map)\b/,/https?:\/\//].some(o=>o.test(e)):!1}function Aa(r){let e=Ze(r).toLowerCase();if(!e)return!1;let t=[/\b(list|show|print|display)\b.*\b(files|folders|directory|dir)\b/,/\b(current|this)\b.*\b(directory|folder|repo|repository)\b/,/\b(read|open|view)\b.*\b(file|log|config|json|yaml|env)\b/],o=[/\b(write|create|update|modify|edit|patch|delete|remove|rename|move|copy)\b/,/\b(run|execute)\b.*\b(command|shell|script|tests?)\b/,/\b(http|get|post|put|delete|download|fetch|curl)\b/,/\b(web|search|scrape|crawl)\b/];return t.some(n=>n.test(e))&&!o.some(n=>n.test(e))}var _n=class extends sT{providers;defaultProvider;toolRegistry;toolsConfig;toolRouter;bm25Engine;queryClassifier;toolOrchestrator;activeMode=null;overrideSystemPrompt;disableBaseContext;toolResultMaxChars;hitlConfig;onToolConfirm;currentRound=0;conversationId;contextWindowConfig;contextWindowStateManager;providerModelCache=new Map;constructor(e){super(),this.providers=new Map(Object.entries(e.providers)),this.defaultProvider=e.defaultProvider,this.toolRegistry=e.toolRegistry,this.toolsConfig=e.toolsConfig||ce,this.toolRouter=new Ut,this.bm25Engine=new qt,this.queryClassifier=new bt,this.toolOrchestrator=new kn,this.overrideSystemPrompt=e.systemPrompt,this.disableBaseContext=e.disableBaseContext||!1;let t=this.toolsConfig.resultMaxChars??ce.resultMaxChars??2e4;this.toolResultMaxChars=Number.isFinite(t)&&t>0?t:2e4,this.hitlConfig=e.hitlConfig,this.onToolConfirm=e.onToolConfirm,this.conversationId=e.conversationId,this.contextWindowConfig=e.contextWindowConfig,this.providerModelCache=new Map,this.contextWindowConfig&&this.contextWindowConfig.enabled!==!1&&(this.contextWindowStateManager=xa(this.contextWindowConfig)),this.toolRegistry&&this.bm25Engine.index(this.toolRegistry.getAll())}getConversationId(){return this.conversationId||"global"}async getModelInfo(e,t){let o=e.name||e.constructor.name,n=this.providerModelCache.get(o);if(!n){try{n=await e.getModels()}catch{n=[]}this.providerModelCache.set(o,n)}return n.find(s=>s.id===t||s.displayName===t)}async countRequestTokens(e,t,o){let n=await t.countTokens(e.messages,o);return typeof n=="number"&&Number.isFinite(n)?n:ga(e.messages,o,t.getDisplayName().toLowerCase())}async pruneConversation(e,t,o){let n=this.contextWindowConfig?.retainSystemMessages??!0,s=e;for(let i=0;i<3;i+=1){let a=await this.countRequestTokens(s,t,s.model);if(a<=o)return s;let l=a-o,p=ya(s.messages,l,n),m=new Set(p.pruneInfo.removedMessages),d=s.messages.filter(b=>!m.has(b)),g={...s,messages:d};if(this.contextWindowStateManager&&this.contextWindowStateManager.recordPruneOperation(this.getConversationId(),p.tokensReclaimed),await this.countRequestTokens(g,t,g.model)<=o||d.length===s.messages.length)return g;s=g}return e}async pruneToMaxMessageHistory(e){let t=this.contextWindowConfig?.maxMessageHistoryLength;if(!t||e.messages.length<=t)return e;let o=this.contextWindowConfig?.retainSystemMessages??!0,n=[];e.messages.forEach((l,p)=>{o&&l.role==="system"||l.role!=="tool"&&n.push(p)});let s=Math.max(0,e.messages.length-t);if(s===0)return e;let i=new Set(n.slice(0,s)),a=e.messages.filter((l,p)=>!i.has(p));return{...e,messages:a}}async summarizeConversation(e,t){let o=e.messages,n=o.filter(x=>x.role==="system"),s=o.filter(x=>x.role!=="system");if(s.length<4)return e;let i=s.slice(-4),a=s.slice(0,-4);if(a.length<2)return e;let l=this.contextWindowConfig?.summarizerModel||e.model,p=wa(a,{model:l,maxSummaryTokens:500}),m=await t.generate({model:l,messages:p,max_tokens:500,temperature:0,response_format:"text"});if(!m.content)throw new Ft("Summarization provider returned no summary",this.getConversationId(),a.length,"invalid_response");let d=await this.countRequestTokens({...e,messages:a},t,l),g=Ta(m.content,a,d),w=ba(g);if(!w.valid)throw new Ft(`Summarization result is invalid: ${w.issues.join("; ")}`,this.getConversationId(),a.length,"invalid_quality",m.content);let b=Qr(g.summary,a.length),T=[...n,b,...i];return this.contextWindowStateManager&&this.contextWindowStateManager.recordSummarization(this.getConversationId(),g.tokensSaved),{...e,messages:T}}async enforceContextWindow(e,t){if(!this.contextWindowConfig||this.contextWindowConfig.enabled===!1)return e;let o=await this.pruneToMaxMessageHistory(e),n=await this.getModelInfo(t,o.model),s=n?.contextWindow??1e5,i=o.max_tokens??n?.maxOutputTokens??1024,a=this.contextWindowConfig.outputTokenBuffer??1.15,l=ha(i,a),p=Math.max(0,s-l),m=Math.floor(s*((this.contextWindowConfig.pruneThreshold??85)/100)),d=Math.min(p,m),g=await this.countRequestTokens(o,t,o.model);if(this.contextWindowStateManager&&(this.contextWindowStateManager.updateTokenCount(this.getConversationId(),g),g>d&&this.contextWindowStateManager.recordWarning(this.getConversationId())),g<=d)return o;let w=this.contextWindowConfig.strategy??"prune";if(w==="fail"&&g>p)throw new jt("Context window exceeded by request messages",this.getConversationId(),g,p,w);if(w==="summarize")try{let T=await this.summarizeConversation(o,t);if(await this.countRequestTokens(T,t,T.model)<=p)return T;o=await this.pruneConversation(T,t,p)}catch{o=await this.pruneConversation(o,t,p)}else o=await this.pruneConversation(o,t,p);let b=await this.countRequestTokens(o,t,o.model);if(b>p&&w==="fail")throw new jt("Context window exceeded after attempted cleanup",this.getConversationId(),b,p,w);return o}isBypassed(e){let t=this.hitlConfig;if(!t||t.enabled===!1)return!0;let o=t.confirmationMode??"all";if(o==="off"||o==="high-only"&&e.confirmation?.level==="medium")return!0;let n=t.bypass??{};return!!(n.tools?.includes(e.name)||n.categories?.includes(e.category)||e.confirmation&&n.levels?.includes(e.confirmation.level))}registerProvider(e,t){this.providers.set(e,t)}getProvider(e){let t=e||this.defaultProvider;if(!t)throw new N("No provider specified and no default provider configured","NO_PROVIDER_CONFIGURED",400);let o=this.providers.get(t);if(!o)throw new N(`Provider '${t}' not found`,"PROVIDER_NOT_FOUND",404);return o}updateHitlConfig(e){this.hitlConfig=e}getHitlConfig(){return this.hitlConfig}setDefaultProvider(e){if(!this.providers.has(e))throw new N(`Provider '${e}' not found`,"PROVIDER_NOT_FOUND",404);this.defaultProvider=e}getToolRegistry(){return this.toolRegistry}getProviders(){return new Map(this.providers)}setToolRegistry(e){this.toolRegistry=e}setToolsConfig(e){this.toolsConfig=e}setSystemPrompt(e){this.overrideSystemPrompt=e}setMode(e){this.activeMode=e,P(`[AIClient] Mode set to: ${e?e.displayName:"none (cleared)"}`)}getMode(){return this.activeMode}getQueryClassifier(){return this.queryClassifier}reindexTools(){this.toolRegistry&&(this.bm25Engine.index(this.toolRegistry.getAll()),P(`[AIClient] Re-indexed ${this.bm25Engine.getIndexedCount()} tools for BM25 search`))}clearToolDiscoveryCache(){this.toolRouter.clearDiscoveryCache()}async generate(e,t){let o=this.getProvider(t);try{let n=Ma(),s=this.injectBaseAgentContext(e);s=this.injectOverrideSystemPrompt(s),s=this.injectModeSystemPrompt(s);let i=t||this.defaultProvider,a=await this.enrichRequestWithTools(s),l=a.request,p=a.requestToolMap;l=await this.enforceContextWindow(l,o);let m=process.env.TOOLPACK_SDK_TOOL_CHOICE_POLICY||this.toolsConfig.toolChoicePolicy||"auto",d=(l.tools?.length||0)>0,g=l.tool_choice!=null,w=Oa(l.messages),b=Aa(l.messages);!g&&d&&(m==="required"||m==="required_for_actions"&&w)&&(l.tool_choice="required");let x=o?.constructor?.name||"UnknownProvider",C=this.activeMode?.response_format,v={...this.stripRequestTools(l),__toolpack_request_id:n,...C?{response_format:C}:{}};P(`[AIClient][${n}] generate() start provider=${i} class=${x} model=${l.model} messages=${l.messages.length} tools=${l.tools?.length||0} tool_choice=${l.tool_choice??"unset"} policy=${m} needsTools=${w} autoExecute=${this.toolsConfig.enabled&&this.toolsConfig.autoExecute}`),Pn(n,l.messages);let $=M=>ua(()=>o.generate(M),{onRetry:(_,D)=>P(`[AIClient][${n}] Rate limited \u2014 retrying in ${D/1e3}s (attempt ${_}/3)`)}),S=await $(v);if(y(`[AIClient][${n}] generate() initial response finish_reason=${S.finish_reason??"unknown"} tool_calls=${S.tool_calls?.length||0} content_preview=${O(S.content||"",200)}`),this.toolsConfig.autoExecute&&(this.toolRegistry||p.size>0)){let M=Ze(l.messages),_=this.queryClassifier.classify(M),D=this.toolsConfig.maxToolRounds,R=l.maxToolRounds!==void 0?l.maxToolRounds:this.queryClassifier.getToolRoundsAdjustment(_,D);l.maxToolRounds!==void 0?y(`[AIClient][${n}] maxToolRounds overridden per-request: ${R} (classifier bypassed)`):R!==D?P(`[AIClient][${n}] Query classified as ${_.type} (confidence: ${_.confidence.toFixed(2)}), adjusted maxToolRounds: ${D} \u2192 ${R}`):y(`[AIClient][${n}] Query classified as ${_.type} (confidence: ${_.confidence.toFixed(2)}), keeping maxToolRounds: ${R}`);let W=0,z=[...l.messages];for(S.tool_calls&&S.tool_calls.length>0&&P(`[AIClient] Received ${S.tool_calls.length} tool call(s): ${S.tool_calls.map(mt=>mt.name).join(", ")}`);S.tool_calls&&S.tool_calls.length>0&&W<R;){W++,this.currentRound=W,P(`[AIClient][${n}] generate() tool round ${W}/${R} tool_calls=${S.tool_calls.length}`),z.push({role:"assistant",content:S.content||"",tool_calls:S.tool_calls.map(K=>({id:K.id,type:"function",function:{name:K.name,arguments:JSON.stringify(K.arguments)}}))});let mt=this.toolOrchestrator.shouldUseParallelExecution(S.tool_calls),dt=3,se=S.tool_calls,Ee=S.tool_calls.filter(K=>K.name==="web.fetch");if(Ee.length>dt){P(`[AIClient][${n}] Limiting web.fetch calls from ${Ee.length} \u2192 ${dt} to prevent context overflow`);let K=Ee.slice(0,dt);se=[...S.tool_calls.filter(Te=>Te.name!=="web.fetch"),...K];let Q=Ee.slice(dt);for(let Te of Q)z.push({role:"tool",tool_call_id:Te.id,content:"[Skipped: web.fetch fan-out limit exceeded]"})}let Y=5e4,ue=0;if(mt){P(`[AIClient][${n}] Using parallel execution for ${se.length} tools`);let K;try{K=await this.toolOrchestrator.executeWithDependencies(se,U=>this.executeTool(U,p),5)}catch(U){pe(`[AIClient][${n}] Parallel tool execution failed: ${U.message}`),K=new Map(se.map(Q=>[Q.id,JSON.stringify({error:U.message??"Tool execution failed"})]))}for(let U of se){let Q=K.get(U.id)??JSON.stringify({error:"Tool execution result missing"}),Te=typeof Q=="string"?Q:JSON.stringify(Q),ie=Y-ue,Z;ue+Te.length>Y?(I(`[AIClient][${n}] Tool output budget exceeded (${Y} chars)`),Z=this.budgetTruncate(Te,ie)):typeof Q=="string"&&Q.length>this.toolResultMaxChars?Z=`${Q.slice(0,this.toolResultMaxChars)}
|
|
410
|
-
[TRUNCATED tool result: ${Q.length} chars]`:Z=
|
|
411
|
-
[TRUNCATED tool result: ${U.length} chars]`:ie=Q;let Z=typeof ie=="string"?ie:JSON.stringify(ie);ue+=Z.length,
|
|
412
|
-
[TRUNCATED tool result: ${ae.length} chars]`:
|
|
408
|
+
- Only ask the user for clarification when you genuinely cannot determine their intent or lack the required tools`}c();var wt=class{analyticalPatterns=[/\b(analyze|find|search|check|list|show)\b/i,/\b(biggest|largest|smallest|most|least|all|every|count)\b/i,/\b(explain|understand|review|audit|inspect|examine)\b/i,/\b(compare|difference|similar|match|pattern)\b/i,/\b(what|where|how many|which|who|when|why|how)\b/i,/\?$/];actionPatterns=[/\b(create|write|update|modify|edit|patch|delete|remove|rename|move|copy)\b/i,/\b(run|execute|start|stop|restart|deploy|install|build)\b/i,/\b(fix|refactor|implement|add|change|replace|insert)\b/i,/\b(make|do|set|configure|setup|initialize)\b/i];classify(e){if(!e||e.trim().length===0)return{type:"conversational",confidence:0};let t=e.toLowerCase(),o=this.analyticalPatterns.filter(a=>a.test(t)).length,n=this.actionPatterns.filter(a=>a.test(t)).length,s=o/this.analyticalPatterns.length,i=n/this.actionPatterns.length;if(o>n&&o>0){let a=Math.min(s,1);return n>0&&(a=Math.min(a,.5)),{type:"analytical",confidence:a,reasoning:`Matched ${o} analytical patterns${n>0?`, ${n} action patterns (capped confidence)`:""}`}}else return n>o&&n>0?{type:"action",confidence:Math.min(i,1),reasoning:`Matched ${n} action patterns`}:o===n&&o>0?{type:"analytical",confidence:.5,reasoning:`Mixed query (${o} analytical, ${n} action patterns)`}:{type:"conversational",confidence:.3,reasoning:"No strong analytical or action patterns detected"}}getToolRoundsAdjustment(e,t){return e.type==="analytical"&&e.confidence>.6?Math.min(t+3,10):(e.type==="action"&&e.confidence>.6,t)}};c();var Pn=class{analyzeDependencies(e){let t=[];for(let o=0;o<e.length;o++){let n=e[o],s=[],i=JSON.stringify(n.arguments).toLowerCase();for(let a=0;a<o;a++){let l=e[a];this.hasDependency(n,l,i)&&s.push(l.id)}t.push({toolCallId:n.id,dependsOn:s})}return t}hasDependency(e,t,o){if(e.arguments.path&&t.arguments.path&&e.arguments.path===t.arguments.path||e.arguments.file_path&&t.arguments.file_path&&e.arguments.file_path===t.arguments.file_path||e.arguments.filePath&&t.arguments.filePath&&e.arguments.filePath===t.arguments.filePath||["fs.write_file","fs.delete_file","fs.move","fs.copy","fs.replace_in_file","fs.append_file"].includes(e.name)&&t.arguments.path&&o.includes(t.arguments.path.toLowerCase())||e.name==="exec.read_output"&&t.name==="exec.run_background"||e.name==="http.download"&&t.name==="http.get"&&t.arguments.url&&o.includes(t.arguments.url.toLowerCase()))return!0;let s=["github.pr.files.list","github.pr.diff.get","github.contents.getText"];if(["github.pr.reviews.submit","github.pr.reviewComments.reply"].includes(e.name)&&s.includes(t.name)||e.name==="github.contents.getText"&&t.name==="github.pr.files.list"||e.name==="github.pr.reviewThreads.resolve"&&t.name==="github.pr.reviewThreads.list")return!0;let a=["slack.conversations.history","slack.conversations.replies"];return!!(["slack.chat.postMessage","slack.chat.postEphemeral"].includes(e.name)&&a.includes(t.name)||e.name==="slack.reactions.add"&&a.includes(t.name))}async executeWithDependencies(e,t,o=5){if(e.length===0)return new Map;let n=this.analyzeDependencies(e),s=new Map,i=new Set;for(;i.size<e.length;){let a=[];for(let p of e){if(i.has(p.id))continue;(n.find(g=>g.toolCallId===p.id)?.dependsOn.every(g=>i.has(g))??!0)&&a.push(p)}if(a.length===0){let p=e.filter(m=>!i.has(m.id));throw new Error(`Circular dependency detected in tool calls: ${p.map(m=>m.name).join(", ")}`)}let l=await this.executeBatchWithLimit(a,t,o);for(let{id:p,result:m}of l)s.set(p,m),i.add(p)}return s}async executeBatchWithLimit(e,t,o){let n=async i=>(await Promise.allSettled(i.map(async l=>({id:l.id,result:await t(l)})))).map((l,p)=>l.status==="fulfilled"?l.value:{id:i[p].id,result:JSON.stringify({error:l.reason?.message??"Tool execution failed"})});if(e.length<=o)return n(e);let s=[];for(let i=0;i<e.length;i+=o)s.push(...await n(e.slice(i,i+o)));return s}shouldUseParallelExecution(e){return e.length>=2}};c();function et(r){for(let e=r.length-1;e>=0;e--){let t=r[e];if(t?.role!=="user")continue;let o=t?.content;return typeof o=="string"?o:Array.isArray(o)?o.map(n=>n?.type==="text"?n.text:"").filter(Boolean).join(`
|
|
409
|
+
`):""}return""}S();var Ma=0;function Aa(){return Ma+=1,`${Date.now()}-${Ma}`}function Rn(r,e){tt("debug")&&(y(`[AIClient][${r}] Messages (${e.length}):`),e.forEach((t,o)=>{let n=A(t.content,300);y(`[AIClient][${r}] #${o} role=${t.role} content=${n}`)}))}function Oa(r){let e=et(r).toLowerCase();return e?[/\b(list|show|print|display)\b.*\b(files|folders|directory|dir)\b/,/\b(current|this)\b.*\b(directory|folder|repo|repository)\b/,/\b(read|open|view)\b.*\b(file|log|config|json|yaml|env)\b/,/\b(write|create|update|modify|edit|patch|delete|remove|rename|move|copy)\b.*\b(file|folder|directory)\b/,/\b(run|execute)\b.*\b(command|shell|script|tests?)\b/,/\b(http|get|post|put|delete|download|fetch|curl)\b/,/\b(web|search|scrape|crawl|map)\b/,/https?:\/\//].some(o=>o.test(e)):!1}function Na(r){let e=et(r).toLowerCase();if(!e)return!1;let t=[/\b(list|show|print|display)\b.*\b(files|folders|directory|dir)\b/,/\b(current|this)\b.*\b(directory|folder|repo|repository)\b/,/\b(read|open|view)\b.*\b(file|log|config|json|yaml|env)\b/],o=[/\b(write|create|update|modify|edit|patch|delete|remove|rename|move|copy)\b/,/\b(run|execute)\b.*\b(command|shell|script|tests?)\b/,/\b(http|get|post|put|delete|download|fetch|curl)\b/,/\b(web|search|scrape|crawl)\b/];return t.some(n=>n.test(e))&&!o.some(n=>n.test(e))}var _n=class extends iT{providers;defaultProvider;toolRegistry;toolsConfig;toolRouter;bm25Engine;queryClassifier;toolOrchestrator;activeMode=null;overrideSystemPrompt;disableBaseContext;toolResultMaxChars;hitlConfig;onToolConfirm;currentRound=0;conversationId;contextWindowConfig;contextWindowStateManager;providerModelCache=new Map;constructor(e){super(),this.providers=new Map(Object.entries(e.providers)),this.defaultProvider=e.defaultProvider,this.toolRegistry=e.toolRegistry,this.toolsConfig=e.toolsConfig||ce,this.toolRouter=new Gt,this.bm25Engine=new Wt,this.queryClassifier=new wt,this.toolOrchestrator=new Pn,this.overrideSystemPrompt=e.systemPrompt,this.disableBaseContext=e.disableBaseContext||!1;let t=this.toolsConfig.resultMaxChars??ce.resultMaxChars??2e4;this.toolResultMaxChars=Number.isFinite(t)&&t>0?t:2e4,this.hitlConfig=e.hitlConfig,this.onToolConfirm=e.onToolConfirm,this.conversationId=e.conversationId,this.contextWindowConfig=e.contextWindowConfig,this.providerModelCache=new Map,this.contextWindowConfig&&this.contextWindowConfig.enabled!==!1&&(this.contextWindowStateManager=va(this.contextWindowConfig)),this.toolRegistry&&this.bm25Engine.index(this.toolRegistry.getAll())}getConversationId(){return this.conversationId||"global"}async getModelInfo(e,t){let o=e.name||e.constructor.name,n=this.providerModelCache.get(o);if(!n){try{n=await e.getModels()}catch{n=[]}this.providerModelCache.set(o,n)}return n.find(s=>s.id===t||s.displayName===t)}async countRequestTokens(e,t,o){let n=await t.countTokens(e.messages,o);return typeof n=="number"&&Number.isFinite(n)?n:ha(e.messages,o,t.getDisplayName().toLowerCase())}async pruneConversation(e,t,o){let n=this.contextWindowConfig?.retainSystemMessages??!0,s=e;for(let i=0;i<3;i+=1){let a=await this.countRequestTokens(s,t,s.model);if(a<=o)return s;let l=a-o,p=ba(s.messages,l,n),m=new Set(p.pruneInfo.removedMessages),d=s.messages.filter(w=>!m.has(w)),g={...s,messages:d};if(this.contextWindowStateManager&&this.contextWindowStateManager.recordPruneOperation(this.getConversationId(),p.tokensReclaimed),await this.countRequestTokens(g,t,g.model)<=o||d.length===s.messages.length)return g;s=g}return e}async pruneToMaxMessageHistory(e){let t=this.contextWindowConfig?.maxMessageHistoryLength;if(!t||e.messages.length<=t)return e;let o=this.contextWindowConfig?.retainSystemMessages??!0,n=[];e.messages.forEach((l,p)=>{o&&l.role==="system"||l.role!=="tool"&&n.push(p)});let s=Math.max(0,e.messages.length-t);if(s===0)return e;let i=new Set(n.slice(0,s)),a=e.messages.filter((l,p)=>!i.has(p));return{...e,messages:a}}async summarizeConversation(e,t){let o=e.messages,n=o.filter(v=>v.role==="system"),s=o.filter(v=>v.role!=="system");if(s.length<4)return e;let i=s.slice(-4),a=s.slice(0,-4);if(a.length<2)return e;let l=this.contextWindowConfig?.summarizerModel||e.model,p=Ta(a,{model:l,maxSummaryTokens:500}),m=await t.generate({model:l,messages:p,max_tokens:500,temperature:0,response_format:"text"});if(!m.content)throw new qt("Summarization provider returned no summary",this.getConversationId(),a.length,"invalid_response");let d=await this.countRequestTokens({...e,messages:a},t,l),g=xa(m.content,a,d),b=wa(g);if(!b.valid)throw new qt(`Summarization result is invalid: ${b.issues.join("; ")}`,this.getConversationId(),a.length,"invalid_quality",m.content);let w=Xr(g.summary,a.length),T=[...n,w,...i];return this.contextWindowStateManager&&this.contextWindowStateManager.recordSummarization(this.getConversationId(),g.tokensSaved),{...e,messages:T}}async enforceContextWindow(e,t){if(!this.contextWindowConfig||this.contextWindowConfig.enabled===!1)return e;let o=await this.pruneToMaxMessageHistory(e),n=await this.getModelInfo(t,o.model),s=n?.contextWindow??1e5,i=o.max_tokens??n?.maxOutputTokens??1024,a=this.contextWindowConfig.outputTokenBuffer??1.15,l=ya(i,a),p=Math.max(0,s-l),m=Math.floor(s*((this.contextWindowConfig.pruneThreshold??85)/100)),d=Math.min(p,m),g=await this.countRequestTokens(o,t,o.model);if(this.contextWindowStateManager&&(this.contextWindowStateManager.updateTokenCount(this.getConversationId(),g),g>d&&this.contextWindowStateManager.recordWarning(this.getConversationId())),g<=d)return o;let b=this.contextWindowConfig.strategy??"prune";if(b==="fail"&&g>p)throw new Ft("Context window exceeded by request messages",this.getConversationId(),g,p,b);if(b==="summarize")try{let T=await this.summarizeConversation(o,t);if(await this.countRequestTokens(T,t,T.model)<=p)return T;o=await this.pruneConversation(T,t,p)}catch{o=await this.pruneConversation(o,t,p)}else o=await this.pruneConversation(o,t,p);let w=await this.countRequestTokens(o,t,o.model);if(w>p&&b==="fail")throw new Ft("Context window exceeded after attempted cleanup",this.getConversationId(),w,p,b);return o}isBypassed(e){let t=this.hitlConfig;if(!t||t.enabled===!1)return!0;let o=t.confirmationMode??"all";if(o==="off"||o==="high-only"&&e.confirmation?.level==="medium")return!0;let n=t.bypass??{};return!!(n.tools?.includes(e.name)||n.categories?.includes(e.category)||e.confirmation&&n.levels?.includes(e.confirmation.level))}registerProvider(e,t){this.providers.set(e,t)}getProvider(e){let t=e||this.defaultProvider;if(!t)throw new N("No provider specified and no default provider configured","NO_PROVIDER_CONFIGURED",400);let o=this.providers.get(t);if(!o)throw new N(`Provider '${t}' not found`,"PROVIDER_NOT_FOUND",404);return o}updateHitlConfig(e){this.hitlConfig=e}getHitlConfig(){return this.hitlConfig}setDefaultProvider(e){if(!this.providers.has(e))throw new N(`Provider '${e}' not found`,"PROVIDER_NOT_FOUND",404);this.defaultProvider=e}getToolRegistry(){return this.toolRegistry}getProviders(){return new Map(this.providers)}setToolRegistry(e){this.toolRegistry=e}setToolsConfig(e){this.toolsConfig=e}setSystemPrompt(e){this.overrideSystemPrompt=e}setMode(e){this.activeMode=e,P(`[AIClient] Mode set to: ${e?e.displayName:"none (cleared)"}`)}getMode(){return this.activeMode}getQueryClassifier(){return this.queryClassifier}reindexTools(){this.toolRegistry&&(this.bm25Engine.index(this.toolRegistry.getAll()),P(`[AIClient] Re-indexed ${this.bm25Engine.getIndexedCount()} tools for BM25 search`))}clearToolDiscoveryCache(){this.toolRouter.clearDiscoveryCache()}async generate(e,t){let o=this.getProvider(t);try{let n=Aa(),s=this.resolveRequestMode(e),i=this.injectBaseAgentContext(e,s);i=this.injectOverrideSystemPrompt(i),i=this.injectModeSystemPrompt(i,s);let a=t||this.defaultProvider,l=await this.enrichRequestWithTools(i,s),p=l.request,m=l.requestToolMap;p=await this.enforceContextWindow(p,o);let d=process.env.TOOLPACK_SDK_TOOL_CHOICE_POLICY||this.toolsConfig.toolChoicePolicy||"auto",g=(p.tools?.length||0)>0,b=p.tool_choice!=null,w=Oa(p.messages),T=Na(p.messages);!b&&g&&(d==="required"||d==="required_for_actions"&&w)&&(p.tool_choice="required");let k=o?.constructor?.name||"UnknownProvider",x=s?.response_format,D={...this.stripRequestTools(p),__toolpack_request_id:n,...x?{response_format:x}:{}};P(`[AIClient][${n}] generate() start provider=${a} class=${k} model=${p.model} messages=${p.messages.length} tools=${p.tools?.length||0} tool_choice=${p.tool_choice??"unset"} policy=${d} needsTools=${w} autoExecute=${this.toolsConfig.enabled&&this.toolsConfig.autoExecute}`),Rn(n,p.messages);let M=R=>fa(()=>o.generate(R),{onRetry:($,E)=>P(`[AIClient][${n}] Rate limited \u2014 retrying in ${E/1e3}s (attempt ${$}/3)`)}),C=await M(D);if(y(`[AIClient][${n}] generate() initial response finish_reason=${C.finish_reason??"unknown"} tool_calls=${C.tool_calls?.length||0} content_preview=${A(C.content||"",200)}`),this.toolsConfig.autoExecute&&(this.toolRegistry||m.size>0)){let R=et(p.messages),$=this.queryClassifier.classify(R),E=this.toolsConfig.maxToolRounds,j=p.maxToolRounds!==void 0?p.maxToolRounds:this.queryClassifier.getToolRoundsAdjustment($,E);p.maxToolRounds!==void 0?y(`[AIClient][${n}] maxToolRounds overridden per-request: ${j} (classifier bypassed)`):j!==E?P(`[AIClient][${n}] Query classified as ${$.type} (confidence: ${$.confidence.toFixed(2)}), adjusted maxToolRounds: ${E} \u2192 ${j}`):y(`[AIClient][${n}] Query classified as ${$.type} (confidence: ${$.confidence.toFixed(2)}), keeping maxToolRounds: ${j}`);let we=0,V=[...p.messages];for(C.tool_calls&&C.tool_calls.length>0&&P(`[AIClient] Received ${C.tool_calls.length} tool call(s): ${C.tool_calls.map(dt=>dt.name).join(", ")}`);C.tool_calls&&C.tool_calls.length>0&&we<j;){we++,this.currentRound=we,P(`[AIClient][${n}] generate() tool round ${we}/${j} tool_calls=${C.tool_calls.length}`),V.push({role:"assistant",content:C.content||"",tool_calls:C.tool_calls.map(H=>({id:H.id,type:"function",function:{name:H.name,arguments:JSON.stringify(H.arguments)}}))});let dt=this.toolOrchestrator.shouldUseParallelExecution(C.tool_calls),ut=3,se=C.tool_calls,De=C.tool_calls.filter(H=>H.name==="web.fetch");if(De.length>ut){P(`[AIClient][${n}] Limiting web.fetch calls from ${De.length} \u2192 ${ut} to prevent context overflow`);let H=De.slice(0,ut);se=[...C.tool_calls.filter(xe=>xe.name!=="web.fetch"),...H];let Q=De.slice(ut);for(let xe of Q)V.push({role:"tool",tool_call_id:xe.id,content:"[Skipped: web.fetch fan-out limit exceeded]"})}let Y=5e4,ue=0;if(dt){P(`[AIClient][${n}] Using parallel execution for ${se.length} tools`);let H;try{H=await this.toolOrchestrator.executeWithDependencies(se,U=>this.executeTool(U,m,s),5)}catch(U){pe(`[AIClient][${n}] Parallel tool execution failed: ${U.message}`),H=new Map(se.map(Q=>[Q.id,JSON.stringify({error:U.message??"Tool execution failed"})]))}for(let U of se){let Q=H.get(U.id)??JSON.stringify({error:"Tool execution result missing"}),xe=typeof Q=="string"?Q:JSON.stringify(Q),ie=Y-ue,Z;ue+xe.length>Y?(I(`[AIClient][${n}] Tool output budget exceeded (${Y} chars)`),Z=this.budgetTruncate(xe,ie)):typeof Q=="string"&&Q.length>this.toolResultMaxChars?Z=`${Q.slice(0,this.toolResultMaxChars)}
|
|
410
|
+
[TRUNCATED tool result: ${Q.length} chars]`:Z=xe;let _=typeof Z=="string"?Z:JSON.stringify(Z);ue+=_.length,V.push({role:"tool",tool_call_id:U.id,content:Z})}y(`[AIClient][${n}] Round tool output size: ${ue} chars (budget: ${Y})`)}else{P(`[AIClient][${n}] Using sequential execution for ${se.length} tools`);for(let H of se){let U;try{U=await this.executeTool(H,m,s)}catch(_){U=JSON.stringify({error:_.message??"Tool execution failed"})}let Q=typeof U=="string"?U:JSON.stringify(U),xe=Y-ue,ie;ue+Q.length>Y?(I(`[AIClient][${n}] Tool output budget exceeded (${Y} chars)`),ie=this.budgetTruncate(Q,xe)):typeof U=="string"&&U.length>this.toolResultMaxChars?ie=`${U.slice(0,this.toolResultMaxChars)}
|
|
411
|
+
[TRUNCATED tool result: ${U.length} chars]`:ie=Q;let Z=typeof ie=="string"?ie:JSON.stringify(ie);ue+=Z.length,V.push({role:"tool",tool_call_id:H.id,content:ie})}y(`[AIClient][${n}] Round tool output size: ${ue} chars (budget: ${Y})`)}let ft={...p,messages:V,__toolpack_request_id:n,...x?{response_format:x}:{}},Te=this.stripRequestTools((await this.enrichRequestWithTools(ft,s)).request);Te=await this.enforceContextWindow(Te,o),Te.tool_choice==="required"&&(Te.tool_choice=T?"none":"auto",P(`[AIClient][${n}] generate() followup tool_choice override required->${Te.tool_choice}`)),tt("debug")&&(y(`[AIClient][${n}] generate() followup request messages=${V.length}`),Rn(n,V)),C=await M(Te),y(`[AIClient][${n}] generate() followup response finish_reason=${C.finish_reason??"unknown"} tool_calls=${C.tool_calls?.length||0} content_preview=${A(C.content||"",200)}`)}}return C.data===void 0&&C.content&&e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format&&(C.data=e.response_format.parse(JSON.parse(C.content))),C}catch(n){throw this.wrapError(n)}}async*stream(e,t){let o=this.getProvider(t);try{let n=Aa(),s=t||this.defaultProvider,i=this.resolveRequestMode(e),a=this.injectBaseAgentContext(e,i);a=this.injectOverrideSystemPrompt(a),a=this.injectModeSystemPrompt(a,i);let l=await this.enrichRequestWithTools(a,i),p=l.request,m=l.requestToolMap;p=await this.enforceContextWindow(p,o);let d=process.env.TOOLPACK_SDK_TOOL_CHOICE_POLICY||this.toolsConfig.toolChoicePolicy||"auto",g=(p.tools?.length||0)>0,b=p.tool_choice!=null,w=Oa(p.messages),T=Na(p.messages);!b&&g&&(d==="required"||d==="required_for_actions"&&w)&&(p.tool_choice="required");let k=o?.constructor?.name||"UnknownProvider",x=i?.response_format,D={...this.stripRequestTools(p),__toolpack_request_id:n,...x?{response_format:x}:{}};if(P(`[AIClient][${n}] stream() start provider=${s} class=${k} model=${p.model} messages=${p.messages.length} tools=${p.tools?.length||0} tool_choice=${p.tool_choice??"unset"} policy=${d} needsTools=${w} autoExecute=${this.toolsConfig.enabled&&this.toolsConfig.autoExecute}`),Rn(n,p.messages),!this.toolsConfig.autoExecute||!this.toolRegistry&&m.size===0){yield*o.stream(D);return}let M=[...p.messages],C=0,R=et(p.messages),$=this.queryClassifier.classify(R),E=this.toolsConfig.maxToolRounds,j=p.maxToolRounds!==void 0?p.maxToolRounds:this.queryClassifier.getToolRoundsAdjustment($,E);for(p.maxToolRounds!==void 0?y(`[AIClient][${n}] stream() maxToolRounds overridden per-request: ${j} (classifier bypassed)`):j!==E&&P(`[AIClient][${n}] stream() Query classified as ${$.type} (confidence: ${$.confidence.toFixed(2)}), adjusted maxToolRounds: ${E} \u2192 ${j}`);C<=j;){if(e.signal?.aborted){P(`[AIClient][${n}] stream() aborted by signal`);return}let we="",V=[];C++,this.currentRound=C,P(`[AIClient][${n}] stream() round_start ${C}/${j}`);let dt=null,ut={...p,messages:M,...x?{response_format:x}:{}},se=this.stripRequestTools((await this.enrichRequestWithTools(ut,i)).request);se=await this.enforceContextWindow(se,o),C>1&&se.tool_choice==="required"&&(se.tool_choice=T?"none":"auto",P(`[AIClient][${n}] stream() round_${C} tool_choice override required->${se.tool_choice}`));for await(let _ of o.stream(se)){if(e.signal?.aborted){P(`[AIClient][${n}] stream() aborted by signal during chunk processing`);return}_.tool_calls&&_.tool_calls.length>0&&(V.push(..._.tool_calls),y(`[AIClient][${n}] stream() tool_calls_chunk count=${_.tool_calls.length} names=${_.tool_calls.map(ae=>ae.name).join(", ")}`),yield _),_.delta&&(we+=_.delta,yield _),_.finish_reason&&(dt=_.finish_reason),_.finish_reason==="stop"&&(yield _)}if(y(`[AIClient][${n}] stream() round_end finish_reason=${dt??"unknown"} accumulated_len=${we.length} tool_calls_total=${V.length} content_preview=${A(we,200)}`),V.length===0)break;P(`[AIClient][${n}] stream() received ${V.length} tool call(s): ${V.map(_=>_.name).join(", ")}`),P(`[AIClient][${n}] stream() tool round ${C}/${j}`),M.push({role:"assistant",content:we||"",tool_calls:V.map(_=>({id:_.id,type:"function",function:{name:_.name,arguments:JSON.stringify(_.arguments)}}))});let De=3,Y=V,ue=V.filter(_=>_.name==="web.fetch");if(ue.length>De){P(`[AIClient][${n}] Limiting web.fetch calls from ${ue.length} \u2192 ${De} to prevent context overflow`);let _=ue.slice(0,De);Y=[...V.filter(Lt=>Lt.name!=="web.fetch"),..._];let Me=ue.slice(De);for(let Lt of Me)M.push({role:"tool",tool_call_id:Lt.id,content:"[Skipped: web.fetch fan-out limit exceeded]"})}let ft=5e4,Te=0,H=[],U=!1,Q=setInterval(()=>{U||H.push({delta:""})},500),xe=Date.now(),ie,Z;try{if(Y.length>=2)P(`[AIClient][${n}] stream() using parallel execution for ${Y.length} tools`),Z=new Map,ie=await this.toolOrchestrator.executeWithDependencies(Y,async _=>{let ae=Date.now(),Me=await this.executeTool(_,m,i);return Z.set(_.id,Date.now()-ae),Me},5);else{P(`[AIClient][${n}] stream() executing single tool sequentially`),Z=new Map,ie=new Map;for(let _ of Y){let ae=Date.now(),Me=await this.executeTool(_,m,i);Z.set(_.id,Date.now()-ae),ie.set(_.id,Me)}}}finally{U=!0,clearInterval(Q)}for(;H.length>0;)yield H.shift();await new Promise(_=>setTimeout(_,0)),y(`[AIClient][${n}] stream() tool batch completed in ${Date.now()-xe}ms`);for(let _ of Y){let ae=ie.get(_.id),Me=typeof ae=="string"?ae:JSON.stringify(ae),Lt=ft-Te,Lw=Z.get(_.id)??0,Qe;Te+Me.length>ft?(I(`[AIClient][${n}] Tool output budget exceeded (${ft} chars)`),Qe=this.budgetTruncate(Me,Lt)):typeof ae=="string"&&ae.length>this.toolResultMaxChars?Qe=`${ae.slice(0,this.toolResultMaxChars)}
|
|
412
|
+
[TRUNCATED tool result: ${ae.length} chars]`:Qe=Me;let ca=typeof Qe=="string"?Qe:JSON.stringify(Qe);Te+=ca.length,M.push({role:"tool",tool_call_id:_.id,content:Qe}),yield{delta:"",tool_calls:[{..._,result:ca,duration:Lw}]}}y(`[AIClient][${n}] Round tool output size: ${Te} chars (budget: ${ft})`),tt("debug")&&(y(`[AIClient][${n}] stream() after_tools messages=${M.length}`),Rn(n,M))}}catch(n){throw this.wrapError(n)}}async embed(e,t){let o=this.getProvider(t);try{return await o.embed(e)}catch(n){throw this.wrapError(n)}}async enrichRequestWithTools(e,t){if(t?.blockAllTools)return P(`[AIClient] Mode "${t.displayName}" blocks all tools`),{request:e,requestToolMap:new Map};let o=this.buildRequestToolMap(e.requestTools),n=Array.from(o.values()).map(d=>this.requestToolToSchema(d)),s=o.size>0;if(!this.toolsConfig.enabled&&!s)return y("[AIClient] Tools disabled and no request-scoped tools"),{request:e,requestToolMap:o};let i=this.toolsConfig;if(t?.toolSearch&&this.toolsConfig.toolSearch&&(i={...this.toolsConfig,toolSearch:{...this.toolsConfig.toolSearch,...t.toolSearch.enabled!==void 0?{enabled:t.toolSearch.enabled}:{},...t.toolSearch.alwaysLoadedTools?{alwaysLoadedTools:t.toolSearch.alwaysLoadedTools}:{},...t.toolSearch.alwaysLoadedCategories?{alwaysLoadedCategories:t.toolSearch.alwaysLoadedCategories}:{}}},y(`[AIClient] Merged mode toolSearch config: enabled=${i.toolSearch?.enabled}, alwaysLoadedTools=${i.toolSearch?.alwaysLoadedTools?.length||0}`)),e.tools&&e.tools.length>0){if(!i.toolSearch?.enabled||!this.toolRegistry){y(`[AIClient] Request already has ${e.tools.length} tools`);let T=this.mergeToolCallRequests(e.tools,this.schemasToToolCallRequests(n)),v=T===e.tools?e:{...e,tools:T};return{request:this.injectRequestToolGuidance(v,T),requestToolMap:o}}let d=await this.toolRouter.resolve(e.messages,this.toolRegistry,i);if(y(`[AIClient] Resolved ${d.length} tools to send: ${d.map(T=>T.name).join(", ")||"none"}`),t&&d.length>0){let T=d.length;d=this.filterSchemasByMode(d,t);let v=T-d.length;v>0&&P(`[AIClient] Mode "${t.displayName}" filtered out ${v} tools`)}let g=new Set(e.tools.map(T=>T.function.name)),b=d.filter(T=>!g.has(T.name)).map(T=>({type:"function",function:{name:T.name,description:T.description,parameters:T.parameters}}));if(b.length===0){y(`[AIClient] Request already has ${e.tools.length} tools (no new discoveries)`);let T=this.mergeToolCallRequests(e.tools,this.schemasToToolCallRequests(n)),v=T===e.tools?e:{...e,tools:T};return{request:this.injectRequestToolGuidance(v,T),requestToolMap:o}}let w={...e,tools:this.mergeToolCallRequests([...e.tools,...b],this.schemasToToolCallRequests(n))};return i.toolSearch?.enabled&&this.toolRegistry&&(w=this.injectToolSearchPrompt(w)),{request:this.injectRequestToolGuidance(w,w.tools),requestToolMap:o}}if(!this.toolRegistry){y("[AIClient] Tool registry not configured, skipping tool resolution");let d=this.schemasToToolCallRequests(n),g=d.length>0?{...e,tools:d}:e;return{request:this.injectRequestToolGuidance(g,d),requestToolMap:o}}let a=this.toolRegistry,l=await this.toolRouter.resolve(e.messages,a,i);if(y(`[AIClient] Resolved ${l.length} tools to send: ${l.map(d=>d.name).join(", ")||"none"}`),t&&l.length>0){let d=l.length;l=this.filterSchemasByMode(l,t);let g=d-l.length;g>0&&P(`[AIClient] Mode "${t.displayName}" filtered out ${g} tools`)}let p=this.schemasToToolCallRequests(this.mergeSchemas(l,n));if(p.length===0)return{request:e,requestToolMap:o};let m={...e,tools:p};return this.toolsConfig.toolSearch?.enabled&&a&&(m=this.injectToolSearchPrompt(m)),{request:this.injectRequestToolGuidance(m,p),requestToolMap:o}}buildRequestToolMap(e){let t=new Map;for(let o of e||[])t.set(o.name,o);return t}requestToolToSchema(e){return{name:e.name,displayName:e.displayName,description:e.description,parameters:e.parameters,category:e.category,cacheable:e.cacheable}}mergeSchemas(e,t){let o=new Map;for(let n of e)o.set(n.name,n);for(let n of t)o.set(n.name,n);return Array.from(o.values())}schemasToToolCallRequests(e){return e.map(t=>({type:"function",function:{name:t.name,description:t.description,parameters:t.parameters}}))}mergeToolCallRequests(e,t){if(t.length===0)return e;let o=new Map;for(let n of e)o.set(n.function.name,n);for(let n of t)o.set(n.function.name,n);return Array.from(o.values())}injectRequestToolGuidance(e,t){let o=new Set((t||e.tools||[]).map(l=>l.function.name));if(o.size===0)return e;let n="<!-- TOOLPACK_REQUEST_TOOL_GUIDANCE -->",s=[];if(o.has("knowledge_search")||o.has("knowledge_add")){let l=["Knowledge Base:"];o.has("knowledge_search")&&l.push("- Use `knowledge_search` when you need factual or domain-specific information that may already be stored."),o.has("knowledge_add")&&l.push("- Use `knowledge_add` when you encounter a durable fact, user preference, or decision that future conversations should know. Do not add confidential information, routine task outputs, or context that is specific to this conversation only."),s.push(l.join(`
|
|
413
413
|
`))}if(o.has("conversation_search")&&s.push("Conversation History:\n- Only recent messages may be present in context.\n- Use `conversation_search` to find relevant details from earlier in this conversation when needed."),s.length===0)return e;let i=`${n}
|
|
414
414
|
${s.join(`
|
|
415
415
|
|
|
416
416
|
`)}`,a=e.messages.findIndex(l=>l.role==="system");if(a>=0){let l=e.messages.map((p,m)=>{if(m!==a)return p;let d=typeof p.content=="string"?p.content:"";return d.includes(n)?p:{...p,content:`${d}
|
|
417
417
|
|
|
418
|
-
${i}`.trim()}});return{...e,messages:l}}return{...e,messages:[{role:"system",content:i},...e.messages]}}stripRequestTools(e){let{requestTools:t,...
|
|
418
|
+
${i}`.trim()}});return{...e,messages:l}}return{...e,messages:[{role:"system",content:i},...e.messages]}}stripRequestTools(e){let{requestTools:t,mode:o,...n}=e;return n}resolveRequestMode(e){return e.mode===void 0?this.activeMode:e.mode===null?null:typeof e.mode=="string"?(I(`[AIClient] Unresolved mode name "${e.mode}" on request \u2014 falling back to active mode. Pass requests through Toolpack.generate()/stream() to resolve mode names.`),this.activeMode):e.mode}filterSchemasByMode(e,t){return e.filter(o=>{if(t.blockedTools.includes(o.name)||t.blockedToolCategories.includes(o.category))return!1;if(bt(o.name)){let i=t.toolSearch?.enabled;if(i!==void 0?i:this.toolsConfig.toolSearch?.enabled??!1)return!0}let n=t.allowedTools.length>0,s=t.allowedToolCategories.length>0;if(n||s){let i=n&&t.allowedTools.includes(o.name),a=s&&t.allowedToolCategories.includes(o.category);return i||a}return!0})}injectModeSystemPrompt(e,t){if(!t||!t.systemPrompt)return y(`[AIClient] injectModeSystemPrompt: No active mode or empty systemPrompt. mode=${t?.name}, systemPrompt=${t?.systemPrompt?.substring(0,50)}`),e;let o=t.systemPrompt;if(y(`[AIClient] injectModeSystemPrompt: Injecting mode prompt for ${t.name}, length=${o.length}`),e.messages.some(s=>s.role==="system")){let s=e.messages.map(i=>{if(i.role==="system"){let a=typeof i.content=="string"?i.content:"";return{...i,content:`${a}
|
|
419
419
|
|
|
420
|
-
${
|
|
420
|
+
${o}`}}return i});return{...e,messages:s}}else return{...e,messages:[{role:"system",content:o},...e.messages]}}injectOverrideSystemPrompt(e){if(!this.overrideSystemPrompt)return e;let t=this.overrideSystemPrompt;if(e.messages.some(n=>n.role==="system")){let n=e.messages.map(s=>{if(s.role==="system"){let i=typeof s.content=="string"?s.content:"";return{...s,content:`${i}
|
|
421
421
|
|
|
422
|
-
${t}`}}return s});return{...e,messages:n}}else return{...e,messages:[{role:"system",content:t},...e.messages]}}injectBaseAgentContext(e){let
|
|
422
|
+
${t}`}}return s});return{...e,messages:n}}else return{...e,messages:[{role:"system",content:t},...e.messages]}}injectBaseAgentContext(e,t){let o=!0,n=!0,s,i=this.disableBaseContext;if(t?.baseContext===!1)return e;t?.baseContext&&(o=t.baseContext.includeWorkingDirectory!==!1,n=t.baseContext.includeToolCategories!==!1,s=t.baseContext.custom);let a=s||Ra({workingDirectory:process.cwd(),toolCategories:this.toolRegistry?this.toolRegistry.getCategories():[],disabled:i,includeWorkingDirectory:o,includeToolCategories:n});if(!a)return e;if(e.messages.some(p=>p.role==="system")){let p=e.messages.map(m=>{if(m.role==="system"){let d=typeof m.content=="string"?m.content:"";return{...m,content:`${a}
|
|
423
423
|
|
|
424
|
-
${
|
|
424
|
+
${d}`}}return m});return{...e,messages:p}}else return{...e,messages:[{role:"system",content:a},...e.messages]}}injectToolSearchPrompt(e){if(!this.toolRegistry)return e;let t=e.messages.some(i=>i.role==="system"),o=this.toolsConfig.toolSearch?.alwaysLoadedTools??[],n="";if(o.length>0){let i=o.map(a=>{let l=this.toolRegistry?.get(a);return l?` - **${l.name}**: ${l.description}`:null}).filter(Boolean).join(`
|
|
425
425
|
`);i&&(n=`
|
|
426
426
|
|
|
427
427
|
You have these tools always available:
|
|
@@ -432,7 +432,7 @@ IMPORTANT: Tool Discovery Instructions
|
|
|
432
432
|
|
|
433
433
|
You have access to a limited set of tools. If you need a tool that is not in your current list, you MUST use the 'tool.search' tool to discover it.${n}
|
|
434
434
|
|
|
435
|
-
${
|
|
435
|
+
${Zr(this.toolRegistry)}
|
|
436
436
|
|
|
437
437
|
When you need a tool:
|
|
438
438
|
1. Check if it's in your current tool list
|
|
@@ -442,11 +442,11 @@ When you need a tool:
|
|
|
442
442
|
NEVER guess or hallucinate tool names. ALWAYS use tool.search to discover tools you don't have.
|
|
443
443
|
`.trim();if(t){let i=e.messages.map(a=>{if(a.role==="system"){let l=typeof a.content=="string"?a.content:"";return{...a,content:`${l}
|
|
444
444
|
|
|
445
|
-
${s}`}}return a});return{...e,messages:i}}else return{...e,messages:[{role:"system",content:s},...e.messages]}}async executeTool(e,t){let
|
|
446
|
-
[Output truncated \u2014 round budget reached. Call the tool again with a narrower query to retrieve more.]`,s=t-o.length;return s>=100?e.slice(0,s)+o:"[Tool output omitted \u2014 round budget exhausted. Call the tool again with a narrower query.]"}};c();c();import
|
|
445
|
+
${s}`}}return a});return{...e,messages:i}}else return{...e,messages:[{role:"system",content:s},...e.messages]}}async executeTool(e,t,o){let n=Date.now();this.emit("tool:started",{toolName:e.name,toolCallId:e.id,status:"started",args:e.arguments}),P(`[AIClient] Executing tool: ${e.name} with args: ${A(e.arguments,500)}`);let s=t.get(e.name),i=s?void 0:this.toolRegistry?.get(e.name);if(!s&&!this.toolRegistry){let l="No tool registry configured";return this.emit("tool:failed",{toolName:e.name,toolCallId:e.id,status:"failed",error:l,duration:Date.now()-n}),JSON.stringify({error:l})}if(bt(e.name)){let l=this.executeToolSearch(e.arguments,o),p=Date.now()-n;return this.emit("tool:completed",{toolName:e.name,toolCallId:e.id,status:"completed",result:typeof l=="string"?l.substring(0,200):JSON.stringify(l).substring(0,200),duration:p}),this.emit("tool:log",{id:e.id,name:e.name,arguments:e.arguments,result:l,duration:p,status:"success",timestamp:Date.now()}),l}let a=s||i;if(!a){I(`[AIClient] Tool '${e.name}' not found in registry`);let l=this.findSimilarToolName(e.name),p=l?`Tool '${e.name}' not found. Did you mean '${l}'? Use tool.search to discover available tools.`:`Tool '${e.name}' not found. Use tool.search to discover available tools.`;return this.emit("tool:failed",{toolName:e.name,toolCallId:e.id,status:"failed",error:p,duration:Date.now()-n}),JSON.stringify({error:p})}try{let l=e.arguments;if(i?.confirmation&&this.onToolConfirm&&!this.isBypassed(i)){this.emit("tool:confirmation_requested",{tool:i,args:l,level:i.confirmation.level,reason:i.confirmation.reason});let b=await this.onToolConfirm(i,l,{roundNumber:this.currentRound,conversationId:this.conversationId});if(this.emit("tool:confirmation_resolved",{tool:i,args:l,level:i.confirmation.level,reason:i.confirmation.reason,decision:b}),b.action==="deny"){let w=`[Execution denied by user${b.reason?": "+b.reason:""}]`,T=Date.now()-n;return this.emit("tool:completed",{toolName:e.name,toolCallId:e.id,status:"completed",result:w,duration:T}),this.emit("tool:log",{id:e.id,name:e.name,arguments:l,result:w,duration:T,status:"success",timestamp:Date.now()}),w}b.action==="modify"&&(l=b.args)}let p={workspaceRoot:process.cwd(),config:this.toolsConfig?.additionalConfigurations??{},log:b=>P(`[Tool] ${b}`)},m=s?await s.execute(l):await a.execute(l,p),d=Date.now()-n;this.emit("tool:completed",{toolName:e.name,toolCallId:e.id,status:"completed",result:typeof m=="string"?m.substring(0,200):JSON.stringify(m).substring(0,200),duration:d}),this.emit("tool:log",{id:e.id,name:e.name,arguments:e.arguments,result:m,duration:d,status:"success",timestamp:Date.now()});let g=typeof m=="string"?m.length:JSON.stringify(m).length;return P(`[AIClient] Tool ${e.name} executed successfully in ${d}ms result_len=${g}`),tt("debug")&&y(`[AIClient] Tool ${e.name} result_preview=${A(m,400)}`),typeof m=="string"?m:JSON.stringify(m)}catch(l){let p=Date.now()-n,m=l.message||"Tool execution failed";return this.emit("tool:failed",{toolName:e.name,toolCallId:e.id,status:"failed",error:m,duration:p}),this.emit("tool:log",{id:e.id,name:e.name,arguments:e.arguments,result:JSON.stringify({error:m}),duration:p,status:"error",timestamp:Date.now()}),pe(`[AIClient] Tool ${e.name} failed: ${A(m,300)}`),JSON.stringify({error:m})}}findSimilarToolName(e){if(!this.toolRegistry)return null;let t=this.toolRegistry.getAll(),o=e.replace(/_/g,".");if(t.some(l=>l.name===o))return o;let n=e.replace(/\./g,"_");if(t.some(l=>l.name===n))return n;let s=e.replace(/([a-z])([A-Z])/g,"$1_$2").toLowerCase().replace(/_/g,".");if(t.some(l=>l.name===s))return s;let i=null,a=1/0;for(let l of t){let p=this.levenshteinDistance(e.toLowerCase(),l.name.toLowerCase());p<=2&&p<a&&(a=p,i=l.name)}return i}levenshteinDistance(e,t){let o=[];for(let n=0;n<=t.length;n++)o[n]=[n];for(let n=0;n<=e.length;n++)o[0][n]=n;for(let n=1;n<=t.length;n++)for(let s=1;s<=e.length;s++)t.charAt(n-1)===e.charAt(s-1)?o[n][s]=o[n-1][s-1]:o[n][s]=Math.min(o[n-1][s-1]+1,o[n][s-1]+1,o[n-1][s]+1);return o[t.length][e.length]}executeToolSearch(e,t){let{query:o,category:n}=e,s=this.toolsConfig.toolSearch?.searchResultLimit??5,i=typeof n=="string"&&n.length>0?n:void 0,a=t===void 0?this.activeMode:t;if(a&&!(this.filterSchemasByMode([Ze()],a).length>0))return I("[AIClient] tool.search blocked by active mode"),JSON.stringify({query:o,found:0,tools:[],hint:"tool.search is not allowed in the current mode."});P(`[AIClient] Executing tool.search: query="${o}" category=${i||"all"} limit=${s}`);let l=a?Math.max(s*4,s):s,p=this.bm25Engine.search(o,{limit:l,category:i});if(a&&p.length>0){let d=this.filterSchemasByMode(p.map(T=>T.tool),a),g=new Set(d.map(T=>T.name)),b=p.length;p=p.filter(T=>g.has(T.toolName));let w=b-p.length;w>0&&y(`[AIClient] tool.search filtered out ${w} disallowed results for mode "${a.displayName}"`)}p.length>s&&(p=p.slice(0,s));let m=p.map(d=>d.toolName);return this.toolRouter.getDiscoveryCache().recordDiscovery(o,m),y(`[AIClient] tool.search found ${p.length} tools: ${m.join(", ")||"none"}`),JSON.stringify({query:o,found:p.length,tools:p.map(d=>({name:d.tool.name,displayName:d.tool.displayName,description:d.tool.description,category:d.tool.category,parameters:d.tool.parameters,relevanceScore:Math.round(d.score*100)/100})),hint:p.length>0?`Found ${p.length} tools. You can now call any of these tools directly.`:`No tools found for "${o}". Try a different search term.`})}wrapError(e){return e instanceof N?e:new W(e.message||"Unknown provider error","UNKNOWN_PROVIDER_ERROR",500,e)}budgetTruncate(e,t){let o=`
|
|
446
|
+
[Output truncated \u2014 round budget reached. Call the tool again with a narrower query to retrieve more.]`,s=t-o.length;return s>=100?e.slice(0,s)+o:"[Tool output omitted \u2014 round budget exhausted. Call the tool again with a narrower query.]"}};c();c();import Ga from"@anthropic-ai/sdk";import{zodOutputFormat as pT}from"@anthropic-ai/sdk/helpers/zod";c();le();var oe=class{name;async getModels(){return[]}getDisplayName(){return this.name||this.constructor.name.replace(/Adapter$/,"")}supportsFileUpload(){return!1}async uploadFile(e){throw new L(`File upload API is not supported by ${this.getDisplayName()}`)}async deleteFile(e){throw new L(`File deletion API is not supported by ${this.getDisplayName()}`)}async countTokens(e,t){return null}};le();S();var $n=class extends oe{client;constructor(e,t){super(),this.client=new Ga({apiKey:e,baseURL:t})}supportsFileUpload(){return!0}async uploadFile(e){try{let t=await import("fs");if(!e.filePath)throw new L("Anthropic uploadFile requires a filePath.");return{id:(await this.client.files.create({file:t.createReadStream(e.filePath),purpose:e.purpose||"vision"})).id}}catch(t){throw this.handleError(t)}}async deleteFile(e){try{await this.client.files.delete(e)}catch(t){throw this.handleError(t)}}getDisplayName(){return"Anthropic"}async getModels(){return[{id:"claude-haiku-4-5-20251001",displayName:"Claude Haiku 4.5",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:2e5,maxOutputTokens:64e3},{id:"claude-sonnet-4-5-20250929",displayName:"Claude Sonnet 4.5",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:2e5,maxOutputTokens:16384},{id:"claude-sonnet-4-6",displayName:"Claude Sonnet 4.6",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:2e5,maxOutputTokens:16384},{id:"claude-opus-4-5",displayName:"Claude Opus 4.5",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:2e5,maxOutputTokens:16384},{id:"claude-opus-4-6",displayName:"Claude Opus 4.6",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:2e5,maxOutputTokens:16384}]}sanitizeToolName(e){return e.replace(/\./g,"_")}restoreToolName(e,t){return t?.find(n=>this.sanitizeToolName(n.function.name)===e)?.function.name||e.replace(/_/g,".")}async generate(e){try{let t=e.__toolpack_request_id||`gen-${Date.now()}`,o=await this.toAnthropicMessages(e.messages,e.mediaOptions),n=o.system,s=o.userMessages,i={model:e.model,messages:s,system:n,max_tokens:e.max_tokens||4096,temperature:e.temperature,top_p:e.top_p,stream:!1};e.tools&&e.tools.length>0?(i.tools=e.tools.map(b=>({name:this.sanitizeToolName(b.function.name),description:b.function.description,input_schema:b.function.parameters})),e.tool_choice==="required"?i.tool_choice={type:"any"}:e.tool_choice==="none"?delete i.tools:i.tool_choice={type:"auto"},y(`[Anthropic][${t}] Sending ${i.tools?.length||0} tools with tool_choice: ${i.tool_choice?.type||"unset"}`),i.tools&&i.tools.length>0&&y(`[Anthropic][${t}] First tool: ${A(i.tools[0],800)}`)):y(`[Anthropic][${t}] NO TOOLS in request`),y(`[Anthropic][${t}] generate() request: model=${i.model}, messages=${i.messages.length}, tools=${i.tools?.length||0}, tool_choice=${i.tool_choice?.type??"unset"}`),te(t,"Anthropic",i.messages);let a=e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format;a&&(i.output_config={format:pT(e.response_format)});let p=a?await this.client.messages.parse(i,e.signal?{signal:e.signal}:void 0):await this.client.messages.create(i,e.signal?{signal:e.signal}:void 0),m=[],d=[];for(let b of p.content)b.type==="text"?m.push(b.text):b.type==="tool_use"&&d.push({id:b.id,name:this.restoreToolName(b.name,e.tools),arguments:b.input});y(`[Anthropic][${t}] Response finish_reason=${p.stop_reason} tool_calls=${d.length} content_preview=${A(m.join(""),200)}`);let g={content:m.length>0?m.join(""):null,usage:{prompt_tokens:p.usage.input_tokens,completion_tokens:p.usage.output_tokens,total_tokens:p.usage.input_tokens+p.usage.output_tokens},finish_reason:this.mapFinishReason(p.stop_reason),tool_calls:d.length>0?d:void 0,raw:p};return a&&p.parsed_output!==void 0&&(g.data=p.parsed_output),g}catch(t){throw this.handleError(t)}}async*stream(e){try{let t=e.__toolpack_request_id||`str-${Date.now()}`,o=await this.toAnthropicMessages(e.messages,e.mediaOptions),n={model:e.model,messages:o.userMessages,system:o.system,max_tokens:e.max_tokens||4096,temperature:e.temperature,top_p:e.top_p,stream:!0};e.tools&&e.tools.length>0?(n.tools=e.tools.map(m=>({name:this.sanitizeToolName(m.function.name),description:m.function.description,input_schema:m.function.parameters})),e.tool_choice==="required"?n.tool_choice={type:"any"}:e.tool_choice==="none"?delete n.tools:n.tool_choice={type:"auto"},y(`[Anthropic][${t}] Sending ${n.tools?.length||0} tools with tool_choice: ${n.tool_choice?.type||"unset"}`),n.tools&&n.tools.length>0&&y(`[Anthropic][${t}] First tool: ${A(n.tools[0],800)}`)):y(`[Anthropic][${t}] NO TOOLS in request`),y(`[Anthropic][${t}] Stream request: model=${n.model}, messages=${n.messages.length}, tools=${n.tools?.length||0}, tool_choice=${n.tool_choice?.type??"unset"}`),te(t,"Anthropic",n.messages);let s=await this.client.messages.create(n,e.signal?{signal:e.signal}:void 0),i="",a="",l="",p=!1;for await(let m of s)m.type==="content_block_start"&&m.content_block?.type==="tool_use"&&(p=!0,i=m.content_block.id,a=m.content_block.name,l=""),m.type==="content_block_delta"&&(m.delta.type==="text_delta"?yield{delta:m.delta.text}:m.delta.type==="input_json_delta"&&p&&(l+=m.delta.partial_json)),m.type==="content_block_stop"&&p&&(y(`[Anthropic][${t}] Stream finish_reason=tool_calls accumulated_call=${a}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:[{id:i,name:this.restoreToolName(a,e.tools),arguments:JSON.parse(l||"{}")}]},p=!1),m.type==="message_stop"&&(je(`[Anthropic][${t}] Stream chunk finish_reason=stop`),yield{delta:"",finish_reason:"stop"})}catch(t){throw this.handleError(t)}}async embed(e){throw new L("Embeddings are not strictly supported by the Anthropic API currently.")}async toAnthropicMessages(e,t={}){let o,n=[],{normalizeImagePart:s}=await Promise.resolve().then(()=>(xt(),Kt));for(let i of e)if(i.role==="system"){if(typeof i.content=="string")o=i.content;else if(i.content!==null){let a=i.content.filter(l=>typeof l=="object"&&l.type==="text").map(l=>l.text).join(`
|
|
447
447
|
`);a&&(o=a)}}else if(i.role==="tool"&&i.tool_call_id)n.push({role:"user",content:[{type:"tool_result",tool_use_id:i.tool_call_id,content:typeof i.content=="string"?i.content:JSON.stringify(i.content)}]});else if(i.role==="assistant"&&i.tool_calls&&i.tool_calls.length>0){let a=[];if(typeof i.content=="string"&&i.content)a.push({type:"text",text:i.content});else if(Array.isArray(i.content)){let l=i.content.filter(p=>typeof p=="object"&&p.type==="text").map(p=>p.text).join(`
|
|
448
|
-
`);l&&a.push({type:"text",text:l})}for(let l of i.tool_calls)a.push({type:"tool_use",id:l.id,name:this.sanitizeToolName(l.function.name),input:typeof l.function.arguments=="string"?JSON.parse(l.function.arguments||"{}"):l.function.arguments});n.push({role:"assistant",content:a})}else{let a=[];typeof i.content=="string"?a=i.content:i.content!==null&&(a=(await Promise.all(i.content.map(async l=>{if(l.type==="text")return{type:"text",text:l.text};if(l.type==="image_url"){let p=l.image_url.url;if(p.startsWith("data:")){let m=p.match(/^data:(image\/\w+);base64,(.+)$/);if(m)return{type:"image",source:{type:"base64",media_type:m[1],data:m[2]}}}return{type:"image",source:{type:"url",url:p}}}if(l.type==="image_data"||l.type==="image_file"){let{data:p,mimeType:m}=await s(l);return{type:"image",source:{type:"base64",media_type:m,data:p}}}return null}))).filter(Boolean)),n.push({role:i.role==="user"?"user":"assistant",content:a})}return{system:o,userMessages:n}}mapFinishReason(e){return e==="end_turn"?"stop":e==="max_tokens"?"length":e==="stop_sequence"?"stop":e}handleError(e){if(e instanceof
|
|
449
|
-
`)}sanitizeToolName(e){return e.replace(/\./g,"_")}restoreToolName(e,t){return t?.find(n=>this.sanitizeToolName(n.function.name)===e)?.function.name??e.replace(/_/g,".")}sanitizeSchema(e){if(!e||typeof e!="object")return e;let t={};for(let[o,n]of Object.entries(e))["additionalProperties","exclusiveMinimum","exclusiveMaximum","$schema","$id","definitions","$defs"].includes(o)||(t[o]=typeof n=="object"&&n!==null?Array.isArray(n)?n.map(s=>this.sanitizeSchema(s)):this.sanitizeSchema(n):n);return t}handleError(e){let t=e?.message??String(e);return e?.status===429||t.includes("RESOURCE_EXHAUSTED")?new fe(t,void 0,e):e?.status===401||e?.status===403||t.includes("UNAUTHENTICATED")||t.includes("PERMISSION_DENIED")?new
|
|
448
|
+
`);l&&a.push({type:"text",text:l})}for(let l of i.tool_calls)a.push({type:"tool_use",id:l.id,name:this.sanitizeToolName(l.function.name),input:typeof l.function.arguments=="string"?JSON.parse(l.function.arguments||"{}"):l.function.arguments});n.push({role:"assistant",content:a})}else{let a=[];typeof i.content=="string"?a=i.content:i.content!==null&&(a=(await Promise.all(i.content.map(async l=>{if(l.type==="text")return{type:"text",text:l.text};if(l.type==="image_url"){let p=l.image_url.url;if(p.startsWith("data:")){let m=p.match(/^data:(image\/\w+);base64,(.+)$/);if(m)return{type:"image",source:{type:"base64",media_type:m[1],data:m[2]}}}return{type:"image",source:{type:"url",url:p}}}if(l.type==="image_data"||l.type==="image_file"){let{data:p,mimeType:m}=await s(l);return{type:"image",source:{type:"base64",media_type:m,data:p}}}return null}))).filter(Boolean)),n.push({role:i.role==="user"?"user":"assistant",content:a})}return{system:o,userMessages:n}}mapFinishReason(e){return e==="end_turn"?"stop":e==="max_tokens"?"length":e==="stop_sequence"?"stop":e}handleError(e){if(e instanceof Ga.APIError){let t=e.message;return e.status===401?new ve(t,e):e.status===429?new fe(t,void 0,e):e.status&&e.status>=400&&e.status<500?new L(t,e):new W(t,"ANTHROPIC_ERROR",e.status||500,e)}return new W("Unknown Anthropic error","UNKNOWN",500,e)}};c();import{GoogleGenAI as mT}from"@google/genai";import{zodToJsonSchema as dT}from"zod-to-json-schema";le();S();var En=class extends oe{ai;location;constructor(e={}){super(),this.name="vertexai";let t=e.projectId??process.env.TOOLPACK_VERTEXAI_PROJECT??process.env.VERTEX_AI_PROJECT??process.env.GOOGLE_CLOUD_PROJECT;if(!t)throw new ve("Vertex AI requires a GCP project ID. Pass projectId in config or set TOOLPACK_VERTEXAI_PROJECT / VERTEX_AI_PROJECT / GOOGLE_CLOUD_PROJECT.");this.location=e.location??process.env.TOOLPACK_VERTEXAI_LOCATION??process.env.VERTEX_AI_LOCATION??"us-central1",this.ai=new mT({vertexai:!0,project:t,location:this.location,...e.googleAuthOptions?{googleAuthOptions:e.googleAuthOptions}:{}})}getDisplayName(){return"Google Vertex AI"}async getModels(){return[{id:"gemini-2.5-pro-preview-05-06",displayName:"Gemini 2.5 Pro Preview",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0},contextWindow:1048576,maxOutputTokens:65536},{id:"gemini-2.5-flash-preview-04-17",displayName:"Gemini 2.5 Flash Preview",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0},contextWindow:1048576,maxOutputTokens:65536},{id:"gemini-2.0-flash-001",displayName:"Gemini 2.0 Flash",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0},contextWindow:1048576,maxOutputTokens:8192},{id:"gemini-1.5-pro-002",displayName:"Gemini 1.5 Pro",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0},contextWindow:2097152,maxOutputTokens:8192},{id:"gemini-1.5-flash-002",displayName:"Gemini 1.5 Flash",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0},contextWindow:1048576,maxOutputTokens:8192}]}async generate(e){try{let t=e.__toolpack_request_id||`vtx-${Date.now()}`;y(`[VertexAI][${t}] generate() model=${e.model} messages=${e.messages.length} tools=${e.tools?.length??0}`),te(t,"VertexAI",e.messages);let{model:o,config:n}=this.buildRequestParams(e),{history:s,lastUserMessage:i}=this.formatHistory(e.messages),a=[...s,{role:"user",parts:typeof i=="string"?[{text:i}]:i}],l=await this.ai.models.generateContent({model:o,contents:a,config:n}),{content:p,toolCalls:m}=this.parseResponse(l,e.tools);return y(`[VertexAI][${t}] Response finish_reason=${m.length>0?"tool_calls":"stop"} tool_calls=${m.length} content_preview=${A(p,200)}`),{content:p||null,usage:{prompt_tokens:l.usageMetadata?.promptTokenCount??0,completion_tokens:l.usageMetadata?.candidatesTokenCount??0,total_tokens:l.usageMetadata?.totalTokenCount??0},finish_reason:m.length>0?"tool_calls":"stop",tool_calls:m.length>0?m:void 0,raw:l}}catch(t){throw this.handleError(t)}}async*stream(e){try{let t=e.__toolpack_request_id||`vtx-str-${Date.now()}`;y(`[VertexAI][${t}] stream() model=${e.model} messages=${e.messages.length} tools=${e.tools?.length??0}`),te(t,"VertexAI",e.messages);let{model:o,config:n}=this.buildRequestParams(e),{history:s,lastUserMessage:i}=this.formatHistory(e.messages),a=[...s,{role:"user",parts:typeof i=="string"?[{text:i}]:i}],l=await this.ai.models.generateContentStream({model:o,contents:a,config:n});for await(let p of l)for(let m of p.candidates??[])for(let d of m.content?.parts??[])if(d.functionCall){let g=d.functionCall;y(`[VertexAI][${t}] stream tool_call name=${g.name}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:[{id:`vtx_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,name:this.restoreToolName(g.name,e.tools),arguments:g.args??{}}]}}else d.text&&(yield{delta:d.text})}catch(t){throw this.handleError(t)}}async embed(e){throw new L("Vertex AI embeddings are not supported by this adapter. Use the Gemini adapter (gemini provider) with text-embedding-004 instead.")}buildRequestParams(e){let t=e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format,o={systemInstruction:this.extractSystemInstruction(e.messages),maxOutputTokens:e.max_tokens,temperature:e.temperature,topP:e.top_p,responseMimeType:(e.response_format==="json_object"||t)&&!e.tools?.length?"application/json":"text/plain",...t&&!e.tools?.length?{responseSchema:this.sanitizeSchema(dT(e.response_format))}:{}};return e.tools&&e.tools.length>0&&(o.tools=[{functionDeclarations:e.tools.map(n=>({name:this.sanitizeToolName(n.function.name),description:n.function.description,parameters:this.sanitizeSchema(n.function.parameters)}))}]),{model:e.model,config:o}}formatHistory(e){let t=e.filter(a=>a.role!=="system");if(t.length===0)return{history:[],lastUserMessage:""};let o=t.slice(0,-1),n=t[t.length-1],s=o.map(a=>{if(a.role==="tool"&&a.tool_call_id)return{role:"function",parts:[{functionResponse:{name:this.sanitizeToolName(a.name??a.tool_call_id),response:{name:this.sanitizeToolName(a.name??a.tool_call_id),content:typeof a.content=="string"?a.content:JSON.stringify(a.content)}}}]};if(a.role==="assistant"&&a.tool_calls&&a.tool_calls.length>0){let l=[];typeof a.content=="string"&&a.content&&l.push({text:a.content});for(let p of a.tool_calls)l.push({functionCall:{name:this.sanitizeToolName(p.function.name),args:typeof p.function.arguments=="string"?JSON.parse(p.function.arguments||"{}"):p.function.arguments}});return{role:"model",parts:l}}return{role:a.role==="user"?"user":"model",parts:this.contentToParts(a.content)}}),i=[];for(let a of s){let l=i[i.length-1];a.role==="function"&&l?.role==="function"?l.parts.push(...a.parts):i.push(a)}return{history:i,lastUserMessage:this.contentToParts(n.content)}}contentToParts(e){return typeof e=="string"?[{text:e}]:e?e.map(t=>t.type==="text"?{text:t.text}:t.type==="image_data"?{inlineData:{mimeType:t.mimeType??"image/jpeg",data:t.data}}:null).filter(t=>t!==null):[]}parseResponse(e,t){let o=[],n="";for(let s of e.candidates??[])for(let i of s.content?.parts??[])if(i.text&&(n+=i.text),i.functionCall){let a=i.functionCall;o.push({id:`vtx_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,name:this.restoreToolName(a.name,t),arguments:a.args??{}})}return{content:n,toolCalls:o}}extractSystemInstruction(e){let t=e.filter(o=>o.role==="system");if(t.length!==0)return t.map(o=>typeof o.content=="string"?o.content:"").join(`
|
|
449
|
+
`)}sanitizeToolName(e){return e.replace(/\./g,"_")}restoreToolName(e,t){return t?.find(n=>this.sanitizeToolName(n.function.name)===e)?.function.name??e.replace(/_/g,".")}sanitizeSchema(e){if(!e||typeof e!="object")return e;let t={};for(let[o,n]of Object.entries(e))["additionalProperties","exclusiveMinimum","exclusiveMaximum","$schema","$id","definitions","$defs"].includes(o)||(t[o]=typeof n=="object"&&n!==null?Array.isArray(n)?n.map(s=>this.sanitizeSchema(s)):this.sanitizeSchema(n):n);return t}handleError(e){let t=e?.message??String(e);return e?.status===429||t.includes("RESOURCE_EXHAUSTED")?new fe(t,void 0,e):e?.status===401||e?.status===403||t.includes("UNAUTHENTICATED")||t.includes("PERMISSION_DENIED")?new ve(t,e):e?.status>=400&&e?.status<500?new L(t,e):new W(t||"Vertex AI Error","VERTEXAI_ERROR",e?.status??500,e)}};c();import{GoogleGenerativeAI as uT}from"@google/generative-ai";import{zodToJsonSchema as Ba}from"zod-to-json-schema";le();S();var Dn=class extends oe{genAI;constructor(e){super(),this.genAI=new uT(e)}supportsFileUpload(){return!0}sanitizeSchema(e){if(!e||typeof e!="object")return e;let t={};for(let[o,n]of Object.entries(e))o==="additionalProperties"||o==="exclusiveMinimum"||o==="exclusiveMaximum"||o==="$schema"||o==="$id"||o==="definitions"||o==="$defs"||(typeof n=="object"&&n!==null?Array.isArray(n)?t[o]=n.map(s=>this.sanitizeSchema(s)):t[o]=this.sanitizeSchema(n):t[o]=n);return t}async uploadFile(e){try{let t=await import("fs"),o=await import("path");if(!e.filePath)throw new L("Gemini uploadFile requires a filePath.");let n=await t.promises.readFile(e.filePath),s=o.basename(e.filePath),i=e.mimeType||"application/octet-stream",l=`https://generativelanguage.googleapis.com/upload/v1beta/files?key=${this.genAI.apiKey}`,p="----WebKitFormBoundary"+Math.random().toString(36).substring(2),m=JSON.stringify({file:{displayName:s}}),d=Buffer.concat([Buffer.from(`--${p}\r
|
|
450
450
|
Content-Type: application/json\r
|
|
451
451
|
\r
|
|
452
452
|
${m}\r
|
|
@@ -455,49 +455,49 @@ Content-Type: ${i}\r
|
|
|
455
455
|
\r
|
|
456
456
|
`),n,Buffer.from(`\r
|
|
457
457
|
--${p}--\r
|
|
458
|
-
`)]),g=await fetch(l,{method:"POST",headers:{"Content-Type":`multipart/related; boundary=${p}`},body:d});if(!g.ok){let
|
|
458
|
+
`)]),g=await fetch(l,{method:"POST",headers:{"Content-Type":`multipart/related; boundary=${p}`},body:d});if(!g.ok){let w=await g.text();throw new Error(`Gemini file upload failed: ${g.status} ${w}`)}let b=await g.json();return{id:b.file?.name||b.name,url:b.file?.uri||b.uri}}catch(t){throw this.handleError(t)}}async deleteFile(e){try{let t=this.genAI.apiKey,o=`https://generativelanguage.googleapis.com/v1beta/${e}?key=${t}`,n=await fetch(o,{method:"DELETE"});if(!n.ok){let s=await n.text();throw new Error(`Gemini file deletion failed: ${n.status} ${s}`)}}catch(t){throw this.handleError(t)}}getDisplayName(){return"Google Gemini"}async getModels(){return[{id:"gemini-3.1-flash-lite-preview",displayName:"Gemini 3.1 Flash-Lite Preview",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1048576,maxOutputTokens:65536},{id:"gemini-3-flash-preview",displayName:"Gemini 3 Flash Preview",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1048576,maxOutputTokens:65536},{id:"gemini-3.1-pro-preview",displayName:"Gemini 3.1 Pro Preview",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1048576,maxOutputTokens:65536}]}sanitizeToolName(e){return e.replace(/\./g,"_")}restoreToolName(e,t){return t?.find(n=>this.sanitizeToolName(n.function.name)===e)?.function.name||e.replace(/_/g,".")}async generate(e){try{let t=e.__toolpack_request_id||`gen-${Date.now()}`,o={model:e.model,systemInstruction:this.extractSystemInstruction(e.messages)};e.tools&&e.tools.length>0?(o.tools=[{functionDeclarations:e.tools.map(g=>({name:this.sanitizeToolName(g.function.name),description:g.function.description,parameters:this.sanitizeSchema(g.function.parameters)}))}],y(`[Gemini][${t}] Sending ${e.tools.length} tools`),e.tools.length>0&&y(`[Gemini][${t}] First tool: ${A(e.tools[0],800)}`)):y(`[Gemini][${t}] NO TOOLS in request`),y(`[Gemini][${t}] generate() request: model=${e.model}, messages=${e.messages.length}, tools=${e.tools?.length||0}`),te(t,"Gemini",e.messages);let n=this.genAI.getGenerativeModel(o),{history:s,lastUserMessage:i}=await this.formatHistory(e.messages,e.mediaOptions),p=await(await n.startChat({history:s,generationConfig:{maxOutputTokens:e.max_tokens,temperature:e.temperature,topP:e.top_p,responseMimeType:(e.response_format==="json_object"||e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format)&&!e.tools?.length?"application/json":"text/plain",...e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format&&!e.tools?.length?{responseSchema:this.sanitizeSchema(Ba(e.response_format))}:{}}}).sendMessage(i)).response,m=[],d="";for(let g of p.candidates||[])for(let b of g.content?.parts||[])if(b.text&&(d+=b.text),b.functionCall){let w=b.functionCall;m.push({id:`gemini_${Date.now()}_${Math.random().toString(36).substring(2,8)}`,name:this.restoreToolName(w.name,e.tools),arguments:w.args||{}})}return y(`[Gemini][${t}] Response finish_reason=${m.length>0?"tool_calls":"stop"} tool_calls=${m.length} content_preview=${A(d,200)}`),{content:d||null,usage:{prompt_tokens:p.usageMetadata?.promptTokenCount||0,completion_tokens:p.usageMetadata?.candidatesTokenCount||0,total_tokens:p.usageMetadata?.totalTokenCount||0},finish_reason:m.length>0?"tool_calls":"stop",tool_calls:m.length>0?m:void 0,raw:p}}catch(t){throw this.handleError(t)}}async*stream(e){try{let t={model:e.model,systemInstruction:this.extractSystemInstruction(e.messages)};e.tools&&e.tools.length>0&&(t.tools=[{functionDeclarations:e.tools.map(p=>({name:this.sanitizeToolName(p.function.name),description:p.function.description,parameters:this.sanitizeSchema(p.function.parameters)}))}]);let o=e.__toolpack_request_id||`str-${Date.now()}`;y(`[Gemini][${o}] Stream request: model=${e.model}, messages=${e.messages.length}, tools=${e.tools?.length||0}`),e.tools&&e.tools.length>0&&y(`[Gemini][${o}] First tool: ${A(e.tools[0],800)}`),te(o,"Gemini",e.messages);let n=this.genAI.getGenerativeModel(t),{history:s,lastUserMessage:i}=await this.formatHistory(e.messages,e.mediaOptions),l=await n.startChat({history:s,generationConfig:{maxOutputTokens:e.max_tokens,temperature:e.temperature,topP:e.top_p,responseMimeType:(e.response_format==="json_object"||e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format)&&!e.tools?.length?"application/json":"text/plain",...e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format&&!e.tools?.length?{responseSchema:this.sanitizeSchema(Ba(e.response_format))}:{}}}).sendMessageStream(i);for await(let p of l.stream){for(let m of p.candidates?.[0]?.content?.parts||[])m.functionCall?(y(`[Gemini][${o}] Stream finish_reason=tool_calls name=${m.functionCall.name}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:[{id:`gemini_${Date.now()}_${Math.random().toString(36).substring(2,8)}`,name:this.restoreToolName(m.functionCall.name,e.tools),arguments:m.functionCall.args||{}}]}):m.text&&(yield{delta:m.text});try{let m=p.text();m&&!p.candidates?.[0]?.content?.parts?.some(d=>d.text)&&(yield{delta:m})}catch{}}}catch(t){throw this.handleError(t)}}async embed(e){try{let t=this.genAI.getGenerativeModel({model:e.model});return Array.isArray(e.input)?{embeddings:await Promise.all(e.input.map(async n=>(await t.embedContent(n)).embedding.values))}:{embeddings:[(await t.embedContent(e.input)).embedding.values]}}catch(t){throw this.handleError(t)}}extractSystemInstruction(e){let t=e.filter(o=>o.role==="system");if(t.length!==0)return t.map(o=>typeof o.content=="string"?o.content:o.content===null?"":o.content.map(n=>n.text).join(`
|
|
459
459
|
`)).join(`
|
|
460
|
-
`)}async formatHistory(e,t={}){let o=e.filter(d=>d.role!=="system");if(o.length===0)return{history:[],lastUserMessage:""};let n=o[o.length-1],s=o.slice(0,o.length-1),{normalizeImagePart:i}=await Promise.resolve().then(()=>(
|
|
461
|
-
`);
|
|
462
|
-
`);d=
|
|
463
|
-
Available models: ${e.map(n=>n.name).join(", ")||"(none)"}`);return e}async listModels(){try{let e=await _e(this.baseUrl,"/api/tags","GET",void 0,5e3);if(e.status!==200)throw new
|
|
460
|
+
`)}async formatHistory(e,t={}){let o=e.filter(d=>d.role!=="system");if(o.length===0)return{history:[],lastUserMessage:""};let n=o[o.length-1],s=o.slice(0,o.length-1),{normalizeImagePart:i}=await Promise.resolve().then(()=>(xt(),Kt)),a=async d=>typeof d=="string"?[{text:d}]:d===null?[]:(await Promise.all(d.map(async b=>{if(b.type==="text")return{text:b.text};if(b.type==="image_data"||b.type==="image_file"||b.type==="image_url")try{let{data:w,mimeType:T}=await i(b);return{inlineData:{mimeType:T,data:w}}}catch{return b.type==="image_url"?{text:`[Image: ${b.image_url.url}]`}:{text:"[Unresolvable Image]"}}return null}))).filter(Boolean),l=await Promise.all(s.map(async d=>{if(d.role==="tool"&&d.tool_call_id)return{role:"function",parts:[{functionResponse:{name:this.sanitizeToolName(d.name||d.tool_call_id),response:{name:this.sanitizeToolName(d.name||d.tool_call_id),content:typeof d.content=="string"?d.content:JSON.stringify(d.content)}}}]};if(d.role==="assistant"&&d.tool_calls&&d.tool_calls.length>0){let g=[];if(typeof d.content=="string"&&d.content)g.push({text:d.content});else if(Array.isArray(d.content)){let b=d.content.filter(w=>typeof w=="object"&&w.type==="text").map(w=>w.text).join(`
|
|
461
|
+
`);b&&g.push({text:b})}for(let b of d.tool_calls)g.push({functionCall:{name:this.sanitizeToolName(b.function.name),args:typeof b.function.arguments=="string"?JSON.parse(b.function.arguments||"{}"):b.function.arguments}});return{role:"model",parts:g}}return{role:d.role==="user"?"user":"model",parts:await a(d.content)}})),p=[];for(let d of l){let g=p[p.length-1];d.role==="function"&&g?.role==="function"?g.parts.push(...d.parts):p.push(d)}let m=typeof n.content=="string"?n.content:await a(n.content);return{history:p,lastUserMessage:m}}handleError(e){return e.status===429?new fe(e.message,void 0,e):e.status>=400&&e.status<500?new L(e.message,e):e.message&&e.message.includes("API key")?new ve(e.message,e):new W(e.message||"Gemini Error","GEMINI_ERROR",e.status||500,e)}};c();le();import*as Le from"fs";import*as os from"path";var za="toolpack.config.json",Mn=new Map;async function Ha(r){for(;Mn.has(r);)await Mn.get(r);let e,t=new Promise(o=>{e=o});return Mn.set(r,t),()=>{Mn.delete(r),e()}}function ot(r){if(r&&Le.existsSync(r))return r;let e=os.join(process.cwd(),za);return Le.existsSync(e)?e:null}function Vt(r){if(!r)return null;try{let e=Le.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}var Jt=null;function ns(r){if(Jt)return Jt;let e=r||ot();return Jt=Vt(e)||{},Jt}function rs(){Jt=null}function fT(r){return(ns(r).ollama?.models||[]).map(o=>({type:`ollama-${o.model.replace(/[:.]/g,"-")}`,model:o.model,label:o.label||o.model}))}function An(r){return ns(r).ollama?.baseUrl||"http://localhost:11434"}async function gT(r){let{type:e,value:t,configPath:o}=r,n=o||ot();n||(n=os.join(process.cwd(),za));let s=await Ha(n);try{let i=Vt(n)||{};switch(i.hitl||(i.hitl={}),i.hitl.bypass||(i.hitl.bypass={}),e){case"tool":i.hitl.bypass.tools||(i.hitl.bypass.tools=[]),i.hitl.bypass.tools.includes(t)||i.hitl.bypass.tools.push(t);break;case"category":i.hitl.bypass.categories||(i.hitl.bypass.categories=[]),i.hitl.bypass.categories.includes(t)||i.hitl.bypass.categories.push(t);break;case"level":{i.hitl.bypass.levels||(i.hitl.bypass.levels=[]);let a=t;i.hitl.bypass.levels.includes(a)||i.hitl.bypass.levels.push(a);break}}try{Le.writeFileSync(n,JSON.stringify(i,null,4),"utf-8")}catch(a){throw new N(`Failed to write bypass rule to config file: ${a instanceof Error?a.message:String(a)}`,"CONFIG_WRITE_ERROR")}rs()}finally{s()}}async function hT(r){let{type:e,value:t,configPath:o}=r,n=o||ot();if(!n)return;let s=await Ha(n);try{let i=Vt(n);if(!i?.hitl?.bypass)return;switch(e){case"tool":i.hitl.bypass.tools&&(i.hitl.bypass.tools=i.hitl.bypass.tools.filter(a=>a!==t));break;case"category":i.hitl.bypass.categories&&(i.hitl.bypass.categories=i.hitl.bypass.categories.filter(a=>a!==t));break;case"level":i.hitl.bypass.levels&&(i.hitl.bypass.levels=i.hitl.bypass.levels.filter(a=>a!==t));break}try{Le.writeFileSync(n,JSON.stringify(i,null,4),"utf-8")}catch(a){throw new N(`Failed to remove bypass rule from config file: ${a instanceof Error?a.message:String(a)}`,"CONFIG_WRITE_ERROR")}rs()}finally{s()}}c();c();import{zodToJsonSchema as Ja}from"zod-to-json-schema";le();S();c();import Ka from"http";function _e(r,e,t,o,n=12e4){return new Promise((s,i)=>{let a=new URL(e,r),l={hostname:a.hostname,port:a.port,path:a.pathname,method:t,headers:{"Content-Type":"application/json"},timeout:n},p=Ka.request(l,m=>{let d=[];m.on("data",g=>d.push(g)),m.on("end",()=>{s({status:m.statusCode||0,body:Buffer.concat(d).toString("utf-8")})})});p.on("error",m=>i(m)),p.on("timeout",()=>{p.destroy(),i(new Error("Request timed out"))}),o&&p.write(JSON.stringify(o)),p.end()})}function ss(r,e,t,o=12e4,n){let s,i=!1;return n&&n.addEventListener("abort",()=>{i=!0,s&&s.destroy()},{once:!0}),{stream:async function*(){let l=new URL(e,r),p={hostname:l.hostname,port:l.port,path:l.pathname,method:"POST",headers:{"Content-Type":"application/json"},timeout:o},m=await new Promise((g,b)=>{s=Ka.request(p,g),s.on("error",b),s.on("timeout",()=>{s.destroy(),b(new Error("Stream request timed out"))}),s.write(JSON.stringify(t)),s.end()});if(m.statusCode&&m.statusCode>=400){let g="";for await(let b of m)g+=b.toString();throw new Error(`Ollama HTTP ${m.statusCode}: ${g}`)}let d="";for await(let g of m){if(i)break;let b=g.toString();if(d+=b,d.includes('"error"'))try{let T=JSON.parse(d.trim());if(T.error)throw new Error(`Ollama: ${T.error}`)}catch(T){if(T.message.startsWith("Ollama:"))throw T}let w=d.split(`
|
|
462
|
+
`);d=w.pop()||"";for(let T of w)T.trim()&&(yield T)}d.trim()&&!i&&(yield d.trim())}(),abort:()=>{i=!0,s&&s.destroy()}}}var nt=class extends oe{config;baseUrl;timeout;modelName;constructor(e){super(),this.config=e,this.baseUrl=e.baseUrl||"http://localhost:11434",this.timeout=e.timeout||12e4,this.modelName=e.model}getDisplayName(){return"Ollama"}async getModels(){try{return(await this.listModels()).map(t=>({id:t.name,displayName:t.name,capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!0,vision:!0}}))}catch{return[]}}async connect(){let e=await this.listModels(),t=this.config.model.split(":")[0].toLowerCase();if(!e.some(n=>n.name.split(":")[0].toLowerCase()===t||n.name.toLowerCase()===this.config.model.toLowerCase()))throw new L(`Model "${this.config.model}" is not pulled in Ollama. Run: ollama pull ${this.config.model}
|
|
463
|
+
Available models: ${e.map(n=>n.name).join(", ")||"(none)"}`);return e}async listModels(){try{let e=await _e(this.baseUrl,"/api/tags","GET",void 0,5e3);if(e.status!==200)throw new W(`Ollama returned status ${e.status}`,"OLLAMA_ERROR",e.status);return JSON.parse(e.body).models||[]}catch(e){throw e instanceof W?e:new Xe(`Cannot connect to Ollama at ${this.baseUrl}. Is Ollama running? (ollama serve)`,e)}}async isAvailable(){try{return await _e(this.baseUrl,"/api/tags","GET",void 0,3e3),!0}catch{return!1}}async isModelAvailable(e){try{let t=await this.listModels(),o=(e||this.config.model).toLowerCase(),n=o.split(":")[0];return t.some(s=>s.name.split(":")[0].toLowerCase()===n||s.name.toLowerCase()===o)}catch{return!1}}sanitizeToolName(e){return e.replace(/\./g,"_")}restoreToolName(e,t){return t?.find(n=>this.sanitizeToolName(n.function.name)===e)?.function.name||e.replace(/_/g,".")}async generate(e){let t=e.__toolpack_request_id||`gen-${Date.now()}`,o=await Promise.all(e.messages.map(i=>this.toOllamaMessage(i,e.mediaOptions))),n=e.model||this.config.model,s={model:n,messages:o,stream:!1,options:{temperature:e.temperature??this.config.temperature??.7,num_ctx:this.config.numCtx}};e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format&&(s.format=Ja(e.response_format)),e.tools&&e.tools.length>0&&e.tool_choice!=="none"&&(s.tools=e.tools.map(i=>({type:"function",function:{name:this.sanitizeToolName(i.function.name),description:i.function.description,parameters:i.function.parameters}})),y(`[Ollama][${t}] Sending ${e.tools.length} tools with tool_choice: ${e.tool_choice||"unset"}`),e.tools.length>0&&y(`[Ollama][${t}] First tool: ${A(e.tools[0],800)}`),y(`[Ollama][${t}] NO TOOLS in request`)),y(`[Ollama][${t}] generate() request: model=${n}, messages=${e.messages.length}, tools=${e.tools?.length||0}`),te(t,"Ollama",e.messages);try{let i=await _e(this.baseUrl,"/api/chat","POST",s,this.timeout);if(i.status!==200)throw this.handleHttpError(i.status,i.body);let a=JSON.parse(i.body),l=[];if(a.message?.tool_calls)for(let m of a.message.tool_calls)l.push({id:`ollama_${Date.now()}_${Math.random().toString(36).substring(2,8)}`,name:this.restoreToolName(m.function.name,e.tools),arguments:m.function.arguments||{}});let p={content:a.message?.content||null,usage:a.prompt_eval_count!=null?{prompt_tokens:a.prompt_eval_count||0,completion_tokens:a.eval_count||0,total_tokens:(a.prompt_eval_count||0)+(a.eval_count||0)}:void 0,finish_reason:l.length>0?"tool_calls":a.done?"stop":void 0,tool_calls:l.length>0?l:void 0,raw:a};return y(`[Ollama][${t}] Response finish_reason=${p.finish_reason} tool_calls=${l.length} content_preview=${A(p.content,200)}`),p}catch(i){throw i instanceof W?i:new Xe(`Failed to generate with Ollama model "${n}": ${i.message}`,i)}}async*stream(e){let t=e.__toolpack_request_id||`str-${Date.now()}`,o=await Promise.all(e.messages.map(a=>this.toOllamaMessage(a,e.mediaOptions))),n=e.model||this.config.model,s={model:n,messages:o,stream:!0,options:{temperature:e.temperature??this.config.temperature??.7,num_ctx:this.config.numCtx}};e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format&&(s.format=Ja(e.response_format)),e.tools&&e.tools.length>0&&e.tool_choice!=="none"&&(s.tools=e.tools.map(a=>({type:"function",function:{name:this.sanitizeToolName(a.function.name),description:a.function.description,parameters:a.function.parameters}})),y(`[Ollama][${t}] Sending ${e.tools.length} tools with tool_choice: ${e.tool_choice||"unset"}`),e.tools.length>0&&y(`[Ollama][${t}] First tool: ${A(e.tools[0],800)}`),y(`[Ollama][${t}] NO TOOLS in request`)),y(`[Ollama][${t}] Stream request: model=${n}, messages=${e.messages.length}, tools=${e.tools?.length||0}`),te(t,"Ollama",e.messages);let{stream:i}=ss(this.baseUrl,"/api/chat",s,this.timeout,e.signal);try{for await(let a of i)try{let l=JSON.parse(a);if(l.message?.content){let p=l.message.tool_calls&&l.message.tool_calls.length>0;yield{delta:l.message.content,finish_reason:l.done&&!p?"stop":void 0,usage:l.done&&l.prompt_eval_count!=null?{prompt_tokens:l.prompt_eval_count||0,completion_tokens:l.eval_count||0,total_tokens:(l.prompt_eval_count||0)+(l.eval_count||0)}:void 0}}if(l.message?.tool_calls&&l.message.tool_calls.length>0){let p=l.message.tool_calls.map(m=>({id:`ollama_${Date.now()}_${Math.random().toString(36).substring(2,8)}`,name:this.restoreToolName(m.function.name,e.tools),arguments:m.function.arguments||{}}));y(`[Ollama][${t}] Stream finish_reason=tool_calls name=${p[0]?.name}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:p}}if(l.done&&!l.message?.content&&!l.message?.tool_calls){je(`[Ollama][${t}] Stream chunk finish_reason=stop`),yield{delta:"",finish_reason:"stop"};return}}catch{}}catch(a){throw new Xe(`Stream failed for Ollama model "${n}": ${a.message}`,a)}}async embed(e){let t=e.__toolpack_request_id||`emb-${Date.now()}`,o=typeof e.input=="string"?[e.input]:e.input,n=e.model||this.config.model;y(`[Ollama][${t}] Embedding request: model=${n}, inputs=${o.length}`);try{let s=await _e(this.baseUrl,"/api/embed","POST",{model:n,input:o},this.timeout);if(s.status!==200)throw this.handleHttpError(s.status,s.body);return{embeddings:JSON.parse(s.body).embeddings||[]}}catch(s){throw s instanceof W?s:new Xe(`Embedding failed for Ollama model "${n}": ${s.message}`,s)}}async disconnect(){}async toOllamaMessage(e,t={}){let o="",n=[],{normalizeImagePart:s}=await Promise.resolve().then(()=>(xt(),Kt));if(typeof e.content=="string")o=e.content;else if(e.content!==null){for(let a of e.content)if(a.type==="text")o+=a.text+`
|
|
464
464
|
`;else if(a.type==="image_url"||a.type==="image_data"||a.type==="image_file")try{let{data:l}=await s(a);n.push(l)}catch{a.type==="image_url"?o+=`[Image: ${a.image_url.url}]
|
|
465
465
|
`:o+=`[Unresolvable Image]
|
|
466
|
-
`}o=o.trim()}let i={role:e.role,content:o};return n.length>0&&(i.images=n),e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0?i.tool_calls=e.tool_calls.map(a=>({function:{name:this.sanitizeToolName(a.function.name),arguments:typeof a.function.arguments=="string"?JSON.parse(a.function.arguments||"{}"):a.function.arguments}})):e.role==="tool"&&(i.content=o||JSON.stringify(e.content),e.name&&(i.tool_name=this.sanitizeToolName(e.name))),i}handleHttpError(e,t){let o=`Ollama error (HTTP ${e})`;try{let n=JSON.parse(t);n.error&&(o=`Ollama: ${n.error}`)}catch{}return e===404?new L(`Model not found: ${o}`):new q(o,"OLLAMA_ERROR",e)}};c();var Vt=class extends oe{baseUrl;timeout;adapterCache=new Map;capabilityCache=new Map;constructor(e){super(),this.baseUrl=e?.baseUrl||"http://localhost:11434",this.timeout=12e4}getDisplayName(){return"Ollama"}async getModels(){let e;try{let t=await _e(this.baseUrl,"/api/tags","GET",void 0,5e3);if(t.status!==200)return[];e=JSON.parse(t.body).models||[]}catch{return[]}return Promise.all(e.map(t=>this.buildModelInfo(t)))}async generate(e){return this.getAdapterForModel(e.model).generate(this.stripToolsIfNeeded(e))}async*stream(e){yield*this.getAdapterForModel(e.model).stream(this.stripToolsIfNeeded(e))}async embed(e){return this.getAdapterForModel(e.model).embed(e)}async disconnect(){this.adapterCache.clear(),this.capabilityCache.clear()}stripToolsIfNeeded(e){let t=this.capabilityCache.get(e.model);if(t&&!t.toolCalling&&e.tools&&e.tools.length>0){let{tools:o,tool_choice:n,...s}=e,i=s,a={role:"system",content:"You do not have access to any tools or functions. Do not attempt to call tools, output tool invocations, or reference tool usage. Answer the user directly using only your own knowledge."};return i.messages=[...i.messages,a],i}return e}getAdapterForModel(e){let t=this.adapterCache.get(e);return t||(t=new ot({model:e,baseUrl:this.baseUrl,timeout:this.timeout}),this.adapterCache.set(e,t)),t}async buildModelInfo(e){let t=!1,o=!1,n=!1;try{let a=await _e(this.baseUrl,"/api/show","POST",{model:e.name},3e3);if(a.status===200){let p=(JSON.parse(a.body).details?.families||[]).map(m=>m.toLowerCase());o=p.some(m=>["clip","mllama"].includes(m)),n=p.some(m=>m.includes("bert")||m.includes("nomic"))}}catch{}t=await this.probeToolSupport(e.name);let s=e.name.toLowerCase();o||(o=["llava","vision","bakllava","moondream"].some(l=>s.includes(l))),n||(n=["nomic-embed","mxbai-embed","all-minilm","bge-","snowflake-arctic-embed"].some(l=>s.includes(l)));let i={toolCalling:t,vision:o,embeddings:n};return this.capabilityCache.set(e.name,i),{id:e.name,displayName:e.name,capabilities:{chat:!0,streaming:!0,toolCalling:t,embeddings:n,vision:o}}}async probeToolSupport(e){try{let t=await _e(this.baseUrl,"/api/chat","POST",{model:e,messages:[{role:"user",content:"hi"}],tools:[{type:"function",function:{name:"__probe",description:"probe",parameters:{type:"object",properties:{}}}}],stream:!1},1e4);return t.status>=400?!1:!JSON.parse(t.body).error}catch{return!1}}};c();var ss=[{model:"qwen2.5-coder:3b",label:"Qwen 2.5 Coder 3B",params:"3B",size:"~2GB",selectorCapability:5,description:"Best code understanding at small size. Excellent HTML/CSS comprehension."},{model:"phi3:mini",label:"Phi-3 Mini",params:"3.8B",size:"~2.3GB",selectorCapability:4,description:"Strong reasoning for its size. Good at structured output."},{model:"codegemma:2b",label:"CodeGemma 2B",params:"2B",size:"~1.4GB",selectorCapability:4,description:"Compact code model from Google. Fast inference."},{model:"deepseek-coder:1.3b",label:"DeepSeek Coder 1.3B",params:"1.3B",size:"~0.8GB",selectorCapability:3,description:"Smallest viable option. Very fast but less accurate."},{model:"qwen2.5-coder:7b",label:"Qwen 2.5 Coder 7B",params:"7B",size:"~4.5GB",selectorCapability:5,description:"Higher accuracy than 3B variant. Requires more RAM/VRAM."},{model:"codellama:7b",label:"Code Llama 7B",params:"7B",size:"~3.8GB",selectorCapability:4,description:"Meta code model. Solid HTML/CSS understanding."}];function hT(){return ss[0].model}function yT(r){let e=r.toLowerCase();return ss.some(t=>t.model.toLowerCase()===e||t.model.split(":")[0].toLowerCase()===e.split(":")[0].toLowerCase())}function bT(){return[...ss]}c();import Ja from"openai";import{zodResponseFormat as Va}from"openai/helpers/zod";le();k();var xt=class extends oe{client;constructor(e,t){super(),this.client=new Ja({apiKey:e,baseURL:t,timeout:6e4,maxRetries:2})}supportsFileUpload(){return!0}async uploadFile(e){try{let t=await import("fs");if(!e.filePath)throw new L("OpenAI uploadFile requires a filePath.");return{id:(await this.client.files.create({file:t.createReadStream(e.filePath),purpose:e.purpose||"vision"})).id}}catch(t){throw this.handleError(t)}}async deleteFile(e){try{await this.client.files.delete(e)}catch(t){throw this.handleError(t)}}getDisplayName(){return"OpenAI"}async getModels(){return[{id:"gpt-4.1-mini",displayName:"GPT-4.1 Mini",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1047576,maxOutputTokens:32768,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:null,costTier:"low"},{id:"gpt-4.1",displayName:"GPT-4.1",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1047576,maxOutputTokens:32768,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:null,costTier:"medium"},{id:"gpt-5.1",displayName:"GPT-5.1",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:4e5,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"medium"},{id:"gpt-5.2",displayName:"GPT-5.2",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:4e5,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"high"},{id:"gpt-5.4",displayName:"GPT-5.4",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:105e4,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"high"},{id:"gpt-5.4-pro",displayName:"GPT-5.4 Pro",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:105e4,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"extended",costTier:"premium"}]}sanitizeToolName(e){return e.replace(/\./g,"_")}async generate(e){try{let t=e.__toolpack_request_id||`gen-${Date.now()}`,n={messages:await Promise.all(e.messages.map(d=>this.toOpenAIMessage(d,e.mediaOptions))),model:e.model,temperature:e.temperature,max_tokens:e.max_tokens,top_p:e.top_p,response_format:e.response_format==="json_object"?{type:"json_object"}:e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format?Va(e.response_format,"structured_output"):void 0,stream:!1},s=new Map;e.tools&&e.tools.length>0&&(n.tools=e.tools.map(d=>{let g=this.sanitizeToolName(d.function.name);return s.set(g,d.function.name),{type:"function",function:{name:g,description:d.function.description,parameters:d.function.parameters}}}),n.tool_choice=e.tool_choice||"auto",y(`[OpenAI][${t}] Sending ${n.tools.length} tools with tool_choice: ${n.tool_choice}`),y(`[OpenAI][${t}] First tool: ${O(n.tools[0],800)}`)),y(`[OpenAI][${t}] Request params: ${O({model:n.model,messages_count:n.messages.length,has_tools:!!n.tools,tools_count:n.tools?.length,tool_choice:n.tool_choice},800)}`),te(t,"OpenAI",n.messages);let i=await this.client.chat.completions.create(n,e.signal?{signal:e.signal}:void 0);Ie(`[OpenAI][${t}] Raw completion: ${JSON.stringify(i)}`);let a=i.choices[0].message;y(`[OpenAI][${t}] Response: finish_reason=${i.choices[0].finish_reason}`),y(`[OpenAI][${t}] Response has tool_calls: ${!!a.tool_calls}, count: ${a.tool_calls?.length||0}`),y(`[OpenAI][${t}] Response content: ${JSON.stringify(a.content)}`),a.content&&y(`[OpenAI][${t}] Response content preview: ${O(a.content,200)}`);let l=i.choices[0],p,m=l.message.tool_calls;return m&&m.length>0&&(p=m.map(d=>({id:d.id,name:s.get(d.function.name)||d.function.name,arguments:JSON.parse(d.function.arguments)}))),{content:l.message.content,usage:i.usage?{prompt_tokens:i.usage.prompt_tokens,completion_tokens:i.usage.completion_tokens,total_tokens:i.usage.total_tokens}:void 0,finish_reason:l.finish_reason,tool_calls:p,raw:i}}catch(t){throw this.handleError(t)}}async*stream(e){try{let t=e.__toolpack_request_id||`str-${Date.now()}`,n={messages:await Promise.all(e.messages.map(l=>this.toOpenAIMessage(l,e.mediaOptions))),model:e.model,temperature:e.temperature,max_tokens:e.max_tokens,top_p:e.top_p,response_format:e.response_format==="json_object"?{type:"json_object"}:e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format?Va(e.response_format,"structured_output"):void 0,stream:!0},s=new Map;e.tools&&e.tools.length>0?(n.tools=e.tools.map(l=>{let p=this.sanitizeToolName(l.function.name);return s.set(p,l.function.name),{type:"function",function:{name:p,description:l.function.description,parameters:l.function.parameters}}}),n.tool_choice=e.tool_choice||"auto",y(`[OpenAI][${t}] Sending ${n.tools.length} tools with tool_choice: ${n.tool_choice}`),y(`[OpenAI][${t}] First tool: ${O(n.tools[0],800)}`)):y(`[OpenAI][${t}] NO TOOLS in request`),y(`[OpenAI][${t}] Stream request: model=${n.model}, messages=${n.messages.length}, tools=${n.tools?.length||0}, tool_choice=${n.tool_choice??"unset"}`),te(t,"OpenAI",n.messages);let i=await this.client.chat.completions.create(n,e.signal?{signal:e.signal}:void 0),a=new Map;for await(let l of i){let p=l.choices[0];if(p.finish_reason&&Ie(`[OpenAI][${t}] Stream chunk finish_reason=${p.finish_reason}`),p.delta.tool_calls)for(let m of p.delta.tool_calls){let d=m.index;a.has(d)||a.set(d,{id:m.id||"",name:m.function?.name||"",args:""});let g=a.get(d);m.id&&(g.id=m.id),m.function?.name&&(g.name=m.function.name),m.function?.arguments&&(g.args+=m.function.arguments),Ie(`[OpenAI][${t}] tool_call_delta idx=${d} id=${m.id||g.id||""} name=${m.function?.name||g.name||""} args_delta=${O(m.function?.arguments||"",200)}`)}if(p.delta.content&&(yield{delta:p.delta.content,finish_reason:p.finish_reason,usage:l.usage}),!p.delta.content&&p.finish_reason&&p.finish_reason!=="tool_calls"&&(yield{delta:"",finish_reason:p.finish_reason,usage:l.usage}),p.finish_reason==="tool_calls"&&a.size>0){let m=Array.from(a.values()).map(d=>({id:d.id,name:s.get(d.name)||d.name,arguments:JSON.parse(d.args||"{}")}));y(`[OpenAI][${t}] Stream finish_reason=tool_calls accumulated_calls=${m.length} names=${m.map(d=>d.name).join(", ")}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:m}}}}catch(t){throw this.handleError(t)}}async embed(e){try{let t=typeof e.input=="string"?[e.input]:e.input,o=await this.client.embeddings.create({model:e.model,input:t});return{embeddings:o.data.map(n=>n.embedding),usage:o.usage}}catch(t){throw this.handleError(t)}}async toOpenAIMessage(e,t={}){if(e.role==="tool"&&e.tool_call_id)return{role:"tool",tool_call_id:e.tool_call_id,content:typeof e.content=="string"?e.content:JSON.stringify(e.content??"")};if(e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0)return{role:"assistant",content:typeof e.content=="string"?e.content:"",tool_calls:e.tool_calls.map(s=>({id:s.id,type:"function",function:{name:this.sanitizeToolName(s.function.name),arguments:s.function.arguments}}))};if(typeof e.content=="string")return{role:e.role,content:e.content};if(e.content===null||e.content===void 0)return{role:e.role,content:""};let{normalizeImagePart:o}=await Promise.resolve().then(()=>(Tt(),Ht)),n=await Promise.all(e.content.map(async s=>{if(s.type==="text")return{type:"text",text:s.text};if(s.type==="image_url")return{type:"image_url",image_url:{url:s.image_url.url}};if(s.type==="image_data"||s.type==="image_file"){let{data:i,mimeType:a}=await o(s);return{type:"image_url",image_url:{url:`data:${a};base64,${i}`}}}return null}));return{role:e.role,content:n.filter(Boolean)}}handleError(e){if(e instanceof Ja.APIError){let t=e.message;return e.status===401?new xe(t,e):e.status===429?new fe(t,void 0,e):e.status&&e.status>=400&&e.status<500?new L(t,e):new q(t,e.code||"OPENAI_ERROR",e.status||500,e)}return new q("Unknown error","UNKNOWN",500,e)}};c();var Qa="https://openrouter.ai/api/v1",On=class extends xt{name="openrouter";_apiKey;constructor(e,t={}){super(e,Qa),this._apiKey=e}getDisplayName(){return"OpenRouter"}supportsFileUpload(){return!1}async generate(e){return super.generate(this.normalizeRequest(e))}async*stream(e){yield*super.stream(this.normalizeRequest(e))}normalizeRequest(e){return e.tool_choice==="none"?{...e,tools:void 0,tool_choice:void 0}:e}async getModels(){try{let e=await fetch(`${Qa}/models`,{headers:{Authorization:`Bearer ${this._apiKey}`}});return e.ok?(await e.json()).data.map(o=>this.mapModel(o)):[]}catch{return[]}}mapModel(e){let o=(e.architecture?.modality??"text->text").includes("image");return{id:e.id,displayName:e.name??e.id,capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:o},contextWindow:e.context_length??void 0,maxOutputTokens:e.top_provider?.max_completion_tokens??void 0,inputModalities:o?["text","image"]:["text"],outputModalities:["text"],reasoningTier:null,costTier:this.deriveCostTier(e.pricing)}}deriveCostTier(e){if(!e?.prompt)return"unknown";let t=parseFloat(e.prompt)*1e6;return t<1?"low":t<5?"medium":t<20?"high":"premium"}};Tt();c();Gt();c();Gt();var Tn=class{tools=new Map;projects=new Map;config=ce;register(e){this.tools.set(e.name,e)}registerCustom(e){this.tools.set(e.name,e)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getNames(){return Array.from(this.tools.keys())}getByCategory(e){return Array.from(this.tools.values()).filter(t=>t.category===e)}getEnabled(){if(this.config.enabledTools.length===0&&this.config.enabledToolCategories.length===0)return Array.from(this.tools.values());let e=this.getByNames(this.config.enabledTools),t=this.getByCategories(this.config.enabledToolCategories),o=new Set,n=[];for(let s of[...e,...t])o.has(s.name)||(o.add(s.name),n.push(s));return n}getSchemas(e){return(e?e.map(o=>this.tools.get(o)).filter(Boolean):this.getEnabled()).map(o=>({name:o.name,displayName:o.displayName,description:o.description,parameters:o.parameters,category:o.category,...o.cacheable!==void 0&&{cacheable:o.cacheable},...o.annotations!==void 0&&{annotations:o.annotations}}))}getByNames(e){return e.map(t=>this.tools.get(t)).filter(Boolean)}getByCategories(e){let t=new Set(e);return Array.from(this.tools.values()).filter(o=>t.has(o.category))}getCategories(){let e=new Set;for(let t of this.tools.values())e.add(t.category);return Array.from(e)}getAll(){return Array.from(this.tools.values())}setConfig(e){this.config=e}getConfig(){return this.config}get size(){return this.tools.size}async validateDependencies(e){let t=e.dependencies;if(!t||Object.keys(t).length===0)return[];let o=[];for(let n of Object.keys(t))try{await import(n)}catch{o.push(n)}return o}async loadProject(e){let t=await this.validateDependencies(e);if(t.length>0)throw new Error(`Tool project "${e.manifest.name}" has missing dependencies: ${t.join(", ")}. Install them with: npm install ${t.join(" ")}`);this.projects.set(e.manifest.name,e);for(let o of e.tools)this.register(o)}async loadProjects(e){for(let t of e)await this.loadProject(t)}getProject(e){return this.projects.get(e)}getProjects(){return Array.from(this.projects.values())}getProjectNames(){return Array.from(this.projects.keys())}async loadBuiltIn(){let{fsToolsProject:e}=await Promise.resolve().then(()=>(Ss(),pp)),{execToolsProject:t}=await Promise.resolve().then(()=>(Os(),cm)),{systemToolsProject:o}=await Promise.resolve().then(()=>(qs(),Bm)),{httpToolsProject:n}=await Promise.resolve().then(()=>(Hs(),_d)),{githubToolsProject:s}=await Promise.resolve().then(()=>(ni(),Ou)),{webToolsProject:i}=await Promise.resolve().then(()=>(hi(),og)),{codingToolsProject:a}=await Promise.resolve().then(()=>(Ai(),zh)),{gitToolsProject:l}=await Promise.resolve().then(()=>(Ni(),Sy)),{diffToolsProject:p}=await Promise.resolve().then(()=>(Ii(),Fy)),{dbToolsProject:m}=await Promise.resolve().then(()=>(ji(),db)),{cloudToolsProject:d}=await Promise.resolve().then(()=>(Fi(),Cb)),{slackToolsProject:g}=await Promise.resolve().then(()=>(Hi(),aw)),{k8sToolsProject:w}=await Promise.resolve().then(()=>(Ki(),mw));await this.loadProjects([e,t,o,n,s,i,a,l,p,m,d,g,w])}};ii();c();k();function $C(r){if(!r.key||!/^[a-z0-9-]+$/.test(r.key))throw new Error(`Invalid tool project key: "${r.key}". Must be non-empty, lowercase, and contain no spaces (use hyphens).`);if(!r.name.trim())throw new Error("Tool project name cannot be empty.");if(!r.tools||r.tools.length===0)throw new Error("Tool project must contain at least one tool.");for(let t of r.tools){if(!t.name)throw new Error("Tool is missing a name.");if(!t.description)throw new Error(`Tool "${t.name}" is missing a description.`);if(!t.parameters)throw new Error(`Tool "${t.name}" is missing parameters.`);if(typeof t.execute!="function")throw new Error(`Tool "${t.name}" is missing an execute function.`);t.category!==r.category&&I(`[Toolpack] Tool "${t.name}" has category "${t.category}" which does not match project category "${r.category}".`)}let e=r.tools.map(t=>t.name);return{manifest:{key:r.key,name:r.name,displayName:r.displayName,version:r.version,description:r.description,author:r.author,repository:r.repository,category:r.category,tools:e},dependencies:r.dependencies,tools:r.tools}}Wt();Ss();Os();qs();Hs();ni();hi();Ai();Ni();Ii();ji();Fi();Ki();Hi();c();c();k();import{spawn as EC}from"child_process";import{EventEmitter as DC}from"events";var Ar=class extends Error{constructor(e,t){super(`MCP request timed out after ${t}ms: ${e}`),this.name="McpTimeoutError"}},Oe=class extends Error{constructor(t,o){super(t);this.exitCode=o;this.name="McpConnectionError"}exitCode},xn=class extends DC{constructor(t){super();this.config=t;this.defaultTimeoutMs=t.requestTimeoutMs??3e4,this.autoReconnect=t.autoReconnect??!1,this.maxReconnectAttempts=t.maxReconnectAttempts??3,this.reconnectDelayMs=t.reconnectDelayMs??1e3}config;process=null;messageQueue=new Map;nextId=1;buffer="";_connected=!1;_shuttingDown=!1;_reconnectAttempts=0;defaultTimeoutMs;autoReconnect;maxReconnectAttempts;reconnectDelayMs;get connected(){return this._connected&&this.process!==null}async initializeServer(){await this.request("initialize",{client:"toolpack-sdk"})}async connect(){if(this._shuttingDown)throw new Oe("Client is shutting down");if(this.buffer="",this.process=EC(this.config.command,this.config.args||[],{env:{...process.env,...this.config.env},stdio:["pipe","pipe","pipe"]}),!this.process.stdout||!this.process.stdin)throw new Oe("Failed to spawn MCP server: stdout/stdin unavailable");this.process.stdout.on("data",t=>{this.handleData(t)}),this.process.stderr&&this.process.stderr.on("data",t=>{I(`[MCP server stderr] ${t.toString().trim()}`)}),this.process.on("error",t=>{this._connected=!1,this.emit("error",t)}),this.process.on("exit",t=>{let o=this._connected;this._connected=!1,this.process=null,this.rejectAllPending(new Oe(`MCP server exited with code ${t}`,t)),this.emit("close",t),o&&!this._shuttingDown&&this.autoReconnect&&this.attemptReconnect()}),this._reconnectAttempts=0,await this.initializeServer(),this._connected=!0}async attemptReconnect(){if(this._reconnectAttempts>=this.maxReconnectAttempts){this.emit("reconnect_failed",this._reconnectAttempts);return}this._reconnectAttempts++;let t=this._reconnectAttempts;if(this.emit("reconnecting",{attempt:t,max:this.maxReconnectAttempts}),await new Promise(o=>setTimeout(o,this.reconnectDelayMs*t)),!this._shuttingDown)try{await this.connect(),this.emit("reconnected",{attempt:t})}catch(o){this.emit("reconnect_error",{attempt:t,error:o})}}handleData(t){this.buffer+=t.toString();let o;for(;(o=this.buffer.indexOf(`
|
|
467
|
-
`))!==-1;){let n=this.buffer.slice(0,o).trim();if(this.buffer=this.buffer.slice(o+1),n)try{let s=JSON.parse(n);this.handleMessage(s)}catch{}}}handleMessage(t){if(t.id&&(t.result!==void 0||t.error)){let o=this.messageQueue.get(t.id);o&&(o.timer&&clearTimeout(o.timer),t.error?o.reject(new Error(t.error.message)):o.resolve(t.result),this.messageQueue.delete(t.id))}else t.method&&(this.emit("notification",t),this.emit(t.method,t.params))}async callTool(t,o={},n){return this.request("tools/call",{name:t,arguments:o},n)}async readResource(t,o){return this.request("resources/read",{uri:t},o)}async request(t,o,n){if(!this.process||!this.process.stdin)throw new Oe("Client not connected");let s=this.nextId++,i=n??this.defaultTimeoutMs,a={jsonrpc:"2.0",id:s,method:t,params:o};return new Promise((l,p)=>{let m;i>0&&(m=setTimeout(()=>{let d=this.messageQueue.get(s);d&&(this.messageQueue.delete(s),d.reject(new
|
|
468
|
-
`)}catch(d){m&&clearTimeout(m),this.messageQueue.delete(s),p(d)}})}async disconnect(t=3e3){if(this._shuttingDown=!0,this.rejectAllPending(new Oe("Client disconnecting")),!this.process){this._shuttingDown=!1;return}let o=this.process;return new Promise(n=>{let s=!1,i=()=>{s||(s=!0,this.process=null,this._connected=!1,this._shuttingDown=!1,n())};o.once("exit",i),o.kill("SIGTERM"),setTimeout(()=>{if(!s){try{o.kill("SIGKILL")}catch{}i()}},t)})}kill(){this._shuttingDown=!0,this.rejectAllPending(new Oe("Client killed")),this.process&&(this.process.kill("SIGKILL"),this.process=null),this._connected=!1,this._shuttingDown=!1}rejectAllPending(t){for(let[o,n]of this.messageQueue)n.timer&&clearTimeout(n.timer),n.reject(t);this.messageQueue.clear()}};
|
|
469
|
-
`)){let n=o.indexOf(":");if(n===-1)continue;let s=o.substring(0,n).trim(),i=o.substring(n+1).trim();e[s]=i}return e}function
|
|
470
|
-
`).filter(n=>n.startsWith("- "))){let n=o.match(/^- "(.*)"/);n&&n[1]&&e.push(n[1])}return e}function
|
|
466
|
+
`}o=o.trim()}let i={role:e.role,content:o};return n.length>0&&(i.images=n),e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0?i.tool_calls=e.tool_calls.map(a=>({function:{name:this.sanitizeToolName(a.function.name),arguments:typeof a.function.arguments=="string"?JSON.parse(a.function.arguments||"{}"):a.function.arguments}})):e.role==="tool"&&(i.content=o||JSON.stringify(e.content),e.name&&(i.tool_name=this.sanitizeToolName(e.name))),i}handleHttpError(e,t){let o=`Ollama error (HTTP ${e})`;try{let n=JSON.parse(t);n.error&&(o=`Ollama: ${n.error}`)}catch{}return e===404?new L(`Model not found: ${o}`):new W(o,"OLLAMA_ERROR",e)}};c();var Qt=class extends oe{baseUrl;timeout;adapterCache=new Map;capabilityCache=new Map;constructor(e){super(),this.baseUrl=e?.baseUrl||"http://localhost:11434",this.timeout=12e4}getDisplayName(){return"Ollama"}async getModels(){let e;try{let t=await _e(this.baseUrl,"/api/tags","GET",void 0,5e3);if(t.status!==200)return[];e=JSON.parse(t.body).models||[]}catch{return[]}return Promise.all(e.map(t=>this.buildModelInfo(t)))}async generate(e){return this.getAdapterForModel(e.model).generate(this.stripToolsIfNeeded(e))}async*stream(e){yield*this.getAdapterForModel(e.model).stream(this.stripToolsIfNeeded(e))}async embed(e){return this.getAdapterForModel(e.model).embed(e)}async disconnect(){this.adapterCache.clear(),this.capabilityCache.clear()}stripToolsIfNeeded(e){let t=this.capabilityCache.get(e.model);if(t&&!t.toolCalling&&e.tools&&e.tools.length>0){let{tools:o,tool_choice:n,...s}=e,i=s,a={role:"system",content:"You do not have access to any tools or functions. Do not attempt to call tools, output tool invocations, or reference tool usage. Answer the user directly using only your own knowledge."};return i.messages=[...i.messages,a],i}return e}getAdapterForModel(e){let t=this.adapterCache.get(e);return t||(t=new nt({model:e,baseUrl:this.baseUrl,timeout:this.timeout}),this.adapterCache.set(e,t)),t}async buildModelInfo(e){let t=!1,o=!1,n=!1;try{let a=await _e(this.baseUrl,"/api/show","POST",{model:e.name},3e3);if(a.status===200){let p=(JSON.parse(a.body).details?.families||[]).map(m=>m.toLowerCase());o=p.some(m=>["clip","mllama"].includes(m)),n=p.some(m=>m.includes("bert")||m.includes("nomic"))}}catch{}t=await this.probeToolSupport(e.name);let s=e.name.toLowerCase();o||(o=["llava","vision","bakllava","moondream"].some(l=>s.includes(l))),n||(n=["nomic-embed","mxbai-embed","all-minilm","bge-","snowflake-arctic-embed"].some(l=>s.includes(l)));let i={toolCalling:t,vision:o,embeddings:n};return this.capabilityCache.set(e.name,i),{id:e.name,displayName:e.name,capabilities:{chat:!0,streaming:!0,toolCalling:t,embeddings:n,vision:o}}}async probeToolSupport(e){try{let t=await _e(this.baseUrl,"/api/chat","POST",{model:e,messages:[{role:"user",content:"hi"}],tools:[{type:"function",function:{name:"__probe",description:"probe",parameters:{type:"object",properties:{}}}}],stream:!1},1e4);return t.status>=400?!1:!JSON.parse(t.body).error}catch{return!1}}};c();var is=[{model:"qwen2.5-coder:3b",label:"Qwen 2.5 Coder 3B",params:"3B",size:"~2GB",selectorCapability:5,description:"Best code understanding at small size. Excellent HTML/CSS comprehension."},{model:"phi3:mini",label:"Phi-3 Mini",params:"3.8B",size:"~2.3GB",selectorCapability:4,description:"Strong reasoning for its size. Good at structured output."},{model:"codegemma:2b",label:"CodeGemma 2B",params:"2B",size:"~1.4GB",selectorCapability:4,description:"Compact code model from Google. Fast inference."},{model:"deepseek-coder:1.3b",label:"DeepSeek Coder 1.3B",params:"1.3B",size:"~0.8GB",selectorCapability:3,description:"Smallest viable option. Very fast but less accurate."},{model:"qwen2.5-coder:7b",label:"Qwen 2.5 Coder 7B",params:"7B",size:"~4.5GB",selectorCapability:5,description:"Higher accuracy than 3B variant. Requires more RAM/VRAM."},{model:"codellama:7b",label:"Code Llama 7B",params:"7B",size:"~3.8GB",selectorCapability:4,description:"Meta code model. Solid HTML/CSS understanding."}];function yT(){return is[0].model}function bT(r){let e=r.toLowerCase();return is.some(t=>t.model.toLowerCase()===e||t.model.split(":")[0].toLowerCase()===e.split(":")[0].toLowerCase())}function wT(){return[...is]}c();import Va from"openai";import{zodResponseFormat as Qa}from"openai/helpers/zod";le();S();var vt=class extends oe{client;constructor(e,t){super(),this.client=new Va({apiKey:e,baseURL:t,timeout:6e4,maxRetries:2})}supportsFileUpload(){return!0}async uploadFile(e){try{let t=await import("fs");if(!e.filePath)throw new L("OpenAI uploadFile requires a filePath.");return{id:(await this.client.files.create({file:t.createReadStream(e.filePath),purpose:e.purpose||"vision"})).id}}catch(t){throw this.handleError(t)}}async deleteFile(e){try{await this.client.files.delete(e)}catch(t){throw this.handleError(t)}}getDisplayName(){return"OpenAI"}async getModels(){return[{id:"gpt-4.1-mini",displayName:"GPT-4.1 Mini",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1047576,maxOutputTokens:32768,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:null,costTier:"low"},{id:"gpt-4.1",displayName:"GPT-4.1",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:1047576,maxOutputTokens:32768,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:null,costTier:"medium"},{id:"gpt-5.1",displayName:"GPT-5.1",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:4e5,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"medium"},{id:"gpt-5.2",displayName:"GPT-5.2",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:4e5,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"high"},{id:"gpt-5.4",displayName:"GPT-5.4",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:105e4,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"standard",costTier:"high"},{id:"gpt-5.4-pro",displayName:"GPT-5.4 Pro",capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:!0,fileUpload:!0},contextWindow:105e4,maxOutputTokens:128e3,inputModalities:["text","image"],outputModalities:["text"],reasoningTier:"extended",costTier:"premium"}]}sanitizeToolName(e){return e.replace(/\./g,"_")}async generate(e){try{let t=e.__toolpack_request_id||`gen-${Date.now()}`,n={messages:await Promise.all(e.messages.map(d=>this.toOpenAIMessage(d,e.mediaOptions))),model:e.model,temperature:e.temperature,max_tokens:e.max_tokens,top_p:e.top_p,response_format:e.response_format==="json_object"?{type:"json_object"}:e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format?Qa(e.response_format,"structured_output"):void 0,stream:!1},s=new Map;e.tools&&e.tools.length>0&&(n.tools=e.tools.map(d=>{let g=this.sanitizeToolName(d.function.name);return s.set(g,d.function.name),{type:"function",function:{name:g,description:d.function.description,parameters:d.function.parameters}}}),n.tool_choice=e.tool_choice||"auto",y(`[OpenAI][${t}] Sending ${n.tools.length} tools with tool_choice: ${n.tool_choice}`),y(`[OpenAI][${t}] First tool: ${A(n.tools[0],800)}`)),y(`[OpenAI][${t}] Request params: ${A({model:n.model,messages_count:n.messages.length,has_tools:!!n.tools,tools_count:n.tools?.length,tool_choice:n.tool_choice},800)}`),te(t,"OpenAI",n.messages);let i=await this.client.chat.completions.create(n,e.signal?{signal:e.signal}:void 0);je(`[OpenAI][${t}] Raw completion: ${JSON.stringify(i)}`);let a=i.choices[0].message;y(`[OpenAI][${t}] Response: finish_reason=${i.choices[0].finish_reason}`),y(`[OpenAI][${t}] Response has tool_calls: ${!!a.tool_calls}, count: ${a.tool_calls?.length||0}`),y(`[OpenAI][${t}] Response content: ${JSON.stringify(a.content)}`),a.content&&y(`[OpenAI][${t}] Response content preview: ${A(a.content,200)}`);let l=i.choices[0],p,m=l.message.tool_calls;return m&&m.length>0&&(p=m.map(d=>({id:d.id,name:s.get(d.function.name)||d.function.name,arguments:JSON.parse(d.function.arguments)}))),{content:l.message.content,usage:i.usage?{prompt_tokens:i.usage.prompt_tokens,completion_tokens:i.usage.completion_tokens,total_tokens:i.usage.total_tokens}:void 0,finish_reason:l.finish_reason,tool_calls:p,raw:i}}catch(t){throw this.handleError(t)}}async*stream(e){try{let t=e.__toolpack_request_id||`str-${Date.now()}`,n={messages:await Promise.all(e.messages.map(l=>this.toOpenAIMessage(l,e.mediaOptions))),model:e.model,temperature:e.temperature,max_tokens:e.max_tokens,top_p:e.top_p,response_format:e.response_format==="json_object"?{type:"json_object"}:e.response_format&&typeof e.response_format=="object"&&"parse"in e.response_format?Qa(e.response_format,"structured_output"):void 0,stream:!0},s=new Map;e.tools&&e.tools.length>0?(n.tools=e.tools.map(l=>{let p=this.sanitizeToolName(l.function.name);return s.set(p,l.function.name),{type:"function",function:{name:p,description:l.function.description,parameters:l.function.parameters}}}),n.tool_choice=e.tool_choice||"auto",y(`[OpenAI][${t}] Sending ${n.tools.length} tools with tool_choice: ${n.tool_choice}`),y(`[OpenAI][${t}] First tool: ${A(n.tools[0],800)}`)):y(`[OpenAI][${t}] NO TOOLS in request`),y(`[OpenAI][${t}] Stream request: model=${n.model}, messages=${n.messages.length}, tools=${n.tools?.length||0}, tool_choice=${n.tool_choice??"unset"}`),te(t,"OpenAI",n.messages);let i=await this.client.chat.completions.create(n,e.signal?{signal:e.signal}:void 0),a=new Map;for await(let l of i){let p=l.choices[0];if(p.finish_reason&&je(`[OpenAI][${t}] Stream chunk finish_reason=${p.finish_reason}`),p.delta.tool_calls)for(let m of p.delta.tool_calls){let d=m.index;a.has(d)||a.set(d,{id:m.id||"",name:m.function?.name||"",args:""});let g=a.get(d);m.id&&(g.id=m.id),m.function?.name&&(g.name=m.function.name),m.function?.arguments&&(g.args+=m.function.arguments),je(`[OpenAI][${t}] tool_call_delta idx=${d} id=${m.id||g.id||""} name=${m.function?.name||g.name||""} args_delta=${A(m.function?.arguments||"",200)}`)}if(p.delta.content&&(yield{delta:p.delta.content,finish_reason:p.finish_reason,usage:l.usage}),!p.delta.content&&p.finish_reason&&p.finish_reason!=="tool_calls"&&(yield{delta:"",finish_reason:p.finish_reason,usage:l.usage}),p.finish_reason==="tool_calls"&&a.size>0){let m=Array.from(a.values()).map(d=>({id:d.id,name:s.get(d.name)||d.name,arguments:JSON.parse(d.args||"{}")}));y(`[OpenAI][${t}] Stream finish_reason=tool_calls accumulated_calls=${m.length} names=${m.map(d=>d.name).join(", ")}`),yield{delta:"",finish_reason:"tool_calls",tool_calls:m}}}}catch(t){throw this.handleError(t)}}async embed(e){try{let t=typeof e.input=="string"?[e.input]:e.input,o=await this.client.embeddings.create({model:e.model,input:t});return{embeddings:o.data.map(n=>n.embedding),usage:o.usage}}catch(t){throw this.handleError(t)}}async toOpenAIMessage(e,t={}){if(e.role==="tool"&&e.tool_call_id)return{role:"tool",tool_call_id:e.tool_call_id,content:typeof e.content=="string"?e.content:JSON.stringify(e.content??"")};if(e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0)return{role:"assistant",content:typeof e.content=="string"?e.content:"",tool_calls:e.tool_calls.map(s=>({id:s.id,type:"function",function:{name:this.sanitizeToolName(s.function.name),arguments:s.function.arguments}}))};if(typeof e.content=="string")return{role:e.role,content:e.content};if(e.content===null||e.content===void 0)return{role:e.role,content:""};let{normalizeImagePart:o}=await Promise.resolve().then(()=>(xt(),Kt)),n=await Promise.all(e.content.map(async s=>{if(s.type==="text")return{type:"text",text:s.text};if(s.type==="image_url")return{type:"image_url",image_url:{url:s.image_url.url}};if(s.type==="image_data"||s.type==="image_file"){let{data:i,mimeType:a}=await o(s);return{type:"image_url",image_url:{url:`data:${a};base64,${i}`}}}return null}));return{role:e.role,content:n.filter(Boolean)}}handleError(e){if(e instanceof Va.APIError){let t=e.message;return e.status===401?new ve(t,e):e.status===429?new fe(t,void 0,e):e.status&&e.status>=400&&e.status<500?new L(t,e):new W(t,e.code||"OPENAI_ERROR",e.status||500,e)}return new W("Unknown error","UNKNOWN",500,e)}};c();var Xa="https://openrouter.ai/api/v1",On=class extends vt{name="openrouter";_apiKey;constructor(e,t={}){super(e,Xa),this._apiKey=e}getDisplayName(){return"OpenRouter"}supportsFileUpload(){return!1}async generate(e){return super.generate(this.normalizeRequest(e))}async*stream(e){yield*super.stream(this.normalizeRequest(e))}normalizeRequest(e){return e.tool_choice==="none"?{...e,tools:void 0,tool_choice:void 0}:e}async getModels(){try{let e=await fetch(`${Xa}/models`,{headers:{Authorization:`Bearer ${this._apiKey}`}});return e.ok?(await e.json()).data.map(o=>this.mapModel(o)):[]}catch{return[]}}mapModel(e){let o=(e.architecture?.modality??"text->text").includes("image");return{id:e.id,displayName:e.name??e.id,capabilities:{chat:!0,streaming:!0,toolCalling:!0,embeddings:!1,vision:o},contextWindow:e.context_length??void 0,maxOutputTokens:e.top_provider?.max_completion_tokens??void 0,inputModalities:o?["text","image"]:["text"],outputModalities:["text"],reasoningTier:null,costTier:this.deriveCostTier(e.pricing)}}deriveCostTier(e){if(!e?.prompt)return"unknown";let t=parseFloat(e.prompt)*1e6;return t<1?"low":t<5?"medium":t<20?"high":"premium"}};xt();c();Bt();c();Bt();var xn=class{tools=new Map;projects=new Map;config=ce;register(e){this.tools.set(e.name,e)}registerCustom(e){this.tools.set(e.name,e)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getNames(){return Array.from(this.tools.keys())}getByCategory(e){return Array.from(this.tools.values()).filter(t=>t.category===e)}getEnabled(){if(this.config.enabledTools.length===0&&this.config.enabledToolCategories.length===0)return Array.from(this.tools.values());let e=this.getByNames(this.config.enabledTools),t=this.getByCategories(this.config.enabledToolCategories),o=new Set,n=[];for(let s of[...e,...t])o.has(s.name)||(o.add(s.name),n.push(s));return n}getSchemas(e){return(e?e.map(o=>this.tools.get(o)).filter(Boolean):this.getEnabled()).map(o=>({name:o.name,displayName:o.displayName,description:o.description,parameters:o.parameters,category:o.category,...o.cacheable!==void 0&&{cacheable:o.cacheable},...o.annotations!==void 0&&{annotations:o.annotations}}))}getByNames(e){return e.map(t=>this.tools.get(t)).filter(Boolean)}getByCategories(e){let t=new Set(e);return Array.from(this.tools.values()).filter(o=>t.has(o.category))}getCategories(){let e=new Set;for(let t of this.tools.values())e.add(t.category);return Array.from(e)}getAll(){return Array.from(this.tools.values())}setConfig(e){this.config=e}getConfig(){return this.config}get size(){return this.tools.size}async validateDependencies(e){let t=e.dependencies;if(!t||Object.keys(t).length===0)return[];let o=[];for(let n of Object.keys(t))try{await import(n)}catch{o.push(n)}return o}async loadProject(e){let t=await this.validateDependencies(e);if(t.length>0)throw new Error(`Tool project "${e.manifest.name}" has missing dependencies: ${t.join(", ")}. Install them with: npm install ${t.join(" ")}`);this.projects.set(e.manifest.name,e);for(let o of e.tools)this.register(o)}async loadProjects(e){for(let t of e)await this.loadProject(t)}getProject(e){return this.projects.get(e)}getProjects(){return Array.from(this.projects.values())}getProjectNames(){return Array.from(this.projects.keys())}async loadBuiltIn(){let{fsToolsProject:e}=await Promise.resolve().then(()=>(ks(),mp)),{execToolsProject:t}=await Promise.resolve().then(()=>(Os(),pm)),{systemToolsProject:o}=await Promise.resolve().then(()=>(Ws(),zm)),{httpToolsProject:n}=await Promise.resolve().then(()=>(Ks(),_d)),{githubToolsProject:s}=await Promise.resolve().then(()=>(ri(),Ou)),{webToolsProject:i}=await Promise.resolve().then(()=>(yi(),ng)),{codingToolsProject:a}=await Promise.resolve().then(()=>(Ni(),Hh)),{gitToolsProject:l}=await Promise.resolve().then(()=>(Ii(),ky)),{diffToolsProject:p}=await Promise.resolve().then(()=>(ji(),qy)),{dbToolsProject:m}=await Promise.resolve().then(()=>(Fi(),ub)),{cloudToolsProject:d}=await Promise.resolve().then(()=>(qi(),Sb)),{slackToolsProject:g}=await Promise.resolve().then(()=>(Ki(),lw)),{k8sToolsProject:b}=await Promise.resolve().then(()=>(Ji(),dw));await this.loadProjects([e,t,o,n,s,i,a,l,p,m,d,g,b])}};ai();c();S();function EC(r){if(!r.key||!/^[a-z0-9-]+$/.test(r.key))throw new Error(`Invalid tool project key: "${r.key}". Must be non-empty, lowercase, and contain no spaces (use hyphens).`);if(!r.name.trim())throw new Error("Tool project name cannot be empty.");if(!r.tools||r.tools.length===0)throw new Error("Tool project must contain at least one tool.");for(let t of r.tools){if(!t.name)throw new Error("Tool is missing a name.");if(!t.description)throw new Error(`Tool "${t.name}" is missing a description.`);if(!t.parameters)throw new Error(`Tool "${t.name}" is missing parameters.`);if(typeof t.execute!="function")throw new Error(`Tool "${t.name}" is missing an execute function.`);t.category!==r.category&&I(`[Toolpack] Tool "${t.name}" has category "${t.category}" which does not match project category "${r.category}".`)}let e=r.tools.map(t=>t.name);return{manifest:{key:r.key,name:r.name,displayName:r.displayName,version:r.version,description:r.description,author:r.author,repository:r.repository,category:r.category,tools:e},dependencies:r.dependencies,tools:r.tools}}Ut();ks();Os();Ws();Ks();ri();yi();Ni();Ii();ji();Fi();qi();Ji();Ki();c();c();S();import{spawn as DC}from"child_process";import{EventEmitter as MC}from"events";var Nr=class extends Error{constructor(e,t){super(`MCP request timed out after ${t}ms: ${e}`),this.name="McpTimeoutError"}},Oe=class extends Error{constructor(t,o){super(t);this.exitCode=o;this.name="McpConnectionError"}exitCode},vn=class extends MC{constructor(t){super();this.config=t;this.defaultTimeoutMs=t.requestTimeoutMs??3e4,this.autoReconnect=t.autoReconnect??!1,this.maxReconnectAttempts=t.maxReconnectAttempts??3,this.reconnectDelayMs=t.reconnectDelayMs??1e3}config;process=null;messageQueue=new Map;nextId=1;buffer="";_connected=!1;_shuttingDown=!1;_reconnectAttempts=0;defaultTimeoutMs;autoReconnect;maxReconnectAttempts;reconnectDelayMs;get connected(){return this._connected&&this.process!==null}async initializeServer(){await this.request("initialize",{client:"toolpack-sdk"})}async connect(){if(this._shuttingDown)throw new Oe("Client is shutting down");if(this.buffer="",this.process=DC(this.config.command,this.config.args||[],{env:{...process.env,...this.config.env},stdio:["pipe","pipe","pipe"]}),!this.process.stdout||!this.process.stdin)throw new Oe("Failed to spawn MCP server: stdout/stdin unavailable");this.process.stdout.on("data",t=>{this.handleData(t)}),this.process.stderr&&this.process.stderr.on("data",t=>{I(`[MCP server stderr] ${t.toString().trim()}`)}),this.process.on("error",t=>{this._connected=!1,this.emit("error",t)}),this.process.on("exit",t=>{let o=this._connected;this._connected=!1,this.process=null,this.rejectAllPending(new Oe(`MCP server exited with code ${t}`,t)),this.emit("close",t),o&&!this._shuttingDown&&this.autoReconnect&&this.attemptReconnect()}),this._reconnectAttempts=0,await this.initializeServer(),this._connected=!0}async attemptReconnect(){if(this._reconnectAttempts>=this.maxReconnectAttempts){this.emit("reconnect_failed",this._reconnectAttempts);return}this._reconnectAttempts++;let t=this._reconnectAttempts;if(this.emit("reconnecting",{attempt:t,max:this.maxReconnectAttempts}),await new Promise(o=>setTimeout(o,this.reconnectDelayMs*t)),!this._shuttingDown)try{await this.connect(),this.emit("reconnected",{attempt:t})}catch(o){this.emit("reconnect_error",{attempt:t,error:o})}}handleData(t){this.buffer+=t.toString();let o;for(;(o=this.buffer.indexOf(`
|
|
467
|
+
`))!==-1;){let n=this.buffer.slice(0,o).trim();if(this.buffer=this.buffer.slice(o+1),n)try{let s=JSON.parse(n);this.handleMessage(s)}catch{}}}handleMessage(t){if(t.id&&(t.result!==void 0||t.error)){let o=this.messageQueue.get(t.id);o&&(o.timer&&clearTimeout(o.timer),t.error?o.reject(new Error(t.error.message)):o.resolve(t.result),this.messageQueue.delete(t.id))}else t.method&&(this.emit("notification",t),this.emit(t.method,t.params))}async callTool(t,o={},n){return this.request("tools/call",{name:t,arguments:o},n)}async readResource(t,o){return this.request("resources/read",{uri:t},o)}async request(t,o,n){if(!this.process||!this.process.stdin)throw new Oe("Client not connected");let s=this.nextId++,i=n??this.defaultTimeoutMs,a={jsonrpc:"2.0",id:s,method:t,params:o};return new Promise((l,p)=>{let m;i>0&&(m=setTimeout(()=>{let d=this.messageQueue.get(s);d&&(this.messageQueue.delete(s),d.reject(new Nr(t,i)))},i)),this.messageQueue.set(s,{resolve:l,reject:p,timer:m});try{this.process.stdin.write(JSON.stringify(a)+`
|
|
468
|
+
`)}catch(d){m&&clearTimeout(m),this.messageQueue.delete(s),p(d)}})}async disconnect(t=3e3){if(this._shuttingDown=!0,this.rejectAllPending(new Oe("Client disconnecting")),!this.process){this._shuttingDown=!1;return}let o=this.process;return new Promise(n=>{let s=!1,i=()=>{s||(s=!0,this.process=null,this._connected=!1,this._shuttingDown=!1,n())};o.once("exit",i),o.kill("SIGTERM"),setTimeout(()=>{if(!s){try{o.kill("SIGKILL")}catch{}i()}},t)})}kill(){this._shuttingDown=!0,this.rejectAllPending(new Oe("Client killed")),this.process&&(this.process.kill("SIGKILL"),this.process=null),this._connected=!1,this._shuttingDown=!1}rejectAllPending(t){for(let[o,n]of this.messageQueue)n.timer&&clearTimeout(n.timer),n.reject(t);this.messageQueue.clear()}};S();var Ir=class{constructor(e){this.config=e}config;clients=new Map;serverConfigs=new Map;toolDefinitions=new Map;toolOwners=new Map;async connectServer(e){let{name:t,displayName:o,toolPrefix:n,...s}=e;P(`[MCP] Connecting to server: ${o||t}`);try{let i=new vn({...s,requestTimeoutMs:s.requestTimeoutMs??this.config.defaultTimeoutMs,autoReconnect:s.autoReconnect??this.config.autoReconnect??!0});this.setupClientEvents(i,t),await i.connect(),this.clients.set(t,i),this.serverConfigs.set(t,e),await this.discoverServerTools(t,i,e)}catch(i){throw pe(`[MCP] Failed to connect to ${t}: ${i}`),i}}async connectAll(){let e=this.config.servers.filter(t=>t.autoConnect!==!1).map(t=>this.connectServer(t));await Promise.allSettled(e)}async disconnectServer(e){let t=this.clients.get(e);if(!t){I(`[MCP] Server ${e} not found`);return}P(`[MCP] Disconnecting from ${e}`);for(let[o,n]of this.toolOwners)n===e&&(this.toolDefinitions.delete(o),this.toolOwners.delete(o));await t.disconnect(),this.clients.delete(e),this.serverConfigs.delete(e)}async disconnectAll(){let e=Array.from(this.clients.keys()).map(t=>this.disconnectServer(t));await Promise.allSettled(e)}getToolDefinitions(){return Array.from(this.toolDefinitions.values())}getConnectedServers(){return Array.from(this.clients.keys())}isServerConnected(e){return this.clients.get(e)?.connected??!1}convertMcpTool(e,t,o,n){let s={type:"object",properties:e.inputSchema.properties||{},required:e.inputSchema.required||[]};return{name:`${o}${e.name}`,displayName:e.name,description:e.description||`MCP tool from ${t}`,category:"mcp",parameters:s,execute:async i=>{try{P(`[MCP] Executing ${e.name} on ${t}`);let a=await n.callTool(e.name,i);return JSON.stringify(a)}catch(a){throw pe(`[MCP] Tool execution failed: ${a}`),a}}}}setupClientEvents(e,t){e.on("error",o=>{pe(`[MCP] ${t} error: ${o}`)}),e.on("close",o=>{I(`[MCP] ${t} closed with code ${o}`)}),e.on("reconnecting",({attempt:o,max:n})=>{P(`[MCP] ${t} reconnecting (${o}/${n})`)}),e.on("reconnected",({attempt:o})=>{P(`[MCP] ${t} reconnected after ${o} attempts`),this.refreshServerTools(t).catch(n=>{pe(`[MCP] ${t} tool refresh failed after reconnect: ${n}`)})}),e.on("reconnect_failed",o=>{pe(`[MCP] ${t} failed to reconnect after ${o} attempts`)}),e.on("notification",o=>{P(`[MCP] ${t} notification: ${JSON.stringify(o)}`)})}removeServerToolDefinitions(e){for(let[t,o]of this.toolOwners)o===e&&(this.toolDefinitions.delete(t),this.toolOwners.delete(t))}async discoverServerTools(e,t,o){let s=(await t.request("tools/list"))?.tools||[];P(`[MCP] Discovered ${s.length} tools from ${e}`),this.removeServerToolDefinitions(e);let i=o.toolPrefix||`mcp.${e}.`;for(let a of s){let l=this.convertMcpTool(a,e,i,t);this.toolDefinitions.set(l.name,l),this.toolOwners.set(l.name,e)}}async refreshServerTools(e){let t=this.clients.get(e),o=this.serverConfigs.get(e);!t||!o||await this.discoverServerTools(e,t,o)}};async function Vi(r){let e=new Ir(r);await e.connectAll();let t=e.getToolDefinitions();return{manifest:{key:"mcp-tools",name:"mcp-tools",displayName:"MCP Tools",version:"1.0.0",description:`Tools from ${e.getConnectedServers().length} MCP server(s)`,category:"mcp",author:"Toolpack SDK",tools:t.map(n=>n.name)},tools:t,mcpManager:e}}async function Qi(r){"mcpManager"in r&&await r.mcpManager.disconnectAll()}c();import*as J from"fs/promises";import*as ne from"path";function Yi(r){let e={},t=r.match(/^---\n([\s\S]*?)\n---/);if(!t||!t[1])return e;for(let o of t[1].split(`
|
|
469
|
+
`)){let n=o.indexOf(":");if(n===-1)continue;let s=o.substring(0,n).trim(),i=o.substring(n+1).trim();e[s]=i}return e}function Zi(r){let e=r.match(/\[(.*)\]/);return!e||!e[1]?[]:e[1].split(",").map(t=>t.trim().replace(/"/g,"")).filter(Boolean)}function Xi(r){let e=[],t=r.match(/## Triggers\n\n([\s\S]*?)(?=\n## |$)/);if(!t||!t[1])return e;for(let o of t[1].split(`
|
|
470
|
+
`).filter(n=>n.startsWith("- "))){let n=o.match(/^- "(.*)"/);n&&n[1]&&e.push(n[1])}return e}function pt(r,e){let t=r.match(new RegExp(`## ${e}\\n\\n([\\s\\S]*?)(?=\\n## |$)`));return t&&t[1]?t[1].trim():""}async function uw(r,e){async function t(o){let n;try{n=await J.readdir(o)}catch{return null}for(let s of n){let i=ne.join(o,s),a;try{a=await J.stat(i)}catch{continue}if(a.isDirectory()){let l=await t(i);if(l)return l}else if(a.isFile()&&s===`${e}.skill.md`)return i}return null}return t(r)}async function AC(r){let e=[];async function t(o){let n;try{n=await J.readdir(o)}catch{return}for(let s of n){let i=ne.join(o,s),a;try{a=await J.stat(i)}catch{continue}a.isDirectory()?await t(i):a.isFile()&&s.endsWith(".skill.md")&&e.push(i)}}return await t(r),e}function OC(r){let{name:e,title:t,description:o,triggers:n,instructions:s,examples:i,tags:a}=r,l=new Date().toISOString(),p=a&&a.length>0?a.map(d=>`"${d}"`).join(", "):"",m=["---",`name: ${e}`,`title: ${t}`,"version: 1.0.0",`updated: ${l}`,`tags: [${p}]`,"---","","## Description","",o,"","## Triggers","",n.map(d=>`- "${d}"`).join(`
|
|
471
471
|
`),"","## Instructions","",s,""];return i&&m.push("## Examples","",i,""),m.join(`
|
|
472
|
-
`)}function
|
|
473
|
-
`),i=
|
|
474
|
-
`),d=
|
|
472
|
+
`)}function NC(r){return{name:"skill.create",displayName:"Create Skill",description:"Create a new .skill.md file in the skill library.",category:"skills",parameters:{type:"object",properties:{name:{type:"string",description:'Skill name in kebab-case (e.g. "code-review"). Used as the filename.'},title:{type:"string",description:"Human-readable title for the skill (max 100 chars)."},description:{type:"string",description:"Short description for BM25 search indexing (max 300 chars)."},triggers:{type:"array",items:{type:"string"},description:"List of trigger phrases that activate this skill (min 1, max 10)."},instructions:{type:"string",description:"Behavioral instructions injected into context when the skill activates (max 2000 chars)."},examples:{type:"string",description:"Optional examples section (max 3000 chars, never auto-injected)."},tags:{type:"array",items:{type:"string"},description:"Optional tags for filtering and search (max 10)."},subfolder:{type:"string",description:'Optional subfolder within the skills directory (e.g. "coding").'}},required:["name","title","description","triggers","instructions"]},async execute(e){let t=e.name,o=e.title,n=e.description,s=e.triggers??[],i=e.instructions,a=e.examples,l=e.tags??[],p=e.subfolder;if(!/^[a-z][a-z0-9-]*$/.test(t))return JSON.stringify({error:"invalid_name",message:"Skill name must be kebab-case (lowercase letters, numbers, hyphens, starting with a letter)"},null,2);let m=p?ne.join(r,p):r;await J.mkdir(m,{recursive:!0});let d=ne.join(m,`${t}.skill.md`);try{return await J.access(d),JSON.stringify({error:"skill_exists",message:`Skill "${t}" already exists at ${d}. Use skill.update to modify it.`},null,2)}catch{}let g=OC({name:t,title:o,description:n,triggers:s,instructions:i,examples:a,tags:l});return await J.writeFile(d,g,"utf-8"),JSON.stringify({success:!0,skill:t,path:d,message:`Skill "${o}" created successfully`},null,2)}}}function IC(r){return{name:"skill.read",displayName:"Read Skill",description:"Read a skill file by name. Optionally read only a specific section.",category:"skills",parameters:{type:"object",properties:{name:{type:"string",description:"Skill name (without the .skill.md extension)."},section:{type:"string",enum:["all","metadata","description","triggers","instructions","examples"],description:"Which section to return (default: all).",default:"all"}},required:["name"]},async execute(e){let t=e.name,o=e.section||"all",n=await uw(r,t);if(!n)return JSON.stringify({error:"skill_not_found",message:`Skill "${t}" not found. Use skill.list to see available skills.`},null,2);let s=(await J.readFile(n,"utf-8")).replace(/\r\n/g,`
|
|
473
|
+
`),i=Yi(s),a={name:i.name||t,title:i.title||t,version:i.version,tags:i.tags?Zi(i.tags):[],updated:i.updated,path:n};return JSON.stringify(o==="metadata"?{skill:t,metadata:a}:o==="description"?{skill:t,description:pt(s,"Description")}:o==="triggers"?{skill:t,triggers:Xi(s)}:o==="instructions"?{skill:t,instructions:pt(s,"Instructions")}:o==="examples"?{skill:t,examples:pt(s,"Examples")}:{skill:t,path:n,metadata:a,description:pt(s,"Description"),triggers:Xi(s),instructions:pt(s,"Instructions"),examples:pt(s,"Examples")||void 0},null,2)}}}function jC(r){return{name:"skill.update",displayName:"Update Skill",description:"Update fields of an existing skill. Only provided fields are changed.",category:"skills",parameters:{type:"object",properties:{name:{type:"string",description:"Skill name to update."},title:{type:"string",description:"New title (optional)."},description:{type:"string",description:"New description replacing the existing one (optional)."},triggers:{type:"array",items:{type:"string"},description:"New triggers list replacing the existing one (optional)."},instructions:{type:"string",description:"New instructions replacing the existing ones (optional)."},addExamples:{type:"string",description:"Additional examples text to append to the Examples section (optional)."},addTags:{type:"array",items:{type:"string"},description:"Tags to add to the existing tags (optional)."}},required:["name"]},async execute(e){let t=e.name,o=e.title,n=e.description,s=e.triggers,i=e.instructions,a=e.addExamples,l=e.addTags,p=await uw(r,t);if(!p)return JSON.stringify({error:"skill_not_found",message:`Skill "${t}" not found. Use skill.create to create it first.`},null,2);let m=(await J.readFile(p,"utf-8")).replace(/\r\n/g,`
|
|
474
|
+
`),d=Yi(m),g=d.tags?Zi(d.tags):[],b=d.title||t,w=d.version||"1.0.0",T=o??b,v=l?[...new Set([...g,...l])]:g,k=new Date().toISOString();if(n!==void 0&&(m=m.replace(/## Description\n\n[\s\S]*?(?=\n## )/,`## Description
|
|
475
475
|
|
|
476
476
|
${n}
|
|
477
477
|
|
|
478
|
-
`)),s!==void 0){let
|
|
478
|
+
`)),s!==void 0){let D=s.map(M=>`- "${M}"`).join(`
|
|
479
479
|
`);m=m.replace(/## Triggers\n\n[\s\S]*?(?=\n## )/,`## Triggers
|
|
480
480
|
|
|
481
|
-
${
|
|
481
|
+
${D}
|
|
482
482
|
|
|
483
483
|
`)}if(i!==void 0&&(m=m.replace(/## Instructions\n\n[\s\S]*?(?=\n## |$)/,`## Instructions
|
|
484
484
|
|
|
485
485
|
${i}
|
|
486
486
|
|
|
487
|
-
`)),a){let
|
|
487
|
+
`)),a){let D=m.match(/## Examples\n\n([\s\S]*?)(?=\n## |$)/);if(D){let M=D[1]??"",C=M.trim()?`
|
|
488
488
|
|
|
489
489
|
`:"";m=m.replace(/## Examples\n\n[\s\S]*?(?=\n## |$)/,`## Examples
|
|
490
490
|
|
|
491
|
-
${
|
|
491
|
+
${M}${C}${a}
|
|
492
492
|
|
|
493
493
|
`)}else m=m.trimEnd()+`
|
|
494
494
|
|
|
495
495
|
## Examples
|
|
496
496
|
|
|
497
497
|
${a}
|
|
498
|
-
`}m=m.replace(/^---\n[\s\S]*?\n---/,["---",`name: ${t}`,`title: ${T}`,`version: ${
|
|
499
|
-
`)),await
|
|
500
|
-
`),l=
|
|
498
|
+
`}m=m.replace(/^---\n[\s\S]*?\n---/,["---",`name: ${t}`,`title: ${T}`,`version: ${w}`,`updated: ${k}`,`tags: [${v.map(D=>`"${D}"`).join(", ")}]`,"---"].join(`
|
|
499
|
+
`)),await J.writeFile(p,m,"utf-8");let x=[];return o&&x.push("title"),n!==void 0&&x.push("description"),s!==void 0&&x.push("triggers"),i!==void 0&&x.push("instructions"),a&&x.push("examples (appended)"),l&&x.push(`tags (+${l.length})`),JSON.stringify({success:!0,skill:t,path:p,updated:x,message:`Skill "${t}" updated successfully`},null,2)}}}function LC(r){return{name:"skill.list",displayName:"List Skills",description:"List all skills in the skill library, optionally filtered by tag.",category:"skills",parameters:{type:"object",properties:{tag:{type:"string",description:"Filter skills by tag (optional)."},verbose:{type:"boolean",description:"Include description and triggers in the output (default: false).",default:!1}},required:[]},async execute(e){let t=e.tag,o=e.verbose??!1;try{await J.access(r)}catch{return JSON.stringify({skills:[],count:0,message:"No skills directory found. Use skill.create to create your first skill."},null,2)}let n=await AC(r);if(n.length===0)return JSON.stringify({skills:[],count:0,message:"No skills found. Use skill.create to create your first skill."},null,2);let s=[];for(let i of n){let a=(await J.readFile(i,"utf-8")).replace(/\r\n/g,`
|
|
500
|
+
`),l=Yi(a),p=l.name||ne.basename(i,".skill.md"),m=l.title||p,d=l.tags?Zi(l.tags):[];if(t&&!d.includes(t))continue;let g=ne.dirname(ne.relative(r,i)),b=g==="."?void 0:g.split(ne.sep)[0];o?s.push({name:p,title:m,tags:d,category:b,description:pt(a,"Description")||void 0,triggers:Xi(a)}):s.push({name:p,title:m,tags:d,category:b})}return JSON.stringify({skills:s,count:s.length,filtered:t?`by tag: ${t}`:null},null,2)}}}function FC(r){let e=ne.resolve(r?.dir??".toolpack/skills"),t=[NC(e),IC(e),jC(e),LC(e)];return{manifest:{key:"skill",name:"skill-tools",displayName:"Skill Management",version:"1.0.0",description:"Tools for creating, reading, updating, and listing agent skill files.",tools:["skill.create","skill.read","skill.update","skill.list"],category:"skills"},tools:t}}c();c();c();c();var ea=`
|
|
501
501
|
You are a planning assistant. Given a user request, create a detailed step-by-step plan.
|
|
502
502
|
|
|
503
503
|
Rules:
|
|
@@ -523,7 +523,7 @@ Rules:
|
|
|
523
523
|
}
|
|
524
524
|
]
|
|
525
525
|
}
|
|
526
|
-
`,
|
|
526
|
+
`,K1={name:"Direct",planning:{enabled:!1},progress:{enabled:!0}},fw={name:"Agent",planning:{enabled:!0,planningPrompt:ea},progress:{enabled:!0},complexityRouting:{enabled:!0,strategy:"single-step",confidenceThreshold:.6}},qC=`
|
|
527
527
|
Create a step-by-step plan for this coding task.
|
|
528
528
|
|
|
529
529
|
Rules:
|
|
@@ -546,7 +546,7 @@ JSON Schema:
|
|
|
546
546
|
}
|
|
547
547
|
]
|
|
548
548
|
}
|
|
549
|
-
`,fw={name:"Coding",planning:{enabled:!0,planningPrompt:FC},progress:{enabled:!0},complexityRouting:{enabled:!0,strategy:"single-step",confidenceThreshold:.6}},gw={name:"Chat",planning:{enabled:!1},progress:{enabled:!1}};var hw={name:"agent",displayName:"Agent",description:"Full autonomous access \u2014 read, write, execute, browse",systemPrompt:["You are an autonomous AI agent with full access to all available tools.","You must use the tools provided to accomplish tasks end-to-end proactively.","If you require a capability that is not listed in your current tools, ALWAYS use `tool.search` to find it before improvising or giving up.","Before considering a tool to call, make sure that is the right tool for the job as per the users prompt.","Verify your actions and check for success or failure states.","Explain your actions briefly as you go."].join(" "),allowedToolCategories:[],blockedToolCategories:[],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!0,includeToolCategories:!0},workflow:uw,toolSearch:{alwaysLoadedTools:["fs.read_file","fs.write_file","fs.list_dir","web.search","web.fetch","skill.search","skill.read"]}},yw={name:"chat",displayName:"Chat",description:"Conversational assistant with web access",systemPrompt:["You are a conversational AI assistant with web access.","You can search the web, fetch online content, and make HTTP requests.","You do NOT have access to the local filesystem, command execution, or code modification.","Answer questions using your knowledge and web tools when helpful.","If the user asks for local file operations or code changes,","explain that you are in Chat mode and suggest they switch to Agent mode."].join(" "),allowedToolCategories:["network"],blockedToolCategories:["filesystem","execution","system","coding","git","database"],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!1,includeToolCategories:!0},workflow:gw,toolSearch:{alwaysLoadedTools:["web.search","web.fetch","fs.read_file","fs.list_dir"]}},bw={name:"coding",displayName:"Coding",description:"Concise coding mode \u2014 minimal text, focused on file operations and code changes",systemPrompt:["Coding assistant. Use tools to modify code.","Be concise. No conversational filler.","Show code changes clearly."].join(" "),allowedToolCategories:[],blockedToolCategories:[],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!0,includeToolCategories:!0},workflow:fw,toolSearch:{alwaysLoadedTools:["coding.read_code","coding.search_code","fs.read_file","fs.write_file","fs.list_dir","skill.search","skill.read","web.search","web.fetch"]}},Ir=[hw,bw,yw],Ot="chat";var vn=class{modes=new Map;orderedNames=[];constructor(){for(let e of Ir)this.register(e)}register(e){if(!e.name||typeof e.name!="string")throw new Error("ModeConfig.name is required and must be a non-empty string");if(!e.displayName||typeof e.displayName!="string")throw new Error("ModeConfig.displayName is required and must be a non-empty string");if(typeof e.systemPrompt!="string")throw new Error("ModeConfig.systemPrompt must be a string (can be empty for passthrough)");if(e.blockAllTools!==void 0&&typeof e.blockAllTools!="boolean")throw new Error("ModeConfig.blockAllTools must be a boolean");let t=["allowedToolCategories","blockedToolCategories","allowedTools","blockedTools"];for(let n of t)if(e[n]!==void 0&&!Array.isArray(e[n]))throw new Error(`ModeConfig.${n} must be an array`);let o=this.modes.has(e.name);this.modes.set(e.name,e),o||this.orderedNames.push(e.name)}get(e){return this.modes.get(e)}has(e){return this.modes.has(e)}getAll(){let e=[];for(let t of this.orderedNames){let o=this.modes.get(t);o&&e.push(o)}return e}getNames(){return[...this.orderedNames]}getDefault(){let e=this.modes.get(Ot);if(!e)throw new Error(`Default mode "${Ot}" not found in registry`);return e}getNext(e){let t=this.orderedNames.indexOf(e),o=t===-1?0:(t+1)%this.orderedNames.length,n=this.orderedNames[o],s=this.modes.get(n);if(!s)throw new Error(`Mode "${n}" not found in registry`);return s}get size(){return this.modes.size}remove(e){if(Ir.some(n=>n.name===e))return!1;let o=this.modes.delete(e);return o&&(this.orderedNames=this.orderedNames.filter(n=>n!==e)),o}};c();function qC(r){return{name:r.name,displayName:r.displayName,description:r.description||r.displayName,systemPrompt:r.systemPrompt,allowedToolCategories:r.allowedToolCategories||[],blockedToolCategories:r.blockedToolCategories||[],allowedTools:r.allowedTools||[],blockedTools:r.blockedTools||[],blockAllTools:r.blockAllTools||!1,response_format:r.response_format,baseContext:r.baseContext,workflow:r.workflow}}c();var ea={planning:{enabled:!1},progress:{enabled:!0}};c();k();var WC=Zi,Cn=class{client;config;constructor(e,t){this.client=e,this.config=t}async createPlan(e,t){let o=this.config?.planningPrompt||WC,n=e.messages.filter(p=>p.role==="user").map(p=>typeof p.content=="string"?p.content:"[obj]").join(" ").substring(0,100);y(`[Planner] createPlan() provider=${t??"default"} maxSteps=${this.config?.maxSteps??20} request="${n}..."`);let s=e.messages.filter(p=>p.role==="system"),i=e.messages.filter(p=>p.role!=="system"),a=[{role:"system",content:o},...s,...i],l={...e,tools:void 0,tool_choice:"none",response_format:"json_object",messages:a};try{let p=await this.client.generate(l,t),m=this.parsePlan(p.content||"",e,p);return P(`[Planner] createPlan() succeeded plan.id=${m.id} steps=${m.steps.length}`),m}catch(p){return I(`[Planner] createPlan() failed, using fallback: ${p.message}`),this.createFallbackPlan(e)}}parsePlan(e,t,o){try{let n=JSON.parse(e);if(!n.summary||!Array.isArray(n.steps))throw new Error("Invalid plan structure: missing summary or steps array");let s=this.config?.maxSteps??20,i=n.steps.slice(0,s);n.steps.length>s&&I(`[Planner] parsePlan() truncated ${n.steps.length} steps to maxSteps=${s}`),y(`[Planner] parsePlan() parsed ${i.length} steps successfully`);let a=i.map((p,m)=>({id:`step-${Date.now()}-${m}`,number:p.number||m+1,description:p.description||"Unknown step",expectedTools:p.expectedTools||[],dependsOn:p.dependsOn||[],status:"pending"})),l=t.messages.filter(p=>p.role==="user").map(p=>typeof p.content=="string"?p.content:"[Complex Object]").join("\\n");return{id:`plan-${Date.now()}`,request:l,summary:n.summary,steps:a,status:"draft",createdAt:new Date,planningResponse:o}}catch(n){return I(`[Planner] parsePlan() failed: ${n.message} \u2014 using fallback`),this.createFallbackPlan(t)}}createFallbackPlan(e){I("[Planner] createFallbackPlan() \u2014 creating single-step fallback due to plan generation failure");let t=e.messages.filter(o=>o.role==="user").map(o=>typeof o.content=="string"?o.content:"[Complex Object]").join("\\n");return{id:`plan-${Date.now()}-fallback`,request:t,summary:"Fallback single-step plan due to generation failure",steps:[{id:"step-1",number:1,description:"Execute the user request",status:"pending",expectedTools:[],dependsOn:[]}],status:"draft",createdAt:new Date}}};c();import{EventEmitter as UC}from"events";k();var Lr=class extends UC{client;config;planner;queryClassifier;pendingApprovals=new Map;constructor(e,t,o){super(),this.client=e,this.config=t,this.queryClassifier=o||new bt,this.planner=new Cn(e,t.planning)}getConfig(){return this.config}setConfig(e){this.config=e,this.planner=new Cn(this.client,e.planning)}shouldRouteSimpleQuery(e){if(!this.config.complexityRouting?.enabled)return!1;let t=this.config.complexityRouting.strategy??"single-step";if(t==="disabled")return!1;let o=Ze(e.messages);if(!o)return!1;let n=this.queryClassifier.classify(o),s=this.config.complexityRouting.confidenceThreshold??.6,i=!1;switch(n.type){case"action":i=!1;break;case"conversational":i=!0;break;case"analytical":i=n.confidence>=s;break}return y(`[Workflow] shouldRouteSimpleQuery() type=${n.type} confidence=${n.confidence.toFixed(2)} threshold=${s} shouldRoute=${i} strategy=${t}`),i}async execute(e,t){if(this.shouldRouteSimpleQuery(e))return this.executeDirect(e,t);let o=this.config.planning?.enabled;if(y(`[Workflow] execute() planningEnabled=${o} provider=${t??"default"}`),!o)return y("[Workflow] execute() mode=direct"),this.executeDirect(e,t);y("[Workflow] execute() mode=plan-direct \u2014 creating plan");let n=await this.createPlan(e,t);if(this.emit("workflow:plan_created",n),this.config.planning?.requireApproval){P(`[Workflow] Plan "${n.id}" requires approval \u2014 waiting`),this.emitProgress(n,"awaiting_approval","Waiting for plan approval");let s=await this.waitForApproval(n.id);if(this.emit("workflow:plan_decision",n,s),!s)return P(`[Workflow] Plan "${n.id}" rejected by user`),n.status="cancelled",this.emitProgress(n,"failed","Plan rejected by user"),{success:!1,plan:n,error:"Plan rejected by user",metrics:{totalDuration:0,stepsCompleted:0,stepsFailed:0,retriesUsed:0}};P(`[Workflow] Plan "${n.id}" approved`)}return n.status="approved",this.executePlanDirect(n,e,t)}async executeDirect(e,t){let o=Date.now(),n=this.createDummyPlan(e);y(`[Workflow] executeDirect() provider=${t??"default"}`);try{this.emitProgress(n,"executing","Direct execution");let s=await this.client.generate(e,t);n.status="completed",n.completedAt=new Date,n.steps[0].status="completed";let i=Date.now()-o;y(`[Workflow] executeDirect() completed in ${i}ms content_len=${s.content?.length??0}`);let a={success:!0,plan:n,output:s.content||void 0,response:s,metrics:{totalDuration:Date.now()-o,stepsCompleted:1,stepsFailed:0,retriesUsed:0}};return this.emit("workflow:completed",n,a),this.emitProgress(n,"completed","Done"),a}catch(s){n.status="failed",n.completedAt=new Date,n.steps[0].status="failed",I(`[Workflow] executeDirect() failed: ${s.message}`);let i={success:!1,plan:n,error:s.message,metrics:{totalDuration:Date.now()-o,stepsCompleted:0,stepsFailed:1,retriesUsed:0}};return this.emit("workflow:failed",n,s),this.emitProgress(n,"failed","Execution failed"),i}}async createPlan(e,t){y(`[Workflow] createPlan() provider=${t??"default"}`);let o=this.createDummyPlan(e);o.status="draft",this.emitProgress(o,"planning","Creating plan...");let n=await this.planner.createPlan(e,t);return P(`[Workflow] createPlan() completed plan.id=${n.id} steps=${n.steps.length}`),n}async executePlanDirect(e,t,o){let n=Date.now();e.status="in_progress",e.startedAt=new Date,this.emit("workflow:started",e),this.emitProgress(e,"executing","Executing plan",10),y(`[Workflow] executePlanDirect() plan.id=${e.id} steps=${e.steps.length} provider=${o??"default"}`);let s=`
|
|
549
|
+
`,gw={name:"Coding",planning:{enabled:!0,planningPrompt:qC},progress:{enabled:!0},complexityRouting:{enabled:!0,strategy:"single-step",confidenceThreshold:.6}},hw={name:"Chat",planning:{enabled:!1},progress:{enabled:!1}};var yw={name:"agent",displayName:"Agent",description:"Full autonomous access \u2014 read, write, execute, browse",systemPrompt:["You are an autonomous AI agent with full access to all available tools.","You must use the tools provided to accomplish tasks end-to-end proactively.","If you require a capability that is not listed in your current tools, ALWAYS use `tool.search` to find it before improvising or giving up.","Before considering a tool to call, make sure that is the right tool for the job as per the users prompt.","Verify your actions and check for success or failure states.","Explain your actions briefly as you go."].join(" "),allowedToolCategories:[],blockedToolCategories:[],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!0,includeToolCategories:!0},workflow:fw,toolSearch:{alwaysLoadedTools:["fs.read_file","fs.write_file","fs.list_dir","web.search","web.fetch","skill.search","skill.read"]}},bw={name:"chat",displayName:"Chat",description:"Conversational assistant with web access",systemPrompt:["You are a conversational AI assistant with web access.","You can search the web, fetch online content, and make HTTP requests.","You do NOT have access to the local filesystem, command execution, or code modification.","Answer questions using your knowledge and web tools when helpful.","If the user asks for local file operations or code changes,","explain that you are in Chat mode and suggest they switch to Agent mode."].join(" "),allowedToolCategories:["network"],blockedToolCategories:["filesystem","execution","system","coding","git","database"],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!1,includeToolCategories:!0},workflow:hw,toolSearch:{alwaysLoadedTools:["web.search","web.fetch","fs.read_file","fs.list_dir"]}},ww={name:"coding",displayName:"Coding",description:"Concise coding mode \u2014 minimal text, focused on file operations and code changes",systemPrompt:["Coding assistant. Use tools to modify code.","Be concise. No conversational filler.","Show code changes clearly."].join(" "),allowedToolCategories:[],blockedToolCategories:[],allowedTools:[],blockedTools:[],blockAllTools:!1,baseContext:{includeWorkingDirectory:!0,includeToolCategories:!0},workflow:gw,toolSearch:{alwaysLoadedTools:["coding.read_code","coding.search_code","fs.read_file","fs.write_file","fs.list_dir","skill.search","skill.read","web.search","web.fetch"]}},jr=[yw,ww,bw],Ot="chat";var Cn=class{modes=new Map;orderedNames=[];constructor(){for(let e of jr)this.register(e)}register(e){if(!e.name||typeof e.name!="string")throw new Error("ModeConfig.name is required and must be a non-empty string");if(!e.displayName||typeof e.displayName!="string")throw new Error("ModeConfig.displayName is required and must be a non-empty string");if(typeof e.systemPrompt!="string")throw new Error("ModeConfig.systemPrompt must be a string (can be empty for passthrough)");if(e.blockAllTools!==void 0&&typeof e.blockAllTools!="boolean")throw new Error("ModeConfig.blockAllTools must be a boolean");let t=["allowedToolCategories","blockedToolCategories","allowedTools","blockedTools"];for(let n of t)if(e[n]!==void 0&&!Array.isArray(e[n]))throw new Error(`ModeConfig.${n} must be an array`);let o=this.modes.has(e.name);this.modes.set(e.name,e),o||this.orderedNames.push(e.name)}get(e){return this.modes.get(e)}has(e){return this.modes.has(e)}getAll(){let e=[];for(let t of this.orderedNames){let o=this.modes.get(t);o&&e.push(o)}return e}getNames(){return[...this.orderedNames]}getDefault(){let e=this.modes.get(Ot);if(!e)throw new Error(`Default mode "${Ot}" not found in registry`);return e}getNext(e){let t=this.orderedNames.indexOf(e),o=t===-1?0:(t+1)%this.orderedNames.length,n=this.orderedNames[o],s=this.modes.get(n);if(!s)throw new Error(`Mode "${n}" not found in registry`);return s}get size(){return this.modes.size}remove(e){if(jr.some(n=>n.name===e))return!1;let o=this.modes.delete(e);return o&&(this.orderedNames=this.orderedNames.filter(n=>n!==e)),o}};c();function WC(r){return{name:r.name,displayName:r.displayName,description:r.description||r.displayName,systemPrompt:r.systemPrompt,allowedToolCategories:r.allowedToolCategories||[],blockedToolCategories:r.blockedToolCategories||[],allowedTools:r.allowedTools||[],blockedTools:r.blockedTools||[],blockAllTools:r.blockAllTools||!1,response_format:r.response_format,baseContext:r.baseContext,workflow:r.workflow}}c();var ta={planning:{enabled:!1},progress:{enabled:!0}};c();S();var UC=ea,Sn=class{client;config;constructor(e,t){this.client=e,this.config=t}async createPlan(e,t){let o=this.config?.planningPrompt||UC,n=e.messages.filter(p=>p.role==="user").map(p=>typeof p.content=="string"?p.content:"[obj]").join(" ").substring(0,100);y(`[Planner] createPlan() provider=${t??"default"} maxSteps=${this.config?.maxSteps??20} request="${n}..."`);let s=e.messages.filter(p=>p.role==="system"),i=e.messages.filter(p=>p.role!=="system"),a=[{role:"system",content:o},...s,...i],l={...e,tools:void 0,tool_choice:"none",response_format:"json_object",messages:a};try{let p=await this.client.generate(l,t),m=this.parsePlan(p.content||"",e,p);return P(`[Planner] createPlan() succeeded plan.id=${m.id} steps=${m.steps.length}`),m}catch(p){return I(`[Planner] createPlan() failed, using fallback: ${p.message}`),this.createFallbackPlan(e)}}parsePlan(e,t,o){try{let n=JSON.parse(e);if(!n.summary||!Array.isArray(n.steps))throw new Error("Invalid plan structure: missing summary or steps array");let s=this.config?.maxSteps??20,i=n.steps.slice(0,s);n.steps.length>s&&I(`[Planner] parsePlan() truncated ${n.steps.length} steps to maxSteps=${s}`),y(`[Planner] parsePlan() parsed ${i.length} steps successfully`);let a=i.map((p,m)=>({id:`step-${Date.now()}-${m}`,number:p.number||m+1,description:p.description||"Unknown step",expectedTools:p.expectedTools||[],dependsOn:p.dependsOn||[],status:"pending"})),l=t.messages.filter(p=>p.role==="user").map(p=>typeof p.content=="string"?p.content:"[Complex Object]").join("\\n");return{id:`plan-${Date.now()}`,request:l,summary:n.summary,steps:a,status:"draft",createdAt:new Date,planningResponse:o}}catch(n){return I(`[Planner] parsePlan() failed: ${n.message} \u2014 using fallback`),this.createFallbackPlan(t)}}createFallbackPlan(e){I("[Planner] createFallbackPlan() \u2014 creating single-step fallback due to plan generation failure");let t=e.messages.filter(o=>o.role==="user").map(o=>typeof o.content=="string"?o.content:"[Complex Object]").join("\\n");return{id:`plan-${Date.now()}-fallback`,request:t,summary:"Fallback single-step plan due to generation failure",steps:[{id:"step-1",number:1,description:"Execute the user request",status:"pending",expectedTools:[],dependsOn:[]}],status:"draft",createdAt:new Date}}};c();import{EventEmitter as GC}from"events";S();var Lr=class extends GC{client;config;planner;queryClassifier;pendingApprovals=new Map;constructor(e,t,o){super(),this.client=e,this.config=t,this.queryClassifier=o||new wt,this.planner=new Sn(e,t.planning)}getConfig(){return this.config}setConfig(e){this.config=e,this.planner=new Sn(this.client,e.planning)}shouldRouteSimpleQuery(e){if(!this.config.complexityRouting?.enabled)return!1;let t=this.config.complexityRouting.strategy??"single-step";if(t==="disabled")return!1;let o=et(e.messages);if(!o)return!1;let n=this.queryClassifier.classify(o),s=this.config.complexityRouting.confidenceThreshold??.6,i=!1;switch(n.type){case"action":i=!1;break;case"conversational":i=!0;break;case"analytical":i=n.confidence>=s;break}return y(`[Workflow] shouldRouteSimpleQuery() type=${n.type} confidence=${n.confidence.toFixed(2)} threshold=${s} shouldRoute=${i} strategy=${t}`),i}async execute(e,t){if(this.shouldRouteSimpleQuery(e))return this.executeDirect(e,t);let o=this.config.planning?.enabled;if(y(`[Workflow] execute() planningEnabled=${o} provider=${t??"default"}`),!o)return y("[Workflow] execute() mode=direct"),this.executeDirect(e,t);y("[Workflow] execute() mode=plan-direct \u2014 creating plan");let n=await this.createPlan(e,t);if(this.emit("workflow:plan_created",n),this.config.planning?.requireApproval){P(`[Workflow] Plan "${n.id}" requires approval \u2014 waiting`),this.emitProgress(n,"awaiting_approval","Waiting for plan approval");let s=await this.waitForApproval(n.id);if(this.emit("workflow:plan_decision",n,s),!s)return P(`[Workflow] Plan "${n.id}" rejected by user`),n.status="cancelled",this.emitProgress(n,"failed","Plan rejected by user"),{success:!1,plan:n,error:"Plan rejected by user",metrics:{totalDuration:0,stepsCompleted:0,stepsFailed:0,retriesUsed:0}};P(`[Workflow] Plan "${n.id}" approved`)}return n.status="approved",this.executePlanDirect(n,e,t)}async executeDirect(e,t){let o=Date.now(),n=this.createDummyPlan(e);y(`[Workflow] executeDirect() provider=${t??"default"}`);try{this.emitProgress(n,"executing","Direct execution");let s=await this.client.generate(e,t);n.status="completed",n.completedAt=new Date,n.steps[0].status="completed";let i=Date.now()-o;y(`[Workflow] executeDirect() completed in ${i}ms content_len=${s.content?.length??0}`);let a={success:!0,plan:n,output:s.content||void 0,response:s,metrics:{totalDuration:Date.now()-o,stepsCompleted:1,stepsFailed:0,retriesUsed:0}};return this.emit("workflow:completed",n,a),this.emitProgress(n,"completed","Done"),a}catch(s){n.status="failed",n.completedAt=new Date,n.steps[0].status="failed",I(`[Workflow] executeDirect() failed: ${s.message}`);let i={success:!1,plan:n,error:s.message,metrics:{totalDuration:Date.now()-o,stepsCompleted:0,stepsFailed:1,retriesUsed:0}};return this.emit("workflow:failed",n,s),this.emitProgress(n,"failed","Execution failed"),i}}async createPlan(e,t){y(`[Workflow] createPlan() provider=${t??"default"}`);let o=this.createDummyPlan(e);o.status="draft",this.emitProgress(o,"planning","Creating plan...");let n=await this.planner.createPlan(e,t);return P(`[Workflow] createPlan() completed plan.id=${n.id} steps=${n.steps.length}`),n}async executePlanDirect(e,t,o){let n=Date.now();e.status="in_progress",e.startedAt=new Date,this.emit("workflow:started",e),this.emitProgress(e,"executing","Executing plan",10),y(`[Workflow] executePlanDirect() plan.id=${e.id} steps=${e.steps.length} provider=${o??"default"}`);let s=`
|
|
550
550
|
You have created the following plan to fulfill the request:
|
|
551
551
|
Summary: ${e.summary}
|
|
552
552
|
|
|
@@ -580,8 +580,8 @@ ${e.steps.map(a=>`${a.number}. ${a.description}`).join(`
|
|
|
580
580
|
`)}
|
|
581
581
|
|
|
582
582
|
Execute this plan now.
|
|
583
|
-
`.trim(),s={...t,messages:this.injectPlanContext(t.messages,n)},i="";for await(let a of this.client.stream(s,o))a.delta&&(i+=a.delta),yield a;e.steps.forEach(a=>{a.status="completed",a.result={success:!0,output:i}}),e.status="completed",e.completedAt=new Date,this.emit("workflow:completed",e,{success:!0,plan:e,output:i,metrics:this.computeMetrics(e,e.startedAt.getTime(),0)}),this.emitProgress(e,"completed","Done")}waitForApproval(e){return new Promise(t=>{this.pendingApprovals.set(e,t)})}approvePlan(e){let t=this.pendingApprovals.get(e);t&&(t(!0),this.pendingApprovals.delete(e))}rejectPlan(e){let t=this.pendingApprovals.get(e);t&&(t(!1),this.pendingApprovals.delete(e))}};c();import{EventEmitter as Pw}from"events";k();var _w=class r extends Pw{client;activeProviderName;modeRegistry;workflowExecutor;knowledgeLayers=[];customProviderNames=new Set;mcpToolProject=null;_interceptors=[];constructor(e,t,o){super(),this.client=e,this.activeProviderName=t,this.modeRegistry=o;let n=this.client.getProvider(t);n&&this.forwardEvents(n),this.workflowExecutor=new Lr(this.client,ea,this.client.getQueryClassifier()),this.forwardWorkflowEvents()}buildKnowledgeRequestTools(){return this.knowledgeLayers.length===0?[]:this.knowledgeLayers.length===1?[this.knowledgeLayers[0].toTool(),{name:"knowledge_add",displayName:"Add to Knowledge",description:"Add important new information to the knowledge base for future reference.",category:"knowledge",parameters:{type:"object",properties:{content:{type:"string",description:"The content to add to the knowledge base."},metadata:{type:"object",description:"Optional metadata such as source, category, or tags."}},required:["content"]},execute:async s=>({success:!0,id:await this.knowledgeLayers[0].add(s.content,s.metadata),message:"Content added to knowledge base successfully."})}]:[{name:"knowledge_search",displayName:"Knowledge Search",description:`Search across ${this.knowledgeLayers.length} knowledge layers for relevant information.`,category:"search",cacheable:!1,parameters:{type:"object",properties:{query:{type:"string",description:"Search query to find relevant information"},limit:{type:"number",description:"Maximum number of results to return (default: 10)"},threshold:{type:"number",description:"Minimum similarity threshold 0-1 (default: 0.7)"},filter:{type:"object",description:"Optional metadata filters"}},required:["query"]},execute:async o=>{let s=(await Promise.all(this.knowledgeLayers.map(async(a,l)=>(await a.toTool().execute({query:o.query,limit:o.limit,threshold:o.threshold,filter:o.filter})).map(d=>({...d,_layer:l}))))).flat();s.sort((a,l)=>(l.score??0)-(a.score??0));let i=o.limit??10;return s.slice(0,i)}},{name:"knowledge_add",displayName:"Add to Knowledge",description:"Add important new information to the primary knowledge base for future reference.",category:"knowledge",parameters:{type:"object",properties:{content:{type:"string",description:"The content to add to the knowledge base."},metadata:{type:"object",description:"Optional metadata such as source, category, or tags."}},required:["content"]},execute:async o=>({success:!0,id:await this.knowledgeLayers[0].add(o.content,o.metadata),message:"Content added to knowledge base successfully."})}]}prepareRequest(e){let t=[...this.buildKnowledgeRequestTools(),...e.requestTools||[]];if(t.length===0)return e;let o=new Map;for(let n of t)o.set(n.name,n);return{...e,requestTools:Array.from(o.values())}}static async init(e){let t=qn(e.configPath);$a(t.logging);let o=new Tn,n=Bo(e.configPath);o.setConfig(n),e.tools&&await o.loadBuiltIn(),e.customTools&&await o.loadProjects(e.customTools);let s=null,i=e.mcp||t.mcp;if(i)try{P("[MCP] Initializing MCP tool integration");let _=await Ji(i);s=_,await o.loadProjects([_]),P(`[MCP] Loaded ${_.tools.length} tools from MCP servers`)}catch(_){pe(`[MCP] Failed to initialize MCP tools: ${_}`)}let a=t.systemPrompt,l=e.disableBaseContext||t.disableBaseContext||t.baseContext===!1||!1,p=t.modeOverrides||{},m={},d=new Set,g=e.defaultProvider||e.provider;if(e.providers)for(let[_,D]of Object.entries(e.providers)){let R=_===g,W=await r.createProvider(_,D,e.configPath,!R);W&&(m[_]=W)}else if(e.provider){let _={apiKey:e.apiKey,model:e.model,projectId:e.projectId,location:e.location,googleAuthOptions:e.googleAuthOptions},D=await r.createProvider(e.provider,_,e.configPath,!1);D&&(m[e.provider]=D)}else if(!e.customProviders)throw new Error('No provider specified. Pass { provider: "name" }, { providers: { ... } }, or { customProviders: { ... } } to init().');if(e.customProviders){let _=Array.isArray(e.customProviders)?e.customProviders:Object.entries(e.customProviders).map(([D,R])=>(R.name=R.name||D,R));for(let D of _){if(typeof D.generate!="function"||typeof D.stream!="function"||typeof D.embed!="function")throw new Error("Custom provider must implement the ProviderAdapter interface (generate, stream, embed methods). Import { ProviderAdapter } from 'toolpack' and implement or extend it.");let R=D.name;if(!R)throw new Error("Custom provider must have a 'name' property set. Set adapter.name in the constructor or use the record syntax: { 'provider-name': adapter }");if(m[R])throw new Error(`Custom provider name "${R}" conflicts with a built-in provider designation. Choose a different name.`);d.add(R),m[R]=D}}if(!g&&e.customProviders&&(g=(Array.isArray(e.customProviders)?e.customProviders[0]:Object.values(e.customProviders)[0])?.name),!g)throw new Error("No default provider specified.");let w=new vn;if(e.customModes)for(let _ of e.customModes)w.register(_);let b={...p,...e.modeOverrides||{}};for(let[_,D]of Object.entries(b)){let R=w.get(_);if(R){D.systemPrompt!==void 0&&(R.systemPrompt=D.systemPrompt),D.toolSearch&&(R.toolSearch={...R.toolSearch||{},...D.toolSearch});for(let[W,z]of Object.entries(D))W!=="systemPrompt"&&W!=="toolSearch"&&(R[W]=z)}}let T=t.hitl||{};e.confirmationMode!==void 0&&(T.confirmationMode=e.confirmationMode),T.enabled===void 0&&e.onToolConfirm&&(T.enabled=!0),T.confirmationMode===void 0&&e.onToolConfirm&&(T.confirmationMode="all");let x=new _n({providers:m,defaultProvider:g,toolRegistry:o,toolsConfig:o.getConfig(),systemPrompt:a,disableBaseContext:l,hitlConfig:Object.keys(T).length>0?T:void 0,onToolConfirm:e.onToolConfirm,conversationId:e.conversationId,contextWindowConfig:e.contextWindow}),C=new r(x,g,w),v=e.knowledge,$=v==null?[]:Array.isArray(v)?v:[v];C.knowledgeLayers=$.filter(_=>!!_&&typeof _.toTool=="function"),C.customProviderNames=d,C.mcpToolProject=s,C._interceptors=e.interceptors??[];for(let _ of C._interceptors)_.init&&await _.init();let S=e.defaultMode||Ot,M=w.get(S);return M&&(x.setMode(M),M.workflow&&C.workflowExecutor.setConfig(M.workflow)),C}static async createProvider(e,t,o,n=!1){if(e==="vertexai")return new $n({projectId:t.projectId,location:t.location,googleAuthOptions:t.googleAuthOptions});if(["openai","anthropic","gemini","openrouter"].includes(e)){let s=`TOOLPACK_${e.toUpperCase()}_KEY`,i=t.apiKey||process.env[s]||process.env[`${e.toUpperCase()}_API_KEY`];if(!i){if(n)return null;throw new Error(`No API key found for '${e}'. Set ${s} or pass apiKey in config.`)}switch(e){case"openai":return new xt(i,t.baseUrl);case"anthropic":return new Rn(i,t.baseUrl);case"gemini":return new En(i);case"openrouter":return new On(i,{siteUrl:t.siteUrl,siteName:t.siteName})}}if(e==="ollama")return new Vt({baseUrl:t.baseUrl||Mn(o)});if(e.startsWith("ollama-")){let s=t.model||e.replace(/^ollama-/,""),i=t.baseUrl||Mn(o);return new ot({model:s,baseUrl:i})}throw new Error(`Unknown provider type: ${e}`)}async generate(e,t){let o;if(typeof e=="string"?o={messages:[{role:"user",content:e}],model:""}:o=e,o=this.prepareRequest(o),this.getMode()?.workflow?.planning?.enabled){let s=await this.workflowExecutor.execute(o,t||this.activeProviderName),i=0,a=0,l=0,p={steps:[]};s.plan.planningResponse?.usage&&(i+=s.plan.planningResponse.usage.prompt_tokens,a+=s.plan.planningResponse.usage.completion_tokens||0,l+=s.plan.planningResponse.usage.total_tokens,p.planning=s.plan.planningResponse.usage);for(let d of s.plan.steps)if(d.status==="completed"&&d.result?.response?.usage){let g=d.result.response.usage;i+=g.prompt_tokens,a+=g.completion_tokens||0,l+=g.total_tokens,p.steps.push({stepNumber:d.number,description:d.description,usage:g})}let m={prompt_tokens:i,completion_tokens:a,total_tokens:l};return s.response?{...s.response,content:s.output||s.response.content||null,usage:m,usage_details:p}:{content:s.output||null,usage:m,usage_details:p}}return this._interceptors.length>0?this._buildInterceptorChain(this._interceptors,i=>this.client.generate(i??o,t))(o):this.client.generate(o,t)}_buildInterceptorChain(e,t){return e.reduceRight((o,n)=>s=>n(s,i=>o(i??s)),t)}async*stream(e,t){let o=this.prepareRequest(e),n=this.getMode(),s=t||this.activeProviderName;if(n?.workflow?.planning?.enabled){yield*this.workflowExecutor.stream(o,s);return}yield*this.client.stream(o,t)}async embed(e,t){return this.client.embed(e,t)}setProvider(e){let t=this.client.getProvider(e);this.activeProviderName=e,this.client.setDefaultProvider(e),this.forwardEvents(t)}getProvider(){return this.client.getProvider(this.activeProviderName)}getClient(){return this.client}reloadConfig(e){let t=e||tt();if(t)try{let o=Jt(t);o?.hitl&&this.client.updateHitlConfig(o.hitl)}catch(o){I(`[Toolpack] Failed to reload config from ${t}: ${o instanceof Error?o.message:String(o)}`)}}getWorkflowExecutor(){return this.workflowExecutor}async disconnect(){let e=this.getProvider();e&&"disconnect"in e&&await e.disconnect(),this.mcpToolProject&&await Vi(this.mcpToolProject)}async listProviders(){let e=this.client.getProviders(),t=[];for(let[o,n]of e.entries()){let s=this.customProviderNames.has(o),i=[];try{i=await n.getModels()}catch(a){I(`[Toolpack] Failed to fetch models for provider '${o}': ${a}`)}t.push({name:o,displayName:n.getDisplayName(),type:s?"custom":"built-in",models:i})}return t}async loadToolProject(e){let t=this.client.getToolRegistry();if(t)await t.loadProject(e);else throw new Error("No tool registry configured. Initialize Toolpack with tools enabled.")}async startMcpServer(e){let t=this.client.getToolRegistry();if(!t)throw new Error("No tool registry configured. Initialize Toolpack with tools enabled: Toolpack.init({ tools: true })");let o;try{o=(await Promise.resolve().then(()=>(kw(),Sw))).startMcpServer}catch(s){throw s instanceof Error&&s.code==="MODULE_NOT_FOUND"&&s.message.includes("@modelcontextprotocol")?new Error(`MCP server requires @modelcontextprotocol/sdk. Install it with:
|
|
584
|
-
npm install @modelcontextprotocol/sdk`):s}let n=e.searchMode?s=>this.client.executeToolSearch(s):void 0;return o(t,e,n)}async listModels(){let e=await this.listProviders(),t=[];for(let o of e)for(let n of o.models)t.push({...n,provider:o.name});return t}setMode(e){let t=this.modeRegistry.get(e);if(!t)throw new Error(`Mode "${e}" not found. Available modes: ${this.modeRegistry.getNames().join(", ")}`);return this.client.setMode(t),t.workflow?this.workflowExecutor.setConfig(t.workflow):this.workflowExecutor.setConfig(
|
|
583
|
+
`.trim(),s={...t,messages:this.injectPlanContext(t.messages,n)},i="";for await(let a of this.client.stream(s,o))a.delta&&(i+=a.delta),yield a;e.steps.forEach(a=>{a.status="completed",a.result={success:!0,output:i}}),e.status="completed",e.completedAt=new Date,this.emit("workflow:completed",e,{success:!0,plan:e,output:i,metrics:this.computeMetrics(e,e.startedAt.getTime(),0)}),this.emitProgress(e,"completed","Done")}waitForApproval(e){return new Promise(t=>{this.pendingApprovals.set(e,t)})}approvePlan(e){let t=this.pendingApprovals.get(e);t&&(t(!0),this.pendingApprovals.delete(e))}rejectPlan(e){let t=this.pendingApprovals.get(e);t&&(t(!1),this.pendingApprovals.delete(e))}};c();import{EventEmitter as Rw}from"events";S();var _w=class r extends Rw{client;activeProviderName;modeRegistry;workflowExecutor;knowledgeLayers=[];customProviderNames=new Set;mcpToolProject=null;_interceptors=[];constructor(e,t,o){super(),this.client=e,this.activeProviderName=t,this.modeRegistry=o;let n=this.client.getProvider(t);n&&this.forwardEvents(n),this.workflowExecutor=new Lr(this.client,ta,this.client.getQueryClassifier()),this.forwardWorkflowEvents()}buildKnowledgeRequestTools(){return this.knowledgeLayers.length===0?[]:this.knowledgeLayers.length===1?[this.knowledgeLayers[0].toTool(),{name:"knowledge_add",displayName:"Add to Knowledge",description:"Add important new information to the knowledge base for future reference.",category:"knowledge",parameters:{type:"object",properties:{content:{type:"string",description:"The content to add to the knowledge base."},metadata:{type:"object",description:"Optional metadata such as source, category, or tags."}},required:["content"]},execute:async s=>({success:!0,id:await this.knowledgeLayers[0].add(s.content,s.metadata),message:"Content added to knowledge base successfully."})}]:[{name:"knowledge_search",displayName:"Knowledge Search",description:`Search across ${this.knowledgeLayers.length} knowledge layers for relevant information.`,category:"search",cacheable:!1,parameters:{type:"object",properties:{query:{type:"string",description:"Search query to find relevant information"},limit:{type:"number",description:"Maximum number of results to return (default: 10)"},threshold:{type:"number",description:"Minimum similarity threshold 0-1 (default: 0.7)"},filter:{type:"object",description:"Optional metadata filters"}},required:["query"]},execute:async o=>{let s=(await Promise.all(this.knowledgeLayers.map(async(a,l)=>(await a.toTool().execute({query:o.query,limit:o.limit,threshold:o.threshold,filter:o.filter})).map(d=>({...d,_layer:l}))))).flat();s.sort((a,l)=>(l.score??0)-(a.score??0));let i=o.limit??10;return s.slice(0,i)}},{name:"knowledge_add",displayName:"Add to Knowledge",description:"Add important new information to the primary knowledge base for future reference.",category:"knowledge",parameters:{type:"object",properties:{content:{type:"string",description:"The content to add to the knowledge base."},metadata:{type:"object",description:"Optional metadata such as source, category, or tags."}},required:["content"]},execute:async o=>({success:!0,id:await this.knowledgeLayers[0].add(o.content,o.metadata),message:"Content added to knowledge base successfully."})}]}prepareRequest(e){let t=[...this.buildKnowledgeRequestTools(),...e.requestTools||[]];if(t.length===0)return e;let o=new Map;for(let n of t)o.set(n.name,n);return{...e,requestTools:Array.from(o.values())}}static async init(e){let t=Wn(e.configPath);Ea(t.logging);let o=new xn,n=zo(e.configPath);o.setConfig(n),e.tools&&await o.loadBuiltIn(),e.customTools&&await o.loadProjects(e.customTools);let s=null,i=e.mcp||t.mcp;if(i)try{P("[MCP] Initializing MCP tool integration");let R=await Vi(i);s=R,await o.loadProjects([R]),P(`[MCP] Loaded ${R.tools.length} tools from MCP servers`)}catch(R){pe(`[MCP] Failed to initialize MCP tools: ${R}`)}let a=t.systemPrompt,l=e.disableBaseContext||t.disableBaseContext||t.baseContext===!1||!1,p=t.modeOverrides||{},m={},d=new Set,g=e.defaultProvider||e.provider;if(e.providers)for(let[R,$]of Object.entries(e.providers)){let E=R===g,j=await r.createProvider(R,$,e.configPath,!E);j&&(m[R]=j)}else if(e.provider){let R={apiKey:e.apiKey,model:e.model,projectId:e.projectId,location:e.location,googleAuthOptions:e.googleAuthOptions},$=await r.createProvider(e.provider,R,e.configPath,!1);$&&(m[e.provider]=$)}else if(!e.customProviders)throw new Error('No provider specified. Pass { provider: "name" }, { providers: { ... } }, or { customProviders: { ... } } to init().');if(e.customProviders){let R=Array.isArray(e.customProviders)?e.customProviders:Object.entries(e.customProviders).map(([$,E])=>(E.name=E.name||$,E));for(let $ of R){if(typeof $.generate!="function"||typeof $.stream!="function"||typeof $.embed!="function")throw new Error("Custom provider must implement the ProviderAdapter interface (generate, stream, embed methods). Import { ProviderAdapter } from 'toolpack' and implement or extend it.");let E=$.name;if(!E)throw new Error("Custom provider must have a 'name' property set. Set adapter.name in the constructor or use the record syntax: { 'provider-name': adapter }");if(m[E])throw new Error(`Custom provider name "${E}" conflicts with a built-in provider designation. Choose a different name.`);d.add(E),m[E]=$}}if(!g&&e.customProviders&&(g=(Array.isArray(e.customProviders)?e.customProviders[0]:Object.values(e.customProviders)[0])?.name),!g)throw new Error("No default provider specified.");let b=new Cn;if(e.customModes)for(let R of e.customModes)b.register(R);let w={...p,...e.modeOverrides||{}};for(let[R,$]of Object.entries(w)){let E=b.get(R);if(E){$.systemPrompt!==void 0&&(E.systemPrompt=$.systemPrompt),$.toolSearch&&(E.toolSearch={...E.toolSearch||{},...$.toolSearch});for(let[j,we]of Object.entries($))j!=="systemPrompt"&&j!=="toolSearch"&&(E[j]=we)}}let T=t.hitl||{};e.confirmationMode!==void 0&&(T.confirmationMode=e.confirmationMode),T.enabled===void 0&&e.onToolConfirm&&(T.enabled=!0),T.confirmationMode===void 0&&e.onToolConfirm&&(T.confirmationMode="all");let v=new _n({providers:m,defaultProvider:g,toolRegistry:o,toolsConfig:o.getConfig(),systemPrompt:a,disableBaseContext:l,hitlConfig:Object.keys(T).length>0?T:void 0,onToolConfirm:e.onToolConfirm,conversationId:e.conversationId,contextWindowConfig:e.contextWindow}),k=new r(v,g,b),x=e.knowledge,D=x==null?[]:Array.isArray(x)?x:[x];k.knowledgeLayers=D.filter(R=>!!R&&typeof R.toTool=="function"),k.customProviderNames=d,k.mcpToolProject=s,k._interceptors=e.interceptors??[];for(let R of k._interceptors)R.init&&await R.init();let M=e.defaultMode||Ot,C=b.get(M);return C&&(v.setMode(C),C.workflow&&k.workflowExecutor.setConfig(C.workflow)),k}static async createProvider(e,t,o,n=!1){if(e==="vertexai")return new En({projectId:t.projectId,location:t.location,googleAuthOptions:t.googleAuthOptions});if(["openai","anthropic","gemini","openrouter"].includes(e)){let s=`TOOLPACK_${e.toUpperCase()}_KEY`,i=t.apiKey||process.env[s]||process.env[`${e.toUpperCase()}_API_KEY`];if(!i){if(n)return null;throw new Error(`No API key found for '${e}'. Set ${s} or pass apiKey in config.`)}switch(e){case"openai":return new vt(i,t.baseUrl);case"anthropic":return new $n(i,t.baseUrl);case"gemini":return new Dn(i);case"openrouter":return new On(i,{siteUrl:t.siteUrl,siteName:t.siteName})}}if(e==="ollama")return new Qt({baseUrl:t.baseUrl||An(o)});if(e.startsWith("ollama-")){let s=t.model||e.replace(/^ollama-/,""),i=t.baseUrl||An(o);return new nt({model:s,baseUrl:i})}throw new Error(`Unknown provider type: ${e}`)}async generate(e,t){let o;if(typeof e=="string"?o={messages:[{role:"user",content:e}],model:""}:o=e,o=this.prepareRequest(o),o=this.resolveRequestModeName(o),(o.mode!==void 0?o.mode:this.getMode())?.workflow?.planning?.enabled){let s=await this.workflowExecutor.execute(o,t||this.activeProviderName),i=0,a=0,l=0,p={steps:[]};s.plan.planningResponse?.usage&&(i+=s.plan.planningResponse.usage.prompt_tokens,a+=s.plan.planningResponse.usage.completion_tokens||0,l+=s.plan.planningResponse.usage.total_tokens,p.planning=s.plan.planningResponse.usage);for(let d of s.plan.steps)if(d.status==="completed"&&d.result?.response?.usage){let g=d.result.response.usage;i+=g.prompt_tokens,a+=g.completion_tokens||0,l+=g.total_tokens,p.steps.push({stepNumber:d.number,description:d.description,usage:g})}let m={prompt_tokens:i,completion_tokens:a,total_tokens:l};return s.response?{...s.response,content:s.output||s.response.content||null,usage:m,usage_details:p}:{content:s.output||null,usage:m,usage_details:p}}return this._interceptors.length>0?this._buildInterceptorChain(this._interceptors,i=>this.client.generate(i??o,t))(o):this.client.generate(o,t)}resolveRequestModeName(e){if(typeof e.mode!="string")return e;let t=this.modeRegistry.get(e.mode);if(!t)throw new Error(`Mode "${e.mode}" not found. Available modes: ${this.modeRegistry.getNames().join(", ")}`);return{...e,mode:t}}_buildInterceptorChain(e,t){return e.reduceRight((o,n)=>s=>n(s,i=>o(i??s)),t)}async*stream(e,t){let o=this.prepareRequest(e);o=this.resolveRequestModeName(o);let n=o.mode!==void 0?o.mode:this.getMode(),s=t||this.activeProviderName;if(n?.workflow?.planning?.enabled){yield*this.workflowExecutor.stream(o,s);return}yield*this.client.stream(o,t)}async embed(e,t){return this.client.embed(e,t)}setProvider(e){let t=this.client.getProvider(e);this.activeProviderName=e,this.client.setDefaultProvider(e),this.forwardEvents(t)}getProvider(){return this.client.getProvider(this.activeProviderName)}getClient(){return this.client}reloadConfig(e){let t=e||ot();if(t)try{let o=Vt(t);o?.hitl&&this.client.updateHitlConfig(o.hitl)}catch(o){I(`[Toolpack] Failed to reload config from ${t}: ${o instanceof Error?o.message:String(o)}`)}}getWorkflowExecutor(){return this.workflowExecutor}async disconnect(){let e=this.getProvider();e&&"disconnect"in e&&await e.disconnect(),this.mcpToolProject&&await Qi(this.mcpToolProject)}async listProviders(){let e=this.client.getProviders(),t=[];for(let[o,n]of e.entries()){let s=this.customProviderNames.has(o),i=[];try{i=await n.getModels()}catch(a){I(`[Toolpack] Failed to fetch models for provider '${o}': ${a}`)}t.push({name:o,displayName:n.getDisplayName(),type:s?"custom":"built-in",models:i})}return t}async loadToolProject(e){let t=this.client.getToolRegistry();if(t)await t.loadProject(e);else throw new Error("No tool registry configured. Initialize Toolpack with tools enabled.")}async startMcpServer(e){let t=this.client.getToolRegistry();if(!t)throw new Error("No tool registry configured. Initialize Toolpack with tools enabled: Toolpack.init({ tools: true })");let o;try{o=(await Promise.resolve().then(()=>(Pw(),kw))).startMcpServer}catch(s){throw s instanceof Error&&s.code==="MODULE_NOT_FOUND"&&s.message.includes("@modelcontextprotocol")?new Error(`MCP server requires @modelcontextprotocol/sdk. Install it with:
|
|
584
|
+
npm install @modelcontextprotocol/sdk`):s}let n=e.searchMode?s=>this.client.executeToolSearch(s):void 0;return o(t,e,n)}async listModels(){let e=await this.listProviders(),t=[];for(let o of e)for(let n of o.models)t.push({...n,provider:o.name});return t}setMode(e){let t=this.modeRegistry.get(e);if(!t)throw new Error(`Mode "${e}" not found. Available modes: ${this.modeRegistry.getNames().join(", ")}`);return this.client.setMode(t),t.workflow?this.workflowExecutor.setConfig(t.workflow):this.workflowExecutor.setConfig(ta),t}getMode(){return this.client.getMode()}getActiveModeName(){let e=this.client.getMode();return e?e.displayName:"Default"}getModes(){return this.modeRegistry.getAll()}cycleMode(){let e=this.client.getMode(),t=e?e.name:"default",o=this.modeRegistry.getNext(t);return this.client.setMode(o),o}registerMode(e){this.modeRegistry.register(e)}forwardEvents(e){e instanceof Rw&&e.on("status",t=>this.emit("status",t))}forwardWorkflowEvents(){let e=this.workflowExecutor;e.on("workflow:plan_created",t=>this.emit("workflow:plan_created",t)),e.on("workflow:plan_decision",(t,o)=>this.emit("workflow:plan_decision",t,o)),e.on("workflow:started",t=>this.emit("workflow:started",t)),e.on("workflow:progress",t=>this.emit("workflow:progress",t)),e.on("workflow:completed",(t,o)=>this.emit("workflow:completed",t,o)),e.on("workflow:failed",(t,o)=>this.emit("workflow:failed",t,o))}};c();c();c();var Fr=class{capacity;map;constructor(e){this.capacity=e,this.map=new Map}get(e){let t=this.map.get(e);if(t!==void 0)return this.map.delete(e),this.map.set(e,t),t}set(e,t){if(this.map.has(e))this.map.delete(e);else if(this.map.size>=this.capacity){let o=this.map.keys().next().value;o!==void 0&&this.map.delete(o)}this.map.set(e,t)}has(e){return this.map.has(e)}get size(){return this.map.size}};var sa=class{lru;maxMessagesPerConversation;constructor(e={}){this.lru=new Fr(e.maxConversations??500),this.maxMessagesPerConversation=e.maxMessagesPerConversation??500}async append(e){let t=this.lru.get(e.conversationId);t||(t=[],this.lru.set(e.conversationId,t)),!t.some(o=>o.id===e.id)&&(t.push(e),t.sort((o,n)=>o.timestamp.localeCompare(n.timestamp)),t.length>this.maxMessagesPerConversation&&t.splice(0,t.length-this.maxMessagesPerConversation))}async get(e,t={}){let n=(this.lru.get(e)??[]).slice();if(t.scope!==void 0&&(n=n.filter(s=>s.scope===t.scope)),t.sinceTimestamp!==void 0&&(n=n.filter(s=>s.timestamp>=t.sinceTimestamp)),t.participantIds!==void 0&&t.participantIds.length>0){let s=new Set(t.participantIds);n=n.filter(i=>s.has(i.participant.id))}return t.limit!==void 0&&n.length>t.limit&&(n=n.slice(n.length-t.limit)),n}async search(e,t,o={}){let n=this.lru.get(e)??[],s=t.toLowerCase(),i=o.limit??10,a=o.tokenCap??2e3,l=n.filter(d=>d.content.toLowerCase().includes(s)).slice().reverse(),p=[],m=0;for(let d of l){if(p.length>=i)break;let g=Math.ceil(d.content.length/4);if(p.length>0&&m+g>a)break;p.push(d),m+=g}return p}async deleteMessages(e,t){let o=this.lru.get(e);if(!o||t.length===0)return;let n=new Set(t),s=o.filter(i=>!n.has(i.id));this.lru.set(e,s)}clearConversation(e){this.lru.set(e,[])}get conversationCount(){return this.lru.size}};c();import nS from"better-sqlite3";import*as Nt from"fs";import*as kn from"path";function rS(){let r=kn.join(process.cwd(),".toolpack","db","conversation");return Nt.existsSync(r)||Nt.mkdirSync(r,{recursive:!0}),kn.join(r,"conversation.sqlite")}var ia=class{db;maxMessagesPerConversation;useFTS;constructor(e={}){let t=e.dbPath??rS(),o=kn.dirname(t);if(Nt.existsSync(o)||Nt.mkdirSync(o,{recursive:!0}),this.db=new nS(t),e.enableWAL!==!1){try{this.db.pragma("journal_mode = WAL")}catch{}try{this.db.pragma("synchronous = NORMAL")}catch{}}this.useFTS=e.useFTS===!0,this.maxMessagesPerConversation=e.maxMessagesPerConversation??500,this.initSchema()}initSchema(){this.db.exec(`
|
|
585
585
|
CREATE TABLE IF NOT EXISTS messages (
|
|
586
586
|
id TEXT NOT NULL,
|
|
587
587
|
conversation_id TEXT NOT NULL,
|
|
@@ -596,7 +596,7 @@ Execute this plan now.
|
|
|
596
596
|
)`),this.db.exec("CREATE INDEX IF NOT EXISTS idx_messages_conv_ts ON messages (conversation_id, timestamp)"),this.db.exec("CREATE INDEX IF NOT EXISTS idx_messages_conv_scope_ts ON messages (conversation_id, scope, timestamp)"),this.db.exec("CREATE INDEX IF NOT EXISTS idx_messages_conv_participant_ts ON messages (conversation_id, participant_id, timestamp)"),this.useFTS&&(this.db.exec("CREATE VIRTUAL TABLE IF NOT EXISTS messages_fts USING fts5(doc_key UNINDEXED, content, tokenize = 'unicode61')"),this.db.exec("CREATE INDEX IF NOT EXISTS idx_messages_fts_key ON messages_fts (doc_key)"))}async append(e){let t=this.db.prepare(`INSERT OR IGNORE INTO messages (
|
|
597
597
|
id, conversation_id, participant_kind, participant_id, participant_display_name,
|
|
598
598
|
content, timestamp, scope, metadata
|
|
599
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`),o=e.metadata?JSON.stringify(e.metadata):null,n=t.run(e.id,e.conversationId,e.participant.kind,e.participant.id,e.participant.displayName??null,e.content,e.timestamp,e.scope,o);if(this.useFTS&&n.changes>0){let s=`${e.conversationId}:${e.id}`;this.db.prepare("INSERT INTO messages_fts (doc_key, content) VALUES (?, ?)").run(s,e.content)}if(this.maxMessagesPerConversation>0){let a=this.db.prepare("SELECT COUNT(1) as c FROM messages WHERE conversation_id = ?").get(e.conversationId)?.c??0;if(a>this.maxMessagesPerConversation){let l=a-this.maxMessagesPerConversation,m=this.db.prepare("SELECT id FROM messages WHERE conversation_id = ? ORDER BY timestamp ASC LIMIT ?").all(e.conversationId,l).map(d=>d.id);if(m.length>0){let d=m.map(()=>"?").join(",");if(this.db.prepare(`DELETE FROM messages WHERE conversation_id = ? AND id IN (${d})`).run(e.conversationId,...m),this.useFTS){let
|
|
599
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`),o=e.metadata?JSON.stringify(e.metadata):null,n=t.run(e.id,e.conversationId,e.participant.kind,e.participant.id,e.participant.displayName??null,e.content,e.timestamp,e.scope,o);if(this.useFTS&&n.changes>0){let s=`${e.conversationId}:${e.id}`;this.db.prepare("INSERT INTO messages_fts (doc_key, content) VALUES (?, ?)").run(s,e.content)}if(this.maxMessagesPerConversation>0){let a=this.db.prepare("SELECT COUNT(1) as c FROM messages WHERE conversation_id = ?").get(e.conversationId)?.c??0;if(a>this.maxMessagesPerConversation){let l=a-this.maxMessagesPerConversation,m=this.db.prepare("SELECT id FROM messages WHERE conversation_id = ? ORDER BY timestamp ASC LIMIT ?").all(e.conversationId,l).map(d=>d.id);if(m.length>0){let d=m.map(()=>"?").join(",");if(this.db.prepare(`DELETE FROM messages WHERE conversation_id = ? AND id IN (${d})`).run(e.conversationId,...m),this.useFTS){let b=m.map(v=>`${e.conversationId}:${v}`),w=b.map(()=>"?").join(",");this.db.prepare(`DELETE FROM messages_fts WHERE doc_key IN (${w})`).run(...b)}}}}}async get(e,t={}){let o=["conversation_id = ?"],n=[e];if(t.scope!==void 0&&(o.push("scope = ?"),n.push(t.scope)),t.sinceTimestamp!==void 0&&(o.push("timestamp >= ?"),n.push(t.sinceTimestamp)),t.participantIds&&t.participantIds.length>0){let p=t.participantIds.map(()=>"?").join(",");o.push(`participant_id IN (${p})`),n.push(...t.participantIds)}let i=`SELECT id, conversation_id, participant_kind, participant_id, participant_display_name, content, timestamp, scope, metadata FROM messages ${o.length?`WHERE ${o.join(" AND ")}`:""} ORDER BY timestamp ASC`,l=this.db.prepare(i).all(n).map(p=>this.rowToMessage(p));return t.limit!==void 0&&l.length>t.limit&&(l=l.slice(l.length-t.limit)),l}async search(e,t,o={}){let n=o.limit??10,s=o.tokenCap??2e3,i=[];this.useFTS?i=this.db.prepare(`
|
|
600
600
|
SELECT m.id, m.conversation_id, m.participant_kind, m.participant_id, m.participant_display_name,
|
|
601
601
|
m.content, m.timestamp, m.scope, m.metadata
|
|
602
602
|
FROM messages m
|
|
@@ -607,19 +607,19 @@ Execute this plan now.
|
|
|
607
607
|
content, timestamp, scope, metadata
|
|
608
608
|
FROM messages
|
|
609
609
|
WHERE conversation_id = ? AND content LIKE ? COLLATE NOCASE
|
|
610
|
-
ORDER BY timestamp DESC`).all(e,`%${t}%`);let a=i.map(m=>this.rowToMessage(m)),l=[],p=0;for(let m of a){if(l.length>=n)break;let d=Math.ceil(m.content.length/4);if(l.length>0&&p+d>s)break;l.push(m),p+=d}return l}async deleteMessages(e,t){if(!t||t.length===0)return;let o=t.map(()=>"?").join(",");if(this.db.prepare(`DELETE FROM messages WHERE conversation_id = ? AND id IN (${o})`).run(e,...t),this.useFTS){let s=t.map(l=>`${e}:${l}`),i=s.map(()=>"?").join(",");this.db.prepare(`DELETE FROM messages_fts WHERE doc_key IN (${i})`).run(...s)}}clearConversation(e){this.useFTS&&this.db.prepare("DELETE FROM messages_fts WHERE doc_key LIKE ?").run(`${e}:%`),this.db.prepare("DELETE FROM messages WHERE conversation_id = ?").run(e)}rowToMessage(e){return{id:e.id,conversationId:e.conversation_id,participant:{kind:e.participant_kind,id:e.participant_id,displayName:e.participant_display_name??void 0},content:e.content,timestamp:e.timestamp,scope:e.scope,metadata:e.metadata?JSON.parse(e.metadata):void 0}}close(){try{this.db.close()}catch{}}};c();import*as
|
|
611
|
-
`);for(let
|
|
612
|
-
`).filter(
|
|
613
|
-
`),a=
|
|
610
|
+
ORDER BY timestamp DESC`).all(e,`%${t}%`);let a=i.map(m=>this.rowToMessage(m)),l=[],p=0;for(let m of a){if(l.length>=n)break;let d=Math.ceil(m.content.length/4);if(l.length>0&&p+d>s)break;l.push(m),p+=d}return l}async deleteMessages(e,t){if(!t||t.length===0)return;let o=t.map(()=>"?").join(",");if(this.db.prepare(`DELETE FROM messages WHERE conversation_id = ? AND id IN (${o})`).run(e,...t),this.useFTS){let s=t.map(l=>`${e}:${l}`),i=s.map(()=>"?").join(",");this.db.prepare(`DELETE FROM messages_fts WHERE doc_key IN (${i})`).run(...s)}}clearConversation(e){this.useFTS&&this.db.prepare("DELETE FROM messages_fts WHERE doc_key LIKE ?").run(`${e}:%`),this.db.prepare("DELETE FROM messages WHERE conversation_id = ?").run(e)}rowToMessage(e){return{id:e.id,conversationId:e.conversation_id,participant:{kind:e.participant_kind,id:e.participant_id,displayName:e.participant_display_name??void 0},content:e.content,timestamp:e.timestamp,scope:e.scope,metadata:e.metadata?JSON.parse(e.metadata):void 0}}close(){try{this.db.close()}catch{}}};c();import*as $w from"os";import*as mt from"path";import*as It from"fs";var Ew=".toolpack",Dw="config",Mw="toolpack.config.json";function sS(){return $w.homedir()}function iS(){return mt.join(sS(),Ew)}function Aw(){return mt.join(iS(),Dw)}function qr(){return mt.join(Aw(),Mw)}function aS(r=process.cwd()){return mt.join(r,Ew)}function Ow(r=process.cwd()){return mt.join(aS(r),Dw)}function Wr(r=process.cwd()){return mt.join(Ow(r),Mw)}function Nw(){let r=Aw();It.existsSync(r)||It.mkdirSync(r,{recursive:!0})}function fB(r=process.cwd()){let e=Ow(r);It.existsSync(e)||It.mkdirSync(e,{recursive:!0})}c();import*as re from"fs";import*as Ur from"path";function la(r,e){if(!e)return r;if(!r)return e;let t={...r};for(let o of Object.keys(e))e[o]instanceof Array?t[o]=e[o]:e[o]instanceof Object&&o in r?t[o]=la(r[o],e[o]):t[o]=e[o];return t}function aa(r){if(!re.existsSync(r))return null;try{let e=re.readFileSync(r,"utf-8");return JSON.parse(e)}catch{return null}}function wB(r=process.cwd()){let e=Ur.join(r,"toolpack.config.json"),t=qr(),o=Wr(r),n=aa(e)||{},s=aa(t)||{},i=aa(o)||{},a=la(n,s);return a=la(a,i),a}function TB(r=process.cwd()){let e=Ur.join(r,"toolpack.config.json"),t=qr(),o=Wr(r),n=!re.existsSync(t),s=null,i="default";return re.existsSync(o)?(s=o,i="local"):re.existsSync(t)?(s=t,i="global"):re.existsSync(e)&&(s=e,i="base"),{isFirstRun:n,activeConfigPath:s,configSource:i}}function xB(r=process.cwd()){let e=qr();if(!re.existsSync(e)){Nw();let t=null,o=Wr(r);if(re.existsSync(o))t=o;else{let s=Ur.join(r,"toolpack.config.json");if(re.existsSync(s))t=s;else{let i=ot();i&&re.existsSync(i)&&(t=i)}}let n={};if(t)try{let s=re.readFileSync(t,"utf-8");n=JSON.parse(s)}catch{}re.writeFileSync(e,JSON.stringify(n,null,4),"utf-8")}}c();c();c();import*as Ve from"fs/promises";import*as jt from"path";c();var lS=new Set(["a","an","the","and","or","but","in","on","at","to","for","of","with","by","from","as","is","was","are","were","been","be","have","has","had","do","does","did","will","would","could","should","may","might","must","shall","can","need","it","its","this","that","these","those","i","you","he","she","we","they","what","which","who","when","where","why","how","all","each","every","both","few","more","most","other","some","such","no","nor","not","only","own","same","so","than","too","very","just","also","now","here","there","then"]),Gr=class{documents=new Map;termFrequencies=new Map;documentLengths=new Map;avgDocLength=0;k1;b;constructor(e=1.5,t=.75){this.k1=e,this.b=t}tokenize(e){if(!e)return[];let t=e.toLowerCase();return t=t.replace(/([a-z])([A-Z])/g,"$1 $2"),t=t.replace(/[^a-z0-9]/g," "),t.split(/\s+/).filter(o=>o.length>1).filter(o=>!lS.has(o))}addDocument(e,t){this.documents.set(e,t);let o=this.tokenize(t);this.documentLengths.set(e,o.length);let n={};for(let s of o)n[s]=(n[s]??0)+1;for(let[s,i]of Object.entries(n))this.termFrequencies.has(s)||this.termFrequencies.set(s,new Map),this.termFrequencies.get(s).set(e,i);this.updateAvgDocLength()}clear(){this.documents.clear(),this.termFrequencies.clear(),this.documentLengths.clear(),this.avgDocLength=0}get size(){return this.documents.size}updateAvgDocLength(){if(this.documentLengths.size===0){this.avgDocLength=0;return}let e=0;this.documentLengths.forEach(t=>{e+=t}),this.avgDocLength=e/this.documentLengths.size}idf(e){let t=this.documents.size,o=this.termFrequencies.get(e)?.size??0;return o===0?0:Math.log((t-o+.5)/(o+.5)+1)}search(e,t=10){let o=this.tokenize(e);if(o.length===0)return[];let n={};this.documents.forEach((i,a)=>{let l=0,p=this.documentLengths.get(a)??0;for(let m of o){let d=this.termFrequencies.get(m);if(!d)continue;let g=d.get(a)??0;if(g===0)continue;let b=this.idf(m),w=g*(this.k1+1),T=g+this.k1*(1-this.b+this.b*(p/this.avgDocLength));l+=b*(w/T)}l>0&&(n[a]=l)});let s=Object.entries(n).map(([i,a])=>({id:i,score:a}));return s.sort((i,a)=>a.score-i.score),s.slice(0,t)}};c();import*as Je from"path";function Iw(r,e,t){let o=r.match(/^---\n([\s\S]*?)\n---/),n="",s="",i,a=[];if(o&&o[1]){let D=o[1].split(`
|
|
611
|
+
`);for(let M of D){let C=M.indexOf(":");if(C===-1)continue;let R=M.substring(0,C).trim(),$=M.substring(C+1).trim();if(R==="name"&&(n=$),R==="title"&&(s=$),R==="version"&&(i=$),R==="tags"){let E=$.match(/\[(.*)\]/);E&&E[1]&&(a=E[1].split(",").map(j=>j.trim().replace(/"/g,"")).filter(Boolean))}}}n||(n=Je.basename(e,".skill.md"));let l=r.match(/## Description\n\n([\s\S]*?)(?=\n## |$)/),p=l&&l[1]?l[1].trim():"",m=r.match(/## Triggers\n\n([\s\S]*?)(?=\n## |$)/),d=[];if(m&&m[1]){let D=m[1].split(`
|
|
612
|
+
`).filter(M=>M.startsWith("- "));for(let M of D){let C=M.match(/^- "(.*)"/);C&&C[1]&&d.push(C[1])}}let g=r.match(/## Instructions\n\n([\s\S]*?)(?=\n## |$)/),b=g&&g[1]?g[1].trim():"",w=r.match(/## Examples\n\n([\s\S]*?)(?=\n## |$)/),T=w&&w[1]?w[1].trim():void 0,v=Je.relative(t,e),k=Je.dirname(v),x=k==="."?void 0:k.split(Je.sep)[0];return{name:n,title:s,version:i,tags:a,category:x,filePath:e,description:p,triggers:d,instructions:b,examples:T||void 0,lastModified:0}}c();c();var z={name:50,title:100,tags:{count:10,each:30},description:300,triggers:{count:10,min:1,each:100},instructions:2e3,examples:3e3};var cS=/^[a-z][a-z0-9-]*$/;function jw(r,e){let t=[],o=[];r.name?(cS.test(r.name)||t.push(`name "${r.name}" must match kebab-case pattern /^[a-z][a-z0-9-]*$/`),r.name.length>z.name&&o.push(`name exceeds ${z.name} character limit (${r.name.length} chars)`)):t.push("name is required in frontmatter"),r.title?r.title.length>z.title&&o.push(`title exceeds ${z.title} character limit (${r.title.length} chars)`):t.push("title is required in frontmatter"),r.tags.length>z.tags.count&&o.push(`too many tags (${r.tags.length}); maximum is ${z.tags.count}`);for(let n of r.tags)n.length>z.tags.each&&o.push(`tag "${n}" exceeds ${z.tags.each} character limit`);if(r.description?r.description.length>z.description&&o.push(`description exceeds ${z.description} character limit (${r.description.length} chars)`):t.push("## Description section is required and must not be empty"),!r.triggers||r.triggers.length===0)t.push("## Triggers section must contain at least one trigger");else{r.triggers.length>z.triggers.count&&o.push(`too many triggers (${r.triggers.length}); maximum is ${z.triggers.count}`);for(let n of r.triggers)n.length>z.triggers.each&&o.push(`trigger "${n.substring(0,50)}..." exceeds ${z.triggers.each} character limit`)}return r.instructions?r.instructions.length>z.instructions&&o.push(`instructions exceed ${z.instructions} character limit (${r.instructions.length} chars)`):t.push("## Instructions section is required and must not be empty"),r.examples&&r.examples.length>z.examples&&o.push(`examples exceed ${z.examples} character limit (${r.examples.length} chars)`),{file:e,errors:t,warnings:o}}var Br=class{dir;onValidationError;loaded=!1;skills=new Map;fileMtimes=new Map;index=new Gr;_buildPromise=null;constructor(e){this.dir=jt.resolve(e.dir),this.onValidationError=e.onValidationError}async findSkillFiles(e){let t=[],o;try{o=await Ve.readdir(e)}catch{return t}for(let n of o){let s=jt.join(e,n),i;try{i=await Ve.stat(s)}catch{continue}if(i.isDirectory()){let a=await this.findSkillFiles(s);t.push(...a)}else i.isFile()&&n.endsWith(".skill.md")&&t.push(s)}return t}buildIndexContent(e){let t=[];t.push(e.name,e.name,e.name),t.push(e.title,e.title,e.title);for(let o of e.tags)t.push(o,o);for(let o of e.triggers)t.push(o,o);return t.push(e.description),t.join(" ")}async needsRebuild(e){if(!this.loaded||e.length!==this.fileMtimes.size)return!0;for(let t of e)try{let o=await Ve.stat(t),n=this.fileMtimes.get(t);if(n===void 0||o.mtimeMs!==n)return!0}catch{return!0}return!1}async buildIndex(e){this.loaded=!1,this.skills.clear(),this.fileMtimes.clear(),this.index.clear();let t=[],o=[],n=new Map;for(let s of e){let i,a;try{let[g,b]=await Promise.all([Ve.readFile(s,"utf-8"),Ve.stat(s)]);i=g.replace(/\r\n/g,`
|
|
613
|
+
`),a=b.mtimeMs}catch{continue}this.fileMtimes.set(s,a);let l=Iw(i,s,this.dir);l.lastModified=a;let p=jt.relative(this.dir,s),m=jw(l,p);if(m.warnings.length>0)for(let g of m.warnings)console.warn(`[skills] ${p}: ${g}`);if(m.errors.length>0){t.push({file:p,errors:m.errors}),this.onValidationError==="warn"&&console.warn(`[skills] Skipping invalid skill "${p}": ${m.errors.join("; ")}`);continue}let d=n.get(l.name);if(d){let g=`duplicate skill name "${l.name}" \u2014 already defined in "${d}"`;t.push({file:p,errors:[g]}),this.onValidationError==="warn"&&console.warn(`[skills] Skipping "${p}": ${g}`);continue}n.set(l.name,p),o.push(l)}if(t.length>0&&this.onValidationError==="fail"){let s=t.map(i=>` ${i.file}:
|
|
614
614
|
${i.errors.join(`
|
|
615
615
|
`)}`).join(`
|
|
616
616
|
`);throw new Error(`Skills validation failed \u2014 fix the following files before starting:
|
|
617
|
-
${s}`)}for(let s of o)this.skills.set(s.name,s),this.index.addDocument(s.name,this.buildIndexContent(s));this.loaded=!0}async ensureLoaded(){if(this._buildPromise)return this._buildPromise;let e=await this.findSkillFiles(this.dir);if(this._buildPromise)return this._buildPromise;if(await this.needsRebuild(e))return this._buildPromise?this._buildPromise:(this._buildPromise=this.buildIndex(e).finally(()=>{this._buildPromise=null}),this._buildPromise)}async search(e,t,o){await this.ensureLoaded();let n=this.index.search(e,t),s=[];for(let i of n){if(i.score<o)continue;let a=this.skills.get(i.id);a&&s.push({skill:a,score:i.score})}return s}async get(e){return await this.ensureLoaded(),this.skills.get(e)}async list(e){await this.ensureLoaded();let t=Array.from(this.skills.values());return e?.tag?t.filter(o=>o.tags.includes(e.tag)):t}};function
|
|
618
|
-
${g.map(
|
|
619
|
-
${
|
|
617
|
+
${s}`)}for(let s of o)this.skills.set(s.name,s),this.index.addDocument(s.name,this.buildIndexContent(s));this.loaded=!0}async ensureLoaded(){if(this._buildPromise)return this._buildPromise;let e=await this.findSkillFiles(this.dir);if(this._buildPromise)return this._buildPromise;if(await this.needsRebuild(e))return this._buildPromise?this._buildPromise:(this._buildPromise=this.buildIndex(e).finally(()=>{this._buildPromise=null}),this._buildPromise)}async search(e,t,o){await this.ensureLoaded();let n=this.index.search(e,t),s=[];for(let i of n){if(i.score<o)continue;let a=this.skills.get(i.id);a&&s.push({skill:a,score:i.score})}return s}async get(e){return await this.ensureLoaded(),this.skills.get(e)}async list(e){await this.ensureLoaded();let t=Array.from(this.skills.values());return e?.tag?t.filter(o=>o.tags.includes(e.tag)):t}};function pS(r){let e=r?.dir??".toolpack/skills",t=r?.maxSkills??3,o=r?.minScore??.3,n=r?.onValidationError??"fail",s=new Br({dir:e,onValidationError:n});return Object.assign(async(i,a)=>{let l=i.messages??[],p=-1;for(let g=l.length-1;g>=0;g--)if(l[g].role==="user"){p=g;break}let m=p>=0?l[p]:null,d=m&&typeof m.content=="string"?m.content.trim():"";if(d){let g=await s.search(d,t,o);if(g.length>0){let w=`<skill-instructions>
|
|
618
|
+
${g.map(v=>`--- Skill: ${v.skill.title} ---
|
|
619
|
+
${v.skill.instructions.trim()}
|
|
620
620
|
---`).join(`
|
|
621
621
|
|
|
622
622
|
`)}
|
|
623
|
-
</skill-instructions>`,T=l.map((
|
|
623
|
+
</skill-instructions>`,T=l.map((v,k)=>k===p&&typeof v.content=="string"?{...v,content:`${w}
|
|
624
624
|
|
|
625
|
-
${
|
|
625
|
+
${v.content}`}:v);return a({...i,messages:T})}}return a(i)},{init:()=>s.ensureLoaded()})}export{yw as AGENT_MODE,ea as AGENT_PLANNING_PROMPT,fw as AGENT_WORKFLOW,_n as AIClient,$n as AnthropicAdapter,ve as AuthenticationError,Wt as BM25SearchEngine,jr as BUILT_IN_MODES,bw as CHAT_MODE,hw as CHAT_WORKFLOW,ww as CODING_MODE,qC as CODING_PLANNING_PROMPT,gw as CODING_WORKFLOW,Dw as CONFIG_DIR_NAME,Mw as CONFIG_FILE_NAME,Xe as ConnectionError,da as ContextWindowConfigError,zr as ContextWindowExceededError,Yr as ContextWindowStateManager,ua as ConversationNotFoundError,Ot as DEFAULT_MODE_NAME,ce as DEFAULT_TOOLS_CONFIG,eT as DEFAULT_TOOL_SEARCH_CONFIG,K1 as DEFAULT_WORKFLOW,ta as DEFAULT_WORKFLOW_CONFIG,Dn as GeminiAdapter,sa as InMemoryConversationStore,Hr as InsufficientContextError,L as InvalidRequestError,vn as McpClient,Oe as McpConnectionError,Nr as McpTimeoutError,Ir as McpToolManager,Cn as ModeRegistry,nt as OllamaAdapter,Qt as OllamaProvider,vt as OpenAIAdapter,On as OpenRouterAdapter,pa as PageError,Sn as Planner,oe as ProviderAdapter,W as ProviderError,fe as RateLimitError,N as SDKError,ia as SQLiteConversationStore,Kr as SummarizationError,Ew as TOOLPACK_DIR_NAME,Ye as TOOL_SEARCH_NAME,ma as TimeoutError,ht as ToolDiscoveryCache,xn as ToolRegistry,Gt as ToolRouter,_w as Toolpack,En as VertexAIAdapter,Lr as WorkflowExecutor,gT as addBypassRule,IS as buildSummarizedHistory,xr as cloudDeployTool,Cr as cloudListTool,vr as cloudStatusTool,Cb as cloudToolsProject,dn as codingExtractFunctionTool,rn as codingFindReferencesTool,tn as codingFindSymbolTool,un as codingGetCallHierarchyTool,pn as codingGetDiagnosticsTool,mn as codingGetExportsTool,nn as codingGetImportsTool,cn as codingGetOutlineTool,on as codingGetSymbolsTool,sn as codingGoToDefinitionTool,an as codingMultiFileEditTool,ln as codingRefactorRenameTool,zh as codingToolsProject,ha as countTokens,va as createContextWindowStateManager,Vi as createMcpToolProject,WC as createMode,pS as createSkillInterceptor,FC as createSkillTools,jS as createSummarizationReport,Xr as createSummarySystemMessage,EC as createToolProject,wr as dbCountTool,br as dbDeleteTool,hr as dbInsertTool,ur as dbQueryTool,fr as dbSchemaTool,gr as dbTablesTool,db as dbToolsProject,yr as dbUpdateTool,lr as diffApplyTool,ar as diffCreateTool,cr as diffPreviewTool,Fy as diffToolsProject,Qi as disconnectMcpToolProject,Nw as ensureGlobalConfigDir,fB as ensureLocalConfigDir,Xw as estimateSummaryTokens,Ie as estimateTokenCount,Co as execKillTool,So as execListProcessesTool,xo as execReadOutputTool,wo as execRunBackgroundTool,To as execRunBlockingTool,bo as execRunShellTool,yo as execRunTool,vo as execTailOutputTool,cm as execToolsProject,NS as extractConversationKeypoints,Ua as fetchUrlAsBase64,Zt as fsAppendFileTool,go as fsBatchReadTool,ho as fsBatchWriteTool,ao as fsCopyTool,ro as fsCreateDirTool,fo as fsDeleteDirTool,eo as fsDeleteFileTool,to as fsExistsTool,uo as fsGlobTool,no as fsListDirTool,so as fsMoveTool,lo as fsReadFileRangeTool,Xt as fsReadFileTool,po as fsReplaceInFileTool,co as fsSearchTool,oo as fsStatTool,pp as fsToolsProject,mo as fsTreeTool,Yt as fsWriteFileTool,Qw as generateSummarizationPrompt,Zr as generateToolCategoriesPrompt,PS as getContextWindowPercentage,yT as getDefaultSlmModel,Aw as getGlobalConfigDir,qr as getGlobalConfigPath,iS as getGlobalToolpackDir,Ow as getLocalConfigDir,Wr as getLocalConfigPath,aS as getLocalToolpackDir,DS as getMessageStats,La as getMimeType,An as getOllamaBaseUrl,fT as getOllamaProviderEntries,wT as getRegisteredSlmModels,TB as getRuntimeConfigStatus,ya as getSafeOutputReserve,Ze as getToolSearchSchema,ns as getToolpackConfig,sS as getUserHomeDir,Yn as gitAddTool,er as gitBlameTool,or as gitBranchCreateTool,tr as gitBranchListTool,nr as gitCheckoutTool,ir as gitCloneTool,Zn as gitCommitTool,Qn as gitDiffTool,Xn as gitLogTool,Vn as gitStatusTool,Sy as gitToolsProject,Io as githubContentsGetTextTool,No as githubGraphqlExecuteTool,Go as githubIssuesCommentsCreateTool,qo as githubPrDiffGetTool,Wo as githubPrFilesListTool,Fo as githubPrReviewCommentsReplyTool,jo as githubPrReviewThreadsListTool,Lo as githubPrReviewThreadsResolveTool,Uo as githubPrReviewsSubmitTool,Au as githubToolsProject,ES as groupMessagesByRole,hS as handleContextWindowError,Ao as httpDeleteTool,Oo as httpDownloadTool,Eo as httpGetTool,Do as httpPostTool,Mo as httpPutTool,Rd as httpToolsProject,xB as initializeGlobalConfigIfFirstRun,gS as isContextWindowError,Fa as isDataUri,bT as isRegisteredSlm,bt as isToolSearchTool,Rr as k8sApplyManifestTool,_r as k8sDeleteResourceTool,kr as k8sDescribeTool,Dr as k8sGetConfigMapTool,Pr as k8sGetLogsTool,Ar as k8sGetNamespacesTool,Er as k8sListDeploymentsTool,Sr as k8sListPodsTool,$r as k8sListServicesTool,Mr as k8sSwitchContextTool,mw as k8sToolsProject,Or as k8sWaitForDeploymentTool,Wn as loadFullConfig,wB as loadRuntimeConfig,zo as loadToolsConfig,LS as mergeSummarizationResults,cT as normalizeImagePart,_e as ollamaRequest,ss as ollamaStream,qa as parseDataUri,xa as parseSummarizationResponse,Ta as prepareSummarizationRequest,ba as pruneMessages,Wa as readFileAsBase64,rs as reloadToolpackConfig,hT as removeBypassRule,Mx as saveToolsConfig,Tn as slackAuthTestTool,hn as slackChatPostEphemeralTool,gn as slackChatPostMessageTool,bn as slackConversationsHistoryTool,wn as slackConversationsRepliesTool,yn as slackReactionsAddTool,aw as slackToolsProject,_o as systemCwdTool,$o as systemDiskUsageTool,Po as systemEnvTool,ko as systemInfoTool,Ro as systemSetEnvTool,Bm as systemToolsProject,lT as toDataUri,yt as toolSearchDefinition,$S as truncateMessage,wa as validateSummarizationResult,Jo as webExtractLinksTool,Yo as webFeedTool,Bo as webFetchTool,Vo as webMapTool,Qo as webMetadataTool,Ko as webScrapeTool,Zo as webScreenshotTool,Ho as webSearchTool,Xo as webSitemapTool,og as webToolsProject,kS as wouldExceedContextWindow};
|