@zuplo/runtime 6.57.1 → 6.57.3

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.
Files changed (2) hide show
  1. package/out/esm/index.js +1 -1
  2. package/package.json +1 -1
package/out/esm/index.js CHANGED
@@ -87,7 +87,7 @@ Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.
87
87
  `)}async hexBodyHash(){let e=this.headers.get("X-Amz-Content-Sha256");if(e==null){if(this.body&&typeof this.body!="string"&&!("byteLength"in this.body))throw new Z("body must be a string, ArrayBuffer or ArrayBufferView, unless you include the X-Amz-Content-Sha256 header");e=Aa(await Ng(this.body||""))}return e}};async function xn(t,e){let r=await crypto.subtle.importKey("raw",typeof t=="string"?La.encode(t):t,{name:"HMAC",hash:{name:"SHA-256"}},!1,["sign"]);return crypto.subtle.sign("HMAC",r,La.encode(e))}i(xn,"hmac");async function Ng(t){return crypto.subtle.digest("SHA-256",typeof t=="string"?La.encode(t):t)}i(Ng,"hash");function Aa(t){return Array.prototype.map.call(new Uint8Array(t),e=>("0"+e.toString(16)).slice(-2)).join("")}i(Aa,"buf2hex");function zg(t){return t.replace(/[!'()*]/g,e=>"%"+e.charCodeAt(0).toString(16).toUpperCase())}i(zg,"encodeRfc3986");function Ax(t,e){let{hostname:r,pathname:n}=t,o=r.replace("dualstack.","").match(/([^.]+)\.(?:([^.]*)\.)?amazonaws\.com(?:\.cn)?$/),[s,a]=(o||["",""]).slice(1,3);if(a==="us-gov")a="us-gov-west-1";else if(a==="s3"||a==="s3-accelerate")a="us-east-1",s="s3";else if(s==="iot")r.startsWith("iot.")?s="execute-api":r.startsWith("data.jobs.iot.")?s="iot-jobs-data":s=n==="/mqtt"?"iotdevicegateway":"iotdata";else if(s==="autoscaling"){let u=(e.get("X-Amz-Target")||"").split(".")[0];u==="AnyScaleFrontendService"?s="application-autoscaling":u==="AnyScaleScalingPlannerFrontendService"&&(s="autoscaling-plans")}else a==null&&s.startsWith("s3-")?(a=s.slice(3).replace(/^fips-|^external-1/,""),s="s3"):s.endsWith("-fips")?s=s.slice(0,-5):a&&/-\d$/.test(s)&&!/-\d$/.test(a)&&([s,a]=[a,s]);return s in Lg?[Lg[s],a]:[s,a]}i(Ax,"guessServiceRegion");function Lx(t){return t>64&&t<91?t-65:t>96&&t<123?t-71:t>47&&t<58?t+4:t===43?62:t===47?63:0}i(Lx,"b64ToUint6");function Ug(t,e){let r=t.replace(/[^A-Za-z0-9+/]/g,""),n=r.length,o=e?Math.ceil((n*3+1>>2)/e)*e:n*3+1>>2,s=new Uint8Array(o),a,u,c=0,l=0;for(let d=0;d<n;d++)if(u=d&3,c|=Lx(r.charCodeAt(d))<<6*(3-u),u===3||n-d===1){for(a=0;a<3&&l<o;)s[l]=c>>>(16>>>a&24)&255,a++,l++;c=0}return s}i(Ug,"base64Decode");function ai(t){return t<26?t+65:t<52?t+71:t<62?t-4:t===62?43:t===63?47:65}i(ai,"uint6ToB64");function Dg(t){let e=2,r="",n=t.length,o=0;for(let s=0;s<n;s++)e=s%3,o|=t[s]<<(16>>>e&24),(e===2||t.length-s===1)&&(r+=String.fromCodePoint(ai(o>>>18&63),ai(o>>>12&63),ai(o>>>6&63),ai(o&63)),o=0);return r.substring(0,r.length-2+e)+(e===2?"":e===1?"=":"==")}i(Dg,"base64Encode");function wr(t){let e=t.toString();return`${e.length===1?"0":""}${e}`}i(wr,"numberToString");function Nx(t){let e=t.getTimezoneOffset(),r=Math.abs(e),n=e>0?"-":"+",o=wr(Math.floor(r/60)),s=wr(r%60);return`${n}${o}${s}`}i(Nx,"getCLFOffset");function za(t=new Date){if(!(t instanceof Date))throw new Error("clf-date: invalid parameter");let e=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],r=wr(t.getDate()),n=e[t.getMonth()],o=t.getFullYear(),s=wr(t.getHours()),a=wr(t.getMinutes()),u=wr(t.getSeconds()),c=Nx(t);return`${r}/${n}/${o}:${s}:${a}:${u} ${c}`}i(za,"toCLFDate");var Zg=Me("zuplo:runtime"),zx="X-Amzn-Trace-Id",Ux="x-amzn-errortype",jg=[],Dx=i(async(t,e,r)=>{let n=r;for await(let o of jg)n=await o(t,e,r);return n},"onSendingAwsLambdaEvent"),We=class extends Z{static{i(this,"AwsLambdaError")}traceId;errorType;constructor(e,r){super(`Failed to invoke AWS Lambda function. ${e}`),this.traceId=r.get(zx)??void 0,this.errorType=r.get(Ux)??void 0}},Zx={addSendingAwsLambdaEventHook:i(t=>{jg.push(t)},"addSendingAwsLambdaEventHook")};async function jx(t,e){b("handler.aws-lambda");let{accessKeyId:r,secretAccessKey:n,region:o,functionName:s,useLambdaProxyIntegration:a=!0,useAwsResourcePathStyle:u=!1,binaryMediaTypes:c}=e.route.handler.options;if(!r)throw new y("awsAccessKeyId is not set in the handler options");if(!n)throw new y("secretAccessKey is not set in the handler options");if(!o)throw new y("region is not set in the handler options");if(!s)throw new y("functionName is not set in the handler options");let l=new vr({accessKeyId:r,secretAccessKey:n}),d=`https://lambda.${o}.amazonaws.com/2015-03-31/functions/${s}/invocations`;if(Zg(`AWS Lambda URL: ${d}`),!a)return l.fetch(d,{body:await t.arrayBuffer()});let[p,m]=await Fx(t,{binaryMediaTypes:c}),{options:f}=e.route.handler,h;f&&typeof f=="object"&&"payloadFormatVersion"in f&&f.payloadFormatVersion==="2.0"?h=Hx(t,e):h=await qx(t,e,{useAwsResourcePathStyle:u}),Zg("Calling onSendingAwsLambdaEvent hook");let w=await Dx(t,e,h);w.body=p,w.isBase64Encoded=m;let x=await l.fetch(d,{body:JSON.stringify(w)});try{return Mx(x)}catch(k){if(k instanceof We){let _=f&&typeof f=="object"&&"returnAmazonTraceIdHeader"in f&&f.returnAmazonTraceIdHeader&&k.traceId?{AMZN_TRACE_ID_HEADER:k.traceId}:void 0;return A.internalServerError(t,e,void 0,_)}throw k}}i(jx,"awsLambdaHandler");async function Mx(t){let e;try{e=await t.json()}catch{throw new We("Lambda response did not contain valid JSON",t.headers)}if(t.status!==200)throw e&&typeof e=="object"&&"message"in e&&typeof e.message=="string"?new We(e.message,t.headers):new We(`Status: ${t.statusText}`,t.headers);if(e&&typeof e=="object"&&"errorMessage"in e&&typeof e.errorMessage=="string")throw new We(e.errorMessage,t.headers);if(!e||typeof e!="object"||!("statusCode"in e)||typeof e.statusCode!="number")return new Response(JSON.stringify(e),{status:t.status,headers:{"content-type":"application/json"}});let r=new Headers;if("headers"in e&&e.headers){if(typeof e.headers!="object")throw new We(`Response headers must be an object. Received ${typeof e.headers}`,t.headers);for(let[o,s]of Object.entries(e.headers))r.set(o,s)}if("cookies"in e&&e.cookies){if(!Array.isArray(e.cookies))throw new We(`Response cookies must be an array. Received ${typeof e.cookies}`,t.headers);r.set("cookie",e.cookies.join(";"))}let n;if("isBase64Encoded"in e&&typeof e.isBase64Encoded!="boolean")throw new We(`Response property isBase64Encoded must be a boolean. Received ${typeof e.isBase64Encoded}`,t.headers);if("isBase64Encoded"in e&&e.isBase64Encoded===!0){if(!("body"in e))throw new We("Response was set to base64 encoded but no body was set",t.headers);if(typeof e.body!="string")throw new We("Response was set to base64 encoded but body was not a string",t.headers);n=Ug(e.body)}else"body"in e&&typeof e.body=="string"?n=e.statusCode===204&&e.body===""?null:e.body:"body"in e&&e.body!==null&&e.body!==void 0?n=JSON.stringify(e.body):n=null;if(n!==null&&"bodyEncoding"in e){if(typeof e.bodyEncoding!="string"||!(e.bodyEncoding==="gzip"||e.bodyEncoding==="deflate"))throw new We(`Response property bodyEncoding can only be set to 'gzip' or 'deflate'. Received ${e.bodyEncoding}`,t.headers);let o=new Blob([n]).stream().pipeThrough(new DecompressionStream(e.bodyEncoding));n=await new Response(o).arrayBuffer()}return new Response(n,{headers:r,status:e.statusCode})}i(Mx,"getResponse");async function qx(t,e,{useAwsResourcePathStyle:r}){let n={},o={};t.headers.forEach((l,d)=>{n[d]=l,o[d]=[l]});let s=t.query,a={};for(let[l,d]of Object.entries(s))a[l]||(a[l]=[]),a[l].push(d);let u=new URL(t.url);return{version:"1.0",resource:u.pathname,path:u.pathname,httpMethod:t.method,headers:n,multiValueHeaders:o,queryStringParameters:s,multiValueQueryStringParameters:a,requestContext:{accountId:null,apiId:null,authorizer:{claims:{},scopes:[]},domainName:u.hostname,domainPrefix:null,extendedRequestId:e.requestId,httpMethod:t.method,identity:{accessKey:null,accountId:null,caller:null,cognitoAuthenticationProvider:null,cognitoAuthenticationType:null,cognitoIdentityId:null,cognitoIdentityPoolId:null,principalOrgId:null,sourceIp:t.headers.get("CF-Connecting-IP"),user:null,userAgent:t.headers.get("user-agent"),userArn:null,clientCert:{clientCertPem:null,subjectDN:null,issuerDN:null,serialNumber:null,validity:{notBefore:null,notAfter:null}}},path:u.pathname,protocol:"HTTP/1.1",requestId:e.requestId,requestTime:za(),requestTimeEpoch:new Date().valueOf(),resourceId:e.route.operationId??null,resourcePath:Vx(e.route.path,r),stage:null},pathParameters:t.params,stageVariables:null}}i(qx,"buildEventVersion1");function Hx(t,e){let r={};t.headers.forEach((s,a)=>{r[a]=s});let n=new URL(t.url);return{version:"2.0",routeKey:null,rawPath:n.pathname,rawQueryString:n.search,cookies:[],headers:r,queryStringParameters:t.query,requestContext:{accountId:null,apiId:null,authentication:{clientCert:{clientCertPem:null,subjectDN:null,issuerDN:null,serialNumber:null,validity:{notBefore:null,notAfter:null}}},authorizer:{jwt:{claims:{},scopes:[]}},domainName:n.hostname,domainPrefix:null,http:{method:t.method,path:n.pathname,protocol:"HTTP/1.1",sourceIp:t.headers.get("CF-Connecting-IP"),userAgent:t.headers.get("user-agent")},requestId:e.requestId,routeKey:null,stage:null,time:za(),timeEpoch:new Date().valueOf()},pathParameters:t.params,stageVariables:null}}i(Hx,"buildEventVersion2");async function Fx(t,{binaryMediaTypes:e}){let r,n=!1,o=t.headers.get("content-type");if(t.method==="GET"||t.method==="HEAD")r=null;else if(e&&o&&Bx(e,o)){let s=await t.arrayBuffer();r=Dg(new Uint8Array(s)),n=!0}else r=await t.clone().text();return[r,n]}i(Fx,"getBodyResult");function Bx(t,e){let r=e.split(";")[0].trim().toLowerCase();return t.findIndex(n=>n==="*/*"?!0:n.toLowerCase()===r)>-1}i(Bx,"matchesContentType");function Vx(t,e=!1){if(!e)return t;let r=Ca(t),n=Ag(t),o={};return r.forEach(s=>{typeof s=="string"?o[s]=`{${s}}`:o[s.name]=`{${s.name}}`}),n(o)}i(Vx,"getResourcePath");var Gx=[502,503,504];async function xr(t,e){if(Gx.includes(t.status)){let r=ue.getLogger(e),o=await t.clone().text(),s={};for(let[a,u]of t.headers)s[a]=u;r.warn(`BadGatewayResponse ${t.status}`,{status:t.status,statusText:t.statusText,body:o,headers:s})}}i(xr,"logBadGatewayResponses");var Ua;function Dt(t){if(Ua===void 0){let r=R.instance.runtime.ZUPLO_HANDLER_WRITE_LOG_LEVEL;["debug","info","warn","error"].includes(r??"")||(r="debug"),Ua=r}return t.log[Ua]}i(Dt,"getHandlerUserLogFunction");async function Jx(t,e){b("handler.open-api");let r=R.instance.build.BUILD_ID,{buildAssetsUrl:n}=R.instance,o=e.route.handler.options,{openApiFilePath:s}=o;if(!s)throw new y("Open API Spec Handler must have 'openApiFilePath' specified");let a=Wx(s);if(!a.isValid)throw new y(a.error);let u=`${n}/${r}${s.substring(1)}`,c=await V.fetch(u,{method:t.method,body:t.body,headers:t.headers});if(c.status!==200)return A.notFound(t,e,{detail:"OpenAPI file could not be found."});let l=new Response(c.body,{headers:{"content-type":"application/json","content-encoding":c.headers.get("content-encoding")||"",vary:"Accept-Encoding"},status:c.status,statusText:c.statusText});return xr(l,e),l}i(Jx,"openApiSpecHandler");var Wx=i(t=>t.startsWith("./")?t.startsWith("./config")?t.endsWith(".oas.json")?{isValid:!0}:{isValid:!1,error:"'openApiFilePath' must point to a file ending in '.oas.json'"}:{isValid:!1,error:"'openApiFilePath' must point to a file in your /config directory"}:{isValid:!1,error:"'openApiFilePath' must start with './'"},"validateOpenApiPath");async function Kx(t,e){b("handler.redirect");let r=e.route.handler.options;if(!r.location)throw new y("Redirect Handler must have 'location' specified");let n=r.status??302;return new Response(null,{status:n,headers:{location:r.location}})}i(Kx,"redirectHandler");async function Qx(t){if(b("handler.zuplo-service-proxy"),Object.entries(t.params).length!==1)throw new y("The service proxy handler only supports one wildcard path parameter. Change your url to something like '/service/{path}'");let e=new URL(t.params.path,R.instance.zuploEdgeApiUrl),r=new Headers(t.headers);return r.set("Authorization",`Bearer ${R.instance.authApiJWT}`),V.fetch(e,{method:t.method,headers:r,body:t.body})}i(Qx,"zuploServiceProxy");function Xx(t,e){let r=t.endsWith("/"),n=e.startsWith("/");return r&&n?`${t.substring(0,t.length-1)}${e}`:!r&&!n?`${t}/${e}`:`${t}${e}`}i(Xx,"join");async function Yx(t,e){b("handler.url-forward");let r=Dt(e),n=e.route.handler.options,o=n.forwardSearch!==!1,s;if(R.instance.build.COMPATIBILITY_FLAGS.useForwardRedirectsPropOnUrlForwardHandler?s=n.followRedirects===!0?"follow":"manual":typeof n.followRedirects<"u"&&b("handler.url-forward.follow-redirects"),!n.baseUrl)throw new Error("URL Forward Handler must have 'baseUrl' specified");if(!n||typeof n.__rewriteFunction!="function")throw new y("Invalid options for this route");let a=Ut(e),u=new URL(t.url),c=n.__rewriteFunction(t,a),l=Xx(c,u.pathname),d=o?`${l}${u.search}`:l.toString(),p=Date.now();r(`URL Forwarding to '${d}'`);let m=await fetch(d,{method:t.method,body:t.body,headers:t.headers,redirect:s}),f=Date.now()-p;return r(`URL Forward received response ${m.status} - ${m.statusText} in ${f}ms`),xr(m,e),m}i(Yx,"urlForwardHandler");var eR=i((t,e)=>{let r=new URL(t),n=new URL(e);for(let[o,s]of n.searchParams.entries())r.searchParams.append(o,s);return r.toString()},"addQuery");async function tR(t,e){b("handler.url-rewrite");let r=Dt(e),n=e.route.handler.options,o=n.forwardSearch!==!1,s=n.followRedirects??!1;if(!n||typeof n.__rewriteFunction!="function")throw new y("Invalid options for this route");let a=Ut(e),u=n.__rewriteFunction(t,a),c=o?eR(u,t.url):u,l=Date.now();r(`URL Rewriting to '${c}'`);let d=await fetch(c.toString(),{method:t.method,body:t.body,headers:t.headers,redirect:s?"follow":"manual"}),p=Date.now()-l;return r(`URL Rewrite received response ${d.status} - ${d.statusText} in ${p}ms`),xr(d,e),d}i(tR,"urlRewriteHandler");async function rR(t,e){b("handler.websocket");let r=e.route.handler.options,n=Dt(e);if(!r||!r.rewritePattern)throw new y("WebSocket Handler must have option 'rewritePattern' specified");let o=t.headers.get("Upgrade");if(!o||o!=="websocket")return A.badRequest(t,e,{detail:"Request must include header 'Upgrade: websocket'"});if(!r||typeof r.__rewriteFunction!="function")throw new y("Invalid options for this route");let s=Ut(e),a=r.__rewriteFunction(t,s),u=Date.now();n(`Attempting WebSocket connection to '${a}'`),a=a.replace(/^(ws)/,"http");let c=await fetch(a,{method:t.method,headers:t.headers,body:t.body});if(c.status!==101||!c.webSocket){let d=await c.text(),p=`WebSocket connection error - ${c.status}: ${c.statusText}, content: '${d}'`;throw new Error(p)}let l=Date.now()-u;return n(`WebSocket connected, received response ${c.status} - ${c.statusText} in ${l}ms`),new Response(null,{status:101,webSocket:c.webSocket})}i(rR,"webSocketHandler");async function nR(t,e){let r=ye.instance.runtimeSettings.developerPortal.urls?.urls?.[0];if(!r)throw new y("Developer portal URL is not configured.");let n=oR(t.url,r);return e.log.info(`Redirecting from legacy dev portal to ${n}`),new Response(null,{status:301,headers:{location:n}})}i(nR,"redirectLegacyDevPortal");function oR(t,e){let r=new URL(t),n=r.pathname.split("/")[1];if(!n)throw new y("The request URL does not contain a valid developer portal base path. This handler cannot be used on a root path");return r.hostname=new URL(e).hostname,r.pathname=r.pathname.substring(n.length+1),r.toString()}i(oR,"getDevPortalRedirectUrl");var Da=i((t,e)=>t.map((n,o)=>{let s;if(typeof n.module=="object"&&(s=n.module[n.export]),!s||typeof s!="function"){let a=e==="inbound"?"WebSocketInboundPolicy":"WebSocketOutboundPolicy",u=`policy in position: ${o+1}, export name: ${n.export}`;throw new y(`${a} - Websocket policy must be a valid function (${u})`)}return s}),"getWebSocketPolicyFunctions"),Mg=i(async(t,e,r,n,o,s)=>{let a=t.data;if(s&&s.length>0){let u=[...s];for(;u.length>0;){let c=u.shift();if(!c)return a;if(a=await c(a,r,e,n,o),a===void 0)return}}return a},"webSocketPolicyProcessor");function qg(t,e,r,n,o){t.addEventListener("close",()=>{e.close()}),t.addEventListener("error",s=>{n.log.error("WebSocket error: ",s),e.send(JSON.stringify(s))}),t.addEventListener("message",s=>{try{let u=i(async c=>{let l=await Mg(c,t,e,r,n,o);l!==void 0&&e.send(l)},"innerPipeline")(s).catch(n.log.error);n.waitUntil(u)}catch(a){n.log.error(a)}})}i(qg,"wireUpListeners");async function iR(t,e){b("handler.websocket-pipeline");let r=e.route.handler.options,n=Dt(e);if(!r||!r.rewritePattern)throw new y("WebSocket Pipeline Handler must have option 'rewritePattern' specified");let o=t.headers.get("Upgrade");if(!o||o!=="websocket")return A.badRequest(t,e,{detail:"Request must include header 'Upgrade: websocket'"});if(!r||typeof r.__rewriteFunction!="function")throw new y("Invalid options for this route");let s=Ut(e),a=r.__rewriteFunction(t,s),u=Date.now();n(`Attempting WebSocket connection to '${a}'`),a=a.replace(/^(ws)/,"http");let c=await fetch(a,{method:t.method,headers:t.headers,body:t.body});if(c.status!==101||!c.webSocket){let x=await c.text(),k=`WebSocket connection error - ${c.status}: ${c.statusText}, content: '${x}'`;throw new Error(k)}let l=new WebSocketPair,[d,p]=Object.values(l),m=Date.now()-u;n(`WebSocket connected, received response ${c.status} - ${c.statusText} in ${m}ms`);let f=c.webSocket;f.accept(),p.accept();let h=r.policies&&r.policies.inbound?Da(r.policies.inbound,"inbound"):[],w=r.policies&&r.policies.outbound?Da(r.policies.outbound,"outbound"):[];return qg(p,f,t,e,h),qg(f,p,t,e,w),new Response(null,{status:101,webSocket:d})}i(iR,"webSocketPipelineHandler");Le();Le();ao();ps();var V_=g.object({jsonrpc:g.literal(Mt),id:Or,error:g.object({code:g.number().int(),message:g.string(),data:g.optional(g.unknown())})}).strict();ms();Ar();Lr();var uo=i(t=>Tb.safeParse(t).success,"isJSONRPCRequest"),Ob=i(t=>kb.safeParse(t).success,"isJSONRPCNotification"),fs=i(t=>$b.safeParse(t).success,"isJSONRPCResponse");var ir=class{static{i(this,"NoOpLogger")}debug(){}info(){}warn(){}error(){}};function gs(){return new ir}i(gs,"createDefaultLogger");Le();Ar();Lr();Le();var Cb=g.object({experimental:g.optional(g.object({}).loose()),roots:g.optional(g.object({listChanged:g.optional(g.boolean())}).loose()),sampling:g.optional(g.object({}).loose()),elicitation:g.optional(g.object({}).loose())}).loose(),Ab=g.object({experimental:g.optional(g.object({}).loose()),logging:g.optional(g.object({}).loose()),completions:g.optional(g.object({}).loose()),prompts:g.optional(g.object({listChanged:g.optional(g.boolean())}).loose()),resources:g.optional(g.object({subscribe:g.optional(g.boolean()),listChanged:g.optional(g.boolean())}).loose()),tools:g.optional(g.object({listChanged:g.optional(g.boolean())}).loose())}).loose();Le();co();var pp=sr.extend({version:g.string()});var Lb=at.extend({method:g.literal("initialize"),params:st.extend({protocolVersion:g.string(),capabilities:Cb,clientInfo:pp})}),aq=vt.extend({protocolVersion:g.string(),capabilities:Ab,serverInfo:pp,instructions:g.optional(g.string())});Le();ms();Ar();Lr();co();fp();var dE=g.object({title:g.optional(g.string()),readOnlyHint:g.optional(g.boolean()),destructiveHint:g.optional(g.boolean()),idempotentHint:g.optional(g.boolean()),openWorldHint:g.optional(g.boolean())}).loose(),pE=sr.extend({description:g.optional(g.string()),inputSchema:g.object({type:g.literal("object"),properties:g.optional(g.record(g.string(),g.object({}).loose())),required:g.optional(g.array(g.string()))}).loose(),outputSchema:g.optional(g.object({type:g.literal("object"),properties:g.optional(g.record(g.string(),g.object({}).loose())),required:g.optional(g.array(g.string()))}).loose()),annotations:g.optional(dE),_meta:g.optional(g.object({}).loose())}),Cq=Nr.extend({method:g.literal("tools/list")}),Aq=zr.extend({tools:g.array(pE)}),Fb=at.extend({method:g.literal("tools/call"),params:st.extend({name:g.string(),arguments:g.optional(g.record(g.string(),g.unknown()))})}),Lq=g.lazy(()=>{let{TextContentSchema:t,ImageContentSchema:e,AudioContentSchema:r,EmbeddedResourceSchema:n}=(Db(),uf(Ub)),{ResourceLinkSchema:o}=(Hb(),uf(qb));return vt.extend({content:g.array(g.discriminatedUnion("type",[t,e,r,o,n])),structuredContent:g.optional(g.record(g.string(),g.unknown())),isError:g.optional(g.boolean())})}),Nq=Cr.extend({method:g.literal("notifications/tools/list_changed")});var yp="2025-06-18",bp="2025-03-26",vp="2024-11-05",wp="2024-10-07",xp=[yp,bp,vp,wp];var Ur=class{static{i(this,"MCPServer")}capabilities;tools=new Map;name;version;instructions;logger;constructor(e){this.name=e.name||"MCP Server",this.version=e.version||"1.0.0",this.instructions=e.instructions||void 0,this.logger=e.logger||gs(),this.capabilities={tools:{supported:!0,available:[]},...e.capabilities}}withTransport(e){e.onMessage(async r=>{try{if(uo(r)){let n=await this.handleRequest(r);if(n)return await e.send(n),n}else{if(Ob(r))return await this.handleNotification(r),null;if(fs(r))return this.logger.debug("Received response:",r),null}}catch(n){if(this.logger.error("Error processing message:",n),uo(r)){let o={jsonrpc:"2.0",id:r.id,error:{code:-32603,message:n instanceof Error?n.message:"Internal error"}};return await e.send(o),o}}return null})}getTool(e){return this.tools.get(e)?.tool}getTools(){let e=new Map;for(let[r,n]of this.tools.entries())e.set(r,n.tool);return e}getCapabilities(){return{...this.capabilities}}addTool(e){let{name:r,validator:n,handler:o,description:s=`Execute the ${r} tool`,outputSchema:a}=e,c={tool:{name:r,description:s,inputSchema:n.jsonSchema,...a&&{outputSchema:a}},validator:n,handler:o};this.tools.set(r,c),this.updateAvailableTools()}removeTool(e){let r=this.tools.delete(e);return r&&this.updateAvailableTools(),r}getToolDefinitions(){return Array.from(this.tools.values()).map(e=>e.tool)}async handleRequest(e){try{switch(e.method){case"ping":return this.handlePing(e);case"initialize":return this.handleInitialize(e);case"tools/list":return this.handleToolListRequest(e);case"tools/call":return this.handleToolCallRequest(e);default:return{jsonrpc:"2.0",id:e.id,error:{code:-32601,message:`Method "${e.method}" not found`}}}}catch(r){return this.logger.error("Error handling request:",r),{jsonrpc:"2.0",id:e.id,error:{code:-32603,message:r instanceof Error?r.message:"Internal error"}}}}async handleNotification(e){this.logger.debug("Received notification:",e.method)}handlePing(e){return{jsonrpc:"2.0",id:e.id,result:{}}}handleInitialize(e){let r=Lb.safeParse(e);if(!r.success){let o=g.treeifyError(r.error),s=g.prettifyError(r.error);return{jsonrpc:"2.0",id:e.id,error:{code:-32602,message:`Invalid request parameters: ${s}`,data:o}}}let n=r.data.params.protocolVersion;switch(n){case yp:case bp:case vp:case wp:{let o={protocolVersion:n,capabilities:this.getCapabilities(),serverInfo:{name:this.name,version:this.version},...this.instructions?{instructions:this.instructions}:{}};return{jsonrpc:"2.0",id:e.id,result:o}}default:return{jsonrpc:"2.0",id:e.id,error:{code:-32602,message:`Unsupported protocol version: ${n} - supported versions: ${xp}`,data:{supportedVersions:xp}}}}}async handleToolListRequest(e){let n={tools:Array.from(this.tools.entries()).map(([o,s])=>s.tool)};return{jsonrpc:"2.0",id:e.id,result:n}}async handleToolCallRequest(e){let r=Fb.safeParse(e);if(!r.success)return this.logger.warn("Could not validate tool call:",r.error),{jsonrpc:"2.0",id:e.id,error:{code:-32600,message:`Invalid request ${r.error}`}};let n=r.data,o=n.params.name,s=this.tools.get(o);if(!s)return{jsonrpc:"2.0",id:e.id,error:{code:-32601,message:`Tool "${o}" not found`}};let a=n.params.arguments??{},u=s.validator.parse(a);if(!u.success)return{jsonrpc:"2.0",id:e.id,error:{code:-32602,message:u.errorMessage?`Invalid arguments for tool '${o}': ${u.errorMessage}`:`Invalid arguments for tool '${o}'`,data:u.errorData}};try{let c=u.data,l=await s.handler(c);return{jsonrpc:"2.0",id:e.id,result:l}}catch(c){return this.logger.error(`Error executing tool "${o}":`,c),{jsonrpc:"2.0",id:e.id,error:{code:-32603,message:c instanceof Error?c.message:"Tool execution error"}}}}updateAvailableTools(){this.capabilities.tools&&(this.capabilities.tools.available=Array.from(this.tools.keys()))}};var Dr=class{static{i(this,"HTTPStreamableTransport")}messageHandler=null;closeCallback=null;options;connected=!1;enableStreaming=!1;sessions=new Map;streams=new Map;logger;constructor(e={},r=!1){this.options={timeout:30*60*1e3,enableSessions:!1,...e},this.logger=e.logger||gs(),r&&this.startSessionCleanup()}onError(e){throw new Error("Method not implemented.")}getSessionId(){throw new Error("Method not implemented.")}setSessionId(e){throw new Error("Method not implemented.")}async connect(){this.connected=!0}async send(e){if(!this.connected)throw new Error("Transport not connected");if(fs(e)){for(let[r,n]of this.sessions.entries())for(let[o,s]of n.streams.entries())if(s.pendingRequests.has(e.id)){await this.sendToStream(s,e),s.pendingRequests.delete(e.id),s.pendingRequests.size===0&&await this.closeStream(r,o);return}}else for(let r of this.sessions.values()){let n=[...r.streams.values()][0];n&&(await this.sendToStream(n,e),uo(e)&&n.pendingRequests.add(e.id))}}onMessage(e){this.messageHandler=e}onClose(e){this.closeCallback=e}async close(){this.connected=!1;for(let e of this.sessions.values()){for(let[r,n]of e.streams.entries())try{await n.writer.close()}catch(o){this.logger.warn("Error closing stream:",o)}e.streams.clear()}this.sessions.clear(),this.closeCallback&&this.closeCallback()}async handleRequest(e){if(!this.connected)return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32e3,message:"Transport not connected"},id:null}),{status:503,headers:{"Content-Type":"application/json"}});if(!this.messageHandler)return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32e3,message:"No message handler registered"},id:null}),{status:500,headers:{"Content-Type":"application/json"}});let r=e.method.toUpperCase();try{this.validateOrigin(e);let n=e.headers.get("Mcp-Session-Id"),o;if(n&&(o=this.sessions.get(n),!o&&r!=="DELETE"))return new Response(null,{status:404});switch(r){case"POST":return await this.handlePostRequest(e,o);case"GET":return await this.handleGetRequest(e,o);case"DELETE":return await this.handleDeleteRequest(e,o?.id);default:return new Response(null,{status:405,headers:{Allow:"POST, GET, DELETE"}})}}catch(n){this.logger.error("Error handling request:",n);let o=400,s={jsonrpc:"2.0",error:{code:-32603,message:n||"Server error"},id:null};return new Response(JSON.stringify(s),{status:o,headers:{"Content-Type":"application/json"}})}}async handlePostRequest(e,r){let n=e.headers.get("Accept")||"";if(!n.includes("application/json")&&!n.includes("text/event-stream"))return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32600,message:"Not Acceptable: Client must accept application/json and text/event-stream"},id:null}),{status:406,headers:{"Content-Type":"application/json"}});let o=await this.extractJSONRPC(e);if(!o||Array.isArray(o)&&o.length===0)return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32700,message:"Parse error"},id:null}),{status:400,headers:{"Content-Type":"application/json"}});let s=Array.isArray(o)?o:[o],a=s.some(c=>this.isRequest(c)),u=r;if(this.options.enableSessions&&!u&&s.some(c=>this.isRequest(c)&&c.method==="initialize")){let c=this.generateFallbackUUID();u=this.createSession(c)}try{if(!a){for(let m of s)await this.messageHandler?.(m);return new Response(null,{status:202,headers:u?{"Mcp-Session-Id":u.id}:void 0})}if(!this.enableStreaming){let m=[];for(let w of s)if(this.isRequest(w)){let x=await this.messageHandler?.(w);x&&m.push(x)}else await this.messageHandler?.(w);let f=m.length===1?m[0]:m,h={"Content-Type":"application/json"};return u&&(h["Mcp-Session-Id"]=u.id),new Response(JSON.stringify(f),{status:200,headers:h})}let{stream:c,streamId:l}=this.createStream(u),d=[];for(let m of s)if(this.isRequest(m)){this.streams.get(l)?.pendingRequests.add(m.id);let f=this.messageHandler?.(m);d.push(f)}else await this.messageHandler?.(m);let p={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"};return u&&(p["Mcp-Session-Id"]=u.id),new Response(c.readable,{headers:p})}catch(c){return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32603,message:c||"Internal error"},id:null}),{status:500,headers:{"Content-Type":"application/json"}})}}async handleGetRequest(e,r){if(!(e.headers.get("Accept")||"").includes("text/event-stream"))return new Response(null,{status:406,headers:{"Content-Type":"application/json"}});if(this.options.enableSessions&&!r)return new Response(JSON.stringify({jsonrpc:"2.0",error:{code:-32e3,message:"Session required"},id:null}),{status:400,headers:{"Content-Type":"application/json"}});let{stream:o,streamId:s}=this.createStream(r),a=e.headers.get("Last-Event-ID");a&&r&&await this.replayMessages(r,s,a);let u={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"};return r&&(u["Mcp-Session-Id"]=r.id),new Response(o.readable,{headers:u})}async handleDeleteRequest(e,r){if(!r)return new Response(null,{status:400});if(this.options.enableSessions&&r){let n=this.sessions.get(r);if(n){for(let[o,s]of n.streams.entries())await this.closeStream(r,o);return this.sessions.delete(r),new Response(null,{status:204})}}return new Response(null,{status:404})}async sendToStream(e,r){try{let n=String(++e.eventCounter),o=JSON.stringify(r);e.messages.push(r),e.messages.length>100&&e.messages.shift();let s=`id: ${n}
88
88
  data: ${o}
89
89
 
90
- `;await e.writer.write(new TextEncoder().encode(s))}catch(n){this.logger.warn("Error sending to stream:",n)}}async closeStream(e,r){let n=this.sessions.get(e);if(!n)return;let o=n.streams.get(r);if(o){try{await o.writer.close()}catch(s){this.logger.warn("Error closing stream:",s)}n.streams.delete(r),this.streams.delete(r)}}createSession(e){let r={id:e,createdAt:Date.now(),lastActivity:Date.now(),streams:new Map};return this.sessions.set(e,r),r}createStream(e){let r=new TransformStream,n=r.writable.getWriter(),o=crypto.randomUUID?.()||this.generateFallbackUUID(),s={id:o,writer:n,eventCounter:0,messages:[],pendingRequests:new Set};return this.streams.set(o,s),e&&(e.streams.set(o,s),e.lastActivity=Date.now()),{stream:r,streamId:o}}async replayMessages(e,r,n){for(let o of e.streams.values()){if(o.id===r)continue;let s=Number.parseInt(n,10);if(Number.isNaN(s))continue;let a=o.messages.slice(s),u=this.streams.get(r);if(u&&a.length>0)for(let c of a)await this.sendToStream(u,c)}}startSessionCleanup(){setInterval(()=>{let e=Date.now();for(let[r,n]of this.sessions.entries()){let o=this.options.timeout??6e4;if(e-n.lastActivity>o){for(let[s,a]of n.streams.entries()){try{a.writer.close().catch(u=>this.logger.warn("Error closing stream:",u))}catch(u){this.logger.warn("Error closing stream:",u)}this.streams.delete(s)}this.sessions.delete(r)}}},6e4)}async extractJSONRPC(e){try{let n=await e.clone().text();if(!n)throw new Error("Empty request body");return JSON.parse(n)}catch(r){throw new Error(`Failed to parse JSON-RPC message: ${r}`)}}validateOrigin(e){let r=e.headers.get("Origin");if(r&&!this.isValidOrigin(r))throw new Error("Invalid origin")}isValidOrigin(e){return!0}isRequest(e){return e!==null&&typeof e=="object"&&"jsonrpc"in e&&e.jsonrpc==="2.0"&&"method"in e&&"id"in e&&e.id!==null&&e.id!==void 0}generateFallbackUUID(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let r=Math.random()*16|0;return(e==="x"?r:r&3|8).toString(16)})}};var mo=class{static{i(this,"R")}type=3;name="";prefix="";value="";suffix="";modifier=3;constructor(t,e,r,n,o,s){this.type=t,this.name=e,this.prefix=r,this.value=n,this.suffix=o,this.modifier=s}hasCustomName(){return this.name!==""&&typeof this.name!="number"}},mE=/[$_\p{ID_Start}]/u,fE=/[$_\u200C\u200D\p{ID_Continue}]/u,Pp=".*";function gE(t,e){return(e?/^[\x00-\xFF]*$/:/^[\x00-\x7F]*$/).test(t)}i(gE,"Re");function Gb(t,e=!1){let r=[],n=0;for(;n<t.length;){let o=t[n],s=i(function(a){if(!e)throw new TypeError(a);r.push({type:"INVALID_CHAR",index:n,value:t[n++]})},"c");if(o==="*"){r.push({type:"ASTERISK",index:n,value:t[n++]});continue}if(o==="+"||o==="?"){r.push({type:"OTHER_MODIFIER",index:n,value:t[n++]});continue}if(o==="\\"){r.push({type:"ESCAPED_CHAR",index:n++,value:t[n++]});continue}if(o==="{"){r.push({type:"OPEN",index:n,value:t[n++]});continue}if(o==="}"){r.push({type:"CLOSE",index:n,value:t[n++]});continue}if(o===":"){let a="",u=n+1;for(;u<t.length;){let c=t.substr(u,1);if(u===n+1&&mE.test(c)||u!==n+1&&fE.test(c)){a+=t[u++];continue}break}if(!a){s(`Missing parameter name at ${n}`);continue}r.push({type:"NAME",index:n,value:a}),n=u;continue}if(o==="("){let a=1,u="",c=n+1,l=!1;if(t[c]==="?"){s(`Pattern cannot start with "?" at ${c}`);continue}for(;c<t.length;){if(!gE(t[c],!1)){s(`Invalid character '${t[c]}' at ${c}.`),l=!0;break}if(t[c]==="\\"){u+=t[c++]+t[c++];continue}if(t[c]===")"){if(a--,a===0){c++;break}}else if(t[c]==="("&&(a++,t[c+1]!=="?")){s(`Capturing groups are not allowed at ${c}`),l=!0;break}u+=t[c++]}if(l)continue;if(a){s(`Unbalanced pattern at ${n}`);continue}if(!u){s(`Missing pattern at ${n}`);continue}r.push({type:"REGEX",index:n,value:u}),n=c;continue}r.push({type:"CHAR",index:n,value:t[n++]})}return r.push({type:"END",index:n,value:""}),r}i(Gb,"v");function Jb(t,e={}){let r=Gb(t);e.delimiter??="/#?",e.prefixes??="./";let n=`[^${rt(e.delimiter)}]+?`,o=[],s=0,a=0,u="",c=new Set,l=i(L=>{if(a<r.length&&r[a].type===L)return r[a++].value},"a"),d=i(()=>l("OTHER_MODIFIER")??l("ASTERISK"),"f"),p=i(L=>{let U=l(L);if(U!==void 0)return U;let{type:z,index:E}=r[a];throw new TypeError(`Unexpected ${z} at ${E}, expected ${L}`)},"d"),m=i(()=>{let L="",U;for(;U=l("CHAR")??l("ESCAPED_CHAR");)L+=U;return L},"T"),f=i(L=>L,"Se"),h=e.encodePart||f,w="",x=i(L=>{w+=L},"U"),k=i(()=>{w.length&&(o.push(new mo(3,"","",h(w),"",3)),w="")},"$"),_=i((L,U,z,E,j)=>{let W=3;switch(j){case"?":W=1;break;case"*":W=0;break;case"+":W=2;break}if(!U&&!z&&W===3){x(L);return}if(k(),!U&&!z){if(!L)return;o.push(new mo(3,"","",h(L),"",W));return}let G;z?z==="*"?G=Pp:G=z:G=n;let C=2;G===n?(C=1,G=""):G===Pp&&(C=0,G="");let T;if(U?T=U:z&&(T=s++),c.has(T))throw new TypeError(`Duplicate name '${T}'.`);c.add(T),o.push(new mo(C,T,h(L),G,h(E),W))},"V");for(;a<r.length;){let L=l("CHAR"),U=l("NAME"),z=l("REGEX");if(!U&&!z&&(z=l("ASTERISK")),U||z){let j=L??"";e.prefixes.indexOf(j)===-1&&(x(j),j=""),k();let W=d();_(j,U,z,"",W);continue}let E=L??l("ESCAPED_CHAR");if(E){x(E);continue}if(l("OPEN")){let j=m(),W=l("NAME"),G=l("REGEX");!W&&!G&&(G=l("ASTERISK"));let C=m();p("CLOSE");let T=d();_(j,W,G,C,T);continue}k(),p("END")}return o}i(Jb,"D");function rt(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(rt,"S");function Bb(t){return t&&t.ignoreCase?"ui":"u"}i(Bb,"X");function hE(t,e,r){return Wb(Jb(t,r),e,r)}i(hE,"Z");function Zr(t){switch(t){case 0:return"*";case 1:return"?";case 2:return"+";case 3:return""}}i(Zr,"k");function Wb(t,e,r={}){r.delimiter??="/#?",r.prefixes??="./",r.sensitive??=!1,r.strict??=!1,r.end??=!0,r.start??=!0,r.endsWith="";let n=r.start?"^":"";for(let u of t){if(u.type===3){u.modifier===3?n+=rt(u.value):n+=`(?:${rt(u.value)})${Zr(u.modifier)}`;continue}e&&e.push(u.name);let c=`[^${rt(r.delimiter)}]+?`,l=u.value;if(u.type===1?l=c:u.type===0&&(l=Pp),!u.prefix.length&&!u.suffix.length){u.modifier===3||u.modifier===1?n+=`(${l})${Zr(u.modifier)}`:n+=`((?:${l})${Zr(u.modifier)})`;continue}if(u.modifier===3||u.modifier===1){n+=`(?:${rt(u.prefix)}(${l})${rt(u.suffix)})`,n+=Zr(u.modifier);continue}n+=`(?:${rt(u.prefix)}`,n+=`((?:${l})(?:`,n+=rt(u.suffix),n+=rt(u.prefix),n+=`(?:${l}))*)${rt(u.suffix)})`,u.modifier===0&&(n+="?")}let o=`[${rt(r.endsWith)}]|$`,s=`[${rt(r.delimiter)}]`;if(r.end)return r.strict||(n+=`${s}?`),r.endsWith.length?n+=`(?=${o})`:n+="$",new RegExp(n,Bb(r));r.strict||(n+=`(?:${s}(?=${o}))?`);let a=!1;if(t.length){let u=t[t.length-1];u.type===3&&u.modifier===3&&(a=r.delimiter.indexOf(u)>-1)}return a||(n+=`(?=${s}|${o})`),new RegExp(n,Bb(r))}i(Wb,"F");var Ft={delimiter:"",prefixes:"",sensitive:!0,strict:!0},yE={delimiter:".",prefixes:"",sensitive:!0,strict:!0},bE={delimiter:"/",prefixes:"/",sensitive:!0,strict:!0};function vE(t,e){return t.length?t[0]==="/"?!0:!e||t.length<2?!1:(t[0]=="\\"||t[0]=="{")&&t[1]=="/":!1}i(vE,"J");function Kb(t,e){return t.startsWith(e)?t.substring(e.length,t.length):t}i(Kb,"Q");function wE(t,e){return t.endsWith(e)?t.substr(0,t.length-e.length):t}i(wE,"Ee");function Qb(t){return!t||t.length<2?!1:t[0]==="["||(t[0]==="\\"||t[0]==="{")&&t[1]==="["}i(Qb,"W");var Xb=["ftp","file","http","https","ws","wss"];function Yb(t){if(!t)return!0;for(let e of Xb)if(t.test(e))return!0;return!1}i(Yb,"N");function xE(t,e){if(t=Kb(t,"#"),e||t==="")return t;let r=new URL("https://example.com");return r.hash=t,r.hash?r.hash.substring(1,r.hash.length):""}i(xE,"te");function RE(t,e){if(t=Kb(t,"?"),e||t==="")return t;let r=new URL("https://example.com");return r.search=t,r.search?r.search.substring(1,r.search.length):""}i(RE,"re");function PE(t,e){return e||t===""?t:Qb(t)?rv(t):tv(t)}i(PE,"ne");function IE(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.password=t,r.password}i(IE,"se");function SE(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.username=t,r.username}i(SE,"ie");function _E(t,e,r){if(r||t==="")return t;if(e&&!Xb.includes(e))return new URL(`${e}:${t}`).pathname;let n=t[0]=="/";return t=new URL(n?t:"/-"+t,"https://example.com").pathname,n||(t=t.substring(2,t.length)),t}i(_E,"ae");function EE(t,e,r){return ev(e)===t&&(t=""),r||t===""?t:nv(t)}i(EE,"oe");function kE(t,e){return t=wE(t,":"),e||t===""?t:Ip(t)}i(kE,"ce");function ev(t){switch(t){case"ws":case"http":return"80";case"wws":case"https":return"443";case"ftp":return"21";default:return""}}i(ev,"_");function Ip(t){if(t==="")return t;if(/^[-+.A-Za-z0-9]*$/.test(t))return t.toLowerCase();throw new TypeError(`Invalid protocol '${t}'.`)}i(Ip,"y");function TE(t){if(t==="")return t;let e=new URL("https://example.com");return e.username=t,e.username}i(TE,"le");function $E(t){if(t==="")return t;let e=new URL("https://example.com");return e.password=t,e.password}i($E,"fe");function tv(t){if(t==="")return t;if(/[\t\n\r #%/:<>?@[\]^\\|]/g.test(t))throw new TypeError(`Invalid hostname '${t}'`);let e=new URL("https://example.com");return e.hostname=t,e.hostname}i(tv,"z");function rv(t){if(t==="")return t;if(/[^0-9a-fA-F[\]:]/g.test(t))throw new TypeError(`Invalid IPv6 hostname '${t}'`);return t.toLowerCase()}i(rv,"j");function nv(t){if(t===""||/^[0-9]*$/.test(t)&&parseInt(t)<=65535)return t;throw new TypeError(`Invalid port '${t}'.`)}i(nv,"K");function OE(t){if(t==="")return t;let e=new URL("https://example.com");return e.pathname=t[0]!=="/"?"/-"+t:t,t[0]!=="/"?e.pathname.substring(2,e.pathname.length):e.pathname}i(OE,"he");function CE(t){return t===""?t:new URL(`data:${t}`).pathname}i(CE,"ue");function AE(t){if(t==="")return t;let e=new URL("https://example.com");return e.search=t,e.search.substring(1,e.search.length)}i(AE,"de");function LE(t){if(t==="")return t;let e=new URL("https://example.com");return e.hash=t,e.hash.substring(1,e.hash.length)}i(LE,"pe");var NE=class{static{i(this,"H")}#e;#t=[];#n={};#r=0;#o=1;#i=0;#s=0;#u=0;#c=0;#l=!1;constructor(t){this.#e=t}get result(){return this.#n}parse(){for(this.#t=Gb(this.#e,!0);this.#r<this.#t.length;this.#r+=this.#o){if(this.#o=1,this.#t[this.#r].type==="END"){if(this.#s===0){this.#v(),this.#m()?this.#a(9,1):this.#f()?this.#a(8,1):this.#a(7,0);continue}else if(this.#s===2){this.#g(5);continue}this.#a(10,0);break}if(this.#u>0)if(this.#_())this.#u-=1;else continue;if(this.#S()){this.#u+=1;continue}switch(this.#s){case 0:this.#w()&&this.#g(1);break;case 1:if(this.#w()){this.#T();let t=7,e=1;this.#R()?(t=2,e=3):this.#l&&(t=2),this.#a(t,e)}break;case 2:this.#y()?this.#g(3):(this.#b()||this.#f()||this.#m())&&this.#g(5);break;case 3:this.#P()?this.#a(4,1):this.#y()&&this.#a(5,1);break;case 4:this.#y()&&this.#a(5,1);break;case 5:this.#E()?this.#c+=1:this.#k()&&(this.#c-=1),this.#I()&&!this.#c?this.#a(6,1):this.#b()?this.#a(7,0):this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 6:this.#b()?this.#a(7,0):this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 7:this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 8:this.#m()&&this.#a(9,1);break;case 9:break;case 10:break}}this.#n.hostname!==void 0&&this.#n.port===void 0&&(this.#n.port="")}#a(t,e){switch(this.#s){case 0:break;case 1:this.#n.protocol=this.#p();break;case 2:break;case 3:this.#n.username=this.#p();break;case 4:this.#n.password=this.#p();break;case 5:this.#n.hostname=this.#p();break;case 6:this.#n.port=this.#p();break;case 7:this.#n.pathname=this.#p();break;case 8:this.#n.search=this.#p();break;case 9:this.#n.hash=this.#p();break;case 10:break}this.#s!==0&&t!==10&&([1,2,3,4].includes(this.#s)&&[6,7,8,9].includes(t)&&(this.#n.hostname??=""),[1,2,3,4,5,6].includes(this.#s)&&[8,9].includes(t)&&(this.#n.pathname??=this.#l?"/":""),[1,2,3,4,5,6,7].includes(this.#s)&&t===9&&(this.#n.search??="")),this.#x(t,e)}#x(t,e){this.#s=t,this.#i=this.#r+e,this.#r+=e,this.#o=0}#v(){this.#r=this.#i,this.#o=0}#g(t){this.#v(),this.#s=t}#h(t){return t<0&&(t=this.#t.length-t),t<this.#t.length?this.#t[t]:this.#t[this.#t.length-1]}#d(t,e){let r=this.#h(t);return r.value===e&&(r.type==="CHAR"||r.type==="ESCAPED_CHAR"||r.type==="INVALID_CHAR")}#w(){return this.#d(this.#r,":")}#R(){return this.#d(this.#r+1,"/")&&this.#d(this.#r+2,"/")}#y(){return this.#d(this.#r,"@")}#P(){return this.#d(this.#r,":")}#I(){return this.#d(this.#r,":")}#b(){return this.#d(this.#r,"/")}#f(){if(this.#d(this.#r,"?"))return!0;if(this.#t[this.#r].value!=="?")return!1;let t=this.#h(this.#r-1);return t.type!=="NAME"&&t.type!=="REGEX"&&t.type!=="CLOSE"&&t.type!=="ASTERISK"}#m(){return this.#d(this.#r,"#")}#S(){return this.#t[this.#r].type=="OPEN"}#_(){return this.#t[this.#r].type=="CLOSE"}#E(){return this.#d(this.#r,"[")}#k(){return this.#d(this.#r,"]")}#p(){let t=this.#t[this.#r],e=this.#h(this.#i).index;return this.#e.substring(e,t.index)}#T(){let t={};Object.assign(t,Ft),t.encodePart=Ip;let e=hE(this.#p(),void 0,t);this.#l=Yb(e)}},Rp=["protocol","username","password","hostname","port","pathname","search","hash"],Ht="*";function Vb(t,e){if(typeof t!="string")throw new TypeError("parameter 1 is not of type 'string'.");let r=new URL(t,e);return{protocol:r.protocol.substring(0,r.protocol.length-1),username:r.username,password:r.password,hostname:r.hostname,port:r.port,pathname:r.pathname,search:r.search!==""?r.search.substring(1,r.search.length):void 0,hash:r.hash!==""?r.hash.substring(1,r.hash.length):void 0}}i(Vb,"ge");function Ot(t,e){return e?po(t):t}i(Ot,"b");function lo(t,e,r){let n;if(typeof e.baseURL=="string")try{n=new URL(e.baseURL),e.protocol===void 0&&(t.protocol=Ot(n.protocol.substring(0,n.protocol.length-1),r)),!r&&e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.username===void 0&&(t.username=Ot(n.username,r)),!r&&e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.username===void 0&&e.password===void 0&&(t.password=Ot(n.password,r)),e.protocol===void 0&&e.hostname===void 0&&(t.hostname=Ot(n.hostname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&(t.port=Ot(n.port,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&(t.pathname=Ot(n.pathname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&e.search===void 0&&(t.search=Ot(n.search.substring(1,n.search.length),r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&e.search===void 0&&e.hash===void 0&&(t.hash=Ot(n.hash.substring(1,n.hash.length),r))}catch{throw new TypeError(`invalid baseURL '${e.baseURL}'.`)}if(typeof e.protocol=="string"&&(t.protocol=kE(e.protocol,r)),typeof e.username=="string"&&(t.username=SE(e.username,r)),typeof e.password=="string"&&(t.password=IE(e.password,r)),typeof e.hostname=="string"&&(t.hostname=PE(e.hostname,r)),typeof e.port=="string"&&(t.port=EE(e.port,t.protocol,r)),typeof e.pathname=="string"){if(t.pathname=e.pathname,n&&!vE(t.pathname,r)){let o=n.pathname.lastIndexOf("/");o>=0&&(t.pathname=Ot(n.pathname.substring(0,o+1),r)+t.pathname)}t.pathname=_E(t.pathname,t.protocol,r)}return typeof e.search=="string"&&(t.search=RE(e.search,r)),typeof e.hash=="string"&&(t.hash=xE(e.hash,r)),t}i(lo,"w");function po(t){return t.replace(/([+*?:{}()\\])/g,"\\$1")}i(po,"C");function zE(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(zE,"Oe");function UE(t,e){e.delimiter??="/#?",e.prefixes??="./",e.sensitive??=!1,e.strict??=!1,e.end??=!0,e.start??=!0,e.endsWith="";let r=".*",n=`[^${zE(e.delimiter)}]+?`,o=/[$_\u200C\u200D\p{ID_Continue}]/u,s="";for(let a=0;a<t.length;++a){let u=t[a];if(u.type===3){if(u.modifier===3){s+=po(u.value);continue}s+=`{${po(u.value)}}${Zr(u.modifier)}`;continue}let c=u.hasCustomName(),l=!!u.suffix.length||!!u.prefix.length&&(u.prefix.length!==1||!e.prefixes.includes(u.prefix)),d=a>0?t[a-1]:null,p=a<t.length-1?t[a+1]:null;if(!l&&c&&u.type===1&&u.modifier===3&&p&&!p.prefix.length&&!p.suffix.length)if(p.type===3){let m=p.value.length>0?p.value[0]:"";l=o.test(m)}else l=!p.hasCustomName();if(!l&&!u.prefix.length&&d&&d.type===3){let m=d.value[d.value.length-1];l=e.prefixes.includes(m)}l&&(s+="{"),s+=po(u.prefix),c&&(s+=`:${u.name}`),u.type===2?s+=`(${u.value})`:u.type===1?c||(s+=`(${n})`):u.type===0&&(!c&&(!d||d.type===3||d.modifier!==3||l||u.prefix!=="")?s+="*":s+=`(${r})`),u.type===1&&c&&u.suffix.length&&o.test(u.suffix[0])&&(s+="\\"),s+=po(u.suffix),l&&(s+="}"),u.modifier!==3&&(s+=Zr(u.modifier))}return s}i(UE,"ke");var hs=class{static{i(this,"me")}#e;#t={};#n={};#r={};#o={};#i=!1;constructor(t={},e,r){try{let n;if(typeof e=="string"?n=e:r=e,typeof t=="string"){let u=new NE(t);if(u.parse(),t=u.result,n===void 0&&typeof t.protocol!="string")throw new TypeError("A base URL must be provided for a relative constructor string.");t.baseURL=n}else{if(!t||typeof t!="object")throw new TypeError("parameter 1 is not of type 'string' and cannot convert to dictionary.");if(n)throw new TypeError("parameter 1 is not of type 'string'.")}typeof r>"u"&&(r={ignoreCase:!1});let o={ignoreCase:r.ignoreCase===!0},s={pathname:Ht,protocol:Ht,username:Ht,password:Ht,hostname:Ht,port:Ht,search:Ht,hash:Ht};this.#e=lo(s,t,!0),ev(this.#e.protocol)===this.#e.port&&(this.#e.port="");let a;for(a of Rp){if(!(a in this.#e))continue;let u={},c=this.#e[a];switch(this.#n[a]=[],a){case"protocol":Object.assign(u,Ft),u.encodePart=Ip;break;case"username":Object.assign(u,Ft),u.encodePart=TE;break;case"password":Object.assign(u,Ft),u.encodePart=$E;break;case"hostname":Object.assign(u,yE),Qb(c)?u.encodePart=rv:u.encodePart=tv;break;case"port":Object.assign(u,Ft),u.encodePart=nv;break;case"pathname":Yb(this.#t.protocol)?(Object.assign(u,bE,o),u.encodePart=OE):(Object.assign(u,Ft,o),u.encodePart=CE);break;case"search":Object.assign(u,Ft,o),u.encodePart=AE;break;case"hash":Object.assign(u,Ft,o),u.encodePart=LE;break}try{this.#o[a]=Jb(c,u),this.#t[a]=Wb(this.#o[a],this.#n[a],u),this.#r[a]=UE(this.#o[a],u),this.#i=this.#i||this.#o[a].some(l=>l.type===2)}catch{throw new TypeError(`invalid ${a} pattern '${this.#e[a]}'.`)}}}catch(n){throw new TypeError(`Failed to construct 'URLPattern': ${n.message}`)}}test(t={},e){let r={pathname:"",protocol:"",username:"",password:"",hostname:"",port:"",search:"",hash:""};if(typeof t!="string"&&e)throw new TypeError("parameter 1 is not of type 'string'.");if(typeof t>"u")return!1;try{typeof t=="object"?r=lo(r,t,!1):r=lo(r,Vb(t,e),!1)}catch{return!1}let n;for(n of Rp)if(!this.#t[n].exec(r[n]))return!1;return!0}exec(t={},e){let r={pathname:"",protocol:"",username:"",password:"",hostname:"",port:"",search:"",hash:""};if(typeof t!="string"&&e)throw new TypeError("parameter 1 is not of type 'string'.");if(typeof t>"u")return;try{typeof t=="object"?r=lo(r,t,!1):r=lo(r,Vb(t,e),!1)}catch{return null}let n={};e?n.inputs=[t,e]:n.inputs=[t];let o;for(o of Rp){let s=this.#t[o].exec(r[o]);if(!s)return null;let a={};for(let[u,c]of this.#n[o].entries())if(typeof c=="string"||typeof c=="number"){let l=s[u+1];a[c]=l}n[o]={input:r[o]??"",groups:a}}return n}static compareComponent(t,e,r){let n=i((u,c)=>{for(let l of["type","modifier","prefix","value","suffix"]){if(u[l]<c[l])return-1;if(u[l]!==c[l])return 1}return 0},"o"),o=new mo(3,"","","","",3),s=new mo(0,"","","","",3),a=i((u,c)=>{let l=0;for(;l<Math.min(u.length,c.length);++l){let d=n(u[l],c[l]);if(d)return d}return u.length===c.length?0:n(u[l]??o,c[l]??o)},"s");return!e.#r[t]&&!r.#r[t]?0:e.#r[t]&&!r.#r[t]?a(e.#o[t],[s]):!e.#r[t]&&r.#r[t]?a([s],r.#o[t]):a(e.#o[t],r.#o[t])}get protocol(){return this.#r.protocol}get username(){return this.#r.username}get password(){return this.#r.password}get hostname(){return this.#r.hostname}get port(){return this.#r.port}get pathname(){return this.#r.pathname}get search(){return this.#r.search}get hash(){return this.#r.hash}get hasRegExpGroups(){return this.#i}};var ys=class{static{i(this,"UrlPatternBuilder")}pattern;pathParams={};searchParams=new URLSearchParams;expectedPathParams=new Set;seenPathParams=new Set;constructor(e){this.pattern=new hs({pathname:e});let r=/:(\w+)(\([^)]*\))?[*+?]?/g,n;for(;(n=r.exec(e))!==null;)this.expectedPathParams.add(n[1])}addParameter(e,r,n){let o=this.getParameterValue(e,r,n);if(o!=null)switch(e.in){case"path":if(!this.expectedPathParams.has(e.name))throw new y(`path parameter '${e.name}' missing from pattern '${this.pattern.pathname}'`);this.seenPathParams.add(e.name),this.addPathParameter(e.name,o);break;case"query":this.addQueryParameter(e.name,o);break;default:break}}getParameterValue(e,r,n){switch(e.in){case"path":return r?.[e.name];case"query":return n?.[e.name];default:return}}addPathParameter(e,r){this.pathParams[e]=String(r)}addQueryParameter(e,r){Array.isArray(r)?r.forEach(n=>{n!=null&&this.searchParams.append(e,String(n))}):typeof r=="object"&&r!==null?this.searchParams.append(e,JSON.stringify(r)):this.searchParams.append(e,String(r))}toString(){let e=[...this.expectedPathParams].filter(s=>!this.seenPathParams.has(s));if(e.length>0)throw new y(`missing path parameters in OpenAPI spec: ${e.join(", ")}`);let r=this.pattern.pathname.replace(/:(\w+)(\([^)]*\))?([*+?])?/g,(s,a)=>this.pathParams[a]?encodeURIComponent(this.pathParams[a]):s),n=this.cleanupUrlPatternSyntax(r),o=this.searchParams.toString();return o?`${n}?${o}`:n}cleanupUrlPatternSyntax(e){return e.replace(/\{\/\}\?/g,"").replace(/\{\/\}[*+]/g,"/").replace(/\{\/\}/g,"/").replace(/(\{[^}]*\})[?*+]/g,"$1")}};var bs=class{constructor(e){this.routeData=e}static{i(this,"McpUrlBuilder")}build(e,r){let n=this.routeData.pathPattern?this.routeData.pathPattern:this.routeData.path,o=this.routeData.raw()?.parameters||[],s=new ys(n);for(let a of o)s.addParameter(a,e,r);return s.toString()}};var Bt=class{static{i(this,"CustomValidator")}jsonSchema;parseFn;constructor(e,r){this.jsonSchema=e,this.parseFn=r}parse(e){return this.parseFn(e)}};Le();Le();Le();var vs=class{static{i(this,"ZodFormatSchemaRegistry")}static formatter=new Map([["email",()=>g.email()],["uri",()=>g.url()],["url",()=>g.url()],["uuid",()=>g.uuid()],["date",()=>g.iso.date()],["date-time",()=>g.iso.datetime()],["time",()=>g.iso.time()],["ipv4",()=>g.ipv4()],["ipv6",()=>g.ipv6()],["int32",()=>g.int32()],["int64",()=>g.int64()],["float",()=>g.number()],["double",()=>g.number()]]);static get(e){return this.formatter.get(e)}static register(e,r){this.formatter.set(e,r)}},fo=class{static{i(this,"OpenApiToZodTranspiler")}static typeTranspilers=new Map([["string",this.transpileString.bind(this)],["number",this.transpileNumber.bind(this)],["integer",this.transpileInteger.bind(this)],["boolean",this.transpileBoolean.bind(this)],["array",this.transpileArray.bind(this)],["object",this.transpileObject.bind(this)],["null",this.transpileNull.bind(this)]]);static run(e,r){let n={path:[],definitions:{},visitedRefs:new Set,...r};return this.transpileSchema(e,n)}static transpileSchema(e,r){if(!e)return g.unknown();try{if("$ref"in e)return this.resolveReference(e.$ref,r);if(e.allOf)return this.transpileAllOf(e.allOf,r);if(e.oneOf)return this.transpileOneOf(e.oneOf,r);if(e.anyOf)return this.transpileAnyOf(e.anyOf,r);if(e.not)return this.transpileNot(e.not,r);let n=this.transpileByType(e,r);return n=this.applyCommonModifiers(n,e),n}catch(n){let o=r.path.join(".");throw new Error(`Failed to transpile schema at path "${o}": ${n.message}`)}}static transpileByType(e,r){let n=this.typeTranspilers.get(e.type||"unknown");return n?n(e,r):g.unknown()}static transpileString(e,r){if(e.enum)return g.enum(e.enum);let n=e.format?vs.get(e.format):null,o=n?n():g.string();if(o instanceof g.ZodString){let s=o;return e.minLength!==void 0&&(s=s.min(e.minLength)),e.maxLength!==void 0&&(s=s.max(e.maxLength)),e.pattern&&(s=s.regex(new RegExp(e.pattern))),s}else e.minLength||e.maxLength||e.pattern;return o}static applyNumericConstraints(e,r,n){let o=e;if(r.minimum!==void 0&&(o=o.min(r.minimum)),r.maximum!==void 0&&(o=o.max(r.maximum)),r.exclusiveMinimum!==void 0){let s;if(typeof r.exclusiveMinimum=="number")s=r.exclusiveMinimum;else if(r.minimum!==void 0)s=r.minimum+Number.EPSILON;else throw new Error(`exclusiveMinimum requires minimum to be set at path "${n.path.join(".")}"`);o=o.gt(s)}if(r.exclusiveMaximum!==void 0){let s;if(typeof r.exclusiveMaximum=="number")s=r.exclusiveMaximum;else if(r.maximum!==void 0)s=r.maximum-Number.EPSILON;else throw new Error(`exclusiveMaximum requires maximum to be set at path "${n.path.join(".")}"`);o=o.lt(s)}return o}static transpileNumber(e,r){let n=g.number();return this.applyNumericConstraints(n,{...e,type:"number"},r)}static transpileInteger(e,r){let n=g.int();return this.applyNumericConstraints(n,{...e,type:"number"},r)}static transpileBoolean(e,r){return g.boolean()}static transpileArray(e,r){let n=e.items?this.transpileSchema(e.items,{...r,path:[...r.path,"items"]}):g.unknown(),o=g.array(n);return e.minItems!==void 0&&(o=o.min(e.minItems)),e.maxItems!==void 0&&(o=o.max(e.maxItems)),e.uniqueItems&&(o=o.refine(s=>new Set(s).size===s.length,{message:"Array must contain unique items"})),o}static transpileObject(e,r){let n;if(e.properties){let o={},s=new Set(e.required||[]);for(let[u,c]of Object.entries(e.properties)){let l={...r,path:[...r.path,u]},d=this.transpileSchema(c,l);s.has(u)||(d=d.optional()),o[u]=d}let a=g.object(o);e.additionalProperties===!1?a=a.strict():typeof e.additionalProperties=="object"&&(a=a.passthrough()),n=a}else if(e.additionalProperties===!1)n=g.object({}).strict();else if(typeof e.additionalProperties=="object"){let o=this.transpileSchema(e.additionalProperties,r);n=g.record(g.string(),o)}else n=g.unknown();return(e.minProperties!==void 0||e.maxProperties!==void 0)&&(n=n.refine(o=>{let s=Object.keys(o).length;return!(e.minProperties!==void 0&&s<e.minProperties||e.maxProperties!==void 0&&s>e.maxProperties)},{message:this.buildPropertyCountErrorMessage(e.minProperties,e.maxProperties)})),n}static buildPropertyCountErrorMessage(e,r){return e!==void 0&&r!==void 0?`Object must have between ${e} and ${r} properties`:e!==void 0?`Object must have at least ${e} properties`:`Object must have at most ${r} properties`}static transpileNull(e,r){return g.null()}static transpileAllOf(e,r){return e.map((o,s)=>this.transpileSchema(o,{...r,path:[...r.path,`allOf[${s}]`]})).reduce((o,s)=>o.and(s))}static transpileOneOf(e,r){let n=e.map((o,s)=>this.transpileSchema(o,{...r,path:[...r.path,`oneOf[${s}]`]}));return n.length===0?g.never():n.length===1?n[0]:g.union(n)}static transpileAnyOf(e,r){return this.transpileOneOf(e,r)}static transpileNot(e,r){let n=this.transpileSchema(e,{...r,path:[...r.path,"not"]});return g.unknown().refine(o=>!n.safeParse(o).success,{message:"Value must not match the schema"})}static resolveReference(e,r){if(r.visitedRefs?.has(e))return g.lazy(()=>this.resolveReference(e,r));r.visitedRefs?.add(e);let n=e.split("/");if(n[0]==="#"&&n[1]==="definitions"&&r.definitions){let o=r.definitions[n[2]];if(o)return this.transpileSchema(o,r)}throw new Error(`Unable to resolve reference: ${e}`)}static applyCommonModifiers(e,r){let n=e;return r.nullable&&(n=n.nullable()),r.default!==void 0&&(n=n.default(r.default)),r.description&&(n=n.describe(r.description)),r.examples&&r.examples.length>0&&(n=n.meta({examples:r.examples})),n}static registerTypeTranspiler(e,r){this.typeTranspilers.set(e,r)}static registerFormatSchema(e,r){vs.register(e,r)}};var ws=class{constructor(e,r){this.routeData=e;this.contentType=r}static{i(this,"RequestBodySchemaBuilder")}build(){let e=this.routeData.raw()?.requestBody;if(!e?.content?.[this.contentType])return null;let r=e.content[this.contentType].schema;return r?fo.run(r):null}},xs=class{constructor(e){this.parameters=e}static{i(this,"ParameterSchemaBuilder")}build(){if(this.parameters.length===0)return null;let e={};for(let r of this.parameters)e[r.name]=this.buildParameterSchema(r);return g.object(e)}buildParameterSchema(e){let r;e.schema?r=fo.run(e.schema):r=g.string(),e.required||(r=r.optional()),e.description&&(r=r.describe(e.description));let n=[];if(e.schema?.example!==void 0&&n.push(e.schema.example),e.schema?.examples!==void 0&&Array.isArray(e.schema.examples)&&n.push(...e.schema.examples),e.examples&&(Array.isArray(e.examples)?n.push(...e.examples):typeof e.examples=="object"&&Object.values(e.examples).forEach(o=>{o?.value!==void 0&&n.push(o.value)})),e.example!==void 0&&n.push(e.example),n.length>0){let o=[...new Set(n.map(s=>JSON.stringify(s)))].map(s=>JSON.parse(s));r=r.meta({examples:o})}return r}};var Sp=class{static{i(this,"UniversalValidatorBuilder")}components={};withBody(e){return e&&(this.components.body=e),this}withQueryParams(e){return e&&(this.components.queryParams=e),this}withPathParams(e){return e&&(this.components.pathParams=e),this}withHeaders(e){return e&&(this.components.headers=e),this}build(){if(Object.keys(this.components).length===0)return this.buildEmptyValidator();let e=g.object(this.components),r=g.toJSONSchema(e);return new Bt(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:n,errorData:null}:{success:!1,data:null,errorMessage:this.formatValidationErrors(o.error.issues),errorData:o.error}})}buildEmptyValidator(){let e={type:"object",properties:{},required:[],additionalProperties:!1};return new Bt(e,()=>({success:!0,data:{},errorData:null}))}formatValidationErrors(e){return e.map(r=>`${r.path.length>0?r.path.join("."):"root"}: ${r.message}`).join(", ")}},Rs=class{static{i(this,"SchemaBuilderFactory")}static createRequestBodyBuilder(e,r){return new ws(e,r)}static createParameterBuilder(e,r){let n=r?e.filter(o=>o.in===r):e;return new xs(n)}static createValidatorBuilder(e,r){let n=new Sp,o=e.raw()?.parameters||[];if(r){let c=this.createRequestBodyBuilder(e,r);n.withBody(c.build())}let s=this.createParameterBuilder(o,"query");n.withQueryParams(s.build());let a=this.createParameterBuilder(o,"path");n.withPathParams(a.build());let u=this.createParameterBuilder(o,"header");return n.withHeaders(u.build()),n}};import{AsyncLocalStorage as DE}from"node:async_hooks";var _p=new DE;function ov(t,e,r){return _p.run({headers:t,zuploContext:e},r)}i(ov,"runWithInvokeContext");function iv(){return _p.getStore()?.headers??{}}i(iv,"getInvokeHeaders");function sv(){let t=_p.getStore();if(!t)throw new Error("No Zuplo context available in current execution context");return t.zuploContext}i(sv,"getInvokeContext");var Ps=class t{static{i(this,"ZuploMcpServer")}static instances=new Map;static async getInstance(e,r){let n=r.route?.path??"unknown-route",o=e.debugMode??!1,s=t.instances.get(n);if(s)o&&r.log.debug("MCP Server warm reuse",{routeKey:n});else{let a=Date.now();if(s=new t(e,r),s.registerToolsFromOptions(s.opts.openApiTools??[]),s.registerToolsFromFiles(s.opts.openApiFilePaths??[]),await s.transport.connect(),s.server.withTransport(s.transport),t.instances.set(n,s),o){let u=s.server.getTools(),c=u?u.size:0,l=Date.now()-a;r.log.debug("MCP Server cold start",{routeKey:n,toolCount:c,totalElapsedMs:l,debugMode:o,includeOutputSchema:s.includeOutputSchema,includeStructuredContent:s.includeStructuredContent})}}return s}transport;server;opts;context;includeOutputSchema;includeStructuredContent;debugMode;constructor(e,r){this.debugMode=e.debugMode??!1;let n;this.debugMode?n=r.log:n=new ir,this.context=r,this.opts=e,this.server=new Ur({name:e.name??"Zuplo MCP Server",version:e.version??"0.0.0",logger:n}),this.transport=new Dr({logger:n}),this.includeOutputSchema=e.includeOutputSchema??!1,this.includeStructuredContent=e.includeStructuredContent??!1}buildInvokeHeaders(){return iv()}async handleRequest(e,r){let n=Date.now();try{let o=await e.clone().json().catch(()=>({}));if(this.debugMode&&r.log.debug("MCP Server request start",{method:o.method,requestId:o.id,routePath:r.route?.path}),this.debugMode&&o.method==="tools/list"){let u=this.server.getTools(),c=u?Array.from(u.keys()):[];r.log.debug("MCP Server list tools request",{toolCount:c.length,toolNames:c})}let s=await this.transport.handleRequest(e),a=Date.now()-n;if(this.debugMode){let u=await s.clone().json().catch(()=>({}));r.log.debug("MCP Server response complete",{status:s.status,requestMethod:o.method,requestId:o.id,totalElapsedMs:a,respData:u})}return s}catch(o){let s=Date.now()-n;return r.log.error("MCP server internal error",{elapsedMs:s,err:o}),new Response("Internal error",{status:500})}}generateToolNameFromSpec(e,r){let n=e.raw();if(n?.operationId)return`${n.operationId}`;let o=`${r}_${e.path}`.replace(/[^\w]/g,"_");return this.context.log.warn(`No operationId found for route ${r} ${e.path}. Using auto-generated name "${o}". To improve AI tool selection, add a descriptive operationId to your OpenAPI spec (e.g., "get_user_by_id" instead of "GET_/users/{id}")`),o}generateToolDescriptionFromSpec(e,r){let n=e.raw();return n?.description?n.description:n?.summary?n.summary:`Call ${r.toUpperCase()} ${e.path}`}registerToolsFromOptions(e){let r=new Set;for(let n of e){if(n.name){if(typeof n.name!="string"||n.name.trim()==="")throw new Error("MCP Tool configuration error: Tool name must be a non-empty string if provided.");if(r.has(n.name))throw new Error(`MCP Tool configuration error: Duplicate tool name "${n.name}". Tool names must be unique across all configured tools.`)}let o=this.getRouteDataForOptions(n);if(!o){let l=n.operationId?`operationId: "${n.operationId}"`:`path: "${n.path}"`;throw new Error(`MCP Tool configuration error: Could not find gateway route data for ${n.method.toUpperCase()} ${l}. Verify that the route exists in your OpenAPI specification and that the provided metadata matches OpenAPI specification data.`)}if(!o.handler){let l=n.operationId?`operationId: "${n.operationId}"`:`path: "${n.path}"`;throw new Error(`MCP Tool configuration error: Route ${n.method.toUpperCase()} ${l} has no handler configured. Ensure the route has a proper handler defined in your OpenAPI specification.`)}let s=n.name??this.generateToolNameFromSpec(o,n.method);if(r.has(s))throw new Error(`MCP Tool configuration error: Tool name conflict detected. The name "${s}" is already in use. Consider providing a unique 'name' in your tool configuration or ensure your operationIds are unique.`);r.add(s);let a=n.description??this.generateToolDescriptionFromSpec(o,n.method),u=n.includeOutputSchema??this.includeOutputSchema??!0,c=n.includeStructuredContent??this.includeStructuredContent??!0;this.registerToolsForMethod(o,n.method,s,a,u,c)}}registerToolsFromFiles(e){let r=new Set(e.map(s=>s.filePath)),n=new Set;for(let s of ye.instance.routeData.routes){let a=s.metadata?.filepath;a&&r.has(a)&&(n.add(a),this.registerToolsForRawRoutedata(s,this.includeOutputSchema,this.includeStructuredContent))}let o=e.map(s=>s.filePath).filter(s=>!n.has(s));if(o.length>0)throw new Error(`MCP Tool configuration error: Could not find routes for the following file paths: ${o.join(", ")}. Verify that these OpenAPI files exist and are properly loaded in your Gateway configuration.`)}registerToolsForRawRoutedata(e,r,n){if(e.mcp?.enabled!==!1){if(!e)throw new Error("MCP Tool configuration error: Route data cannot be null or undefined.");if(!e.methods||e.methods.length===0)throw new Error(`MCP Tool configuration error: Route "${e.path}" has no HTTP methods defined. Ensure the route has at least one HTTP method (GET, POST, etc.) in your OpenAPI specification.`);if(!e.handler)throw new Error(`MCP Tool configuration error: Route "${e.path}" has no handler configured. Ensure the route has a proper handler defined in your OpenAPI specification.`);for(let o of e.methods){let s=this.generateToolNameFromSpec(e,o),a=this.generateToolDescriptionFromSpec(e,o);this.registerToolsForMethod(e,o,s,a,r,n)}}}registerToolsForMethod(e,r,n,o,s,a){if(e.handler?.export!=="mcpServerHandler")if(e.raw().requestBody?.content)for(let u of Object.keys(e.raw().requestBody?.content)){let l=Object.keys(e.raw().requestBody?.content).length>1?`${n}_${u.replace(/[^\w]/g,"_")}`:n;this.registerGenericToolSpec(l,o,e,r,u,s,a)}else this.registerGenericToolSpec(n,o,e,r,null,s,a)}registerGenericToolSpec(e,r,n,o,s,a,u){let c=this.buildUniversalValidator(n,s);if(!c)throw new Error(`MCP Tool registration error: Could not build parameter validator for ${o.toUpperCase()} ${n.path}. This may indicate an issue with the OpenAPI parameter definitions for this route.`);let l=a?this.extractOutputSchema(n):void 0;try{this.server.addTool({name:e,description:r,validator:c,...l&&{outputSchema:l},handler:i(async d=>{let p=sv(),m=Date.now();try{this.debugMode&&p.log.debug("MCP tool invoked",{toolName:e,operationId:n.raw()?.operationId,method:o,path:n.path,args:d});let f=this.buildToolUrl(n,d),h=this.buildToolRequest(o,s,d);this.debugMode&&p.log.debug("MCP tool downstream call",{toolName:e,url:f,method:o,headers:h.headers?Object.keys(h.headers).join(", "):"",bodyPreview:d.body});let w=Date.now(),x=await p.invokeRoute(f,h),k=Date.now()-w,_=await x.text(),L;if(u)try{L=JSON.parse(_)}catch(z){this.debugMode&&p.log.debug("MCP tool structuredContent JSON parse failed",{toolName:e,body:_,parseErr:z})}let U=Date.now()-m;return this.debugMode&&(x.ok?p.log.debug("MCP tool ok response",{toolName:e,operationId:n.raw()?.operationId,status:x.status,elapsedMs:U,downstreamElapsedMs:k}):p.log.debug("MCP tool 'isError' response",{toolName:e,operationId:n.raw()?.operationId,status:x.status,elapsedMs:U,downstreamElapsedMs:k,response:_})),{content:[{type:"text",text:_}],...L&&{structuredContent:L},isError:!x.ok}}catch(f){let h=Date.now()-m,w=f instanceof Error?`${f.name}: ${f.message}`:String(f);return p.log.error("MCP server tool invocation failed",{toolName:e,operationId:n.raw()?.operationId,method:o,path:n.path,elapsedMs:h,err:f}),{content:[{type:"text",text:`MCP tool call failed for tool '${e}': ${w}`}],isError:!0}}},"handler")}),this.debugMode&&this.context.log.debug("MCP tool registered",{toolName:e,method:o.toUpperCase(),path:n.path,operationId:n.raw()?.operationId,contentType:s||"none",includeOutputSchema:a,includeStructuredContent:u,hasValidator:!!c,hasOutputSchema:!!l})}catch(d){throw new Error(`Failed to add tool ${o} ${n.path}`,d)}}buildToolUrl(e,r){return new bs(e).build(r.pathParams,r.queryParams)}buildToolRequest(e,r,n){let o=this.buildToolHeaders(e,r,n),s={method:e,headers:o};return this.shouldIncludeBody(e,r,n)&&(s.body=this.serializeBody(n.body,r)),s}buildToolHeaders(e,r,n){let o={...this.buildInvokeHeaders()};return n.headers&&Object.entries(n.headers).forEach(([s,a])=>{o[s.toLowerCase()]=a}),r&&n.body!==void 0&&(o["content-type"]=r),this.isBodyMethod(e||"")&&n.body!==void 0&&!o["content-type"]&&(o["content-type"]="application/json"),o}shouldIncludeBody(e,r,n){return n.body===void 0?!1:this.isBodyMethod(e)?!0:r!==null}isBodyMethod(e){return["POST","PUT","PATCH"].includes(e.toUpperCase())}serializeBody(e,r){return JSON.stringify(e)}buildUniversalValidator(e,r){try{let o=Rs.createValidatorBuilder(e,r).build();return this.debugMode&&this.context.log.debug("MCP validator built successfully",{method:e.methods?.[0],path:e.path,contentType:r||"none",operationId:e.raw()?.operationId}),o}catch(n){let o=n instanceof Error?n.message:String(n);throw this.context.log.warn("MCP validator build failed",{method:e.methods?.[0],path:e.path,contentType:r||"none",operationId:e.raw()?.operationId,error:o}),n}}getRouteDataForOptions(e){let{routes:r}=ye.instance.routeData,n=!!e.operationId,o=!!e.path;if(!n&&!o)throw new Error("MCP Tool configuration error: Either 'operationId' or 'path' must be provided in your tool specification.");return n?r.find(s=>s?.raw().operationId===e.operationId&&s?.methods?.some(a=>a.toUpperCase()===e.method.toUpperCase())):r.find(s=>s?.path===e.path&&s?.methods?.some(a=>a.toUpperCase()===e.method.toUpperCase()))}extractOutputSchema(e){try{let r=e.raw(),n=r?.responses;if(!n){this.context.log.warn("No responses found in OpenAPI spec for outputSchema",{path:e.path,operationId:r?.operationId});return}for(let o of Object.keys(n))if(o.startsWith("2")){let a=n[o]?.content;if(a){for(let u of["application/json","application/json; charset=utf-8"])if(a[u]?.schema){let c=a[u].schema;return this.debugMode&&this.context.log.debug("Output schema extracted successfully",{path:e.path,operationId:r?.operationId,statusCode:o,contentType:u,schemaKeys:c&&typeof c=="object"?Object.keys(c).join(", "):"none"}),c}}}this.debugMode&&this.context.log.debug("No OpenAPI spec 2xx responses fond for outputSchema",{path:e.path,operationId:r?.operationId,statusCodes:Object.keys(n).join(", ")});return}catch(r){this.context.log.warn("Failed to extract outputSchema",{path:e.path,operationId:e.raw()?.operationId,error:r instanceof Error?r.message:String(r),stack:r instanceof Error?r.stack:void 0});return}}};async function ZE(t,e){if(b("handler.mcp-server"),e.route.methods.some(s=>s.toUpperCase()!=="POST"))throw new y(`Invalid route config: mcpServerHandler may only use POST. Route '${e.route.path}' declares methods: [${e.route.methods.join(", ")}]`);let r={};t.headers.forEach((s,a)=>{r[a]=s});let n=e.route?.handler?.options??{},o=await Ps.getInstance(n,e);return ov(r,e,()=>o.handleRequest(t,e))}i(ZE,"mcpServerHandler");Le();var Ep=class extends Se{static{i(this,"McpCustomToolsPlugin")}options;mcpServer=null;transport=null;constructor(e){super(),this.options=e,this.validateTools()}validateTools(){let e=new Set;for(let r of this.options.tools){if(e.has(r.name))throw new y(`Duplicate tool name: ${r.name}`);e.add(r.name)}}registerRoutes(e){let{router:r}=e;r.addPluginRoute({path:this.options.endpoint??"/mcp",methods:["POST"],handler:this.createMcpHandler()})}createMcpHandler(){return async(e,r)=>{if(b("plugin.mcp-custom-tools"),e.method!=="POST")throw new y(`MCP Custom Tools endpoint only supports POST requests, got ${e.method}`);if(await this.initializeMcpServer(r),!this.transport)throw new y("MCP transport not initialized");try{return this.transport.handleRequest(e)}catch(n){return r.log.error("MCP request failed:",n),new Response(JSON.stringify({error:{code:-32603,message:"Internal error"}}),{status:500,headers:{"Content-Type":"application/json"}})}}}async initializeMcpServer(e){if(!(this.mcpServer&&this.transport)){this.mcpServer=new Ur({name:this.options.name||"MCP Custom Server",version:this.options.version||"0.0.0"});for(let r of this.options.tools)await this.registerTool(r,e);this.transport=new Dr({logger:new ir}),await this.transport.connect(),this.mcpServer.withTransport(this.transport)}}async registerTool(e,r){let{name:n,description:o,schema:s,outputSchema:a,handler:u}=e,c;if(s){let d=g.toJSONSchema(s);c=new Bt(d,p=>{let m=s.safeParse(p);return m.success?{success:!0,data:m.data,errorData:null}:{success:!1,data:null,errorData:m.error}})}else{let d={type:"object",properties:{},required:[],additionalProperties:!1};c=new Bt(d,()=>({success:!0,data:{},errorData:null}))}let l={name:n,description:o,validator:c,handler:i(async d=>{try{let p=await u(d,r);if(!p||typeof p!="object"||!Array.isArray(p.content))throw new Error("Handler must return an object with a content array");return p}catch(p){return r.log.error(`Custom tool '${n}' execution failed:`,p),{content:[{type:"text",text:`Tool execution failed: ${p instanceof Error?p.message:String(p)}`}],isError:!0}}},"handler")};if(a){let d=g.toJSONSchema(a);if(typeof d!="object"||d===null)throw new Error(`output schema for tool "${n}" must be an object`);l.outputSchema={...d,type:"object"}}this.mcpServer&&this.mcpServer.addTool(l)}};var go=class extends Se{static{i(this,"OAuthProtectedResourcePlugin")}options;constructor(e){super(),this.options=e}createOauthProtectedResourceHandler(){return async(e,r)=>{let n=new URL(e.url),o=e.params.resourcePath,a={resource:o?`${n.origin}/${o}`:n.origin,authorization_servers:this.options.authorizationServers,resource_name:this.options.resourceName};return new Response(JSON.stringify(a),{headers:{"Content-Type":"application/json"}})}}registerRoutes(e){let{router:r}=e;r.addPluginRoute({methods:["GET"],path:"/.well-known/oauth-protected-resource/:resourcePath*",handler:this.createOauthProtectedResourceHandler(),corsPolicy:"anything-goes",processors:[gr]})}};var Is=class{static{i(this,"McpToolBuilder")}config={};name(e){return this.config.name=e,this}description(e){return this.config.description=e,this}schema(e){return this.config.schema=e,this}outSchema(e){return this.config.outSchema=e,this}handler(e){return this.config.handler=e,this}build(){if(!this.config.name||!this.config.description||!this.config.handler)throw new Error("Tool must have name, description, and handler defined");return{name:this.config.name,description:this.config.description,schema:this.config.schema,outputSchema:this.config.outSchema,handler:this.config.handler}}},kp=class{static{i(this,"McpCustomToolsSDK")}createTool(){return new Is}defineTool(e){return{name:e.name,description:e.description,schema:e.schema,outputSchema:e.outputSchema,handler:e.handler}}textResponse(e){return{content:[{type:"text",text:e}]}}jsonResponse(e){return{content:[{type:"text",text:JSON.stringify(e,null,2)}],structuredContent:e}}errorResponse(e){return{content:[{type:"text",text:`Error: ${e}`}],isError:!0}}imageResponse(e,r){return{content:[{type:"image",data:e,mimeType:r}]}}resourceResponse(e,r){return{content:[{type:"resource",uri:e,mimeType:r}]}}};var Tp=class extends Te{constructor(r){super();this.options=r}static{i(this,"DynaTraceLoggingPlugin")}getTransport(){return new $p(this.options)}},$p=class{static{i(this,"DynaTraceTransport")}constructor(e){b("logging.dynatrace"),this.#e=e.url,this.#t=e.apiToken,this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.fields??{}}#e;#t;#n;#r;#o;#i;log(e,r){e.messages.forEach(n=>{let o=Object.assign({timestamp:new Date().toISOString(),message:Je(n),severity:e.level,"log.source":e.logSource,requestId:e.requestId,"custom.atomicCounter":e.vectorClock,"custom.environment":this.#n,"custom.environmentStage":this.#o,"custom.environmentType":this.#r,"custom.loggingId":e.loggingId,"custom.rayId":e.rayId===null?void 0:e.rayId},this.#i);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#s=i(async e=>{if(e.length!==0)try{let r=await V.fetch(this.#e,{method:"POST",body:JSON.stringify(e),headers:{"content-type":"application/json; charset=utf-8",authorization:`Api-Token ${this.#t}`}});r.ok||await pe({level:"error",messages:[`Failed to send logs to Dynatrace: ${r.status} - ${r.statusText}`]},r)}catch{await pe({level:"error",messages:["Failed to connect to Dynatrace logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("dyna-trace-log-transport",10,this.#s)};var Op=class extends Te{constructor(r){super();this.options=r}static{i(this,"NewRelicLoggingPlugin")}getTransport(){return new Cp(this.options)}},Cp=class{static{i(this,"NewRelicTransport")}constructor(e){b("logging.newrelic"),this.#e=e.url??"https://log-api.newrelic.com/log/v1",this.#t=e.apiKey,this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.fields??{},this.#s=e.service??"Zuplo"}#e;#t;#n;#r;#o;#i;#s;log(e,r){e.messages.forEach(n=>{let o=Object.assign({message:Je(n),level:e.level,timestamp:Date.now(),service:this.#s,request_id:e.requestId,atomic_counter:e.vectorClock,environment:this.#n,environment_stage:this.#o,environment_type:this.#r,logging_id:e.loggingId,ray_id:e.rayId===null?void 0:e.rayId,log_source:e.logSource},this.#i);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#u=i(async e=>{if(e.length!==0)try{let r=await V.fetch(this.#e,{method:"POST",body:JSON.stringify(e),headers:{"Content-Type":"application/json","Api-Key":this.#t}});r.ok||await pe({level:"error",messages:[`Failed to send logs to New Relic: ${r.status} - ${r.statusText}`]},r)}catch{await pe({level:"error",messages:["Failed to connect to New Relic logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("new-relic-log-transport",10,this.#u)};var Ap=class extends Te{constructor(r){super();this.options=r}static{i(this,"LokiLoggingPlugin")}getTransport(){return new Np(this.options)}},Lp=class{static{i(this,"LokiStream")}constructor(e,r,n,o,s,a){this.level=e,this.environment=r,this.environmentType=n,this.environmentStage=o,this.requestId=a,this.job=s}job;level;environment;environmentType;environmentStage;requestId;equals=i(e=>this.level===e.level&&this.requestId===e.requestId,"equals")};function jE(t,e){return btoa(`${t}:${e}`)}i(jE,"createBasicDigest");var Np=class{static{i(this,"LokiTransport")}constructor(e){b("logging.loki"),this.#n=e.url,this.#r=jE(e.username,e.password),this.#i=R.instance.loggingEnvironmentType,this.#s=R.instance.loggingEnvironmentStage,this.#o=R.instance.deploymentName,this.#e=e.version??1,this.#t=e.job??"zuplo",this.#u=e.fields??{}}#e;#t;#n;#r;#o;#i;#s;#u;log(e,r){let n=new Lp(e.level,this.#o,this.#i,this.#s,this.#t,this.#e===1?e.requestId:void 0);e.messages.forEach(o=>{let s=Object.assign({stream:n,requestId:e.requestId,rayId:e.rayId,atomicCounter:e.vectorClock,message:Je(o),nanoSecondEpoch:`${e.timestamp.getTime()}000000`},this.#u);this.batcher.enqueue(s)}),r.waitUntil(this.batcher.waitUntilFlushed())}#c=i(e=>{let r={streams:[]};return e.forEach(n=>{let o=r.streams.find(s=>s.stream.equals(n.stream));o||(o={stream:n.stream,values:[]},r.streams.push(o)),o.values.push(this.#e>1?[n.nanoSecondEpoch,n.message,{requestId:n.requestId,rayId:n.rayId,atomicCounter:JSON.stringify(n.atomicCounter)}]:[n.nanoSecondEpoch,n.message])}),r},"#convertToLokiStreamsBatch");#l=i(async e=>{if(e.length===0)return;let r=this.#c(e);try{let n=await V.fetch(this.#n,{method:"POST",body:JSON.stringify(r),headers:{"content-type":"application/json",authorization:`Basic ${this.#r}`}});n.ok||await pe({level:"error",messages:[`Failed to send logs to Loki: ${n.status} - ${n.statusText}`]},n)}catch{await pe({level:"error",messages:["Failed to connect to Loki logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("loki-log-transport",10,this.#l)};var zp=class extends Te{constructor(r){super();this.options=r}static{i(this,"SumoLogicLoggingPlugin")}getTransport(){return new Up(this.options)}},Up=class{static{i(this,"SumoLogicTransport")}constructor(e){b("logging.sumologic"),this.#e=e.url,this.#o=e.category,this.#i=e.name,this.#n=R.instance.loggingEnvironmentType,this.#r=R.instance.loggingEnvironmentStage,this.#t=R.instance.deploymentName,this.#s=e.fields??{}}#e;#t;#n;#r;#o;#i;#s;log(e,r){e.messages.forEach(n=>{let o=Object.assign({timestamp:new Date().toISOString(),message:Je(n),severity:e.level,source:e.logSource,requestId:e.requestId,environment:this.#t,environmentType:this.#n,environmentStage:this.#r,rayId:e.rayId===null?void 0:e.rayId},this.#s);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#u=i(async e=>{if(e.length===0)return;let r=e.map(o=>JSON.stringify(o)).join(`
90
+ `;await e.writer.write(new TextEncoder().encode(s))}catch(n){this.logger.warn("Error sending to stream:",n)}}async closeStream(e,r){let n=this.sessions.get(e);if(!n)return;let o=n.streams.get(r);if(o){try{await o.writer.close()}catch(s){this.logger.warn("Error closing stream:",s)}n.streams.delete(r),this.streams.delete(r)}}createSession(e){let r={id:e,createdAt:Date.now(),lastActivity:Date.now(),streams:new Map};return this.sessions.set(e,r),r}createStream(e){let r=new TransformStream,n=r.writable.getWriter(),o=crypto.randomUUID?.()||this.generateFallbackUUID(),s={id:o,writer:n,eventCounter:0,messages:[],pendingRequests:new Set};return this.streams.set(o,s),e&&(e.streams.set(o,s),e.lastActivity=Date.now()),{stream:r,streamId:o}}async replayMessages(e,r,n){for(let o of e.streams.values()){if(o.id===r)continue;let s=Number.parseInt(n,10);if(Number.isNaN(s))continue;let a=o.messages.slice(s),u=this.streams.get(r);if(u&&a.length>0)for(let c of a)await this.sendToStream(u,c)}}startSessionCleanup(){setInterval(()=>{let e=Date.now();for(let[r,n]of this.sessions.entries()){let o=this.options.timeout??6e4;if(e-n.lastActivity>o){for(let[s,a]of n.streams.entries()){try{a.writer.close().catch(u=>this.logger.warn("Error closing stream:",u))}catch(u){this.logger.warn("Error closing stream:",u)}this.streams.delete(s)}this.sessions.delete(r)}}},6e4)}async extractJSONRPC(e){try{let n=await e.clone().text();if(!n)throw new Error("Empty request body");return JSON.parse(n)}catch(r){throw new Error(`Failed to parse JSON-RPC message: ${r}`)}}validateOrigin(e){let r=e.headers.get("Origin");if(r&&!this.isValidOrigin(r))throw new Error("Invalid origin")}isValidOrigin(e){return!0}isRequest(e){return e!==null&&typeof e=="object"&&"jsonrpc"in e&&e.jsonrpc==="2.0"&&"method"in e&&"id"in e&&e.id!==null&&e.id!==void 0}generateFallbackUUID(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{let r=Math.random()*16|0;return(e==="x"?r:r&3|8).toString(16)})}};var mo=class{static{i(this,"R")}type=3;name="";prefix="";value="";suffix="";modifier=3;constructor(t,e,r,n,o,s){this.type=t,this.name=e,this.prefix=r,this.value=n,this.suffix=o,this.modifier=s}hasCustomName(){return this.name!==""&&typeof this.name!="number"}},mE=/[$_\p{ID_Start}]/u,fE=/[$_\u200C\u200D\p{ID_Continue}]/u,Pp=".*";function gE(t,e){return(e?/^[\x00-\xFF]*$/:/^[\x00-\x7F]*$/).test(t)}i(gE,"Re");function Gb(t,e=!1){let r=[],n=0;for(;n<t.length;){let o=t[n],s=i(function(a){if(!e)throw new TypeError(a);r.push({type:"INVALID_CHAR",index:n,value:t[n++]})},"c");if(o==="*"){r.push({type:"ASTERISK",index:n,value:t[n++]});continue}if(o==="+"||o==="?"){r.push({type:"OTHER_MODIFIER",index:n,value:t[n++]});continue}if(o==="\\"){r.push({type:"ESCAPED_CHAR",index:n++,value:t[n++]});continue}if(o==="{"){r.push({type:"OPEN",index:n,value:t[n++]});continue}if(o==="}"){r.push({type:"CLOSE",index:n,value:t[n++]});continue}if(o===":"){let a="",u=n+1;for(;u<t.length;){let c=t.substr(u,1);if(u===n+1&&mE.test(c)||u!==n+1&&fE.test(c)){a+=t[u++];continue}break}if(!a){s(`Missing parameter name at ${n}`);continue}r.push({type:"NAME",index:n,value:a}),n=u;continue}if(o==="("){let a=1,u="",c=n+1,l=!1;if(t[c]==="?"){s(`Pattern cannot start with "?" at ${c}`);continue}for(;c<t.length;){if(!gE(t[c],!1)){s(`Invalid character '${t[c]}' at ${c}.`),l=!0;break}if(t[c]==="\\"){u+=t[c++]+t[c++];continue}if(t[c]===")"){if(a--,a===0){c++;break}}else if(t[c]==="("&&(a++,t[c+1]!=="?")){s(`Capturing groups are not allowed at ${c}`),l=!0;break}u+=t[c++]}if(l)continue;if(a){s(`Unbalanced pattern at ${n}`);continue}if(!u){s(`Missing pattern at ${n}`);continue}r.push({type:"REGEX",index:n,value:u}),n=c;continue}r.push({type:"CHAR",index:n,value:t[n++]})}return r.push({type:"END",index:n,value:""}),r}i(Gb,"v");function Jb(t,e={}){let r=Gb(t);e.delimiter??="/#?",e.prefixes??="./";let n=`[^${rt(e.delimiter)}]+?`,o=[],s=0,a=0,u="",c=new Set,l=i(L=>{if(a<r.length&&r[a].type===L)return r[a++].value},"a"),d=i(()=>l("OTHER_MODIFIER")??l("ASTERISK"),"f"),p=i(L=>{let U=l(L);if(U!==void 0)return U;let{type:z,index:E}=r[a];throw new TypeError(`Unexpected ${z} at ${E}, expected ${L}`)},"d"),m=i(()=>{let L="",U;for(;U=l("CHAR")??l("ESCAPED_CHAR");)L+=U;return L},"T"),f=i(L=>L,"Se"),h=e.encodePart||f,w="",x=i(L=>{w+=L},"U"),k=i(()=>{w.length&&(o.push(new mo(3,"","",h(w),"",3)),w="")},"$"),_=i((L,U,z,E,j)=>{let W=3;switch(j){case"?":W=1;break;case"*":W=0;break;case"+":W=2;break}if(!U&&!z&&W===3){x(L);return}if(k(),!U&&!z){if(!L)return;o.push(new mo(3,"","",h(L),"",W));return}let G;z?z==="*"?G=Pp:G=z:G=n;let C=2;G===n?(C=1,G=""):G===Pp&&(C=0,G="");let T;if(U?T=U:z&&(T=s++),c.has(T))throw new TypeError(`Duplicate name '${T}'.`);c.add(T),o.push(new mo(C,T,h(L),G,h(E),W))},"V");for(;a<r.length;){let L=l("CHAR"),U=l("NAME"),z=l("REGEX");if(!U&&!z&&(z=l("ASTERISK")),U||z){let j=L??"";e.prefixes.indexOf(j)===-1&&(x(j),j=""),k();let W=d();_(j,U,z,"",W);continue}let E=L??l("ESCAPED_CHAR");if(E){x(E);continue}if(l("OPEN")){let j=m(),W=l("NAME"),G=l("REGEX");!W&&!G&&(G=l("ASTERISK"));let C=m();p("CLOSE");let T=d();_(j,W,G,C,T);continue}k(),p("END")}return o}i(Jb,"D");function rt(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(rt,"S");function Bb(t){return t&&t.ignoreCase?"ui":"u"}i(Bb,"X");function hE(t,e,r){return Wb(Jb(t,r),e,r)}i(hE,"Z");function Zr(t){switch(t){case 0:return"*";case 1:return"?";case 2:return"+";case 3:return""}}i(Zr,"k");function Wb(t,e,r={}){r.delimiter??="/#?",r.prefixes??="./",r.sensitive??=!1,r.strict??=!1,r.end??=!0,r.start??=!0,r.endsWith="";let n=r.start?"^":"";for(let u of t){if(u.type===3){u.modifier===3?n+=rt(u.value):n+=`(?:${rt(u.value)})${Zr(u.modifier)}`;continue}e&&e.push(u.name);let c=`[^${rt(r.delimiter)}]+?`,l=u.value;if(u.type===1?l=c:u.type===0&&(l=Pp),!u.prefix.length&&!u.suffix.length){u.modifier===3||u.modifier===1?n+=`(${l})${Zr(u.modifier)}`:n+=`((?:${l})${Zr(u.modifier)})`;continue}if(u.modifier===3||u.modifier===1){n+=`(?:${rt(u.prefix)}(${l})${rt(u.suffix)})`,n+=Zr(u.modifier);continue}n+=`(?:${rt(u.prefix)}`,n+=`((?:${l})(?:`,n+=rt(u.suffix),n+=rt(u.prefix),n+=`(?:${l}))*)${rt(u.suffix)})`,u.modifier===0&&(n+="?")}let o=`[${rt(r.endsWith)}]|$`,s=`[${rt(r.delimiter)}]`;if(r.end)return r.strict||(n+=`${s}?`),r.endsWith.length?n+=`(?=${o})`:n+="$",new RegExp(n,Bb(r));r.strict||(n+=`(?:${s}(?=${o}))?`);let a=!1;if(t.length){let u=t[t.length-1];u.type===3&&u.modifier===3&&(a=r.delimiter.indexOf(u)>-1)}return a||(n+=`(?=${s}|${o})`),new RegExp(n,Bb(r))}i(Wb,"F");var Ft={delimiter:"",prefixes:"",sensitive:!0,strict:!0},yE={delimiter:".",prefixes:"",sensitive:!0,strict:!0},bE={delimiter:"/",prefixes:"/",sensitive:!0,strict:!0};function vE(t,e){return t.length?t[0]==="/"?!0:!e||t.length<2?!1:(t[0]=="\\"||t[0]=="{")&&t[1]=="/":!1}i(vE,"J");function Kb(t,e){return t.startsWith(e)?t.substring(e.length,t.length):t}i(Kb,"Q");function wE(t,e){return t.endsWith(e)?t.substr(0,t.length-e.length):t}i(wE,"Ee");function Qb(t){return!t||t.length<2?!1:t[0]==="["||(t[0]==="\\"||t[0]==="{")&&t[1]==="["}i(Qb,"W");var Xb=["ftp","file","http","https","ws","wss"];function Yb(t){if(!t)return!0;for(let e of Xb)if(t.test(e))return!0;return!1}i(Yb,"N");function xE(t,e){if(t=Kb(t,"#"),e||t==="")return t;let r=new URL("https://example.com");return r.hash=t,r.hash?r.hash.substring(1,r.hash.length):""}i(xE,"te");function RE(t,e){if(t=Kb(t,"?"),e||t==="")return t;let r=new URL("https://example.com");return r.search=t,r.search?r.search.substring(1,r.search.length):""}i(RE,"re");function PE(t,e){return e||t===""?t:Qb(t)?rv(t):tv(t)}i(PE,"ne");function IE(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.password=t,r.password}i(IE,"se");function SE(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.username=t,r.username}i(SE,"ie");function _E(t,e,r){if(r||t==="")return t;if(e&&!Xb.includes(e))return new URL(`${e}:${t}`).pathname;let n=t[0]=="/";return t=new URL(n?t:"/-"+t,"https://example.com").pathname,n||(t=t.substring(2,t.length)),t}i(_E,"ae");function EE(t,e,r){return ev(e)===t&&(t=""),r||t===""?t:nv(t)}i(EE,"oe");function kE(t,e){return t=wE(t,":"),e||t===""?t:Ip(t)}i(kE,"ce");function ev(t){switch(t){case"ws":case"http":return"80";case"wws":case"https":return"443";case"ftp":return"21";default:return""}}i(ev,"_");function Ip(t){if(t==="")return t;if(/^[-+.A-Za-z0-9]*$/.test(t))return t.toLowerCase();throw new TypeError(`Invalid protocol '${t}'.`)}i(Ip,"y");function TE(t){if(t==="")return t;let e=new URL("https://example.com");return e.username=t,e.username}i(TE,"le");function $E(t){if(t==="")return t;let e=new URL("https://example.com");return e.password=t,e.password}i($E,"fe");function tv(t){if(t==="")return t;if(/[\t\n\r #%/:<>?@[\]^\\|]/g.test(t))throw new TypeError(`Invalid hostname '${t}'`);let e=new URL("https://example.com");return e.hostname=t,e.hostname}i(tv,"z");function rv(t){if(t==="")return t;if(/[^0-9a-fA-F[\]:]/g.test(t))throw new TypeError(`Invalid IPv6 hostname '${t}'`);return t.toLowerCase()}i(rv,"j");function nv(t){if(t===""||/^[0-9]*$/.test(t)&&parseInt(t)<=65535)return t;throw new TypeError(`Invalid port '${t}'.`)}i(nv,"K");function OE(t){if(t==="")return t;let e=new URL("https://example.com");return e.pathname=t[0]!=="/"?"/-"+t:t,t[0]!=="/"?e.pathname.substring(2,e.pathname.length):e.pathname}i(OE,"he");function CE(t){return t===""?t:new URL(`data:${t}`).pathname}i(CE,"ue");function AE(t){if(t==="")return t;let e=new URL("https://example.com");return e.search=t,e.search.substring(1,e.search.length)}i(AE,"de");function LE(t){if(t==="")return t;let e=new URL("https://example.com");return e.hash=t,e.hash.substring(1,e.hash.length)}i(LE,"pe");var NE=class{static{i(this,"H")}#e;#t=[];#n={};#r=0;#o=1;#i=0;#s=0;#u=0;#c=0;#l=!1;constructor(t){this.#e=t}get result(){return this.#n}parse(){for(this.#t=Gb(this.#e,!0);this.#r<this.#t.length;this.#r+=this.#o){if(this.#o=1,this.#t[this.#r].type==="END"){if(this.#s===0){this.#v(),this.#m()?this.#a(9,1):this.#f()?this.#a(8,1):this.#a(7,0);continue}else if(this.#s===2){this.#g(5);continue}this.#a(10,0);break}if(this.#u>0)if(this.#_())this.#u-=1;else continue;if(this.#S()){this.#u+=1;continue}switch(this.#s){case 0:this.#w()&&this.#g(1);break;case 1:if(this.#w()){this.#T();let t=7,e=1;this.#R()?(t=2,e=3):this.#l&&(t=2),this.#a(t,e)}break;case 2:this.#y()?this.#g(3):(this.#b()||this.#f()||this.#m())&&this.#g(5);break;case 3:this.#P()?this.#a(4,1):this.#y()&&this.#a(5,1);break;case 4:this.#y()&&this.#a(5,1);break;case 5:this.#E()?this.#c+=1:this.#k()&&(this.#c-=1),this.#I()&&!this.#c?this.#a(6,1):this.#b()?this.#a(7,0):this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 6:this.#b()?this.#a(7,0):this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 7:this.#f()?this.#a(8,1):this.#m()&&this.#a(9,1);break;case 8:this.#m()&&this.#a(9,1);break;case 9:break;case 10:break}}this.#n.hostname!==void 0&&this.#n.port===void 0&&(this.#n.port="")}#a(t,e){switch(this.#s){case 0:break;case 1:this.#n.protocol=this.#p();break;case 2:break;case 3:this.#n.username=this.#p();break;case 4:this.#n.password=this.#p();break;case 5:this.#n.hostname=this.#p();break;case 6:this.#n.port=this.#p();break;case 7:this.#n.pathname=this.#p();break;case 8:this.#n.search=this.#p();break;case 9:this.#n.hash=this.#p();break;case 10:break}this.#s!==0&&t!==10&&([1,2,3,4].includes(this.#s)&&[6,7,8,9].includes(t)&&(this.#n.hostname??=""),[1,2,3,4,5,6].includes(this.#s)&&[8,9].includes(t)&&(this.#n.pathname??=this.#l?"/":""),[1,2,3,4,5,6,7].includes(this.#s)&&t===9&&(this.#n.search??="")),this.#x(t,e)}#x(t,e){this.#s=t,this.#i=this.#r+e,this.#r+=e,this.#o=0}#v(){this.#r=this.#i,this.#o=0}#g(t){this.#v(),this.#s=t}#h(t){return t<0&&(t=this.#t.length-t),t<this.#t.length?this.#t[t]:this.#t[this.#t.length-1]}#d(t,e){let r=this.#h(t);return r.value===e&&(r.type==="CHAR"||r.type==="ESCAPED_CHAR"||r.type==="INVALID_CHAR")}#w(){return this.#d(this.#r,":")}#R(){return this.#d(this.#r+1,"/")&&this.#d(this.#r+2,"/")}#y(){return this.#d(this.#r,"@")}#P(){return this.#d(this.#r,":")}#I(){return this.#d(this.#r,":")}#b(){return this.#d(this.#r,"/")}#f(){if(this.#d(this.#r,"?"))return!0;if(this.#t[this.#r].value!=="?")return!1;let t=this.#h(this.#r-1);return t.type!=="NAME"&&t.type!=="REGEX"&&t.type!=="CLOSE"&&t.type!=="ASTERISK"}#m(){return this.#d(this.#r,"#")}#S(){return this.#t[this.#r].type=="OPEN"}#_(){return this.#t[this.#r].type=="CLOSE"}#E(){return this.#d(this.#r,"[")}#k(){return this.#d(this.#r,"]")}#p(){let t=this.#t[this.#r],e=this.#h(this.#i).index;return this.#e.substring(e,t.index)}#T(){let t={};Object.assign(t,Ft),t.encodePart=Ip;let e=hE(this.#p(),void 0,t);this.#l=Yb(e)}},Rp=["protocol","username","password","hostname","port","pathname","search","hash"],Ht="*";function Vb(t,e){if(typeof t!="string")throw new TypeError("parameter 1 is not of type 'string'.");let r=new URL(t,e);return{protocol:r.protocol.substring(0,r.protocol.length-1),username:r.username,password:r.password,hostname:r.hostname,port:r.port,pathname:r.pathname,search:r.search!==""?r.search.substring(1,r.search.length):void 0,hash:r.hash!==""?r.hash.substring(1,r.hash.length):void 0}}i(Vb,"ge");function Ot(t,e){return e?po(t):t}i(Ot,"b");function lo(t,e,r){let n;if(typeof e.baseURL=="string")try{n=new URL(e.baseURL),e.protocol===void 0&&(t.protocol=Ot(n.protocol.substring(0,n.protocol.length-1),r)),!r&&e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.username===void 0&&(t.username=Ot(n.username,r)),!r&&e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.username===void 0&&e.password===void 0&&(t.password=Ot(n.password,r)),e.protocol===void 0&&e.hostname===void 0&&(t.hostname=Ot(n.hostname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&(t.port=Ot(n.port,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&(t.pathname=Ot(n.pathname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&e.search===void 0&&(t.search=Ot(n.search.substring(1,n.search.length),r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&e.search===void 0&&e.hash===void 0&&(t.hash=Ot(n.hash.substring(1,n.hash.length),r))}catch{throw new TypeError(`invalid baseURL '${e.baseURL}'.`)}if(typeof e.protocol=="string"&&(t.protocol=kE(e.protocol,r)),typeof e.username=="string"&&(t.username=SE(e.username,r)),typeof e.password=="string"&&(t.password=IE(e.password,r)),typeof e.hostname=="string"&&(t.hostname=PE(e.hostname,r)),typeof e.port=="string"&&(t.port=EE(e.port,t.protocol,r)),typeof e.pathname=="string"){if(t.pathname=e.pathname,n&&!vE(t.pathname,r)){let o=n.pathname.lastIndexOf("/");o>=0&&(t.pathname=Ot(n.pathname.substring(0,o+1),r)+t.pathname)}t.pathname=_E(t.pathname,t.protocol,r)}return typeof e.search=="string"&&(t.search=RE(e.search,r)),typeof e.hash=="string"&&(t.hash=xE(e.hash,r)),t}i(lo,"w");function po(t){return t.replace(/([+*?:{}()\\])/g,"\\$1")}i(po,"C");function zE(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(zE,"Oe");function UE(t,e){e.delimiter??="/#?",e.prefixes??="./",e.sensitive??=!1,e.strict??=!1,e.end??=!0,e.start??=!0,e.endsWith="";let r=".*",n=`[^${zE(e.delimiter)}]+?`,o=/[$_\u200C\u200D\p{ID_Continue}]/u,s="";for(let a=0;a<t.length;++a){let u=t[a];if(u.type===3){if(u.modifier===3){s+=po(u.value);continue}s+=`{${po(u.value)}}${Zr(u.modifier)}`;continue}let c=u.hasCustomName(),l=!!u.suffix.length||!!u.prefix.length&&(u.prefix.length!==1||!e.prefixes.includes(u.prefix)),d=a>0?t[a-1]:null,p=a<t.length-1?t[a+1]:null;if(!l&&c&&u.type===1&&u.modifier===3&&p&&!p.prefix.length&&!p.suffix.length)if(p.type===3){let m=p.value.length>0?p.value[0]:"";l=o.test(m)}else l=!p.hasCustomName();if(!l&&!u.prefix.length&&d&&d.type===3){let m=d.value[d.value.length-1];l=e.prefixes.includes(m)}l&&(s+="{"),s+=po(u.prefix),c&&(s+=`:${u.name}`),u.type===2?s+=`(${u.value})`:u.type===1?c||(s+=`(${n})`):u.type===0&&(!c&&(!d||d.type===3||d.modifier!==3||l||u.prefix!=="")?s+="*":s+=`(${r})`),u.type===1&&c&&u.suffix.length&&o.test(u.suffix[0])&&(s+="\\"),s+=po(u.suffix),l&&(s+="}"),u.modifier!==3&&(s+=Zr(u.modifier))}return s}i(UE,"ke");var hs=class{static{i(this,"me")}#e;#t={};#n={};#r={};#o={};#i=!1;constructor(t={},e,r){try{let n;if(typeof e=="string"?n=e:r=e,typeof t=="string"){let u=new NE(t);if(u.parse(),t=u.result,n===void 0&&typeof t.protocol!="string")throw new TypeError("A base URL must be provided for a relative constructor string.");t.baseURL=n}else{if(!t||typeof t!="object")throw new TypeError("parameter 1 is not of type 'string' and cannot convert to dictionary.");if(n)throw new TypeError("parameter 1 is not of type 'string'.")}typeof r>"u"&&(r={ignoreCase:!1});let o={ignoreCase:r.ignoreCase===!0},s={pathname:Ht,protocol:Ht,username:Ht,password:Ht,hostname:Ht,port:Ht,search:Ht,hash:Ht};this.#e=lo(s,t,!0),ev(this.#e.protocol)===this.#e.port&&(this.#e.port="");let a;for(a of Rp){if(!(a in this.#e))continue;let u={},c=this.#e[a];switch(this.#n[a]=[],a){case"protocol":Object.assign(u,Ft),u.encodePart=Ip;break;case"username":Object.assign(u,Ft),u.encodePart=TE;break;case"password":Object.assign(u,Ft),u.encodePart=$E;break;case"hostname":Object.assign(u,yE),Qb(c)?u.encodePart=rv:u.encodePart=tv;break;case"port":Object.assign(u,Ft),u.encodePart=nv;break;case"pathname":Yb(this.#t.protocol)?(Object.assign(u,bE,o),u.encodePart=OE):(Object.assign(u,Ft,o),u.encodePart=CE);break;case"search":Object.assign(u,Ft,o),u.encodePart=AE;break;case"hash":Object.assign(u,Ft,o),u.encodePart=LE;break}try{this.#o[a]=Jb(c,u),this.#t[a]=Wb(this.#o[a],this.#n[a],u),this.#r[a]=UE(this.#o[a],u),this.#i=this.#i||this.#o[a].some(l=>l.type===2)}catch{throw new TypeError(`invalid ${a} pattern '${this.#e[a]}'.`)}}}catch(n){throw new TypeError(`Failed to construct 'URLPattern': ${n.message}`)}}test(t={},e){let r={pathname:"",protocol:"",username:"",password:"",hostname:"",port:"",search:"",hash:""};if(typeof t!="string"&&e)throw new TypeError("parameter 1 is not of type 'string'.");if(typeof t>"u")return!1;try{typeof t=="object"?r=lo(r,t,!1):r=lo(r,Vb(t,e),!1)}catch{return!1}let n;for(n of Rp)if(!this.#t[n].exec(r[n]))return!1;return!0}exec(t={},e){let r={pathname:"",protocol:"",username:"",password:"",hostname:"",port:"",search:"",hash:""};if(typeof t!="string"&&e)throw new TypeError("parameter 1 is not of type 'string'.");if(typeof t>"u")return;try{typeof t=="object"?r=lo(r,t,!1):r=lo(r,Vb(t,e),!1)}catch{return null}let n={};e?n.inputs=[t,e]:n.inputs=[t];let o;for(o of Rp){let s=this.#t[o].exec(r[o]);if(!s)return null;let a={};for(let[u,c]of this.#n[o].entries())if(typeof c=="string"||typeof c=="number"){let l=s[u+1];a[c]=l}n[o]={input:r[o]??"",groups:a}}return n}static compareComponent(t,e,r){let n=i((u,c)=>{for(let l of["type","modifier","prefix","value","suffix"]){if(u[l]<c[l])return-1;if(u[l]!==c[l])return 1}return 0},"o"),o=new mo(3,"","","","",3),s=new mo(0,"","","","",3),a=i((u,c)=>{let l=0;for(;l<Math.min(u.length,c.length);++l){let d=n(u[l],c[l]);if(d)return d}return u.length===c.length?0:n(u[l]??o,c[l]??o)},"s");return!e.#r[t]&&!r.#r[t]?0:e.#r[t]&&!r.#r[t]?a(e.#o[t],[s]):!e.#r[t]&&r.#r[t]?a([s],r.#o[t]):a(e.#o[t],r.#o[t])}get protocol(){return this.#r.protocol}get username(){return this.#r.username}get password(){return this.#r.password}get hostname(){return this.#r.hostname}get port(){return this.#r.port}get pathname(){return this.#r.pathname}get search(){return this.#r.search}get hash(){return this.#r.hash}get hasRegExpGroups(){return this.#i}};var ys=class{static{i(this,"UrlPatternBuilder")}pattern;pathParams={};searchParams=new URLSearchParams;expectedPathParams=new Set;seenPathParams=new Set;constructor(e){this.pattern=new hs({pathname:e});let r=/:(\w+)(\([^)]*\))?[*+?]?/g,n;for(;(n=r.exec(e))!==null;)this.expectedPathParams.add(n[1])}addParameter(e,r,n){let o=this.getParameterValue(e,r,n);if(o!=null)switch(e.in){case"path":if(!this.expectedPathParams.has(e.name))throw new y(`path parameter '${e.name}' missing from pattern '${this.pattern.pathname}'`);this.seenPathParams.add(e.name),this.addPathParameter(e.name,o);break;case"query":this.addQueryParameter(e.name,o);break;default:break}}getParameterValue(e,r,n){switch(e.in){case"path":return r?.[e.name];case"query":return n?.[e.name];default:return}}addPathParameter(e,r){this.pathParams[e]=String(r)}addQueryParameter(e,r){Array.isArray(r)?r.forEach(n=>{n!=null&&this.searchParams.append(e,String(n))}):typeof r=="object"&&r!==null?this.searchParams.append(e,JSON.stringify(r)):this.searchParams.append(e,String(r))}toString(){let e=[...this.expectedPathParams].filter(s=>!this.seenPathParams.has(s));if(e.length>0)throw new y(`missing path parameters in OpenAPI spec: ${e.join(", ")}`);let r=this.pattern.pathname.replace(/:(\w+)(\([^)]*\))?([*+?])?/g,(s,a)=>this.pathParams[a]?encodeURIComponent(this.pathParams[a]):s),n=this.cleanupUrlPatternSyntax(r),o=this.searchParams.toString();return o?`${n}?${o}`:n}cleanupUrlPatternSyntax(e){return e.replace(/\{\/\}\?/g,"").replace(/\{\/\}[*+]/g,"/").replace(/\{\/\}/g,"/").replace(/(\{[^}]*\})[?*+]/g,"$1")}};var bs=class{constructor(e){this.routeData=e}static{i(this,"McpUrlBuilder")}build(e,r){let n=this.routeData.pathPattern?this.routeData.pathPattern:this.routeData.path,o=this.routeData.raw()?.parameters||[],s=new ys(n);for(let a of o)s.addParameter(a,e,r);return s.toString()}};var Bt=class{static{i(this,"CustomValidator")}jsonSchema;parseFn;constructor(e,r){this.jsonSchema=e,this.parseFn=r}parse(e){return this.parseFn(e)}};Le();Le();Le();var vs=class{static{i(this,"ZodFormatSchemaRegistry")}static formatter=new Map([["email",()=>g.email()],["uri",()=>g.url()],["url",()=>g.url()],["uuid",()=>g.uuid()],["date",()=>g.iso.date()],["date-time",()=>g.iso.datetime()],["time",()=>g.iso.time()],["ipv4",()=>g.ipv4()],["ipv6",()=>g.ipv6()],["int32",()=>g.int32()],["int64",()=>g.int64()],["float",()=>g.number()],["double",()=>g.number()]]);static get(e){return this.formatter.get(e)}static register(e,r){this.formatter.set(e,r)}},fo=class{static{i(this,"OpenApiToZodTranspiler")}static typeTranspilers=new Map([["string",this.transpileString.bind(this)],["number",this.transpileNumber.bind(this)],["integer",this.transpileInteger.bind(this)],["boolean",this.transpileBoolean.bind(this)],["array",this.transpileArray.bind(this)],["object",this.transpileObject.bind(this)],["null",this.transpileNull.bind(this)]]);static run(e,r){let n={path:[],definitions:{},visitedRefs:new Set,...r};return this.transpileSchema(e,n)}static transpileSchema(e,r){if(!e)return g.unknown();try{if("$ref"in e)return this.resolveReference(e.$ref,r);if(e.allOf)return this.transpileAllOf(e.allOf,r);if(e.oneOf)return this.transpileOneOf(e.oneOf,r);if(e.anyOf)return this.transpileAnyOf(e.anyOf,r);if(e.not)return this.transpileNot(e.not,r);let n=this.transpileByType(e,r);return n=this.applyCommonModifiers(n,e),n}catch(n){let o=r.path.join(".");throw new Error(`Failed to transpile schema at path "${o}": ${n.message}`)}}static transpileByType(e,r){let n=e.type;!n&&e.properties&&(n="object");let o=this.typeTranspilers.get(n||"unknown");return o?o(e,r):g.unknown()}static transpileString(e,r){if(e.enum)return g.enum(e.enum);let n=e.format?vs.get(e.format):null,o=n?n():g.string();if(o instanceof g.ZodString){let s=o;return e.minLength!==void 0&&(s=s.min(e.minLength)),e.maxLength!==void 0&&(s=s.max(e.maxLength)),e.pattern&&(s=s.regex(new RegExp(e.pattern))),s}else e.minLength||e.maxLength||e.pattern;return o}static applyNumericConstraints(e,r,n){let o=e;if(r.minimum!==void 0&&(o=o.min(r.minimum)),r.maximum!==void 0&&(o=o.max(r.maximum)),r.exclusiveMinimum!==void 0){let s;if(typeof r.exclusiveMinimum=="number")s=r.exclusiveMinimum;else if(r.minimum!==void 0)s=r.minimum+Number.EPSILON;else throw new Error(`exclusiveMinimum requires minimum to be set at path "${n.path.join(".")}"`);o=o.gt(s)}if(r.exclusiveMaximum!==void 0){let s;if(typeof r.exclusiveMaximum=="number")s=r.exclusiveMaximum;else if(r.maximum!==void 0)s=r.maximum-Number.EPSILON;else throw new Error(`exclusiveMaximum requires maximum to be set at path "${n.path.join(".")}"`);o=o.lt(s)}return o}static transpileNumber(e,r){let n=g.number();return this.applyNumericConstraints(n,{...e,type:"number"},r)}static transpileInteger(e,r){let n=g.int();return this.applyNumericConstraints(n,{...e,type:"number"},r)}static transpileBoolean(e,r){return g.boolean()}static transpileArray(e,r){let n=e.items?this.transpileSchema(e.items,{...r,path:[...r.path,"items"]}):g.unknown(),o=g.array(n);return e.minItems!==void 0&&(o=o.min(e.minItems)),e.maxItems!==void 0&&(o=o.max(e.maxItems)),e.uniqueItems&&(o=o.refine(s=>new Set(s).size===s.length,{message:"Array must contain unique items"})),o}static transpileObject(e,r){let n;if(e.properties){let o={},s=new Set(e.required||[]);for(let[u,c]of Object.entries(e.properties)){let l={...r,path:[...r.path,u]},d=this.transpileSchema(c,l);s.has(u)||(d=d.optional()),o[u]=d}let a=g.object(o);e.additionalProperties===!1?a=a.strict():(e.additionalProperties,a=a.passthrough()),n=a}else if(e.additionalProperties===!1)n=g.object({}).strict();else if(typeof e.additionalProperties=="object"){let o=this.transpileSchema(e.additionalProperties,r);n=g.record(g.string(),o)}else n=g.unknown();return(e.minProperties!==void 0||e.maxProperties!==void 0)&&(n=n.refine(o=>{let s=Object.keys(o).length;return!(e.minProperties!==void 0&&s<e.minProperties||e.maxProperties!==void 0&&s>e.maxProperties)},{message:this.buildPropertyCountErrorMessage(e.minProperties,e.maxProperties)})),n}static buildPropertyCountErrorMessage(e,r){return e!==void 0&&r!==void 0?`Object must have between ${e} and ${r} properties`:e!==void 0?`Object must have at least ${e} properties`:`Object must have at most ${r} properties`}static transpileNull(e,r){return g.null()}static transpileAllOf(e,r){return e.map((o,s)=>this.transpileSchema(o,{...r,path:[...r.path,`allOf[${s}]`]})).reduce((o,s)=>o.and(s))}static transpileOneOf(e,r){let n=e.map((o,s)=>this.transpileSchema(o,{...r,path:[...r.path,`oneOf[${s}]`]}));return n.length===0?g.never():n.length===1?n[0]:g.union(n)}static transpileAnyOf(e,r){return this.transpileOneOf(e,r)}static transpileNot(e,r){let n=this.transpileSchema(e,{...r,path:[...r.path,"not"]});return g.unknown().refine(o=>!n.safeParse(o).success,{message:"Value must not match the schema"})}static resolveReference(e,r){if(r.visitedRefs?.has(e))return g.lazy(()=>this.resolveReference(e,r));r.visitedRefs?.add(e);let n=e.split("/");if(n[0]==="#"&&n[1]==="definitions"&&r.definitions){let o=r.definitions[n[2]];if(o)return this.transpileSchema(o,r)}throw new Error(`Unable to resolve reference: ${e}`)}static applyCommonModifiers(e,r){let n=e;return r.nullable&&(n=n.nullable()),r.default!==void 0&&(n=n.default(r.default)),r.description&&(n=n.describe(r.description)),r.examples&&r.examples.length>0&&(n=n.meta({examples:r.examples})),n}static registerTypeTranspiler(e,r){this.typeTranspilers.set(e,r)}static registerFormatSchema(e,r){vs.register(e,r)}};var ws=class{constructor(e,r){this.routeData=e;this.contentType=r}static{i(this,"RequestBodySchemaBuilder")}build(){let e=this.routeData.raw()?.requestBody;if(!e?.content?.[this.contentType])return null;let r=e.content[this.contentType].schema;return r?fo.run(r):null}},xs=class{constructor(e){this.parameters=e}static{i(this,"ParameterSchemaBuilder")}build(){if(this.parameters.length===0)return null;let e={};for(let r of this.parameters)e[r.name]=this.buildParameterSchema(r);return g.object(e)}buildParameterSchema(e){let r;e.schema?r=fo.run(e.schema):r=g.string(),e.required||(r=r.optional()),e.description&&(r=r.describe(e.description));let n=[];if(e.schema?.example!==void 0&&n.push(e.schema.example),e.schema?.examples!==void 0&&Array.isArray(e.schema.examples)&&n.push(...e.schema.examples),e.examples&&(Array.isArray(e.examples)?n.push(...e.examples):typeof e.examples=="object"&&Object.values(e.examples).forEach(o=>{o?.value!==void 0&&n.push(o.value)})),e.example!==void 0&&n.push(e.example),n.length>0){let o=[...new Set(n.map(s=>JSON.stringify(s)))].map(s=>JSON.parse(s));r=r.meta({examples:o})}return r}};var Sp=class{static{i(this,"UniversalValidatorBuilder")}components={};withBody(e){return e&&(this.components.body=e),this}withQueryParams(e){return e&&(this.components.queryParams=e),this}withPathParams(e){return e&&(this.components.pathParams=e),this}withHeaders(e){return e&&(this.components.headers=e),this}build(){if(Object.keys(this.components).length===0)return this.buildEmptyValidator();let e=g.object(this.components),r=g.toJSONSchema(e);return new Bt(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:n,errorData:null}:{success:!1,data:null,errorMessage:this.formatValidationErrors(o.error.issues),errorData:o.error}})}buildEmptyValidator(){let e={type:"object",properties:{},required:[],additionalProperties:!1};return new Bt(e,()=>({success:!0,data:{},errorData:null}))}formatValidationErrors(e){return e.map(r=>`${r.path.length>0?r.path.join("."):"root"}: ${r.message}`).join(", ")}},Rs=class{static{i(this,"SchemaBuilderFactory")}static createRequestBodyBuilder(e,r){return new ws(e,r)}static createParameterBuilder(e,r){let n=r?e.filter(o=>o.in===r):e;return new xs(n)}static createValidatorBuilder(e,r){let n=new Sp,o=e.raw()?.parameters||[];if(r){let c=this.createRequestBodyBuilder(e,r);n.withBody(c.build())}let s=this.createParameterBuilder(o,"query");n.withQueryParams(s.build());let a=this.createParameterBuilder(o,"path");n.withPathParams(a.build());let u=this.createParameterBuilder(o,"header");return n.withHeaders(u.build()),n}};import{AsyncLocalStorage as DE}from"node:async_hooks";var _p=new DE;function ov(t,e,r){return _p.run({headers:t,zuploContext:e},r)}i(ov,"runWithInvokeContext");function iv(){return _p.getStore()?.headers??{}}i(iv,"getInvokeHeaders");function sv(){let t=_p.getStore();if(!t)throw new Error("No Zuplo context available in current execution context");return t.zuploContext}i(sv,"getInvokeContext");var Ps=class t{static{i(this,"ZuploMcpServer")}static instances=new Map;static async getInstance(e,r){let n=r.route?.path??"unknown-route",o=e.debugMode??!1,s=t.instances.get(n);if(s)o&&r.log.debug("MCP Server warm reuse",{routeKey:n});else{let a=Date.now();if(s=new t(e,r),s.registerToolsFromOptions(s.opts.openApiTools??[]),s.registerToolsFromFiles(s.opts.openApiFilePaths??[]),await s.transport.connect(),s.server.withTransport(s.transport),t.instances.set(n,s),o){let u=s.server.getTools(),c=u?u.size:0,l=Date.now()-a;r.log.debug("MCP Server cold start",{routeKey:n,toolCount:c,totalElapsedMs:l,debugMode:o,includeOutputSchema:s.includeOutputSchema,includeStructuredContent:s.includeStructuredContent})}}return s}transport;server;opts;context;includeOutputSchema;includeStructuredContent;debugMode;constructor(e,r){this.debugMode=e.debugMode??!1;let n;this.debugMode?n=r.log:n=new ir,this.context=r,this.opts=e,this.server=new Ur({name:e.name??"Zuplo MCP Server",version:e.version??"0.0.0",logger:n}),this.transport=new Dr({logger:n}),this.includeOutputSchema=e.includeOutputSchema??!1,this.includeStructuredContent=e.includeStructuredContent??!1}buildInvokeHeaders(){return iv()}async handleRequest(e,r){let n=Date.now();try{let o=await e.clone().json().catch(()=>({}));if(this.debugMode&&r.log.debug("MCP Server request start",{method:o.method,requestId:o.id,routePath:r.route?.path}),this.debugMode&&o.method==="tools/list"){let u=this.server.getTools(),c=u?Array.from(u.keys()):[];r.log.debug("MCP Server list tools request",{toolCount:c.length,toolNames:c})}let s=await this.transport.handleRequest(e),a=Date.now()-n;if(this.debugMode){let u=await s.clone().json().catch(()=>({}));r.log.debug("MCP Server response complete",{status:s.status,requestMethod:o.method,requestId:o.id,totalElapsedMs:a,respData:u})}return s}catch(o){let s=Date.now()-n;return r.log.error("MCP server internal error",{elapsedMs:s,err:o}),new Response("Internal error",{status:500})}}generateToolNameFromSpec(e,r){let n=e.raw();if(n?.operationId)return`${n.operationId}`;let o=`${r}_${e.path}`.replace(/[^\w]/g,"_");return this.context.log.warn(`No operationId found for route ${r} ${e.path}. Using auto-generated name "${o}". To improve AI tool selection, add a descriptive operationId to your OpenAPI spec (e.g., "get_user_by_id" instead of "GET_/users/{id}")`),o}generateToolDescriptionFromSpec(e,r){let n=e.raw();return n?.description?n.description:n?.summary?n.summary:`Call ${r.toUpperCase()} ${e.path}`}registerToolsFromOptions(e){let r=new Set;for(let n of e){if(n.name){if(typeof n.name!="string"||n.name.trim()==="")throw new Error("MCP Tool configuration error: Tool name must be a non-empty string if provided.");if(r.has(n.name))throw new Error(`MCP Tool configuration error: Duplicate tool name "${n.name}". Tool names must be unique across all configured tools.`)}let o=this.getRouteDataForOptions(n);if(!o){let l=n.operationId?`operationId: "${n.operationId}"`:`path: "${n.path}"`;throw new Error(`MCP Tool configuration error: Could not find gateway route data for ${n.method.toUpperCase()} ${l}. Verify that the route exists in your OpenAPI specification and that the provided metadata matches OpenAPI specification data.`)}if(!o.handler){let l=n.operationId?`operationId: "${n.operationId}"`:`path: "${n.path}"`;throw new Error(`MCP Tool configuration error: Route ${n.method.toUpperCase()} ${l} has no handler configured. Ensure the route has a proper handler defined in your OpenAPI specification.`)}let s=n.name??this.generateToolNameFromSpec(o,n.method);if(r.has(s))throw new Error(`MCP Tool configuration error: Tool name conflict detected. The name "${s}" is already in use. Consider providing a unique 'name' in your tool configuration or ensure your operationIds are unique.`);r.add(s);let a=n.description??this.generateToolDescriptionFromSpec(o,n.method),u=n.includeOutputSchema??this.includeOutputSchema??!0,c=n.includeStructuredContent??this.includeStructuredContent??!0;this.registerToolsForMethod(o,n.method,s,a,u,c)}}registerToolsFromFiles(e){let r=new Set(e.map(s=>s.filePath)),n=new Set;for(let s of ye.instance.routeData.routes){let a=s.metadata?.filepath;a&&r.has(a)&&(n.add(a),this.registerToolsForRawRoutedata(s,this.includeOutputSchema,this.includeStructuredContent))}let o=e.map(s=>s.filePath).filter(s=>!n.has(s));if(o.length>0)throw new Error(`MCP Tool configuration error: Could not find routes for the following file paths: ${o.join(", ")}. Verify that these OpenAPI files exist and are properly loaded in your Gateway configuration.`)}registerToolsForRawRoutedata(e,r,n){if(e.mcp?.enabled!==!1){if(!e)throw new Error("MCP Tool configuration error: Route data cannot be null or undefined.");if(!e.methods||e.methods.length===0)throw new Error(`MCP Tool configuration error: Route "${e.path}" has no HTTP methods defined. Ensure the route has at least one HTTP method (GET, POST, etc.) in your OpenAPI specification.`);if(!e.handler)throw new Error(`MCP Tool configuration error: Route "${e.path}" has no handler configured. Ensure the route has a proper handler defined in your OpenAPI specification.`);for(let o of e.methods){let s=this.generateToolNameFromSpec(e,o),a=this.generateToolDescriptionFromSpec(e,o);this.registerToolsForMethod(e,o,s,a,r,n)}}}registerToolsForMethod(e,r,n,o,s,a){if(e.handler?.export!=="mcpServerHandler")if(e.raw().requestBody?.content)for(let u of Object.keys(e.raw().requestBody?.content)){let l=Object.keys(e.raw().requestBody?.content).length>1?`${n}_${u.replace(/[^\w]/g,"_")}`:n;this.registerGenericToolSpec(l,o,e,r,u,s,a)}else this.registerGenericToolSpec(n,o,e,r,null,s,a)}registerGenericToolSpec(e,r,n,o,s,a,u){let c=this.buildUniversalValidator(n,s);if(!c)throw new Error(`MCP Tool registration error: Could not build parameter validator for ${o.toUpperCase()} ${n.path}. This may indicate an issue with the OpenAPI parameter definitions for this route.`);let l=a?this.extractOutputSchema(n):void 0;try{this.server.addTool({name:e,description:r,validator:c,...l&&{outputSchema:l},handler:i(async d=>{let p=sv(),m=Date.now();try{this.debugMode&&p.log.debug("MCP tool invoked",{toolName:e,operationId:n.raw()?.operationId,method:o,path:n.path,args:d});let f=this.buildToolUrl(n,d),h=this.buildToolRequest(o,s,d);this.debugMode&&p.log.debug("MCP tool downstream call",{toolName:e,url:f,method:o,headers:h.headers?Object.keys(h.headers).join(", "):"",bodyPreview:d.body});let w=Date.now(),x=await p.invokeRoute(f,h),k=Date.now()-w,_=await x.text(),L;if(u)try{L=JSON.parse(_)}catch(z){this.debugMode&&p.log.debug("MCP tool structuredContent JSON parse failed",{toolName:e,body:_,parseErr:z})}let U=Date.now()-m;return this.debugMode&&(x.ok?p.log.debug("MCP tool ok response",{toolName:e,operationId:n.raw()?.operationId,status:x.status,elapsedMs:U,downstreamElapsedMs:k}):p.log.debug("MCP tool 'isError' response",{toolName:e,operationId:n.raw()?.operationId,status:x.status,elapsedMs:U,downstreamElapsedMs:k,response:_})),{content:[{type:"text",text:_}],...L&&{structuredContent:L},isError:!x.ok}}catch(f){let h=Date.now()-m,w=f instanceof Error?`${f.name}: ${f.message}`:String(f);return p.log.error("MCP server tool invocation failed",{toolName:e,operationId:n.raw()?.operationId,method:o,path:n.path,elapsedMs:h,err:f}),{content:[{type:"text",text:`MCP tool call failed for tool '${e}': ${w}`}],isError:!0}}},"handler")}),this.debugMode&&this.context.log.debug("MCP tool registered",{toolName:e,method:o.toUpperCase(),path:n.path,operationId:n.raw()?.operationId,contentType:s||"none",includeOutputSchema:a,includeStructuredContent:u,hasValidator:!!c,hasOutputSchema:!!l})}catch(d){throw new Error(`Failed to add tool ${o} ${n.path}`,d)}}buildToolUrl(e,r){return new bs(e).build(r.pathParams,r.queryParams)}buildToolRequest(e,r,n){let o=this.buildToolHeaders(e,r,n),s={method:e,headers:o};return this.shouldIncludeBody(e,r,n)&&(s.body=this.serializeBody(n.body,r)),s}buildToolHeaders(e,r,n){let o={...this.buildInvokeHeaders()};return n.headers&&Object.entries(n.headers).forEach(([s,a])=>{o[s.toLowerCase()]=a}),r&&n.body!==void 0&&(o["content-type"]=r),this.isBodyMethod(e||"")&&n.body!==void 0&&!o["content-type"]&&(o["content-type"]="application/json"),o}shouldIncludeBody(e,r,n){return n.body===void 0?!1:this.isBodyMethod(e)?!0:r!==null}isBodyMethod(e){return["POST","PUT","PATCH"].includes(e.toUpperCase())}serializeBody(e,r){return JSON.stringify(e)}buildUniversalValidator(e,r){try{let o=Rs.createValidatorBuilder(e,r).build();return this.debugMode&&this.context.log.debug("MCP validator built successfully",{method:e.methods?.[0],path:e.path,contentType:r||"none",operationId:e.raw()?.operationId}),o}catch(n){let o=n instanceof Error?n.message:String(n);throw this.context.log.warn("MCP validator build failed",{method:e.methods?.[0],path:e.path,contentType:r||"none",operationId:e.raw()?.operationId,error:o}),n}}getRouteDataForOptions(e){let{routes:r}=ye.instance.routeData,n=!!e.operationId,o=!!e.path;if(!n&&!o)throw new Error("MCP Tool configuration error: Either 'operationId' or 'path' must be provided in your tool specification.");return n?r.find(s=>s?.raw().operationId===e.operationId&&s?.methods?.some(a=>a.toUpperCase()===e.method.toUpperCase())):r.find(s=>s?.path===e.path&&s?.methods?.some(a=>a.toUpperCase()===e.method.toUpperCase()))}extractOutputSchema(e){try{let r=e.raw(),n=r?.responses;if(!n){this.context.log.warn("No responses found in OpenAPI spec for outputSchema",{path:e.path,operationId:r?.operationId});return}for(let o of Object.keys(n))if(o.startsWith("2")){let a=n[o]?.content;if(a){for(let u of["application/json","application/json; charset=utf-8"])if(a[u]?.schema){let c=a[u].schema;return this.debugMode&&this.context.log.debug("Output schema extracted successfully",{path:e.path,operationId:r?.operationId,statusCode:o,contentType:u,schemaKeys:c&&typeof c=="object"?Object.keys(c).join(", "):"none"}),c}}}this.debugMode&&this.context.log.debug("No OpenAPI spec 2xx responses fond for outputSchema",{path:e.path,operationId:r?.operationId,statusCodes:Object.keys(n).join(", ")});return}catch(r){this.context.log.warn("Failed to extract outputSchema",{path:e.path,operationId:e.raw()?.operationId,error:r instanceof Error?r.message:String(r),stack:r instanceof Error?r.stack:void 0});return}}};async function ZE(t,e){if(b("handler.mcp-server"),e.route.methods.some(s=>s.toUpperCase()!=="POST"))throw new y(`Invalid route config: mcpServerHandler may only use POST. Route '${e.route.path}' declares methods: [${e.route.methods.join(", ")}]`);let r={};t.headers.forEach((s,a)=>{r[a]=s});let n=e.route?.handler?.options??{},o=await Ps.getInstance(n,e);return ov(r,e,()=>o.handleRequest(t,e))}i(ZE,"mcpServerHandler");Le();var Ep=class extends Se{static{i(this,"McpCustomToolsPlugin")}options;mcpServer=null;transport=null;constructor(e){super(),this.options=e,this.validateTools()}validateTools(){let e=new Set;for(let r of this.options.tools){if(e.has(r.name))throw new y(`Duplicate tool name: ${r.name}`);e.add(r.name)}}registerRoutes(e){let{router:r}=e;r.addPluginRoute({path:this.options.endpoint??"/mcp",methods:["POST"],handler:this.createMcpHandler()})}createMcpHandler(){return async(e,r)=>{if(b("plugin.mcp-custom-tools"),e.method!=="POST")throw new y(`MCP Custom Tools endpoint only supports POST requests, got ${e.method}`);if(await this.initializeMcpServer(r),!this.transport)throw new y("MCP transport not initialized");try{return this.transport.handleRequest(e)}catch(n){return r.log.error("MCP request failed:",n),new Response(JSON.stringify({error:{code:-32603,message:"Internal error"}}),{status:500,headers:{"Content-Type":"application/json"}})}}}async initializeMcpServer(e){if(!(this.mcpServer&&this.transport)){this.mcpServer=new Ur({name:this.options.name||"MCP Custom Server",version:this.options.version||"0.0.0"});for(let r of this.options.tools)await this.registerTool(r,e);this.transport=new Dr({logger:new ir}),await this.transport.connect(),this.mcpServer.withTransport(this.transport)}}async registerTool(e,r){let{name:n,description:o,schema:s,outputSchema:a,handler:u}=e,c;if(s){let d=g.toJSONSchema(s);c=new Bt(d,p=>{let m=s.safeParse(p);return m.success?{success:!0,data:m.data,errorData:null}:{success:!1,data:null,errorData:m.error}})}else{let d={type:"object",properties:{},required:[],additionalProperties:!1};c=new Bt(d,()=>({success:!0,data:{},errorData:null}))}let l={name:n,description:o,validator:c,handler:i(async d=>{try{let p=await u(d,r);if(!p||typeof p!="object"||!Array.isArray(p.content))throw new Error("Handler must return an object with a content array");return p}catch(p){return r.log.error(`Custom tool '${n}' execution failed:`,p),{content:[{type:"text",text:`Tool execution failed: ${p instanceof Error?p.message:String(p)}`}],isError:!0}}},"handler")};if(a){let d=g.toJSONSchema(a);if(typeof d!="object"||d===null)throw new Error(`output schema for tool "${n}" must be an object`);l.outputSchema={...d,type:"object"}}this.mcpServer&&this.mcpServer.addTool(l)}};var go=class extends Se{static{i(this,"OAuthProtectedResourcePlugin")}options;constructor(e){super(),this.options=e}createOauthProtectedResourceHandler(){return async(e,r)=>{let n=new URL(e.url),o=e.params.resourcePath,a={resource:o?`${n.origin}/${o}`:n.origin,authorization_servers:this.options.authorizationServers,resource_name:this.options.resourceName};return new Response(JSON.stringify(a),{headers:{"Content-Type":"application/json"}})}}registerRoutes(e){let{router:r}=e;r.addPluginRoute({methods:["GET"],path:"/.well-known/oauth-protected-resource/:resourcePath*",handler:this.createOauthProtectedResourceHandler(),corsPolicy:"anything-goes",processors:[gr]})}};var Is=class{static{i(this,"McpToolBuilder")}config={};name(e){return this.config.name=e,this}description(e){return this.config.description=e,this}schema(e){return this.config.schema=e,this}outSchema(e){return this.config.outSchema=e,this}handler(e){return this.config.handler=e,this}build(){if(!this.config.name||!this.config.description||!this.config.handler)throw new Error("Tool must have name, description, and handler defined");return{name:this.config.name,description:this.config.description,schema:this.config.schema,outputSchema:this.config.outSchema,handler:this.config.handler}}},kp=class{static{i(this,"McpCustomToolsSDK")}createTool(){return new Is}defineTool(e){return{name:e.name,description:e.description,schema:e.schema,outputSchema:e.outputSchema,handler:e.handler}}textResponse(e){return{content:[{type:"text",text:e}]}}jsonResponse(e){return{content:[{type:"text",text:JSON.stringify(e,null,2)}],structuredContent:e}}errorResponse(e){return{content:[{type:"text",text:`Error: ${e}`}],isError:!0}}imageResponse(e,r){return{content:[{type:"image",data:e,mimeType:r}]}}resourceResponse(e,r){return{content:[{type:"resource",uri:e,mimeType:r}]}}};var Tp=class extends Te{constructor(r){super();this.options=r}static{i(this,"DynaTraceLoggingPlugin")}getTransport(){return new $p(this.options)}},$p=class{static{i(this,"DynaTraceTransport")}constructor(e){b("logging.dynatrace"),this.#e=e.url,this.#t=e.apiToken,this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.fields??{}}#e;#t;#n;#r;#o;#i;log(e,r){e.messages.forEach(n=>{let o=Object.assign({timestamp:new Date().toISOString(),message:Je(n),severity:e.level,"log.source":e.logSource,requestId:e.requestId,"custom.atomicCounter":e.vectorClock,"custom.environment":this.#n,"custom.environmentStage":this.#o,"custom.environmentType":this.#r,"custom.loggingId":e.loggingId,"custom.rayId":e.rayId===null?void 0:e.rayId},this.#i);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#s=i(async e=>{if(e.length!==0)try{let r=await V.fetch(this.#e,{method:"POST",body:JSON.stringify(e),headers:{"content-type":"application/json; charset=utf-8",authorization:`Api-Token ${this.#t}`}});r.ok||await pe({level:"error",messages:[`Failed to send logs to Dynatrace: ${r.status} - ${r.statusText}`]},r)}catch{await pe({level:"error",messages:["Failed to connect to Dynatrace logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("dyna-trace-log-transport",10,this.#s)};var Op=class extends Te{constructor(r){super();this.options=r}static{i(this,"NewRelicLoggingPlugin")}getTransport(){return new Cp(this.options)}},Cp=class{static{i(this,"NewRelicTransport")}constructor(e){b("logging.newrelic"),this.#e=e.url??"https://log-api.newrelic.com/log/v1",this.#t=e.apiKey,this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.fields??{},this.#s=e.service??"Zuplo"}#e;#t;#n;#r;#o;#i;#s;log(e,r){e.messages.forEach(n=>{let o=Object.assign({message:Je(n),level:e.level,timestamp:Date.now(),service:this.#s,request_id:e.requestId,atomic_counter:e.vectorClock,environment:this.#n,environment_stage:this.#o,environment_type:this.#r,logging_id:e.loggingId,ray_id:e.rayId===null?void 0:e.rayId,log_source:e.logSource},this.#i);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#u=i(async e=>{if(e.length!==0)try{let r=await V.fetch(this.#e,{method:"POST",body:JSON.stringify(e),headers:{"Content-Type":"application/json","Api-Key":this.#t}});r.ok||await pe({level:"error",messages:[`Failed to send logs to New Relic: ${r.status} - ${r.statusText}`]},r)}catch{await pe({level:"error",messages:["Failed to connect to New Relic logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("new-relic-log-transport",10,this.#u)};var Ap=class extends Te{constructor(r){super();this.options=r}static{i(this,"LokiLoggingPlugin")}getTransport(){return new Np(this.options)}},Lp=class{static{i(this,"LokiStream")}constructor(e,r,n,o,s,a){this.level=e,this.environment=r,this.environmentType=n,this.environmentStage=o,this.requestId=a,this.job=s}job;level;environment;environmentType;environmentStage;requestId;equals=i(e=>this.level===e.level&&this.requestId===e.requestId,"equals")};function jE(t,e){return btoa(`${t}:${e}`)}i(jE,"createBasicDigest");var Np=class{static{i(this,"LokiTransport")}constructor(e){b("logging.loki"),this.#n=e.url,this.#r=jE(e.username,e.password),this.#i=R.instance.loggingEnvironmentType,this.#s=R.instance.loggingEnvironmentStage,this.#o=R.instance.deploymentName,this.#e=e.version??1,this.#t=e.job??"zuplo",this.#u=e.fields??{}}#e;#t;#n;#r;#o;#i;#s;#u;log(e,r){let n=new Lp(e.level,this.#o,this.#i,this.#s,this.#t,this.#e===1?e.requestId:void 0);e.messages.forEach(o=>{let s=Object.assign({stream:n,requestId:e.requestId,rayId:e.rayId,atomicCounter:e.vectorClock,message:Je(o),nanoSecondEpoch:`${e.timestamp.getTime()}000000`},this.#u);this.batcher.enqueue(s)}),r.waitUntil(this.batcher.waitUntilFlushed())}#c=i(e=>{let r={streams:[]};return e.forEach(n=>{let o=r.streams.find(s=>s.stream.equals(n.stream));o||(o={stream:n.stream,values:[]},r.streams.push(o)),o.values.push(this.#e>1?[n.nanoSecondEpoch,n.message,{requestId:n.requestId,rayId:n.rayId,atomicCounter:JSON.stringify(n.atomicCounter)}]:[n.nanoSecondEpoch,n.message])}),r},"#convertToLokiStreamsBatch");#l=i(async e=>{if(e.length===0)return;let r=this.#c(e);try{let n=await V.fetch(this.#n,{method:"POST",body:JSON.stringify(r),headers:{"content-type":"application/json",authorization:`Basic ${this.#r}`}});n.ok||await pe({level:"error",messages:[`Failed to send logs to Loki: ${n.status} - ${n.statusText}`]},n)}catch{await pe({level:"error",messages:["Failed to connect to Loki logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("loki-log-transport",10,this.#l)};var zp=class extends Te{constructor(r){super();this.options=r}static{i(this,"SumoLogicLoggingPlugin")}getTransport(){return new Up(this.options)}},Up=class{static{i(this,"SumoLogicTransport")}constructor(e){b("logging.sumologic"),this.#e=e.url,this.#o=e.category,this.#i=e.name,this.#n=R.instance.loggingEnvironmentType,this.#r=R.instance.loggingEnvironmentStage,this.#t=R.instance.deploymentName,this.#s=e.fields??{}}#e;#t;#n;#r;#o;#i;#s;log(e,r){e.messages.forEach(n=>{let o=Object.assign({timestamp:new Date().toISOString(),message:Je(n),severity:e.level,source:e.logSource,requestId:e.requestId,environment:this.#t,environmentType:this.#n,environmentStage:this.#r,rayId:e.rayId===null?void 0:e.rayId},this.#s);this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}#u=i(async e=>{if(e.length===0)return;let r=e.map(o=>JSON.stringify(o)).join(`
91
91
  `),n=new Headers({"content-type":"application/json; charset=utf-8"});this.#i&&n.set("X-Sumo-Name",this.#i),this.#o&&n.set("X-Sumo-Category",this.#o);try{let o=await V.fetch(this.#e,{method:"POST",body:r,headers:n});o.ok||await pe({level:"error",messages:[`Failed to send logs to Sumologic: ${o.status} - ${o.statusText}`]},o)}catch{await pe({level:"error",messages:["Failed to connect to Sumologic logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("sumo-logic-log-transport",10,this.#u)};var ME="d3a5b78f823648f5b1df4fe269d41172",Dp=class extends Te{constructor(r){super();this.options=r}static{i(this,"VMWareLogInsightLoggingPlugin")}getTransport(){return new Zp(this.options)}},Zp=class{static{i(this,"VMWareLogInsightTransport")}constructor(e){b("logging.vmware-loginsight");let r;try{r=new URL(e.url),r.pathname==="/"&&(r.pathname=`/api/v1/events/ingest/${e.agentId??ME}`)}catch{throw new y(`Invalid option 'url' on 'VMWareLogInsightTransport' plugin. Must be a valid URL, received '${e.url}'`)}this.#e=r.toString(),this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.onMessageSending,this.#t=e.textReplacements,e.fields&&(this.#s=Object.entries(e.fields).map(([n,o])=>({name:n,content:o})))}#e;#t;#n;#r;#o;#i;#s;log(e,r){let n=this.buildEntry(e,r);this.batcher.enqueue(n),r.waitUntil(this.batcher.waitUntilFlushed())}buildEntry(e,r){let n=bg(e.messages);this.#t?.forEach(s=>{n=n.replaceAll(s[0],s[1])});let o={timestamp:Date.now(),text:n,fields:[{name:"severity",content:e.level.toUpperCase()},{name:"request_id",content:e.requestId},{name:"environment_type",content:this.#r},{name:"environment_stage",content:this.#o},{name:"log_source",content:e.logSource},{name:"atomic_counter",content:e.vectorClock}]};return e.rayId&&o.fields.push({name:"request_ray_id",content:e.rayId}),this.#n&&o.fields.push({name:"environment",content:this.#n}),this.#s&&o.fields.push(...this.#s),r.custom&&Object.entries(r.custom).forEach(([s,a])=>{let u=va(a);u&&o.fields.push({name:s,content:u})}),this.#i&&(o=this.#i(o)),o}#u=i(async e=>{if(e.length!==0)try{let r=await V.fetch(this.#e,{method:"POST",body:JSON.stringify({events:e}),headers:{"content-type":"application/json; charset=utf-8"}});r.ok||await pe({level:"error",messages:[`Failed to send logs to Log Insight: ${r.status} - ${r.statusText}`]},r)}catch{await pe({level:"error",messages:["Failed to connect to Log Insight logging service. Check that the URL is correct."]})}},"#dispatchFunction");batcher=new ce("vmware-log-insights-log-transport",10,this.#u)};var jp=class extends Te{constructor(r){super();this.options=r}static{i(this,"AWSLoggingPlugin")}getTransport(){return new Mp(this.options)}},Mp=class{static{i(this,"AWSLogTransport")}awsClient;environment;environmentType;environmentStage;logGroupName;logStreamName;region;fields;batcher=new ce("aws-log-transport",10,async e=>{if(e.length===0)return;let r=JSON.stringify({logGroupName:this.logGroupName,logStreamName:this.logStreamName,logEvents:e});try{let n=await this.awsClient.fetch(`https://logs.${this.region}.amazonaws.com`,{headers:{"Content-Type":"application/x-amz-json-1.1","x-amz-Target":"Logs_20140328.PutLogEvents"},body:r,aws:{accessKeyId:this.awsClient.accessKeyId,secretAccessKey:this.awsClient.secretAccessKey,service:this.awsClient.service,region:this.awsClient.region}});n.ok||await pe({level:"error",messages:[`Failed to send logs to AWS: ${n.status} - ${n.statusText}`]},n)}catch{await pe({level:"error",messages:["Failed to connect to AWS logging service. Check that the URL is correct."]})}});constructor({accessKeyId:e,logStreamName:r,logGroupName:n,secretAccessKey:o,region:s,fields:a}){b("logging.aws"),this.awsClient=new vr({accessKeyId:e,secretAccessKey:o,service:"logs",region:s}),this.logGroupName=n,this.logStreamName=r,this.region=s,this.environmentType=R.instance.loggingEnvironmentType,this.environmentStage=R.instance.loggingEnvironmentStage,this.environment=R.instance.deploymentName,this.fields=a??{}}log(e,r){e.messages.forEach(n=>{let o={timestamp:new Date().getTime(),message:JSON.stringify(Object.assign({data:Je(n),severity:e.level,source:e.logSource,environment:this.environment,atomicCounter:e.vectorClock,requestId:e.requestId,environmentType:this.environmentType,environmentStage:this.environmentStage,rayId:e.rayId===null?void 0:e.rayId},this.fields))};this.batcher.enqueue(o)}),r.waitUntil(this.batcher.waitUntilFlushed())}};var qp=class extends Te{constructor(r){super();this.options=r}static{i(this,"SplunkLoggingPlugin")}getTransport(){return new Hp(this.options)}},Hp=class{static{i(this,"SplunkTransport")}constructor(e){b("logging.splunk"),this.#e=e.url,this.#t=e.token,this.#r=R.instance.loggingEnvironmentType,this.#o=R.instance.loggingEnvironmentStage,this.#n=R.instance.deploymentName,this.#i=e.fields??{},this.#s=e.index??"main",this.#u=e.sourcetype??"json",this.#c=e.host??"zuplo-api",this.#l=e.channel}#e;#t;#n;#r;#o;#i;#s;#u;#c;#l;log(e,r){e.messages.forEach(n=>{let s={event:{message:Je(n),level:e.level,timestamp:new Date().toISOString(),request_id:e.requestId,atomic_counter:e.vectorClock,environment:this.#n,environment_stage:this.#o,environment_type:this.#r,logging_id:e.loggingId,ray_id:e.rayId===null?void 0:e.rayId,log_source:e.logSource,...this.#i},sourcetype:this.#u,host:this.#c,index:this.#s,time:Math.floor(Date.now()/1e3)};this.batcher.enqueue(s)}),r.waitUntil(this.batcher.waitUntilFlushed())}#a=i(async e=>{if(e.length!==0)try{for(let r of e){let n={"Content-Type":"application/json",Authorization:`Splunk ${this.#t}`};this.#l&&(n["X-Splunk-Request-Channel"]=this.#l);let o=await V.fetch(this.#e,{method:"POST",body:JSON.stringify(r),headers:n});if(!o.ok){let s=await o.text();await pe({level:"error",messages:[`Failed to send logs to Splunk: ${o.status} - ${o.statusText}`,`Response: ${s}`]},o)}}}catch(r){await pe({level:"error",messages:["Failed to connect to Splunk logging service. Check that the URL is correct.",`Error: ${r instanceof Error?r.message:String(r)}`]})}},"#dispatchFunction");batcher=new ce("splunk-log-transport",10,this.#a)};var Fp=new WeakMap,qE={tags:[]},Bp=class extends mt{constructor(r){super();this.options=r;b("metrics.datadog")}static{i(this,"DataDogMetricsPlugin")}getTransport(){return new Vp(this.options)}static setContext(r,n){let o=Fp.get(r);o||(o=qE);let s=Object.assign({...o},n);Fp.set(r,s)}},Vp=class{static{i(this,"DataDogMetricsTransport")}#e;#t;#n;#r;#o;#i=void 0;constructor(e){this.#e=e.apiKey,this.#t=e.url??"https://api.datadoghq.com/api/v2/series",this.#n=Object.assign({latency:!0,requestContentLength:!0,responseContentLength:!0},e.metrics),this.#o=e.include??{},this.#r=e.tags??[]}pushMetrics(e,r){this.#i===void 0&&(this.#i=new ce("data-dog-metrics-transport",10,this.dispatchFunction,ue.getLogger(r)));let n=Math.floor(e.timestamp.getTime()/1e3),o=this.#r.concat(Fp.get(r)?.tags??[]);if(this.#o.country&&o.push(`country:${e.country}`),this.#o.httpMethod&&o.push(`httpMethod:${e.method}`),this.#o.statusCode&&o.push(`statusCode:${e.statusCode}`),this.#o.path){let s=e.systemRouteName||e.routePath;o.push(`path:${s}`)}this.#n.latency&&this.#i.enqueue({metric:"zuplo.request.latency",type:3,points:[{timestamp:n,value:e.durationMs}],tags:o}),this.#n.requestContentLength&&e.requestContentLength&&this.#i.enqueue({metric:"zuplo.request.content_length",type:3,points:[{timestamp:n,value:e.requestContentLength}],tags:o}),this.#n.responseContentLength&&e.responseContentLength&&this.#i.enqueue({metric:"zuplo.response.content_length",type:3,points:[{timestamp:n,value:e.responseContentLength}],tags:o}),r.waitUntil(this.#i.waitUntilFlushed())}dispatchFunction=i(async e=>{if(e.length!==0)try{let r=JSON.stringify({series:e}),n=await V.fetch(this.#t,{method:"POST",body:r,headers:{"content-type":"application/json","DD-API-KEY":this.#e}});n.ok||await pe({level:"error",messages:["Failed to send metrics to DataDog."]},n)}catch{await pe({level:"error",messages:["Failed to connect to DataDog metrics service. Check that the URL is correct."]})}},"dispatchFunction")};var Gp=new WeakMap,HE={dimensions:[]},Jp=class extends mt{constructor(r){super();this.options=r;b("metrics.dynatrace")}static{i(this,"DynatraceMetricsPlugin")}getTransport(){return new Wp(this.options)}static setContext(r,n){let o=Gp.get(r);o||(o=HE);let s=Object.assign({...o},n);Gp.set(r,s)}},Wp=class{static{i(this,"DynaTraceMetricsTransport")}apiToken;#e;#t;dimensions;#n;#r=void 0;constructor(e){this.apiToken=e.apiToken,this.#e=e.url,this.#t=Object.assign({latency:!0,requestContentLength:!0,responseContentLength:!0},e.metrics),this.#n=e.include??{},this.dimensions=e.dimensions??[]}pushMetrics(e,r){this.#r===void 0&&(this.#r=new ce("dynatrace-metrics-transport",10,this.dispatchFunction,ue.getLogger(r)));let n=Math.floor(e.timestamp.getTime()),o=this.dimensions.concat(Gp.get(r)?.dimensions??[]);if(this.#n.country&&o.push(`country="${e.country}"`),this.#n.httpMethod&&o.push(`http_method="${e.method}"`),this.#n.statusCode&&o.push(`status_code="${e.statusCode}"`),this.#n.path){let a=e.systemRouteName||e.routePath;o.push(`path="${a}"`)}let s=o.join(",");this.#t.latency&&this.#r.enqueue(`zuplo.request.latency,${s} ${e.durationMs} ${n}`),this.#t.requestContentLength&&e.requestContentLength&&this.#r.enqueue(`zuplo.request.content_length,${s} ${e.requestContentLength} ${n}`),this.#t.responseContentLength&&e.responseContentLength&&this.#r.enqueue(`zuplo.response.content_length,${s} ${e.responseContentLength} ${n}`),r.waitUntil(this.#r.waitUntilFlushed())}dispatchFunction=i(async e=>{if(e.length!==0)try{let r=e.join(`
92
92
  `),n=await V.fetch(this.#e,{method:"POST",body:r,headers:{"content-type":"text/plain",Authorization:`Api-Token ${this.apiToken}`}});n.ok||await pe({level:"error",messages:["Failed to send metrics to Dynatrace."]},n)}catch{await pe({level:"error",messages:["Failed to connect to Dynatrace metrics service. Check that the URL is correct."]})}},"dispatchFunction")};var Kp=new WeakMap,FE={attributes:{}},Qp=class extends mt{constructor(r){super();this.options=r;b("metrics.newrelic")}static{i(this,"NewRelicMetricsPlugin")}getTransport(){return new Xp(this.options)}static setContext(r,n){let o=Kp.get(r);o||(o=FE);let s=Object.assign({...o},n);Kp.set(r,s)}},Xp=class{static{i(this,"NewRelicMetricsTransport")}#e;#t;#n;#r;#o;#i=void 0;constructor(e){this.#e=e.apiKey,this.#t=e.url??"https://metric-api.newrelic.com/metric/v1",this.#n=Object.assign({latency:!0,requestContentLength:!0,responseContentLength:!0},e.metrics),this.#o=e.include??{},this.#r=e.attributes??{service:"zuplo"}}pushMetrics(e,r){this.#i===void 0&&(this.#i=new ce("new-relic-metrics-transport",10,this.dispatchFunction,ue.getLogger(r)));let n=Math.floor(e.timestamp.getTime()),o={...this.#r,...Kp.get(r)?.attributes};if(this.#o.country&&(o.country=e.country),this.#o.httpMethod&&(o.httpMethod=e.method),this.#o.statusCode&&(o.statusCode=e.statusCode.toString()),this.#o.path){let s=e.systemRouteName||e.routePath;o.path=s}this.#n.latency&&this.#i.enqueue({name:"zuplo.request.latency",type:"gauge",value:e.durationMs,timestamp:n,attributes:o}),this.#n.requestContentLength&&e.requestContentLength&&this.#i.enqueue({name:"zuplo.request.content_length",type:"gauge",value:e.requestContentLength,timestamp:n,attributes:o}),this.#n.responseContentLength&&e.responseContentLength&&this.#i.enqueue({name:"zuplo.response.content_length",type:"gauge",value:e.responseContentLength,timestamp:n,attributes:o}),r.waitUntil(this.#i.waitUntilFlushed())}dispatchFunction=i(async e=>{if(e.length!==0)try{let r=JSON.stringify([{metrics:e}]),n=await V.fetch(this.#t,{method:"POST",body:r,headers:{"Content-Type":"application/json","Api-Key":this.#e}});n.ok||await pe({level:"error",messages:[`Failed to send metrics to New Relic. Status: ${n.status} ${n.statusText}`]},n)}catch{await pe({level:"error",messages:["Failed to connect to New Relic metrics service. Check that the URL is correct."]})}},"dispatchFunction")};var Yp=class{static{i(this,"AuditLogDataStaxProvider")}constructor(e){this.#e=e,b("audit-logs.datastax")}#e;writeLogBatch=i(async e=>{await Promise.allSettled(e.map(async r=>{await V.fetch(this.#e.url,{method:"POST",headers:{"X-Cassandra-Token":this.#e.xCassandraToken,"content-type":"application/json"},body:JSON.stringify(r)})}))},"writeLogBatch")};var em=class extends Se{static{i(this,"AuditLogPlugin")}constructor(e,r){super(),this.#e=e,this.#t=r,b("audit-logs")}#e;#t;async initialize(e){new tm(e,this.#e,this.#t)}},av=i(t=>{let e={};return t.forEach((r,n)=>{e[n]=r}),e},"serializableHeaders"),BE={requestFilter:i(async()=>!0,"requestFilter"),include:{request:{headers:!0,body:!0},response:{headers:!0,body:!0}}},tm=class{static{i(this,"AuditPluginImpl")}constructor(e,r,n){this.#t=r;let o={...BE};n?.requestFilter&&(o.requestFilter=n.requestFilter),n?.include?.request&&Object.assign(o,n.include.request),n?.include?.response&&Object.assign(o,n.include.response),this.#e=o,e.addRequestHook(this.#i),this.#n=new ce("audit-log",10,this.#r)}#e;#t;#n;#r=i(async e=>{await this.#t.writeLogBatch(e)},"#dispatch");#o=i(async(e,r,n,o,s,a)=>{try{let u={timestamp:o,durationMs:s,routePath:n.route.path,requestId:n.requestId,userSub:a,request:{url:r.url,method:r.method,headers:this.#e.include?.request?.headers?av(r.headers):void 0,body:this.#e.include?.request?.body?await r.text():void 0},response:{status:e.status,statusText:e.statusText,headers:this.#e.include?.response?.headers?av(e.headers):void 0,body:this.#e.include?.response?.body?await e.text():void 0}};this.#n.enqueue(u),n.waitUntil(this.#n.waitUntilFlushed())}catch(u){n.log.error(u)}},"#asyncPrepLogs");#i=i(async(e,r)=>{try{if(!await this.#e.requestFilter(e,r))return e;let o=new Date,s=Date.now(),a=e.clone();return r.addResponseSendingFinalHook(async(u,c)=>{let l=Date.now(),d=u.clone(),p=this.#o(d,a,r,o,l-s,c.user?.sub).catch(m=>{r.log.error(m)});r.waitUntil(p)}),e}catch(n){return r.log.error(n),e}},"#auditHook")};var rm={None:0,JsonEscape:1},ho=class{constructor(e,r={}){this.stream=e;this.options=r;this.placeholder=`__STREAM_TOKEN_${crypto.randomUUID()}__`}static{i(this,"StreamToken")}placeholder;getRawStream(){return this.stream}getOptions(){return this.options}getSafeToken(){return this.placeholder}async getContent(){if(!this.stream)return this.options.useEmptyStringIfNull?"":null;let e=this.stream.getReader(),r=[];try{for(;;){let{done:u,value:c}=await e.read();if(u)break;r.push(c)}}finally{e.releaseLock()}let n=r.reduce((u,c)=>u+c.length,0),o=new Uint8Array(n),s=0;for(let u of r)o.set(u,s),s+=u.length;let a=new TextDecoder().decode(o);return this.options.base64Encode&&(a=btoa(a)),a}},Ss=class{static{i(this,"StreamBuilder")}template;tokens;flags;constructor(e){this.template=e.template,this.tokens=e.tokens,this.flags=e.flags}escapeJsonString(e){return e.replace(/[\\\"\n\r\t\f\b]/g,r=>{switch(r){case"\\":return"\\\\";case'"':return'\\"';case`
93
93
  `:return"\\n";case"\r":return"\\r";case" ":return"\\t";case"\f":return"\\f";case"\b":return"\\b";default:return r}})}async toString(){let r=this.getStream().getReader(),n=new TextDecoder,o="";for(;;){let{done:s,value:a}=await r.read();if(s)break;o+=n.decode(a,{stream:!0})}return o+=n.decode(),o}getStream(){let e=this.template,r=this.flags,n=new TextEncoder,o=new Map;for(let m of this.tokens)o.set(m.getSafeToken(),m);let s=/"(__STREAM_TOKEN_[^"]+__)"|(__STREAM_TOKEN_[^"]+__)/g,a=[],u=0,c;for(;(c=s.exec(e))!==null;){if(c.index>u&&a.push({type:"literal",value:e.substring(u,c.index)}),c[1]){let m=o.get(c[1]);m?a.push({type:"token",token:m,isQuoted:!0}):a.push({type:"literal",value:c[0]})}else if(c[2]){let m=o.get(c[2]);m?a.push({type:"token",token:m,isQuoted:!1}):a.push({type:"literal",value:c[0]})}u=s.lastIndex}u<e.length&&a.push({type:"literal",value:e.substring(u)});function l(){let m="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",f=new Uint8Array(0);return new TransformStream({transform(h,w){let x=new Uint8Array(f.length+h.length);x.set(f),x.set(h,f.length);let k=x.length%3,_=x.length-k;if(_>0){let L=x.subarray(0,_),U="";for(let z=0;z<L.length;z+=3){let E=L[z],j=L[z+1],W=L[z+2],G=E<<16|j<<8|W;U+=m[G>>18&63],U+=m[G>>12&63],U+=m[G>>6&63],U+=m[G&63]}w.enqueue(U)}f=x.subarray(x.length-k)},flush(h){if(f.length>0){let w=f[0],x=f.length>1?f[1]:0,k=w<<16|x<<8,_="";_+=m[k>>18&63],_+=m[k>>12&63],_+=f.length===2?m[k>>6&63]:"=",_+="=",h.enqueue(_)}}})}i(l,"createBase64EncodeTransformStream");function d(){return new TransformStream({transform(m,f){let h=m.replace(/[\\\"\n\r\t\f\b]/g,w=>{switch(w){case"\\":return"\\\\";case'"':return'\\"';case`
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@zuplo/runtime",
3
3
  "type": "module",
4
- "version": "6.57.1",
4
+ "version": "6.57.3",
5
5
  "repository": "https://github.com/zuplo/zuplo",
6
6
  "author": "Zuplo, Inc.",
7
7
  "exports": {