@anthropic-ai/claude-agent-sdk 0.2.89 → 0.2.90
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/bridge.mjs +43 -38
- package/browser-sdk.js +3 -3
- package/cli.js +2102 -2015
- package/manifest.json +18 -18
- package/manifest.zst.json +22 -22
- package/package.json +2 -2
- package/sdk.d.ts +2 -2
- package/sdk.mjs +6 -5
- package/vendor/ripgrep/arm64-darwin/rg +0 -0
- package/vendor/ripgrep/arm64-linux/rg +0 -0
- package/vendor/ripgrep/x64-darwin/rg +0 -0
- package/vendor/ripgrep/x64-linux/rg +0 -0
package/sdk.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
// (c) Anthropic PBC. All rights reserved. Use is subject to the Legal Agreements outlined here: https://code.claude.com/docs/en/legal-and-compliance.
|
|
3
3
|
|
|
4
|
-
// Version: 0.2.
|
|
4
|
+
// Version: 0.2.90
|
|
5
5
|
|
|
6
6
|
// Want to see the unminified source? We're hiring!
|
|
7
7
|
// https://job-boards.greenhouse.io/anthropic/jobs/4816199008
|
|
@@ -53,9 +53,9 @@ you can set the \`dangerouslyAllowBrowser\` option to \`true\`, e.g.,
|
|
|
53
53
|
new Anthropic({ apiKey, dangerouslyAllowBrowser: true });
|
|
54
54
|
`);this.baseURL=Y.baseURL,this.timeout=Y.timeout??vz.DEFAULT_TIMEOUT,this.logger=Y.logger??console;let z="warn";this.logLevel=z,this.logLevel=Gz(Y.logLevel,"ClientOptions.logLevel",this)??Gz(mX("ANTHROPIC_LOG"),"process.env['ANTHROPIC_LOG']",this)??z,this.fetchOptions=Y.fetchOptions,this.maxRetries=Y.maxRetries??2,this.fetch=Y.fetch??EH(),v(this,bJ,SH,"f"),this._options=Y,this.apiKey=typeof X==="string"?X:null,this.authToken=J}withOptions($){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,...$})}defaultQuery(){return this._options.defaultQuery}validateHeaders({values:$,nulls:X}){if($.get("x-api-key")||$.get("authorization"))return;if(this.apiKey&&$.get("x-api-key"))return;if(X.has("x-api-key"))return;if(this.authToken&&$.get("authorization"))return;if(X.has("authorization"))return;throw 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($){return n([await this.apiKeyAuth($),await this.bearerAuth($)])}async apiKeyAuth($){if(this.apiKey==null)return;return n([{"X-Api-Key":this.apiKey}])}async bearerAuth($){if(this.authToken==null)return;return n([{Authorization:`Bearer ${this.authToken}`}])}stringifyQuery($){return Object.entries($).filter(([X,J])=>typeof J<"u").map(([X,J])=>{if(typeof J==="string"||typeof J==="number"||typeof J==="boolean")return`${encodeURIComponent(X)}=${encodeURIComponent(J)}`;if(J===null)return`${encodeURIComponent(X)}=`;throw new T(`Cannot stringify type ${typeof J}; 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 ${I4}`}defaultIdempotencyKey(){return`stainless-node-retry-${Jz()}`}makeStatusError($,X,J,Q){return v$.generate($,X,J,Q)}buildURL($,X,J){let Q=!D(this,Sz,"m",GK).call(this)&&J||this.baseURL,Y=DH($)?new URL($):new URL(Q+(Q.endsWith("/")&&$.startsWith("/")?$.slice(1):$)),z=this.defaultQuery();if(!LH(z))X={...z,...X};if(typeof X==="object"&&X&&!Array.isArray(X))Y.search=this.stringifyQuery(X);return Y.toString()}_calculateNonstreamingTimeout($){if(3600*$/128000>600)throw new T("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 600000}async prepareOptions($){}async prepareRequest($,{url:X,options:J}){}get($,X){return this.methodRequest("get",$,X)}post($,X){return this.methodRequest("post",$,X)}patch($,X){return this.methodRequest("patch",$,X)}put($,X){return this.methodRequest("put",$,X)}delete($,X){return this.methodRequest("delete",$,X)}methodRequest($,X,J){return this.request(Promise.resolve(J).then((Q)=>{return{method:$,path:X,...Q}}))}request($,X=null){return new J1(this,this.makeRequest($,X,void 0))}async makeRequest($,X,J){let Q=await $,Y=Q.maxRetries??this.maxRetries;if(X==null)X=Y;await this.prepareOptions(Q);let{req:z,url:W,timeout:G}=await this.buildRequest(Q,{retryCount:Y-X});await this.prepareRequest(z,{url:W,options:Q});let U="log_"+(Math.random()*16777216|0).toString(16).padStart(6,"0"),H=J===void 0?"":`, retryOf: ${J}`,K=Date.now();if(_$(this).debug(`[${U}] sending request`,e6({retryOfRequestLogID:J,method:Q.method,url:W,options:Q,headers:z.headers})),Q.signal?.aborted)throw new T$;let V=new AbortController,O=await this.fetchWithTimeout(W,z,G,V).catch($X),N=Date.now();if(O instanceof globalThis.Error){let L=`retrying, ${X} attempts remaining`;if(Q.signal?.aborted)throw new T$;let j=s6(O)||/timed? ?out/i.test(String(O)+("cause"in O?String(O.cause):""));if(X)return _$(this).info(`[${U}] connection ${j?"timed out":"failed"} - ${L}`),_$(this).debug(`[${U}] connection ${j?"timed out":"failed"} (${L})`,e6({retryOfRequestLogID:J,url:W,durationMs:N-K,message:O.message})),this.retryRequest(Q,X,J??U);if(_$(this).info(`[${U}] connection ${j?"timed out":"failed"} - error; no more retries left`),_$(this).debug(`[${U}] connection ${j?"timed out":"failed"} (error; no more retries left)`,e6({retryOfRequestLogID:J,url:W,durationMs:N-K,message:O.message})),j)throw new XX;throw new X1({cause:O})}let w=[...O.headers.entries()].filter(([L])=>L==="request-id").map(([L,j])=>", "+L+": "+JSON.stringify(j)).join(""),B=`[${U}${H}${w}] ${z.method} ${W} ${O.ok?"succeeded":"failed"} with status ${O.status} in ${N-K}ms`;if(!O.ok){let L=await this.shouldRetry(O);if(X&&L){let B$=`retrying, ${X} attempts remaining`;return await RH(O.body),_$(this).info(`${B} - ${B$}`),_$(this).debug(`[${U}] response error (${B$})`,e6({retryOfRequestLogID:J,url:O.url,status:O.status,headers:O.headers,durationMs:N-K})),this.retryRequest(Q,X,J??U,O.headers)}let j=L?"error; no more retries left":"error; not retryable";_$(this).info(`${B} - ${j}`);let I=await O.text().catch((B$)=>$X(B$).message),b=e9(I),x=b?void 0:I;throw _$(this).debug(`[${U}] response error (${j})`,e6({retryOfRequestLogID:J,url:O.url,status:O.status,headers:O.headers,message:x,durationMs:Date.now()-K})),this.makeStatusError(O.status,b,x,O.headers)}return _$(this).info(B),_$(this).debug(`[${U}] response start`,e6({retryOfRequestLogID:J,url:O.url,status:O.status,headers:O.headers,durationMs:N-K})),{response:O,options:Q,controller:V,requestLogID:U,retryOfRequestLogID:J,startTime:K}}getAPIList($,X,J){return this.requestAPIList(X,J&&"then"in J?J.then((Q)=>({method:"get",path:$,...Q})):{method:"get",path:$,...J})}requestAPIList($,X){let J=this.makeRequest(X,null,void 0);return new zJ(this,J,$)}async fetchWithTimeout($,X,J,Q){let{signal:Y,method:z,...W}=X||{},G=this._makeAbort(Q);if(Y)Y.addEventListener("abort",G,{once:!0});let U=setTimeout(G,J),H=globalThis.ReadableStream&&W.body instanceof globalThis.ReadableStream||typeof W.body==="object"&&W.body!==null&&Symbol.asyncIterator in W.body,K={signal:Q.signal,...H?{duplex:"half"}:{},method:"GET",...W};if(z)K.method=z.toUpperCase();try{return await this.fetch.call(void 0,$,K)}finally{clearTimeout(U)}}async shouldRetry($){let X=$.headers.get("x-should-retry");if(X==="true")return!0;if(X==="false")return!1;if($.status===408)return!0;if($.status===409)return!0;if($.status===429)return!0;if($.status>=500)return!0;return!1}async retryRequest($,X,J,Q){let Y,z=Q?.get("retry-after-ms");if(z){let G=parseFloat(z);if(!Number.isNaN(G))Y=G}let W=Q?.get("retry-after");if(W&&!Y){let G=parseFloat(W);if(!Number.isNaN(G))Y=G*1000;else Y=Date.parse(W)-Date.now()}if(!(Y&&0<=Y&&Y<60000)){let G=$.maxRetries??this.maxRetries;Y=this.calculateDefaultRetryTimeoutMillis(X,G)}return await MH(Y),this.makeRequest($,X-1,J)}calculateDefaultRetryTimeoutMillis($,X){let Y=X-$,z=Math.min(0.5*Math.pow(2,Y),8),W=1-Math.random()*0.25;return z*W*1000}calculateNonstreamingTimeout($,X){if(3600000*$/128000>600000||X!=null&&$>X)throw new T("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 600000}async buildRequest($,{retryCount:X=0}={}){let J={...$},{method:Q,path:Y,query:z,defaultBaseURL:W}=J,G=this.buildURL(Y,z,W);if("timeout"in J)FH("timeout",J.timeout);J.timeout=J.timeout??this.timeout;let{bodyHeaders:U,body:H}=this.buildBody({options:J}),K=await this.buildHeaders({options:$,method:Q,bodyHeaders:U,retryCount:X});return{req:{method:Q,headers:K,...J.signal&&{signal:J.signal},...globalThis.ReadableStream&&H instanceof globalThis.ReadableStream&&{duplex:"half"},...H&&{body:H},...this.fetchOptions??{},...J.fetchOptions??{}},url:G,timeout:J.timeout}}async buildHeaders({options:$,method:X,bodyHeaders:J,retryCount:Q}){let Y={};if(this.idempotencyHeader&&X!=="get"){if(!$.idempotencyKey)$.idempotencyKey=this.defaultIdempotencyKey();Y[this.idempotencyHeader]=$.idempotencyKey}let z=n([Y,{Accept:"application/json","User-Agent":this.getUserAgent(),"X-Stainless-Retry-Count":String(Q),...$.timeout?{"X-Stainless-Timeout":String(Math.trunc($.timeout/1000))}:{},...ZH(),...this._options.dangerouslyAllowBrowser?{"anthropic-dangerous-direct-browser-access":"true"}:void 0,"anthropic-version":"2023-06-01"},await this.authHeaders($),this._options.defaultHeaders,J,$.headers]);return this.validateHeaders(z),z.values}_makeAbort($){return()=>$.abort()}buildBody({options:{body:$,headers:X}}){if(!$)return{bodyHeaders:void 0,body:void 0};let J=n([X]);if(ArrayBuffer.isView($)||$ instanceof ArrayBuffer||$ instanceof DataView||typeof $==="string"&&J.values.has("content-type")||globalThis.Blob&&$ instanceof globalThis.Blob||$ instanceof FormData||$ instanceof URLSearchParams||globalThis.ReadableStream&&$ instanceof globalThis.ReadableStream)return{bodyHeaders:void 0,body:$};else if(typeof $==="object"&&((Symbol.asyncIterator in $)||(Symbol.iterator in $)&&("next"in $)&&typeof $.next==="function"))return{bodyHeaders:void 0,body:$J($)};else return D(this,bJ,"f").call(this,{body:$,headers:J})}}vz=P$,bJ=new WeakMap,Sz=new WeakSet,GK=function(){return this.baseURL!=="https://api.anthropic.com"};P$.Anthropic=vz;P$.HUMAN_PROMPT=UK;P$.AI_PROMPT=HK;P$.DEFAULT_TIMEOUT=600000;P$.AnthropicError=T;P$.APIError=v$;P$.APIConnectionError=X1;P$.APIConnectionTimeoutError=XX;P$.APIUserAbortError=T$;P$.NotFoundError=zX;P$.ConflictError=WX;P$.RateLimitError=UX;P$.BadRequestError=JX;P$.AuthenticationError=YX;P$.InternalServerError=HX;P$.PermissionDeniedError=QX;P$.UnprocessableEntityError=GX;P$.toFile=WJ;class U1 extends P${constructor(){super(...arguments);this.completions=new a1(this),this.messages=new G1(this),this.models=new e1(this),this.beta=new u6(this)}}U1.Completions=a1;U1.Messages=G1;U1.Models=e1;U1.Beta=u6;function KK($){return $ instanceof Error?$:Error(String($))}function lX($){return $ instanceof Error?$.message:String($)}function H1($){if($&&typeof $==="object"&&"code"in $&&typeof $.code==="string")return $.code;return}function NK($){return H1($)==="ENOENT"}import{randomUUID as kF}from"crypto";import{appendFile as _F,mkdir as xF}from"fs/promises";import{join as VK}from"path";var X0,$0=null;function TF(){if($0)return $0;if(!B6(process.env.DEBUG_CLAUDE_AGENT_SDK))return X0=null,$0=Promise.resolve(),$0;let $=VK(c1(),"debug");return X0=VK($,`sdk-${kF()}.txt`),process.stderr.write(`SDK debug logs: ${X0}
|
|
55
55
|
`),$0=xF($,{recursive:!0}).then(()=>{}).catch(()=>{}),$0}function s$($){if(X0===null)return;let J=`${new Date().toISOString()} ${$}
|
|
56
|
-
`;TF().then(()=>{if(X0)_F(X0,J).catch(()=>{})})}import{realpathSync as OK}from"fs";import{cwd as yF}from"process";import{randomUUID as PJ}from"crypto";function Cz(){let $=new Set;return{subscribe(X){return $.add(X),()=>{$.delete(X)}},emit(...X){for(let J of $)J(...X)},clear(){$.clear()}}}function fF(){let $="";if(typeof process<"u"&&typeof process.cwd==="function"&&typeof OK==="function"){let J=yF();try{$=OK(J).normalize("NFC")}catch{$=J.normalize("NFC")}}return{originalCwd:$,projectRoot:$,totalCostUSD:0,totalAPIDuration:0,totalAPIDurationWithoutRetries:0,totalToolDuration:0,turnHookDurationMs:0,turnToolDurationMs:0,turnClassifierDurationMs:0,turnToolCount:0,turnHookCount:0,turnClassifierCount:0,startTime:Date.now(),lastInteractionTime:Date.now(),totalLinesAdded:0,totalLinesRemoved:0,hasUnknownModelCost:!1,cwd:$,modelUsage:{},mainLoopModelOverride:void 0,initialMainLoopModel:null,modelStrings:null,isInteractive:!1,kairosActive:!1,strictToolResultPairing:!1,sdkAgentProgressSummariesEnabled:!1,userMsgOptIn:!1,clientType:"cli",sessionSource:void 0,questionPreviewFormat:void 0,sessionIngressToken:void 0,oauthTokenFromFd:void 0,apiKeyFromFd:void 0,flagSettingsPath:void 0,flagSettingsInline:null,allowedSettingSources:["userSettings","projectSettings","localSettings","flagSettings","policySettings"],meter:null,sessionCounter:null,locCounter:null,prCounter:null,commitCounter:null,costCounter:null,tokenCounter:null,codeEditToolDecisionCounter:null,activeTimeCounter:null,statsStore:null,sessionId:PJ(),parentSessionId:void 0,loggerProvider:null,eventLogger:null,meterProvider:null,tracerProvider:null,agentColorMap:new Map,agentColorIndex:0,lastAPIRequest:null,lastAPIRequestMessages:null,lastClassifierRequests:null,cachedClaudeMdContent:null,inMemoryErrorLog:[],inlinePlugins:[],chromeFlagOverride:void 0,useCoworkPlugins:!1,sessionBypassPermissionsMode:!1,scheduledTasksEnabled:!1,sessionCronTasks:[],sessionCreatedTeams:new Set,sessionTrustAccepted:!1,sessionPersistenceDisabled:!1,hasExitedPlanMode:!1,needsPlanModeExitAttachment:!1,needsAutoModeExitAttachment:!1,lspRecommendationShownThisSession:!1,initJsonSchema:null,registeredHooks:null,planSlugCache:new Map,teleportedSessionInfo:null,invokedSkills:new Map,slowOperations:[],sdkBetas:void 0,mainThreadAgentType:void 0,isRemoteMode:!1,...{},directConnectServerUrl:void 0,systemPromptSectionCache:new Map,lastEmittedDate:null,additionalDirectoriesForClaudeMd:[],allowedChannels:[],hasDevChannels:!1,sessionProjectDir:null,promptCache1hAllowlist:null,promptCache1hEligible:null,afkModeHeaderLatched:null,fastModeHeaderLatched:null,cacheEditingHeaderLatched:null,thinkingClearLatched:null,promptId:null,lastMainRequestId:void 0,lastApiCompletionTimestamp:null,pendingPostCompaction:!1}}var gF=fF();function wK(){return gF.sessionId}var hF=Cz(),Pu=hF.subscribe;var uF=Cz(),Zu=uF.subscribe;import{appendFile as $M,mkdir as XM,symlink as JM,unlink as YM}from"fs/promises";import{dirname as IK,join as AK}from"path";function BK({writeFn:$,flushIntervalMs:X=1000,maxBufferSize:J=100,maxBufferBytes:Q=1/0,immediateMode:Y=!1}){let z=[],W=0,G=null,U=null;function H(){if(G)clearTimeout(G),G=null}function K(){if(U)$(U.join("")),U=null;if(z.length===0)return;$(z.join("")),z=[],W=0,H()}function V(){if(!G)G=setTimeout(K,X)}function O(){if(U){U.push(...z),z=[],W=0,H();return}let N=z;z=[],W=0,H(),U=N,setImmediate(()=>{let w=U;if(U=null,w)$(w.join(""))})}return{write(N){if(Y){$(N);return}if(z.push(N),W+=N.length,V(),z.length>=J||W>=Q)O()},flush:K,dispose(){K()}}}var qK=new Set;function DK($){return qK.add($),()=>qK.delete($)}var LK=E6(($)=>{if(!$||$.trim()==="")return null;let X=$.split(",").map((z)=>z.trim()).filter(Boolean);if(X.length===0)return null;let J=X.some((z)=>z.startsWith("!")),Q=X.some((z)=>!z.startsWith("!"));if(J&&Q)return null;let Y=X.map((z)=>z.replace(/^!/,"").toLowerCase());return{include:J?[]:Y,exclude:J?Y:[],isExclusive:J}});function mF($){let X=[],J=$.match(/^MCP server ["']([^"']+)["']/);if(J&&J[1])X.push("mcp"),X.push(J[1].toLowerCase());else{let z=$.match(/^([^:[]+):/);if(z&&z[1])X.push(z[1].trim().toLowerCase())}let Q=$.match(/^\[([^\]]+)]/);if(Q&&Q[1])X.push(Q[1].trim().toLowerCase());if($.toLowerCase().includes("1p event:"))X.push("1p");let Y=$.match(/:\s*([^:]+?)(?:\s+(?:type|mode|status|event))?:/);if(Y&&Y[1]){let z=Y[1].trim().toLowerCase();if(z.length<30&&!z.includes(" "))X.push(z)}return Array.from(new Set(X))}function lF($,X){if(!X)return!0;if($.length===0)return!1;if(X.isExclusive)return!$.some((J)=>X.exclude.includes(J));else return $.some((J)=>X.include.includes(J))}function jK($,X){if(!X)return!0;let J=mF($);return lF(J,X)}import*as r from"fs";import{mkdir as cF,open as pF,readdir as iF,readFile as FK,rename as nF,rmdir as dF,rm as rF,stat as oF,unlink as tF}from"fs/promises";var aF={cwd(){return process.cwd()},existsSync($){let J=[];try{const X=N$(J,b$`fs.existsSync(${$})`,0);return r.existsSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},async stat($){return oF($)},async readdir($){return iF($,{withFileTypes:!0})},async unlink($){return tF($)},async rmdir($){return dF($)},async rm($,X){return rF($,X)},async mkdir($,X){try{await cF($,{recursive:!0,...X})}catch(J){if(H1(J)!=="EEXIST")throw J}},async readFile($,X){return FK($,{encoding:X.encoding})},async rename($,X){return nF($,X)},statSync($){let J=[];try{const X=N$(J,b$`fs.statSync(${$})`,0);return r.statSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},lstatSync($){let J=[];try{const X=N$(J,b$`fs.lstatSync(${$})`,0);return r.lstatSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readFileSync($,X){let Q=[];try{const J=N$(Q,b$`fs.readFileSync(${$})`,0);return r.readFileSync($,{encoding:X.encoding})}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},readFileBytesSync($){let J=[];try{const X=N$(J,b$`fs.readFileBytesSync(${$})`,0);return r.readFileSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readSync($,X){let Y=[];try{const J=N$(Y,b$`fs.readSync(${$}, ${X.length} bytes)`,0);let Q=void 0;try{Q=r.openSync($,"r");let U=Buffer.alloc(X.length),H=r.readSync(Q,U,0,X.length,0);return{buffer:U,bytesRead:H}}finally{if(Q)r.closeSync(Q)}}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},appendFileSync($,X,J){let Y=[];try{const Q=N$(Y,b$`fs.appendFileSync(${$}, ${X.length} chars)`,0);if(J?.mode!==void 0)try{let U=r.openSync($,"ax",J.mode);try{r.appendFileSync(U,X)}finally{r.closeSync(U)}return}catch(U){if(H1(U)!=="EEXIST")throw U}r.appendFileSync($,X)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},copyFileSync($,X){let Q=[];try{const J=N$(Q,b$`fs.copyFileSync(${$} → ${X})`,0);r.copyFileSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},unlinkSync($){let J=[];try{const X=N$(J,b$`fs.unlinkSync(${$})`,0);r.unlinkSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},renameSync($,X){let Q=[];try{const J=N$(Q,b$`fs.renameSync(${$} → ${X})`,0);r.renameSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},linkSync($,X){let Q=[];try{const J=N$(Q,b$`fs.linkSync(${$} → ${X})`,0);r.linkSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},symlinkSync($,X,J){let Y=[];try{const Q=N$(Y,b$`fs.symlinkSync(${$} → ${X})`,0);r.symlinkSync($,X,J)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},readlinkSync($){let J=[];try{const X=N$(J,b$`fs.readlinkSync(${$})`,0);return r.readlinkSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},realpathSync($){let J=[];try{const X=N$(J,b$`fs.realpathSync(${$})`,0);return r.realpathSync($).normalize("NFC")}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},mkdirSync($,X){let Y=[];try{const J=N$(Y,b$`fs.mkdirSync(${$})`,0);let Q={recursive:!0};if(X?.mode!==void 0)Q.mode=X.mode;try{r.mkdirSync($,Q)}catch(U){if(H1(U)!=="EEXIST")throw U}}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},readdirSync($){let J=[];try{const X=N$(J,b$`fs.readdirSync(${$})`,0);return r.readdirSync($,{withFileTypes:!0})}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readdirStringSync($){let J=[];try{const X=N$(J,b$`fs.readdirStringSync(${$})`,0);return r.readdirSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},isDirEmptySync($){let Q=[];try{const X=N$(Q,b$`fs.isDirEmptySync(${$})`,0);let J=this.readdirSync($);return J.length===0}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},rmdirSync($){let J=[];try{const X=N$(J,b$`fs.rmdirSync(${$})`,0);r.rmdirSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},rmSync($,X){let Q=[];try{const J=N$(Q,b$`fs.rmSync(${$})`,0);r.rmSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},createWriteStream($){return r.createWriteStream($)},async readFileBytes($,X){if(X===void 0)return FK($);let J=await pF($,"r");try{let{size:Q}=await J.stat(),Y=Math.min(Q,X),z=Buffer.allocUnsafe(Y),W=0;while(W<Y){let{bytesRead:G}=await J.read(z,W,Y-W,W);if(G===0)break;W+=G}return W<Y?z.subarray(0,W):z}finally{await J.close()}}},sF=aF;function kz(){return sF}function eF($,X){if($.destroyed)return;$.write(X)}function MK($){eF(process.stderr,$)}var xz={verbose:0,debug:1,info:2,warn:3,error:4},QM=E6(()=>{let $=process.env.CLAUDE_CODE_DEBUG_LOG_LEVEL?.toLowerCase().trim();if($&&Object.hasOwn(xz,$))return $;return"debug"}),zM=!1,Tz=E6(()=>{return zM||B6(process.env.DEBUG)||B6(process.env.DEBUG_SDK)||process.argv.includes("--debug")||process.argv.includes("-d")||bK()||process.argv.some(($)=>$.startsWith("--debug="))||PK()!==null});var WM=E6(()=>{let $=process.argv.find((J)=>J.startsWith("--debug="));if(!$)return null;let X=$.substring(8);return LK(X)}),bK=E6(()=>{return process.argv.includes("--debug-to-stderr")||process.argv.includes("-d2e")}),PK=E6(()=>{for(let $=0;$<process.argv.length;$++){let X=process.argv[$];if(X.startsWith("--debug-file="))return X.substring(13);if(X==="--debug-file"&&$+1<process.argv.length)return process.argv[$+1]}return null});function GM($){if(!Tz())return!1;if(typeof process>"u"||typeof process.versions>"u"||typeof process.versions.node>"u")return!1;let X=WM();return jK($,X)}var UM=!1;var ZJ=null,_z=Promise.resolve();async function HM($,X,J,Q){if($)await XM(X,{recursive:!0}).catch(()=>{});await $M(J,Q),EK()}function KM(){}function NM(){if(!ZJ){let $=null;ZJ=BK({writeFn:(X)=>{let J=ZK(),Q=IK(J),Y=$!==Q;if($=Q,Tz()){if(Y)try{kz().mkdirSync(Q)}catch{}kz().appendFileSync(J,X),EK();return}_z=_z.then(HM.bind(null,Y,Q,J,X)).catch(KM)},flushIntervalMs:1000,maxBufferSize:100,immediateMode:Tz()}),DK(async()=>{ZJ?.dispose(),await _z})}return ZJ}function m6($,{level:X}={level:"debug"}){if(xz[X]<xz[QM()])return;if(!GM($))return;if(UM&&$.includes(`
|
|
56
|
+
`;TF().then(()=>{if(X0)_F(X0,J).catch(()=>{})})}import{realpathSync as OK}from"fs";import{cwd as yF}from"process";import{randomUUID as PJ}from"crypto";function Cz(){let $=new Set;return{subscribe(X){return $.add(X),()=>{$.delete(X)}},emit(...X){for(let J of $)J(...X)},clear(){$.clear()}}}function fF(){let $="";if(typeof process<"u"&&typeof process.cwd==="function"&&typeof OK==="function"){let J=yF();try{$=OK(J).normalize("NFC")}catch{$=J.normalize("NFC")}}return{originalCwd:$,projectRoot:$,totalCostUSD:0,totalAPIDuration:0,totalAPIDurationWithoutRetries:0,totalToolDuration:0,turnHookDurationMs:0,turnToolDurationMs:0,turnClassifierDurationMs:0,turnToolCount:0,turnHookCount:0,turnClassifierCount:0,startTime:Date.now(),lastInteractionTime:Date.now(),totalLinesAdded:0,totalLinesRemoved:0,hasUnknownModelCost:!1,cwd:$,modelUsage:{},mainLoopModelOverride:void 0,initialMainLoopModel:null,modelStrings:null,isInteractive:!1,kairosActive:!1,strictToolResultPairing:!1,memoryToggledOff:!1,sdkAgentProgressSummariesEnabled:!1,userMsgOptIn:!1,clientType:"cli",sessionSource:void 0,questionPreviewFormat:void 0,sessionIngressToken:void 0,oauthTokenFromFd:void 0,apiKeyFromFd:void 0,flagSettingsPath:void 0,flagSettingsInline:null,allowedSettingSources:["userSettings","projectSettings","localSettings","flagSettings","policySettings"],meter:null,sessionCounter:null,locCounter:null,prCounter:null,commitCounter:null,costCounter:null,tokenCounter:null,codeEditToolDecisionCounter:null,activeTimeCounter:null,statsStore:null,sessionId:PJ(),parentSessionId:void 0,loggerProvider:null,eventLogger:null,meterProvider:null,tracerProvider:null,agentColorMap:new Map,agentColorIndex:0,lastAPIRequest:null,lastAPIRequestMessages:null,lastClassifierRequests:null,cachedClaudeMdContent:null,inMemoryErrorLog:[],inlinePlugins:[],chromeFlagOverride:void 0,useCoworkPlugins:!1,sessionBypassPermissionsMode:!1,scheduledTasksEnabled:!1,sessionCronTasks:[],sessionCreatedTeams:new Set,sessionTrustAccepted:!1,sessionPersistenceDisabled:!1,hasExitedPlanMode:!1,needsPlanModeExitAttachment:!1,needsAutoModeExitAttachment:!1,lspRecommendationShownThisSession:!1,initJsonSchema:null,registeredHooks:null,planSlugCache:new Map,teleportedSessionInfo:null,invokedSkills:new Map,slowOperations:[],sdkBetas:void 0,mainThreadAgentType:void 0,isRemoteMode:!1,...!1,directConnectServerUrl:void 0,systemPromptSectionCache:new Map,lastEmittedDate:null,additionalDirectoriesForClaudeMd:[],allowedChannels:[],hasDevChannels:!1,sessionProjectDir:null,promptCache1hAllowlist:null,afkModeHeaderLatched:null,fastModeHeaderLatched:null,cacheEditingHeaderLatched:null,thinkingClearLatched:null,promptId:null,lastMainRequestId:void 0,lastApiCompletionTimestamp:null,pendingPostCompaction:!1}}var gF=fF();function wK(){return gF.sessionId}var hF=Cz(),Pu=hF.subscribe;var uF=Cz(),Zu=uF.subscribe;import{appendFile as $M,mkdir as XM,symlink as JM,unlink as YM}from"fs/promises";import{dirname as IK,join as AK}from"path";function BK({writeFn:$,flushIntervalMs:X=1000,maxBufferSize:J=100,maxBufferBytes:Q=1/0,immediateMode:Y=!1}){let z=[],W=0,G=null,U=null;function H(){if(G)clearTimeout(G),G=null}function K(){if(U)$(U.join("")),U=null;if(z.length===0)return;$(z.join("")),z=[],W=0,H()}function V(){if(!G)G=setTimeout(K,X)}function O(){if(U){U.push(...z),z=[],W=0,H();return}let N=z;z=[],W=0,H(),U=N,setImmediate(()=>{let w=U;if(U=null,w)$(w.join(""))})}return{write(N){if(Y){$(N);return}if(z.push(N),W+=N.length,V(),z.length>=J||W>=Q)O()},flush:K,dispose(){K()}}}var qK=new Set;function DK($){return qK.add($),()=>qK.delete($)}var LK=E6(($)=>{if(!$||$.trim()==="")return null;let X=$.split(",").map((z)=>z.trim()).filter(Boolean);if(X.length===0)return null;let J=X.some((z)=>z.startsWith("!")),Q=X.some((z)=>!z.startsWith("!"));if(J&&Q)return null;let Y=X.map((z)=>z.replace(/^!/,"").toLowerCase());return{include:J?[]:Y,exclude:J?Y:[],isExclusive:J}});function mF($){let X=[],J=$.match(/^MCP server ["']([^"']+)["']/);if(J&&J[1])X.push("mcp"),X.push(J[1].toLowerCase());else{let z=$.match(/^([^:[]+):/);if(z&&z[1])X.push(z[1].trim().toLowerCase())}let Q=$.match(/^\[([^\]]+)]/);if(Q&&Q[1])X.push(Q[1].trim().toLowerCase());if($.toLowerCase().includes("1p event:"))X.push("1p");let Y=$.match(/:\s*([^:]+?)(?:\s+(?:type|mode|status|event))?:/);if(Y&&Y[1]){let z=Y[1].trim().toLowerCase();if(z.length<30&&!z.includes(" "))X.push(z)}return Array.from(new Set(X))}function lF($,X){if(!X)return!0;if($.length===0)return!1;if(X.isExclusive)return!$.some((J)=>X.exclude.includes(J));else return $.some((J)=>X.include.includes(J))}function jK($,X){if(!X)return!0;let J=mF($);return lF(J,X)}import*as r from"fs";import{mkdir as cF,open as pF,readdir as iF,readFile as FK,rename as nF,rmdir as dF,rm as rF,stat as oF,unlink as tF}from"fs/promises";var aF={cwd(){return process.cwd()},existsSync($){let J=[];try{const X=N$(J,b$`fs.existsSync(${$})`,0);return r.existsSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},async stat($){return oF($)},async readdir($){return iF($,{withFileTypes:!0})},async unlink($){return tF($)},async rmdir($){return dF($)},async rm($,X){return rF($,X)},async mkdir($,X){try{await cF($,{recursive:!0,...X})}catch(J){if(H1(J)!=="EEXIST")throw J}},async readFile($,X){return FK($,{encoding:X.encoding})},async rename($,X){return nF($,X)},statSync($){let J=[];try{const X=N$(J,b$`fs.statSync(${$})`,0);return r.statSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},lstatSync($){let J=[];try{const X=N$(J,b$`fs.lstatSync(${$})`,0);return r.lstatSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readFileSync($,X){let Q=[];try{const J=N$(Q,b$`fs.readFileSync(${$})`,0);return r.readFileSync($,{encoding:X.encoding})}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},readFileBytesSync($){let J=[];try{const X=N$(J,b$`fs.readFileBytesSync(${$})`,0);return r.readFileSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readSync($,X){let Y=[];try{const J=N$(Y,b$`fs.readSync(${$}, ${X.length} bytes)`,0);let Q=void 0;try{Q=r.openSync($,"r");let U=Buffer.alloc(X.length),H=r.readSync(Q,U,0,X.length,0);return{buffer:U,bytesRead:H}}finally{if(Q)r.closeSync(Q)}}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},appendFileSync($,X,J){let Y=[];try{const Q=N$(Y,b$`fs.appendFileSync(${$}, ${X.length} chars)`,0);if(J?.mode!==void 0)try{let U=r.openSync($,"ax",J.mode);try{r.appendFileSync(U,X)}finally{r.closeSync(U)}return}catch(U){if(H1(U)!=="EEXIST")throw U}r.appendFileSync($,X)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},copyFileSync($,X){let Q=[];try{const J=N$(Q,b$`fs.copyFileSync(${$} → ${X})`,0);r.copyFileSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},unlinkSync($){let J=[];try{const X=N$(J,b$`fs.unlinkSync(${$})`,0);r.unlinkSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},renameSync($,X){let Q=[];try{const J=N$(Q,b$`fs.renameSync(${$} → ${X})`,0);r.renameSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},linkSync($,X){let Q=[];try{const J=N$(Q,b$`fs.linkSync(${$} → ${X})`,0);r.linkSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},symlinkSync($,X,J){let Y=[];try{const Q=N$(Y,b$`fs.symlinkSync(${$} → ${X})`,0);r.symlinkSync($,X,J)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},readlinkSync($){let J=[];try{const X=N$(J,b$`fs.readlinkSync(${$})`,0);return r.readlinkSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},realpathSync($){let J=[];try{const X=N$(J,b$`fs.realpathSync(${$})`,0);return r.realpathSync($).normalize("NFC")}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},mkdirSync($,X){let Y=[];try{const J=N$(Y,b$`fs.mkdirSync(${$})`,0);let Q={recursive:!0};if(X?.mode!==void 0)Q.mode=X.mode;try{r.mkdirSync($,Q)}catch(U){if(H1(U)!=="EEXIST")throw U}}catch(z){var W=z,G=1}finally{V$(Y,W,G)}},readdirSync($){let J=[];try{const X=N$(J,b$`fs.readdirSync(${$})`,0);return r.readdirSync($,{withFileTypes:!0})}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},readdirStringSync($){let J=[];try{const X=N$(J,b$`fs.readdirStringSync(${$})`,0);return r.readdirSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},isDirEmptySync($){let Q=[];try{const X=N$(Q,b$`fs.isDirEmptySync(${$})`,0);let J=this.readdirSync($);return J.length===0}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},rmdirSync($){let J=[];try{const X=N$(J,b$`fs.rmdirSync(${$})`,0);r.rmdirSync($)}catch(Q){var Y=Q,z=1}finally{V$(J,Y,z)}},rmSync($,X){let Q=[];try{const J=N$(Q,b$`fs.rmSync(${$})`,0);r.rmSync($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}},createWriteStream($){return r.createWriteStream($)},async readFileBytes($,X){if(X===void 0)return FK($);let J=await pF($,"r");try{let{size:Q}=await J.stat(),Y=Math.min(Q,X),z=Buffer.allocUnsafe(Y),W=0;while(W<Y){let{bytesRead:G}=await J.read(z,W,Y-W,W);if(G===0)break;W+=G}return W<Y?z.subarray(0,W):z}finally{await J.close()}}},sF=aF;function kz(){return sF}function eF($,X){if($.destroyed)return;$.write(X)}function MK($){eF(process.stderr,$)}var xz={verbose:0,debug:1,info:2,warn:3,error:4},QM=E6(()=>{let $=process.env.CLAUDE_CODE_DEBUG_LOG_LEVEL?.toLowerCase().trim();if($&&Object.hasOwn(xz,$))return $;return"debug"}),zM=!1,Tz=E6(()=>{return zM||B6(process.env.DEBUG)||B6(process.env.DEBUG_SDK)||process.argv.includes("--debug")||process.argv.includes("-d")||bK()||process.argv.some(($)=>$.startsWith("--debug="))||PK()!==null});var WM=E6(()=>{let $=process.argv.find((J)=>J.startsWith("--debug="));if(!$)return null;let X=$.substring(8);return LK(X)}),bK=E6(()=>{return process.argv.includes("--debug-to-stderr")||process.argv.includes("-d2e")}),PK=E6(()=>{for(let $=0;$<process.argv.length;$++){let X=process.argv[$];if(X.startsWith("--debug-file="))return X.substring(13);if(X==="--debug-file"&&$+1<process.argv.length)return process.argv[$+1]}return null});function GM($){if(!Tz())return!1;if(typeof process>"u"||typeof process.versions>"u"||typeof process.versions.node>"u")return!1;let X=WM();return jK($,X)}var UM=!1;var ZJ=null,_z=Promise.resolve();async function HM($,X,J,Q){if($)await XM(X,{recursive:!0}).catch(()=>{});await $M(J,Q),EK()}function KM(){}function NM(){if(!ZJ){let $=null;ZJ=BK({writeFn:(X)=>{let J=ZK(),Q=IK(J),Y=$!==Q;if($=Q,Tz()){if(Y)try{kz().mkdirSync(Q)}catch{}kz().appendFileSync(J,X),EK();return}_z=_z.then(HM.bind(null,Y,Q,J,X)).catch(KM)},flushIntervalMs:1000,maxBufferSize:100,immediateMode:Tz()}),DK(async()=>{ZJ?.dispose(),await _z})}return ZJ}function m6($,{level:X}={level:"debug"}){if(xz[X]<xz[QM()])return;if(!GM($))return;if(UM&&$.includes(`
|
|
57
57
|
`))$=q$($);let Q=`${new Date().toISOString()} [${X.toUpperCase()}] ${$.trim()}
|
|
58
|
-
`;if(bK()){MK(Q);return}NM().write(Q)}function ZK(){return PK()??process.env.CLAUDE_CODE_DEBUG_LOGS_DIR??AK(c1(),"debug",`${wK()}.txt`)}var EK=E6(async()=>{try{let $=ZK(),X=IK($),J=AK(X,"latest");await YM(J).catch(()=>{}),await JM($,J)}catch{}});var $m=(()=>{let $=process.env.CLAUDE_CODE_SLOW_OPERATION_THRESHOLD_MS;if($!==void 0){let X=Number($);if(!Number.isNaN(X)&&X>=0)return X}return 1/0})();var VM={[Symbol.dispose](){}};function OM(){return VM}var b$=OM;function q$($,X,J){let Y=[];try{const Q=N$(Y,b$`JSON.stringify(${$})`,0);return JSON.stringify($,X,J)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}}var L6=($,X)=>{let Q=[];try{const J=N$(Q,b$`JSON.parse(${$})`,0);return typeof X>"u"?JSON.parse($):JSON.parse($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}};function wM($){let X=$.trim();return X.startsWith("{")&&X.endsWith("}")}function RK($,X){let J={...$};if(X){let Q=J.settings;if(Q&&!wM(Q))throw Error("Cannot use both a settings file path and the sandbox option. Include the sandbox configuration in your settings file instead.");let Y={sandbox:X};if(Q)try{Y={...L6(Q),sandbox:X}}catch{}J.settings=q$(Y)}return J}var DM=2000;class cX{options;process;processStdin;processStdout;ready=!1;abortController;exitError;exitListeners=[];processExitHandler;abortHandler;constructor($){this.options=$;this.abortController=$.abortController||y1(),this.initialize()}getDefaultExecutable(){return f1()?"bun":"node"}spawnLocalProcess($){let{command:X,args:J,cwd:Q,env:Y,signal:z}=$,W=B6(Y.DEBUG_CLAUDE_AGENT_SDK)||this.options.stderr?"pipe":"ignore",G=BM(X,J,{cwd:Q,stdio:["pipe","pipe",W],signal:z,env:Y,windowsHide:!0});if(B6(Y.DEBUG_CLAUDE_AGENT_SDK)||this.options.stderr)G.stderr.on("data",(H)=>{let K=H.toString();if(s$(K),this.options.stderr)this.options.stderr(K)});return{stdin:G.stdin,stdout:G.stdout,get killed(){return G.killed},get exitCode(){return G.exitCode},kill:G.kill.bind(G),on:G.on.bind(G),once:G.once.bind(G),off:G.off.bind(G)}}initialize(){try{let{additionalDirectories:$=[],agent:X,betas:J,cwd:Q,executable:Y=this.getDefaultExecutable(),executableArgs:z=[],extraArgs:W={},pathToClaudeCodeExecutable:G,env:U={...process.env},thinkingConfig:H,maxTurns:K,maxBudgetUsd:V,taskBudget:O,model:N,fallbackModel:w,jsonSchema:B,permissionMode:L,allowDangerouslySkipPermissions:j,permissionPromptToolName:I,continueConversation:b,resume:x,settingSources:h,allowedTools:B$=[],disallowedTools:x$=[],tools:G6,mcpServers:o6,strictMcpConfig:h6,canUseTool:a4,includePartialMessages:_1,plugins:t6,sandbox:r0}=this.options,p=["--output-format","stream-json","--verbose","--input-format","stream-json"];if(H)switch(H.type){case"enabled":if(H.budgetTokens===void 0)p.push("--thinking","adaptive");else p.push("--max-thinking-tokens",H.budgetTokens.toString());break;case"disabled":p.push("--thinking","disabled");break;case"adaptive":p.push("--thinking","adaptive");break}if(this.options.effort)p.push("--effort",this.options.effort);if(K)p.push("--max-turns",K.toString());if(V!==void 0)p.push("--max-budget-usd",V.toString());if(O)p.push("--task-budget",O.total.toString());if(N)p.push("--model",N);if(X)p.push("--agent",X);if(J&&J.length>0)p.push("--betas",J.join(","));if(B)p.push("--json-schema",q$(B));if(this.options.debugFile)p.push("--debug-file",this.options.debugFile);else if(this.options.debug)p.push("--debug");if(B6(U.DEBUG_CLAUDE_AGENT_SDK))p.push("--debug-to-stderr");if(a4){if(I)throw Error("canUseTool callback cannot be used with permissionPromptToolName. Please use one or the other.");p.push("--permission-prompt-tool","stdio")}else if(I)p.push("--permission-prompt-tool",I);if(b)p.push("--continue");if(x)p.push("--resume",x);if(this.options.proactive)p.push("--proactive");if(this.options.assistant)p.push("--assistant");if(this.options.channels&&this.options.channels.length>0)p.push("--channels",...this.options.channels);if(B$.length>0)p.push("--allowedTools",B$.join(","));if(x$.length>0)p.push("--disallowedTools",x$.join(","));if(G6!==void 0)if(Array.isArray(G6))if(G6.length===0)p.push("--tools","");else p.push("--tools",G6.join(","));else p.push("--tools","default");if(o6&&Object.keys(o6).length>0)p.push("--mcp-config",q$({mcpServers:o6}));if(h!==void 0)p.push(`--setting-sources=${h.join(",")}`);if(h6)p.push("--strict-mcp-config");if(L)p.push("--permission-mode",L);if(j)p.push("--allow-dangerously-skip-permissions");if(w){if(N&&w===N)throw Error("Fallback model cannot be the same as the main model. Please specify a different model for fallbackModel option.");p.push("--fallback-model",w)}if(this.options.includeHookEvents)p.push("--include-hook-events");if(_1)p.push("--include-partial-messages");for(let p$ of $)p.push("--add-dir",p$);if(t6&&t6.length>0)for(let p$ of t6)if(p$.type==="local")p.push("--plugin-dir",p$.path);else throw Error(`Unsupported plugin type: ${p$.type}`);if(this.options.forkSession)p.push("--fork-session");if(this.options.resumeSessionAt)p.push("--resume-session-at",this.options.resumeSessionAt);if(this.options.sessionId)p.push("--session-id",this.options.sessionId);if(this.options.persistSession===!1)p.push("--no-session-persistence");let n9={...W??{}};if(this.options.settings)n9.settings=this.options.settings;let aQ=RK(n9,r0);for(let[p$,j4]of Object.entries(aQ))if(j4===null)p.push(`--${p$}`);else p.push(`--${p$}`,j4);if(!U.CLAUDE_CODE_ENTRYPOINT)U.CLAUDE_CODE_ENTRYPOINT="sdk-ts";if(delete U.NODE_OPTIONS,B6(U.DEBUG_CLAUDE_AGENT_SDK))U.DEBUG="1";else delete U.DEBUG;let o0=LM(G),t0=o0?G:Y,s4=o0?[...z,...p]:[...z,G,...p],d9={command:t0,args:s4,cwd:Q,env:U,signal:this.abortController.signal};if(this.options.spawnClaudeCodeProcess)s$(`Spawning Claude Code (custom): ${t0} ${s4.join(" ")}`),this.process=this.options.spawnClaudeCodeProcess(d9);else s$(`Spawning Claude Code: ${t0} ${s4.join(" ")}`),this.process=this.spawnLocalProcess(d9);this.processStdin=this.process.stdin,this.processStdout=this.process.stdout;let x1=()=>{if(this.process&&!this.process.killed)this.process.kill("SIGTERM")};this.processExitHandler=x1,this.abortHandler=x1,process.on("exit",this.processExitHandler),this.abortController.signal.addEventListener("abort",this.abortHandler),this.process.on("error",(p$)=>{if(this.ready=!1,this.abortController.signal.aborted)this.exitError=new a$("Claude Code process aborted by user");else if(NK(p$)){let j4=o0?`Claude Code native binary not found at ${G}. Please ensure Claude Code is installed via native installer or specify a valid path with options.pathToClaudeCodeExecutable.`:`Claude Code executable not found at ${G}. Is options.pathToClaudeCodeExecutable set?`;this.exitError=ReferenceError(j4),s$(this.exitError.message)}else this.exitError=Error(`Failed to spawn Claude Code process: ${p$.message}`),s$(this.exitError.message)}),this.process.on("exit",(p$,j4)=>{if(this.ready=!1,this.abortController.signal.aborted)this.exitError=new a$("Claude Code process aborted by user");else{let a0=this.getProcessExitError(p$,j4);if(a0)this.exitError=a0,s$(a0.message)}}),this.ready=!0}catch($){throw this.ready=!1,$}}getProcessExitError($,X){if($!==0&&$!==null)return Error(`Claude Code process exited with code ${$}`);else if(X)return Error(`Claude Code process terminated by signal ${X}`);return}write($){if(this.abortController.signal.aborted)throw new a$("Operation aborted");if(!this.ready||!this.processStdin)throw Error("ProcessTransport is not ready for writing");if(this.processStdin.writableEnded){s$("[ProcessTransport] Dropping write to ended stdin stream");return}if(this.process?.killed||this.process?.exitCode!==null)throw Error("Cannot write to terminated process");if(this.exitError)throw Error(`Cannot write to process that exited with error: ${this.exitError.message}`);s$(`[ProcessTransport] Writing to stdin: ${$.substring(0,100)}`);try{if(!this.processStdin.write($))s$("[ProcessTransport] Write buffer full, data queued")}catch(X){throw this.ready=!1,Error(`Failed to write to process stdin: ${lX(X)}`)}}close(){if(this.processStdin)this.processStdin.end(),this.processStdin=void 0;if(this.abortHandler)this.abortController.signal.removeEventListener("abort",this.abortHandler),this.abortHandler=void 0;for(let{handler:X}of this.exitListeners)this.process?.off("exit",X);this.exitListeners=[];let $=this.process;if($&&!$.killed&&$.exitCode===null)setTimeout((X)=>{if(X.killed||X.exitCode!==null)return;X.kill("SIGTERM"),setTimeout((J)=>{if(J.exitCode===null)J.kill("SIGKILL")},5000,X).unref()},DM,$).unref(),$.once("exit",()=>{if(this.processExitHandler)process.off("exit",this.processExitHandler),this.processExitHandler=void 0});else if(this.processExitHandler)process.off("exit",this.processExitHandler),this.processExitHandler=void 0;this.ready=!1}isReady(){return this.ready}async*readMessages(){if(!this.processStdout)throw Error("ProcessTransport output stream not available");let $=qM({input:this.processStdout});try{for await(let X of $)if(X.trim()){let J;try{J=L6(X)}catch(Q){s$(`Non-JSON stdout: ${X}`);continue}yield J}await this.waitForExit()}catch(X){throw X}finally{$.close()}}endInput(){if(this.processStdin)this.processStdin.end()}getInputStream(){return this.processStdin}onExit($){if(!this.process)return()=>{};let X=(J,Q)=>{let Y=this.getProcessExitError(J,Q);$(Y)};return this.process.on("exit",X),this.exitListeners.push({callback:$,handler:X}),()=>{if(this.process)this.process.off("exit",X);let J=this.exitListeners.findIndex((Q)=>Q.handler===X);if(J!==-1)this.exitListeners.splice(J,1)}}async waitForExit(){if(!this.process){if(this.exitError)throw this.exitError;return}if(this.process.exitCode!==null||this.process.killed){if(this.exitError)throw this.exitError;return}return new Promise(($,X)=>{let J=(Y,z)=>{if(this.abortController.signal.aborted){X(new a$("Operation aborted"));return}let W=this.getProcessExitError(Y,z);if(W)X(W);else $()};this.process.once("exit",J);let Q=(Y)=>{this.process.off("exit",J),X(Y)};this.process.once("error",Q),this.process.once("exit",()=>{this.process.off("error",Q)})})}}function LM($){return![".js",".mjs",".tsx",".ts",".jsx"].some((J)=>$.endsWith(J))}class K1{returned;queue=[];readResolve;readReject;isDone=!1;hasError;started=!1;constructor($){this.returned=$}[Symbol.asyncIterator](){if(this.started)throw Error("Stream can only be iterated once");return this.started=!0,this}next(){if(this.queue.length>0)return Promise.resolve({done:!1,value:this.queue.shift()});if(this.isDone)return Promise.resolve({done:!0,value:void 0});if(this.hasError)return Promise.reject(this.hasError);return new Promise(($,X)=>{this.readResolve=$,this.readReject=X})}enqueue($){if(this.readResolve){let X=this.readResolve;this.readResolve=void 0,this.readReject=void 0,X({done:!1,value:$})}else this.queue.push($)}done(){if(this.isDone=!0,this.readResolve){let $=this.readResolve;this.readResolve=void 0,this.readReject=void 0,$({done:!0,value:void 0})}}error($){if(this.hasError=$,this.readReject){let X=this.readReject;this.readResolve=void 0,this.readReject=void 0,X($)}}return(){if(this.isDone=!0,this.returned)this.returned();return Promise.resolve({done:!0,value:void 0})}}class yz{sendMcpMessage;isClosed=!1;constructor($){this.sendMcpMessage=$}onclose;onerror;onmessage;async start(){}async send($){if(this.isClosed)throw Error("Transport is closed");this.sendMcpMessage($)}async close(){if(this.isClosed)return;this.isClosed=!0,this.onclose?.()}}class pX{transport;isSingleUserTurn;canUseTool;hooks;abortController;jsonSchema;initConfig;onElicitation;pendingControlResponses=new Map;cleanupPerformed=!1;sdkMessages;inputStream=new K1;initialization;cancelControllers=new Map;hookCallbacks=new Map;nextCallbackId=0;sdkMcpTransports=new Map;sdkMcpServerInstances=new Map;pendingMcpResponses=new Map;firstResultReceivedResolve;firstResultReceived=!1;lastErrorResultText;setIsSingleUserTurn($){this.isSingleUserTurn=$}hasBidirectionalNeeds(){return this.sdkMcpTransports.size>0||this.hooks!==void 0&&Object.keys(this.hooks).length>0||this.canUseTool!==void 0||this.onElicitation!==void 0}constructor($,X,J,Q,Y,z=new Map,W,G,U){this.transport=$;this.isSingleUserTurn=X;this.canUseTool=J;this.hooks=Q;this.abortController=Y;this.jsonSchema=W;this.initConfig=G;this.onElicitation=U;for(let[H,K]of z)this.connectSdkMcpServer(H,K);this.sdkMessages=this.readSdkMessages(),this.readMessages(),this.initialization=this.initialize(),this.initialization.catch(()=>{})}setError($){this.inputStream.error($)}async stopTask($){await this.request({subtype:"stop_task",task_id:$})}close(){this.cleanup()}cleanup($){if(this.cleanupPerformed)return;this.cleanupPerformed=!0;try{for(let J of this.cancelControllers.values())J.abort();this.cancelControllers.clear(),this.transport.close();let X=Error("Query closed before response received");for(let{reject:J}of this.pendingControlResponses.values())J(X);this.pendingControlResponses.clear();for(let{reject:J}of this.pendingMcpResponses.values())J(X);this.pendingMcpResponses.clear(),this.hookCallbacks.clear();for(let J of this.sdkMcpTransports.values())try{J.close()}catch{}if(this.sdkMcpTransports.clear(),$)this.inputStream.error($);else this.inputStream.done()}catch(X){}}next(...[$]){return this.sdkMessages.next(...[$])}return($){return this.sdkMessages.return($)}throw($){return this.sdkMessages.throw($)}[Symbol.asyncIterator](){return this.sdkMessages}[Symbol.asyncDispose](){return this.sdkMessages[Symbol.asyncDispose]()}async readMessages(){try{for await(let $ of this.transport.readMessages()){if($.type==="control_response"){let X=this.pendingControlResponses.get($.response.request_id);if(X)X.handler($.response);continue}else if($.type==="control_request"){this.handleControlRequest($);continue}else if($.type==="control_cancel_request"){this.handleControlCancelRequest($);continue}else if($.type==="keep_alive")continue;if($.type==="streamlined_text"||$.type==="streamlined_tool_use_summary")continue;if($.type==="system"&&$.subtype==="post_turn_summary")continue;if($.type==="result"){if(this.lastErrorResultText=$.is_error?$.subtype==="success"?$.result:$.errors.join("; "):void 0,this.firstResultReceived=!0,this.firstResultReceivedResolve)this.firstResultReceivedResolve();if(this.isSingleUserTurn)m6("[Query.readMessages] First result received for single-turn query, closing stdin"),this.transport.endInput()}else if(!($.type==="system"&&$.subtype==="session_state_changed"))this.lastErrorResultText=void 0;this.inputStream.enqueue($)}if(this.firstResultReceivedResolve)this.firstResultReceivedResolve();this.inputStream.done(),this.cleanup()}catch($){if(this.firstResultReceivedResolve)this.firstResultReceivedResolve();if(this.lastErrorResultText!==void 0&&!($ instanceof a$)){let X=Error(`Claude Code returned an error result: ${this.lastErrorResultText}`);m6(`[Query.readMessages] Replacing exit error with result text. Original: ${lX($)}`),this.inputStream.error(X),this.cleanup(X);return}this.inputStream.error($),this.cleanup($)}}async handleControlRequest($){let X=new AbortController;this.cancelControllers.set($.request_id,X);try{let J=await this.processControlRequest($,X.signal);if(this.cleanupPerformed)return;let Q={type:"control_response",response:{subtype:"success",request_id:$.request_id,response:J}};await Promise.resolve(this.transport.write(q$(Q)+`
|
|
58
|
+
`;if(bK()){MK(Q);return}NM().write(Q)}function ZK(){return PK()??process.env.CLAUDE_CODE_DEBUG_LOGS_DIR??AK(c1(),"debug",`${wK()}.txt`)}var EK=E6(async()=>{try{let $=ZK(),X=IK($),J=AK(X,"latest");await YM(J).catch(()=>{}),await JM($,J)}catch{}});var $m=(()=>{let $=process.env.CLAUDE_CODE_SLOW_OPERATION_THRESHOLD_MS;if($!==void 0){let X=Number($);if(!Number.isNaN(X)&&X>=0)return X}return 1/0})();var VM={[Symbol.dispose](){}};function OM(){return VM}var b$=OM;function q$($,X,J){let Y=[];try{const Q=N$(Y,b$`JSON.stringify(${$})`,0);return JSON.stringify($,X,J)}catch(z){var W=z,G=1}finally{V$(Y,W,G)}}var L6=($,X)=>{let Q=[];try{const J=N$(Q,b$`JSON.parse(${$})`,0);return typeof X>"u"?JSON.parse($):JSON.parse($,X)}catch(Y){var z=Y,W=1}finally{V$(Q,z,W)}};function wM($){let X=$.trim();return X.startsWith("{")&&X.endsWith("}")}function RK($,X){let J={...$};if(X){let Q=J.settings;if(Q&&!wM(Q))throw Error("Cannot use both a settings file path and the sandbox option. Include the sandbox configuration in your settings file instead.");let Y={sandbox:X};if(Q)try{Y={...L6(Q),sandbox:X}}catch{}J.settings=q$(Y)}return J}var DM=2000;class cX{options;process;processStdin;processStdout;ready=!1;abortController;exitError;exitListeners=[];processExitHandler;abortHandler;constructor($){this.options=$;this.abortController=$.abortController||y1(),this.initialize()}getDefaultExecutable(){return f1()?"bun":"node"}spawnLocalProcess($){let{command:X,args:J,cwd:Q,env:Y,signal:z}=$,W=B6(Y.DEBUG_CLAUDE_AGENT_SDK)||this.options.stderr?"pipe":"ignore",G=BM(X,J,{cwd:Q,stdio:["pipe","pipe",W],signal:z,env:Y,windowsHide:!0});if(B6(Y.DEBUG_CLAUDE_AGENT_SDK)||this.options.stderr)G.stderr.on("data",(H)=>{let K=H.toString();if(s$(K),this.options.stderr)this.options.stderr(K)});return{stdin:G.stdin,stdout:G.stdout,get killed(){return G.killed},get exitCode(){return G.exitCode},kill:G.kill.bind(G),on:G.on.bind(G),once:G.once.bind(G),off:G.off.bind(G)}}initialize(){try{let{additionalDirectories:$=[],agent:X,betas:J,cwd:Q,executable:Y=this.getDefaultExecutable(),executableArgs:z=[],extraArgs:W={},pathToClaudeCodeExecutable:G,env:U={...process.env},thinkingConfig:H,maxTurns:K,maxBudgetUsd:V,taskBudget:O,model:N,fallbackModel:w,jsonSchema:B,permissionMode:L,allowDangerouslySkipPermissions:j,permissionPromptToolName:I,continueConversation:b,resume:x,settingSources:h,allowedTools:B$=[],disallowedTools:x$=[],tools:G6,mcpServers:o6,strictMcpConfig:h6,canUseTool:a4,includePartialMessages:_1,plugins:t6,sandbox:r0}=this.options,p=["--output-format","stream-json","--verbose","--input-format","stream-json"];if(H)switch(H.type){case"enabled":if(H.budgetTokens===void 0)p.push("--thinking","adaptive");else p.push("--max-thinking-tokens",H.budgetTokens.toString());break;case"disabled":p.push("--thinking","disabled");break;case"adaptive":p.push("--thinking","adaptive");break}if(this.options.effort)p.push("--effort",this.options.effort);if(K)p.push("--max-turns",K.toString());if(V!==void 0)p.push("--max-budget-usd",V.toString());if(O)p.push("--task-budget",O.total.toString());if(N)p.push("--model",N);if(X)p.push("--agent",X);if(J&&J.length>0)p.push("--betas",J.join(","));if(B)p.push("--json-schema",q$(B));if(this.options.debugFile)p.push("--debug-file",this.options.debugFile);else if(this.options.debug)p.push("--debug");if(B6(U.DEBUG_CLAUDE_AGENT_SDK))p.push("--debug-to-stderr");if(a4){if(I)throw Error("canUseTool callback cannot be used with permissionPromptToolName. Please use one or the other.");p.push("--permission-prompt-tool","stdio")}else if(I)p.push("--permission-prompt-tool",I);if(b)p.push("--continue");if(x)p.push("--resume",x);if(this.options.proactive)p.push("--proactive");if(this.options.assistant)p.push("--assistant");if(this.options.channels&&this.options.channels.length>0)p.push("--channels",...this.options.channels);if(B$.length>0)p.push("--allowedTools",B$.join(","));if(x$.length>0)p.push("--disallowedTools",x$.join(","));if(G6!==void 0)if(Array.isArray(G6))if(G6.length===0)p.push("--tools","");else p.push("--tools",G6.join(","));else p.push("--tools","default");if(o6&&Object.keys(o6).length>0)p.push("--mcp-config",q$({mcpServers:o6}));if(h!==void 0)p.push(`--setting-sources=${h.join(",")}`);if(h6)p.push("--strict-mcp-config");if(L)p.push("--permission-mode",L);if(j)p.push("--allow-dangerously-skip-permissions");if(w){if(N&&w===N)throw Error("Fallback model cannot be the same as the main model. Please specify a different model for fallbackModel option.");p.push("--fallback-model",w)}if(this.options.includeHookEvents)p.push("--include-hook-events");if(_1)p.push("--include-partial-messages");for(let p$ of $)p.push("--add-dir",p$);if(t6&&t6.length>0)for(let p$ of t6)if(p$.type==="local")p.push("--plugin-dir",p$.path);else throw Error(`Unsupported plugin type: ${p$.type}`);if(this.options.forkSession)p.push("--fork-session");if(this.options.resumeSessionAt)p.push("--resume-session-at",this.options.resumeSessionAt);if(this.options.sessionId)p.push("--session-id",this.options.sessionId);if(this.options.persistSession===!1)p.push("--no-session-persistence");let n9={...W??{}};if(this.options.settings)n9.settings=this.options.settings;let aQ=RK(n9,r0);for(let[p$,j4]of Object.entries(aQ))if(j4===null)p.push(`--${p$}`);else p.push(`--${p$}`,j4);if(!U.CLAUDE_CODE_ENTRYPOINT)U.CLAUDE_CODE_ENTRYPOINT="sdk-ts";if(delete U.NODE_OPTIONS,B6(U.DEBUG_CLAUDE_AGENT_SDK))U.DEBUG="1";else delete U.DEBUG;let o0=LM(G),t0=o0?G:Y,s4=o0?[...z,...p]:[...z,G,...p],d9={command:t0,args:s4,cwd:Q,env:U,signal:this.abortController.signal};if(this.options.spawnClaudeCodeProcess)s$(`Spawning Claude Code (custom): ${t0} ${s4.join(" ")}`),this.process=this.options.spawnClaudeCodeProcess(d9);else s$(`Spawning Claude Code: ${t0} ${s4.join(" ")}`),this.process=this.spawnLocalProcess(d9);this.processStdin=this.process.stdin,this.processStdout=this.process.stdout;let x1=()=>{if(this.process&&!this.process.killed)this.process.kill("SIGTERM")};this.processExitHandler=x1,this.abortHandler=x1,process.on("exit",this.processExitHandler),this.abortController.signal.addEventListener("abort",this.abortHandler),this.process.on("error",(p$)=>{if(this.ready=!1,this.abortController.signal.aborted)this.exitError=new a$("Claude Code process aborted by user");else if(NK(p$)){let j4=o0?`Claude Code native binary not found at ${G}. Please ensure Claude Code is installed via native installer or specify a valid path with options.pathToClaudeCodeExecutable.`:`Claude Code executable not found at ${G}. Is options.pathToClaudeCodeExecutable set?`;this.exitError=ReferenceError(j4),s$(this.exitError.message)}else this.exitError=Error(`Failed to spawn Claude Code process: ${p$.message}`),s$(this.exitError.message)}),this.process.on("exit",(p$,j4)=>{if(this.ready=!1,this.abortController.signal.aborted)this.exitError=new a$("Claude Code process aborted by user");else{let a0=this.getProcessExitError(p$,j4);if(a0)this.exitError=a0,s$(a0.message)}}),this.ready=!0}catch($){throw this.ready=!1,$}}getProcessExitError($,X){if($!==0&&$!==null)return Error(`Claude Code process exited with code ${$}`);else if(X)return Error(`Claude Code process terminated by signal ${X}`);return}write($){if(this.abortController.signal.aborted)throw new a$("Operation aborted");if(!this.ready||!this.processStdin)throw Error("ProcessTransport is not ready for writing");if(this.processStdin.writableEnded){s$("[ProcessTransport] Dropping write to ended stdin stream");return}if(this.process?.killed||this.process?.exitCode!==null)throw Error("Cannot write to terminated process");if(this.exitError)throw Error(`Cannot write to process that exited with error: ${this.exitError.message}`);s$(`[ProcessTransport] Writing to stdin: ${$.substring(0,100)}`);try{if(!this.processStdin.write($))s$("[ProcessTransport] Write buffer full, data queued")}catch(X){throw this.ready=!1,Error(`Failed to write to process stdin: ${lX(X)}`)}}close(){if(this.processStdin)this.processStdin.end(),this.processStdin=void 0;if(this.abortHandler)this.abortController.signal.removeEventListener("abort",this.abortHandler),this.abortHandler=void 0;for(let{handler:X}of this.exitListeners)this.process?.off("exit",X);this.exitListeners=[];let $=this.process;if($&&!$.killed&&$.exitCode===null)setTimeout((X)=>{if(X.killed||X.exitCode!==null)return;X.kill("SIGTERM"),setTimeout((J)=>{if(J.exitCode===null)J.kill("SIGKILL")},5000,X).unref()},DM,$).unref(),$.once("exit",()=>{if(this.processExitHandler)process.off("exit",this.processExitHandler),this.processExitHandler=void 0});else if(this.processExitHandler)process.off("exit",this.processExitHandler),this.processExitHandler=void 0;this.ready=!1}isReady(){return this.ready}async*readMessages(){if(!this.processStdout)throw Error("ProcessTransport output stream not available");let $=qM({input:this.processStdout});try{for await(let X of $)if(X.trim()){let J;try{J=L6(X)}catch(Q){s$(`Non-JSON stdout: ${X}`);continue}yield J}await this.waitForExit()}catch(X){throw X}finally{$.close()}}endInput(){if(this.processStdin)this.processStdin.end()}getInputStream(){return this.processStdin}onExit($){if(!this.process)return()=>{};let X=(J,Q)=>{let Y=this.getProcessExitError(J,Q);$(Y)};return this.process.on("exit",X),this.exitListeners.push({callback:$,handler:X}),()=>{if(this.process)this.process.off("exit",X);let J=this.exitListeners.findIndex((Q)=>Q.handler===X);if(J!==-1)this.exitListeners.splice(J,1)}}async waitForExit(){if(!this.process){if(this.exitError)throw this.exitError;return}if(this.process.exitCode!==null||this.process.killed){if(this.exitError)throw this.exitError;return}return new Promise(($,X)=>{let J=(Y,z)=>{if(this.abortController.signal.aborted){X(new a$("Operation aborted"));return}let W=this.getProcessExitError(Y,z);if(W)X(W);else $()};this.process.once("exit",J);let Q=(Y)=>{this.process.off("exit",J),X(Y)};this.process.once("error",Q),this.process.once("exit",()=>{this.process.off("error",Q)})})}}function LM($){return![".js",".mjs",".tsx",".ts",".jsx"].some((J)=>$.endsWith(J))}class K1{returned;queue=[];readResolve;readReject;isDone=!1;hasError;started=!1;constructor($){this.returned=$}[Symbol.asyncIterator](){if(this.started)throw Error("Stream can only be iterated once");return this.started=!0,this}next(){if(this.queue.length>0)return Promise.resolve({done:!1,value:this.queue.shift()});if(this.isDone)return Promise.resolve({done:!0,value:void 0});if(this.hasError)return Promise.reject(this.hasError);return new Promise(($,X)=>{this.readResolve=$,this.readReject=X})}enqueue($){if(this.readResolve){let X=this.readResolve;this.readResolve=void 0,this.readReject=void 0,X({done:!1,value:$})}else this.queue.push($)}done(){if(this.isDone=!0,this.readResolve){let $=this.readResolve;this.readResolve=void 0,this.readReject=void 0,$({done:!0,value:void 0})}}error($){if(this.hasError=$,this.readReject){let X=this.readReject;this.readResolve=void 0,this.readReject=void 0,X($)}}return(){if(this.isDone=!0,this.returned)this.returned();return Promise.resolve({done:!0,value:void 0})}}class yz{sendMcpMessage;isClosed=!1;constructor($){this.sendMcpMessage=$}onclose;onerror;onmessage;async start(){}async send($){if(this.isClosed)throw Error("Transport is closed");this.sendMcpMessage($)}async close(){if(this.isClosed)return;this.isClosed=!0,this.onclose?.()}}class pX{transport;isSingleUserTurn;canUseTool;hooks;abortController;jsonSchema;initConfig;onElicitation;pendingControlResponses=new Map;cleanupPerformed=!1;sdkMessages;inputStream=new K1;initialization;cancelControllers=new Map;hookCallbacks=new Map;nextCallbackId=0;sdkMcpTransports=new Map;sdkMcpServerInstances=new Map;pendingMcpResponses=new Map;firstResultReceivedResolve;firstResultReceived=!1;lastErrorResultText;setIsSingleUserTurn($){this.isSingleUserTurn=$}hasBidirectionalNeeds(){return this.sdkMcpTransports.size>0||this.hooks!==void 0&&Object.keys(this.hooks).length>0||this.canUseTool!==void 0||this.onElicitation!==void 0}constructor($,X,J,Q,Y,z=new Map,W,G,U){this.transport=$;this.isSingleUserTurn=X;this.canUseTool=J;this.hooks=Q;this.abortController=Y;this.jsonSchema=W;this.initConfig=G;this.onElicitation=U;for(let[H,K]of z)this.connectSdkMcpServer(H,K);this.sdkMessages=this.readSdkMessages(),this.readMessages(),this.initialization=this.initialize(),this.initialization.catch(()=>{})}setError($){this.inputStream.error($)}async stopTask($){await this.request({subtype:"stop_task",task_id:$})}close(){this.cleanup()}cleanup($){if(this.cleanupPerformed)return;this.cleanupPerformed=!0;try{for(let J of this.cancelControllers.values())J.abort();this.cancelControllers.clear(),this.transport.close();let X=Error("Query closed before response received");for(let{reject:J}of this.pendingControlResponses.values())J(X);this.pendingControlResponses.clear();for(let{reject:J}of this.pendingMcpResponses.values())J(X);this.pendingMcpResponses.clear(),this.hookCallbacks.clear();for(let J of this.sdkMcpTransports.values())try{J.close()}catch{}if(this.sdkMcpTransports.clear(),$)this.inputStream.error($);else this.inputStream.done()}catch(X){}}next(...[$]){return this.sdkMessages.next(...[$])}return($){return this.sdkMessages.return($)}throw($){return this.sdkMessages.throw($)}[Symbol.asyncIterator](){return this.sdkMessages}[Symbol.asyncDispose](){return this.sdkMessages[Symbol.asyncDispose]()}async readMessages(){try{for await(let $ of this.transport.readMessages()){if($.type==="control_response"){let X=this.pendingControlResponses.get($.response.request_id);if(X)X.handler($.response);continue}else if($.type==="control_request"){this.handleControlRequest($);continue}else if($.type==="control_cancel_request"){this.handleControlCancelRequest($);continue}else if($.type==="keep_alive")continue;if($.type==="system"&&$.subtype==="post_turn_summary")continue;if($.type==="result"){if(this.lastErrorResultText=$.is_error?$.subtype==="success"?$.result:$.errors.join("; "):void 0,this.firstResultReceived=!0,this.firstResultReceivedResolve)this.firstResultReceivedResolve();if(this.isSingleUserTurn)m6("[Query.readMessages] First result received for single-turn query, closing stdin"),this.transport.endInput()}else if(!($.type==="system"&&$.subtype==="session_state_changed"))this.lastErrorResultText=void 0;this.inputStream.enqueue($)}if(this.firstResultReceivedResolve)this.firstResultReceivedResolve();this.inputStream.done(),this.cleanup()}catch($){if(this.firstResultReceivedResolve)this.firstResultReceivedResolve();if(this.lastErrorResultText!==void 0&&!($ instanceof a$)){let X=Error(`Claude Code returned an error result: ${this.lastErrorResultText}`);m6(`[Query.readMessages] Replacing exit error with result text. Original: ${lX($)}`),this.inputStream.error(X),this.cleanup(X);return}this.inputStream.error($),this.cleanup($)}}async handleControlRequest($){let X=new AbortController;this.cancelControllers.set($.request_id,X);try{let J=await this.processControlRequest($,X.signal);if(this.cleanupPerformed)return;let Q={type:"control_response",response:{subtype:"success",request_id:$.request_id,response:J}};await Promise.resolve(this.transport.write(q$(Q)+`
|
|
59
59
|
`))}catch(J){if(this.cleanupPerformed)return;let Q={type:"control_response",response:{subtype:"error",request_id:$.request_id,error:lX(J)}};await Promise.resolve(this.transport.write(q$(Q)+`
|
|
60
60
|
`))}finally{this.cancelControllers.delete($.request_id)}}handleControlCancelRequest($){let X=this.cancelControllers.get($.request_id);if(X)X.abort(),this.cancelControllers.delete($.request_id)}async processControlRequest($,X){if($.request.subtype==="can_use_tool"){if(!this.canUseTool)throw Error("canUseTool callback is not provided.");return{...await this.canUseTool($.request.tool_name,$.request.input,{signal:X,suggestions:$.request.permission_suggestions,blockedPath:$.request.blocked_path,decisionReason:$.request.decision_reason,title:$.request.title,displayName:$.request.display_name,description:$.request.description,toolUseID:$.request.tool_use_id,agentID:$.request.agent_id}),toolUseID:$.request.tool_use_id}}else if($.request.subtype==="hook_callback")return await this.handleHookCallbacks($.request.callback_id,$.request.input,$.request.tool_use_id,X);else if($.request.subtype==="mcp_message"){let J=$.request,Q=this.sdkMcpTransports.get(J.server_name);if(!Q)throw Error(`SDK MCP server not found: ${J.server_name}`);if("method"in J.message&&"id"in J.message&&J.message.id!==null)return{mcp_response:await this.handleMcpControlRequest(J.server_name,J,Q)};else{if(Q.onmessage)Q.onmessage(J.message);return{mcp_response:{jsonrpc:"2.0",result:{},id:0}}}}else if($.request.subtype==="elicitation"){let J=$.request;if(this.onElicitation)return await this.onElicitation({serverName:J.mcp_server_name,message:J.message,mode:J.mode,url:J.url,elicitationId:J.elicitation_id,requestedSchema:J.requested_schema},{signal:X});return{action:"decline"}}throw Error("Unsupported control request subtype: "+$.request.subtype)}async*readSdkMessages(){for await(let $ of this.inputStream)yield $}async initialize(){let $;if(this.hooks){$={};for(let[Y,z]of Object.entries(this.hooks))if(z.length>0)$[Y]=z.map((W)=>{let G=[];for(let U of W.hooks){let H=`hook_${this.nextCallbackId++}`;this.hookCallbacks.set(H,U),G.push(H)}return{matcher:W.matcher,hookCallbackIds:G,timeout:W.timeout}})}let X=this.sdkMcpTransports.size>0?Array.from(this.sdkMcpTransports.keys()):void 0,J={subtype:"initialize",hooks:$,sdkMcpServers:X,jsonSchema:this.jsonSchema,systemPrompt:this.initConfig?.systemPrompt,appendSystemPrompt:this.initConfig?.appendSystemPrompt,agents:this.initConfig?.agents,promptSuggestions:this.initConfig?.promptSuggestions,agentProgressSummaries:this.initConfig?.agentProgressSummaries};return(await this.request(J)).response}async interrupt(){await this.request({subtype:"interrupt"})}async setPermissionMode($){await this.request({subtype:"set_permission_mode",mode:$})}async setModel($){await this.request({subtype:"set_model",model:$})}async setMaxThinkingTokens($){await this.request({subtype:"set_max_thinking_tokens",max_thinking_tokens:$})}async applyFlagSettings($){await this.request({subtype:"apply_flag_settings",settings:$})}async getSettings(){return(await this.request({subtype:"get_settings"})).response}async rewindFiles($,X){return(await this.request({subtype:"rewind_files",user_message_id:$,dry_run:X?.dryRun})).response}async cancelAsyncMessage($){return(await this.request({subtype:"cancel_async_message",message_uuid:$})).response.cancelled}async seedReadState($,X){await this.request({subtype:"seed_read_state",path:$,mtime:X})}async enableRemoteControl($){return(await this.request({subtype:"remote_control",enabled:$})).response}async setProactive($){await this.request({subtype:"set_proactive",enabled:$})}async generateSessionTitle($,X){return(await this.request({subtype:"generate_session_title",description:$,persist:X?.persist})).response.title}async askSideQuestion($){return(await this.request({subtype:"side_question",question:$})).response.response}async processPendingPermissionRequests($){for(let X of $)if(X.request.subtype==="can_use_tool")this.handleControlRequest(X).catch(()=>{})}request($){let X=Math.random().toString(36).substring(2,15),J={request_id:X,type:"control_request",request:$};return new Promise((Q,Y)=>{this.pendingControlResponses.set(X,{handler:(z)=>{if(this.pendingControlResponses.delete(X),z.subtype==="success")Q(z);else if(Y(Error(z.error)),z.pending_permission_requests)this.processPendingPermissionRequests(z.pending_permission_requests)},reject:Y}),Promise.resolve(this.transport.write(q$(J)+`
|
|
61
61
|
`))})}async initializationResult(){return this.initialization}async supportedCommands(){return(await this.initialization).commands}async supportedModels(){return(await this.initialization).models}async supportedAgents(){return(await this.initialization).agents}async reconnectMcpServer($){await this.request({subtype:"mcp_reconnect",serverName:$})}async toggleMcpServer($,X){await this.request({subtype:"mcp_toggle",serverName:$,enabled:X})}async enableChannel($){await this.request({subtype:"channel_enable",serverName:$})}async mcpAuthenticate($){return(await this.request({subtype:"mcp_authenticate",serverName:$})).response}async mcpClearAuth($){return(await this.request({subtype:"mcp_clear_auth",serverName:$})).response}async mcpSubmitOAuthCallbackUrl($,X){return(await this.request({subtype:"mcp_oauth_callback_url",serverName:$,callbackUrl:X})).response}async claudeAuthenticate($){return(await this.request({subtype:"claude_authenticate",loginWithClaudeAi:$})).response}async claudeOAuthCallback($,X){return(await this.request({subtype:"claude_oauth_callback",authorizationCode:$,state:X})).response}async claudeOAuthWaitForCompletion(){return(await this.request({subtype:"claude_oauth_wait_for_completion"})).response}async mcpServerStatus(){return(await this.request({subtype:"mcp_status"})).response.mcpServers}async getContextUsage(){return(await this.request({subtype:"get_context_usage"})).response}async reloadPlugins(){return(await this.request({subtype:"reload_plugins"})).response}async setMcpServers($){let X={},J={};for(let[G,U]of Object.entries($))if(U.type==="sdk"&&"instance"in U)X[G]=U.instance;else J[G]=U;let Q=new Set(this.sdkMcpServerInstances.keys()),Y=new Set(Object.keys(X));for(let G of Q)if(!Y.has(G))await this.disconnectSdkMcpServer(G);for(let[G,U]of Object.entries(X))if(!Q.has(G))this.connectSdkMcpServer(G,U);let z={};for(let G of Object.keys(X))z[G]={type:"sdk",name:G};return(await this.request({subtype:"mcp_set_servers",servers:{...J,...z}})).response}async accountInfo(){return(await this.initialization).account}async streamInput($){m6("[Query.streamInput] Starting to process input stream");try{let X=0;for await(let J of $){if(X++,m6(`[Query.streamInput] Processing message ${X}: ${J.type}`),this.abortController?.signal.aborted)break;await Promise.resolve(this.transport.write(q$(J)+`
|
|
@@ -100,6 +100,7 @@ Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.
|
|
|
100
100
|
]))`;continue}else if(Q[U]==="$"){Y+=`($|(?=[\r
|
|
101
101
|
]))`;continue}}if(J.s&&Q[U]==="."){Y+=W?`${Q[U]}\r
|
|
102
102
|
`:`[${Q[U]}\r
|
|
103
|
-
]`;continue}if(Y+=Q[U],Q[U]==="\\")z=!0;else if(W&&Q[U]==="]")W=!1;else if(!W&&Q[U]==="[")W=!0}try{new RegExp(Y)}catch{return console.warn(`Could not convert regex pattern at ${X.currentPath.join("/")} to a flag-independent form! Falling back to the flag-ignorant source`),$.source}return Y}function wQ($,X){if(X.target==="openAi")console.warn("Warning: OpenAI may not support records in schemas! Try an array of key-value pairs instead.");if(X.target==="openApi3"&&$.keyType?._def.typeName===P.ZodEnum)return{type:"object",required:$.keyType._def.values,properties:$.keyType._def.values.reduce((Q,Y)=>({...Q,[Y]:c($.valueType._def,{...X,currentPath:[...X.currentPath,"properties",Y]})??I$(X)}),{}),additionalProperties:X.rejectedAdditionalProperties};let J={type:"object",additionalProperties:c($.valueType._def,{...X,currentPath:[...X.currentPath,"additionalProperties"]})??X.allowedAdditionalProperties};if(X.target==="openApi3")return J;if($.keyType?._def.typeName===P.ZodString&&$.keyType._def.checks?.length){let{type:Q,...Y}=OQ($.keyType._def,X);return{...J,propertyNames:Y}}else if($.keyType?._def.typeName===P.ZodEnum)return{...J,propertyNames:{enum:$.keyType._def.values}};else if($.keyType?._def.typeName===P.ZodBranded&&$.keyType._def.type._def.typeName===P.ZodString&&$.keyType._def.type._def.checks?.length){let{type:Q,...Y}=VQ($.keyType._def,X);return{...J,propertyNames:Y}}return J}function iV($,X){if(X.mapStrategy==="record")return wQ($,X);let J=c($.keyType._def,{...X,currentPath:[...X.currentPath,"items","items","0"]})||I$(X),Q=c($.valueType._def,{...X,currentPath:[...X.currentPath,"items","items","1"]})||I$(X);return{type:"array",maxItems:125,items:{type:"array",items:[J,Q],minItems:2,maxItems:2}}}function nV($){let X=$.values,Q=Object.keys($.values).filter((z)=>{return typeof X[X[z]]!=="number"}).map((z)=>X[z]),Y=Array.from(new Set(Q.map((z)=>typeof z)));return{type:Y.length===1?Y[0]==="string"?"string":"number":["string","number"],enum:Q}}function dV($){return $.target==="openAi"?void 0:{not:I$({...$,currentPath:[...$.currentPath,"not"]})}}function rV($){return $.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var M9={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function tV($,X){if(X.target==="openApi3")return oV($,X);let J=$.options instanceof Map?Array.from($.options.values()):$.options;if(J.every((Q)=>(Q._def.typeName in M9)&&(!Q._def.checks||!Q._def.checks.length))){let Q=J.reduce((Y,z)=>{let W=M9[z._def.typeName];return W&&!Y.includes(W)?[...Y,W]:Y},[]);return{type:Q.length>1?Q:Q[0]}}else if(J.every((Q)=>Q._def.typeName==="ZodLiteral"&&!Q.description)){let Q=J.reduce((Y,z)=>{let W=typeof z._def.value;switch(W){case"string":case"number":case"boolean":return[...Y,W];case"bigint":return[...Y,"integer"];case"object":if(z._def.value===null)return[...Y,"null"];case"symbol":case"undefined":case"function":default:return Y}},[]);if(Q.length===J.length){let Y=Q.filter((z,W,G)=>G.indexOf(z)===W);return{type:Y.length>1?Y:Y[0],enum:J.reduce((z,W)=>{return z.includes(W._def.value)?z:[...z,W._def.value]},[])}}}else if(J.every((Q)=>Q._def.typeName==="ZodEnum"))return{type:"string",enum:J.reduce((Q,Y)=>[...Q,...Y._def.values.filter((z)=>!Q.includes(z))],[])};return oV($,X)}var oV=($,X)=>{let J=($.options instanceof Map?Array.from($.options.values()):$.options).map((Q,Y)=>c(Q._def,{...X,currentPath:[...X.currentPath,"anyOf",`${Y}`]})).filter((Q)=>!!Q&&(!X.strictUnions||typeof Q==="object"&&Object.keys(Q).length>0));return J.length?{anyOf:J}:void 0};function aV($,X){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes($.innerType._def.typeName)&&(!$.innerType._def.checks||!$.innerType._def.checks.length)){if(X.target==="openApi3")return{type:M9[$.innerType._def.typeName],nullable:!0};return{type:[M9[$.innerType._def.typeName],"null"]}}if(X.target==="openApi3"){let Q=c($.innerType._def,{...X,currentPath:[...X.currentPath]});if(Q&&"$ref"in Q)return{allOf:[Q],nullable:!0};return Q&&{...Q,nullable:!0}}let J=c($.innerType._def,{...X,currentPath:[...X.currentPath,"anyOf","0"]});return J&&{anyOf:[J,{type:"null"}]}}function sV($,X){let J={type:"number"};if(!$.checks)return J;for(let Q of $.checks)switch(Q.kind){case"int":J.type="integer",O3(J,"type",Q.message,X);break;case"min":if(X.target==="jsonSchema7")if(Q.inclusive)J$(J,"minimum",Q.value,Q.message,X);else J$(J,"exclusiveMinimum",Q.value,Q.message,X);else{if(!Q.inclusive)J.exclusiveMinimum=!0;J$(J,"minimum",Q.value,Q.message,X)}break;case"max":if(X.target==="jsonSchema7")if(Q.inclusive)J$(J,"maximum",Q.value,Q.message,X);else J$(J,"exclusiveMaximum",Q.value,Q.message,X);else{if(!Q.inclusive)J.exclusiveMaximum=!0;J$(J,"maximum",Q.value,Q.message,X)}break;case"multipleOf":J$(J,"multipleOf",Q.value,Q.message,X);break}return J}function eV($,X){let J=X.target==="openAi",Q={type:"object",properties:{}},Y=[],z=$.shape();for(let G in z){let U=z[G];if(U===void 0||U._def===void 0)continue;let H=VZ(U);if(H&&J){if(U._def.typeName==="ZodOptional")U=U._def.innerType;if(!U.isNullable())U=U.nullable();H=!1}let K=c(U._def,{...X,currentPath:[...X.currentPath,"properties",G],propertyPath:[...X.currentPath,"properties",G]});if(K===void 0)continue;if(Q.properties[G]=K,!H)Y.push(G)}if(Y.length)Q.required=Y;let W=NZ($,X);if(W!==void 0)Q.additionalProperties=W;return Q}function NZ($,X){if($.catchall._def.typeName!=="ZodNever")return c($.catchall._def,{...X,currentPath:[...X.currentPath,"additionalProperties"]});switch($.unknownKeys){case"passthrough":return X.allowedAdditionalProperties;case"strict":return X.rejectedAdditionalProperties;case"strip":return X.removeAdditionalStrategy==="strict"?X.allowedAdditionalProperties:X.rejectedAdditionalProperties}}function VZ($){try{return $.isOptional()}catch{return!0}}var $O=($,X)=>{if(X.currentPath.toString()===X.propertyPath?.toString())return c($.innerType._def,X);let J=c($.innerType._def,{...X,currentPath:[...X.currentPath,"anyOf","1"]});return J?{anyOf:[{not:I$(X)},J]}:I$(X)};var XO=($,X)=>{if(X.pipeStrategy==="input")return c($.in._def,X);else if(X.pipeStrategy==="output")return c($.out._def,X);let J=c($.in._def,{...X,currentPath:[...X.currentPath,"allOf","0"]}),Q=c($.out._def,{...X,currentPath:[...X.currentPath,"allOf",J?"1":"0"]});return{allOf:[J,Q].filter((Y)=>Y!==void 0)}};function JO($,X){return c($.type._def,X)}function YO($,X){let Q={type:"array",uniqueItems:!0,items:c($.valueType._def,{...X,currentPath:[...X.currentPath,"items"]})};if($.minSize)J$(Q,"minItems",$.minSize.value,$.minSize.message,X);if($.maxSize)J$(Q,"maxItems",$.maxSize.value,$.maxSize.message,X);return Q}function QO($,X){if($.rest)return{type:"array",minItems:$.items.length,items:$.items.map((J,Q)=>c(J._def,{...X,currentPath:[...X.currentPath,"items",`${Q}`]})).reduce((J,Q)=>Q===void 0?J:[...J,Q],[]),additionalItems:c($.rest._def,{...X,currentPath:[...X.currentPath,"additionalItems"]})};else return{type:"array",minItems:$.items.length,maxItems:$.items.length,items:$.items.map((J,Q)=>c(J._def,{...X,currentPath:[...X.currentPath,"items",`${Q}`]})).reduce((J,Q)=>Q===void 0?J:[...J,Q],[])}}function zO($){return{not:I$($)}}function WO($){return I$($)}var GO=($,X)=>{return c($.innerType._def,X)};var UO=($,X,J)=>{switch(X){case P.ZodString:return OQ($,J);case P.ZodNumber:return sV($,J);case P.ZodObject:return eV($,J);case P.ZodBigInt:return yV($,J);case P.ZodBoolean:return fV();case P.ZodDate:return w3($,J);case P.ZodUndefined:return zO(J);case P.ZodNull:return rV(J);case P.ZodArray:return TV($,J);case P.ZodUnion:case P.ZodDiscriminatedUnion:return tV($,J);case P.ZodIntersection:return lV($,J);case P.ZodTuple:return QO($,J);case P.ZodRecord:return wQ($,J);case P.ZodLiteral:return cV($,J);case P.ZodEnum:return mV($);case P.ZodNativeEnum:return nV($);case P.ZodNullable:return aV($,J);case P.ZodOptional:return $O($,J);case P.ZodMap:return iV($,J);case P.ZodSet:return YO($,J);case P.ZodLazy:return()=>$.getter()._def;case P.ZodPromise:return JO($,J);case P.ZodNaN:case P.ZodNever:return dV(J);case P.ZodEffects:return uV($,J);case P.ZodAny:return I$(J);case P.ZodUnknown:return WO(J);case P.ZodDefault:return hV($,J);case P.ZodBranded:return VQ($,J);case P.ZodReadonly:return GO($,J);case P.ZodCatch:return gV($,J);case P.ZodPipeline:return XO($,J);case P.ZodFunction:case P.ZodVoid:case P.ZodSymbol:return;default:return((Q)=>{return})(X)}};function c($,X,J=!1){let Q=X.seen.get($);if(X.override){let G=X.override?.($,X,Q,J);if(G!==kV)return G}if(Q&&!J){let G=OZ(Q,X);if(G!==void 0)return G}let Y={def:$,path:X.currentPath,jsonSchema:void 0};X.seen.set($,Y);let z=UO($,$.typeName,X),W=typeof z==="function"?c(z(),X):z;if(W)wZ($,X,W);if(X.postProcess){let G=X.postProcess(W,$,X);return Y.jsonSchema=W,G}return Y.jsonSchema=W,W}var OZ=($,X)=>{switch(X.$refStrategy){case"root":return{$ref:$.path.join("/")};case"relative":return{$ref:NQ(X.currentPath,$.path)};case"none":case"seen":{if($.path.length<X.currentPath.length&&$.path.every((J,Q)=>X.currentPath[Q]===J))return console.warn(`Recursive reference detected at ${X.currentPath.join("/")}! Defaulting to any`),I$(X);return X.$refStrategy==="seen"?I$(X):void 0}}},wZ=($,X,J)=>{if($.description){if(J.description=$.description,X.markdownDescription)J.markdownDescription=$.description}return J};var D3=($,X)=>{let J=xV(X),Q=typeof X==="object"&&X.definitions?Object.entries(X.definitions).reduce((U,[H,K])=>({...U,[H]:c(K._def,{...J,currentPath:[...J.basePath,J.definitionPath,H]},!0)??I$(J)}),{}):void 0,Y=typeof X==="string"?X:X?.nameStrategy==="title"?void 0:X?.name,z=c($._def,Y===void 0?J:{...J,currentPath:[...J.basePath,J.definitionPath,Y]},!1)??I$(J),W=typeof X==="object"&&X.name!==void 0&&X.nameStrategy==="title"?X.name:void 0;if(W!==void 0)z.title=W;if(J.flags.hasReferencedOpenAiAnyType){if(!Q)Q={};if(!Q[J.openAiAnyTypeName])Q[J.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:J.$refStrategy==="relative"?"1":[...J.basePath,J.definitionPath,J.openAiAnyTypeName].join("/")}}}let G=Y===void 0?Q?{...z,[J.definitionPath]:Q}:z:{$ref:[...J.$refStrategy==="relative"?[]:J.basePath,J.definitionPath,Y].join("/"),[J.definitionPath]:{...Q,[Y]:z}};if(J.target==="jsonSchema7")G.$schema="http://json-schema.org/draft-07/schema#";else if(J.target==="jsonSchema2019-09"||J.target==="openAi")G.$schema="https://json-schema.org/draft/2019-09/schema#";if(J.target==="openAi"&&(("anyOf"in G)||("oneOf"in G)||("allOf"in G)||("type"in G)&&Array.isArray(G.type)))console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property.");return G};function BZ($){if(!$)return"draft-7";if($==="jsonSchema7"||$==="draft-7")return"draft-7";if($==="jsonSchema2019-09"||$==="draft-2020-12")return"draft-2020-12";return"draft-7"}function L3($,X){if(I6($))return Z0($,{target:BZ(X?.target),io:X?.pipeStrategy??"input"});return D3($,{strictUnions:X?.strictUnions??!0,pipeStrategy:X?.pipeStrategy??"input"})}function j3($){let J=h4($)?.method;if(!J)throw Error("Schema is missing a method literal");let Q=v7(J);if(typeof Q!=="string")throw Error("Schema method literal must be a string");return Q}function F3($,X){let J=g4($,X);if(!J.success)throw J.error;return J.data}var qZ=60000;class M3{constructor($){if(this._options=$,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(r7,(X)=>{this._oncancel(X)}),this.setNotificationHandler(t7,(X)=>{this._onprogress(X)}),this.setRequestHandler(o7,(X)=>({})),this._taskStore=$?.taskStore,this._taskMessageQueue=$?.taskMessageQueue,this._taskStore)this.setRequestHandler(a7,async(X,J)=>{let Q=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Q)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return{...Q}}),this.setRequestHandler(e7,async(X,J)=>{let Q=async()=>{let Y=X.params.taskId;if(this._taskMessageQueue){let W;while(W=await this._taskMessageQueue.dequeue(Y,J.sessionId)){if(W.type==="response"||W.type==="error"){let G=W.message,U=G.id,H=this._requestResolvers.get(U);if(H)if(this._requestResolvers.delete(U),W.type==="response")H(G);else{let K=G,V=new g(K.error.code,K.error.message,K.error.data);H(V)}else{let K=W.type==="response"?"Response":"Error";this._onerror(Error(`${K} handler missing for request ${U}`))}continue}await this._transport?.send(W.message,{relatedRequestId:J.requestId})}}let z=await this._taskStore.getTask(Y,J.sessionId);if(!z)throw new g(m.InvalidParams,`Task not found: ${Y}`);if(!l4(z.status))return await this._waitForTaskUpdate(Y,J.signal),await Q();if(l4(z.status)){let W=await this._taskStore.getTaskResult(Y,J.sessionId);return this._clearTaskQueue(Y),{...W,_meta:{...W._meta,[m4]:{taskId:Y}}}}return await Q()};return await Q()}),this.setRequestHandler($Q,async(X,J)=>{try{let{tasks:Q,nextCursor:Y}=await this._taskStore.listTasks(X.params?.cursor,J.sessionId);return{tasks:Q,nextCursor:Y,_meta:{}}}catch(Q){throw new g(m.InvalidParams,`Failed to list tasks: ${Q instanceof Error?Q.message:String(Q)}`)}}),this.setRequestHandler(JQ,async(X,J)=>{try{let Q=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Q)throw new g(m.InvalidParams,`Task not found: ${X.params.taskId}`);if(l4(Q.status))throw new g(m.InvalidParams,`Cannot cancel task in terminal status: ${Q.status}`);await this._taskStore.updateTaskStatus(X.params.taskId,"cancelled","Client cancelled task execution.",J.sessionId),this._clearTaskQueue(X.params.taskId);let Y=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Y)throw new g(m.InvalidParams,`Task not found after cancellation: ${X.params.taskId}`);return{_meta:{},...Y}}catch(Q){if(Q instanceof g)throw Q;throw new g(m.InvalidRequest,`Failed to cancel task: ${Q instanceof Error?Q.message:String(Q)}`)}})}async _oncancel($){if(!$.params.requestId)return;this._requestHandlerAbortControllers.get($.params.requestId)?.abort($.params.reason)}_setupTimeout($,X,J,Q,Y=!1){this._timeoutInfo.set($,{timeoutId:setTimeout(Q,X),startTime:Date.now(),timeout:X,maxTotalTimeout:J,resetTimeoutOnProgress:Y,onTimeout:Q})}_resetTimeout($){let X=this._timeoutInfo.get($);if(!X)return!1;let J=Date.now()-X.startTime;if(X.maxTotalTimeout&&J>=X.maxTotalTimeout)throw this._timeoutInfo.delete($),g.fromError(m.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:X.maxTotalTimeout,totalElapsed:J});return clearTimeout(X.timeoutId),X.timeoutId=setTimeout(X.onTimeout,X.timeout),!0}_cleanupTimeout($){let X=this._timeoutInfo.get($);if(X)clearTimeout(X.timeoutId),this._timeoutInfo.delete($)}async connect($){if(this._transport)throw Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=$;let X=this.transport?.onclose;this._transport.onclose=()=>{X?.(),this._onclose()};let J=this.transport?.onerror;this._transport.onerror=(Y)=>{J?.(Y),this._onerror(Y)};let Q=this._transport?.onmessage;this._transport.onmessage=(Y,z)=>{if(Q?.(Y,z),V9(Y)||FV(Y))this._onresponse(Y);else if(eG(Y))this._onrequest(Y,z);else if(jV(Y))this._onnotification(Y);else this._onerror(Error(`Unknown message type: ${JSON.stringify(Y)}`))},await this._transport.start()}_onclose(){let $=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let J of this._requestHandlerAbortControllers.values())J.abort();this._requestHandlerAbortControllers.clear();let X=g.fromError(m.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let J of $.values())J(X)}_onerror($){this.onerror?.($)}_onnotification($){let X=this._notificationHandlers.get($.method)??this.fallbackNotificationHandler;if(X===void 0)return;Promise.resolve().then(()=>X($)).catch((J)=>this._onerror(Error(`Uncaught error in notification handler: ${J}`)))}_onrequest($,X){let J=this._requestHandlers.get($.method)??this.fallbackRequestHandler,Q=this._transport,Y=$.params?._meta?.[m4]?.taskId;if(J===void 0){let H={jsonrpc:"2.0",id:$.id,error:{code:m.MethodNotFound,message:"Method not found"}};if(Y&&this._taskMessageQueue)this._enqueueTaskMessage(Y,{type:"error",message:H,timestamp:Date.now()},Q?.sessionId).catch((K)=>this._onerror(Error(`Failed to enqueue error response: ${K}`)));else Q?.send(H).catch((K)=>this._onerror(Error(`Failed to send an error response: ${K}`)));return}let z=new AbortController;this._requestHandlerAbortControllers.set($.id,z);let W=qV($.params)?$.params.task:void 0,G=this._taskStore?this.requestTaskStore($,Q?.sessionId):void 0,U={signal:z.signal,sessionId:Q?.sessionId,_meta:$.params?._meta,sendNotification:async(H)=>{if(z.signal.aborted)return;let K={relatedRequestId:$.id};if(Y)K.relatedTask={taskId:Y};await this.notification(H,K)},sendRequest:async(H,K,V)=>{if(z.signal.aborted)throw new g(m.ConnectionClosed,"Request was cancelled");let O={...V,relatedRequestId:$.id};if(Y&&!O.relatedTask)O.relatedTask={taskId:Y};let N=O.relatedTask?.taskId??Y;if(N&&G)await G.updateTaskStatus(N,"input_required");return await this.request(H,K,O)},authInfo:X?.authInfo,requestId:$.id,requestInfo:X?.requestInfo,taskId:Y,taskStore:G,taskRequestedTtl:W?.ttl,closeSSEStream:X?.closeSSEStream,closeStandaloneSSEStream:X?.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(W)this.assertTaskHandlerCapability($.method)}).then(()=>J($,U)).then(async(H)=>{if(z.signal.aborted)return;let K={result:H,jsonrpc:"2.0",id:$.id};if(Y&&this._taskMessageQueue)await this._enqueueTaskMessage(Y,{type:"response",message:K,timestamp:Date.now()},Q?.sessionId);else await Q?.send(K)},async(H)=>{if(z.signal.aborted)return;let K={jsonrpc:"2.0",id:$.id,error:{code:Number.isSafeInteger(H.code)?H.code:m.InternalError,message:H.message??"Internal error",...H.data!==void 0&&{data:H.data}}};if(Y&&this._taskMessageQueue)await this._enqueueTaskMessage(Y,{type:"error",message:K,timestamp:Date.now()},Q?.sessionId);else await Q?.send(K)}).catch((H)=>this._onerror(Error(`Failed to send response: ${H}`))).finally(()=>{this._requestHandlerAbortControllers.delete($.id)})}_onprogress($){let{progressToken:X,...J}=$.params,Q=Number(X),Y=this._progressHandlers.get(Q);if(!Y){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify($)}`));return}let z=this._responseHandlers.get(Q),W=this._timeoutInfo.get(Q);if(W&&z&&W.resetTimeoutOnProgress)try{this._resetTimeout(Q)}catch(G){this._responseHandlers.delete(Q),this._progressHandlers.delete(Q),this._cleanupTimeout(Q),z(G);return}Y(J)}_onresponse($){let X=Number($.id),J=this._requestResolvers.get(X);if(J){if(this._requestResolvers.delete(X),V9($))J($);else{let z=new g($.error.code,$.error.message,$.error.data);J(z)}return}let Q=this._responseHandlers.get(X);if(Q===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify($)}`));return}this._responseHandlers.delete(X),this._cleanupTimeout(X);let Y=!1;if(V9($)&&$.result&&typeof $.result==="object"){let z=$.result;if(z.task&&typeof z.task==="object"){let W=z.task;if(typeof W.taskId==="string")Y=!0,this._taskProgressTokens.set(W.taskId,X)}}if(!Y)this._progressHandlers.delete(X);if(V9($))Q($);else{let z=g.fromError($.error.code,$.error.message,$.error.data);Q(z)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream($,X,J){let{task:Q}=J??{};if(!Q){try{yield{type:"result",result:await this.request($,X,J)}}catch(z){yield{type:"error",error:z instanceof g?z:new g(m.InternalError,String(z))}}return}let Y;try{let z=await this.request($,k0,J);if(z.task)Y=z.task.taskId,yield{type:"taskCreated",task:z.task};else throw new g(m.InternalError,"Task creation did not return a task");while(!0){let W=await this.getTask({taskId:Y},J);if(yield{type:"taskStatus",task:W},l4(W.status)){if(W.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:Y},X,J)};else if(W.status==="failed")yield{type:"error",error:new g(m.InternalError,`Task ${Y} failed`)};else if(W.status==="cancelled")yield{type:"error",error:new g(m.InternalError,`Task ${Y} was cancelled`)};return}if(W.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:Y},X,J)};return}let G=W.pollInterval??this._options?.defaultTaskPollInterval??1000;await new Promise((U)=>setTimeout(U,G)),J?.signal?.throwIfAborted()}}catch(z){yield{type:"error",error:z instanceof g?z:new g(m.InternalError,String(z))}}}request($,X,J){let{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z,task:W,relatedTask:G}=J??{};return new Promise((U,H)=>{let K=(j)=>{H(j)};if(!this._transport){K(Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{if(this.assertCapabilityForMethod($.method),W)this.assertTaskCapability($.method)}catch(j){K(j);return}J?.signal?.throwIfAborted();let V=this._requestMessageId++,O={...$,jsonrpc:"2.0",id:V};if(J?.onprogress)this._progressHandlers.set(V,J.onprogress),O.params={...$.params,_meta:{...$.params?._meta||{},progressToken:V}};if(W)O.params={...O.params,task:W};if(G)O.params={...O.params,_meta:{...O.params?._meta||{},[m4]:G}};let N=(j)=>{this._responseHandlers.delete(V),this._progressHandlers.delete(V),this._cleanupTimeout(V),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:V,reason:String(j)}},{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z}).catch((b)=>this._onerror(Error(`Failed to send cancellation: ${b}`)));let I=j instanceof g?j:new g(m.RequestTimeout,String(j));H(I)};this._responseHandlers.set(V,(j)=>{if(J?.signal?.aborted)return;if(j instanceof Error)return H(j);try{let I=g4(X,j.result);if(!I.success)H(I.error);else U(I.data)}catch(I){H(I)}}),J?.signal?.addEventListener("abort",()=>{N(J?.signal?.reason)});let w=J?.timeout??qZ,B=()=>N(g.fromError(m.RequestTimeout,"Request timed out",{timeout:w}));this._setupTimeout(V,w,J?.maxTotalTimeout,B,J?.resetTimeoutOnProgress??!1);let L=G?.taskId;if(L){let j=(I)=>{let b=this._responseHandlers.get(V);if(b)b(I);else this._onerror(Error(`Response handler missing for side-channeled request ${V}`))};this._requestResolvers.set(V,j),this._enqueueTaskMessage(L,{type:"request",message:O,timestamp:Date.now()}).catch((I)=>{this._cleanupTimeout(V),H(I)})}else this._transport.send(O,{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z}).catch((j)=>{this._cleanupTimeout(V),H(j)})})}async getTask($,X){return this.request({method:"tasks/get",params:$},s7,X)}async getTaskResult($,X,J){return this.request({method:"tasks/result",params:$},X,J)}async listTasks($,X){return this.request({method:"tasks/list",params:$},XQ,X)}async cancelTask($,X){return this.request({method:"tasks/cancel",params:$},IV,X)}async notification($,X){if(!this._transport)throw Error("Not connected");this.assertNotificationCapability($.method);let J=X?.relatedTask?.taskId;if(J){let W={...$,jsonrpc:"2.0",params:{...$.params,_meta:{...$.params?._meta||{},[m4]:X.relatedTask}}};await this._enqueueTaskMessage(J,{type:"notification",message:W,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes($.method)&&!$.params&&!X?.relatedRequestId&&!X?.relatedTask){if(this._pendingDebouncedNotifications.has($.method))return;this._pendingDebouncedNotifications.add($.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete($.method),!this._transport)return;let W={...$,jsonrpc:"2.0"};if(X?.relatedTask)W={...W,params:{...W.params,_meta:{...W.params?._meta||{},[m4]:X.relatedTask}}};this._transport?.send(W,X).catch((G)=>this._onerror(G))});return}let z={...$,jsonrpc:"2.0"};if(X?.relatedTask)z={...z,params:{...z.params,_meta:{...z.params?._meta||{},[m4]:X.relatedTask}}};await this._transport.send(z,X)}setRequestHandler($,X){let J=j3($);this.assertRequestHandlerCapability(J),this._requestHandlers.set(J,(Q,Y)=>{let z=F3($,Q);return Promise.resolve(X(z,Y))})}removeRequestHandler($){this._requestHandlers.delete($)}assertCanSetRequestHandler($){if(this._requestHandlers.has($))throw Error(`A request handler for ${$} already exists, which would be overridden`)}setNotificationHandler($,X){let J=j3($);this._notificationHandlers.set(J,(Q)=>{let Y=F3($,Q);return Promise.resolve(X(Y))})}removeNotificationHandler($){this._notificationHandlers.delete($)}_cleanupTaskProgressHandler($){let X=this._taskProgressTokens.get($);if(X!==void 0)this._progressHandlers.delete(X),this._taskProgressTokens.delete($)}async _enqueueTaskMessage($,X,J){if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let Q=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue($,X,J,Q)}async _clearTaskQueue($,X){if(this._taskMessageQueue){let J=await this._taskMessageQueue.dequeueAll($,X);for(let Q of J)if(Q.type==="request"&&eG(Q.message)){let Y=Q.message.id,z=this._requestResolvers.get(Y);if(z)z(new g(m.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(Y);else this._onerror(Error(`Resolver missing for request ${Y} during task ${$} cleanup`))}}}async _waitForTaskUpdate($,X){let J=this._options?.defaultTaskPollInterval??1000;try{let Q=await this._taskStore?.getTask($);if(Q?.pollInterval)J=Q.pollInterval}catch{}return new Promise((Q,Y)=>{if(X.aborted){Y(new g(m.InvalidRequest,"Request cancelled"));return}let z=setTimeout(Q,J);X.addEventListener("abort",()=>{clearTimeout(z),Y(new g(m.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore($,X){let J=this._taskStore;if(!J)throw Error("No task store configured");return{createTask:async(Q)=>{if(!$)throw Error("No request provided");return await J.createTask(Q,$.id,{method:$.method,params:$.params},X)},getTask:async(Q)=>{let Y=await J.getTask(Q,X);if(!Y)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return Y},storeTaskResult:async(Q,Y,z)=>{await J.storeTaskResult(Q,Y,z,X);let W=await J.getTask(Q,X);if(W){let G=D9.parse({method:"notifications/tasks/status",params:W});if(await this.notification(G),l4(W.status))this._cleanupTaskProgressHandler(Q)}},getTaskResult:(Q)=>{return J.getTaskResult(Q,X)},updateTaskStatus:async(Q,Y,z)=>{let W=await J.getTask(Q,X);if(!W)throw new g(m.InvalidParams,`Task "${Q}" not found - it may have been cleaned up`);if(l4(W.status))throw new g(m.InvalidParams,`Cannot update task "${Q}" from terminal status "${W.status}" to "${Y}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await J.updateTaskStatus(Q,Y,z,X);let G=await J.getTask(Q,X);if(G){let U=D9.parse({method:"notifications/tasks/status",params:G});if(await this.notification(U),l4(G.status))this._cleanupTaskProgressHandler(Q)}},listTasks:(Q)=>{return J.listTasks(Q,X)}}}}function HO($){return $!==null&&typeof $==="object"&&!Array.isArray($)}function KO($,X){let J={...$};for(let Q in X){let Y=Q,z=X[Y];if(z===void 0)continue;let W=J[Y];if(HO(W)&&HO(z))J[Y]={...W,...z};else J[Y]=z}return J}var dD=hU(wU(),1),rD=hU(nD(),1);function Px(){let $=new dD.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return rD.default($),$}class bU{constructor($){this._ajv=$??Px()}getValidator($){let X="$id"in $&&typeof $.$id==="string"?this._ajv.getSchema($.$id)??this._ajv.compile($):this._ajv.compile($);return(J)=>{if(X(J))return{valid:!0,data:J,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(X.errors)}}}}class PU{constructor($){this._server=$}requestStream($,X,J){return this._server.requestStream($,X,J)}createMessageStream($,X){let J=this._server.getClientCapabilities();if(($.tools||$.toolChoice)&&!J?.sampling?.tools)throw Error("Client does not support sampling tools capability.");if($.messages.length>0){let Q=$.messages[$.messages.length-1],Y=Array.isArray(Q.content)?Q.content:[Q.content],z=Y.some((H)=>H.type==="tool_result"),W=$.messages.length>1?$.messages[$.messages.length-2]:void 0,G=W?Array.isArray(W.content)?W.content:[W.content]:[],U=G.some((H)=>H.type==="tool_use");if(z){if(Y.some((H)=>H.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!U)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(U){let H=new Set(G.filter((V)=>V.type==="tool_use").map((V)=>V.id)),K=new Set(Y.filter((V)=>V.type==="tool_result").map((V)=>V.toolUseId));if(H.size!==K.size||![...H].every((V)=>K.has(V)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}return this.requestStream({method:"sampling/createMessage",params:$},F9,X)}elicitInputStream($,X){let J=this._server.getClientCapabilities(),Q=$.mode??"form";switch(Q){case"url":{if(!J?.elicitation?.url)throw Error("Client does not support url elicitation.");break}case"form":{if(!J?.elicitation?.form)throw Error("Client does not support form elicitation.");break}}let Y=Q==="form"&&$.mode===void 0?{...$,mode:"form"}:$;return this.requestStream({method:"elicitation/create",params:Y},T0,X)}async getTask($,X){return this._server.getTask({taskId:$},X)}async getTaskResult($,X,J){return this._server.getTaskResult({taskId:$},X,J)}async listTasks($,X){return this._server.listTasks($?{cursor:$}:void 0,X)}async cancelTask($,X){return this._server.cancelTask({taskId:$},X)}}function oD($,X,J){if(!$)throw Error(`${J} does not support task creation (required for ${X})`);switch(X){case"tools/call":if(!$.tools?.call)throw Error(`${J} does not support task creation for tools/call (required for ${X})`);break;default:break}}function tD($,X,J){if(!$)throw Error(`${J} does not support task creation (required for ${X})`);switch(X){case"sampling/createMessage":if(!$.sampling?.createMessage)throw Error(`${J} does not support task creation for sampling/createMessage (required for ${X})`);break;case"elicitation/create":if(!$.elicitation?.create)throw Error(`${J} does not support task creation for elicitation/create (required for ${X})`);break;default:break}}class ZU extends M3{constructor($,X){super(X);if(this._serverInfo=$,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(j9.options.map((J,Q)=>[J,Q])),this.isMessageIgnored=(J,Q)=>{let Y=this._loggingLevels.get(Q);return Y?this.LOG_LEVEL_SEVERITY.get(J)<this.LOG_LEVEL_SEVERITY.get(Y):!1},this._capabilities=X?.capabilities??{},this._instructions=X?.instructions,this._jsonSchemaValidator=X?.jsonSchemaValidator??new bU,this.setRequestHandler(J3,(J)=>this._oninitialize(J)),this.setNotificationHandler(Y3,()=>this.oninitialized?.()),this._capabilities.logging)this.setRequestHandler(K3,async(J,Q)=>{let Y=Q.sessionId||Q.requestInfo?.headers["mcp-session-id"]||void 0,{level:z}=J.params,W=j9.safeParse(z);if(W.success)this._loggingLevels.set(Y,W.data);return{}})}get experimental(){if(!this._experimental)this._experimental={tasks:new PU(this)};return this._experimental}registerCapabilities($){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=KO(this._capabilities,$)}setRequestHandler($,X){let Q=h4($)?.method;if(!Q)throw Error("Schema is missing a method literal");let Y;if(I6(Q)){let W=Q;Y=W._zod?.def?.value??W.value}else{let W=Q;Y=W._def?.value??W.value}if(typeof Y!=="string")throw Error("Schema method literal must be a string");if(Y==="tools/call"){let W=async(G,U)=>{let H=g4(x0,G);if(!H.success){let N=H.error instanceof Error?H.error.message:String(H.error);throw new g(m.InvalidParams,`Invalid tools/call request: ${N}`)}let{params:K}=H.data,V=await Promise.resolve(X(G,U));if(K.task){let N=g4(k0,V);if(!N.success){let w=N.error instanceof Error?N.error.message:String(N.error);throw new g(m.InvalidParams,`Invalid task creation result: ${w}`)}return N.data}let O=g4(HQ,V);if(!O.success){let N=O.error instanceof Error?O.error.message:String(O.error);throw new g(m.InvalidParams,`Invalid tools/call result: ${N}`)}return O.data};return super.setRequestHandler($,W)}return super.setRequestHandler($,X)}assertCapabilityForMethod($){switch($){case"sampling/createMessage":if(!this._clientCapabilities?.sampling)throw Error(`Client does not support sampling (required for ${$})`);break;case"elicitation/create":if(!this._clientCapabilities?.elicitation)throw Error(`Client does not support elicitation (required for ${$})`);break;case"roots/list":if(!this._clientCapabilities?.roots)throw Error(`Client does not support listing roots (required for ${$})`);break;case"ping":break}}assertNotificationCapability($){switch($){case"notifications/message":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"notifications/resources/updated":case"notifications/resources/list_changed":if(!this._capabilities.resources)throw Error(`Server does not support notifying about resources (required for ${$})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw Error(`Server does not support notifying of tool list changes (required for ${$})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw Error(`Server does not support notifying of prompt list changes (required for ${$})`);break;case"notifications/elicitation/complete":if(!this._clientCapabilities?.elicitation?.url)throw Error(`Client does not support URL elicitation (required for ${$})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability($){if(!this._capabilities)return;switch($){case"completion/complete":if(!this._capabilities.completions)throw Error(`Server does not support completions (required for ${$})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw Error(`Server does not support prompts (required for ${$})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw Error(`Server does not support resources (required for ${$})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Server does not support tools (required for ${$})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw Error(`Server does not support tasks capability (required for ${$})`);break;case"ping":case"initialize":break}}assertTaskCapability($){tD(this._clientCapabilities?.tasks?.requests,$,"Client")}assertTaskHandlerCapability($){if(!this._capabilities)return;oD(this._capabilities.tasks?.requests,$,"Server")}async _oninitialize($){let X=$.params.protocolVersion;return this._clientCapabilities=$.params.capabilities,this._clientVersion=$.params.clientInfo,{protocolVersion:OV.includes(X)?X:aG,capabilities:this.getCapabilities(),serverInfo:this._serverInfo,...this._instructions&&{instructions:this._instructions}}}getClientCapabilities(){return this._clientCapabilities}getClientVersion(){return this._clientVersion}getCapabilities(){return this._capabilities}async ping(){return this.request({method:"ping"},d7)}async createMessage($,X){if($.tools||$.toolChoice){if(!this._clientCapabilities?.sampling?.tools)throw Error("Client does not support sampling tools capability.")}if($.messages.length>0){let J=$.messages[$.messages.length-1],Q=Array.isArray(J.content)?J.content:[J.content],Y=Q.some((U)=>U.type==="tool_result"),z=$.messages.length>1?$.messages[$.messages.length-2]:void 0,W=z?Array.isArray(z.content)?z.content:[z.content]:[],G=W.some((U)=>U.type==="tool_use");if(Y){if(Q.some((U)=>U.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!G)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(G){let U=new Set(W.filter((K)=>K.type==="tool_use").map((K)=>K.id)),H=new Set(Q.filter((K)=>K.type==="tool_result").map((K)=>K.toolUseId));if(U.size!==H.size||![...U].every((K)=>H.has(K)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}if($.tools)return this.request({method:"sampling/createMessage",params:$},N3,X);return this.request({method:"sampling/createMessage",params:$},F9,X)}async elicitInput($,X){switch($.mode??"form"){case"url":{if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support url elicitation.");let Q=$;return this.request({method:"elicitation/create",params:Q},T0,X)}case"form":{if(!this._clientCapabilities?.elicitation?.form)throw Error("Client does not support form elicitation.");let Q=$.mode==="form"?$:{...$,mode:"form"},Y=await this.request({method:"elicitation/create",params:Q},T0,X);if(Y.action==="accept"&&Y.content&&Q.requestedSchema)try{let W=this._jsonSchemaValidator.getValidator(Q.requestedSchema)(Y.content);if(!W.valid)throw new g(m.InvalidParams,`Elicitation response content does not match requested schema: ${W.errorMessage}`)}catch(z){if(z instanceof g)throw z;throw new g(m.InternalError,`Error validating elicitation response: ${z instanceof Error?z.message:String(z)}`)}return Y}}}createElicitationCompletionNotifier($,X){if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:$}},X)}async listRoots($,X){return this.request({method:"roots/list",params:$},V3,X)}async sendLoggingMessage($,X){if(this._capabilities.logging){if(!this.isMessageIgnored($.level,X))return this.notification({method:"notifications/message",params:$})}}async sendResourceUpdated($){return this.notification({method:"notifications/resources/updated",params:$})}async sendResourceListChanged(){return this.notification({method:"notifications/resources/list_changed"})}async sendToolListChanged(){return this.notification({method:"notifications/tools/list_changed"})}async sendPromptListChanged(){return this.notification({method:"notifications/prompts/list_changed"})}}var sD=Symbol.for("mcp.completable");function EU($){return!!$&&typeof $==="object"&&sD in $}function eD($){return $[sD]?.complete}var aD;(function($){$.Completable="McpCompletable"})(aD||(aD={}));var Zx=/^[A-Za-z0-9._-]{1,128}$/;function Ex($){let X=[];if($.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if($.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${$.length})`]};if($.includes(" "))X.push("Tool name contains spaces, which may cause parsing issues");if($.includes(","))X.push("Tool name contains commas, which may cause parsing issues");if($.startsWith("-")||$.endsWith("-"))X.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts");if($.startsWith(".")||$.endsWith("."))X.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts");if(!Zx.test($)){let J=$.split("").filter((Q)=>!/[A-Za-z0-9._-]/.test(Q)).filter((Q,Y,z)=>z.indexOf(Q)===Y);return X.push(`Tool name contains invalid characters: ${J.map((Q)=>`"${Q}"`).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:X}}return{isValid:!0,warnings:X}}function Rx($,X){if(X.length>0){console.warn(`Tool name validation warning for "${$}":`);for(let J of X)console.warn(` - ${J}`);console.warn("Tool registration will proceed, but this may cause compatibility issues."),console.warn("Consider updating the tool name to conform to the MCP tool naming standard."),console.warn("See SEP: Specify Format for Tool Names (https://github.com/modelcontextprotocol/modelcontextprotocol/issues/986) for more details.")}}function RU($){let X=Ex($);return Rx($,X.warnings),X.isValid}class SU{constructor($){this._mcpServer=$}registerToolTask($,X,J){let Q={taskSupport:"required",...X.execution};if(Q.taskSupport==="forbidden")throw Error(`Cannot register task-based tool '${$}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool($,X.title,X.description,X.inputSchema,X.outputSchema,X.annotations,Q,X._meta,J)}}class CU{constructor($,X){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new ZU($,X)}get experimental(){if(!this._experimental)this._experimental={tasks:new SU(this)};return this._experimental}async connect($){return await this.server.connect($)}async close(){await this.server.close()}setToolRequestHandlers(){if(this._toolHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(UQ)),this.server.assertCanSetRequestHandler(t4(x0)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(UQ,()=>({tools:Object.entries(this._registeredTools).filter(([,$])=>$.enabled).map(([$,X])=>{let J={name:$,title:X.title,description:X.description,inputSchema:(()=>{let Q=E0(X.inputSchema);return Q?L3(Q,{strictUnions:!0,pipeStrategy:"input"}):Sx})(),annotations:X.annotations,execution:X.execution,_meta:X._meta};if(X.outputSchema){let Q=E0(X.outputSchema);if(Q)J.outputSchema=L3(Q,{strictUnions:!0,pipeStrategy:"output"})}return J})})),this.server.setRequestHandler(x0,async($,X)=>{try{let J=this._registeredTools[$.params.name];if(!J)throw new g(m.InvalidParams,`Tool ${$.params.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Tool ${$.params.name} disabled`);let Q=!!$.params.task,Y=J.execution?.taskSupport,z="createTask"in J.handler;if((Y==="required"||Y==="optional")&&!z)throw new g(m.InternalError,`Tool ${$.params.name} has taskSupport '${Y}' but was not registered with registerToolTask`);if(Y==="required"&&!Q)throw new g(m.MethodNotFound,`Tool ${$.params.name} requires task augmentation (taskSupport: 'required')`);if(Y==="optional"&&!Q&&z)return await this.handleAutomaticTaskPolling(J,$,X);let W=await this.validateToolInput(J,$.params.arguments,$.params.name),G=await this.executeToolHandler(J,W,X);if(Q)return G;return await this.validateToolOutput(J,G,$.params.name),G}catch(J){if(J instanceof g){if(J.code===m.UrlElicitationRequired)throw J}return this.createToolError(J instanceof Error?J.message:String(J))}}),this._toolHandlersInitialized=!0}createToolError($){return{content:[{type:"text",text:$}],isError:!0}}async validateToolInput($,X,J){if(!$.inputSchema)return;let Y=E0($.inputSchema)??$.inputSchema,z=await R7(Y,X);if(!z.success){let W="error"in z?z.error:"Unknown error",G=S7(W);throw new g(m.InvalidParams,`Input validation error: Invalid arguments for tool ${J}: ${G}`)}return z.data}async validateToolOutput($,X,J){if(!$.outputSchema)return;if(!("content"in X))return;if(X.isError)return;if(!X.structuredContent)throw new g(m.InvalidParams,`Output validation error: Tool ${J} has an output schema but no structured content was provided`);let Q=E0($.outputSchema),Y=await R7(Q,X.structuredContent);if(!Y.success){let z="error"in Y?Y.error:"Unknown error",W=S7(z);throw new g(m.InvalidParams,`Output validation error: Invalid structured content for tool ${J}: ${W}`)}}async executeToolHandler($,X,J){let Q=$.handler;if("createTask"in Q){if(!J.taskStore)throw Error("No task store provided.");let z={...J,taskStore:J.taskStore};if($.inputSchema)return await Promise.resolve(Q.createTask(X,z));else return await Promise.resolve(Q.createTask(z))}if($.inputSchema)return await Promise.resolve(Q(X,J));else return await Promise.resolve(Q(J))}async handleAutomaticTaskPolling($,X,J){if(!J.taskStore)throw Error("No task store provided for task-capable tool.");let Q=await this.validateToolInput($,X.params.arguments,X.params.name),Y=$.handler,z={...J,taskStore:J.taskStore},W=Q?await Promise.resolve(Y.createTask(Q,z)):await Promise.resolve(Y.createTask(z)),G=W.task.taskId,U=W.task,H=U.pollInterval??5000;while(U.status!=="completed"&&U.status!=="failed"&&U.status!=="cancelled"){await new Promise((V)=>setTimeout(V,H));let K=await J.taskStore.getTask(G);if(!K)throw new g(m.InternalError,`Task ${G} not found during polling`);U=K}return await J.taskStore.getTaskResult(G)}setCompletionRequestHandler(){if(this._completionHandlerInitialized)return;this.server.assertCanSetRequestHandler(t4(KQ)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(KQ,async($)=>{switch($.params.ref.type){case"ref/prompt":return RV($),this.handlePromptCompletion($,$.params.ref);case"ref/resource":return SV($),this.handleResourceCompletion($,$.params.ref);default:throw new g(m.InvalidParams,`Invalid completion reference: ${$.params.ref}`)}}),this._completionHandlerInitialized=!0}async handlePromptCompletion($,X){let J=this._registeredPrompts[X.name];if(!J)throw new g(m.InvalidParams,`Prompt ${X.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Prompt ${X.name} disabled`);if(!J.argsSchema)return i9;let Y=h4(J.argsSchema)?.[$.params.argument.name];if(!EU(Y))return i9;let z=eD(Y);if(!z)return i9;let W=await z($.params.argument.value,$.params.context);return XL(W)}async handleResourceCompletion($,X){let J=Object.values(this._registeredResourceTemplates).find((z)=>z.resourceTemplate.uriTemplate.toString()===X.uri);if(!J){if(this._registeredResources[X.uri])return i9;throw new g(m.InvalidParams,`Resource template ${$.params.ref.uri} not found`)}let Q=J.resourceTemplate.completeCallback($.params.argument.name);if(!Q)return i9;let Y=await Q($.params.argument.value,$.params.context);return XL(Y)}setResourceRequestHandlers(){if(this._resourceHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(YQ)),this.server.assertCanSetRequestHandler(t4(QQ)),this.server.assertCanSetRequestHandler(t4(zQ)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(YQ,async($,X)=>{let J=Object.entries(this._registeredResources).filter(([Y,z])=>z.enabled).map(([Y,z])=>({uri:Y,name:z.name,...z.metadata})),Q=[];for(let Y of Object.values(this._registeredResourceTemplates)){if(!Y.resourceTemplate.listCallback)continue;let z=await Y.resourceTemplate.listCallback(X);for(let W of z.resources)Q.push({...Y.metadata,...W})}return{resources:[...J,...Q]}}),this.server.setRequestHandler(QQ,async()=>{return{resourceTemplates:Object.entries(this._registeredResourceTemplates).map(([X,J])=>({name:X,uriTemplate:J.resourceTemplate.uriTemplate.toString(),...J.metadata}))}}),this.server.setRequestHandler(zQ,async($,X)=>{let J=new URL($.params.uri),Q=this._registeredResources[J.toString()];if(Q){if(!Q.enabled)throw new g(m.InvalidParams,`Resource ${J} disabled`);return Q.readCallback(J,X)}for(let Y of Object.values(this._registeredResourceTemplates)){let z=Y.resourceTemplate.uriTemplate.match(J.toString());if(z)return Y.readCallback(J,z,X)}throw new g(m.InvalidParams,`Resource ${J} not found`)}),this._resourceHandlersInitialized=!0}setPromptRequestHandlers(){if(this._promptHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(WQ)),this.server.assertCanSetRequestHandler(t4(GQ)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(WQ,()=>({prompts:Object.entries(this._registeredPrompts).filter(([,$])=>$.enabled).map(([$,X])=>{return{name:$,title:X.title,description:X.description,arguments:X.argsSchema?Cx(X.argsSchema):void 0}})})),this.server.setRequestHandler(GQ,async($,X)=>{let J=this._registeredPrompts[$.params.name];if(!J)throw new g(m.InvalidParams,`Prompt ${$.params.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Prompt ${$.params.name} disabled`);if(J.argsSchema){let Q=E0(J.argsSchema),Y=await R7(Q,$.params.arguments);if(!Y.success){let G="error"in Y?Y.error:"Unknown error",U=S7(G);throw new g(m.InvalidParams,`Invalid arguments for prompt ${$.params.name}: ${U}`)}let z=Y.data,W=J.callback;return await Promise.resolve(W(z,X))}else{let Q=J.callback;return await Promise.resolve(Q(X))}}),this._promptHandlersInitialized=!0}resource($,X,...J){let Q;if(typeof J[0]==="object")Q=J.shift();let Y=J[0];if(typeof X==="string"){if(this._registeredResources[X])throw Error(`Resource ${X} is already registered`);let z=this._createRegisteredResource($,void 0,X,Q,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),z}else{if(this._registeredResourceTemplates[$])throw Error(`Resource template ${$} is already registered`);let z=this._createRegisteredResourceTemplate($,void 0,X,Q,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),z}}registerResource($,X,J,Q){if(typeof X==="string"){if(this._registeredResources[X])throw Error(`Resource ${X} is already registered`);let Y=this._createRegisteredResource($,J.title,X,J,Q);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),Y}else{if(this._registeredResourceTemplates[$])throw Error(`Resource template ${$} is already registered`);let Y=this._createRegisteredResourceTemplate($,J.title,X,J,Q);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),Y}}_createRegisteredResource($,X,J,Q,Y){let z={name:$,title:X,metadata:Q,readCallback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({uri:null}),update:(W)=>{if(typeof W.uri<"u"&&W.uri!==J){if(delete this._registeredResources[J],W.uri)this._registeredResources[W.uri]=z}if(typeof W.name<"u")z.name=W.name;if(typeof W.title<"u")z.title=W.title;if(typeof W.metadata<"u")z.metadata=W.metadata;if(typeof W.callback<"u")z.readCallback=W.callback;if(typeof W.enabled<"u")z.enabled=W.enabled;this.sendResourceListChanged()}};return this._registeredResources[J]=z,z}_createRegisteredResourceTemplate($,X,J,Q,Y){let z={resourceTemplate:J,title:X,metadata:Q,readCallback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(U)=>{if(typeof U.name<"u"&&U.name!==$){if(delete this._registeredResourceTemplates[$],U.name)this._registeredResourceTemplates[U.name]=z}if(typeof U.title<"u")z.title=U.title;if(typeof U.template<"u")z.resourceTemplate=U.template;if(typeof U.metadata<"u")z.metadata=U.metadata;if(typeof U.callback<"u")z.readCallback=U.callback;if(typeof U.enabled<"u")z.enabled=U.enabled;this.sendResourceListChanged()}};this._registeredResourceTemplates[$]=z;let W=J.uriTemplate.variableNames;if(Array.isArray(W)&&W.some((U)=>!!J.completeCallback(U)))this.setCompletionRequestHandler();return z}_createRegisteredPrompt($,X,J,Q,Y){let z={title:X,description:J,argsSchema:Q===void 0?void 0:Z1(Q),callback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(W)=>{if(typeof W.name<"u"&&W.name!==$){if(delete this._registeredPrompts[$],W.name)this._registeredPrompts[W.name]=z}if(typeof W.title<"u")z.title=W.title;if(typeof W.description<"u")z.description=W.description;if(typeof W.argsSchema<"u")z.argsSchema=Z1(W.argsSchema);if(typeof W.callback<"u")z.callback=W.callback;if(typeof W.enabled<"u")z.enabled=W.enabled;this.sendPromptListChanged()}};if(this._registeredPrompts[$]=z,Q){if(Object.values(Q).some((G)=>{let U=G instanceof F6?G._def?.innerType:G;return EU(U)}))this.setCompletionRequestHandler()}return z}_createRegisteredTool($,X,J,Q,Y,z,W,G,U){RU($);let H={title:X,description:J,inputSchema:$L(Q),outputSchema:$L(Y),annotations:z,execution:W,_meta:G,handler:U,enabled:!0,disable:()=>H.update({enabled:!1}),enable:()=>H.update({enabled:!0}),remove:()=>H.update({name:null}),update:(K)=>{if(typeof K.name<"u"&&K.name!==$){if(typeof K.name==="string")RU(K.name);if(delete this._registeredTools[$],K.name)this._registeredTools[K.name]=H}if(typeof K.title<"u")H.title=K.title;if(typeof K.description<"u")H.description=K.description;if(typeof K.paramsSchema<"u")H.inputSchema=Z1(K.paramsSchema);if(typeof K.outputSchema<"u")H.outputSchema=Z1(K.outputSchema);if(typeof K.callback<"u")H.handler=K.callback;if(typeof K.annotations<"u")H.annotations=K.annotations;if(typeof K._meta<"u")H._meta=K._meta;if(typeof K.enabled<"u")H.enabled=K.enabled;this.sendToolListChanged()}};return this._registeredTools[$]=H,this.setToolRequestHandlers(),this.sendToolListChanged(),H}tool($,...X){if(this._registeredTools[$])throw Error(`Tool ${$} is already registered`);let J,Q,Y,z;if(typeof X[0]==="string")J=X.shift();if(X.length>1){let G=X[0];if(vU(G)){if(Q=X.shift(),X.length>1&&typeof X[0]==="object"&&X[0]!==null&&!vU(X[0]))z=X.shift()}else if(typeof G==="object"&&G!==null)z=X.shift()}let W=X[0];return this._createRegisteredTool($,void 0,J,Q,Y,z,{taskSupport:"forbidden"},void 0,W)}registerTool($,X,J){if(this._registeredTools[$])throw Error(`Tool ${$} is already registered`);let{title:Q,description:Y,inputSchema:z,outputSchema:W,annotations:G,_meta:U}=X;return this._createRegisteredTool($,Q,Y,z,W,G,{taskSupport:"forbidden"},U,J)}prompt($,...X){if(this._registeredPrompts[$])throw Error(`Prompt ${$} is already registered`);let J;if(typeof X[0]==="string")J=X.shift();let Q;if(X.length>1)Q=X.shift();let Y=X[0],z=this._createRegisteredPrompt($,void 0,J,Q,Y);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),z}registerPrompt($,X,J){if(this._registeredPrompts[$])throw Error(`Prompt ${$} is already registered`);let{title:Q,description:Y,argsSchema:z}=X,W=this._createRegisteredPrompt($,Q,Y,z,J);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),W}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage($,X){return this.server.sendLoggingMessage($,X)}sendResourceListChanged(){if(this.isConnected())this.server.sendResourceListChanged()}sendToolListChanged(){if(this.isConnected())this.server.sendToolListChanged()}sendPromptListChanged(){if(this.isConnected())this.server.sendPromptListChanged()}}var Sx={type:"object",properties:{}};function JL($){return $!==null&&typeof $==="object"&&"parse"in $&&typeof $.parse==="function"&&"safeParse"in $&&typeof $.safeParse==="function"}function vx($){return"_def"in $||"_zod"in $||JL($)}function vU($){if(typeof $!=="object"||$===null)return!1;if(vx($))return!1;if(Object.keys($).length===0)return!0;return Object.values($).some(JL)}function $L($){if(!$)return;if(vU($))return Z1($);return $}function Cx($){let X=h4($);if(!X)return[];return Object.entries(X).map(([J,Q])=>{let Y=RN(Q),z=SN(Q);return{name:J,description:Y,required:!z}})}function t4($){let J=h4($)?.method;if(!J)throw Error("Schema is missing a method literal");let Q=v7(J);if(typeof Q==="string")return Q;throw Error("Schema method literal must be a string")}function XL($){return{completion:{values:$.slice(0,100),total:$.length,hasMore:$.length>100}}}var i9={completion:{values:[],hasMore:!1}};function kx($,X,J,Q,Y){let z={};if(Y?.searchHint)z["anthropic/searchHint"]=Y.searchHint;if(Y?.alwaysLoad)z["anthropic/alwaysLoad"]=!0;return{name:$,description:X,inputSchema:J,handler:Q,annotations:Y?.annotations,_meta:Object.keys(z).length>0?z:void 0}}function _x($){let X=new CU({name:$.name,version:$.version??"1.0.0"},{capabilities:{tools:$.tools?{}:void 0}});if($.tools)$.tools.forEach((J)=>{for(let Q of Object.values(J.inputSchema)){if(!xx(Q))continue;let Y=Q.description;if(Y&&!X6.has(Q))X6.add(Q,{description:Y})}X.registerTool(J.name,{description:J.description,inputSchema:J.inputSchema,annotations:J.annotations,_meta:J._meta},J.handler)});return{type:"sdk",name:$.name,instance:X}}function xx($){return typeof $==="object"&&$!==null&&"_zod"in $}function YL($){let X;return()=>X??=$()}var QL=15000,Tx=YL(()=>u4.object({session_id:u4.string(),ws_url:u4.string(),work_dir:u4.string().optional(),session_key:u4.string().optional()}));class r6 extends Error{constructor($){super($);this.name="DirectConnectError"}}class WL{options;ws;sessionId;workDir;abortController;readyState=!1;closed=!1;exitError;messages=new K1;readyPromise;readyResolve;readyReject;abortHandler;partialLine="";constructor($){this.options=$;this.abortController=$.abortController??new AbortController,this.readyPromise=new Promise((X,J)=>{this.readyResolve=X,this.readyReject=J}),this.readyPromise.catch(()=>{}),this.initialize()}get ready(){return this.readyPromise}getSessionId(){return this.sessionId}getWorkDir(){return this.workDir}async initialize(){if(this.abortController.signal.aborted){this.failInit(new a$("Connection aborted"));return}this.abortHandler=()=>{this.close(),this.exitError=new a$("Connection aborted by user")},this.abortController.signal.addEventListener("abort",this.abortHandler);let $;try{let Y=await fx(this.options);this.sessionId=Y.sessionId,this.workDir=Y.workDir,$=Y.wsUrl}catch(Y){this.failInit(KK(Y));return}if(this.closed){if(this.options.deleteSessionOnClose&&this.sessionId)zL(this.options.serverUrl,this.sessionId,this.options.authToken);return}let X={};if(this.options.authToken)X.authorization=`Bearer ${this.options.authToken}`;let J=new WebSocket($,{headers:X});this.ws=J;let Q=setTimeout((Y,z)=>{if(!Y.readyState){z.close();let W=new r6(`WebSocket connection timeout after ${QL}ms`);Y.exitError=W,Y.readyReject?.(W)}},QL,this,J);J.addEventListener("open",()=>{clearTimeout(Q),this.readyState=!0,s$(`[DirectConnectTransport] Connected to ${this.options.serverUrl}, session=${this.sessionId}`),this.readyResolve?.()}),J.addEventListener("message",(Y)=>{let z=typeof Y.data==="string"?Y.data:"",G=(this.partialLine+z).split(`
|
|
104
|
-
`)
|
|
103
|
+
]`;continue}if(Y+=Q[U],Q[U]==="\\")z=!0;else if(W&&Q[U]==="]")W=!1;else if(!W&&Q[U]==="[")W=!0}try{new RegExp(Y)}catch{return console.warn(`Could not convert regex pattern at ${X.currentPath.join("/")} to a flag-independent form! Falling back to the flag-ignorant source`),$.source}return Y}function wQ($,X){if(X.target==="openAi")console.warn("Warning: OpenAI may not support records in schemas! Try an array of key-value pairs instead.");if(X.target==="openApi3"&&$.keyType?._def.typeName===P.ZodEnum)return{type:"object",required:$.keyType._def.values,properties:$.keyType._def.values.reduce((Q,Y)=>({...Q,[Y]:c($.valueType._def,{...X,currentPath:[...X.currentPath,"properties",Y]})??I$(X)}),{}),additionalProperties:X.rejectedAdditionalProperties};let J={type:"object",additionalProperties:c($.valueType._def,{...X,currentPath:[...X.currentPath,"additionalProperties"]})??X.allowedAdditionalProperties};if(X.target==="openApi3")return J;if($.keyType?._def.typeName===P.ZodString&&$.keyType._def.checks?.length){let{type:Q,...Y}=OQ($.keyType._def,X);return{...J,propertyNames:Y}}else if($.keyType?._def.typeName===P.ZodEnum)return{...J,propertyNames:{enum:$.keyType._def.values}};else if($.keyType?._def.typeName===P.ZodBranded&&$.keyType._def.type._def.typeName===P.ZodString&&$.keyType._def.type._def.checks?.length){let{type:Q,...Y}=VQ($.keyType._def,X);return{...J,propertyNames:Y}}return J}function iV($,X){if(X.mapStrategy==="record")return wQ($,X);let J=c($.keyType._def,{...X,currentPath:[...X.currentPath,"items","items","0"]})||I$(X),Q=c($.valueType._def,{...X,currentPath:[...X.currentPath,"items","items","1"]})||I$(X);return{type:"array",maxItems:125,items:{type:"array",items:[J,Q],minItems:2,maxItems:2}}}function nV($){let X=$.values,Q=Object.keys($.values).filter((z)=>{return typeof X[X[z]]!=="number"}).map((z)=>X[z]),Y=Array.from(new Set(Q.map((z)=>typeof z)));return{type:Y.length===1?Y[0]==="string"?"string":"number":["string","number"],enum:Q}}function dV($){return $.target==="openAi"?void 0:{not:I$({...$,currentPath:[...$.currentPath,"not"]})}}function rV($){return $.target==="openApi3"?{enum:["null"],nullable:!0}:{type:"null"}}var M9={ZodString:"string",ZodNumber:"number",ZodBigInt:"integer",ZodBoolean:"boolean",ZodNull:"null"};function tV($,X){if(X.target==="openApi3")return oV($,X);let J=$.options instanceof Map?Array.from($.options.values()):$.options;if(J.every((Q)=>(Q._def.typeName in M9)&&(!Q._def.checks||!Q._def.checks.length))){let Q=J.reduce((Y,z)=>{let W=M9[z._def.typeName];return W&&!Y.includes(W)?[...Y,W]:Y},[]);return{type:Q.length>1?Q:Q[0]}}else if(J.every((Q)=>Q._def.typeName==="ZodLiteral"&&!Q.description)){let Q=J.reduce((Y,z)=>{let W=typeof z._def.value;switch(W){case"string":case"number":case"boolean":return[...Y,W];case"bigint":return[...Y,"integer"];case"object":if(z._def.value===null)return[...Y,"null"];case"symbol":case"undefined":case"function":default:return Y}},[]);if(Q.length===J.length){let Y=Q.filter((z,W,G)=>G.indexOf(z)===W);return{type:Y.length>1?Y:Y[0],enum:J.reduce((z,W)=>{return z.includes(W._def.value)?z:[...z,W._def.value]},[])}}}else if(J.every((Q)=>Q._def.typeName==="ZodEnum"))return{type:"string",enum:J.reduce((Q,Y)=>[...Q,...Y._def.values.filter((z)=>!Q.includes(z))],[])};return oV($,X)}var oV=($,X)=>{let J=($.options instanceof Map?Array.from($.options.values()):$.options).map((Q,Y)=>c(Q._def,{...X,currentPath:[...X.currentPath,"anyOf",`${Y}`]})).filter((Q)=>!!Q&&(!X.strictUnions||typeof Q==="object"&&Object.keys(Q).length>0));return J.length?{anyOf:J}:void 0};function aV($,X){if(["ZodString","ZodNumber","ZodBigInt","ZodBoolean","ZodNull"].includes($.innerType._def.typeName)&&(!$.innerType._def.checks||!$.innerType._def.checks.length)){if(X.target==="openApi3")return{type:M9[$.innerType._def.typeName],nullable:!0};return{type:[M9[$.innerType._def.typeName],"null"]}}if(X.target==="openApi3"){let Q=c($.innerType._def,{...X,currentPath:[...X.currentPath]});if(Q&&"$ref"in Q)return{allOf:[Q],nullable:!0};return Q&&{...Q,nullable:!0}}let J=c($.innerType._def,{...X,currentPath:[...X.currentPath,"anyOf","0"]});return J&&{anyOf:[J,{type:"null"}]}}function sV($,X){let J={type:"number"};if(!$.checks)return J;for(let Q of $.checks)switch(Q.kind){case"int":J.type="integer",O3(J,"type",Q.message,X);break;case"min":if(X.target==="jsonSchema7")if(Q.inclusive)J$(J,"minimum",Q.value,Q.message,X);else J$(J,"exclusiveMinimum",Q.value,Q.message,X);else{if(!Q.inclusive)J.exclusiveMinimum=!0;J$(J,"minimum",Q.value,Q.message,X)}break;case"max":if(X.target==="jsonSchema7")if(Q.inclusive)J$(J,"maximum",Q.value,Q.message,X);else J$(J,"exclusiveMaximum",Q.value,Q.message,X);else{if(!Q.inclusive)J.exclusiveMaximum=!0;J$(J,"maximum",Q.value,Q.message,X)}break;case"multipleOf":J$(J,"multipleOf",Q.value,Q.message,X);break}return J}function eV($,X){let J=X.target==="openAi",Q={type:"object",properties:{}},Y=[],z=$.shape();for(let G in z){let U=z[G];if(U===void 0||U._def===void 0)continue;let H=VZ(U);if(H&&J){if(U._def.typeName==="ZodOptional")U=U._def.innerType;if(!U.isNullable())U=U.nullable();H=!1}let K=c(U._def,{...X,currentPath:[...X.currentPath,"properties",G],propertyPath:[...X.currentPath,"properties",G]});if(K===void 0)continue;if(Q.properties[G]=K,!H)Y.push(G)}if(Y.length)Q.required=Y;let W=NZ($,X);if(W!==void 0)Q.additionalProperties=W;return Q}function NZ($,X){if($.catchall._def.typeName!=="ZodNever")return c($.catchall._def,{...X,currentPath:[...X.currentPath,"additionalProperties"]});switch($.unknownKeys){case"passthrough":return X.allowedAdditionalProperties;case"strict":return X.rejectedAdditionalProperties;case"strip":return X.removeAdditionalStrategy==="strict"?X.allowedAdditionalProperties:X.rejectedAdditionalProperties}}function VZ($){try{return $.isOptional()}catch{return!0}}var $O=($,X)=>{if(X.currentPath.toString()===X.propertyPath?.toString())return c($.innerType._def,X);let J=c($.innerType._def,{...X,currentPath:[...X.currentPath,"anyOf","1"]});return J?{anyOf:[{not:I$(X)},J]}:I$(X)};var XO=($,X)=>{if(X.pipeStrategy==="input")return c($.in._def,X);else if(X.pipeStrategy==="output")return c($.out._def,X);let J=c($.in._def,{...X,currentPath:[...X.currentPath,"allOf","0"]}),Q=c($.out._def,{...X,currentPath:[...X.currentPath,"allOf",J?"1":"0"]});return{allOf:[J,Q].filter((Y)=>Y!==void 0)}};function JO($,X){return c($.type._def,X)}function YO($,X){let Q={type:"array",uniqueItems:!0,items:c($.valueType._def,{...X,currentPath:[...X.currentPath,"items"]})};if($.minSize)J$(Q,"minItems",$.minSize.value,$.minSize.message,X);if($.maxSize)J$(Q,"maxItems",$.maxSize.value,$.maxSize.message,X);return Q}function QO($,X){if($.rest)return{type:"array",minItems:$.items.length,items:$.items.map((J,Q)=>c(J._def,{...X,currentPath:[...X.currentPath,"items",`${Q}`]})).reduce((J,Q)=>Q===void 0?J:[...J,Q],[]),additionalItems:c($.rest._def,{...X,currentPath:[...X.currentPath,"additionalItems"]})};else return{type:"array",minItems:$.items.length,maxItems:$.items.length,items:$.items.map((J,Q)=>c(J._def,{...X,currentPath:[...X.currentPath,"items",`${Q}`]})).reduce((J,Q)=>Q===void 0?J:[...J,Q],[])}}function zO($){return{not:I$($)}}function WO($){return I$($)}var GO=($,X)=>{return c($.innerType._def,X)};var UO=($,X,J)=>{switch(X){case P.ZodString:return OQ($,J);case P.ZodNumber:return sV($,J);case P.ZodObject:return eV($,J);case P.ZodBigInt:return yV($,J);case P.ZodBoolean:return fV();case P.ZodDate:return w3($,J);case P.ZodUndefined:return zO(J);case P.ZodNull:return rV(J);case P.ZodArray:return TV($,J);case P.ZodUnion:case P.ZodDiscriminatedUnion:return tV($,J);case P.ZodIntersection:return lV($,J);case P.ZodTuple:return QO($,J);case P.ZodRecord:return wQ($,J);case P.ZodLiteral:return cV($,J);case P.ZodEnum:return mV($);case P.ZodNativeEnum:return nV($);case P.ZodNullable:return aV($,J);case P.ZodOptional:return $O($,J);case P.ZodMap:return iV($,J);case P.ZodSet:return YO($,J);case P.ZodLazy:return()=>$.getter()._def;case P.ZodPromise:return JO($,J);case P.ZodNaN:case P.ZodNever:return dV(J);case P.ZodEffects:return uV($,J);case P.ZodAny:return I$(J);case P.ZodUnknown:return WO(J);case P.ZodDefault:return hV($,J);case P.ZodBranded:return VQ($,J);case P.ZodReadonly:return GO($,J);case P.ZodCatch:return gV($,J);case P.ZodPipeline:return XO($,J);case P.ZodFunction:case P.ZodVoid:case P.ZodSymbol:return;default:return((Q)=>{return})(X)}};function c($,X,J=!1){let Q=X.seen.get($);if(X.override){let G=X.override?.($,X,Q,J);if(G!==kV)return G}if(Q&&!J){let G=OZ(Q,X);if(G!==void 0)return G}let Y={def:$,path:X.currentPath,jsonSchema:void 0};X.seen.set($,Y);let z=UO($,$.typeName,X),W=typeof z==="function"?c(z(),X):z;if(W)wZ($,X,W);if(X.postProcess){let G=X.postProcess(W,$,X);return Y.jsonSchema=W,G}return Y.jsonSchema=W,W}var OZ=($,X)=>{switch(X.$refStrategy){case"root":return{$ref:$.path.join("/")};case"relative":return{$ref:NQ(X.currentPath,$.path)};case"none":case"seen":{if($.path.length<X.currentPath.length&&$.path.every((J,Q)=>X.currentPath[Q]===J))return console.warn(`Recursive reference detected at ${X.currentPath.join("/")}! Defaulting to any`),I$(X);return X.$refStrategy==="seen"?I$(X):void 0}}},wZ=($,X,J)=>{if($.description){if(J.description=$.description,X.markdownDescription)J.markdownDescription=$.description}return J};var D3=($,X)=>{let J=xV(X),Q=typeof X==="object"&&X.definitions?Object.entries(X.definitions).reduce((U,[H,K])=>({...U,[H]:c(K._def,{...J,currentPath:[...J.basePath,J.definitionPath,H]},!0)??I$(J)}),{}):void 0,Y=typeof X==="string"?X:X?.nameStrategy==="title"?void 0:X?.name,z=c($._def,Y===void 0?J:{...J,currentPath:[...J.basePath,J.definitionPath,Y]},!1)??I$(J),W=typeof X==="object"&&X.name!==void 0&&X.nameStrategy==="title"?X.name:void 0;if(W!==void 0)z.title=W;if(J.flags.hasReferencedOpenAiAnyType){if(!Q)Q={};if(!Q[J.openAiAnyTypeName])Q[J.openAiAnyTypeName]={type:["string","number","integer","boolean","array","null"],items:{$ref:J.$refStrategy==="relative"?"1":[...J.basePath,J.definitionPath,J.openAiAnyTypeName].join("/")}}}let G=Y===void 0?Q?{...z,[J.definitionPath]:Q}:z:{$ref:[...J.$refStrategy==="relative"?[]:J.basePath,J.definitionPath,Y].join("/"),[J.definitionPath]:{...Q,[Y]:z}};if(J.target==="jsonSchema7")G.$schema="http://json-schema.org/draft-07/schema#";else if(J.target==="jsonSchema2019-09"||J.target==="openAi")G.$schema="https://json-schema.org/draft/2019-09/schema#";if(J.target==="openAi"&&(("anyOf"in G)||("oneOf"in G)||("allOf"in G)||("type"in G)&&Array.isArray(G.type)))console.warn("Warning: OpenAI may not support schemas with unions as roots! Try wrapping it in an object property.");return G};function BZ($){if(!$)return"draft-7";if($==="jsonSchema7"||$==="draft-7")return"draft-7";if($==="jsonSchema2019-09"||$==="draft-2020-12")return"draft-2020-12";return"draft-7"}function L3($,X){if(I6($))return Z0($,{target:BZ(X?.target),io:X?.pipeStrategy??"input"});return D3($,{strictUnions:X?.strictUnions??!0,pipeStrategy:X?.pipeStrategy??"input"})}function j3($){let J=h4($)?.method;if(!J)throw Error("Schema is missing a method literal");let Q=v7(J);if(typeof Q!=="string")throw Error("Schema method literal must be a string");return Q}function F3($,X){let J=g4($,X);if(!J.success)throw J.error;return J.data}var qZ=60000;class M3{constructor($){if(this._options=$,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(r7,(X)=>{this._oncancel(X)}),this.setNotificationHandler(t7,(X)=>{this._onprogress(X)}),this.setRequestHandler(o7,(X)=>({})),this._taskStore=$?.taskStore,this._taskMessageQueue=$?.taskMessageQueue,this._taskStore)this.setRequestHandler(a7,async(X,J)=>{let Q=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Q)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return{...Q}}),this.setRequestHandler(e7,async(X,J)=>{let Q=async()=>{let Y=X.params.taskId;if(this._taskMessageQueue){let W;while(W=await this._taskMessageQueue.dequeue(Y,J.sessionId)){if(W.type==="response"||W.type==="error"){let G=W.message,U=G.id,H=this._requestResolvers.get(U);if(H)if(this._requestResolvers.delete(U),W.type==="response")H(G);else{let K=G,V=new g(K.error.code,K.error.message,K.error.data);H(V)}else{let K=W.type==="response"?"Response":"Error";this._onerror(Error(`${K} handler missing for request ${U}`))}continue}await this._transport?.send(W.message,{relatedRequestId:J.requestId})}}let z=await this._taskStore.getTask(Y,J.sessionId);if(!z)throw new g(m.InvalidParams,`Task not found: ${Y}`);if(!l4(z.status))return await this._waitForTaskUpdate(Y,J.signal),await Q();if(l4(z.status)){let W=await this._taskStore.getTaskResult(Y,J.sessionId);return this._clearTaskQueue(Y),{...W,_meta:{...W._meta,[m4]:{taskId:Y}}}}return await Q()};return await Q()}),this.setRequestHandler($Q,async(X,J)=>{try{let{tasks:Q,nextCursor:Y}=await this._taskStore.listTasks(X.params?.cursor,J.sessionId);return{tasks:Q,nextCursor:Y,_meta:{}}}catch(Q){throw new g(m.InvalidParams,`Failed to list tasks: ${Q instanceof Error?Q.message:String(Q)}`)}}),this.setRequestHandler(JQ,async(X,J)=>{try{let Q=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Q)throw new g(m.InvalidParams,`Task not found: ${X.params.taskId}`);if(l4(Q.status))throw new g(m.InvalidParams,`Cannot cancel task in terminal status: ${Q.status}`);await this._taskStore.updateTaskStatus(X.params.taskId,"cancelled","Client cancelled task execution.",J.sessionId),this._clearTaskQueue(X.params.taskId);let Y=await this._taskStore.getTask(X.params.taskId,J.sessionId);if(!Y)throw new g(m.InvalidParams,`Task not found after cancellation: ${X.params.taskId}`);return{_meta:{},...Y}}catch(Q){if(Q instanceof g)throw Q;throw new g(m.InvalidRequest,`Failed to cancel task: ${Q instanceof Error?Q.message:String(Q)}`)}})}async _oncancel($){if(!$.params.requestId)return;this._requestHandlerAbortControllers.get($.params.requestId)?.abort($.params.reason)}_setupTimeout($,X,J,Q,Y=!1){this._timeoutInfo.set($,{timeoutId:setTimeout(Q,X),startTime:Date.now(),timeout:X,maxTotalTimeout:J,resetTimeoutOnProgress:Y,onTimeout:Q})}_resetTimeout($){let X=this._timeoutInfo.get($);if(!X)return!1;let J=Date.now()-X.startTime;if(X.maxTotalTimeout&&J>=X.maxTotalTimeout)throw this._timeoutInfo.delete($),g.fromError(m.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:X.maxTotalTimeout,totalElapsed:J});return clearTimeout(X.timeoutId),X.timeoutId=setTimeout(X.onTimeout,X.timeout),!0}_cleanupTimeout($){let X=this._timeoutInfo.get($);if(X)clearTimeout(X.timeoutId),this._timeoutInfo.delete($)}async connect($){if(this._transport)throw Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=$;let X=this.transport?.onclose;this._transport.onclose=()=>{X?.(),this._onclose()};let J=this.transport?.onerror;this._transport.onerror=(Y)=>{J?.(Y),this._onerror(Y)};let Q=this._transport?.onmessage;this._transport.onmessage=(Y,z)=>{if(Q?.(Y,z),V9(Y)||FV(Y))this._onresponse(Y);else if(eG(Y))this._onrequest(Y,z);else if(jV(Y))this._onnotification(Y);else this._onerror(Error(`Unknown message type: ${JSON.stringify(Y)}`))},await this._transport.start()}_onclose(){let $=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let J of this._requestHandlerAbortControllers.values())J.abort();this._requestHandlerAbortControllers.clear();let X=g.fromError(m.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let J of $.values())J(X)}_onerror($){this.onerror?.($)}_onnotification($){let X=this._notificationHandlers.get($.method)??this.fallbackNotificationHandler;if(X===void 0)return;Promise.resolve().then(()=>X($)).catch((J)=>this._onerror(Error(`Uncaught error in notification handler: ${J}`)))}_onrequest($,X){let J=this._requestHandlers.get($.method)??this.fallbackRequestHandler,Q=this._transport,Y=$.params?._meta?.[m4]?.taskId;if(J===void 0){let H={jsonrpc:"2.0",id:$.id,error:{code:m.MethodNotFound,message:"Method not found"}};if(Y&&this._taskMessageQueue)this._enqueueTaskMessage(Y,{type:"error",message:H,timestamp:Date.now()},Q?.sessionId).catch((K)=>this._onerror(Error(`Failed to enqueue error response: ${K}`)));else Q?.send(H).catch((K)=>this._onerror(Error(`Failed to send an error response: ${K}`)));return}let z=new AbortController;this._requestHandlerAbortControllers.set($.id,z);let W=qV($.params)?$.params.task:void 0,G=this._taskStore?this.requestTaskStore($,Q?.sessionId):void 0,U={signal:z.signal,sessionId:Q?.sessionId,_meta:$.params?._meta,sendNotification:async(H)=>{if(z.signal.aborted)return;let K={relatedRequestId:$.id};if(Y)K.relatedTask={taskId:Y};await this.notification(H,K)},sendRequest:async(H,K,V)=>{if(z.signal.aborted)throw new g(m.ConnectionClosed,"Request was cancelled");let O={...V,relatedRequestId:$.id};if(Y&&!O.relatedTask)O.relatedTask={taskId:Y};let N=O.relatedTask?.taskId??Y;if(N&&G)await G.updateTaskStatus(N,"input_required");return await this.request(H,K,O)},authInfo:X?.authInfo,requestId:$.id,requestInfo:X?.requestInfo,taskId:Y,taskStore:G,taskRequestedTtl:W?.ttl,closeSSEStream:X?.closeSSEStream,closeStandaloneSSEStream:X?.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(W)this.assertTaskHandlerCapability($.method)}).then(()=>J($,U)).then(async(H)=>{if(z.signal.aborted)return;let K={result:H,jsonrpc:"2.0",id:$.id};if(Y&&this._taskMessageQueue)await this._enqueueTaskMessage(Y,{type:"response",message:K,timestamp:Date.now()},Q?.sessionId);else await Q?.send(K)},async(H)=>{if(z.signal.aborted)return;let K={jsonrpc:"2.0",id:$.id,error:{code:Number.isSafeInteger(H.code)?H.code:m.InternalError,message:H.message??"Internal error",...H.data!==void 0&&{data:H.data}}};if(Y&&this._taskMessageQueue)await this._enqueueTaskMessage(Y,{type:"error",message:K,timestamp:Date.now()},Q?.sessionId);else await Q?.send(K)}).catch((H)=>this._onerror(Error(`Failed to send response: ${H}`))).finally(()=>{this._requestHandlerAbortControllers.delete($.id)})}_onprogress($){let{progressToken:X,...J}=$.params,Q=Number(X),Y=this._progressHandlers.get(Q);if(!Y){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify($)}`));return}let z=this._responseHandlers.get(Q),W=this._timeoutInfo.get(Q);if(W&&z&&W.resetTimeoutOnProgress)try{this._resetTimeout(Q)}catch(G){this._responseHandlers.delete(Q),this._progressHandlers.delete(Q),this._cleanupTimeout(Q),z(G);return}Y(J)}_onresponse($){let X=Number($.id),J=this._requestResolvers.get(X);if(J){if(this._requestResolvers.delete(X),V9($))J($);else{let z=new g($.error.code,$.error.message,$.error.data);J(z)}return}let Q=this._responseHandlers.get(X);if(Q===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify($)}`));return}this._responseHandlers.delete(X),this._cleanupTimeout(X);let Y=!1;if(V9($)&&$.result&&typeof $.result==="object"){let z=$.result;if(z.task&&typeof z.task==="object"){let W=z.task;if(typeof W.taskId==="string")Y=!0,this._taskProgressTokens.set(W.taskId,X)}}if(!Y)this._progressHandlers.delete(X);if(V9($))Q($);else{let z=g.fromError($.error.code,$.error.message,$.error.data);Q(z)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream($,X,J){let{task:Q}=J??{};if(!Q){try{yield{type:"result",result:await this.request($,X,J)}}catch(z){yield{type:"error",error:z instanceof g?z:new g(m.InternalError,String(z))}}return}let Y;try{let z=await this.request($,k0,J);if(z.task)Y=z.task.taskId,yield{type:"taskCreated",task:z.task};else throw new g(m.InternalError,"Task creation did not return a task");while(!0){let W=await this.getTask({taskId:Y},J);if(yield{type:"taskStatus",task:W},l4(W.status)){if(W.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:Y},X,J)};else if(W.status==="failed")yield{type:"error",error:new g(m.InternalError,`Task ${Y} failed`)};else if(W.status==="cancelled")yield{type:"error",error:new g(m.InternalError,`Task ${Y} was cancelled`)};return}if(W.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:Y},X,J)};return}let G=W.pollInterval??this._options?.defaultTaskPollInterval??1000;await new Promise((U)=>setTimeout(U,G)),J?.signal?.throwIfAborted()}}catch(z){yield{type:"error",error:z instanceof g?z:new g(m.InternalError,String(z))}}}request($,X,J){let{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z,task:W,relatedTask:G}=J??{};return new Promise((U,H)=>{let K=(j)=>{H(j)};if(!this._transport){K(Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{if(this.assertCapabilityForMethod($.method),W)this.assertTaskCapability($.method)}catch(j){K(j);return}J?.signal?.throwIfAborted();let V=this._requestMessageId++,O={...$,jsonrpc:"2.0",id:V};if(J?.onprogress)this._progressHandlers.set(V,J.onprogress),O.params={...$.params,_meta:{...$.params?._meta||{},progressToken:V}};if(W)O.params={...O.params,task:W};if(G)O.params={...O.params,_meta:{...O.params?._meta||{},[m4]:G}};let N=(j)=>{this._responseHandlers.delete(V),this._progressHandlers.delete(V),this._cleanupTimeout(V),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:V,reason:String(j)}},{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z}).catch((b)=>this._onerror(Error(`Failed to send cancellation: ${b}`)));let I=j instanceof g?j:new g(m.RequestTimeout,String(j));H(I)};this._responseHandlers.set(V,(j)=>{if(J?.signal?.aborted)return;if(j instanceof Error)return H(j);try{let I=g4(X,j.result);if(!I.success)H(I.error);else U(I.data)}catch(I){H(I)}}),J?.signal?.addEventListener("abort",()=>{N(J?.signal?.reason)});let w=J?.timeout??qZ,B=()=>N(g.fromError(m.RequestTimeout,"Request timed out",{timeout:w}));this._setupTimeout(V,w,J?.maxTotalTimeout,B,J?.resetTimeoutOnProgress??!1);let L=G?.taskId;if(L){let j=(I)=>{let b=this._responseHandlers.get(V);if(b)b(I);else this._onerror(Error(`Response handler missing for side-channeled request ${V}`))};this._requestResolvers.set(V,j),this._enqueueTaskMessage(L,{type:"request",message:O,timestamp:Date.now()}).catch((I)=>{this._cleanupTimeout(V),H(I)})}else this._transport.send(O,{relatedRequestId:Q,resumptionToken:Y,onresumptiontoken:z}).catch((j)=>{this._cleanupTimeout(V),H(j)})})}async getTask($,X){return this.request({method:"tasks/get",params:$},s7,X)}async getTaskResult($,X,J){return this.request({method:"tasks/result",params:$},X,J)}async listTasks($,X){return this.request({method:"tasks/list",params:$},XQ,X)}async cancelTask($,X){return this.request({method:"tasks/cancel",params:$},IV,X)}async notification($,X){if(!this._transport)throw Error("Not connected");this.assertNotificationCapability($.method);let J=X?.relatedTask?.taskId;if(J){let W={...$,jsonrpc:"2.0",params:{...$.params,_meta:{...$.params?._meta||{},[m4]:X.relatedTask}}};await this._enqueueTaskMessage(J,{type:"notification",message:W,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes($.method)&&!$.params&&!X?.relatedRequestId&&!X?.relatedTask){if(this._pendingDebouncedNotifications.has($.method))return;this._pendingDebouncedNotifications.add($.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete($.method),!this._transport)return;let W={...$,jsonrpc:"2.0"};if(X?.relatedTask)W={...W,params:{...W.params,_meta:{...W.params?._meta||{},[m4]:X.relatedTask}}};this._transport?.send(W,X).catch((G)=>this._onerror(G))});return}let z={...$,jsonrpc:"2.0"};if(X?.relatedTask)z={...z,params:{...z.params,_meta:{...z.params?._meta||{},[m4]:X.relatedTask}}};await this._transport.send(z,X)}setRequestHandler($,X){let J=j3($);this.assertRequestHandlerCapability(J),this._requestHandlers.set(J,(Q,Y)=>{let z=F3($,Q);return Promise.resolve(X(z,Y))})}removeRequestHandler($){this._requestHandlers.delete($)}assertCanSetRequestHandler($){if(this._requestHandlers.has($))throw Error(`A request handler for ${$} already exists, which would be overridden`)}setNotificationHandler($,X){let J=j3($);this._notificationHandlers.set(J,(Q)=>{let Y=F3($,Q);return Promise.resolve(X(Y))})}removeNotificationHandler($){this._notificationHandlers.delete($)}_cleanupTaskProgressHandler($){let X=this._taskProgressTokens.get($);if(X!==void 0)this._progressHandlers.delete(X),this._taskProgressTokens.delete($)}async _enqueueTaskMessage($,X,J){if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let Q=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue($,X,J,Q)}async _clearTaskQueue($,X){if(this._taskMessageQueue){let J=await this._taskMessageQueue.dequeueAll($,X);for(let Q of J)if(Q.type==="request"&&eG(Q.message)){let Y=Q.message.id,z=this._requestResolvers.get(Y);if(z)z(new g(m.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(Y);else this._onerror(Error(`Resolver missing for request ${Y} during task ${$} cleanup`))}}}async _waitForTaskUpdate($,X){let J=this._options?.defaultTaskPollInterval??1000;try{let Q=await this._taskStore?.getTask($);if(Q?.pollInterval)J=Q.pollInterval}catch{}return new Promise((Q,Y)=>{if(X.aborted){Y(new g(m.InvalidRequest,"Request cancelled"));return}let z=setTimeout(Q,J);X.addEventListener("abort",()=>{clearTimeout(z),Y(new g(m.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore($,X){let J=this._taskStore;if(!J)throw Error("No task store configured");return{createTask:async(Q)=>{if(!$)throw Error("No request provided");return await J.createTask(Q,$.id,{method:$.method,params:$.params},X)},getTask:async(Q)=>{let Y=await J.getTask(Q,X);if(!Y)throw new g(m.InvalidParams,"Failed to retrieve task: Task not found");return Y},storeTaskResult:async(Q,Y,z)=>{await J.storeTaskResult(Q,Y,z,X);let W=await J.getTask(Q,X);if(W){let G=D9.parse({method:"notifications/tasks/status",params:W});if(await this.notification(G),l4(W.status))this._cleanupTaskProgressHandler(Q)}},getTaskResult:(Q)=>{return J.getTaskResult(Q,X)},updateTaskStatus:async(Q,Y,z)=>{let W=await J.getTask(Q,X);if(!W)throw new g(m.InvalidParams,`Task "${Q}" not found - it may have been cleaned up`);if(l4(W.status))throw new g(m.InvalidParams,`Cannot update task "${Q}" from terminal status "${W.status}" to "${Y}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await J.updateTaskStatus(Q,Y,z,X);let G=await J.getTask(Q,X);if(G){let U=D9.parse({method:"notifications/tasks/status",params:G});if(await this.notification(U),l4(G.status))this._cleanupTaskProgressHandler(Q)}},listTasks:(Q)=>{return J.listTasks(Q,X)}}}}function HO($){return $!==null&&typeof $==="object"&&!Array.isArray($)}function KO($,X){let J={...$};for(let Q in X){let Y=Q,z=X[Y];if(z===void 0)continue;let W=J[Y];if(HO(W)&&HO(z))J[Y]={...W,...z};else J[Y]=z}return J}var dD=hU(wU(),1),rD=hU(nD(),1);function Px(){let $=new dD.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return rD.default($),$}class bU{constructor($){this._ajv=$??Px()}getValidator($){let X="$id"in $&&typeof $.$id==="string"?this._ajv.getSchema($.$id)??this._ajv.compile($):this._ajv.compile($);return(J)=>{if(X(J))return{valid:!0,data:J,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(X.errors)}}}}class PU{constructor($){this._server=$}requestStream($,X,J){return this._server.requestStream($,X,J)}createMessageStream($,X){let J=this._server.getClientCapabilities();if(($.tools||$.toolChoice)&&!J?.sampling?.tools)throw Error("Client does not support sampling tools capability.");if($.messages.length>0){let Q=$.messages[$.messages.length-1],Y=Array.isArray(Q.content)?Q.content:[Q.content],z=Y.some((H)=>H.type==="tool_result"),W=$.messages.length>1?$.messages[$.messages.length-2]:void 0,G=W?Array.isArray(W.content)?W.content:[W.content]:[],U=G.some((H)=>H.type==="tool_use");if(z){if(Y.some((H)=>H.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!U)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(U){let H=new Set(G.filter((V)=>V.type==="tool_use").map((V)=>V.id)),K=new Set(Y.filter((V)=>V.type==="tool_result").map((V)=>V.toolUseId));if(H.size!==K.size||![...H].every((V)=>K.has(V)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}return this.requestStream({method:"sampling/createMessage",params:$},F9,X)}elicitInputStream($,X){let J=this._server.getClientCapabilities(),Q=$.mode??"form";switch(Q){case"url":{if(!J?.elicitation?.url)throw Error("Client does not support url elicitation.");break}case"form":{if(!J?.elicitation?.form)throw Error("Client does not support form elicitation.");break}}let Y=Q==="form"&&$.mode===void 0?{...$,mode:"form"}:$;return this.requestStream({method:"elicitation/create",params:Y},T0,X)}async getTask($,X){return this._server.getTask({taskId:$},X)}async getTaskResult($,X,J){return this._server.getTaskResult({taskId:$},X,J)}async listTasks($,X){return this._server.listTasks($?{cursor:$}:void 0,X)}async cancelTask($,X){return this._server.cancelTask({taskId:$},X)}}function oD($,X,J){if(!$)throw Error(`${J} does not support task creation (required for ${X})`);switch(X){case"tools/call":if(!$.tools?.call)throw Error(`${J} does not support task creation for tools/call (required for ${X})`);break;default:break}}function tD($,X,J){if(!$)throw Error(`${J} does not support task creation (required for ${X})`);switch(X){case"sampling/createMessage":if(!$.sampling?.createMessage)throw Error(`${J} does not support task creation for sampling/createMessage (required for ${X})`);break;case"elicitation/create":if(!$.elicitation?.create)throw Error(`${J} does not support task creation for elicitation/create (required for ${X})`);break;default:break}}class ZU extends M3{constructor($,X){super(X);if(this._serverInfo=$,this._loggingLevels=new Map,this.LOG_LEVEL_SEVERITY=new Map(j9.options.map((J,Q)=>[J,Q])),this.isMessageIgnored=(J,Q)=>{let Y=this._loggingLevels.get(Q);return Y?this.LOG_LEVEL_SEVERITY.get(J)<this.LOG_LEVEL_SEVERITY.get(Y):!1},this._capabilities=X?.capabilities??{},this._instructions=X?.instructions,this._jsonSchemaValidator=X?.jsonSchemaValidator??new bU,this.setRequestHandler(J3,(J)=>this._oninitialize(J)),this.setNotificationHandler(Y3,()=>this.oninitialized?.()),this._capabilities.logging)this.setRequestHandler(K3,async(J,Q)=>{let Y=Q.sessionId||Q.requestInfo?.headers["mcp-session-id"]||void 0,{level:z}=J.params,W=j9.safeParse(z);if(W.success)this._loggingLevels.set(Y,W.data);return{}})}get experimental(){if(!this._experimental)this._experimental={tasks:new PU(this)};return this._experimental}registerCapabilities($){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=KO(this._capabilities,$)}setRequestHandler($,X){let Q=h4($)?.method;if(!Q)throw Error("Schema is missing a method literal");let Y;if(I6(Q)){let W=Q;Y=W._zod?.def?.value??W.value}else{let W=Q;Y=W._def?.value??W.value}if(typeof Y!=="string")throw Error("Schema method literal must be a string");if(Y==="tools/call"){let W=async(G,U)=>{let H=g4(x0,G);if(!H.success){let N=H.error instanceof Error?H.error.message:String(H.error);throw new g(m.InvalidParams,`Invalid tools/call request: ${N}`)}let{params:K}=H.data,V=await Promise.resolve(X(G,U));if(K.task){let N=g4(k0,V);if(!N.success){let w=N.error instanceof Error?N.error.message:String(N.error);throw new g(m.InvalidParams,`Invalid task creation result: ${w}`)}return N.data}let O=g4(HQ,V);if(!O.success){let N=O.error instanceof Error?O.error.message:String(O.error);throw new g(m.InvalidParams,`Invalid tools/call result: ${N}`)}return O.data};return super.setRequestHandler($,W)}return super.setRequestHandler($,X)}assertCapabilityForMethod($){switch($){case"sampling/createMessage":if(!this._clientCapabilities?.sampling)throw Error(`Client does not support sampling (required for ${$})`);break;case"elicitation/create":if(!this._clientCapabilities?.elicitation)throw Error(`Client does not support elicitation (required for ${$})`);break;case"roots/list":if(!this._clientCapabilities?.roots)throw Error(`Client does not support listing roots (required for ${$})`);break;case"ping":break}}assertNotificationCapability($){switch($){case"notifications/message":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"notifications/resources/updated":case"notifications/resources/list_changed":if(!this._capabilities.resources)throw Error(`Server does not support notifying about resources (required for ${$})`);break;case"notifications/tools/list_changed":if(!this._capabilities.tools)throw Error(`Server does not support notifying of tool list changes (required for ${$})`);break;case"notifications/prompts/list_changed":if(!this._capabilities.prompts)throw Error(`Server does not support notifying of prompt list changes (required for ${$})`);break;case"notifications/elicitation/complete":if(!this._clientCapabilities?.elicitation?.url)throw Error(`Client does not support URL elicitation (required for ${$})`);break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability($){if(!this._capabilities)return;switch($){case"completion/complete":if(!this._capabilities.completions)throw Error(`Server does not support completions (required for ${$})`);break;case"logging/setLevel":if(!this._capabilities.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"prompts/get":case"prompts/list":if(!this._capabilities.prompts)throw Error(`Server does not support prompts (required for ${$})`);break;case"resources/list":case"resources/templates/list":case"resources/read":if(!this._capabilities.resources)throw Error(`Server does not support resources (required for ${$})`);break;case"tools/call":case"tools/list":if(!this._capabilities.tools)throw Error(`Server does not support tools (required for ${$})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw Error(`Server does not support tasks capability (required for ${$})`);break;case"ping":case"initialize":break}}assertTaskCapability($){tD(this._clientCapabilities?.tasks?.requests,$,"Client")}assertTaskHandlerCapability($){if(!this._capabilities)return;oD(this._capabilities.tasks?.requests,$,"Server")}async _oninitialize($){let X=$.params.protocolVersion;return this._clientCapabilities=$.params.capabilities,this._clientVersion=$.params.clientInfo,{protocolVersion:OV.includes(X)?X:aG,capabilities:this.getCapabilities(),serverInfo:this._serverInfo,...this._instructions&&{instructions:this._instructions}}}getClientCapabilities(){return this._clientCapabilities}getClientVersion(){return this._clientVersion}getCapabilities(){return this._capabilities}async ping(){return this.request({method:"ping"},d7)}async createMessage($,X){if($.tools||$.toolChoice){if(!this._clientCapabilities?.sampling?.tools)throw Error("Client does not support sampling tools capability.")}if($.messages.length>0){let J=$.messages[$.messages.length-1],Q=Array.isArray(J.content)?J.content:[J.content],Y=Q.some((U)=>U.type==="tool_result"),z=$.messages.length>1?$.messages[$.messages.length-2]:void 0,W=z?Array.isArray(z.content)?z.content:[z.content]:[],G=W.some((U)=>U.type==="tool_use");if(Y){if(Q.some((U)=>U.type!=="tool_result"))throw Error("The last message must contain only tool_result content if any is present");if(!G)throw Error("tool_result blocks are not matching any tool_use from the previous message")}if(G){let U=new Set(W.filter((K)=>K.type==="tool_use").map((K)=>K.id)),H=new Set(Q.filter((K)=>K.type==="tool_result").map((K)=>K.toolUseId));if(U.size!==H.size||![...U].every((K)=>H.has(K)))throw Error("ids of tool_result blocks and tool_use blocks from previous message do not match")}}if($.tools)return this.request({method:"sampling/createMessage",params:$},N3,X);return this.request({method:"sampling/createMessage",params:$},F9,X)}async elicitInput($,X){switch($.mode??"form"){case"url":{if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support url elicitation.");let Q=$;return this.request({method:"elicitation/create",params:Q},T0,X)}case"form":{if(!this._clientCapabilities?.elicitation?.form)throw Error("Client does not support form elicitation.");let Q=$.mode==="form"?$:{...$,mode:"form"},Y=await this.request({method:"elicitation/create",params:Q},T0,X);if(Y.action==="accept"&&Y.content&&Q.requestedSchema)try{let W=this._jsonSchemaValidator.getValidator(Q.requestedSchema)(Y.content);if(!W.valid)throw new g(m.InvalidParams,`Elicitation response content does not match requested schema: ${W.errorMessage}`)}catch(z){if(z instanceof g)throw z;throw new g(m.InternalError,`Error validating elicitation response: ${z instanceof Error?z.message:String(z)}`)}return Y}}}createElicitationCompletionNotifier($,X){if(!this._clientCapabilities?.elicitation?.url)throw Error("Client does not support URL elicitation (required for notifications/elicitation/complete)");return()=>this.notification({method:"notifications/elicitation/complete",params:{elicitationId:$}},X)}async listRoots($,X){return this.request({method:"roots/list",params:$},V3,X)}async sendLoggingMessage($,X){if(this._capabilities.logging){if(!this.isMessageIgnored($.level,X))return this.notification({method:"notifications/message",params:$})}}async sendResourceUpdated($){return this.notification({method:"notifications/resources/updated",params:$})}async sendResourceListChanged(){return this.notification({method:"notifications/resources/list_changed"})}async sendToolListChanged(){return this.notification({method:"notifications/tools/list_changed"})}async sendPromptListChanged(){return this.notification({method:"notifications/prompts/list_changed"})}}var sD=Symbol.for("mcp.completable");function EU($){return!!$&&typeof $==="object"&&sD in $}function eD($){return $[sD]?.complete}var aD;(function($){$.Completable="McpCompletable"})(aD||(aD={}));var Zx=/^[A-Za-z0-9._-]{1,128}$/;function Ex($){let X=[];if($.length===0)return{isValid:!1,warnings:["Tool name cannot be empty"]};if($.length>128)return{isValid:!1,warnings:[`Tool name exceeds maximum length of 128 characters (current: ${$.length})`]};if($.includes(" "))X.push("Tool name contains spaces, which may cause parsing issues");if($.includes(","))X.push("Tool name contains commas, which may cause parsing issues");if($.startsWith("-")||$.endsWith("-"))X.push("Tool name starts or ends with a dash, which may cause parsing issues in some contexts");if($.startsWith(".")||$.endsWith("."))X.push("Tool name starts or ends with a dot, which may cause parsing issues in some contexts");if(!Zx.test($)){let J=$.split("").filter((Q)=>!/[A-Za-z0-9._-]/.test(Q)).filter((Q,Y,z)=>z.indexOf(Q)===Y);return X.push(`Tool name contains invalid characters: ${J.map((Q)=>`"${Q}"`).join(", ")}`,"Allowed characters are: A-Z, a-z, 0-9, underscore (_), dash (-), and dot (.)"),{isValid:!1,warnings:X}}return{isValid:!0,warnings:X}}function Rx($,X){if(X.length>0){console.warn(`Tool name validation warning for "${$}":`);for(let J of X)console.warn(` - ${J}`);console.warn("Tool registration will proceed, but this may cause compatibility issues."),console.warn("Consider updating the tool name to conform to the MCP tool naming standard."),console.warn("See SEP: Specify Format for Tool Names (https://github.com/modelcontextprotocol/modelcontextprotocol/issues/986) for more details.")}}function RU($){let X=Ex($);return Rx($,X.warnings),X.isValid}class SU{constructor($){this._mcpServer=$}registerToolTask($,X,J){let Q={taskSupport:"required",...X.execution};if(Q.taskSupport==="forbidden")throw Error(`Cannot register task-based tool '${$}' with taskSupport 'forbidden'. Use registerTool() instead.`);return this._mcpServer._createRegisteredTool($,X.title,X.description,X.inputSchema,X.outputSchema,X.annotations,Q,X._meta,J)}}class CU{constructor($,X){this._registeredResources={},this._registeredResourceTemplates={},this._registeredTools={},this._registeredPrompts={},this._toolHandlersInitialized=!1,this._completionHandlerInitialized=!1,this._resourceHandlersInitialized=!1,this._promptHandlersInitialized=!1,this.server=new ZU($,X)}get experimental(){if(!this._experimental)this._experimental={tasks:new SU(this)};return this._experimental}async connect($){return await this.server.connect($)}async close(){await this.server.close()}setToolRequestHandlers(){if(this._toolHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(UQ)),this.server.assertCanSetRequestHandler(t4(x0)),this.server.registerCapabilities({tools:{listChanged:!0}}),this.server.setRequestHandler(UQ,()=>({tools:Object.entries(this._registeredTools).filter(([,$])=>$.enabled).map(([$,X])=>{let J={name:$,title:X.title,description:X.description,inputSchema:(()=>{let Q=E0(X.inputSchema);return Q?L3(Q,{strictUnions:!0,pipeStrategy:"input"}):Sx})(),annotations:X.annotations,execution:X.execution,_meta:X._meta};if(X.outputSchema){let Q=E0(X.outputSchema);if(Q)J.outputSchema=L3(Q,{strictUnions:!0,pipeStrategy:"output"})}return J})})),this.server.setRequestHandler(x0,async($,X)=>{try{let J=this._registeredTools[$.params.name];if(!J)throw new g(m.InvalidParams,`Tool ${$.params.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Tool ${$.params.name} disabled`);let Q=!!$.params.task,Y=J.execution?.taskSupport,z="createTask"in J.handler;if((Y==="required"||Y==="optional")&&!z)throw new g(m.InternalError,`Tool ${$.params.name} has taskSupport '${Y}' but was not registered with registerToolTask`);if(Y==="required"&&!Q)throw new g(m.MethodNotFound,`Tool ${$.params.name} requires task augmentation (taskSupport: 'required')`);if(Y==="optional"&&!Q&&z)return await this.handleAutomaticTaskPolling(J,$,X);let W=await this.validateToolInput(J,$.params.arguments,$.params.name),G=await this.executeToolHandler(J,W,X);if(Q)return G;return await this.validateToolOutput(J,G,$.params.name),G}catch(J){if(J instanceof g){if(J.code===m.UrlElicitationRequired)throw J}return this.createToolError(J instanceof Error?J.message:String(J))}}),this._toolHandlersInitialized=!0}createToolError($){return{content:[{type:"text",text:$}],isError:!0}}async validateToolInput($,X,J){if(!$.inputSchema)return;let Y=E0($.inputSchema)??$.inputSchema,z=await R7(Y,X);if(!z.success){let W="error"in z?z.error:"Unknown error",G=S7(W);throw new g(m.InvalidParams,`Input validation error: Invalid arguments for tool ${J}: ${G}`)}return z.data}async validateToolOutput($,X,J){if(!$.outputSchema)return;if(!("content"in X))return;if(X.isError)return;if(!X.structuredContent)throw new g(m.InvalidParams,`Output validation error: Tool ${J} has an output schema but no structured content was provided`);let Q=E0($.outputSchema),Y=await R7(Q,X.structuredContent);if(!Y.success){let z="error"in Y?Y.error:"Unknown error",W=S7(z);throw new g(m.InvalidParams,`Output validation error: Invalid structured content for tool ${J}: ${W}`)}}async executeToolHandler($,X,J){let Q=$.handler;if("createTask"in Q){if(!J.taskStore)throw Error("No task store provided.");let z={...J,taskStore:J.taskStore};if($.inputSchema)return await Promise.resolve(Q.createTask(X,z));else return await Promise.resolve(Q.createTask(z))}if($.inputSchema)return await Promise.resolve(Q(X,J));else return await Promise.resolve(Q(J))}async handleAutomaticTaskPolling($,X,J){if(!J.taskStore)throw Error("No task store provided for task-capable tool.");let Q=await this.validateToolInput($,X.params.arguments,X.params.name),Y=$.handler,z={...J,taskStore:J.taskStore},W=Q?await Promise.resolve(Y.createTask(Q,z)):await Promise.resolve(Y.createTask(z)),G=W.task.taskId,U=W.task,H=U.pollInterval??5000;while(U.status!=="completed"&&U.status!=="failed"&&U.status!=="cancelled"){await new Promise((V)=>setTimeout(V,H));let K=await J.taskStore.getTask(G);if(!K)throw new g(m.InternalError,`Task ${G} not found during polling`);U=K}return await J.taskStore.getTaskResult(G)}setCompletionRequestHandler(){if(this._completionHandlerInitialized)return;this.server.assertCanSetRequestHandler(t4(KQ)),this.server.registerCapabilities({completions:{}}),this.server.setRequestHandler(KQ,async($)=>{switch($.params.ref.type){case"ref/prompt":return RV($),this.handlePromptCompletion($,$.params.ref);case"ref/resource":return SV($),this.handleResourceCompletion($,$.params.ref);default:throw new g(m.InvalidParams,`Invalid completion reference: ${$.params.ref}`)}}),this._completionHandlerInitialized=!0}async handlePromptCompletion($,X){let J=this._registeredPrompts[X.name];if(!J)throw new g(m.InvalidParams,`Prompt ${X.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Prompt ${X.name} disabled`);if(!J.argsSchema)return i9;let Y=h4(J.argsSchema)?.[$.params.argument.name];if(!EU(Y))return i9;let z=eD(Y);if(!z)return i9;let W=await z($.params.argument.value,$.params.context);return XL(W)}async handleResourceCompletion($,X){let J=Object.values(this._registeredResourceTemplates).find((z)=>z.resourceTemplate.uriTemplate.toString()===X.uri);if(!J){if(this._registeredResources[X.uri])return i9;throw new g(m.InvalidParams,`Resource template ${$.params.ref.uri} not found`)}let Q=J.resourceTemplate.completeCallback($.params.argument.name);if(!Q)return i9;let Y=await Q($.params.argument.value,$.params.context);return XL(Y)}setResourceRequestHandlers(){if(this._resourceHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(YQ)),this.server.assertCanSetRequestHandler(t4(QQ)),this.server.assertCanSetRequestHandler(t4(zQ)),this.server.registerCapabilities({resources:{listChanged:!0}}),this.server.setRequestHandler(YQ,async($,X)=>{let J=Object.entries(this._registeredResources).filter(([Y,z])=>z.enabled).map(([Y,z])=>({uri:Y,name:z.name,...z.metadata})),Q=[];for(let Y of Object.values(this._registeredResourceTemplates)){if(!Y.resourceTemplate.listCallback)continue;let z=await Y.resourceTemplate.listCallback(X);for(let W of z.resources)Q.push({...Y.metadata,...W})}return{resources:[...J,...Q]}}),this.server.setRequestHandler(QQ,async()=>{return{resourceTemplates:Object.entries(this._registeredResourceTemplates).map(([X,J])=>({name:X,uriTemplate:J.resourceTemplate.uriTemplate.toString(),...J.metadata}))}}),this.server.setRequestHandler(zQ,async($,X)=>{let J=new URL($.params.uri),Q=this._registeredResources[J.toString()];if(Q){if(!Q.enabled)throw new g(m.InvalidParams,`Resource ${J} disabled`);return Q.readCallback(J,X)}for(let Y of Object.values(this._registeredResourceTemplates)){let z=Y.resourceTemplate.uriTemplate.match(J.toString());if(z)return Y.readCallback(J,z,X)}throw new g(m.InvalidParams,`Resource ${J} not found`)}),this._resourceHandlersInitialized=!0}setPromptRequestHandlers(){if(this._promptHandlersInitialized)return;this.server.assertCanSetRequestHandler(t4(WQ)),this.server.assertCanSetRequestHandler(t4(GQ)),this.server.registerCapabilities({prompts:{listChanged:!0}}),this.server.setRequestHandler(WQ,()=>({prompts:Object.entries(this._registeredPrompts).filter(([,$])=>$.enabled).map(([$,X])=>{return{name:$,title:X.title,description:X.description,arguments:X.argsSchema?Cx(X.argsSchema):void 0}})})),this.server.setRequestHandler(GQ,async($,X)=>{let J=this._registeredPrompts[$.params.name];if(!J)throw new g(m.InvalidParams,`Prompt ${$.params.name} not found`);if(!J.enabled)throw new g(m.InvalidParams,`Prompt ${$.params.name} disabled`);if(J.argsSchema){let Q=E0(J.argsSchema),Y=await R7(Q,$.params.arguments);if(!Y.success){let G="error"in Y?Y.error:"Unknown error",U=S7(G);throw new g(m.InvalidParams,`Invalid arguments for prompt ${$.params.name}: ${U}`)}let z=Y.data,W=J.callback;return await Promise.resolve(W(z,X))}else{let Q=J.callback;return await Promise.resolve(Q(X))}}),this._promptHandlersInitialized=!0}resource($,X,...J){let Q;if(typeof J[0]==="object")Q=J.shift();let Y=J[0];if(typeof X==="string"){if(this._registeredResources[X])throw Error(`Resource ${X} is already registered`);let z=this._createRegisteredResource($,void 0,X,Q,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),z}else{if(this._registeredResourceTemplates[$])throw Error(`Resource template ${$} is already registered`);let z=this._createRegisteredResourceTemplate($,void 0,X,Q,Y);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),z}}registerResource($,X,J,Q){if(typeof X==="string"){if(this._registeredResources[X])throw Error(`Resource ${X} is already registered`);let Y=this._createRegisteredResource($,J.title,X,J,Q);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),Y}else{if(this._registeredResourceTemplates[$])throw Error(`Resource template ${$} is already registered`);let Y=this._createRegisteredResourceTemplate($,J.title,X,J,Q);return this.setResourceRequestHandlers(),this.sendResourceListChanged(),Y}}_createRegisteredResource($,X,J,Q,Y){let z={name:$,title:X,metadata:Q,readCallback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({uri:null}),update:(W)=>{if(typeof W.uri<"u"&&W.uri!==J){if(delete this._registeredResources[J],W.uri)this._registeredResources[W.uri]=z}if(typeof W.name<"u")z.name=W.name;if(typeof W.title<"u")z.title=W.title;if(typeof W.metadata<"u")z.metadata=W.metadata;if(typeof W.callback<"u")z.readCallback=W.callback;if(typeof W.enabled<"u")z.enabled=W.enabled;this.sendResourceListChanged()}};return this._registeredResources[J]=z,z}_createRegisteredResourceTemplate($,X,J,Q,Y){let z={resourceTemplate:J,title:X,metadata:Q,readCallback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(U)=>{if(typeof U.name<"u"&&U.name!==$){if(delete this._registeredResourceTemplates[$],U.name)this._registeredResourceTemplates[U.name]=z}if(typeof U.title<"u")z.title=U.title;if(typeof U.template<"u")z.resourceTemplate=U.template;if(typeof U.metadata<"u")z.metadata=U.metadata;if(typeof U.callback<"u")z.readCallback=U.callback;if(typeof U.enabled<"u")z.enabled=U.enabled;this.sendResourceListChanged()}};this._registeredResourceTemplates[$]=z;let W=J.uriTemplate.variableNames;if(Array.isArray(W)&&W.some((U)=>!!J.completeCallback(U)))this.setCompletionRequestHandler();return z}_createRegisteredPrompt($,X,J,Q,Y){let z={title:X,description:J,argsSchema:Q===void 0?void 0:Z1(Q),callback:Y,enabled:!0,disable:()=>z.update({enabled:!1}),enable:()=>z.update({enabled:!0}),remove:()=>z.update({name:null}),update:(W)=>{if(typeof W.name<"u"&&W.name!==$){if(delete this._registeredPrompts[$],W.name)this._registeredPrompts[W.name]=z}if(typeof W.title<"u")z.title=W.title;if(typeof W.description<"u")z.description=W.description;if(typeof W.argsSchema<"u")z.argsSchema=Z1(W.argsSchema);if(typeof W.callback<"u")z.callback=W.callback;if(typeof W.enabled<"u")z.enabled=W.enabled;this.sendPromptListChanged()}};if(this._registeredPrompts[$]=z,Q){if(Object.values(Q).some((G)=>{let U=G instanceof F6?G._def?.innerType:G;return EU(U)}))this.setCompletionRequestHandler()}return z}_createRegisteredTool($,X,J,Q,Y,z,W,G,U){RU($);let H={title:X,description:J,inputSchema:$L(Q),outputSchema:$L(Y),annotations:z,execution:W,_meta:G,handler:U,enabled:!0,disable:()=>H.update({enabled:!1}),enable:()=>H.update({enabled:!0}),remove:()=>H.update({name:null}),update:(K)=>{if(typeof K.name<"u"&&K.name!==$){if(typeof K.name==="string")RU(K.name);if(delete this._registeredTools[$],K.name)this._registeredTools[K.name]=H}if(typeof K.title<"u")H.title=K.title;if(typeof K.description<"u")H.description=K.description;if(typeof K.paramsSchema<"u")H.inputSchema=Z1(K.paramsSchema);if(typeof K.outputSchema<"u")H.outputSchema=Z1(K.outputSchema);if(typeof K.callback<"u")H.handler=K.callback;if(typeof K.annotations<"u")H.annotations=K.annotations;if(typeof K._meta<"u")H._meta=K._meta;if(typeof K.enabled<"u")H.enabled=K.enabled;this.sendToolListChanged()}};return this._registeredTools[$]=H,this.setToolRequestHandlers(),this.sendToolListChanged(),H}tool($,...X){if(this._registeredTools[$])throw Error(`Tool ${$} is already registered`);let J,Q,Y,z;if(typeof X[0]==="string")J=X.shift();if(X.length>1){let G=X[0];if(vU(G)){if(Q=X.shift(),X.length>1&&typeof X[0]==="object"&&X[0]!==null&&!vU(X[0]))z=X.shift()}else if(typeof G==="object"&&G!==null)z=X.shift()}let W=X[0];return this._createRegisteredTool($,void 0,J,Q,Y,z,{taskSupport:"forbidden"},void 0,W)}registerTool($,X,J){if(this._registeredTools[$])throw Error(`Tool ${$} is already registered`);let{title:Q,description:Y,inputSchema:z,outputSchema:W,annotations:G,_meta:U}=X;return this._createRegisteredTool($,Q,Y,z,W,G,{taskSupport:"forbidden"},U,J)}prompt($,...X){if(this._registeredPrompts[$])throw Error(`Prompt ${$} is already registered`);let J;if(typeof X[0]==="string")J=X.shift();let Q;if(X.length>1)Q=X.shift();let Y=X[0],z=this._createRegisteredPrompt($,void 0,J,Q,Y);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),z}registerPrompt($,X,J){if(this._registeredPrompts[$])throw Error(`Prompt ${$} is already registered`);let{title:Q,description:Y,argsSchema:z}=X,W=this._createRegisteredPrompt($,Q,Y,z,J);return this.setPromptRequestHandlers(),this.sendPromptListChanged(),W}isConnected(){return this.server.transport!==void 0}async sendLoggingMessage($,X){return this.server.sendLoggingMessage($,X)}sendResourceListChanged(){if(this.isConnected())this.server.sendResourceListChanged()}sendToolListChanged(){if(this.isConnected())this.server.sendToolListChanged()}sendPromptListChanged(){if(this.isConnected())this.server.sendPromptListChanged()}}var Sx={type:"object",properties:{}};function JL($){return $!==null&&typeof $==="object"&&"parse"in $&&typeof $.parse==="function"&&"safeParse"in $&&typeof $.safeParse==="function"}function vx($){return"_def"in $||"_zod"in $||JL($)}function vU($){if(typeof $!=="object"||$===null)return!1;if(vx($))return!1;if(Object.keys($).length===0)return!0;return Object.values($).some(JL)}function $L($){if(!$)return;if(vU($))return Z1($);return $}function Cx($){let X=h4($);if(!X)return[];return Object.entries(X).map(([J,Q])=>{let Y=RN(Q),z=SN(Q);return{name:J,description:Y,required:!z}})}function t4($){let J=h4($)?.method;if(!J)throw Error("Schema is missing a method literal");let Q=v7(J);if(typeof Q==="string")return Q;throw Error("Schema method literal must be a string")}function XL($){return{completion:{values:$.slice(0,100),total:$.length,hasMore:$.length>100}}}var i9={completion:{values:[],hasMore:!1}};function kx($,X,J,Q,Y){let z={};if(Y?.searchHint)z["anthropic/searchHint"]=Y.searchHint;if(Y?.alwaysLoad)z["anthropic/alwaysLoad"]=!0;return{name:$,description:X,inputSchema:J,handler:Q,annotations:Y?.annotations,_meta:Object.keys(z).length>0?z:void 0}}function _x($){let X=new CU({name:$.name,version:$.version??"1.0.0"},{capabilities:{tools:$.tools?{}:void 0}});if($.tools)$.tools.forEach((J)=>{for(let Q of Object.values(J.inputSchema)){if(!xx(Q))continue;let Y=Q.description;if(Y&&!X6.has(Q))X6.add(Q,{description:Y})}X.registerTool(J.name,{description:J.description,inputSchema:J.inputSchema,annotations:J.annotations,_meta:J._meta},J.handler)});return{type:"sdk",name:$.name,instance:X}}function xx($){return typeof $==="object"&&$!==null&&"_zod"in $}function YL($){let X;return()=>X??=$()}var QL=15000,Tx=YL(()=>u4.object({session_id:u4.string(),ws_url:u4.string(),work_dir:u4.string().optional(),session_key:u4.string().optional()}));class r6 extends Error{constructor($){super($);this.name="DirectConnectError"}}class WL{options;ws;sessionId;workDir;abortController;readyState=!1;closed=!1;exitError;messages=new K1;readyPromise;readyResolve;readyReject;abortHandler;partialChunks=[];constructor($){this.options=$;this.abortController=$.abortController??new AbortController,this.readyPromise=new Promise((X,J)=>{this.readyResolve=X,this.readyReject=J}),this.readyPromise.catch(()=>{}),this.initialize()}get ready(){return this.readyPromise}getSessionId(){return this.sessionId}getWorkDir(){return this.workDir}async initialize(){if(this.abortController.signal.aborted){this.failInit(new a$("Connection aborted"));return}this.abortHandler=()=>{this.close(),this.exitError=new a$("Connection aborted by user")},this.abortController.signal.addEventListener("abort",this.abortHandler);let $;try{let Y=await fx(this.options);this.sessionId=Y.sessionId,this.workDir=Y.workDir,$=Y.wsUrl}catch(Y){this.failInit(KK(Y));return}if(this.closed){if(this.options.deleteSessionOnClose&&this.sessionId)zL(this.options.serverUrl,this.sessionId,this.options.authToken);return}let X={};if(this.options.authToken)X.authorization=`Bearer ${this.options.authToken}`;let J=new WebSocket($,{headers:X});this.ws=J;let Q=setTimeout((Y,z)=>{if(!Y.readyState){z.close();let W=new r6(`WebSocket connection timeout after ${QL}ms`);Y.exitError=W,Y.readyReject?.(W)}},QL,this,J);J.addEventListener("open",()=>{clearTimeout(Q),this.readyState=!0,s$(`[DirectConnectTransport] Connected to ${this.options.serverUrl}, session=${this.sessionId}`),this.readyResolve?.()}),J.addEventListener("message",(Y)=>{let z=typeof Y.data==="string"?Y.data:"";if(z.indexOf(`
|
|
104
|
+
`)===-1){if(z)this.partialChunks.push(z);return}let W=this.partialChunks.join("")+z;this.partialChunks.length=0;let G=W.split(`
|
|
105
|
+
`),U=G.pop()??"";if(U)this.partialChunks.push(U);for(let H of G){if(!H)continue;let K;try{K=L6(H)}catch(V){s$(`DirectConnect: dropped malformed JSON line (${H.length} bytes): ${V}`);continue}this.messages.enqueue(K)}}),J.addEventListener("error",()=>{clearTimeout(Q);let Y=new r6("WebSocket connection error");this.exitError=Y,this.readyReject?.(Y),this.messages.done()}),J.addEventListener("close",(Y)=>{if(this.readyState=!1,this.closed=!0,Y.code!==1000&&Y.code!==1001&&!this.exitError)this.exitError=new r6(`WebSocket closed abnormally: ${Y.code} ${Y.reason}`);this.messages.done()})}failInit($){this.exitError=$,this.closed=!0,this.readyReject?.($),this.messages.done()}async write($){if(this.abortController.signal.aborted)throw new a$("Operation aborted");if(!this.readyState)await this.readyPromise;if(!this.ws||this.ws.readyState!==WebSocket.OPEN)throw new r6("Transport is not ready for writing");this.ws.send($)}isReady(){return this.readyState&&this.ws?.readyState===WebSocket.OPEN}endInput(){}close(){if(this.closed)return;if(this.closed=!0,this.readyState=!1,this.abortHandler)this.abortController.signal.removeEventListener("abort",this.abortHandler),this.abortHandler=void 0;if(!this.abortController.signal.aborted)this.abortController.abort();if(this.ws&&this.ws.readyState===WebSocket.OPEN)this.ws.close(1000,"Normal closure");if(this.messages.done(),this.options.deleteSessionOnClose&&this.sessionId)zL(this.options.serverUrl,this.sessionId,this.options.authToken)}async*readMessages(){if(yield*this.messages,this.exitError)throw this.exitError}}function yx($){if($.startsWith("cc://")){let Q=$.slice(5),Y=new URL(`http://${Q}`),z=Y.pathname.slice(1)||void 0;return{serverUrl:`http://${Y.host}`,authToken:z}}if($.startsWith("cc+unix://"))throw new r6("Unix socket connect (cc+unix://) is not supported by the SDK transport");let X=/^https?:\/\//i.test($)?$:`http://${$}`,J=new URL(X);return{serverUrl:`${J.protocol}//${J.host}`,authToken:void 0}}async function fx($){let X={"content-type":"application/json"};if($.authToken)X.authorization=`Bearer ${$.authToken}`;let J={};if($.cwd)J.cwd=$.cwd;if($.sessionKey)J.session_key=$.sessionKey;if($.permissionMode)J.permission_mode=$.permissionMode;let Q;try{Q=await fetch(`${$.serverUrl}/sessions`,{method:"POST",headers:X,body:q$(J)})}catch(z){throw new r6(`Failed to connect to server at ${$.serverUrl}: ${z instanceof Error?z.message:String(z)}`)}if(!Q.ok){let z=await Q.text().catch(()=>"");throw new r6(`Failed to create session: ${Q.status} ${Q.statusText}${z?` — ${z}`:""}`)}let Y=Tx().safeParse(await Q.json());if(!Y.success)throw new r6(`Invalid session response: ${Y.error.message}`);return{sessionId:Y.data.session_id,wsUrl:Y.data.ws_url,workDir:Y.data.work_dir}}async function zL($,X,J){let Q={};if(J)Q.authorization=`Bearer ${J}`;try{await fetch(`${$}/sessions/${X}`,{method:"DELETE",headers:Q})}catch{}}function UL($,X){let{systemPrompt:J,settings:Q,settingSources:Y,sandbox:z,...W}=$??{},G,U;if(J===void 0)G="";else if(typeof J==="string")G=J;else if(J.type==="preset")U=J.append;let H=W.pathToClaudeCodeExecutable;if(!H){let r9=gx(import.meta.url),T1=GL(r9,"..");H=GL(T1,"cli.js")}process.env.CLAUDE_AGENT_SDK_VERSION="0.2.90";let{abortController:K=y1(),additionalDirectories:V=[],agent:O,agents:N,allowedTools:w=[],betas:B,canUseTool:L,continue:j,cwd:I,debug:b,debugFile:x,disallowedTools:h=[],tools:B$,env:x$,executable:G6=f1()?"bun":"node",executableArgs:o6=[],extraArgs:h6={},fallbackModel:a4,enableFileCheckpointing:_1,toolConfig:t6,forkSession:r0,hooks:p,includeHookEvents:n9,includePartialMessages:aQ,onElicitation:o0,persistSession:t0,thinking:s4,effort:d9,maxThinkingTokens:x1,maxTurns:p$,maxBudgetUsd:j4,taskBudget:a0,mcpServers:kU,model:KL,outputFormat:_U,permissionMode:NL="default",allowDangerouslySkipPermissions:VL=!1,permissionPromptToolName:OL,plugins:wL,workload:xU,resume:BL,resumeSessionAt:qL,sessionId:DL,stderr:LL,strictMcpConfig:jL}=W,TU=_U?.type==="json_schema"?_U.schema:void 0,e4=x$;if(!e4)e4={...process.env};if(!e4.CLAUDE_CODE_ENTRYPOINT)e4.CLAUDE_CODE_ENTRYPOINT="sdk-ts";if(_1)e4.CLAUDE_CODE_ENABLE_SDK_FILE_CHECKPOINTING="true";if(t6?.askUserQuestion?.previewFormat)e4.CLAUDE_CODE_QUESTION_PREVIEW_FORMAT=t6.askUserQuestion.previewFormat;let yU={},fU=new Map;if(kU)for(let[r9,T1]of Object.entries(kU))if(T1.type==="sdk"&&T1.instance)fU.set(r9,T1.instance);else yU[r9]=T1;let s0;if(s4)switch(s4.type){case"adaptive":s0={type:"adaptive"};break;case"enabled":s0={type:"enabled",budgetTokens:s4.budgetTokens};break;case"disabled":s0={type:"disabled"};break}else if(x1!==void 0)s0=x1===0?{type:"disabled"}:{type:"enabled",budgetTokens:x1};let gU=new cX({abortController:K,additionalDirectories:V,agent:O,betas:B,cwd:I,debug:b,debugFile:x,executable:G6,executableArgs:o6,extraArgs:xU?{...h6,workload:xU}:h6,pathToClaudeCodeExecutable:H,env:e4,forkSession:r0,stderr:LL,thinkingConfig:s0,effort:d9,maxTurns:p$,maxBudgetUsd:j4,taskBudget:a0,model:KL,fallbackModel:a4,jsonSchema:TU,permissionMode:NL,allowDangerouslySkipPermissions:VL,permissionPromptToolName:OL,continueConversation:j,resume:BL,resumeSessionAt:qL,sessionId:DL,settings:typeof Q==="object"?q$(Q):Q,settingSources:Y,allowedTools:w,disallowedTools:h,tools:B$,mcpServers:yU,strictMcpConfig:jL,canUseTool:!!L,hooks:!!p,includeHookEvents:n9,includePartialMessages:aQ,persistSession:t0,plugins:wL,sandbox:z,spawnClaudeCodeProcess:W.spawnClaudeCodeProcess}),FL={systemPrompt:G,appendSystemPrompt:U,agents:N,promptSuggestions:W.promptSuggestions,agentProgressSummaries:W.agentProgressSummaries};return{queryInstance:new pX(gU,X,L,p,K,fU,TU,FL,o0),transport:gU,abortController:K}}function HL($,X,J,Q){if(typeof J==="string")X.write(q$({type:"user",session_id:"",message:{role:"user",content:[{type:"text",text:J}]},parent_tool_use_id:null})+`
|
|
105
106
|
`);else $.streamInput(J).catch((Y)=>Q.abort(Y))}function $s({prompt:$,options:X}){let{queryInstance:J,transport:Q,abortController:Y}=UL(X,typeof $==="string");return HL(J,Q,$,Y),J}async function Xs({options:$}={}){let{queryInstance:X,transport:J,abortController:Q}=UL($,!1);try{await X.initializationResult()}catch(W){throw X.close(),W}let Y=!1;function z(){if(Y)return;Y=!0,X.close()}return{query(W){if(Y)throw Error("WarmQuery.query() can only be called once");Y=!0;try{HL(X,J,W,Q)}catch(G){throw X.close(),G}if(typeof W==="string")X.setIsSingleUserTurn(!0);return X},close:z,async[Symbol.asyncDispose](){if(!Y)z()}}}function Js($){return gz($)}function Ys($,X){return vK($,X)}async function Qs($,X){let Q=[];try{const J=N$(Q,gz(X),1);await J.send($);for await(let U of J.stream())if(U.type==="result")return U;throw Error("Session ended without result message")}catch(Y){var z=Y,W=1}finally{var G=V$(Q,z,W);G&&await G}}async function zs($,X){return fK($,X)}async function Ws($){return hK($)}async function Gs($,X){return uK($,X)}async function Us($,X,J){return lK($,X,J)}async function Hs($,X,J){return cK($,X,J)}async function Ks($,X){return nK($,X)}async function Ns($,X){return oK($,X)}async function Vs($,X,J){return tK($,X,J)}export{Ys as unstable_v2_resumeSession,Qs as unstable_v2_prompt,Js as unstable_v2_createSession,kx as tool,Hs as tagSession,Xs as startup,Us as renameSession,$s as query,yx as parseDirectConnectUrl,Ns as listSubagents,Ws as listSessions,Vs as getSubagentMessages,zs as getSessionMessages,Gs as getSessionInfo,Ks as forkSession,_x as createSdkMcpServer,xL as HOOK_EVENTS,TL as EXIT_REASONS,WL as DirectConnectTransport,r6 as DirectConnectError,a$ as AbortError};
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|