@mcp-use/inspector 0.14.0-canary.0 → 0.14.0-canary.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +10 -54
- package/dist/client/assets/base-Bnm339-a.js +2 -0
- package/dist/client/assets/{index-pqhVKjyB.js → base-RWAdy9P6.js} +33 -36
- package/dist/client/assets/browser-9kmymM9X.js +12 -0
- package/dist/client/assets/embeddings-C7cRBw1j.js +1 -0
- package/dist/client/assets/{index-CTUcNdQF.js → index-Apq2pBJl.js} +2 -2
- package/dist/client/assets/index-BsLLCsBP.js +1701 -0
- package/dist/client/assets/index-C2UfjD9L.js +4 -0
- package/dist/client/assets/index-C69r9Nt9.js +34 -0
- package/dist/client/assets/index-CtpnfKmY.js +7 -0
- package/dist/client/assets/{index-DorqJhTq.js → index-DIa0UgbZ.js} +1 -1
- package/dist/client/assets/index-DKR-Owed.js +70 -0
- package/dist/client/assets/{index-DvTyGyQK.js → index-DXrgZUfu.js} +3 -3
- package/dist/client/index.html +2 -2
- package/dist/server/{chunk-YLX7JQDX.js → chunk-BC23UV5D.js} +3 -1
- package/dist/server/{chunk-XGILHZOF.js → chunk-F7YWZTWJ.js} +4 -48
- package/dist/server/{chunk-JEKCWLHD.js → chunk-NOEIHEAG.js} +2 -2
- package/dist/server/{chunk-MCMZDGO6.js → chunk-Z5QIR3IS.js} +2 -2
- package/dist/server/cli.js +3 -3
- package/dist/server/index.js +4 -4
- package/dist/server/middleware.js +4 -4
- package/dist/server/server.d.ts.map +1 -1
- package/dist/server/server.js +29 -6
- package/dist/server/shared-routes.d.ts.map +1 -1
- package/dist/server/shared-routes.js +2 -2
- package/dist/server/shared-static.d.ts.map +1 -1
- package/dist/server/shared-static.js +1 -1
- package/dist/server/shared-utils-browser.d.ts.map +1 -1
- package/dist/server/shared-utils-browser.js +1 -1
- package/package.json +2 -2
- package/dist/client/assets/browser-2Ez00ml2.js +0 -501
- package/dist/client/assets/display-A5IEINAP-D2Zkswj8.js +0 -17
- package/dist/client/assets/embeddings-SLmbAVWP.js +0 -1
- package/dist/client/assets/fs-u42MReIY.js +0 -1
- package/dist/client/assets/index-BFXh5irY.js +0 -1701
- package/dist/client/assets/index-DDOzs1PG.js +0 -20
- package/dist/client/assets/index-DF_VhD4l.js +0 -33
- package/dist/client/assets/index-DRz5BQNA.js +0 -1
- package/dist/client/assets/index-JiKw9JSs.js +0 -5
- package/dist/client/assets/index-ZoGs-72y.js +0 -7
- package/dist/client/assets/index-jWGWxByD.js +0 -71
- package/dist/client/assets/llms-Og3hdOaD.js +0 -2
- package/dist/client/assets/path-BX1ROoWV.js +0 -1
- package/dist/client/assets/path-MNZaYwxc.js +0 -1
- package/dist/client/assets/posthog-node-CuYhrq1Q.js +0 -1
- package/dist/client/assets/util-t-trnxQI.js +0 -1
- package/dist/client/assets/winston-CYVymxcI.js +0 -37
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import{g as wn,O as Ut,h as bn,c as $t,f as xn,S as Sn,J as kn,R as Bt}from"./index-jWGWxByD.js";import{r as Tn,K as xs,t as Lt,ah as jt,I as Mn,J as On,E as N,B as qt,L as vn,y as ie,i as at,D as In,M as Rn}from"./index-pqhVKjyB.js";import{o as y,d as Wt,e as An,f as Cn,u as Dt,s as b,l as w,n as E,h as Ze,t as Mt,i as Pn,j as En}from"./index-BFXh5irY.js";import"./index-ZoGs-72y.js";import"./index-DRz5BQNA.js";var Ft=class extends wn{static lc_name(){return"AnthropicToolsOutputParser"}lc_namespace=["langchain","anthropic","output_parsers"];returnId=!1;keyName;returnSingle=!1;zodSchema;constructor(t){super(t),this.keyName=t.keyName,this.returnSingle=t.returnSingle??this.returnSingle,this.zodSchema=t.zodSchema}async _validateResult(t){let e=t;if(typeof t=="string")try{e=JSON.parse(t)}catch(n){throw new Ut(`Failed to parse. Text: "${JSON.stringify(t,null,2)}". Error: ${JSON.stringify(n.message)}`,t)}else e=t;if(this.zodSchema===void 0)return e;const s=await Tn(this.zodSchema,e);if(s.success)return s.data;throw new Ut(`Failed to parse. Text: "${JSON.stringify(t,null,2)}". Error: ${JSON.stringify(s.error.issues)}`,JSON.stringify(e,null,2))}async parseResult(t){const e=t.flatMap(r=>{const{message:a}=r;return Array.isArray(a.content)?Ss(a.content)[0]:[]});if(e[0]===void 0)throw new Error("No parseable tool calls provided to AnthropicToolsOutputParser.");const[s]=e;return await this._validateResult(s.args)}};function Ss(t){const e=[];for(const s of t)s.type==="tool_use"&&e.push({name:s.name,args:s.input,id:s.id,type:"tool_call"});return e}function Nn(t){if(t)return t==="any"?{type:"any"}:t==="auto"?{type:"auto"}:t==="none"?{type:"none"}:typeof t=="string"?{type:"tool",name:t}:t}const Un=y({cache_control:Cn().optional().nullable(),defer_loading:An().optional(),input_examples:Wt(Dt()).optional(),allowed_callers:Wt(Dt()).optional()}),Ht={tool_search_tool_regex_20251119:"advanced-tool-use-2025-11-20",tool_search_tool_bm25_20251119:"advanced-tool-use-2025-11-20",memory_20250818:"context-management-2025-06-27",web_fetch_20250910:"web-fetch-2025-09-10",code_execution_20250825:"code-execution-2025-08-25",computer_20251124:"computer-use-2025-11-24",computer_20250124:"computer-use-2025-01-24",mcp_toolset:"mcp-client-2025-11-20"};function $n(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="thinking"}function Bn(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="redacted_thinking"}function Ln(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="search_result"}function jn(t){return typeof t!="object"||t==null||!("type"in t)||t.type!=="image"||!("source"in t)||typeof t.source!="object"||t.source==null||!("type"in t.source)?!1:t.source.type==="base64"?!(!("media_type"in t.source)||typeof t.source.media_type!="string"||!("data"in t.source)||typeof t.source.data!="string"):t.source.type==="url"?!(!("url"in t.source)||typeof t.source.url!="string"):!1}const qn={providerName:"anthropic",fromStandardTextBlock(t){return{type:"text",text:t.text,..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}},fromStandardImageBlock(t){if(t.source_type==="url"){const e=xs({dataUrl:t.url,asTypedArray:!1});return e?{type:"image",source:{type:"base64",data:e.data,media_type:e.mime_type},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}:{type:"image",source:{type:"url",url:t.url},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}}else{if(t.source_type==="base64")return{type:"image",source:{type:"base64",data:t.data,media_type:t.mime_type??""},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}};throw new Error(`Unsupported image source type: ${t.source_type}`)}},fromStandardFileBlock(t){const e=(t.mime_type??"").split(";")[0];if(t.source_type==="url"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"url",url:t.url},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file url source: ${t.mime_type}`)}else if(t.source_type==="text"){if(e==="text/plain"||e==="")return{type:"document",source:{type:"text",data:t.text,media_type:t.mime_type??""},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file text source: ${t.mime_type}`)}else if(t.source_type==="base64"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"base64",data:t.data,media_type:"application/pdf"},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};if(["image/jpeg","image/png","image/gif","image/webp"].includes(e))return{type:"document",source:{type:"content",content:[{type:"image",source:{type:"base64",data:t.data,media_type:e}}]},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file base64 source: ${t.mime_type}`)}else throw new Error(`Unsupported file source type: ${t.source_type}`)}},Wn=t=>t();function Dn(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="citation"}function Fn(t){function*e(){for(const s of t)Dn(s)&&(s.source==="char"?yield{type:"char_location",file_id:s.url??"",start_char_index:s.startIndex??0,end_char_index:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="page"?yield{type:"page_location",file_id:s.url??"",start_page_number:s.startIndex??0,end_page_number:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="block"?yield{type:"content_block_location",file_id:s.url??"",start_block_index:s.startIndex??0,end_block_index:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="url"?yield{type:"web_search_result_location",url:s.url??"",title:s.title??null,encrypted_index:String(s.startIndex??0),cited_text:s.citedText??""}:s.source==="search"&&(yield{type:"search_result_location",title:s.title??null,start_block_index:s.startIndex??0,end_block_index:s.endIndex??0,search_result_index:0,source:s.source??"",cited_text:s.citedText??""}))}return Array.from(e())}function oe(t){return typeof t=="string"?t:Hn(t)}function Hn(t){const e=[];for(let s=0,{length:n}=t;s<n;s++)e.push(String.fromCharCode(t[s]));return btoa(e.join(""))}function it(t){return(t??"").split(";")[0].toLowerCase()}function ke(t,e){if(t!=null&&typeof t=="object"&&e in t)return t[e]}function Z(t,e){const s=ke(e,"cache_control");s!==void 0&&(t.cache_control=s);const n=ke(e,"citations");n!==void 0&&(t.citations=n);const r=ke(e,"context");r!==void 0&&(t.context=r);const a=ke(e,"title");return a!==void 0&&(t.title=a),t}function ot(t,e){const s=ke(e,"cache_control");return s!==void 0&&(t.cache_control=s),t}function Jt(t){return new Set(["image/jpeg","image/png","image/gif","image/webp"]).has(t)}function Jn(t){const e=[],s=t.response_metadata,n="model_provider"in s&&s?.model_provider==="anthropic";for(const r of t.contentBlocks)if(r.type==="text")r.annotations?e.push({type:"text",text:r.text,citations:Fn(r.annotations)}):e.push({type:"text",text:r.text});else if(r.type==="tool_call")e.push({type:"tool_use",id:r.id??"",name:r.name,input:r.args});else if(r.type==="tool_call_chunk"){const a=Wn(()=>{if(typeof r.args!="string")return r.args;try{return JSON.parse(r.args)}catch{return{}}});e.push({type:"tool_use",id:r.id??"",name:r.name??"",input:a})}else if(r.type==="reasoning"&&n)e.push({type:"thinking",thinking:r.reasoning,signature:String(r.signature)});else if(r.type==="server_tool_call"&&n)r.name==="web_search"?e.push({type:"server_tool_use",name:r.name,id:r.id??"",input:r.args}):r.name==="code_execution"&&e.push({type:"server_tool_use",name:r.name,id:r.id??"",input:r.args});else if(r.type==="server_tool_call_result"&&n)if(r.name==="web_search"&&Array.isArray(r.output.urls)){const a=r.output.urls.map(i=>({type:"web_search_result",title:"",encrypted_content:"",url:i}));e.push({type:"web_search_tool_result",tool_use_id:r.toolCallId??"",content:a})}else r.name==="code_execution"?e.push({type:"code_execution_tool_result",tool_use_id:r.toolCallId??"",content:r.output}):r.name==="mcp_tool_result"&&e.push({type:"mcp_tool_result",tool_use_id:r.toolCallId??"",content:r.output});else{if(r.type==="audio")throw new Error("Anthropic does not support audio content blocks.");if(r.type==="file"){const a=r.metadata;if(r.fileId){e.push(Z({type:"document",source:{type:"file",file_id:r.fileId}},a));continue}if(r.url){const i=it(r.mimeType);if(i==="application/pdf"||i===""){e.push(Z({type:"document",source:{type:"url",url:r.url}},a));continue}}if(r.data){const i=it(r.mimeType);if(i===""||i==="application/pdf")e.push(Z({type:"document",source:{type:"base64",data:oe(r.data),media_type:"application/pdf"}},a));else if(i==="text/plain")e.push(Z({type:"document",source:{type:"text",data:oe(r.data),media_type:"text/plain"}},a));else if(Jt(i))e.push(Z({type:"document",source:{type:"content",content:[{type:"image",source:{type:"base64",data:oe(r.data),media_type:i}}]}},a));else throw new Error(`Unsupported file mime type for Anthropic base64 source: ${i}`);continue}throw new Error("File content block must include a fileId, url, or data property.")}else if(r.type==="image"){const a=r.metadata;if(r.fileId){e.push(ot({type:"image",source:{type:"file",file_id:r.fileId}},a));continue}if(r.url){e.push(ot({type:"image",source:{type:"url",url:r.url}},a));continue}if(r.data){const i=it(r.mimeType)||"image/png";Jt(i)&&e.push(ot({type:"image",source:{type:"base64",data:oe(r.data),media_type:i}},a));continue}throw new Error("Image content block must include a fileId, url, or data property.")}else r.type==="video"||(r.type==="text-plain"?r.data&&e.push(Z({type:"document",source:{type:"text",data:oe(r.data),media_type:"text/plain"}},r.metadata)):r.type==="non_standard"&&n&&e.push(r.value))}return e}function Kt(t){const e=xs({dataUrl:t});if(e)return{type:"base64",media_type:e.mime_type,data:e.data};let s;try{s=new URL(t)}catch{throw new Error([`Malformed image URL: ${JSON.stringify(t)}. Content blocks of type 'image_url' must be a valid http, https, or base64-encoded data URL.`,"Example: data:image/png;base64,/9j/4AAQSk...","Example: https://example.com/image.jpg"].join(`
|
|
1
|
+
import{B as wn,O as Ut,a as bn,S as xn,J as Sn,R as $t}from"./index-DKR-Owed.js";import{as as kn,J as xs,ab as Bt,G as Lt,a5 as Tn,af as Mn,D as N,E as jt,at as On,aq as ie,i as at,ar as vn,au as In}from"./base-RWAdy9P6.js";import{o as y,b as qt,c as Rn,d as An,u as Wt,s as b,l as w,n as E,e as Ze,t as Mt,_ as Cn,f as Pn}from"./index-BsLLCsBP.js";import"./index-C2UfjD9L.js";import{c as Dt,d as En}from"./base-Bnm339-a.js";import"./index-CtpnfKmY.js";var Ft=class extends wn{static lc_name(){return"AnthropicToolsOutputParser"}lc_namespace=["langchain","anthropic","output_parsers"];returnId=!1;keyName;returnSingle=!1;zodSchema;constructor(t){super(t),this.keyName=t.keyName,this.returnSingle=t.returnSingle??this.returnSingle,this.zodSchema=t.zodSchema}async _validateResult(t){let e=t;if(typeof t=="string")try{e=JSON.parse(t)}catch(n){throw new Ut(`Failed to parse. Text: "${JSON.stringify(t,null,2)}". Error: ${JSON.stringify(n.message)}`,t)}else e=t;if(this.zodSchema===void 0)return e;const s=await kn(this.zodSchema,e);if(s.success)return s.data;throw new Ut(`Failed to parse. Text: "${JSON.stringify(t,null,2)}". Error: ${JSON.stringify(s.error.issues)}`,JSON.stringify(e,null,2))}async parseResult(t){const e=t.flatMap(r=>{const{message:a}=r;return Array.isArray(a.content)?Ss(a.content)[0]:[]});if(e[0]===void 0)throw new Error("No parseable tool calls provided to AnthropicToolsOutputParser.");const[s]=e;return await this._validateResult(s.args)}};function Ss(t){const e=[];for(const s of t)s.type==="tool_use"&&e.push({name:s.name,args:s.input,id:s.id,type:"tool_call"});return e}function Nn(t){if(t)return t==="any"?{type:"any"}:t==="auto"?{type:"auto"}:t==="none"?{type:"none"}:typeof t=="string"?{type:"tool",name:t}:t}const Un=y({cache_control:An().optional().nullable(),defer_loading:Rn().optional(),input_examples:qt(Wt()).optional(),allowed_callers:qt(Wt()).optional()}),Ht={tool_search_tool_regex_20251119:"advanced-tool-use-2025-11-20",tool_search_tool_bm25_20251119:"advanced-tool-use-2025-11-20",memory_20250818:"context-management-2025-06-27",web_fetch_20250910:"web-fetch-2025-09-10",code_execution_20250825:"code-execution-2025-08-25",computer_20251124:"computer-use-2025-11-24",computer_20250124:"computer-use-2025-01-24",mcp_toolset:"mcp-client-2025-11-20"};function $n(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="thinking"}function Bn(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="redacted_thinking"}function Ln(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="search_result"}function jn(t){return typeof t!="object"||t==null||!("type"in t)||t.type!=="image"||!("source"in t)||typeof t.source!="object"||t.source==null||!("type"in t.source)?!1:t.source.type==="base64"?!(!("media_type"in t.source)||typeof t.source.media_type!="string"||!("data"in t.source)||typeof t.source.data!="string"):t.source.type==="url"?!(!("url"in t.source)||typeof t.source.url!="string"):!1}const qn={providerName:"anthropic",fromStandardTextBlock(t){return{type:"text",text:t.text,..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}},fromStandardImageBlock(t){if(t.source_type==="url"){const e=xs({dataUrl:t.url,asTypedArray:!1});return e?{type:"image",source:{type:"base64",data:e.data,media_type:e.mime_type},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}:{type:"image",source:{type:"url",url:t.url},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}}}else{if(t.source_type==="base64")return{type:"image",source:{type:"base64",data:t.data,media_type:t.mime_type??""},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{}};throw new Error(`Unsupported image source type: ${t.source_type}`)}},fromStandardFileBlock(t){const e=(t.mime_type??"").split(";")[0];if(t.source_type==="url"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"url",url:t.url},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file url source: ${t.mime_type}`)}else if(t.source_type==="text"){if(e==="text/plain"||e==="")return{type:"document",source:{type:"text",data:t.text,media_type:t.mime_type??""},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file text source: ${t.mime_type}`)}else if(t.source_type==="base64"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"base64",data:t.data,media_type:"application/pdf"},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};if(["image/jpeg","image/png","image/gif","image/webp"].includes(e))return{type:"document",source:{type:"content",content:[{type:"image",source:{type:"base64",data:t.data,media_type:e}}]},..."cache_control"in(t.metadata??{})?{cache_control:t.metadata.cache_control}:{},..."citations"in(t.metadata??{})?{citations:t.metadata.citations}:{},..."context"in(t.metadata??{})?{context:t.metadata.context}:{},..."title"in(t.metadata??{})?{title:t.metadata.title}:{}};throw new Error(`Unsupported file mime type for file base64 source: ${t.mime_type}`)}else throw new Error(`Unsupported file source type: ${t.source_type}`)}},Wn=t=>t();function Dn(t){return typeof t=="object"&&t!==null&&"type"in t&&t.type==="citation"}function Fn(t){function*e(){for(const s of t)Dn(s)&&(s.source==="char"?yield{type:"char_location",file_id:s.url??"",start_char_index:s.startIndex??0,end_char_index:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="page"?yield{type:"page_location",file_id:s.url??"",start_page_number:s.startIndex??0,end_page_number:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="block"?yield{type:"content_block_location",file_id:s.url??"",start_block_index:s.startIndex??0,end_block_index:s.endIndex??0,document_title:s.title??null,document_index:0,cited_text:s.citedText??""}:s.source==="url"?yield{type:"web_search_result_location",url:s.url??"",title:s.title??null,encrypted_index:String(s.startIndex??0),cited_text:s.citedText??""}:s.source==="search"&&(yield{type:"search_result_location",title:s.title??null,start_block_index:s.startIndex??0,end_block_index:s.endIndex??0,search_result_index:0,source:s.source??"",cited_text:s.citedText??""}))}return Array.from(e())}function oe(t){return typeof t=="string"?t:Hn(t)}function Hn(t){const e=[];for(let s=0,{length:n}=t;s<n;s++)e.push(String.fromCharCode(t[s]));return btoa(e.join(""))}function it(t){return(t??"").split(";")[0].toLowerCase()}function ke(t,e){if(t!=null&&typeof t=="object"&&e in t)return t[e]}function Z(t,e){const s=ke(e,"cache_control");s!==void 0&&(t.cache_control=s);const n=ke(e,"citations");n!==void 0&&(t.citations=n);const r=ke(e,"context");r!==void 0&&(t.context=r);const a=ke(e,"title");return a!==void 0&&(t.title=a),t}function ot(t,e){const s=ke(e,"cache_control");return s!==void 0&&(t.cache_control=s),t}function Jt(t){return new Set(["image/jpeg","image/png","image/gif","image/webp"]).has(t)}function Jn(t){const e=[],s=t.response_metadata,n="model_provider"in s&&s?.model_provider==="anthropic";for(const r of t.contentBlocks)if(r.type==="text")r.annotations?e.push({type:"text",text:r.text,citations:Fn(r.annotations)}):e.push({type:"text",text:r.text});else if(r.type==="tool_call")e.push({type:"tool_use",id:r.id??"",name:r.name,input:r.args});else if(r.type==="tool_call_chunk"){const a=Wn(()=>{if(typeof r.args!="string")return r.args;try{return JSON.parse(r.args)}catch{return{}}});e.push({type:"tool_use",id:r.id??"",name:r.name??"",input:a})}else if(r.type==="reasoning"&&n)e.push({type:"thinking",thinking:r.reasoning,signature:String(r.signature)});else if(r.type==="server_tool_call"&&n)r.name==="web_search"?e.push({type:"server_tool_use",name:r.name,id:r.id??"",input:r.args}):r.name==="code_execution"&&e.push({type:"server_tool_use",name:r.name,id:r.id??"",input:r.args});else if(r.type==="server_tool_call_result"&&n)if(r.name==="web_search"&&Array.isArray(r.output.urls)){const a=r.output.urls.map(i=>({type:"web_search_result",title:"",encrypted_content:"",url:i}));e.push({type:"web_search_tool_result",tool_use_id:r.toolCallId??"",content:a})}else r.name==="code_execution"?e.push({type:"code_execution_tool_result",tool_use_id:r.toolCallId??"",content:r.output}):r.name==="mcp_tool_result"&&e.push({type:"mcp_tool_result",tool_use_id:r.toolCallId??"",content:r.output});else{if(r.type==="audio")throw new Error("Anthropic does not support audio content blocks.");if(r.type==="file"){const a=r.metadata;if(r.fileId){e.push(Z({type:"document",source:{type:"file",file_id:r.fileId}},a));continue}if(r.url){const i=it(r.mimeType);if(i==="application/pdf"||i===""){e.push(Z({type:"document",source:{type:"url",url:r.url}},a));continue}}if(r.data){const i=it(r.mimeType);if(i===""||i==="application/pdf")e.push(Z({type:"document",source:{type:"base64",data:oe(r.data),media_type:"application/pdf"}},a));else if(i==="text/plain")e.push(Z({type:"document",source:{type:"text",data:oe(r.data),media_type:"text/plain"}},a));else if(Jt(i))e.push(Z({type:"document",source:{type:"content",content:[{type:"image",source:{type:"base64",data:oe(r.data),media_type:i}}]}},a));else throw new Error(`Unsupported file mime type for Anthropic base64 source: ${i}`);continue}throw new Error("File content block must include a fileId, url, or data property.")}else if(r.type==="image"){const a=r.metadata;if(r.fileId){e.push(ot({type:"image",source:{type:"file",file_id:r.fileId}},a));continue}if(r.url){e.push(ot({type:"image",source:{type:"url",url:r.url}},a));continue}if(r.data){const i=it(r.mimeType)||"image/png";Jt(i)&&e.push(ot({type:"image",source:{type:"base64",data:oe(r.data),media_type:i}},a));continue}throw new Error("Image content block must include a fileId, url, or data property.")}else r.type==="video"||(r.type==="text-plain"?r.data&&e.push(Z({type:"document",source:{type:"text",data:oe(r.data),media_type:"text/plain"}},r.metadata)):r.type==="non_standard"&&n&&e.push(r.value))}return e}function Kt(t){const e=xs({dataUrl:t});if(e)return{type:"base64",media_type:e.mime_type,data:e.data};let s;try{s=new URL(t)}catch{throw new Error([`Malformed image URL: ${JSON.stringify(t)}. Content blocks of type 'image_url' must be a valid http, https, or base64-encoded data URL.`,"Example: data:image/png;base64,/9j/4AAQSk...","Example: https://example.com/image.jpg"].join(`
|
|
2
2
|
|
|
3
3
|
`))}if(s.protocol==="http:"||s.protocol==="https:")return{type:"url",url:t};throw new Error([`Invalid image URL protocol: ${JSON.stringify(s.protocol)}. Anthropic only supports images as http, https, or base64-encoded data URLs on 'image_url' content blocks.`,"Example: data:image/png;base64,/9j/4AAQSk...","Example: https://example.com/image.jpg"].join(`
|
|
4
4
|
|
|
5
|
-
`))}function Kn(t){const e=[];for(const s of t)if(s._getType()==="tool")if(typeof s.content=="string"){const n=e[e.length-1];n?._getType()==="human"&&Array.isArray(n.content)&&"type"in n.content[0]&&n.content[0].type==="tool_result"?n.content.push({type:"tool_result",content:s.content,tool_use_id:s.tool_call_id}):e.push(new
|
|
5
|
+
`))}function Kn(t){const e=[];for(const s of t)if(s._getType()==="tool")if(typeof s.content=="string"){const n=e[e.length-1];n?._getType()==="human"&&Array.isArray(n.content)&&"type"in n.content[0]&&n.content[0].type==="tool_result"?n.content.push({type:"tool_result",content:s.content,tool_use_id:s.tool_call_id}):e.push(new Lt({content:[{type:"tool_result",content:s.content,tool_use_id:s.tool_call_id}]}))}else e.push(new Lt({content:[{type:"tool_result",...s.content!=null?{content:_t(s)}:{},tool_use_id:s.tool_call_id}]}));else e.push(s);return e}function Xt(t){if(t.id===void 0)throw new Error('Anthropic requires all tool calls to have an "id".');return{type:"tool_use",id:t.id,name:t.name,input:t.args}}function*Xn(t){const e=["bash_code_execution_tool_result","input_json_delta","server_tool_use","text_editor_code_execution_tool_result","tool_result","tool_use","web_search_result","web_search_tool_result"],s=["text","text_delta"];for(const n of t){Tn(n)&&(yield Mn(n,qn));const r="cache_control"in n?n.cache_control:void 0;if(n.type==="image_url"){let a;typeof n.image_url=="string"?a=Kt(n.image_url):typeof n.image_url=="object"&&n.image_url!==null&&"url"in n.image_url&&typeof n.image_url.url=="string"&&(a=Kt(n.image_url.url)),a&&(yield{type:"image",source:a,...r?{cache_control:r}:{}})}else{if(jn(n))return n;if(n.type==="document")yield{...n,...r?{cache_control:r}:{}};else if($n(n))yield{type:"thinking",thinking:n.thinking,signature:n.signature,...r?{cache_control:r}:{}};else if(Bn(n))yield{type:"redacted_thinking",data:n.data,...r?{cache_control:r}:{}};else if(Ln(n))yield{type:"search_result",title:n.title,source:n.source,..."cache_control"in n&&n.cache_control?{cache_control:n.cache_control}:{},..."citations"in n&&n.citations?{citations:n.citations}:{},content:n.content};else if(s.find(a=>a===n.type)&&"text"in n)yield{type:"text",text:n.text,...r?{cache_control:r}:{},..."citations"in n&&n.citations?{citations:n.citations}:{}};else if(e.find(a=>a===n.type)){const a={...n};if("index"in a&&delete a.index,a.type==="input_json_delta"&&(a.type="tool_use"),"input"in a&&typeof a.input=="string")try{a.input=JSON.parse(a.input)}catch{a.input={}}yield{...a,...r?{cache_control:r}:{}}}else n.type==="container_upload"&&(yield{...n,...r?{cache_control:r}:{}})}}}function _t(t){const{content:e}=t;return typeof e=="string"?e:Array.from(Xn(e))}function zt(t){const e=Kn(t);let s;e.length>0&&e[0]._getType()==="system"&&(s=t[0].content);const r=(s!==void 0?e.slice(1):e).map(a=>{let i;if(a._getType()==="human")i="user";else if(a._getType()==="ai")i="assistant";else if(a._getType()==="tool")i="user";else throw a._getType()==="system"?new Error("System messages are only permitted as the first passed message."):new Error(`Message type "${a.type}" is not supported.`);if(Bt(a)&&a.response_metadata?.output_version==="v1")return{role:i,content:Jn(a)};if(Bt(a)&&a.tool_calls?.length){if(typeof a.content=="string")return a.content===""?{role:i,content:a.tool_calls.map(Xt)}:{role:i,content:[{type:"text",text:a.content},...a.tool_calls.map(Xt)]};{const{content:u}=a;return!a.tool_calls.every(h=>u.find(p=>(p.type==="tool_use"||p.type==="input_json_delta"||p.type==="server_tool_use")&&p.id===h.id))&&console.warn('The "tool_calls" field on a message is only respected if content is a string.'),{role:i,content:_t(a)}}}else return{role:i,content:_t(a)}});return{messages:zn(r),system:s}}function zn(t){if(!t||t.length<=1)return t;const e=[];let s=t[0];const n=a=>typeof a=="string"?[{type:"text",text:a}]:a,r=a=>a.role!=="user"||typeof a.content=="string"?!1:Array.isArray(a.content)&&a.content.every(i=>i.type==="tool_result");for(let a=1;a<t.length;a+=1){const i=t[a];r(s)&&r(i)?s={...s,content:[...n(s.content),...n(i.content)]}:(e.push(s),s=i)}return e.push(s),e}function Vn(t,e){const s={model_provider:"anthropic"};if(t.type==="message_start"){const{content:n,usage:r,...a}=t.message,i={};for(const[_,d]of Object.entries(a))d!=null&&(i[_]=d);const{input_tokens:u,output_tokens:c,...h}=r??{},p=u+h.cache_creation_input_tokens+h.cache_read_input_tokens,f={input_tokens:p,output_tokens:c,total_tokens:p+c,input_token_details:{cache_creation:h.cache_creation_input_tokens,cache_read:h.cache_read_input_tokens}};return{chunk:new N({content:e.coerceContentToString?"":[],additional_kwargs:i,usage_metadata:e.streamUsage?f:void 0,response_metadata:{...s,usage:{...h}},id:t.message.id})}}else if(t.type==="message_delta"){const n={input_tokens:0,output_tokens:t.usage.output_tokens,total_tokens:t.usage.output_tokens,input_token_details:{cache_creation:t.usage.cache_creation_input_tokens,cache_read:t.usage.cache_read_input_tokens}},r="context_management"in t.delta?{context_management:t.delta.context_management}:void 0;return{chunk:new N({content:e.coerceContentToString?"":[],response_metadata:r,additional_kwargs:{...t.delta},usage_metadata:e.streamUsage?n:void 0})}}else if(t.type==="content_block_start"&&["tool_use","document","server_tool_use","web_search_tool_result"].includes(t.content_block.type)){const n=t.content_block;let r;return n.type==="tool_use"?r=[{id:n.id,index:t.index,name:n.name,args:""}]:r=[],{chunk:new N({content:e.coerceContentToString?"":[{index:t.index,...t.content_block,input:n.type==="server_tool_use"||n.type==="tool_use"?"":void 0}],response_metadata:s,additional_kwargs:{},tool_call_chunks:r})}}else if(t.type==="content_block_delta"&&["text_delta","citations_delta","thinking_delta","signature_delta"].includes(t.delta.type)){if(e.coerceContentToString&&"text"in t.delta)return{chunk:new N({content:t.delta.text})};{const n=t.delta;return"citation"in n&&(n.citations=[n.citation],delete n.citation),n.type==="thinking_delta"||n.type==="signature_delta"?{chunk:new N({content:[{index:t.index,...n,type:"thinking"}],response_metadata:s})}:{chunk:new N({content:[{index:t.index,...n,type:"text"}],response_metadata:s})}}}else{if(t.type==="content_block_delta"&&t.delta.type==="input_json_delta")return{chunk:new N({content:e.coerceContentToString?"":[{index:t.index,input:t.delta.partial_json,type:t.delta.type}],response_metadata:s,additional_kwargs:{},tool_call_chunks:[{index:t.index,args:t.delta.partial_json}]})};if(t.type==="content_block_start"&&t.content_block.type==="text"){const n=t.content_block?.text;if(n!==void 0)return{chunk:new N({content:e.coerceContentToString?n:[{index:t.index,...t.content_block}],response_metadata:s,additional_kwargs:{}})}}else{if(t.type==="content_block_start"&&t.content_block.type==="redacted_thinking")return{chunk:new N({content:e.coerceContentToString?"":[{index:t.index,...t.content_block}],response_metadata:s})};if(t.type==="content_block_start"&&t.content_block.type==="thinking"){const n=t.content_block.thinking;return{chunk:new N({content:e.coerceContentToString?n:[{index:t.index,...t.content_block}],response_metadata:s})}}}}return null}function Qn(t,e){const s={...e,model_provider:"anthropic"},n=e.usage,r=n!=null?{input_tokens:n.input_tokens??0,output_tokens:n.output_tokens??0,total_tokens:(n.input_tokens??0)+(n.output_tokens??0),input_token_details:{cache_creation:n.cache_creation_input_tokens,cache_read:n.cache_read_input_tokens}}:void 0;if(t.length===1&&t[0].type==="text")return[{text:t[0].text,message:new jt({content:t[0].text,additional_kwargs:e,usage_metadata:r,response_metadata:s,id:e.id})}];{const a=Ss(t);return[{text:"",message:new jt({content:t,additional_kwargs:e,tool_calls:a,usage_metadata:r,response_metadata:s,id:e.id})}]}}function Ce(t,e){return t.lc_error_code=e,t.message=`${t.message}
|
|
6
6
|
|
|
7
7
|
Troubleshooting URL: https://docs.langchain.com/oss/javascript/langchain/errors/${e}/
|
|
8
8
|
`,t}function Vt(t){let e;return t.status===400&&t.message.includes("tool")?e=Ce(t,"INVALID_TOOL_RESULTS"):t.status===401?e=Ce(t,"MODEL_AUTHENTICATION"):t.status===404?e=Ce(t,"MODEL_NOT_FOUND"):t.status===429?e=Ce(t,"MODEL_RATE_LIMIT"):e=t,e}const Yn={"claude-opus-4-0":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:32e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-5-sonnet-20241022":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:8192,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-opus-4-1":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:32e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-haiku-4-5":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-5-sonnet-20240620":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:8192,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-5-haiku-latest":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:8192,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-opus-20240229":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:4096,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-sonnet-4-5":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-sonnet-4-5-20250929":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-sonnet-4-20250514":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-opus-4-20250514":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:32e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-5-haiku-20241022":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:8192,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-haiku-20240307":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:4096,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-7-sonnet-20250219":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-7-sonnet-latest":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-sonnet-4-0":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-opus-4-1-20250805":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:32e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-3-sonnet-20240229":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:4096,reasoningOutput:!1,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0},"claude-haiku-4-5-20251001":{maxInputTokens:2e5,imageInputs:!0,audioInputs:!1,pdfInputs:!0,videoInputs:!1,maxOutputTokens:64e3,reasoningOutput:!0,imageOutputs:!1,audioOutputs:!1,videoOutputs:!1,toolCalling:!0,structuredOutput:!1,imageUrlInputs:!0,pdfToolMessage:!0,imageToolMessage:!0}};var Gn=Yn;function l(t,e,s,n,r){if(typeof e=="function"?t!==e||!0:!e.has(t))throw new TypeError("Cannot write private member to an object whose class did not declare it");return e.set(t,s),s}function o(t,e,s,n){if(s==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?t!==e||!n:!e.has(t))throw new TypeError("Cannot read private member from an object whose class did not declare it");return s==="m"?n:s==="a"?n.call(t):n?n.value:e.get(t)}let ks=function(){const{crypto:t}=globalThis;if(t?.randomUUID)return ks=t.randomUUID.bind(t),t.randomUUID();const e=new Uint8Array(1),s=t?()=>t.getRandomValues(e)[0]:()=>Math.random()*255&255;return"10000000-1000-4000-8000-100000000000".replace(/[018]/g,n=>(+n^s()&15>>+n/4).toString(16))};function Oe(t){return typeof t=="object"&&t!==null&&("name"in t&&t.name==="AbortError"||"message"in t&&String(t.message).includes("FetchRequestCanceledException"))}const yt=t=>{if(t instanceof Error)return t;if(typeof t=="object"&&t!==null){try{if(Object.prototype.toString.call(t)==="[object Error]"){const e=new Error(t.message,t.cause?{cause:t.cause}:{});return t.stack&&(e.stack=t.stack),t.cause&&!e.cause&&(e.cause=t.cause),t.name&&(e.name=t.name),e}}catch{}try{return new Error(JSON.stringify(t))}catch{}}return new Error(t)};class m extends Error{}class T extends m{constructor(e,s,n,r){super(`${T.makeMessage(e,s,n)}`),this.status=e,this.headers=r,this.requestID=r?.get("request-id"),this.error=s}static makeMessage(e,s,n){const r=s?.message?typeof s.message=="string"?s.message:JSON.stringify(s.message):s?JSON.stringify(s):n;return e&&r?`${e} ${r}`:e?`${e} status code (no body)`:r||"(no status code or body)"}static generate(e,s,n,r){if(!e||!r)return new et({message:n,cause:yt(s)});const a=s;return e===400?new Ms(e,a,n,r):e===401?new Os(e,a,n,r):e===403?new vs(e,a,n,r):e===404?new Is(e,a,n,r):e===409?new Rs(e,a,n,r):e===422?new As(e,a,n,r):e===429?new Cs(e,a,n,r):e>=500?new Ps(e,a,n,r):new T(e,a,n,r)}}class U extends T{constructor({message:e}={}){super(void 0,void 0,e||"Request was aborted.",void 0)}}class et extends T{constructor({message:e,cause:s}){super(void 0,void 0,e||"Connection error.",void 0),s&&(this.cause=s)}}class Ts extends et{constructor({message:e}={}){super({message:e??"Request timed out."})}}class Ms extends T{}class Os extends T{}class vs extends T{}class Is extends T{}class Rs extends T{}class As extends T{}class Cs extends T{}class Ps extends T{}const Zn=/^[a-z][a-z0-9+.-]*:/i,er=t=>Zn.test(t);let wt=t=>(wt=Array.isArray,wt(t)),Qt=wt;function bt(t){return typeof t!="object"?{}:t??{}}function tr(t){if(!t)return!0;for(const e in t)return!1;return!0}function sr(t,e){return Object.prototype.hasOwnProperty.call(t,e)}const nr=(t,e)=>{if(typeof e!="number"||!Number.isInteger(e))throw new m(`${t} must be an integer`);if(e<0)throw new m(`${t} must be a positive integer`);return e},Es=t=>{try{return JSON.parse(t)}catch{return}},O=(t,e)=>{const s=t[e];return delete t[e],s},rr=t=>new Promise(e=>setTimeout(e,t)),se="0.71.2",ar=()=>typeof window<"u"&&typeof window.document<"u"&&typeof navigator<"u";function ir(){return typeof Deno<"u"&&Deno.build!=null?"deno":typeof EdgeRuntime<"u"?"edge":Object.prototype.toString.call(typeof globalThis.process<"u"?globalThis.process:0)==="[object process]"?"node":"unknown"}const or=()=>{const t=ir();if(t==="deno")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":se,"X-Stainless-OS":Gt(Deno.build.os),"X-Stainless-Arch":Yt(Deno.build.arch),"X-Stainless-Runtime":"deno","X-Stainless-Runtime-Version":typeof Deno.version=="string"?Deno.version:Deno.version?.deno??"unknown"};if(typeof EdgeRuntime<"u")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":se,"X-Stainless-OS":"Unknown","X-Stainless-Arch":`other:${EdgeRuntime}`,"X-Stainless-Runtime":"edge","X-Stainless-Runtime-Version":globalThis.process.version};if(t==="node")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":se,"X-Stainless-OS":Gt(globalThis.process.platform??"unknown"),"X-Stainless-Arch":Yt(globalThis.process.arch??"unknown"),"X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":globalThis.process.version??"unknown"};const e=ur();return e?{"X-Stainless-Lang":"js","X-Stainless-Package-Version":se,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":`browser:${e.browser}`,"X-Stainless-Runtime-Version":e.version}:{"X-Stainless-Lang":"js","X-Stainless-Package-Version":se,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":"unknown","X-Stainless-Runtime-Version":"unknown"}};function ur(){if(typeof navigator>"u"||!navigator)return null;const t=[{key:"edge",pattern:/Edge(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/MSIE(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/Trident(?:.*rv\:(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"chrome",pattern:/Chrome(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"firefox",pattern:/Firefox(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"safari",pattern:/(?:Version\W+(\d+)\.(\d+)(?:\.(\d+))?)?(?:\W+Mobile\S*)?\W+Safari/}];for(const{key:e,pattern:s}of t){const n=s.exec(navigator.userAgent);if(n){const r=n[1]||0,a=n[2]||0,i=n[3]||0;return{browser:e,version:`${r}.${a}.${i}`}}}return null}const Yt=t=>t==="x32"?"x32":t==="x86_64"||t==="x64"?"x64":t==="arm"?"arm":t==="aarch64"||t==="arm64"?"arm64":t?`other:${t}`:"unknown",Gt=t=>(t=t.toLowerCase(),t.includes("ios")?"iOS":t==="android"?"Android":t==="darwin"?"MacOS":t==="win32"?"Windows":t==="freebsd"?"FreeBSD":t==="openbsd"?"OpenBSD":t==="linux"?"Linux":t?`Other:${t}`:"Unknown");let Zt;const cr=()=>Zt??(Zt=or());function lr(){if(typeof fetch<"u")return fetch;throw new Error("`fetch` is not defined as a global; Either pass `fetch` to the client, `new Anthropic({ fetch })` or polyfill the global, `globalThis.fetch = fetch`")}function Ns(...t){const e=globalThis.ReadableStream;if(typeof e>"u")throw new Error("`ReadableStream` is not defined as a global; You will need to polyfill it, `globalThis.ReadableStream = ReadableStream`");return new e(...t)}function Us(t){let e=Symbol.asyncIterator in t?t[Symbol.asyncIterator]():t[Symbol.iterator]();return Ns({start(){},async pull(s){const{done:n,value:r}=await e.next();n?s.close():s.enqueue(r)},async cancel(){await e.return?.()}})}function Ot(t){if(t[Symbol.asyncIterator])return t;const e=t.getReader();return{async next(){try{const s=await e.read();return s?.done&&e.releaseLock(),s}catch(s){throw e.releaseLock(),s}},async return(){const s=e.cancel();return e.releaseLock(),await s,{done:!0,value:void 0}},[Symbol.asyncIterator](){return this}}}async function dr(t){if(t===null||typeof t!="object")return;if(t[Symbol.asyncIterator]){await t[Symbol.asyncIterator]().return?.();return}const e=t.getReader(),s=e.cancel();e.releaseLock(),await s}const hr=({headers:t,body:e})=>({bodyHeaders:{"content-type":"application/json"},body:JSON.stringify(e)});function pr(t){let e=0;for(const r of t)e+=r.length;const s=new Uint8Array(e);let n=0;for(const r of t)s.set(r,n),n+=r.length;return s}let es;function vt(t){let e;return(es??(e=new globalThis.TextEncoder,es=e.encode.bind(e)))(t)}let ts;function ss(t){let e;return(ts??(e=new globalThis.TextDecoder,ts=e.decode.bind(e)))(t)}var R,A;class ve{constructor(){R.set(this,void 0),A.set(this,void 0),l(this,R,new Uint8Array),l(this,A,null)}decode(e){if(e==null)return[];const s=e instanceof ArrayBuffer?new Uint8Array(e):typeof e=="string"?vt(e):e;l(this,R,pr([o(this,R,"f"),s]));const n=[];let r;for(;(r=fr(o(this,R,"f"),o(this,A,"f")))!=null;){if(r.carriage&&o(this,A,"f")==null){l(this,A,r.index);continue}if(o(this,A,"f")!=null&&(r.index!==o(this,A,"f")+1||r.carriage)){n.push(ss(o(this,R,"f").subarray(0,o(this,A,"f")-1))),l(this,R,o(this,R,"f").subarray(o(this,A,"f"))),l(this,A,null);continue}const a=o(this,A,"f")!==null?r.preceding-1:r.preceding,i=ss(o(this,R,"f").subarray(0,a));n.push(i),l(this,R,o(this,R,"f").subarray(r.index)),l(this,A,null)}return n}flush(){return o(this,R,"f").length?this.decode(`
|
|
@@ -46,4 +46,4 @@ you can set the \`dangerouslyAllowBrowser\` option to \`true\`, e.g.,
|
|
|
46
46
|
new Anthropic({ apiKey, dangerouslyAllowBrowser: true });
|
|
47
47
|
`);this.baseURL=a.baseURL,this.timeout=a.timeout??Ct.DEFAULT_TIMEOUT,this.logger=a.logger??console;const i="warn";this.logLevel=i,this.logLevel=ns(a.logLevel,"ClientOptions.logLevel",this)??ns(Xe("ANTHROPIC_LOG"),"process.env['ANTHROPIC_LOG']",this)??i,this.fetchOptions=a.fetchOptions,this.maxRetries=a.maxRetries??2,this.fetch=a.fetch??lr(),l(this,Ve,hr),this._options=a,this.apiKey=typeof s=="string"?s:null,this.authToken=n}withOptions(e){return new this.constructor({...this._options,baseURL:this.baseURL,maxRetries:this.maxRetries,timeout:this.timeout,logger:this.logger,logLevel:this.logLevel,fetch:this.fetch,fetchOptions:this.fetchOptions,apiKey:this.apiKey,authToken:this.authToken,...e})}defaultQuery(){return this._options.defaultQuery}validateHeaders({values:e,nulls:s}){if(!(e.get("x-api-key")||e.get("authorization"))&&!(this.apiKey&&e.get("x-api-key"))&&!s.has("x-api-key")&&!(this.authToken&&e.get("authorization"))&&!s.has("authorization"))throw new Error('Could not resolve authentication method. Expected either apiKey or authToken to be set. Or for one of the "X-Api-Key" or "Authorization" headers to be explicitly omitted')}async authHeaders(e){return g([await this.apiKeyAuth(e),await this.bearerAuth(e)])}async apiKeyAuth(e){if(this.apiKey!=null)return g([{"X-Api-Key":this.apiKey}])}async bearerAuth(e){if(this.authToken!=null)return g([{Authorization:`Bearer ${this.authToken}`}])}stringifyQuery(e){return Object.entries(e).filter(([s,n])=>typeof n<"u").map(([s,n])=>{if(typeof n=="string"||typeof n=="number"||typeof n=="boolean")return`${encodeURIComponent(s)}=${encodeURIComponent(n)}`;if(n===null)return`${encodeURIComponent(s)}=`;throw new m(`Cannot stringify type ${typeof n}; Expected string, number, boolean, or null. If you need to pass nested query parameters, you can manually encode them, e.g. { query: { 'foo[key1]': value1, 'foo[key2]': value2 } }, and please open a GitHub issue requesting better support for your use case.`)}).join("&")}getUserAgent(){return`${this.constructor.name}/JS ${se}`}defaultIdempotencyKey(){return`stainless-node-retry-${ks()}`}makeStatusError(e,s,n,r){return T.generate(e,s,n,r)}buildURL(e,s,n){const r=!o(this,Tt,"m",sn).call(this)&&n||this.baseURL,a=er(e)?new URL(e):new URL(r+(r.endsWith("/")&&e.startsWith("/")?e.slice(1):e)),i=this.defaultQuery();return tr(i)||(s={...i,...s}),typeof s=="object"&&s&&!Array.isArray(s)&&(a.search=this.stringifyQuery(s)),a.toString()}_calculateNonstreamingTimeout(e){if(3600*e/128e3>600)throw new m("Streaming is required for operations that may take longer than 10 minutes. See https://github.com/anthropics/anthropic-sdk-typescript#streaming-responses for more details");return 600*1e3}async prepareOptions(e){}async prepareRequest(e,{url:s,options:n}){}get(e,s){return this.methodRequest("get",e,s)}post(e,s){return this.methodRequest("post",e,s)}patch(e,s){return this.methodRequest("patch",e,s)}put(e,s){return this.methodRequest("put",e,s)}delete(e,s){return this.methodRequest("delete",e,s)}methodRequest(e,s,n){return this.request(Promise.resolve(n).then(r=>({method:e,path:s,...r})))}request(e,s=null){return new tt(this,this.makeRequest(e,s,void 0))}async makeRequest(e,s,n){const r=await e,a=r.maxRetries??this.maxRetries;s==null&&(s=a),await this.prepareOptions(r);const{req:i,url:u,timeout:c}=await this.buildRequest(r,{retryCount:a-s});await this.prepareRequest(i,{url:u,options:r});const h="log_"+(Math.random()*(1<<24)|0).toString(16).padStart(6,"0"),p=n===void 0?"":`, retryOf: ${n}`,f=Date.now();if(M(this).debug(`[${h}] sending request`,Y({retryOfRequestLogID:n,method:r.method,url:u,options:r,headers:i.headers})),r.signal?.aborted)throw new U;const _=new AbortController,d=await this.fetchWithTimeout(u,i,c,_).catch(yt),v=Date.now();if(d instanceof globalThis.Error){const q=`retrying, ${s} attempts remaining`;if(r.signal?.aborted)throw new U;const L=Oe(d)||/timed? ?out/i.test(String(d)+("cause"in d?String(d.cause):""));if(s)return M(this).info(`[${h}] connection ${L?"timed out":"failed"} - ${q}`),M(this).debug(`[${h}] connection ${L?"timed out":"failed"} (${q})`,Y({retryOfRequestLogID:n,url:u,durationMs:v-f,message:d.message})),this.retryRequest(r,s,n??h);throw M(this).info(`[${h}] connection ${L?"timed out":"failed"} - error; no more retries left`),M(this).debug(`[${h}] connection ${L?"timed out":"failed"} (error; no more retries left)`,Y({retryOfRequestLogID:n,url:u,durationMs:v-f,message:d.message})),L?new Ts:new et({cause:d})}const X=[...d.headers.entries()].filter(([q])=>q==="request-id").map(([q,L])=>", "+q+": "+JSON.stringify(L)).join(""),rt=`[${h}${p}${X}] ${i.method} ${u} ${d.ok?"succeeded":"failed"} with status ${d.status} in ${v-f}ms`;if(!d.ok){const q=await this.shouldRetry(d);if(s&&q){const Ae=`retrying, ${s} attempts remaining`;return await dr(d.body),M(this).info(`${rt} - ${Ae}`),M(this).debug(`[${h}] response error (${Ae})`,Y({retryOfRequestLogID:n,url:d.url,status:d.status,headers:d.headers,durationMs:v-f})),this.retryRequest(r,s,n??h,d.headers)}const L=q?"error; no more retries left":"error; not retryable";M(this).info(`${rt} - ${L}`);const Pt=await d.text().catch(Ae=>yt(Ae).message),Et=Es(Pt),Nt=Et?void 0:Pt;throw M(this).debug(`[${h}] response error (${L})`,Y({retryOfRequestLogID:n,url:d.url,status:d.status,headers:d.headers,message:Nt,durationMs:Date.now()-f})),this.makeStatusError(d.status,Et,Nt,d.headers)}return M(this).info(rt),M(this).debug(`[${h}] response start`,Y({retryOfRequestLogID:n,url:d.url,status:d.status,headers:d.headers,durationMs:v-f})),{response:d,options:r,controller:_,requestLogID:h,retryOfRequestLogID:n,startTime:f}}getAPIList(e,s,n){return this.requestAPIList(s,{method:"get",path:e,...n})}requestAPIList(e,s){const n=this.makeRequest(s,null,void 0);return new xr(this,n,e)}async fetchWithTimeout(e,s,n,r){const{signal:a,method:i,...u}=s||{};a&&a.addEventListener("abort",()=>r.abort());const c=setTimeout(()=>r.abort(),n),h=globalThis.ReadableStream&&u.body instanceof globalThis.ReadableStream||typeof u.body=="object"&&u.body!==null&&Symbol.asyncIterator in u.body,p={signal:r.signal,...h?{duplex:"half"}:{},method:"GET",...u};i&&(p.method=i.toUpperCase());try{return await this.fetch.call(void 0,e,p)}finally{clearTimeout(c)}}async shouldRetry(e){const s=e.headers.get("x-should-retry");return s==="true"?!0:s==="false"?!1:e.status===408||e.status===409||e.status===429||e.status>=500}async retryRequest(e,s,n,r){let a;const i=r?.get("retry-after-ms");if(i){const c=parseFloat(i);Number.isNaN(c)||(a=c)}const u=r?.get("retry-after");if(u&&!a){const c=parseFloat(u);Number.isNaN(c)?a=Date.parse(u)-Date.now():a=c*1e3}if(!(a&&0<=a&&a<60*1e3)){const c=e.maxRetries??this.maxRetries;a=this.calculateDefaultRetryTimeoutMillis(s,c)}return await rr(a),this.makeRequest(e,s-1,n)}calculateDefaultRetryTimeoutMillis(e,s){const a=s-e,i=Math.min(.5*Math.pow(2,a),8),u=1-Math.random()*.25;return i*u*1e3}calculateNonstreamingTimeout(e,s){if(36e5*e/128e3>6e5||s!=null&&e>s)throw new m("Streaming is required for operations that may take longer than 10 minutes. See https://github.com/anthropics/anthropic-sdk-typescript#long-requests for more details");return 6e5}async buildRequest(e,{retryCount:s=0}={}){const n={...e},{method:r,path:a,query:i,defaultBaseURL:u}=n,c=this.buildURL(a,i,u);"timeout"in n&&nr("timeout",n.timeout),n.timeout=n.timeout??this.timeout;const{bodyHeaders:h,body:p}=this.buildBody({options:n}),f=await this.buildHeaders({options:e,method:r,bodyHeaders:h,retryCount:s});return{req:{method:r,headers:f,...n.signal&&{signal:n.signal},...globalThis.ReadableStream&&p instanceof globalThis.ReadableStream&&{duplex:"half"},...p&&{body:p},...this.fetchOptions??{},...n.fetchOptions??{}},url:c,timeout:n.timeout}}async buildHeaders({options:e,method:s,bodyHeaders:n,retryCount:r}){let a={};this.idempotencyHeader&&s!=="get"&&(e.idempotencyKey||(e.idempotencyKey=this.defaultIdempotencyKey()),a[this.idempotencyHeader]=e.idempotencyKey);const i=g([a,{Accept:"application/json","User-Agent":this.getUserAgent(),"X-Stainless-Retry-Count":String(r),...e.timeout?{"X-Stainless-Timeout":String(Math.trunc(e.timeout/1e3))}:{},...cr(),...this._options.dangerouslyAllowBrowser?{"anthropic-dangerous-direct-browser-access":"true"}:void 0,"anthropic-version":"2023-06-01"},await this.authHeaders(e),this._options.defaultHeaders,n,e.headers]);return this.validateHeaders(i),i.values}buildBody({options:{body:e,headers:s}}){if(!e)return{bodyHeaders:void 0,body:void 0};const n=g([s]);return ArrayBuffer.isView(e)||e instanceof ArrayBuffer||e instanceof DataView||typeof e=="string"&&n.values.has("content-type")||globalThis.Blob&&e instanceof globalThis.Blob||e instanceof FormData||e instanceof URLSearchParams||globalThis.ReadableStream&&e instanceof globalThis.ReadableStream?{bodyHeaders:void 0,body:e}:typeof e=="object"&&(Symbol.asyncIterator in e||Symbol.iterator in e&&"next"in e&&typeof e.next=="function")?{bodyHeaders:void 0,body:Us(e)}:o(this,Ve,"f").call(this,{body:e,headers:n})}}Ct=x,Ve=new WeakMap,Tt=new WeakSet,sn=function(){return this.baseURL!=="https://api.anthropic.com"};x.Anthropic=Ct;x.HUMAN_PROMPT=jr;x.AI_PROMPT=qr;x.DEFAULT_TIMEOUT=6e5;x.AnthropicError=m;x.APIError=T;x.APIConnectionError=et;x.APIConnectionTimeoutError=Ts;x.APIUserAbortError=U;x.NotFoundError=Is;x.ConflictError=Rs;x.RateLimitError=Cs;x.BadRequestError=Ms;x.AuthenticationError=Os;x.InternalServerError=Ps;x.PermissionDeniedError=vs;x.UnprocessableEntityError=As;x.toFile=vr;class Re extends x{constructor(){super(...arguments),this.completions=new Zs(this),this.messages=new At(this),this.models=new tn(this),this.beta=new ae(this)}}Re.Completions=Zs;Re.Messages=At;Re.Models=tn;Re.Beta=ae;const Wr=new Set(["date-time","time","date","duration","email","hostname","uri","ipv4","ipv6","uuid"]);function Dr(t){return JSON.parse(JSON.stringify(t))}function Fr(t){const e=Dr(t);return G(e)}function G(t){const e={},s=O(t,"$ref");if(s!==void 0)return e.$ref=s,e;const n=O(t,"$defs");if(n!==void 0){const p={};e.$defs=p;for(const[f,_]of Object.entries(n))p[f]=G(_)}const r=O(t,"type"),a=O(t,"anyOf"),i=O(t,"oneOf"),u=O(t,"allOf");if(Array.isArray(a))e.anyOf=a.map(p=>G(p));else if(Array.isArray(i))e.anyOf=i.map(p=>G(p));else if(Array.isArray(u))e.allOf=u.map(p=>G(p));else{if(r===void 0)throw new Error("JSON schema must have a type defined if anyOf/oneOf/allOf are not used");e.type=r}const c=O(t,"description");c!==void 0&&(e.description=c);const h=O(t,"title");if(h!==void 0&&(e.title=h),r==="object"){const p=O(t,"properties")||{};e.properties=Object.fromEntries(Object.entries(p).map(([_,d])=>[_,G(d)])),O(t,"additionalProperties"),e.additionalProperties=!1;const f=O(t,"required");f!==void 0&&(e.required=f)}else if(r==="string"){const p=O(t,"format");p!==void 0&&Wr.has(p)?e.format=p:p!==void 0&&(t.format=p)}else if(r==="array"){const p=O(t,"items");p!==void 0&&(e.items=G(p));const f=O(t,"minItems");f!==void 0&&(f===0||f===1)?e.minItems=f:f!==void 0&&(t.minItems=f)}if(Object.keys(t).length>0){const p=e.description;e.description=(p?p+`
|
|
48
48
|
|
|
49
|
-
`:"")+"{"+Object.entries(t).map(([f,_])=>`${f}: ${JSON.stringify(_)}`).join(", ")+"}"}return e}const Hr={"claude-opus-4-1":8192,"claude-opus-4":8192,"claude-sonnet-4":8192,"claude-sonnet-3-7-sonnet":8192,"claude-3-5-sonnet":4096,"claude-3-5-haiku":4096,"claude-3-haiku":2048},bs=2048;function Jr(t){return t?Object.entries(Hr).find(([s])=>t.startsWith(s))?.[1]??bs:bs}function Kr(t){return!!(t.tools&&t.tools.length>0)}function Xr(t){for(const e of t.messages??[])if(typeof e.content!="string"){for(const s of e.content??[])if(typeof s=="object"&&s!=null&&s.type==="document"&&typeof s.citations=="object"&&s.citations?.enabled)return!0}return!1}function zr(t){return!!(t.thinking&&t.thinking.type==="enabled")}function Vr(t){return"input_schema"in t}function Qr(t){const e=["text_editor_","computer_","bash_","web_search_","web_fetch_","str_replace_editor_","str_replace_based_edit_tool_","code_execution_","memory_","tool_search_","mcp_toolset"];return typeof t=="object"&&t!==null&&"type"in t&&("name"in t||"mcp_server_name"in t)&&typeof t.type=="string"&&e.some(s=>typeof t.type=="string"&&t.type.startsWith(s))}function Yr(t,e,...s){return Array.from(new Set([...t??[],...e??[],...s.flatMap(n=>Array.from(n))]))}function Gr(t){if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)&&t.content.length>=1&&"input"in t.content[0])return typeof t.content[0].input=="string"?t.content[0].input:JSON.stringify(t.content[0].input);if(Array.isArray(t.content)&&t.content.length>=1&&"text"in t.content[0]&&typeof t.content[0].text=="string")return t.content[0].text}var Zr=class extends bn{static lc_name(){return"ChatAnthropic"}get lc_secrets(){return{anthropicApiKey:"ANTHROPIC_API_KEY",apiKey:"ANTHROPIC_API_KEY"}}get lc_aliases(){return{modelName:"model"}}lc_serializable=!0;anthropicApiKey;apiKey;apiUrl;temperature;topK;topP;maxTokens;modelName="claude-3-5-sonnet-latest";model="claude-3-5-sonnet-latest";invocationKwargs;stopSequences;streaming=!1;clientOptions;thinking={type:"disabled"};contextManagement;batchClient;streamingClient;streamUsage=!0;betas;createClient;constructor(t){if(super(t??{}),this.anthropicApiKey=t?.apiKey??t?.anthropicApiKey??vn("ANTHROPIC_API_KEY"),!this.anthropicApiKey&&!t?.createClient)throw new Error("Anthropic API key not found");this.clientOptions=t?.clientOptions??{},this.apiKey=this.anthropicApiKey,this.apiUrl=t?.anthropicApiUrl,this.modelName=t?.model??t?.modelName??this.model,this.model=this.modelName,this.invocationKwargs=t?.invocationKwargs??{},this.topP=t?.topP??this.topP,this.temperature=t?.temperature??this.temperature,this.topK=t?.topK??this.topK,this.maxTokens=t?.maxTokens??Jr(this.model),this.stopSequences=t?.stopSequences??this.stopSequences,this.streaming=t?.streaming??!1,this.streamUsage=t?.streamUsage??this.streamUsage,this.thinking=t?.thinking??this.thinking,this.contextManagement=t?.contextManagement??this.contextManagement,this.betas=t?.betas??this.betas,this.createClient=t?.createClient??(e=>new Re(e))}getLsParams(t){const e=this.invocationParams(t);return{ls_provider:"anthropic",ls_model_name:this.model,ls_model_type:"chat",ls_temperature:e.temperature??void 0,ls_max_tokens:e.max_tokens??void 0,ls_stop:t.stop}}formatStructuredToolToAnthropic(t){if(!(!t||!t.length))return t.map(e=>{if($t(e)&&e.extras?.providerToolDefinition)return e.extras.providerToolDefinition;if(Qr(e)||Vr(e))return e;if(xn(e))return{name:e.function.name,description:e.function.description,input_schema:e.function.parameters};if($t(e))return{name:e.name,description:e.description,input_schema:at(e.schema)?ie(e.schema):e.schema,...e.extras?Un.parse(e.extras):{}};throw new Error(`Unknown tool type passed to ChatAnthropic: ${JSON.stringify(e,null,2)}`)})}bindTools(t,e){return this.withConfig({tools:this.formatStructuredToolToAnthropic(t),...e})}invocationParams(t){const e=Nn(t?.tool_choice),s=t?.tools?.reduce((r,a)=>{if(typeof a=="object"&&"type"in a&&a.type in Ht){const i=Ht[a.type];if(!r.includes(i))return[...r,i]}return r},[]),n={model:this.model,stop_sequences:t?.stop??this.stopSequences,stream:this.streaming,max_tokens:this.maxTokens,tools:this.formatStructuredToolToAnthropic(t?.tools),tool_choice:e,thinking:this.thinking,context_management:this.contextManagement,...this.invocationKwargs,container:t?.container,betas:Yr(this.betas,t?.betas,s??[]),output_format:t?.output_format,mcp_servers:t?.mcp_servers};if(this.thinking.type==="enabled"){if(this.topP!==void 0&&this.topK!==-1)throw new Error("topK is not supported when thinking is enabled");if(this.temperature!==void 0&&this.temperature!==1)throw new Error("temperature is not supported when thinking is enabled")}else n.temperature=this.temperature,n.top_k=this.topK,n.top_p=this.topP;return n}_identifyingParams(){return{model_name:this.model,...this.invocationParams()}}identifyingParams(){return{model_name:this.model,...this.invocationParams()}}async*_streamResponseChunks(t,e,s){const n=this.invocationParams(e),r=zt(t),a={...n,...r,stream:!0},i=!Kr(a)&&!Xr(a)&&!zr(a),u=await this.createStreamWithRetry(a,{headers:e.headers});for await(const c of u){if(e.signal?.aborted)throw u.controller.abort(),new Error("AbortError: User aborted the request.");const h=this.streamUsage??e.streamUsage,p=Vn(c,{streamUsage:h,coerceContentToString:i});if(!p)continue;const{chunk:f}=p,_=Gr(f),d=new In({message:new N({content:f.content,additional_kwargs:f.additional_kwargs,tool_call_chunks:f.tool_call_chunks,usage_metadata:h?f.usage_metadata:void 0,response_metadata:f.response_metadata,id:f.id}),text:_??""});yield d,await s?.handleLLMNewToken(_??"",void 0,void 0,void 0,void 0,{chunk:d})}}async _generateNonStreaming(t,e,s){const n=await this.completionWithRetry({...e,stream:!1,...zt(t)},s),{content:r,...a}=n,i=Qn(r,a),{role:u,type:c,...h}=a;return{generations:i,llmOutput:h}}async _generate(t,e,s){if(this.stopSequences&&e.stop)throw new Error('"stopSequence" parameter found in input and default params');const n=this.invocationParams(e);if(n.stream){let r;const a=this._streamResponseChunks(t,e,s);for await(const i of a)r===void 0?r=i:r=r.concat(i);if(r===void 0)throw new Error("No chunks returned from Anthropic API.");return{generations:[{text:r.text,message:r.message}]}}else return this._generateNonStreaming(t,n,{signal:e.signal,headers:e.headers})}async createStreamWithRetry(t,e){if(!this.streamingClient){const a=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.streamingClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...a,apiKey:this.apiKey,maxRetries:0})}const{betas:s,...n}=t,r=async()=>{try{return t?.betas?.length?await this.streamingClient.beta.messages.create({...n,betas:s,...this.invocationKwargs,stream:!0},e):await this.streamingClient.messages.create({...n,...this.invocationKwargs,stream:!0},e)}catch(a){throw Vt(a)}};return this.caller.call(r)}async completionWithRetry(t,e){if(!this.batchClient){const a=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.batchClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...a,apiKey:this.apiKey,maxRetries:0})}const{betas:s,...n}=t,r=async()=>{try{return t?.betas?.length?await this.batchClient.beta.messages.create({...n,...this.invocationKwargs,betas:s},e):await this.batchClient.messages.create({...n,...this.invocationKwargs},e)}catch(a){throw Vt(a)}};return this.caller.callWithOptions({signal:e.signal??void 0},r)}_llmType(){return"anthropic"}get profile(){return Gn[this.model]??{}}withStructuredOutput(t,e){let s,n;const{schema:r,name:a,includeRaw:i}={...e,schema:t};let u=e?.method??"functionCalling";if(u==="jsonMode"&&(console.warn('"jsonMode" is not supported for Anthropic models. Falling back to "jsonSchema".'),u="jsonSchema"),u==="jsonSchema"){n=at(r)?Sn.fromZodSchema(r):new kn;const f=Fr(ie(r));s=this.withConfig({outputVersion:"v0",output_format:{type:"json_schema",schema:f},betas:["structured-outputs-2025-11-13"],ls_structured_output_format:{kwargs:{method:"json_schema"},schema:f}})}else if(u==="functionCalling"){let f=a??"extract",_;if(at(r)){const d=ie(r);_=[{name:f,description:d.description??"A function available to call.",input_schema:d}],n=new Ft({returnSingle:!0,keyName:f,zodSchema:r})}else{let d;typeof r.name=="string"&&typeof r.description=="string"&&typeof r.input_schema=="object"&&r.input_schema!=null?(d=r,f=r.name):d={name:f,description:r.description??"",input_schema:r},_=[d],n=new Ft({returnSingle:!0,keyName:f})}if(this.thinking?.type==="enabled"){const d="Anthropic structured output relies on forced tool calling, which is not supported when `thinking` is enabled. This method will raise OutputParserException if tool calls are not generated. Consider disabling `thinking` or adjust your prompt to ensure the tool is called.";console.warn(d),s=this.withConfig({outputVersion:"v0",tools:_,ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ie(r)}});const v=X=>{if(!X.tool_calls||X.tool_calls.length===0)throw new Error(d);return X};s=s.pipe(v)}else s=this.withConfig({outputVersion:"v0",tools:_,tool_choice:{type:"tool",name:f},ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ie(r)}})}else throw new TypeError(`Unrecognized structured output method '${u}'. Expected 'functionCalling' or 'jsonSchema'`);if(!i)return s.pipe(n).withConfig({runName:"ChatAnthropicStructuredOutput"});const c=Bt.assign({parsed:(f,_)=>n.invoke(f.raw,_)}),h=Bt.assign({parsed:()=>null}),p=c.withFallbacks({fallbacks:[h]});return Rn.from([{raw:s},p]).withConfig({runName:"StructuredOutputRunnable"})}},Sa=class extends Zr{};const ea=y({command:w("view"),path:b()}),ta=y({command:w("create"),path:b(),file_text:b()}),sa=y({command:w("str_replace"),path:b(),old_str:b(),new_str:b()}),na=y({command:w("insert"),path:b(),insert_line:E(),insert_text:b()}),ra=y({command:w("delete"),path:b()}),aa=y({command:w("rename"),old_path:b(),new_path:b()});Ze("command",[ea,ta,sa,na,ra,aa]);const ia=y({command:w("view"),path:b(),view_range:Mt([E(),E()]).optional()}),oa=y({command:w("str_replace"),path:b(),old_str:b(),new_str:b()}),ua=y({command:w("create"),path:b(),file_text:b()}),ca=y({command:w("insert"),path:b(),insert_line:E(),new_str:b()});Ze("command",[ia,oa,ua,ca]);const $=Mt([E(),E()]),nn=y({action:w("screenshot")}),rn=y({action:w("left_click"),coordinate:$}),an=y({action:w("right_click"),coordinate:$}),on=y({action:w("middle_click"),coordinate:$}),un=y({action:w("double_click"),coordinate:$}),cn=y({action:w("triple_click"),coordinate:$}),ln=y({action:w("left_click_drag"),start_coordinate:$,end_coordinate:$}),dn=y({action:w("left_mouse_down"),coordinate:$}),hn=y({action:w("left_mouse_up"),coordinate:$}),pn=y({action:w("scroll"),coordinate:$,scroll_direction:Pn(["up","down","left","right"]),scroll_amount:E()}),fn=y({action:w("type"),text:b()}),mn=y({action:w("key"),key:b()}),gn=y({action:w("mouse_move"),coordinate:$}),_n=y({action:w("hold_key"),key:b()}),yn=y({action:w("wait"),duration:E().optional()}),la=y({action:w("zoom"),region:Mt([E(),E(),E(),E()])});Ze("action",[nn,rn,an,on,un,cn,ln,dn,hn,pn,fn,mn,gn,_n,yn]);Ze("action",[nn,rn,an,on,un,cn,ln,dn,hn,pn,fn,mn,gn,_n,yn,la]);const da=y({command:b().describe("The bash command to run")}),ha=y({restart:w(!0).describe("Set to true to restart the bash session")});En([da,ha]);export{Sa as ChatAnthropic,Zr as ChatAnthropicMessages};
|
|
49
|
+
`:"")+"{"+Object.entries(t).map(([f,_])=>`${f}: ${JSON.stringify(_)}`).join(", ")+"}"}return e}const Hr={"claude-opus-4-1":8192,"claude-opus-4":8192,"claude-sonnet-4":8192,"claude-sonnet-3-7-sonnet":8192,"claude-3-5-sonnet":4096,"claude-3-5-haiku":4096,"claude-3-haiku":2048},bs=2048;function Jr(t){return t?Object.entries(Hr).find(([s])=>t.startsWith(s))?.[1]??bs:bs}function Kr(t){return!!(t.tools&&t.tools.length>0)}function Xr(t){for(const e of t.messages??[])if(typeof e.content!="string"){for(const s of e.content??[])if(typeof s=="object"&&s!=null&&s.type==="document"&&typeof s.citations=="object"&&s.citations?.enabled)return!0}return!1}function zr(t){return!!(t.thinking&&t.thinking.type==="enabled")}function Vr(t){return"input_schema"in t}function Qr(t){const e=["text_editor_","computer_","bash_","web_search_","web_fetch_","str_replace_editor_","str_replace_based_edit_tool_","code_execution_","memory_","tool_search_","mcp_toolset"];return typeof t=="object"&&t!==null&&"type"in t&&("name"in t||"mcp_server_name"in t)&&typeof t.type=="string"&&e.some(s=>typeof t.type=="string"&&t.type.startsWith(s))}function Yr(t,e,...s){return Array.from(new Set([...t??[],...e??[],...s.flatMap(n=>Array.from(n))]))}function Gr(t){if(typeof t.content=="string")return t.content;if(Array.isArray(t.content)&&t.content.length>=1&&"input"in t.content[0])return typeof t.content[0].input=="string"?t.content[0].input:JSON.stringify(t.content[0].input);if(Array.isArray(t.content)&&t.content.length>=1&&"text"in t.content[0]&&typeof t.content[0].text=="string")return t.content[0].text}var Zr=class extends bn{static lc_name(){return"ChatAnthropic"}get lc_secrets(){return{anthropicApiKey:"ANTHROPIC_API_KEY",apiKey:"ANTHROPIC_API_KEY"}}get lc_aliases(){return{modelName:"model"}}lc_serializable=!0;anthropicApiKey;apiKey;apiUrl;temperature;topK;topP;maxTokens;modelName="claude-3-5-sonnet-latest";model="claude-3-5-sonnet-latest";invocationKwargs;stopSequences;streaming=!1;clientOptions;thinking={type:"disabled"};contextManagement;batchClient;streamingClient;streamUsage=!0;betas;createClient;constructor(t){if(super(t??{}),this.anthropicApiKey=t?.apiKey??t?.anthropicApiKey??On("ANTHROPIC_API_KEY"),!this.anthropicApiKey&&!t?.createClient)throw new Error("Anthropic API key not found");this.clientOptions=t?.clientOptions??{},this.apiKey=this.anthropicApiKey,this.apiUrl=t?.anthropicApiUrl,this.modelName=t?.model??t?.modelName??this.model,this.model=this.modelName,this.invocationKwargs=t?.invocationKwargs??{},this.topP=t?.topP??this.topP,this.temperature=t?.temperature??this.temperature,this.topK=t?.topK??this.topK,this.maxTokens=t?.maxTokens??Jr(this.model),this.stopSequences=t?.stopSequences??this.stopSequences,this.streaming=t?.streaming??!1,this.streamUsage=t?.streamUsage??this.streamUsage,this.thinking=t?.thinking??this.thinking,this.contextManagement=t?.contextManagement??this.contextManagement,this.betas=t?.betas??this.betas,this.createClient=t?.createClient??(e=>new Re(e))}getLsParams(t){const e=this.invocationParams(t);return{ls_provider:"anthropic",ls_model_name:this.model,ls_model_type:"chat",ls_temperature:e.temperature??void 0,ls_max_tokens:e.max_tokens??void 0,ls_stop:t.stop}}formatStructuredToolToAnthropic(t){if(!(!t||!t.length))return t.map(e=>{if(Dt(e)&&e.extras?.providerToolDefinition)return e.extras.providerToolDefinition;if(Qr(e)||Vr(e))return e;if(En(e))return{name:e.function.name,description:e.function.description,input_schema:e.function.parameters};if(Dt(e))return{name:e.name,description:e.description,input_schema:at(e.schema)?ie(e.schema):e.schema,...e.extras?Un.parse(e.extras):{}};throw new Error(`Unknown tool type passed to ChatAnthropic: ${JSON.stringify(e,null,2)}`)})}bindTools(t,e){return this.withConfig({tools:this.formatStructuredToolToAnthropic(t),...e})}invocationParams(t){const e=Nn(t?.tool_choice),s=t?.tools?.reduce((r,a)=>{if(typeof a=="object"&&"type"in a&&a.type in Ht){const i=Ht[a.type];if(!r.includes(i))return[...r,i]}return r},[]),n={model:this.model,stop_sequences:t?.stop??this.stopSequences,stream:this.streaming,max_tokens:this.maxTokens,tools:this.formatStructuredToolToAnthropic(t?.tools),tool_choice:e,thinking:this.thinking,context_management:this.contextManagement,...this.invocationKwargs,container:t?.container,betas:Yr(this.betas,t?.betas,s??[]),output_format:t?.output_format,mcp_servers:t?.mcp_servers};if(this.thinking.type==="enabled"){if(this.topP!==void 0&&this.topK!==-1)throw new Error("topK is not supported when thinking is enabled");if(this.temperature!==void 0&&this.temperature!==1)throw new Error("temperature is not supported when thinking is enabled")}else n.temperature=this.temperature,n.top_k=this.topK,n.top_p=this.topP;return n}_identifyingParams(){return{model_name:this.model,...this.invocationParams()}}identifyingParams(){return{model_name:this.model,...this.invocationParams()}}async*_streamResponseChunks(t,e,s){const n=this.invocationParams(e),r=zt(t),a={...n,...r,stream:!0},i=!Kr(a)&&!Xr(a)&&!zr(a),u=await this.createStreamWithRetry(a,{headers:e.headers});for await(const c of u){if(e.signal?.aborted)throw u.controller.abort(),new Error("AbortError: User aborted the request.");const h=this.streamUsage??e.streamUsage,p=Vn(c,{streamUsage:h,coerceContentToString:i});if(!p)continue;const{chunk:f}=p,_=Gr(f),d=new vn({message:new N({content:f.content,additional_kwargs:f.additional_kwargs,tool_call_chunks:f.tool_call_chunks,usage_metadata:h?f.usage_metadata:void 0,response_metadata:f.response_metadata,id:f.id}),text:_??""});yield d,await s?.handleLLMNewToken(_??"",void 0,void 0,void 0,void 0,{chunk:d})}}async _generateNonStreaming(t,e,s){const n=await this.completionWithRetry({...e,stream:!1,...zt(t)},s),{content:r,...a}=n,i=Qn(r,a),{role:u,type:c,...h}=a;return{generations:i,llmOutput:h}}async _generate(t,e,s){if(this.stopSequences&&e.stop)throw new Error('"stopSequence" parameter found in input and default params');const n=this.invocationParams(e);if(n.stream){let r;const a=this._streamResponseChunks(t,e,s);for await(const i of a)r===void 0?r=i:r=r.concat(i);if(r===void 0)throw new Error("No chunks returned from Anthropic API.");return{generations:[{text:r.text,message:r.message}]}}else return this._generateNonStreaming(t,n,{signal:e.signal,headers:e.headers})}async createStreamWithRetry(t,e){if(!this.streamingClient){const a=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.streamingClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...a,apiKey:this.apiKey,maxRetries:0})}const{betas:s,...n}=t,r=async()=>{try{return t?.betas?.length?await this.streamingClient.beta.messages.create({...n,betas:s,...this.invocationKwargs,stream:!0},e):await this.streamingClient.messages.create({...n,...this.invocationKwargs,stream:!0},e)}catch(a){throw Vt(a)}};return this.caller.call(r)}async completionWithRetry(t,e){if(!this.batchClient){const a=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.batchClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...a,apiKey:this.apiKey,maxRetries:0})}const{betas:s,...n}=t,r=async()=>{try{return t?.betas?.length?await this.batchClient.beta.messages.create({...n,...this.invocationKwargs,betas:s},e):await this.batchClient.messages.create({...n,...this.invocationKwargs},e)}catch(a){throw Vt(a)}};return this.caller.callWithOptions({signal:e.signal??void 0},r)}_llmType(){return"anthropic"}get profile(){return Gn[this.model]??{}}withStructuredOutput(t,e){let s,n;const{schema:r,name:a,includeRaw:i}={...e,schema:t};let u=e?.method??"functionCalling";if(u==="jsonMode"&&(console.warn('"jsonMode" is not supported for Anthropic models. Falling back to "jsonSchema".'),u="jsonSchema"),u==="jsonSchema"){n=at(r)?xn.fromZodSchema(r):new Sn;const f=Fr(ie(r));s=this.withConfig({outputVersion:"v0",output_format:{type:"json_schema",schema:f},betas:["structured-outputs-2025-11-13"],ls_structured_output_format:{kwargs:{method:"json_schema"},schema:f}})}else if(u==="functionCalling"){let f=a??"extract",_;if(at(r)){const d=ie(r);_=[{name:f,description:d.description??"A function available to call.",input_schema:d}],n=new Ft({returnSingle:!0,keyName:f,zodSchema:r})}else{let d;typeof r.name=="string"&&typeof r.description=="string"&&typeof r.input_schema=="object"&&r.input_schema!=null?(d=r,f=r.name):d={name:f,description:r.description??"",input_schema:r},_=[d],n=new Ft({returnSingle:!0,keyName:f})}if(this.thinking?.type==="enabled"){const d="Anthropic structured output relies on forced tool calling, which is not supported when `thinking` is enabled. This method will raise OutputParserException if tool calls are not generated. Consider disabling `thinking` or adjust your prompt to ensure the tool is called.";console.warn(d),s=this.withConfig({outputVersion:"v0",tools:_,ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ie(r)}});const v=X=>{if(!X.tool_calls||X.tool_calls.length===0)throw new Error(d);return X};s=s.pipe(v)}else s=this.withConfig({outputVersion:"v0",tools:_,tool_choice:{type:"tool",name:f},ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ie(r)}})}else throw new TypeError(`Unrecognized structured output method '${u}'. Expected 'functionCalling' or 'jsonSchema'`);if(!i)return s.pipe(n).withConfig({runName:"ChatAnthropicStructuredOutput"});const c=$t.assign({parsed:(f,_)=>n.invoke(f.raw,_)}),h=$t.assign({parsed:()=>null}),p=c.withFallbacks({fallbacks:[h]});return In.from([{raw:s},p]).withConfig({runName:"StructuredOutputRunnable"})}},ka=class extends Zr{};const ea=y({command:w("view"),path:b()}),ta=y({command:w("create"),path:b(),file_text:b()}),sa=y({command:w("str_replace"),path:b(),old_str:b(),new_str:b()}),na=y({command:w("insert"),path:b(),insert_line:E(),insert_text:b()}),ra=y({command:w("delete"),path:b()}),aa=y({command:w("rename"),old_path:b(),new_path:b()});Ze("command",[ea,ta,sa,na,ra,aa]);const ia=y({command:w("view"),path:b(),view_range:Mt([E(),E()]).optional()}),oa=y({command:w("str_replace"),path:b(),old_str:b(),new_str:b()}),ua=y({command:w("create"),path:b(),file_text:b()}),ca=y({command:w("insert"),path:b(),insert_line:E(),new_str:b()});Ze("command",[ia,oa,ua,ca]);const $=Mt([E(),E()]),nn=y({action:w("screenshot")}),rn=y({action:w("left_click"),coordinate:$}),an=y({action:w("right_click"),coordinate:$}),on=y({action:w("middle_click"),coordinate:$}),un=y({action:w("double_click"),coordinate:$}),cn=y({action:w("triple_click"),coordinate:$}),ln=y({action:w("left_click_drag"),start_coordinate:$,end_coordinate:$}),dn=y({action:w("left_mouse_down"),coordinate:$}),hn=y({action:w("left_mouse_up"),coordinate:$}),pn=y({action:w("scroll"),coordinate:$,scroll_direction:Cn(["up","down","left","right"]),scroll_amount:E()}),fn=y({action:w("type"),text:b()}),mn=y({action:w("key"),key:b()}),gn=y({action:w("mouse_move"),coordinate:$}),_n=y({action:w("hold_key"),key:b()}),yn=y({action:w("wait"),duration:E().optional()}),la=y({action:w("zoom"),region:Mt([E(),E(),E(),E()])});Ze("action",[nn,rn,an,on,un,cn,ln,dn,hn,pn,fn,mn,gn,_n,yn]);Ze("action",[nn,rn,an,on,un,cn,ln,dn,hn,pn,fn,mn,gn,_n,yn,la]);const da=y({command:b().describe("The bash command to run")}),ha=y({restart:w(!0).describe("Set to true to restart the bash session")});Pn([da,ha]);export{ka as ChatAnthropic,Zr as ChatAnthropicMessages};
|
package/dist/client/index.html
CHANGED
|
@@ -27,9 +27,9 @@
|
|
|
27
27
|
rel="stylesheet"
|
|
28
28
|
/>
|
|
29
29
|
<title>Inspector | mcp-use</title>
|
|
30
|
-
<script type="module" crossorigin src="/inspector/assets/index-
|
|
30
|
+
<script type="module" crossorigin src="/inspector/assets/index-BsLLCsBP.js"></script>
|
|
31
31
|
<link rel="stylesheet" crossorigin href="/inspector/assets/index-cMXsdFDY.css">
|
|
32
|
-
<script>window.__INSPECTOR_VERSION__ = "0.14.0-canary.
|
|
32
|
+
<script>window.__INSPECTOR_VERSION__ = "0.14.0-canary.2";</script>
|
|
33
33
|
</head>
|
|
34
34
|
<body>
|
|
35
35
|
<script>
|
|
@@ -42,7 +42,9 @@ function registerStaticRoutes(app, clientDistPath) {
|
|
|
42
42
|
return c.notFound();
|
|
43
43
|
});
|
|
44
44
|
app.get("/", (c) => {
|
|
45
|
-
|
|
45
|
+
const url = new URL(c.req.url);
|
|
46
|
+
const queryString = url.search;
|
|
47
|
+
return c.redirect(`/inspector${queryString}`);
|
|
46
48
|
});
|
|
47
49
|
app.get("/inspector", (c) => {
|
|
48
50
|
const indexPath = join(distPath, "index.html");
|
|
@@ -12,60 +12,16 @@ import {
|
|
|
12
12
|
handleChatRequest,
|
|
13
13
|
handleChatRequestStream,
|
|
14
14
|
storeWidgetData
|
|
15
|
-
} from "./chunk-
|
|
15
|
+
} from "./chunk-Z5QIR3IS.js";
|
|
16
16
|
|
|
17
17
|
// src/server/shared-routes.ts
|
|
18
|
-
import {
|
|
18
|
+
import { mountMcpProxy } from "mcp-use/server";
|
|
19
19
|
function registerInspectorRoutes(app, config) {
|
|
20
20
|
app.get("/inspector/health", (c) => {
|
|
21
21
|
return c.json({ status: "ok", timestamp: (/* @__PURE__ */ new Date()).toISOString() });
|
|
22
22
|
});
|
|
23
|
-
app
|
|
24
|
-
|
|
25
|
-
try {
|
|
26
|
-
const targetUrl = c.req.header("X-Target-URL");
|
|
27
|
-
if (!targetUrl) {
|
|
28
|
-
return c.json({ error: "X-Target-URL header is required" }, 400);
|
|
29
|
-
}
|
|
30
|
-
const method = c.req.method;
|
|
31
|
-
const headers = {};
|
|
32
|
-
const requestHeaders = c.req.header();
|
|
33
|
-
for (const [key, value] of Object.entries(requestHeaders)) {
|
|
34
|
-
const lowerKey = key.toLowerCase();
|
|
35
|
-
if (!lowerKey.startsWith("x-proxy-") && !lowerKey.startsWith("x-target-") && lowerKey !== "host" && lowerKey !== "accept-encoding") {
|
|
36
|
-
headers[key] = value;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
headers["Accept-Encoding"] = "identity";
|
|
40
|
-
try {
|
|
41
|
-
const targetUrlObj = new URL(targetUrl);
|
|
42
|
-
headers.Host = targetUrlObj.host;
|
|
43
|
-
} catch {
|
|
44
|
-
return c.json({ error: "Invalid target URL" }, 400);
|
|
45
|
-
}
|
|
46
|
-
const body = method !== "GET" && method !== "HEAD" ? await c.req.arrayBuffer() : void 0;
|
|
47
|
-
const response = await fetch(targetUrl, {
|
|
48
|
-
method,
|
|
49
|
-
headers,
|
|
50
|
-
body: body ? new Uint8Array(body) : void 0
|
|
51
|
-
});
|
|
52
|
-
const responseHeaders = {};
|
|
53
|
-
response.headers.forEach((value, key) => {
|
|
54
|
-
const lowerKey = key.toLowerCase();
|
|
55
|
-
if (lowerKey !== "content-encoding" && lowerKey !== "transfer-encoding" && lowerKey !== "content-length") {
|
|
56
|
-
responseHeaders[key] = value;
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
return new Response(response.body, {
|
|
60
|
-
status: response.status,
|
|
61
|
-
statusText: response.statusText,
|
|
62
|
-
headers: responseHeaders
|
|
63
|
-
});
|
|
64
|
-
} catch (error) {
|
|
65
|
-
const message = error instanceof Error ? error.message : "Unknown error";
|
|
66
|
-
console.error("Proxy request failed:", message, error);
|
|
67
|
-
return c.json({ error: "Proxy request failed", details: message }, 500);
|
|
68
|
-
}
|
|
23
|
+
mountMcpProxy(app, {
|
|
24
|
+
path: "/inspector/api/proxy"
|
|
69
25
|
});
|
|
70
26
|
app.post("/inspector/api/chat/stream", async (c) => {
|
|
71
27
|
try {
|
|
@@ -15,7 +15,7 @@ async function* handleChatRequestStream(requestBody) {
|
|
|
15
15
|
"Missing required fields: mcpServerUrl, llmConfig, messages"
|
|
16
16
|
);
|
|
17
17
|
}
|
|
18
|
-
const { MCPAgent, MCPClient } = await import("mcp-use
|
|
18
|
+
const { MCPAgent, MCPClient } = await import("mcp-use");
|
|
19
19
|
let llm;
|
|
20
20
|
if (llmConfig.provider === "openai") {
|
|
21
21
|
const { ChatOpenAI } = await import("@langchain/openai");
|
|
@@ -129,7 +129,7 @@ async function handleChatRequest(requestBody) {
|
|
|
129
129
|
"Missing required fields: mcpServerUrl, llmConfig, messages"
|
|
130
130
|
);
|
|
131
131
|
}
|
|
132
|
-
const { MCPAgent, MCPClient } = await import("mcp-use
|
|
132
|
+
const { MCPAgent, MCPClient } = await import("mcp-use");
|
|
133
133
|
let llm;
|
|
134
134
|
if (llmConfig.provider === "openai") {
|
|
135
135
|
const { ChatOpenAI } = await import("@langchain/openai");
|
package/dist/server/cli.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import {
|
|
3
3
|
registerInspectorRoutes
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-F7YWZTWJ.js";
|
|
5
5
|
import {
|
|
6
6
|
findAvailablePort,
|
|
7
7
|
isValidUrl
|
|
@@ -9,9 +9,9 @@ import {
|
|
|
9
9
|
import "./chunk-CVECQ7BJ.js";
|
|
10
10
|
import {
|
|
11
11
|
registerStaticRoutes
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-BC23UV5D.js";
|
|
13
13
|
import "./chunk-67ROKQZG.js";
|
|
14
|
-
import "./chunk-
|
|
14
|
+
import "./chunk-Z5QIR3IS.js";
|
|
15
15
|
import "./chunk-PKBMQBKP.js";
|
|
16
16
|
|
|
17
17
|
// src/server/cli.ts
|
package/dist/server/index.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import {
|
|
2
2
|
mountInspector
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
3
|
+
} from "./chunk-NOEIHEAG.js";
|
|
4
|
+
import "./chunk-F7YWZTWJ.js";
|
|
5
5
|
import "./chunk-JCLAFMDT.js";
|
|
6
6
|
import "./chunk-CVECQ7BJ.js";
|
|
7
|
-
import "./chunk-
|
|
7
|
+
import "./chunk-BC23UV5D.js";
|
|
8
8
|
import "./chunk-67ROKQZG.js";
|
|
9
9
|
import {
|
|
10
10
|
handleChatRequest,
|
|
11
11
|
handleChatRequestStream
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-Z5QIR3IS.js";
|
|
13
13
|
import "./chunk-PKBMQBKP.js";
|
|
14
14
|
export {
|
|
15
15
|
handleChatRequest,
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
mountInspector
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-
|
|
3
|
+
} from "./chunk-NOEIHEAG.js";
|
|
4
|
+
import "./chunk-F7YWZTWJ.js";
|
|
5
5
|
import "./chunk-JCLAFMDT.js";
|
|
6
6
|
import "./chunk-CVECQ7BJ.js";
|
|
7
|
-
import "./chunk-
|
|
7
|
+
import "./chunk-BC23UV5D.js";
|
|
8
8
|
import "./chunk-67ROKQZG.js";
|
|
9
|
-
import "./chunk-
|
|
9
|
+
import "./chunk-Z5QIR3IS.js";
|
|
10
10
|
import "./chunk-PKBMQBKP.js";
|
|
11
11
|
export {
|
|
12
12
|
mountInspector
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/server/server.ts"],"names":[],"mappings":"AAyCA,iBAAe,WAAW;;;GAwFzB;;;;AAOD,wBAA+B"}
|
package/dist/server/server.js
CHANGED
|
@@ -1,24 +1,40 @@
|
|
|
1
1
|
import {
|
|
2
2
|
registerInspectorRoutes
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-F7YWZTWJ.js";
|
|
4
4
|
import {
|
|
5
5
|
isPortAvailable
|
|
6
6
|
} from "./chunk-JCLAFMDT.js";
|
|
7
7
|
import "./chunk-CVECQ7BJ.js";
|
|
8
8
|
import {
|
|
9
9
|
registerStaticRoutesWithDevProxy
|
|
10
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-BC23UV5D.js";
|
|
11
11
|
import "./chunk-67ROKQZG.js";
|
|
12
|
-
import "./chunk-
|
|
12
|
+
import "./chunk-Z5QIR3IS.js";
|
|
13
13
|
import "./chunk-PKBMQBKP.js";
|
|
14
14
|
|
|
15
15
|
// src/server/server.ts
|
|
16
|
-
import { exec } from "child_process";
|
|
17
|
-
import { promisify } from "util";
|
|
18
16
|
import { serve } from "@hono/node-server";
|
|
19
17
|
import { Hono } from "hono";
|
|
20
18
|
import { cors } from "hono/cors";
|
|
19
|
+
import { exec } from "child_process";
|
|
20
|
+
import { promisify } from "util";
|
|
21
21
|
var execAsync = promisify(exec);
|
|
22
|
+
function parsePortFromArgs() {
|
|
23
|
+
const args = process.argv.slice(2);
|
|
24
|
+
for (let i = 0; i < args.length; i++) {
|
|
25
|
+
if (args[i] === "--port" && i + 1 < args.length) {
|
|
26
|
+
const parsedPort = Number.parseInt(args[i + 1], 10);
|
|
27
|
+
if (Number.isNaN(parsedPort) || parsedPort < 1 || parsedPort > 65535) {
|
|
28
|
+
console.error(
|
|
29
|
+
`Error: Port must be a number between 1 and 65535, got: ${args[i + 1]}`
|
|
30
|
+
);
|
|
31
|
+
process.exit(1);
|
|
32
|
+
}
|
|
33
|
+
return parsedPort;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
22
38
|
var app = new Hono();
|
|
23
39
|
app.use("*", cors());
|
|
24
40
|
registerInspectorRoutes(app);
|
|
@@ -26,9 +42,16 @@ registerStaticRoutesWithDevProxy(app);
|
|
|
26
42
|
async function startServer() {
|
|
27
43
|
try {
|
|
28
44
|
const isDev = process.env.NODE_ENV === "development" || process.env.VITE_DEV === "true";
|
|
29
|
-
|
|
45
|
+
const cliPort = parsePortFromArgs();
|
|
46
|
+
let port = cliPort ?? 3001;
|
|
30
47
|
const available = await isPortAvailable(port);
|
|
31
48
|
if (!available) {
|
|
49
|
+
if (cliPort !== null) {
|
|
50
|
+
console.error(
|
|
51
|
+
`\u274C Port ${port} is not available. Please stop the process using this port and try again.`
|
|
52
|
+
);
|
|
53
|
+
process.exit(1);
|
|
54
|
+
}
|
|
32
55
|
if (isDev) {
|
|
33
56
|
console.error(
|
|
34
57
|
`\u274C\u274C\u274C Port ${port} is not available (probably used by Vite dev server as fallback so you should stop port 3000). Please stop the process using this port and try again.`
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-routes.d.ts","sourceRoot":"","sources":["../../src/server/shared-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAiBjC;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,GAAG,EAAE,IAAI,EACT,MAAM,CAAC,EAAE;IAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,
|
|
1
|
+
{"version":3,"file":"shared-routes.d.ts","sourceRoot":"","sources":["../../src/server/shared-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAiBjC;;GAEG;AACH,wBAAgB,uBAAuB,CACrC,GAAG,EAAE,IAAI,EACT,MAAM,CAAC,EAAE;IAAE,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,QAgiB5C"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import {
|
|
2
2
|
registerInspectorRoutes
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-F7YWZTWJ.js";
|
|
4
4
|
import "./chunk-JCLAFMDT.js";
|
|
5
5
|
import "./chunk-CVECQ7BJ.js";
|
|
6
|
-
import "./chunk-
|
|
6
|
+
import "./chunk-Z5QIR3IS.js";
|
|
7
7
|
import "./chunk-PKBMQBKP.js";
|
|
8
8
|
export {
|
|
9
9
|
registerInspectorRoutes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-static.d.ts","sourceRoot":"","sources":["../../src/server/shared-static.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AASjC;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,IAAI,EAAE,cAAc,CAAC,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"shared-static.d.ts","sourceRoot":"","sources":["../../src/server/shared-static.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AASjC;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,IAAI,EAAE,cAAc,CAAC,EAAE,MAAM,QAwGtE;AAED;;GAEG;AACH,wBAAgB,gCAAgC,CAC9C,GAAG,EAAE,IAAI,EACT,cAAc,CAAC,EAAE,MAAM,QA+DxB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"shared-utils-browser.d.ts","sourceRoot":"","sources":["../../src/server/shared-utils-browser.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,UAAU,SAAS;IACjB,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC5C,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,UAAU,WAAW;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,UAAU,UAAU;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,UAAU,WAAW;IACnB,IAAI,EAAE,QAAQ,GAAG,MAAM,GAAG,WAAW,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,QAAQ;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AA2BD;;GAEG;AACH,wBAAuB,uBAAuB,CAAC,WAAW,EAAE;IAC1D,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,QAAQ,EAAE,WAAW,EAAE,CAAC;CACzB,GAAG,cAAc,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"shared-utils-browser.d.ts","sourceRoot":"","sources":["../../src/server/shared-utils-browser.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,UAAU,SAAS;IACjB,QAAQ,EAAE,QAAQ,GAAG,WAAW,GAAG,QAAQ,CAAC;IAC5C,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,UAAU,WAAW;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,UAAU,UAAU;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,UAAU,WAAW;IACnB,IAAI,EAAE,QAAQ,GAAG,MAAM,GAAG,WAAW,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,QAAQ;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AA2BD;;GAEG;AACH,wBAAuB,uBAAuB,CAAC,WAAW,EAAE;IAC1D,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,QAAQ,EAAE,WAAW,EAAE,CAAC;CACzB,GAAG,cAAc,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CA8JrC;AAED;;GAEG;AACH,wBAAsB,iBAAiB,CAAC,WAAW,EAAE;IACnD,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,UAAU,CAAC,EAAE,UAAU,CAAC;IACxB,QAAQ,EAAE,WAAW,EAAE,CAAC;CACzB,GAAG,OAAO,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,QAAQ,EAAE,CAAA;CAAE,CAAC,CA6ItD;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC/B,UAAU,EAAE,GAAG,CAAC;IAChB,oBAAoB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC3C,YAAY,EAAE,GAAG,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE;QACV,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;QAC3B,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;KAC7B,CAAC;IACF,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,OAAO,GAAG,MAAM,CAAC;CAC1B;AAkBD;;GAEG;AACH,wBAAgB,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,GAAG;IACpE,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CA6DA;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS,CAEpE;AAED;;GAEG;AACH,wBAAgB,2BAA2B,CACzC,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,GACb,MAAM,CAiCR;AAED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,UAAU,EAAE,UAAU,GAAG;IACjE,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CA4WA;AAED;;GAEG;AACH,wBAAgB,wBAAwB,CACtC,SAAS,CAAC,EAAE;IACV,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;CAC7B,EACD,gBAAgB,CAAC,EAAE,MAAM,GACxB,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CA+FxB"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mcp-use/inspector",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "0.14.0-canary.
|
|
4
|
+
"version": "0.14.0-canary.2",
|
|
5
5
|
"description": "MCP Inspector - A tool for inspecting and debugging MCP servers",
|
|
6
6
|
"author": "",
|
|
7
7
|
"license": "MIT",
|
|
@@ -86,7 +86,7 @@
|
|
|
86
86
|
"sonner": "^2.0.7",
|
|
87
87
|
"tailwind-merge": "^3.4.0",
|
|
88
88
|
"vite-express": "^0.21.1",
|
|
89
|
-
"mcp-use": "1.
|
|
89
|
+
"mcp-use": "1.12.0-canary.2"
|
|
90
90
|
},
|
|
91
91
|
"publishConfig": {
|
|
92
92
|
"access": "public"
|