@zuplo/runtime 6.70.44 → 6.70.46
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.
|
@@ -22,28 +22,28 @@
|
|
|
22
22
|
* DEALINGS IN THE SOFTWARE.
|
|
23
23
|
*--------------------------------------------------------------------------------------------*/
|
|
24
24
|
|
|
25
|
-
import{$ as Y,A as Un,Aa as no,B as kn,Ba as oo,C as Tn,Ca as ao,D as ht,Da as io,E as Pn,Ea as so,F as En,Fa as co,G as On,Ga as S,H as qn,Ha as C,I as Mn,Ia as X,J as Dn,Ja as I,K as $,Ka as uo,L as Hn,La as Es,M as zn,Ma as lo,N as b,Na as po,O as W,Oa as Rt,P as U,Pa as mo,Q as Bn,Qa as fo,R as V,Sa as ho,T as jn,Ta as go,U as Ln,Ua as bt,V as le,W as w,X as Nn,Y as $n,Z as Gn,_ as gt,a as gn,aa as Ft,b as ue,ba as Kt,c as yn,ca as Zn,d as j,da as Fn,e as _n,ea as Jt,f as Ps,fa as Wt,g as wn,ga as Kn,h as Rn,ha as E,i as bn,ia as Jn,j as _,ja as Wn,k as be,ka as Vn,l as Se,la as Yn,m as Ce,ma as Vt,n as ve,na as Xn,o as Sn,oa as Yt,p as Cn,pa as Xt,q as L,qa as yt,r as vn,ra as Ie,s as In,sa as Qn,t as xn,ta as eo,u as pt,ua as _t,v as An,va as to,w as Zt,wa as Qt,x as mt,xa as ro,y as ft,ya as je,z as Be,za as wt}from"../chunk-LU6CEICL.js";import{J as dn,L as u,M as un,N as Gt,O as J,Q as ln,S as h,T as re,U as lt,_ as pn,a as dt,ca as mn,da as fn,ea as d,fa as B,j as de,k as an,m as sn,ma as hn,q as cn,s as ut}from"../chunk-J7JE2DD5.js";import"../chunk-JRXZBVXH.js";import{a as R}from"../chunk-4SACVMDH.js";import{$ as D,a as n,aa as g,ba as P,ca as on,da as ct}from"../chunk-ZIKV2LUM.js";B();function Os(e){let t=ft.safeParse(e);return t.success?t.data.id:void 0}n(Os,"parseJsonRpcRequestId");function yo(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return Os(t)}catch{return}}n(yo,"readJsonRpcRequestIdFromBody");function St(e){return Un.parse({jsonrpc:mt,...e.id===void 0?{}:{id:e.id},error:{code:e.error.code,message:e.error.message,...e.error.data===void 0?{}:{data:e.error.data}}})}n(St,"jsonRpcErrorResponse");function _o(e){return new Tn([kn.parse({mode:"url",message:e.message,elicitationId:e.elicitationId,url:e.url})],e.message)}n(_o,"urlElicitationRequiredError");var Ct=d.record(d.string(),d.unknown()),qs=d.record(d.string(),d.unknown()),Ms=d.object({name:d.string().min(1),description:d.string().min(1).optional(),annotations:qs.optional(),_meta:Ct.optional()}).strict(),Ds=d.object({name:d.string().min(1),description:d.string().min(1).optional(),_meta:Ct.optional()}).strict(),Hs=d.object({uri:d.string().min(1),name:d.string().min(1).optional(),description:d.string().min(1).optional(),mimeType:d.string().min(1).optional(),_meta:Ct.optional()}).strict(),zs=d.object({uriTemplate:d.string().min(1),name:d.string().min(1).optional(),description:d.string().min(1).optional(),mimeType:d.string().min(1).optional(),_meta:Ct.optional()}).strict(),Bs=d.array(d.union([d.string(),Ms])),js=d.array(d.union([d.string(),Ds])),Ls=d.array(d.union([d.string(),Hs])),Ns=d.array(d.union([d.string(),zs])),$s=d.object({tools:Bs.optional(),prompts:js.optional(),resources:Ls.optional(),resourceTemplates:Ns.optional()}).strict(),tr=[{option:"tools",listMethod:"tools/list",resultProperty:"tools",itemProperty:"name",directMethods:[{method:"tools/call",paramProperty:"name"}]},{option:"prompts",listMethod:"prompts/list",resultProperty:"prompts",itemProperty:"name",directMethods:[{method:"prompts/get",paramProperty:"name"}]},{option:"resources",listMethod:"resources/list",resultProperty:"resources",itemProperty:"uri",directMethods:[{method:"resources/read",paramProperty:"uri"}]},{option:"resourceTemplates",listMethod:"resources/templates/list",resultProperty:"resourceTemplates",itemProperty:"uriTemplate",directMethods:[]}];function Gs(e,t){return _n($s,e,`MCP capability filter policy "${t}"`)}n(Gs,"parseMcpCapabilityFilterOptions");function O(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(O,"isRecord");function Zs(e,t){if(!O(e))return;let r=e[t];return typeof r=="string"?r:void 0}n(Zs,"readParamString");function rr(e){let t=e.id;return typeof t=="string"||typeof t=="number"||t===null?t:void 0}n(rr,"readRequestId");function So(e){return e===void 0?void 0:JSON.stringify(e)}n(So,"requestIdKey");function Fs(e){let t={};for(let r of tr){let o=e[r.option];if(o===void 0)continue;let a=new Map;for(let i of o){let s=Vs(i,r.itemProperty);s!==void 0&&a.set(s.key,s)}t[r.option]=a}return t}n(Fs,"buildProjectionMaps");function nr(e){return tr.find(t=>t.listMethod===e)}n(nr,"findListRule");function Ks(e){return e.requests.some(t=>{if(!O(t))return!1;let r=nr(t.method);return r!==void 0&&e.projectionMaps[r.option]!==void 0})}n(Ks,"shouldFilterListResponses");function Js(e){for(let t of tr){let r=e.projectionMaps[t.option];if(r!==void 0)for(let o of t.directMethods){if(e.request.method!==o.method)continue;let a=Zs(e.request.params,o.paramProperty);if(a!==void 0&&!r.has(a))return{id:rr(e.request)}}}}n(Js,"findDisallowedDirectAccess");function Ws(e){return Response.json(St({id:e,error:{code:Be.MethodNotFound,message:"Method not found"}}))}n(Ws,"methodNotFoundResponse");function Vs(e,t){if(typeof e=="string")return{key:e,overlay:{}};if(!O(e))return;let r=e[t];if(typeof r=="string")return{key:r,overlay:e}}n(Vs,"buildProjection");function wo(e){let t=e.base[e.property],r=e.overlay[e.property];return O(r)?O(t)?{...t,...r}:r:t}n(wo,"mergeRecordProperty");function Ys(e,t){let r={...e,...t.overlay},o=wo({base:e,overlay:t.overlay,property:"annotations"});o!==void 0&&(r.annotations=o);let a=wo({base:e,overlay:t.overlay,property:"_meta"});return a!==void 0&&(r._meta=a),r}n(Ys,"applyProjection");function Ro(e,t,r){if(!O(e))return e;let o=e.result;if(!O(o))return e;let a=o[t.resultProperty];return!Array.isArray(a)||!a.every(i=>O(i)&&typeof i[t.itemProperty]=="string")?e:{...e,result:{...o,[t.resultProperty]:a.flatMap(i=>{if(!O(i))return[];let s=i[t.itemProperty];if(typeof s!="string")return[];let c=r.get(s);return c===void 0?[]:[Ys(i,c)]})}}}n(Ro,"filterAndProjectItems");function Xs(e){let t=new Map;if(!Array.isArray(e))return t;for(let r of e){if(!O(r))continue;let o=nr(r.method),a=rr(r),i=So(a);o!==void 0&&i!==void 0&&t.set(i,o)}return t}n(Xs,"buildListRulesByResponseId");function Qs(e){if(Array.isArray(e.responseBody)){let o=Xs(e.requestBody);return o.size===0?e.responseBody:e.responseBody.map(a=>{if(!O(a)||"error"in a)return a;let i=So(rr(a)),s=i===void 0?void 0:o.get(i),c=s===void 0?void 0:e.projectionMaps[s.option];return s===void 0||c===void 0?a:Ro(a,s,c)})}if(!O(e.requestBody)||!O(e.responseBody)||"error"in e.responseBody)return e.responseBody;let t=nr(e.requestBody.method),r=t===void 0?void 0:e.projectionMaps[t.option];return t===void 0||r===void 0?e.responseBody:Ro(e.responseBody,t,r)}n(Qs,"filterJsonRpcResponse");async function bo(e){return e.clone().json()}n(bo,"readJson");function ec(e){return e.headers.get("content-type")?.includes("json")??!1}n(ec,"isJsonResponse");var er=class extends ut{static{n(this,"McpCapabilityFilterInboundPolicy")}#e;constructor(t,r){let o=Gs(t,r);super(o,r),this.#e=Fs(o)}async handler(t,r){dt("policy.inbound.mcp-capability-filter");let o;try{o=await bo(t)}catch{return t}let a=Array.isArray(o)?o:[o];for(let i of a){if(!O(i))continue;let s=Js({request:i,projectionMaps:this.#e});if(s!==void 0)return Ws(s.id)}return Ks({requests:a,projectionMaps:this.#e})&&r.addResponseSendingHook(async i=>{if(!ec(i))return i;let s;try{s=await bo(i)}catch{return i}let c=Qs({requestBody:o,responseBody:s,projectionMaps:this.#e});if(c===s)return i;let l=new Headers(i.headers);return l.delete("content-length"),new Response(JSON.stringify(c),{status:i.status,statusText:i.statusText,headers:l})}),t}};var or;or=globalThis.crypto;async function tc(e){return(await or).getRandomValues(new Uint8Array(e))}n(tc,"getRandomValues");async function rc(e){let t="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~",r=Math.pow(2,8)-Math.pow(2,8)%t.length,o="";for(;o.length<e;){let a=await tc(e-o.length);for(let i of a)i<r&&(o+=t[i%t.length])}return o}n(rc,"random");async function nc(e){return await rc(e)}n(nc,"generateVerifier");async function oc(e){let t=await(await or).subtle.digest("SHA-256",new TextEncoder().encode(e));return btoa(String.fromCharCode(...new Uint8Array(t))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}n(oc,"generateChallenge");async function ar(e){if(e||(e=43),e<43||e>128)throw`Expected a length between 43 and 128. Received ${e}.`;let t=await nc(e),r=await oc(t);return{code_verifier:t,code_challenge:r}}n(ar,"pkceChallenge");B();var T=un().superRefine((e,t)=>{if(!URL.canParse(e))return t.addIssue({code:mn.custom,message:"URL must be parseable",fatal:!0}),dn}).refine(e=>{let t=new URL(e);return t.protocol!=="javascript:"&&t.protocol!=="data:"&&t.protocol!=="vbscript:"},{message:"URL cannot use javascript:, data:, or vbscript: scheme"}),vt=lt({resource:u().url(),authorization_servers:h(T).optional(),jwks_uri:u().url().optional(),scopes_supported:h(u()).optional(),bearer_methods_supported:h(u()).optional(),resource_signing_alg_values_supported:h(u()).optional(),resource_name:u().optional(),resource_documentation:u().optional(),resource_policy_uri:u().url().optional(),resource_tos_uri:u().url().optional(),tls_client_certificate_bound_access_tokens:J().optional(),authorization_details_types_supported:h(u()).optional(),dpop_signing_alg_values_supported:h(u()).optional(),dpop_bound_access_tokens_required:J().optional()}),Le=lt({issuer:u(),authorization_endpoint:T,token_endpoint:T,registration_endpoint:T.optional(),scopes_supported:h(u()).optional(),response_types_supported:h(u()),response_modes_supported:h(u()).optional(),grant_types_supported:h(u()).optional(),token_endpoint_auth_methods_supported:h(u()).optional(),token_endpoint_auth_signing_alg_values_supported:h(u()).optional(),service_documentation:T.optional(),revocation_endpoint:T.optional(),revocation_endpoint_auth_methods_supported:h(u()).optional(),revocation_endpoint_auth_signing_alg_values_supported:h(u()).optional(),introspection_endpoint:u().optional(),introspection_endpoint_auth_methods_supported:h(u()).optional(),introspection_endpoint_auth_signing_alg_values_supported:h(u()).optional(),code_challenge_methods_supported:h(u()).optional(),client_id_metadata_document_supported:J().optional()}),ac=lt({issuer:u(),authorization_endpoint:T,token_endpoint:T,userinfo_endpoint:T.optional(),jwks_uri:T,registration_endpoint:T.optional(),scopes_supported:h(u()).optional(),response_types_supported:h(u()),response_modes_supported:h(u()).optional(),grant_types_supported:h(u()).optional(),acr_values_supported:h(u()).optional(),subject_types_supported:h(u()),id_token_signing_alg_values_supported:h(u()),id_token_encryption_alg_values_supported:h(u()).optional(),id_token_encryption_enc_values_supported:h(u()).optional(),userinfo_signing_alg_values_supported:h(u()).optional(),userinfo_encryption_alg_values_supported:h(u()).optional(),userinfo_encryption_enc_values_supported:h(u()).optional(),request_object_signing_alg_values_supported:h(u()).optional(),request_object_encryption_alg_values_supported:h(u()).optional(),request_object_encryption_enc_values_supported:h(u()).optional(),token_endpoint_auth_methods_supported:h(u()).optional(),token_endpoint_auth_signing_alg_values_supported:h(u()).optional(),display_values_supported:h(u()).optional(),claim_types_supported:h(u()).optional(),claims_supported:h(u()).optional(),service_documentation:u().optional(),claims_locales_supported:h(u()).optional(),ui_locales_supported:h(u()).optional(),claims_parameter_supported:J().optional(),request_parameter_supported:J().optional(),request_uri_parameter_supported:J().optional(),require_request_uri_registration:J().optional(),op_policy_uri:T.optional(),op_tos_uri:T.optional(),client_id_metadata_document_supported:J().optional()}),It=re({...ac.shape,...Le.pick({code_challenge_methods_supported:!0}).shape}),xe=re({access_token:u(),id_token:u().optional(),token_type:u(),expires_in:fn.number().optional(),scope:u().optional(),refresh_token:u().optional()}).strip(),vo=re({error:u(),error_description:u().optional(),error_uri:u().optional()}),Co=T.optional().or(pn("").transform(()=>{})),ic=re({redirect_uris:h(T),token_endpoint_auth_method:u().optional(),grant_types:h(u()).optional(),response_types:h(u()).optional(),client_name:u().optional(),client_uri:T.optional(),logo_uri:Co,scope:u().optional(),contacts:h(u()).optional(),tos_uri:Co,policy_uri:u().optional(),jwks_uri:T.optional(),jwks:ln().optional(),software_id:u().optional(),software_version:u().optional(),software_statement:u().optional()}).strip(),ir=re({client_id:u(),client_secret:u().optional(),client_id_issued_at:Gt().optional(),client_secret_expires_at:Gt().optional()}).strip(),Ne=ic.merge(ir),Vm=re({error:u(),error_description:u().optional()}).strip(),Ym=re({token:u(),token_type_hint:u().optional()}).strip();function Io(e){let t=typeof e=="string"?new URL(e):new URL(e.href);return t.hash="",t}n(Io,"resourceUrlFromServerUrl");function xo({requestedResource:e,configuredResource:t}){let r=typeof e=="string"?new URL(e):new URL(e.href),o=typeof t=="string"?new URL(t):new URL(t.href);if(r.origin!==o.origin||r.pathname.length<o.pathname.length)return!1;let a=r.pathname.endsWith("/")?r.pathname:r.pathname+"/",i=o.pathname.endsWith("/")?o.pathname:o.pathname+"/";return a.startsWith(i)}n(xo,"checkResourceAllowed");var x=class extends Error{static{n(this,"OAuthError")}constructor(t,r){super(t),this.errorUri=r,this.name=this.constructor.name}toResponseObject(){let t={error:this.errorCode,error_description:this.message};return this.errorUri&&(t.error_uri=this.errorUri),t}get errorCode(){return this.constructor.errorCode}},$e=class extends x{static{n(this,"InvalidRequestError")}};$e.errorCode="invalid_request";var pe=class extends x{static{n(this,"InvalidClientError")}};pe.errorCode="invalid_client";var me=class extends x{static{n(this,"InvalidGrantError")}};me.errorCode="invalid_grant";var fe=class extends x{static{n(this,"UnauthorizedClientError")}};fe.errorCode="unauthorized_client";var Ge=class extends x{static{n(this,"UnsupportedGrantTypeError")}};Ge.errorCode="unsupported_grant_type";var Ze=class extends x{static{n(this,"InvalidScopeError")}};Ze.errorCode="invalid_scope";var Fe=class extends x{static{n(this,"AccessDeniedError")}};Fe.errorCode="access_denied";var Q=class extends x{static{n(this,"ServerError")}};Q.errorCode="server_error";var Ke=class extends x{static{n(this,"TemporarilyUnavailableError")}};Ke.errorCode="temporarily_unavailable";var Je=class extends x{static{n(this,"UnsupportedResponseTypeError")}};Je.errorCode="unsupported_response_type";var We=class extends x{static{n(this,"UnsupportedTokenTypeError")}};We.errorCode="unsupported_token_type";var Ve=class extends x{static{n(this,"InvalidTokenError")}};Ve.errorCode="invalid_token";var Ye=class extends x{static{n(this,"MethodNotAllowedError")}};Ye.errorCode="method_not_allowed";var Xe=class extends x{static{n(this,"TooManyRequestsError")}};Xe.errorCode="too_many_requests";var he=class extends x{static{n(this,"InvalidClientMetadataError")}};he.errorCode="invalid_client_metadata";var Qe=class extends x{static{n(this,"InsufficientScopeError")}};Qe.errorCode="insufficient_scope";var et=class extends x{static{n(this,"InvalidTargetError")}};et.errorCode="invalid_target";var Ao={[$e.errorCode]:$e,[pe.errorCode]:pe,[me.errorCode]:me,[fe.errorCode]:fe,[Ge.errorCode]:Ge,[Ze.errorCode]:Ze,[Fe.errorCode]:Fe,[Q.errorCode]:Q,[Ke.errorCode]:Ke,[Je.errorCode]:Je,[We.errorCode]:We,[Ve.errorCode]:Ve,[Ye.errorCode]:Ye,[Xe.errorCode]:Xe,[he.errorCode]:he,[Qe.errorCode]:Qe,[et.errorCode]:et};function sc(e){return["client_secret_basic","client_secret_post","none"].includes(e)}n(sc,"isClientAuthMethod");var sr="code",cr="S256";function cc(e,t){let r=e.client_secret!==void 0;return"token_endpoint_auth_method"in e&&e.token_endpoint_auth_method&&sc(e.token_endpoint_auth_method)&&(t.length===0||t.includes(e.token_endpoint_auth_method))?e.token_endpoint_auth_method:t.length===0?r?"client_secret_basic":"none":r&&t.includes("client_secret_basic")?"client_secret_basic":r&&t.includes("client_secret_post")?"client_secret_post":t.includes("none")?"none":r?"client_secret_post":"none"}n(cc,"selectClientAuthMethod");function dc(e,t,r,o){let{client_id:a,client_secret:i}=t;switch(e){case"client_secret_basic":uc(a,i,r);return;case"client_secret_post":lc(a,i,o);return;case"none":pc(a,o);return;default:throw new Error(`Unsupported client authentication method: ${e}`)}}n(dc,"applyClientAuthentication");function uc(e,t,r){if(!t)throw new Error("client_secret_basic authentication requires a client_secret");let o=btoa(`${e}:${t}`);r.set("Authorization",`Basic ${o}`)}n(uc,"applyBasicAuth");function lc(e,t,r){r.set("client_id",e),t&&r.set("client_secret",t)}n(lc,"applyPostAuth");function pc(e,t){t.set("client_id",e)}n(pc,"applyPublicAuth");async function ko(e){let t=e instanceof Response?e.status:void 0,r=e instanceof Response?await e.text():e;try{let o=vo.parse(JSON.parse(r)),{error:a,error_description:i,error_uri:s}=o,c=Ao[a]||Q;return new c(i||"",s)}catch(o){let a=`${t?`HTTP ${t}: `:""}Invalid OAuth error response: ${o}. Raw body: ${r}`;return new Q(a)}}n(ko,"parseErrorResponse");async function lr(e,t){try{return await dr(e,t)}catch(r){if(r instanceof pe||r instanceof fe)return await e.invalidateCredentials?.("all"),await dr(e,t);if(r instanceof me)return await e.invalidateCredentials?.("tokens"),await dr(e,t);throw r}}n(lr,"auth");async function dr(e,{serverUrl:t,authorizationCode:r,scope:o,resourceMetadataUrl:a,fetchFn:i}){let s=await e.discoveryState?.(),c,l,m,f=a;if(!f&&s?.resourceMetadataUrl&&(f=new URL(s.resourceMetadataUrl)),s?.authorizationServerUrl){if(l=s.authorizationServerUrl,c=s.resourceMetadata,m=s.authorizationServerMetadata??await Eo(l,{fetchFn:i}),!c)try{c=await Po(t,{resourceMetadataUrl:f},i)}catch{}(m!==s.authorizationServerMetadata||c!==s.resourceMetadata)&&await e.saveDiscoveryState?.({authorizationServerUrl:String(l),resourceMetadataUrl:f?.toString(),resourceMetadata:c,authorizationServerMetadata:m})}else{let M=await _c(t,{resourceMetadataUrl:f,fetchFn:i});l=M.authorizationServerUrl,m=M.authorizationServerMetadata,c=M.resourceMetadata,await e.saveDiscoveryState?.({authorizationServerUrl:String(l),resourceMetadataUrl:f?.toString(),resourceMetadata:c,authorizationServerMetadata:m})}let A=await mc(t,e,c),v=o||c?.scopes_supported?.join(" ")||e.clientMetadata.scope,N=await Promise.resolve(e.clientInformation());if(!N){if(r!==void 0)throw new Error("Existing OAuth client information is required when exchanging an authorization code");let M=m?.client_id_metadata_document_supported===!0,ze=e.clientMetadataUrl;if(ze&&!pr(ze))throw new he(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${ze}`);if(M&&ze)N={client_id:ze},await e.saveClientInformation?.(N);else{if(!e.saveClientInformation)throw new Error("OAuth client information must be saveable for dynamic registration");let nn=await Cc(l,{metadata:m,clientMetadata:e.clientMetadata,scope:v,fetchFn:i});await e.saveClientInformation(nn),N=nn}}let Re=!e.redirectUrl;if(r!==void 0||Re){let M=await Sc(e,l,{metadata:m,resource:A,authorizationCode:r,fetchFn:i});return await e.saveTokens(M),"AUTHORIZED"}let rn=await e.tokens();if(rn?.refresh_token)try{let M=await bc(l,{metadata:m,clientInformation:N,refreshToken:rn.refresh_token,resource:A,addClientAuthentication:e.addClientAuthentication,fetchFn:i});return await e.saveTokens(M),"AUTHORIZED"}catch(M){if(!(!(M instanceof x)||M instanceof Q))throw M}let Us=e.state?await e.state():void 0,{authorizationUrl:ks,codeVerifier:Ts}=await wc(l,{metadata:m,clientInformation:N,state:Us,redirectUrl:e.redirectUrl,scope:v,resource:A});return await e.saveCodeVerifier(Ts),await e.redirectToAuthorization(ks),"REDIRECT"}n(dr,"authInternal");function pr(e){if(!e)return!1;try{let t=new URL(e);return t.protocol==="https:"&&t.pathname!=="/"}catch{return!1}}n(pr,"isHttpsUrl");async function mc(e,t,r){let o=Io(e);if(t.validateResourceURL)return await t.validateResourceURL(o,r?.resource);if(r){if(!xo({requestedResource:o,configuredResource:r.resource}))throw new Error(`Protected resource ${r.resource} does not match expected ${o} (or origin)`);return new URL(r.resource)}}n(mc,"selectResourceURL");function To(e){let t=e.headers.get("WWW-Authenticate");if(!t)return{};let[r,o]=t.split(" ");if(r.toLowerCase()!=="bearer"||!o)return{};let a=ur(e,"resource_metadata")||void 0,i;if(a)try{i=new URL(a)}catch{}let s=ur(e,"scope")||void 0,c=ur(e,"error")||void 0;return{resourceMetadataUrl:i,scope:s,error:c}}n(To,"extractWWWAuthenticateParams");function ur(e,t){let r=e.headers.get("WWW-Authenticate");if(!r)return null;let o=new RegExp(`${t}=(?:"([^"]+)"|([^\\s,]+))`),a=r.match(o);return a?a[1]||a[2]:null}n(ur,"extractFieldFromWwwAuth");async function Po(e,t,r=fetch){let o=await gc(e,"oauth-protected-resource",r,{protocolVersion:t?.protocolVersion,metadataUrl:t?.resourceMetadataUrl});if(!o||o.status===404)throw await o?.body?.cancel(),new Error("Resource server does not implement OAuth 2.0 Protected Resource Metadata.");if(!o.ok)throw await o.body?.cancel(),new Error(`HTTP ${o.status} trying to load well-known OAuth protected resource metadata.`);return vt.parse(await o.json())}n(Po,"discoverOAuthProtectedResourceMetadata");async function mr(e,t,r=fetch){try{return await r(e,{headers:t})}catch(o){if(o instanceof TypeError)return t?mr(e,void 0,r):void 0;throw o}}n(mr,"fetchWithCorsRetry");function fc(e,t="",r={}){return t.endsWith("/")&&(t=t.slice(0,-1)),r.prependPathname?`${t}/.well-known/${e}`:`/.well-known/${e}${t}`}n(fc,"buildWellKnownPath");async function Uo(e,t,r=fetch){return await mr(e,{"MCP-Protocol-Version":t},r)}n(Uo,"tryMetadataDiscovery");function hc(e,t){return!e||e.status>=400&&e.status<500&&t!=="/"}n(hc,"shouldAttemptFallback");async function gc(e,t,r,o){let a=new URL(e),i=o?.protocolVersion??Zt,s;if(o?.metadataUrl)s=new URL(o.metadataUrl);else{let l=fc(t,a.pathname);s=new URL(l,o?.metadataServerUrl??a),s.search=a.search}let c=await Uo(s,i,r);if(!o?.metadataUrl&&hc(c,a.pathname)){let l=new URL(`/.well-known/${t}`,a);c=await Uo(l,i,r)}return c}n(gc,"discoverMetadataWithFallback");function yc(e){let t=typeof e=="string"?new URL(e):e,r=t.pathname!=="/",o=[];if(!r)return o.push({url:new URL("/.well-known/oauth-authorization-server",t.origin),type:"oauth"}),o.push({url:new URL("/.well-known/openid-configuration",t.origin),type:"oidc"}),o;let a=t.pathname;return a.endsWith("/")&&(a=a.slice(0,-1)),o.push({url:new URL(`/.well-known/oauth-authorization-server${a}`,t.origin),type:"oauth"}),o.push({url:new URL(`/.well-known/openid-configuration${a}`,t.origin),type:"oidc"}),o.push({url:new URL(`${a}/.well-known/openid-configuration`,t.origin),type:"oidc"}),o}n(yc,"buildDiscoveryUrls");async function Eo(e,{fetchFn:t=fetch,protocolVersion:r=Zt}={}){let o={"MCP-Protocol-Version":r,Accept:"application/json"},a=yc(e);for(let{url:i,type:s}of a){let c=await mr(i,o,t);if(c){if(!c.ok){if(await c.body?.cancel(),c.status>=400&&c.status<500)continue;throw new Error(`HTTP ${c.status} trying to load ${s==="oauth"?"OAuth":"OpenID provider"} metadata from ${i}`)}return s==="oauth"?Le.parse(await c.json()):It.parse(await c.json())}}}n(Eo,"discoverAuthorizationServerMetadata");async function _c(e,t){let r,o;try{r=await Po(e,{resourceMetadataUrl:t?.resourceMetadataUrl},t?.fetchFn),r.authorization_servers&&r.authorization_servers.length>0&&(o=r.authorization_servers[0])}catch{}o||(o=String(new URL("/",e)));let a=await Eo(o,{fetchFn:t?.fetchFn});return{authorizationServerUrl:o,authorizationServerMetadata:a,resourceMetadata:r}}n(_c,"discoverOAuthServerInfo");async function wc(e,{metadata:t,clientInformation:r,redirectUrl:o,scope:a,state:i,resource:s}){let c;if(t){if(c=new URL(t.authorization_endpoint),!t.response_types_supported.includes(sr))throw new Error(`Incompatible auth server: does not support response type ${sr}`);if(t.code_challenge_methods_supported&&!t.code_challenge_methods_supported.includes(cr))throw new Error(`Incompatible auth server: does not support code challenge method ${cr}`)}else c=new URL("/authorize",e);let l=await ar(),m=l.code_verifier,f=l.code_challenge;return c.searchParams.set("response_type",sr),c.searchParams.set("client_id",r.client_id),c.searchParams.set("code_challenge",f),c.searchParams.set("code_challenge_method",cr),c.searchParams.set("redirect_uri",String(o)),i&&c.searchParams.set("state",i),a&&c.searchParams.set("scope",a),a?.includes("offline_access")&&c.searchParams.append("prompt","consent"),s&&c.searchParams.set("resource",s.href),{authorizationUrl:c,codeVerifier:m}}n(wc,"startAuthorization");function Rc(e,t,r){return new URLSearchParams({grant_type:"authorization_code",code:e,code_verifier:t,redirect_uri:String(r)})}n(Rc,"prepareAuthorizationCodeRequest");async function Oo(e,{metadata:t,tokenRequestParams:r,clientInformation:o,addClientAuthentication:a,resource:i,fetchFn:s}){let c=t?.token_endpoint?new URL(t.token_endpoint):new URL("/token",e),l=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(i&&r.set("resource",i.href),a)await a(l,r,c,t);else if(o){let f=t?.token_endpoint_auth_methods_supported??[],A=cc(o,f);dc(A,o,l,r)}let m=await(s??fetch)(c,{method:"POST",headers:l,body:r});if(!m.ok)throw await ko(m);return xe.parse(await m.json())}n(Oo,"executeTokenRequest");async function bc(e,{metadata:t,clientInformation:r,refreshToken:o,resource:a,addClientAuthentication:i,fetchFn:s}){let c=new URLSearchParams({grant_type:"refresh_token",refresh_token:o}),l=await Oo(e,{metadata:t,tokenRequestParams:c,clientInformation:r,addClientAuthentication:i,resource:a,fetchFn:s});return{refresh_token:o,...l}}n(bc,"refreshAuthorization");async function Sc(e,t,{metadata:r,resource:o,authorizationCode:a,fetchFn:i}={}){let s=e.clientMetadata.scope,c;if(e.prepareTokenRequest&&(c=await e.prepareTokenRequest(s)),!c){if(!a)throw new Error("Either provider.prepareTokenRequest() or authorizationCode is required");if(!e.redirectUrl)throw new Error("redirectUrl is required for authorization_code flow");let m=await e.codeVerifier();c=Rc(a,m,e.redirectUrl)}let l=await e.clientInformation();return Oo(t,{metadata:r,tokenRequestParams:c,clientInformation:l??void 0,addClientAuthentication:e.addClientAuthentication,resource:o,fetchFn:i})}n(Sc,"fetchToken");async function Cc(e,{metadata:t,clientMetadata:r,scope:o,fetchFn:a}){let i;if(t){if(!t.registration_endpoint)throw new Error("Incompatible auth server: does not support dynamic client registration");i=new URL(t.registration_endpoint)}else i=new URL("/register",e);let s=await(a??fetch)(i,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...r,...o!==void 0?{scope:o}:{}})});if(!s.ok)throw await ko(s);return Ne.parse(await s.json())}n(Cc,"registerClient");var fr="zuplo.com",vc=new Set(["co.jp","co.kr","co.nz","co.uk","com.au","com.br","com.cn","com.mx","com.sg","co.in"]),Ic=[".example.test",".example.com",".example.org",".invalid",".localhost",".test"];function qo(e){return`https://www.google.com/s2/favicons?domain=${e}&sz=128`}n(qo,"s2FaviconHref");function xc(e){return`https://t0.gstatic.com/faviconV2?client=SOCIAL&type=FAVICON&drop_404_icon=true&fallback_opts=TYPE,SIZE,URL&url=http://${e}&size=128`}n(xc,"strictFaviconHref");var tt=qo(fr);function hr(e){let t=e.toLowerCase();return t===fr||t==="zuplo.app"||t==="zuplo.dev"||t.endsWith(".zuplo.app")||t.endsWith(".zuplo.dev")?qo(fr):xc(e)}n(hr,"resolveIconHref");function Ac(e){try{return new URL(`http://${e}`).hostname}catch{return e}}n(Ac,"hostnameFromHost");function Uc(e){return e==="localhost"||e.includes(":")||/^\d{1,3}(?:\.\d{1,3}){3}$/.test(e)}n(Uc,"isLocalOrAddressHost");function kc(e){let t=Ac(e).toLowerCase().replace(/\.$/,"");if(Uc(t)||Ic.some(i=>t===i.slice(1)||t.endsWith(i)))return t;let r=t.split(".").filter(Boolean);if(r.length<=2)return t;let o=r.slice(-2).join("."),a=vc.has(o)?3:2;return r.slice(-a).join(".")}n(kc,"inferFaviconDomain");function gr(e){return{src:hr(kc(e)),mimeType:"image/png",sizes:["128x128"]}}n(gr,"resolveMcpFaviconIcon");function xt(e){try{return gr(new URL(e).host)}catch{return}}n(xt,"resolveMcpFaviconIconFromUrl");function ne(e){let t=$().connectionsById.get(e);if(!t)throw new P(`Unknown upstream server "${e}". Check the route's MCP upstream policy and ensure policies.json declares a matching upstream connection.`);return{displayName:t.displayName,...t.description===void 0?{}:{description:t.description},...t.serverInfo===void 0?{}:{serverInfo:t.serverInfo},transport:{baseUrl:t.mcpUrl,resourceMetadataUrl:t.protectedResourceMetadataUrl}}}n(ne,"getUpstreamServerConfig");function Tc(e){let t=$().connectionsById.get(e.upstreamServerId);if(!t||t.authProfileId!==e.authProfileId)throw new P(`Unknown auth profile "${String(e.authProfileId)}" for upstream server "${e.upstreamServerId}". Check the route's MCP upstream policy and ensure policies.json declares a matching auth mode for that upstream connection.`);return t.authProfileId}n(Tc,"resolveUpstreamAuthProfileId");function yr(e){Tc(e);let t=$().connectionsById.get(e.upstreamServerId);if(!t)throw new P(`Auth profile could not be resolved for upstream server "${e.upstreamServerId}". Check the route's MCP upstream policy and ensure policies.json declares the upstream connection before this handler runs.`);return t.authConfig}n(yr,"getUpstreamAuthConfig");function ge(e,t){let r=yr({upstreamServerId:e,authProfileId:t});if(!En(r))throw new P(`Upstream server "${e}" does not use upstream OAuth. Select an auth mode that supports the requested upstream connect flow or remove the upstream OAuth route for this server.`);return r.oauth}n(ge,"requireUpstreamOAuthConfig");var Pc={"shared-oauth":{authMode:"shared-oauth",ownerMode:"shared",connectSupport:"oauth_authorization",connectUnsupportedDetail:void 0,callbackSupport:"authorization_code",credentialAcquisition:"oauth_connection"},"user-oauth":{authMode:"user-oauth",ownerMode:"user",connectSupport:"oauth_authorization",connectUnsupportedDetail:void 0,callbackSupport:"authorization_code",credentialAcquisition:"oauth_connection"}};function G(e){return Pc[e]}n(G,"describeUpstreamAuthMode");function At(e){return G(e).ownerMode}n(At,"resolveOwnerModeForUpstreamAuthMode");B();import{errors as No,jwtVerify as $o,SignJWT as Go}from"jose";var q="zuplo-mcp-gateway",H=q,z="HS256";import{base64url as Ec}from"jose";var Oc=new TextEncoder,qc="MCP gateway could not initialize secure key material.",Mc=32,Mo=new Map,Do=new Map,Dc;function Hc(){return Dc??on.instance.authPrivateKey}n(Hc,"readAuthPrivateKey");function Ho(e){return new D(qc,e===void 0?void 0:{cause:e})}n(Ho,"createGeneratedKeyMaterialError");function zo(e,t){let r=Ec.decode(t);if(r.byteLength!==Mc)throw new Error(`Generated deployment auth key ${e} is invalid.`);return r}n(zo,"decodeJwkKeyField");function zc(e){let t=Hc();if(!t)throw Ho();try{let r=JSON.parse(t);if(r.kty!=="OKP"||r.crv!=="Ed25519"||typeof r.d!="string"||typeof r.x!="string")throw new Error("Generated deployment auth key is not an Ed25519 JWK.");let o=zo("d",r.d);zo("x",r.x);let a=Oc.encode(`zuplo-mcp-gateway:${e}:Ed25519:`),i=new Uint8Array(a.byteLength+o.byteLength);return i.set(a),i.set(o,a.byteLength),i}catch(r){throw Ho(r)}}n(zc,"decodeGeneratedKeyMaterial");function Bc(e){let t=Mo.get(e);return t||(t=zc(e),Mo.set(e,t)),t}n(Bc,"getMasterKeyMaterial");async function Z(e){let t=Do.get(e.purpose);if(t!==void 0)return t;let r=await e.derive(Bc(e.keyMaterialPurpose));return Do.set(e.purpose,r),r}n(Z,"readCachedDerivedKey");var jc="SHA-256";var Lc="zuplo-mcp-gateway:",Nc=new TextEncoder,Bo=new WeakMap;async function oe(e,t){let r=Bo.get(e);r||(r=new Map,Bo.set(e,r));let o=r.get(t);if(o)return o;let a=await $c(e,t);return r.set(t,a),a}n(oe,"deriveGatewaySigningKey");async function $c(e,t){let r=jo(e),o=await crypto.subtle.importKey("raw",r,{name:"HKDF"},!1,["deriveBits"]),a=Nc.encode(`${Lc}${t}`),i=await crypto.subtle.deriveBits({name:"HKDF",hash:jc,salt:new Uint8Array,info:jo(a)},o,32*8);return new Uint8Array(i)}n($c,"hkdfExpand");function jo(e){let t=new ArrayBuffer(e.byteLength);return new Uint8Array(t).set(e),t}n(jo,"copyToArrayBuffer");var Zo=15*60,Gc=15*60,Zc=ro.extend({id:no}),Fc=Zc.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Fo=Qt.extend({id:oo,purpose:d.literal("browser_connect")}),Kc=Qt.extend({purpose:d.literal("browser_connect")}),Jc=Fo.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Ko=Zo*1e3;async function Jo(){return Z({purpose:"oauth-state",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"oauth-state"),"derive")})}n(Jo,"getOAuthStateKey");async function Wo(){return Z({purpose:"browser-connect",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-connect"),"derive")})}n(Wo,"getBrowserConnectKey");async function Vo(e){let t=Math.floor(Date.now()/1e3)+Zo;return new Go(e).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(q).setAudience(H).setIssuedAt().setExpirationTime(t).sign(await Jo())}n(Vo,"signOAuthState");async function Ut(e){try{let{payload:t}=await $o(e,await Jo(),{algorithms:[z],issuer:q,audience:H});return Fc.parse(t)}catch(t){throw t instanceof No.JWTExpired?new g({message:"OAuth state has expired",extensionMembers:{[_]:"oauth_state_expired"}},{cause:t}):new g({message:"OAuth state could not be verified",extensionMembers:{[_]:"oauth_state_invalid"}},{cause:t})}}n(Ut,"verifyOAuthState");async function Yo(e){let t=Math.floor(Date.now()/1e3)+Gc,r=Kc.parse(e),o=Fo.parse({...r,id:co()});return new Go(o).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(q).setAudience(H).setIssuedAt().setExpirationTime(t).sign(await Wo())}n(Yo,"signBrowserConnectTicket");async function Xo(e){try{let{payload:t}=await $o(e,await Wo(),{algorithms:[z],issuer:q,audience:H});return Jc.parse(t)}catch(t){throw t instanceof No.JWTExpired?new g({message:"Browser connect ticket has expired",extensionMembers:{[_]:"oauth_state_expired"}},{cause:t}):new g({message:"Browser connect ticket could not be verified",extensionMembers:{[_]:"oauth_state_invalid"}},{cause:t})}}n(Xo,"verifyBrowserConnectTicket");async function Qo(e){if((await S().consumeBrowserConnectTicket({id:e.id,expiresAt:b(new Date(e.exp*1e3)),now:b(new Date)})).kind==="consumed")throw new g({message:"Browser connect ticket has already been used",extensionMembers:{[_]:"oauth_state_reused"}})}n(Qo,"consumeBrowserConnectTicket");function Wc(e,t,r=!1){return r?`${e} authorization must be renewed before this ${t} can be used.`:`${e} authorization is required before this ${t} can be used.`}n(Wc,"buildConnectRequiredMessage");async function Vc(e){let t=U(e.requestUrl,e.requestHeaders),r=new URL(e.path,t);return e.redirect&&r.searchParams.set("redirect","true"),r.searchParams.set("operationId",e.operationId),r.searchParams.set("browserTicket",await Yo({...je(e),purpose:"browser_connect"})),r.toString()}n(Vc,"buildGatewayBrowserTicketUrl");function Yc(e){return`/auth/connections/${encodeURIComponent(e)}/connect`}n(Yc,"buildGatewayConnectPath");async function _r(e){return Vc({...e,path:Yc(e.upstreamServerId),redirect:!0})}n(_r,"buildGatewayConnectUrl");async function kt(e){let t={requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.returnTo===void 0?{}:{returnTo:e.returnTo}};return{state:e.requiresReconsent?"reconsent_required":"authenticating",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.connectionId?{connectionId:e.connectionId}:{},authUrl:await _r(t),message:Wc(e.upstreamDisplayName,e.subject,e.requiresReconsent),nextAction:"redirect"}}n(kt,"buildRedirectConnectRequiredResponse");function ea(e){return Xc({...e,message:e.requiresReconsent?`An administrator must reconnect ${e.upstreamDisplayName} before this tool can be used.`:`An administrator must connect ${e.upstreamDisplayName} before this tool can be used.`})}n(ea,"buildAdminConnectRequiredResponse");function Xc(e){return{state:"admin_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.connectionId?{connectionId:e.connectionId}:{},message:e.message,nextAction:"admin_setup_required"}}n(Xc,"buildAdminSetupRequiredResponse");B();function wr(e){return`Zuplo MCP Gateway - ${e}`}n(wr,"buildGatewayOAuthClientName");function ta(e,t,r){let o=new URL(e,U(t,r));return ue(o)&&gn(o.hostname)!=="localhost"&&(o.hostname="localhost"),o.toString()}n(ta,"buildGatewayOAuthRedirectUri");function Rr(e){let t=new URL(`/.well-known/oauth-client/${encodeURIComponent(e.upstreamServerId)}`,e.origin);return t.searchParams.set("authProfileId",e.authProfileId),t.toString()}n(Rr,"buildOAuthClientMetadataDocumentUrl");function ra(e,t){return U(e,t)}n(ra,"requireOAuthClientMetadataOrigin");function na(e,t,r){let o=ne(t),a=ge(t,r),i={client_id:Rr({origin:e,upstreamServerId:t,authProfileId:r}),client_name:wr(o.displayName),client_uri:new URL("/",e).toString(),redirect_uris:[new URL(a.redirectPath,e).toString()],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",token_endpoint_auth_method:"none"};return a.scopes.length>0&&(i.scope=a.scopes.join(a.scopeDelimiter)),i}n(na,"buildOAuthClientMetadataDocument");B();import{base64url as ae}from"jose";var Qc="SHA-256",Ue="AES-GCM",ed=12,Sr="zuplo-secret",Cr=1,oa="generated:auth_private_key:token-encryption",td=d.object({version:d.literal(Cr),keyId:d.literal(oa),algorithm:d.literal(Ue),iv:d.string().min(1),ciphertext:d.string().min(1)}).strict();function Ae(e){let t=new ArrayBuffer(e.byteLength);return new Uint8Array(t).set(e),t}n(Ae,"copyToArrayBuffer");async function br(){return Z({purpose:"token-encryption",keyMaterialPurpose:"token-encryption",derive:n(async e=>{let t=await crypto.subtle.digest(Qc,Ae(e));return crypto.subtle.importKey("raw",t,{name:Ue},!1,["encrypt","decrypt"])},"derive")})}n(br,"getEncryptionKey");function aa(e){return Ae(new TextEncoder().encode(`${Sr}:v${e.version}:${e.keyId}`))}n(aa,"getAssociatedData");function rd(e){return`${Sr}:v${e.version}:${ae.encode(new TextEncoder().encode(JSON.stringify(e)))}`}n(rd,"encodeEnvelope");function nd(e){let t=`${Sr}:v${Cr}:`;if(!e.startsWith(t))return;let r=e.slice(t.length),o=new TextDecoder().decode(ae.decode(r));return td.parse(JSON.parse(o))}n(nd,"decodeEnvelope");async function Tt(e){let t=await br(),r=crypto.getRandomValues(new Uint8Array(ed)),o={version:Cr,keyId:oa},a=await crypto.subtle.encrypt({name:Ue,iv:r,additionalData:aa(o)},t,new TextEncoder().encode(e));return rd({...o,algorithm:Ue,iv:ae.encode(r),ciphertext:ae.encode(new Uint8Array(a))})}n(Tt,"encryptSecret");async function rt(e){let t=nd(e);if(t){let s=await br(),c=await crypto.subtle.decrypt({name:Ue,iv:Ae(ae.decode(t.iv)),additionalData:aa(t)},s,Ae(ae.decode(t.ciphertext)));return new TextDecoder().decode(c)}let[r,o]=e.split(".");if(!r||!o)throw new D("Encrypted payload is malformed");let a=await br(),i=await crypto.subtle.decrypt({name:Ue,iv:Ae(ae.decode(r))},a,Ae(ae.decode(o)));return new TextDecoder().decode(i)}n(rt,"decryptSecret");var od=d.union([Ne,ir]),ad=d.object({authorizationServerUrl:d.url(),resourceMetadataUrl:d.url().optional(),resourceMetadata:vt.optional(),authorizationServerMetadata:d.union([Le,It]).optional()}).passthrough(),id="Bearer",sd="__zuplo_refresh_only_upstream_access_token__",cd=new Set(["client_id","code_challenge","code_challenge_method","display","login_hint","nonce","prompt","redirect_uri","response_mode","response_type","state"]);function dd(e){return e?e.split(/[,\s]+/).filter(Boolean):[]}n(dd,"splitScopes");function ud(e){let t=[];for(let r of cd)e.authorizationUrl.searchParams.getAll(r).length>1&&t.push(r);if(t.length!==0)throw new P(`Upstream OAuth authorization metadata for upstream "${e.upstreamServerId}" produced duplicate singleton authorization request parameter(s): ${t.join(", ")}. Remove request-specific query parameters such as "prompt" from the upstream authorization_endpoint; the gateway and OAuth client SDK add per-request parameters during the authorization flow.`)}n(ud,"assertNoDuplicateSingletonAuthorizationRequestParams");function ld(e){return gt.parse(e)}n(ld,"parsePkceCodeVerifier");function pd(e){if(typeof e.expires_in=="number")return b(new Date(Date.now()+e.expires_in*1e3))}n(pd,"readTokenExpiry");async function ia(e){if(e!==void 0)return Tt(JSON.stringify(e))}n(ia,"encryptJson");async function sa(e,t){if(!e)return;let r=await rt(e);try{return t.parse(JSON.parse(r))}catch(o){throw new g({message:"Stored upstream OAuth JSON state is invalid.",extensionMembers:{[_]:"oauth_state_invalid"}},{cause:o})}}n(sa,"decryptJson");function md(e){if(e===void 0)return;let t={authorizationServerUrl:e.authorizationServerUrl};return e.resourceMetadataUrl!==void 0&&(t.resourceMetadataUrl=e.resourceMetadataUrl),e.resourceMetadata!==void 0&&(t.resourceMetadata=e.resourceMetadata),e.authorizationServerMetadata!==void 0&&(t.authorizationServerMetadata=e.authorizationServerMetadata),t}n(md,"toOAuthDiscoveryState");function fd(e,t){return"redirect_uris"in e?e.redirect_uris.includes(t):!0}n(fd,"clientInformationAllowsRedirectUri");function hd(e,t,r){let o=ne(e),a=ge(e,t),i=vr(a.scopes,a.scopeDelimiter);return{client_name:wr(o.displayName),client_uri:new URL("/",new URL(r).origin).toString(),redirect_uris:[r],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",scope:i,token_endpoint_auth_method:"none"}}n(hd,"buildOAuthClientMetadata");function vr(e,t){return e&&e.length>0?e.join(t):void 0}n(vr,"joinOAuthScopes");function gd(e,t){return t===void 0?e:{...e,scope:t}}n(gd,"applyOAuthClientMetadataScope");function ca(e,t){return vr(e?.resourceMetadata?.scopes_supported,t)}n(ca,"readResourceMetadataScope");function yd(e){let t;if(e.registration.tokenEndpointAuthMethod!=="none"&&(t=e.registration.clientSecret,!t))throw new P(`Manual OAuth registration for upstream "${e.upstreamServerId}" requires clientSecret. Set the env var that backs the client secret or use tokenEndpointAuthMethod "none".`);return Ne.parse({...e.clientMetadata,client_id:e.registration.clientId,token_endpoint_auth_method:e.registration.tokenEndpointAuthMethod,...t===void 0?{}:{client_secret:t}})}n(yd,"buildManualOAuthClientInformation");function _d(e,t,r){let o=Rr({origin:new URL(r).origin,upstreamServerId:e,authProfileId:t});return pr(o)?o:void 0}n(_d,"buildClientMetadataUrl");function da(e){for(let t of e)if(t!==void 0)return t}n(da,"firstDefined");function wd(e){let t=ge(e.target.upstreamServerId,e.target.authProfileId),r=hd(e.target.upstreamServerId,e.target.authProfileId,e.redirectUri),o=vr(t.scopes,t.scopeDelimiter);if(t.clientRegistration.mode==="manual")return{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter,configuredClientInformation:yd({clientMetadata:r,registration:t.clientRegistration,upstreamServerId:e.target.upstreamServerId})};let a=_d(e.target.upstreamServerId,e.target.authProfileId,e.redirectUri);return a===void 0?{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter}:{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter,clientMetadataUrl:a}}n(wd,"buildInitialOAuthClientSetup");function Rd(e,t){if(t===void 0)return da([e.pendingState?.encryptedClientInformation,e.connectionMetadata?.encryptedClientInformation,e.connection?.metadata?.encryptedClientInformation])}n(Rd,"readEncryptedClientInformation");function bd(e){return da([e.pendingState?.encryptedDiscoveryState,e.connectionMetadata?.encryptedDiscoveryState,e.connection?.metadata?.encryptedDiscoveryState])}n(bd,"readEncryptedDiscoveryState");var ye=class{static{n(this,"UpstreamOAuthProvider")}clientMetadataUrl;target;redirectUriValue;returnOrigin;clientMetadataValue;configuredScope;scopeDelimiter;configuredClientInformation;challengeScope;inferredScope;authorizationUrlValue;connection;pendingState;encryptedClientInformation;encryptedDiscoveryState;cachedClientInformation;clientInformationLoaded=!1;cachedDiscoveryState;discoveryStateLoaded=!1;cachedTokens;tokensLoaded=!1;constructor(t){let r=wd({target:t.target,redirectUri:t.redirectUri});this.target=t.target,this.redirectUriValue=t.redirectUri,this.returnOrigin=t.returnOrigin,this.clientMetadataValue=r.clientMetadata,this.configuredScope=r.configuredScope,this.scopeDelimiter=r.scopeDelimiter,this.configuredClientInformation=r.configuredClientInformation,r.clientMetadataUrl!==void 0&&(this.clientMetadataUrl=r.clientMetadataUrl),this.connection=t.connection,this.pendingState=t.pendingState?{...t.pendingState}:void 0,this.encryptedClientInformation=Rd(t,this.configuredClientInformation),this.encryptedDiscoveryState=bd(t)}get authorizationUrl(){return this.authorizationUrlValue}get redirectUrl(){return this.redirectUriValue}get clientMetadata(){return gd(this.clientMetadataValue,this.readEffectiveScope())}async state(){let t=await this.createPendingState();return Vo({id:t.id,...je({owner:this.target.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId})})}async clientInformation(){return this.configuredClientInformation?this.configuredClientInformation:this.loadPersistedClientInformation()}async saveClientInformation(t){this.configuredClientInformation||(this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.encryptedClientInformation=await ia(t),await this.syncPendingState(!1))}async discoveryState(){return this.loadPersistedDiscoveryState()}applyChallengeScope(t){this.challengeScope=t}async saveDiscoveryState(t){this.cachedDiscoveryState=t,this.discoveryStateLoaded=!0,this.inferredScope=ca(t,this.scopeDelimiter),this.encryptedDiscoveryState=await ia(t),await this.syncPendingState(!1)}async tokens(){return this.loadStoredTokens()}async saveTokens(t){let r=xe.parse(t),o=this.target.owner.mode==="user"?this.target.owner.subjectId:void 0,a=r.refresh_token?await Tt(r.refresh_token):this.connection?.encryptedRefreshToken;this.cachedTokens=r.refresh_token||!this.connection?.encryptedRefreshToken?r:xe.parse({...r,refresh_token:await rt(this.connection.encryptedRefreshToken)}),this.tokensLoaded=!0;let i={id:this.connection?.id??io(),ownerMode:this.target.owner.mode,subjectId:o,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,status:"active",encryptedAccessToken:await Tt(r.access_token),encryptedRefreshToken:a,scopes:dd(r.scope??this.readEffectiveScope()),expiresAt:pd(r),metadata:this.readStoredOAuthPersistence(this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0)};this.connection=await S().upsertUpstreamConnection(i)}async redirectToAuthorization(t){ud({authorizationUrl:t,upstreamServerId:this.target.upstreamServerId}),this.authorizationUrlValue=t.toString()}async saveCodeVerifier(t){let r=await this.createPendingState();await this.persistPendingState({...r,codeVerifier:ld(t)})}async codeVerifier(){if(!this.pendingState?.codeVerifier)throw new g({message:"OAuth code verifier is missing",extensionMembers:{[_]:"oauth_state_invalid"}});return this.pendingState.codeVerifier}async invalidateCredentials(t){let r=t==="all"||t==="client"||t==="tokens",o=t==="all"||t==="client",a=t==="all"||t==="discovery",i=t==="all"||t==="verifier";o&&(this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,this.encryptedClientInformation=void 0),a&&(this.cachedDiscoveryState=void 0,this.discoveryStateLoaded=!0,this.encryptedDiscoveryState=void 0,this.challengeScope=void 0,this.inferredScope=void 0),r&&(this.cachedTokens=void 0,this.tokensLoaded=!0),await this.syncPendingState(i),await this.persistCredentialInvalidation(r)}async createPendingState(){if(this.pendingState)return this.pendingState;let t={id:so(),...je({owner:this.target.owner,initiatedBySubjectId:this.target.initiatedBySubjectId,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,operationId:this.target.operationId,...this.target.returnTo===void 0?{}:{returnTo:this.target.returnTo}}),callbackPath:new URL(this.redirectUriValue).pathname,expiresAt:b(new Date(Date.now()+Ko)),redirectUri:this.redirectUriValue,...this.returnOrigin===void 0?{}:{returnOrigin:this.returnOrigin},encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState,connectedBySubjectId:this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0};return await this.persistPendingState(t),t}async persistPendingState(t){await S().saveUpstreamOAuthState({record:t}),this.pendingState=t}async syncPendingState(t){this.pendingState&&await this.persistPendingState({...this.pendingState,codeVerifier:t?void 0:this.pendingState.codeVerifier,encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState})}async loadPersistedClientInformation(){if(this.clientInformationLoaded)return this.cachedClientInformation;let t;try{t=await sa(this.encryptedClientInformation,od)}catch{this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}if(t&&!fd(t,this.redirectUriValue)){this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1);return}return this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.cachedClientInformation}async loadPersistedDiscoveryState(){if(this.discoveryStateLoaded)return this.cachedDiscoveryState;try{this.cachedDiscoveryState=md(await sa(this.encryptedDiscoveryState,ad))}catch{this.encryptedDiscoveryState=void 0,this.cachedDiscoveryState=void 0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1)}return this.discoveryStateLoaded=!0,this.inferredScope=ca(this.cachedDiscoveryState,this.scopeDelimiter),this.cachedDiscoveryState}readEffectiveScope(){return this.configuredScope??this.challengeScope??this.inferredScope}async loadStoredTokens(){if(this.tokensLoaded)return this.cachedTokens;if(this.tokensLoaded=!0,!this.connection||this.connection.status!=="active")return;let t=this.connection.encryptedAccessToken?await rt(this.connection.encryptedAccessToken):void 0,r=this.connection.encryptedRefreshToken?await rt(this.connection.encryptedRefreshToken):void 0;if(!t&&!r)return;let o=xe.parse({access_token:t??sd,token_type:id,refresh_token:r,scope:this.connection.scopes.length>0?this.connection.scopes.join(" "):void 0});return this.cachedTokens=o,o}async persistCredentialInvalidation(t){if(!this.connection)return;let r={id:this.connection.id,ownerMode:this.connection.ownerMode,subjectId:this.connection.subjectId,upstreamServerId:this.connection.upstreamServerId,authProfileId:this.connection.authProfileId,status:this.connection.status,encryptedAccessToken:this.connection.encryptedAccessToken,encryptedRefreshToken:this.connection.encryptedRefreshToken,scopes:[...this.connection.scopes],expiresAt:this.connection.expiresAt,metadata:this.connection.metadata?{...this.connection.metadata}:void 0};t&&(r.status="reconsent_required",r.encryptedAccessToken=void 0,r.encryptedRefreshToken=void 0,r.scopes=[],r.expiresAt=void 0),r.metadata=this.readStoredOAuthPersistence(this.connection.metadata?.connectedBySubjectId),this.connection=await S().upsertUpstreamConnection(r)}readStoredOAuthPersistence(t){if(!(!this.encryptedClientInformation&&!this.encryptedDiscoveryState&&!t))return{encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState,connectedBySubjectId:t}}};var Sd=3e4,Cd=256*1024,vd=2;function Id(e){return!e||e.status!=="active"||!e.encryptedAccessToken?!1:e.expiresAt?new Date(e.expiresAt).getTime()>Date.now():!0}n(Id,"hasUsableAccessToken");var xd="does not support dynamic client registration",Ad=["Resource server does not implement OAuth 2.0 Protected Resource Metadata","trying to load well-known OAuth protected resource metadata"],Ud=["HTTP 403 Forbidden","Access Denied","permission to access"];function kd(e){return e instanceof Error&&e.message.includes(xd)}n(kd,"isDynamicClientRegistrationUnsupported");function Td(e){return e instanceof Error&&Ad.some(t=>e.message.includes(t))}n(Td,"isProtectedResourceMetadataUnavailable");function Pd(e){return e instanceof Error&&Ud.some(t=>e.message.includes(t))}n(Pd,"isUpstreamProviderAccessDenied");function Ed(e){if(e.error instanceof g&&e.error.extensionMembers?.[_]!==void 0)return e.error;if(kd(e.error))return new g({message:`The authorization server for ${e.upstreamServerId} does not advertise Client ID Metadata Document support and does not support Dynamic Client Registration. Register an OAuth client for the gateway manually before retrying.`,extensionMembers:{[_]:"upstream_client_registration_required"}},{cause:e.error});if(Td(e.error))return new g({message:`The upstream MCP server "${e.upstreamServerId}" does not publish OAuth protected resource metadata at "${e.resourceMetadataUrl}". Configure protectedResourceMetadataUrl to a working metadata document, use a provider-supported legacy client, or contact the provider to approve/allowlist this gateway OAuth client before retrying.`,extensionMembers:{[_]:"upstream_oauth_discovery_unavailable"}},{cause:e.error});if(Pd(e.error))return new g({message:`The upstream provider denied access while connecting ${e.upstreamServerId}. Confirm the provider allows this gateway and its OAuth client, then retry.`,extensionMembers:{[_]:"upstream_provider_access_denied"}},{cause:e.error})}n(Ed,"mapUpstreamOAuthSetupError");function Od(e){return typeof e=="string"||e instanceof URL?{url:new URL(e.toString())}:{method:e.method,url:new URL(e.url)}}n(Od,"readOAuthFetchRequest");function qd(e,t){return(e.headers.get("content-type")??"").includes("json")||t.trimStart().startsWith("{")||t.trimStart().startsWith("[")}n(qd,"responseLooksJson");function Md(e,t){let r=e.headers.get("content-type")??"",o=t.trimStart().toLowerCase();return r.includes("html")||o.startsWith("<!doctype html")||o.startsWith("<html")}n(Md,"responseLooksHtml");function Dd(e){let t=e.response.statusText?` ${e.response.statusText}`:"",r=e.response.headers.get("content-type")??"text/html";throw new g({message:`The upstream provider returned ${e.response.status}${t} (${r}) from ${e.request.url.toString()} while connecting ${e.upstreamServerId}.`,extensionMembers:{[_]:e.response.status===403?"upstream_provider_access_denied":"upstream_token_exchange_failed",[Ce]:e.response.status,[be]:r,[ve]:e.request.url.toString(),[Se]:e.body}})}n(Dd,"throwUpstreamHtmlError");function ua(e){return async(t,r)=>{let o=Od(t),a=await fo(t,r,{maxRedirects:vd,maxResponseBytes:Cd,problemCode:"upstream_token_exchange_failed",timeoutMs:Sd}),i=await a.clone().text();if(!a.ok&&Md(a,i)&&Dd({upstreamServerId:e,request:o,response:a,body:i}),!qd(a,i))return a;try{JSON.parse(i)}catch(s){throw new g({message:`Upstream OAuth fetch ${o.url.origin}${o.url.pathname} for ${e} returned invalid JSON.`,extensionMembers:{[_]:"upstream_token_exchange_failed"}},{cause:s})}return a}}n(ua,"createUpstreamOAuthFetch");async function la(e,t){e.applyChallengeScope(t.requestedScope);try{let r={serverUrl:t.serverUrl,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:ua(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),await lr(e,r)}catch(r){let o=Ed({upstreamServerId:t.upstreamServerId,resourceMetadataUrl:t.resourceMetadataUrl,error:r});throw o!==void 0?o:r}}n(la,"runUpstreamOAuth");async function Hd(e,t){e.applyChallengeScope(t.requestedScope);let r={serverUrl:t.serverUrl,authorizationCode:t.authorizationCode,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:ua(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),lr(e,r)}n(Hd,"exchangeUpstreamAuthorizationCode");async function pa(e,t){let r=await la(e,t);if(r==="REDIRECT"&&e.authorizationUrl)return e.authorizationUrl;throw r==="AUTHORIZED"?new g({message:`OAuth connect flow reused existing credentials instead of producing a redirect for ${t.upstreamServerId}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}}):new g({message:`Unexpected OAuth result for ${t.upstreamServerId}: ${r}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}})}n(pa,"requireUpstreamAuthorizationRedirect");async function ma(e){if(!e.forceRefresh&&Id(e.connection))return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};let t=await la(e.provider,{upstreamServerId:e.target.upstreamServerId,serverUrl:e.serverUrl,resourceMetadataUrl:e.resourceMetadataUrl,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope}});if(t==="AUTHORIZED")return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};if(t!=="REDIRECT")throw new g({message:`Unexpected OAuth result for ${e.target.upstreamServerId}: ${t}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}});if(!e.provider.authorizationUrl)throw new g({message:`OAuth connect-required flow did not produce a redirect for ${e.target.upstreamServerId}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}});return{kind:"connect_required",payload:await Nd({requestUrl:e.target.request.url,requestHeaders:e.target.request.headers,connection:e.connection,owner:e.target.owner,initiatedBySubjectId:e.target.initiatedBySubjectId,upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.target.operationId,...e.target.returnTo===void 0?{}:{returnTo:e.target.returnTo}})}}n(ma,"authorizeUpstreamOAuthSession");async function zd(e){let t=await Ut(e.stateToken),r=await S().consumeUpstreamOAuthState({id:t.id,now:b(new Date)}),o=Bd(r);return jd({storedState:o,signedState:t,upstreamServerId:e.upstreamServerId,callbackPath:new URL(e.request.url).pathname}),Ld(o),o}n(zd,"consumeStoredCallbackState");function Bd(e){switch(e.kind){case"consumed":throw new g({message:"OAuth state has already been used",extensionMembers:{[_]:"oauth_state_reused"}});case"missing":throw new g({message:"OAuth state is missing or expired",extensionMembers:{[_]:"oauth_state_expired"}});case"available":return e.record}}n(Bd,"readConsumedCallbackState");function jd(e){if(![e.storedState.ownerMode===e.signedState.ownerMode,e.storedState.initiatedBySubjectId===e.signedState.initiatedBySubjectId,e.storedState.ownerSubjectId===e.signedState.ownerSubjectId,e.storedState.upstreamServerId===e.signedState.upstreamServerId,e.storedState.authProfileId===e.signedState.authProfileId,e.storedState.operationId===e.signedState.operationId,e.storedState.upstreamServerId===e.upstreamServerId,e.storedState.callbackPath===e.callbackPath].every(Boolean))throw new g({message:"OAuth callback did not match the initiating request",extensionMembers:{[_]:"oauth_callback_mismatch"}})}n(jd,"assertStoredCallbackStateMatches");function Ld(e){if(new Date(e.expiresAt).getTime()<=Date.now())throw new g({message:"OAuth state has expired",extensionMembers:{[_]:"oauth_state_expired"}})}n(Ld,"assertStoredCallbackStateFresh");async function Nd(e){if(e.owner.mode==="shared"){let r={upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.operationId,requiresReconsent:!!e.connection};return e.connection!==void 0&&(r.connectionId=e.connection.id),ea(r)}let t={requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.operationId,subject:"tool",requiresReconsent:!!e.connection,...e.returnTo===void 0?{}:{returnTo:e.returnTo}};return e.connection!==void 0&&(t.connectionId=e.connection.id),kt(t)}n(Nd,"buildOAuthConnectRequiredResponse");async function fa(e){let t=await zd({request:e.request,upstreamServerId:e.upstreamServerId,stateToken:e.stateToken}),r=wt(t),[o]=await S().batchGetUpstreamConnections([{owner:r,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId}]),a={target:{owner:r,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,...t.returnTo===void 0?{}:{returnTo:t.returnTo}},redirectUri:t.redirectUri,pendingState:t};o!==void 0&&(a.connection=o);let i=new ye(a),s=await Hd(i,{upstreamServerId:e.upstreamServerId,serverUrl:e.upstreamServerConfig.transport.baseUrl,authorizationCode:e.authorizationCode,resourceMetadataUrl:e.upstreamServerConfig.transport.resourceMetadataUrl});if(s==="AUTHORIZED")return t;throw s!=="REDIRECT"?new g({message:`Unexpected OAuth result for ${e.upstreamServerId}: ${s}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}}):new g({message:`OAuth callback flow did not finish authorization for ${e.upstreamServerId}`,extensionMembers:{[_]:"upstream_token_exchange_failed"}})}n(fa,"finishUpstreamOAuthCallback");async function ha(e){let t=ne(e.upstreamServerId),r=ge(e.upstreamServerId,e.authProfileId),o=ta(r.redirectPath,e.request.url,e.request.headers),a="preloadedConnection"in e?e.preloadedConnection:(await S().batchGetUpstreamConnections([{owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}]))[0];return{upstreamServerConfig:t,connection:a,providerInput:{target:{owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.returnTo===void 0?{}:{returnTo:e.returnTo}},redirectUri:o,returnOrigin:U(e.request.url,e.request.headers)}}}n(ha,"prepareUpstreamOAuthRequest");async function ga(e){let t=await ha(e),r=new ye({...t.providerInput,...t.connection?.metadata===void 0?{}:{connectionMetadata:t.connection.metadata}});return pa(r,{upstreamServerId:e.upstreamServerId,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(ga,"startUpstreamConnect");async function ya(e){let t=await ha(e),r=new ye({...t.providerInput,...t.connection===void 0?{}:{connection:t.connection}});return ma({target:e,provider:r,connection:t.connection,forceRefresh:e.forceRefresh,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope},upstreamDisplayName:t.upstreamServerConfig.displayName,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(ya,"authorizeUpstreamRequest");async function ke(e){let{routeAuth:t}=e;switch(t.authMode){case"shared-oauth":case"user-oauth":return ya({request:e.request,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,forceRefresh:e.forceRefresh,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope},...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},...t.returnTo===void 0?{}:{returnTo:t.returnTo}})}let r=t;throw new D(`Unsupported upstream auth route context ${JSON.stringify(r)}.`)}n(ke,"resolveUpstreamCredentialForRoute");async function _a(e){let t,r={request:e.request,owner:e.connectRequest.owner,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,upstreamServerId:e.connectRequest.upstreamServerId,authProfileId:e.connectRequest.authProfileId,operationId:e.connectRequest.operationId,...e.connectRequest.returnTo===void 0?{}:{returnTo:e.connectRequest.returnTo}},o=G(e.connectRequest.authMode);switch(o.connectSupport){case"oauth_authorization":t=await ga(r);break;case"none":throw new D(o.connectUnsupportedDetail??`Upstream server ${e.connectRequest.upstreamServerId} does not support browser connection flows.`)}return{authProfileId:e.connectRequest.authProfileId,authUrl:t,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,owner:e.connectRequest.owner,upstreamDisplayName:e.connectRequest.upstreamDisplayName,operationId:e.connectRequest.operationId}}n(_a,"startUpstreamConnectForRequest");async function wa(e){let r=(await Ut(e.callbackRequest.state)).authProfileId,o=yr({upstreamServerId:e.callbackRequest.upstreamServerId,authProfileId:r});if(G(o.mode).callbackSupport!=="authorization_code")throw new D(`Upstream server ${e.callbackRequest.upstreamServerId} does not support OAuth callbacks.`);return fa({request:e.request,upstreamServerId:e.callbackRequest.upstreamServerId,authorizationCode:e.callbackRequest.code,stateToken:e.callbackRequest.state,upstreamServerConfig:ne(e.callbackRequest.upstreamServerId)})}n(wa,"finishUpstreamCallbackForRequest");function $d(e){let t=G(e.connection.authMode);return{upstreamServerId:e.connection.upstreamServerId,operationId:e.operationId,authProfileId:e.connection.authProfileId,upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:t.ownerMode}}n($d,"buildRouteAuthBaseFromConnection");function ba(e){let t=G(e.connection.authMode);return{upstreamServerId:e.connection.id,operationId:e.operationId,authProfileId:ht(e.connection.id,e.connection.authMode),upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:t.ownerMode}}n(ba,"buildRouteAuthBaseFromPolicyOptions");function Pt(e,t){let o=$().byOperationId.get(t);if(!o)throw new P(`Unknown MCP route "${t}". Ensure routes.oas.json declares this operationId before starting an upstream connection flow.`);if(o.connection===void 0)throw new P(`MCP route "${t}" does not declare an MCP token exchange policy. Add one before starting an upstream connection flow.`);if(o.connection.upstreamServerId!==e)throw new P(`MCP route "${t}" does not bind upstream "${e}". Check the route's MCP upstream policies and bind the upstream before starting an upstream connection flow.`);return $d({connection:o.connection,operationId:t})}n(Pt,"resolveRouteAuthBase");function Ra(e,t){switch(e){case"user":return _t(t);case"shared":return to()}}n(Ra,"buildOwnerForSubject");function Te(e,t){switch(e.ownerMode){case"shared":return{...e,owner:Ra(e.ownerMode,t),initiatedBySubjectId:t};case"user":return{...e,owner:Ra(e.ownerMode,t),initiatedBySubjectId:t}}}n(Te,"resolveRouteAuthForSubject");var Gd=Be.InvalidRequest,Zd=new Set(["connection","keep-alive","proxy-authenticate","te","trailer","transfer-encoding","upgrade"]);function Fd(e,t){return{credentialType:e.type,forceRefresh:t,...e.type==="headers"?{headerNames:Object.keys(e.headers).sort()}:{}}}n(Fd,"buildCredentialResolvedAttributes");function Kd(e){switch(e){case"admin_connect_required":return"admin_connect_required";case"authenticating":return"connect_required"}}n(Kd,"connectRequiredReasonCode");function Sa(e){C(e.context,{eventType:R.MCP_AUTH_UPSTREAM_CREDENTIAL_RESOLVED,outcome:"success",routeBinding:e.routeBinding,attributes:Fd(e.credential,e.forceRefresh===!0)})}n(Sa,"emitCredentialResolvedAnalyticsEvent");function Ca(e){let t={forceRefresh:e.forceRefresh===!0,nextAction:e.payload.nextAction,state:e.payload.state};if(C(e.context,{eventType:R.MCP_AUTH_UPSTREAM_CREDENTIAL_MISSING,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"connect_required",reasonClass:"auth",attributes:t}),e.payload.state==="reconsent_required"){C(e.context,{eventType:R.MCP_AUTH_UPSTREAM_RECONSENT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"reconsent_required",reasonClass:"auth",attributes:t});return}C(e.context,{eventType:R.MCP_AUTH_UPSTREAM_CONNECT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:Kd(e.payload.state),reasonClass:"auth",attributes:t})}n(Ca,"emitCredentialMissingAnalyticsEvents");function Jd(e){let t=e.route.raw();return pt.parse(t?.operationId)}n(Jd,"readOperationId");async function Wd(e,t,r,o){let a=await ke({request:e,routeAuth:t});if(a.kind==="connect_required")return Ca({context:o,payload:a.payload,routeBinding:t}),o.log.info({event:"mcp_upstream_connect_required",upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId},"MCP upstream proxy: upstream connection required"),{kind:"connect_required",payload:a.payload};let i=a.credential;switch(Sa({context:o,credential:i,routeBinding:t}),i.type){case"none":return{kind:"headers",headers:[]};case"bearer_token":return{kind:"headers",headers:[["authorization",`Bearer ${i.token}`]]};case"headers":return{kind:"headers",headers:Object.entries(i.headers)};case"mcp_oauth_provider":{let s=await i.provider.tokens();return s?{kind:"headers",headers:[["authorization",`${s.token_type??"Bearer"} ${s.access_token}`]]}:(o.log.warn({event:"mcp_upstream_no_tokens",upstreamServerId:t.upstreamServerId},"MCP upstream proxy: OAuth provider returned no tokens"),Response.json({error:"no_upstream_tokens"},{status:401}))}}}n(Wd,"buildCredentialHeaders");var Vd=new Set(["authorization","cookie","cookie2"]);function Yd(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return t&&typeof t=="object"&&!Array.isArray(t)&&"method"in t&&typeof t.method=="string"?t.method:void 0}catch{return}}n(Yd,"readJsonRequestMethod");function Xd(e){let t=e.headers.get("content-type")??"";return/\bapplication\/(?:[\w.+-]+\+)?json\b/i.test(t)}n(Xd,"isJsonResponse");function Ir(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(Ir,"isRecord");function Qd(e){return Array.isArray(e)&&e.length>0}n(Qd,"hasIconList");function eu(e){if(e.connection.serverInfo?.icons!==void 0&&e.connection.serverInfo.icons.length>0)return e.connection.serverInfo.icons;try{let t=xt(vn(e.context.route.handler));return t===void 0?void 0:[t]}catch{return}}n(eu,"readFallbackServerIcons");function tu(e){if(!Ir(e.body))return e.body;let t=e.body.result;if(!Ir(t))return e.body;let r=t.serverInfo;return!Ir(r)||Qd(r.icons)?e.body:{...e.body,result:{...t,serverInfo:{...r,icons:e.icons}}}}n(tu,"addMissingServerIcons");function ru(e,t){let r=new Headers(e.headers);for(let o of Vd)r.delete(o);for(let[o,a]of t)r.set(o,a);return new sn(e,{headers:r})}n(ru,"applyUpstreamHeaders");function nu(e){let t=new Headers(e.headers);for(let r of Zd)t.delete(r);return t}n(nu,"buildProxyHeaders");async function ou(e){if(!(e.method==="GET"||e.method==="HEAD"))return e.clone().arrayBuffer()}n(ou,"readRetryBody");function va(e,t){let r=t.authUrl===void 0?void 0:_o({message:t.message,elicitationId:["connect",t.operationId,t.upstreamServerId,t.authProfileId].join(":"),url:t.authUrl});return Response.json(St({id:yo(e),error:{code:r?.code??Gd,message:t.message,data:{...r?.data??{},connectRequired:t}}}))}n(va,"connectRequiredJsonRpcResponse");async function au(e){let{scope:t}=To(e.upstreamResponse),r=await ke({request:e.request,routeAuth:e.routeAuth,forceRefresh:!0,...t===void 0?{}:{requestedScope:t}});if(r.kind==="connect_required")return Ca({context:e.context,payload:r.payload,routeBinding:e.routeAuth,forceRefresh:!0}),{kind:"connect_required",payload:r.payload};let o=new Headers(e.headers),a=r.credential;switch(Sa({context:e.context,credential:a,routeBinding:e.routeAuth,forceRefresh:!0}),a.type){case"none":return o.delete("authorization"),{kind:"headers",headers:o};case"bearer_token":return o.set("authorization",`Bearer ${a.token}`),{kind:"headers",headers:o};case"headers":for(let[i,s]of Object.entries(a.headers))o.set(i,s);return{kind:"headers",headers:o};case"mcp_oauth_provider":{let i=await a.provider.tokens();return i?(o.set("authorization",`${i.token_type??"Bearer"} ${i.access_token}`),{kind:"headers",headers:o}):(e.context.log.warn({event:"mcp_upstream_no_tokens_after_refresh",upstreamServerId:e.routeAuth.upstreamServerId},"MCP upstream proxy: OAuth provider returned no tokens after refresh"),{kind:"response",response:Response.json({error:"no_upstream_tokens"},{status:401})})}}}n(au,"applyRefreshedCredentialHeaders");function iu(e){e.context.addResponseSendingHook(async(t,r)=>{if(t.status!==401)return t;let o=await au({request:e.request,context:e.context,headers:nu(r),routeAuth:e.routeAuth,upstreamResponse:t});if(o.kind==="connect_required")return va(e.requestBody,o.payload);if(o.kind==="response")return o.response;let a=In({handler:e.context.route.handler,request:r,body:e.requestBody,headers:o.headers});return ct.fetch(a.url,a.init)})}n(iu,"installUpstreamAuthRetryHook");function su(e){if(Yd(e.requestBody)!=="initialize")return;let t=eu({connection:e.connection,context:e.context});t===void 0||t.length===0||e.context.addResponseSendingHook(async r=>{if(!Xd(r))return r;let o;try{o=await r.clone().json()}catch{return r}let a=tu({body:o,icons:t});if(a===o)return r;let i=new Headers(r.headers);return i.delete("content-length"),new Response(JSON.stringify(a),{status:r.status,statusText:r.statusText,headers:i})})}n(su,"installInitializeIconHook");async function xr(e,t,r){let o=Jd(t),a=await ou(e),i=ba({connection:r,operationId:o}),s=Ie(e.user,e.url,e.headers);jn(t,s);let c=Te(i,s.subjectId),l=await Wd(e,c,r,t);if(!(l instanceof Response)&&l.kind==="connect_required")return va(a,l.payload);if(l instanceof Response)return l;let m=ru(e,l.headers);return iu({request:m,context:t,requestBody:a,routeAuth:c}),su({context:t,requestBody:a,connection:r}),m}n(xr,"mcpTokenExchangePolicy");var Ar=class extends ut{static{n(this,"McpTokenExchangeInboundPolicy")}constructor(t,r){let o=Pn(t,r);super(o,r)}async handler(t,r){return dt("policy.inbound.mcp-token-exchange"),xr(t,r,this.options)}};B();var Ia=Symbol("Html");function cu(e){return e.replaceAll("&","&").replaceAll("<","<").replaceAll(">",">").replaceAll('"',""").replaceAll("'","'")}n(cu,"escapeHtml");function du(e){return e===null||typeof e!="object"?!1:e[Ia]===!0}n(du,"isHtml");function Et(e){return e==null||e===!1?"":Array.isArray(e)?e.map(Et).join(""):du(e)?e.value:cu(String(e))}n(Et,"renderValue");function F(e){return{[Ia]:!0,value:e}}n(F,"trustedHtml");var k=F("");function y(e,...t){let r=e[0]??"";for(let o=0;o<t.length;o+=1)r+=Et(t[o]),r+=e[o+1]??"";return F(r)}n(y,"html");function xa(e,t=k){let r=Et(t),o="",a=!0;for(let i of e)a||(o+=r),o+=Et(i),a=!1;return F(o)}n(xa,"joinHtml");function Pe(e){return e.value}n(Pe,"renderHtml");function Aa(e){return y`<p class="card__description">${e.detail}</p>${e.guidance} ${e.technicalDetails} ${e.action}`}n(Aa,"renderBrowserErrorPage");var Ee=F('*,:before,:after{box-sizing:border-box}:root{--bg:#f5f6f8;--surface:#fff;--surface-2:#f8fafc;--border:#e5e7eb;--border-strong:#d1d5db;--text:#0f172a;--text-2:#475569;--text-3:#64748b;--text-muted:#94a3b8;--accent:#0f172a;--accent-hover:#1e293b;--accent-text:#fff;--focus-ring:#0f172a29;--danger:#b91c1c;--danger-bg:#b91c1c0f;--danger-border:#b91c1c38;--warning:#92400e;--warning-bg:#fffbeb;--warning-border:#fde68a;--success:#15803d;--success-bg:#f0fdf4;--success-border:#bbf7d0;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-pill:9999px;--shadow-sm:0 1px 2px #0f172a0d;--shadow:0 1px 2px #0f172a0a,0 6px 16px #0f172a0f;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,system-ui,sans-serif;--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Monaco,Consolas,monospace}@media (prefers-color-scheme:dark){:root{--bg:#0a0c10;--surface:#15171c;--surface-2:#1e2128;--border:#262932;--border-strong:#3a3e48;--text:#fafafa;--text-2:#cbd5e1;--text-3:#94a3b8;--text-muted:#71717a;--accent:#fafafa;--accent-hover:#e4e4e7;--accent-text:#0a0c10;--focus-ring:#fafafa2e;--danger:#f87171;--danger-bg:#f8717114;--danger-border:#f871714d;--warning:#fbbf24;--warning-bg:#fbbf2414;--warning-border:#fbbf2447;--success:#34d399;--success-bg:#34d39914;--success-border:#34d3994d;--shadow-sm:0 1px 2px #0006;--shadow:0 1px 2px #0006,0 8px 24px #0006}}html,body{margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:48px 20px;font-size:14px;line-height:1.5;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow);overflow:hidden}.card__head{text-align:center;padding:32px 32px 24px}.card__icon{border-radius:var(--radius);background:var(--surface-2);object-fit:contain;border:1px solid var(--border);width:48px;height:48px;margin:0 auto 16px;display:block}.card__title{letter-spacing:-.01em;color:var(--text);margin:0;font-size:20px;font-weight:600;line-height:1.3}.card__subtitle{color:var(--text-2);margin:8px 0 0;font-size:14px;line-height:1.55}.card__subtitle strong{color:var(--text);font-weight:600}.card__description{color:var(--text-3);margin:12px 0 0;font-size:13px;line-height:1.55}.card__principal{color:var(--text-3);background:var(--surface-2);border-radius:var(--radius-pill);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;max-width:100%;margin:16px 0 0;padding:4px 12px;font-size:12.5px;display:inline-flex;overflow:hidden}.card__body{flex-direction:column;gap:20px;padding:8px 32px 24px;display:flex}.card__head+.card__body{border-top:1px solid var(--border);padding-top:24px}.card__footer{border-top:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;padding:16px 24px;display:flex}.card__fineprint{color:var(--text-3);text-align:center;margin:0;font-size:12.5px;line-height:1.5}.card__fineprint strong{color:var(--text-2);font-weight:600}.section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);align-items:baseline;gap:6px;margin:0;font-size:11px;font-weight:600;display:flex}.section-label__count{color:var(--text-3);letter-spacing:0;font-weight:500}.banner{border-radius:var(--radius);border:1px solid;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;display:flex}.banner__icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-top:1px;display:inline-flex}.banner__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.banner__title{color:var(--text);margin:0;font-size:13px;font-weight:600}.banner__message{color:var(--text-2);margin:0;font-size:13px;line-height:1.5}.banner--warning{background:var(--warning-bg);border-color:var(--warning-border)}.banner--warning .banner__icon{color:var(--warning)}.banner--alert{background:var(--danger-bg);border-color:var(--danger-border)}.banner--alert .banner__icon,.banner--alert .banner__title{color:var(--danger)}.upstream-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.upstream-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:14px;display:flex}.upstream-card--needs-action{border-color:var(--warning-border);background:var(--warning-bg)}.upstream-card__head{align-items:flex-start;gap:10px;display:flex}.icon-frame{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);width:32px;height:32px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.icon-frame img{object-fit:contain;max-width:100%;max-height:100%}.icon-frame--fallback svg{width:18px;height:18px}.inline-icon{object-fit:contain;vertical-align:-2px;border-radius:2px;width:14px;height:14px;margin-right:4px}.upstream-card__main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.upstream-card__title-row{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.upstream-card__title{color:var(--text);letter-spacing:-.005em;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;font-size:14px;font-weight:600;line-height:1.3;overflow:hidden}.upstream-card__meta{color:var(--text-3);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.upstream-card__host{font-family:var(--font-mono);background:var(--surface-2);color:var(--text-2);border-radius:var(--radius-sm);padding:1px 6px;font-size:11.5px}.upstream-card__sep{color:var(--border-strong)}.upstream-card__description{color:var(--text-2);margin:4px 0 0;font-size:12.5px;line-height:1.5}.status-badge{border-radius:var(--radius-pill);white-space:nowrap;border:1px solid #0000;flex-shrink:0;align-items:center;gap:6px;padding:2px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.status-badge:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.status-badge--success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.status-badge--warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}.status-badge--neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}.upstream-card__capabilities,.upstream-card__scopes{border-top:1px solid var(--border);margin-top:2px;padding-top:10px}.upstream-card__capabilities--empty{color:var(--text-3);font-size:12px;font-style:italic}.capabilities-summary,.scopes-summary{cursor:pointer;user-select:none;color:var(--text-2);justify-content:space-between;align-items:center;gap:12px;padding:2px 0;font-size:12.5px;list-style:none;display:flex}.capabilities-summary::-webkit-details-marker,.scopes-summary::-webkit-details-marker{display:none}.capabilities-summary:hover,.scopes-summary:hover{color:var(--text)}.capabilities-summary:focus-visible,.scopes-summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.capabilities-summary__counts{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.count-pill{color:var(--text-2);align-items:baseline;gap:4px;font-size:12.5px;display:inline-flex}.count-pill__num{font-variant-numeric:tabular-nums;color:var(--text);font-size:13px;font-weight:600}.count-pill--destructive .count-pill__num,.count-pill--destructive .count-pill__label{color:var(--danger)}.capabilities-summary__chevron{color:var(--text-3);flex-shrink:0;transition:transform .15s;display:inline-flex}details[open]>.capabilities-summary .capabilities-summary__chevron,details[open]>.scopes-summary .capabilities-summary__chevron{transform:rotate(180deg)}.capabilities-detail{margin-top:10px}.capability-section{margin-top:14px}.capability-section:first-child{margin-top:6px}.capability-section__title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin:0 0 6px;font-size:11px;font-weight:600}.capability-list{flex-direction:column;gap:5px;margin:0;padding:0;font-size:12.5px;list-style:none;display:flex}.capability-row{flex-wrap:wrap;align-items:baseline;gap:6px;padding:2px 0;display:flex}.capability-row__name{font-weight:500;font-family:var(--font-mono);color:var(--text);font-size:12.5px}.capability-row__description{color:var(--text-3);flex-basis:100%;font-size:12px;line-height:1.45}.capability-row__description code{font-family:var(--font-mono);background:var(--surface-2);border-radius:var(--radius-sm);color:var(--text-2);padding:1px 4px}.capability-row--more{color:var(--text-3);font-size:12px;font-style:italic}.scopes-list{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.scope-chip{font-family:var(--font-mono);background:var(--surface-2);color:var(--text-2);border-radius:var(--radius-sm);border:1px solid var(--border);padding:2px 7px;font-size:11.5px}.badge{border-radius:var(--radius-sm);letter-spacing:.04em;text-transform:uppercase;align-items:center;padding:1px 5px;font-size:10px;font-weight:600;display:inline-flex}.badge--destructive{background:var(--danger-bg);color:var(--danger)}.badge--muted{background:var(--surface-2);color:var(--text-3)}.badge-row{flex-wrap:wrap;gap:4px;display:inline-flex}.muted{color:var(--text-3)}.button{font:inherit;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s,color .12s,box-shadow .12s,transform 40ms;display:inline-flex}.button:active{transform:translateY(1px)}.button:focus-visible{box-shadow:0 0 0 3px var(--focus-ring);outline:0}.button--small{padding:5px 10px;font-size:12.5px}.button--primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.button--primary:hover:not(:disabled):not([aria-disabled=true]){background:var(--accent-hover);border-color:var(--accent-hover)}.button:disabled,.button[aria-disabled=true]{cursor:not-allowed;opacity:.55}.button:disabled:hover,.button[aria-disabled=true]:hover{background:var(--accent);border-color:var(--accent)}.button--secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.button--secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.button--block{width:100%}.reconnect-action{align-items:center;margin-right:auto;display:inline-flex;position:relative}.reconnect-button{gap:7px}.tooltip{width:16px;height:16px;color:var(--accent);background:color-mix(in srgb,var(--accent)8%,transparent);cursor:help;border:1.5px solid;border-radius:50%;justify-content:center;align-items:center;font-size:10.5px;font-weight:700;line-height:1;display:inline-flex;position:relative}.tooltip:after{content:attr(aria-label);z-index:10;border-radius:var(--radius-sm);background:var(--accent);width:280px;max-width:min(280px,100vw - 48px);color:var(--accent-text);box-shadow:var(--shadow);text-align:left;white-space:normal;opacity:0;pointer-events:none;padding:12px 14px;font-size:13px;font-weight:600;line-height:1.45;transition:opacity .12s;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%)}.tooltip:before{content:"";z-index:11;border-left:7px solid #0000;border-right:7px solid #0000;border-top:8px solid var(--accent);opacity:0;pointer-events:none;transition:opacity .12s;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}.tooltip:hover:after,.tooltip:hover:before,.tooltip:focus-visible:after,.tooltip:focus-visible:before{opacity:1}.form{flex-direction:column;gap:6px;display:flex}.form__label{color:var(--text);margin:8px 0 0;font-size:13px;font-weight:600;display:block}.form__label:first-child{margin-top:0}.form__input{box-sizing:border-box;border:1px solid var(--border-strong);border-radius:var(--radius);width:100%;font:inherit;background:var(--surface);color:var(--text);padding:9px 12px;font-size:14px;transition:border-color .12s,box-shadow .12s}.form__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring);outline:0}.form__note{color:var(--text-3);margin:4px 0 0;font-size:12.5px;line-height:1.5}.form__submit{margin-top:8px}.empty{text-align:center;color:var(--text-3);border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);padding:24px 16px;font-size:13px}.actions{gap:8px;margin:0;display:flex}@media (width<=480px){body{padding:0}.card{box-shadow:none;border-left:0;border-right:0;border-radius:0;min-height:100dvh}.card__head{padding:24px 20px 16px}.card__body{padding:16px 20px}.card__footer{flex-direction:column-reverse;align-items:stretch;padding:14px 20px}.card__footer .button{width:100%}.reconnect-action{justify-content:center;width:100%;margin-right:0}.reconnect-action .button{flex:1}.tooltip:after{left:auto;right:0;transform:none}}@media (prefers-reduced-motion:reduce){*{transition:none!important}}');function Oe(e){return y`<!doctype html><html lang="en"><head><meta charset="utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1" /><meta name="referrer" content="no-referrer" /><meta name="robots" content="noindex" /><title>${e.title}</title><link rel="icon" href="${e.iconHref}" /><style>
|
|
25
|
+
import{$ as V,A as xn,Aa as to,B as An,Ba as ro,C as Un,Ca as no,D as ft,Da as oo,E as kn,Ea as io,F as Tn,Fa as ao,G as Pn,Ga as b,H as En,Ha as v,I as On,Ia as Y,J as qn,Ja as I,K as N,Ka as so,L as Mn,La as vs,M as Dn,Ma as co,N as R,Na as uo,O as J,Oa as wt,P as U,Pa as lo,Q as zn,Qa as po,R as W,Sa as mo,T as Hn,Ta as fo,U as Bn,Ua as Rt,V as le,W as _,X as jn,Y as Ln,Z as Nn,_ as ht,a as fn,aa as Zt,b as ue,ba as Ft,c as hn,ca as Gn,d as B,da as $n,e as gn,ea as Kt,f as Ss,fa as Jt,g as yn,ga as Zn,h as _n,ha as P,i as wn,ia as Fn,j as y,ja as Kn,k as be,ka as Jn,l as Se,la as Wn,m as ve,ma as Wt,n as Ce,na as Vn,o as Rn,oa as Vt,p as bn,pa as Yt,q as j,qa as gt,r as Sn,ra as Ie,s as vn,sa as Yn,t as Cn,ta as Xn,u as lt,ua as yt,v as In,va as Qn,w as $t,wa as Xt,x as pt,xa as eo,y as mt,ya as je,z as Be,za as _t}from"../chunk-LU6CEICL.js";import{J as sn,L as u,M as cn,N as Gt,O as K,Q as dn,S as h,T as re,U as ut,_ as un,a as ct,ca as ln,da as pn,ea as d,fa as H,j as de,k as nn,m as on,ma as mn,q as an,s as dt}from"../chunk-J7JE2DD5.js";import"../chunk-JRXZBVXH.js";import{a as w}from"../chunk-4SACVMDH.js";import{$ as M,a as n,aa as g,ba as T,ca as rn,da as st}from"../chunk-ZIKV2LUM.js";H();function Cs(e){let t=mt.safeParse(e);return t.success?t.data.id:void 0}n(Cs,"parseJsonRpcRequestId");function ho(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return Cs(t)}catch{return}}n(ho,"readJsonRpcRequestIdFromBody");function bt(e){return xn.parse({jsonrpc:pt,...e.id===void 0?{}:{id:e.id},error:{code:e.error.code,message:e.error.message,...e.error.data===void 0?{}:{data:e.error.data}}})}n(bt,"jsonRpcErrorResponse");function go(e){return new Un([An.parse({mode:"url",message:e.message,elicitationId:e.elicitationId,url:e.url})],e.message)}n(go,"urlElicitationRequiredError");var St=d.record(d.string(),d.unknown()),Is=d.record(d.string(),d.unknown()),xs=d.object({name:d.string().min(1),description:d.string().min(1).optional(),annotations:Is.optional(),_meta:St.optional()}).strict(),As=d.object({name:d.string().min(1),description:d.string().min(1).optional(),_meta:St.optional()}).strict(),Us=d.object({uri:d.string().min(1),name:d.string().min(1).optional(),description:d.string().min(1).optional(),mimeType:d.string().min(1).optional(),_meta:St.optional()}).strict(),ks=d.object({uriTemplate:d.string().min(1),name:d.string().min(1).optional(),description:d.string().min(1).optional(),mimeType:d.string().min(1).optional(),_meta:St.optional()}).strict(),Ts=d.array(d.union([d.string(),xs])),Ps=d.array(d.union([d.string(),As])),Es=d.array(d.union([d.string(),Us])),Os=d.array(d.union([d.string(),ks])),qs=d.object({tools:Ts.optional(),prompts:Ps.optional(),resources:Es.optional(),resourceTemplates:Os.optional()}).strict(),er=[{option:"tools",listMethod:"tools/list",resultProperty:"tools",itemProperty:"name",directMethods:[{method:"tools/call",paramProperty:"name"}]},{option:"prompts",listMethod:"prompts/list",resultProperty:"prompts",itemProperty:"name",directMethods:[{method:"prompts/get",paramProperty:"name"}]},{option:"resources",listMethod:"resources/list",resultProperty:"resources",itemProperty:"uri",directMethods:[{method:"resources/read",paramProperty:"uri"}]},{option:"resourceTemplates",listMethod:"resources/templates/list",resultProperty:"resourceTemplates",itemProperty:"uriTemplate",directMethods:[]}];function Ms(e,t){return gn(qs,e,`MCP capability filter policy "${t}"`)}n(Ms,"parseMcpCapabilityFilterOptions");function E(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(E,"isRecord");function Ds(e,t){if(!E(e))return;let r=e[t];return typeof r=="string"?r:void 0}n(Ds,"readParamString");function tr(e){let t=e.id;return typeof t=="string"||typeof t=="number"||t===null?t:void 0}n(tr,"readRequestId");function Ro(e){return e===void 0?void 0:JSON.stringify(e)}n(Ro,"requestIdKey");function zs(e){let t={};for(let r of er){let o=e[r.option];if(o===void 0)continue;let i=new Map;for(let a of o){let s=Ls(a,r.itemProperty);s!==void 0&&i.set(s.key,s)}t[r.option]=i}return t}n(zs,"buildProjectionMaps");function rr(e){return er.find(t=>t.listMethod===e)}n(rr,"findListRule");function Hs(e){return e.requests.some(t=>{if(!E(t))return!1;let r=rr(t.method);return r!==void 0&&e.projectionMaps[r.option]!==void 0})}n(Hs,"shouldFilterListResponses");function Bs(e){for(let t of er){let r=e.projectionMaps[t.option];if(r!==void 0)for(let o of t.directMethods){if(e.request.method!==o.method)continue;let i=Ds(e.request.params,o.paramProperty);if(i!==void 0&&!r.has(i))return{id:tr(e.request)}}}}n(Bs,"findDisallowedDirectAccess");function js(e){return Response.json(bt({id:e,error:{code:Be.MethodNotFound,message:"Method not found"}}))}n(js,"methodNotFoundResponse");function Ls(e,t){if(typeof e=="string")return{key:e,overlay:{}};if(!E(e))return;let r=e[t];if(typeof r=="string")return{key:r,overlay:e}}n(Ls,"buildProjection");function yo(e){let t=e.base[e.property],r=e.overlay[e.property];return E(r)?E(t)?{...t,...r}:r:t}n(yo,"mergeRecordProperty");function Ns(e,t){let r={...e,...t.overlay},o=yo({base:e,overlay:t.overlay,property:"annotations"});o!==void 0&&(r.annotations=o);let i=yo({base:e,overlay:t.overlay,property:"_meta"});return i!==void 0&&(r._meta=i),r}n(Ns,"applyProjection");function _o(e,t,r){if(!E(e))return e;let o=e.result;if(!E(o))return e;let i=o[t.resultProperty];return!Array.isArray(i)||!i.every(a=>E(a)&&typeof a[t.itemProperty]=="string")?e:{...e,result:{...o,[t.resultProperty]:i.flatMap(a=>{if(!E(a))return[];let s=a[t.itemProperty];if(typeof s!="string")return[];let c=r.get(s);return c===void 0?[]:[Ns(a,c)]})}}}n(_o,"filterAndProjectItems");function Gs(e){let t=new Map;if(!Array.isArray(e))return t;for(let r of e){if(!E(r))continue;let o=rr(r.method),i=tr(r),a=Ro(i);o!==void 0&&a!==void 0&&t.set(a,o)}return t}n(Gs,"buildListRulesByResponseId");function $s(e){if(Array.isArray(e.responseBody)){let o=Gs(e.requestBody);return o.size===0?e.responseBody:e.responseBody.map(i=>{if(!E(i)||"error"in i)return i;let a=Ro(tr(i)),s=a===void 0?void 0:o.get(a),c=s===void 0?void 0:e.projectionMaps[s.option];return s===void 0||c===void 0?i:_o(i,s,c)})}if(!E(e.requestBody)||!E(e.responseBody)||"error"in e.responseBody)return e.responseBody;let t=rr(e.requestBody.method),r=t===void 0?void 0:e.projectionMaps[t.option];return t===void 0||r===void 0?e.responseBody:_o(e.responseBody,t,r)}n($s,"filterJsonRpcResponse");async function wo(e){return e.clone().json()}n(wo,"readJson");function Zs(e){return e.headers.get("content-type")?.includes("json")??!1}n(Zs,"isJsonResponse");var Qt=class extends dt{static{n(this,"McpCapabilityFilterInboundPolicy")}#e;constructor(t,r){let o=Ms(t,r);super(o,r),this.#e=zs(o)}async handler(t,r){ct("policy.inbound.mcp-capability-filter");let o;try{o=await wo(t)}catch{return t}let i=Array.isArray(o)?o:[o];for(let a of i){if(!E(a))continue;let s=Bs({request:a,projectionMaps:this.#e});if(s!==void 0)return js(s.id)}return Hs({requests:i,projectionMaps:this.#e})&&r.addResponseSendingHook(async a=>{if(!Zs(a))return a;let s;try{s=await wo(a)}catch{return a}let c=$s({requestBody:o,responseBody:s,projectionMaps:this.#e});if(c===s)return a;let l=new Headers(a.headers);return l.delete("content-length"),new Response(JSON.stringify(c),{status:a.status,statusText:a.statusText,headers:l})}),t}};var nr;nr=globalThis.crypto;async function Fs(e){return(await nr).getRandomValues(new Uint8Array(e))}n(Fs,"getRandomValues");async function Ks(e){let t="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~",r=Math.pow(2,8)-Math.pow(2,8)%t.length,o="";for(;o.length<e;){let i=await Fs(e-o.length);for(let a of i)a<r&&(o+=t[a%t.length])}return o}n(Ks,"random");async function Js(e){return await Ks(e)}n(Js,"generateVerifier");async function Ws(e){let t=await(await nr).subtle.digest("SHA-256",new TextEncoder().encode(e));return btoa(String.fromCharCode(...new Uint8Array(t))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}n(Ws,"generateChallenge");async function or(e){if(e||(e=43),e<43||e>128)throw`Expected a length between 43 and 128. Received ${e}.`;let t=await Js(e),r=await Ws(t);return{code_verifier:t,code_challenge:r}}n(or,"pkceChallenge");H();var k=cn().superRefine((e,t)=>{if(!URL.canParse(e))return t.addIssue({code:ln.custom,message:"URL must be parseable",fatal:!0}),sn}).refine(e=>{let t=new URL(e);return t.protocol!=="javascript:"&&t.protocol!=="data:"&&t.protocol!=="vbscript:"},{message:"URL cannot use javascript:, data:, or vbscript: scheme"}),vt=ut({resource:u().url(),authorization_servers:h(k).optional(),jwks_uri:u().url().optional(),scopes_supported:h(u()).optional(),bearer_methods_supported:h(u()).optional(),resource_signing_alg_values_supported:h(u()).optional(),resource_name:u().optional(),resource_documentation:u().optional(),resource_policy_uri:u().url().optional(),resource_tos_uri:u().url().optional(),tls_client_certificate_bound_access_tokens:K().optional(),authorization_details_types_supported:h(u()).optional(),dpop_signing_alg_values_supported:h(u()).optional(),dpop_bound_access_tokens_required:K().optional()}),Le=ut({issuer:u(),authorization_endpoint:k,token_endpoint:k,registration_endpoint:k.optional(),scopes_supported:h(u()).optional(),response_types_supported:h(u()),response_modes_supported:h(u()).optional(),grant_types_supported:h(u()).optional(),token_endpoint_auth_methods_supported:h(u()).optional(),token_endpoint_auth_signing_alg_values_supported:h(u()).optional(),service_documentation:k.optional(),revocation_endpoint:k.optional(),revocation_endpoint_auth_methods_supported:h(u()).optional(),revocation_endpoint_auth_signing_alg_values_supported:h(u()).optional(),introspection_endpoint:u().optional(),introspection_endpoint_auth_methods_supported:h(u()).optional(),introspection_endpoint_auth_signing_alg_values_supported:h(u()).optional(),code_challenge_methods_supported:h(u()).optional(),client_id_metadata_document_supported:K().optional()}),Vs=ut({issuer:u(),authorization_endpoint:k,token_endpoint:k,userinfo_endpoint:k.optional(),jwks_uri:k,registration_endpoint:k.optional(),scopes_supported:h(u()).optional(),response_types_supported:h(u()),response_modes_supported:h(u()).optional(),grant_types_supported:h(u()).optional(),acr_values_supported:h(u()).optional(),subject_types_supported:h(u()),id_token_signing_alg_values_supported:h(u()),id_token_encryption_alg_values_supported:h(u()).optional(),id_token_encryption_enc_values_supported:h(u()).optional(),userinfo_signing_alg_values_supported:h(u()).optional(),userinfo_encryption_alg_values_supported:h(u()).optional(),userinfo_encryption_enc_values_supported:h(u()).optional(),request_object_signing_alg_values_supported:h(u()).optional(),request_object_encryption_alg_values_supported:h(u()).optional(),request_object_encryption_enc_values_supported:h(u()).optional(),token_endpoint_auth_methods_supported:h(u()).optional(),token_endpoint_auth_signing_alg_values_supported:h(u()).optional(),display_values_supported:h(u()).optional(),claim_types_supported:h(u()).optional(),claims_supported:h(u()).optional(),service_documentation:u().optional(),claims_locales_supported:h(u()).optional(),ui_locales_supported:h(u()).optional(),claims_parameter_supported:K().optional(),request_parameter_supported:K().optional(),request_uri_parameter_supported:K().optional(),require_request_uri_registration:K().optional(),op_policy_uri:k.optional(),op_tos_uri:k.optional(),client_id_metadata_document_supported:K().optional()}),Ct=re({...Vs.shape,...Le.pick({code_challenge_methods_supported:!0}).shape}),xe=re({access_token:u(),id_token:u().optional(),token_type:u(),expires_in:pn.number().optional(),scope:u().optional(),refresh_token:u().optional()}).strip(),So=re({error:u(),error_description:u().optional(),error_uri:u().optional()}),bo=k.optional().or(un("").transform(()=>{})),Ys=re({redirect_uris:h(k),token_endpoint_auth_method:u().optional(),grant_types:h(u()).optional(),response_types:h(u()).optional(),client_name:u().optional(),client_uri:k.optional(),logo_uri:bo,scope:u().optional(),contacts:h(u()).optional(),tos_uri:bo,policy_uri:u().optional(),jwks_uri:k.optional(),jwks:dn().optional(),software_id:u().optional(),software_version:u().optional(),software_statement:u().optional()}).strip(),ir=re({client_id:u(),client_secret:u().optional(),client_id_issued_at:Gt().optional(),client_secret_expires_at:Gt().optional()}).strip(),Ne=Ys.merge(ir),Em=re({error:u(),error_description:u().optional()}).strip(),Om=re({token:u(),token_type_hint:u().optional()}).strip();function vo(e){let t=typeof e=="string"?new URL(e):new URL(e.href);return t.hash="",t}n(vo,"resourceUrlFromServerUrl");function Co({requestedResource:e,configuredResource:t}){let r=typeof e=="string"?new URL(e):new URL(e.href),o=typeof t=="string"?new URL(t):new URL(t.href);if(r.origin!==o.origin||r.pathname.length<o.pathname.length)return!1;let i=r.pathname.endsWith("/")?r.pathname:r.pathname+"/",a=o.pathname.endsWith("/")?o.pathname:o.pathname+"/";return i.startsWith(a)}n(Co,"checkResourceAllowed");var x=class extends Error{static{n(this,"OAuthError")}constructor(t,r){super(t),this.errorUri=r,this.name=this.constructor.name}toResponseObject(){let t={error:this.errorCode,error_description:this.message};return this.errorUri&&(t.error_uri=this.errorUri),t}get errorCode(){return this.constructor.errorCode}},Ge=class extends x{static{n(this,"InvalidRequestError")}};Ge.errorCode="invalid_request";var pe=class extends x{static{n(this,"InvalidClientError")}};pe.errorCode="invalid_client";var me=class extends x{static{n(this,"InvalidGrantError")}};me.errorCode="invalid_grant";var fe=class extends x{static{n(this,"UnauthorizedClientError")}};fe.errorCode="unauthorized_client";var $e=class extends x{static{n(this,"UnsupportedGrantTypeError")}};$e.errorCode="unsupported_grant_type";var Ze=class extends x{static{n(this,"InvalidScopeError")}};Ze.errorCode="invalid_scope";var Fe=class extends x{static{n(this,"AccessDeniedError")}};Fe.errorCode="access_denied";var X=class extends x{static{n(this,"ServerError")}};X.errorCode="server_error";var Ke=class extends x{static{n(this,"TemporarilyUnavailableError")}};Ke.errorCode="temporarily_unavailable";var Je=class extends x{static{n(this,"UnsupportedResponseTypeError")}};Je.errorCode="unsupported_response_type";var We=class extends x{static{n(this,"UnsupportedTokenTypeError")}};We.errorCode="unsupported_token_type";var Ve=class extends x{static{n(this,"InvalidTokenError")}};Ve.errorCode="invalid_token";var Ye=class extends x{static{n(this,"MethodNotAllowedError")}};Ye.errorCode="method_not_allowed";var Xe=class extends x{static{n(this,"TooManyRequestsError")}};Xe.errorCode="too_many_requests";var he=class extends x{static{n(this,"InvalidClientMetadataError")}};he.errorCode="invalid_client_metadata";var Qe=class extends x{static{n(this,"InsufficientScopeError")}};Qe.errorCode="insufficient_scope";var et=class extends x{static{n(this,"InvalidTargetError")}};et.errorCode="invalid_target";var Io={[Ge.errorCode]:Ge,[pe.errorCode]:pe,[me.errorCode]:me,[fe.errorCode]:fe,[$e.errorCode]:$e,[Ze.errorCode]:Ze,[Fe.errorCode]:Fe,[X.errorCode]:X,[Ke.errorCode]:Ke,[Je.errorCode]:Je,[We.errorCode]:We,[Ve.errorCode]:Ve,[Ye.errorCode]:Ye,[Xe.errorCode]:Xe,[he.errorCode]:he,[Qe.errorCode]:Qe,[et.errorCode]:et};function Xs(e){return["client_secret_basic","client_secret_post","none"].includes(e)}n(Xs,"isClientAuthMethod");var ar="code",sr="S256";function Qs(e,t){let r=e.client_secret!==void 0;return"token_endpoint_auth_method"in e&&e.token_endpoint_auth_method&&Xs(e.token_endpoint_auth_method)&&(t.length===0||t.includes(e.token_endpoint_auth_method))?e.token_endpoint_auth_method:t.length===0?r?"client_secret_basic":"none":r&&t.includes("client_secret_basic")?"client_secret_basic":r&&t.includes("client_secret_post")?"client_secret_post":t.includes("none")?"none":r?"client_secret_post":"none"}n(Qs,"selectClientAuthMethod");function ec(e,t,r,o){let{client_id:i,client_secret:a}=t;switch(e){case"client_secret_basic":tc(i,a,r);return;case"client_secret_post":rc(i,a,o);return;case"none":nc(i,o);return;default:throw new Error(`Unsupported client authentication method: ${e}`)}}n(ec,"applyClientAuthentication");function tc(e,t,r){if(!t)throw new Error("client_secret_basic authentication requires a client_secret");let o=btoa(`${e}:${t}`);r.set("Authorization",`Basic ${o}`)}n(tc,"applyBasicAuth");function rc(e,t,r){r.set("client_id",e),t&&r.set("client_secret",t)}n(rc,"applyPostAuth");function nc(e,t){t.set("client_id",e)}n(nc,"applyPublicAuth");async function Ao(e){let t=e instanceof Response?e.status:void 0,r=e instanceof Response?await e.text():e;try{let o=So.parse(JSON.parse(r)),{error:i,error_description:a,error_uri:s}=o,c=Io[i]||X;return new c(a||"",s)}catch(o){let i=`${t?`HTTP ${t}: `:""}Invalid OAuth error response: ${o}. Raw body: ${r}`;return new X(i)}}n(Ao,"parseErrorResponse");async function ur(e,t){try{return await cr(e,t)}catch(r){if(r instanceof pe||r instanceof fe)return await e.invalidateCredentials?.("all"),await cr(e,t);if(r instanceof me)return await e.invalidateCredentials?.("tokens"),await cr(e,t);throw r}}n(ur,"auth");async function cr(e,{serverUrl:t,authorizationCode:r,scope:o,resourceMetadataUrl:i,fetchFn:a}){let s=await e.discoveryState?.(),c,l,m,f=i;if(!f&&s?.resourceMetadataUrl&&(f=new URL(s.resourceMetadataUrl)),s?.authorizationServerUrl){if(l=s.authorizationServerUrl,c=s.resourceMetadata,m=s.authorizationServerMetadata??await To(l,{fetchFn:a}),!c)try{c=await ko(t,{resourceMetadataUrl:f},a)}catch{}(m!==s.authorizationServerMetadata||c!==s.resourceMetadata)&&await e.saveDiscoveryState?.({authorizationServerUrl:String(l),resourceMetadataUrl:f?.toString(),resourceMetadata:c,authorizationServerMetadata:m})}else{let q=await dc(t,{resourceMetadataUrl:f,fetchFn:a});l=q.authorizationServerUrl,m=q.authorizationServerMetadata,c=q.resourceMetadata,await e.saveDiscoveryState?.({authorizationServerUrl:String(l),resourceMetadataUrl:f?.toString(),resourceMetadata:c,authorizationServerMetadata:m})}let A=await oc(t,e,c),C=o||c?.scopes_supported?.join(" ")||e.clientMetadata.scope,L=await Promise.resolve(e.clientInformation());if(!L){if(r!==void 0)throw new Error("Existing OAuth client information is required when exchanging an authorization code");let q=m?.client_id_metadata_document_supported===!0,He=e.clientMetadataUrl;if(He&&!lr(He))throw new he(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${He}`);if(q&&He)L={client_id:He},await e.saveClientInformation?.(L);else{if(!e.saveClientInformation)throw new Error("OAuth client information must be saveable for dynamic registration");let tn=await fc(l,{metadata:m,clientMetadata:e.clientMetadata,scope:C,fetchFn:a});await e.saveClientInformation(tn),L=tn}}let Re=!e.redirectUrl;if(r!==void 0||Re){let q=await mc(e,l,{metadata:m,resource:A,authorizationCode:r,fetchFn:a});return await e.saveTokens(q),"AUTHORIZED"}let en=await e.tokens();if(en?.refresh_token)try{let q=await pc(l,{metadata:m,clientInformation:L,refreshToken:en.refresh_token,resource:A,addClientAuthentication:e.addClientAuthentication,fetchFn:a});return await e.saveTokens(q),"AUTHORIZED"}catch(q){if(!(!(q instanceof x)||q instanceof X))throw q}let ws=e.state?await e.state():void 0,{authorizationUrl:Rs,codeVerifier:bs}=await uc(l,{metadata:m,clientInformation:L,state:ws,redirectUrl:e.redirectUrl,scope:C,resource:A});return await e.saveCodeVerifier(bs),await e.redirectToAuthorization(Rs),"REDIRECT"}n(cr,"authInternal");function lr(e){if(!e)return!1;try{let t=new URL(e);return t.protocol==="https:"&&t.pathname!=="/"}catch{return!1}}n(lr,"isHttpsUrl");async function oc(e,t,r){let o=vo(e);if(t.validateResourceURL)return await t.validateResourceURL(o,r?.resource);if(r){if(!Co({requestedResource:o,configuredResource:r.resource}))throw new Error(`Protected resource ${r.resource} does not match expected ${o} (or origin)`);return new URL(r.resource)}}n(oc,"selectResourceURL");function Uo(e){let t=e.headers.get("WWW-Authenticate");if(!t)return{};let[r,o]=t.split(" ");if(r.toLowerCase()!=="bearer"||!o)return{};let i=dr(e,"resource_metadata")||void 0,a;if(i)try{a=new URL(i)}catch{}let s=dr(e,"scope")||void 0,c=dr(e,"error")||void 0;return{resourceMetadataUrl:a,scope:s,error:c}}n(Uo,"extractWWWAuthenticateParams");function dr(e,t){let r=e.headers.get("WWW-Authenticate");if(!r)return null;let o=new RegExp(`${t}=(?:"([^"]+)"|([^\\s,]+))`),i=r.match(o);return i?i[1]||i[2]:null}n(dr,"extractFieldFromWwwAuth");async function ko(e,t,r=fetch){let o=await sc(e,"oauth-protected-resource",r,{protocolVersion:t?.protocolVersion,metadataUrl:t?.resourceMetadataUrl});if(!o||o.status===404)throw await o?.body?.cancel(),new Error("Resource server does not implement OAuth 2.0 Protected Resource Metadata.");if(!o.ok)throw await o.body?.cancel(),new Error(`HTTP ${o.status} trying to load well-known OAuth protected resource metadata.`);return vt.parse(await o.json())}n(ko,"discoverOAuthProtectedResourceMetadata");async function pr(e,t,r=fetch){try{return await r(e,{headers:t})}catch(o){if(o instanceof TypeError)return t?pr(e,void 0,r):void 0;throw o}}n(pr,"fetchWithCorsRetry");function ic(e,t="",r={}){return t.endsWith("/")&&(t=t.slice(0,-1)),r.prependPathname?`${t}/.well-known/${e}`:`/.well-known/${e}${t}`}n(ic,"buildWellKnownPath");async function xo(e,t,r=fetch){return await pr(e,{"MCP-Protocol-Version":t},r)}n(xo,"tryMetadataDiscovery");function ac(e,t){return!e||e.status>=400&&e.status<500&&t!=="/"}n(ac,"shouldAttemptFallback");async function sc(e,t,r,o){let i=new URL(e),a=o?.protocolVersion??$t,s;if(o?.metadataUrl)s=new URL(o.metadataUrl);else{let l=ic(t,i.pathname);s=new URL(l,o?.metadataServerUrl??i),s.search=i.search}let c=await xo(s,a,r);if(!o?.metadataUrl&&ac(c,i.pathname)){let l=new URL(`/.well-known/${t}`,i);c=await xo(l,a,r)}return c}n(sc,"discoverMetadataWithFallback");function cc(e){let t=typeof e=="string"?new URL(e):e,r=t.pathname!=="/",o=[];if(!r)return o.push({url:new URL("/.well-known/oauth-authorization-server",t.origin),type:"oauth"}),o.push({url:new URL("/.well-known/openid-configuration",t.origin),type:"oidc"}),o;let i=t.pathname;return i.endsWith("/")&&(i=i.slice(0,-1)),o.push({url:new URL(`/.well-known/oauth-authorization-server${i}`,t.origin),type:"oauth"}),o.push({url:new URL(`/.well-known/openid-configuration${i}`,t.origin),type:"oidc"}),o.push({url:new URL(`${i}/.well-known/openid-configuration`,t.origin),type:"oidc"}),o}n(cc,"buildDiscoveryUrls");async function To(e,{fetchFn:t=fetch,protocolVersion:r=$t}={}){let o={"MCP-Protocol-Version":r,Accept:"application/json"},i=cc(e);for(let{url:a,type:s}of i){let c=await pr(a,o,t);if(c){if(!c.ok){if(await c.body?.cancel(),c.status>=400&&c.status<500)continue;throw new Error(`HTTP ${c.status} trying to load ${s==="oauth"?"OAuth":"OpenID provider"} metadata from ${a}`)}return s==="oauth"?Le.parse(await c.json()):Ct.parse(await c.json())}}}n(To,"discoverAuthorizationServerMetadata");async function dc(e,t){let r,o;try{r=await ko(e,{resourceMetadataUrl:t?.resourceMetadataUrl},t?.fetchFn),r.authorization_servers&&r.authorization_servers.length>0&&(o=r.authorization_servers[0])}catch{}o||(o=String(new URL("/",e)));let i=await To(o,{fetchFn:t?.fetchFn});return{authorizationServerUrl:o,authorizationServerMetadata:i,resourceMetadata:r}}n(dc,"discoverOAuthServerInfo");async function uc(e,{metadata:t,clientInformation:r,redirectUrl:o,scope:i,state:a,resource:s}){let c;if(t){if(c=new URL(t.authorization_endpoint),!t.response_types_supported.includes(ar))throw new Error(`Incompatible auth server: does not support response type ${ar}`);if(t.code_challenge_methods_supported&&!t.code_challenge_methods_supported.includes(sr))throw new Error(`Incompatible auth server: does not support code challenge method ${sr}`)}else c=new URL("/authorize",e);let l=await or(),m=l.code_verifier,f=l.code_challenge;return c.searchParams.set("response_type",ar),c.searchParams.set("client_id",r.client_id),c.searchParams.set("code_challenge",f),c.searchParams.set("code_challenge_method",sr),c.searchParams.set("redirect_uri",String(o)),a&&c.searchParams.set("state",a),i&&c.searchParams.set("scope",i),i?.includes("offline_access")&&c.searchParams.append("prompt","consent"),s&&c.searchParams.set("resource",s.href),{authorizationUrl:c,codeVerifier:m}}n(uc,"startAuthorization");function lc(e,t,r){return new URLSearchParams({grant_type:"authorization_code",code:e,code_verifier:t,redirect_uri:String(r)})}n(lc,"prepareAuthorizationCodeRequest");async function Po(e,{metadata:t,tokenRequestParams:r,clientInformation:o,addClientAuthentication:i,resource:a,fetchFn:s}){let c=t?.token_endpoint?new URL(t.token_endpoint):new URL("/token",e),l=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(a&&r.set("resource",a.href),i)await i(l,r,c,t);else if(o){let f=t?.token_endpoint_auth_methods_supported??[],A=Qs(o,f);ec(A,o,l,r)}let m=await(s??fetch)(c,{method:"POST",headers:l,body:r});if(!m.ok)throw await Ao(m);return xe.parse(await m.json())}n(Po,"executeTokenRequest");async function pc(e,{metadata:t,clientInformation:r,refreshToken:o,resource:i,addClientAuthentication:a,fetchFn:s}){let c=new URLSearchParams({grant_type:"refresh_token",refresh_token:o}),l=await Po(e,{metadata:t,tokenRequestParams:c,clientInformation:r,addClientAuthentication:a,resource:i,fetchFn:s});return{refresh_token:o,...l}}n(pc,"refreshAuthorization");async function mc(e,t,{metadata:r,resource:o,authorizationCode:i,fetchFn:a}={}){let s=e.clientMetadata.scope,c;if(e.prepareTokenRequest&&(c=await e.prepareTokenRequest(s)),!c){if(!i)throw new Error("Either provider.prepareTokenRequest() or authorizationCode is required");if(!e.redirectUrl)throw new Error("redirectUrl is required for authorization_code flow");let m=await e.codeVerifier();c=lc(i,m,e.redirectUrl)}let l=await e.clientInformation();return Po(t,{metadata:r,tokenRequestParams:c,clientInformation:l??void 0,addClientAuthentication:e.addClientAuthentication,resource:o,fetchFn:a})}n(mc,"fetchToken");async function fc(e,{metadata:t,clientMetadata:r,scope:o,fetchFn:i}){let a;if(t){if(!t.registration_endpoint)throw new Error("Incompatible auth server: does not support dynamic client registration");a=new URL(t.registration_endpoint)}else a=new URL("/register",e);let s=await(i??fetch)(a,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...r,...o!==void 0?{scope:o}:{}})});if(!s.ok)throw await Ao(s);return Ne.parse(await s.json())}n(fc,"registerClient");var mr="zuplo.com",hc=new Set(["co.jp","co.kr","co.nz","co.uk","com.au","com.br","com.cn","com.mx","com.sg","co.in"]),gc=[".example.test",".example.com",".example.org",".invalid",".localhost",".test"];function Eo(e){return`https://www.google.com/s2/favicons?domain=${e}&sz=128`}n(Eo,"s2FaviconHref");function yc(e){return`https://t0.gstatic.com/faviconV2?client=SOCIAL&type=FAVICON&drop_404_icon=true&fallback_opts=TYPE,SIZE,URL&url=http://${e}&size=128`}n(yc,"strictFaviconHref");var It=Eo(mr);function fr(e){let t=e.toLowerCase();return t===mr||t==="zuplo.app"||t==="zuplo.dev"||t.endsWith(".zuplo.app")||t.endsWith(".zuplo.dev")?Eo(mr):yc(e)}n(fr,"resolveIconHref");function _c(e){try{return new URL(`http://${e}`).hostname}catch{return e}}n(_c,"hostnameFromHost");function wc(e){return e==="localhost"||e.includes(":")||/^\d{1,3}(?:\.\d{1,3}){3}$/.test(e)}n(wc,"isLocalOrAddressHost");function Rc(e){let t=_c(e).toLowerCase().replace(/\.$/,"");if(wc(t)||gc.some(a=>t===a.slice(1)||t.endsWith(a)))return t;let r=t.split(".").filter(Boolean);if(r.length<=2)return t;let o=r.slice(-2).join("."),i=hc.has(o)?3:2;return r.slice(-i).join(".")}n(Rc,"inferFaviconDomain");function hr(e){return{src:fr(Rc(e)),mimeType:"image/png",sizes:["128x128"]}}n(hr,"resolveMcpFaviconIcon");function xt(e){try{return hr(new URL(e).host)}catch{return}}n(xt,"resolveMcpFaviconIconFromUrl");function ne(e){let t=N().connectionsById.get(e);if(!t)throw new T(`Unknown upstream server "${e}". Check the route's MCP upstream policy and ensure policies.json declares a matching upstream connection.`);return{displayName:t.displayName,...t.description===void 0?{}:{description:t.description},...t.serverInfo===void 0?{}:{serverInfo:t.serverInfo},transport:{baseUrl:t.mcpUrl,resourceMetadataUrl:t.protectedResourceMetadataUrl}}}n(ne,"getUpstreamServerConfig");function bc(e){let t=N().connectionsById.get(e.upstreamServerId);if(!t||t.authProfileId!==e.authProfileId)throw new T(`Unknown auth profile "${String(e.authProfileId)}" for upstream server "${e.upstreamServerId}". Check the route's MCP upstream policy and ensure policies.json declares a matching auth mode for that upstream connection.`);return t.authProfileId}n(bc,"resolveUpstreamAuthProfileId");function gr(e){bc(e);let t=N().connectionsById.get(e.upstreamServerId);if(!t)throw new T(`Auth profile could not be resolved for upstream server "${e.upstreamServerId}". Check the route's MCP upstream policy and ensure policies.json declares the upstream connection before this handler runs.`);return t.authConfig}n(gr,"getUpstreamAuthConfig");function ge(e,t){let r=gr({upstreamServerId:e,authProfileId:t});if(!Tn(r))throw new T(`Upstream server "${e}" does not use upstream OAuth. Select an auth mode that supports the requested upstream connect flow or remove the upstream OAuth route for this server.`);return r.oauth}n(ge,"requireUpstreamOAuthConfig");var Sc={"shared-oauth":{authMode:"shared-oauth",ownerMode:"shared",connectSupport:"oauth_authorization",connectUnsupportedDetail:void 0,callbackSupport:"authorization_code",credentialAcquisition:"oauth_connection"},"user-oauth":{authMode:"user-oauth",ownerMode:"user",connectSupport:"oauth_authorization",connectUnsupportedDetail:void 0,callbackSupport:"authorization_code",credentialAcquisition:"oauth_connection"}};function G(e){return Sc[e]}n(G,"describeUpstreamAuthMode");function At(e){return G(e).ownerMode}n(At,"resolveOwnerModeForUpstreamAuthMode");H();import{errors as jo,jwtVerify as Lo,SignJWT as No}from"jose";var O="zuplo-mcp-gateway",D=O,z="HS256";import{base64url as vc}from"jose";var Cc=new TextEncoder,Ic="MCP gateway could not initialize secure key material.",xc=32,Oo=new Map,qo=new Map,Ac;function Uc(){return Ac??rn.instance.authPrivateKey}n(Uc,"readAuthPrivateKey");function Mo(e){return new M(Ic,e===void 0?void 0:{cause:e})}n(Mo,"createGeneratedKeyMaterialError");function Do(e,t){let r=vc.decode(t);if(r.byteLength!==xc)throw new Error(`Generated deployment auth key ${e} is invalid.`);return r}n(Do,"decodeJwkKeyField");function kc(e){let t=Uc();if(!t)throw Mo();try{let r=JSON.parse(t);if(r.kty!=="OKP"||r.crv!=="Ed25519"||typeof r.d!="string"||typeof r.x!="string")throw new Error("Generated deployment auth key is not an Ed25519 JWK.");let o=Do("d",r.d);Do("x",r.x);let i=Cc.encode(`zuplo-mcp-gateway:${e}:Ed25519:`),a=new Uint8Array(i.byteLength+o.byteLength);return a.set(i),a.set(o,i.byteLength),a}catch(r){throw Mo(r)}}n(kc,"decodeGeneratedKeyMaterial");function Tc(e){let t=Oo.get(e);return t||(t=kc(e),Oo.set(e,t)),t}n(Tc,"getMasterKeyMaterial");async function $(e){let t=qo.get(e.purpose);if(t!==void 0)return t;let r=await e.derive(Tc(e.keyMaterialPurpose));return qo.set(e.purpose,r),r}n($,"readCachedDerivedKey");var Pc="SHA-256";var Ec="zuplo-mcp-gateway:",Oc=new TextEncoder,zo=new WeakMap;async function oe(e,t){let r=zo.get(e);r||(r=new Map,zo.set(e,r));let o=r.get(t);if(o)return o;let i=await qc(e,t);return r.set(t,i),i}n(oe,"deriveGatewaySigningKey");async function qc(e,t){let r=Ho(e),o=await crypto.subtle.importKey("raw",r,{name:"HKDF"},!1,["deriveBits"]),i=Oc.encode(`${Ec}${t}`),a=await crypto.subtle.deriveBits({name:"HKDF",hash:Pc,salt:new Uint8Array,info:Ho(i)},o,32*8);return new Uint8Array(a)}n(qc,"hkdfExpand");function Ho(e){let t=new ArrayBuffer(e.byteLength);return new Uint8Array(t).set(e),t}n(Ho,"copyToArrayBuffer");var Go=15*60,Mc=15*60,Dc=eo.extend({id:to}),zc=Dc.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),$o=Xt.extend({id:ro,purpose:d.literal("browser_connect")}),Hc=Xt.extend({purpose:d.literal("browser_connect")}),Bc=$o.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Zo=Go*1e3;async function Fo(){return $({purpose:"oauth-state",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"oauth-state"),"derive")})}n(Fo,"getOAuthStateKey");async function Ko(){return $({purpose:"browser-connect",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-connect"),"derive")})}n(Ko,"getBrowserConnectKey");async function Jo(e){let t=Math.floor(Date.now()/1e3)+Go;return new No(e).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(O).setAudience(D).setIssuedAt().setExpirationTime(t).sign(await Fo())}n(Jo,"signOAuthState");async function Ut(e){try{let{payload:t}=await Lo(e,await Fo(),{algorithms:[z],issuer:O,audience:D});return zc.parse(t)}catch(t){throw t instanceof jo.JWTExpired?new g({message:"OAuth state has expired",extensionMembers:{[y]:"oauth_state_expired"}},{cause:t}):new g({message:"OAuth state could not be verified",extensionMembers:{[y]:"oauth_state_invalid"}},{cause:t})}}n(Ut,"verifyOAuthState");async function Wo(e){let t=Math.floor(Date.now()/1e3)+Mc,r=Hc.parse(e),o=$o.parse({...r,id:ao()});return new No(o).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(O).setAudience(D).setIssuedAt().setExpirationTime(t).sign(await Ko())}n(Wo,"signBrowserConnectTicket");async function Vo(e){try{let{payload:t}=await Lo(e,await Ko(),{algorithms:[z],issuer:O,audience:D});return Bc.parse(t)}catch(t){throw t instanceof jo.JWTExpired?new g({message:"Browser connect ticket has expired",extensionMembers:{[y]:"oauth_state_expired"}},{cause:t}):new g({message:"Browser connect ticket could not be verified",extensionMembers:{[y]:"oauth_state_invalid"}},{cause:t})}}n(Vo,"verifyBrowserConnectTicket");async function Yo(e){if((await b().consumeBrowserConnectTicket({id:e.id,expiresAt:R(new Date(e.exp*1e3)),now:R(new Date)})).kind==="consumed")throw new g({message:"Browser connect ticket has already been used",extensionMembers:{[y]:"oauth_state_reused"}})}n(Yo,"consumeBrowserConnectTicket");function jc(e,t,r=!1){return r?`${e} authorization must be renewed before this ${t} can be used.`:`${e} authorization is required before this ${t} can be used.`}n(jc,"buildConnectRequiredMessage");async function Lc(e){let t=U(e.requestUrl,e.requestHeaders),r=new URL(e.path,t);return e.redirect&&r.searchParams.set("redirect","true"),r.searchParams.set("operationId",e.operationId),r.searchParams.set("browserTicket",await Wo({...je(e),purpose:"browser_connect"})),r.toString()}n(Lc,"buildGatewayBrowserTicketUrl");function Nc(e){return`/auth/connections/${encodeURIComponent(e)}/connect`}n(Nc,"buildGatewayConnectPath");async function yr(e){return Lc({...e,path:Nc(e.upstreamServerId),redirect:!0})}n(yr,"buildGatewayConnectUrl");async function kt(e){let t={requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.returnTo===void 0?{}:{returnTo:e.returnTo}};return{state:e.requiresReconsent?"reconsent_required":"authenticating",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.connectionId?{connectionId:e.connectionId}:{},authUrl:await yr(t),message:jc(e.upstreamDisplayName,e.subject,e.requiresReconsent),nextAction:"redirect"}}n(kt,"buildRedirectConnectRequiredResponse");function Xo(e){return Gc({...e,message:e.requiresReconsent?`An administrator must reconnect ${e.upstreamDisplayName} before this tool can be used.`:`An administrator must connect ${e.upstreamDisplayName} before this tool can be used.`})}n(Xo,"buildAdminConnectRequiredResponse");function Gc(e){return{state:"admin_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.connectionId?{connectionId:e.connectionId}:{},message:e.message,nextAction:"admin_setup_required"}}n(Gc,"buildAdminSetupRequiredResponse");H();function _r(e){return`Zuplo MCP Gateway - ${e}`}n(_r,"buildGatewayOAuthClientName");function Qo(e,t,r){let o=new URL(e,U(t,r));return ue(o)&&fn(o.hostname)!=="localhost"&&(o.hostname="localhost"),o.toString()}n(Qo,"buildGatewayOAuthRedirectUri");function wr(e){let t=new URL(`/.well-known/oauth-client/${encodeURIComponent(e.upstreamServerId)}`,e.origin);return t.searchParams.set("authProfileId",e.authProfileId),t.toString()}n(wr,"buildOAuthClientMetadataDocumentUrl");function ei(e,t){return U(e,t)}n(ei,"requireOAuthClientMetadataOrigin");function ti(e,t,r){let o=ne(t),i=ge(t,r),a={client_id:wr({origin:e,upstreamServerId:t,authProfileId:r}),client_name:_r(o.displayName),client_uri:new URL("/",e).toString(),redirect_uris:[new URL(i.redirectPath,e).toString()],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",token_endpoint_auth_method:"none"};return i.scopes.length>0&&(a.scope=i.scopes.join(i.scopeDelimiter)),a}n(ti,"buildOAuthClientMetadataDocument");H();import{base64url as ie}from"jose";var $c="SHA-256",Ue="AES-GCM",Zc=12,br="zuplo-secret",Sr=1,ri="generated:auth_private_key:token-encryption",Fc=d.object({version:d.literal(Sr),keyId:d.literal(ri),algorithm:d.literal(Ue),iv:d.string().min(1),ciphertext:d.string().min(1)}).strict();function Ae(e){let t=new ArrayBuffer(e.byteLength);return new Uint8Array(t).set(e),t}n(Ae,"copyToArrayBuffer");async function Rr(){return $({purpose:"token-encryption",keyMaterialPurpose:"token-encryption",derive:n(async e=>{let t=await crypto.subtle.digest($c,Ae(e));return crypto.subtle.importKey("raw",t,{name:Ue},!1,["encrypt","decrypt"])},"derive")})}n(Rr,"getEncryptionKey");function ni(e){return Ae(new TextEncoder().encode(`${br}:v${e.version}:${e.keyId}`))}n(ni,"getAssociatedData");function Kc(e){return`${br}:v${e.version}:${ie.encode(new TextEncoder().encode(JSON.stringify(e)))}`}n(Kc,"encodeEnvelope");function Jc(e){let t=`${br}:v${Sr}:`;if(!e.startsWith(t))return;let r=e.slice(t.length),o=new TextDecoder().decode(ie.decode(r));return Fc.parse(JSON.parse(o))}n(Jc,"decodeEnvelope");async function Tt(e){let t=await Rr(),r=crypto.getRandomValues(new Uint8Array(Zc)),o={version:Sr,keyId:ri},i=await crypto.subtle.encrypt({name:Ue,iv:r,additionalData:ni(o)},t,new TextEncoder().encode(e));return Kc({...o,algorithm:Ue,iv:ie.encode(r),ciphertext:ie.encode(new Uint8Array(i))})}n(Tt,"encryptSecret");async function tt(e){let t=Jc(e);if(t){let s=await Rr(),c=await crypto.subtle.decrypt({name:Ue,iv:Ae(ie.decode(t.iv)),additionalData:ni(t)},s,Ae(ie.decode(t.ciphertext)));return new TextDecoder().decode(c)}let[r,o]=e.split(".");if(!r||!o)throw new M("Encrypted payload is malformed");let i=await Rr(),a=await crypto.subtle.decrypt({name:Ue,iv:Ae(ie.decode(r))},i,Ae(ie.decode(o)));return new TextDecoder().decode(a)}n(tt,"decryptSecret");var Wc=d.union([Ne,ir]),Vc=d.object({authorizationServerUrl:d.url(),resourceMetadataUrl:d.url().optional(),resourceMetadata:vt.optional(),authorizationServerMetadata:d.union([Le,Ct]).optional()}).passthrough(),Yc="Bearer",Xc="__zuplo_refresh_only_upstream_access_token__",Qc=new Set(["client_id","code_challenge","code_challenge_method","display","login_hint","nonce","prompt","redirect_uri","response_mode","response_type","state"]);function ed(e){return e?e.split(/[,\s]+/).filter(Boolean):[]}n(ed,"splitScopes");function td(e){let t=[];for(let r of Qc)e.authorizationUrl.searchParams.getAll(r).length>1&&t.push(r);if(t.length!==0)throw new T(`Upstream OAuth authorization metadata for upstream "${e.upstreamServerId}" produced duplicate singleton authorization request parameter(s): ${t.join(", ")}. Remove request-specific query parameters such as "prompt" from the upstream authorization_endpoint; the gateway and OAuth client SDK add per-request parameters during the authorization flow.`)}n(td,"assertNoDuplicateSingletonAuthorizationRequestParams");function rd(e){return ht.parse(e)}n(rd,"parsePkceCodeVerifier");function nd(e){if(typeof e.expires_in=="number")return R(new Date(Date.now()+e.expires_in*1e3))}n(nd,"readTokenExpiry");async function oi(e){if(e!==void 0)return Tt(JSON.stringify(e))}n(oi,"encryptJson");async function ii(e,t){if(!e)return;let r=await tt(e);try{return t.parse(JSON.parse(r))}catch(o){throw new g({message:"Stored upstream OAuth JSON state is invalid.",extensionMembers:{[y]:"oauth_state_invalid"}},{cause:o})}}n(ii,"decryptJson");function od(e){if(e===void 0)return;let t={authorizationServerUrl:e.authorizationServerUrl};return e.resourceMetadataUrl!==void 0&&(t.resourceMetadataUrl=e.resourceMetadataUrl),e.resourceMetadata!==void 0&&(t.resourceMetadata=e.resourceMetadata),e.authorizationServerMetadata!==void 0&&(t.authorizationServerMetadata=e.authorizationServerMetadata),t}n(od,"toOAuthDiscoveryState");function id(e,t){return"redirect_uris"in e?e.redirect_uris.includes(t):!0}n(id,"clientInformationAllowsRedirectUri");function ad(e,t,r){let o=ne(e),i=ge(e,t),a=vr(i.scopes,i.scopeDelimiter);return{client_name:_r(o.displayName),client_uri:new URL("/",new URL(r).origin).toString(),redirect_uris:[r],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",scope:a,token_endpoint_auth_method:"none"}}n(ad,"buildOAuthClientMetadata");function vr(e,t){return e&&e.length>0?e.join(t):void 0}n(vr,"joinOAuthScopes");function sd(e,t){return t===void 0?e:{...e,scope:t}}n(sd,"applyOAuthClientMetadataScope");function ai(e,t){return vr(e?.resourceMetadata?.scopes_supported,t)}n(ai,"readResourceMetadataScope");function cd(e){let t;if(e.registration.tokenEndpointAuthMethod!=="none"&&(t=e.registration.clientSecret,!t))throw new T(`Manual OAuth registration for upstream "${e.upstreamServerId}" requires clientSecret. Set the env var that backs the client secret or use tokenEndpointAuthMethod "none".`);return Ne.parse({...e.clientMetadata,client_id:e.registration.clientId,token_endpoint_auth_method:e.registration.tokenEndpointAuthMethod,...t===void 0?{}:{client_secret:t}})}n(cd,"buildManualOAuthClientInformation");function dd(e,t,r){let o=wr({origin:new URL(r).origin,upstreamServerId:e,authProfileId:t});return lr(o)?o:void 0}n(dd,"buildClientMetadataUrl");function si(e){for(let t of e)if(t!==void 0)return t}n(si,"firstDefined");function ud(e){let t=ge(e.target.upstreamServerId,e.target.authProfileId),r=ad(e.target.upstreamServerId,e.target.authProfileId,e.redirectUri),o=vr(t.scopes,t.scopeDelimiter);if(t.clientRegistration.mode==="manual")return{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter,configuredClientInformation:cd({clientMetadata:r,registration:t.clientRegistration,upstreamServerId:e.target.upstreamServerId})};let i=dd(e.target.upstreamServerId,e.target.authProfileId,e.redirectUri);return i===void 0?{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter}:{clientMetadata:r,configuredScope:o,scopeDelimiter:t.scopeDelimiter,clientMetadataUrl:i}}n(ud,"buildInitialOAuthClientSetup");function ld(e,t){if(t===void 0)return si([e.pendingState?.encryptedClientInformation,e.connectionMetadata?.encryptedClientInformation,e.connection?.metadata?.encryptedClientInformation])}n(ld,"readEncryptedClientInformation");function pd(e){return si([e.pendingState?.encryptedDiscoveryState,e.connectionMetadata?.encryptedDiscoveryState,e.connection?.metadata?.encryptedDiscoveryState])}n(pd,"readEncryptedDiscoveryState");var ye=class{static{n(this,"UpstreamOAuthProvider")}clientMetadataUrl;target;redirectUriValue;returnOrigin;clientMetadataValue;configuredScope;scopeDelimiter;configuredClientInformation;challengeScope;inferredScope;authorizationUrlValue;connection;pendingState;encryptedClientInformation;encryptedDiscoveryState;cachedClientInformation;clientInformationLoaded=!1;cachedDiscoveryState;discoveryStateLoaded=!1;cachedTokens;tokensLoaded=!1;constructor(t){let r=ud({target:t.target,redirectUri:t.redirectUri});this.target=t.target,this.redirectUriValue=t.redirectUri,this.returnOrigin=t.returnOrigin,this.clientMetadataValue=r.clientMetadata,this.configuredScope=r.configuredScope,this.scopeDelimiter=r.scopeDelimiter,this.configuredClientInformation=r.configuredClientInformation,r.clientMetadataUrl!==void 0&&(this.clientMetadataUrl=r.clientMetadataUrl),this.connection=t.connection,this.pendingState=t.pendingState?{...t.pendingState}:void 0,this.encryptedClientInformation=ld(t,this.configuredClientInformation),this.encryptedDiscoveryState=pd(t)}get authorizationUrl(){return this.authorizationUrlValue}get redirectUrl(){return this.redirectUriValue}get clientMetadata(){return sd(this.clientMetadataValue,this.readEffectiveScope())}async state(){let t=await this.createPendingState();return Jo({id:t.id,...je({owner:this.target.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId})})}async clientInformation(){return this.configuredClientInformation?this.configuredClientInformation:this.loadPersistedClientInformation()}async saveClientInformation(t){this.configuredClientInformation||(this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.encryptedClientInformation=await oi(t),await this.syncPendingState(!1))}async discoveryState(){return this.loadPersistedDiscoveryState()}applyChallengeScope(t){this.challengeScope=t}async saveDiscoveryState(t){this.cachedDiscoveryState=t,this.discoveryStateLoaded=!0,this.inferredScope=ai(t,this.scopeDelimiter),this.encryptedDiscoveryState=await oi(t),await this.syncPendingState(!1)}async tokens(){return this.loadStoredTokens()}async saveTokens(t){let r=xe.parse(t),o=this.target.owner.mode==="user"?this.target.owner.subjectId:void 0,i=r.refresh_token?await Tt(r.refresh_token):this.connection?.encryptedRefreshToken;this.cachedTokens=r.refresh_token||!this.connection?.encryptedRefreshToken?r:xe.parse({...r,refresh_token:await tt(this.connection.encryptedRefreshToken)}),this.tokensLoaded=!0;let a={id:this.connection?.id??oo(),ownerMode:this.target.owner.mode,subjectId:o,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,status:"active",encryptedAccessToken:await Tt(r.access_token),encryptedRefreshToken:i,scopes:ed(r.scope??this.readEffectiveScope()),expiresAt:nd(r),metadata:this.readStoredOAuthPersistence(this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0)};this.connection=await b().upsertUpstreamConnection(a)}async redirectToAuthorization(t){td({authorizationUrl:t,upstreamServerId:this.target.upstreamServerId}),this.authorizationUrlValue=t.toString()}async saveCodeVerifier(t){let r=await this.createPendingState();await this.persistPendingState({...r,codeVerifier:rd(t)})}async codeVerifier(){if(!this.pendingState?.codeVerifier)throw new g({message:"OAuth code verifier is missing",extensionMembers:{[y]:"oauth_state_invalid"}});return this.pendingState.codeVerifier}async invalidateCredentials(t){let r=t==="all"||t==="client"||t==="tokens",o=t==="all"||t==="client",i=t==="all"||t==="discovery",a=t==="all"||t==="verifier";o&&(this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,this.encryptedClientInformation=void 0),i&&(this.cachedDiscoveryState=void 0,this.discoveryStateLoaded=!0,this.encryptedDiscoveryState=void 0,this.challengeScope=void 0,this.inferredScope=void 0),r&&(this.cachedTokens=void 0,this.tokensLoaded=!0),await this.syncPendingState(a),await this.persistCredentialInvalidation(r)}async createPendingState(){if(this.pendingState)return this.pendingState;let t={id:io(),...je({owner:this.target.owner,initiatedBySubjectId:this.target.initiatedBySubjectId,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,operationId:this.target.operationId,...this.target.returnTo===void 0?{}:{returnTo:this.target.returnTo}}),callbackPath:new URL(this.redirectUriValue).pathname,expiresAt:R(new Date(Date.now()+Zo)),redirectUri:this.redirectUriValue,...this.returnOrigin===void 0?{}:{returnOrigin:this.returnOrigin},encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState,connectedBySubjectId:this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0};return await this.persistPendingState(t),t}async persistPendingState(t){await b().saveUpstreamOAuthState({record:t}),this.pendingState=t}async syncPendingState(t){this.pendingState&&await this.persistPendingState({...this.pendingState,codeVerifier:t?void 0:this.pendingState.codeVerifier,encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState})}async loadPersistedClientInformation(){if(this.clientInformationLoaded)return this.cachedClientInformation;let t;try{t=await ii(this.encryptedClientInformation,Wc)}catch{this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}if(t&&!id(t,this.redirectUriValue)){this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1);return}return this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.cachedClientInformation}async loadPersistedDiscoveryState(){if(this.discoveryStateLoaded)return this.cachedDiscoveryState;try{this.cachedDiscoveryState=od(await ii(this.encryptedDiscoveryState,Vc))}catch{this.encryptedDiscoveryState=void 0,this.cachedDiscoveryState=void 0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1)}return this.discoveryStateLoaded=!0,this.inferredScope=ai(this.cachedDiscoveryState,this.scopeDelimiter),this.cachedDiscoveryState}readEffectiveScope(){return this.configuredScope??this.challengeScope??this.inferredScope}async loadStoredTokens(){if(this.tokensLoaded)return this.cachedTokens;if(this.tokensLoaded=!0,!this.connection||this.connection.status!=="active")return;let t=this.connection.encryptedAccessToken?await tt(this.connection.encryptedAccessToken):void 0,r=this.connection.encryptedRefreshToken?await tt(this.connection.encryptedRefreshToken):void 0;if(!t&&!r)return;let o=xe.parse({access_token:t??Xc,token_type:Yc,refresh_token:r,scope:this.connection.scopes.length>0?this.connection.scopes.join(" "):void 0});return this.cachedTokens=o,o}async persistCredentialInvalidation(t){if(!this.connection)return;let r={id:this.connection.id,ownerMode:this.connection.ownerMode,subjectId:this.connection.subjectId,upstreamServerId:this.connection.upstreamServerId,authProfileId:this.connection.authProfileId,status:this.connection.status,encryptedAccessToken:this.connection.encryptedAccessToken,encryptedRefreshToken:this.connection.encryptedRefreshToken,scopes:[...this.connection.scopes],expiresAt:this.connection.expiresAt,metadata:this.connection.metadata?{...this.connection.metadata}:void 0};t&&(r.status="reconsent_required",r.encryptedAccessToken=void 0,r.encryptedRefreshToken=void 0,r.scopes=[],r.expiresAt=void 0),r.metadata=this.readStoredOAuthPersistence(this.connection.metadata?.connectedBySubjectId),this.connection=await b().upsertUpstreamConnection(r)}readStoredOAuthPersistence(t){if(!(!this.encryptedClientInformation&&!this.encryptedDiscoveryState&&!t))return{encryptedClientInformation:this.encryptedClientInformation,encryptedDiscoveryState:this.encryptedDiscoveryState,connectedBySubjectId:t}}};var md=3e4,fd=256*1024,hd=2;function gd(e){return!e||e.status!=="active"||!e.encryptedAccessToken?!1:e.expiresAt?new Date(e.expiresAt).getTime()>Date.now():!0}n(gd,"hasUsableAccessToken");var yd="does not support dynamic client registration",_d=["Resource server does not implement OAuth 2.0 Protected Resource Metadata","trying to load well-known OAuth protected resource metadata"],wd=["HTTP 403 Forbidden","Access Denied","permission to access"];function Rd(e){return e instanceof Error&&e.message.includes(yd)}n(Rd,"isDynamicClientRegistrationUnsupported");function bd(e){return e instanceof Error&&_d.some(t=>e.message.includes(t))}n(bd,"isProtectedResourceMetadataUnavailable");function Sd(e){return e instanceof Error&&wd.some(t=>e.message.includes(t))}n(Sd,"isUpstreamProviderAccessDenied");function vd(e){if(e.error instanceof g&&e.error.extensionMembers?.[y]!==void 0)return e.error;if(Rd(e.error))return new g({message:`The authorization server for ${e.upstreamServerId} does not advertise Client ID Metadata Document support and does not support Dynamic Client Registration. Register an OAuth client for the gateway manually before retrying.`,extensionMembers:{[y]:"upstream_client_registration_required"}},{cause:e.error});if(bd(e.error))return new g({message:`The upstream MCP server "${e.upstreamServerId}" does not publish OAuth protected resource metadata at "${e.resourceMetadataUrl}". Configure protectedResourceMetadataUrl to a working metadata document, use a provider-supported legacy client, or contact the provider to approve/allowlist this gateway OAuth client before retrying.`,extensionMembers:{[y]:"upstream_oauth_discovery_unavailable"}},{cause:e.error});if(Sd(e.error))return new g({message:`The upstream provider denied access while connecting ${e.upstreamServerId}. Confirm the provider allows this gateway and its OAuth client, then retry.`,extensionMembers:{[y]:"upstream_provider_access_denied"}},{cause:e.error})}n(vd,"mapUpstreamOAuthSetupError");function Cd(e){return typeof e=="string"||e instanceof URL?{url:new URL(e.toString())}:{method:e.method,url:new URL(e.url)}}n(Cd,"readOAuthFetchRequest");function Id(e,t){return(e.headers.get("content-type")??"").includes("json")||t.trimStart().startsWith("{")||t.trimStart().startsWith("[")}n(Id,"responseLooksJson");function xd(e,t){let r=e.headers.get("content-type")??"",o=t.trimStart().toLowerCase();return r.includes("html")||o.startsWith("<!doctype html")||o.startsWith("<html")}n(xd,"responseLooksHtml");function Ad(e){let t=e.response.statusText?` ${e.response.statusText}`:"",r=e.response.headers.get("content-type")??"text/html";throw new g({message:`The upstream provider returned ${e.response.status}${t} (${r}) from ${e.request.url.toString()} while connecting ${e.upstreamServerId}.`,extensionMembers:{[y]:e.response.status===403?"upstream_provider_access_denied":"upstream_token_exchange_failed",[ve]:e.response.status,[be]:r,[Ce]:e.request.url.toString(),[Se]:e.body}})}n(Ad,"throwUpstreamHtmlError");function ci(e){return async(t,r)=>{let o=Cd(t),i=await po(t,r,{maxRedirects:hd,maxResponseBytes:fd,problemCode:"upstream_token_exchange_failed",timeoutMs:md}),a=await i.clone().text();if(!i.ok&&xd(i,a)&&Ad({upstreamServerId:e,request:o,response:i,body:a}),!Id(i,a))return i;try{JSON.parse(a)}catch(s){throw new g({message:`Upstream OAuth fetch ${o.url.origin}${o.url.pathname} for ${e} returned invalid JSON.`,extensionMembers:{[y]:"upstream_token_exchange_failed"}},{cause:s})}return i}}n(ci,"createUpstreamOAuthFetch");async function di(e,t){e.applyChallengeScope(t.requestedScope);try{let r={serverUrl:t.serverUrl,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:ci(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),await ur(e,r)}catch(r){let o=vd({upstreamServerId:t.upstreamServerId,resourceMetadataUrl:t.resourceMetadataUrl,error:r});throw o!==void 0?o:r}}n(di,"runUpstreamOAuth");async function Ud(e,t){e.applyChallengeScope(t.requestedScope);let r={serverUrl:t.serverUrl,authorizationCode:t.authorizationCode,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:ci(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),ur(e,r)}n(Ud,"exchangeUpstreamAuthorizationCode");async function ui(e,t){let r=await di(e,t);if(r==="REDIRECT"&&e.authorizationUrl)return e.authorizationUrl;throw r==="AUTHORIZED"?new g({message:`OAuth connect flow reused existing credentials instead of producing a redirect for ${t.upstreamServerId}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}}):new g({message:`Unexpected OAuth result for ${t.upstreamServerId}: ${r}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}})}n(ui,"requireUpstreamAuthorizationRedirect");async function li(e){if(!e.forceRefresh&&gd(e.connection))return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};let t=await di(e.provider,{upstreamServerId:e.target.upstreamServerId,serverUrl:e.serverUrl,resourceMetadataUrl:e.resourceMetadataUrl,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope}});if(t==="AUTHORIZED")return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};if(t!=="REDIRECT")throw new g({message:`Unexpected OAuth result for ${e.target.upstreamServerId}: ${t}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}});if(!e.provider.authorizationUrl)throw new g({message:`OAuth connect-required flow did not produce a redirect for ${e.target.upstreamServerId}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}});return{kind:"connect_required",payload:await Od({requestUrl:e.target.request.url,requestHeaders:e.target.request.headers,connection:e.connection,owner:e.target.owner,initiatedBySubjectId:e.target.initiatedBySubjectId,upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.target.operationId,...e.target.returnTo===void 0?{}:{returnTo:e.target.returnTo}})}}n(li,"authorizeUpstreamOAuthSession");async function kd(e){let t=await Ut(e.stateToken),r=await b().consumeUpstreamOAuthState({id:t.id,now:R(new Date)}),o=Td(r);return Pd({storedState:o,signedState:t,upstreamServerId:e.upstreamServerId,callbackPath:new URL(e.request.url).pathname}),Ed(o),o}n(kd,"consumeStoredCallbackState");function Td(e){switch(e.kind){case"consumed":throw new g({message:"OAuth state has already been used",extensionMembers:{[y]:"oauth_state_reused"}});case"missing":throw new g({message:"OAuth state is missing or expired",extensionMembers:{[y]:"oauth_state_expired"}});case"available":return e.record}}n(Td,"readConsumedCallbackState");function Pd(e){if(![e.storedState.ownerMode===e.signedState.ownerMode,e.storedState.initiatedBySubjectId===e.signedState.initiatedBySubjectId,e.storedState.ownerSubjectId===e.signedState.ownerSubjectId,e.storedState.upstreamServerId===e.signedState.upstreamServerId,e.storedState.authProfileId===e.signedState.authProfileId,e.storedState.operationId===e.signedState.operationId,e.storedState.upstreamServerId===e.upstreamServerId,e.storedState.callbackPath===e.callbackPath].every(Boolean))throw new g({message:"OAuth callback did not match the initiating request",extensionMembers:{[y]:"oauth_callback_mismatch"}})}n(Pd,"assertStoredCallbackStateMatches");function Ed(e){if(new Date(e.expiresAt).getTime()<=Date.now())throw new g({message:"OAuth state has expired",extensionMembers:{[y]:"oauth_state_expired"}})}n(Ed,"assertStoredCallbackStateFresh");async function Od(e){if(e.owner.mode==="shared"){let r={upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.operationId,requiresReconsent:!!e.connection};return e.connection!==void 0&&(r.connectionId=e.connection.id),Xo(r)}let t={requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,upstreamDisplayName:e.upstreamDisplayName,operationId:e.operationId,subject:"tool",requiresReconsent:!!e.connection,...e.returnTo===void 0?{}:{returnTo:e.returnTo}};return e.connection!==void 0&&(t.connectionId=e.connection.id),kt(t)}n(Od,"buildOAuthConnectRequiredResponse");async function pi(e){let t=await kd({request:e.request,upstreamServerId:e.upstreamServerId,stateToken:e.stateToken}),r=_t(t),[o]=await b().batchGetUpstreamConnections([{owner:r,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId}]),i={target:{owner:r,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,...t.returnTo===void 0?{}:{returnTo:t.returnTo}},redirectUri:t.redirectUri,pendingState:t};o!==void 0&&(i.connection=o);let a=new ye(i),s=await Ud(a,{upstreamServerId:e.upstreamServerId,serverUrl:e.upstreamServerConfig.transport.baseUrl,authorizationCode:e.authorizationCode,resourceMetadataUrl:e.upstreamServerConfig.transport.resourceMetadataUrl});if(s==="AUTHORIZED")return t;throw s!=="REDIRECT"?new g({message:`Unexpected OAuth result for ${e.upstreamServerId}: ${s}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}}):new g({message:`OAuth callback flow did not finish authorization for ${e.upstreamServerId}`,extensionMembers:{[y]:"upstream_token_exchange_failed"}})}n(pi,"finishUpstreamOAuthCallback");async function mi(e){let t=ne(e.upstreamServerId),r=ge(e.upstreamServerId,e.authProfileId),o=Qo(r.redirectPath,e.request.url,e.request.headers),i="preloadedConnection"in e?e.preloadedConnection:(await b().batchGetUpstreamConnections([{owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}]))[0];return{upstreamServerConfig:t,connection:i,providerInput:{target:{owner:e.owner,initiatedBySubjectId:e.initiatedBySubjectId,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,...e.returnTo===void 0?{}:{returnTo:e.returnTo}},redirectUri:o,returnOrigin:U(e.request.url,e.request.headers)}}}n(mi,"prepareUpstreamOAuthRequest");async function fi(e){let t=await mi(e),r=new ye({...t.providerInput,...t.connection?.metadata===void 0?{}:{connectionMetadata:t.connection.metadata}});return ui(r,{upstreamServerId:e.upstreamServerId,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(fi,"startUpstreamConnect");async function hi(e){let t=await mi(e),r=new ye({...t.providerInput,...t.connection===void 0?{}:{connection:t.connection}});return li({target:e,provider:r,connection:t.connection,forceRefresh:e.forceRefresh,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope},upstreamDisplayName:t.upstreamServerConfig.displayName,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(hi,"authorizeUpstreamRequest");async function ke(e){let{routeAuth:t}=e;switch(t.authMode){case"shared-oauth":case"user-oauth":return hi({request:e.request,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,forceRefresh:e.forceRefresh,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope},...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},...t.returnTo===void 0?{}:{returnTo:t.returnTo}})}let r=t;throw new M(`Unsupported upstream auth route context ${JSON.stringify(r)}.`)}n(ke,"resolveUpstreamCredentialForRoute");async function gi(e){let t,r={request:e.request,owner:e.connectRequest.owner,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,upstreamServerId:e.connectRequest.upstreamServerId,authProfileId:e.connectRequest.authProfileId,operationId:e.connectRequest.operationId,...e.connectRequest.returnTo===void 0?{}:{returnTo:e.connectRequest.returnTo}},o=G(e.connectRequest.authMode);switch(o.connectSupport){case"oauth_authorization":t=await fi(r);break;case"none":throw new M(o.connectUnsupportedDetail??`Upstream server ${e.connectRequest.upstreamServerId} does not support browser connection flows.`)}return{authProfileId:e.connectRequest.authProfileId,authUrl:t,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,owner:e.connectRequest.owner,upstreamDisplayName:e.connectRequest.upstreamDisplayName,operationId:e.connectRequest.operationId}}n(gi,"startUpstreamConnectForRequest");async function yi(e){let r=(await Ut(e.callbackRequest.state)).authProfileId,o=gr({upstreamServerId:e.callbackRequest.upstreamServerId,authProfileId:r});if(G(o.mode).callbackSupport!=="authorization_code")throw new M(`Upstream server ${e.callbackRequest.upstreamServerId} does not support OAuth callbacks.`);return pi({request:e.request,upstreamServerId:e.callbackRequest.upstreamServerId,authorizationCode:e.callbackRequest.code,stateToken:e.callbackRequest.state,upstreamServerConfig:ne(e.callbackRequest.upstreamServerId)})}n(yi,"finishUpstreamCallbackForRequest");function qd(e){let t=G(e.connection.authMode);return{upstreamServerId:e.connection.upstreamServerId,operationId:e.operationId,authProfileId:e.connection.authProfileId,upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:t.ownerMode}}n(qd,"buildRouteAuthBaseFromConnection");function wi(e){let t=G(e.connection.authMode);return{upstreamServerId:e.connection.id,operationId:e.operationId,authProfileId:ft(e.connection.id,e.connection.authMode),upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:t.ownerMode}}n(wi,"buildRouteAuthBaseFromPolicyOptions");function Pt(e,t){let o=N().byOperationId.get(t);if(!o)throw new T(`Unknown MCP route "${t}". Ensure routes.oas.json declares this operationId before starting an upstream connection flow.`);if(o.connection===void 0)throw new T(`MCP route "${t}" does not declare an MCP token exchange policy. Add one before starting an upstream connection flow.`);if(o.connection.upstreamServerId!==e)throw new T(`MCP route "${t}" does not bind upstream "${e}". Check the route's MCP upstream policies and bind the upstream before starting an upstream connection flow.`);return qd({connection:o.connection,operationId:t})}n(Pt,"resolveRouteAuthBase");function _i(e,t){switch(e){case"user":return yt(t);case"shared":return Qn()}}n(_i,"buildOwnerForSubject");function Te(e,t){switch(e.ownerMode){case"shared":return{...e,owner:_i(e.ownerMode,t),initiatedBySubjectId:t};case"user":return{...e,owner:_i(e.ownerMode,t),initiatedBySubjectId:t}}}n(Te,"resolveRouteAuthForSubject");var Md=Be.InvalidRequest,Dd=new Set(["connection","keep-alive","proxy-authenticate","te","trailer","transfer-encoding","upgrade"]);function zd(e,t){return{credentialType:e.type,forceRefresh:t,...e.type==="headers"?{headerNames:Object.keys(e.headers).sort()}:{}}}n(zd,"buildCredentialResolvedAttributes");function Hd(e){switch(e){case"admin_connect_required":return"admin_connect_required";case"authenticating":return"connect_required"}}n(Hd,"connectRequiredReasonCode");function Ri(e){v(e.context,{eventType:w.MCP_AUTH_UPSTREAM_CREDENTIAL_RESOLVED,outcome:"success",routeBinding:e.routeBinding,attributes:zd(e.credential,e.forceRefresh===!0)})}n(Ri,"emitCredentialResolvedAnalyticsEvent");function bi(e){let t={forceRefresh:e.forceRefresh===!0,nextAction:e.payload.nextAction,state:e.payload.state};if(v(e.context,{eventType:w.MCP_AUTH_UPSTREAM_CREDENTIAL_MISSING,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"connect_required",reasonClass:"auth",attributes:t}),e.payload.state==="reconsent_required"){v(e.context,{eventType:w.MCP_AUTH_UPSTREAM_RECONSENT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"reconsent_required",reasonClass:"auth",attributes:t});return}v(e.context,{eventType:w.MCP_AUTH_UPSTREAM_CONNECT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:Hd(e.payload.state),reasonClass:"auth",attributes:t})}n(bi,"emitCredentialMissingAnalyticsEvents");function Bd(e){let t=e.route.raw();return lt.parse(t?.operationId)}n(Bd,"readOperationId");async function jd(e,t,r,o){let i=await ke({request:e,routeAuth:t});if(i.kind==="connect_required")return bi({context:o,payload:i.payload,routeBinding:t}),o.log.info({event:"mcp_upstream_connect_required",upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId},"MCP upstream proxy: upstream connection required"),{kind:"connect_required",payload:i.payload};let a=i.credential;switch(Ri({context:o,credential:a,routeBinding:t}),a.type){case"none":return{kind:"headers",headers:[]};case"bearer_token":return{kind:"headers",headers:[["authorization",`Bearer ${a.token}`]]};case"headers":return{kind:"headers",headers:Object.entries(a.headers)};case"mcp_oauth_provider":{let s=await a.provider.tokens();return s?{kind:"headers",headers:[["authorization",`${s.token_type??"Bearer"} ${s.access_token}`]]}:(o.log.warn({event:"mcp_upstream_no_tokens",upstreamServerId:t.upstreamServerId},"MCP upstream proxy: OAuth provider returned no tokens"),Response.json({error:"no_upstream_tokens"},{status:401}))}}}n(jd,"buildCredentialHeaders");var Ld=new Set(["authorization","cookie","cookie2"]);function Nd(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return t&&typeof t=="object"&&!Array.isArray(t)&&"method"in t&&typeof t.method=="string"?t.method:void 0}catch{return}}n(Nd,"readJsonRequestMethod");function Gd(e){let t=e.headers.get("content-type")??"";return/\bapplication\/(?:[\w.+-]+\+)?json\b/i.test(t)}n(Gd,"isJsonResponse");function Cr(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(Cr,"isRecord");function $d(e){return Array.isArray(e)&&e.length>0}n($d,"hasIconList");function Zd(e){if(e.connection.serverInfo?.icons!==void 0&&e.connection.serverInfo.icons.length>0)return e.connection.serverInfo.icons;try{let t=xt(Sn(e.context.route.handler));return t===void 0?void 0:[t]}catch{return}}n(Zd,"readFallbackServerIcons");function Fd(e){if(!Cr(e.body))return e.body;let t=e.body.result;if(!Cr(t))return e.body;let r=t.serverInfo;return!Cr(r)||$d(r.icons)?e.body:{...e.body,result:{...t,serverInfo:{...r,icons:e.icons}}}}n(Fd,"addMissingServerIcons");function Kd(e,t){let r=new Headers(e.headers);for(let o of Ld)r.delete(o);for(let[o,i]of t)r.set(o,i);return new on(e,{headers:r})}n(Kd,"applyUpstreamHeaders");function Jd(e){let t=new Headers(e.headers);for(let r of Dd)t.delete(r);return t}n(Jd,"buildProxyHeaders");async function Wd(e){if(!(e.method==="GET"||e.method==="HEAD"))return e.clone().arrayBuffer()}n(Wd,"readRetryBody");function Si(e,t){let r=t.authUrl===void 0?void 0:go({message:t.message,elicitationId:["connect",t.operationId,t.upstreamServerId,t.authProfileId].join(":"),url:t.authUrl});return Response.json(bt({id:ho(e),error:{code:r?.code??Md,message:t.message,data:{...r?.data??{},connectRequired:t}}}))}n(Si,"connectRequiredJsonRpcResponse");async function Vd(e){let{scope:t}=Uo(e.upstreamResponse),r=await ke({request:e.request,routeAuth:e.routeAuth,forceRefresh:!0,...t===void 0?{}:{requestedScope:t}});if(r.kind==="connect_required")return bi({context:e.context,payload:r.payload,routeBinding:e.routeAuth,forceRefresh:!0}),{kind:"connect_required",payload:r.payload};let o=new Headers(e.headers),i=r.credential;switch(Ri({context:e.context,credential:i,routeBinding:e.routeAuth,forceRefresh:!0}),i.type){case"none":return o.delete("authorization"),{kind:"headers",headers:o};case"bearer_token":return o.set("authorization",`Bearer ${i.token}`),{kind:"headers",headers:o};case"headers":for(let[a,s]of Object.entries(i.headers))o.set(a,s);return{kind:"headers",headers:o};case"mcp_oauth_provider":{let a=await i.provider.tokens();return a?(o.set("authorization",`${a.token_type??"Bearer"} ${a.access_token}`),{kind:"headers",headers:o}):(e.context.log.warn({event:"mcp_upstream_no_tokens_after_refresh",upstreamServerId:e.routeAuth.upstreamServerId},"MCP upstream proxy: OAuth provider returned no tokens after refresh"),{kind:"response",response:Response.json({error:"no_upstream_tokens"},{status:401})})}}}n(Vd,"applyRefreshedCredentialHeaders");function Yd(e){e.context.addResponseSendingHook(async(t,r)=>{if(t.status!==401)return t;let o=await Vd({request:e.request,context:e.context,headers:Jd(r),routeAuth:e.routeAuth,upstreamResponse:t});if(o.kind==="connect_required")return Si(e.requestBody,o.payload);if(o.kind==="response")return o.response;let i=vn({handler:e.context.route.handler,request:r,body:e.requestBody,headers:o.headers});return st.fetch(i.url,i.init)})}n(Yd,"installUpstreamAuthRetryHook");function Xd(e){if(Nd(e.requestBody)!=="initialize")return;let t=Zd({connection:e.connection,context:e.context});t===void 0||t.length===0||e.context.addResponseSendingHook(async r=>{if(!Gd(r))return r;let o;try{o=await r.clone().json()}catch{return r}let i=Fd({body:o,icons:t});if(i===o)return r;let a=new Headers(r.headers);return a.delete("content-length"),new Response(JSON.stringify(i),{status:r.status,statusText:r.statusText,headers:a})})}n(Xd,"installInitializeIconHook");async function Ir(e,t,r){let o=Bd(t),i=await Wd(e),a=wi({connection:r,operationId:o}),s=Ie(e.user,e.url,e.headers);Hn(t,s);let c=Te(a,s.subjectId),l=await jd(e,c,r,t);if(!(l instanceof Response)&&l.kind==="connect_required")return Si(i,l.payload);if(l instanceof Response)return l;let m=Kd(e,l.headers);return Yd({request:m,context:t,requestBody:i,routeAuth:c}),Xd({context:t,requestBody:i,connection:r}),m}n(Ir,"mcpTokenExchangePolicy");var xr=class extends dt{static{n(this,"McpTokenExchangeInboundPolicy")}constructor(t,r){let o=kn(t,r);super(o,r)}async handler(t,r){return ct("policy.inbound.mcp-token-exchange"),Ir(t,r,this.options)}};H();var vi=Symbol("Html");function Qd(e){return e.replaceAll("&","&").replaceAll("<","<").replaceAll(">",">").replaceAll('"',""").replaceAll("'","'")}n(Qd,"escapeHtml");function eu(e){return e===null||typeof e!="object"?!1:e[vi]===!0}n(eu,"isHtml");function Ci(e){return e==null||e===!1?"":Array.isArray(e)?e.map(Ci).join(""):eu(e)?e.value:Qd(String(e))}n(Ci,"renderValue");function Q(e){return{[vi]:!0,value:e}}n(Q,"trustedHtml");var Z=Q("");function S(e,...t){let r=e[0]??"";for(let o=0;o<t.length;o+=1)r+=Ci(t[o]),r+=e[o+1]??"";return Q(r)}n(S,"html");function Pe(e){return e.value}n(Pe,"renderHtml");function Ii(e){return S`<p class="card__description">${e.detail}</p>${e.guidance} ${e.technicalDetails} ${e.action}`}n(Ii,"renderBrowserErrorPage");var Ee=Q('*,:before,:after{box-sizing:border-box}:root{--bg:#f5f6f8;--surface:#fff;--surface-2:#f8fafc;--border:#e5e7eb;--border-strong:#d1d5db;--text:#0f172a;--text-2:#475569;--text-3:#64748b;--text-muted:#94a3b8;--accent:#0f172a;--accent-hover:#1e293b;--accent-text:#fff;--focus-ring:#0f172a29;--danger:#b91c1c;--danger-bg:#b91c1c0f;--danger-border:#b91c1c38;--warning:#92400e;--warning-bg:#fffbeb;--warning-border:#fde68a;--success:#15803d;--success-bg:#f0fdf4;--success-border:#bbf7d0;--radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-pill:9999px;--shadow-sm:0 1px 2px #0f172a0d;--shadow:0 1px 2px #0f172a0a,0 6px 16px #0f172a0f;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,system-ui,sans-serif;--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Monaco,Consolas,monospace}@media (prefers-color-scheme:dark){:root{--bg:#0a0c10;--surface:#15171c;--surface-2:#1e2128;--border:#262932;--border-strong:#3a3e48;--text:#fafafa;--text-2:#cbd5e1;--text-3:#94a3b8;--text-muted:#71717a;--accent:#fafafa;--accent-hover:#e4e4e7;--accent-text:#0a0c10;--focus-ring:#fafafa2e;--danger:#f87171;--danger-bg:#f8717114;--danger-border:#f871714d;--warning:#fbbf24;--warning-bg:#fbbf2414;--warning-border:#fbbf2447;--success:#34d399;--success-bg:#34d39914;--success-border:#34d3994d;--shadow-sm:0 1px 2px #0006;--shadow:0 1px 2px #0006,0 8px 24px #0006}}html,body{margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:48px 20px;font-size:14px;line-height:1.5;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow);overflow:hidden}.card__head{text-align:center;padding:32px 32px 24px}.card__icon{border-radius:var(--radius);background:var(--surface-2);object-fit:contain;border:1px solid var(--border);width:48px;height:48px;margin:0 auto 16px;display:block}.card__title{letter-spacing:-.01em;color:var(--text);margin:0;font-size:20px;font-weight:600;line-height:1.3}.card__subtitle{color:var(--text-2);margin:8px 0 0;font-size:14px;line-height:1.55}.card__subtitle strong{color:var(--text);font-weight:600}.card__description{color:var(--text-3);margin:12px 0 0;font-size:13px;line-height:1.55}.card__principal{color:var(--text-3);background:var(--surface-2);border-radius:var(--radius-pill);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:6px;max-width:100%;margin:16px 0 0;padding:4px 12px;font-size:12.5px;display:inline-flex;overflow:hidden}.card__body{flex-direction:column;gap:20px;padding:8px 32px 24px;display:flex}.card__head+.card__body{border-top:1px solid var(--border);padding-top:24px}.card__footer{border-top:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;padding:16px 24px;display:flex}.card__fineprint{color:var(--text-3);text-align:center;margin:0;font-size:12.5px;line-height:1.5}.card__fineprint strong{color:var(--text-2);font-weight:600}.section-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);align-items:baseline;gap:6px;margin:0;font-size:11px;font-weight:600;display:flex}.section-label__count{color:var(--text-3);letter-spacing:0;font-weight:500}.banner{border-radius:var(--radius);border:1px solid;align-items:flex-start;gap:10px;padding:12px 14px;font-size:13px;display:flex}.banner__icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;margin-top:1px;display:inline-flex}.banner__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.banner__title{color:var(--text);margin:0;font-size:13px;font-weight:600}.banner__message{color:var(--text-2);margin:0;font-size:13px;line-height:1.5}.banner--warning{background:var(--warning-bg);border-color:var(--warning-border)}.banner--warning .banner__icon{color:var(--warning)}.banner--alert{background:var(--danger-bg);border-color:var(--danger-border)}.banner--alert .banner__icon,.banner--alert .banner__title{color:var(--danger)}.upstream-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.upstream-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;padding:14px;display:flex}.upstream-card--needs-action{border-color:var(--warning-border);background:var(--warning-bg)}.upstream-card__head{align-items:flex-start;gap:10px;display:flex}.icon-frame{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);width:32px;height:32px;color:var(--text-3);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.icon-frame img{object-fit:contain;max-width:100%;max-height:100%}.icon-frame--fallback svg{width:18px;height:18px}.inline-icon{object-fit:contain;vertical-align:-2px;border-radius:2px;width:14px;height:14px;margin-right:4px}.upstream-card__main{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.upstream-card__title-row{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.upstream-card__title{color:var(--text);letter-spacing:-.005em;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin:0;font-size:14px;font-weight:600;line-height:1.3;overflow:hidden}.upstream-card__meta{color:var(--text-3);flex-wrap:wrap;align-items:center;gap:6px;font-size:12px;display:flex}.upstream-card__host{font-family:var(--font-mono);background:var(--surface-2);color:var(--text-2);border-radius:var(--radius-sm);padding:1px 6px;font-size:11.5px}.upstream-card__sep{color:var(--border-strong)}.upstream-card__description{color:var(--text-2);margin:4px 0 0;font-size:12.5px;line-height:1.5}.status-badge{border-radius:var(--radius-pill);white-space:nowrap;border:1px solid #0000;flex-shrink:0;align-items:center;gap:6px;padding:2px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.status-badge:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:5px;height:5px}.status-badge--success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.status-badge--warning{background:var(--warning-bg);color:var(--warning);border-color:var(--warning-border)}.status-badge--neutral{background:var(--surface-2);color:var(--text-2);border-color:var(--border)}.upstream-card__capabilities,.upstream-card__scopes{border-top:1px solid var(--border);margin-top:2px;padding-top:10px}.upstream-card__capabilities--empty{color:var(--text-3);font-size:12px;font-style:italic}.capabilities-summary,.scopes-summary{cursor:pointer;user-select:none;color:var(--text-2);justify-content:space-between;align-items:center;gap:12px;padding:2px 0;font-size:12.5px;list-style:none;display:flex}.capabilities-summary::-webkit-details-marker,.scopes-summary::-webkit-details-marker{display:none}.capabilities-summary:hover,.scopes-summary:hover{color:var(--text)}.capabilities-summary:focus-visible,.scopes-summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.capabilities-summary__counts{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.count-pill{color:var(--text-2);align-items:baseline;gap:4px;font-size:12.5px;display:inline-flex}.count-pill__num{font-variant-numeric:tabular-nums;color:var(--text);font-size:13px;font-weight:600}.count-pill--destructive .count-pill__num,.count-pill--destructive .count-pill__label{color:var(--danger)}.capabilities-summary__chevron{color:var(--text-3);flex-shrink:0;transition:transform .15s;display:inline-flex}details[open]>.capabilities-summary .capabilities-summary__chevron,details[open]>.scopes-summary .capabilities-summary__chevron{transform:rotate(180deg)}.capabilities-detail{margin-top:10px}.capability-section{margin-top:14px}.capability-section:first-child{margin-top:6px}.capability-section__title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin:0 0 6px;font-size:11px;font-weight:600}.capability-list{flex-direction:column;gap:5px;margin:0;padding:0;font-size:12.5px;list-style:none;display:flex}.capability-row{flex-wrap:wrap;align-items:baseline;gap:6px;padding:2px 0;display:flex}.capability-row__name{font-weight:500;font-family:var(--font-mono);color:var(--text);font-size:12.5px}.capability-row__description{color:var(--text-3);flex-basis:100%;font-size:12px;line-height:1.45}.capability-row__description code{font-family:var(--font-mono);background:var(--surface-2);border-radius:var(--radius-sm);color:var(--text-2);padding:1px 4px}.capability-row--more{color:var(--text-3);font-size:12px;font-style:italic}.scopes-list{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.scope-chip{font-family:var(--font-mono);background:var(--surface-2);color:var(--text-2);border-radius:var(--radius-sm);border:1px solid var(--border);padding:2px 7px;font-size:11.5px}.badge{border-radius:var(--radius-sm);letter-spacing:.04em;text-transform:uppercase;align-items:center;padding:1px 5px;font-size:10px;font-weight:600;display:inline-flex}.badge--destructive{background:var(--danger-bg);color:var(--danger)}.badge--muted{background:var(--surface-2);color:var(--text-3)}.badge-row{flex-wrap:wrap;gap:4px;display:inline-flex}.muted{color:var(--text-3)}.button{font:inherit;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,border-color .12s,color .12s,box-shadow .12s,transform 40ms;display:inline-flex}.button:active{transform:translateY(1px)}.button:focus-visible{box-shadow:0 0 0 3px var(--focus-ring);outline:0}.button--small{padding:5px 10px;font-size:12.5px}.button--primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.button--primary:hover:not(:disabled):not([aria-disabled=true]){background:var(--accent-hover);border-color:var(--accent-hover)}.button:disabled,.button[aria-disabled=true]{cursor:not-allowed;opacity:.55}.button:disabled:hover,.button[aria-disabled=true]:hover{background:var(--accent);border-color:var(--accent)}.button--secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.button--secondary:hover{background:var(--surface-2);border-color:var(--border-strong)}.button--block{width:100%}.reconnect-action{align-items:center;margin-right:auto;display:inline-flex;position:relative}.reconnect-button{gap:7px}.tooltip{width:16px;height:16px;color:var(--accent);background:color-mix(in srgb,var(--accent)8%,transparent);cursor:help;border:1.5px solid;border-radius:50%;justify-content:center;align-items:center;font-size:10.5px;font-weight:700;line-height:1;display:inline-flex;position:relative}.tooltip:after{content:attr(aria-label);z-index:10;border-radius:var(--radius-sm);background:var(--accent);width:280px;max-width:min(280px,100vw - 48px);color:var(--accent-text);box-shadow:var(--shadow);text-align:left;white-space:normal;opacity:0;pointer-events:none;padding:12px 14px;font-size:13px;font-weight:600;line-height:1.45;transition:opacity .12s;position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%)}.tooltip:before{content:"";z-index:11;border-left:7px solid #0000;border-right:7px solid #0000;border-top:8px solid var(--accent);opacity:0;pointer-events:none;transition:opacity .12s;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}.tooltip:hover:after,.tooltip:hover:before,.tooltip:focus-visible:after,.tooltip:focus-visible:before{opacity:1}.form{flex-direction:column;gap:6px;display:flex}.form__label{color:var(--text);margin:8px 0 0;font-size:13px;font-weight:600;display:block}.form__label:first-child{margin-top:0}.form__input{box-sizing:border-box;border:1px solid var(--border-strong);border-radius:var(--radius);width:100%;font:inherit;background:var(--surface);color:var(--text);padding:9px 12px;font-size:14px;transition:border-color .12s,box-shadow .12s}.form__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus-ring);outline:0}.form__note{color:var(--text-3);margin:4px 0 0;font-size:12.5px;line-height:1.5}.form__submit{margin-top:8px}.empty{text-align:center;color:var(--text-3);border:1px dashed var(--border);border-radius:var(--radius);background:var(--surface);padding:24px 16px;font-size:13px}.actions{gap:8px;margin:0;display:flex}@media (width<=480px){body{padding:0}.card{box-shadow:none;border-left:0;border-right:0;border-radius:0;min-height:100dvh}.card__head{padding:24px 20px 16px}.card__body{padding:16px 20px}.card__footer{flex-direction:column-reverse;align-items:stretch;padding:14px 20px}.card__footer .button{width:100%}.reconnect-action{justify-content:center;width:100%;margin-right:0}.reconnect-action .button{flex:1}.tooltip:after{left:auto;right:0;transform:none}}@media (prefers-reduced-motion:reduce){*{transition:none!important}}');function Oe(e){return S`<!doctype html><html lang="en"><head><meta charset="utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1" /><meta name="referrer" content="no-referrer" /><meta name="robots" content="noindex" /><title>${e.title}</title><link rel="icon" href="${e.iconHref}" /><style>
|
|
26
26
|
${e.styles}
|
|
27
|
-
</style></head><body><main class="card"><header class="card__head">${e.headerIcon}<h1 class="card__title">${e.heading}</h1>${e.subhead}</header><div class="card__body">${e.body}</div>${e.footer}</main></body></html>`}n(Oe,"renderShell");var
|
|
28
|
-
`);return
|
|
27
|
+
</style></head><body><main class="card"><header class="card__head">${e.headerIcon}<h1 class="card__title">${e.heading}</h1>${e.subhead}</header><div class="card__body">${e.body}</div>${e.footer}</main></body></html>`}n(Oe,"renderShell");var tu="text/html; charset=utf-8";function qe(e){try{return new URL(e).host}catch{return""}}n(qe,"safeHostFromUrl");function F(e){let t=nu(e.kind??"authorization_failed"),r=ru(e);return new Response(Pe(Oe({title:e.title??t.title,iconHref:"",styles:Ee,headerIcon:Z,heading:e.title??t.title,subhead:"",body:Ii({detail:e.detail,guidance:S`<p class="card__description">${t.guidance}</p>`,technicalDetails:cu({diagnostic:r,upstreamHtml:e.upstreamHtml}),action:au(e.action)}),footer:""})),{status:e.status??400,headers:{"content-type":tu,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(F,"browserErrorPageResponse");function ru(e){let t=e.diagnostic?.code??e.code??"unknown";return{code:t,stage:e.diagnostic?.stage??ou(t),timestamp:e.diagnostic?.timestamp??new Date().toISOString(),...e.requestId===void 0&&e.diagnostic?.requestId===void 0?{}:{requestId:e.diagnostic?.requestId??e.requestId},...e.diagnostic?.operationId===void 0?{}:{operationId:e.diagnostic.operationId},...e.diagnostic?.routePath===void 0?{}:{routePath:e.diagnostic.routePath},...e.diagnostic?.upstreamServerId===void 0?{}:{upstreamServerId:e.diagnostic.upstreamServerId},...e.diagnostic?.authProfileId===void 0?{}:{authProfileId:e.diagnostic.authProfileId},...e.diagnostic?.upstreamUrl===void 0?{}:{upstreamUrl:e.diagnostic.upstreamUrl},...e.diagnostic?.metadataUrl===void 0?{}:{metadataUrl:e.diagnostic.metadataUrl},...e.diagnostic?.httpStatus===void 0?{}:{httpStatus:e.diagnostic.httpStatus},...e.diagnostic?.contentType===void 0?{}:{contentType:e.diagnostic.contentType},...e.diagnostic?.providerError===void 0?{}:{providerError:e.diagnostic.providerError},...e.diagnostic?.providerErrorDescription===void 0?{}:{providerErrorDescription:e.diagnostic.providerErrorDescription},suggestedFix:e.diagnostic?.suggestedFix??iu(t),underlyingError:e.diagnostic?.underlyingError??e.developerDetail}}n(ru,"buildBrowserErrorDiagnostic");function nu(e){switch(e){case"session_expired":return{title:"Authorization expired",guidance:"Return to your MCP client and reconnect. Expired authorization requests cannot be resumed."};case"access_denied":return{title:"Authorization canceled",guidance:"Return to your MCP client to retry if you want to grant access."};case"configuration_error":return{title:"Configuration needs attention",guidance:"Contact your workspace admin with this error code. The gateway or upstream configuration must be fixed before retrying."};case"connection_failed":return{title:"Connection failed",guidance:"Return to your MCP client and reconnect this upstream. If this keeps happening, contact your gateway administrator with this error code."};case"invalid_request":return{title:"Authorization request invalid",guidance:"Return to your MCP client and try connecting again. If this keeps happening, the client request may need to be fixed."};case"admin_required":return{title:"Admin setup required",guidance:"Contact your workspace admin with this error code. This connection cannot be completed until setup is finished."};case"internal_error":return{title:"Gateway error",guidance:"Try again later from your MCP client. If this keeps happening, contact your gateway administrator with this error code."};case"authorization_failed":return{title:"Authorization failed",guidance:"Return to your MCP client and start authorization again. If this keeps happening, contact your gateway administrator with this error code."}}}n(nu,"readBrowserErrorPagePresentation");function ou(e){switch(e){case"upstream_oauth_discovery_unavailable":return"upstream_oauth_discovery";case"upstream_client_registration_required":return"upstream_oauth_client_registration";case"upstream_provider_access_denied":case"upstream_token_exchange_failed":case"upstream_token_response_invalid":return"upstream_token_exchange";case"provider_access_denied":return"upstream_oauth_callback";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"upstream_oauth_state";case"browser_login_verification_failed":return"downstream_browser_login";case"authentication_required":case"identity_context_missing":return"downstream_auth";case"mcp_route_not_enabled":case"unknown_upstream_server":case"unknown_mcp_route":case"unknown_auth_profile":case"mcp_route_upstream_mismatch":return"gateway_configuration";case"server_error":case"internal_server_error":return"gateway_internal";default:return"gateway_request"}}n(ou,"readBrowserErrorStage");function iu(e){switch(e){case"upstream_oauth_discovery_unavailable":return"Confirm the upstream MCP URL and OAuth protected resource metadata. If the provider requires approval, configure the provider app or contact the provider.";case"upstream_client_registration_required":return"Register an OAuth client with the upstream provider, then configure the gateway to use that client before retrying.";case"upstream_provider_access_denied":return"Confirm the provider allows this gateway, OAuth client, and upstream MCP URL, then retry the connection.";case"upstream_token_exchange_failed":return"Retry the connection. If it repeats, verify the upstream OAuth client, redirect URI, token endpoint, and provider allowlist.";case"upstream_token_response_invalid":return"Verify the upstream token endpoint returns a valid OAuth token response for this gateway client.";case"provider_access_denied":return"Start the connection again if access was denied by mistake. Otherwise, grant the requested upstream provider access.";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"Start a new connection from the MCP client. The previous browser authorization request cannot be resumed.";case"browser_login_verification_failed":return"Retry the browser login flow. If it repeats, verify the downstream login callback configuration.";case"mcp_route_not_enabled":case"unknown_upstream_server":case"unknown_mcp_route":case"unknown_auth_profile":case"mcp_route_upstream_mismatch":return"Check the MCP route, upstream server, and auth profile entries in the gateway configuration.";case"authentication_required":case"identity_context_missing":return"Verify the normal Zuplo auth policy runs before the MCP gateway policy and sets request.user.";case"server_error":case"internal_server_error":return"Retry later and check gateway logs with the request ID.";default:return"Check the gateway configuration and request details associated with this error code."}}n(iu,"readBrowserErrorSuggestedFix");function au(e){return e===void 0?Z:S`<a class="button button--primary button--block" href="${e.href}">${e.label}</a>`}n(au,"renderAction");function su(e){let t=[["Error code",e.code],["Stage",e.stage],["Request ID",e.requestId],["Time",e.timestamp],["Gateway route",e.routePath],["Operation ID",e.operationId],["Upstream",e.upstreamServerId],["Auth profile",e.authProfileId],["Upstream URL",e.upstreamUrl],["Metadata URL",e.metadataUrl],["HTTP status",e.httpStatus],["Content type",e.contentType],["Provider error",e.providerError],["Provider error description",e.providerErrorDescription],["Suggested fix",e.suggestedFix],["Underlying error",e.underlyingError]].filter(r=>r[1]!==void 0).map(([r,o])=>`${r}: ${o}`).join(`
|
|
28
|
+
`);return S`<pre class="banner__message" style="white-space: pre-wrap; overflow-wrap: anywhere; margin-top: 8px;"><code>${t}</code></pre>`}n(su,"renderTechnicalPre");function Et(e){return e.value===void 0||e.value===""?Z:S`<p class="banner__message"><strong>${e.label}:</strong> <code>${e.value}</code></p>`}n(Et,"renderOptionalTechnicalRow");function cu(e){return S`<section class="banner banner--warning" aria-label="Developer details">
|
|
29
29
|
<span class="banner__icon" aria-hidden="true">!</span>
|
|
30
30
|
<div class="banner__body">
|
|
31
31
|
<p class="banner__title">Developer details</p>
|
|
32
32
|
<p class="banner__message" data-gateway-error-code="${e.diagnostic.code}">
|
|
33
33
|
<strong>Error code:</strong> <code>${e.diagnostic.code}</code>
|
|
34
34
|
</p>
|
|
35
|
-
${
|
|
36
|
-
${
|
|
37
|
-
${
|
|
38
|
-
${
|
|
39
|
-
${
|
|
40
|
-
${
|
|
35
|
+
${Et({label:"Stage",value:e.diagnostic.stage})}
|
|
36
|
+
${Et({label:"Request ID",value:e.diagnostic.requestId})}
|
|
37
|
+
${Et({label:"Suggested fix",value:e.diagnostic.suggestedFix})}
|
|
38
|
+
${Et({label:"Reason",value:e.diagnostic.underlyingError})}
|
|
39
|
+
${su(e.diagnostic)}
|
|
40
|
+
${du(e.upstreamHtml)}
|
|
41
41
|
</div>
|
|
42
|
-
</section>`}n(
|
|
42
|
+
</section>`}n(cu,"renderTechnicalDetails");function du(e){return e===void 0?Z:S`<iframe
|
|
43
43
|
title="Upstream HTML error response"
|
|
44
44
|
sandbox
|
|
45
45
|
srcdoc="${e}"
|
|
46
46
|
style="border: 1px solid var(--warning-border); border-radius: var(--radius-sm); background: white; width: 100%; min-height: 220px; margin-top: 8px;"
|
|
47
|
-
></iframe>`}n(_u,"renderUpstreamHtml");var Ua="application/json",wu="application/x-www-form-urlencoded";function qt(e,t){return new g({message:e,extensionMembers:{[_]:"invalid_request"}},t===void 0?void 0:{cause:t})}n(qt,"invalidRequestError");function Ru(e){return(e??"").split(";")[0]?.trim().toLowerCase()??""}n(Ru,"normalizeContentType");function bu(e,t){return e===t?!0:t===Ua&&e.endsWith("+json")}n(bu,"contentTypeMatches");function Su(e,t){if(!t||t.length===0)return;let r=Ru(e.headers.get("content-type"));if(!t.some(o=>bu(r,o)))throw qt(`Request body must be ${t.join(" or ")}.`)}n(Su,"assertExpectedContentType");function Cu(e,t,r){let o=e.headers.get("content-length");if(!o)return;let a=Number.parseInt(o,10);if(Number.isFinite(a)&&a>t)throw qt(`${r} exceeded the maximum allowed size.`)}n(Cu,"assertContentLengthWithinLimit");async function ka(e,t){let r=t.label??"Request body";Su(e,t.expectedContentTypes),Cu(e,t.maxBytes,r);let o=await mo(e.body,{maxBytes:t.maxBytes,createLimitError:n(()=>qt(`${r} exceeded the maximum allowed size.`),"createLimitError")});return new TextDecoder().decode(o)}n(ka,"readBoundedTextBody");async function Ta(e,t){let r=await ka(e,{...t,expectedContentTypes:[Ua]});try{return JSON.parse(r)}catch(o){throw qt("Request body must be valid JSON.",o)}}n(Ta,"readBoundedJsonBody");async function Pa(e,t){let r=await ka(e,{...t,expectedContentTypes:[wu]});return new URLSearchParams(r)}n(Pa,"readBoundedFormUrlEncodedBody");B();B();import{errors as Ha,jwtVerify as za,SignJWT as Ba}from"jose";B();import{errors as vu,jwtVerify as Iu,SignJWT as xu}from"jose";var kr="zuplo_mcp_session",Au=d.object({purpose:d.literal("gateway_browser_session"),sub:yt,browserLoginOrigin:d.string().min(1),roles:d.array(d.string().min(1)).optional(),exp:d.number().int().positive(),iat:d.number().int().positive().optional()});function Uu(e){let t=new Map;if(!e)return t;for(let r of e.split(";")){let o=r.indexOf("=");if(o<0)continue;let a=r.slice(0,o).trim(),i=r.slice(o+1).trim();if(a)try{t.set(a,decodeURIComponent(i))}catch{t.set(a,i)}}return t}n(Uu,"parseCookieHeader");async function Ea(){return Z({purpose:"browser-session",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-session"),"derive")})}n(Ea,"getBrowserSessionKey");function Ur(e,t){let r=new URL(U(e,t)),o=[`${kr}=`,"Path=/","HttpOnly","SameSite=Lax","Max-Age=0"];return r.protocol==="https:"&&o.push("Secure"),o.join("; ")}n(Ur,"buildBrowserSessionEvictionCookie");function ku(e){let t=new URL(U(e.requestUrl,e.requestHeaders)),r=[`${kr}=${encodeURIComponent(e.value)}`,"Path=/","HttpOnly","SameSite=Lax",`Max-Age=${e.ttlSeconds}`];return t.protocol==="https:"&&r.push("Secure"),r.join("; ")}n(ku,"serializeSessionCookie");function Oa(){return new URL(bt("url")).origin}n(Oa,"readBrowserLoginOrigin");function Tr(){return j().browserLogin.stateTtlSeconds}n(Tr,"readBrowserLoginStateTtlSeconds");function qa(e){if(!e.user)throw w("authentication_required","The browser login callback did not include an authenticated Zuplo principal.");return Ie(e.user,e.url)}n(qa,"resolveCurrentRequestPrincipal");async function Mt(e,t={}){let r=Uu(e.headers.get("cookie")).get(kr);if(!r)return{};try{let{payload:o}=await Iu(r,await Ea(),{algorithms:[z],issuer:q,audience:H}),a=Au.parse(o);if(a.browserLoginOrigin!==Oa())return{evictCookie:Ur(e.url,e.headers)};let i={subjectId:a.sub};return a.roles&&a.roles.length>0&&(i.roles=a.roles),{principal:i}}catch(o){return o instanceof vu.JWTExpired?{evictCookie:Ur(e.url,e.headers)}:(t.context?.log.warn({event:"browser_session_verification_failed",errorName:o instanceof Error?o.name:"unknown",errorMessage:o instanceof Error?o.message:"verification failed"},"Browser session JWT verification failed"),{evictCookie:Ur(e.url,e.headers)})}}n(Mt,"readBrowserSession");async function Dt(e){let t=j().browserLogin.sessionTtlSeconds,r={purpose:"gateway_browser_session",sub:e.principal.subjectId,browserLoginOrigin:Oa()};e.principal.roles&&(r.roles=e.principal.roles);let o=await new xu(r).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(q).setAudience(H).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+t).sign(await Ea());return ku({value:o,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},ttlSeconds:t})}n(Dt,"createBrowserSessionCookie");async function Ma(e){let t={};e.context!==void 0&&(t.context=e.context);let r=await Mt(e.request,t);if(r.principal)return r.principal;let o=typeof e.request.query.code=="string"?e.request.query.code:void 0;if(!o)throw w("oauth_callback_mismatch","Federated browser login callback is missing an authorization code.");let{exchangeFederatedAuthorizationCode:a}=await import("../browser-login-idp-SQ4CJMPN.js");return a({code:o,nonce:e.stateId,requestUrl:e.request.url,requestHeaders:e.request.headers,...e.context===void 0?{}:{context:e.context}})}n(Ma,"resolveBrowserLoginCallbackPrincipal");function Da(e){let t=j().browserLogin,r=new URL(bt("url")),o=new URL("/oauth/callback",Bn(e.requestUrl,e.requestHeaders));return Wn(r)?(r.searchParams.set("redirect_uri",o.toString()),r.searchParams.set("state",e.state),r):(r.searchParams.set("response_type","code"),r.searchParams.set("client_id",bt("clientId")),r.searchParams.set("redirect_uri",o.toString()),r.searchParams.set("scope",t.scope),r.searchParams.set("state",e.state),r.searchParams.set("nonce",e.nonce),t.audience&&r.searchParams.set("audience",t.audience),r)}n(Da,"buildBrowserLoginUrl");var Tu={invalid_request:400,invalid_client:401,invalid_grant:400,invalid_target:400,unsupported_grant_type:400,server_error:500,invalid_redirect_uri:400,invalid_client_metadata:400},p=class extends Error{static{n(this,"OAuthProtocolError")}errorCode;status;constructor(t,r,o=Tu[t],a){super(r,a),this.name="OAuthProtocolError",this.errorCode=t,this.status=o}};var Pu=5*60,Eu=d.object({purpose:d.literal("gateway_browser_login"),transactionId:Ft,stateId:Kt,exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Ou=d.object({purpose:d.literal("gateway_authorization_setup"),transactionId:Ft,stateId:Kt,exp:d.number().int().positive(),iat:d.number().int().positive().optional()});async function ja(){return Z({purpose:"browser-login",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-login"),"derive")})}n(ja,"getBrowserLoginKey");async function La(){return Z({purpose:"authorization-csrf",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"authorization-csrf"),"derive")})}n(La,"getCsrfKey");function Na(e){return{now:e.now??new Date,ttlSeconds:Tr()}}n(Na,"readPendingTransactionDependencies");function qu(e,t){return e.subjectId===t.subjectId}n(qu,"principalsMatch");function $a(e){return{subjectId:e.subjectId,...e.roles===void 0?{}:{roles:e.roles}}}n($a,"toPendingPrincipal");function Ga(e){let t={id:e.id,currentStateHash:e.currentStateHash,clientId:e.transaction.clientId,redirectUri:e.transaction.redirectUri,resource:e.transaction.resource,operationId:e.transaction.operationId,scope:e.transaction.scope,codeChallenge:e.transaction.codeChallenge,codeChallengeMethod:e.transaction.codeChallengeMethod,createdAt:b(e.now),expiresAt:b(W(e.now,e.ttlSeconds)),...e.transaction.clientState===void 0?{}:{clientState:e.transaction.clientState}};if(e.phase==="awaiting_login")return{...t,phase:"awaiting_login"};if(!e.principal)throw w("identity_context_missing","Authorization setup requires a principal.");return{...t,phase:"awaiting_setup",principal:$a(e.principal)}}n(Ga,"createTransactionRecord");async function Za(e){let{id:t,...r}=e.record,o=await S().startAuthorization({...r,transactionId:t,...e.client===void 0?{}:{client:e.client}});switch(o.kind){case"started":return o.transaction;case"already_exists":throw w("oauth_state_reused","Authorization transaction state already exists.");case"invalid_client":throw new p("invalid_client","OAuth client is not registered.");case"redirect_uri_mismatch":throw new p("invalid_request","redirect_uri is not registered for the client.")}}n(Za,"startPendingTransaction");async function Mu(e){return new Ba({purpose:"gateway_browser_login",transactionId:e.transactionId,stateId:e.stateId}).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(q).setAudience(H).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await ja())}n(Mu,"signBrowserLoginState");async function Fa(e){return new Ba({purpose:"gateway_authorization_setup",transactionId:e.transactionId,stateId:Wt()}).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(q).setAudience(H).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await La())}n(Fa,"signCsrfToken");async function Pr(e){try{let{payload:t}=await za(e,await ja(),{algorithms:[z],issuer:q,audience:H}),r=Eu.parse(t);return{transactionId:r.transactionId,stateId:r.stateId}}catch(t){throw t instanceof Ha.JWTExpired?w("oauth_state_expired","Browser login state has expired.",t):w("oauth_state_invalid","Browser login state could not be verified.",t)}}n(Pr,"verifyBrowserLoginStateToken");async function Ht(e){try{let{payload:t}=await za(e,await La(),{algorithms:[z],issuer:q,audience:H});return{transactionId:Ou.parse(t).transactionId}}catch(t){throw t instanceof Ha.JWTExpired?w("oauth_state_expired","Authorization setup state has expired.",t):w("oauth_state_invalid","Authorization setup state could not be verified.",t)}}n(Ht,"verifyCsrfToken");function Er(e){return e==="consumed"||e==="consumed_already"||e==="stale_hash"?"oauth_state_reused":e==="expired"?"oauth_state_expired":"oauth_state_invalid"}n(Er,"pendingStateErrorCode");function Du(e){return e.kind==="available"?{kind:"available",record:e.transaction}:e}n(Du,"toPendingAuthorizationGetResult");function Hu(e){return e.kind==="advanced"?{kind:"advanced",record:e.transaction}:e}n(Hu,"toPendingAuthorizationAdvanceResult");function Or(e){return e==="principal_mismatch"?"oauth_callback_mismatch":Er(e==="consumed_already"?"consumed_already":e)}n(Or,"setupDecisionErrorCode");async function Ka(e){let t=e.now??new Date,r=await Ht(e.csrfToken),o=await S().markAuthorizationSetupApproved({transactionId:r.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:b(t)});if(o.kind!=="marked")throw w(Or(o.kind),"Authorization setup state is invalid, expired, or already used.");return Ja({kind:"available",record:o.transaction})}n(Ka,"markSetupApproved");function Ja(e){if(e.kind!=="available")throw w(Er(e.kind),"Authorization setup state is invalid, expired, or already used.");if(e.record.phase!=="awaiting_setup")throw w("oauth_state_invalid","Authorization setup state is not in the setup phase.");return e.record}n(Ja,"requireAwaitingSetup");function zu(e){if(!qu(e.currentBrowserPrincipal,e.transaction.principal))throw w("oauth_callback_mismatch","Authorization setup state does not match the current browser session.")}n(zu,"requireCurrentPrincipalMatches");async function Wa(e){let t=e.now??new Date,r=Tr(),o=Jt(),a=Wt(),i=await Mu({transactionId:o,stateId:a,ttlSeconds:r}),s=Ga({id:o,transaction:e.transaction,currentStateHash:await I(i),phase:"awaiting_login",now:t,ttlSeconds:r});if(s.phase!=="awaiting_login")throw w("oauth_state_invalid","Authorization transaction did not start in login phase.");let c=await Za({record:s,client:e.transaction.client});if(c.phase!=="awaiting_login")throw w("oauth_state_invalid","Authorization transaction did not start in login phase.");return{transaction:c,browserLoginStateToken:i,browserLoginUrl:Da({state:i,nonce:a,operationId:s.operationId,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}})}}n(Wa,"startAwaitingLogin");async function Va(e){let{now:t,ttlSeconds:r}=Na(e),o=Jt(),a=await Fa({transactionId:o,ttlSeconds:r}),i=Ga({id:o,transaction:e.transaction,currentStateHash:await I(a),phase:"awaiting_setup",principal:e.principal,now:t,ttlSeconds:r});if(i.phase!=="awaiting_setup")throw w("oauth_state_invalid","Authorization transaction did not start in setup phase.");let s=await Za({record:i,client:e.transaction.client});if(s.phase!=="awaiting_setup")throw w("oauth_state_invalid","Authorization transaction did not start in setup phase.");return{transaction:s,csrfToken:a}}n(Va,"startAwaitingSetup");async function Ya(e){let{now:t,ttlSeconds:r}=Na(e),o=await Pr(e.browserLoginStateToken),a=await Fa({transactionId:o.transactionId,ttlSeconds:r}),i=Hu(await S().advancePendingAuthorization({transactionId:o.transactionId,expectedPhase:"awaiting_login",currentStateHash:await I(e.browserLoginStateToken),nextStateHash:await I(a),nextPhase:"awaiting_setup",principal:$a(e.principal),now:b(t)}));if(i.kind!=="advanced")throw w(Er(i.kind),"Browser login state is invalid, expired, or already used.");if(i.record.phase!=="awaiting_setup")throw w("oauth_state_invalid","Browser login did not advance to setup.");return{transaction:i.record,csrfToken:a}}n(Ya,"completeLogin");async function Xa(e){let t=await qr(e);return zu({transaction:t,currentBrowserPrincipal:e.currentBrowserPrincipal}),t}n(Xa,"getSetup");async function qr(e){let t=e.now??new Date,r=await Ht(e.csrfToken);return Ja(Du(await S().readPendingAuthorization({transactionId:r.transactionId,currentStateHash:await I(e.csrfToken),now:b(t)})))}n(qr,"getSetupTransaction");async function Bu(e){let t=await Ht(e.csrfToken),r=X(),o=b(W(e.now,Pu)),a=await S().decideAuthorizationSetup({decision:"approve",transactionId:t.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},authorizationCodeHash:await I(r),authorizationCodeExpiresAt:o,grantId:Kn(),now:b(e.now)});if(a.kind!=="approved")throw w(a.kind==="cancelled"?"oauth_state_invalid":Or(a.kind),"Authorization setup state is invalid, expired, or already used.");let i=new URL(a.transaction.redirectUri);return i.searchParams.set("code",r),a.transaction.clientState&&i.searchParams.set("state",a.transaction.clientState),i}n(Bu,"createAuthorizationCodeRedirectWithDecision");async function ju(e){let t=await Ht(e.csrfToken),r=await S().decideAuthorizationSetup({decision:"cancel",transactionId:t.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:b(e.now)});if(r.kind!=="cancelled")throw w(r.kind==="approved"?"oauth_state_invalid":Or(r.kind),"Authorization setup state is invalid, expired, or already used.");return Lu({redirectUri:r.transaction.redirectUri,clientState:r.transaction.clientState})}n(ju,"createCancelRedirectWithDecision");function Lu(e){let t=new URL(e.redirectUri);return t.searchParams.set("error","access_denied"),t.searchParams.set("error_description","The user cancelled the MCP authorization request."),e.clientState!==void 0&&t.searchParams.set("state",e.clientState),t}n(Lu,"buildClientCancelRedirect");async function Qa(e){let t=e.now??new Date;return Bu({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Qa,"approve");async function ei(e){let t=e.now??new Date;return ju({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(ei,"cancel");B();var Nu=1e4,$u=5*1024,Gu=2,Zu=90*24*60*60,Mr="dcr:pkjwt:",Fu="chatgpt.com",Ku="ChatGPT CIMD client metadata could not be used by this gateway. In ChatGPT advanced OAuth settings, change Registration method to Dynamic Client Registration (DCR), keep the discovered Registration URL, and retry connecting.",Dr=["authorization_code","refresh_token"],Hr=["code"],Ju=d.object({client_name:d.string().min(1).optional(),redirect_uris:d.array(d.string().min(1)).min(1),grant_types:d.array(d.enum(Dr)).min(1).max(2).optional(),response_types:d.array(d.enum(Hr)).min(1).max(1).optional(),scope:d.literal(E).optional(),token_endpoint_auth_method:Zn.optional(),jwks_uri:d.string().min(1).optional()});function Wu(e){try{let t=new URL(e);return(t.protocol==="https:"||t.protocol==="http:"&&ue(t))&&t.pathname!=="/"}catch{return!1}}n(Wu,"isCimdClientIdCandidate");function Vu(e){try{let t=new URL(e);return t.protocol==="https:"&&t.hostname===Fu&&t.pathname.startsWith("/oauth/")&&t.pathname.endsWith("/client.json")}catch{return!1}}n(Vu,"isChatGptCimdClientId");function ti(e){throw new p("invalid_client",Vu(e)?Ku:"OAuth client is not registered.")}n(ti,"invalidCimdClientError");function Me(e,t="invalid_request",r="authorize"){if(Yu(e))throw new p(t,"redirect_uris must not include raw whitespace or control characters.");let o;try{o=new URL(e)}catch{throw new p(t,"redirect_uris must be absolute URIs.")}if(o.hash||o.username||o.password)throw new p(t,"redirect_uris must not include credentials or fragments.");let a={source:r},i=$n({url:o,context:a});if(i.kind!=="rejected"){i.mode!=="strict"&&void 0;return}throw new p(t,"redirect_uris must use HTTPS, loopback HTTP, or a native-app private-use URI scheme.")}n(Me,"assertValidRedirectUri");function Yu(e){for(let t=0;t<e.length;t+=1){let r=e.charCodeAt(t);if(r<=32||r>=127&&r<=159)return!0}return!1}n(Yu,"hasForbiddenRawRedirectUriCharacter");async function Xu(e){let{response:t,json:r}=await ho(e.initialUrl,{headers:{accept:"application/json"}},{maxRedirects:Gu,maxResponseBytes:$u,timeoutMs:Nu});if(!t.ok)throw w("invalid_request","CIMD metadata could not be fetched.");let o=Fn.parse(r);for(let a of o.redirect_uris)Me(a,"invalid_request","cimd");if(o.jwks_uri!==void 0&&Rt(o.jwks_uri),o.client_id!==e.clientId)throw w("invalid_request","Fetched CIMD client_id must exactly match the requested client_id.");return o}n(Xu,"fetchCimdMetadata");async function Qu(e){let t=po(e),r=await Xu({clientId:e,initialUrl:t});return{kind:"cimd",clientId:e,metadata:r}}n(Qu,"resolveCimdClient");async function zt(e,t){let r=Y.parse(e);if(Wu(r)){j().gateway.cimdEnabled||ti(r);try{return await Qu(r)}catch{ti(r)}}let o=await S().readClient({clientId:r});if(o.kind==="found"){let a=o.client,i=cl(a.clientId),s=i===void 0?a.tokenEndpointAuthMethod:"private_key_jwt",c=a.jwksUri??i;if(s==="private_key_jwt"&&c===void 0)throw new p("invalid_client","Dynamic private_key_jwt client is missing JWKS metadata. Re-run client registration before authorization.");let l={client_id:a.clientId,client_name:a.clientName,redirect_uris:a.redirectUris,token_endpoint_auth_method:s,...c===void 0?{}:{jwks_uri:c}},m={kind:"dcr",clientId:r,metadata:l};return a.hashedClientSecret&&(m.hashedClientSecret=a.hashedClientSecret),m}throw new p("invalid_client",r.startsWith("dcr:")?"Dynamic client is not registered. Re-run client registration before authorization.":"OAuth client is not registered.")}n(zt,"resolveClient");function ri(e,t){if(!e.metadata.redirect_uris.some(r=>Jn(r,t)))throw w("invalid_request","redirect_uri is not registered for the client.")}n(ri,"assertRedirectRegistered");function el(e){let t=ni(e.grant_types),r=e.response_types??[...Hr];if(!tl(t))throw new p("invalid_client_metadata","grant_types must be a subset of authorization_code and refresh_token.");if(!rl(r))throw new p("invalid_client_metadata","response_types must be code.");if(!nl(e.scope))throw new p("invalid_client_metadata",`Only the ${E} scope is supported.`)}n(el,"assertSupportedDcrRequest");function ni(e){return e===void 0?[...Dr]:Array.from(new Set(e))}n(ni,"normalizeGrantTypes");function tl(e){return e.length===0?!1:e.every(t=>Dr.includes(t))}n(tl,"isSupportedGrantTypes");function rl(e){return e.length===Hr.length&&e[0]==="code"}n(rl,"isSupportedResponseTypes");function nl(e){return e===void 0||e===E}n(nl,"isSupportedDcrScope");function ol(e){try{Rt(e)}catch(t){throw new p("invalid_client_metadata","jwks_uri must be an HTTPS URL with a path, no credentials, query, or fragment, and must not point at a blocked host.",void 0,{cause:t})}}n(ol,"assertValidDcrJwksUri");function al(e){let t=new TextEncoder().encode(e),r="";for(let o of t)r+=String.fromCharCode(o);return btoa(r).replaceAll("+","-").replaceAll("/","_").replace(/=+$/,"")}n(al,"encodeBase64Url");function il(e){let t=e.replaceAll("-","+").replaceAll("_","/"),r=t.padEnd(t.length+(4-t.length%4)%4,"="),o;try{o=atob(r)}catch{return}let a=new Uint8Array(o.length);for(let i=0;i<o.length;i+=1)a[i]=o.charCodeAt(i);return new TextDecoder().decode(a)}n(il,"decodeBase64Url");function sl(e){return e.tokenEndpointAuthMethod==="private_key_jwt"&&e.jwksUri!==void 0?Y.parse(`${Mr}${crypto.randomUUID()}:${al(e.jwksUri)}`):Y.parse(`dcr:${crypto.randomUUID()}`)}n(sl,"createDcrClientId");function Bt(e){return e.startsWith(Mr)}n(Bt,"isPrivateKeyJwtDcrCompatibilityClientId");function cl(e){if(!Bt(e))return;let t=e.slice(Mr.length),r=t.indexOf(":");if(r===-1)return;let o=il(t.slice(r+1));if(o!==void 0){try{Rt(o)}catch{return}return o}}n(cl,"readPrivateKeyJwtDcrClientIdJwksUri");function nt(e){if(e===void 0||e===E)return E;throw new p("invalid_request",`Only the ${E} scope is supported.`)}n(nt,"assertSupportedOAuthScope");function De(e,t,r){let o;try{o=new URL(t)}catch{throw new p("invalid_target","resource must be an absolute URI.")}if(o.hash)throw new p("invalid_target","resource must not include a fragment.");if(o.protocol!=="https:"&&!ue(o))throw new p("invalid_target","resource must use HTTPS except loopback HTTP resources in local development.");let a=U(e,r),i=zn(),s=i?[...i.byOperationId.values()].find(c=>new URL(c.routePath,a).toString()===t):void 0;if(!s)throw new p("invalid_target","resource must match a published MCP route.");return s}n(De,"resolveResource");async function oi(e){let t;try{t=Ju.parse(e)}catch(v){if(v instanceof d.ZodError){let N=v.issues.some(Re=>Re.path[0]==="redirect_uris");throw new p(N?"invalid_redirect_uri":"invalid_client_metadata",v.issues[0]?.message??"Client metadata is invalid.",void 0,{cause:v})}throw v}el(t);for(let v of t.redirect_uris)Me(v,"invalid_redirect_uri","dcr");if(t.token_endpoint_auth_method==="private_key_jwt"&&t.jwks_uri===void 0)throw new p("invalid_client_metadata","jwks_uri is required for private_key_jwt clients.");t.jwks_uri!==void 0&&ol(t.jwks_uri);let r=new Date,o=t.token_endpoint_auth_method??"none",a=o==="private_key_jwt"?"none":o,i=sl({tokenEndpointAuthMethod:o,jwksUri:t.jwks_uri}),s=W(r,Zu),c=Math.floor(r.getTime()/1e3),l=Math.floor(s.getTime()/1e3),m={client_id:i,client_name:t.client_name??"Dynamically registered MCP client",redirect_uris:t.redirect_uris,grant_types:ni(t.grant_types),response_types:["code"],scope:E,token_endpoint_auth_method:o,client_id_issued_at:c,...t.jwks_uri===void 0?{}:{jwks_uri:t.jwks_uri}},f={clientId:i,clientName:String(m.client_name),redirectUris:t.redirect_uris,tokenEndpointAuthMethod:a,createdAt:b(r),clientExpiresAt:b(s)};if(o==="client_secret_basic"||o==="client_secret_post"){let v=X();f.hashedClientSecret=await I(v),f.clientSecretExpiresAt=b(s),m.client_secret=v,m.client_secret_expires_at=l,m.client_secret_issued_at=c}if((await S().registerClient(f)).kind==="already_exists")throw w("invalid_request","OAuth client is already registered.");return m}n(oi,"registerDownstreamClient");function jt(e){return y`<img class="card__icon" src="${e.iconHref}" alt="" width="48" height="48" referrerpolicy="no-referrer" onerror=" this.onerror = null; this.src = '${e.fallbackIconHref}'; " />`}n(jt,"renderShellIcon");function ai(e){return y`<form class="actions" method="post" action="/oauth/setup" ${e.submitOnceAttrs}><input type="hidden" name="state" value="${e.state}" /><button class="button button--secondary" type="submit" name="decision" value="cancel" formnovalidate >Cancel</button><button class="button button--primary" type="submit" name="decision" value="approve" ${e.authorizeAttrs} >Authorize</button></form>`}n(ai,"renderActions");var qy=F('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><circle cx="8" cy="8" r="6.5"/><line x1="8" y1="4.6" x2="8" y2="8.4"/><circle cx="8" cy="11" r=".7" fill="currentColor" stroke="none"/></svg>');function ii(e){return y`<div class="banner banner--warning" role="status"><span class="banner__icon" aria-hidden="true">${e.icon}</span><div class="banner__body"><p class="banner__title">Setup required</p><p class="banner__message">${e.message}</p></div></div>`}n(ii,"renderBannerWarning");var My=F('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="14" height="14" fill="none" stroke="currentColor" stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M4 6.5l4 4 4-4"/></svg>'),si=F('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.6" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><rect x="3" y="4" width="18" height="7" rx="1.5"/><rect x="3" y="13" width="18" height="7" rx="1.5"/><circle cx="7" cy="7.5" r=".75" fill="currentColor" stroke="none"/><circle cx="7" cy="16.5" r=".75" fill="currentColor" stroke="none"/></svg>');function ci(e){return y`${e.banner}<section class="upstreams"><header class="section-label">Upstream services <span class="section-label__count">${e.sectionCount}</span></header><ul class="upstream-list">${e.cards}</ul></section>${e.fineprint}`}n(ci,"renderSetupPage");function di(e){return y`<article class="${e.cardClass}"><div class="upstream-card__head">${e.iconFrame}<div class="upstream-card__main"><div class="upstream-card__title-row"><h3 class="upstream-card__title">${e.upstreamDisplayName}</h3>${e.control}</div><div class="upstream-card__meta">${e.host}<span>${e.authModeLabel}</span><span class="upstream-card__sep" aria-hidden="true">·</span><span>${e.ownerModeLabel}</span></div>${e.description}</div></div>${e.capabilities} ${e.scopes}</article>`}n(di,"renderUpstreamCard");var ui=F('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M7.13 2.46 1.39 12.5a1 1 0 0 0 .87 1.5h11.48a1 1 0 0 0 .87-1.5L8.87 2.46a1 1 0 0 0-1.74 0Z"/><line x1="8" y1="6" x2="8" y2="9.4"/><circle cx="8" cy="11.4" r=".7" fill="currentColor" stroke="none"/></svg>');var dl="data:,",pi=y`data-submit-once="true" onsubmit="if (this.dataset.submitted === 'true') return false; this.dataset.submitted = 'true'; setTimeout(() => this.querySelectorAll('button').forEach((button) => { button.disabled = true; }), 0);"`,Br=y`data-activate-once="true" onclick="if (this.dataset.activated === 'true') return false; this.dataset.activated = 'true'; this.setAttribute('aria-disabled', 'true'); this.style.pointerEvents = 'none';"`;function mi(e,t){if(e)try{let r=new URL(t).origin,o=new URL(e,r);return o.origin!==r||!o.pathname.startsWith("/auth/connections/")?void 0:o.toString()}catch{return}}n(mi,"safeGatewayConnectHref");function ul(e){return e.some(r=>r.ownerMode==="user"&&r.status!=="active")?"setup":"grant"}n(ul,"deriveMode");function ll(e){return ai({state:e.state,submitOnceAttrs:pi,authorizeAttrs:k})}n(ll,"renderActions");function zr(e,t,r){for(let o of e){if(o.ownerMode!=="user"||o.status!==r)continue;let a=mi(o.connectUrl,t);if(a)return a}}n(zr,"firstUserConnectHref");function pl(e){let t=e.connectHref?y`<a class="button button--primary" href="${e.connectHref}" ${Br}>Connect</a>`:y`<button class="button button--primary" type="button" disabled aria-disabled="true">Connect</button>`;return y`<form class="actions" method="post" action="/oauth/setup" ${pi}><input type="hidden" name="state" value="${e.state}" /><button class="button button--secondary" type="submit" name="decision" value="cancel" formnovalidate>Cancel</button>${t}</form>`}n(pl,"renderSetupActions");function ml(e){return e?y`<span class="reconnect-action"><a class="button button--secondary reconnect-button" href="${e}" ${Br}>Re-connect<span class="tooltip" tabindex="0" aria-label="Reset or change how the gateway connects to the upstream service, including changing scopes.">?</span></a></span>`:k}n(ml,"renderReconnectAction");function fl(e){try{let t=new URL(e);return t.protocol==="https:"||t.protocol==="http:"?!0:t.protocol==="data:"&&/^data:image\/(?:png|jpe?g|webp|svg\+xml);/i.test(e)}catch{return!1}}n(fl,"isRenderableIconHref");function fi(e){return e?.find(t=>fl(t.src))?.src}n(fi,"readIconHref");function hi(e){return fi(e.serverIcons)??(e.transportHost===void 0?void 0:gr(e.transportHost).src)}n(hi,"readUpstreamIconHref");function hl(e){let t=hi(e);return t===void 0?y`<span class="icon-frame icon-frame--fallback" aria-hidden="true">${si}</span>`:y`<span class="icon-frame"><img src="${t}" alt="" referrerpolicy="no-referrer" loading="lazy" onerror=" this.onerror = null; this.src = '${tt}'; " /></span>`}n(hl,"renderIconFrame");function gl(e){let t=fi(e.routeIcons);if(t!==void 0)return t;for(let r of e.upstreams){let o=hi(r);if(o!==void 0)return o}}n(gl,"readHeaderIconHref");function yl(e){return y`<p class="card__subtitle"><strong>${e.clientDisplayName}</strong> wants to access <strong>${e.routeDisplayName}</strong></p>${e.routeDescription===void 0?k:y`<p class="card__description">${e.routeDescription}</p>`}${e.principalLabel===void 0?k:y`<span class="card__principal" title="Signed in as ${e.principalLabel}">${e.principalLabel}</span>`}`}n(yl,"renderSubhead");function _l(e){let t=e.filter(o=>o.ownerMode==="user"&&o.status!=="active");if(t.length===0)return k;let r=t.length===1?y`Connect ${t[0]?.upstreamDisplayName??"the required service"} before continuing. Authorization will continue automatically once it is ready.`:y`Connect the ${t.length} services below before continuing. Authorization will continue automatically once each is ready.`;return ii({icon:ui,message:r})}n(_l,"renderSetupBanner");function wl(e){return e===void 0?k:y`<code class="upstream-card__host">${e}</code><span class="upstream-card__sep" aria-hidden="true">·</span>`}n(wl,"renderHost");function Rl(e){switch(e){case"shared-oauth":case"user-oauth":return"OAuth";default:return e}}n(Rl,"readAuthModeLabel");function bl(e){switch(e){case"user":return"your account";case"shared":return"workspace";case"none":return"no auth"}}n(bl,"readOwnerModeLabel");function Sl(e){switch(e){case"active":return"Connected";case"reconsent_required":return"Reconnect";case"not_connected":return"Setup required"}}n(Sl,"readStatusLabel");function li(e){let t=e.status==="active"?"status-badge status-badge--success":"status-badge status-badge--warning";return y`<span class="${t}">${Sl(e.status)}</span>`}n(li,"renderStatusBadge");function Cl(e,t){if(!(e.ownerMode==="user"&&e.status!=="active"))return li(e);let o=mi(e.connectUrl,t);return o===void 0?li(e):y`<a class="button button--secondary button--small" href="${o}" ${Br}>Connect</a>`}n(Cl,"renderUpstreamControl");function vl(e){return e===void 0?k:y`<p class="upstream-card__description">${e}</p>`}n(vl,"renderDescription");function Il(e){return xa(e.upstreams.map(t=>{let r=t.ownerMode==="user"&&t.status!=="active";return y`<li>${di({cardClass:r?"upstream-card upstream-card--needs-action":"upstream-card",iconFrame:hl(t),upstreamDisplayName:t.upstreamDisplayName,control:Cl(t,e.gatewayOrigin),host:wl(t.transportHost),authModeLabel:Rl(t.authMode),ownerModeLabel:bl(t.ownerMode),description:vl(t.description),capabilities:k,scopes:k})}</li>`}))}n(Il,"renderUpstreamCards");function xl(e){return e.mode==="setup"?y`<p class="card__fineprint">Authorization continues automatically once every required service is connected.</p>`:y`<p class="card__fineprint"><strong>${e.clientDisplayName}</strong> will receive a token scoped to <strong>${e.routeDisplayName}</strong>.</p>`}n(xl,"renderFineprint");function Al(e){return e.upstreams.length===0?k:ci({banner:e.mode==="setup"?_l(e.upstreams):k,sectionCount:`(${e.upstreams.length})`,cards:Il({upstreams:e.upstreams,gatewayOrigin:e.gatewayOrigin}),fineprint:xl({mode:e.mode,clientDisplayName:e.clientDisplayName,routeDisplayName:e.routeDisplayName})})}n(Al,"renderBody");function jr(e){let t=ul(e.upstreams),r=zr(e.upstreams,e.gatewayOrigin,"not_connected"),o=zr(e.upstreams,e.gatewayOrigin,"reconsent_required"),a=zr(e.upstreams,e.gatewayOrigin,"active"),i=t==="setup"?r??o:void 0,s=gl({routeIcons:e.routeIcons,upstreams:e.upstreams}),c=t==="setup"?y`<footer class="card__footer">${pl({state:e.state,connectHref:i})}</footer>`:y`<footer class="card__footer">${ml(a)}${ll({state:e.state})}</footer>`;return Pe(Oe({title:`Authorize access \xB7 ${e.routeDisplayName}`,iconHref:s??dl,styles:Ee,headerIcon:s===void 0?k:jt({iconHref:s,fallbackIconHref:tt}),heading:"Authorize access",subhead:yl({routeDisplayName:e.routeDisplayName,routeDescription:e.routeDescription,clientDisplayName:e.clientDisplayName,principalLabel:e.principalLabel}),body:Al({mode:t,gatewayOrigin:e.gatewayOrigin,routeDisplayName:e.routeDisplayName,clientDisplayName:e.clientDisplayName,upstreams:e.upstreams}),footer:c}))}n(jr,"renderConsentPage");var Ul=1e4,gi="mcp-session-id",kl,yi;function Si(){return{tools:[],prompts:[],resources:[]}}n(Si,"emptyCapabilities");function _i(e){let t=new Headers({accept:"application/json, text/event-stream","content-type":"application/json","mcp-protocol-version":Vt});switch(e.type){case"none":return t;case"bearer_token":return t.set("authorization",`Bearer ${e.token}`),t;case"headers":for(let[r,o]of Object.entries(e.headers))t.set(r,o);return t;case"mcp_oauth_provider":throw new Error("MCP OAuth provider credentials require async headers.")}}n(_i,"buildCredentialHeaders");async function wi(e){if(e.type!=="mcp_oauth_provider")return _i(e);let t=await e.provider.tokens();if(!t)return;let r=_i({type:"none"});return r.set("authorization",`${t.token_type??"Bearer"} ${t.access_token}`),r}n(wi,"buildAsyncCredentialHeaders");function Ri(e){return new Request(e.upstreamUrl,{method:"POST",headers:e.headers,body:JSON.stringify(ft.parse({jsonrpc:mt,id:1,method:"initialize",params:{protocolVersion:Vt,capabilities:{},clientInfo:{name:"zuplo-mcp-gateway-readiness",version:"0.0.0"}}}))})}n(Ri,"buildInitializePreflight");async function Lr(e){lo(e.url);let t=new AbortController,r=setTimeout(()=>t.abort(),Ul);try{let o=new Request(e,{redirect:"manual",signal:t.signal});return yi?await yi(o):await ct.fetch(o)}finally{clearTimeout(r)}}n(Lr,"runPreflight");function Nr(e){e.body?.cancel().catch(()=>{})}n(Nr,"releasePreflightBody");async function Tl(e){let t=e.response.headers.get(gi);if(!t)return;let r=new Headers(e.headers);r.set(gi,t),r.delete("content-type");try{let o=await Lr(new Request(e.upstreamUrl,{method:"DELETE",headers:r}));Nr(o)}catch{}}n(Tl,"terminatePreflightSession");async function Ci(e){let{response:t}=e;return Nr(t),t.status>=200&&t.status<300?(await Tl(e),{kind:"ready",upstreamStatus:t.status,capabilities:Si()}):t.status===401||t.status===403?{kind:"upstream_auth_rejected",status:t.status,message:"Upstream MCP server rejected the configured credential."}:{kind:"upstream_unavailable",status:t.status,message:"Upstream MCP server did not accept the readiness preflight."}}n(Ci,"classifyResponse");function bi(e){let t={status:e.state==="reconsent_required"?"reconsent_required":"not_connected",connected:!1};return e.nextAction==="admin_setup_required"?{kind:"admin_setup_required",payload:e,connectionStatus:t}:{kind:"connect_required",payload:e,connectionStatus:t}}n(bi,"connectRequiredResult");async function Pl(e){try{return Ci({response:await Lr(e.request),upstreamUrl:e.upstreamUrl,headers:e.headers})}catch(t){return{kind:"upstream_unavailable",message:t instanceof Error?t.message:"Upstream MCP server readiness preflight failed."}}}n(Pl,"classifyPreflight");async function El(e){let t=e.route.connection;if(t===void 0)return{kind:"ready",upstreamStatus:204,capabilities:Si()};let r=Pt(t.upstreamServerId,e.route.operationId),o=Te(r,e.subjectId),a=e.returnTo===void 0?o:{...o,returnTo:e.returnTo},i=new Request(e.requestUrl,{...e.requestHeaders===void 0?{}:{headers:e.requestHeaders}}),s=await ke({request:i,routeAuth:a,preloadedConnection:e.preloadedConnection});if(s.kind==="connect_required")return bi(s.payload);let c=await wi(s.credential);if(c===void 0)return{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens."};let l=Ri({upstreamUrl:t.mcpUrl,headers:c}),m;try{m=await Lr(l)}catch(v){return{kind:"upstream_unavailable",message:v instanceof Error?v.message:"Upstream MCP server readiness preflight failed."}}if(m.status!==401)return Ci({response:m,upstreamUrl:t.mcpUrl,headers:c});Nr(m);let f=await ke({request:i,routeAuth:a,forceRefresh:!0,preloadedConnection:e.preloadedConnection});if(f.kind==="connect_required")return bi(f.payload);let A=await wi(f.credential);return A===void 0?{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens after refresh."}:Pl({request:Ri({upstreamUrl:t.mcpUrl,headers:A}),upstreamUrl:t.mcpUrl,headers:A})}n(El,"checkUpstreamRouteReadinessImpl");function vi(e){return(kl??El)(e)}n(vi,"checkUpstreamRouteReadiness");function Ol(e){try{return new URL(e).host}catch{return}}n(Ol,"safeUrlHost");function ql(e){if(e.mode==="user-oauth"||e.mode==="shared-oauth")return e.oauth.scopes}n(ql,"readOAuthScopes");function Ii(e){return e!==void 0&&e.length>0}n(Ii,"hasItems");function Ml(e){let t=e.serverInfo?.icons;if(Ii(t))return t;let r=xt(e.mcpUrl);return r===void 0?void 0:[r]}n(Ml,"readServerIcons");async function Dl(e){if(!(e.returnTo===void 0||!e.isUserOwned))return _r({requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.userOwner,initiatedBySubjectId:e.transaction.principal.subjectId,upstreamServerId:e.registeredConnection.upstreamServerId,authProfileId:e.registeredConnection.authProfileId,operationId:e.route.operationId,returnTo:e.returnTo})}n(Dl,"readConnectUrl");function _e(e,t){return t===void 0?{}:{[e]:t}}n(_e,"optionalRequirementField");function Hl(e){return e.readiness!==void 0?e.readiness:e.isUserOwned?ao(e.connection):{connected:!0,status:"active"}}n(Hl,"readSetupConnectionStatus");function zl(e){let t=ql(e);return Ii(t)?t:void 0}n(zl,"readScopesRequested");function Bl(e){return e.isUserOwned&&"updatedAt"in e.connectionStatus&&e.connectionStatus.updatedAt!==void 0?e.connectionStatus.updatedAt:void 0}n(Bl,"readUpdatedAt");function jl(){return{tools:[],prompts:[],resources:[]}}n(jl,"readRouteCapabilities");async function Ll(e){let{authConfig:t,authMode:r,description:o,displayName:a,mcpUrl:i,upstreamServerId:s,authProfileId:c}=e.registeredConnection,l=At(r),m=l==="user",f=Hl({connection:e.connection,isUserOwned:m,readiness:e.readiness}),A=e.readiness?.connectUrl??await Dl({...e,connected:f.connected,isUserOwned:m});return{upstreamServerId:s,authProfileId:c,authMode:r,ownerMode:l,upstreamDisplayName:a,status:f.status,connected:f.connected,capabilities:jl(),..._e("description",o),..._e("transportHost",Ol(i)),..._e("scopesRequested",zl(t)),..._e("serverIcons",Ml(e.registeredConnection)),..._e("connectUrl",A),..._e("updatedAt",Bl({connectionStatus:f,isUserOwned:m})),..._e("expiresAt",e.readiness?.expiresAt??e.connection?.expiresAt)}}n(Ll,"buildSetupRequirement");function xi(e){let t=$().byOperationId.get(e);if(!t)throw w("unknown_mcp_route",`Unknown MCP route: ${e}`);return t}n(xi,"requireRoute");async function $r(e){let t=xi(e.transaction.operationId),r=_t(e.transaction.principal.subjectId),o=[],a=new Map,i=t.connection;if(i===void 0)return[];At(i.authMode)==="user"&&(a.set(i,o.length),o.push({owner:r,upstreamServerId:i.upstreamServerId,authProfileId:i.authProfileId}));let s=await S().batchGetUpstreamConnections(o),c=[],l=At(i.authMode)==="user",m=a.get(i),f=await vi({requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},route:t,subjectId:e.transaction.principal.subjectId,preloadedConnection:l&&m!==void 0?s[m]:void 0,...e.returnTo===void 0?{}:{returnTo:e.returnTo}}),A=(()=>{if("connectionStatus"in f&&f.connectionStatus)return f.connectionStatus})(),v=(f.kind==="connect_required"||f.kind==="admin_setup_required")&&f.payload.authUrl!==void 0?f.payload.authUrl:void 0;return c.push(await Ll({connection:l&&m!==void 0?s[m]:void 0,registeredConnection:i,route:t,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},returnTo:e.returnTo,transaction:e.transaction,userOwner:r,readiness:A===void 0?void 0:{...A,...v===void 0?{}:{connectUrl:v}}})),c}n($r,"requirementsForSetup");function Nl(e){return e.route.connection?.displayName??e.route.operationId}n(Nl,"readRouteDisplayName");async function Gr(e){let t=xi(e.transaction.operationId),r=Nl({route:t}),o=await S().readClient({clientId:e.transaction.clientId}),a=o.kind==="found"?o.client:void 0,i={gatewayOrigin:U(e.requestUrl,e.requestHeaders),routeDisplayName:r,clientDisplayName:a?.clientName??String(e.transaction.clientId),principalLabel:e.transaction.principal.subjectId},s=t.connection?.description;return s!==void 0&&(i.routeDescription=s),i}n(Gr,"consentContext");function Zr(e){return e.some(t=>t.ownerMode==="user"&&t.status!=="active")}n(Zr,"hasUnresolvedUserUpstream");var $l=["mcp_user"],Gl="dev-browser-user",Zl=["resource is required for /oauth/authorize.","MCP clients should start at the MCP server URL and follow its WWW-Authenticate resource_metadata link.","If your client reached this endpoint directly, use /oauth/authorize/{routePath} where {routePath} is the published MCP route path without a leading slash and each segment is URL-encoded as needed, for example /oauth/authorize/mcp/linear, or add resource={protected resource URI from protected-resource metadata}."].join(" "),Fl=d.object({response_type:d.literal("code"),client_id:d.string().min(1),redirect_uri:d.string().min(1),resource:d.url(),code_challenge:d.string().min(43),code_challenge_method:Gn,state:d.string().min(1).optional(),scope:d.literal(E).default(E)}),Kl=d.enum(["continue","approve","cancel"]).default("continue"),Jl=d.object({state:d.string().min(1),decision:Kl}),ie=class extends Error{static{n(this,"DownstreamAuthorizeRedirectError")}redirectUri;clientState;errorCode;errorDescription;constructor(t){super(t.errorDescription?`${t.errorCode}: ${t.errorDescription}`:t.errorCode,t.cause===void 0?void 0:{cause:t.cause}),this.name="DownstreamAuthorizeRedirectError",this.redirectUri=t.redirectUri,this.clientState=t.clientState,this.errorCode=t.errorCode,this.errorDescription=t.errorDescription}};function Ai(e){return typeof e=="string"&&e.length>0?e:void 0}n(Ai,"readQueryString");function Wl(e){let t=Array.from($().byOperationId.values());if(t.length!==1)return;let r=t[0];if(r!==void 0)return Yt(r.operationId,e.url,e.headers)}n(Wl,"inferSingleRouteResource");function Vl(e,t){let r=Ai(e.query.resource);if(t===void 0){if(r!==void 0)return r;let a=Wl(e);if(a!==void 0)return a;throw new p("invalid_target",Zl)}let o=Yt(t,e.url,e.headers);if(r===void 0||r===o)return o;throw new p("invalid_target","resource must match the scoped OAuth authorization endpoint resource.")}n(Vl,"requireAuthorizeResource");async function Yl(e,t){let r={};t!==void 0&&(r.context=t);let o=await Mt(e,r);if(o.principal)return{principal:o.principal};if(!e.user)return o.evictCookie===void 0?{}:{setCookie:o.evictCookie};let a=qa(e);return{principal:a,setCookie:await Dt({principal:a,requestUrl:e.url,requestHeaders:e.headers})}}n(Yl,"resolveBrowserPrincipal");async function Xl(e,t){let r={};t!==void 0&&(r.context=t);let o=await Mt(e,r);if(!o.principal)throw w("authentication_required","Authorization setup requires a current browser session.");return o.principal}n(Xl,"requireSetupPrincipal");function Ui(e){return`/oauth/setup?state=${encodeURIComponent(e)}`}n(Ui,"buildSetupReturnTo");async function ki(e){let t=await $r({transaction:e.transaction,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},returnTo:Ui(e.csrfToken)}),r=await Gr({transaction:e.transaction,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}}),o={kind:"setup_page",html:jr({state:e.csrfToken,operationId:e.transaction.operationId,upstreams:t,...r})};return e.setCookie!==void 0&&(o.setCookie=e.setCookie),o}n(ki,"renderSetup");function Ql(e){if(e===void 0)return;let t=e.metadata.token_endpoint_auth_method;return{clientId:e.clientId,clientName:e.metadata.client_name,tokenEndpointAuthMethod:t}}n(Ql,"toAuthorizationTransactionClient");async function Fr(e,t={}){let r=Fl.parse({...e.query,resource:Vl(e,t.operationId),state:Ai(e.query.state)}),o=nt(r.scope);Me(r.redirect_uri,"invalid_request","authorize");let a=new Date,i=Y.parse(r.client_id),s=await zt(r.client_id,a);ri(s,r.redirect_uri);try{let c=De(e.url,r.resource,e.headers),l=Ql(s);t.context?.log.info({event:"oauth_authorize_request_parsed",clientId:i,operationId:c.operationId,scope:o,hasClientState:r.state!==void 0},"Downstream OAuth authorize: request parsed and client resolved"),t.context&&C(t.context,{eventType:R.MCP_OAUTH_AUTHORIZE_STARTED,outcome:"success",virtualServerName:c.operationId,attributes:{clientId:i,scope:o,responseType:r.response_type}});let m={clientId:s?.clientId??i,...l===void 0?{}:{client:l},redirectUri:r.redirect_uri,resource:r.resource,operationId:c.operationId,scope:o,codeChallenge:r.code_challenge,codeChallengeMethod:r.code_challenge_method,...r.state===void 0?{}:{clientState:r.state}},{principal:f,setCookie:A}=await Yl(e,t.context);if(!f){let N=await Wa({transaction:m,requestUrl:e.url,requestHeaders:e.headers,now:a});t.context?.log.info({event:"oauth_authorize_awaiting_login",clientId:i,operationId:c.operationId},"Downstream OAuth authorize: redirecting to browser login (no session)");let Re={kind:"redirect",location:N.browserLoginUrl};return A!==void 0&&(Re.setCookie=A),Re}let v=await Va({transaction:m,principal:f,now:a});return t.context?.log.info({event:"oauth_authorize_awaiting_setup",clientId:i,operationId:c.operationId,subjectId:f.subjectId},"Downstream OAuth authorize: rendering consent/setup page"),t.context&&C(t.context,{eventType:R.MCP_OAUTH_AUTHORIZE_AWAITING_SETUP,outcome:"success",virtualServerName:c.operationId,attributes:{clientId:i,scope:o,responseType:r.response_type,subjectId:f.subjectId}}),ki({transaction:v.transaction,csrfToken:v.csrfToken,requestUrl:e.url,requestHeaders:e.headers,setCookie:A})}catch(c){throw ep({redirectUri:r.redirect_uri,clientState:r.state,cause:c})}}n(Fr,"authorizeDownstreamClient");function ep(e){if(e.cause instanceof ie)return e.cause;let t=tp(e.cause);return t?new ie({redirectUri:e.redirectUri,clientState:e.clientState,errorCode:t.errorCode,errorDescription:t.errorDescription,cause:e.cause}):e.cause}n(ep,"toDownstreamAuthorizeRedirectError");function tp(e){if(e instanceof p)return{errorCode:e.errorCode,errorDescription:e.message};if(e instanceof d.ZodError){let t=e.issues[0];return{errorCode:t?.path.includes("resource")?"invalid_target":"invalid_request",errorDescription:t?.message}}}n(tp,"mapToOAuthRedirectError");async function Ti(e,t={}){let r=typeof e.query.error=="string"?e.query.error:void 0;if(r){let m=typeof e.query.error_description=="string"?e.query.error_description.slice(0,256):void 0,f=typeof e.query.error_uri=="string"?e.query.error_uri.slice(0,256):void 0;throw t.context?.log.warn({event:"browser_login_callback_idp_error",code:"provider_access_denied",idpError:r,...m===void 0?{}:{idpErrorDescription:m},...f===void 0?{}:{idpErrorUri:f}},"Identity provider redirected browser-login callback with an error"),w("provider_access_denied",m??"The delegated browser login was not completed.")}let o=typeof e.query.state=="string"?e.query.state:void 0;if(!o)throw t.context?.log.warn({event:"browser_login_callback_state_missing",code:"oauth_state_invalid"},"Browser login callback was invoked without a state parameter"),w("oauth_state_invalid","Browser login callback is missing state.");let a=await Pr(o),i={request:e,stateId:a.stateId};t.context!==void 0&&(i.context=t.context);let s=await Ma(i),c=await Ya({browserLoginStateToken:o,principal:s}),l=await ki({transaction:c.transaction,csrfToken:c.csrfToken,requestUrl:e.url,requestHeaders:e.headers});return l.setCookie=await Dt({principal:s,requestUrl:e.url,requestHeaders:e.headers}),l}n(Ti,"completeBrowserLoginCallback");async function Pi(e){let t=j(),r=new URL(e.url);if(!ue(r))throw w("forbidden","Local browser login is only available on loopback HTTP origins.");let o=typeof e.query.state=="string"?e.query.state:void 0;if(!o)throw w("oauth_state_invalid","Local browser login is missing state.");let a=new URL(typeof e.query.redirect_uri=="string"?e.query.redirect_uri:"/oauth/callback",U(e.url)),i=new URL(U(e.url)).origin;if(a.origin!==i||a.pathname!=="/oauth/callback")throw w("oauth_callback_mismatch","Local browser login redirect_uri must target this gateway's /oauth/callback route.");a.searchParams.set("state",o);let s={subjectId:yt.parse(Gl),roles:$l};return{kind:"redirect",location:a,setCookie:await Dt({principal:s,requestUrl:e.url,requestHeaders:e.headers})}}n(Pi,"completeLocalDevBrowserLogin");function rp(e){let t=e.method==="POST"?e.body:e.query;return Jl.parse(t)}n(rp,"readSetupContinueRequest");async function Ei(e){let{state:t,decision:r}=rp({method:e.request.method,query:e.request.query,body:e.body}),o=new Date,a=await qr({csrfToken:t,now:o}),i=await Xl(e.request,e.context);if(r==="cancel")return{kind:"redirect",location:await ei({csrfToken:t,currentBrowserPrincipal:i,now:o})};let s=await Xa({csrfToken:t,currentBrowserPrincipal:i,now:o}),c=await $r({transaction:s,requestUrl:e.request.url,requestHeaders:e.request.headers,returnTo:Ui(t)});if(r==="approve"&&Zr(c)&&await Ka({csrfToken:t,currentBrowserPrincipal:i,now:o}),Zr(c)){let l=await Gr({transaction:s,requestUrl:e.request.url,requestHeaders:e.request.headers});return{kind:"setup_page",html:jr({state:t,operationId:s.operationId,upstreams:c,...l})}}return{kind:"redirect",location:await Qa({csrfToken:t,currentBrowserPrincipal:i,now:o})}}n(Ei,"continueDownstreamAuthorizeSetup");B();import{createLocalJWKSet as np,decodeJwt as op,errors as ot,jwtVerify as ap}from"jose";var ip=new Set(["authorization_code","refresh_token"]),sp="urn:ietf:params:oauth:client-assertion-type:jwt-bearer",cp=1e4,dp=32*1024,up=2,Oi=d.object({client_id:d.string().min(1).optional(),client_secret:d.string().min(1).optional(),client_assertion_type:d.string().min(1).optional(),client_assertion:d.string().min(1).optional()}),lp=d.discriminatedUnion("grant_type",[Oi.extend({grant_type:d.literal("authorization_code"),code:d.string().min(1),redirect_uri:d.string().min(1),code_verifier:gt,resource:d.url().optional(),scope:d.literal(E).optional()}),Oi.extend({grant_type:d.literal("refresh_token"),refresh_token:d.string().min(1),resource:d.url().optional(),scope:d.literal(E).optional()})]);function pp(e){if(typeof e!="object"||e===null)return;let t=e.grant_type;if(t!==void 0&&(typeof t!="string"||!ip.has(t)))throw new p("unsupported_grant_type",`Grant type "${typeof t=="string"?t:""}" is not supported.`)}n(pp,"assertSupportedGrantType");var mp=d.object({token:d.string().min(1),client_id:d.string().min(1).optional(),token_type_hint:d.string().optional(),client_secret:d.string().min(1).optional(),client_assertion_type:d.string().min(1).optional(),client_assertion:d.string().min(1).optional()}),fp=d.object({keys:d.array(d.record(d.string(),d.unknown())).min(1)}).passthrough();function qi(){return j().gateway.accessTokenTtlSeconds}n(qi,"readAccessTokenTtlSeconds");function hp(){return j().gateway.refreshTokenTtlSeconds}n(hp,"readRefreshTokenTtlSeconds");function gp(e,t){let r=qi(),o=Math.max(1,Math.floor((new Date(t).getTime()-e.getTime())/1e3)),a=Math.min(r,o);return{expiresAt:b(W(e,a)),expiresIn:a}}n(gp,"calculateAccessTokenExpiresAt");function Mi(e){if(!e?.startsWith("Basic "))return{};let t;try{t=atob(e.slice(6))}catch{throw new p("invalid_client","Malformed HTTP Basic client authentication.")}let r=t.indexOf(":");if(r<0)throw new p("invalid_client","Malformed HTTP Basic client authentication.");try{return{clientId:decodeURIComponent(t.slice(0,r)),clientSecret:decodeURIComponent(t.slice(r+1))}}catch{throw new p("invalid_client","Malformed HTTP Basic client authentication.")}}n(Mi,"readBasicClientSecret");function Di(e){if(e.basicClientId!==void 0&&e.bodyClientId!==void 0&&e.basicClientId!==e.bodyClientId)throw new p("invalid_request","Authenticated client_id must match request client_id.");let t=e.basicClientId??e.bodyClientId;if(t!==void 0)return t;if(e.clientAssertion!==void 0){try{let r=op(e.clientAssertion);if(typeof r.iss=="string"&&typeof r.sub=="string"&&r.iss===r.sub)return r.iss}catch{throw new p("invalid_client","Malformed private_key_jwt client assertion.")}throw new p("invalid_client","private_key_jwt client assertion must identify the client with matching iss and sub claims.")}throw new p("invalid_client","Client authentication or client_id is required.")}n(Di,"resolveAuthenticatedClientId");function yp(e){if(e.basicClientSecret!==void 0&&e.bodyClientSecret!==void 0)throw new p("invalid_request","Use only one client authentication method per request.");return e.basicClientSecret!==void 0?{clientSecret:e.basicClientSecret,clientSecretSource:"basic"}:e.bodyClientSecret!==void 0?{clientSecret:e.bodyClientSecret,clientSecretSource:"post"}:{}}n(yp,"resolveClientSecretInput");function _p(e){return e.clientAssertion!==void 0||e.clientAssertionType!==void 0}n(_p,"hasClientAssertion");function wp(e){if(e.requestUrl===void 0)throw new p("invalid_request","Request URL is required for private_key_jwt client authentication.");let t=new URL(e.pathname,U(e.requestUrl,e.requestHeaders));return t.search="",t.hash="",t.toString()}n(wp,"buildEndpointAudience");function Rp(e){return e instanceof ot.JWTExpired?"expired":e instanceof ot.JWTClaimValidationFailed?"claim":e instanceof ot.JWSSignatureVerificationFailed?"signature":e instanceof ot.JWKSNoMatchingKey?"jwks_no_match":e instanceof ot.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(Rp,"readJwtFailureKind");async function bp(e){let{response:t,json:r}=await go(e.jwksUri,{headers:{accept:"application/json"}},{context:e.context,maxRedirects:up,maxResponseBytes:dp,timeoutMs:cp});if(!t.ok)throw new p("invalid_client","Client JWKS could not be fetched.");return fp.parse(r)}n(bp,"fetchClientJwks");async function Sp(e){if(e.clientAssertionType!==sp||e.clientAssertion===void 0)throw new p("invalid_request","private_key_jwt client authentication requires a JWT bearer client_assertion and client_assertion_type.");let t=Y.parse(e.clientId),r=await zt(t,e.now);if(r.metadata.token_endpoint_auth_method!=="private_key_jwt")throw new p("invalid_client","Client is not registered for private_key_jwt authentication.");let o=r.metadata.jwks_uri;if(o===void 0)throw new p("invalid_client","Client JWKS URI is required for private_key_jwt authentication.");let a=wp({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,pathname:e.endpointPathname});try{let i=await bp({jwksUri:o,context:e.context});await ap(e.clientAssertion,np(i),{issuer:t,subject:t,audience:a,currentDate:e.now})}catch(i){throw e.context?.log.warn({event:"oauth_private_key_jwt_client_auth_failed",clientId:t,failureKind:Rp(i)},"OAuth private_key_jwt client authentication failed"),new p("invalid_client","Client authentication failed.")}return Bt(t)?{method:"none",clientId:t}:{method:"private_key_jwt",clientId:t}}n(Sp,"verifyPrivateKeyJwtClientAssertion");async function Cp(e){let t=Y.parse(e.clientId);if(Bt(t))throw new p("invalid_client","Client is registered for private_key_jwt authentication.");return e.clientSecret===void 0?{method:"none",clientId:t}:{method:e.clientSecretSource==="post"?"client_secret_post":"client_secret_basic",clientId:t,clientSecretHashInput:await I(e.clientSecret)}}n(Cp,"buildRuntimeHttpClientAuth");async function Hi(e){if(_p({clientAssertion:e.clientAssertion,clientAssertionType:e.clientAssertionType})){if(e.basicClientSecret!==void 0||e.bodyClientSecret!==void 0)throw new p("invalid_request","Use only one client authentication method per request.");return Sp(e)}let t=yp({basicClientSecret:e.basicClientSecret,bodyClientSecret:e.bodyClientSecret});return Cp({clientId:e.clientId,...t})}n(Hi,"resolveRuntimeHttpClientAuth");async function zi(e){pp(e.body);let t=lp.parse(e.body),r=Mi(e.authorizationHeader),o=Di({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),a=new Date,i=await Hi({clientId:o,basicClientSecret:r.clientSecret,bodyClientSecret:t.client_secret,clientAssertion:t.client_assertion,clientAssertionType:t.client_assertion_type,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,endpointPathname:"/oauth/token",now:a,context:e.context});return vp({parsed:t,clientId:o,clientAuth:i,now:a,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,context:e.context})}n(zi,"exchangeDownstreamToken");async function vp(e){if(e.parsed.grant_type==="authorization_code"){Me(e.parsed.redirect_uri,"invalid_request","token"),nt(e.parsed.scope),e.parsed.resource!==void 0&&De(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let s=X(),c=X(),l=b(W(e.now,hp())),m=gp(e.now,l),f=await S().exchangeAuthorizationCode({clientAuth:e.clientAuth,codeHash:await I(e.parsed.code),redirectUri:e.parsed.redirect_uri,...e.parsed.resource===void 0?{}:{resource:e.parsed.resource},codeChallenge:await uo(e.parsed.code_verifier),currentRefreshTokenHash:await I(s),accessTokenHash:await I(c),grantExpiresAt:l,accessTokenExpiresAt:m.expiresAt,now:b(e.now)});if(f.kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");if(f.kind==="resource_mismatch")throw new p("invalid_target","Token request resource must match the authorization code resource.");if(f.kind!=="exchanged")throw new p("invalid_grant","Authorization code is invalid, expired, already used, or failed binding validation.");return e.context&&C(e.context,{eventType:R.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"authorization_code"}}),{access_token:c,token_type:"Bearer",expires_in:m.expiresIn,refresh_token:s,scope:f.grant.scope,resource:f.grant.resource}}nt(e.parsed.scope),e.parsed.resource!==void 0&&De(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let t=X(),r=X(),o=b(W(e.now,qi())),a=await S().refreshToken({clientAuth:e.clientAuth,currentRefreshTokenHash:await I(e.parsed.refresh_token),nextRefreshTokenHash:await I(t),accessTokenHash:await I(r),...e.parsed.resource===void 0?{}:{resource:e.parsed.resource},accessTokenExpiresAt:o,now:b(e.now)});if(a.kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");if(a.kind==="resource_mismatch")throw new p("invalid_target","Token request resource must match the refresh token grant resource.");if(a.kind!=="rotated")throw new p("invalid_grant","Refresh token is invalid, expired, or revoked.");De(e.requestUrl??a.grant.resource,a.grant.resource,e.requestHeaders);let i=a.accessToken.expiresAt;return e.context&&(C(e.context,{eventType:R.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"refresh_token"}}),C(e.context,{eventType:R.MCP_OAUTH_TOKEN_REFRESH_ROTATED,outcome:"success",attributes:{clientId:e.clientId}})),{access_token:r,token_type:"Bearer",expires_in:Math.max(1,Math.floor((new Date(i).getTime()-e.now.getTime())/1e3)),refresh_token:t,scope:a.grant.scope,resource:a.grant.resource}}n(vp,"exchangeDownstreamTokenWithRuntimeHttp");async function Bi(e){let t=mp.parse(e.body),r=Mi(e.authorizationHeader),o=Di({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),a=new Date;if((await S().revokeOAuthToken({clientAuth:await Hi({clientId:o,basicClientSecret:r.clientSecret,bodyClientSecret:t.client_secret,clientAssertion:t.client_assertion,clientAssertionType:t.client_assertion_type,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,endpointPathname:"/oauth/revoke",now:a,context:e.context}),tokenHash:await I(t.token),now:b(a)})).kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");e.context?.log.info({event:"oauth_token_revoked",clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}},"OAuth token revocation request processed"),e.context&&C(e.context,{eventType:R.MCP_OAUTH_TOKEN_REVOKED,outcome:"success",attributes:{clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}}})}n(Bi,"revokeDownstreamToken");var Ip=64*1024,xp=16*1024,Ap="text/html; charset=utf-8";function Up(e){let t={};for(let[r,o]of e.entries())t[r]=o;return t}n(Up,"formDataToObject");async function kp(e){return Ta(e,{maxBytes:Ip,label:"Request body"})}n(kp,"readJsonBody");async function Jr(e){return Up(await Pa(e,{maxBytes:xp,label:"Request body"}))}n(Jr,"readFormBody");async function Li(e,t,r){let o=le(r),a=r instanceof d.ZodError?se(r):void 0,i={code:o??(r instanceof d.ZodError?"invalid_request":"internal_server_error")};return a!==void 0&&(i.detail=a),Nn(e,t,i)}n(Li,"handleProblem");function Ni(e){return e?.requestId}n(Ni,"readBrowserRequestId");function $i(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[Se];return typeof t=="string"?t:void 0}n($i,"readUpstreamHtmlError");function ji(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(ji,"readRuntimeErrorExtensionString");function Tp(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(Tp,"readRuntimeErrorExtensionNumber");function Pp(e){try{return new URL(e.url).pathname}catch{return}}n(Pp,"readBrowserRequestPath");function we(e){let t={code:e.code,requestId:e.requestId,routePath:Pp(e.request),underlyingError:e.underlyingError};return e.error instanceof g&&(t.httpStatus=Tp(e.error,Ce),t.contentType=ji(e.error,be),t.upstreamUrl=ji(e.error,ve)),t}n(we,"buildBrowserErrorDiagnostic");function at(e){let t=new Headers(e.headers);t.set("cache-control","no-store"),t.set("pragma","no-cache");let r={error:e.error};return e.errorDescription!==void 0&&(r.error_description=e.errorDescription),Response.json(r,{status:e.status??400,headers:t})}n(at,"oauthErrorResponse");function Ep(e,t){return e.errorCode!=="invalid_client"?{}:t.includeInvalidClientChallenge===!1?{}:{"WWW-Authenticate":'Basic realm="OAuth"'}}n(Ep,"readOAuthProtocolHeaders");function Op(e,t){let r=L("internal_server_error");return at({error:e.errorCode,errorDescription:e.errorCode==="server_error"?r.publicDetail:e.message,status:e.status,headers:Ep(e,t)})}n(Op,"oauthProtocolErrorResponse");function Kr(e){return e.issues[0]?.path.includes("resource")===!0?"invalid_target":"invalid_request"}n(Kr,"readZodOAuthErrorCode");function qp(e){let t={error:Kr(e)},r=se(e);return r!==void 0&&(t.errorDescription=r),at(t)}n(qp,"oauthZodErrorResponse");function Mp(e){let t=le(e);if(t===void 0)return;let r=L(t);if(r.oauthError===void 0)return;let o={error:r.oauthError,status:Hp(r.oauthError)};return r.oauthError==="server_error"?o.errorDescription=r.publicDetail:e instanceof Error?o.errorDescription=e.message:o.errorDescription=r.publicDetail,at(o)}n(Mp,"oauthGatewayProblemResponse");function Dp(){let t={error:"server_error",status:500,errorDescription:L("internal_server_error").publicDetail};return at(t)}n(Dp,"oauthFallbackErrorResponse");function Hp(e){switch(e){case"invalid_client":return 401;case"server_error":return 500;default:return 400}}n(Hp,"readOAuthStatus");function Wr(e,t={}){return e instanceof ie?Fi(e):e instanceof p?Op(e,t):e instanceof d.ZodError?qp(e):Mp(e)??Dp()}n(Wr,"oauthProblemResponse");function Vr(e,t,r){let o=qe(e.url),a=Ni(t);if(r instanceof ie)return Fi(r);if(r instanceof p){let c=L("internal_server_error");return K({host:o,kind:zp(r.errorCode),title:"Authorization failed",detail:r.errorCode==="server_error"?c.publicDetail:r.message,developerDetail:r.errorCode==="server_error"?c.publicDetail:r.message,code:r.errorCode,diagnostic:we({request:e,requestId:a,code:r.errorCode,underlyingError:r.errorCode==="server_error"?c.publicDetail:r.message,error:r}),requestId:a,status:r.status})}if(r instanceof d.ZodError)return K({host:o,kind:"invalid_request",detail:se(r)??"The authorization request was invalid.",developerDetail:se(r)??"The authorization request was invalid.",code:Kr(r),diagnostic:we({request:e,requestId:a,code:Kr(r),underlyingError:se(r)??"The authorization request was invalid.",error:r}),requestId:a});let i=le(r);if(i!==void 0){let c=L(i);return K({host:o,kind:Zi(i),detail:c.publicDetail,developerDetail:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,code:i,diagnostic:we({request:e,requestId:a,code:i,underlyingError:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,error:r}),requestId:a,upstreamHtml:$i(r),status:c.status})}let s=L("internal_server_error");return K({host:o,kind:"internal_error",detail:s.publicDetail,developerDetail:s.publicDetail,code:"server_error",diagnostic:we({request:e,requestId:a,code:"server_error",underlyingError:s.publicDetail,error:r}),requestId:a,status:s.status})}n(Vr,"browserOAuthProblemResponse");function Gi(e,t,r){let o=qe(e.url),a=Ni(t),i=le(r);if(i!==void 0){let c=L(i);return K({host:o,kind:Zi(i),detail:c.publicDetail,developerDetail:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,code:i,diagnostic:we({request:e,requestId:a,code:i,underlyingError:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,error:r}),requestId:a,upstreamHtml:$i(r),status:c.status})}if(r instanceof d.ZodError)return K({host:o,kind:"invalid_request",detail:se(r)??"The authorization request was invalid.",developerDetail:se(r)??"The authorization request was invalid.",code:"invalid_request",diagnostic:we({request:e,requestId:a,code:"invalid_request",underlyingError:se(r)??"The authorization request was invalid.",error:r}),requestId:a});let s=L("internal_server_error");return K({host:o,kind:"internal_error",detail:s.publicDetail,developerDetail:s.publicDetail,code:"internal_server_error",diagnostic:we({request:e,requestId:a,code:"internal_server_error",underlyingError:s.publicDetail,error:r}),requestId:a,status:s.status})}n(Gi,"browserGatewayProblemResponse");function zp(e){return e==="server_error"?"internal_error":"invalid_request"}n(zp,"readOAuthBrowserErrorKind");function Zi(e){if(L(e).status>=500)return"internal_error";switch(e){case"mcp_route_not_enabled":case"unknown_upstream_server":case"unknown_mcp_route":case"unknown_auth_profile":case"mcp_route_upstream_mismatch":return"configuration_error";case"provider_access_denied":return"access_denied";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"session_expired";case"upstream_oauth_discovery_unavailable":case"upstream_provider_access_denied":case"upstream_client_registration_required":return"admin_required";case"browser_login_verification_failed":case"upstream_token_exchange_failed":case"upstream_token_response_invalid":return"connection_failed";case"invalid_request":case"authentication_required":case"forbidden":case"not_found":case"too_many_requests":case"identity_context_missing":return"invalid_request";case"upstream_capability_invocation_failed":case"upstream_capability_unavailable":case"upstream_import_failed":return"connection_failed";case"internal_server_error":return"internal_error"}return"authorization_failed"}n(Zi,"readGatewayBrowserErrorKind");function ee(e,t,r){let o={event:t},a=!1;if(r instanceof p)o.oauthError=r.errorCode,o.status=r.status,V(o,"error",r);else if(r instanceof ie)o.oauthError=r.errorCode,V(o,"error",r);else if(r instanceof d.ZodError){o.code="invalid_request",V(o,"error",r);let i=r.issues[0];i&&(o.zodPath=i.path.join("."))}else{let i=le(r);if(i!==void 0){let s=L(i);o.code=i,o.status=s.status,s.oauthError!==void 0&&(o.oauthError=s.oauthError),a=s.status>=500||s.oauthError==="server_error",V(o,"error",r)}else a=!0,V(o,"error",r)}if(a){let i=r instanceof Error?r:new Error("Non-Error thrown from OAuth handler",{cause:r});e.log.error(o,i.message)}else e.log.warn(o,"OAuth handler rejected the request")}n(ee,"logUnexpectedOAuthHandlerError");function Fi(e){let t;try{t=new URL(e.redirectUri)}catch{return at({error:e.errorCode,...e.errorDescription===void 0?{}:{errorDescription:e.errorDescription}})}t.searchParams.set("error",e.errorCode),e.errorDescription!==void 0&&t.searchParams.set("error_description",e.errorDescription),e.clientState!==void 0&&t.searchParams.set("state",e.clientState);let r=new Headers({location:t.toString(),"cache-control":"no-store"});return new Response(null,{status:302,headers:r})}n(Fi,"downstreamAuthorizeRedirectErrorResponse");function se(e){let t=e.issues[0];if(!t)return;let r=t.path.join(".");return r?`${r}: ${t.message}`:t.message}n(se,"formatZodErrorDetail");function Bp(e,t){let r={event:"browser_login_callback_failed",code:le(t)??"invalid_request"};V(r,"error",t),e.log.warn(r,"Browser login callback failed; client received a connection-failure page")}n(Bp,"logBrowserLoginCallbackFailure");function Ki(e){e.location.hash||(e.location.hash="#");let t=new Headers({location:e.location.toString(),"cache-control":"no-store"});return e.setCookie&&t.append("set-cookie",e.setCookie),new Response(null,{status:302,headers:t})}n(Ki,"redirectResultResponse");function Lt(e){if(e.kind==="setup_page"){let t=new Headers({"content-type":Ap,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"});return e.setCookie&&t.append("set-cookie",e.setCookie),new Response(e.html,{status:200,headers:t})}return Ki(e)}n(Lt,"authorizeResultResponse");async function Ji(e,t){try{return Response.json(Vn(e.url,e.headers))}catch(r){return ee(t,"oauth_authorization_server_metadata_failed",r),Li(e,t,r)}}n(Ji,"authorizationServerMetadataHandler");async function Wi(e,t){try{let r=Xt(e.params.routePath);return Response.json(Yn({operationId:r.operationId,requestUrl:e.url,requestHeaders:e.headers}))}catch(r){return ee(t,"oauth_authorization_server_metadata_failed",r),Li(e,t,r)}}n(Wi,"scopedAuthorizationServerMetadataHandler");async function Vi(e,t){try{let r=await oi(await kp(e)),o=r,a=typeof o.client_id=="string"?o.client_id:void 0,i=typeof o.client_name=="string"?o.client_name:void 0,s=Array.isArray(o.redirect_uris)?o.redirect_uris.length:void 0,c=typeof o.token_endpoint_auth_method=="string"?o.token_endpoint_auth_method:void 0;return t.log.info({event:"oauth_dcr_client_registered",clientId:a,clientName:i,redirectUriCount:s,tokenEndpointAuthMethod:c},"OAuth Dynamic Client Registration completed"),C(t,{eventType:R.MCP_OAUTH_CLIENT_REGISTERED,outcome:"success",clientName:i,attributes:{clientId:a,redirectUriCount:s,tokenEndpointAuthMethod:c}}),Response.json(r,{status:201,headers:{"cache-control":"no-store"}})}catch(r){return ee(t,"oauth_register_failed",r),Wr(r)}}n(Vi,"registerHandler");async function Yi(e,t){try{return Lt(await Fr(e,{context:t}))}catch(r){return ee(t,"oauth_authorize_failed",r),Vr(e,t,r)}}n(Yi,"authorizeHandler");async function Xi(e,t){try{let r=Xt(e.params.routePath);return Lt(await Fr(e,{operationId:r.operationId,context:t}))}catch(r){return ee(t,"oauth_authorize_scoped_failed",r),Vr(e,t,r)}}n(Xi,"scopedAuthorizeHandler");async function Qi(e,t){try{let r=await Ti(e,{context:t});return t.log.info({event:"browser_login_callback_completed",resultKind:r.kind},"Browser login callback completed; consent setup rendered"),Lt(r)}catch(r){return Bp(t,r),Gi(e,t,r)}}n(Qi,"callbackHandler");async function es(e,t){try{return Ki(await Pi(e))}catch(r){return ee(t,"oauth_dev_login_failed",r),Vr(e,t,r)}}n(es,"devLoginHandler");async function ts(e,t){try{if(!["GET","POST"].includes(e.method))return new Response(null,{status:405,headers:{allow:"GET, POST"}});let r=await Ei({request:e,body:e.method==="POST"?await Jr(e):void 0,context:t});return Lt(r)}catch(r){return ee(t,"oauth_setup_failed",r),Gi(e,t,r)}}n(ts,"setupHandler");async function rs(e,t){try{return Response.json(await zi({body:await Jr(e),authorizationHeader:e.headers.get("authorization"),requestUrl:e.url,requestHeaders:e.headers,context:t}),{headers:{"cache-control":"no-store",pragma:"no-cache"}})}catch(r){return ee(t,"oauth_token_failed",r),Wr(r)}}n(rs,"tokenHandler");async function ns(e,t){try{return await Bi({body:await Jr(e),authorizationHeader:e.headers.get("authorization"),requestUrl:e.url,requestHeaders:e.headers,context:t}),new Response(null,{status:200,headers:{"cache-control":"no-store"}})}catch(r){return ee(t,"oauth_revoke_failed",r),Wr(r)}}n(ns,"revokeHandler");var jp={connect:"Connect",callback_authorization_code:"Callback",callback_provider_error:"Callback",callback_invalid:"Callback",client_metadata:"Client metadata"},os=Symbol("upstream-request");function Lp(e){let t=e[os];if(!t)throw new D("Upstream request context has not been set");return t}n(Lp,"readUpstreamRequestContext");function Np(e,t){return t.some(r=>r===e)}n(Np,"requestContextMatchesKind");function $p(e){return typeof e=="string"?[e]:e}n($p,"toExpectedKinds");function He(e,t){Object.defineProperty(e,os,{configurable:!0,value:t})}n(He,"setUpstreamRequestContext");function it(e,t){let r=Lp(e),o=$p(t);if(!Np(r.kind,o)){let a=jp[o[0]];throw new D(`${a} request context has not been set`)}return r}n(it,"requireUpstreamRequestContext");function as(e){return y`<p data-gateway-error-code="${e.code}">${e.body}</p>`}n(as,"renderBrowserResult");var Gp="text/html; charset=utf-8",Zp="none";function Fp(e){let t=hr(e.host);return Oe({title:e.title,iconHref:t,styles:Ee,headerIcon:jt({iconHref:t,fallbackIconHref:tt}),heading:e.title,subhead:"",body:as({body:e.body,code:e.code??Zp}),footer:""})}n(Fp,"browserResultHtml");function Kp(e,t=200){return new Response(Pe(e),{status:t,headers:{"content-type":Gp,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(Kp,"browserResultResponse");function is(e){return Kp(Fp(e))}n(is,"browserConnectionSuccessResponse");function Nt(e,t,r={}){let o=Ln(t);return K({host:e,kind:Jp(t),detail:o.body,developerDetail:r.developerDetail,code:t,diagnostic:r.diagnostic,upstreamHtml:r.upstreamHtml})}n(Nt,"browserConnectionFailureResponse");function Jp(e){switch(e){case"provider_access_denied":return"access_denied";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"session_expired";case"browser_login_verification_failed":case"upstream_token_exchange_failed":case"upstream_token_response_invalid":return"connection_failed";case"upstream_oauth_discovery_unavailable":case"upstream_provider_access_denied":case"upstream_client_registration_required":return"admin_required"}}n(Jp,"readCallbackFailureBrowserErrorKind");var Wp=["callback_authorization_code","callback_provider_error","callback_invalid"];function Yr(e){try{return new URL(e.url).pathname}catch{return}}n(Yr,"readBrowserRequestPath");function Vp(e){return"cause"in e?e.cause:void 0}n(Vp,"readErrorCause");function Yp(e){return e.stack?.split(`
|
|
48
|
-
`).slice(1,4).map(t=>t.trim()).join(" | ")}n(Yp,"readFirstStackFrame");function ss(e,t,r){r instanceof Error&&(e[`${t}Name`]=r.name,e[`${t}Message`]=r.message,e[`${t}StackFrame`]=Yp(r))}n(ss,"addErrorAttributes");function Xr(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[_];return Sn(t)?t:void 0}n(Xr,"readRuntimeGatewayCode");function cs(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(cs,"readRuntimeErrorExtensionString");function Xp(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(Xp,"readRuntimeErrorExtensionNumber");function Qp(e,t,r,o){switch(r.kind){case"callback_provider_error":return t.log.warn({event:"upstream_oauth_provider_error",code:"provider_access_denied",upstreamServerId:r.upstreamServerId,providerError:r.error,...r.errorDescription===void 0?{}:{providerErrorDescription:r.errorDescription.slice(0,256)}},"Upstream identity provider returned an error to the OAuth callback"),C(t,{eventType:R.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:r.upstreamServerId,reasonCode:"provider_access_denied",reasonClass:"auth",attributes:{error:r.error,errorDescription:r.errorDescription}}),Nt(o,"provider_access_denied",{developerDetail:r.errorDescription??r.error,diagnostic:{code:"provider_access_denied",requestId:t.requestId,routePath:Yr(e),upstreamServerId:r.upstreamServerId,providerError:r.error,providerErrorDescription:r.errorDescription,underlyingError:r.errorDescription??r.error}});case"callback_invalid":return t.log.warn({event:"upstream_oauth_callback_invalid",code:"oauth_state_invalid",upstreamServerId:r.upstreamServerId},"Upstream OAuth callback request missing required code/state parameters"),Nt(o,"oauth_state_invalid",{diagnostic:{code:"oauth_state_invalid",requestId:t.requestId,routePath:Yr(e),upstreamServerId:r.upstreamServerId}});case"callback_authorization_code":return r}}n(Qp,"requireAuthorizationCallbackRequest");function em(e,t){C(e,{eventType:R.MCP_AUTH_UPSTREAM_CALLBACK_RECEIVED,outcome:"success",upstreamServerName:t.upstreamServerId})}n(em,"emitCallbackReceivedAnalyticsEvent");function tm(e,t){C(e,{eventType:R.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_SUCCEEDED,outcome:"success",upstreamServerName:t.upstreamServerId,virtualServerName:t.operationId})}n(tm,"emitTokenExchangeSucceededAnalyticsEvent");function rm(e,t){if(t.returnTo){let r=t.returnOrigin??e.url;return Response.redirect(new URL(t.returnTo,r).toString(),302)}return is({host:qe(e.url),title:"Connection complete",body:"The upstream authorization flow completed successfully. You can return to your MCP client."})}n(rm,"buildSuccessfulCallbackResponse");function nm(e){let t={detail:e instanceof Error?e.message:void 0};return ss(t,"error",e),e instanceof Error&&ss(t,"cause",Vp(e)),t}n(nm,"buildTokenExchangeFailureAttributes");function om(e){C(e.context,{eventType:R.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:e.callbackRequest.upstreamServerId,reasonCode:Xr(e.error)??"token_exchange_failed",reasonClass:"auth",errorType:e.error instanceof Error?e.error.name:"unknown",attributes:nm(e.error)})}n(om,"emitTokenExchangeFailedAnalyticsEvent");function am(e){let t=e.error,r=Xr(t),o=Cn(r)?r:"upstream_token_exchange_failed",a={code:o,requestId:e.context.requestId,routePath:Yr(e.request),upstreamServerId:e.callbackRequest.upstreamServerId,underlyingError:t instanceof Error?t.message:void 0,...t instanceof g?{httpStatus:Xp(t,Ce),contentType:cs(t,be),upstreamUrl:cs(t,ve)}:{}};return Nt(e.host,o,{developerDetail:t instanceof Error?t.message:void 0,diagnostic:a,upstreamHtml:im(t)})}n(am,"tokenExchangeFailureResponse");function im(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[Se];return typeof t=="string"?t:void 0}n(im,"readUpstreamHtmlError");async function Qr(e,t){let r=it(e,Wp),o=qe(e.url),a=Qp(e,t,r,o);if(a instanceof Response)return a;em(t,a);try{let i=await wa({request:e,callbackRequest:a});return tm(t,i),t.log.info({event:"upstream_oauth_token_exchange_succeeded",upstreamServerId:i.upstreamServerId,operationId:i.operationId,authProfileId:i.authProfileId,ownerMode:i.ownerMode},"Upstream OAuth token exchange completed; user connection established"),rm(e,i)}catch(i){let s={event:"upstream_oauth_token_exchange_failed",code:Xr(i)??"upstream_token_exchange_failed",upstreamServerId:a.upstreamServerId};return V(s,"error",i),t.log.warn(s,"Upstream OAuth token exchange failed; user shown connection-failure page"),om({context:t,callbackRequest:a,error:i}),am({request:e,context:t,host:o,callbackRequest:a,error:i})}}n(Qr,"callbackHandler");function sm(e){return(e instanceof Error?e.message:void 0)??"The requested upstream client metadata document was not found."}n(sm,"clientMetadataProblemDetail");async function ds(e,t){let r=it(e,"connect"),o=await _a({request:e,connectRequest:r});if(C(t,{eventType:R.MCP_AUTH_UPSTREAM_CONNECT_STARTED,outcome:"success",upstreamServerName:r.upstreamServerId,virtualServerName:o.operationId,upstreamServerTitle:o.upstreamDisplayName}),t.log.info({event:"upstream_connect_started",upstreamServerId:r.upstreamServerId,authProfileId:o.authProfileId,operationId:o.operationId,ownerMode:r.ownerMode,redirect:r.redirect,hasReturnTo:r.returnTo!==void 0},"Upstream OAuth connect flow started"),r.redirect)return Response.redirect(o.authUrl,302);let a=await kt({requestUrl:e.url,requestHeaders:e.headers,owner:o.owner,initiatedBySubjectId:o.initiatedBySubjectId,upstreamServerId:r.upstreamServerId,authProfileId:o.authProfileId,upstreamDisplayName:o.upstreamDisplayName,operationId:o.operationId,subject:"MCP route",...r.returnTo===void 0?{}:{returnTo:r.returnTo}});return Response.json(a,{status:428})}n(ds,"connectHandler");async function us(e,t){let r=it(e,"client_metadata");try{let o=ra(e.url,e.headers),a=na(o,r.upstreamServerId,r.authProfileId);return Response.json(a)}catch(o){if(!(o instanceof P))throw o;let a=o instanceof Error?o.message:String(o);return t.log.warn({event:"oauth_client_metadata_request_failed",upstreamServerId:r.upstreamServerId,authProfileId:r.authProfileId,errorMessage:a},"Failed to serve OAuth client metadata document for upstream connection"),de.notFound(e,t,{code:"not_found",detail:sm(o)})}}n(us,"oauthClientMetadataHandler");function ce(e){if(typeof e=="string"&&e.length!==0)return e}n(ce,"readOptionalQueryString");function cm(e,t){let r=e.params[t];if(typeof r!="string"||r.length===0)throw new D(`Validated path parameter ${t} is missing`);return r}n(cm,"requirePathString");function dm(e){let t=ce(e);return t?pt.parse(t):void 0}n(dm,"readOptionalOperationId");function um(e,t){let r=ce(e);return r?An.parse(r):ht(t,"user-oauth")}n(um,"readOptionalAuthProfileId");function lm(e){let t=dm(e);if(!t)throw new g({message:"operationId query parameter is required.",extensionMembers:{[_]:"invalid_request"}});return t}n(lm,"readRequiredOperationId");function pm(e){let t=eo(ce(e));return t===void 0?{}:{returnTo:t}}n(pm,"readOptionalReturnTo");function mm(e){let t=ce(e.query.error_description);return t===void 0?{}:{errorDescription:t}}n(mm,"readOptionalProviderErrorDescription");function fm(e){let t=G(e.authMode);if(t.connectSupport!=="none")return e;throw new g({message:t.connectUnsupportedDetail??"This upstream does not support browser connection flows.",extensionMembers:{[_]:"invalid_request"}})}n(fm,"requireConnectableRouteAuth");function hm(e,t,r,o){return{kind:"connect",...Te(e,t.subjectId),...o===void 0?{}:{returnTo:o},redirect:r}}n(hm,"buildConnectContextForUser");function gm(e,t,r){let o=wt(t),a=G(e.authMode);if(o.mode!==a.ownerMode)throw new g({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[_]:"oauth_callback_mismatch"}});return{kind:"connect",...e,...t.returnTo===void 0?{}:{returnTo:t.returnTo},owner:o,initiatedBySubjectId:t.initiatedBySubjectId,redirect:r}}n(gm,"buildConnectContextForTicket");async function ym(e,t){let r=fm(Pt(t,lm(e.query.operationId))),o=e.query.redirect==="true",a=ce(e.query.browserTicket);if(e.user){if(a)throw new g({message:"Use either an authenticated gateway request or a browser connect ticket, not both.",extensionMembers:{[_]:"invalid_request"}});let s=Ie(e.user,e.url);return hm(r,s,o,pm(e.query.returnTo).returnTo)}if(!a)throw new g({message:"Authentication is required to start the upstream connection flow.",extensionMembers:{[_]:"authentication_required"}});let i=await Xo(a);if(i.ownerMode!==r.ownerMode||i.upstreamServerId!==r.upstreamServerId||i.authProfileId!==r.authProfileId||i.operationId!==r.operationId)throw new g({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[_]:"oauth_callback_mismatch"}});return await Qo(i),gm(r,i,o)}n(ym,"resolveConnectContext");async function _m(e,t,r){let o=xn.parse(cm(e,"connection"));switch(r){case"connect":He(e,await ym(e,o));return;case"callback":{let a=ce(e.query.error);if(a){He(e,{kind:"callback_provider_error",upstreamServerId:o,error:a,...mm(e)});return}let i=ce(e.query.code),s=ce(e.query.state);if(i&&s){He(e,{kind:"callback_authorization_code",upstreamServerId:o,code:i,state:s});return}He(e,{kind:"callback_invalid",upstreamServerId:o});return}case"client_metadata":He(e,{kind:"client_metadata",upstreamServerId:o,authProfileId:um(e.query.authProfileId,o)});return}}n(_m,"resolveUpstreamRequestInbound");async function wm(e,t,r){try{await _m(e,t,r);return}catch(o){let a=o instanceof g?o.extensionMembers?.[_]:void 0,i=o instanceof Error?o.message:void 0;switch(a){case"invalid_request":case"oauth_callback_mismatch":return de.badRequest(e,t,{code:a,detail:i});case"authentication_required":return de.unauthorized(e,t,{code:a,detail:i});default:throw o}}}n(wm,"applyUpstreamRequestContext");function $t(e,t){return n(async(o,a)=>{let i=await wm(o,a,e);return i||t(o,a)},"wrapped")}n($t,"withUpstreamRequestContext");var Rm={"access-control-allow-origin":"*","access-control-allow-methods":"GET, OPTIONS","access-control-allow-headers":"content-type, authorization","access-control-max-age":"86400"};function bm(){return new Response(null,{status:204,headers:Rm})}n(bm,"buildWellKnownPreflightResponse");function Sm(e){let t=new Headers(e.headers);return t.set("access-control-allow-origin","*"),new Response(e.body,{status:e.status,statusText:e.statusText,headers:t})}n(Sm,"withWellKnownCorsHeaders");function en(e){return async(t,r)=>t.method==="OPTIONS"?bm():Sm(await e(t,r))}n(en,"wrapWellKnownHandler");var ms=[{routeName:"oauth_as_metadata",path:"/.well-known/oauth-authorization-server",methods:["GET","OPTIONS"],handler:en(Ji),corsPolicy:"anything-goes"},{routeName:"oauth_as_metadata_scoped",path:"/.well-known/oauth-authorization-server/:routePath*",methods:["GET","OPTIONS"],handler:en(Wi),corsPolicy:"anything-goes"},{routeName:"oauth_protected_resource_metadata",path:"/.well-known/oauth-protected-resource/:routePath*",methods:["GET","OPTIONS"],handler:en(Xn),corsPolicy:"anything-goes"},{routeName:"oauth_register",path:"/oauth/register",methods:["POST"],handler:Vi},{routeName:"oauth_authorize",path:"/oauth/authorize",methods:["GET"],handler:Yi},{routeName:"oauth_authorize_scoped",path:"/oauth/authorize/:routePath*",methods:["GET"],handler:Xi},{routeName:"oauth_callback",path:"/oauth/callback",methods:["GET"],handler:Qi},{routeName:"oauth_dev_login",path:"/oauth/dev-login",methods:["GET"],handler:es},{routeName:"oauth_setup",path:"/oauth/setup",methods:["GET","POST"],handler:ts},{routeName:"oauth_token",path:"/oauth/token",methods:["POST"],handler:rs},{routeName:"oauth_revoke",path:"/oauth/revoke",methods:["POST"],handler:ns},{routeName:"upstream_client_metadata",path:"/.well-known/oauth-client/:connection",methods:["GET"],handler:$t("client_metadata",us)},{routeName:"upstream_connect",path:"/auth/connections/:connection/connect",methods:["GET"],handler:$t("connect",ds)},{routeName:"upstream_callback",path:"/auth/connections/:connection/callback",methods:["GET"],handler:$t("callback",Qr)}],Cm=ms.filter(e=>!e.routeName.startsWith("upstream_")),vm=ms.filter(e=>e.routeName.startsWith("upstream_"));function fs(e){return e?.some(Rn)??!1}n(fs,"hasMcpOAuthRuntimeConfigPolicy");function hs(e){return e?.some(t=>On(t.policyType))??!1}n(hs,"hasMcpTokenExchangePolicy");function gs(e){return fs(e)||hs(e)}n(gs,"shouldRegisterMcpGatewayInternalRoutes");function Im(e){Dn(qn({routes:e.routes,policies:e.policies}))}n(Im,"initializeMcpGatewayConnectionRegistry");function xm(e){let t=bn(e.policies);if(!t){let r=[...wn].map(o=>`\`${o}\``).join(", ");throw new P(`MCP gateway: could not find an MCP authorization policy in policies.json. Add one of [${r}] and reference it on your MCP routes.`)}return t.config}n(xm,"initializeMcpGatewayOAuthRuntimeConfig");function ls(e,t,r){return async(o,a)=>{r&&yn(a,r());let i=o.method==="OPTIONS",s=Date.now();i||a.log.info({event:`${e}_received`,method:o.method},`MCP gateway: ${e} received`);let c=await t(o,a);return i||a.log.info({event:`${e}_responded`,status:c.status,durationMs:Date.now()-s},`MCP gateway: ${e} responded`),c}}n(ls,"wrapInternalHandler");function ps(e,t,r){e.addPluginRoute({path:t.path,methods:t.methods,handler:r,processors:[cn],corsPolicy:t.corsPolicy??"none"})}n(ps,"addInternalRoute");function ys(e,t){Im(t);let r=fs(t.policies),o=hs(t.policies),a,i=n(()=>(a===void 0&&(a=xm(t)),a),"readOAuthConfig");if(r)for(let s of Cm)ps(e,s,ls(s.routeName,s.handler,i));if(o)for(let s of vm)ps(e,s,ls(s.routeName,s.handler))}n(ys,"registerMcpGatewayInternalRoutes");function _s(e){Mn(e)}n(_s,"configureLazyMcpGatewayState");var tn=class extends an{static{n(this,"McpGatewayPlugin")}registerRoutes(t){let r=t.parsedRouteData;if(!r||!gs(r.policies))return;let o={routes:r.routes,policies:r.policies};_s(o),ys(t.router,o)}};var Am=new TextDecoder;function Um(e){if(e)try{return JSON.parse(Am.decode(e))}catch{return}}n(Um,"readBodyJson");function te(e){return e&&typeof e=="object"?e:void 0}n(te,"readRecord");function st(e,t){let r=te(e)?.[t];return typeof r=="string"?r:void 0}n(st,"readStringProperty");function Rs(e,t){let r=te(e)?.[t];return typeof r=="number"?r:void 0}n(Rs,"readNumberProperty");function ws(e,t){return Rs(e,"code")??(t.status>=400?t.status:void 0)}n(ws,"readErrorCode");function bs(e){return Array.isArray(e)?e.map(bs).find(t=>t?.method):te(e)}n(bs,"readJsonRpcMessage");function Ss(e){let t=bs(Um(e)),r=typeof t?.method=="string"?t.method:"",o=t?.params;switch(r){case"tools/list":return{mcpMethod:r,capabilityType:"tool"};case"tools/call":return{mcpMethod:r,capabilityType:"tool",capabilityName:st(o,"name")};case"prompts/list":return{mcpMethod:r,capabilityType:"prompt"};case"prompts/get":return{mcpMethod:r,capabilityType:"prompt",capabilityName:st(o,"name")};case"resources/list":case"resources/templates/list":return{mcpMethod:r,capabilityType:"resource"};case"resources/read":{let a=st(o,"uri");return{mcpMethod:r,capabilityType:"resource",capabilityName:a,resourceUri:a}}default:return null}}n(Ss,"buildBaseCapabilityInput");function Cs(e){return e==="tools/list"||e==="prompts/list"||e==="resources/list"||e==="resources/templates/list"}n(Cs,"isCapabilityListMethod");function km(e,t,r){let i=te(r)?.[e==="resources/templates/list"?"resourceTemplates":t==="tool"?"tools":t==="prompt"?"prompts":"resources"];return Array.isArray(i)?i.length:void 0}n(km,"readItemCount");async function Tm(e){try{return await e.clone().json()}catch{return}}n(Tm,"readResponseJson");function vs(e){let t=Ss(e);return!t||Cs(t.mcpMethod)?null:{eventType:R.MCP_CAPABILITY_INVOKED,outcome:"success",...t}}n(vs,"buildCapabilityInvokedAnalyticsInput");async function Is(e,t){let r=Ss(e);if(!r)return null;let o=te(await Tm(t)),a=te(o?.error),i=te(a?.data),s=o?.result,c=r.mcpMethod==="tools/call"&&te(s)?.isError===!0;if(te(i?.connectRequired))return{eventType:R.MCP_CAPABILITY_CONNECT_REQUIRED,outcome:"connect_required",...r,httpStatusCode:t.status,reasonCode:"connect_required",reasonClass:"auth",errorType:"connect_required",errorCode:Rs(a,"code"),mcpErrorType:st(a,"message")};if(Cs(r.mcpMethod)){let l=t.status>=400?void 0:km(r.mcpMethod,r.capabilityType,s);return{eventType:R.MCP_CAPABILITY_LISTED,outcome:t.status>=400||a?"failure":"success",...r,httpStatusCode:t.status,...t.status>=400||a?{reasonCode:"upstream_capability_list_failed",reasonClass:"upstream",errorType:"capability_list_error",errorCode:ws(a,t)}:{},...l===void 0?{}:{attributes:{itemCount:l}}}}return t.status>=400||a?{eventType:R.MCP_CAPABILITY_FAILED,outcome:"failure",...r,httpStatusCode:t.status,reasonCode:"upstream_capability_invocation_failed",reasonClass:"upstream",errorType:"capability_error",errorCode:ws(a,t),mcpErrorType:st(a,"message")}:{eventType:R.MCP_CAPABILITY_COMPLETED,outcome:c?"application_error":"success",...r,httpStatusCode:t.status,toolResultIsError:c,applicationError:c}}n(Is,"buildCapabilityFinalAnalyticsInput");var Pm={Allow:"POST"};async function Em(e){try{return await e.clone().arrayBuffer()}catch{return}}n(Em,"readRequestBody");function xs(e){try{let t=Hn(e.route.path);return{virtualServerName:t.operationId,upstreamServerName:t.connection?.upstreamServerId,upstreamServerTitle:t.connection?.displayName,authProfileId:t.connection?.authProfileId,upstreamAuthMode:t.connection?.authMode}}catch{return{}}}n(xs,"readRouteAnalyticsFields");function As(e){return Qn(e.user,e.url,e.headers)?.subjectId}n(As,"readRequestSubjectId");function Om(e){let t=vs(e.requestBody);t&&C(e.context,{...t,...xs(e.context),httpMethod:e.request.method,subjectId:As(e.request),transport:"http"})}n(Om,"emitCapabilityInvokedAnalytics");async function qm(e){let t=await Is(e.requestBody,e.response);t&&C(e.context,{...t,...xs(e.context),httpMethod:e.request.method,subjectId:As(e.request),transport:"http",latencyMs:Date.now()-e.startedAt})}n(qm,"emitCapabilityFinalAnalytics");async function Mm(e,t){if(e.method==="GET")return de.methodNotAllowed(e,t,{detail:"MCP Gateway routes support stateless Streamable HTTP requests over POST. Server-sent event GET streams are not supported."},Pm);let r=Date.now(),o=await Em(e);Om({context:t,request:e,requestBody:o});let a=await hn(e,t);return await qm({context:t,request:e,requestBody:o,response:a,startedAt:r}),a}n(Mm,"McpProxyHandler");export{Es as McpAuth0OAuthInboundPolicy,er as McpCapabilityFilterInboundPolicy,tn as McpGatewayPlugin,Ps as McpOAuthInboundPolicy,Mm as McpProxyHandler,Ar as McpTokenExchangeInboundPolicy};
|
|
47
|
+
></iframe>`}n(du,"renderUpstreamHtml");var xi="application/json",uu="application/x-www-form-urlencoded";function Ot(e,t){return new g({message:e,extensionMembers:{[y]:"invalid_request"}},t===void 0?void 0:{cause:t})}n(Ot,"invalidRequestError");function lu(e){return(e??"").split(";")[0]?.trim().toLowerCase()??""}n(lu,"normalizeContentType");function pu(e,t){return e===t?!0:t===xi&&e.endsWith("+json")}n(pu,"contentTypeMatches");function mu(e,t){if(!t||t.length===0)return;let r=lu(e.headers.get("content-type"));if(!t.some(o=>pu(r,o)))throw Ot(`Request body must be ${t.join(" or ")}.`)}n(mu,"assertExpectedContentType");function fu(e,t,r){let o=e.headers.get("content-length");if(!o)return;let i=Number.parseInt(o,10);if(Number.isFinite(i)&&i>t)throw Ot(`${r} exceeded the maximum allowed size.`)}n(fu,"assertContentLengthWithinLimit");async function Ai(e,t){let r=t.label??"Request body";mu(e,t.expectedContentTypes),fu(e,t.maxBytes,r);let o=await lo(e.body,{maxBytes:t.maxBytes,createLimitError:n(()=>Ot(`${r} exceeded the maximum allowed size.`),"createLimitError")});return new TextDecoder().decode(o)}n(Ai,"readBoundedTextBody");async function Ui(e,t){let r=await Ai(e,{...t,expectedContentTypes:[xi]});try{return JSON.parse(r)}catch(o){throw Ot("Request body must be valid JSON.",o)}}n(Ui,"readBoundedJsonBody");async function ki(e,t){let r=await Ai(e,{...t,expectedContentTypes:[uu]});return new URLSearchParams(r)}n(ki,"readBoundedFormUrlEncodedBody");H();H();import{errors as Mi,jwtVerify as Di,SignJWT as zi}from"jose";H();import{errors as hu,jwtVerify as gu,SignJWT as yu}from"jose";var Ur="zuplo_mcp_session",_u=d.object({purpose:d.literal("gateway_browser_session"),sub:gt,browserLoginOrigin:d.string().min(1),roles:d.array(d.string().min(1)).optional(),exp:d.number().int().positive(),iat:d.number().int().positive().optional()});function wu(e){let t=new Map;if(!e)return t;for(let r of e.split(";")){let o=r.indexOf("=");if(o<0)continue;let i=r.slice(0,o).trim(),a=r.slice(o+1).trim();if(i)try{t.set(i,decodeURIComponent(a))}catch{t.set(i,a)}}return t}n(wu,"parseCookieHeader");async function Ti(){return $({purpose:"browser-session",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-session"),"derive")})}n(Ti,"getBrowserSessionKey");function Ar(e,t){let r=new URL(U(e,t)),o=[`${Ur}=`,"Path=/","HttpOnly","SameSite=Lax","Max-Age=0"];return r.protocol==="https:"&&o.push("Secure"),o.join("; ")}n(Ar,"buildBrowserSessionEvictionCookie");function Ru(e){let t=new URL(U(e.requestUrl,e.requestHeaders)),r=[`${Ur}=${encodeURIComponent(e.value)}`,"Path=/","HttpOnly","SameSite=Lax",`Max-Age=${e.ttlSeconds}`];return t.protocol==="https:"&&r.push("Secure"),r.join("; ")}n(Ru,"serializeSessionCookie");function Pi(){return new URL(Rt("url")).origin}n(Pi,"readBrowserLoginOrigin");function kr(){return B().browserLogin.stateTtlSeconds}n(kr,"readBrowserLoginStateTtlSeconds");function Ei(e){if(!e.user)throw _("authentication_required","The browser login callback did not include an authenticated Zuplo principal.");return Ie(e.user,e.url)}n(Ei,"resolveCurrentRequestPrincipal");async function qt(e,t={}){let r=wu(e.headers.get("cookie")).get(Ur);if(!r)return{};try{let{payload:o}=await gu(r,await Ti(),{algorithms:[z],issuer:O,audience:D}),i=_u.parse(o);if(i.browserLoginOrigin!==Pi())return{evictCookie:Ar(e.url,e.headers)};let a={subjectId:i.sub};return i.roles&&i.roles.length>0&&(a.roles=i.roles),{principal:a}}catch(o){return o instanceof hu.JWTExpired?{evictCookie:Ar(e.url,e.headers)}:(t.context?.log.warn({event:"browser_session_verification_failed",errorName:o instanceof Error?o.name:"unknown",errorMessage:o instanceof Error?o.message:"verification failed"},"Browser session JWT verification failed"),{evictCookie:Ar(e.url,e.headers)})}}n(qt,"readBrowserSession");async function Mt(e){let t=B().browserLogin.sessionTtlSeconds,r={purpose:"gateway_browser_session",sub:e.principal.subjectId,browserLoginOrigin:Pi()};e.principal.roles&&(r.roles=e.principal.roles);let o=await new yu(r).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(O).setAudience(D).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+t).sign(await Ti());return Ru({value:o,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},ttlSeconds:t})}n(Mt,"createBrowserSessionCookie");async function Oi(e){let t={};e.context!==void 0&&(t.context=e.context);let r=await qt(e.request,t);if(r.principal)return r.principal;let o=typeof e.request.query.code=="string"?e.request.query.code:void 0;if(!o)throw _("oauth_callback_mismatch","Federated browser login callback is missing an authorization code.");let{exchangeFederatedAuthorizationCode:i}=await import("../browser-login-idp-SQ4CJMPN.js");return i({code:o,nonce:e.stateId,requestUrl:e.request.url,requestHeaders:e.request.headers,...e.context===void 0?{}:{context:e.context}})}n(Oi,"resolveBrowserLoginCallbackPrincipal");function qi(e){let t=B().browserLogin,r=new URL(Rt("url")),o=new URL("/oauth/callback",zn(e.requestUrl,e.requestHeaders));return Kn(r)?(r.searchParams.set("redirect_uri",o.toString()),r.searchParams.set("state",e.state),r):(r.searchParams.set("response_type","code"),r.searchParams.set("client_id",Rt("clientId")),r.searchParams.set("redirect_uri",o.toString()),r.searchParams.set("scope",t.scope),r.searchParams.set("state",e.state),r.searchParams.set("nonce",e.nonce),t.audience&&r.searchParams.set("audience",t.audience),r)}n(qi,"buildBrowserLoginUrl");var bu={invalid_request:400,invalid_client:401,invalid_grant:400,invalid_target:400,unsupported_grant_type:400,server_error:500,invalid_redirect_uri:400,invalid_client_metadata:400},p=class extends Error{static{n(this,"OAuthProtocolError")}errorCode;status;constructor(t,r,o=bu[t],i){super(r,i),this.name="OAuthProtocolError",this.errorCode=t,this.status=o}};var Su=5*60,vu=d.object({purpose:d.literal("gateway_browser_login"),transactionId:Zt,stateId:Ft,exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Cu=d.object({purpose:d.literal("gateway_authorization_setup"),transactionId:Zt,stateId:Ft,exp:d.number().int().positive(),iat:d.number().int().positive().optional()});async function Hi(){return $({purpose:"browser-login",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"browser-login"),"derive")})}n(Hi,"getBrowserLoginKey");async function Bi(){return $({purpose:"authorization-csrf",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>oe(e,"authorization-csrf"),"derive")})}n(Bi,"getCsrfKey");function ji(e){return{now:e.now??new Date,ttlSeconds:kr()}}n(ji,"readPendingTransactionDependencies");function Iu(e,t){return e.subjectId===t.subjectId}n(Iu,"principalsMatch");function Li(e){return{subjectId:e.subjectId,...e.roles===void 0?{}:{roles:e.roles}}}n(Li,"toPendingPrincipal");function Ni(e){let t={id:e.id,currentStateHash:e.currentStateHash,clientId:e.transaction.clientId,redirectUri:e.transaction.redirectUri,resource:e.transaction.resource,operationId:e.transaction.operationId,scope:e.transaction.scope,codeChallenge:e.transaction.codeChallenge,codeChallengeMethod:e.transaction.codeChallengeMethod,createdAt:R(e.now),expiresAt:R(J(e.now,e.ttlSeconds)),...e.transaction.clientState===void 0?{}:{clientState:e.transaction.clientState}};if(e.phase==="awaiting_login")return{...t,phase:"awaiting_login"};if(!e.principal)throw _("identity_context_missing","Authorization setup requires a principal.");return{...t,phase:"awaiting_setup",principal:Li(e.principal)}}n(Ni,"createTransactionRecord");async function Gi(e){let{id:t,...r}=e.record,o=await b().startAuthorization({...r,transactionId:t,...e.client===void 0?{}:{client:e.client}});switch(o.kind){case"started":return o.transaction;case"already_exists":throw _("oauth_state_reused","Authorization transaction state already exists.");case"invalid_client":throw new p("invalid_client","OAuth client is not registered.");case"redirect_uri_mismatch":throw new p("invalid_request","redirect_uri is not registered for the client.")}}n(Gi,"startPendingTransaction");async function xu(e){return new zi({purpose:"gateway_browser_login",transactionId:e.transactionId,stateId:e.stateId}).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(O).setAudience(D).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Hi())}n(xu,"signBrowserLoginState");async function $i(e){return new zi({purpose:"gateway_authorization_setup",transactionId:e.transactionId,stateId:Jt()}).setProtectedHeader({alg:z,typ:"JWT"}).setIssuer(O).setAudience(D).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Bi())}n($i,"signCsrfToken");async function Tr(e){try{let{payload:t}=await Di(e,await Hi(),{algorithms:[z],issuer:O,audience:D}),r=vu.parse(t);return{transactionId:r.transactionId,stateId:r.stateId}}catch(t){throw t instanceof Mi.JWTExpired?_("oauth_state_expired","Browser login state has expired.",t):_("oauth_state_invalid","Browser login state could not be verified.",t)}}n(Tr,"verifyBrowserLoginStateToken");async function Dt(e){try{let{payload:t}=await Di(e,await Bi(),{algorithms:[z],issuer:O,audience:D});return{transactionId:Cu.parse(t).transactionId}}catch(t){throw t instanceof Mi.JWTExpired?_("oauth_state_expired","Authorization setup state has expired.",t):_("oauth_state_invalid","Authorization setup state could not be verified.",t)}}n(Dt,"verifyCsrfToken");function Pr(e){return e==="consumed"||e==="consumed_already"||e==="stale_hash"?"oauth_state_reused":e==="expired"?"oauth_state_expired":"oauth_state_invalid"}n(Pr,"pendingStateErrorCode");function Au(e){return e.kind==="available"?{kind:"available",record:e.transaction}:e}n(Au,"toPendingAuthorizationGetResult");function Uu(e){return e.kind==="advanced"?{kind:"advanced",record:e.transaction}:e}n(Uu,"toPendingAuthorizationAdvanceResult");function Er(e){return e==="principal_mismatch"?"oauth_callback_mismatch":Pr(e==="consumed_already"?"consumed_already":e)}n(Er,"setupDecisionErrorCode");async function Zi(e){let t=e.now??new Date,r=await Dt(e.csrfToken),o=await b().markAuthorizationSetupApproved({transactionId:r.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:R(t)});if(o.kind!=="marked")throw _(Er(o.kind),"Authorization setup state is invalid, expired, or already used.");return Fi({kind:"available",record:o.transaction})}n(Zi,"markSetupApproved");function Fi(e){if(e.kind!=="available")throw _(Pr(e.kind),"Authorization setup state is invalid, expired, or already used.");if(e.record.phase!=="awaiting_setup")throw _("oauth_state_invalid","Authorization setup state is not in the setup phase.");return e.record}n(Fi,"requireAwaitingSetup");function ku(e){if(!Iu(e.currentBrowserPrincipal,e.transaction.principal))throw _("oauth_callback_mismatch","Authorization setup state does not match the current browser session.")}n(ku,"requireCurrentPrincipalMatches");async function Ki(e){let t=e.now??new Date,r=kr(),o=Kt(),i=Jt(),a=await xu({transactionId:o,stateId:i,ttlSeconds:r}),s=Ni({id:o,transaction:e.transaction,currentStateHash:await I(a),phase:"awaiting_login",now:t,ttlSeconds:r});if(s.phase!=="awaiting_login")throw _("oauth_state_invalid","Authorization transaction did not start in login phase.");let c=await Gi({record:s,client:e.transaction.client});if(c.phase!=="awaiting_login")throw _("oauth_state_invalid","Authorization transaction did not start in login phase.");return{transaction:c,browserLoginStateToken:a,browserLoginUrl:qi({state:a,nonce:i,operationId:s.operationId,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}})}}n(Ki,"startAwaitingLogin");async function Ji(e){let{now:t,ttlSeconds:r}=ji(e),o=Kt(),i=await $i({transactionId:o,ttlSeconds:r}),a=Ni({id:o,transaction:e.transaction,currentStateHash:await I(i),phase:"awaiting_setup",principal:e.principal,now:t,ttlSeconds:r});if(a.phase!=="awaiting_setup")throw _("oauth_state_invalid","Authorization transaction did not start in setup phase.");let s=await Gi({record:a,client:e.transaction.client});if(s.phase!=="awaiting_setup")throw _("oauth_state_invalid","Authorization transaction did not start in setup phase.");return{transaction:s,csrfToken:i}}n(Ji,"startAwaitingSetup");async function Wi(e){let{now:t,ttlSeconds:r}=ji(e),o=await Tr(e.browserLoginStateToken),i=await $i({transactionId:o.transactionId,ttlSeconds:r}),a=Uu(await b().advancePendingAuthorization({transactionId:o.transactionId,expectedPhase:"awaiting_login",currentStateHash:await I(e.browserLoginStateToken),nextStateHash:await I(i),nextPhase:"awaiting_setup",principal:Li(e.principal),now:R(t)}));if(a.kind!=="advanced")throw _(Pr(a.kind),"Browser login state is invalid, expired, or already used.");if(a.record.phase!=="awaiting_setup")throw _("oauth_state_invalid","Browser login did not advance to setup.");return{transaction:a.record,csrfToken:i}}n(Wi,"completeLogin");async function Vi(e){let t=await Or(e);return ku({transaction:t,currentBrowserPrincipal:e.currentBrowserPrincipal}),t}n(Vi,"getSetup");async function Or(e){let t=e.now??new Date,r=await Dt(e.csrfToken);return Fi(Au(await b().readPendingAuthorization({transactionId:r.transactionId,currentStateHash:await I(e.csrfToken),now:R(t)})))}n(Or,"getSetupTransaction");async function Tu(e){let t=await Dt(e.csrfToken),r=Y(),o=R(J(e.now,Su)),i=await b().decideAuthorizationSetup({decision:"approve",transactionId:t.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},authorizationCodeHash:await I(r),authorizationCodeExpiresAt:o,grantId:Zn(),now:R(e.now)});if(i.kind!=="approved")throw _(i.kind==="cancelled"?"oauth_state_invalid":Er(i.kind),"Authorization setup state is invalid, expired, or already used.");let a=new URL(i.transaction.redirectUri);return a.searchParams.set("code",r),i.transaction.clientState&&a.searchParams.set("state",i.transaction.clientState),a}n(Tu,"createAuthorizationCodeRedirectWithDecision");async function Pu(e){let t=await Dt(e.csrfToken),r=await b().decideAuthorizationSetup({decision:"cancel",transactionId:t.transactionId,currentStateHash:await I(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:R(e.now)});if(r.kind!=="cancelled")throw _(r.kind==="approved"?"oauth_state_invalid":Er(r.kind),"Authorization setup state is invalid, expired, or already used.");return Eu({redirectUri:r.transaction.redirectUri,clientState:r.transaction.clientState})}n(Pu,"createCancelRedirectWithDecision");function Eu(e){let t=new URL(e.redirectUri);return t.searchParams.set("error","access_denied"),t.searchParams.set("error_description","The user cancelled the MCP authorization request."),e.clientState!==void 0&&t.searchParams.set("state",e.clientState),t}n(Eu,"buildClientCancelRedirect");async function Yi(e){let t=e.now??new Date;return Tu({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Yi,"approve");async function Xi(e){let t=e.now??new Date;return Pu({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Xi,"cancel");H();var Ou=1e4,qu=5*1024,Mu=2,Du=90*24*60*60,qr="dcr:pkjwt:",zu="chatgpt.com",Hu="ChatGPT CIMD client metadata could not be used by this gateway. In ChatGPT advanced OAuth settings, change Registration method to Dynamic Client Registration (DCR), keep the discovered Registration URL, and retry connecting.",Mr=["authorization_code","refresh_token"],Dr=["code"],Bu=d.object({client_name:d.string().min(1).optional(),redirect_uris:d.array(d.string().min(1)).min(1),grant_types:d.array(d.enum(Mr)).min(1).max(2).optional(),response_types:d.array(d.enum(Dr)).min(1).max(1).optional(),scope:d.literal(P).optional(),token_endpoint_auth_method:Gn.optional(),jwks_uri:d.string().min(1).optional()});function ju(e){try{let t=new URL(e);return(t.protocol==="https:"||t.protocol==="http:"&&ue(t))&&t.pathname!=="/"}catch{return!1}}n(ju,"isCimdClientIdCandidate");function Lu(e){try{let t=new URL(e);return t.protocol==="https:"&&t.hostname===zu&&t.pathname.startsWith("/oauth/")&&t.pathname.endsWith("/client.json")}catch{return!1}}n(Lu,"isChatGptCimdClientId");function Qi(e){throw new p("invalid_client",Lu(e)?Hu:"OAuth client is not registered.")}n(Qi,"invalidCimdClientError");function Me(e,t="invalid_request",r="authorize"){if(Nu(e))throw new p(t,"redirect_uris must not include raw whitespace or control characters.");let o;try{o=new URL(e)}catch{throw new p(t,"redirect_uris must be absolute URIs.")}if(o.hash||o.username||o.password)throw new p(t,"redirect_uris must not include credentials or fragments.");let i={source:r},a=Ln({url:o,context:i});if(a.kind!=="rejected"){a.mode!=="strict"&&void 0;return}throw new p(t,"redirect_uris must use HTTPS, loopback HTTP, or a native-app private-use URI scheme.")}n(Me,"assertValidRedirectUri");function Nu(e){for(let t=0;t<e.length;t+=1){let r=e.charCodeAt(t);if(r<=32||r>=127&&r<=159)return!0}return!1}n(Nu,"hasForbiddenRawRedirectUriCharacter");async function Gu(e){let{response:t,json:r}=await mo(e.initialUrl,{headers:{accept:"application/json"}},{maxRedirects:Mu,maxResponseBytes:qu,timeoutMs:Ou});if(!t.ok)throw _("invalid_request","CIMD metadata could not be fetched.");let o=$n.parse(r);for(let i of o.redirect_uris)Me(i,"invalid_request","cimd");if(o.jwks_uri!==void 0&&wt(o.jwks_uri),o.client_id!==e.clientId)throw _("invalid_request","Fetched CIMD client_id must exactly match the requested client_id.");return o}n(Gu,"fetchCimdMetadata");async function $u(e){let t=uo(e),r=await Gu({clientId:e,initialUrl:t});return{kind:"cimd",clientId:e,metadata:r}}n($u,"resolveCimdClient");async function zt(e,t){let r=V.parse(e);if(ju(r)){B().gateway.cimdEnabled||Qi(r);try{return await $u(r)}catch{Qi(r)}}let o=await b().readClient({clientId:r});if(o.kind==="found"){let i=o.client,a=Qu(i.clientId),s=a===void 0?i.tokenEndpointAuthMethod:"private_key_jwt",c=i.jwksUri??a;if(s==="private_key_jwt"&&c===void 0)throw new p("invalid_client","Dynamic private_key_jwt client is missing JWKS metadata. Re-run client registration before authorization.");let l={client_id:i.clientId,client_name:i.clientName,redirect_uris:i.redirectUris,token_endpoint_auth_method:s,...c===void 0?{}:{jwks_uri:c}},m={kind:"dcr",clientId:r,metadata:l};return i.hashedClientSecret&&(m.hashedClientSecret=i.hashedClientSecret),m}throw new p("invalid_client",r.startsWith("dcr:")?"Dynamic client is not registered. Re-run client registration before authorization.":"OAuth client is not registered.")}n(zt,"resolveClient");function ea(e,t){if(!e.metadata.redirect_uris.some(r=>Fn(r,t)))throw _("invalid_request","redirect_uri is not registered for the client.")}n(ea,"assertRedirectRegistered");function Zu(e){let t=ta(e.grant_types),r=e.response_types??[...Dr];if(!Fu(t))throw new p("invalid_client_metadata","grant_types must be a subset of authorization_code and refresh_token.");if(!Ku(r))throw new p("invalid_client_metadata","response_types must be code.");if(!Ju(e.scope))throw new p("invalid_client_metadata",`Only the ${P} scope is supported.`)}n(Zu,"assertSupportedDcrRequest");function ta(e){return e===void 0?[...Mr]:Array.from(new Set(e))}n(ta,"normalizeGrantTypes");function Fu(e){return e.length===0?!1:e.every(t=>Mr.includes(t))}n(Fu,"isSupportedGrantTypes");function Ku(e){return e.length===Dr.length&&e[0]==="code"}n(Ku,"isSupportedResponseTypes");function Ju(e){return e===void 0||e===P}n(Ju,"isSupportedDcrScope");function Wu(e){try{wt(e)}catch(t){throw new p("invalid_client_metadata","jwks_uri must be an HTTPS URL with a path, no credentials, query, or fragment, and must not point at a blocked host.",void 0,{cause:t})}}n(Wu,"assertValidDcrJwksUri");function Vu(e){let t=new TextEncoder().encode(e),r="";for(let o of t)r+=String.fromCharCode(o);return btoa(r).replaceAll("+","-").replaceAll("/","_").replace(/=+$/,"")}n(Vu,"encodeBase64Url");function Yu(e){let t=e.replaceAll("-","+").replaceAll("_","/"),r=t.padEnd(t.length+(4-t.length%4)%4,"="),o;try{o=atob(r)}catch{return}let i=new Uint8Array(o.length);for(let a=0;a<o.length;a+=1)i[a]=o.charCodeAt(a);return new TextDecoder().decode(i)}n(Yu,"decodeBase64Url");function Xu(e){return e.tokenEndpointAuthMethod==="private_key_jwt"&&e.jwksUri!==void 0?V.parse(`${qr}${crypto.randomUUID()}:${Vu(e.jwksUri)}`):V.parse(`dcr:${crypto.randomUUID()}`)}n(Xu,"createDcrClientId");function Ht(e){return e.startsWith(qr)}n(Ht,"isPrivateKeyJwtDcrCompatibilityClientId");function Qu(e){if(!Ht(e))return;let t=e.slice(qr.length),r=t.indexOf(":");if(r===-1)return;let o=Yu(t.slice(r+1));if(o!==void 0){try{wt(o)}catch{return}return o}}n(Qu,"readPrivateKeyJwtDcrClientIdJwksUri");function rt(e){if(e===void 0||e===P)return P;throw new p("invalid_request",`Only the ${P} scope is supported.`)}n(rt,"assertSupportedOAuthScope");function De(e,t,r){let o;try{o=new URL(t)}catch{throw new p("invalid_target","resource must be an absolute URI.")}if(o.hash)throw new p("invalid_target","resource must not include a fragment.");if(o.protocol!=="https:"&&!ue(o))throw new p("invalid_target","resource must use HTTPS except loopback HTTP resources in local development.");let i=U(e,r),a=Dn(),s=a?[...a.byOperationId.values()].find(c=>new URL(c.routePath,i).toString()===t):void 0;if(!s)throw new p("invalid_target","resource must match a published MCP route.");return s}n(De,"resolveResource");async function ra(e){let t;try{t=Bu.parse(e)}catch(C){if(C instanceof d.ZodError){let L=C.issues.some(Re=>Re.path[0]==="redirect_uris");throw new p(L?"invalid_redirect_uri":"invalid_client_metadata",C.issues[0]?.message??"Client metadata is invalid.",void 0,{cause:C})}throw C}Zu(t);for(let C of t.redirect_uris)Me(C,"invalid_redirect_uri","dcr");if(t.token_endpoint_auth_method==="private_key_jwt"&&t.jwks_uri===void 0)throw new p("invalid_client_metadata","jwks_uri is required for private_key_jwt clients.");t.jwks_uri!==void 0&&Wu(t.jwks_uri);let r=new Date,o=t.token_endpoint_auth_method??"none",i=o==="private_key_jwt"?"none":o,a=Xu({tokenEndpointAuthMethod:o,jwksUri:t.jwks_uri}),s=J(r,Du),c=Math.floor(r.getTime()/1e3),l=Math.floor(s.getTime()/1e3),m={client_id:a,client_name:t.client_name??"Dynamically registered MCP client",redirect_uris:t.redirect_uris,grant_types:ta(t.grant_types),response_types:["code"],scope:P,token_endpoint_auth_method:o,client_id_issued_at:c,...t.jwks_uri===void 0?{}:{jwks_uri:t.jwks_uri}},f={clientId:a,clientName:String(m.client_name),redirectUris:t.redirect_uris,tokenEndpointAuthMethod:i,createdAt:R(r),clientExpiresAt:R(s)};if(o==="client_secret_basic"||o==="client_secret_post"){let C=Y();f.hashedClientSecret=await I(C),f.clientSecretExpiresAt=R(s),m.client_secret=C,m.client_secret_expires_at=l,m.client_secret_issued_at=c}if((await b().registerClient(f)).kind==="already_exists")throw _("invalid_request","OAuth client is already registered.");return m}n(ra,"registerDownstreamClient");function Bt(e){return S`<img class="card__icon" src="${e.iconHref}" alt="" width="48" height="48" referrerpolicy="no-referrer" onerror=" this.onerror = null; this.src = '${e.fallbackIconHref}'; " />`}n(Bt,"renderShellIcon");function na(e){return S`<form class="actions" method="post" action="/oauth/setup" ${e.submitOnceAttrs}><input type="hidden" name="state" value="${e.state}" /><button class="button button--secondary" type="submit" name="decision" value="cancel" formnovalidate >Cancel</button><button class="button button--primary" type="submit" name="decision" value="approve" ${e.authorizeAttrs} >Authorize</button></form>`}n(na,"renderActions");var gy=Q('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><circle cx="8" cy="8" r="6.5"/><line x1="8" y1="4.6" x2="8" y2="8.4"/><circle cx="8" cy="11" r=".7" fill="currentColor" stroke="none"/></svg>');var yy=Q('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="14" height="14" fill="none" stroke="currentColor" stroke-width="1.8" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M4 6.5l4 4 4-4"/></svg>'),_y=Q('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.6" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><rect x="3" y="4" width="18" height="7" rx="1.5"/><rect x="3" y="13" width="18" height="7" rx="1.5"/><circle cx="7" cy="7.5" r=".75" fill="currentColor" stroke="none"/><circle cx="7" cy="16.5" r=".75" fill="currentColor" stroke="none"/></svg>');var wy=Q('<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16" width="16" height="16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M7.13 2.46 1.39 12.5a1 1 0 0 0 .87 1.5h11.48a1 1 0 0 0 .87-1.5L8.87 2.46a1 1 0 0 0-1.74 0Z"/><line x1="8" y1="6" x2="8" y2="9.4"/><circle cx="8" cy="11.4" r=".7" fill="currentColor" stroke="none"/></svg>');var el="data:,",oa=S`data-submit-once="true" onsubmit="if (this.dataset.submitted === 'true') return false; this.dataset.submitted = 'true'; setTimeout(() => this.querySelectorAll('button').forEach((button) => { button.disabled = true; }), 0);"`,ia=S`data-activate-once="true" onclick="if (this.dataset.activated === 'true') return false; this.dataset.activated = 'true'; this.setAttribute('aria-disabled', 'true'); this.style.pointerEvents = 'none';"`;function tl(e,t){if(e)try{let r=new URL(t).origin,o=new URL(e,r);return o.origin!==r||!o.pathname.startsWith("/auth/connections/")?void 0:o.toString()}catch{return}}n(tl,"safeGatewayConnectHref");function rl(e){return e.some(r=>r.ownerMode==="user"&&r.status!=="active")?"setup":"grant"}n(rl,"deriveMode");function nl(e){return na({state:e.state,submitOnceAttrs:oa,authorizeAttrs:Z})}n(nl,"renderActions");function zr(e,t,r){for(let o of e){if(o.ownerMode!=="user"||o.status!==r)continue;let i=tl(o.connectUrl,t);if(i)return i}}n(zr,"firstUserConnectHref");function ol(e){let t=e.connectHref?S`<a class="button button--primary" href="${e.connectHref}" ${ia}>Connect</a>`:S`<button class="button button--primary" type="button" disabled aria-disabled="true">Connect</button>`;return S`<form class="actions" method="post" action="/oauth/setup" ${oa}><input type="hidden" name="state" value="${e.state}" /><button class="button button--secondary" type="submit" name="decision" value="cancel" formnovalidate>Cancel</button>${t}</form>`}n(ol,"renderSetupActions");function il(e){return e?S`<span class="reconnect-action"><a class="button button--secondary reconnect-button" href="${e}" ${ia}>Re-connect<span class="tooltip" tabindex="0" aria-label="Reset or change how the gateway connects to the upstream service, including changing scopes.">?</span></a></span>`:Z}n(il,"renderReconnectAction");function al(e){try{let t=new URL(e);return t.protocol==="https:"||t.protocol==="http:"?!0:t.protocol==="data:"&&/^data:image\/(?:png|jpe?g|webp|svg\+xml);/i.test(e)}catch{return!1}}n(al,"isRenderableIconHref");function aa(e){return e?.find(t=>al(t.src))?.src}n(aa,"readIconHref");function sl(e){return aa(e.serverIcons)??(e.transportHost===void 0?void 0:hr(e.transportHost).src)}n(sl,"readUpstreamIconHref");function cl(e){let t=aa(e.routeIcons);if(t!==void 0)return t;for(let r of e.upstreams){let o=sl(r);if(o!==void 0)return o}}n(cl,"readHeaderIconHref");function dl(e){return S`<p class="card__subtitle">Authorize '<strong>${e.clientDisplayName}</strong>' to access '<strong>${e.routeDisplayName}</strong>' on your behalf?</p>`}n(dl,"renderBody");function Hr(e){let t=rl(e.upstreams),r=zr(e.upstreams,e.gatewayOrigin,"not_connected"),o=zr(e.upstreams,e.gatewayOrigin,"reconsent_required"),i=zr(e.upstreams,e.gatewayOrigin,"active"),a=t==="setup"?r??o:void 0,s=cl({routeIcons:e.routeIcons,upstreams:e.upstreams}),c=t==="setup"?S`<footer class="card__footer">${ol({state:e.state,connectHref:a})}</footer>`:S`<footer class="card__footer">${il(i)}${nl({state:e.state})}</footer>`;return Pe(Oe({title:`Authorize access \xB7 ${e.routeDisplayName}`,iconHref:s??el,styles:Ee,headerIcon:s===void 0?Z:Bt({iconHref:s,fallbackIconHref:It}),heading:"Authorize access",subhead:Z,body:dl({routeDisplayName:e.routeDisplayName,clientDisplayName:e.clientDisplayName}),footer:c}))}n(Hr,"renderConsentPage");var ul=1e4,sa="mcp-session-id",ll,ca;function ma(){return{tools:[],prompts:[],resources:[]}}n(ma,"emptyCapabilities");function da(e){let t=new Headers({accept:"application/json, text/event-stream","content-type":"application/json","mcp-protocol-version":Wt});switch(e.type){case"none":return t;case"bearer_token":return t.set("authorization",`Bearer ${e.token}`),t;case"headers":for(let[r,o]of Object.entries(e.headers))t.set(r,o);return t;case"mcp_oauth_provider":throw new Error("MCP OAuth provider credentials require async headers.")}}n(da,"buildCredentialHeaders");async function ua(e){if(e.type!=="mcp_oauth_provider")return da(e);let t=await e.provider.tokens();if(!t)return;let r=da({type:"none"});return r.set("authorization",`${t.token_type??"Bearer"} ${t.access_token}`),r}n(ua,"buildAsyncCredentialHeaders");function la(e){return new Request(e.upstreamUrl,{method:"POST",headers:e.headers,body:JSON.stringify(mt.parse({jsonrpc:pt,id:1,method:"initialize",params:{protocolVersion:Wt,capabilities:{},clientInfo:{name:"zuplo-mcp-gateway-readiness",version:"0.0.0"}}}))})}n(la,"buildInitializePreflight");async function Br(e){co(e.url);let t=new AbortController,r=setTimeout(()=>t.abort(),ul);try{let o=new Request(e,{redirect:"manual",signal:t.signal});return ca?await ca(o):await st.fetch(o)}finally{clearTimeout(r)}}n(Br,"runPreflight");function jr(e){e.body?.cancel().catch(()=>{})}n(jr,"releasePreflightBody");async function pl(e){let t=e.response.headers.get(sa);if(!t)return;let r=new Headers(e.headers);r.set(sa,t),r.delete("content-type");try{let o=await Br(new Request(e.upstreamUrl,{method:"DELETE",headers:r}));jr(o)}catch{}}n(pl,"terminatePreflightSession");async function fa(e){let{response:t}=e;return jr(t),t.status>=200&&t.status<300?(await pl(e),{kind:"ready",upstreamStatus:t.status,capabilities:ma()}):t.status===401||t.status===403?{kind:"upstream_auth_rejected",status:t.status,message:"Upstream MCP server rejected the configured credential."}:{kind:"upstream_unavailable",status:t.status,message:"Upstream MCP server did not accept the readiness preflight."}}n(fa,"classifyResponse");function pa(e){let t={status:e.state==="reconsent_required"?"reconsent_required":"not_connected",connected:!1};return e.nextAction==="admin_setup_required"?{kind:"admin_setup_required",payload:e,connectionStatus:t}:{kind:"connect_required",payload:e,connectionStatus:t}}n(pa,"connectRequiredResult");async function ml(e){try{return fa({response:await Br(e.request),upstreamUrl:e.upstreamUrl,headers:e.headers})}catch(t){return{kind:"upstream_unavailable",message:t instanceof Error?t.message:"Upstream MCP server readiness preflight failed."}}}n(ml,"classifyPreflight");async function fl(e){let t=e.route.connection;if(t===void 0)return{kind:"ready",upstreamStatus:204,capabilities:ma()};let r=Pt(t.upstreamServerId,e.route.operationId),o=Te(r,e.subjectId),i=e.returnTo===void 0?o:{...o,returnTo:e.returnTo},a=new Request(e.requestUrl,{...e.requestHeaders===void 0?{}:{headers:e.requestHeaders}}),s=await ke({request:a,routeAuth:i,preloadedConnection:e.preloadedConnection});if(s.kind==="connect_required")return pa(s.payload);let c=await ua(s.credential);if(c===void 0)return{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens."};let l=la({upstreamUrl:t.mcpUrl,headers:c}),m;try{m=await Br(l)}catch(C){return{kind:"upstream_unavailable",message:C instanceof Error?C.message:"Upstream MCP server readiness preflight failed."}}if(m.status!==401)return fa({response:m,upstreamUrl:t.mcpUrl,headers:c});jr(m);let f=await ke({request:a,routeAuth:i,forceRefresh:!0,preloadedConnection:e.preloadedConnection});if(f.kind==="connect_required")return pa(f.payload);let A=await ua(f.credential);return A===void 0?{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens after refresh."}:ml({request:la({upstreamUrl:t.mcpUrl,headers:A}),upstreamUrl:t.mcpUrl,headers:A})}n(fl,"checkUpstreamRouteReadinessImpl");function ha(e){return(ll??fl)(e)}n(ha,"checkUpstreamRouteReadiness");function hl(e){try{return new URL(e).host}catch{return}}n(hl,"safeUrlHost");function gl(e){if(e.mode==="user-oauth"||e.mode==="shared-oauth")return e.oauth.scopes}n(gl,"readOAuthScopes");function ga(e){return e!==void 0&&e.length>0}n(ga,"hasItems");function yl(e){let t=e.serverInfo?.icons;if(ga(t))return t;let r=xt(e.mcpUrl);return r===void 0?void 0:[r]}n(yl,"readServerIcons");async function _l(e){if(!(e.returnTo===void 0||!e.isUserOwned))return yr({requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},owner:e.userOwner,initiatedBySubjectId:e.transaction.principal.subjectId,upstreamServerId:e.registeredConnection.upstreamServerId,authProfileId:e.registeredConnection.authProfileId,operationId:e.route.operationId,returnTo:e.returnTo})}n(_l,"readConnectUrl");function _e(e,t){return t===void 0?{}:{[e]:t}}n(_e,"optionalRequirementField");function wl(e){return e.readiness!==void 0?e.readiness:e.isUserOwned?no(e.connection):{connected:!0,status:"active"}}n(wl,"readSetupConnectionStatus");function Rl(e){let t=gl(e);return ga(t)?t:void 0}n(Rl,"readScopesRequested");function bl(e){return e.isUserOwned&&"updatedAt"in e.connectionStatus&&e.connectionStatus.updatedAt!==void 0?e.connectionStatus.updatedAt:void 0}n(bl,"readUpdatedAt");function Sl(){return{tools:[],prompts:[],resources:[]}}n(Sl,"readRouteCapabilities");async function vl(e){let{authConfig:t,authMode:r,description:o,displayName:i,mcpUrl:a,upstreamServerId:s,authProfileId:c}=e.registeredConnection,l=At(r),m=l==="user",f=wl({connection:e.connection,isUserOwned:m,readiness:e.readiness}),A=e.readiness?.connectUrl??await _l({...e,connected:f.connected,isUserOwned:m});return{upstreamServerId:s,authProfileId:c,authMode:r,ownerMode:l,upstreamDisplayName:i,status:f.status,connected:f.connected,capabilities:Sl(),..._e("description",o),..._e("transportHost",hl(a)),..._e("scopesRequested",Rl(t)),..._e("serverIcons",yl(e.registeredConnection)),..._e("connectUrl",A),..._e("updatedAt",bl({connectionStatus:f,isUserOwned:m})),..._e("expiresAt",e.readiness?.expiresAt??e.connection?.expiresAt)}}n(vl,"buildSetupRequirement");function ya(e){let t=N().byOperationId.get(e);if(!t)throw _("unknown_mcp_route",`Unknown MCP route: ${e}`);return t}n(ya,"requireRoute");async function Lr(e){let t=ya(e.transaction.operationId),r=yt(e.transaction.principal.subjectId),o=[],i=new Map,a=t.connection;if(a===void 0)return[];At(a.authMode)==="user"&&(i.set(a,o.length),o.push({owner:r,upstreamServerId:a.upstreamServerId,authProfileId:a.authProfileId}));let s=await b().batchGetUpstreamConnections(o),c=[],l=At(a.authMode)==="user",m=i.get(a),f=await ha({requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},route:t,subjectId:e.transaction.principal.subjectId,preloadedConnection:l&&m!==void 0?s[m]:void 0,...e.returnTo===void 0?{}:{returnTo:e.returnTo}}),A=(()=>{if("connectionStatus"in f&&f.connectionStatus)return f.connectionStatus})(),C=(f.kind==="connect_required"||f.kind==="admin_setup_required")&&f.payload.authUrl!==void 0?f.payload.authUrl:void 0;return c.push(await vl({connection:l&&m!==void 0?s[m]:void 0,registeredConnection:a,route:t,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},returnTo:e.returnTo,transaction:e.transaction,userOwner:r,readiness:A===void 0?void 0:{...A,...C===void 0?{}:{connectUrl:C}}})),c}n(Lr,"requirementsForSetup");function Cl(e){return e.route.connection?.displayName??e.route.operationId}n(Cl,"readRouteDisplayName");async function Nr(e){let t=ya(e.transaction.operationId),r=Cl({route:t}),o=await b().readClient({clientId:e.transaction.clientId}),i=o.kind==="found"?o.client:void 0,a={gatewayOrigin:U(e.requestUrl,e.requestHeaders),routeDisplayName:r,clientDisplayName:i?.clientName??String(e.transaction.clientId),principalLabel:e.transaction.principal.subjectId},s=t.connection?.description;return s!==void 0&&(a.routeDescription=s),a}n(Nr,"consentContext");function Gr(e){return e.some(t=>t.ownerMode==="user"&&t.status!=="active")}n(Gr,"hasUnresolvedUserUpstream");var Il=["mcp_user"],xl="dev-browser-user",Al=["resource is required for /oauth/authorize.","MCP clients should start at the MCP server URL and follow its WWW-Authenticate resource_metadata link.","If your client reached this endpoint directly, use /oauth/authorize/{routePath} where {routePath} is the published MCP route path without a leading slash and each segment is URL-encoded as needed, for example /oauth/authorize/mcp/linear, or add resource={protected resource URI from protected-resource metadata}."].join(" "),Ul=d.object({response_type:d.literal("code"),client_id:d.string().min(1),redirect_uri:d.string().min(1),resource:d.url(),code_challenge:d.string().min(43),code_challenge_method:Nn,state:d.string().min(1).optional(),scope:d.literal(P).default(P)}),kl=d.enum(["continue","approve","cancel"]).default("continue"),Tl=d.object({state:d.string().min(1),decision:kl}),ae=class extends Error{static{n(this,"DownstreamAuthorizeRedirectError")}redirectUri;clientState;errorCode;errorDescription;constructor(t){super(t.errorDescription?`${t.errorCode}: ${t.errorDescription}`:t.errorCode,t.cause===void 0?void 0:{cause:t.cause}),this.name="DownstreamAuthorizeRedirectError",this.redirectUri=t.redirectUri,this.clientState=t.clientState,this.errorCode=t.errorCode,this.errorDescription=t.errorDescription}};function _a(e){return typeof e=="string"&&e.length>0?e:void 0}n(_a,"readQueryString");function Pl(e){let t=Array.from(N().byOperationId.values());if(t.length!==1)return;let r=t[0];if(r!==void 0)return Vt(r.operationId,e.url,e.headers)}n(Pl,"inferSingleRouteResource");function El(e,t){let r=_a(e.query.resource);if(t===void 0){if(r!==void 0)return r;let i=Pl(e);if(i!==void 0)return i;throw new p("invalid_target",Al)}let o=Vt(t,e.url,e.headers);if(r===void 0||r===o)return o;throw new p("invalid_target","resource must match the scoped OAuth authorization endpoint resource.")}n(El,"requireAuthorizeResource");async function Ol(e,t){let r={};t!==void 0&&(r.context=t);let o=await qt(e,r);if(o.principal)return{principal:o.principal};if(!e.user)return o.evictCookie===void 0?{}:{setCookie:o.evictCookie};let i=Ei(e);return{principal:i,setCookie:await Mt({principal:i,requestUrl:e.url,requestHeaders:e.headers})}}n(Ol,"resolveBrowserPrincipal");async function ql(e,t){let r={};t!==void 0&&(r.context=t);let o=await qt(e,r);if(!o.principal)throw _("authentication_required","Authorization setup requires a current browser session.");return o.principal}n(ql,"requireSetupPrincipal");function wa(e){return`/oauth/setup?state=${encodeURIComponent(e)}`}n(wa,"buildSetupReturnTo");async function Ra(e){let t=await Lr({transaction:e.transaction,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders},returnTo:wa(e.csrfToken)}),r=await Nr({transaction:e.transaction,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}}),o={kind:"setup_page",html:Hr({state:e.csrfToken,operationId:e.transaction.operationId,upstreams:t,...r})};return e.setCookie!==void 0&&(o.setCookie=e.setCookie),o}n(Ra,"renderSetup");function Ml(e){if(e===void 0)return;let t=e.metadata.token_endpoint_auth_method;return{clientId:e.clientId,clientName:e.metadata.client_name,tokenEndpointAuthMethod:t}}n(Ml,"toAuthorizationTransactionClient");async function $r(e,t={}){let r=Ul.parse({...e.query,resource:El(e,t.operationId),state:_a(e.query.state)}),o=rt(r.scope);Me(r.redirect_uri,"invalid_request","authorize");let i=new Date,a=V.parse(r.client_id),s=await zt(r.client_id,i);ea(s,r.redirect_uri);try{let c=De(e.url,r.resource,e.headers),l=Ml(s);t.context?.log.info({event:"oauth_authorize_request_parsed",clientId:a,operationId:c.operationId,scope:o,hasClientState:r.state!==void 0},"Downstream OAuth authorize: request parsed and client resolved"),t.context&&v(t.context,{eventType:w.MCP_OAUTH_AUTHORIZE_STARTED,outcome:"success",virtualServerName:c.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type}});let m={clientId:s?.clientId??a,...l===void 0?{}:{client:l},redirectUri:r.redirect_uri,resource:r.resource,operationId:c.operationId,scope:o,codeChallenge:r.code_challenge,codeChallengeMethod:r.code_challenge_method,...r.state===void 0?{}:{clientState:r.state}},{principal:f,setCookie:A}=await Ol(e,t.context);if(!f){let L=await Ki({transaction:m,requestUrl:e.url,requestHeaders:e.headers,now:i});t.context?.log.info({event:"oauth_authorize_awaiting_login",clientId:a,operationId:c.operationId},"Downstream OAuth authorize: redirecting to browser login (no session)");let Re={kind:"redirect",location:L.browserLoginUrl};return A!==void 0&&(Re.setCookie=A),Re}let C=await Ji({transaction:m,principal:f,now:i});return t.context?.log.info({event:"oauth_authorize_awaiting_setup",clientId:a,operationId:c.operationId,subjectId:f.subjectId},"Downstream OAuth authorize: rendering consent/setup page"),t.context&&v(t.context,{eventType:w.MCP_OAUTH_AUTHORIZE_AWAITING_SETUP,outcome:"success",virtualServerName:c.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type,subjectId:f.subjectId}}),Ra({transaction:C.transaction,csrfToken:C.csrfToken,requestUrl:e.url,requestHeaders:e.headers,setCookie:A})}catch(c){throw Dl({redirectUri:r.redirect_uri,clientState:r.state,cause:c})}}n($r,"authorizeDownstreamClient");function Dl(e){if(e.cause instanceof ae)return e.cause;let t=zl(e.cause);return t?new ae({redirectUri:e.redirectUri,clientState:e.clientState,errorCode:t.errorCode,errorDescription:t.errorDescription,cause:e.cause}):e.cause}n(Dl,"toDownstreamAuthorizeRedirectError");function zl(e){if(e instanceof p)return{errorCode:e.errorCode,errorDescription:e.message};if(e instanceof d.ZodError){let t=e.issues[0];return{errorCode:t?.path.includes("resource")?"invalid_target":"invalid_request",errorDescription:t?.message}}}n(zl,"mapToOAuthRedirectError");async function ba(e,t={}){let r=typeof e.query.error=="string"?e.query.error:void 0;if(r){let m=typeof e.query.error_description=="string"?e.query.error_description.slice(0,256):void 0,f=typeof e.query.error_uri=="string"?e.query.error_uri.slice(0,256):void 0;throw t.context?.log.warn({event:"browser_login_callback_idp_error",code:"provider_access_denied",idpError:r,...m===void 0?{}:{idpErrorDescription:m},...f===void 0?{}:{idpErrorUri:f}},"Identity provider redirected browser-login callback with an error"),_("provider_access_denied",m??"The delegated browser login was not completed.")}let o=typeof e.query.state=="string"?e.query.state:void 0;if(!o)throw t.context?.log.warn({event:"browser_login_callback_state_missing",code:"oauth_state_invalid"},"Browser login callback was invoked without a state parameter"),_("oauth_state_invalid","Browser login callback is missing state.");let i=await Tr(o),a={request:e,stateId:i.stateId};t.context!==void 0&&(a.context=t.context);let s=await Oi(a),c=await Wi({browserLoginStateToken:o,principal:s}),l=await Ra({transaction:c.transaction,csrfToken:c.csrfToken,requestUrl:e.url,requestHeaders:e.headers});return l.setCookie=await Mt({principal:s,requestUrl:e.url,requestHeaders:e.headers}),l}n(ba,"completeBrowserLoginCallback");async function Sa(e){let t=B(),r=new URL(e.url);if(!ue(r))throw _("forbidden","Local browser login is only available on loopback HTTP origins.");let o=typeof e.query.state=="string"?e.query.state:void 0;if(!o)throw _("oauth_state_invalid","Local browser login is missing state.");let i=new URL(typeof e.query.redirect_uri=="string"?e.query.redirect_uri:"/oauth/callback",U(e.url)),a=new URL(U(e.url)).origin;if(i.origin!==a||i.pathname!=="/oauth/callback")throw _("oauth_callback_mismatch","Local browser login redirect_uri must target this gateway's /oauth/callback route.");i.searchParams.set("state",o);let s={subjectId:gt.parse(xl),roles:Il};return{kind:"redirect",location:i,setCookie:await Mt({principal:s,requestUrl:e.url,requestHeaders:e.headers})}}n(Sa,"completeLocalDevBrowserLogin");function Hl(e){let t=e.method==="POST"?e.body:e.query;return Tl.parse(t)}n(Hl,"readSetupContinueRequest");async function va(e){let{state:t,decision:r}=Hl({method:e.request.method,query:e.request.query,body:e.body}),o=new Date,i=await Or({csrfToken:t,now:o}),a=await ql(e.request,e.context);if(r==="cancel")return{kind:"redirect",location:await Xi({csrfToken:t,currentBrowserPrincipal:a,now:o})};let s=await Vi({csrfToken:t,currentBrowserPrincipal:a,now:o}),c=await Lr({transaction:s,requestUrl:e.request.url,requestHeaders:e.request.headers,returnTo:wa(t)});if(r==="approve"&&Gr(c)&&await Zi({csrfToken:t,currentBrowserPrincipal:a,now:o}),Gr(c)){let l=await Nr({transaction:s,requestUrl:e.request.url,requestHeaders:e.request.headers});return{kind:"setup_page",html:Hr({state:t,operationId:s.operationId,upstreams:c,...l})}}return{kind:"redirect",location:await Yi({csrfToken:t,currentBrowserPrincipal:a,now:o})}}n(va,"continueDownstreamAuthorizeSetup");H();import{createLocalJWKSet as Bl,decodeJwt as jl,errors as nt,jwtVerify as Ll}from"jose";var Nl=new Set(["authorization_code","refresh_token"]),Gl="urn:ietf:params:oauth:client-assertion-type:jwt-bearer",$l=1e4,Zl=32*1024,Fl=2,Ca=d.object({client_id:d.string().min(1).optional(),client_secret:d.string().min(1).optional(),client_assertion_type:d.string().min(1).optional(),client_assertion:d.string().min(1).optional()}),Kl=d.discriminatedUnion("grant_type",[Ca.extend({grant_type:d.literal("authorization_code"),code:d.string().min(1),redirect_uri:d.string().min(1),code_verifier:ht,resource:d.url().optional(),scope:d.literal(P).optional()}),Ca.extend({grant_type:d.literal("refresh_token"),refresh_token:d.string().min(1),resource:d.url().optional(),scope:d.literal(P).optional()})]);function Jl(e){if(typeof e!="object"||e===null)return;let t=e.grant_type;if(t!==void 0&&(typeof t!="string"||!Nl.has(t)))throw new p("unsupported_grant_type",`Grant type "${typeof t=="string"?t:""}" is not supported.`)}n(Jl,"assertSupportedGrantType");var Wl=d.object({token:d.string().min(1),client_id:d.string().min(1).optional(),token_type_hint:d.string().optional(),client_secret:d.string().min(1).optional(),client_assertion_type:d.string().min(1).optional(),client_assertion:d.string().min(1).optional()}),Vl=d.object({keys:d.array(d.record(d.string(),d.unknown())).min(1)}).passthrough();function Ia(){return B().gateway.accessTokenTtlSeconds}n(Ia,"readAccessTokenTtlSeconds");function Yl(){return B().gateway.refreshTokenTtlSeconds}n(Yl,"readRefreshTokenTtlSeconds");function Xl(e,t){let r=Ia(),o=Math.max(1,Math.floor((new Date(t).getTime()-e.getTime())/1e3)),i=Math.min(r,o);return{expiresAt:R(J(e,i)),expiresIn:i}}n(Xl,"calculateAccessTokenExpiresAt");function xa(e){if(!e?.startsWith("Basic "))return{};let t;try{t=atob(e.slice(6))}catch{throw new p("invalid_client","Malformed HTTP Basic client authentication.")}let r=t.indexOf(":");if(r<0)throw new p("invalid_client","Malformed HTTP Basic client authentication.");try{return{clientId:decodeURIComponent(t.slice(0,r)),clientSecret:decodeURIComponent(t.slice(r+1))}}catch{throw new p("invalid_client","Malformed HTTP Basic client authentication.")}}n(xa,"readBasicClientSecret");function Aa(e){if(e.basicClientId!==void 0&&e.bodyClientId!==void 0&&e.basicClientId!==e.bodyClientId)throw new p("invalid_request","Authenticated client_id must match request client_id.");let t=e.basicClientId??e.bodyClientId;if(t!==void 0)return t;if(e.clientAssertion!==void 0){try{let r=jl(e.clientAssertion);if(typeof r.iss=="string"&&typeof r.sub=="string"&&r.iss===r.sub)return r.iss}catch{throw new p("invalid_client","Malformed private_key_jwt client assertion.")}throw new p("invalid_client","private_key_jwt client assertion must identify the client with matching iss and sub claims.")}throw new p("invalid_client","Client authentication or client_id is required.")}n(Aa,"resolveAuthenticatedClientId");function Ql(e){if(e.basicClientSecret!==void 0&&e.bodyClientSecret!==void 0)throw new p("invalid_request","Use only one client authentication method per request.");return e.basicClientSecret!==void 0?{clientSecret:e.basicClientSecret,clientSecretSource:"basic"}:e.bodyClientSecret!==void 0?{clientSecret:e.bodyClientSecret,clientSecretSource:"post"}:{}}n(Ql,"resolveClientSecretInput");function ep(e){return e.clientAssertion!==void 0||e.clientAssertionType!==void 0}n(ep,"hasClientAssertion");function tp(e){if(e.requestUrl===void 0)throw new p("invalid_request","Request URL is required for private_key_jwt client authentication.");let t=new URL(e.pathname,U(e.requestUrl,e.requestHeaders));return t.search="",t.hash="",t.toString()}n(tp,"buildEndpointAudience");function rp(e){return e instanceof nt.JWTExpired?"expired":e instanceof nt.JWTClaimValidationFailed?"claim":e instanceof nt.JWSSignatureVerificationFailed?"signature":e instanceof nt.JWKSNoMatchingKey?"jwks_no_match":e instanceof nt.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(rp,"readJwtFailureKind");async function np(e){let{response:t,json:r}=await fo(e.jwksUri,{headers:{accept:"application/json"}},{context:e.context,maxRedirects:Fl,maxResponseBytes:Zl,timeoutMs:$l});if(!t.ok)throw new p("invalid_client","Client JWKS could not be fetched.");return Vl.parse(r)}n(np,"fetchClientJwks");async function op(e){if(e.clientAssertionType!==Gl||e.clientAssertion===void 0)throw new p("invalid_request","private_key_jwt client authentication requires a JWT bearer client_assertion and client_assertion_type.");let t=V.parse(e.clientId),r=await zt(t,e.now);if(r.metadata.token_endpoint_auth_method!=="private_key_jwt")throw new p("invalid_client","Client is not registered for private_key_jwt authentication.");let o=r.metadata.jwks_uri;if(o===void 0)throw new p("invalid_client","Client JWKS URI is required for private_key_jwt authentication.");let i=tp({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,pathname:e.endpointPathname});try{let a=await np({jwksUri:o,context:e.context});await Ll(e.clientAssertion,Bl(a),{issuer:t,subject:t,audience:i,currentDate:e.now})}catch(a){throw e.context?.log.warn({event:"oauth_private_key_jwt_client_auth_failed",clientId:t,failureKind:rp(a)},"OAuth private_key_jwt client authentication failed"),new p("invalid_client","Client authentication failed.")}return Ht(t)?{method:"none",clientId:t}:{method:"private_key_jwt",clientId:t}}n(op,"verifyPrivateKeyJwtClientAssertion");async function ip(e){let t=V.parse(e.clientId);if(Ht(t))throw new p("invalid_client","Client is registered for private_key_jwt authentication.");return e.clientSecret===void 0?{method:"none",clientId:t}:{method:e.clientSecretSource==="post"?"client_secret_post":"client_secret_basic",clientId:t,clientSecretHashInput:await I(e.clientSecret)}}n(ip,"buildRuntimeHttpClientAuth");async function Ua(e){if(ep({clientAssertion:e.clientAssertion,clientAssertionType:e.clientAssertionType})){if(e.basicClientSecret!==void 0||e.bodyClientSecret!==void 0)throw new p("invalid_request","Use only one client authentication method per request.");return op(e)}let t=Ql({basicClientSecret:e.basicClientSecret,bodyClientSecret:e.bodyClientSecret});return ip({clientId:e.clientId,...t})}n(Ua,"resolveRuntimeHttpClientAuth");async function ka(e){Jl(e.body);let t=Kl.parse(e.body),r=xa(e.authorizationHeader),o=Aa({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date,a=await Ua({clientId:o,basicClientSecret:r.clientSecret,bodyClientSecret:t.client_secret,clientAssertion:t.client_assertion,clientAssertionType:t.client_assertion_type,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,endpointPathname:"/oauth/token",now:i,context:e.context});return ap({parsed:t,clientId:o,clientAuth:a,now:i,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,context:e.context})}n(ka,"exchangeDownstreamToken");async function ap(e){if(e.parsed.grant_type==="authorization_code"){Me(e.parsed.redirect_uri,"invalid_request","token"),rt(e.parsed.scope),e.parsed.resource!==void 0&&De(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let s=Y(),c=Y(),l=R(J(e.now,Yl())),m=Xl(e.now,l),f=await b().exchangeAuthorizationCode({clientAuth:e.clientAuth,codeHash:await I(e.parsed.code),redirectUri:e.parsed.redirect_uri,...e.parsed.resource===void 0?{}:{resource:e.parsed.resource},codeChallenge:await so(e.parsed.code_verifier),currentRefreshTokenHash:await I(s),accessTokenHash:await I(c),grantExpiresAt:l,accessTokenExpiresAt:m.expiresAt,now:R(e.now)});if(f.kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");if(f.kind==="resource_mismatch")throw new p("invalid_target","Token request resource must match the authorization code resource.");if(f.kind!=="exchanged")throw new p("invalid_grant","Authorization code is invalid, expired, already used, or failed binding validation.");return e.context&&v(e.context,{eventType:w.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"authorization_code"}}),{access_token:c,token_type:"Bearer",expires_in:m.expiresIn,refresh_token:s,scope:f.grant.scope,resource:f.grant.resource}}rt(e.parsed.scope),e.parsed.resource!==void 0&&De(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let t=Y(),r=Y(),o=R(J(e.now,Ia())),i=await b().refreshToken({clientAuth:e.clientAuth,currentRefreshTokenHash:await I(e.parsed.refresh_token),nextRefreshTokenHash:await I(t),accessTokenHash:await I(r),...e.parsed.resource===void 0?{}:{resource:e.parsed.resource},accessTokenExpiresAt:o,now:R(e.now)});if(i.kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");if(i.kind==="resource_mismatch")throw new p("invalid_target","Token request resource must match the refresh token grant resource.");if(i.kind!=="rotated")throw new p("invalid_grant","Refresh token is invalid, expired, or revoked.");De(e.requestUrl??i.grant.resource,i.grant.resource,e.requestHeaders);let a=i.accessToken.expiresAt;return e.context&&(v(e.context,{eventType:w.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"refresh_token"}}),v(e.context,{eventType:w.MCP_OAUTH_TOKEN_REFRESH_ROTATED,outcome:"success",attributes:{clientId:e.clientId}})),{access_token:r,token_type:"Bearer",expires_in:Math.max(1,Math.floor((new Date(a).getTime()-e.now.getTime())/1e3)),refresh_token:t,scope:i.grant.scope,resource:i.grant.resource}}n(ap,"exchangeDownstreamTokenWithRuntimeHttp");async function Ta(e){let t=Wl.parse(e.body),r=xa(e.authorizationHeader),o=Aa({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date;if((await b().revokeOAuthToken({clientAuth:await Ua({clientId:o,basicClientSecret:r.clientSecret,bodyClientSecret:t.client_secret,clientAssertion:t.client_assertion,clientAssertionType:t.client_assertion_type,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,endpointPathname:"/oauth/revoke",now:i,context:e.context}),tokenHash:await I(t.token),now:R(i)})).kind==="invalid_client")throw new p("invalid_client","Client authentication failed.");e.context?.log.info({event:"oauth_token_revoked",clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}},"OAuth token revocation request processed"),e.context&&v(e.context,{eventType:w.MCP_OAUTH_TOKEN_REVOKED,outcome:"success",attributes:{clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}}})}n(Ta,"revokeDownstreamToken");var sp=64*1024,cp=16*1024,dp="text/html; charset=utf-8";function up(e){let t={};for(let[r,o]of e.entries())t[r]=o;return t}n(up,"formDataToObject");async function lp(e){return Ui(e,{maxBytes:sp,label:"Request body"})}n(lp,"readJsonBody");async function Fr(e){return up(await ki(e,{maxBytes:cp,label:"Request body"}))}n(Fr,"readFormBody");async function Ea(e,t,r){let o=le(r),i=r instanceof d.ZodError?se(r):void 0,a={code:o??(r instanceof d.ZodError?"invalid_request":"internal_server_error")};return i!==void 0&&(a.detail=i),jn(e,t,a)}n(Ea,"handleProblem");function Oa(e){return e?.requestId}n(Oa,"readBrowserRequestId");function qa(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[Se];return typeof t=="string"?t:void 0}n(qa,"readUpstreamHtmlError");function Pa(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(Pa,"readRuntimeErrorExtensionString");function pp(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(pp,"readRuntimeErrorExtensionNumber");function mp(e){try{return new URL(e.url).pathname}catch{return}}n(mp,"readBrowserRequestPath");function we(e){let t={code:e.code,requestId:e.requestId,routePath:mp(e.request),underlyingError:e.underlyingError};return e.error instanceof g&&(t.httpStatus=pp(e.error,ve),t.contentType=Pa(e.error,be),t.upstreamUrl=Pa(e.error,Ce)),t}n(we,"buildBrowserErrorDiagnostic");function ot(e){let t=new Headers(e.headers);t.set("cache-control","no-store"),t.set("pragma","no-cache");let r={error:e.error};return e.errorDescription!==void 0&&(r.error_description=e.errorDescription),Response.json(r,{status:e.status??400,headers:t})}n(ot,"oauthErrorResponse");function fp(e,t){return e.errorCode!=="invalid_client"?{}:t.includeInvalidClientChallenge===!1?{}:{"WWW-Authenticate":'Basic realm="OAuth"'}}n(fp,"readOAuthProtocolHeaders");function hp(e,t){let r=j("internal_server_error");return ot({error:e.errorCode,errorDescription:e.errorCode==="server_error"?r.publicDetail:e.message,status:e.status,headers:fp(e,t)})}n(hp,"oauthProtocolErrorResponse");function Zr(e){return e.issues[0]?.path.includes("resource")===!0?"invalid_target":"invalid_request"}n(Zr,"readZodOAuthErrorCode");function gp(e){let t={error:Zr(e)},r=se(e);return r!==void 0&&(t.errorDescription=r),ot(t)}n(gp,"oauthZodErrorResponse");function yp(e){let t=le(e);if(t===void 0)return;let r=j(t);if(r.oauthError===void 0)return;let o={error:r.oauthError,status:wp(r.oauthError)};return r.oauthError==="server_error"?o.errorDescription=r.publicDetail:e instanceof Error?o.errorDescription=e.message:o.errorDescription=r.publicDetail,ot(o)}n(yp,"oauthGatewayProblemResponse");function _p(){let t={error:"server_error",status:500,errorDescription:j("internal_server_error").publicDetail};return ot(t)}n(_p,"oauthFallbackErrorResponse");function wp(e){switch(e){case"invalid_client":return 401;case"server_error":return 500;default:return 400}}n(wp,"readOAuthStatus");function Kr(e,t={}){return e instanceof ae?za(e):e instanceof p?hp(e,t):e instanceof d.ZodError?gp(e):yp(e)??_p()}n(Kr,"oauthProblemResponse");function Jr(e,t,r){let o=qe(e.url),i=Oa(t);if(r instanceof ae)return za(r);if(r instanceof p){let c=j("internal_server_error");return F({host:o,kind:Rp(r.errorCode),title:"Authorization failed",detail:r.errorCode==="server_error"?c.publicDetail:r.message,developerDetail:r.errorCode==="server_error"?c.publicDetail:r.message,code:r.errorCode,diagnostic:we({request:e,requestId:i,code:r.errorCode,underlyingError:r.errorCode==="server_error"?c.publicDetail:r.message,error:r}),requestId:i,status:r.status})}if(r instanceof d.ZodError)return F({host:o,kind:"invalid_request",detail:se(r)??"The authorization request was invalid.",developerDetail:se(r)??"The authorization request was invalid.",code:Zr(r),diagnostic:we({request:e,requestId:i,code:Zr(r),underlyingError:se(r)??"The authorization request was invalid.",error:r}),requestId:i});let a=le(r);if(a!==void 0){let c=j(a);return F({host:o,kind:Da(a),detail:c.publicDetail,developerDetail:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,code:a,diagnostic:we({request:e,requestId:i,code:a,underlyingError:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:qa(r),status:c.status})}let s=j("internal_server_error");return F({host:o,kind:"internal_error",detail:s.publicDetail,developerDetail:s.publicDetail,code:"server_error",diagnostic:we({request:e,requestId:i,code:"server_error",underlyingError:s.publicDetail,error:r}),requestId:i,status:s.status})}n(Jr,"browserOAuthProblemResponse");function Ma(e,t,r){let o=qe(e.url),i=Oa(t),a=le(r);if(a!==void 0){let c=j(a);return F({host:o,kind:Da(a),detail:c.publicDetail,developerDetail:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,code:a,diagnostic:we({request:e,requestId:i,code:a,underlyingError:c.status>=500||!(r instanceof Error)?c.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:qa(r),status:c.status})}if(r instanceof d.ZodError)return F({host:o,kind:"invalid_request",detail:se(r)??"The authorization request was invalid.",developerDetail:se(r)??"The authorization request was invalid.",code:"invalid_request",diagnostic:we({request:e,requestId:i,code:"invalid_request",underlyingError:se(r)??"The authorization request was invalid.",error:r}),requestId:i});let s=j("internal_server_error");return F({host:o,kind:"internal_error",detail:s.publicDetail,developerDetail:s.publicDetail,code:"internal_server_error",diagnostic:we({request:e,requestId:i,code:"internal_server_error",underlyingError:s.publicDetail,error:r}),requestId:i,status:s.status})}n(Ma,"browserGatewayProblemResponse");function Rp(e){return e==="server_error"?"internal_error":"invalid_request"}n(Rp,"readOAuthBrowserErrorKind");function Da(e){if(j(e).status>=500)return"internal_error";switch(e){case"mcp_route_not_enabled":case"unknown_upstream_server":case"unknown_mcp_route":case"unknown_auth_profile":case"mcp_route_upstream_mismatch":return"configuration_error";case"provider_access_denied":return"access_denied";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"session_expired";case"upstream_oauth_discovery_unavailable":case"upstream_provider_access_denied":case"upstream_client_registration_required":return"admin_required";case"browser_login_verification_failed":case"upstream_token_exchange_failed":case"upstream_token_response_invalid":return"connection_failed";case"invalid_request":case"authentication_required":case"forbidden":case"not_found":case"too_many_requests":case"identity_context_missing":return"invalid_request";case"upstream_capability_invocation_failed":case"upstream_capability_unavailable":case"upstream_import_failed":return"connection_failed";case"internal_server_error":return"internal_error"}return"authorization_failed"}n(Da,"readGatewayBrowserErrorKind");function ee(e,t,r){let o={event:t},i=!1;if(r instanceof p)o.oauthError=r.errorCode,o.status=r.status,W(o,"error",r);else if(r instanceof ae)o.oauthError=r.errorCode,W(o,"error",r);else if(r instanceof d.ZodError){o.code="invalid_request",W(o,"error",r);let a=r.issues[0];a&&(o.zodPath=a.path.join("."))}else{let a=le(r);if(a!==void 0){let s=j(a);o.code=a,o.status=s.status,s.oauthError!==void 0&&(o.oauthError=s.oauthError),i=s.status>=500||s.oauthError==="server_error",W(o,"error",r)}else i=!0,W(o,"error",r)}if(i){let a=r instanceof Error?r:new Error("Non-Error thrown from OAuth handler",{cause:r});e.log.error(o,a.message)}else e.log.warn(o,"OAuth handler rejected the request")}n(ee,"logUnexpectedOAuthHandlerError");function za(e){let t;try{t=new URL(e.redirectUri)}catch{return ot({error:e.errorCode,...e.errorDescription===void 0?{}:{errorDescription:e.errorDescription}})}t.searchParams.set("error",e.errorCode),e.errorDescription!==void 0&&t.searchParams.set("error_description",e.errorDescription),e.clientState!==void 0&&t.searchParams.set("state",e.clientState);let r=new Headers({location:t.toString(),"cache-control":"no-store"});return new Response(null,{status:302,headers:r})}n(za,"downstreamAuthorizeRedirectErrorResponse");function se(e){let t=e.issues[0];if(!t)return;let r=t.path.join(".");return r?`${r}: ${t.message}`:t.message}n(se,"formatZodErrorDetail");function bp(e,t){let r={event:"browser_login_callback_failed",code:le(t)??"invalid_request"};W(r,"error",t),e.log.warn(r,"Browser login callback failed; client received a connection-failure page")}n(bp,"logBrowserLoginCallbackFailure");function Ha(e){e.location.hash||(e.location.hash="#");let t=new Headers({location:e.location.toString(),"cache-control":"no-store"});return e.setCookie&&t.append("set-cookie",e.setCookie),new Response(null,{status:302,headers:t})}n(Ha,"redirectResultResponse");function jt(e){if(e.kind==="setup_page"){let t=new Headers({"content-type":dp,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"});return e.setCookie&&t.append("set-cookie",e.setCookie),new Response(e.html,{status:200,headers:t})}return Ha(e)}n(jt,"authorizeResultResponse");async function Ba(e,t){try{return Response.json(Jn(e.url,e.headers))}catch(r){return ee(t,"oauth_authorization_server_metadata_failed",r),Ea(e,t,r)}}n(Ba,"authorizationServerMetadataHandler");async function ja(e,t){try{let r=Yt(e.params.routePath);return Response.json(Wn({operationId:r.operationId,requestUrl:e.url,requestHeaders:e.headers}))}catch(r){return ee(t,"oauth_authorization_server_metadata_failed",r),Ea(e,t,r)}}n(ja,"scopedAuthorizationServerMetadataHandler");async function La(e,t){try{let r=await ra(await lp(e)),o=r,i=typeof o.client_id=="string"?o.client_id:void 0,a=typeof o.client_name=="string"?o.client_name:void 0,s=Array.isArray(o.redirect_uris)?o.redirect_uris.length:void 0,c=typeof o.token_endpoint_auth_method=="string"?o.token_endpoint_auth_method:void 0;return t.log.info({event:"oauth_dcr_client_registered",clientId:i,clientName:a,redirectUriCount:s,tokenEndpointAuthMethod:c},"OAuth Dynamic Client Registration completed"),v(t,{eventType:w.MCP_OAUTH_CLIENT_REGISTERED,outcome:"success",clientName:a,attributes:{clientId:i,redirectUriCount:s,tokenEndpointAuthMethod:c}}),Response.json(r,{status:201,headers:{"cache-control":"no-store"}})}catch(r){return ee(t,"oauth_register_failed",r),Kr(r)}}n(La,"registerHandler");async function Na(e,t){try{return jt(await $r(e,{context:t}))}catch(r){return ee(t,"oauth_authorize_failed",r),Jr(e,t,r)}}n(Na,"authorizeHandler");async function Ga(e,t){try{let r=Yt(e.params.routePath);return jt(await $r(e,{operationId:r.operationId,context:t}))}catch(r){return ee(t,"oauth_authorize_scoped_failed",r),Jr(e,t,r)}}n(Ga,"scopedAuthorizeHandler");async function $a(e,t){try{let r=await ba(e,{context:t});return t.log.info({event:"browser_login_callback_completed",resultKind:r.kind},"Browser login callback completed; consent setup rendered"),jt(r)}catch(r){return bp(t,r),Ma(e,t,r)}}n($a,"callbackHandler");async function Za(e,t){try{return Ha(await Sa(e))}catch(r){return ee(t,"oauth_dev_login_failed",r),Jr(e,t,r)}}n(Za,"devLoginHandler");async function Fa(e,t){try{if(!["GET","POST"].includes(e.method))return new Response(null,{status:405,headers:{allow:"GET, POST"}});let r=await va({request:e,body:e.method==="POST"?await Fr(e):void 0,context:t});return jt(r)}catch(r){return ee(t,"oauth_setup_failed",r),Ma(e,t,r)}}n(Fa,"setupHandler");async function Ka(e,t){try{return Response.json(await ka({body:await Fr(e),authorizationHeader:e.headers.get("authorization"),requestUrl:e.url,requestHeaders:e.headers,context:t}),{headers:{"cache-control":"no-store",pragma:"no-cache"}})}catch(r){return ee(t,"oauth_token_failed",r),Kr(r)}}n(Ka,"tokenHandler");async function Ja(e,t){try{return await Ta({body:await Fr(e),authorizationHeader:e.headers.get("authorization"),requestUrl:e.url,requestHeaders:e.headers,context:t}),new Response(null,{status:200,headers:{"cache-control":"no-store"}})}catch(r){return ee(t,"oauth_revoke_failed",r),Kr(r)}}n(Ja,"revokeHandler");var Sp={connect:"Connect",callback_authorization_code:"Callback",callback_provider_error:"Callback",callback_invalid:"Callback",client_metadata:"Client metadata"},Wa=Symbol("upstream-request");function vp(e){let t=e[Wa];if(!t)throw new M("Upstream request context has not been set");return t}n(vp,"readUpstreamRequestContext");function Cp(e,t){return t.some(r=>r===e)}n(Cp,"requestContextMatchesKind");function Ip(e){return typeof e=="string"?[e]:e}n(Ip,"toExpectedKinds");function ze(e,t){Object.defineProperty(e,Wa,{configurable:!0,value:t})}n(ze,"setUpstreamRequestContext");function it(e,t){let r=vp(e),o=Ip(t);if(!Cp(r.kind,o)){let i=Sp[o[0]];throw new M(`${i} request context has not been set`)}return r}n(it,"requireUpstreamRequestContext");function Va(e){return S`<p data-gateway-error-code="${e.code}">${e.body}</p>`}n(Va,"renderBrowserResult");var xp="text/html; charset=utf-8",Ap="none";function Up(e){let t=fr(e.host);return Oe({title:e.title,iconHref:t,styles:Ee,headerIcon:Bt({iconHref:t,fallbackIconHref:It}),heading:e.title,subhead:"",body:Va({body:e.body,code:e.code??Ap}),footer:""})}n(Up,"browserResultHtml");function kp(e,t=200){return new Response(Pe(e),{status:t,headers:{"content-type":xp,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(kp,"browserResultResponse");function Ya(e){return kp(Up(e))}n(Ya,"browserConnectionSuccessResponse");function Lt(e,t,r={}){let o=Bn(t);return F({host:e,kind:Tp(t),detail:o.body,developerDetail:r.developerDetail,code:t,diagnostic:r.diagnostic,upstreamHtml:r.upstreamHtml})}n(Lt,"browserConnectionFailureResponse");function Tp(e){switch(e){case"provider_access_denied":return"access_denied";case"oauth_state_invalid":case"oauth_state_expired":case"oauth_state_reused":case"oauth_callback_mismatch":return"session_expired";case"browser_login_verification_failed":case"upstream_token_exchange_failed":case"upstream_token_response_invalid":return"connection_failed";case"upstream_oauth_discovery_unavailable":case"upstream_provider_access_denied":case"upstream_client_registration_required":return"admin_required"}}n(Tp,"readCallbackFailureBrowserErrorKind");var Pp=["callback_authorization_code","callback_provider_error","callback_invalid"];function Wr(e){try{return new URL(e.url).pathname}catch{return}}n(Wr,"readBrowserRequestPath");function Ep(e){return"cause"in e?e.cause:void 0}n(Ep,"readErrorCause");function Op(e){return e.stack?.split(`
|
|
48
|
+
`).slice(1,4).map(t=>t.trim()).join(" | ")}n(Op,"readFirstStackFrame");function Xa(e,t,r){r instanceof Error&&(e[`${t}Name`]=r.name,e[`${t}Message`]=r.message,e[`${t}StackFrame`]=Op(r))}n(Xa,"addErrorAttributes");function Vr(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[y];return Rn(t)?t:void 0}n(Vr,"readRuntimeGatewayCode");function Qa(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(Qa,"readRuntimeErrorExtensionString");function qp(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(qp,"readRuntimeErrorExtensionNumber");function Mp(e,t,r,o){switch(r.kind){case"callback_provider_error":return t.log.warn({event:"upstream_oauth_provider_error",code:"provider_access_denied",upstreamServerId:r.upstreamServerId,providerError:r.error,...r.errorDescription===void 0?{}:{providerErrorDescription:r.errorDescription.slice(0,256)}},"Upstream identity provider returned an error to the OAuth callback"),v(t,{eventType:w.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:r.upstreamServerId,reasonCode:"provider_access_denied",reasonClass:"auth",attributes:{error:r.error,errorDescription:r.errorDescription}}),Lt(o,"provider_access_denied",{developerDetail:r.errorDescription??r.error,diagnostic:{code:"provider_access_denied",requestId:t.requestId,routePath:Wr(e),upstreamServerId:r.upstreamServerId,providerError:r.error,providerErrorDescription:r.errorDescription,underlyingError:r.errorDescription??r.error}});case"callback_invalid":return t.log.warn({event:"upstream_oauth_callback_invalid",code:"oauth_state_invalid",upstreamServerId:r.upstreamServerId},"Upstream OAuth callback request missing required code/state parameters"),Lt(o,"oauth_state_invalid",{diagnostic:{code:"oauth_state_invalid",requestId:t.requestId,routePath:Wr(e),upstreamServerId:r.upstreamServerId}});case"callback_authorization_code":return r}}n(Mp,"requireAuthorizationCallbackRequest");function Dp(e,t){v(e,{eventType:w.MCP_AUTH_UPSTREAM_CALLBACK_RECEIVED,outcome:"success",upstreamServerName:t.upstreamServerId})}n(Dp,"emitCallbackReceivedAnalyticsEvent");function zp(e,t){v(e,{eventType:w.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_SUCCEEDED,outcome:"success",upstreamServerName:t.upstreamServerId,virtualServerName:t.operationId})}n(zp,"emitTokenExchangeSucceededAnalyticsEvent");function Hp(e,t){if(t.returnTo){let r=t.returnOrigin??e.url;return Response.redirect(new URL(t.returnTo,r).toString(),302)}return Ya({host:qe(e.url),title:"Connection complete",body:"The upstream authorization flow completed successfully. You can return to your MCP client."})}n(Hp,"buildSuccessfulCallbackResponse");function Bp(e){let t={detail:e instanceof Error?e.message:void 0};return Xa(t,"error",e),e instanceof Error&&Xa(t,"cause",Ep(e)),t}n(Bp,"buildTokenExchangeFailureAttributes");function jp(e){v(e.context,{eventType:w.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:e.callbackRequest.upstreamServerId,reasonCode:Vr(e.error)??"token_exchange_failed",reasonClass:"auth",errorType:e.error instanceof Error?e.error.name:"unknown",attributes:Bp(e.error)})}n(jp,"emitTokenExchangeFailedAnalyticsEvent");function Lp(e){let t=e.error,r=Vr(t),o=bn(r)?r:"upstream_token_exchange_failed",i={code:o,requestId:e.context.requestId,routePath:Wr(e.request),upstreamServerId:e.callbackRequest.upstreamServerId,underlyingError:t instanceof Error?t.message:void 0,...t instanceof g?{httpStatus:qp(t,ve),contentType:Qa(t,be),upstreamUrl:Qa(t,Ce)}:{}};return Lt(e.host,o,{developerDetail:t instanceof Error?t.message:void 0,diagnostic:i,upstreamHtml:Np(t)})}n(Lp,"tokenExchangeFailureResponse");function Np(e){if(!(e instanceof g))return;let t=e.extensionMembers?.[Se];return typeof t=="string"?t:void 0}n(Np,"readUpstreamHtmlError");async function Yr(e,t){let r=it(e,Pp),o=qe(e.url),i=Mp(e,t,r,o);if(i instanceof Response)return i;Dp(t,i);try{let a=await yi({request:e,callbackRequest:i});return zp(t,a),t.log.info({event:"upstream_oauth_token_exchange_succeeded",upstreamServerId:a.upstreamServerId,operationId:a.operationId,authProfileId:a.authProfileId,ownerMode:a.ownerMode},"Upstream OAuth token exchange completed; user connection established"),Hp(e,a)}catch(a){let s={event:"upstream_oauth_token_exchange_failed",code:Vr(a)??"upstream_token_exchange_failed",upstreamServerId:i.upstreamServerId};return W(s,"error",a),t.log.warn(s,"Upstream OAuth token exchange failed; user shown connection-failure page"),jp({context:t,callbackRequest:i,error:a}),Lp({request:e,context:t,host:o,callbackRequest:i,error:a})}}n(Yr,"callbackHandler");function Gp(e){return(e instanceof Error?e.message:void 0)??"The requested upstream client metadata document was not found."}n(Gp,"clientMetadataProblemDetail");async function es(e,t){let r=it(e,"connect"),o=await gi({request:e,connectRequest:r});if(v(t,{eventType:w.MCP_AUTH_UPSTREAM_CONNECT_STARTED,outcome:"success",upstreamServerName:r.upstreamServerId,virtualServerName:o.operationId,upstreamServerTitle:o.upstreamDisplayName}),t.log.info({event:"upstream_connect_started",upstreamServerId:r.upstreamServerId,authProfileId:o.authProfileId,operationId:o.operationId,ownerMode:r.ownerMode,redirect:r.redirect,hasReturnTo:r.returnTo!==void 0},"Upstream OAuth connect flow started"),r.redirect)return Response.redirect(o.authUrl,302);let i=await kt({requestUrl:e.url,requestHeaders:e.headers,owner:o.owner,initiatedBySubjectId:o.initiatedBySubjectId,upstreamServerId:r.upstreamServerId,authProfileId:o.authProfileId,upstreamDisplayName:o.upstreamDisplayName,operationId:o.operationId,subject:"MCP route",...r.returnTo===void 0?{}:{returnTo:r.returnTo}});return Response.json(i,{status:428})}n(es,"connectHandler");async function ts(e,t){let r=it(e,"client_metadata");try{let o=ei(e.url,e.headers),i=ti(o,r.upstreamServerId,r.authProfileId);return Response.json(i)}catch(o){if(!(o instanceof T))throw o;let i=o instanceof Error?o.message:String(o);return t.log.warn({event:"oauth_client_metadata_request_failed",upstreamServerId:r.upstreamServerId,authProfileId:r.authProfileId,errorMessage:i},"Failed to serve OAuth client metadata document for upstream connection"),de.notFound(e,t,{code:"not_found",detail:Gp(o)})}}n(ts,"oauthClientMetadataHandler");function ce(e){if(typeof e=="string"&&e.length!==0)return e}n(ce,"readOptionalQueryString");function $p(e,t){let r=e.params[t];if(typeof r!="string"||r.length===0)throw new M(`Validated path parameter ${t} is missing`);return r}n($p,"requirePathString");function Zp(e){let t=ce(e);return t?lt.parse(t):void 0}n(Zp,"readOptionalOperationId");function Fp(e,t){let r=ce(e);return r?In.parse(r):ft(t,"user-oauth")}n(Fp,"readOptionalAuthProfileId");function Kp(e){let t=Zp(e);if(!t)throw new g({message:"operationId query parameter is required.",extensionMembers:{[y]:"invalid_request"}});return t}n(Kp,"readRequiredOperationId");function Jp(e){let t=Xn(ce(e));return t===void 0?{}:{returnTo:t}}n(Jp,"readOptionalReturnTo");function Wp(e){let t=ce(e.query.error_description);return t===void 0?{}:{errorDescription:t}}n(Wp,"readOptionalProviderErrorDescription");function Vp(e){let t=G(e.authMode);if(t.connectSupport!=="none")return e;throw new g({message:t.connectUnsupportedDetail??"This upstream does not support browser connection flows.",extensionMembers:{[y]:"invalid_request"}})}n(Vp,"requireConnectableRouteAuth");function Yp(e,t,r,o){return{kind:"connect",...Te(e,t.subjectId),...o===void 0?{}:{returnTo:o},redirect:r}}n(Yp,"buildConnectContextForUser");function Xp(e,t,r){let o=_t(t),i=G(e.authMode);if(o.mode!==i.ownerMode)throw new g({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[y]:"oauth_callback_mismatch"}});return{kind:"connect",...e,...t.returnTo===void 0?{}:{returnTo:t.returnTo},owner:o,initiatedBySubjectId:t.initiatedBySubjectId,redirect:r}}n(Xp,"buildConnectContextForTicket");async function Qp(e,t){let r=Vp(Pt(t,Kp(e.query.operationId))),o=e.query.redirect==="true",i=ce(e.query.browserTicket);if(e.user){if(i)throw new g({message:"Use either an authenticated gateway request or a browser connect ticket, not both.",extensionMembers:{[y]:"invalid_request"}});let s=Ie(e.user,e.url);return Yp(r,s,o,Jp(e.query.returnTo).returnTo)}if(!i)throw new g({message:"Authentication is required to start the upstream connection flow.",extensionMembers:{[y]:"authentication_required"}});let a=await Vo(i);if(a.ownerMode!==r.ownerMode||a.upstreamServerId!==r.upstreamServerId||a.authProfileId!==r.authProfileId||a.operationId!==r.operationId)throw new g({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[y]:"oauth_callback_mismatch"}});return await Yo(a),Xp(r,a,o)}n(Qp,"resolveConnectContext");async function em(e,t,r){let o=Cn.parse($p(e,"connection"));switch(r){case"connect":ze(e,await Qp(e,o));return;case"callback":{let i=ce(e.query.error);if(i){ze(e,{kind:"callback_provider_error",upstreamServerId:o,error:i,...Wp(e)});return}let a=ce(e.query.code),s=ce(e.query.state);if(a&&s){ze(e,{kind:"callback_authorization_code",upstreamServerId:o,code:a,state:s});return}ze(e,{kind:"callback_invalid",upstreamServerId:o});return}case"client_metadata":ze(e,{kind:"client_metadata",upstreamServerId:o,authProfileId:Fp(e.query.authProfileId,o)});return}}n(em,"resolveUpstreamRequestInbound");async function tm(e,t,r){try{await em(e,t,r);return}catch(o){let i=o instanceof g?o.extensionMembers?.[y]:void 0,a=o instanceof Error?o.message:void 0;switch(i){case"invalid_request":case"oauth_callback_mismatch":return de.badRequest(e,t,{code:i,detail:a});case"authentication_required":return de.unauthorized(e,t,{code:i,detail:a});default:throw o}}}n(tm,"applyUpstreamRequestContext");function Nt(e,t){return n(async(o,i)=>{let a=await tm(o,i,e);return a||t(o,i)},"wrapped")}n(Nt,"withUpstreamRequestContext");var rm={"access-control-allow-origin":"*","access-control-allow-methods":"GET, OPTIONS","access-control-allow-headers":"content-type, authorization","access-control-max-age":"86400"};function nm(){return new Response(null,{status:204,headers:rm})}n(nm,"buildWellKnownPreflightResponse");function om(e){let t=new Headers(e.headers);return t.set("access-control-allow-origin","*"),new Response(e.body,{status:e.status,statusText:e.statusText,headers:t})}n(om,"withWellKnownCorsHeaders");function Xr(e){return async(t,r)=>t.method==="OPTIONS"?nm():om(await e(t,r))}n(Xr,"wrapWellKnownHandler");var os=[{routeName:"oauth_as_metadata",path:"/.well-known/oauth-authorization-server",methods:["GET","OPTIONS"],handler:Xr(Ba),corsPolicy:"anything-goes"},{routeName:"oauth_as_metadata_scoped",path:"/.well-known/oauth-authorization-server/:routePath*",methods:["GET","OPTIONS"],handler:Xr(ja),corsPolicy:"anything-goes"},{routeName:"oauth_protected_resource_metadata",path:"/.well-known/oauth-protected-resource/:routePath*",methods:["GET","OPTIONS"],handler:Xr(Vn),corsPolicy:"anything-goes"},{routeName:"oauth_register",path:"/oauth/register",methods:["POST"],handler:La},{routeName:"oauth_authorize",path:"/oauth/authorize",methods:["GET"],handler:Na},{routeName:"oauth_authorize_scoped",path:"/oauth/authorize/:routePath*",methods:["GET"],handler:Ga},{routeName:"oauth_callback",path:"/oauth/callback",methods:["GET"],handler:$a},{routeName:"oauth_dev_login",path:"/oauth/dev-login",methods:["GET"],handler:Za},{routeName:"oauth_setup",path:"/oauth/setup",methods:["GET","POST"],handler:Fa},{routeName:"oauth_token",path:"/oauth/token",methods:["POST"],handler:Ka},{routeName:"oauth_revoke",path:"/oauth/revoke",methods:["POST"],handler:Ja},{routeName:"upstream_client_metadata",path:"/.well-known/oauth-client/:connection",methods:["GET"],handler:Nt("client_metadata",ts)},{routeName:"upstream_connect",path:"/auth/connections/:connection/connect",methods:["GET"],handler:Nt("connect",es)},{routeName:"upstream_callback",path:"/auth/connections/:connection/callback",methods:["GET"],handler:Nt("callback",Yr)}],im=os.filter(e=>!e.routeName.startsWith("upstream_")),am=os.filter(e=>e.routeName.startsWith("upstream_"));function is(e){return e?.some(_n)??!1}n(is,"hasMcpOAuthRuntimeConfigPolicy");function as(e){return e?.some(t=>Pn(t.policyType))??!1}n(as,"hasMcpTokenExchangePolicy");function ss(e){return is(e)||as(e)}n(ss,"shouldRegisterMcpGatewayInternalRoutes");function sm(e){qn(En({routes:e.routes,policies:e.policies}))}n(sm,"initializeMcpGatewayConnectionRegistry");function cm(e){let t=wn(e.policies);if(!t){let r=[...yn].map(o=>`\`${o}\``).join(", ");throw new T(`MCP gateway: could not find an MCP authorization policy in policies.json. Add one of [${r}] and reference it on your MCP routes.`)}return t.config}n(cm,"initializeMcpGatewayOAuthRuntimeConfig");function rs(e,t,r){return async(o,i)=>{r&&hn(i,r());let a=o.method==="OPTIONS",s=Date.now();a||i.log.info({event:`${e}_received`,method:o.method},`MCP gateway: ${e} received`);let c=await t(o,i);return a||i.log.info({event:`${e}_responded`,status:c.status,durationMs:Date.now()-s},`MCP gateway: ${e} responded`),c}}n(rs,"wrapInternalHandler");function ns(e,t,r){e.addPluginRoute({path:t.path,methods:t.methods,handler:r,processors:[an],corsPolicy:t.corsPolicy??"none"})}n(ns,"addInternalRoute");function cs(e,t){sm(t);let r=is(t.policies),o=as(t.policies),i,a=n(()=>(i===void 0&&(i=cm(t)),i),"readOAuthConfig");if(r)for(let s of im)ns(e,s,rs(s.routeName,s.handler,a));if(o)for(let s of am)ns(e,s,rs(s.routeName,s.handler))}n(cs,"registerMcpGatewayInternalRoutes");function ds(e){On(e)}n(ds,"configureLazyMcpGatewayState");var Qr=class extends nn{static{n(this,"McpGatewayPlugin")}registerRoutes(t){let r=t.parsedRouteData;if(!r||!ss(r.policies))return;let o={routes:r.routes,policies:r.policies};ds(o),cs(t.router,o)}};var dm=new TextDecoder;function um(e){if(e)try{return JSON.parse(dm.decode(e))}catch{return}}n(um,"readBodyJson");function te(e){return e&&typeof e=="object"?e:void 0}n(te,"readRecord");function at(e,t){let r=te(e)?.[t];return typeof r=="string"?r:void 0}n(at,"readStringProperty");function ls(e,t){let r=te(e)?.[t];return typeof r=="number"?r:void 0}n(ls,"readNumberProperty");function us(e,t){return ls(e,"code")??(t.status>=400?t.status:void 0)}n(us,"readErrorCode");function ps(e){return Array.isArray(e)?e.map(ps).find(t=>t?.method):te(e)}n(ps,"readJsonRpcMessage");function ms(e){let t=ps(um(e)),r=typeof t?.method=="string"?t.method:"",o=t?.params;switch(r){case"tools/list":return{mcpMethod:r,capabilityType:"tool"};case"tools/call":return{mcpMethod:r,capabilityType:"tool",capabilityName:at(o,"name")};case"prompts/list":return{mcpMethod:r,capabilityType:"prompt"};case"prompts/get":return{mcpMethod:r,capabilityType:"prompt",capabilityName:at(o,"name")};case"resources/list":case"resources/templates/list":return{mcpMethod:r,capabilityType:"resource"};case"resources/read":{let i=at(o,"uri");return{mcpMethod:r,capabilityType:"resource",capabilityName:i,resourceUri:i}}default:return null}}n(ms,"buildBaseCapabilityInput");function fs(e){return e==="tools/list"||e==="prompts/list"||e==="resources/list"||e==="resources/templates/list"}n(fs,"isCapabilityListMethod");function lm(e,t,r){let a=te(r)?.[e==="resources/templates/list"?"resourceTemplates":t==="tool"?"tools":t==="prompt"?"prompts":"resources"];return Array.isArray(a)?a.length:void 0}n(lm,"readItemCount");async function pm(e){try{return await e.clone().json()}catch{return}}n(pm,"readResponseJson");function hs(e){let t=ms(e);return!t||fs(t.mcpMethod)?null:{eventType:w.MCP_CAPABILITY_INVOKED,outcome:"success",...t}}n(hs,"buildCapabilityInvokedAnalyticsInput");async function gs(e,t){let r=ms(e);if(!r)return null;let o=te(await pm(t)),i=te(o?.error),a=te(i?.data),s=o?.result,c=r.mcpMethod==="tools/call"&&te(s)?.isError===!0;if(te(a?.connectRequired))return{eventType:w.MCP_CAPABILITY_CONNECT_REQUIRED,outcome:"connect_required",...r,httpStatusCode:t.status,reasonCode:"connect_required",reasonClass:"auth",errorType:"connect_required",errorCode:ls(i,"code"),mcpErrorType:at(i,"message")};if(fs(r.mcpMethod)){let l=t.status>=400?void 0:lm(r.mcpMethod,r.capabilityType,s);return{eventType:w.MCP_CAPABILITY_LISTED,outcome:t.status>=400||i?"failure":"success",...r,httpStatusCode:t.status,...t.status>=400||i?{reasonCode:"upstream_capability_list_failed",reasonClass:"upstream",errorType:"capability_list_error",errorCode:us(i,t)}:{},...l===void 0?{}:{attributes:{itemCount:l}}}}return t.status>=400||i?{eventType:w.MCP_CAPABILITY_FAILED,outcome:"failure",...r,httpStatusCode:t.status,reasonCode:"upstream_capability_invocation_failed",reasonClass:"upstream",errorType:"capability_error",errorCode:us(i,t),mcpErrorType:at(i,"message")}:{eventType:w.MCP_CAPABILITY_COMPLETED,outcome:c?"application_error":"success",...r,httpStatusCode:t.status,toolResultIsError:c,applicationError:c}}n(gs,"buildCapabilityFinalAnalyticsInput");var mm={Allow:"POST"};async function fm(e){try{return await e.clone().arrayBuffer()}catch{return}}n(fm,"readRequestBody");function ys(e){try{let t=Mn(e.route.path);return{virtualServerName:t.operationId,upstreamServerName:t.connection?.upstreamServerId,upstreamServerTitle:t.connection?.displayName,authProfileId:t.connection?.authProfileId,upstreamAuthMode:t.connection?.authMode}}catch{return{}}}n(ys,"readRouteAnalyticsFields");function _s(e){return Yn(e.user,e.url,e.headers)?.subjectId}n(_s,"readRequestSubjectId");function hm(e){let t=hs(e.requestBody);t&&v(e.context,{...t,...ys(e.context),httpMethod:e.request.method,subjectId:_s(e.request),transport:"http"})}n(hm,"emitCapabilityInvokedAnalytics");async function gm(e){let t=await gs(e.requestBody,e.response);t&&v(e.context,{...t,...ys(e.context),httpMethod:e.request.method,subjectId:_s(e.request),transport:"http",latencyMs:Date.now()-e.startedAt})}n(gm,"emitCapabilityFinalAnalytics");async function ym(e,t){if(e.method==="GET")return de.methodNotAllowed(e,t,{detail:"MCP Gateway routes support stateless Streamable HTTP requests over POST. Server-sent event GET streams are not supported."},mm);let r=Date.now(),o=await fm(e);hm({context:t,request:e,requestBody:o});let i=await mn(e,t);return await gm({context:t,request:e,requestBody:o,response:i,startedAt:r}),i}n(ym,"McpProxyHandler");export{vs as McpAuth0OAuthInboundPolicy,Qt as McpCapabilityFilterInboundPolicy,Qr as McpGatewayPlugin,Ss as McpOAuthInboundPolicy,ym as McpProxyHandler,xr as McpTokenExchangeInboundPolicy};
|
|
49
49
|
//# sourceMappingURL=index.js.map
|