@zuplo/runtime 6.60.14 → 6.60.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/out/esm/index.js +1 -1
- package/out/esm/index.js.map +1 -1
- 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 q("body must be a string, ArrayBuffer or ArrayBufferView, unless you include the X-Amz-Content-Sha256 header");e=iu(await hh(this.body||""))}return e}};async function Mn(t,e){let r=await crypto.subtle.importKey("raw",typeof t=="string"?su.encode(t):t,{name:"HMAC",hash:{name:"SHA-256"}},!1,["sign"]);return crypto.subtle.sign("HMAC",r,su.encode(e))}i(Mn,"hmac");async function hh(t){return crypto.subtle.digest("SHA-256",typeof t=="string"?su.encode(t):t)}i(hh,"hash");function iu(t){return Array.prototype.map.call(new Uint8Array(t),e=>("0"+e.toString(16)).slice(-2)).join("")}i(iu,"buf2hex");function yh(t){return t.replace(/[!'()*]/g,e=>"%"+e.charCodeAt(0).toString(16).toUpperCase())}i(yh,"encodeRfc3986");function RP(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 gh?[gh[s],a]:[s,a]}i(RP,"guessServiceRegion");function IP(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(IP,"b64ToUint6");function bh(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|=IP(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(bh,"base64Decode");function ki(t){return t<26?t+65:t<52?t+71:t<62?t-4:t===62?43:t===63?47:65}i(ki,"uint6ToB64");function vh(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(ki(o>>>18&63),ki(o>>>12&63),ki(o>>>6&63),ki(o&63)),o=0);return r.substring(0,r.length-2+e)+(e===2?"":e===1?"=":"==")}i(vh,"base64Encode");function Mr(t){let e=t.toString();return`${e.length===1?"0":""}${e}`}i(Mr,"numberToString");function SP(t){let e=t.getTimezoneOffset(),r=Math.abs(e),n=e>0?"-":"+",o=Mr(Math.floor(r/60)),s=Mr(r%60);return`${n}${o}${s}`}i(SP,"getCLFOffset");function uu(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=Mr(t.getDate()),n=e[t.getMonth()],o=t.getFullYear(),s=Mr(t.getHours()),a=Mr(t.getMinutes()),u=Mr(t.getSeconds()),c=SP(t);return`${r}/${n}/${o}:${s}:${a}:${u} ${c}`}i(uu,"toCLFDate");var wh=Ze("zuplo:runtime"),Ur="X-Amzn-Trace-Id",kP="x-amzn-errortype",xh=[],TP=i(async(t,e,r)=>{let n=r;for await(let o of xh)n=await o(t,e,r);return n},"onSendingAwsLambdaEvent"),et=class extends q{static{i(this,"AwsLambdaError")}traceId;errorType;constructor(e,r){super(`Failed to invoke AWS Lambda function. ${e}`),this.traceId=r.get(Ur)??void 0,this.errorType=r.get(kP)??void 0}},_P={addSendingAwsLambdaEventHook:i(t=>{xh.push(t)},"addSendingAwsLambdaEventHook")};async function EP(t,e){w("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 v("awsAccessKeyId is not set in the handler options");if(!n)throw new v("secretAccessKey is not set in the handler options");if(!o)throw new v("region is not set in the handler options");if(!s)throw new v("functionName is not set in the handler options");let l=new Lr({accessKeyId:r,secretAccessKey:n}),d=`https://lambda.${o}.amazonaws.com/2015-03-31/functions/${s}/invocations`;if(wh(`AWS Lambda URL: ${d}`),!a)return l.fetch(d,{body:await t.arrayBuffer()});let[p,m]=await AP(t,{binaryMediaTypes:c}),{options:f}=e.route.handler,h;f&&typeof f=="object"&&"payloadFormatVersion"in f&&f.payloadFormatVersion==="2.0"?h=OP(t,e):h=await $P(t,e,{useAwsResourcePathStyle:u}),wh("Calling onSendingAwsLambdaEvent hook");let b=await TP(t,e,h);b.body=p,b.isBase64Encoded=m;let y=await l.fetch(d,{body:JSON.stringify(b)}),S=f&&typeof f=="object"&&"returnAmazonTraceIdHeader"in f&&typeof f.returnAmazonTraceIdHeader=="boolean"?f.returnAmazonTraceIdHeader:!1;try{return CP(y,{returnLambdaTraceIdHeader:S})}catch(x){if(x instanceof et){let $=S&&x.traceId?{[Ur]:x.traceId}:void 0;return M.internalServerError(t,e,void 0,$)}throw x}}i(EP,"awsLambdaHandler");async function CP(t,{returnLambdaTraceIdHeader:e}){let r;try{r=await t.json()}catch{throw new et("Lambda response did not contain valid JSON",t.headers)}if(t.status!==200)throw r&&typeof r=="object"&&"message"in r&&typeof r.message=="string"?new et(r.message,t.headers):new et(`Status: ${t.statusText}`,t.headers);if(r&&typeof r=="object"&&"errorMessage"in r&&typeof r.errorMessage=="string")throw new et(r.errorMessage,t.headers);if(!r||typeof r!="object"||!("statusCode"in r)||typeof r.statusCode!="number"){let a=t.headers.get(Ur);return new Response(JSON.stringify(r),{status:t.status,headers:{"content-type":"application/json",...e&&a?{[Ur]:a}:{}}})}let n=new Headers;if("headers"in r&&r.headers){if(typeof r.headers!="object")throw new et(`Response headers must be an object. Received ${typeof r.headers}`,t.headers);for(let[a,u]of Object.entries(r.headers))n.set(a,u)}if("cookies"in r&&r.cookies){if(!Array.isArray(r.cookies))throw new et(`Response cookies must be an array. Received ${typeof r.cookies}`,t.headers);n.set("cookie",r.cookies.join(";"))}let o;if("isBase64Encoded"in r&&typeof r.isBase64Encoded!="boolean")throw new et(`Response property isBase64Encoded must be a boolean. Received ${typeof r.isBase64Encoded}`,t.headers);if("isBase64Encoded"in r&&r.isBase64Encoded===!0){if(!("body"in r))throw new et("Response was set to base64 encoded but no body was set",t.headers);if(typeof r.body!="string")throw new et("Response was set to base64 encoded but body was not a string",t.headers);o=bh(r.body)}else"body"in r&&typeof r.body=="string"?o=r.statusCode===204&&r.body===""?null:r.body:"body"in r&&r.body!==null&&r.body!==void 0?o=JSON.stringify(r.body):o=null;if(o!==null&&"bodyEncoding"in r){if(typeof r.bodyEncoding!="string"||!(r.bodyEncoding==="gzip"||r.bodyEncoding==="deflate"))throw new et(`Response property bodyEncoding can only be set to 'gzip' or 'deflate'. Received ${r.bodyEncoding}`,t.headers);let a=new Blob([o]).stream().pipeThrough(new DecompressionStream(r.bodyEncoding));o=await new Response(a).arrayBuffer()}let s=t.headers.get(Ur);return e&&s&&n.set(Ur,s),new Response(o,{headers:n,status:r.statusCode})}i(CP,"getResponse");async function $P(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:uu(),requestTimeEpoch:new Date().valueOf(),resourceId:e.route.operationId??null,resourcePath:LP(e.route.path,r),stage:null},pathParameters:t.params,stageVariables:null}}i($P,"buildEventVersion1");function OP(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:uu(),timeEpoch:new Date().valueOf()},pathParameters:t.params,stageVariables:null}}i(OP,"buildEventVersion2");async function AP(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&&NP(e,o)){let s=await t.arrayBuffer();r=vh(new Uint8Array(s)),n=!0}else r=await t.clone().text();return[r,n]}i(AP,"getBodyResult");function NP(t,e){let r=e.split(";")[0].trim().toLowerCase();return t.findIndex(n=>n==="*/*"?!0:n.toLowerCase()===r)>-1}i(NP,"matchesContentType");function LP(t,e=!1){if(!e)return t;let r=ou(t),n=fh(t),o={};return r.forEach(s=>{typeof s=="string"?o[s]=`{${s}}`:o[s.name]=`{${s.name}}`}),n(o)}i(LP,"getResourcePath");var MP=[502,503,504];async function zr(t,e){if(MP.includes(t.status)){let r=Y.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(zr,"logBadGatewayResponses");var cu;function Jt(t){if(cu===void 0){let r=P.instance.runtime.ZUPLO_HANDLER_WRITE_LOG_LEVEL;["debug","info","warn","error"].includes(r??"")||(r="debug"),cu=r}return t.log[cu]}i(Jt,"getHandlerUserLogFunction");async function UP(t,e){w("handler.open-api");let r=P.instance.build.BUILD_ID,{buildAssetsUrl:n}=P.instance,o=e.route.handler.options,{openApiFilePath:s}=o;if(!s)throw new v("Open API Spec Handler must have 'openApiFilePath' specified");let a=zP(s);if(!a.isValid)throw new v(a.error);let u=`${n}/${r}${s.substring(1)}`,c=await J.fetch(u,{method:t.method,body:t.body,headers:t.headers});if(c.status!==200)return M.notFound(t,e,{detail:"OpenAPI file could not be found."});let l={"content-type":"application/json",vary:"Accept-Encoding"};P.instance.isDeno||(l["content-encoding"]=c.headers.get("content-encoding")||"");let d=new Response(c.body,{headers:l,status:c.status,statusText:c.statusText});return zr(d,e),d}i(UP,"openApiSpecHandler");var zP=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 DP(t,e){w("handler.redirect");let r=e.route.handler.options;if(!r.location)throw new v("Redirect Handler must have 'location' specified");let n=r.status??302;return new Response(null,{status:n,headers:{location:r.location}})}i(DP,"redirectHandler");async function ZP(t){if(w("handler.zuplo-service-proxy"),Object.entries(t.params).length!==1)throw new v("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,P.instance.zuploEdgeApiUrl),r=new Headers(t.headers);return r.set("Authorization",`Bearer ${P.instance.authApiJWT}`),J.fetch(e,{method:t.method,headers:r,body:t.body})}i(ZP,"zuploServiceProxy");function jP(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(jP,"join");async function qP(t,e){w("handler.url-forward");let r=Jt(e),n=e.route.handler.options,o=n.forwardSearch!==!1,s;if(P.instance.build.COMPATIBILITY_FLAGS.useForwardRedirectsPropOnUrlForwardHandler?s=n.followRedirects===!0?"follow":"manual":typeof n.followRedirects<"u"&&w("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 v("Invalid options for this route");let a=Vt(e),u=new URL(t.url),c=n.__rewriteFunction(t,a),l=jP(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`),zr(m,e),m}i(qP,"urlForwardHandler");var HP=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 FP(t,e){w("handler.url-rewrite");let r=Jt(e),n=e.route.handler.options,o=n.forwardSearch!==!1,s=n.followRedirects??!1;if(!n||typeof n.__rewriteFunction!="function")throw new v("Invalid options for this route");let a=Vt(e),u=n.__rewriteFunction(t,a),c=o?HP(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`),zr(d,e),d}i(FP,"urlRewriteHandler");function BP(t,e,r){t.addEventListener("close",()=>{e.close()}),e.addEventListener("close",()=>{t.close()}),t.addEventListener("error",n=>{r.log.error(`Incoming WebSocket error: ${JSON.stringify(n)}`),e.send(JSON.stringify(n))}),e.addEventListener("error",n=>{r.log.error(`Outgoing WebSocket error: ${JSON.stringify(n)}`),t.send(JSON.stringify(n))}),t.addEventListener("message",n=>{e.send(n.data)}),e.addEventListener("message",n=>{t.send(n.data)})}i(BP,"wireUpPassthrough");async function GP(t,e){w("handler.websocket");let r=e.route.handler.options,n=Jt(e);if(!r||!r.rewritePattern)throw new v("WebSocket Handler must have option 'rewritePattern' specified");let o=t.headers.get("Upgrade");if(!o||o!=="websocket")return M.badRequest(t,e,{detail:"Request must include header 'Upgrade: websocket'"});if(!r||typeof r.__rewriteFunction!="function")throw new v("Invalid options for this route");let s=Vt(e),a=r.__rewriteFunction(t,s);if(n(`Attempting WebSocket connection to '${a}'`),P.instance.isDeno){if(!t.originalRequest)throw new Error("Original websocket request is not available");let u=new WebSocket(a);await new Promise((d,p)=>{let m=i(()=>{h(),n("WebSocket connection established with upstream"),d()},"onOpen"),f=i(b=>{h(),n(`WebSocket connection error: ${b}`),p(new Error("Upstream open failed"))},"onErr"),h=i(()=>{u.removeEventListener("open",m),u.removeEventListener("error",f)},"cleanup");u.addEventListener("open",m),u.addEventListener("error",f)}).catch(d=>{throw new Error(`Failed to open outgoing socket: ${d.message}`)});let{socket:c,response:l}=globalThis.Deno.upgradeWebSocket(t.originalRequest);return BP(c,u,e),l}else{a=a.replace(/^(ws)/,"http");let u=await fetch(a,{method:t.method,headers:t.headers,body:t.body});if(u.status!==101||!u.webSocket){let c=await u.text(),l=`WebSocket connection error - ${u.status}: ${u.statusText}, content: '${c}'`;throw new Error(l)}return n(`WebSocket connected, received response ${u.status} - ${u.statusText}`),new Response(null,{status:101,webSocket:u.webSocket})}}i(GP,"webSocketHandler");async function VP(t,e){let r=ve.instance.runtimeSettings.developerPortal.urls?.urls?.[0];if(!r)throw new v("Developer portal URL is not configured.");let n=JP(t.url,r);return e.log.info(`Redirecting from legacy dev portal to ${n}`),new Response(null,{status:301,headers:{location:n}})}i(VP,"redirectLegacyDevPortal");function JP(t,e){let r=new URL(t),n=r.pathname.split("/")[1];if(!n)throw new v("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(JP,"getDevPortalRedirectUrl");var lu=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 v(`${a} - Websocket policy must be a valid function (${u})`)}return s}),"getWebSocketPolicyFunctions"),Ph=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");async function WP(t,e,r){r(`Attempting WebSocket connection to '${e}'`);let n=new WebSocket(e);await new Promise((a,u)=>{let c=i(()=>{d(),r("WebSocket connection established with upstream"),a()},"onOpen"),l=i(p=>{d(),r(`WebSocket connection error: ${p}`),u(new Error("Upstream open failed"))},"onErr"),d=i(()=>{n.removeEventListener("open",c),n.removeEventListener("error",l)},"cleanup");n.addEventListener("open",c),n.addEventListener("error",l)}).catch(a=>{throw new Error(`Failed to open outgoing socket: ${a.message}`)});let{socket:o,response:s}=globalThis.Deno.upgradeWebSocket(t);return{clientSocket:o,outgoingSocket:n,response:s}}i(WP,"getDenoClientAndServerSockets");async function KP(t,e,r){r(`Attempting WebSocket connection to '${e}'`);let n=await fetch(e,{method:t.method,headers:t.headers,body:t.body});if(n.status!==101||!n.webSocket){let c=await n.text(),l=`WebSocket connection error - ${n.status}: ${n.statusText}, content: '${c}'`;throw new Error(l)}let o=new WebSocketPair,[s,a]=Object.values(o);r(`WebSocket connected, received response ${n.status} - ${n.statusText}`),n.webSocket.accept(),a.accept();let u=new Response(null,{status:101,webSocket:s});return{clientSocket:s,outgoingSocket:n.webSocket,serverSocket:a,response:u}}i(KP,"getCfClientAndServerSockets");function Rh(t,e,r,n,o,s){t.addEventListener("close",()=>{e.close()}),t.addEventListener("error",a=>{n.log.error(`WebSocket error: ${JSON.stringify(a)}, direction: ${s}`),e.send(JSON.stringify(a))}),t.addEventListener("message",a=>{try{let c=i(async l=>{let d=await Ph(l,t,e,r,n,o);d!==void 0&&e.send(d)},"innerPipeline")(a).catch(n.log.error);n.waitUntil(c)}catch(u){n.log.error(u)}})}i(Rh,"wireUpListeners");async function QP(t,e){w("handler.websocket-pipeline");let r=e.route.handler.options,n=Jt(e);if(!r||!r.rewritePattern)throw new v("WebSocket Pipeline Handler must have option 'rewritePattern' specified");let o=t.headers.get("Upgrade");if(!o||o!=="websocket")return M.badRequest(t,e,{detail:"Request must include header 'Upgrade: websocket'"});if(!r||typeof r.__rewriteFunction!="function")throw new v("Invalid options for this route");let s=Vt(e),a=r.__rewriteFunction(t,s),u=r.policies&&r.policies.inbound?lu(r.policies.inbound,"inbound"):[],c=r.policies&&r.policies.outbound?lu(r.policies.outbound,"outbound"):[],l,d,p,m;if(P.instance.isDeno){if(!t.originalRequest)throw new Error("Original websocket request is not available");let f=await WP(t.originalRequest,a,n);p=f.clientSocket,l=p,d=f.outgoingSocket,m=f.response}else{a=a.replace(/^(ws)/,"http");let f=await KP(t,a,n);l=f.serverSocket,d=f.outgoingSocket,p=f.clientSocket,m=f.response}return Rh(l,d,t,e,u,"inbound"),Rh(d,l,t,e,c,"outbound"),m}i(QP,"webSocketPipelineHandler");De();Qt();Qt();function br({id:t,result:e}){return{jsonrpc:ht,id:t,result:e}}i(br,"newJSONRPCReponse");function Oe({id:t,code:e,message:r,data:n}){return{jsonrpc:ht,id:t,error:{code:e,message:r,data:n}}}i(Oe,"newJSONRPCError");De();Qt();$s();var zT=g.object({jsonrpc:g.literal(ht),id:uv,error:g.object({code:g.number().int(),message:g.string(),data:g.optional(g.unknown())})}).strict();Io();vr();wr();var So=i(t=>lv.safeParse(t).success,"isJSONRPCRequest"),pv=i(t=>cv.safeParse(t).success,"isJSONRPCNotification"),Os=i(t=>dv.safeParse(t).success,"isJSONRPCResponse");var ko=class{static{i(this,"NoOpLogger")}debug(){}info(){}warn(){}error(){}};function As(){return new ko}i(As,"createDefaultLogger");De();vr();wr();De();var mv=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(),fv=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();De();Jr();var zp=Tt.extend({version:g.string()});var gv=ot.extend({method:g.literal("initialize"),params:nt.extend({protocolVersion:g.string(),capabilities:mv,clientInfo:zp})}),Z1=lt.extend({protocolVersion:g.string(),capabilities:fv,serverInfo:zp,instructions:g.optional(g.string())});De();Io();vr();wr();Jr();Ns();var n_=Tt.extend({description:g.optional(g.string()),required:g.optional(g.boolean())}),o_=Tt.extend({description:g.optional(g.string()),arguments:g.optional(g.array(n_)),_meta:g.optional(g.object({}).loose())}),i_=g.lazy(()=>{let{TextContentSchema:t,ImageContentSchema:e,AudioContentSchema:r,EmbeddedResourceSchema:n}=(jp(),qo(Zp)),{ResourceLinkSchema:o}=(Bp(),qo(Fp));return g.object({role:g.enum(["user","assistant"]),content:g.discriminatedUnion("type",[t,e,r,o,n])}).loose()}),xv=er.extend({method:g.literal("prompts/list")}),dH=tr.extend({prompts:g.array(o_)}),Pv=ot.extend({method:g.literal("prompts/get"),params:nt.extend({name:g.string(),arguments:g.optional(g.record(g.string(),g.string()))})}),pH=lt.extend({description:g.optional(g.string()),messages:g.array(i_)}),mH=Xt.extend({method:g.literal("notifications/prompts/list_changed")});De();Io();vr();wr();Jr();Ns();var s_=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(),a_=Tt.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(s_),_meta:g.optional(g.object({}).loose())}),xH=er.extend({method:g.literal("tools/list")}),PH=tr.extend({tools:g.array(a_)}),Rv=ot.extend({method:g.literal("tools/call"),params:nt.extend({name:g.string(),arguments:g.optional(g.record(g.string(),g.unknown()))})}),RH=g.lazy(()=>{let{TextContentSchema:t,ImageContentSchema:e,AudioContentSchema:r,EmbeddedResourceSchema:n}=(jp(),qo(Zp)),{ResourceLinkSchema:o}=(Bp(),qo(Fp));return lt.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())})}),IH=Xt.extend({method:g.literal("notifications/tools/list_changed")});var Gp="2025-06-18",Vp="2025-03-26",Jp="2024-11-05",Wp="2024-10-07",Kp=[Gp,Vp,Jp,Wp];var u_="MCP Server",c_="0.0.0",Ls=class{static{i(this,"MCPServer")}capabilities;tools=new Map;prompts=new Map;name;version;instructions;logger;constructor(e){this.name=e.name||u_,this.version=e.version||c_,this.instructions=e.instructions||void 0,this.logger=e.logger||As(),this.capabilities={tools:{supported:!0,available:[]},prompts:{},...e.capabilities}}withTransport(e){e.onMessage(async r=>{try{if(So(r)){let n=await this.handleRequest(r);if(n)return await e.send(n),n}else{if(pv(r))return await this.handleNotification(r),null;if(Os(r))return this.logger.debug("Received response:",r),null}}catch(n){if(this.logger.error("Error processing message:",n),So(r)){let o=Oe({id:r.id,code:$e.InternalError,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)}addPrompt(e){let{name:r,validator:n,generator:o,description:s}=e,a=n.jsonSchema,u;if(a.properties&&typeof a.properties=="object"){let d=new Set(a.required||[]);u=Object.entries(a.properties).map(([p,m])=>({name:p,description:m.description??`Prompt for ${p}`,required:d.has(p)}))}let l={prompt:{name:r,description:s,...u&&{arguments:u}},validator:n,generator:o};this.prompts.set(r,l)}removePrompt(e){return this.prompts.delete(e)}getPrompt(e){return this.prompts.get(e)?.prompt}getPromptDefinitions(){return Array.from(this.prompts.values()).map(e=>e.prompt)}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);case"prompts/list":return this.handlePromptListRequest(e);case"prompts/get":return this.handlePromptGetRequest(e);default:return Oe({id:e.id,code:$e.MethodNotFound,message:`Method "${e.method}" not found`})}}catch(r){return this.logger.error("Error handling request:",r),Oe({id:e.id,code:$e.InternalError,message:r instanceof Error?r.message:"Internal error"})}}async handleNotification(e){this.logger.debug("Received notification:",e.method)}handlePing(e){return br({id:e.id,result:{}})}handleInitialize(e){let r=gv.safeParse(e);if(!r.success){let o=g.treeifyError(r.error),s=g.prettifyError(r.error);return Oe({id:e.id,code:$e.InvalidParams,message:`Invalid request parameters: ${s}`,data:o})}let n=r.data.params.protocolVersion;switch(n){case Gp:case Vp:case Jp:case Wp:{let o={protocolVersion:n,capabilities:this.getCapabilities(),serverInfo:{name:this.name,version:this.version},...this.instructions?{instructions:this.instructions}:{}};return br({id:e.id,result:o})}default:return Oe({id:e.id,code:$e.InvalidParams,message:`Unsupported protocol version: ${n} - supported versions: ${Kp}`,data:{supportedVersions:Kp}})}}async handleToolListRequest(e){let n={tools:Array.from(this.tools.entries()).map(([o,s])=>s.tool)};return br({id:e.id,result:n})}async handleToolCallRequest(e){let r=Rv.safeParse(e);if(!r.success)return this.logger.warn("Could not validate tool call:",r.error),Oe({id:e.id,code:$e.InvalidRequest,message:`Invalid request ${r.error}`});let n=r.data,o=n.params.name,s=this.tools.get(o);if(!s)return Oe({id:e.id,code:$e.InvalidParams,message:`Tool "${o}" not found`});let a=n.params.arguments??{},u=s.validator.parse(a);if(!u.success)return Oe({id:e.id,code:$e.InvalidParams,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 br({id:e.id,result:l})}catch(c){return this.logger.error(`Error executing tool "${o}":`,c),Oe({id:e.id,code:$e.InternalError,message:c instanceof Error?c.message:"Tool execution error"})}}async handlePromptListRequest(e){let r=xv.safeParse(e);if(!r.success){let s=g.treeifyError(r.error),a=g.prettifyError(r.error);return Oe({id:e.id,code:$e.InvalidParams,message:`Invalid request parameters: ${a}`,data:s})}let o={prompts:Array.from(this.prompts.values()).map(s=>s.prompt)};return br({id:e.id,result:o})}async handlePromptGetRequest(e){let r=Pv.safeParse(e);if(!r.success){let u=g.treeifyError(r.error),c=g.prettifyError(r.error);return Oe({id:e.id,code:$e.InvalidParams,message:`Invalid request parameters: ${c}`,data:u})}let n=r.data.params.name,o=this.prompts.get(n);if(!o)return Oe({id:e.id,code:$e.InvalidParams,message:`Prompt "${n}" not found`});let s=r.data.params.arguments??{},a=o.validator.parse(s);if(!a.success)return Oe({id:e.id,code:$e.InvalidParams,message:a.errorMessage?`Invalid arguments for prompt '${n}': ${a.errorMessage}`:`Invalid arguments for prompt '${n}'`,data:a.errorData});try{let u=a.data,c=await o.generator(u),l={...o.prompt.description&&{description:o.prompt.description},messages:c};return br({id:e.id,result:l})}catch(u){return this.logger.error(`Error generating prompt "${n}":`,u),Oe({id:e.id,code:$e.InternalError,message:u instanceof Error?u.message:"Prompt generation error"})}}updateAvailableTools(){this.capabilities.tools&&(this.capabilities.tools.available=Array.from(this.tools.keys()))}};Qt();var Ms=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||As(),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(Os(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),So(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(Oe({code:-32e3,message:"Transport not connected",id:null})),{status:503,headers:{"Content-Type":"application/json"}});if(!this.messageHandler)return new Response(JSON.stringify(Oe({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){return this.logger.error("Error handling request:",n),new Response(JSON.stringify(Oe({code:$e.InternalError,message:"Internal server error",id:null})),{status:400,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(Oe({code:$e.InvalidRequest,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(Oe({code:$e.ParseError,message:"Parse error: received invalid JSON",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 b of s)if(this.isRequest(b)){let y=await this.messageHandler?.(b);y&&m.push(y)}else await this.messageHandler?.(b);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{return new Response(JSON.stringify(Oe({code:$e.InternalError,message:"Internal server 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(Oe({code:$e.InvalidRequest,message:"Session ID 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 Eo=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"}},l_=/[$_\p{ID_Start}]/u,d_=/[$_\u200C\u200D\p{ID_Continue}]/u,Xp=".*";function p_(t,e){return(e?/^[\x00-\xFF]*$/:/^[\x00-\x7F]*$/).test(t)}i(p_,"Re");function kv(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&&l_.test(c)||u!==n+1&&d_.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(!p_(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(kv,"v");function Tv(t,e={}){let r=kv(t);e.delimiter??="/#?",e.prefixes??="./";let n=`[^${dt(e.delimiter)}]+?`,o=[],s=0,a=0,u="",c=new Set,l=i($=>{if(a<r.length&&r[a].type===$)return r[a++].value},"a"),d=i(()=>l("OTHER_MODIFIER")??l("ASTERISK"),"f"),p=i($=>{let O=l($);if(O!==void 0)return O;let{type:A,index:T}=r[a];throw new TypeError(`Unexpected ${A} at ${T}, expected ${$}`)},"d"),m=i(()=>{let $="",O;for(;O=l("CHAR")??l("ESCAPED_CHAR");)$+=O;return $},"T"),f=i($=>$,"Se"),h=e.encodePart||f,b="",y=i($=>{b+=$},"U"),S=i(()=>{b.length&&(o.push(new Eo(3,"","",h(b),"",3)),b="")},"$"),x=i(($,O,A,T,U)=>{let D=3;switch(U){case"?":D=1;break;case"*":D=0;break;case"+":D=2;break}if(!O&&!A&&D===3){y($);return}if(S(),!O&&!A){if(!$)return;o.push(new Eo(3,"","",h($),"",D));return}let Z;A?A==="*"?Z=Xp:Z=A:Z=n;let C=2;Z===n?(C=1,Z=""):Z===Xp&&(C=0,Z="");let _;if(O?_=O:A&&(_=s++),c.has(_))throw new TypeError(`Duplicate name '${_}'.`);c.add(_),o.push(new Eo(C,_,h($),Z,h(T),D))},"V");for(;a<r.length;){let $=l("CHAR"),O=l("NAME"),A=l("REGEX");if(!O&&!A&&(A=l("ASTERISK")),O||A){let U=$??"";e.prefixes.indexOf(U)===-1&&(y(U),U=""),S();let D=d();x(U,O,A,"",D);continue}let T=$??l("ESCAPED_CHAR");if(T){y(T);continue}if(l("OPEN")){let U=m(),D=l("NAME"),Z=l("REGEX");!D&&!Z&&(Z=l("ASTERISK"));let C=m();p("CLOSE");let _=d();x(U,D,Z,C,_);continue}S(),p("END")}return o}i(Tv,"D");function dt(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(dt,"S");function Iv(t){return t&&t.ignoreCase?"ui":"u"}i(Iv,"X");function m_(t,e,r){return _v(Tv(t,r),e,r)}i(m_,"Z");function Wr(t){switch(t){case 0:return"*";case 1:return"?";case 2:return"+";case 3:return""}}i(Wr,"k");function _v(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+=dt(u.value):n+=`(?:${dt(u.value)})${Wr(u.modifier)}`;continue}e&&e.push(u.name);let c=`[^${dt(r.delimiter)}]+?`,l=u.value;if(u.type===1?l=c:u.type===0&&(l=Xp),!u.prefix.length&&!u.suffix.length){u.modifier===3||u.modifier===1?n+=`(${l})${Wr(u.modifier)}`:n+=`((?:${l})${Wr(u.modifier)})`;continue}if(u.modifier===3||u.modifier===1){n+=`(?:${dt(u.prefix)}(${l})${dt(u.suffix)})`,n+=Wr(u.modifier);continue}n+=`(?:${dt(u.prefix)}`,n+=`((?:${l})(?:`,n+=dt(u.suffix),n+=dt(u.prefix),n+=`(?:${l}))*)${dt(u.suffix)})`,u.modifier===0&&(n+="?")}let o=`[${dt(r.endsWith)}]|$`,s=`[${dt(r.delimiter)}]`;if(r.end)return r.strict||(n+=`${s}?`),r.endsWith.length?n+=`(?=${o})`:n+="$",new RegExp(n,Iv(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,Iv(r))}i(_v,"F");var nr={delimiter:"",prefixes:"",sensitive:!0,strict:!0},f_={delimiter:".",prefixes:"",sensitive:!0,strict:!0},g_={delimiter:"/",prefixes:"/",sensitive:!0,strict:!0};function h_(t,e){return t.length?t[0]==="/"?!0:!e||t.length<2?!1:(t[0]=="\\"||t[0]=="{")&&t[1]=="/":!1}i(h_,"J");function Ev(t,e){return t.startsWith(e)?t.substring(e.length,t.length):t}i(Ev,"Q");function y_(t,e){return t.endsWith(e)?t.substr(0,t.length-e.length):t}i(y_,"Ee");function Cv(t){return!t||t.length<2?!1:t[0]==="["||(t[0]==="\\"||t[0]==="{")&&t[1]==="["}i(Cv,"W");var $v=["ftp","file","http","https","ws","wss"];function Ov(t){if(!t)return!0;for(let e of $v)if(t.test(e))return!0;return!1}i(Ov,"N");function b_(t,e){if(t=Ev(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(b_,"te");function v_(t,e){if(t=Ev(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(v_,"re");function w_(t,e){return e||t===""?t:Cv(t)?Lv(t):Nv(t)}i(w_,"ne");function x_(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.password=t,r.password}i(x_,"se");function P_(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.username=t,r.username}i(P_,"ie");function R_(t,e,r){if(r||t==="")return t;if(e&&!$v.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(R_,"ae");function I_(t,e,r){return Av(e)===t&&(t=""),r||t===""?t:Mv(t)}i(I_,"oe");function S_(t,e){return t=y_(t,":"),e||t===""?t:Yp(t)}i(S_,"ce");function Av(t){switch(t){case"ws":case"http":return"80";case"wws":case"https":return"443";case"ftp":return"21";default:return""}}i(Av,"_");function Yp(t){if(t==="")return t;if(/^[-+.A-Za-z0-9]*$/.test(t))return t.toLowerCase();throw new TypeError(`Invalid protocol '${t}'.`)}i(Yp,"y");function k_(t){if(t==="")return t;let e=new URL("https://example.com");return e.username=t,e.username}i(k_,"le");function T_(t){if(t==="")return t;let e=new URL("https://example.com");return e.password=t,e.password}i(T_,"fe");function Nv(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(Nv,"z");function Lv(t){if(t==="")return t;if(/[^0-9a-fA-F[\]:]/g.test(t))throw new TypeError(`Invalid IPv6 hostname '${t}'`);return t.toLowerCase()}i(Lv,"j");function Mv(t){if(t===""||/^[0-9]*$/.test(t)&&parseInt(t)<=65535)return t;throw new TypeError(`Invalid port '${t}'.`)}i(Mv,"K");function __(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(__,"he");function E_(t){return t===""?t:new URL(`data:${t}`).pathname}i(E_,"ue");function C_(t){if(t==="")return t;let e=new URL("https://example.com");return e.search=t,e.search.substring(1,e.search.length)}i(C_,"de");function $_(t){if(t==="")return t;let e=new URL("https://example.com");return e.hash=t,e.hash.substring(1,e.hash.length)}i($_,"pe");var O_=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=kv(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.#k())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.#E();let t=7,e=1;this.#P()?(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.#R()?this.#a(4,1):this.#y()&&this.#a(5,1);break;case 4:this.#y()&&this.#a(5,1);break;case 5:this.#T()?this.#c+=1:this.#_()&&(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,":")}#P(){return this.#d(this.#r+1,"/")&&this.#d(this.#r+2,"/")}#y(){return this.#d(this.#r,"@")}#R(){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"}#k(){return this.#t[this.#r].type=="CLOSE"}#T(){return this.#d(this.#r,"[")}#_(){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)}#E(){let t={};Object.assign(t,nr),t.encodePart=Yp;let e=m_(this.#p(),void 0,t);this.#l=Ov(e)}},Qp=["protocol","username","password","hostname","port","pathname","search","hash"],rr="*";function Sv(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(Sv,"ge");function jt(t,e){return e?_o(t):t}i(jt,"b");function To(t,e,r){let n;if(typeof e.baseURL=="string")try{n=new URL(e.baseURL),e.protocol===void 0&&(t.protocol=jt(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=jt(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=jt(n.password,r)),e.protocol===void 0&&e.hostname===void 0&&(t.hostname=jt(n.hostname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&(t.port=jt(n.port,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&(t.pathname=jt(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=jt(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=jt(n.hash.substring(1,n.hash.length),r))}catch{throw new TypeError(`invalid baseURL '${e.baseURL}'.`)}if(typeof e.protocol=="string"&&(t.protocol=S_(e.protocol,r)),typeof e.username=="string"&&(t.username=P_(e.username,r)),typeof e.password=="string"&&(t.password=x_(e.password,r)),typeof e.hostname=="string"&&(t.hostname=w_(e.hostname,r)),typeof e.port=="string"&&(t.port=I_(e.port,t.protocol,r)),typeof e.pathname=="string"){if(t.pathname=e.pathname,n&&!h_(t.pathname,r)){let o=n.pathname.lastIndexOf("/");o>=0&&(t.pathname=jt(n.pathname.substring(0,o+1),r)+t.pathname)}t.pathname=R_(t.pathname,t.protocol,r)}return typeof e.search=="string"&&(t.search=v_(e.search,r)),typeof e.hash=="string"&&(t.hash=b_(e.hash,r)),t}i(To,"w");function _o(t){return t.replace(/([+*?:{}()\\])/g,"\\$1")}i(_o,"C");function A_(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(A_,"Oe");function N_(t,e){e.delimiter??="/#?",e.prefixes??="./",e.sensitive??=!1,e.strict??=!1,e.end??=!0,e.start??=!0,e.endsWith="";let r=".*",n=`[^${A_(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+=_o(u.value);continue}s+=`{${_o(u.value)}}${Wr(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+=_o(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+=_o(u.suffix),l&&(s+="}"),u.modifier!==3&&(s+=Wr(u.modifier))}return s}i(N_,"ke");var Us=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 O_(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:rr,protocol:rr,username:rr,password:rr,hostname:rr,port:rr,search:rr,hash:rr};this.#e=To(s,t,!0),Av(this.#e.protocol)===this.#e.port&&(this.#e.port="");let a;for(a of Qp){if(!(a in this.#e))continue;let u={},c=this.#e[a];switch(this.#n[a]=[],a){case"protocol":Object.assign(u,nr),u.encodePart=Yp;break;case"username":Object.assign(u,nr),u.encodePart=k_;break;case"password":Object.assign(u,nr),u.encodePart=T_;break;case"hostname":Object.assign(u,f_),Cv(c)?u.encodePart=Lv:u.encodePart=Nv;break;case"port":Object.assign(u,nr),u.encodePart=Mv;break;case"pathname":Ov(this.#t.protocol)?(Object.assign(u,g_,o),u.encodePart=__):(Object.assign(u,nr,o),u.encodePart=E_);break;case"search":Object.assign(u,nr,o),u.encodePart=C_;break;case"hash":Object.assign(u,nr,o),u.encodePart=$_;break}try{this.#o[a]=Tv(c,u),this.#t[a]=_v(this.#o[a],this.#n[a],u),this.#r[a]=N_(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=To(r,t,!1):r=To(r,Sv(t,e),!1)}catch{return!1}let n;for(n of Qp)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=To(r,t,!1):r=To(r,Sv(t,e),!1)}catch{return null}let n={};e?n.inputs=[t,e]:n.inputs=[t];let o;for(o of Qp){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 Eo(3,"","","","",3),s=new Eo(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 zs=class{static{i(this,"UrlPatternBuilder")}pattern;pathParams={};searchParams=new URLSearchParams;expectedPathParams=new Set;seenPathParams=new Set;constructor(e){this.pattern=new Us({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 v(`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 v(`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 Ds=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 zs(n);for(let a of o)s.addParameter(a,e,r);return s.toString()}};var Kr=class{static{i(this,"CustomValidator")}jsonSchema;parseFn;constructor(e,r){this.jsonSchema=e,this.parseFn=r}parse(e){return this.parseFn(e)}};De();De();De();var Zs=class{static{i(this,"ZodFormatSchemaRegistry")}static formatter=new Map([["email",()=>g.email()],["uri",()=>g.url()],["url",()=>g.url()],["date",()=>g.iso.date()],["date-time",()=>g.iso.datetime()],["time",()=>g.iso.time()],["ipv4",()=>g.ipv4()],["ipv6",()=>g.ipv6()],["uuid",()=>g.guid()],["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)}},Qr=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?Zs.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){Zs.register(e,r)}};var js=class{constructor(e){this.schema=e}static{i(this,"JSONSchemaBuilder")}build(){return Qr.run(this.schema)}},qs=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?Qr.run(r):null}},Hs=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=Qr.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 Co=class t{static{i(this,"UniversalValidatorBuilder")}root=null;components={};static withRoot(e){let r=new t;return r.root=e,r}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(){return this.root?this.buildFromSchema(this.root):Object.keys(this.components).length>0?this.buildFromComponents():this.buildEmptyValidator()}buildFromSchema(e){let r=g.toJSONSchema(e);return new Kr(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:o.data,errorData:null}:{success:!1,data:null,errorMessage:g.prettifyError(o.error),errorData:g.treeifyError(o.error)}})}buildFromComponents(){let e=g.object(this.components),r=g.toJSONSchema(e);return new Kr(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:o.data,errorData:null}:{success:!1,data:null,errorMessage:g.prettifyError(o.error),errorData:g.treeifyError(o.error)}})}buildEmptyValidator(){let e={type:"object",properties:{},required:[],additionalProperties:!1};return new Kr(e,r=>({success:!0,data:r,errorData:null}))}},$o=class{static{i(this,"SchemaBuilderFactory")}static createJsonSchemaBuilder(e){return new js(e)}static createRequestBodyBuilder(e,r){return new qs(e,r)}static createParameterBuilder(e,r){let n=r?e.filter(o=>o.in===r):e;return new Hs(n)}static createValidatorBuilder(e,r){let n=new Co,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}static createPromptValidatorBuilder(e){let r=new Co,o=e.raw()?.requestBody;if(!o?.content||!o.content["application/json"])return r;let a=this.createRequestBodyBuilder(e,"application/json");return Co.withRoot(a.build())}};import{AsyncLocalStorage as L_}from"node:async_hooks";var em=new L_;function Uv(t,e,r){return em.run({headers:t,zuploContext:e},r)}i(Uv,"runWithInvokeContext");function zv(){return em.getStore()?.headers??{}}i(zv,"getInvokeHeaders");function tm(){let t=em.getStore();if(!t)throw new Error("No Zuplo context available in current execution context");return t.zuploContext}i(tm,"getInvokeContext");var Fs=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??[]),s.registerToolsFromFileSources(s.opts.files??[]),s.registerPromptsFromFileSources(s.opts.prompts??[]),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=s.server.getPromptDefinitions(),d=l?l.length:0,p=Date.now()-a;r.log.debug("MCP Server cold start",{routeKey:n,toolCount:c,promptCount:d,totalElapsedMs:p,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 ko,this.context=r,this.opts=e,this.server=new Ls({name:e.name??"Zuplo MCP Server",version:e.version??"0.0.0",logger:n}),this.transport=new Ms({logger:n}),this.includeOutputSchema=e.includeOutputSchema??!1,this.includeStructuredContent=e.includeStructuredContent??!1}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})}if(this.debugMode&&o.method==="prompts/list"){let u=this.server.getPromptDefinitions(),c=u?u.map(l=>l.name):[];r.log.debug("MCP Server list prompts request",{promptCount:c.length,promptNames: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})}}generatePromptDescriptionFromSpec(e){let r=e.raw();return r?.description?r.description:r?.summary?r.summary:`Generate content for operation for ${e.path}`}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(this.context.log.warn(`DEPRECATED: Registering MCP tool with name: "${n.name}", operationId: "${n.operationId}", method: "${n.method}" from "options.openApiTools" will soon be deprecated: migrate to using "options.files" configurations`),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)}}static getOperationsMetadataForFile(e){let{routes:r}=ve.instance.routeData,n=r.filter(s=>s.metadata?.filepath===e);if(n.length===0)throw new Error(`MCP Tool configuration error: No routes found for file path ${e}. Verify that the OpenAPI file exists and is properly loaded in your Gateway configuration with routes.`);let o=new Map;for(let s of n){let a=s?.raw().operationId;if(a){o.set(a,{routeConfig:s});let u=s?.raw()["x-zuplo-mcp-tool"],c=s?.raw()["x-zuplo-mcp-prompt"];(u||c)&&o.set(a,{routeConfig:s,toolExtension:u||void 0,promptExtension:c||void 0})}}return o}registerPromptsFromFileSources(e){for(let r of e){let n=t.getOperationsMetadataForFile(r.path),o=new Set;for(let s of r.operationIds){let a=n.get(s);if(!a)throw new Error(`MCP Prompt configuration error: Could not find operation with ID "${s}" in file ${r.path}. Verify that the operation ID exists in your OpenAPI specification.`);let{routeConfig:u,promptExtension:c}=a,l=c?.name??s;if(o.has(l))throw new Error(`MCP Prompt configuration error: Duplicate prompt name "${l}". Prompt names must be unique across all configured prompts.`);o.add(l);let d=c?.description??this.generatePromptDescriptionFromSpec(u);if(!(c?.enabled??!0)){this.debugMode&&this.context.log.debug("MCP prompt disabled by extension",{promptName:l,operationId:s});continue}this.registerPromptForOperation(l,d,u,s)}}}registerPromptForOperation(e,r,n,o){try{if(n.handler?.export==="mcpServerHandler")return;let a=$o.createPromptValidatorBuilder(n).build();this.server.addPrompt({name:e,description:r,validator:a,generator:i(async u=>{let c=tm(),l=Date.now();try{this.debugMode&&c.log.debug("MCP prompt invoked",{promptName:e,operationId:n.raw()?.operationId,path:n.path,args:u});let d=this.buildToolUrl(n,{body:u}),p=this.buildToolRequest("POST","application/json",{body:u});this.debugMode&&c.log.debug("MCP prompt downstream call",{promptName:e,url:d,method:"POST",bodyPreview:u});let m=Date.now(),f=await c.invokeRoute(d,p),h=Date.now()-m,b=await f.json();if(!f.ok)throw new Error(`Route returned ${f.status}: ${b}`);let y;try{if(y=b.messages||b,!Array.isArray(y))throw new Error("Response must contain a 'messages' array or be an array of messages")}catch(x){throw new Error(`Invalid JSON response or missing messages array: ${x instanceof Error?x.message:String(x)}`)}let S=Date.now()-l;return this.debugMode&&c.log.debug("MCP prompt response complete",{promptName:e,operationId:n.raw()?.operationId,status:f.status,elapsedMs:S,downstreamElapsedMs:h,messageCount:y.length}),y}catch(d){let p=Date.now()-l,m=d instanceof Error?`${d.name}: ${d.message}`:String(d);throw c.log.error("MCP prompt invocation failed",{promptName:e,operationId:n.raw()?.operationId,path:n.path,elapsedMs:p,err:d}),new Error(`MCP tool call failed for tool '${e}': ${m}`)}},"generator")}),this.debugMode&&this.context.log.debug("MCP prompt registered from file source",{promptName:e,operationId:o,path:n.path})}catch(s){throw this.context.log.error("Failed to register MCP prompt",{promptName:e,operationId:o,error:s instanceof Error?s.message:String(s)}),new Error(`Failed to register prompt "${e}" for operation "${o}": ${s instanceof Error?s.message:String(s)}`)}}registerToolsFromFileSources(e){let r=new Set;for(let n of e){let o=t.getOperationsMetadataForFile(n.path);this.debugMode&&this.context.log.debug("Processing file source",{path:n.path,operationIds:n.operationIds,availableOperationIds:Array.from(o.keys())});for(let s of n.operationIds){let a=o.get(s);if(!a)throw new Error(`MCP Tool configuration error: Operation ID "${s}" not found in OpenAPI spec at ${n.path}. Available operation IDs: ${Array.from(o.keys()).join(", ")}`);if(a.toolExtension?.enabled===!1){this.debugMode&&this.context.log.debug("Skipping disabled tool",{operationId:s,path:n.path});continue}let u=a.toolExtension?.name?.trim()??s,c=(a.toolExtension?.description?.trim()||null)??(a.routeConfig.raw().description?.trim()||null)??(a.routeConfig.raw().summary?.trim()||null);if(!c)throw new Error(`MCP Tool configuration error: no tool description found for operationId: "${s}" in file "${n.path}"`);if(r.has(u))throw new Error(`MCP Tool configuration error: Tool name conflict detected. The name "${u}" is already in use. Consider providing a unique 'name' in the x-zuplo-mcp-tool extension for operation "${s}".`);r.add(u);let l=a.toolExtension?.includeOutputSchema??this.includeOutputSchema??!1,d=a.toolExtension?.includeStructuredContent??this.includeStructuredContent??!1;if(a.routeConfig.methods.length!=1)throw new Error(`MCP tool configuration error: multiple methods "${a.routeConfig.methods.join(", ")}" on operation "${s}" not permitted. Only tools with one singular method is permitted.`);this.registerToolsForMethod(a.routeConfig,a.routeConfig.methods[0],u,c,l,d)}}}registerToolsFromFiles(e){let r=new Set(e.map(s=>s.filePath)),n=new Set;for(let s of ve.instance.routeData.routes){let a=s.metadata?.filepath;a&&r.has(a)&&(this.context.log.warn(`DEPRECATED: Registering MCP tool with operationId: "${s.raw()?.operationId}"from file: "${a}" with "options.openApiFilePaths" will soon be removed: migrate to using "options.files" configurations`),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=tm(),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}),p.analyticsContext.addAnalyticsEvent(1,je.MCP_TOOL_USAGE,{toolName:e,toolPath:n.path,toolMethod:o,toolOperationId:n.raw()?.operationId??"unknown"});let b=Date.now(),y=await p.invokeRoute(f,h),S=Date.now()-b,x=await y.text(),$;if(u)try{$=JSON.parse(x)}catch(A){this.debugMode&&p.log.debug("MCP tool structuredContent JSON parse failed",{toolName:e,body:x,parseErr:A})}let O=Date.now()-m;return this.debugMode&&(y.ok?p.log.debug("MCP tool ok response",{toolName:e,operationId:n.raw()?.operationId,status:y.status,elapsedMs:O,downstreamElapsedMs:S}):p.log.debug("MCP tool 'isError' response",{toolName:e,operationId:n.raw()?.operationId,status:y.status,elapsedMs:O,downstreamElapsedMs:S,response:x})),{content:[{type:"text",text:x}],...$&&{structuredContent:$},isError:!y.ok}}catch(f){let h=Date.now()-m,b=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}': ${b}`}],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 Ds(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={...zv()};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=$o.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}=ve.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 M_(t,e){if(w("handler.mcp-server"),e.route.methods.some(s=>s.toUpperCase()!=="POST"))throw new v(`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 Fs.getInstance(n,e);return Uv(r,e,()=>o.handleRequest(t,e))}i(M_,"mcpServerHandler");function Be(t,e){let r={};for(let n in t){let o=t[n];Array.isArray(o)||(o=[o]);for(let s of o)if(s.param){if(n in e){let a=U_(n,e,s);a!==void 0&&Dv(r,s.param,a)}else if(s&&s.required&&s.default!==void 0){let a=typeof s.default=="function"?s.default(e):s.default;Dv(r,s.param,a)}}}return r}i(Be,"validateAndTransformRequest");function U_(t,e,r){let n=e[t];return r.transform&&(n=r.transform(e)),n===void 0&&r.default!==void 0&&(n=typeof r.default=="function"?r.default(e):r.default),typeof n=="number"&&(r.min!==void 0&&n<r.min&&(n=r.min),r.max!==void 0&&n>r.max&&(n=r.max)),n}i(U_,"getValue");function Dv(t,e,r){if(r===void 0)return;let n=e.split("."),o=t;for(let s=0;s<n.length-1;s++){let a=n[s];o[a]||(o[a]={}),o=o[a]}o[n[n.length-1]]=r}i(Dv,"setNestedProperty");async function xr(t){let e=new TextEncoder().encode(t),r=await crypto.subtle.digest({name:"SHA-256"},e);return[...new Uint8Array(r)].map(o=>o.toString(16).padStart(2,"0")).join("")}i(xr,"sha256");var Zv=new Map;async function Pe(t,e,r){let n,o=`${t}-${e}`,s=Zv.get(o);return s!==void 0?n=s:(n=`zuplo-policy-${await xr(JSON.stringify({policyName:t,options:r}))}`,Zv.set(t,n)),n}i(Pe,"getPolicyCacheName");var z_=60,D_={openai:{"gpt-5":{model:"gpt-5",kind:"completions",status:"active",inputCostPerToken:125e-8,outputCostPerToken:1e-5},"gpt-5-nano":{model:"gpt-5-nano",kind:"completions",status:"active",inputCostPerToken:5e-8,outputCostPerToken:4e-7},"gpt-5-mini":{model:"gpt-5-mini",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:2e-6},"gpt-4o":{model:"gpt-4o",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-11-20":{model:"gpt-4o-2024-11-20",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-08-06":{model:"gpt-4o-2024-08-06",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-05-13":{model:"gpt-4o-2024-05-13",kind:"completions",status:"active",inputCostPerToken:5e-6,outputCostPerToken:15e-6},"gpt-4o-mini":{model:"gpt-4o-mini",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gpt-4o-mini-2024-07-18":{model:"gpt-4o-mini-2024-07-18",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gpt-4.1":{model:"gpt-4.1",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gpt-4.1-mini":{model:"gpt-4.1-mini",kind:"completions",status:"active",inputCostPerToken:4e-7,outputCostPerToken:16e-7},"gpt-4.1-nano":{model:"gpt-4.1-nano",kind:"completions",status:"active",inputCostPerToken:1e-7,outputCostPerToken:4e-7},"gpt-4-turbo":{model:"gpt-4-turbo",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-turbo-2024-04-09":{model:"gpt-4-turbo-2024-04-09",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-turbo-preview":{model:"gpt-4-turbo-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-0125-preview":{model:"gpt-4-0125-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-1106-preview":{model:"gpt-4-1106-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-vision-preview":{model:"gpt-4-vision-preview",kind:"completions",status:"deprecated",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4":{model:"gpt-4",kind:"completions",status:"active",inputCostPerToken:3e-5,outputCostPerToken:6e-5},"gpt-4-0613":{model:"gpt-4-0613",kind:"completions",status:"active",inputCostPerToken:3e-5,outputCostPerToken:6e-5},"gpt-4-32k":{model:"gpt-4-32k",kind:"completions",status:"deprecated",inputCostPerToken:6e-5,outputCostPerToken:12e-5},"gpt-4-32k-0613":{model:"gpt-4-32k-0613",kind:"completions",status:"deprecated",inputCostPerToken:6e-5,outputCostPerToken:12e-5},"gpt-3.5-turbo":{model:"gpt-3.5-turbo",kind:"completions",status:"active",inputCostPerToken:15e-7,outputCostPerToken:2e-6},"gpt-3.5-turbo-0125":{model:"gpt-3.5-turbo-0125",kind:"completions",status:"active",inputCostPerToken:5e-7,outputCostPerToken:15e-7},"gpt-3.5-turbo-1106":{model:"gpt-3.5-turbo-1106",kind:"completions",status:"active",inputCostPerToken:1e-6,outputCostPerToken:2e-6},"gpt-3.5-turbo-16k":{model:"gpt-3.5-turbo-16k",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:4e-6},"text-embedding-3-large":{model:"text-embedding-3-large",kind:"embeddings",status:"active",inputCostPerToken:13e-8,outputCostPerToken:0},"text-embedding-3-small":{model:"text-embedding-3-small",kind:"embeddings",status:"active",inputCostPerToken:2e-8,outputCostPerToken:0},"text-embedding-ada-002":{model:"text-embedding-ada-002",kind:"embeddings",status:"active",inputCostPerToken:1e-7,outputCostPerToken:0}},anthropic:{"claude-opus-4-20250514":{model:"claude-opus-4-20250514",kind:"completions",status:"active",inputCostPerToken:15e-6,outputCostPerToken:75e-6},"claude-sonnet-4-20250514":{model:"claude-sonnet-4-20250514",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-7-sonnet-20250219":{model:"claude-3-7-sonnet-20250219",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-sonnet-20241022":{model:"claude-3-5-sonnet-20241022",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-sonnet-20240620":{model:"claude-3-5-sonnet-20240620",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-haiku-20241022":{model:"claude-3-5-haiku-20241022",kind:"completions",status:"active",inputCostPerToken:8e-7,outputCostPerToken:4e-6},"claude-3-opus-20240229":{model:"claude-3-opus-20240229",kind:"completions",status:"active",inputCostPerToken:15e-6,outputCostPerToken:75e-6},"claude-3-haiku-20240307":{model:"claude-3-haiku-20240307",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:125e-8},"claude-2.1":{model:"claude-2.1",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"claude-2.0":{model:"claude-2.0",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"claude-instant-1.2":{model:"claude-instant-1.2",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6}},google:{"gemini-2.0-flash-exp":{model:"gemini-2.0-flash-exp",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gemini-1.5-pro":{model:"gemini-1.5-pro",kind:"completions",status:"active",inputCostPerToken:125e-8,outputCostPerToken:5e-6},"gemini-1.5-pro-latest":{model:"gemini-1.5-pro-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash":{model:"gemini-1.5-flash",kind:"completions",status:"active",inputCostPerToken:75e-9,outputCostPerToken:3e-7},"gemini-1.5-flash-latest":{model:"gemini-1.5-flash-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash-8b":{model:"gemini-1.5-flash-8b",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash-8b-latest":{model:"gemini-1.5-flash-8b-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"embedding-001":{model:"embedding-001",kind:"embeddings",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6}},mistral:{"mistral-large-latest":{model:"mistral-large-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"mistral-large-2411":{model:"mistral-large-2411",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"mistral-large-2407":{model:"mistral-large-2407",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:9e-6},"mistral-medium-latest":{model:"mistral-medium-latest",kind:"completions",status:"active",inputCostPerToken:4e-7,outputCostPerToken:2e-6},"mistral-small-latest":{model:"mistral-small-latest",kind:"completions",status:"active",inputCostPerToken:1e-7,outputCostPerToken:3e-7},"mistral-small-2409":{model:"mistral-small-2409",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"open-mistral-7b":{model:"open-mistral-7b",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:25e-8},"open-mixtral-8x7b":{model:"open-mixtral-8x7b",kind:"completions",status:"active",inputCostPerToken:7e-7,outputCostPerToken:7e-7},"open-mixtral-8x22b":{model:"open-mixtral-8x22b",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"open-mistral-nemo":{model:"open-mistral-nemo",kind:"completions",status:"active",inputCostPerToken:3e-7,outputCostPerToken:3e-7},"codestral-latest":{model:"codestral-latest",kind:"completions",status:"active",inputCostPerToken:1e-6,outputCostPerToken:3e-6},"ministral-3b-latest":{model:"ministral-3b-latest",kind:"completions",status:"active",inputCostPerToken:4e-8,outputCostPerToken:4e-8},"ministral-8b-latest":{model:"ministral-8b-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"mistral-embed":{model:"mistral-embed",kind:"embeddings",status:"active",inputCostPerToken:1e-7,outputCostPerToken:0}}};async function pt(t){let e=Y.getLogger(t),r=await Pe("supported-models","models",{}),n=new be(r,t),o=await n.get("models");if(o)return e.info("Using cached supported models data",{providersCount:Object.keys(o.modelsByProvider).length,providers:Object.keys(o.modelsByProvider)}),o.modelsByProvider;let s=new Headers({"content-type":"application/json"});ze(s,t.requestId);let a=`${P.instance.zuploEdgeApiUrl}/v1/buckets/${Se.ZUPLO_SERVICE_BUCKET_ID}/providers`;e.info("Fetching supported models from Gateway service",{url:a,bucketId:Se.ZUPLO_SERVICE_BUCKET_ID,requestId:t.requestId,hasAuthJWT:!!P.instance.authApiJWT});let u=await _e({retryDelayMs:5,retries:2},a,{method:"GET",headers:s}),c;if(u.status!==200){try{let d=await u.text(),p=JSON.parse(d);e.error("Gateway service unavailable, using fallback models",p)}catch{e.error("Gateway service unavailable, using fallback models")}console.log("AI Gateway: Using fallback model data due to service unavailability"),c=D_}else{let d=await u.json();e.info("Gateway service response received",{providersCount:Object.keys(d.data).length,providers:Object.keys(d.data),totalModels:Object.values(d.data).reduce((p,m)=>p+m.length,0)}),c={};for(let[p,m]of Object.entries(d.data)){let f=p.toLowerCase();c[f]={},e.debug(`Processing provider: ${p} with ${m.length} models`);for(let h of m)c[f][h.model]=h}e.info("Gateway service models processed successfully",{processedProviders:Object.keys(c)})}let l={modelsByProvider:c};return n.put("models",l,z_),c}i(pt,"getSupportedModels");function _t(t,e,r,n,o,s){let a=e.toLowerCase(),u=o[a];if(!u)return s.warn("Provider not found in supported models list",{provider:e,model:t}),0;let c=u[t];if(!c)return s.warn("Model not found in supported models list for provider",{provider:e,model:t}),0;let l=r*c.inputCostPerToken,d=n*c.outputCostPerToken;return l+d}i(_t,"calculateModelCost");function jv(t,e,r,n){let o=e.toLowerCase(),s=n[o];if(!s)return!1;let a=s[t];return a?a.kind===r&&a.status==="active":!1}i(jv,"isModelSupported");function qv(t,e,r){let n=t.toLowerCase(),o=r[n];return o?Object.values(o).filter(s=>s.kind===e&&s.status==="active").map(s=>s.model):[]}i(qv,"getModelsByProviderAndKind");var nm=class{static{i(this,"GatewayServiceClient")}baseUrl;constructor(e){this.baseUrl=e??P.instance.zuploEdgeApiUrl}async fetchCurrentMeters(e,r){let n=`${this.baseUrl}/v1/hierarchical-quota/${e}`,o=new Headers({"Content-Type":"application/json"});ze(o,r.requestId);let s=await fetch(n,{method:"GET",headers:o});if(!s.ok)throw new ue(`Failed to fetch meters: ${s.status} ${s.statusText}`);return await s.json()}async checkHierarchicalQuotaLimits(e,r){let n=`${this.baseUrl}/v1/hierarchical-quota/${e}/limits`,o=new Headers({"Content-Type":"application/json"});ze(o,r.requestId);let s=await fetch(n,{method:"GET",headers:o});if(!s.ok)throw new ue(`Failed to check quota limits: ${s.status} ${s.statusText}`);return await s.json()}async incrementMeters(e,r,n){let o=`${this.baseUrl}/v1/hierarchical-quota/${e}`,s=new Headers({"Content-Type":"application/json"});ze(s,n.requestId);let a=await fetch(o,{method:"POST",headers:s,body:JSON.stringify({increments:r})});if(!a.ok)throw new ue(`Failed to increment meters: ${a.status} ${a.statusText}`)}},rm=null,Bs={get instance(){return rm===null&&(rm=new nm),rm}};var Hv=Ze("zuplo:policies:AIGatewayMeteringInboundPolicy"),Fv=Symbol("ai-gateway-meter-increments"),it=class t extends xe{static{i(this,"AIGatewayMeteringInboundPolicy")}static setIncrements(e,r){de.set(e,Fv,r)}static getIncrements(e){return de.get(e,Fv)??{}}constructor(e,r){super(e,r),w("policy.inbound.ai-gateway-metering-inbound")}async handler(e,r){let n=Date.now(),o=Y.getLogger(r),s=i((a,u)=>{if(this.options.throwOnFailure)throw new ue(a,{cause:u});o.error(u,a)},"throwOrLog");try{let a=e.user?.configuration;if(!a)throw new v(`AIGatewayMeteringInboundPolicy '${this.policyName}' - No configuration found in request.user. Ensure ai-gateway-inbound policy runs first.`);let u=a;if(!u.id)throw new v(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Configuration ID not found.`);let c=await this.fetchCurrentMeters(u.id,r,o),l=this.checkWarnings(u,c);for(let p of l)r.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_WARNING_COUNT,{type:`quota-${p.type}-${p.period}`,configId:u.id});let d=await this.checkHierarchicalQuotaLimits(u.id,r,o);return d.violation?(r.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_BLOCKED_COUNT,{type:`quota-${d.violation.meter}-${d.violation.period}`,configId:u.id}),this.createHierarchicalQuotaExceededResponse(e,r,d.violation)):(r.addResponseSendingFinalHook(async()=>{try{let p=t.getIncrements(r);Hv(`AIGatewayMeteringInboundPolicy '${this.policyName}' - increments ${JSON.stringify(p)}`),Object.keys(p).length>0&&await t.incrementMetersInternal(u.id,p,r,o)}catch(p){s(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to increment meters`,p)}}),e)}catch(a){if(a instanceof v)throw a;return s(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Error`,a),e}finally{let a=Date.now()-n;Hv(`AIGatewayMeteringInboundPolicy '${this.policyName}' - latency ${a}ms`)}}async fetchCurrentMeters(e,r,n){try{return await Bs.instance.fetchCurrentMeters(e,r)}catch(o){throw n.error(o,`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to fetch meters`),o}}async checkHierarchicalQuotaLimits(e,r,n){try{return await Bs.instance.checkHierarchicalQuotaLimits(e,r)}catch(o){throw n.error(o,`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to check hierarchical quota limits`),o}}static async incrementMeters(e,r,n){let o=Y.getLogger(n);return t.incrementMetersInternal(e,r,n,o)}static async incrementMetersInternal(e,r,n,o){try{await Bs.instance.incrementMeters(e,r,n)}catch(s){throw o.error(s,"AIGatewayMeteringInboundPolicy - Failed to increment meters"),s}}checkWarnings(e,r){let n=[];for(let[o,s]of Object.entries(e.limits)){if(!s)continue;let a=r.meters[o];if(!a)continue;let u=this.checkQuotaWarning(s.daily,a.daily,o,"daily");u&&n.push(u);let c=this.checkQuotaWarning(s.monthly,a.monthly,o,"monthly");c&&n.push(c)}return n}checkQuotaWarning(e,r,n,o){if(!e?.warning?.enabled||!e?.warning?.threshold||!e?.limit)return null;let s=e.warning.threshold/100*e.limit;return r>=s?{type:n,period:o}:null}createHierarchicalQuotaExceededResponse(e,r,n){let o=`${n.period} ${n.meter} quota exceeded in configuration '${n.configLabel}'. Limit: ${n.limit}, Current: ${n.currentUsage}`;return M.tooManyRequests(e,r,{detail:o})}};async function or(t,e){if(!P.instance.remoteLogURL){Y.getLogger(t).debug("Remote log URL is not configured, skipping analytics");return}t.analyticsContext.addAnalyticsEvent(parseFloat(e.cost.toFixed(10)),je.AI_GATEWAY_COST_SUM,{model:e.model,provider:e.provider,configId:e.configId}),t.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_REQUEST_COUNT,{model:e.model,provider:e.provider,configId:e.configId}),t.analyticsContext.addAnalyticsEvent(e.promptTokens,je.AI_GATEWAY_TOKEN_SUM,{model:e.model,provider:e.provider,configId:e.configId,tokenType:"prompt"}),t.analyticsContext.addAnalyticsEvent(e.completionTokens,je.AI_GATEWAY_TOKEN_SUM,{model:e.model,provider:e.provider,configId:e.configId,tokenType:"completion"});let r=t.analyticsContext.flushAnalyticsEvents();new Nr(t,{endpoint:`${P.instance.remoteLogURL}/v2/analytics`}).pushEvents(r)}i(or,"sendStreamAnalytics");var Bv={model:{param:"model",required:!0,default:"gpt-4o-mini"},messages:{param:"messages",required:!0},temperature:{param:"temperature",default:1,min:0,max:2},top_p:{param:"top_p",default:1,min:0,max:1},n:{param:"n",default:1,min:1,max:128},stream:{param:"stream",default:!1},stop:{param:"stop"},max_tokens:{param:"max_tokens",min:0},presence_penalty:{param:"presence_penalty",default:0,min:-2,max:2},frequency_penalty:{param:"frequency_penalty",default:0,min:-2,max:2},logit_bias:{param:"logit_bias"},user:{param:"user"},seed:{param:"seed"},functions:{param:"functions"},function_call:{param:"function_call"},tools:{param:"tools"},tool_choice:{param:"tool_choice"},parallel_tool_calls:{param:"parallel_tool_calls"},response_format:{param:"response_format"},logprobs:{param:"logprobs",default:!1},top_logprobs:{param:"top_logprobs",min:0,max:20},max_completion_tokens:{param:"max_completion_tokens"},service_tier:{param:"service_tier"},stream_options:{param:"stream_options"}},Z_={model:{param:"model",required:!0,default:"text-embedding-3-small"},input:{param:"input",required:!0},user:{param:"user"},dimensions:{param:"dimensions"},encoding_format:{param:"encoding_format",default:"float"}},Gs=class{static{i(this,"OpenAIProvider")}name="openai";async chatComplete(e,r){let n=Be(Bv,e),o=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"},body:JSON.stringify(n)});if(!o.ok){let a=await o.json();throw new Error(`OpenAI API error: ${a.error?.message||"Unknown error"}`)}return{...await o.json(),provider:"openai"}}async chatCompleteStream(e,r,n){let o=Be(Bv,{...e,stream:!0,stream_options:{include_usage:!0}}),s=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"},body:JSON.stringify(o)});if(!s.ok){let m=await s.json();throw new Error(`OpenAI API error: ${m.error?.message||"Unknown error"}`)}if(!s.body)throw new Error("No response body received from OpenAI API");let a=n.custom.userContext,u="",c=new TextDecoder,l=new TransformStream({transform(m,f){f.enqueue(m);let h=c.decode(m);u+=h,!u.includes('"usage"')&&u.length>4096&&(u=u.slice(-32));let b;for(;(b=u.indexOf(`
|
|
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 Eo=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"}},l_=/[$_\p{ID_Start}]/u,d_=/[$_\u200C\u200D\p{ID_Continue}]/u,Xp=".*";function p_(t,e){return(e?/^[\x00-\xFF]*$/:/^[\x00-\x7F]*$/).test(t)}i(p_,"Re");function kv(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&&l_.test(c)||u!==n+1&&d_.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(!p_(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(kv,"v");function Tv(t,e={}){let r=kv(t);e.delimiter??="/#?",e.prefixes??="./";let n=`[^${dt(e.delimiter)}]+?`,o=[],s=0,a=0,u="",c=new Set,l=i($=>{if(a<r.length&&r[a].type===$)return r[a++].value},"a"),d=i(()=>l("OTHER_MODIFIER")??l("ASTERISK"),"f"),p=i($=>{let O=l($);if(O!==void 0)return O;let{type:A,index:T}=r[a];throw new TypeError(`Unexpected ${A} at ${T}, expected ${$}`)},"d"),m=i(()=>{let $="",O;for(;O=l("CHAR")??l("ESCAPED_CHAR");)$+=O;return $},"T"),f=i($=>$,"Se"),h=e.encodePart||f,b="",y=i($=>{b+=$},"U"),S=i(()=>{b.length&&(o.push(new Eo(3,"","",h(b),"",3)),b="")},"$"),x=i(($,O,A,T,U)=>{let D=3;switch(U){case"?":D=1;break;case"*":D=0;break;case"+":D=2;break}if(!O&&!A&&D===3){y($);return}if(S(),!O&&!A){if(!$)return;o.push(new Eo(3,"","",h($),"",D));return}let Z;A?A==="*"?Z=Xp:Z=A:Z=n;let C=2;Z===n?(C=1,Z=""):Z===Xp&&(C=0,Z="");let _;if(O?_=O:A&&(_=s++),c.has(_))throw new TypeError(`Duplicate name '${_}'.`);c.add(_),o.push(new Eo(C,_,h($),Z,h(T),D))},"V");for(;a<r.length;){let $=l("CHAR"),O=l("NAME"),A=l("REGEX");if(!O&&!A&&(A=l("ASTERISK")),O||A){let U=$??"";e.prefixes.indexOf(U)===-1&&(y(U),U=""),S();let D=d();x(U,O,A,"",D);continue}let T=$??l("ESCAPED_CHAR");if(T){y(T);continue}if(l("OPEN")){let U=m(),D=l("NAME"),Z=l("REGEX");!D&&!Z&&(Z=l("ASTERISK"));let C=m();p("CLOSE");let _=d();x(U,D,Z,C,_);continue}S(),p("END")}return o}i(Tv,"D");function dt(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(dt,"S");function Iv(t){return t&&t.ignoreCase?"ui":"u"}i(Iv,"X");function m_(t,e,r){return _v(Tv(t,r),e,r)}i(m_,"Z");function Wr(t){switch(t){case 0:return"*";case 1:return"?";case 2:return"+";case 3:return""}}i(Wr,"k");function _v(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+=dt(u.value):n+=`(?:${dt(u.value)})${Wr(u.modifier)}`;continue}e&&e.push(u.name);let c=`[^${dt(r.delimiter)}]+?`,l=u.value;if(u.type===1?l=c:u.type===0&&(l=Xp),!u.prefix.length&&!u.suffix.length){u.modifier===3||u.modifier===1?n+=`(${l})${Wr(u.modifier)}`:n+=`((?:${l})${Wr(u.modifier)})`;continue}if(u.modifier===3||u.modifier===1){n+=`(?:${dt(u.prefix)}(${l})${dt(u.suffix)})`,n+=Wr(u.modifier);continue}n+=`(?:${dt(u.prefix)}`,n+=`((?:${l})(?:`,n+=dt(u.suffix),n+=dt(u.prefix),n+=`(?:${l}))*)${dt(u.suffix)})`,u.modifier===0&&(n+="?")}let o=`[${dt(r.endsWith)}]|$`,s=`[${dt(r.delimiter)}]`;if(r.end)return r.strict||(n+=`${s}?`),r.endsWith.length?n+=`(?=${o})`:n+="$",new RegExp(n,Iv(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,Iv(r))}i(_v,"F");var nr={delimiter:"",prefixes:"",sensitive:!0,strict:!0},f_={delimiter:".",prefixes:"",sensitive:!0,strict:!0},g_={delimiter:"/",prefixes:"/",sensitive:!0,strict:!0};function h_(t,e){return t.length?t[0]==="/"?!0:!e||t.length<2?!1:(t[0]=="\\"||t[0]=="{")&&t[1]=="/":!1}i(h_,"J");function Ev(t,e){return t.startsWith(e)?t.substring(e.length,t.length):t}i(Ev,"Q");function y_(t,e){return t.endsWith(e)?t.substr(0,t.length-e.length):t}i(y_,"Ee");function Cv(t){return!t||t.length<2?!1:t[0]==="["||(t[0]==="\\"||t[0]==="{")&&t[1]==="["}i(Cv,"W");var $v=["ftp","file","http","https","ws","wss"];function Ov(t){if(!t)return!0;for(let e of $v)if(t.test(e))return!0;return!1}i(Ov,"N");function b_(t,e){if(t=Ev(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(b_,"te");function v_(t,e){if(t=Ev(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(v_,"re");function w_(t,e){return e||t===""?t:Cv(t)?Lv(t):Nv(t)}i(w_,"ne");function x_(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.password=t,r.password}i(x_,"se");function P_(t,e){if(e||t==="")return t;let r=new URL("https://example.com");return r.username=t,r.username}i(P_,"ie");function R_(t,e,r){if(r||t==="")return t;if(e&&!$v.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(R_,"ae");function I_(t,e,r){return Av(e)===t&&(t=""),r||t===""?t:Mv(t)}i(I_,"oe");function S_(t,e){return t=y_(t,":"),e||t===""?t:Yp(t)}i(S_,"ce");function Av(t){switch(t){case"ws":case"http":return"80";case"wws":case"https":return"443";case"ftp":return"21";default:return""}}i(Av,"_");function Yp(t){if(t==="")return t;if(/^[-+.A-Za-z0-9]*$/.test(t))return t.toLowerCase();throw new TypeError(`Invalid protocol '${t}'.`)}i(Yp,"y");function k_(t){if(t==="")return t;let e=new URL("https://example.com");return e.username=t,e.username}i(k_,"le");function T_(t){if(t==="")return t;let e=new URL("https://example.com");return e.password=t,e.password}i(T_,"fe");function Nv(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(Nv,"z");function Lv(t){if(t==="")return t;if(/[^0-9a-fA-F[\]:]/g.test(t))throw new TypeError(`Invalid IPv6 hostname '${t}'`);return t.toLowerCase()}i(Lv,"j");function Mv(t){if(t===""||/^[0-9]*$/.test(t)&&parseInt(t)<=65535)return t;throw new TypeError(`Invalid port '${t}'.`)}i(Mv,"K");function __(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(__,"he");function E_(t){return t===""?t:new URL(`data:${t}`).pathname}i(E_,"ue");function C_(t){if(t==="")return t;let e=new URL("https://example.com");return e.search=t,e.search.substring(1,e.search.length)}i(C_,"de");function $_(t){if(t==="")return t;let e=new URL("https://example.com");return e.hash=t,e.hash.substring(1,e.hash.length)}i($_,"pe");var O_=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=kv(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.#k())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.#E();let t=7,e=1;this.#P()?(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.#R()?this.#a(4,1):this.#y()&&this.#a(5,1);break;case 4:this.#y()&&this.#a(5,1);break;case 5:this.#T()?this.#c+=1:this.#_()&&(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,":")}#P(){return this.#d(this.#r+1,"/")&&this.#d(this.#r+2,"/")}#y(){return this.#d(this.#r,"@")}#R(){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"}#k(){return this.#t[this.#r].type=="CLOSE"}#T(){return this.#d(this.#r,"[")}#_(){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)}#E(){let t={};Object.assign(t,nr),t.encodePart=Yp;let e=m_(this.#p(),void 0,t);this.#l=Ov(e)}},Qp=["protocol","username","password","hostname","port","pathname","search","hash"],rr="*";function Sv(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(Sv,"ge");function jt(t,e){return e?_o(t):t}i(jt,"b");function To(t,e,r){let n;if(typeof e.baseURL=="string")try{n=new URL(e.baseURL),e.protocol===void 0&&(t.protocol=jt(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=jt(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=jt(n.password,r)),e.protocol===void 0&&e.hostname===void 0&&(t.hostname=jt(n.hostname,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&(t.port=jt(n.port,r)),e.protocol===void 0&&e.hostname===void 0&&e.port===void 0&&e.pathname===void 0&&(t.pathname=jt(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=jt(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=jt(n.hash.substring(1,n.hash.length),r))}catch{throw new TypeError(`invalid baseURL '${e.baseURL}'.`)}if(typeof e.protocol=="string"&&(t.protocol=S_(e.protocol,r)),typeof e.username=="string"&&(t.username=P_(e.username,r)),typeof e.password=="string"&&(t.password=x_(e.password,r)),typeof e.hostname=="string"&&(t.hostname=w_(e.hostname,r)),typeof e.port=="string"&&(t.port=I_(e.port,t.protocol,r)),typeof e.pathname=="string"){if(t.pathname=e.pathname,n&&!h_(t.pathname,r)){let o=n.pathname.lastIndexOf("/");o>=0&&(t.pathname=jt(n.pathname.substring(0,o+1),r)+t.pathname)}t.pathname=R_(t.pathname,t.protocol,r)}return typeof e.search=="string"&&(t.search=v_(e.search,r)),typeof e.hash=="string"&&(t.hash=b_(e.hash,r)),t}i(To,"w");function _o(t){return t.replace(/([+*?:{}()\\])/g,"\\$1")}i(_o,"C");function A_(t){return t.replace(/([.+*?^${}()[\]|/\\])/g,"\\$1")}i(A_,"Oe");function N_(t,e){e.delimiter??="/#?",e.prefixes??="./",e.sensitive??=!1,e.strict??=!1,e.end??=!0,e.start??=!0,e.endsWith="";let r=".*",n=`[^${A_(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+=_o(u.value);continue}s+=`{${_o(u.value)}}${Wr(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+=_o(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+=_o(u.suffix),l&&(s+="}"),u.modifier!==3&&(s+=Wr(u.modifier))}return s}i(N_,"ke");var Us=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 O_(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:rr,protocol:rr,username:rr,password:rr,hostname:rr,port:rr,search:rr,hash:rr};this.#e=To(s,t,!0),Av(this.#e.protocol)===this.#e.port&&(this.#e.port="");let a;for(a of Qp){if(!(a in this.#e))continue;let u={},c=this.#e[a];switch(this.#n[a]=[],a){case"protocol":Object.assign(u,nr),u.encodePart=Yp;break;case"username":Object.assign(u,nr),u.encodePart=k_;break;case"password":Object.assign(u,nr),u.encodePart=T_;break;case"hostname":Object.assign(u,f_),Cv(c)?u.encodePart=Lv:u.encodePart=Nv;break;case"port":Object.assign(u,nr),u.encodePart=Mv;break;case"pathname":Ov(this.#t.protocol)?(Object.assign(u,g_,o),u.encodePart=__):(Object.assign(u,nr,o),u.encodePart=E_);break;case"search":Object.assign(u,nr,o),u.encodePart=C_;break;case"hash":Object.assign(u,nr,o),u.encodePart=$_;break}try{this.#o[a]=Tv(c,u),this.#t[a]=_v(this.#o[a],this.#n[a],u),this.#r[a]=N_(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=To(r,t,!1):r=To(r,Sv(t,e),!1)}catch{return!1}let n;for(n of Qp)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=To(r,t,!1):r=To(r,Sv(t,e),!1)}catch{return null}let n={};e?n.inputs=[t,e]:n.inputs=[t];let o;for(o of Qp){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 Eo(3,"","","","",3),s=new Eo(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 zs=class{static{i(this,"UrlPatternBuilder")}pattern;pathParams={};searchParams=new URLSearchParams;expectedPathParams=new Set;seenPathParams=new Set;constructor(e){this.pattern=new Us({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 v(`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 v(`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").replace(/\\:/g,":")}};var Ds=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 zs(n);for(let a of o)s.addParameter(a,e,r);return s.toString()}};var Kr=class{static{i(this,"CustomValidator")}jsonSchema;parseFn;constructor(e,r){this.jsonSchema=e,this.parseFn=r}parse(e){return this.parseFn(e)}};De();De();De();var Zs=class{static{i(this,"ZodFormatSchemaRegistry")}static formatter=new Map([["email",()=>g.email()],["uri",()=>g.url()],["url",()=>g.url()],["date",()=>g.iso.date()],["date-time",()=>g.iso.datetime()],["time",()=>g.iso.time()],["ipv4",()=>g.ipv4()],["ipv6",()=>g.ipv6()],["uuid",()=>g.guid()],["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)}},Qr=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?Zs.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){Zs.register(e,r)}};var js=class{constructor(e){this.schema=e}static{i(this,"JSONSchemaBuilder")}build(){return Qr.run(this.schema)}},qs=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?Qr.run(r):null}},Hs=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=Qr.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 Co=class t{static{i(this,"UniversalValidatorBuilder")}root=null;components={};static withRoot(e){let r=new t;return r.root=e,r}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(){return this.root?this.buildFromSchema(this.root):Object.keys(this.components).length>0?this.buildFromComponents():this.buildEmptyValidator()}buildFromSchema(e){let r=g.toJSONSchema(e);return new Kr(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:o.data,errorData:null}:{success:!1,data:null,errorMessage:g.prettifyError(o.error),errorData:g.treeifyError(o.error)}})}buildFromComponents(){let e=g.object(this.components),r=g.toJSONSchema(e);return new Kr(r,n=>{let o=e.safeParse(n);return o.success?{success:!0,data:o.data,errorData:null}:{success:!1,data:null,errorMessage:g.prettifyError(o.error),errorData:g.treeifyError(o.error)}})}buildEmptyValidator(){let e={type:"object",properties:{},required:[],additionalProperties:!1};return new Kr(e,r=>({success:!0,data:r,errorData:null}))}},$o=class{static{i(this,"SchemaBuilderFactory")}static createJsonSchemaBuilder(e){return new js(e)}static createRequestBodyBuilder(e,r){return new qs(e,r)}static createParameterBuilder(e,r){let n=r?e.filter(o=>o.in===r):e;return new Hs(n)}static createValidatorBuilder(e,r){let n=new Co,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}static createPromptValidatorBuilder(e){let r=new Co,o=e.raw()?.requestBody;if(!o?.content||!o.content["application/json"])return r;let a=this.createRequestBodyBuilder(e,"application/json");return Co.withRoot(a.build())}};import{AsyncLocalStorage as L_}from"node:async_hooks";var em=new L_;function Uv(t,e,r){return em.run({headers:t,zuploContext:e},r)}i(Uv,"runWithInvokeContext");function zv(){return em.getStore()?.headers??{}}i(zv,"getInvokeHeaders");function tm(){let t=em.getStore();if(!t)throw new Error("No Zuplo context available in current execution context");return t.zuploContext}i(tm,"getInvokeContext");var Fs=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??[]),s.registerToolsFromFileSources(s.opts.files??[]),s.registerPromptsFromFileSources(s.opts.prompts??[]),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=s.server.getPromptDefinitions(),d=l?l.length:0,p=Date.now()-a;r.log.debug("MCP Server cold start",{routeKey:n,toolCount:c,promptCount:d,totalElapsedMs:p,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 ko,this.context=r,this.opts=e,this.server=new Ls({name:e.name??"Zuplo MCP Server",version:e.version??"0.0.0",logger:n}),this.transport=new Ms({logger:n}),this.includeOutputSchema=e.includeOutputSchema??!1,this.includeStructuredContent=e.includeStructuredContent??!1}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})}if(this.debugMode&&o.method==="prompts/list"){let u=this.server.getPromptDefinitions(),c=u?u.map(l=>l.name):[];r.log.debug("MCP Server list prompts request",{promptCount:c.length,promptNames: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})}}generatePromptDescriptionFromSpec(e){let r=e.raw();return r?.description?r.description:r?.summary?r.summary:`Generate content for operation for ${e.path}`}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(this.context.log.warn(`DEPRECATED: Registering MCP tool with name: "${n.name}", operationId: "${n.operationId}", method: "${n.method}" from "options.openApiTools" will soon be deprecated: migrate to using "options.files" configurations`),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)}}static getOperationsMetadataForFile(e){let{routes:r}=ve.instance.routeData,n=r.filter(s=>s.metadata?.filepath===e);if(n.length===0)throw new Error(`MCP Tool configuration error: No routes found for file path ${e}. Verify that the OpenAPI file exists and is properly loaded in your Gateway configuration with routes.`);let o=new Map;for(let s of n){let a=s?.raw().operationId;if(a){o.set(a,{routeConfig:s});let u=s?.raw()["x-zuplo-mcp-tool"],c=s?.raw()["x-zuplo-mcp-prompt"];(u||c)&&o.set(a,{routeConfig:s,toolExtension:u||void 0,promptExtension:c||void 0})}}return o}registerPromptsFromFileSources(e){for(let r of e){let n=t.getOperationsMetadataForFile(r.path),o=new Set;for(let s of r.operationIds){let a=n.get(s);if(!a)throw new Error(`MCP Prompt configuration error: Could not find operation with ID "${s}" in file ${r.path}. Verify that the operation ID exists in your OpenAPI specification.`);let{routeConfig:u,promptExtension:c}=a,l=c?.name??s;if(o.has(l))throw new Error(`MCP Prompt configuration error: Duplicate prompt name "${l}". Prompt names must be unique across all configured prompts.`);o.add(l);let d=c?.description??this.generatePromptDescriptionFromSpec(u);if(!(c?.enabled??!0)){this.debugMode&&this.context.log.debug("MCP prompt disabled by extension",{promptName:l,operationId:s});continue}this.registerPromptForOperation(l,d,u,s)}}}registerPromptForOperation(e,r,n,o){try{if(n.handler?.export==="mcpServerHandler")return;let a=$o.createPromptValidatorBuilder(n).build();this.server.addPrompt({name:e,description:r,validator:a,generator:i(async u=>{let c=tm(),l=Date.now();try{this.debugMode&&c.log.debug("MCP prompt invoked",{promptName:e,operationId:n.raw()?.operationId,path:n.path,args:u});let d=this.buildToolUrl(n,{body:u}),p=this.buildToolRequest("POST","application/json",{body:u});this.debugMode&&c.log.debug("MCP prompt downstream call",{promptName:e,url:d,method:"POST",bodyPreview:u});let m=Date.now(),f=await c.invokeRoute(d,p),h=Date.now()-m,b=await f.json();if(!f.ok)throw new Error(`Route returned ${f.status}: ${b}`);let y;try{if(y=b.messages||b,!Array.isArray(y))throw new Error("Response must contain a 'messages' array or be an array of messages")}catch(x){throw new Error(`Invalid JSON response or missing messages array: ${x instanceof Error?x.message:String(x)}`)}let S=Date.now()-l;return this.debugMode&&c.log.debug("MCP prompt response complete",{promptName:e,operationId:n.raw()?.operationId,status:f.status,elapsedMs:S,downstreamElapsedMs:h,messageCount:y.length}),y}catch(d){let p=Date.now()-l,m=d instanceof Error?`${d.name}: ${d.message}`:String(d);throw c.log.error("MCP prompt invocation failed",{promptName:e,operationId:n.raw()?.operationId,path:n.path,elapsedMs:p,err:d}),new Error(`MCP tool call failed for tool '${e}': ${m}`)}},"generator")}),this.debugMode&&this.context.log.debug("MCP prompt registered from file source",{promptName:e,operationId:o,path:n.path})}catch(s){throw this.context.log.error("Failed to register MCP prompt",{promptName:e,operationId:o,error:s instanceof Error?s.message:String(s)}),new Error(`Failed to register prompt "${e}" for operation "${o}": ${s instanceof Error?s.message:String(s)}`)}}registerToolsFromFileSources(e){let r=new Set;for(let n of e){let o=t.getOperationsMetadataForFile(n.path);this.debugMode&&this.context.log.debug("Processing file source",{path:n.path,operationIds:n.operationIds,availableOperationIds:Array.from(o.keys())});for(let s of n.operationIds){let a=o.get(s);if(!a)throw new Error(`MCP Tool configuration error: Operation ID "${s}" not found in OpenAPI spec at ${n.path}. Available operation IDs: ${Array.from(o.keys()).join(", ")}`);if(a.toolExtension?.enabled===!1){this.debugMode&&this.context.log.debug("Skipping disabled tool",{operationId:s,path:n.path});continue}let u=a.toolExtension?.name?.trim()??s,c=(a.toolExtension?.description?.trim()||null)??(a.routeConfig.raw().description?.trim()||null)??(a.routeConfig.raw().summary?.trim()||null);if(!c)throw new Error(`MCP Tool configuration error: no tool description found for operationId: "${s}" in file "${n.path}"`);if(r.has(u))throw new Error(`MCP Tool configuration error: Tool name conflict detected. The name "${u}" is already in use. Consider providing a unique 'name' in the x-zuplo-mcp-tool extension for operation "${s}".`);r.add(u);let l=a.toolExtension?.includeOutputSchema??this.includeOutputSchema??!1,d=a.toolExtension?.includeStructuredContent??this.includeStructuredContent??!1;if(a.routeConfig.methods.length!=1)throw new Error(`MCP tool configuration error: multiple methods "${a.routeConfig.methods.join(", ")}" on operation "${s}" not permitted. Only tools with one singular method is permitted.`);this.registerToolsForMethod(a.routeConfig,a.routeConfig.methods[0],u,c,l,d)}}}registerToolsFromFiles(e){let r=new Set(e.map(s=>s.filePath)),n=new Set;for(let s of ve.instance.routeData.routes){let a=s.metadata?.filepath;a&&r.has(a)&&(this.context.log.warn(`DEPRECATED: Registering MCP tool with operationId: "${s.raw()?.operationId}"from file: "${a}" with "options.openApiFilePaths" will soon be removed: migrate to using "options.files" configurations`),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=tm(),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}),p.analyticsContext.addAnalyticsEvent(1,je.MCP_TOOL_USAGE,{toolName:e,toolPath:n.path,toolMethod:o,toolOperationId:n.raw()?.operationId??"unknown"});let b=Date.now(),y=await p.invokeRoute(f,h),S=Date.now()-b,x=await y.text(),$;if(u)try{$=JSON.parse(x)}catch(A){this.debugMode&&p.log.debug("MCP tool structuredContent JSON parse failed",{toolName:e,body:x,parseErr:A})}let O=Date.now()-m;return this.debugMode&&(y.ok?p.log.debug("MCP tool ok response",{toolName:e,operationId:n.raw()?.operationId,status:y.status,elapsedMs:O,downstreamElapsedMs:S}):p.log.debug("MCP tool 'isError' response",{toolName:e,operationId:n.raw()?.operationId,status:y.status,elapsedMs:O,downstreamElapsedMs:S,response:x})),{content:[{type:"text",text:x}],...$&&{structuredContent:$},isError:!y.ok}}catch(f){let h=Date.now()-m,b=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}': ${b}`}],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 Ds(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={...zv()};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=$o.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}=ve.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 M_(t,e){if(w("handler.mcp-server"),e.route.methods.some(s=>s.toUpperCase()!=="POST"))throw new v(`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 Fs.getInstance(n,e);return Uv(r,e,()=>o.handleRequest(t,e))}i(M_,"mcpServerHandler");function Be(t,e){let r={};for(let n in t){let o=t[n];Array.isArray(o)||(o=[o]);for(let s of o)if(s.param){if(n in e){let a=U_(n,e,s);a!==void 0&&Dv(r,s.param,a)}else if(s&&s.required&&s.default!==void 0){let a=typeof s.default=="function"?s.default(e):s.default;Dv(r,s.param,a)}}}return r}i(Be,"validateAndTransformRequest");function U_(t,e,r){let n=e[t];return r.transform&&(n=r.transform(e)),n===void 0&&r.default!==void 0&&(n=typeof r.default=="function"?r.default(e):r.default),typeof n=="number"&&(r.min!==void 0&&n<r.min&&(n=r.min),r.max!==void 0&&n>r.max&&(n=r.max)),n}i(U_,"getValue");function Dv(t,e,r){if(r===void 0)return;let n=e.split("."),o=t;for(let s=0;s<n.length-1;s++){let a=n[s];o[a]||(o[a]={}),o=o[a]}o[n[n.length-1]]=r}i(Dv,"setNestedProperty");async function xr(t){let e=new TextEncoder().encode(t),r=await crypto.subtle.digest({name:"SHA-256"},e);return[...new Uint8Array(r)].map(o=>o.toString(16).padStart(2,"0")).join("")}i(xr,"sha256");var Zv=new Map;async function Pe(t,e,r){let n,o=`${t}-${e}`,s=Zv.get(o);return s!==void 0?n=s:(n=`zuplo-policy-${await xr(JSON.stringify({policyName:t,options:r}))}`,Zv.set(t,n)),n}i(Pe,"getPolicyCacheName");var z_=60,D_={openai:{"gpt-5":{model:"gpt-5",kind:"completions",status:"active",inputCostPerToken:125e-8,outputCostPerToken:1e-5},"gpt-5-nano":{model:"gpt-5-nano",kind:"completions",status:"active",inputCostPerToken:5e-8,outputCostPerToken:4e-7},"gpt-5-mini":{model:"gpt-5-mini",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:2e-6},"gpt-4o":{model:"gpt-4o",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-11-20":{model:"gpt-4o-2024-11-20",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-08-06":{model:"gpt-4o-2024-08-06",kind:"completions",status:"active",inputCostPerToken:25e-7,outputCostPerToken:1e-5},"gpt-4o-2024-05-13":{model:"gpt-4o-2024-05-13",kind:"completions",status:"active",inputCostPerToken:5e-6,outputCostPerToken:15e-6},"gpt-4o-mini":{model:"gpt-4o-mini",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gpt-4o-mini-2024-07-18":{model:"gpt-4o-mini-2024-07-18",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gpt-4.1":{model:"gpt-4.1",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gpt-4.1-mini":{model:"gpt-4.1-mini",kind:"completions",status:"active",inputCostPerToken:4e-7,outputCostPerToken:16e-7},"gpt-4.1-nano":{model:"gpt-4.1-nano",kind:"completions",status:"active",inputCostPerToken:1e-7,outputCostPerToken:4e-7},"gpt-4-turbo":{model:"gpt-4-turbo",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-turbo-2024-04-09":{model:"gpt-4-turbo-2024-04-09",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-turbo-preview":{model:"gpt-4-turbo-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-0125-preview":{model:"gpt-4-0125-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-1106-preview":{model:"gpt-4-1106-preview",kind:"completions",status:"active",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4-vision-preview":{model:"gpt-4-vision-preview",kind:"completions",status:"deprecated",inputCostPerToken:1e-5,outputCostPerToken:3e-5},"gpt-4":{model:"gpt-4",kind:"completions",status:"active",inputCostPerToken:3e-5,outputCostPerToken:6e-5},"gpt-4-0613":{model:"gpt-4-0613",kind:"completions",status:"active",inputCostPerToken:3e-5,outputCostPerToken:6e-5},"gpt-4-32k":{model:"gpt-4-32k",kind:"completions",status:"deprecated",inputCostPerToken:6e-5,outputCostPerToken:12e-5},"gpt-4-32k-0613":{model:"gpt-4-32k-0613",kind:"completions",status:"deprecated",inputCostPerToken:6e-5,outputCostPerToken:12e-5},"gpt-3.5-turbo":{model:"gpt-3.5-turbo",kind:"completions",status:"active",inputCostPerToken:15e-7,outputCostPerToken:2e-6},"gpt-3.5-turbo-0125":{model:"gpt-3.5-turbo-0125",kind:"completions",status:"active",inputCostPerToken:5e-7,outputCostPerToken:15e-7},"gpt-3.5-turbo-1106":{model:"gpt-3.5-turbo-1106",kind:"completions",status:"active",inputCostPerToken:1e-6,outputCostPerToken:2e-6},"gpt-3.5-turbo-16k":{model:"gpt-3.5-turbo-16k",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:4e-6},"text-embedding-3-large":{model:"text-embedding-3-large",kind:"embeddings",status:"active",inputCostPerToken:13e-8,outputCostPerToken:0},"text-embedding-3-small":{model:"text-embedding-3-small",kind:"embeddings",status:"active",inputCostPerToken:2e-8,outputCostPerToken:0},"text-embedding-ada-002":{model:"text-embedding-ada-002",kind:"embeddings",status:"active",inputCostPerToken:1e-7,outputCostPerToken:0}},anthropic:{"claude-opus-4-20250514":{model:"claude-opus-4-20250514",kind:"completions",status:"active",inputCostPerToken:15e-6,outputCostPerToken:75e-6},"claude-sonnet-4-20250514":{model:"claude-sonnet-4-20250514",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-7-sonnet-20250219":{model:"claude-3-7-sonnet-20250219",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-sonnet-20241022":{model:"claude-3-5-sonnet-20241022",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-sonnet-20240620":{model:"claude-3-5-sonnet-20240620",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:15e-6},"claude-3-5-haiku-20241022":{model:"claude-3-5-haiku-20241022",kind:"completions",status:"active",inputCostPerToken:8e-7,outputCostPerToken:4e-6},"claude-3-opus-20240229":{model:"claude-3-opus-20240229",kind:"completions",status:"active",inputCostPerToken:15e-6,outputCostPerToken:75e-6},"claude-3-haiku-20240307":{model:"claude-3-haiku-20240307",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:125e-8},"claude-2.1":{model:"claude-2.1",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"claude-2.0":{model:"claude-2.0",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"claude-instant-1.2":{model:"claude-instant-1.2",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6}},google:{"gemini-2.0-flash-exp":{model:"gemini-2.0-flash-exp",kind:"completions",status:"active",inputCostPerToken:15e-8,outputCostPerToken:6e-7},"gemini-1.5-pro":{model:"gemini-1.5-pro",kind:"completions",status:"active",inputCostPerToken:125e-8,outputCostPerToken:5e-6},"gemini-1.5-pro-latest":{model:"gemini-1.5-pro-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash":{model:"gemini-1.5-flash",kind:"completions",status:"active",inputCostPerToken:75e-9,outputCostPerToken:3e-7},"gemini-1.5-flash-latest":{model:"gemini-1.5-flash-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash-8b":{model:"gemini-1.5-flash-8b",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"gemini-1.5-flash-8b-latest":{model:"gemini-1.5-flash-8b-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"embedding-001":{model:"embedding-001",kind:"embeddings",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6}},mistral:{"mistral-large-latest":{model:"mistral-large-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"mistral-large-2411":{model:"mistral-large-2411",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"mistral-large-2407":{model:"mistral-large-2407",kind:"completions",status:"active",inputCostPerToken:3e-6,outputCostPerToken:9e-6},"mistral-medium-latest":{model:"mistral-medium-latest",kind:"completions",status:"active",inputCostPerToken:4e-7,outputCostPerToken:2e-6},"mistral-small-latest":{model:"mistral-small-latest",kind:"completions",status:"active",inputCostPerToken:1e-7,outputCostPerToken:3e-7},"mistral-small-2409":{model:"mistral-small-2409",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"open-mistral-7b":{model:"open-mistral-7b",kind:"completions",status:"active",inputCostPerToken:25e-8,outputCostPerToken:25e-8},"open-mixtral-8x7b":{model:"open-mixtral-8x7b",kind:"completions",status:"active",inputCostPerToken:7e-7,outputCostPerToken:7e-7},"open-mixtral-8x22b":{model:"open-mixtral-8x22b",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:6e-6},"open-mistral-nemo":{model:"open-mistral-nemo",kind:"completions",status:"active",inputCostPerToken:3e-7,outputCostPerToken:3e-7},"codestral-latest":{model:"codestral-latest",kind:"completions",status:"active",inputCostPerToken:1e-6,outputCostPerToken:3e-6},"ministral-3b-latest":{model:"ministral-3b-latest",kind:"completions",status:"active",inputCostPerToken:4e-8,outputCostPerToken:4e-8},"ministral-8b-latest":{model:"ministral-8b-latest",kind:"completions",status:"active",inputCostPerToken:2e-6,outputCostPerToken:8e-6},"mistral-embed":{model:"mistral-embed",kind:"embeddings",status:"active",inputCostPerToken:1e-7,outputCostPerToken:0}}};async function pt(t){let e=Y.getLogger(t),r=await Pe("supported-models","models",{}),n=new be(r,t),o=await n.get("models");if(o)return e.info("Using cached supported models data",{providersCount:Object.keys(o.modelsByProvider).length,providers:Object.keys(o.modelsByProvider)}),o.modelsByProvider;let s=new Headers({"content-type":"application/json"});ze(s,t.requestId);let a=`${P.instance.zuploEdgeApiUrl}/v1/buckets/${Se.ZUPLO_SERVICE_BUCKET_ID}/providers`;e.info("Fetching supported models from Gateway service",{url:a,bucketId:Se.ZUPLO_SERVICE_BUCKET_ID,requestId:t.requestId,hasAuthJWT:!!P.instance.authApiJWT});let u=await _e({retryDelayMs:5,retries:2},a,{method:"GET",headers:s}),c;if(u.status!==200){try{let d=await u.text(),p=JSON.parse(d);e.error("Gateway service unavailable, using fallback models",p)}catch{e.error("Gateway service unavailable, using fallback models")}console.log("AI Gateway: Using fallback model data due to service unavailability"),c=D_}else{let d=await u.json();e.info("Gateway service response received",{providersCount:Object.keys(d.data).length,providers:Object.keys(d.data),totalModels:Object.values(d.data).reduce((p,m)=>p+m.length,0)}),c={};for(let[p,m]of Object.entries(d.data)){let f=p.toLowerCase();c[f]={},e.debug(`Processing provider: ${p} with ${m.length} models`);for(let h of m)c[f][h.model]=h}e.info("Gateway service models processed successfully",{processedProviders:Object.keys(c)})}let l={modelsByProvider:c};return n.put("models",l,z_),c}i(pt,"getSupportedModels");function _t(t,e,r,n,o,s){let a=e.toLowerCase(),u=o[a];if(!u)return s.warn("Provider not found in supported models list",{provider:e,model:t}),0;let c=u[t];if(!c)return s.warn("Model not found in supported models list for provider",{provider:e,model:t}),0;let l=r*c.inputCostPerToken,d=n*c.outputCostPerToken;return l+d}i(_t,"calculateModelCost");function jv(t,e,r,n){let o=e.toLowerCase(),s=n[o];if(!s)return!1;let a=s[t];return a?a.kind===r&&a.status==="active":!1}i(jv,"isModelSupported");function qv(t,e,r){let n=t.toLowerCase(),o=r[n];return o?Object.values(o).filter(s=>s.kind===e&&s.status==="active").map(s=>s.model):[]}i(qv,"getModelsByProviderAndKind");var nm=class{static{i(this,"GatewayServiceClient")}baseUrl;constructor(e){this.baseUrl=e??P.instance.zuploEdgeApiUrl}async fetchCurrentMeters(e,r){let n=`${this.baseUrl}/v1/hierarchical-quota/${e}`,o=new Headers({"Content-Type":"application/json"});ze(o,r.requestId);let s=await fetch(n,{method:"GET",headers:o});if(!s.ok)throw new ue(`Failed to fetch meters: ${s.status} ${s.statusText}`);return await s.json()}async checkHierarchicalQuotaLimits(e,r){let n=`${this.baseUrl}/v1/hierarchical-quota/${e}/limits`,o=new Headers({"Content-Type":"application/json"});ze(o,r.requestId);let s=await fetch(n,{method:"GET",headers:o});if(!s.ok)throw new ue(`Failed to check quota limits: ${s.status} ${s.statusText}`);return await s.json()}async incrementMeters(e,r,n){let o=`${this.baseUrl}/v1/hierarchical-quota/${e}`,s=new Headers({"Content-Type":"application/json"});ze(s,n.requestId);let a=await fetch(o,{method:"POST",headers:s,body:JSON.stringify({increments:r})});if(!a.ok)throw new ue(`Failed to increment meters: ${a.status} ${a.statusText}`)}},rm=null,Bs={get instance(){return rm===null&&(rm=new nm),rm}};var Hv=Ze("zuplo:policies:AIGatewayMeteringInboundPolicy"),Fv=Symbol("ai-gateway-meter-increments"),it=class t extends xe{static{i(this,"AIGatewayMeteringInboundPolicy")}static setIncrements(e,r){de.set(e,Fv,r)}static getIncrements(e){return de.get(e,Fv)??{}}constructor(e,r){super(e,r),w("policy.inbound.ai-gateway-metering-inbound")}async handler(e,r){let n=Date.now(),o=Y.getLogger(r),s=i((a,u)=>{if(this.options.throwOnFailure)throw new ue(a,{cause:u});o.error(u,a)},"throwOrLog");try{let a=e.user?.configuration;if(!a)throw new v(`AIGatewayMeteringInboundPolicy '${this.policyName}' - No configuration found in request.user. Ensure ai-gateway-inbound policy runs first.`);let u=a;if(!u.id)throw new v(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Configuration ID not found.`);let c=await this.fetchCurrentMeters(u.id,r,o),l=this.checkWarnings(u,c);for(let p of l)r.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_WARNING_COUNT,{type:`quota-${p.type}-${p.period}`,configId:u.id});let d=await this.checkHierarchicalQuotaLimits(u.id,r,o);return d.violation?(r.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_BLOCKED_COUNT,{type:`quota-${d.violation.meter}-${d.violation.period}`,configId:u.id}),this.createHierarchicalQuotaExceededResponse(e,r,d.violation)):(r.addResponseSendingFinalHook(async()=>{try{let p=t.getIncrements(r);Hv(`AIGatewayMeteringInboundPolicy '${this.policyName}' - increments ${JSON.stringify(p)}`),Object.keys(p).length>0&&await t.incrementMetersInternal(u.id,p,r,o)}catch(p){s(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to increment meters`,p)}}),e)}catch(a){if(a instanceof v)throw a;return s(`AIGatewayMeteringInboundPolicy '${this.policyName}' - Error`,a),e}finally{let a=Date.now()-n;Hv(`AIGatewayMeteringInboundPolicy '${this.policyName}' - latency ${a}ms`)}}async fetchCurrentMeters(e,r,n){try{return await Bs.instance.fetchCurrentMeters(e,r)}catch(o){throw n.error(o,`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to fetch meters`),o}}async checkHierarchicalQuotaLimits(e,r,n){try{return await Bs.instance.checkHierarchicalQuotaLimits(e,r)}catch(o){throw n.error(o,`AIGatewayMeteringInboundPolicy '${this.policyName}' - Failed to check hierarchical quota limits`),o}}static async incrementMeters(e,r,n){let o=Y.getLogger(n);return t.incrementMetersInternal(e,r,n,o)}static async incrementMetersInternal(e,r,n,o){try{await Bs.instance.incrementMeters(e,r,n)}catch(s){throw o.error(s,"AIGatewayMeteringInboundPolicy - Failed to increment meters"),s}}checkWarnings(e,r){let n=[];for(let[o,s]of Object.entries(e.limits)){if(!s)continue;let a=r.meters[o];if(!a)continue;let u=this.checkQuotaWarning(s.daily,a.daily,o,"daily");u&&n.push(u);let c=this.checkQuotaWarning(s.monthly,a.monthly,o,"monthly");c&&n.push(c)}return n}checkQuotaWarning(e,r,n,o){if(!e?.warning?.enabled||!e?.warning?.threshold||!e?.limit)return null;let s=e.warning.threshold/100*e.limit;return r>=s?{type:n,period:o}:null}createHierarchicalQuotaExceededResponse(e,r,n){let o=`${n.period} ${n.meter} quota exceeded in configuration '${n.configLabel}'. Limit: ${n.limit}, Current: ${n.currentUsage}`;return M.tooManyRequests(e,r,{detail:o})}};async function or(t,e){if(!P.instance.remoteLogURL){Y.getLogger(t).debug("Remote log URL is not configured, skipping analytics");return}t.analyticsContext.addAnalyticsEvent(parseFloat(e.cost.toFixed(10)),je.AI_GATEWAY_COST_SUM,{model:e.model,provider:e.provider,configId:e.configId}),t.analyticsContext.addAnalyticsEvent(1,je.AI_GATEWAY_REQUEST_COUNT,{model:e.model,provider:e.provider,configId:e.configId}),t.analyticsContext.addAnalyticsEvent(e.promptTokens,je.AI_GATEWAY_TOKEN_SUM,{model:e.model,provider:e.provider,configId:e.configId,tokenType:"prompt"}),t.analyticsContext.addAnalyticsEvent(e.completionTokens,je.AI_GATEWAY_TOKEN_SUM,{model:e.model,provider:e.provider,configId:e.configId,tokenType:"completion"});let r=t.analyticsContext.flushAnalyticsEvents();new Nr(t,{endpoint:`${P.instance.remoteLogURL}/v2/analytics`}).pushEvents(r)}i(or,"sendStreamAnalytics");var Bv={model:{param:"model",required:!0,default:"gpt-4o-mini"},messages:{param:"messages",required:!0},temperature:{param:"temperature",default:1,min:0,max:2},top_p:{param:"top_p",default:1,min:0,max:1},n:{param:"n",default:1,min:1,max:128},stream:{param:"stream",default:!1},stop:{param:"stop"},max_tokens:{param:"max_tokens",min:0},presence_penalty:{param:"presence_penalty",default:0,min:-2,max:2},frequency_penalty:{param:"frequency_penalty",default:0,min:-2,max:2},logit_bias:{param:"logit_bias"},user:{param:"user"},seed:{param:"seed"},functions:{param:"functions"},function_call:{param:"function_call"},tools:{param:"tools"},tool_choice:{param:"tool_choice"},parallel_tool_calls:{param:"parallel_tool_calls"},response_format:{param:"response_format"},logprobs:{param:"logprobs",default:!1},top_logprobs:{param:"top_logprobs",min:0,max:20},max_completion_tokens:{param:"max_completion_tokens"},service_tier:{param:"service_tier"},stream_options:{param:"stream_options"}},Z_={model:{param:"model",required:!0,default:"text-embedding-3-small"},input:{param:"input",required:!0},user:{param:"user"},dimensions:{param:"dimensions"},encoding_format:{param:"encoding_format",default:"float"}},Gs=class{static{i(this,"OpenAIProvider")}name="openai";async chatComplete(e,r){let n=Be(Bv,e),o=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"},body:JSON.stringify(n)});if(!o.ok){let a=await o.json();throw new Error(`OpenAI API error: ${a.error?.message||"Unknown error"}`)}return{...await o.json(),provider:"openai"}}async chatCompleteStream(e,r,n){let o=Be(Bv,{...e,stream:!0,stream_options:{include_usage:!0}}),s=await fetch("https://api.openai.com/v1/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${r}`,"Content-Type":"application/json"},body:JSON.stringify(o)});if(!s.ok){let m=await s.json();throw new Error(`OpenAI API error: ${m.error?.message||"Unknown error"}`)}if(!s.body)throw new Error("No response body received from OpenAI API");let a=n.custom.userContext,u="",c=new TextDecoder,l=new TransformStream({transform(m,f){f.enqueue(m);let h=c.decode(m);u+=h,!u.includes('"usage"')&&u.length>4096&&(u=u.slice(-32));let b;for(;(b=u.indexOf(`
|
|
91
91
|
|
|
92
92
|
`))!==-1;){let y=u.slice(0,b);if(u=u.slice(b+2),!y.includes('"usage"'))continue;let S="";for(let x of y.split(`
|
|
93
93
|
`))if(x.startsWith("data: ")){S=x.slice(6);break}if(S&&S.trim()!=="[DONE]")try{let x=JSON.parse(S);if(x.usage&&x.usage.total_tokens>0){if(a){let $=x.usage;n.waitUntil((async()=>{try{let O=$.prompt_tokens||0,A=$.completion_tokens||0,T=$.total_tokens||0,U=Y.getLogger(n),D=await pt(n),Z=_t(e.model,"openai",O,A,D,U);U.info("OpenAI streaming usage tracked",{userId:a.sub,promptTokens:O,completionTokens:A,totalTokens:T,model:e.model,provider:"openai",cost:Z});let C=a.configuration?.id;if(C){let _={requests:1,tokens:T,costs:Z};await it.incrementMeters(C,_,n)}else n.log.warn("No configuration ID found for streaming usage metering");await or(n,{promptTokens:O,completionTokens:A,model:e.model,provider:"openai",configId:C||"unknown",cost:Z})}catch(O){n.log.error("Error processing OpenAI streaming token usage",{error:O})}})())}u="";break}}catch{}}if(u.length>8192){let y=u.lastIndexOf(`
|